/* =====================================================================
   GALVORA / GeoRisk Cockpit  —  Stylesheet (v4, Light+Dark, Indigo/Kupfer)
   Marke: Mitternachts-Indigo #1E2F7A · Indigo-Hell #2C42A6 · Indigo-Tint #E9EBF5
   · Kupfer-Wortmarke. Light = Default, Dark via :root[data-theme="dark"].
   IBM Plex Sans + Space Grotesk (Display) · Mono für Daten-Tags.
   Sidebar-Navigation · Per-Company-Workspace · Drill-downs · Weltkarte.
   ===================================================================== */
@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&family=Space+Grotesk:wght@500;600;700&display=swap");

:root{
  /* ===================== LIGHT — „Normaler Mode" (Default) =====================
     Marke: Mitternachts-Indigo #1E2F7A (Primär/CTA) · Indigo Hell #2C42A6 (Hover/Verlauf)
     · Indigo-Tint #E9EBF5 (Flächen/Badge) · Kupfer als sekundärer Marken-Akzent (Wortmarke). */
  --bg:#F4F6FB; --surface-1:#FFFFFF; --surface-2:#F8FAFE; --surface-3:#EBEFF8;
  --hairline:rgba(30,47,122,.07); --border:rgba(30,47,122,.12); --border-strong:rgba(30,47,122,.22); --overlay:rgba(30,47,122,.05);
  --ink:#161E32; --ink-2:#39425A; --ink-3:#646E88; --ink-3-text:#5C6680;
  --accent:#1E2F7A; --accent-bright:#2C42A6; --accent-dim:#E9EBF5; --accent-line:rgba(30,47,122,.26); --accent-glow:rgba(30,47,122,.16); --on-accent:#FFFFFF;
  --copper:#FF6B35; --copper-bright:#FF8458;
  --mark-base:#8A96BC; --mark-accent:#1E2F7A;
  /* Severity = monochrome Intensitäts-Achse (grau→bernstein→rot), für Light abgedunkelt. --ok separat grün. */
  --sev-1:#64707E; --sev-2:#92722F; --sev-3:#B27916; --sev-4:#BE551E; --sev-5:#CE3539;
  --st-active:#CE3539; --st-watch:#B27916; --st-cleared:#7B85A0; --ok:#1A9E6E;
  --glow:rgba(30,47,122,.09); --dot:rgba(30,47,122,.05);
  --map-bg-a:#E9EDF7; --map-bg-b:#DDE3F2; --map-land-fill:rgba(30,47,122,.09); --map-land-stroke:rgba(30,47,122,.20); --map-grid:rgba(30,47,122,.05); --map-region:rgba(30,47,122,.30); --map-hover:#1E2F7A;
  --shadow-card:0 1px 2px rgba(20,28,64,.05),0 8px 22px -14px rgba(20,28,64,.14);
  --shadow-pop:0 24px 56px -22px rgba(20,28,64,.26);
  /* ===================== Theme-unabhängig ===================== */
  --font:"IBM Plex Sans",system-ui,-apple-system,"Segoe UI",Helvetica,Arial,sans-serif;
  --display:"Space Grotesk","IBM Plex Sans",system-ui,-apple-system,"Segoe UI",Helvetica,Arial,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,"SF Mono",Menlo,Consolas,monospace;
  --r-card:16px; --r-md:12px; --r-sm:8px; --r-pill:999px;
  --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:24px; --sp-6:32px;
  --fs-2xs:9px; --fs-2xs-h:9.5px; --fs-xs:10px; --fs-xs-h:10.5px; --fs-sm:11px; --fs-sm-h:11.5px; --fs-base:12px; --fs-base-h:12.5px; --fs-md:13px; --fs-md-h:13.5px; --fs-lg:14px; --fs-xl:15px; --fs-2xl:16px; --fs-3xl:17px; --fs-4xl:18px; --fs-5xl:22px;
}
:root[data-theme="dark"]{
  /* ===================== DARK — indigo-getöntes Mitternacht ===================== */
  --bg:#0A0E1A; --surface-1:#11162A; --surface-2:#161D34; --surface-3:#1F2844;
  --hairline:rgba(255,255,255,.05); --border:rgba(255,255,255,.09); --border-strong:rgba(255,255,255,.15); --overlay:rgba(255,255,255,.045);
  --ink:#ECEFF7; --ink-2:#AEB6CC; --ink-3:#7C86A0; --ink-3-text:#8A93AD;
  --accent:#3D54C9; --accent-bright:#8497EC; --accent-dim:rgba(61,84,201,.22); --accent-line:rgba(132,151,236,.40); --accent-glow:rgba(61,84,201,.42); --on-accent:#FFFFFF;
  --copper:#FF6B35; --copper-bright:#FF8A4D;
  --mark-base:#6B76A0; --mark-accent:#8497EC;
  --sev-1:#6E7A88; --sev-2:#A98B4E; --sev-3:#D99A3C; --sev-4:#DC6E38; --sev-5:#E5484D;
  --st-active:#E5484D; --st-watch:#E0A93E; --st-cleared:#7E8A99; --ok:#3DBE8B;
  --glow:rgba(61,84,201,.16); --dot:rgba(255,255,255,.022);
  --map-bg-a:#0d1722; --map-bg-b:#0a0f14; --map-land-fill:rgba(120,138,153,.10); --map-land-stroke:rgba(174,185,199,.18); --map-grid:rgba(255,255,255,.05); --map-region:rgba(174,185,199,.30); --map-hover:#FFFFFF;
  --shadow-card:0 1px 0 rgba(255,255,255,.04) inset,0 12px 32px -16px rgba(0,0,0,.7);
  --shadow-pop:0 24px 64px -24px rgba(0,0,0,.75);
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font);font-size:var(--fs-xl);line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"ss01";transition:background .25s ease,color .25s ease}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(900px 600px at 80% -10%,var(--glow),transparent 60%),radial-gradient(var(--dot) 1px,transparent 1px);background-size:auto,28px 28px}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}
.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}
.tag{font-family:var(--mono);font-size:var(--fs-xs);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3-text)}
/* Display-Schrift (Space Grotesk) auf Headlines/Werten — markanter Typo-Kontrast, serifenlos */
.sb-brand .word,.page-title,.panel-head h2,.stat .value,.drawer-title,.drawer-head .eyebrow,.brief-card .bt,.report h1,.report h2,.report h3,.scen-card .h .nm,.sec h4,.reg-card .rn,.explore-row .nm{font-family:var(--display)}
.page-title,.stat .value,.report h1{letter-spacing:-.02em}
.panel-head h2,.report h2,.drawer-title{letter-spacing:-.012em}
.dim{color:var(--ink-2)} .muted{color:var(--ink-3-text)}
.blitz{display:inline-flex;align-items:center;vertical-align:-3px;margin-right:5px}
.blitz svg,.blitz-badge svg{display:block;flex:none}
.blitz-badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:var(--fs-2xs);letter-spacing:.06em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent-line);background:var(--accent-dim);border-radius:var(--r-pill);padding:2px 8px;margin-right:6px;vertical-align:middle}
a{color:var(--accent-bright);text-decoration:none} a:hover{text-decoration:underline}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--r-sm)}
button{font:inherit;cursor:pointer}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.82)}}
.pulse{animation:pulse 2s ease-in-out infinite}
@keyframes rise{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.rise{animation:rise .35s ease both}

/* =====================================================================
   APP SHELL
   ===================================================================== */
.shell{display:grid;grid-template-columns:248px minmax(0,1fr);min-height:100vh}
.sidebar{position:sticky;top:0;height:100vh;overflow-y:auto;border-right:1px solid var(--border);background:linear-gradient(180deg,var(--surface-1),var(--bg));padding:var(--sp-4) var(--sp-3);display:flex;flex-direction:column;gap:var(--sp-4)}
.sb-brand{display:flex;align-items:center;gap:10px;padding:6px 8px}
.logo{display:flex;align-items:center;color:var(--ink)}
.sb-theme{margin-top:6px}
.sb-brand .word{font-weight:700;letter-spacing:.13em;font-size:16px}
.sb-brand .product{font-size:11px;color:var(--ink-3)}
.co-switch{position:relative}
.co-switch select{width:100%;font-family:var(--font);font-size:13px;color:var(--ink);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:10px 12px;cursor:pointer}
.co-switch .lbl{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin:0 0 5px 4px}
.nav{display:flex;flex-direction:column;gap:2px}
.nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-md);color:var(--ink-2);font-size:14px;font-weight:500;transition:.13s}
.nav a:hover{background:var(--surface-2);color:var(--ink);text-decoration:none}
.nav a.active{background:var(--accent-dim);color:var(--ink);box-shadow:inset 2px 0 0 var(--accent)}
.nav a svg{width:17px;height:17px;flex:none;opacity:.85}
.nav a.active svg{color:var(--accent-bright);opacity:1}
.nav a .badge{margin-left:auto;font-family:var(--mono);font-size:10px;background:var(--surface-3);color:var(--ink-2);border-radius:var(--r-pill);padding:1px 7px}
.nav a .badge.alert{background:rgba(206,52,57,.14);color:var(--sev-5)}
.nav-sep{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);padding:10px 12px 4px}
.sb-foot{margin-top:auto;font-family:var(--mono);font-size:10.5px;color:var(--ink-3);padding:8px 10px;line-height:1.5}
.sb-logout{display:flex;align-items:center;gap:8px;margin-top:8px;padding:9px 12px;border-radius:var(--r-md);border:1px solid var(--border);color:var(--ink-2);font-size:13px;font-weight:500;transition:.13s}
.sb-logout:hover{background:var(--surface-2);color:var(--ink);text-decoration:none;border-color:var(--border-strong)}
.sb-logout svg{width:16px;height:16px;flex:none;opacity:.85}
.jchip{font-family:var(--mono);font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-bright);border:1px solid var(--accent-line);border-radius:var(--r-pill);padding:1px 7px;margin-left:6px;vertical-align:middle}
.ref.primary{border-color:var(--accent);color:var(--accent-bright);background:var(--accent-dim);font-weight:600}
.snap-row{display:flex;gap:12px;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:12.5px}
.snap-row:last-child{border-bottom:0}
.snap-row .mono{font-family:var(--mono);color:var(--accent-bright);font-weight:600}
.dg-series{margin-bottom:16px}
.dg-h{font-size:13px;margin-bottom:8px}
.dg-bars{display:flex;gap:10px}
.dg-bar{flex:1;display:flex;flex-direction:column;align-items:center}
.dg-track{height:80px;width:100%;display:flex;align-items:flex-end;justify-content:center}
.dg-fill{width:62%;background:linear-gradient(180deg,var(--accent-bright),var(--accent));border-radius:4px 4px 0 0;min-height:3px}
.dg-v{font-size:12px;font-weight:600;margin-top:5px}
.dg-y{font-family:var(--mono);font-size:10px;color:var(--ink-3)}
/* ===== GeoRisk-Copilot (Chat) ===== */
.cq-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.cq{font-size:12px;color:var(--ink-2);background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-pill);padding:7px 12px;cursor:pointer;text-align:left;font-family:var(--font)}
.cq:hover{color:var(--ink);border-color:var(--accent);background:var(--surface-2)}
.copilot-msgs{max-height:52vh;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.cmsg{max-width:86%;font-size:13.5px;line-height:1.5}
.cmsg.user{align-self:flex-end}
.cmsg.user .b{background:var(--accent);color:var(--on-accent);border-radius:12px 12px 4px 12px;padding:10px 13px;font-weight:500}
.cmsg.ai{align-self:flex-start}
.cmsg.ai .b{background:var(--surface-2);border:1px solid var(--border);border-radius:12px 12px 12px 4px;padding:10px 13px;color:var(--ink)}
.cmsg .csrc{font-size:11px;color:var(--ink-3);margin-top:5px}
.cmsg .cmeta{font-family:var(--mono);font-size:10px;color:var(--ink-3);margin-top:3px}
.copilot-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--border)}
.copilot-input input{flex:1;font-family:var(--font);font-size:14px;color:var(--ink);background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);padding:11px 14px}
.copilot-input input:focus{outline:none;border-color:var(--accent)}

.content{min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4) clamp(16px,3vw,28px);position:sticky;top:0;z-index:20;background:linear-gradient(180deg,var(--bg) 72%,transparent);backdrop-filter:blur(6px)}
.page-title{font-size:var(--fs-4xl);font-weight:600}
.page-sub{font-size:12.5px;color:var(--ink-3);margin-top:1px}
.topbar-titles{min-width:0;display:flex;flex-direction:column}
.topbar .spacer{flex:1}
.view{padding:0 clamp(16px,3vw,28px) 44px;animation:rise .25s ease both}

.chip{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-2);border:1px solid var(--border);background:var(--surface-1);border-radius:var(--r-pill);padding:7px 12px;white-space:nowrap}
.chip .dot{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 10px rgba(61,190,139,.5)}
.chip.sim .dot{background:var(--st-watch);box-shadow:0 0 10px rgba(224,169,62,.5)}
/* dezenter Live-Puls (Radar-Ping) — NUR auf dem echten Live-Indikator, sparsam */
@keyframes livedot{0%{box-shadow:0 0 8px 0 rgba(61,190,139,.6),0 0 0 0 rgba(61,190,139,.45)}70%,100%{box-shadow:0 0 8px 0 rgba(61,190,139,.45),0 0 0 5px rgba(61,190,139,0)}}
.chip:not(.sim) .dot{animation:livedot 2.4s ease-out infinite}
@media (prefers-reduced-motion: reduce){.chip:not(.sim) .dot{animation:none}}
.chip b{color:var(--ink);font-weight:600}
.icon-btn{width:38px;height:38px;border-radius:var(--r-md);display:grid;place-items:center;background:var(--surface-1);border:1px solid var(--border);color:var(--ink-2);transition:.15s}
.icon-btn:hover{color:var(--ink);border-color:var(--border-strong);background:var(--surface-2)}
.hamburger{display:none}
.sb-close{display:none;margin-left:auto;flex:0 0 auto;width:34px;height:34px;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:var(--r-sm);color:var(--ink-2);cursor:pointer}
.sb-close:hover{color:var(--ink);border-color:var(--border-strong);background:var(--surface-2)}

/* =====================================================================
   GENERIC PANELS / GRID / CARDS
   ===================================================================== */
.row{display:grid;gap:var(--sp-4)}
.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.span-2{grid-column:span 2}
.panel{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-card);box-shadow:var(--shadow-card)}
.panel-head{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border)}
.panel-head h2{font-size:15px;font-weight:600;margin:0}
.panel-head .count,.panel-head .more{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--ink-3)}
.panel-head .more{cursor:pointer} .panel-head .more:hover{color:var(--accent-bright)}
.panel-body{padding:var(--sp-4) var(--sp-5)}

.stat{position:relative;overflow:hidden;background:linear-gradient(165deg,var(--surface-2),var(--surface-1));border:1px solid var(--border);border-radius:var(--r-card);padding:var(--sp-5);box-shadow:var(--shadow-card);transition:.16s;cursor:pointer;text-align:left;width:100%;color:inherit}
.stat::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent) 0%,transparent 65%);opacity:.55}
.stat.alert::before{background:linear-gradient(90deg,var(--sev-5) 0%,transparent 65%)}
.stat:hover{border-color:var(--accent-line);transform:translateY(-2px)}
.stat .label{font-size:10.5px;color:var(--ink-3);font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.stat .value{font-size:clamp(28px,3.2vw,38px);font-weight:600;line-height:1.05;margin-top:10px;letter-spacing:-.015em;font-variant-numeric:tabular-nums}
.stat .sub{font-size:12px;color:var(--ink-3);margin-top:8px;display:flex;align-items:center;gap:8px}
.stat .sub .go{margin-left:auto;color:var(--accent-bright)}
.stat.alert .value{color:var(--sev-5)}
.stat .spark{position:absolute;right:14px;bottom:12px;opacity:.85}

/* pills */
.pill{font-family:var(--mono);font-size:10px;padding:2px 7px;border-radius:var(--r-pill);border:1px solid var(--border);color:var(--ink-2);white-space:nowrap}
.pill.layer{color:var(--accent-bright);border-color:var(--accent-line)}
.pill.co{color:var(--ink);border-color:var(--border-strong)}
.pill.cc{color:var(--ink-2)}
.pill.adhoc{color:var(--on-accent);background:var(--accent);border-color:var(--accent);font-weight:600}
.pill.st-active{color:var(--sev-5);border-color:rgba(206,52,57,.40)}
.pill.st-watch{color:var(--st-watch);border-color:rgba(224,169,62,.4)}
.pill.st-cleared{color:var(--ink-3)}
.flag{font-family:var(--mono);font-size:10px;padding:1px 6px;border-radius:var(--r-pill);border:1px solid var(--border);color:var(--ink-2)}

/* =====================================================================
   SIGNAL FEED (list + compact)
   ===================================================================== */
.feed{display:flex;flex-direction:column}
.signal{display:grid;grid-template-columns:4px auto 1fr auto;gap:var(--sp-3);align-items:center;padding:14px var(--sp-5);border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}
.signal:hover{background:var(--surface-2)} .signal:last-child{border-bottom:0}
.signal .rail{width:4px;height:38px;border-radius:var(--r-pill)}
.signal .sev{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-size:13px;font-weight:700;color:#06121f}
.signal .mid{min-width:0}
.signal .head{font-size:14px;font-weight:500;line-height:1.3}
.signal .meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;align-items:center}
.signal .right{text-align:right;white-space:nowrap}
.signal .right .exp{font-size:14px;font-weight:600}
.signal .right .ago{font-family:var(--mono);font-size:11px;color:var(--ink-3);margin-top:2px}

/* =====================================================================
   BALANCE / TABLE
   ===================================================================== */
.bstable{width:100%;border-collapse:collapse;font-size:13.5px}
.bstable th{text-align:left;font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);font-weight:500;padding:8px 12px;border-bottom:1px solid var(--border)}
.bstable td{padding:11px 12px;border-bottom:1px solid var(--border);vertical-align:top}
.bstable tr:last-child td{border-bottom:0}
.bstable .amt{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}
.bstable tr.hit{background:rgba(229,72,77,.05)}
.bstable tr.clickable{cursor:pointer} .bstable tr.clickable:hover{background:var(--surface-2)}
.miniifrs{font-family:var(--mono);font-size:10.5px;color:var(--accent-bright)}
.expo-bar{height:6px;border-radius:var(--r-pill);background:var(--surface-3);margin-top:6px;overflow:hidden;min-width:80px}
.expo-bar>span{display:block;height:100%;border-radius:var(--r-pill);background:linear-gradient(90deg,var(--sev-4),var(--sev-5))}

/* drill block */
.drill{border:1px solid var(--border);border-radius:var(--r-md);margin-top:var(--sp-3);overflow:hidden}
.drill summary{list-style:none;cursor:pointer;padding:12px 14px;display:grid;grid-template-columns:1fr auto;gap:6px;align-items:center;background:var(--surface-2)}
.drill summary::-webkit-details-marker{display:none}
.drill summary:hover{background:var(--surface-3)}
.drill .d-pos{font-size:13.5px;font-weight:600}
.drill .d-amt{font-size:13.5px;font-weight:600;text-align:right}
.drill .d-body{padding:14px;border-top:1px solid var(--border)}

/* =====================================================================
   WORLD MAP (schematic equirectangular)
   ===================================================================== */
.map-wrap{position:relative;border-radius:var(--r-md);overflow:hidden;background:radial-gradient(120% 100% at 50% 0%,var(--map-bg-a),var(--map-bg-b));border:1px solid var(--border)}
.map-wrap svg{display:block;width:100%;height:auto}
.map-region{font-family:var(--mono);font-size:9px;letter-spacing:.12em;fill:var(--map-region);text-transform:uppercase}
.map-grid{stroke:var(--map-grid);stroke-width:.5}
.map-land{fill:var(--map-land-fill);stroke:var(--map-land-stroke);stroke-width:.6}
.map-route{stroke:var(--accent-line);stroke-width:1;stroke-dasharray:3 3;fill:none;opacity:.7}
.map-choke{fill:none;stroke:var(--ink-3);stroke-width:1}
.map-choke-lbl{font-family:var(--mono);font-size:8px;fill:var(--ink-3)}
.map-site{cursor:pointer;transition:.12s}
.map-site:hover circle{stroke:var(--map-hover)}
.map-legend{display:flex;flex-wrap:wrap;gap:14px;padding:10px 14px;font-size:11px;color:var(--ink-2);border-top:1px solid var(--border)}
.map-legend .k{display:inline-flex;align-items:center;gap:6px}
.map-legend .sw{width:9px;height:9px;border-radius:50%}
.map-tip{position:absolute;pointer-events:none;background:var(--surface-3);border:1px solid var(--border-strong);border-radius:var(--r-sm);padding:7px 10px;font-size:12px;opacity:0;transition:.1s;max-width:240px;z-index:5;box-shadow:var(--shadow-pop)}
/* Zoom-/Pan-Steuerung der Karte (Scrollrad + Ziehen + Buttons) */
.map-zoom{position:absolute;top:8px;right:8px;display:flex;flex-direction:column;gap:4px;z-index:4}
.map-zoom button{width:26px;height:26px;border-radius:var(--r-sm);border:1px solid var(--border-strong);background:var(--surface-2);color:var(--ink-2);font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;padding:0}
.map-zoom button:hover{background:var(--surface-3);color:var(--ink)}
.map-wrap svg.gv-map{touch-action:none;cursor:grab;display:block}
.map-tip.on{opacity:1}
.map-tip .t-name{font-weight:600} .map-tip .t-meta{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);margin-top:2px}

/* sites table */
.sites .srow{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:10px 4px;border-bottom:1px solid var(--border);cursor:pointer}
.sites .srow:hover{background:var(--surface-2)}
.sdot{width:12px;height:12px;border-radius:50%}

/* =====================================================================
   LEGAL
   ===================================================================== */
.legal-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:14px;margin-bottom:var(--sp-3)}
.legal-card .area{display:flex;align-items:center;gap:8px;font-weight:600;font-size:13.5px}
.legal-card .refs{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}
.legal-card .req{font-size:13px;color:var(--ink-2);line-height:1.5}
.legal-card .st{font-family:var(--mono);font-size:11px;color:var(--ink-3);margin-top:8px}
.ref{font-family:var(--mono);font-size:11px;padding:3px 9px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-1);color:var(--ink)}
.ref.ifrs{color:var(--accent-bright);border-color:var(--accent-line)}
.adhoc-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--on-accent);background:var(--accent);padding:3px 9px;border-radius:var(--r-pill);font-weight:600}

/* =====================================================================
   SCENARIOS
   ===================================================================== */
.scen{display:flex;flex-direction:column;gap:10px}
.scen .s{display:grid;grid-template-columns:96px 1fr auto;gap:10px;align-items:center;font-size:13px}
.scen .track{height:9px;background:var(--surface-3);border-radius:var(--r-pill);overflow:hidden}
.scen .track>span{display:block;height:100%;border-radius:var(--r-pill)}
.scen .Basis>span{background:var(--accent)} .scen .Eskalation>span{background:var(--sev-5)} .scen .Entspannung>span{background:var(--sev-1)}
.scen .amt{font-variant-numeric:tabular-nums;font-weight:600;text-align:right;white-space:nowrap}
.scen .ew{margin-top:6px;font-size:12.5px;color:var(--ink-2)}

/* =====================================================================
   LIVE STRIP (macro)
   ===================================================================== */
.live-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}
.live-cell{background:var(--surface-1);padding:10px 14px;display:flex;flex-direction:column;gap:2px}
.live-cell .k{font-family:var(--mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3)}
.live-cell .v{font-size:17px;font-weight:600} .live-cell .d{font-family:var(--mono);font-size:11px}
.up{color:var(--sev-5)} .down{color:var(--sev-1)} .flat{color:var(--ink-3)}
.wire .w{display:block;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px}
.wire .w:last-child{border-bottom:0}
.wire .w .src{font-family:var(--mono);font-size:10px;color:var(--ink-3)}

/* lists */
.klist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.klist li{display:flex;gap:10px;font-size:13px;color:var(--ink-2);line-height:1.5}
.klist li::before{content:"▸";color:var(--accent);flex:none}

/* L3 teaser */
.locked{position:relative}
.locked .lockbar{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;color:var(--st-watch);border:1px dashed var(--border-strong);border-radius:var(--r-pill);padding:5px 12px}
.l3card{background:var(--surface-2);border:1px dashed var(--border-strong);border-radius:var(--r-md);padding:16px;margin-bottom:var(--sp-3)}
.l3card h3{margin:0 0 6px;font-size:14px}
.disclaimer{background:rgba(224,169,62,.10);border:1px solid rgba(224,169,62,.3);border-radius:var(--r-md);padding:12px 14px;font-size:13px;color:var(--sev-3)}

/* settings */
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}
.toggle-row:last-child{border-bottom:0}
.toggle-row .t-name{font-size:14px} .toggle-row .t-desc{font-size:12px;color:var(--ink-3);margin-top:2px}
.switch{width:42px;height:24px;border-radius:var(--r-pill);background:var(--surface-3);border:1px solid var(--border);position:relative;cursor:pointer;flex:none;transition:.15s}
.switch.on{background:var(--accent)}
.switch::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 2px rgba(20,28,64,.25);transition:.15s}
.switch.on::after{left:21px}

/* =====================================================================
   DRAWER
   ===================================================================== */
.scrim{position:fixed;inset:0;background:rgba(4,7,11,.66);backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:.2s;z-index:40}
.scrim.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100vh;width:min(680px,100%);background:var(--surface-1);border-left:1px solid var(--border-strong);transform:translateX(100%);transition:transform .24s cubic-bezier(.2,.7,.2,1);z-index:50;display:flex;flex-direction:column;box-shadow:var(--shadow-pop)}
.drawer.open{transform:none}
.drawer-head{padding:var(--sp-5);border-bottom:1px solid var(--border);display:flex;gap:var(--sp-3);align-items:flex-start}
.drawer-head .x{margin-left:auto}
.eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-bright)}
.drawer-title{font-size:17px;font-weight:600;line-height:1.25;max-width:46ch;margin-top:8px}
.drawer-co{font-family:var(--mono);font-size:11px;color:var(--ink-3);margin-top:6px}
.drawer-body{overflow-y:auto;padding:var(--sp-5)}
.wk{display:grid;gap:8px;margin:10px 0 var(--sp-5)}
.wk-step{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 14px}
.wk-step .lab{font-family:var(--mono);font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em}
.wk-step p{margin:4px 0 0;font-size:13px}
.wk-arrow{text-align:center;color:var(--accent);font-size:14px;line-height:0}
.sec{margin-top:var(--sp-5)}
.sec h4{font-size:13px;font-weight:600;margin:0 0 10px;display:flex;align-items:center;gap:8px}
.sec h4 .n{font-family:var(--mono);font-size:10px;color:var(--accent-bright);border:1px solid var(--accent-line);border-radius:var(--r-pill);padding:1px 7px}
.secd{margin-top:var(--sp-5);border-top:1px solid var(--border);padding-top:10px}
.secd>summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ink)}
.secd>summary::-webkit-details-marker{display:none}
.secd>summary .n{font-family:var(--mono);font-size:10px;color:var(--accent-bright);border:1px solid var(--accent-line);border-radius:var(--r-pill);padding:1px 7px}
.secd>summary .chev{margin-left:auto;color:var(--ink-3);transition:transform .15s;font-size:11px}
.secd[open]>summary .chev{transform:rotate(90deg)}
.secd-body{padding-top:10px}
.bs{border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}
.bs-row{display:grid;grid-template-columns:1fr auto;gap:4px var(--sp-3);padding:11px 13px;border-bottom:1px solid var(--border)}
.bs-row:last-child{border-bottom:0}
.bs-row .pos{font-size:13px;font-weight:600} .bs-row .amt{font-size:13.5px;font-weight:600;text-align:right;white-space:nowrap}
.bs-row .ifrs{font-family:var(--mono);font-size:10.5px;color:var(--accent-bright);margin-top:2px}
.bs-row .ctx{grid-column:1/-1;font-size:11.5px;color:var(--ink-3);margin-top:2px}
.bs-row .basis{grid-column:1/-1;font-size:12px;color:var(--ink-2);margin-top:6px;line-height:1.45}
.bs-total{display:flex;justify-content:space-between;padding:11px 13px;background:var(--surface-2);font-weight:600;font-size:13px}
.callout{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:13px;font-size:13px;line-height:1.55}
.callout.rec{border-left:3px solid var(--accent)}
.refs{display:flex;flex-wrap:wrap;gap:6px}
.template{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md);padding:14px;margin-top:10px}
.template pre{white-space:pre-wrap;font-family:var(--mono);font-size:11.5px;line-height:1.55;margin:0;color:var(--ink)}
.btn{font-family:var(--font);font-size:var(--fs-md);font-weight:600;border:0;border-radius:var(--r-md);padding:9px 16px;cursor:pointer}
.btn-primary{background:var(--accent);color:var(--on-accent)} .btn-primary:hover{background:var(--accent-bright)}
.audit{font-family:var(--mono);font-size:11px;color:var(--ink-3);margin-top:12px;border-top:1px solid var(--border);padding-top:10px}

.empty{padding:var(--sp-6);text-align:center;color:var(--ink-3);font-size:13px}
.skeleton{padding:var(--sp-5);font-family:var(--mono);font-size:12px;color:var(--ink-3)}
/* Lade-Zustand mit animiertem Marken-Symbol (galvanische Zelle lädt). */
.skeleton.mark{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:72px 16px;letter-spacing:.1em}
.skeleton.mark .gv-mark rect:nth-child(1),.skeleton.mark .gv-mark rect:nth-child(3){animation:gvTerm 1.6s ease-in-out infinite}
.skeleton.mark .gv-mark rect:nth-child(2){transform-origin:15px 10px;animation:gvCharge 1.6s ease-in-out infinite}
@keyframes gvCharge{0%,100%{transform:scaleX(.32);opacity:.5}55%,72%{transform:scaleX(1);opacity:1}}
@keyframes gvTerm{0%,100%{opacity:.45}55%,72%{opacity:1}}
@media (prefers-reduced-motion: reduce){.skeleton.mark .gv-mark rect{animation:none!important}}
/* Live-Status-Strip (FactSet-inspiriert): kompakte Ticker unter der Topbar, nur Desktop. */
.tickbar{display:flex;align-items:center;gap:4px;padding:5px 22px;border-bottom:1px solid var(--border);background:var(--surface-1);overflow-x:auto;scrollbar-width:none;white-space:nowrap}
.tickbar::-webkit-scrollbar{display:none}
.tickbar .tk{display:inline-flex;align-items:baseline;gap:7px;padding:3px 11px;border-radius:var(--r-sm);text-decoration:none;color:inherit;transition:background .14s}
.tickbar .tk:hover{background:var(--surface-3)}
.tickbar .tk-l{font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3)}
.tickbar .tk-v{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}
.tickbar .tk-d{font-family:var(--mono);font-size:10.5px}
.tickbar .tk-ts{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--ink-3);padding-left:12px}
@media (max-width:900px){.tickbar{display:none}}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1100px){.cols-4{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:1fr}}
@media (max-width:900px){
  .shell{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;width:260px;z-index:60;transform:translateX(-100%);transition:transform .2s}
  .sidebar.open{transform:none}
  .hamburger{display:grid}
  .sb-close{display:inline-flex}
  .cols-2{grid-template-columns:1fr}.span-2{grid-column:auto}
  .topbar{gap:10px;padding:12px 14px}
  .page-sub{display:none}
  .page-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:42vw}
  .seg button{padding:6px 9px;font-size:11px}
  .kv{grid-template-columns:1fr;gap:2px}
  .kv .k{margin-top:8px}
  #userChip{max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
}
@media (max-width:520px){
  #userChip{display:none}
  .view{padding-left:12px;padding-right:12px}
  .seg button .dt{display:none}
  .drawer-body{padding:var(--sp-4)}
}

/* =====================================================================
   v4 additions — Demo/Live toggle, profile, forecast, report, L3 mock, belege
   ===================================================================== */
.seg{display:inline-flex;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-pill);padding:3px;gap:2px}
.seg button{border:0;background:transparent;color:var(--ink-2);font-size:12px;font-weight:600;padding:6px 13px;border-radius:var(--r-pill);cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.seg button.on{background:var(--accent);color:var(--on-accent)}
.seg button.on.live{background:var(--ok);color:var(--on-accent)}
.seg .dt{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.7}
.banner{display:flex;gap:10px;align-items:center;background:rgba(61,190,139,.10);border:1px solid rgba(61,190,139,.35);border-radius:var(--r-md);padding:12px 14px;font-size:13px;color:var(--ok);margin-bottom:16px}
.banner.warn{background:rgba(224,169,62,.10);border-color:rgba(224,169,62,.35);color:var(--sev-3)}
/* Geo-Accounting: visuelle Transmissions-Kette auf Kanal-Karten (entlastet Fließtext) */
.chan-flow{display:flex;align-items:center;gap:6px;margin-top:8px}
.chan-flow .cf{flex:1;background:var(--surface-3);border-radius:var(--r-sm);padding:5px 7px;text-align:center;line-height:1.2;font-size:10.5px;color:var(--ink-2)}
.chan-flow .ar{color:var(--accent);flex:none;font-size:11px}
/* Vollausbau-/Simulations-Modus (dritter Schalter neben Demo/Live) — ehrlich & hochwertig: scharf + gerahmt + Glow, nicht geblurrt */
.seg button.on.sim{background:linear-gradient(135deg,var(--accent),var(--accent-bright));color:var(--on-accent);box-shadow:0 0 0 1px var(--accent-line),0 0 16px -3px var(--accent-glow)}
.banner.sim{background:var(--accent-dim);border-color:var(--accent-line);color:var(--accent-bright)}
.banner.sim .dot{width:7px;height:7px;border-radius:50%;background:var(--accent-bright);box-shadow:0 0 10px var(--accent-glow);flex:none}
.sim-frame{position:relative;border:1px solid var(--accent-line);border-radius:var(--r-md);box-shadow:0 0 0 1px var(--accent-dim) inset}
.sim-frame::before{content:"SIMULIERTER VOLLAUSBAU";position:absolute;top:10px;right:12px;z-index:3;font-family:var(--mono);font-size:9px;letter-spacing:.08em;color:var(--accent-bright);background:var(--surface-1);border:1px solid var(--accent-line);border-radius:var(--r-pill);padding:2px 9px}

/* profile */
.kv{display:grid;grid-template-columns:160px 1fr;gap:8px 14px;font-size:13.5px}
.kv .k{color:var(--ink-3)} .kv .v{color:var(--ink)}
.divrow{padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}
.divrow:last-child{border-bottom:0}
.divrow .dh{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.divrow .dh .nm{font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.divrow .dh .pc{font-family:var(--mono);color:var(--ink-2);flex:none}
.divtrack{height:8px;margin-top:6px;background:var(--surface-3);border-radius:var(--r-pill);overflow:hidden}
.newsitem .ext{color:var(--accent-bright);font-size:12px}
.newsitem .orig{font-size:11.5px;color:var(--ink-3);font-style:italic;margin-top:2px}
.divtrack>span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-bright));border-radius:var(--r-pill)}
.src-flow{display:grid;grid-template-columns:1fr;gap:10px}
.src-step{display:flex;gap:12px;align-items:flex-start;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 14px}
.src-step .num{font-family:var(--mono);font-size:11px;color:var(--accent-bright);border:1px solid var(--accent-line);border-radius:var(--r-pill);padding:1px 8px;flex:none;margin-top:1px}
.src-step .t{font-weight:600;font-size:13px} .src-step .d{font-size:12.5px;color:var(--ink-2);margin-top:3px}
.src-step.future{border-style:dashed;opacity:.85}

/* forecast / scenarios */
.fc-wrap{position:relative}
.fc-legend{display:flex;gap:16px;font-size:12px;color:var(--ink-2);margin-top:8px}
.fc-legend .k{display:inline-flex;align-items:center;gap:6px}
.fc-legend .sw{width:10px;height:3px;border-radius:2px}
.ev-big{font-size:clamp(26px,3vw,34px);font-weight:600}
.scen-card{background:var(--surface-2);border:1px solid var(--border);border-left-width:3px;border-radius:var(--r-md);padding:14px;margin-bottom:10px}
.scen-card .h{display:flex;justify-content:space-between;align-items:baseline}
.scen-card .nm{font-weight:600}
.scen-card .amt{font-weight:600;font-variant-numeric:tabular-nums}

/* report */
.report{background:#fff;color:#0a0f14;border-radius:var(--r-md);padding:36px 44px;max-width:780px;margin:0 auto;font-size:14px;line-height:1.66}
.report h1{font-size:22px;margin:0 0 4px;color:#0a0f14}
.report h2{font-size:15px;margin:22px 0 8px;color:#0a0f14;border-bottom:2px solid #1E2F7A;padding-bottom:4px}
.report h3{font-size:13.5px;margin:14px 0 4px;color:#0a0f14}
.report .meta{color:#475569;font-size:12px}
.report table{width:100%;border-collapse:collapse;margin:8px 0;font-size:12.5px}
.report th,.report td{border:1px solid #cbd5e1;padding:6px 8px;text-align:left;vertical-align:top}
.report th{background:#eef2f7}
.report .amt{text-align:right;white-space:nowrap}
.report .tag{color:#475569;font-family:var(--mono);font-size:11px}
.report .sig{margin:10px 0;padding:10px 0;border-bottom:1px solid #e2e8f0}
.report-bar{display:flex;gap:10px;align-items:center;margin-bottom:14px}
@media print{
  body *{visibility:hidden!important}
  #printArea,#printArea *{visibility:visible!important}
  #printArea{position:absolute;left:0;top:0;width:100%}
  .report{box-shadow:none;max-width:none}
}

/* L3 visual mock */
.l3mock{position:relative;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;background:var(--surface-1)}
.l3mock .blur{filter:blur(1.5px) saturate(.7);opacity:.65}
.l3mock .lockover{position:absolute;inset:0;display:grid;place-items:center;background:rgba(10,15,20,.35)}
.l3mock .lockpill{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;color:#fff;background:rgba(10,15,20,.7);border:1px solid var(--border-strong);border-radius:var(--r-pill);padding:8px 16px}
.vessel{animation:none}

/* belege */
.belege{display:flex;flex-direction:column;gap:6px}
.belege a{display:flex;gap:8px;align-items:center;font-size:12.5px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface-2);color:var(--ink)}
.belege a:hover{border-color:var(--accent-line);text-decoration:none}
.belege a .src{font-family:var(--mono);font-size:10px;color:var(--accent-bright);flex:none}
.belege a .u{color:var(--ink-3);margin-left:auto;font-family:var(--mono);font-size:10.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:230px}

/* deadline pill */
.frist{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10.5px;color:var(--sev-3);background:rgba(224,169,62,.12);border:1px solid rgba(224,169,62,.3);border-radius:var(--r-pill);padding:2px 9px}
.frist.urgent{color:var(--sev-5);background:rgba(206,52,57,.12);border-color:rgba(206,52,57,.35)}

/* =====================================================================
   v5 additions — News, Datenquellen, Alarme/Bell/Toast, Bilanz-Explorer,
   Regionen, HQ-Marker, L3-Mock vivid
   ===================================================================== */
/* News */
.news-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;align-items:center}
.news-filters select,.news-filters input{font-family:var(--font);font-size:13px;color:var(--ink);background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);padding:8px 12px}
.news-filters input{min-width:200px}
.newsitem{display:block;padding:14px var(--sp-5);border-bottom:1px solid var(--border);transition:background .12s;cursor:pointer}
.newsitem:hover{background:var(--surface-2);text-decoration:none}
.newsitem .h{font-size:14px;font-weight:500;color:var(--ink);line-height:1.35}
.newsitem .m{display:flex;flex-wrap:wrap;gap:6px;margin-top:7px;align-items:center}
.newsitem .src{font-family:var(--mono);font-size:10px;color:var(--ink-3)}
.pill.region{color:var(--ink-2)} .pill.ifrs{color:var(--accent-bright);border-color:var(--accent-line)}

/* Datenquellen */
.src-table{width:100%;border-collapse:collapse;font-size:13px}
.src-table th{text-align:left;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);padding:8px 10px;border-bottom:1px solid var(--border)}
.src-table td{padding:9px 10px;border-bottom:1px solid var(--border);vertical-align:top}
.src-table tr:hover{background:var(--surface-2)}
.cost{font-family:var(--mono);font-size:10px;padding:2px 8px;border-radius:var(--r-pill);white-space:nowrap}
.cost.gratis{color:var(--ok);background:rgba(61,190,139,.12);border:1px solid rgba(61,190,139,.3)}
.cost.freemium{color:var(--accent-bright);background:var(--accent-dim);border:1px solid var(--accent-line)}
.cost.paid{color:var(--st-watch);background:rgba(224,169,62,.1);border:1px solid rgba(224,169,62,.3)}
.cost.eingeschr{color:var(--ink-3);border:1px solid var(--border)}
.intgr{font-family:var(--mono);font-size:9.5px;color:#06121f;background:var(--ok);border-radius:var(--r-pill);padding:1px 7px;font-weight:600}

/* Alarme / Bell / Toast */
.bell{position:relative}
.bell .cnt{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;border-radius:var(--r-pill);background:var(--sev-5);color:#fff;font-size:9.5px;font-weight:700;display:grid;place-items:center;padding:0 3px}
.bell-pop{position:absolute;top:46px;right:0;width:340px;max-height:60vh;overflow-y:auto;background:var(--surface-1);border:1px solid var(--border-strong);border-radius:var(--r-md);box-shadow:var(--shadow-pop);z-index:60;display:none}
.bell-pop.open{display:block}
.bell-pop .ph{padding:12px 14px;border-bottom:1px solid var(--border);font-weight:600;font-size:13px;display:flex;justify-content:space-between}
.alert-row{display:grid;grid-template-columns:auto 1fr;gap:10px;padding:11px 14px;border-bottom:1px solid var(--border);cursor:pointer}
.alert-row:hover{background:var(--surface-2)} .alert-row:last-child{border-bottom:0}
.alert-row .ad{width:8px;height:8px;border-radius:50%;margin-top:5px}
.alert-row .at{font-size:13px;font-weight:500;line-height:1.3}
.alert-row .am{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);margin-top:3px}
.toast-wrap{position:fixed;right:18px;bottom:18px;z-index:70;display:flex;flex-direction:column;gap:10px;max-width:360px}
.toast{background:var(--surface-2);border:1px solid var(--border-strong);border-left:3px solid var(--sev-5);border-radius:var(--r-md);padding:13px 15px;box-shadow:var(--shadow-pop);animation:rise .3s ease both;cursor:pointer}
.toast .tt{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--sev-5)}
.toast .th{font-size:13px;font-weight:600;margin-top:4px;line-height:1.3}
.toast .tm{font-size:12px;color:var(--ink-2);margin-top:4px}
.alert-card{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:14px var(--sp-5);border-bottom:1px solid var(--border);cursor:pointer}
.alert-card:hover{background:var(--surface-2)}
.alert-card .ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-size:16px}
.sev-dot{width:10px;height:10px;border-radius:50%}

/* Bilanz-Explorer (breadcrumb drill) */
.crumbs{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:13px;margin-bottom:14px}
.crumbs a{color:var(--accent-bright);cursor:pointer} .crumbs .sep{color:var(--ink-3)} .crumbs .cur{color:var(--ink);font-weight:600}
.explore-row{display:grid;grid-template-columns:1fr auto auto;gap:14px;align-items:center;padding:14px 16px;border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:8px;cursor:pointer;transition:.13s;background:var(--surface-1)}
.explore-row.leaf{cursor:default}
.explore-row:hover:not(.leaf){border-color:var(--accent-line);transform:translateY(-1px)}
.explore-row .nm{font-weight:600;font-size:14px}
.explore-row .sub{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);margin-top:3px}
.explore-row .bv{text-align:right;font-variant-numeric:tabular-nums;color:var(--ink-2);font-size:12.5px}
.explore-row .af{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}
.explore-row .chev{color:var(--ink-3)}
.explore-row .ga{font-family:var(--mono);font-size:10px;color:var(--ok);margin-top:3px;text-align:right;white-space:nowrap}

/* Regionen-Facts */
.reg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.reg-card{background:var(--surface-2);border:1px solid var(--border);border-left-width:3px;border-radius:var(--r-md);padding:13px}
.reg-card .rn{font-weight:600;font-size:13.5px}
.reg-card .rk{display:flex;justify-content:space-between;font-size:12px;color:var(--ink-2);margin-top:6px}
.reg-card .rk b{color:var(--ink)}
.reg-card .rf{font-family:var(--mono);font-size:10px;color:var(--accent-bright);margin-top:6px}
/* einheitlicher Klick-Hover für klickbare Karten (Audit P3.4) */
.reg-card[data-country],.reg-card[data-sector],.reg-card[data-channel]{cursor:pointer;transition:.14s}
.reg-card[data-country]:hover,.reg-card[data-sector]:hover,.reg-card[data-channel]:hover{border-color:var(--accent-line);transform:translateY(-1px)}
/* Semantische Severity-Klassen (Audit P1.4) — ersetzen Inline-Severity-Farben verlustfrei.
   --sv spiegelt sevColor(n) fuer n=1..5 exakt wider; .sev-l0 = Fallback (sevColor(0)=--ink-3). */
.sev-l0{--sv:var(--ink-3)}.sev-l1{--sv:var(--sev-1)}.sev-l2{--sv:var(--sev-2)}.sev-l3{--sv:var(--sev-3)}.sev-l4{--sv:var(--sev-4)}.sev-l5{--sv:var(--sev-5)}
.reg-card[class*="sev-l"]{border-left-color:var(--sv)}
.pill.sev{color:var(--sv);border-color:var(--sv)}

/* L3 mock vivid */
.l3badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;color:#06121f;background:var(--st-watch);border-radius:var(--r-pill);padding:2px 9px;font-weight:600}
.l3panel{border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;background:var(--surface-1);position:relative}
.l3panel .cap{position:absolute;top:10px;left:12px;z-index:2}
.heatbar{display:flex;flex-direction:column;gap:8px}
.heatbar .hr{display:grid;grid-template-columns:120px 1fr 44px;gap:10px;align-items:center;font-size:12.5px}
.heatbar .tk{height:9px;border-radius:var(--r-pill);background:var(--surface-3);overflow:hidden}
.heatbar .tk>span{display:block;height:100%;border-radius:var(--r-pill)}

/* ===== v6: Stammdaten-Editor (Onboarding) ===== */
.ed-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.ed-field{display:flex;flex-direction:column;gap:5px;font-size:12px}
.ed-field.wide{grid-column:1/-1;margin-top:12px}
.ed-field>span{font-weight:600;color:var(--ink-2)}
.ed-field input,.ed-field select,.ed-field textarea,.ed-line input,.ed-line select{font-family:var(--font);font-size:13px;color:var(--ink);background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 10px;width:100%}
.ed-field input:focus,.ed-field select:focus,.ed-field textarea:focus,.ed-line input:focus,.ed-line select:focus{outline:none;border-color:var(--accent)}
.ed-field textarea{resize:vertical;line-height:1.5}
.ed-line{display:flex;gap:8px;align-items:center;margin-bottom:8px;flex-wrap:wrap}
.ed-line input,.ed-line select{flex:1 1 110px;min-width:80px}
.ed-line .icon-btn{flex:0 0 auto}
.ed-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.ed-legend{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);margin-bottom:10px}
.ed-stat{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px;text-align:center}
.ed-stat .v{font-size:18px;font-weight:700;color:var(--ink)}
.ed-stat .l{font-size:11px;color:var(--ink-3);margin-top:2px}
/* Währungsrisiko (FX) */
.fx-shock{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.fx-shock label{font-size:12px;color:var(--ink-3);font-family:var(--mono);text-transform:uppercase;letter-spacing:.05em}
.fx-shock input[type=range]{flex:1;min-width:160px;accent-color:var(--accent)}
.fx-shock b{font-family:var(--mono);font-size:14px;color:var(--accent-bright);min-width:54px;text-align:right}
.fx-table td .tag{font-weight:400}
.fx-table th .tag{font-weight:400;text-transform:none;letter-spacing:0;font-family:var(--mono)}
.fx-table tbody tr:hover{background:var(--surface-2)}
/* Monatsbriefings */
.brief-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.brief-card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;cursor:pointer;transition:border-color .12s,background .12s}
.brief-card:hover{border-color:var(--accent-line);background:var(--surface-2)}
.brief-card .bh{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.brief-card .bm{font-family:var(--mono);font-size:12px;color:var(--ink-2);text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.brief-card .bt{font-size:15px;font-weight:600;color:var(--ink);line-height:1.3;margin-bottom:6px}
.brief-card .bs{font-size:12.5px;color:var(--ink-3);line-height:1.5}
.brief-card .bf{display:flex;justify-content:space-between;align-items:center;margin-top:12px;gap:8px}
.brief-card .bf .go{color:var(--accent-bright);font-size:12px;white-space:nowrap}
/* Report: Wasserzeichen + Misuse-Hinweis (illustrativ / öffentliche GB-Daten) */
.report-wm{position:fixed;top:46%;left:50%;transform:translate(-50%,-50%) rotate(-26deg);font-size:46px;font-weight:800;letter-spacing:3px;color:rgba(150,150,150,.10);pointer-events:none;white-space:nowrap;z-index:40}
.report-misuse{background:rgba(232,197,71,.10);border:1px solid rgba(232,197,71,.5);border-radius:8px;padding:12px 14px;font-size:12.5px;line-height:1.55;color:#8a6d12;margin-bottom:16px}
@media print{.report-wm{color:rgba(120,120,120,.13)}}
.btn-danger{background:transparent;border:1px solid var(--sev-5);color:var(--sev-5)}
.btn-danger:hover{background:var(--sev-5);color:#0b1117}
@media(max-width:900px){.ed-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.ed-grid{grid-template-columns:1fr}}
/* Drawer-Divider (Audit P3.2) — trennt Kern-Wirkungskette (1–5) von Compliance/Belege (6–11) */
.drawer-split{display:flex;align-items:center;gap:var(--sp-3);margin:var(--sp-6) 0 var(--sp-2)}
.drawer-split::before,.drawer-split::after{content:"";height:1px;flex:1;background:var(--border)}
.drawer-split span{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);white-space:nowrap}
/* Accessibility P2.5 — Breadcrumb-Links (data-balgo, <a> ohne href) Fokus-Sichtbarkeit */
.crumbs a[data-balgo]:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--r-sm)}
