/* =========================================================================
   Kanduit Schulbau-Monitor — Design tokens & components
   Brand: Petrol (#0E7490), Ink (#0C1517), Archivo + IBM Plex Mono
   ========================================================================= */
:root{
  /* Petrol scale */
  --petrol-900:#072c39; --petrol-800:#0a465a; --petrol-700:#155e75;
  --petrol-600:#0e7490; --petrol-500:#1597b5; --petrol-400:#38a9c4;
  --petrol-300:#84cede; --petrol-200:#b6e3ee; --petrol-100:#e4f4f8;
  /* Cool neutrals */
  --neutral-900:#0f172a; --neutral-800:#1e293b; --neutral-700:#334155;
  --neutral-600:#475569; --neutral-500:#64748b; --neutral-400:#94a3b8;
  --neutral-300:#cbd5e1; --neutral-200:#e2e8f0; --neutral-100:#f1f5f9;
  --ink:#0c1517; --paper:#fbfcfc; --white:#ffffff;
  /* Status */
  --ok:#2f8f6b; --warn:#c9931f; --error:#c24b57; --info:#1391ae;
  /* Data viz */
  --dv-petrol:#0e7490; --dv-cyan:#1fa2c4; --dv-green:#2f8f6b; --dv-lime:#7cb342;
  --dv-amber:#c9931f; --dv-orange:#d97a2b; --dv-coral:#c24b57; --dv-violet:#7c5ba6;
  /* Condition buckets */
  --cond-1:#2f8f6b; --cond-2:#7cb342; --cond-3:#d97a2b; --cond-4:#c24b57;

  --font-display:'Archivo', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono:'IBM Plex Mono', ui-monospace, 'SF Mono', Menlo, monospace;
  --r-card:14px; --r-pill:999px;
  --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:24px; --sp-6:32px; --sp-7:48px;
  --shadow:0 1px 2px rgba(12,21,23,.04), 0 8px 24px -12px rgba(12,21,23,.18);
  --t-micro:.72rem; --t-small:.86rem;
}

*{box-sizing:border-box}
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--font-display); font-size:16px; line-height:1.55;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{ margin:0; letter-spacing:-.02em; text-wrap:balance; }
a{ color:var(--petrol-700); text-decoration:none; }
.mono{ font-family:var(--font-mono); font-variant-numeric:tabular-nums; }
.eyebrow{
  font-family:var(--font-mono); font-size:var(--t-micro); text-transform:uppercase;
  letter-spacing:.1em; color:var(--neutral-500); margin:0 0 6px;
}

/* ---------------- Top bar ---------------- */
.topbar{
  position:sticky; top:0; z-index:50; display:flex; align-items:center; gap:var(--sp-4);
  padding:12px clamp(16px,3vw,32px); background:rgba(251,252,252,.88);
  backdrop-filter:saturate(140%) blur(8px); border-bottom:1px solid var(--neutral-200);
}
.brand{ display:flex; align-items:center; gap:10px; font-family:var(--font-display);
  font-weight:700; font-size:1.12rem; letter-spacing:-.02em; white-space:nowrap; }
.brand .sub{ color:var(--neutral-500); font-weight:500; }
.tabs{ display:flex; gap:2px; margin-left:var(--sp-5); flex-wrap:wrap; }
.tab{
  font-family:var(--font-mono); font-size:var(--t-micro); text-transform:uppercase;
  letter-spacing:.06em; padding:8px 14px; border-radius:var(--r-pill);
  color:var(--neutral-600); cursor:pointer; border:none; background:transparent; transition:.15s;
}
.tab:hover{ background:var(--neutral-100); color:var(--neutral-800); }
.tab.active{ background:var(--petrol-100); color:var(--petrol-700); }
.topbar .right{ margin-left:auto; display:flex; align-items:center; gap:var(--sp-3); }
.stand{ font-family:var(--font-mono); font-size:var(--t-micro); color:var(--neutral-500);
  text-transform:uppercase; letter-spacing:.08em; }
.demo-pill{ font-family:var(--font-mono); font-size:var(--t-micro); letter-spacing:.06em;
  background:#fbf1dc; color:#8a6410; padding:4px 10px; border-radius:var(--r-pill); white-space:nowrap; }

.kbtn{ font-family:var(--font-display); font-weight:600; font-size:.9rem; border:none;
  border-radius:10px; padding:9px 16px; cursor:pointer; transition:.15s; }
.kbtn.primary{ background:var(--petrol-600); color:#fff; }
.kbtn.primary:hover{ background:var(--petrol-700); }
.kbtn.ghost{ background:transparent; color:var(--neutral-700); box-shadow:inset 0 0 0 1px var(--neutral-300); }
.kbtn.ghost:hover{ background:var(--neutral-100); }

/* ---------------- Layout ---------------- */
.wrap{ max-width:1320px; margin:0 auto; padding:clamp(16px,3vw,28px) clamp(16px,3vw,32px); }
.view{ display:none; }
.view.active{ display:block; animation:fade .25s ease; }
@keyframes fade{ from{opacity:0; transform:translateY(4px)} to{opacity:1; transform:none} }
.view-head{ margin-bottom:var(--sp-5); }
.view-head h2{ font-size:1.7rem; font-weight:700; }
.view-head p{ margin:6px 0 0; color:var(--neutral-600); max-width:70ch; }

.grid{ display:grid; gap:var(--sp-4); }
.g2{ grid-template-columns:repeat(2,1fr); }
.g3{ grid-template-columns:repeat(3,1fr); }
.g4{ grid-template-columns:repeat(4,1fr); }
.g6{ grid-template-columns:repeat(6,1fr); }
@media(max-width:1080px){ .g4,.g6{grid-template-columns:repeat(3,1fr)} .g3{grid-template-columns:repeat(2,1fr)} }
@media(max-width:760px){ .g2,.g3,.g4,.g6{grid-template-columns:1fr 1fr} }
@media(max-width:520px){ .g2,.g3,.g4,.g6{grid-template-columns:1fr} }

.card{ background:var(--white); border:1px solid var(--neutral-200); border-radius:var(--r-card);
  padding:var(--sp-5); box-shadow:var(--shadow); }
.card .card-title{ font-family:var(--font-display); font-weight:600; font-size:1.02rem; }
.card .card-sub{ font-family:var(--font-mono); font-size:var(--t-micro); text-transform:uppercase;
  letter-spacing:.07em; color:var(--neutral-500); margin-top:2px; }

/* ---------------- Stat cards ---------------- */
.stat{ background:var(--white); border:1px solid var(--neutral-200); border-radius:var(--r-card);
  padding:18px 20px; box-shadow:var(--shadow); display:flex; flex-direction:column; gap:4px; }
.stat .k{ font-family:var(--font-mono); font-size:var(--t-micro); text-transform:uppercase;
  letter-spacing:.08em; color:var(--neutral-500); }
.stat .v{ font-family:var(--font-display); font-weight:800; font-size:2rem; letter-spacing:-.03em; line-height:1.05; }
.stat .d{ font-size:var(--t-small); color:var(--neutral-500); }
.stat.ink{ background:var(--ink); border-color:var(--ink); }
.stat.ink .k{ color:var(--petrol-300); } .stat.ink .v{ color:#fff; } .stat.ink .d{ color:var(--neutral-300); }
.stat.petrol{ background:var(--petrol-600); border-color:var(--petrol-600); }
.stat.petrol .k{ color:rgba(255,255,255,.8); } .stat.petrol .v{ color:#fff; } .stat.petrol .d{ color:rgba(255,255,255,.85); }

/* ---------------- Tags / pills ---------------- */
.pill{ display:inline-flex; align-items:center; gap:6px; font-family:var(--font-mono);
  font-size:var(--t-micro); letter-spacing:.03em; padding:3px 9px; border-radius:var(--r-pill);
  background:var(--neutral-100); color:var(--neutral-700); white-space:nowrap; }
.pill .dot{ width:7px; height:7px; border-radius:50%; }
.zk{ font-weight:600; }
.zk-1{ background:#e6f3ee; color:#1f6b4f; } .zk-2{ background:#eef6e2; color:#4f7a1e; }
.zk-3{ background:#fbeede; color:#9a5212; } .zk-4{ background:#f8e3e6; color:#9a2f3a; }
.flag{ background:#f8e3e6; color:#9a2f3a; }
.status-geplant{ background:var(--petrol-100); color:var(--petrol-700); }
.status-inumsetzung,.status-in.umsetzung{ background:#eef6e2; color:#4f7a1e; }
.status-abgeschlossen{ background:#e6f3ee; color:#1f6b4f; }
.status-nichtbegonnen{ background:var(--neutral-100); color:var(--neutral-600); }

/* ---------------- Map ---------------- */
.map-layout{ display:grid; grid-template-columns:1.55fr 1fr; gap:var(--sp-4); align-items:start; }
@media(max-width:980px){ .map-layout{ grid-template-columns:1fr; } }
.map-toolbar{ display:flex; flex-wrap:wrap; gap:6px; margin-bottom:var(--sp-4); }
.seg{ display:inline-flex; background:var(--neutral-100); border-radius:10px; padding:3px; gap:2px; }
.seg button{ font-family:var(--font-mono); font-size:var(--t-micro); text-transform:uppercase;
  letter-spacing:.05em; border:none; background:transparent; color:var(--neutral-600);
  padding:7px 12px; border-radius:8px; cursor:pointer; }
.seg button.active{ background:#fff; color:var(--petrol-700); box-shadow:var(--shadow); }
.bezirk{ stroke:#fff; stroke-width:1.2; cursor:pointer; transition:filter .15s, opacity .15s; }
.bezirk:hover{ filter:brightness(1.06); }
.bezirk.dim{ opacity:.35; }
.bezirk.sel{ stroke:var(--ink); stroke-width:2.2; }
.bez-label{ font-family:var(--font-mono); font-size:11px; font-weight:600; fill:#fff;
  paint-order:stroke; stroke:rgba(12,21,23,.35); stroke-width:2.4px; pointer-events:none; }
.school-dot{ stroke:#fff; stroke-width:.8; cursor:pointer; }
.legend{ display:flex; flex-wrap:wrap; gap:14px; margin-top:var(--sp-4); align-items:center; }
.legend .item{ display:flex; align-items:center; gap:7px; font-size:var(--t-small); color:var(--neutral-600); }
.legend .sw{ width:18px; height:12px; border-radius:3px; }
.checkbox{ display:inline-flex; align-items:center; gap:7px; font-size:var(--t-small);
  color:var(--neutral-700); cursor:pointer; user-select:none; }

/* ---------------- Tooltip ---------------- */
.tt{ position:fixed; z-index:200; pointer-events:none; background:var(--ink); color:#fff;
  border-radius:10px; padding:10px 12px; font-size:var(--t-small); box-shadow:0 10px 30px -8px rgba(0,0,0,.5);
  max-width:280px; opacity:0; transition:opacity .12s; }
.tt.show{ opacity:1; }
.tt b{ font-family:var(--font-display); font-weight:700; }
.tt .row{ display:flex; justify-content:space-between; gap:18px; margin-top:3px; color:var(--neutral-300); }
.tt .row span:last-child{ font-family:var(--font-mono); color:#fff; }

/* ---------------- Table ---------------- */
.filters{ display:flex; flex-wrap:wrap; gap:var(--sp-3); align-items:flex-end; margin-bottom:var(--sp-4); }
.field{ display:flex; flex-direction:column; gap:5px; }
.field label{ font-family:var(--font-mono); font-size:var(--t-micro); text-transform:uppercase;
  letter-spacing:.07em; color:var(--neutral-500); }
.field select,.field input{ font-family:var(--font-display); font-size:.9rem; color:var(--ink);
  background:#fff; border:1px solid var(--neutral-300); border-radius:9px; padding:8px 11px; min-width:150px; }
.field input{ min-width:220px; }
.field select:focus,.field input:focus{ outline:2px solid var(--petrol-300); border-color:var(--petrol-400); }
.table-wrap{ background:#fff; border:1px solid var(--neutral-200); border-radius:var(--r-card);
  box-shadow:var(--shadow); overflow-x:auto; overflow-y:hidden; -webkit-overflow-scrolling:touch; }
table{ width:100%; min-width:920px; border-collapse:collapse; font-size:.9rem; }
thead th{ position:sticky; top:0; background:var(--neutral-100); text-align:left;
  font-family:var(--font-mono); font-size:var(--t-micro); text-transform:uppercase; letter-spacing:.06em;
  color:var(--neutral-600); padding:11px 14px; cursor:pointer; white-space:nowrap; border-bottom:1px solid var(--neutral-200); }
thead th.num{ text-align:right; }
thead th:hover{ color:var(--petrol-700); }
thead th .arr{ opacity:.4; }
thead th.sorted .arr{ opacity:1; color:var(--petrol-600); }
tbody td{ padding:10px 14px; border-bottom:1px solid var(--neutral-100); white-space:nowrap; }
/* School-name column: allow wrapping + cap width so long names don't push other columns off-screen */
thead th:first-child{ min-width:220px; }
tbody td:first-child{ white-space:normal; overflow-wrap:anywhere; min-width:220px; max-width:300px; line-height:1.35; }
tbody td.num{ text-align:right; font-family:var(--font-mono); font-variant-numeric:tabular-nums; }
tbody tr{ cursor:pointer; }
tbody tr:hover{ background:var(--petrol-100); }
tbody tr:last-child td{ border-bottom:none; }
.bar-cell{ position:relative; min-width:84px; }
.bar-cell .barbg{ height:7px; border-radius:4px; background:var(--neutral-200); overflow:hidden; }
.bar-cell .barfill{ height:100%; border-radius:4px; }
.tcount{ font-family:var(--font-mono); font-size:var(--t-small); color:var(--neutral-500); margin-bottom:8px; }

/* ---------------- Drawer ---------------- */
.scrim{ position:fixed; inset:0; background:rgba(12,21,23,.45); opacity:0; pointer-events:none;
  transition:.2s; z-index:100; }
.scrim.show{ opacity:1; pointer-events:auto; }
.drawer{ position:fixed; top:0; right:0; height:100%; width:min(480px,94vw); background:var(--paper);
  box-shadow:-20px 0 60px -20px rgba(0,0,0,.4); transform:translateX(100%); transition:transform .26s cubic-bezier(.4,0,.2,1);
  z-index:110; overflow-y:auto; }
.drawer.show{ transform:none; }
.drawer-head{ position:sticky; top:0; background:var(--ink); color:#fff; padding:20px 24px; }
.drawer-head .close{ position:absolute; top:16px; right:18px; background:rgba(255,255,255,.12);
  border:none; color:#fff; width:32px; height:32px; border-radius:8px; cursor:pointer; font-size:1.1rem; }
.drawer-head h3{ font-size:1.3rem; font-weight:700; padding-right:36px; }
.drawer-head .meta{ font-family:var(--font-mono); font-size:var(--t-small); color:var(--petrol-300); margin-top:6px; }
.drawer-body{ padding:22px 24px; }
.kv{ display:grid; grid-template-columns:auto 1fr; gap:8px 16px; font-size:.92rem; margin:14px 0; }
.kv dt{ color:var(--neutral-500); } .kv dd{ margin:0; font-family:var(--font-mono); text-align:right; }
.gauge-wrap{ display:flex; align-items:center; gap:18px; margin:6px 0 16px; }
.section-label{ font-family:var(--font-mono); font-size:var(--t-micro); text-transform:uppercase;
  letter-spacing:.08em; color:var(--neutral-500); margin:20px 0 8px; }
.prio-bar{ display:flex; flex-direction:column; gap:6px; }
.prio-row{ display:grid; grid-template-columns:140px 1fr 48px; align-items:center; gap:10px; font-size:var(--t-small); }
.prio-row .tr{ height:9px; border-radius:5px; background:var(--neutral-200); overflow:hidden; }
.prio-row .tr i{ display:block; height:100%; border-radius:5px; }
.prio-row .pv{ font-family:var(--font-mono); text-align:right; color:var(--neutral-600); }

/* ---------------- Charts (SVG) ---------------- */
.chart{ width:100%; }
.axis line, .axis path{ stroke:var(--neutral-200); }
.gridline{ stroke:var(--neutral-200); stroke-width:1; }
.axis-txt{ font-family:var(--font-mono); font-size:10px; fill:var(--neutral-500); }
.bar{ transition:opacity .15s; cursor:default; }
.bar:hover{ opacity:.82; }
.bar-label{ font-family:var(--font-mono); font-size:10px; fill:var(--neutral-600); }
.dot-school{ cursor:pointer; }
.note{ font-size:var(--t-small); color:var(--neutral-500); margin-top:10px; }

/* ---------------- Scenario / Fahrplan ---------------- */
.scenario-controls{ display:flex; flex-wrap:wrap; gap:var(--sp-5); align-items:center; }
.slider-field{ display:flex; flex-direction:column; gap:6px; min-width:260px; }
.slider-field input[type=range]{ width:100%; accent-color:var(--petrol-600); }
.scenario-out{ display:flex; gap:var(--sp-6); }
.scenario-out .big{ font-family:var(--font-display); font-weight:800; font-size:1.8rem; letter-spacing:-.02em; }
.weights{ display:grid; grid-template-columns:repeat(4,1fr); gap:var(--sp-3); }
@media(max-width:760px){ .weights{ grid-template-columns:1fr 1fr; } }
.weight{ background:var(--neutral-100); border-radius:10px; padding:12px 14px; }
.weight .wv{ font-family:var(--font-display); font-weight:800; font-size:1.5rem; color:var(--petrol-700); }
.weight .wl{ font-size:var(--t-small); color:var(--neutral-600); }

.footer{ background:var(--ink); color:var(--neutral-300); padding:28px clamp(16px,4vw,40px); margin-top:var(--sp-7); }
.footer .wrap{ display:flex; flex-wrap:wrap; gap:18px; justify-content:space-between; align-items:center; padding:0; }
.footer .src{ font-size:var(--t-small); max-width:62ch; line-height:1.5; }
.footer .mono{ font-size:var(--t-micro); text-transform:uppercase; letter-spacing:.08em; color:var(--neutral-500); }

/* ---------------- Mobile / small screens ---------------- */
@media(max-width:760px){
  .topbar{ flex-wrap:wrap; gap:10px 12px; padding:10px 16px; }
  .brand{ font-size:1.02rem; }
  .topbar .right{ margin-left:auto; gap:8px; flex-wrap:wrap; justify-content:flex-end; }
  .stand{ display:none; }
  .tabs{ order:3; width:100%; margin-left:0; flex-wrap:nowrap; overflow-x:auto;
    -webkit-overflow-scrolling:touch; gap:4px; padding-bottom:2px; scrollbar-width:none; }
  .tabs::-webkit-scrollbar{ display:none; }
  .tab{ flex:0 0 auto; }
  /* filters fill the available width instead of overflowing */
  .filters{ gap:10px 12px; }
  .filters .field{ flex:1 1 150px; min-width:0; }
  .filters .field select, .filters .field input{ min-width:0; width:100%; }
  .view-head h2{ font-size:1.45rem; }
}

@media print{
  .topbar, .footer, .map-toolbar .seg, .filters, .drawer, .scrim, .kbtn{ display:none !important; }
  .view{ display:block !important; page-break-after:always; }
  body{ background:#fff; }
}
