/* ============================================================
   Garbit SHIP - Dashboard-Seite · Daten-Viz-Komponenten
   Ergänzt die Inline-Basis-Styles (Nav/Hero/Footer bleiben dort).
   Theme-aware über CSS-Variablen aus der Seite.
   ============================================================ */

:root {
  /* Daten-Viz-Palette - harmonisch, gleiche Helligkeit/Sättigung (oklch-getunt) */
  --c-1: #33cc3f;            /* Garbit-Grün - Primärserie */
  --c-2: oklch(0.70 0.13 200);  /* Teal */
  --c-3: oklch(0.66 0.14 255);  /* Blau */
  --c-4: oklch(0.66 0.15 300);  /* Violett */
  --c-5: oklch(0.78 0.15 85);   /* Amber */
  --c-6: oklch(0.68 0.16 35);   /* Korall */
  --grid-line: var(--border);
  --panel: var(--card-bg);
}

/* ---------- Mutiger Stat-Strip ---------------------------------- */
.statband {
  background: var(--bg-dark);
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  position: relative;
  overflow: hidden;
}
.statband::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 120% at 50% 0%, rgba(51,204,63,0.10), transparent 70%);
  pointer-events: none;
}
.statband__grid {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: repeat(4, 1fr);
  max-width: var(--container); margin: 0 auto;
}
.statband__cell {
  padding: 40px var(--pad);
  border-left: 1px solid rgba(255,255,255,0.07);
  display: flex; flex-direction: column; gap: 6px;
}
.statband__cell:first-child { border-left: none; }
.statband__num {
  font-size: clamp(2rem, 4vw, 3rem); font-weight: 800; line-height: 1;
  color: #fff; letter-spacing: -0.02em; font-variant-numeric: tabular-nums;
}
.statband__num em { color: var(--green); font-style: normal; }
.statband__label {
  font-size: 12px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}
@media (max-width: 760px) {
  .statband__grid { grid-template-columns: 1fr 1fr; }
  .statband__cell:nth-child(odd) { border-left: none; }
  .statband__cell:nth-child(n+3) { border-top: 1px solid rgba(255,255,255,0.07); }
}

/* ---------- App-Window-Mockup (Produkt-UI) --------------------- */
.ui-window {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,0.18), 0 2px 10px rgba(0,0,0,0.06);
}
.ui-window--hero {
  box-shadow: 0 40px 90px rgba(0,0,0,0.55), 0 0 0 1px rgba(255,255,255,0.06);
}
.ui-window__bar {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 16px;
  background: var(--bg-alt);
  border-bottom: 1px solid var(--border);
}
.ui-window__dot { width: 11px; height: 11px; border-radius: 50%; }
.ui-window__dot.r { background: #ff5f57; } .ui-window__dot.y { background: #febc2e; } .ui-window__dot.g { background: #28c840; }
.ui-window__title {
  margin-left: 8px; font-size: 12.5px; font-weight: 600; color: var(--text-muted);
  display: flex; align-items: center; gap: 8px;
}
.ui-window__title b { color: var(--text-head); font-weight: 700; }
.ui-window__live {
  margin-left: auto; display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700; color: var(--green-dark); text-transform: uppercase; letter-spacing: 0.06em;
}
.ui-window__static { margin-left: auto; font-size: 11px; font-weight: 700; color: var(--text-faint); text-transform: uppercase; letter-spacing: 0.06em; }
[data-theme="dark"] .ui-window__live { color: var(--green); }
.ui-window__live::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 0 rgba(51,204,63,0.5); animation: pulse 2s infinite; }
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(51,204,63,0.45);} 70%{box-shadow:0 0 0 7px rgba(51,204,63,0);} 100%{box-shadow:0 0 0 0 rgba(51,204,63,0);} }
@media (prefers-reduced-motion: reduce){ .ui-window__live::before { animation: none; } }

.ui-window__body { display: grid; grid-template-columns: 56px 1fr; }
.ui-rail {
  background: var(--bg-alt); border-right: 1px solid var(--border);
  padding: 16px 0; display: flex; flex-direction: column; align-items: center; gap: 18px;
}
.ui-rail__logo { width: 26px; height: 26px; border-radius: 7px; background: var(--green); display:grid; place-items:center; }
.ui-rail__logo svg { width: 15px; height: 15px; color:#fff; }
.ui-rail__ico { width: 22px; height: 22px; color: var(--text-faint); }
.ui-rail__ico.is-active { color: var(--green); }
.ui-canvas { padding: 22px; display: flex; flex-direction: column; gap: 18px; }

/* KPI tiles inside the window */
.ui-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.ui-kpi {
  background: var(--bg); border: 1px solid var(--border); border-radius: 12px;
  padding: 14px 16px;
}
.ui-kpi__label { font-size: 11px; font-weight: 600; color: var(--text-muted); margin-bottom: 8px; letter-spacing: 0.02em; }
.ui-kpi__row { display: flex; align-items: baseline; gap: 8px; }
.ui-kpi__num { font-size: 26px; font-weight: 800; color: var(--text-head); line-height: 1; font-variant-numeric: tabular-nums; }
.ui-kpi__delta { font-size: 12px; font-weight: 700; display: inline-flex; align-items: center; gap: 2px; }
.ui-kpi__delta.up { color: var(--green-dark); } [data-theme="dark"] .ui-kpi__delta.up { color: var(--green); }
.ui-kpi__delta.down { color: var(--text-muted); }
.ui-kpi__spark { margin-top: 10px; height: 30px; width: 100%; display: block; }

.ui-panels { display: grid; grid-template-columns: 1.4fr 1fr; gap: 14px; }
.ui-panel {
  background: var(--bg); border: 1px solid var(--border); border-radius: 12px; padding: 16px;
}
.ui-panel__head { display:flex; align-items:center; justify-content: space-between; margin-bottom: 14px; }
.ui-panel__title { font-size: 12.5px; font-weight: 700; color: var(--text-head); }
.ui-panel__tag { font-size: 10.5px; font-weight: 600; color: var(--text-muted); background: var(--bg-alt); border:1px solid var(--border); border-radius: 99px; padding: 3px 9px; }

/* CSS column chart */
.colchart { display: flex; align-items: flex-end; gap: 9px; height: 120px; }
.colchart__bar { flex: 1; border-radius: 5px 5px 0 0; background: var(--c-1); min-height: 4px; transition: height 0.9s var(--ease-out); }
.reveal .colchart__bar, .ui-window .colchart__bar { height: var(--h, 30%); }
.colchart__bar:nth-child(7n+2){ background: var(--c-1); opacity: 0.55; }

/* Donut legend */
.donut-wrap { display: flex; align-items: center; gap: 16px; }
.donut { width: 104px; height: 104px; flex-shrink: 0; }
.donut__track { stroke: var(--bg-alt); }
.legend { display: flex; flex-direction: column; gap: 8px; flex: 1; }
.legend__item { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--text); }
.legend__dot { width: 10px; height: 10px; border-radius: 3px; flex-shrink: 0; }
.legend__val { margin-left: auto; font-weight: 700; color: var(--text-head); font-variant-numeric: tabular-nums; }

@media (max-width: 600px){
  .ui-kpis { grid-template-columns: 1fr 1fr; }
  .ui-kpis .ui-kpi:last-child { display: none; }
  .ui-panels { grid-template-columns: 1fr; }
  .ui-rail { display: none; }
  .ui-window__body { grid-template-columns: 1fr; }
}

/* ---------- Widget-Typen-Grid (Sektion 01) -------------------- */
.widget-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.widget {
  background: var(--card-bg); border: 1px solid var(--border); border-radius: 16px;
  padding: 26px 26px 22px; box-shadow: var(--card-shadow);
  transition: box-shadow var(--dur-base), transform var(--dur-base), border-color var(--dur-base);
  position: relative; overflow: hidden;
}
.widget:hover { box-shadow: var(--card-shadow-hover); transform: translateY(-3px); border-color: color-mix(in srgb, var(--green) 40%, var(--border)); }
.widget__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.widget__kicker { font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--green-dark); }
[data-theme="dark"] .widget__kicker { color: var(--green); }
.widget__badge { font-size: 11px; font-weight: 700; color: var(--text-muted); background: var(--bg-alt); border:1px solid var(--border); border-radius: 99px; padding: 4px 10px; }
.widget__name { font-size: 1.15rem; font-weight: 800; color: var(--text-head); margin-bottom: 4px; }
.widget__desc { font-size: 0.875rem; color: var(--text-muted); line-height: 1.6; margin-bottom: 20px; }
.widget__viz { margin-top: auto; }

/* big number widget */
.bignum { display: flex; align-items: baseline; gap: 12px; }
.bignum__val { font-size: 3rem; font-weight: 800; color: var(--text-head); line-height: 1; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }
.bignum__delta { font-size: 14px; font-weight: 700; color: var(--green-dark); display:inline-flex; align-items:center; gap: 3px; }
[data-theme="dark"] .bignum__delta { color: var(--green); }
.bignum__sub { font-size: 12px; color: var(--text-faint); margin-top: 6px; }

/* mini horizontal bars inside widget */
.minibars { display: flex; flex-direction: column; gap: 11px; }
.minibar { display: grid; grid-template-columns: 92px 1fr 44px; align-items: center; gap: 12px; font-size: 12.5px; }
.minibar__label { color: var(--text); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.minibar__track { height: 8px; background: var(--bg-alt); border-radius: 99px; overflow: hidden; }
.minibar__fill { display: block; height: 100%; border-radius: 99px; width: var(--w); background: var(--c-1); transform: scaleX(0); transform-origin: left; transition: transform 1.1s var(--ease-out); }
.reveal.visible .minibar__fill { transform: scaleX(1); }
.minibar__val { text-align: right; font-weight: 700; color: var(--text-head); font-variant-numeric: tabular-nums; }

@media (max-width: 760px){ .widget-grid { grid-template-columns: 1fr; } }

/* ---------- Reporting / Report-Designer (Sektion 02) ---------- */
.report-mock {
  background: var(--card-bg); border: 1px solid var(--border); border-radius: 16px;
  box-shadow: var(--card-shadow); overflow: hidden;
}
.report-mock__bar { display: flex; align-items: center; gap: 8px; padding: 11px 16px; background: var(--bg-alt); border-bottom: 1px solid var(--border); }
.report-mock__doc { padding: 26px; }
.report-mock__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; padding-bottom: 18px; border-bottom: 2px solid var(--text-head); margin-bottom: 18px; }
.report-mock__h { font-size: 1.05rem; font-weight: 800; color: var(--text-head); }
.report-mock__sub { font-size: 11.5px; color: var(--text-muted); margin-top: 3px; }
.report-mock__logo { font-size: 12px; font-weight: 800; color: var(--green-dark); letter-spacing: 0.04em; }
[data-theme="dark"] .report-mock__logo { color: var(--green); }
.rtable { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.rtable th { text-align: left; font-size: 10.5px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--text-faint); padding: 0 0 10px; }
.rtable td { padding: 9px 0; border-top: 1px solid var(--border); color: var(--text); }
.rtable td.num { text-align: right; font-variant-numeric: tabular-nums; font-weight: 700; color: var(--text-head); }
.rtable tr:last-child td { font-weight: 800; color: var(--text-head); border-top: 2px solid var(--border); }

.export-chips { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.export-chip {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 700; color: var(--text-head);
  background: var(--card-bg); border: 1px solid var(--border); border-radius: 10px; padding: 9px 14px;
  transition: border-color var(--dur-base), transform var(--dur-base);
}
.export-chip:hover { border-color: var(--green); transform: translateY(-2px); }
.export-chip__ext { font-size: 10px; font-weight: 800; color: #fff; background: var(--green); border-radius: 5px; padding: 2px 6px; letter-spacing: 0.03em; }
.export-chip:nth-child(2) .export-chip__ext { background: var(--c-3); }
.export-chip:nth-child(3) .export-chip__ext { background: var(--c-6); }

/* ---------- Carrier-Statistik Bar-Chart (Sektion 03) --------- */
.carrierstat {
  background: var(--card-bg); border: 1px solid var(--border); border-radius: 18px;
  box-shadow: var(--card-shadow); padding: 30px 32px;
}
.carrierstat__head { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; margin-bottom: 26px; }
.carrierstat__title { font-size: 1.05rem; font-weight: 800; color: var(--text-head); }
.carrierstat__period { font-size: 12px; font-weight: 600; color: var(--text-muted); display: inline-flex; align-items: center; gap: 6px; background: var(--bg-alt); border: 1px solid var(--border); border-radius: 99px; padding: 6px 14px; }
.cbar { display: grid; grid-template-columns: 130px 1fr 92px; align-items: center; gap: 16px; padding: 9px 0; }
.cbar__name { font-size: 13px; font-weight: 700; color: var(--text-head); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cbar__track { height: 26px; background: var(--bg-alt); border-radius: 7px; overflow: hidden; }
.cbar__fill { display: block; height: 100%; border-radius: 7px; width: var(--w); transform: scaleX(0); transform-origin: left; transition: transform 1.2s var(--ease-out); }
.reveal.visible .cbar__fill { transform: scaleX(1); }
@media (prefers-reduced-motion: reduce){ .cbar__fill, .minibar__fill { transform: none; } }
.cbar__val { text-align: right; font-size: 13px; font-weight: 800; color: var(--text-head); font-variant-numeric: tabular-nums; }
@media (max-width: 600px){ .cbar { grid-template-columns: 88px 1fr 50px; gap: 10px; } .carrierstat { padding: 22px 18px; } }

.tag-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 30px; }
.tag-card {
  background: var(--card-bg); border: 1px solid var(--border); border-radius: 16px; padding: 26px 24px;
  box-shadow: var(--card-shadow); transition: box-shadow var(--dur-base), transform var(--dur-base);
}
.tag-card:hover { box-shadow: var(--card-shadow-hover); transform: translateY(-3px); }
.tag-card__icon { width: 46px; height: 46px; border-radius: 12px; background: var(--green-tint); color: var(--green-dark); display:grid; place-items:center; margin-bottom: 16px; }
[data-theme="dark"] .tag-card__icon { background: rgba(51,204,63,0.14); color: var(--green); }
.tag-card__title { font-size: 1rem; font-weight: 800; color: var(--text-head); margin-bottom: 8px; }
.tag-card__desc { font-size: 0.875rem; color: var(--text-muted); line-height: 1.65; }
@media (max-width: 760px){ .tag-cards { grid-template-columns: 1fr; } }

/* ---------- FAQ ----------------------------------------------- */
[data-theme="dark"] .faq-q:hover { color: var(--green); }

/* ============================================================
   INTERAKTIVE STEUERUNG
   ============================================================ */

/* Segmented control (Zeitraum-Umschalter) */
.seg { display: inline-flex; gap: 4px; padding: 4px; background: var(--bg-alt); border: 1px solid var(--border); border-radius: 12px; }
.seg__btn { font-family: inherit; font-size: 13px; font-weight: 700; color: var(--text-muted); background: none; border: none; cursor: pointer; padding: 8px 16px; border-radius: 9px; transition: color var(--dur-fast), background var(--dur-fast), box-shadow var(--dur-fast); }
.seg__btn:hover { color: var(--text-head); }
.seg__btn.is-active { color: var(--green-dark); background: var(--card-bg); box-shadow: 0 1px 3px rgba(0,0,0,0.10); }
[data-theme="dark"] .seg__btn.is-active { color: var(--green); background: #222; }

.section-head-row { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: 44px; }
.section-head-row .section-lead { margin-bottom: 0; }
.section-head-row .section-title { margin-bottom: 14px; }

/* Tabs (Kennzahl / Zeitraum) */
.tabs { display: inline-flex; flex-wrap: nowrap; gap: 8px; }
.tab { font-family: inherit; font-size: 13px; font-weight: 700; color: var(--text-muted); background: var(--card-bg); border: 1px solid var(--border); cursor: pointer; padding: 9px 16px; border-radius: 99px; transition: color var(--dur-fast), border-color var(--dur-fast), background var(--dur-fast); }
.tab:hover { color: var(--text-head); border-color: var(--text-muted); }
.tab.is-active { color: #fff; background: var(--green); border-color: var(--green); }
.carrierstat__controls { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }

/* Klickbare Carrier-Balken + Auswahl */
.cbar { cursor: pointer; border-radius: 8px; padding: 9px 8px; margin: 0 -8px; transition: background var(--dur-fast); }
.cbar:hover { background: var(--bg-alt); }
.cbar.is-selected { background: color-mix(in srgb, var(--green) 9%, transparent); }
.cbar.is-dim { opacity: 0.42; }
.cbar__val { transition: opacity var(--dur-base); }

/* Auswahl-Readout */
.creadout { margin-top: 22px; border-top: 1px solid var(--border); padding-top: 22px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.cread { display: flex; flex-direction: column; gap: 4px; }
.cread__label { font-size: 11px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-faint); }
.cread__val { font-size: clamp(1.2rem,2.4vw,1.7rem); font-weight: 800; color: var(--text-head); line-height: 1; font-variant-numeric: tabular-nums; }
.cread__val em { font-style: normal; font-size: 0.6em; color: var(--text-muted); font-weight: 700; }
.cread__dot { display:inline-block; width: 11px; height: 11px; border-radius: 3px; vertical-align: middle; margin-right: 7px; }
@media (max-width: 640px){ .creadout { grid-template-columns: 1fr 1fr; } }

/* Legende klickbar */
.legend__item { cursor: pointer; padding: 3px 6px; margin: 0 -6px; border-radius: 6px; transition: background var(--dur-fast), opacity var(--dur-fast); }
.legend__item:hover { background: var(--bg-alt); }
.legend__item.is-dim { opacity: 0.34; }

/* Live-Simulation im Hero-Window */
.simbar { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.simbtn { display: inline-flex; align-items: center; gap: 6px; font-family: inherit; font-size: 11.5px; font-weight: 800; letter-spacing: 0.03em; color: #fff; background: var(--green); border: none; border-radius: 99px; padding: 6px 13px; cursor: pointer; transition: background var(--dur-fast), transform var(--dur-fast); text-transform: uppercase; }
.simbtn:hover { background: var(--green-dark); transform: translateY(-1px); }
.simbtn.is-running { background: var(--bg); color: var(--text-head); border: 1px solid var(--border); }
[data-theme="dark"] .simbtn.is-running { background: #222; }
.simfeed { display: flex; align-items: center; gap: 9px; font-size: 11.5px; color: var(--text-muted); background: var(--bg-alt); border: 1px solid var(--border); border-radius: 9px; padding: 9px 13px; overflow: hidden; white-space: nowrap; }
.simfeed__pill { flex-shrink: 0; font-size: 9.5px; font-weight: 800; letter-spacing: 0.05em; text-transform: uppercase; color: var(--green-dark); background: var(--green-tint); border-radius: 5px; padding: 3px 7px; }
[data-theme="dark"] .simfeed__pill { color: var(--green); background: rgba(51,204,63,0.14); }
.simfeed__txt { overflow: hidden; text-overflow: ellipsis; font-variant-numeric: tabular-nums; }
.simfeed__txt b { color: var(--text-head); font-weight: 700; }
.simfeed.is-new .simfeed__txt { animation: feedIn 0.45s var(--ease-out); }
@keyframes feedIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.ui-kpi__num { transition: color var(--dur-fast); }
.ui-kpi__num.is-bump { color: var(--green); }
.colchart__bar.is-new { animation: barIn 0.5s var(--ease-out); }
@keyframes barIn { from { transform: scaleY(0.2); opacity: 0.3; } to { transform: scaleY(1); opacity: 1; } }
.colchart__bar { transform-origin: bottom; }
@media (prefers-reduced-motion: reduce){ .simfeed.is-new .simfeed__txt, .colchart__bar.is-new { animation: none; } }

/* Schematische-Darstellung-Hinweis */
.mock-note { margin-top: 12px; font-size: 11px; color: var(--text-faint); display: flex; align-items: center; gap: 6px; justify-content: center; }
.mock-note svg { width: 12px; height: 12px; flex-shrink: 0; }
.hero .mock-note { color: rgba(255,255,255,0.4); }

/* ============================================================
   SCREENSHOT-PLATZHALTER (für echte Produkt-Screenshots)
   → .shot__ph durch <img src="…"> ersetzen, src siehe data-shot
   ============================================================ */
.shot { border-radius: 16px; overflow: hidden; border: 1px solid var(--border); box-shadow: var(--card-shadow); background: var(--card-bg); }
.shot__bar { display: flex; align-items: center; gap: 8px; padding: 12px 16px; background: var(--bg-alt); border-bottom: 1px solid var(--border); }
.shot__ph { position: relative; aspect-ratio: 16 / 9; display: grid; place-items: center; text-align: center;
  background-color: var(--bg);
  background-image: repeating-linear-gradient(135deg, var(--bg-alt) 0, var(--bg-alt) 12px, transparent 12px, transparent 24px);
}
.shot--wide .shot__ph { aspect-ratio: 21 / 9; }
.shot__cap { font-family: var(--font-mono, ui-monospace, "SF Mono", Menlo, Consolas, monospace); font-size: 13px; font-weight: 600; color: var(--text-muted); line-height: 1.8; padding: 20px; background: color-mix(in srgb, var(--bg) 78%, transparent); border-radius: 12px; }
.shot__badge { display: inline-block; font-size: 10px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; color: var(--green-dark); background: var(--green-tint); border-radius: 6px; padding: 4px 9px; margin-bottom: 10px; }
[data-theme="dark"] .shot__badge { color: var(--green); background: rgba(51,204,63,0.14); }
.shot__hint { font-size: 11.5px; color: var(--text-faint); }
.shot__cap b { color: var(--text-head); }
