/* ============================================================
   WERTATLAS.NRW — Styleguide v1 (Phase 1, Design-Freeze-Vorlage)
   Palette: Schwarz #101014 · Rot #C8102E · Gold #E6B31E
   Typo: Georgia (Headlines) · System-Sans (Text)
   ============================================================ */
:root{
  --schwarz:#101014; --schwarz-2:#1a1a20;
  --rot:#C8102E; --rot-dunkel:#a30d26;
  --gold:#E6B31E; --gold-hell:#f5cf5a; --gold-bg:#fdf6e3;
  --paper:#faf9f7; --weiss:#fff;
  --text:#26262b; --grau:#6b6b70; --linie:#e8e6e2;
  --radius:12px; --shadow:0 2px 14px rgba(16,16,20,.08);
  --serif:Georgia,'Times New Roman',serif;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Arial,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--text);background:var(--paper);line-height:1.65;font-size:16px}
img,svg{max-width:100%;display:block}
a{color:var(--rot);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1140px;margin:0 auto;padding:0 22px}

/* Prototyp-Hinweis */
.proto{background:var(--gold);color:var(--schwarz);text-align:center;font-size:12.5px;letter-spacing:.6px;padding:6px 10px;font-weight:600}

/* Topbar + Header */
.topbar{background:var(--schwarz);color:#cfcfd6;font-size:12.5px;letter-spacing:1.2px;text-transform:uppercase}
.topbar .wrap{display:flex;justify-content:space-between;padding-top:7px;padding-bottom:7px}
.topbar b{color:var(--gold);font-weight:600}
header.site{background:var(--weiss);border-bottom:1px solid var(--linie);position:sticky;top:0;z-index:50}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:12px;padding-bottom:12px;gap:20px}
.logo img,.logo svg{height:46px;width:auto}
nav.main{display:flex;gap:26px;align-items:center;font-size:14.5px;font-weight:600;letter-spacing:.3px}
nav.main a{color:var(--schwarz)}
nav.main a:hover{color:var(--rot);text-decoration:none}
.btn{display:inline-block;background:var(--rot);color:#fff !important;padding:11px 22px;border-radius:8px;font-weight:700;font-size:15px;border:none;cursor:pointer;letter-spacing:.3px}
.btn:hover{background:var(--rot-dunkel);text-decoration:none}
.btn.gold{background:var(--gold);color:var(--schwarz) !important}
.btn.gold:hover{background:var(--gold-hell)}
.btn.ghost{background:transparent;color:var(--schwarz) !important;border:2px solid var(--schwarz)}
.btn.big{padding:15px 32px;font-size:16.5px}

/* Hero */
.hero{background:linear-gradient(160deg,var(--schwarz) 0%,var(--schwarz-2) 60%,#26202a 100%);color:#fff;padding:72px 0 64px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:5px;background:linear-gradient(90deg,var(--schwarz) 0 33%,var(--rot) 33% 66%,var(--gold) 66% 100%)}
.eyebrow{display:inline-block;color:var(--gold);font-size:12.5px;letter-spacing:2.4px;text-transform:uppercase;font-weight:700;margin-bottom:16px}
.hero h1{font-family:var(--serif);font-size:clamp(30px,4.4vw,50px);line-height:1.15;font-weight:700;max-width:820px}
.hero h1 em{font-style:normal;color:var(--gold)}
.hero p.sub{margin-top:18px;font-size:18px;color:#d6d6dd;max-width:680px}
.hero .cta{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero .note{margin-top:18px;font-size:12.5px;color:#9a9aa4;max-width:720px}

/* Stat-Band */
.stats{background:var(--weiss);border-bottom:1px solid var(--linie)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat{padding:26px 18px;text-align:center;border-left:1px solid var(--linie)}
.stat:first-child{border-left:none}
.stat .num{font-family:var(--serif);font-size:34px;font-weight:700;color:var(--schwarz)}
.stat .num span{color:var(--rot)}
.stat .lbl{font-size:12.5px;letter-spacing:1.6px;text-transform:uppercase;color:var(--grau);margin-top:4px}

/* Sections */
section{padding:64px 0}
section.alt{background:var(--weiss);border-top:1px solid var(--linie);border-bottom:1px solid var(--linie)}
h2{font-family:var(--serif);font-size:clamp(24px,3vw,34px);color:var(--schwarz);margin-bottom:10px}
.lead{color:var(--grau);max-width:760px;margin-bottom:34px;font-size:17px}
.kicker{color:var(--rot);font-size:12px;letter-spacing:2.2px;text-transform:uppercase;font-weight:700;display:block;margin-bottom:8px}

/* City-Grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:18px}
.card{background:var(--weiss);border:1px solid var(--linie);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);transition:transform .15s}
a.card{color:inherit;display:block}
a.card:hover{transform:translateY(-3px);text-decoration:none;border-color:var(--gold)}
.card h3{font-family:var(--serif);font-size:21px;color:var(--schwarz)}
.card .meta{font-size:13px;color:var(--grau);margin:2px 0 12px}
.card .vals{display:flex;gap:18px}
.card .vals div b{display:block;font-size:19px;color:var(--schwarz)}
.card .vals div span{font-size:11.5px;letter-spacing:1px;text-transform:uppercase;color:var(--grau)}
.card .more{margin-top:14px;font-size:13.5px;font-weight:700;color:var(--rot)}

/* Tabellen */
table{width:100%;border-collapse:collapse;background:var(--weiss);border:1px solid var(--linie);border-radius:var(--radius);overflow:hidden;font-size:15px}
th{background:var(--schwarz);color:#fff;text-align:left;padding:12px 14px;font-size:12.5px;letter-spacing:1.2px;text-transform:uppercase;font-weight:600}
td{padding:12px 14px;border-top:1px solid var(--linie)}
tr:nth-child(even) td{background:#fcfbf9}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
.up{color:#1c7c3c;font-weight:700}.down{color:var(--rot);font-weight:700}.flat{color:var(--grau);font-weight:700}
.tbl-note{font-size:12.5px;color:var(--grau);margin-top:10px}

/* Karte */
#map{height:440px;border-radius:var(--radius);border:1px solid var(--linie);box-shadow:var(--shadow)}
.legend{display:flex;gap:18px;flex-wrap:wrap;margin-top:12px;font-size:13px;color:var(--grau)}
.legend i{display:inline-block;width:14px;height:14px;border-radius:3px;margin-right:6px;vertical-align:-2px}

/* Info-Boxen */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.panel{background:var(--weiss);border:1px solid var(--linie);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow)}
.panel.dark{background:var(--schwarz);color:#e8e8ee;border:none}
.panel.dark h3{color:#fff}
.panel h3{font-family:var(--serif);font-size:23px;margin-bottom:10px;color:var(--schwarz)}
.panel ul{margin:14px 0 18px 18px;font-size:15px}
.panel ul li{margin-bottom:6px}
.tag{display:inline-block;background:var(--gold-bg);color:#8a6a0d;border:1px solid #eedb9e;font-size:11.5px;letter-spacing:1.4px;text-transform:uppercase;font-weight:700;padding:4px 10px;border-radius:99px;margin-bottom:12px}
.panel.dark .tag{background:#2a2a33;color:var(--gold);border-color:#3a3a44}

/* FAQ */
details{background:var(--weiss);border:1px solid var(--linie);border-radius:10px;padding:18px 22px;margin-bottom:12px}
details summary{font-weight:700;cursor:pointer;font-size:16px;color:var(--schwarz)}
details p{margin-top:12px;color:var(--text);font-size:15px}

/* Breadcrumb & Stadt-Kopf */
.crumb{font-size:13px;color:var(--grau);padding:16px 0}
.city-head{background:linear-gradient(160deg,var(--schwarz),#241d27);color:#fff;padding:46px 0}
.city-head h1{font-family:var(--serif);font-size:clamp(28px,3.6vw,42px)}
.city-head .facts{display:flex;gap:34px;margin-top:22px;flex-wrap:wrap}
.city-head .facts div b{display:block;font-family:var(--serif);font-size:27px;color:var(--gold)}
.city-head .facts div span{font-size:12px;letter-spacing:1.4px;text-transform:uppercase;color:#a8a8b2}

/* Trend-Balken */
.bars{display:flex;align-items:flex-end;gap:10px;height:190px;padding:10px 4px 0}
.bars .bar{flex:1;background:linear-gradient(180deg,var(--gold),#caa11a);border-radius:5px 5px 0 0;position:relative;min-width:20px}
.bars .bar em{position:absolute;top:-24px;left:50%;transform:translateX(-50%);font-style:normal;font-size:11.5px;font-weight:700;color:var(--schwarz);white-space:nowrap}
.bars .bar span{position:absolute;bottom:-24px;left:50%;transform:translateX(-50%);font-size:11px;color:var(--grau)}
.bars-wrap{padding-bottom:30px}

/* Funnel */
.funnel{max-width:760px;margin:0 auto}
.steps{display:flex;gap:6px;margin-bottom:28px}
.steps div{flex:1;text-align:center;font-size:11.5px;letter-spacing:1px;text-transform:uppercase;color:var(--grau);padding-top:10px;border-top:4px solid var(--linie)}
.steps div.on{border-top-color:var(--rot);color:var(--schwarz);font-weight:700}
.steps div.done{border-top-color:var(--gold)}
.fstep{display:none;background:var(--weiss);border:1px solid var(--linie);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow)}
.fstep.show{display:block}
.fstep h2{font-size:26px}
.choice{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:22px 0}
.choice button{background:var(--paper);border:2px solid var(--linie);border-radius:10px;padding:20px 12px;cursor:pointer;font-size:15px;font-weight:700;color:var(--schwarz);font-family:var(--sans)}
.choice button:hover,.choice button.sel{border-color:var(--rot);background:#fdf2f4}
label{display:block;font-size:12.5px;letter-spacing:1.2px;text-transform:uppercase;font-weight:700;color:var(--grau);margin:16px 0 6px}
input[type=text],input[type=email],input[type=tel],input[type=number],select{width:100%;padding:12px 14px;border:1.5px solid var(--linie);border-radius:8px;font-size:16px;background:#fff;font-family:var(--sans)}
input:focus,select:focus{outline:none;border-color:var(--gold)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fnav{display:flex;justify-content:space-between;margin-top:28px;align-items:center}
.back{background:none;border:none;color:var(--grau);font-size:14px;cursor:pointer;font-weight:600}
.result-box{background:var(--schwarz);color:#fff;border-radius:var(--radius);padding:30px;text-align:center;margin:20px 0}
.result-box .range{font-family:var(--serif);font-size:clamp(26px,4vw,38px);font-weight:700;color:var(--gold);margin:8px 0 4px}
.result-box .per{font-size:14px;color:#b9b9c2}
.check{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:var(--grau);margin-top:14px}
.check input{margin-top:4px}
.trust{display:flex;gap:22px;flex-wrap:wrap;justify-content:center;font-size:12.5px;color:var(--grau);margin-top:20px;letter-spacing:.4px}
.trust span::before{content:"✓ ";color:var(--gold);font-weight:700}

/* Anliegen-Auswahlkarten (Radio) */
.req{color:var(--rot);font-weight:700}
.rcards{display:flex;flex-direction:column;gap:12px;margin:14px 0 4px}
.rcard{display:flex;gap:14px;align-items:flex-start;background:#3a3a42;color:#fff;border:2px solid transparent;border-radius:12px;padding:16px 18px;cursor:pointer;transition:border-color .12s,background .12s}
.rcard:hover{border-color:var(--gold)}
.rcard.sel{border-color:var(--gold);background:#2e2e36}
.rcard input{margin-top:4px;width:18px;height:18px;accent-color:var(--gold);flex-shrink:0}
.rcard b{display:block;font-size:15.5px;line-height:1.35}
.rcard span{font-size:13px;color:#c9c9d1;display:block;margin-top:2px}
.rcard.err{border-color:var(--rot)}
.consent-info{background:var(--paper);border:1px solid var(--linie);border-radius:10px;padding:16px 18px;font-size:13px;color:var(--grau);line-height:1.6;margin-top:18px}

/* Zonen-Infobox (Schritt 3) */
.zone-box{background:var(--weiss);border:2px solid var(--gold);border-radius:16px;padding:24px 26px;margin:6px 0 26px;box-shadow:var(--shadow)}
.zone-box h3{font-family:var(--serif);font-size:21px;color:var(--schwarz);margin-bottom:4px}
.zone-box .zb-sub{font-size:14px;color:var(--grau);margin-bottom:16px}
.zone-box .zb-head{font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:#8a6a0d;background:var(--gold-bg);border:1px solid #eedb9e;border-radius:99px;display:inline-block;padding:4px 12px;font-weight:700;margin-bottom:14px}
.zb-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px 20px}
.zb-grid div span{display:block;font-size:10.5px;letter-spacing:1.3px;text-transform:uppercase;color:var(--grau);margin-bottom:2px}
.zb-grid div b{font-size:15.5px;color:var(--schwarz);font-variant-numeric:tabular-nums}
.zb-grid div b.hi{color:var(--rot);font-size:18px}
.zb-wide{grid-column:1/-1}

/* Adress-Autocomplete */
.ac-wrap{position:relative}
.ac-list{position:absolute;left:0;right:0;top:100%;background:#fff;border:1.5px solid var(--linie);border-top:none;border-radius:0 0 10px 10px;box-shadow:var(--shadow);z-index:30;max-height:240px;overflow-y:auto}
.ac-list div{padding:11px 14px;font-size:14.5px;cursor:pointer;border-top:1px solid var(--paper)}
.ac-list div:hover,.ac-list div.hot{background:var(--gold-bg)}
.ac-list small{color:var(--grau);display:block;font-size:12px}
.auto-hint{color:#b8912a;font-weight:700}

/* Rechtsseiten */
.legal{max-width:840px}
.legal h3{font-family:var(--serif);font-size:20px;color:var(--schwarz);margin:28px 0 8px}
.legal p,.legal li{font-size:14.5px}
.legal ul{margin:8px 0 12px 20px}
.legal .stand{font-size:12.5px;letter-spacing:1.4px;text-transform:uppercase;color:var(--grau);margin-top:34px}

/* Footer */
footer{background:var(--schwarz);color:#b9b9c2;padding:56px 0 30px;font-size:14px;margin-top:70px}
footer::before{content:"";display:block;height:5px;margin-top:-56px;margin-bottom:50px;background:linear-gradient(90deg,var(--schwarz) 0 33%,var(--rot) 33% 66%,var(--gold) 66% 100%)}
footer h5{color:#fff;font-size:13px;letter-spacing:1.8px;text-transform:uppercase;margin-bottom:14px}
footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:34px}
footer a{color:#b9b9c2;display:block;margin-bottom:8px;font-size:13.5px}
footer a:hover{color:var(--gold);text-decoration:none}
footer .fine{border-top:1px solid #2c2c34;margin-top:40px;padding-top:22px;font-size:12px;color:#84848e;line-height:1.7}
footer .brandline{font-family:var(--serif);font-size:20px;color:#fff;margin-bottom:10px}
footer .brandline b{color:var(--gold)}

@media(max-width:860px){
  .stats .wrap{grid-template-columns:repeat(2,1fr)}
  .stat{border-left:none;border-top:1px solid var(--linie)}
  .duo,.row2,footer .cols{grid-template-columns:1fr}
  nav.main{display:none}
}
