:root{--navy:#071936;--gold:#c98b2e;--gold2:#d59a3b;--line:#e6e9ee;--muted:#637083;--soft:#f7f9fc;--shadow:0 20px 45px rgba(7,25,54,.10)}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;color:var(--navy);background:#fff;font-size:15px}.wide{width:min(1500px,calc(100% - 112px));margin-inline:auto}.site-header{height:86px;background:#fff;border-bottom:1px solid #eef1f5;display:flex;align-items:center;position:relative;z-index:10}.nav-wrap{height:100%;display:flex;align-items:center;gap:44px}.brand{text-decoration:none;color:var(--navy);display:flex;align-items:center;gap:12px;min-width:190px}.logo-icon{width:48px;height:48px;border:4px solid var(--gold);border-radius:9px;display:grid;place-items:center;color:var(--gold);font-size:32px;font-weight:800;line-height:1}.brand b{display:block;font-size:32px;letter-spacing:1px;line-height:.86}.brand em{display:block;font-style:normal;color:var(--gold);letter-spacing:8px;font-size:16px;font-weight:600;margin-left:2px}.main-nav{display:flex;align-items:center;justify-content:center;gap:42px;flex:1;font-weight:700;font-size:13px}.main-nav a,.nav-actions a{color:var(--navy);text-decoration:none;white-space:nowrap}.nav-actions{display:flex;align-items:center;gap:22px;font-weight:700;font-size:13px}.nav-actions button,.search-btn,.map-section aside button,.premium aside button{border:0;background:linear-gradient(180deg,#d49a3a,#b87316);color:white;font-weight:800;border-radius:5px;padding:17px 22px;box-shadow:0 8px 16px rgba(184,115,22,.20)}.hero{height:548px;background:linear-gradient(90deg,rgba(255,255,255,.97) 0%,rgba(255,255,255,.90) 34%,rgba(255,255,255,.18) 57%,rgba(255,255,255,0) 100%),url('../img/hero-house.jpg') right center/auto 100% no-repeat;border-bottom:1px solid #eef1f5}.hero-grid{height:100%;display:flex;align-items:flex-start;padding-top:75px}.hero-copy h1{font-family:'Playfair Display',serif;font-size:75px;line-height:.97;margin:0 0 27px;letter-spacing:-2.2px;color:#071936}.hero-copy p{font-size:21px;line-height:1.55;margin:0 0 50px;font-weight:600}.trust-row{display:flex;background:rgba(255,255,255,.82);border:1px solid #edf0f4;border-radius:10px;box-shadow:0 16px 40px rgba(7,25,54,.10);overflow:hidden}.trust-row div{width:205px;padding:17px 19px;display:grid;grid-template-columns:34px 1fr;column-gap:10px;align-items:center;border-right:1px solid #e8ebef}.trust-row div:last-child{border-right:0}.trust-row span{grid-row:span 2;color:var(--gold);font-size:28px}.trust-row b{font-size:13px}.trust-row small{font-size:12px;color:var(--navy);font-weight:500}.search-shell{position:relative;margin-top:-83px;background:#fff;border:1px solid #e5e9ee;border-radius:13px;box-shadow:var(--shadow);padding:0 30px 27px;z-index:2}.tabs{height:74px;display:flex;align-items:center;gap:72px;border-bottom:1px solid #e9edf2}.tabs button{height:74px;background:transparent;border:0;color:#334058;font-size:16px;font-weight:600;position:relative;padding:0 0}.tabs .active{color:var(--navy);font-weight:800}.tabs .active:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:3px;background:var(--gold)}.form-grid{display:grid;grid-template-columns:1.35fr 1fr 1fr 1fr 165px;gap:30px;align-items:end;padding-top:25px}.form-grid label{display:block;position:relative}.form-grid span{display:block;font-size:13px;font-weight:800;margin-bottom:11px}.form-grid input,.form-grid select{width:100%;height:55px;border:1px solid #dfe4eb;border-radius:6px;padding:0 19px;color:#7d8797;font-size:14px;background:#fff}.form-grid i{position:absolute;right:18px;bottom:15px;font-style:normal;color:#617084;font-size:22px}.search-btn{height:55px;border-radius:7px;font-size:15px}.chips{border-top:1px solid #eff2f5;margin-top:26px;padding-top:21px;display:flex;align-items:center;gap:15px;font-size:13px}.chips span{border:1px solid #e1e5eb;background:#fff;border-radius:24px;padding:8px 18px;font-weight:600}.block{margin-top:42px}.block h2,.section-head h2,.map-card h2,.map-section aside h2{font-size:27px;letter-spacing:-.6px;margin:0 0 23px}.cat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}.cat-grid article{height:108px;border:1px solid #e0e6ee;border-radius:8px;background:#fff;display:flex;align-items:center;gap:18px;padding:0 27px;box-shadow:0 8px 18px rgba(7,25,54,.035)}.cat-grid span{font-size:43px}.cat-grid b{line-height:1.2;font-size:14px}.section-head{display:flex;align-items:end;justify-content:space-between}.section-head a{font-weight:600;color:var(--navy);text-decoration:none}.property-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px}.property-card{border:1px solid #dfe5ec;border-radius:7px;background:#fff;overflow:hidden;box-shadow:0 8px 20px rgba(7,25,54,.06)}.pic{height:157px;position:relative;overflow:hidden}.pic img{width:100%;height:100%;object-fit:cover}.pic em{position:absolute;top:12px;left:10px;background:#08204a;color:white;border-radius:4px;padding:7px 10px;font-style:normal;font-size:11px;font-weight:800}.pic em:empty{display:none}.pic em.green{background:#45a540}.pic i{position:absolute;right:12px;top:10px;color:white;font-size:25px;font-style:normal}.pc-body{padding:15px 16px 17px}.pc-body h3{font-size:15px;line-height:1.25;margin:0 0 8px}.pc-body small{display:block;color:#5f6d80;font-size:11px;margin-bottom:15px}.pc-body p{font-size:12px;color:#526073;margin:0 0 17px;display:flex;gap:13px;white-space:nowrap}.pc-body strong{font-size:19px}.city-row{display:grid;grid-template-columns:repeat(10,1fr);gap:15px}.city-row article{border:1px solid #dde4ec;border-radius:7px;overflow:hidden;background:white;box-shadow:0 7px 16px rgba(7,25,54,.05)}.city-row img{width:100%;height:78px;object-fit:cover;display:block}.city-row b{display:block;padding:10px 10px 2px;font-size:13px}.city-row small{display:block;padding:0 10px 10px;color:#627084;font-size:11px}.map-section{margin-top:35px;display:grid;grid-template-columns:1fr 390px;border:1px solid #e0e6ee;border-radius:8px;overflow:hidden;box-shadow:0 8px 20px rgba(7,25,54,.04)}.map-card{padding:27px 28px 0;background:#fff}.map-card img{width:100%;height:316px;object-fit:cover;display:block}.map-section aside{background:#fff;padding:92px 50px 40px;border-left:1px solid #e5e9ef}.map-section aside label{display:block;margin:13px 0;font-size:14px;font-weight:600}.map-section aside input{accent-color:#104d9d}.map-section aside button{background:var(--navy);margin-top:21px;border-radius:5px;padding:16px 23px}.service-grid{margin-top:34px;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.service-grid article{border:1px solid #e0e6ee;border-radius:7px;padding:29px 26px;min-height:147px;display:grid;grid-template-columns:55px 1fr;background:white}.service-grid span{font-size:37px;grid-row:span 3}.service-grid b{font-size:16px}.service-grid p{margin:8px 0 12px;color:#506074;line-height:1.35;font-size:13px}.service-grid a{color:var(--navy);font-weight:700;font-size:13px}.premium{margin-top:36px;padding-bottom:60px}.section-head p{margin:-12px 0 0;color:#5f6d80}.premium-grid{display:grid;grid-template-columns:repeat(3,1fr) 360px;gap:19px}.premium-grid article,.premium-grid aside{border:1px solid #e0e6ee;border-radius:7px;background:white;overflow:hidden}.premium-grid article img{height:155px;width:100%;object-fit:cover}.premium-grid article{padding-bottom:18px}.premium-grid article h3{font-size:16px;line-height:1.25;margin:14px 18px 7px}.premium-grid article small,.premium-grid article p{margin-left:18px;color:#607084;font-size:12px}.premium-grid article strong{display:block;text-align:right;margin:0 18px;font-size:18px}.premium-grid aside{background:#fff8ee;display:flex;flex-direction:column;align-items:center;text-align:center;justify-content:center;padding:35px}.premium-grid aside span{font-size:42px;color:var(--gold);margin-bottom:18px}.premium-grid aside h3{font-size:21px;margin:0 0 13px}.premium-grid aside p{line-height:1.55;margin:0 0 28px}.premium-grid aside button{padding:15px 24px;border-radius:5px}
@media(max-width:1200px){.wide{width:calc(100% - 40px)}.main-nav{gap:18px}.property-grid{grid-template-columns:repeat(3,1fr)}.cat-grid{grid-template-columns:repeat(3,1fr)}.city-row{grid-template-columns:repeat(5,1fr)}.map-section{grid-template-columns:1fr}.map-section aside{border-left:0;padding:30px}.service-grid,.premium-grid{grid-template-columns:repeat(2,1fr)}.premium-grid aside{grid-column:span 2}}@media(max-width:720px){.site-header{height:auto;padding:16px 0}.nav-wrap,.main-nav,.nav-actions{flex-wrap:wrap;gap:14px}.hero{height:auto;padding-bottom:120px;background-position:center bottom}.hero-copy h1{font-size:48px}.form-grid{grid-template-columns:1fr}.tabs{gap:24px;overflow:auto}.property-grid,.cat-grid,.city-row,.service-grid,.premium-grid{grid-template-columns:1fr}.premium-grid aside{grid-column:auto}}

/* --------------------------------------------------
   Responsive Update – Desktop-Layout bleibt unverändert
   -------------------------------------------------- */
.mobile-toggle{display:none;width:44px;height:40px;border:1px solid #e2e7ee;background:#fff;border-radius:8px;align-items:center;justify-content:center;flex-direction:column;gap:5px;padding:0;cursor:pointer}.mobile-toggle span{display:block;width:20px;height:2px;background:var(--navy);border-radius:3px}.main-nav a,.nav-actions a,.nav-actions button,.tabs button,.cat-grid article,.property-card,.city-row article,.service-grid article,.premium-grid article,.premium-grid aside{transition:.18s ease}.property-grid,.cat-grid,.city-row,.service-grid,.premium-grid{min-width:0}.property-card,.premium-grid article{min-width:0}.pc-body h3,.premium-grid article h3{overflow-wrap:anywhere}

@media (min-width:1401px){
  /* Desktop bleibt exakt auf der breiten V4-Anmutung */
}

@media (max-width:1400px){
  .wide{width:calc(100% - 64px)}
  .nav-wrap{gap:26px}.main-nav{gap:24px}.nav-actions{gap:16px}.nav-actions button{padding:15px 18px}
  .hero-copy h1{font-size:68px}.hero-copy p{font-size:19px}.hero{height:520px}
  .tabs{gap:52px}.form-grid{gap:22px;grid-template-columns:1.3fr .95fr .95fr .95fr 150px}
  .property-grid{gap:16px}.pic{height:145px}.pc-body{padding:14px}.pc-body p{gap:8px;font-size:11px}.pc-body strong{font-size:17px}
  .city-row{gap:12px}.map-section{grid-template-columns:1fr 340px}.map-section aside{padding:82px 38px 36px}
  .premium-grid{grid-template-columns:repeat(3,1fr) 320px}
}

@media (max-width:1180px){
  .site-header{height:78px}.wide{width:calc(100% - 40px)}
  .brand{min-width:auto}.logo-icon{width:42px;height:42px;font-size:27px;border-width:3px}.brand b{font-size:27px}.brand em{font-size:13px;letter-spacing:6px}
  .mobile-toggle{display:flex;margin-left:auto}.main-nav,.nav-actions{display:none}.site-header.menu-open .main-nav,.site-header.menu-open .nav-actions{display:flex}
  .nav-wrap{position:relative}.site-header.menu-open{z-index:50}.site-header.menu-open .nav-wrap{align-items:center}
  .site-header.menu-open .main-nav{position:absolute;left:0;right:0;top:78px;background:#fff;border:1px solid #e4e9ef;border-radius:0 0 14px 14px;box-shadow:0 18px 38px rgba(7,25,54,.12);padding:18px 20px;flex-direction:column;align-items:flex-start;gap:15px}
  .site-header.menu-open .nav-actions{position:absolute;left:0;right:0;top:353px;background:#fff;border:1px solid #e4e9ef;border-top:0;border-radius:0 0 14px 14px;box-shadow:0 18px 38px rgba(7,25,54,.12);padding:0 20px 20px;align-items:flex-start;gap:14px;flex-direction:column}
  .hero{height:500px;background-position:62% center}.hero-grid{padding-top:58px}.hero-copy h1{font-size:58px}.hero-copy p{font-size:18px}.trust-row div{width:180px;padding:15px}
  .search-shell{margin-top:-70px;padding:0 24px 24px}.tabs{gap:40px;overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tabs button{white-space:nowrap}
  .form-grid{grid-template-columns:1fr 1fr;gap:18px}.search-btn{grid-column:1/-1;width:220px;justify-self:end}.chips{flex-wrap:wrap}
  .cat-grid{grid-template-columns:repeat(3,1fr)}.property-grid{grid-template-columns:repeat(3,1fr)}.pic{height:170px}
  .city-row{display:flex;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory}.city-row article{min-width:145px;scroll-snap-align:start}.city-row img{height:82px}
  .map-section{grid-template-columns:1fr}.map-card img{height:300px}.map-section aside{border-left:0;border-top:1px solid #e5e9ef;padding:28px 32px}.map-section aside label{display:inline-block;margin-right:24px}.map-section aside button{display:block}
  .service-grid{grid-template-columns:repeat(2,1fr)}.premium-grid{grid-template-columns:repeat(2,1fr)}.premium-grid aside{grid-column:1/-1;min-height:260px}
}

@media (max-width:760px){
  body{font-size:14px}.wide{width:calc(100% - 28px)}.site-header{height:70px}.site-header.menu-open .main-nav{top:70px}.site-header.menu-open .nav-actions{top:345px}.nav-wrap{gap:12px}.logo-icon{width:38px;height:38px;font-size:24px}.brand b{font-size:23px}.brand em{font-size:11px;letter-spacing:5px}.mobile-toggle{width:42px;height:38px}
  .hero{height:auto;min-height:560px;padding-bottom:150px;background:linear-gradient(180deg,rgba(255,255,255,.98) 0%,rgba(255,255,255,.92) 38%,rgba(255,255,255,.35) 65%,rgba(255,255,255,0) 100%),url('../img/hero-house.jpg') center bottom/auto 70% no-repeat}.hero-grid{padding-top:44px}.hero-copy h1{font-size:48px;letter-spacing:-1.4px}.hero-copy p{font-size:16px}.trust-row{display:grid;grid-template-columns:1fr;max-width:310px}.trust-row div{width:auto;border-right:0;border-bottom:1px solid #e8ebef}.trust-row div:last-child{border-bottom:0}
  .search-shell{margin-top:-96px;border-radius:12px;padding:0 18px 20px}.tabs{height:62px;gap:30px}.tabs button{height:62px;font-size:15px}.form-grid{grid-template-columns:1fr;padding-top:20px}.form-grid input,.form-grid select,.search-btn{height:52px}.search-btn{width:100%;justify-self:stretch}.chips{gap:10px}.chips b{width:100%}.chips span{padding:7px 13px;font-size:12px}
  .block{margin-top:34px}.block h2,.section-head h2,.map-card h2,.map-section aside h2{font-size:23px}.section-head{align-items:flex-start;gap:8px}.section-head a{font-size:13px}.cat-grid{grid-template-columns:repeat(2,1fr);gap:12px}.cat-grid article{height:96px;padding:0 16px;gap:12px}.cat-grid span{font-size:34px}.cat-grid b{font-size:13px}
  .property-grid{grid-template-columns:1fr;gap:16px}.pic{height:220px}.pc-body h3{font-size:16px}.pc-body p{font-size:12px;gap:12px}.pc-body strong{font-size:20px}
  .map-section{margin-top:28px}.map-card{padding:22px 18px 0}.map-card img{height:250px}.map-section aside{padding:24px 22px}.map-section aside label{display:block;margin:12px 0}.map-section aside button{width:100%}
  .service-grid{grid-template-columns:1fr;gap:14px}.service-grid article{min-height:130px;padding:24px 20px}.premium{padding-bottom:42px}.premium-grid{grid-template-columns:1fr}.premium-grid article img{height:205px}.premium-grid article strong{text-align:left;margin-top:8px}.premium-grid aside{grid-column:auto;min-height:240px}
}

@media (max-width:430px){
  .wide{width:calc(100% - 22px)}.brand{gap:8px}.logo-icon{width:34px;height:34px;font-size:21px}.brand b{font-size:21px}.brand em{font-size:10px;letter-spacing:4px}
  .hero{min-height:535px}.hero-copy h1{font-size:41px}.hero-copy p{font-size:15px}.trust-row{max-width:100%}.search-shell{margin-top:-88px}.cat-grid{grid-template-columns:1fr 1fr}.cat-grid article{height:92px}.pic{height:195px}.city-row article{min-width:132px}.service-grid article{grid-template-columns:44px 1fr}.service-grid span{font-size:30px}
}

/* --------------------------------------------------
   Phase 2.1 – Theme-Grundlage
   Desktop Light-Layout bleibt unverändert.
   -------------------------------------------------- */
.theme-toggle{width:42px;height:42px;border-radius:50%;padding:0!important;display:inline-grid;place-items:center;background:#fff!important;color:var(--navy)!important;border:1px solid #e1e6ed!important;box-shadow:none!important;font-size:17px;line-height:1;cursor:pointer}
.theme-dark{--navy:#f5f7fb;--line:#26354b;--muted:#a9b5c7;--soft:#101d30;--shadow:0 20px 45px rgba(0,0,0,.32);background:#081426;color:#f5f7fb}
.theme-dark .site-header,.theme-dark .search-shell,.theme-dark .cat-grid article,.theme-dark .property-card,.theme-dark .city-row article,.theme-dark .map-section,.theme-dark .map-card,.theme-dark .map-section aside,.theme-dark .service-grid article,.theme-dark .premium-grid article{background:#0d1b2f;border-color:#26354b;color:#f5f7fb}
.theme-dark .hero{background:linear-gradient(90deg,rgba(8,20,38,.98) 0%,rgba(8,20,38,.92) 34%,rgba(8,20,38,.22) 57%,rgba(8,20,38,0) 100%),url('../img/hero-house.jpg') right center/auto 100% no-repeat;border-bottom-color:#26354b}
.theme-dark .hero-copy h1,.theme-dark .main-nav a,.theme-dark .nav-actions a,.theme-dark .brand,.theme-dark .form-grid span,.theme-dark .pc-body h3,.theme-dark .service-grid a{color:#f5f7fb}
.theme-dark .trust-row,.theme-dark .form-grid input,.theme-dark .form-grid select{background:#10223a;border-color:#2b3c54;color:#f5f7fb}
.theme-dark .chips span,.theme-dark .premium-grid aside{background:#172740;border-color:#2b3c54;color:#f5f7fb}
.theme-dark .theme-toggle{background:#13243b!important;color:#f5f7fb!important;border-color:#2b3c54!important}
.theme-dark .mobile-toggle{background:#13243b;border-color:#2b3c54}.theme-dark .mobile-toggle span{background:#f5f7fb}
.theme-dark.site-header.menu-open .main-nav,.theme-dark.site-header.menu-open .nav-actions,.theme-dark .site-header.menu-open .main-nav,.theme-dark .site-header.menu-open .nav-actions{background:#0d1b2f;border-color:#26354b}

/* --------------------------------------------------
   Phase 2.2 – Premium Footer
   Wird nur unterhalb des bestehenden V4-Layouts ergänzt.
   -------------------------------------------------- */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.site-footer{margin-top:0;background:#071936;color:#fff;border-top:1px solid rgba(255,255,255,.08)}
.footer-newsletter{ margin-top:30px;display:grid;grid-template-columns:1.05fr .95fr;gap:42px;align-items:center;background:linear-gradient(135deg,#fff 0%,#fff8ef 100%);color:#071936;border:1px solid #e4e8ef;border-radius:12px;box-shadow:0 22px 50px rgba(7,25,54,.12);padding:34px 38px;margin-bottom:46px}
.footer-newsletter span{display:inline-block;color:var(--gold);font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.9px;margin-bottom:10px}
.footer-newsletter h2{font-size:30px;line-height:1.12;letter-spacing:-.7px;margin:0 0 10px}
.footer-newsletter p{margin:0;color:#5d6a7d;line-height:1.55;font-size:14px;max-width:650px}
.newsletter-form{display:grid;grid-template-columns:1fr 155px;gap:12px;align-items:center;background:#fff;border:1px solid #e0e6ee;border-radius:9px;padding:9px;box-shadow:0 10px 24px rgba(7,25,54,.06)}
.newsletter-form input{height:52px;border:0;background:transparent;padding:0 16px;font-size:14px;color:#071936;outline:none}
.newsletter-form button{height:52px;border:0;border-radius:7px;background:linear-gradient(180deg,#d49a3a,#b87316);color:white;font-weight:800;cursor:pointer;box-shadow:0 8px 16px rgba(184,115,22,.18)}
.footer-main{display:grid;grid-template-columns:1.28fr repeat(4,1fr);gap:52px;padding:62px 0 48px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-brand p{margin:22px 0 0;color:#aeb9c9;line-height:1.65;font-size:14px;max-width:330px}.footer-logo{color:#fff}.footer-logo .logo-icon{border-color:var(--gold);color:var(--gold)}
.footer-column h3{font-size:15px;margin:0 0 18px;color:#fff;letter-spacing:.1px}.footer-column a{display:block;color:#aeb9c9;text-decoration:none;font-size:14px;line-height:1.2;margin:0 0 13px;transition:.18s ease}.footer-column a:hover{color:#fff;transform:translateX(2px)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:24px 0 28px}.footer-bottom p{margin:0;color:#aeb9c9;font-size:13px}.footer-social{display:flex;align-items:center;gap:10px}.footer-social a{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;color:#fff;text-decoration:none;font-weight:800;font-size:13px;background:rgba(255,255,255,.04)}
.theme-dark .footer-newsletter{background:linear-gradient(135deg,#0d1b2f 0%,#13233a 100%);border-color:#26354b;color:#f5f7fb}.theme-dark .footer-newsletter p{color:#a9b5c7}.theme-dark .newsletter-form{background:#10223a;border-color:#2b3c54}.theme-dark .newsletter-form input{color:#f5f7fb}.theme-dark .newsletter-form input::placeholder{color:#8e9caf}
@media(max-width:1180px){.footer-newsletter{grid-template-columns:1fr;gap:24px}.footer-main{grid-template-columns:repeat(2,1fr);gap:34px 46px}.footer-brand{grid-column:1/-1}.newsletter-form{max-width:720px}}
@media(max-width:760px){.footer-newsletter{padding:28px 22px;margin-bottom:30px}.footer-newsletter h2{font-size:24px}.newsletter-form{grid-template-columns:1fr;padding:8px}.newsletter-form button{width:100%}.footer-main{grid-template-columns:1fr;gap:24px;padding:42px 0 34px}.footer-column h3{margin-bottom:13px}.footer-column a{margin-bottom:10px}.footer-bottom{flex-direction:column;align-items:flex-start;padding:22px 0 26px}.footer-social a{width:34px;height:34px}}

/* Phase 3: Immobilien-Detailseite */
.detail-page{padding-top:34px;padding-bottom:78px}.detail-breadcrumb{display:flex;align-items:center;gap:10px;margin:0 0 22px;color:#7c8798;font-size:14px}.detail-breadcrumb a{color:#7c8798;text-decoration:none}.detail-breadcrumb strong{color:#182235;font-weight:700}.detail-hero-card{background:#fff;border:1px solid rgba(20,32,52,.08);border-radius:30px;box-shadow:0 28px 70px rgba(24,34,53,.08);padding:28px}.detail-titlebar{display:flex;align-items:flex-end;justify-content:space-between;gap:28px;margin-bottom:24px}.detail-kicker{display:inline-flex;align-items:center;height:32px;padding:0 14px;border-radius:999px;background:#f6efe2;color:#b18435;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.detail-titlebar h1{font-size:46px;line-height:1.04;margin:14px 0 12px;color:#111a2b;letter-spacing:-.04em}.detail-titlebar p{margin:0;color:#6c7688;font-size:17px}.detail-pricebox-top{text-align:right;min-width:230px}.detail-pricebox-top small{display:block;color:#7b8594;margin-bottom:6px}.detail-pricebox-top strong{font-size:31px;color:#111a2b;letter-spacing:-.03em}.detail-gallery{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:255px 255px;gap:16px;position:relative}.detail-gallery figure{margin:0;border-radius:24px;overflow:hidden;background:#eef2f7}.detail-gallery img{width:100%;height:100%;object-fit:cover;display:block}.gallery-main{grid-row:span 2}.detail-gallery button{position:absolute;right:22px;bottom:22px;border:0;border-radius:999px;background:#fff;color:#172135;font-weight:800;padding:13px 19px;box-shadow:0 14px 34px rgba(12,21,34,.18)}.detail-layout{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:30px;margin-top:30px}.detail-content{display:flex;flex-direction:column;gap:24px}.detail-facts{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.detail-facts article,.detail-panel,.contact-card{background:#fff;border:1px solid rgba(20,32,52,.08);border-radius:24px;box-shadow:0 18px 50px rgba(24,34,53,.06)}.detail-facts article{padding:22px}.detail-facts span{display:block;color:#7b8594;font-size:13px;margin-bottom:8px}.detail-facts strong{color:#111a2b;font-size:20px}.detail-panel{padding:32px}.detail-panel h2{font-size:28px;margin:0 0 18px;color:#111a2b;letter-spacing:-.03em}.detail-panel p{font-size:16px;line-height:1.8;color:#5f6b7c;margin:0}.feature-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.feature-list span{background:#f7f8fb;border:1px solid rgba(20,32,52,.06);border-radius:16px;padding:14px 16px;color:#253149;font-weight:700}.location-map{height:320px;margin-top:22px;border-radius:22px;overflow:hidden;background:#edf1f6}.location-map img{width:100%;height:100%;object-fit:cover}.detail-sidebar{position:relative}.sticky-card{position:sticky;top:22px}.contact-card{padding:28px}.contact-label{display:inline-flex;height:30px;align-items:center;padding:0 12px;border-radius:999px;background:#eef4ff;color:#244d87;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.contact-card h3{font-size:24px;margin:16px 0 10px;color:#111a2b}.contact-card p{color:#6a7485;line-height:1.65;margin:0 0 20px}.contact-card form{display:flex;flex-direction:column;gap:12px}.contact-card input,.contact-card textarea{width:100%;border:1px solid rgba(20,32,52,.12);border-radius:15px;padding:14px 15px;font:inherit;color:#182235;background:#fff}.contact-card textarea{min-height:116px;resize:vertical}.contact-card form button,.contact-actions button{border:0;border-radius:16px;background:#c99b4a;color:#fff;font-weight:900;padding:15px 18px;cursor:pointer}.contact-actions{display:flex;flex-direction:column;gap:10px;margin-top:18px}.contact-actions a,.contact-actions button{text-decoration:none;text-align:center;border-radius:15px;padding:13px 14px;font-weight:800}.contact-actions a{background:#f7f8fb;color:#172135}.contact-actions button{background:#172135;color:#fff}.detail-similar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.detail-similar-grid a{display:block;text-decoration:none;color:#172135;background:#f7f8fb;border-radius:18px;overflow:hidden;border:1px solid rgba(20,32,52,.07)}.detail-similar-grid img{width:100%;height:150px;object-fit:cover;display:block}.detail-similar-grid b{display:block;padding:14px 14px 5px;font-size:16px;line-height:1.25}.detail-similar-grid span{display:block;padding:0 14px 16px;color:#c09243;font-weight:900}.property-card{text-decoration:none;color:inherit;display:block}
@media (max-width:1180px){.detail-titlebar{align-items:flex-start;flex-direction:column}.detail-pricebox-top{text-align:left}.detail-layout{grid-template-columns:1fr}.sticky-card{position:static}.detail-gallery{grid-template-rows:220px 220px}}
@media (max-width:820px){.detail-page{padding-top:22px}.detail-hero-card{padding:18px;border-radius:24px}.detail-titlebar h1{font-size:34px}.detail-gallery{grid-template-columns:1fr;grid-template-rows:330px 150px 150px}.gallery-main{grid-row:auto}.detail-facts{grid-template-columns:repeat(2,1fr)}.feature-list,.detail-similar-grid{grid-template-columns:1fr}.detail-panel{padding:24px}.detail-gallery button{right:14px;bottom:14px}}
@media (max-width:560px){.detail-titlebar h1{font-size:29px}.detail-gallery{grid-template-rows:260px 130px 130px}.detail-facts{grid-template-columns:1fr}.detail-facts article{padding:18px}.contact-card{padding:22px}}

.city-row .city-card{border:1px solid #dde4ec;border-radius:7px;overflow:hidden;background:white;box-shadow:0 7px 16px rgba(7,25,54,.05);text-decoration:none;color:inherit;display:block}.city-row .city-card img{width:100%;height:78px;object-fit:cover;display:block}.city-row .city-card b{display:block;padding:10px 10px 2px;font-size:13px}.city-row .city-card small{display:block;padding:0 10px 10px;color:#627084;font-size:11px}.city-page{padding:34px 0 78px;background:#fff}.city-hero{min-height:430px;border-radius:30px;overflow:hidden;position:relative;background:linear-gradient(90deg,rgba(255,255,255,.98),rgba(255,255,255,.88) 44%,rgba(255,255,255,.25) 67%,rgba(255,255,255,0)),var(--city-bg) center right/cover no-repeat;border:1px solid rgba(20,32,52,.08);box-shadow:0 28px 70px rgba(24,34,53,.08);display:flex;align-items:center}.city-hero-copy{max-width:720px;padding:48px 54px}.city-kicker{display:inline-flex;align-items:center;height:32px;padding:0 14px;border-radius:999px;background:#f6efe2;color:#b18435;font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.city-hero h1{font-family:'Playfair Display',serif;font-size:58px;line-height:1.02;letter-spacing:-.05em;margin:18px 0 16px;color:#101b30}.city-hero p{font-size:18px;line-height:1.65;color:#5e697a;margin:0 0 26px}.city-hero-stats{display:flex;gap:12px;flex-wrap:wrap}.city-hero-stats article{min-width:168px;background:rgba(255,255,255,.86);border:1px solid rgba(20,32,52,.08);border-radius:17px;padding:17px 18px;box-shadow:0 14px 34px rgba(24,34,53,.08)}.city-hero-stats strong{display:block;color:#111a2b;font-size:18px;margin-bottom:5px}.city-hero-stats span{display:block;color:#667284;font-size:12px;font-weight:700}.city-search-panel{position:relative;margin-top:-52px;background:#fff;border:1px solid #e5e9ee;border-radius:13px;box-shadow:var(--shadow);padding:0 30px 27px;z-index:2}.city-listings{margin-top:48px}.city-empty{border:1px dashed #d7dee8;border-radius:22px;padding:30px;background:#f8fafc;color:#647084;font-weight:700}.city-seo-grid{display:grid;grid-template-columns:1fr 380px;gap:22px;margin-top:38px}.city-seo-grid article,.city-seo-grid aside{background:#fff;border:1px solid rgba(20,32,52,.08);border-radius:24px;box-shadow:0 18px 50px rgba(24,34,53,.06);padding:30px}.city-seo-grid h2,.city-seo-grid h3{margin:0 0 16px;color:#111a2b}.city-seo-grid p{color:#5f6b7c;line-height:1.75;margin:0 0 14px}.city-seo-grid aside a{display:block;text-decoration:none;color:#172135;font-weight:800;padding:12px 0;border-bottom:1px solid #edf1f5}.city-seo-grid aside a:last-child{border-bottom:0}.city-more{margin-top:38px}.theme-dark .city-page{background:#071426}.theme-dark .city-hero,.theme-dark .city-search-panel,.theme-dark .city-seo-grid article,.theme-dark .city-seo-grid aside,.theme-dark .city-row .city-card{background-color:#0d1b2f;border-color:#26354b;color:#f5f7fb}.theme-dark .city-hero h1,.theme-dark .city-hero-stats strong,.theme-dark .city-seo-grid h2,.theme-dark .city-seo-grid h3,.theme-dark .city-seo-grid aside a{color:#f5f7fb}.theme-dark .city-hero p,.theme-dark .city-seo-grid p{color:#b9c3d2}.theme-dark .city-hero-stats article{background:rgba(13,27,47,.88);border-color:#26354b}@media(max-width:1200px){.city-hero h1{font-size:46px}.city-seo-grid{grid-template-columns:1fr}.city-row .city-card{min-width:145px;scroll-snap-align:start}}@media(max-width:720px){.city-page{padding-top:20px}.city-hero{min-height:auto;border-radius:24px;background:linear-gradient(0deg,rgba(255,255,255,.98),rgba(255,255,255,.88)),var(--city-bg) center/cover no-repeat}.city-hero-copy{padding:28px 24px}.city-hero h1{font-size:35px}.city-hero p{font-size:15px}.city-hero-stats{display:grid;grid-template-columns:1fr}.city-search-panel{margin-top:18px;padding:0 20px 22px}.city-seo-grid article,.city-seo-grid aside{padding:24px}.city-row .city-card{min-width:132px}}

/* Phase 9: Merkliste / Favoriten - reine Funktionserweiterung, Desktop-Layout bleibt gleich */
.property-card{position:relative}.property-card-link{display:block;color:inherit;text-decoration:none}.favorite-mini{position:absolute;right:12px;top:10px;z-index:4;margin:0}.favorite-mini button{width:38px;height:38px;border:0;border-radius:999px;background:rgba(255,255,255,.92);color:#172135;font-size:22px;line-height:1;display:grid;place-items:center;box-shadow:0 10px 24px rgba(7,25,54,.18);cursor:pointer}.favorite-mini button.active{background:#172135;color:#fff}.favorite-count{display:inline-grid;place-items:center;min-width:20px;height:20px;padding:0 6px;margin-left:5px;border-radius:999px;background:#f3eadb;color:#9a6a1f;font-size:11px;font-weight:900}.detail-favorite-form{margin:0}.detail-favorite-form button.active{background:#c99b4a;color:#fff}.favorites-page{padding-top:34px;padding-bottom:78px}.favorites-hero{display:flex;align-items:center;justify-content:space-between;gap:24px;background:#fff;border:1px solid rgba(20,32,52,.08);border-radius:30px;box-shadow:0 28px 70px rgba(24,34,53,.08);padding:34px;margin-bottom:28px}.favorites-hero h1{font-size:46px;line-height:1.04;margin:14px 0 12px;color:#111a2b;letter-spacing:-.04em}.favorites-hero p{margin:0;color:#6c7688;font-size:17px}.favorites-hero>strong{display:inline-flex;align-items:center;justify-content:center;min-width:130px;height:54px;border-radius:999px;background:#f6efe2;color:#b18435;font-size:15px;font-weight:900}.empty-favorites{max-width:780px}.primary-link-button{display:inline-flex;align-items:center;justify-content:center;margin-top:22px;padding:15px 22px;border-radius:16px;background:#172135;color:#fff;text-decoration:none;font-weight:900}.favorites-list{margin-top:0}.theme-dark .favorite-mini button{background:#172135;color:#fff}.theme-dark .favorite-mini button.active{background:#c99b4a}.theme-dark .favorites-hero,.theme-dark .empty-favorites{background:#0d1b2f;border-color:#26354b;color:#f5f7fb}.theme-dark .favorites-hero h1,.theme-dark .detail-breadcrumb strong{color:#f5f7fb}.theme-dark .favorites-hero p{color:#c0cad8}
@media (max-width:820px){.favorites-page{padding-top:22px}.favorites-hero{align-items:flex-start;flex-direction:column;padding:24px;border-radius:24px}.favorites-hero h1{font-size:34px}.favorite-mini{right:10px;top:10px}.favorite-mini button{width:36px;height:36px}}

/* Phase 10: Anfrageformular Meldungen */
.contact-message{border-radius:16px;padding:12px 14px;margin:14px 0;font-weight:800;font-size:14px}.contact-message.success{background:#ecfdf5;color:#047857;border:1px solid #bbf7d0}.contact-message.error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}

/* Phase 11: Inserat aufgeben */
.submit-property-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 18px;
    border-radius: 999px;
    background: #c79a42;
    color: #fff !important;
    font-weight: 800;
    text-decoration: none;
    box-shadow: 0 14px 28px rgba(199,154,66,.22);
}
.submit-hero {
    padding: 72px 0 36px;
    background: linear-gradient(180deg, #fff 0%, #f7f3eb 100%);
}
.submit-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 420px;
    gap: 34px;
    align-items: end;
}
.submit-hero h1 {
    margin: 10px 0 16px;
    font-family: 'Playfair Display', serif;
    font-size: clamp(44px, 5vw, 84px);
    line-height: .95;
    letter-spacing: -.05em;
    color: #13233a;
}
.submit-hero p {
    max-width: 720px;
    margin: 0;
    color: #657086;
    font-size: 18px;
    line-height: 1.7;
}
.submit-hero-card {
    padding: 30px;
    border-radius: 28px;
    background: #fff;
    box-shadow: 0 26px 70px rgba(19,35,58,.10);
    border: 1px solid rgba(199,154,66,.18);
}
.submit-hero-card strong,
.submit-hero-card span,
.submit-hero-card small {
    display: block;
}
.submit-hero-card strong {
    color: #13233a;
    font-size: 22px;
    margin-bottom: 10px;
}
.submit-hero-card span {
    color: #566176;
    line-height: 1.6;
}
.submit-hero-card small {
    margin-top: 18px;
    color: #9b7940;
    font-weight: 800;
}
.submit-section {
    padding: 56px 0 94px;
    background: #f8f9fb;
}
.submit-message {
    display: grid;
    gap: 6px;
    margin: 0 0 20px;
    padding: 18px 22px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid #e9edf3;
    color: #4d596f;
}
.submit-message strong { color: #13233a; }
.submit-message.success { border-color: rgba(29,142,85,.25); background: #f1fbf6; }
.submit-message.error { border-color: rgba(192,73,73,.25); background: #fff5f5; }
.submit-message.warning { border-color: rgba(199,154,66,.25); background: #fffaf0; }
.listing-wizard {
    display: grid;
    gap: 24px;
}
.wizard-progress {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 12px;
    padding: 10px;
    border-radius: 22px;
    background: #fff;
    box-shadow: 0 20px 54px rgba(19,35,58,.07);
}
.wizard-progress span {
    padding: 13px 12px;
    border-radius: 16px;
    background: #f6f7f9;
    color: #69748a;
    text-align: center;
    font-weight: 800;
    font-size: 13px;
}
.wizard-progress span:first-child {
    background: #13233a;
    color: #fff;
}
.wizard-step {
    padding: 34px;
    border-radius: 30px;
    background: #fff;
    box-shadow: 0 24px 70px rgba(19,35,58,.08);
    border: 1px solid #edf0f5;
}
.step-head {
    margin-bottom: 24px;
}
.step-head span {
    display: inline-flex;
    padding: 7px 12px;
    border-radius: 999px;
    background: #f4ebd8;
    color: #9b7232;
    font-weight: 900;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.step-head h2 {
    margin: 12px 0 0;
    color: #13233a;
    font-size: 30px;
    letter-spacing: -.03em;
}
.choice-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
.choice-grid.small {
    grid-template-columns: repeat(2, 1fr);
    margin-top: 16px;
}
.choice-card {
    position: relative;
    display: grid;
    gap: 8px;
    min-height: 126px;
    padding: 22px;
    border-radius: 22px;
    border: 1px solid #e7ebf1;
    background: #fbfcfe;
    cursor: pointer;
}
.choice-card input {
    position: absolute;
    right: 18px;
    top: 18px;
    accent-color: #c79a42;
}
.choice-card strong { color: #13233a; font-size: 20px; }
.choice-card span { color: #738096; }
.form-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
.form-grid label {
    display: grid;
    gap: 9px;
    color: #354156;
    font-weight: 800;
}
.form-grid .full { grid-column: 1 / -1; }
.form-grid input,
.form-grid textarea,
.form-grid select {
    width: 100%;
    border: 1px solid #e3e8ef;
    border-radius: 16px;
    padding: 15px 16px;
    color: #13233a;
    background: #fbfcfe;
    font: inherit;
    outline: none;
}
.form-grid textarea { resize: vertical; }
.upload-drop {
    display: grid;
    place-items: center;
    gap: 10px;
    min-height: 210px;
    border: 2px dashed #d8dee8;
    border-radius: 26px;
    background: #fbfcfe;
    text-align: center;
    color: #657086;
    cursor: pointer;
}
.upload-drop input { max-width: 340px; }
.upload-drop strong { color: #13233a; font-size: 22px; }
.submission-preview {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 22px;
    padding: 24px;
    border-radius: 22px;
    background: #f8f4eb;
}
.submission-preview strong,
.submission-preview span { display: block; }
.submission-preview strong { color: #13233a; font-size: 22px; }
.submission-preview span { margin-top: 6px; color: #6d778c; }
.primary-submit {
    border: 0;
    border-radius: 999px;
    min-height: 54px;
    padding: 0 26px;
    background: #13233a;
    color: #fff;
    font-weight: 900;
    cursor: pointer;
}

@media (max-width: 1100px) {
    .submit-hero-grid { grid-template-columns: 1fr; }
    .choice-grid { grid-template-columns: repeat(2, 1fr); }
    .form-grid { grid-template-columns: repeat(2, 1fr); }
    .wizard-progress { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 700px) {
    .submit-hero { padding-top: 42px; }
    .wizard-step { padding: 22px; border-radius: 22px; }
    .choice-grid,
    .choice-grid.small,
    .form-grid,
    .wizard-progress { grid-template-columns: 1fr; }
    .submission-preview { align-items: stretch; flex-direction: column; }
    .primary-submit { width: 100%; }
}

/* Phase 12: Benutzerkonten / Kundenbereich */
.account-hero{padding:70px 0 34px;background:linear-gradient(180deg,#f8fafc 0%,#fff 100%);border-bottom:1px solid rgba(12,31,55,.08)}
.account-hero-inner{max-width:1500px}.account-hero h1{margin:10px 0 10px;font-size:clamp(36px,5vw,72px);line-height:1;color:#102033;letter-spacing:-.04em}.account-hero p{font-size:19px;color:#65758b;max-width:760px;margin:0}.account-section,.account-dashboard{padding:46px 0 80px}.account-card{background:#fff;border:1px solid rgba(16,32,51,.1);border-radius:28px;box-shadow:0 22px 70px rgba(16,32,51,.08);padding:32px}.auth-card{max-width:620px;margin:0 auto}.account-form{display:grid;gap:18px}.account-form label{font-weight:700;color:#102033;display:grid;gap:8px}.account-form input,.account-form select{height:54px;border:1px solid rgba(16,32,51,.14);border-radius:16px;padding:0 16px;font:inherit;background:#fff}.primary-btn,.ghost-btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 22px;border-radius:999px;font-weight:800;text-decoration:none;border:0;cursor:pointer}.primary-btn{background:#c9a05b;color:#fff}.ghost-btn{background:#f3f6fa;color:#102033}.auth-switch,.demo-login{margin:18px 0 0;color:#65758b}.auth-switch a{color:#102033;font-weight:800}.form-message{padding:14px 16px;border-radius:16px;margin-bottom:18px;font-weight:700}.form-message.success{background:#ecfdf3;color:#166534}.form-message.error{background:#fef2f2;color:#991b1b}.account-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:24px}.account-tile{background:#fff;border:1px solid rgba(16,32,51,.1);border-radius:24px;padding:26px;text-decoration:none;color:#102033;box-shadow:0 18px 55px rgba(16,32,51,.07)}.account-tile strong{display:block;font-size:30px;margin-bottom:8px}.account-tile span{color:#65758b;font-weight:700}.account-overview h2{margin-top:0}.account-actions,.account-headline{display:flex;gap:14px;align-items:center;justify-content:space-between;flex-wrap:wrap}.account-table-wrap{overflow:auto}.account-table{width:100%;border-collapse:collapse}.account-table th,.account-table td{padding:16px;border-bottom:1px solid rgba(16,32,51,.08);text-align:left}.account-table th{color:#65758b;font-size:13px;text-transform:uppercase;letter-spacing:.08em}.status-pill{display:inline-flex;padding:7px 12px;border-radius:999px;background:#f3f6fa;color:#102033;font-weight:800;font-size:12px}
@media(max-width:1100px){.account-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.account-grid{grid-template-columns:1fr}.account-card{padding:22px;border-radius:22px}.account-hero{padding:48px 0 28px}.account-actions,.account-headline{align-items:stretch;flex-direction:column}.account-actions a,.account-headline a{width:100%}}

/* Phase 14: Premium-Pakete & Bezahlgrundlage */
.pricing-hero{
    padding:72px 0 42px;
    background:linear-gradient(180deg,#f8fafc 0%,#fff 100%);
    border-bottom:1px solid rgba(16,32,51,.08);
}
.pricing-hero h1{
    max-width:980px;
    margin:12px 0 14px;
    color:#102033;
    font-size:clamp(38px,5.4vw,78px);
    line-height:.95;
    letter-spacing:-.055em;
}
.pricing-hero p{
    max-width:780px;
    margin:0;
    color:#66758b;
    font-size:19px;
    line-height:1.7;
}
.pricing-section{padding:50px 0 88px;background:#fff}.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}.pricing-card{display:flex;flex-direction:column;gap:22px;padding:28px;border:1px solid rgba(16,32,51,.1);border-radius:30px;background:#fff;box-shadow:0 22px 70px rgba(16,32,51,.08)}.pricing-card.featured{border-color:rgba(199,154,66,.45);background:linear-gradient(180deg,#fff 0%,#fffaf1 100%)}.pricing-top span{display:inline-flex;padding:8px 12px;border-radius:999px;background:#f4f6f9;color:#102033;font-weight:900;font-size:13px}.pricing-top strong{display:block;margin-top:18px;font-size:42px;letter-spacing:-.05em;color:#102033}.pricing-top small{display:block;margin-top:4px;color:#6b7587;font-weight:800}.pricing-card p{margin:0;color:#637086;line-height:1.65}.pricing-card ul{display:grid;gap:11px;margin:0;padding:0;list-style:none}.pricing-card li{position:relative;padding-left:24px;color:#26364d;font-weight:750}.pricing-card li:before{content:'✓';position:absolute;left:0;color:#c79a42;font-weight:950}.pricing-btn{margin-top:auto;display:inline-flex;align-items:center;justify-content:center;min-height:50px;border-radius:999px;background:#102033;color:#fff;text-decoration:none;font-weight:900}.payment-section{padding:70px 0 90px;background:#f7f9fc}.payment-card{max-width:880px;background:#fff;border:1px solid rgba(16,32,51,.1);border-radius:32px;box-shadow:0 26px 80px rgba(16,32,51,.1);padding:36px}.payment-card h1{margin:12px 0;color:#102033;font-size:clamp(32px,4vw,54px);letter-spacing:-.05em}.payment-card p{color:#66758b;line-height:1.7}.payment-summary{display:grid;grid-template-columns:180px 1fr;gap:12px 20px;margin:28px 0;padding:22px;border-radius:22px;background:#f8fafc}.payment-summary span{color:#66758b;font-weight:850}.payment-summary strong{color:#102033}.pricing-inline-link{display:inline-flex;margin-top:12px;color:#102033;font-weight:900;text-decoration:underline;text-underline-offset:4px}
@media(max-width:1180px){.pricing-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:680px){.pricing-grid{grid-template-columns:1fr}.payment-card{padding:24px;border-radius:24px}.payment-summary{grid-template-columns:1fr}.pricing-hero{padding:52px 0 30px}}

/* Phase 15: Suchauftrag & Preisalarm */
.alert-hero{padding:72px 0 70px;background:linear-gradient(180deg,#f8fafc 0%,#fff 100%)}
.alert-hero-grid{display:grid;grid-template-columns:minmax(0,1fr) 520px;gap:46px;align-items:center}
.alert-hero h1{margin:14px 0 18px;color:#102033;font-size:clamp(42px,5vw,76px);line-height:.95;letter-spacing:-.06em;max-width:780px}
.alert-hero p{margin:0;color:#66758b;font-size:18px;line-height:1.75;max-width:650px}
.alert-benefits{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}.alert-benefits span{padding:10px 14px;border-radius:999px;background:#fff;border:1px solid rgba(16,32,51,.08);font-weight:900;color:#23344d;box-shadow:0 14px 34px rgba(16,32,51,.06)}
.alert-form{background:#fff;border:1px solid rgba(16,32,51,.1);border-radius:34px;box-shadow:0 30px 90px rgba(16,32,51,.11);padding:30px}.alert-form h2{margin:0 0 22px;color:#102033;font-size:28px;letter-spacing:-.04em}.alert-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.alert-form label{display:grid;gap:8px;font-weight:900;color:#25354c}.alert-form input,.alert-form select{width:100%;border:1px solid rgba(16,32,51,.13);border-radius:16px;padding:13px 14px;background:#fff;font:inherit;color:#102033}.alert-check{grid-column:1/-1;display:flex!important;align-items:center;gap:10px;background:#f8fafc;border-radius:16px;padding:14px}.alert-check input{width:auto}.alert-submit{margin-top:20px;width:100%;min-height:54px;border:0;border-radius:999px;background:#102033;color:#fff;font-weight:950;font-size:16px;cursor:pointer}.form-success,.form-error{padding:13px 15px;border-radius:16px;margin-bottom:18px;font-weight:850}.form-success{background:#dcfce7;color:#166534}.form-error{background:#fee2e2;color:#991b1b}.alert-info-section{padding:20px 0 90px;background:#fff}.alert-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.alert-info-grid article{padding:28px;border-radius:28px;border:1px solid rgba(16,32,51,.08);box-shadow:0 18px 50px rgba(16,32,51,.06)}.alert-info-grid strong{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;background:#c79a42;color:#111827;font-weight:950}.alert-info-grid h3{margin:18px 0 8px;color:#102033}.alert-info-grid p{margin:0;color:#65758b;line-height:1.65}@media(max-width:1050px){.alert-hero-grid{grid-template-columns:1fr}.alert-form{max-width:720px}}@media(max-width:680px){.alert-hero{padding:48px 0}.alert-form{padding:22px;border-radius:26px}.alert-form-grid,.alert-info-grid{grid-template-columns:1fr}.alert-hero h1{font-size:40px}}

/* Phase 16 – echte Suche & Filter: Hero-Auswahl sauber nebeneinander */
.hero-search{display:block}
.search-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:0;align-items:center}
.search-tabs label{height:74px;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;color:#334058;font-size:16px;font-weight:700;white-space:nowrap}
.search-tabs label input{position:absolute;opacity:0;pointer-events:none}
.search-tabs label span{height:74px;display:flex;align-items:center;justify-content:center;position:relative;padding:0 14px}
.search-tabs label input:checked + span{color:var(--navy);font-weight:900}
.search-tabs label input:checked + span:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:3px;background:var(--gold)}
.chips a{border:1px solid #e1e5eb;background:#fff;border-radius:24px;padding:8px 18px;font-weight:600;text-decoration:none;color:var(--navy)}
.search-results-hero{padding:62px 0 22px}.search-results-hero .eyebrow{display:inline-flex;border:1px solid #eadcc6;background:#fff8ed;color:#9a6a1f;border-radius:999px;padding:8px 13px;font-weight:900;font-size:12px;letter-spacing:.08em;text-transform:uppercase}.search-results-hero h1{font-size:clamp(38px,5vw,68px);line-height:.98;letter-spacing:-.055em;margin:18px 0 14px;color:#102033}.search-results-hero p{margin:0;color:#65758b;font-size:18px;line-height:1.65}.search-page-shell{margin-top:14px}.search-results-block{padding-bottom:70px}.empty-state{background:#fff;border:1px solid rgba(16,32,51,.09);border-radius:28px;box-shadow:0 22px 70px rgba(16,32,51,.08);padding:42px;text-align:center}.empty-state h3{font-size:28px;margin:0 0 10px}.empty-state p{color:#65758b;margin:0}.theme-dark .search-results-hero h1,.theme-dark .empty-state h3{color:#f5f7fb}.theme-dark .search-results-hero p,.theme-dark .empty-state p{color:#c0cad8}.theme-dark .empty-state{background:#0d1b2f;border-color:#26354b}
@media(max-width:720px){.search-tabs{grid-template-columns:repeat(4,minmax(118px,1fr));overflow-x:auto;scrollbar-width:none}.search-tabs::-webkit-scrollbar{display:none}.search-tabs label{justify-content:center}.search-tabs label span{padding:0 18px}.search-results-hero{padding:42px 0 12px}.search-results-hero h1{font-size:38px}}

/* Phase 16.1 – Fix: Hero-Suchreiter Kaufen/Mieten/Neubau/Gewerbe exakt 4 nebeneinander */
.search-shell.hero-search > .tabs.search-tabs,
form.hero-search > .tabs.search-tabs,
.hero-search .search-tabs {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 0 !important;
    column-gap: 0 !important;
    width: 100% !important;
    min-width: 0 !important;
    align-items: stretch !important;
    overflow: visible !important;
}

.search-shell.hero-search > .tabs.search-tabs > label,
form.hero-search > .tabs.search-tabs > label,
.hero-search .search-tabs > label {
    width: 100% !important;
    min-width: 0 !important;
    height: 74px !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
}

.hero-search .search-tabs > label > span {
    width: 100% !important;
    height: 74px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    white-space: nowrap !important;
}

@media (max-width: 720px) {
    .search-shell.hero-search > .tabs.search-tabs,
    form.hero-search > .tabs.search-tabs,
    .hero-search .search-tabs {
        grid-template-columns: repeat(4, minmax(104px, 1fr)) !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch;
    }
}

/* Phase 16.2 – Fix: Hero-Suchfelder auf Desktop exakt in einer Reihe
   Wo? | Preis bis | Zimmer | Wohnfläche ab | Suchen */
.search-shell.hero-search .form-grid,
form.hero-search .form-grid {
    display: grid !important;
    grid-template-columns: minmax(260px, 1.45fr) minmax(190px, 1fr) minmax(190px, 1fr) minmax(190px, 1fr) 170px !important;
    gap: 30px !important;
    align-items: end !important;
    width: 100% !important;
}

.search-shell.hero-search .form-grid > label,
form.hero-search .form-grid > label {
    min-width: 0 !important;
    width: 100% !important;
}

.search-shell.hero-search .form-grid .search-btn,
form.hero-search .form-grid .search-btn {
    grid-column: auto !important;
    width: 100% !important;
    min-width: 170px !important;
    justify-self: stretch !important;
    align-self: end !important;
}

@media (max-width: 1180px) {
    .search-shell.hero-search .form-grid,
    form.hero-search .form-grid {
        grid-template-columns: 1fr 1fr !important;
        gap: 18px !important;
    }
    .search-shell.hero-search .form-grid .search-btn,
    form.hero-search .form-grid .search-btn {
        grid-column: 1 / -1 !important;
        width: 220px !important;
        min-width: 0 !important;
        justify-self: end !important;
    }
}

@media (max-width: 720px) {
    .search-shell.hero-search .form-grid,
    form.hero-search .form-grid {
        grid-template-columns: 1fr !important;
    }
    .search-shell.hero-search .form-grid .search-btn,
    form.hero-search .form-grid .search-btn {
        width: 100% !important;
        justify-self: stretch !important;
    }
}

/* Phase 19: Rechtliches & DSGVO */
.legal-page{padding:72px 0 96px}.legal-page h1{font-family:'Playfair Display',serif;font-size:clamp(38px,5vw,68px);color:var(--navy);margin:8px 0 30px}.legal-card{background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:0 18px 50px rgba(15,31,58,.08);padding:42px;max-width:980px}.legal-card h2{font-size:20px;color:var(--navy);margin:28px 0 10px}.legal-card h2:first-child{margin-top:0}.legal-card p{color:#4a5668;line-height:1.75;margin:0 0 12px}.legal-note{background:#fff7e8;border:1px solid rgba(199,135,35,.22);border-radius:14px;padding:14px 16px;color:#7a531d!important}.cookie-settings-box{display:grid;gap:14px;margin:24px 0}.cookie-settings-box label{display:flex;gap:10px;align-items:center;font-weight:700;color:var(--navy)}.cookie-banner{position:fixed;left:24px;right:24px;bottom:24px;z-index:9999;display:flex;align-items:center;justify-content:space-between;gap:24px;background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:0 22px 70px rgba(15,31,58,.18);padding:22px 24px}.cookie-banner[hidden],.cookie-modal[hidden]{display:none}.cookie-banner strong{display:block;color:var(--navy);font-size:18px;margin-bottom:4px}.cookie-banner p{margin:0;color:#526072;max-width:760px;line-height:1.5}.cookie-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.cookie-btn{border:0;background:linear-gradient(135deg,var(--gold),#b97410);color:#fff;border-radius:12px;padding:12px 18px;font-weight:800;cursor:pointer}.cookie-btn.ghost{background:#f5f7fb;color:var(--navy);border:1px solid var(--line)}.cookie-modal{position:fixed;inset:0;background:rgba(7,18,36,.48);z-index:10000;display:grid;place-items:center;padding:24px}.cookie-modal-card{background:#fff;border-radius:24px;box-shadow:0 30px 90px rgba(0,0,0,.25);padding:30px;max-width:460px;width:100%}.cookie-modal-card h2{margin:0 0 18px;color:var(--navy)}.cookie-modal-card label{display:flex;gap:10px;margin:14px 0;color:var(--navy);font-weight:700}.privacy-consent{display:flex!important;align-items:flex-start!important;gap:10px!important;font-size:14px!important;line-height:1.45!important;color:#536072!important}.privacy-consent input{margin-top:3px}.privacy-consent a{color:var(--gold);font-weight:800}@media(max-width:760px){.cookie-banner{left:12px;right:12px;bottom:12px;display:block}.cookie-actions{margin-top:16px}.legal-card{padding:26px}.legal-page{padding:44px 0 70px}}

/* Phase 20: Header-Zielseiten */
.page-hero{padding:72px 0 36px}.simple-hero{max-width:1500px}.simple-hero h1,.split-hero h1{font-size:clamp(42px,5vw,72px);line-height:1.02;margin:10px 0 16px;color:#10233f}.simple-hero p,.split-hero p{max-width:760px;color:#637087;font-size:18px;line-height:1.75}.split-hero{display:grid;grid-template-columns:1.15fr .85fr;gap:36px;align-items:stretch}.info-panel,.calc-card,.contact-card{background:#fff;border:1px solid rgba(16,35,63,.08);box-shadow:0 24px 70px rgba(16,35,63,.10);border-radius:28px;padding:34px}.info-panel h3{font-size:28px;margin:0 0 14px;color:#10233f}.feature-row{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:34px;margin-bottom:46px}.feature-row article,.article-card{background:#fff;border:1px solid rgba(16,35,63,.08);border-radius:24px;padding:28px;box-shadow:0 16px 45px rgba(16,35,63,.07)}.feature-row h3,.article-card h2{margin:0 0 10px;color:#10233f}.feature-row p,.article-card p{color:#667389;line-height:1.65}.mini-filter{margin-top:28px;display:grid;grid-template-columns:1.4fr 1fr 1fr 170px;gap:14px;background:#fff;border-radius:24px;padding:16px;box-shadow:0 20px 60px rgba(16,35,63,.10);border:1px solid rgba(16,35,63,.08)}.mini-filter input,.mini-filter select,.calc-card input,.contact-card input,.contact-card textarea{width:100%;border:1px solid rgba(16,35,63,.14);border-radius:14px;padding:14px 16px;font:inherit;background:#fff}.mini-filter button,.primary-btn{border:0;border-radius:14px;background:#c89b3c;color:#fff;font-weight:800;padding:14px 20px;text-decoration:none;display:inline-flex;justify-content:center;align-items:center;cursor:pointer}.calc-card{display:grid;grid-template-columns:1fr 1fr;gap:16px}.calc-card label,.contact-card label{font-weight:700;color:#10233f;display:grid;gap:8px}.calc-card strong{grid-column:1/-1;font-size:22px;color:#10233f;padding-top:8px}.article-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin:20px auto 64px}.article-card span{display:inline-block;color:#c89b3c;text-transform:uppercase;letter-spacing:.12em;font-size:12px;font-weight:800;margin-bottom:14px}.article-card a{font-weight:800;color:#10233f;text-decoration:none}.contact-card{display:grid;gap:16px}.check-row{display:flex!important;grid-template-columns:none!important;align-items:flex-start;gap:10px;font-weight:600!important;color:#667389!important}.check-row input{width:auto!important;margin-top:4px}
@media (max-width:1100px){.split-hero,.feature-row,.article-grid{grid-template-columns:1fr}.mini-filter{grid-template-columns:1fr 1fr}.calc-card{grid-template-columns:1fr}}
@media (max-width:680px){.page-hero{padding:42px 0 24px}.mini-filter{grid-template-columns:1fr}.info-panel,.calc-card,.contact-card{padding:24px;border-radius:22px}.feature-row article,.article-card{padding:22px}.simple-hero h1,.split-hero h1{font-size:38px}}


/* --------------------------------------------------
   Detailseite Sidebar Hardfix
   Behebt: Inhalt klebt rechts am Rand / läuft aus der Kontaktbox.
   Betrifft ausschließlich die rechte Sidebar auf immobilie.php.
   -------------------------------------------------- */
.detail-layout .detail-sidebar,
.detail-layout .detail-sidebar *{
  box-sizing:border-box;
}
.detail-layout .detail-sidebar{
  min-width:0;
  overflow:visible;
}
.detail-layout .detail-sidebar .contact-card{
  width:100%;
  max-width:100%;
  padding:32px 34px !important;
  overflow:hidden;
}
.detail-layout .detail-sidebar .contact-card form,
.detail-layout .detail-sidebar .contact-actions,
.detail-layout .detail-sidebar .detail-favorite-form{
  width:100%;
  max-width:100%;
  min-width:0;
}
.detail-layout .detail-sidebar .contact-card input,
.detail-layout .detail-sidebar .contact-card textarea,
.detail-layout .detail-sidebar .contact-card select,
.detail-layout .detail-sidebar .contact-actions a,
.detail-layout .detail-sidebar .contact-actions button,
.detail-layout .detail-sidebar .detail-favorite-form button{
  display:block;
  width:100%;
  max-width:100%;
  min-width:0;
  box-sizing:border-box;
}
.detail-layout .detail-sidebar .privacy-consent{
  display:block;
  width:100%;
  max-width:100%;
  line-height:1.45;
  padding-right:0;
  margin:2px 0 4px;
  overflow-wrap:anywhere;
}
.detail-layout .detail-sidebar .privacy-consent input{
  width:auto;
  display:inline-block;
  margin-right:8px;
  vertical-align:-2px;
}
.detail-layout .detail-sidebar .contact-message{
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  overflow-wrap:anywhere;
}

@media (max-width:560px){
  .detail-layout .detail-sidebar .contact-card{
    padding:24px 22px !important;
  }
}

/* --------------------------------------------------
   Detailseite Finalfix: DSGVO-Hinweis in Sidebar kompakt
   Muss nach allen anderen Contact-/Legal-Regeln stehen.
   -------------------------------------------------- */
.detail-layout .detail-sidebar .contact-card form label.privacy-consent,
.detail-layout .detail-sidebar .privacy-consent{
  display:flex !important;
  align-items:flex-start !important;
  grid-template-columns:none !important;
  gap:7px !important;
  width:100% !important;
  max-width:100% !important;
  margin:0 0 2px !important;
  padding:0 !important;
  font-size:10.5px !important;
  line-height:1.32 !important;
  font-weight:500 !important;
  color:#758094 !important;
  letter-spacing:0 !important;
  overflow-wrap:normal !important;
  word-break:normal !important;
}

.detail-layout .detail-sidebar .contact-card form label.privacy-consent input,
.detail-layout .detail-sidebar .privacy-consent input{
  flex:0 0 auto !important;
  width:13px !important;
  height:13px !important;
  min-width:13px !important;
  margin:1px 0 0 0 !important;
  padding:0 !important;
  display:inline-block !important;
  accent-color:#c98b2e;
}

.detail-layout .detail-sidebar .contact-card form label.privacy-consent a,
.detail-layout .detail-sidebar .privacy-consent a{
  color:#b87316 !important;
  font-weight:700 !important;
  text-decoration:none !important;
}

.detail-layout .detail-sidebar .contact-card form label.privacy-consent a:hover,
.detail-layout .detail-sidebar .privacy-consent a:hover{
  text-decoration:underline !important;
}


/* Feinschliff: Beliebte Kategorien komplett verlinkt + mehr Luft unter Angebotsbereichen */
.cat-grid > a.category-card{
    height:108px;
    border:1px solid #e0e6ee;
    border-radius:8px;
    background:#fff;
    display:flex;
    align-items:center;
    gap:18px;
    padding:0 27px;
    box-shadow:0 8px 18px rgba(7,25,54,.035);
    color:var(--navy);
    text-decoration:none;
    min-width:0;
}
.cat-grid > a.category-card:hover{
    transform:translateY(-2px);
    box-shadow:0 14px 28px rgba(7,25,54,.08);
}
.cat-grid > a.category-card span{font-size:43px}
.cat-grid > a.category-card b{line-height:1.2;font-size:14px}
.section-block .property-grid{margin-bottom:50px}
.theme-dark .cat-grid > a.category-card{background:#0d1b2f;border-color:#26354b;color:#f5f7fb}
@media(max-width:760px){
    .cat-grid > a.category-card{height:96px;padding:0 16px;gap:12px}
    .cat-grid > a.category-card span{font-size:34px}
    .cat-grid > a.category-card b{font-size:13px}
}
@media(max-width:430px){
    .cat-grid > a.category-card{height:92px}
}

/* Phase 22 – Echte Deutschlandkarte mit Angebotsliste */
.map-section-live{
    grid-template-columns:minmax(0,1fr) 430px;
    align-items:stretch;
}
.map-card-live{
    padding:30px;
}
.map-card-head{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:24px;
    margin-bottom:20px;
}
.map-card-head h2{
    margin:0 0 8px;
}
.map-card-head p{
    margin:0;
    color:#647084;
    line-height:1.55;
    font-size:14px;
}
.map-card-head a{
    color:var(--navy);
    text-decoration:none;
    font-weight:900;
    white-space:nowrap;
    margin-top:6px;
}
.immo-map{
    width:100%;
    height:420px;
    border-radius:18px;
    overflow:hidden;
    background:#edf2f7;
    border:1px solid #e1e7ef;
}
.map-fallback{
    margin-top:12px;
    padding:13px 15px;
    border-radius:14px;
    background:#fff8ee;
    border:1px solid #eadcc6;
    color:#8a631f;
    font-weight:800;
    font-size:13px;
}
.map-offers-panel{
    padding:34px 30px!important;
}
.map-panel-kicker{
    display:inline-flex;
    align-items:center;
    height:30px;
    padding:0 12px;
    border-radius:999px;
    background:#f6efe2;
    color:#9a6a1f;
    font-size:12px;
    font-weight:900;
    letter-spacing:.07em;
    text-transform:uppercase;
    margin-bottom:14px;
}
.map-offers-panel h2{
    margin:0 0 10px!important;
}
.map-offers-panel>p{
    margin:0 0 22px;
    color:#647084;
    line-height:1.55;
    font-size:14px;
}
.map-offer-list{
    display:flex;
    flex-direction:column;
    gap:12px;
}
.map-offer-item{
    display:grid;
    grid-template-columns:82px minmax(0,1fr);
    gap:13px;
    align-items:center;
    padding:11px;
    border-radius:16px;
    background:#fff;
    border:1px solid #e2e8f0;
    text-decoration:none;
    color:var(--navy);
    transition:.18s ease;
}
.map-offer-item:hover,
.map-offer-item.active{
    border-color:#d7a24f;
    background:#fff8ee;
    box-shadow:0 14px 30px rgba(7,25,54,.08);
    transform:translateY(-1px);
}
.map-offer-item img{
    width:82px;
    height:66px;
    border-radius:12px;
    object-fit:cover;
    display:block;
}
.map-offer-item b,
.map-offer-item small,
.map-offer-item strong{
    display:block;
}
.map-offer-item b{
    font-size:13px;
    line-height:1.25;
    margin-bottom:4px;
}
.map-offer-item small{
    color:#687487;
    font-size:11px;
    margin-bottom:5px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.map-offer-item strong{
    color:#b87316;
    font-size:13px;
    font-weight:900;
}
.immo-map-pin span{
    display:block;
    width:34px;
    height:34px;
    border-radius:50% 50% 50% 0;
    background:linear-gradient(180deg,#d49a3a,#b87316);
    border:3px solid #fff;
    transform:rotate(-45deg);
    box-shadow:0 10px 22px rgba(7,25,54,.24);
}
.immo-map-pin span:after{
    content:"";
    position:absolute;
    width:9px;
    height:9px;
    border-radius:50%;
    background:#fff;
    left:50%;
    top:50%;
    transform:translate(-50%,-50%);
}
.map-popup{
    display:grid;
    gap:5px;
    min-width:185px;
}
.map-popup strong{
    color:#071936;
    font-size:14px;
    line-height:1.25;
}
.map-popup small{
    color:#647084;
}
.map-popup b{
    color:#b87316;
}
.map-popup a{
    margin-top:4px;
    color:#071936;
    font-weight:900;
    text-decoration:none;
}
.theme-dark .map-card-live,
.theme-dark .map-offers-panel,
.theme-dark .map-offer-item{
    background:#0d1b2f;
    border-color:#26354b;
    color:#f5f7fb;
}
.theme-dark .map-card-head p,
.theme-dark .map-offers-panel>p,
.theme-dark .map-offer-item small{
    color:#a9b5c7;
}
.theme-dark .map-card-head a,
.theme-dark .map-offer-item b{
    color:#f5f7fb;
}
.theme-dark .map-offer-item:hover,
.theme-dark .map-offer-item.active{
    background:#172740;
    border-color:#d7a24f;
}
@media(max-width:1180px){
    .map-section-live{grid-template-columns:1fr}
    .map-card-live{padding:24px}
    .immo-map{height:360px}
    .map-offers-panel{border-top:1px solid #e5e9ef!important;padding:28px 24px!important}
    .map-offer-list{display:grid;grid-template-columns:repeat(2,1fr)}
}
@media(max-width:720px){
    .map-card-head{flex-direction:column;gap:10px}
    .immo-map{height:320px;border-radius:14px}
    .map-offer-list{grid-template-columns:1fr}
    .map-offer-item{grid-template-columns:76px 1fr}
    .map-offer-item img{width:76px;height:62px}
}


/* Phase 22.1 – Startseiten-Servicekacheln aktiviert */
.service-grid-linked{
    align-items:stretch;
}
.service-card{
    display:block;
    height:100%;
    color:inherit;
    text-decoration:none;
}
.service-card article{
    height:100%;
    transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.service-card:hover article{
    transform:translateY(-3px);
    box-shadow:0 18px 35px rgba(7,25,54,.10);
    border-color:rgba(201,139,46,.35);
}
.service-card strong{
    color:#b87316;
    font-size:13px;
    font-weight:800;
    align-self:end;
}

/* Phase 22.1 – Immobilienbewertung */
.valuation-hero{
    padding:72px 0 48px;
    background:linear-gradient(180deg,#f8fafc 0%,#fff 100%);
}
.valuation-grid{
    display:grid;
    grid-template-columns:minmax(0,1fr) 520px;
    gap:42px;
    align-items:start;
}
.valuation-copy h1{
    margin:12px 0 18px;
    color:#102033;
    font-size:clamp(42px,5vw,76px);
    line-height:.95;
    letter-spacing:-.06em;
}
.valuation-copy p{
    margin:0;
    max-width:720px;
    color:#66758b;
    font-size:18px;
    line-height:1.75;
}
.valuation-benefits{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin-top:28px;
}
.valuation-benefits span{
    padding:10px 14px;
    border-radius:999px;
    background:#fff;
    border:1px solid rgba(16,32,51,.08);
    font-weight:900;
    color:#23344d;
    box-shadow:0 14px 34px rgba(16,32,51,.06);
}
.valuation-form{
    background:#fff;
    border:1px solid rgba(16,32,51,.1);
    border-radius:34px;
    box-shadow:0 30px 90px rgba(16,32,51,.11);
    padding:30px;
}
.valuation-form h2{
    margin:0 0 22px;
    color:#102033;
    font-size:28px;
    letter-spacing:-.04em;
}
.valuation-form-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:16px;
}
.valuation-form label{
    display:grid;
    gap:8px;
    font-weight:900;
    color:#25354c;
}
.valuation-form label.full{
    grid-column:1/-1;
}
.valuation-form input,
.valuation-form select,
.valuation-form textarea{
    width:100%;
    border:1px solid rgba(16,32,51,.13);
    border-radius:16px;
    padding:13px 14px;
    background:#fff;
    font:inherit;
    color:#102033;
}
.valuation-form textarea{
    resize:vertical;
    min-height:96px;
}
.valuation-submit{
    margin-top:20px;
    width:100%;
    min-height:54px;
    border:0;
    border-radius:999px;
    background:#102033;
    color:#fff;
    font-weight:950;
    font-size:16px;
    cursor:pointer;
}
.valuation-info{
    padding:20px 0 90px;
    background:#fff;
}
.valuation-info-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:22px;
}
.valuation-info-grid article{
    padding:28px;
    border-radius:28px;
    border:1px solid rgba(16,32,51,.08);
    box-shadow:0 18px 50px rgba(16,32,51,.06);
}
.valuation-info-grid strong{
    display:grid;
    place-items:center;
    width:42px;
    height:42px;
    border-radius:50%;
    background:#c79a42;
    color:#111827;
    font-weight:950;
}
.valuation-info-grid h3{
    margin:18px 0 8px;
    color:#102033;
}
.valuation-info-grid p{
    margin:0;
    color:#65758b;
    line-height:1.65;
}
@media(max-width:1050px){
    .valuation-grid{grid-template-columns:1fr}
    .valuation-form{max-width:720px}
}
@media(max-width:680px){
    .valuation-hero{padding:48px 0}
    .valuation-form{padding:22px;border-radius:26px}
    .valuation-form-grid,.valuation-info-grid{grid-template-columns:1fr}
    .valuation-copy h1{font-size:40px}
}


/* Phase 22.2 – echte Lagekarte auf der Immobilien-Detailseite
   Nur der vorhandene Kartenplatzhalter im Bereich "Lage" wird ersetzt. */
.location-map-live{
    position:relative;
    height:380px;
    margin-top:22px;
    border-radius:22px;
    overflow:hidden;
    background:#edf1f6;
    border:1px solid rgba(20,32,52,.08);
}
.property-map{
    width:100%;
    height:100%;
    min-height:380px;
    background:#edf1f6;
}
.property-map .leaflet-container,
.location-map-live .leaflet-container{
    width:100%;
    height:100%;
}
.property-map-fallback{
    position:absolute;
    inset:0;
    display:grid;
    place-items:center;
    padding:24px;
    text-align:center;
    background:#f7f8fb;
    color:#667284;
    font-weight:800;
    z-index:2;
}
.property-map-pin{
    width:34px!important;
    height:34px!important;
    border-radius:50%;
    background:#fff;
    border:3px solid #c98b2e;
    box-shadow:0 12px 28px rgba(7,25,54,.25);
}
.property-map-pin span{
    display:block;
    width:12px;
    height:12px;
    border-radius:50%;
    background:#071936;
    margin:8px auto 0;
}
.property-map-popup strong,
.property-map-popup small,
.property-map-popup b,
.property-map-popup a{
    display:block;
}
.property-map-popup strong{
    color:#071936;
    font-size:14px;
    margin-bottom:5px;
}
.property-map-popup small{
    color:#667284;
    margin-bottom:6px;
}
.property-map-popup b{
    color:#c98b2e;
    margin-bottom:7px;
}
.property-map-popup a{
    color:#071936;
    font-weight:900;
    text-decoration:none;
}
@media(max-width:820px){
    .location-map-live,
    .property-map{
        height:320px;
        min-height:320px;
    }
}

/* Premium-Bereich klickbar + Hover */

.premium-grid article,
.premium-grid aside{
    cursor:pointer;
    transition:all .25s ease;
}

.premium-grid article:hover,
.premium-grid aside:hover{
    transform:translateY(-4px);
    box-shadow:0 20px 40px rgba(7,25,54,.12);
}

.premium-grid article:hover h3,
.premium-grid aside:hover h3{
    color:#c98b2e;
}

.premium-grid aside button{
    cursor:pointer;
}
