/* =========================================================
   baupotenzial.de – Landing (Navy CI)
   Datei: /assets/site.css
   Hinweis: Hero Hintergrundbild liegt bei /assets/hero-map.jpg
========================================================= */

/* ---- Reset ---- */
*,
*::before,
*::after { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, "Helvetica Neue", Arial, sans-serif;
  color: #0f172a;
  background: #f5f7fb;
}

/* ---- Tokens ---- */
:root{
  --navy:#0b1f3b;
  --navy2:#132f55;
  --accent:#2f80ed;
  --text:#0f172a;
  --muted: rgba(15,23,42,.72);
  --bg:#f5f7fb;
  --card:#ffffff;
  --radius: 22px;
  --shadow: 0 30px 70px rgba(2,6,23,.28);
  --shadow2: 0 14px 32px rgba(2,6,23,.12);
  --line: rgba(11,31,59,.14);
}

/* ---- Helpers ---- */
.container{
  width: min(1180px, calc(100% - 40px));
  margin: 0 auto;
}
.muted{ color: var(--muted); }
.badge{
  display:inline-flex;
  align-items:center;
  padding: 6px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.72);
  color: rgba(15,23,42,.75);
  font-weight: 800;
  font-size: 12px;
}
.badge--navy{ background: rgba(11,31,59,.08); }

/* ---- Buttons ---- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border:none;
  cursor:pointer;
  border-radius: 999px;
  background: var(--navy);
  color:#fff;
  font-weight: 950;
  text-decoration:none;
  padding: 14px 18px;
  transition: transform .08s ease, background .2s ease, box-shadow .2s ease;
  box-shadow: 0 10px 26px rgba(2,6,23,.18);
}
.btn:hover{ background: var(--navy2); }
.btn:active{ transform: translateY(1px); }
.btn--outline{
  background: transparent;
  color: var(--navy);
  border: 1px solid var(--line);
  box-shadow: none;
}
.btn--outline:hover{ background: rgba(11,31,59,.06); }
.btn--sm{ padding: 10px 12px; font-weight: 900; }
.btn--lg{ padding: 16px 22px; }

/* ---- Topbar ---- */
.topbar{
  position: sticky;
  top:0;
  z-index: 50;
  backdrop-filter: blur(10px);
  background: rgba(245,247,251,.78);
  border-bottom: 1px solid rgba(11,31,59,.10);
}
.topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding: 12px 0;
}
.brand{
  display:flex;
  gap:10px;
  align-items:center;
  text-decoration:none;
  color: var(--navy);
  font-weight: 950;
}
.brand__dot{
  width: 12px; height:12px;
  border-radius: 999px;
  background: var(--accent);
  box-shadow: 0 0 0 6px rgba(47,128,237,.14);
}
.brand__name{ letter-spacing:.2px; }
.topnav{
  display:flex;
  gap:18px;
  align-items:center;
}
.topnav a{
  color: rgba(11,31,59,.85);
  text-decoration:none;
  font-weight: 800;
  font-size: 13px;
}
.topnav a:hover{ color: var(--navy); }

.navtoggle{
  display:none;
  border:1px solid var(--line);
  background:#fff;
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 900;
  cursor:pointer;
}
.mobilemenu{
  border-top:1px solid rgba(11,31,59,.10);
  padding: 10px 0 14px;
}
.mobilemenu a{
  display:block;
  padding: 10px 0;
  text-decoration:none;
  color: rgba(11,31,59,.88);
  font-weight: 850;
}

/* ---- Hero ---- */
.heroC{
  position:relative;
  isolation:isolate;
  min-height: clamp(640px, 88vh, 940px);
  display:flex;
  align-items:center;
  overflow:hidden;
  background: #071327;
}
.heroC::before{
  content:"";
  position:absolute;
  inset:0;
  background-image: url("hero-map.jpg");
  background-size: cover;
  background-position: center;
  background-repeat:no-repeat;
  filter: saturate(.95) contrast(1.05);
  transform: scale(1.04);
  z-index:0;
}
.heroC::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:1;
  background:
    radial-gradient(900px 520px at 20% 20%, rgba(47,128,237,.18), transparent 60%),
    radial-gradient(900px 520px at 80% 25%, rgba(255,255,255,.10), transparent 62%),
    linear-gradient(180deg, rgba(11,31,59,.78), rgba(11,31,59,.68));
}
.hero{ position:relative; z-index:2; width:100%; }
.hero--center{
  display:flex;
  align-items:center;
  justify-content:center;
}
.hero-center-card{
  width: min(860px, 100%);
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(255,255,255,.55);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: clamp(20px, 3.6vw, 34px);
  backdrop-filter: blur(12px);
  text-align:center;
}
.kicker{
  display:inline-flex;
  gap:10px;
  align-items:center;
  color: var(--navy);
  font-weight: 950;
  letter-spacing:.2px;
}
.kicker__dot{
  width:10px; height:10px;
  border-radius:999px;
  background: var(--accent);
  box-shadow: 0 0 0 7px rgba(47,128,237,.14);
}
.hero-center-card h1{
  margin: 12px 0 10px;
  font-size: clamp(30px, 4.2vw, 50px);
  line-height: 1.03;
  color: var(--navy);
  font-weight: 950;
}
.hero-center-card p{
  margin: 0 auto 18px;
  max-width: 76ch;
  color: rgba(15,23,42,.76);
  font-size: 16px;
}
.hero-address-form{
  display:flex;
  gap:12px;
  align-items:stretch;
  flex-wrap:wrap;
  justify-content:center;
  margin-top: 10px;
}
.hero-inputwrap{
  position:relative;
  flex: 1 1 520px;
  min-width: 280px;
}
.hero-address-form input{
  width:100%;
  border: 1px solid rgba(11,31,59,.16);
  border-radius: 999px;
  padding: 18px 18px;
  font-size: 18px;
  outline:none;
  background:#fff;
  box-shadow: 0 10px 26px rgba(2,6,23,.08);
}
.hero-address-form input:focus{
  border-color: rgba(47,128,237,.55);
  box-shadow: 0 0 0 6px rgba(47,128,237,.14), 0 14px 32px rgba(2,6,23,.10);
}
.hero-address-form button{
  border:none;
  cursor:pointer;
  border-radius: 999px;
  padding: 18px 22px;
  font-weight: 950;
  background: var(--navy);
  color:#fff;
  box-shadow: 0 12px 30px rgba(2,6,23,.22);
  white-space: nowrap;
}
.hero-address-form button:hover{ background: var(--navy2); }

.trustrow{
  margin-top: 14px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(11,31,59,.06);
  border: 1px solid rgba(11,31,59,.12);
  color: rgba(15,23,42,.78);
  font-weight: 850;
  font-size: 13px;
}
.check{
  width:20px; height:20px;
  border-radius:999px;
  background: rgba(47,128,237,.16);
  display:inline-grid;
  place-items:center;
  color: var(--accent);
  font-weight: 950;
}
.micro{
  margin-top: 10px;
  font-size: 12.5px;
  color: rgba(15,23,42,.62);
}

/* ---- Alert ---- */
.alert{
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(220,38,38,.25);
  background: rgba(220,38,38,.08);
  color: rgba(127,29,29,1);
  font-weight: 850;
}

/* ---- Autocomplete Dropdown ---- */
.ac{
  position:absolute;
  left:0; right:0;
  top: calc(100% + 10px);
  z-index: 10;
  border-radius: 16px;
  background: #fff;
  border: 1px solid rgba(11,31,59,.14);
  box-shadow: 0 18px 48px rgba(2,6,23,.18);
  overflow:hidden;
}
.ac__item{
  padding: 12px 14px;
  cursor:pointer;
  border-bottom: 1px solid rgba(11,31,59,.06);
  font-weight: 800;
  color: rgba(11,31,59,.92);
}
.ac__item small{
  display:block;
  font-weight: 700;
  color: rgba(15,23,42,.60);
  margin-top: 2px;
}
.ac__item:hover{ background: rgba(47,128,237,.10); }

/* ---- Sections ---- */
.section{
  padding: 72px 0;
}
.section--tight{ padding: 40px 0; }
.section--alt{ background: #eef3fb; }
.sectionhead{
  margin-bottom: 22px;
}
.sectionhead h2{
  margin: 0 0 8px;
  color: var(--navy);
  font-size: 30px;
  letter-spacing: -.2px;
}
.sectionhead p{
  margin: 0;
  color: rgba(15,23,42,.70);
  max-width: 84ch;
}

/* ---- Grids ---- */
.grid2{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.grid3{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
@media (max-width: 960px){
  .grid3{ grid-template-columns: 1fr; }
  .grid2{ grid-template-columns: 1fr; }
}

/* ---- Cards ---- */
.card, .statcard, .chartcard, .infobox{
  background: var(--card);
  border-radius: var(--radius);
  border: 1px solid rgba(11,31,59,.10);
  box-shadow: var(--shadow2);
}
.card{
  padding: 18px 18px;
}
.card h3{ margin: 0 0 8px; color: var(--navy); }
.card p{ color: rgba(15,23,42,.72); margin: 0 0 10px; }

.list{
  margin: 10px 0 0;
  padding-left: 18px;
  color: rgba(15,23,42,.74);
}
.list li{ margin: 6px 0; }

.statcard{
  padding: 18px 18px;
  display:grid;
  gap: 6px;
}
.statcard__kpi{
  font-size: 30px;
  font-weight: 950;
  color: var(--accent);
}
.statcard__title{
  font-weight: 950;
  color: var(--navy);
}
.statcard__text{
  color: rgba(15,23,42,.70);
}

/* ---- How ---- */
.how{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 14px;
}
.how__step{
  background: var(--card);
  border-radius: var(--radius);
  border: 1px solid rgba(11,31,59,.10);
  box-shadow: var(--shadow2);
  padding: 18px 18px;
}
.how__num{
  width: 38px; height:38px;
  border-radius: 14px;
  background: rgba(47,128,237,.14);
  color: var(--accent);
  display:grid;
  place-items:center;
  font-weight: 950;
  margin-bottom: 10px;
}
.how h3{ margin: 0 0 6px; color: var(--navy); }
.how p{ margin: 0; color: rgba(15,23,42,.72); }
@media (max-width: 960px){ .how{ grid-template-columns: 1fr; } }

.callout{
  margin-top: 18px;
  padding: 16px 16px;
  border-radius: var(--radius);
  background: rgba(47,128,237,.10);
  border: 1px solid rgba(47,128,237,.22);
}
.callout__title{ font-weight: 950; color: var(--navy); margin-bottom: 4px; }
.callout__text{ color: rgba(15,23,42,.74); }

/* ---- Info boxes ---- */
.infogrid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 18px;
  margin-top: 18px;
}
.infobox{ padding: 18px 18px; }
.infobox h4{ margin:0 0 8px; color: var(--navy); }
.infobox p{ margin:0; color: rgba(15,23,42,.72); }
@media (max-width: 960px){ .infogrid{ grid-template-columns: 1fr; } }

/* ---- Charts ---- */
.charts{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 18px;
  margin-top: 18px;
}
.chartcard{ padding: 18px 18px; }
.chartcard__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.chartcard h4{ margin:0; color: var(--navy); }
.chart{ width:100%; height:auto; border-radius: 14px; background: rgba(255,255,255,.6); }
.chartnote{ margin: 10px 0 0; color: rgba(15,23,42,.66); }
@media (max-width: 960px){ .charts{ grid-template-columns: 1fr; } }

/* ---- Split ---- */
.split{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 18px;
  margin-top: 18px;
}
@media (max-width: 960px){ .split{ grid-template-columns: 1fr; } }

/* ---- CTA ---- */
.cta{ padding: 56px 0; }
.ctabox{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 18px;
  background: linear-gradient(135deg, rgba(47,128,237,.15), rgba(11,31,59,.06));
  border: 1px solid rgba(11,31,59,.10);
  border-radius: var(--radius);
  padding: 22px 22px;
  box-shadow: var(--shadow2);
}
.ctabox h2{ margin:0 0 6px; color: var(--navy); }
.ctabox p{ margin:0; color: rgba(15,23,42,.70); }
@media (max-width: 820px){
  .ctabox{ flex-direction:column; align-items:flex-start; }
}

/* ---- FAQ ---- */
.faq details{
  background:#fff;
  border:1px solid rgba(11,31,59,.10);
  border-radius: 16px;
  padding: 14px 14px;
  box-shadow: var(--shadow2);
  margin-bottom: 12px;
}
.faq summary{
  cursor:pointer;
  font-weight: 950;
  color: var(--navy);
  list-style:none;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq__body{
  margin-top: 10px;
  color: rgba(15,23,42,.72);
  line-height: 1.5;
}

/* ---- Footer ---- */
.footer{
  padding: 36px 0;
  border-top: 1px solid rgba(11,31,59,.10);
  background: #f2f6fc;
}
.footer__inner{
  display:grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 18px;
  align-items:start;
}
.footer__brand{
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.footer__name{ font-weight: 950; color: var(--navy); }
.footer__sub{ color: rgba(15,23,42,.66); font-weight: 800; font-size: 13px; margin-top: 4px; }
.footer__links{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.footer__links a{
  color: rgba(11,31,59,.86);
  text-decoration:none;
  font-weight: 850;
}
.footer__links a:hover{ color: var(--navy); }
.footer__fine{
  grid-column: 1 / -1;
  display:flex;
  justify-content:space-between;
  gap: 12px;
  color: rgba(15,23,42,.66);
  font-weight: 800;
  font-size: 12.5px;
  margin-top: 8px;
}
@media (max-width: 820px){
  .footer__inner{ grid-template-columns: 1fr; }
  .footer__links{ justify-content:flex-start; }
  .footer__fine{ flex-direction:column; }
}

/* ---- Responsive nav ---- */
@media (max-width: 920px){
  .topnav{ display:none; }
  .navtoggle{ display:inline-flex; }
}

/* ---- Mobile hero tweaks ---- */
@media (max-width: 640px){
  .heroC{ min-height: 100vh; }
  .hero-center-card{ padding: 18px 16px; }
  .hero-address-form{ gap: 10px; }
  .hero-address-form input{ font-size: 16px; padding: 16px; border-radius: 16px; }
  .hero-address-form button{ width: 100%; padding: 16px; }
  .hero-inputwrap{ flex: 1 1 100%; }
}



/* =========================================================
   MAP UI (User Journey: nur markieren + speichern)
   - große Buttons links
   - Leaflet mini draw controls ausblenden
========================================================= */
html.map-page, body.map-page { height: 100%; }
body.map-page { margin: 0; }
#map { height: 100vh; width: 100%; }

/* alte Leaflet Controls (Zoom / Draw) ausblenden */
.leaflet-control-zoom { display: none !important; }
.leaflet-draw { display: none !important; }

.map-ui{
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1200;
}
.map-ui__top{
  pointer-events: auto;
  position: absolute;
  top: 16px;
  left: 16px;
  right: 16px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 14px;
  align-items: start;
}
.map-ui__back{
  display: inline-flex;
  align-items:center;
  justify-content:center;
  height: 42px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(11,31,59,.14);
  color: var(--navy);
  font-weight: 950;
  text-decoration: none;
  box-shadow: 0 14px 32px rgba(2,6,23,.14);
}
.map-ui__meta{ padding-top: 2px; }
.map-ui__title{ font-weight: 950; color: var(--navy); }
.map-ui__addr{ color: rgba(15,23,42,.70); font-weight: 800; font-size: 13px; max-width: 70vw; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

.map-ui__chips{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  flex-wrap:wrap;
}
.chip{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(11,31,59,.14);
  border-radius: 16px;
  padding: 10px 12px;
  box-shadow: 0 14px 32px rgba(2,6,23,.12);
  min-width: 130px;
}
.chip__k{ font-size: 11px; font-weight: 900; color: rgba(15,23,42,.55); letter-spacing:.2px; }
.chip__v{ font-size: 13px; font-weight: 950; color: var(--navy); }

.draw-overlay{
  pointer-events:auto;
  position:absolute;
  left: 16px;
  top: 92px;
  width: 230px;
  display:flex;
  flex-direction:column;
  gap: 10px;
}
.toolbtn{
  display:flex;
  align-items:center;
  gap: 10px;
  border-radius: 14px;
  border: 1px solid rgba(11,31,59,.14);
  background: rgba(255,255,255,.92);
  color: var(--navy);
  font-weight: 950;
  padding: 12px 12px;
  cursor:pointer;
  box-shadow: 0 16px 36px rgba(2,6,23,.16);
}
.toolbtn:hover{ background:#fff; }
.toolbtn__icon{ width: 22px; display:inline-flex; justify-content:center; }
.toolbtn--primary{
  background: rgba(11,31,59,.92);
  border-color: rgba(11,31,59,.22);
  color:#fff;
}
.toolbtn--primary:hover{ background: rgba(19,47,85,.92); }
.toolbtn--danger{ border-color: rgba(220,38,38,.25); }
.toolbtn--danger:hover{ background: rgba(220,38,38,.06); }

.toolsep{ height: 8px; }

.savebtn{
  border:none;
  border-radius: 14px;
  padding: 12px 12px;
  font-weight: 950;
  background: var(--navy);
  color:#fff;
  cursor:pointer;
  box-shadow: 0 16px 36px rgba(2,6,23,.18);
  opacity: .55;
}
.savebtn.is-enabled{ opacity: 1; }
.savebtn:disabled{ cursor:not-allowed; }

.hint{
  margin-top: 6px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(47,128,237,.25);
  border-radius: 16px;
  padding: 12px 12px;
  box-shadow: 0 16px 36px rgba(2,6,23,.14);
}
.hint__title{ font-weight: 950; color: var(--navy); margin-bottom: 4px; }
.hint__text{ color: rgba(15,23,42,.70); font-weight: 800; font-size: 12.5px; line-height: 1.35; }
.hint.is-hidden{ display:none; }

@media (max-width: 900px){
  .map-ui__top{ grid-template-columns: auto 1fr; }
  .map-ui__chips{ grid-column: 1 / -1; justify-content:flex-start; }
  .draw-overlay{ top: 140px; width: 210px; }
}
@media (max-width: 640px){
  .draw-overlay{
    left: 12px;
    right: 12px;
    width: auto;
    top: auto;
    bottom: 12px;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 10px;
  }
  .toolbtn, .savebtn{ flex: 1 1 calc(50% - 10px); }
  .hint{ display:none; } /* mobile: hint weglassen */
}



/* =========================================================
   LEAD MODAL (Map – Feinschliff)
   - spacing, focus, mobile bottom-sheet
   Hinweis: bewusst breit selektiert (id/class Varianten),
   aber auf body.map-page gescoped, damit Landing nicht beeinflusst wird.
========================================================= */

/* Overlay / Container (falls als echtes Modal umgesetzt) */
body.map-page .leadmodal,
body.map-page .lead-modal,
body.map-page #leadModal,
body.map-page #lead-modal{
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: none;            /* per JS: block/flex */
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(2,6,23,.55);
  backdrop-filter: blur(6px);
}

/* common “open” toggles */
body.map-page .leadmodal.is-open,
body.map-page .lead-modal.is-open,
body.map-page #leadModal.is-open,
body.map-page #lead-modal.is-open,
body.map-page .leadmodal[aria-hidden="false"],
body.map-page .lead-modal[aria-hidden="false"],
body.map-page #leadModal[aria-hidden="false"],
body.map-page #lead-modal[aria-hidden="false"]{
  display: flex;
}

/* Dialog / Content */
body.map-page .leadmodal__dialog,
body.map-page .lead-modal__dialog,
body.map-page .leadmodal-content,
body.map-page .lead-modal-content,
body.map-page .modal-content,
body.map-page #leadModal .content,
body.map-page #lead-modal .content{
  width: min(760px, 100%);
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(11,31,59,.14);
  border-radius: 18px;
  box-shadow: 0 30px 80px rgba(2,6,23,.30);
  overflow: hidden;
}

/* Header */
body.map-page .leadmodal__header,
body.map-page .lead-modal__header,
body.map-page .modal-header,
body.map-page #leadModal header,
body.map-page #lead-modal header{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding: 14px 16px;
  background: rgba(11,31,59,.06);
  border-bottom: 1px solid rgba(11,31,59,.10);
}

body.map-page .leadmodal__title,
body.map-page .lead-modal__title,
body.map-page .modal-title,
body.map-page #leadModal h2,
body.map-page #lead-modal h2{
  margin: 0;
  font-size: 16px;
  font-weight: 950;
  color: var(--navy);
  letter-spacing: .2px;
}

/* Close button */
body.map-page .leadmodal__close,
body.map-page .lead-modal__close,
body.map-page .modal-close,
body.map-page #leadModal .close,
body.map-page #lead-modal .close{
  appearance:none;
  border: 1px solid rgba(11,31,59,.14);
  background: rgba(255,255,255,.9);
  border-radius: 12px;
  width: 38px;
  height: 38px;
  cursor:pointer;
  display:grid;
  place-items:center;
  color: rgba(11,31,59,.85);
  font-weight: 950;
}
body.map-page .leadmodal__close:hover,
body.map-page .lead-modal__close:hover,
body.map-page .modal-close:hover,
body.map-page #leadModal .close:hover,
body.map-page #lead-modal .close:hover{
  background:#fff;
}

/* Body */
body.map-page .leadmodal__body,
body.map-page .lead-modal__body,
body.map-page .modal-body,
body.map-page #leadModal .body,
body.map-page #lead-modal .body{
  padding: 16px;
}

/* Form layout – robust für verschiedene Markups */
body.map-page .leadmodal form,
body.map-page .lead-modal form,
body.map-page #leadModal form,
body.map-page #lead-modal form{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin: 0;
}

body.map-page .leadmodal form .full,
body.map-page .lead-modal form .full{
  grid-column: 1 / -1;
}

/* Labels */
body.map-page .leadmodal label,
body.map-page .lead-modal label,
body.map-page #leadModal label,
body.map-page #lead-modal label{
  display:block;
  font-weight: 900;
  font-size: 12px;
  color: rgba(15,23,42,.70);
  margin: 0 0 6px;
}

/* Inputs */
body.map-page .leadmodal input,
body.map-page .leadmodal textarea,
body.map-page .lead-modal input,
body.map-page .lead-modal textarea,
body.map-page #leadModal input,
body.map-page #leadModal textarea,
body.map-page #lead-modal input,
body.map-page #lead-modal textarea{
  width: 100%;
  border: 1px solid rgba(11,31,59,.16);
  border-radius: 14px;
  padding: 12px 12px;
  font-size: 14px;
  background: #fff;
  outline: none;
  box-shadow: 0 10px 26px rgba(2,6,23,.06);
}

body.map-page .leadmodal textarea,
body.map-page .lead-modal textarea,
body.map-page #leadModal textarea,
body.map-page #lead-modal textarea{
  min-height: 92px;
  resize: vertical;
}

body.map-page .leadmodal input:focus,
body.map-page .leadmodal textarea:focus,
body.map-page .lead-modal input:focus,
body.map-page .lead-modal textarea:focus,
body.map-page #leadModal input:focus,
body.map-page #leadModal textarea:focus,
body.map-page #lead-modal input:focus,
body.map-page #lead-modal textarea:focus{
  border-color: rgba(47,128,237,.65);
  box-shadow: 0 0 0 6px rgba(47,128,237,.14), 0 14px 34px rgba(2,6,23,.10);
}

/* Actions */
body.map-page .leadmodal__actions,
body.map-page .lead-modal__actions,
body.map-page .modal-actions,
body.map-page #leadModal .actions,
body.map-page #lead-modal .actions{
  display:flex;
  gap: 10px;
  justify-content:flex-end;
  padding: 14px 16px 16px;
  border-top: 1px solid rgba(11,31,59,.10);
  background: rgba(255,255,255,.92);
}

/* Buttons inside modal (falls plain buttons verwendet werden) */
body.map-page .leadmodal button,
body.map-page .lead-modal button,
body.map-page #leadModal button,
body.map-page #lead-modal button{
  border:none;
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 950;
  cursor:pointer;
}

body.map-page .leadmodal button[type="submit"],
body.map-page .lead-modal button[type="submit"],
body.map-page #leadModal button[type="submit"],
body.map-page #lead-modal button[type="submit"]{
  background: var(--navy);
  color:#fff;
  box-shadow: 0 14px 34px rgba(2,6,23,.18);
}
body.map-page .leadmodal button[type="submit"]:hover,
body.map-page .lead-modal button[type="submit"]:hover,
body.map-page #leadModal button[type="submit"]:hover,
body.map-page #lead-modal button[type="submit"]:hover{
  background: var(--navy2);
}

body.map-page .leadmodal button[type="button"],
body.map-page .lead-modal button[type="button"],
body.map-page #leadModal button[type="button"],
body.map-page #lead-modal button[type="button"]{
  background: rgba(11,31,59,.06);
  color: var(--navy);
  border: 1px solid rgba(11,31,59,.14);
  box-shadow: none;
}
body.map-page .leadmodal button[type="button"]:hover,
body.map-page .lead-modal button[type="button"]:hover,
body.map-page #leadModal button[type="button"]:hover,
body.map-page #lead-modal button[type="button"]:hover{
  background: rgba(11,31,59,.10);
}

/* Fallback: falls das Lead-Form als “Bottom Bar” gerendert wird (wie auf deinem Screenshot) */
body.map-page #leadForm,
body.map-page .leadform,
body.map-page .lead-form-inline{
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1900;
  background: rgba(255,255,255,.98);
  border-top: 1px solid rgba(11,31,59,.14);
  box-shadow: 0 -18px 46px rgba(2,6,23,.22);
  padding: 10px 12px;
}

body.map-page #leadForm .leadform__row,
body.map-page .leadform .leadform__row,
body.map-page .lead-form-inline .leadform__row{
  display: grid;
  grid-template-columns: 1.2fr 1.2fr 1fr 1.6fr auto;
  gap: 10px;
  align-items: end;
}

body.map-page #leadForm input,
body.map-page #leadForm textarea{
  width: 100%;
}

body.map-page #leadForm textarea{
  min-height: 44px;
}

body.map-page #leadForm .leadform__actions{
  display:flex;
  gap: 8px;
}

/* Mobile: Bottom sheet */
@media (max-width: 720px){
  body.map-page .leadmodal,
  body.map-page .lead-modal,
  body.map-page #leadModal,
  body.map-page #lead-modal{
    align-items: flex-end;
    padding: 10px;
  }

  body.map-page .leadmodal__dialog,
  body.map-page .lead-modal__dialog,
  body.map-page .leadmodal-content,
  body.map-page .lead-modal-content,
  body.map-page .modal-content,
  body.map-page #leadModal .content,
  body.map-page #lead-modal .content{
    border-radius: 18px 18px 14px 14px;
  }

  body.map-page .leadmodal form,
  body.map-page .lead-modal form,
  body.map-page #leadModal form,
  body.map-page #lead-modal form{
    grid-template-columns: 1fr;
  }

  body.map-page #leadForm .leadform__row,
  body.map-page .leadform .leadform__row,
  body.map-page .lead-form-inline .leadform__row{
    grid-template-columns: 1fr;
  }

  body.map-page #leadForm{
    padding-bottom: calc(10px + env(safe-area-inset-bottom));
  }
}

/* Accessibility: reduce motion */
@media (prefers-reduced-motion: reduce){
  body.map-page .leadmodal,
  body.map-page .lead-modal,
  body.map-page #leadModal,
  body.map-page #lead-modal{
    backdrop-filter: none;
  }
}



/* =========================================================
   LEAD MODAL – FINAL CLEAN (passend zu map.php Markup)
   Markup: #leadModal .leadmodal__panel + form.leadform > label.leadform__row
========================================================= */

body.map-page #leadModal{
  position: fixed;
  inset: 0;
  z-index: 2500;
  display: none; /* JS toggelt */
  align-items: center;
  justify-content: center;
  padding: 22px;
  background: rgba(2,6,23,.55);
  backdrop-filter: blur(6px);
}
body.map-page #leadModal.is-open,
body.map-page #leadModal[aria-hidden="false"]{
  display: flex;
}

body.map-page #leadModal .leadmodal__backdrop{
  position: absolute;
  inset: 0;
}

body.map-page #leadModal .leadmodal__panel{
  position: relative;
  width: min(720px, 100%);
  background: rgba(255,255,255,.98);
  border: 1px solid rgba(11,31,59,.14);
  border-radius: 18px;
  box-shadow: 0 30px 90px rgba(2,6,23,.32);
  overflow: hidden;
}

/* Header */
body.map-page #leadModal .leadmodal__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 14px 16px;
  background: rgba(11,31,59,.06);
  border-bottom: 1px solid rgba(11,31,59,.10);
}
body.map-page #leadModal .leadmodal__title{
  font-size: 16px;
  font-weight: 950;
  color: var(--navy);
}
body.map-page #leadModal .leadmodal__x{
  appearance:none;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(11,31,59,.14);
  background: rgba(255,255,255,.92);
  cursor:pointer;
  display:grid;
  place-items:center;
  color: rgba(11,31,59,.9);
  font-weight: 950;
}
body.map-page #leadModal .leadmodal__x:hover{ background:#fff; }

/* Form grid: 2 Spalten, Notiz + Actions über volle Breite */
body.map-page #leadModal form.leadform{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 16px;
  padding: 16px;
  margin: 0;
}

/* Jede Field-Row: Label oben, Input darunter */
body.map-page #leadModal label.leadform__row{
  display: grid;
  gap: 6px;
  align-items: start;
  margin: 0;
}
body.map-page #leadModal .leadform__label{
  font-size: 12px;
  font-weight: 900;
  color: rgba(15,23,42,.72);
}

/* Inputs volle Breite (dein Hauptproblem vorher) */
body.map-page #leadModal .leadform__input,
body.map-page #leadModal .leadform__textarea{
  width: 100% !important;
  min-width: 0;
  border: 1px solid rgba(11,31,59,.16);
  border-radius: 14px;
  padding: 12px 12px;
  font-size: 14px;
  background: #fff;
  outline: none;
  box-shadow: 0 10px 26px rgba(2,6,23,.06);
}
body.map-page #leadModal .leadform__textarea{
  min-height: 110px;
  resize: vertical;
}
body.map-page #leadModal .leadform__input:focus,
body.map-page #leadModal .leadform__textarea:focus{
  border-color: rgba(47,128,237,.70);
  box-shadow: 0 0 0 6px rgba(47,128,237,.14), 0 14px 34px rgba(2,6,23,.10);
}

/* Notiz soll über beide Spalten gehen */
body.map-page #leadModal textarea.leadform__textarea{
  grid-column: 1 / -1;
}

/* Actions über volle Breite, rechtsbündig */
body.map-page #leadModal .leadform__actions{
  grid-column: 1 / -1;
  display:flex;
  justify-content:flex-end;
  gap: 10px;
  padding-top: 14px;
  margin-top: 2px;
  border-top: 1px solid rgba(11,31,59,.10);
}

/* Buttons */
body.map-page #leadModal .leadform__btn{
  border:none;
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 950;
  cursor:pointer;
}
body.map-page #leadModal .leadform__btn--primary{
  background: var(--navy);
  color:#fff;
  box-shadow: 0 14px 34px rgba(2,6,23,.18);
}
body.map-page #leadModal .leadform__btn--primary:hover{ background: var(--navy2); }
body.map-page #leadModal .leadform__btn--ghost{
  background: rgba(11,31,59,.06);
  color: var(--navy);
  border: 1px solid rgba(11,31,59,.14);
  box-shadow:none;
}
body.map-page #leadModal .leadform__btn--ghost:hover{ background: rgba(11,31,59,.10); }

/* Mobile: 1 Spalte + Bottom Sheet */
@media (max-width: 720px){
  body.map-page #leadModal{
    align-items: flex-end;
    padding: 10px;
  }
  body.map-page #leadModal .leadmodal__panel{
    width: 100%;
    border-radius: 18px 18px 14px 14px;
  }
  body.map-page #leadModal form.leadform{
    grid-template-columns: 1fr;
    padding: 14px;
  }
  body.map-page #leadModal textarea.leadform__textarea{
    grid-column: auto;
  }
}

/* Prevent the old “bottom bar” fallback from hijacking the form id */
body.map-page #leadForm{
  position: static !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  top: auto !important;
  box-shadow: none !important;
}


/* =========================================================
   FINAL DESKTOP FIX – Lead Modal Inputs erzwingen
   Ursache: globales Formular-CSS überschreibt width
========================================================= */

body.map-page .leadmodal label,
body.map-page .leadmodal__panel label,
body.map-page #leadForm label{
  display: block !important;
  width: 100% !important;
}

body.map-page .leadmodal input,
body.map-page .leadmodal textarea,
body.map-page #leadForm input,
body.map-page #leadForm textarea{
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  flex: none !important;
  align-self: stretch !important;
}

/* verhindert "Pillen"-Inputs */
body.map-page .leadmodal input[type="text"],
body.map-page .leadmodal input[type="email"],
body.map-page .leadmodal input[type="tel"]{
  box-sizing: border-box !important;
}

/* Desktop-Grid sauber erzwingen */
@media (min-width: 721px){
  body.map-page .leadform__row{
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
  }

  body.map-page textarea{
    grid-column: 1 / -1 !important;
  }
}


/* ===== Lead Success Message ===== */
body.map-page .leadform__success{
  margin-bottom: 14px;
  padding: 12px 14px;
  border-radius: 12px;
  background: rgba(22,163,74,.12);
  border: 1px solid rgba(22,163,74,.35);
  color: #166534;
  font-weight: 900;
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}

