/* ============================================================================
   sga-scorecard.css — canonical SGA executive-scorecard dashboard style.
   The look behind sga-di-followups (Follow-Up Performance). Light/white only.
   STYLE LAYER: composes on drillable-dashboard (which owns tabs/rail/filter JS).
   Link this file as-is; do NOT re-fork the palette per dashboard.

   Fonts: load Inter for the intended feel (falls back to system UI cleanly):
     <link rel="preconnect" href="https://fonts.googleapis.com">
     <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;800&display=swap" rel="stylesheet">

   Design tokens (the whole palette lives here — recolor only via :root):
     navy #0f2742 / navy2 #1b365d = headings/values/SGA;  gold #c8a45c = accents/active tab/peak
     teal #0f8a8a = Gen4 / secondary line;  green/amber/red = good/watch/critical
     bg #f4f6f8, cards #ffffff, line #e6eaef;  soft layered shadow; 14px card radius
   ============================================================================ */
:root{
  --bg:#f4f6f8; --card:#ffffff; --navy:#0f2742; --navy2:#1b365d; --gold:#c8a45c;
  --ink:#16202c; --muted:#6b7280; --line:#e6eaef;
  --red:#d64545; --redbg:#fbeaea; --green:#2e9e5b; --greenbg:#e8f6ee; --amber:#d99a2b; --amberbg:#fbf2e0;
  --sga:#1b365d; --gen4:#0f8a8a;
  --shadow:0 1px 3px rgba(16,39,66,.07),0 8px 24px rgba(16,39,66,.06);
}
*{box-sizing:border-box}
body{margin:0;font-family:'Inter',-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}
.wrap{max-width:1320px;margin:0 auto;padding:22px 22px 80px}
header.top{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:18px}
.title h1{margin:0;font-size:22px;font-weight:800;letter-spacing:-.02em;color:var(--navy)}
.title p{margin:4px 0 0;color:var(--muted);font-size:13px}
.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.seg{display:inline-flex;background:#eef1f5;border-radius:10px;padding:3px}
.seg button{border:0;background:transparent;padding:7px 13px;border-radius:8px;font-size:12.5px;font-weight:600;color:var(--muted);cursor:pointer;transition:.15s}
.seg button.active{background:#fff;color:var(--navy);box-shadow:0 1px 2px rgba(0,0,0,.08)}
.lbl{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-right:2px}

/* KPI strip — counter-tween the .k-v values; flag the headline risk card .alert */
.kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:18px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:15px 16px;box-shadow:var(--shadow);opacity:0;transform:translateY(8px);animation:rise .5s forwards}
.kpi .k-l{font-size:11.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.kpi .k-v{font-size:25px;font-weight:800;letter-spacing:-.02em;margin-top:6px;color:var(--navy);font-variant-numeric:tabular-nums}
.kpi .k-s{font-size:12px;color:var(--muted);margin-top:3px}
.kpi.alert{background:linear-gradient(180deg,#fff, #fff6f6);border-color:#f3cccc}
.kpi.alert .k-v{color:var(--red)}
.kpi.alert .k-l{color:var(--red)}
@keyframes rise{to{opacity:1;transform:none}}

/* Tabs — gold underline on active; opinion-first default tab */
.tabs{display:flex;gap:6px;border-bottom:1px solid var(--line);margin-bottom:18px;flex-wrap:wrap}
.tabs button{border:0;background:transparent;padding:11px 15px;font-size:13.5px;font-weight:700;color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-1px}
.tabs button.active{color:var(--navy);border-color:var(--gold)}
.panel{display:none;animation:fade .35s}
.panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1}}

.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow);margin-bottom:16px}
.card h3{margin:0 0 2px;font-size:15px;color:var(--navy);font-weight:800}
.card .sub{color:var(--muted);font-size:12.5px;margin:0 0 14px}
.chart-wrap{position:relative;height:340px}      /* ALWAYS wrap canvases in a sized div */
.chart-wrap.sm{height:260px}
.grid2{display:grid;grid-template-columns:1.6fr 1fr;gap:16px}
@media(max-width:980px){.grid2{grid-template-columns:1fr}.kpis{grid-template-columns:repeat(2,1fr)}}

/* Period summary cards (quarter/month) with QoQ delta color */
.qrow{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
@media(max-width:980px){.qrow{grid-template-columns:repeat(2,1fr)}}
.qcard{border:1px solid var(--line);border-radius:11px;padding:12px;background:#fcfdff}
.qcard .q{font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase}
.qcard .qv{font-size:18px;font-weight:800;color:var(--navy);margin-top:5px;font-variant-numeric:tabular-nums}
.qcard .qd{font-size:12px;margin-top:3px;font-weight:700}
.up{color:var(--green)} .down{color:var(--red)} .flat{color:var(--muted)}

/* Sortable scorecard table — right-aligned tabular nums, in-cell magnitude bars */
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:12px}
.toolbar input[type=search]{border:1px solid var(--line);border-radius:9px;padding:8px 11px;font-size:13px;min-width:220px;outline:none}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{text-align:right;padding:9px 10px;color:var(--muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line);cursor:pointer;user-select:none;white-space:nowrap}
thead th.l{text-align:left}
thead th.sorted{color:var(--navy)}
tbody td{padding:9px 10px;text-align:right;border-bottom:1px solid #f1f4f7;font-variant-numeric:tabular-nums;white-space:nowrap}
tbody td.l{text-align:left}
tbody tr{cursor:pointer;transition:background .12s}
tbody tr:hover{background:#f7fafd}
.pill{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700}
.pill.sga{background:#e8eef7;color:var(--sga)} .pill.gen4{background:#e1f3f3;color:var(--gen4)}
.bar{position:relative}
.bar .fill{position:absolute;left:0;top:50%;transform:translateY(-50%);height:18px;background:linear-gradient(90deg,rgba(27,54,93,.16),rgba(27,54,93,.05));border-radius:4px;z-index:0}
.bar span{position:relative;z-index:1}
.rate-good{color:var(--green);font-weight:700}.rate-mid{color:var(--amber);font-weight:700}.rate-bad{color:var(--red);font-weight:700}

/* Right-slide drill rail — preserves full source record, not a summary */
.rail{position:fixed;top:0;right:-560px;width:540px;max-width:94vw;height:100vh;background:#fff;box-shadow:-12px 0 40px rgba(16,39,66,.18);transition:right .3s cubic-bezier(.4,0,.2,1);z-index:50;overflow-y:auto;padding:22px}
.rail.open{right:0}
.rail .x{position:absolute;top:16px;right:18px;border:0;background:#eef1f5;border-radius:8px;width:32px;height:32px;font-size:17px;cursor:pointer;color:var(--muted)}
.rail h2{margin:0 8px 2px 0;font-size:19px;color:var(--navy);max-width:440px}
.rail .meta{color:var(--muted);font-size:12.5px;margin-bottom:16px}
.mini{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}
.mini div{border:1px solid var(--line);border-radius:10px;padding:10px}
.mini .m-l{font-size:10.5px;color:var(--muted);text-transform:uppercase;font-weight:700}
.mini .m-v{font-size:16px;font-weight:800;color:var(--navy);margin-top:3px;font-variant-numeric:tabular-nums}
.overlay{position:fixed;inset:0;background:rgba(16,39,66,.28);opacity:0;pointer-events:none;transition:.3s;z-index:40}
.overlay.show{opacity:1;pointer-events:auto}
.note{font-size:12px;color:var(--muted);background:#f7fafd;border:1px dashed var(--line);border-radius:10px;padding:10px 12px;margin-top:8px}

/* Optional: cream "send-out" email-preview card (Krista-style update generator) */
.email{margin-top:14px;background:#fffdf8;border:1px solid #f0e6cf;border-radius:12px;padding:18px 20px;font-size:13.5px;line-height:1.62;color:#2a2f36;white-space:pre-wrap}
.email h4{margin:2px 0 6px;font-size:16px;color:var(--navy)}
.email .em-sec{margin:13px 0 3px;font-weight:800;color:var(--navy2)}
.email .em-stat{background:#fff;border:1px solid #f0e6cf;border-radius:8px;padding:8px 11px;margin:6px 0;font-weight:600}
.foot{color:var(--muted);font-size:11.5px;margin-top:20px;line-height:1.6}
