/* roofscan design tokens
   Struktur-Sprache: Propeller-Aero-Muster (flache Cards, minimaler Radius,
   KPI-Kacheln, 8er-Spacing, 1200px-Container, Line-SVG-Icons).
   Eingefaerbt in BBE-CI (#00ae3b). Typografie = WWA-Hausstil. */
:root{
  /* Farbe */
  --bg:#F6F8F6; --surface:#FFFFFF; --surface-2:#F0F4F1;
  --ink:#0D1B12; --dim:rgba(13,27,18,.56); --line:rgba(13,27,18,.10);
  --brand:#00AE3B; --brand-700:#018A2F; --brand-050:#E7F7ED;
  --warn:#E5A300; --bad:#D6453B; --ok:#00AE3B;
  /* Typografie */
  --disp:"Space Grotesk",system-ui,sans-serif;
  --body:"Inter",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --t-hero:clamp(34px,5vw,56px); --t-h2:32px; --t-h3:20px;
  --t-body:16px; --t-small:13px; --t-kpi:clamp(30px,3.4vw,42px);
  /* Raum (8er-Skala) */
  --s1:8px; --s2:16px; --s3:24px; --s4:32px; --s5:48px; --s6:64px;
  --container:1200px;
  /* Form */
  --r-sm:10px; --r:14px; --r-lg:20px; --r-pill:999px;
  --sh:0 1px 2px rgba(13,27,18,.06);
  --sh-2:0 10px 30px rgba(13,27,18,.10);
}
@media (prefers-color-scheme:dark){
  :root{--bg:#0B1310;--surface:#111B16;--surface-2:#0F1813;
    --ink:#EAF3EC;--dim:rgba(234,243,236,.60);--line:rgba(234,243,236,.12);
    --brand:#2BD46B;--brand-700:#19B254;--brand-050:rgba(43,212,107,.12);}
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--body);
  font-size:var(--t-body);line-height:1.55;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--disp);letter-spacing:-.02em;margin:0;font-weight:700}
.wrap{max-width:var(--container);margin:0 auto;padding:0 var(--s3)}
a{color:inherit}

/* Top-Bar */
.bar{position:sticky;top:0;z-index:30;background:color-mix(in srgb,var(--surface) 86%,transparent);
  backdrop-filter:saturate(1.2) blur(10px);border-bottom:1px solid var(--line)}
.bar .wrap{display:flex;align-items:center;gap:var(--s2);height:64px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--disp);font-weight:700;font-size:18px}
.dot{width:22px;height:22px;border-radius:7px;background:var(--brand);display:inline-grid;place-items:center;color:#fff}
.bar nav{margin-left:auto;display:flex;gap:var(--s3);font-size:14px;color:var(--dim)}
.bar nav a:hover{color:var(--ink)}

/* Hero */
.hero{padding:var(--s6) 0 var(--s4)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font:600 var(--t-small)/1 var(--mono);
  color:var(--brand-700);background:var(--brand-050);padding:7px 12px;border-radius:var(--r-pill);
  text-transform:uppercase;letter-spacing:.08em}
.hero h1{font-size:var(--t-hero);line-height:1.04;margin:var(--s3) 0 var(--s2);max-width:16ch}
.hero p{font-size:18px;color:var(--dim);max-width:54ch;margin:0 0 var(--s3)}

/* Such-Box */
.search{display:flex;gap:10px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);padding:10px;box-shadow:var(--sh);max-width:640px}
.search input{flex:1;border:0;background:transparent;color:var(--ink);font:500 16px/1.4 var(--body);
  padding:10px 12px;outline:none}
.btn{border:0;cursor:pointer;font:600 15px/1 var(--body);border-radius:var(--r-sm);
  padding:14px 22px;display:inline-flex;align-items:center;gap:8px;transition:.15s}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-700)}
.btn-ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line)}
.hint{font-size:var(--t-small);color:var(--dim);margin-top:10px}

/* Sektion */
.section{padding:var(--s5) 0}
.section h2{font-size:var(--t-h2);margin-bottom:var(--s1)}
.section .lead{color:var(--dim);max-width:60ch;margin-bottom:var(--s4)}

/* KPI-Kacheln (Propeller-Muster) */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s2)}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:var(--s3);box-shadow:var(--sh)}
.kpi .ico{width:40px;height:40px;border-radius:var(--r-sm);background:var(--brand-050);
  color:var(--brand-700);display:grid;place-items:center;margin-bottom:var(--s2)}
.kpi .num{font:600 var(--t-kpi)/1 var(--mono);letter-spacing:-.02em}
.kpi .unit{font:500 14px/1 var(--mono);color:var(--dim);margin-left:4px}
.kpi .lab{font-size:14px;color:var(--dim);margin-top:6px}

/* Flaechen-Cards */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s2)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:var(--s3);box-shadow:var(--sh);transition:.18s}
.card:hover{box-shadow:var(--sh-2);transform:translateY(-2px)}
.card .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s2)}
.compass{width:46px;height:46px;border-radius:50%;border:2px solid var(--line);
  display:grid;place-items:center;font:700 14px/1 var(--mono);color:var(--brand-700)}
.tag{font:600 11px/1 var(--mono);padding:6px 10px;border-radius:var(--r-pill);text-transform:uppercase;letter-spacing:.06em}
.tag.ok{background:var(--brand-050);color:var(--brand-700)}
.tag.no{background:rgba(214,69,59,.10);color:var(--bad)}
.row{display:flex;justify-content:space-between;padding:7px 0;border-top:1px dashed var(--line);font-size:14px}
.row:first-of-type{border-top:0}
.row b{font-family:var(--mono);font-weight:600}

/* Footprint-Visual */
.viz{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--s3);display:grid;place-items:center;min-height:320px}
.viz svg{width:100%;height:auto;max-height:420px}

.muted{color:var(--dim)} .center{text-align:center}
.spinner{width:20px;height:20px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;
  border-radius:50%;animation:spin .7s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
.foot{padding:var(--s5) 0;border-top:1px solid var(--line);color:var(--dim);font-size:13px}
.hidden{display:none}
@media(max-width:860px){.kpis{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:1fr}}
