*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg: #0b0b0f;
  --card: #15151c;
  --card2: #1c1c26;
  --border: #26262f;
  --text: #e2e2ec;
  --text-muted: #888899;
  --text-dim: #555566;
  --purple: #7c3aed;
  --pink: #ec4899;
  --elite: #4ade80;
  --elite-bg: rgba(74,222,128,0.12);
  --good: #60a5fa;
  --good-bg: rgba(96,165,250,0.12);
  --alert: #facc15;
  --alert-bg: rgba(250,204,21,0.12);
  --danger: #f87171;
  --danger-bg: rgba(248,113,113,0.12);
  --radius: 10px;
  --radius-sm: 6px;
}

html { font-size: 14px; }
body { background: var(--bg); color: var(--text); font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; min-height: 100vh; }

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

/* ── Login ── */
.login-page { display: flex; align-items: center; justify-content: center; min-height: 100vh; background: var(--bg); }
.login-box { background: var(--card); border: 1px solid var(--border); border-radius: 16px; padding: 48px 40px; width: 360px; }
.login-logo { font-size: 22px; font-weight: 700; background: linear-gradient(135deg, var(--purple), var(--pink)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; margin-bottom: 8px; }
.login-subtitle { color: var(--text-muted); font-size: 13px; margin-bottom: 32px; }
.login-box label { display: block; font-size: 12px; color: var(--text-muted); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 6px; }
.login-box input { width: 100%; background: var(--bg); border: 1px solid var(--border); color: var(--text); border-radius: var(--radius-sm); padding: 10px 14px; font-size: 14px; margin-bottom: 20px; outline: none; transition: border-color .15s; }
.login-box input:focus { border-color: var(--purple); }
.login-btn { width: 100%; padding: 11px; background: linear-gradient(135deg, var(--purple), var(--pink)); border: none; border-radius: var(--radius-sm); color: #fff; font-size: 14px; font-weight: 600; cursor: pointer; transition: opacity .15s; }
.login-btn:hover { opacity: .88; }
.login-error { background: var(--danger-bg); border: 1px solid var(--danger); border-radius: var(--radius-sm); color: var(--danger); font-size: 12px; padding: 8px 12px; margin-bottom: 16px; }

/* ── Layout ── */
#app { max-width: 1400px; margin: 0 auto; padding: 0 24px 60px; }

/* ── Header ── */
.header { position: sticky; top: 0; z-index: 100; background: rgba(11,11,15,.95); backdrop-filter: blur(8px); border-bottom: 1px solid var(--border); padding: 14px 24px; display: flex; align-items: center; gap: 12px; margin: 0 -24px 24px; padding-left: 24px; padding-right: 24px; }
.header-title { font-size: 15px; font-weight: 700; background: linear-gradient(135deg, var(--purple), var(--pink)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; white-space: nowrap; flex-shrink: 0; }
/* Site selector */
.site-selector { display: flex; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm); overflow: hidden; flex-shrink: 0; }
.site-btn { padding: 6px 14px; background: none; border: none; color: var(--text-muted); font-size: 12px; font-weight: 600; cursor: pointer; transition: all .15s; letter-spacing: .02em; }
.site-btn.active { background: linear-gradient(135deg, var(--purple), var(--pink)); color: #fff; }
.header-spacer { flex: 1; }
.view-toggle { display: flex; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm); overflow: hidden; flex-shrink: 0; }
.view-btn { padding: 7px 16px; background: none; border: none; color: var(--text-muted); font-size: 12px; font-weight: 500; cursor: pointer; transition: all .15s; }
.view-btn.active { background: var(--purple); color: #fff; }
.icon-btn { background: var(--card); border: 1px solid var(--border); color: var(--text-muted); border-radius: var(--radius-sm); padding: 7px 14px; font-size: 12px; cursor: pointer; transition: all .15s; white-space: nowrap; }
.icon-btn:hover { border-color: var(--purple); color: var(--text); }

/* ── Date Picker Bar ── */
.datepicker-bar { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px 18px; margin-bottom: 20px; display: flex; align-items: center; flex-wrap: wrap; gap: 10px; }
.preset-group { display: flex; gap: 6px; flex-wrap: wrap; }
.preset-btn { padding: 5px 12px; background: transparent; border: 1px solid var(--border); border-radius: 20px; color: var(--text-muted); font-size: 12px; cursor: pointer; transition: all .15s; white-space: nowrap; }
.preset-btn:hover { border-color: var(--purple); color: var(--text); }
.preset-btn.active { background: var(--purple); border-color: var(--purple); color: #fff; }
.date-sep { color: var(--text-dim); font-size: 11px; padding: 0 4px; }
.custom-range { display: flex; align-items: center; gap: 8px; }
.date-input { background: var(--bg); border: 1px solid var(--border); color: var(--text); border-radius: var(--radius-sm); padding: 5px 10px; font-size: 12px; cursor: pointer; }
.date-input:focus { outline: none; border-color: var(--purple); }
.comparison-select { background: var(--bg); border: 1px solid var(--border); color: var(--text-muted); border-radius: var(--radius-sm); padding: 5px 10px; font-size: 12px; cursor: pointer; }
.comparison-select:focus { outline: none; }
.date-range-display { font-size: 12px; color: var(--text-muted); background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 5px 12px; }

/* ── North Star (compact) ── */
.north-star { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px 24px; margin-bottom: 20px; }
.ns-badge { font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 20px; margin-left: 10px; vertical-align: middle; }
.ns-badge.on-track  { background: var(--elite-bg);  color: var(--elite);  border: 1px solid rgba(74,222,128,.3); }
.ns-badge.behind    { background: var(--alert-bg);  color: var(--alert);  border: 1px solid rgba(250,204,21,.3); }
.ns-badge.far-behind{ background: var(--danger-bg); color: var(--danger); border: 1px solid rgba(248,113,113,.3); }

.ns-compact-title { font-size: 13px; font-weight: 600; color: var(--text-muted); margin-bottom: 16px; }

.ns-table { display: grid; gap: 0; overflow-x: auto; }
.ns-col-header { font-size: 11px; font-weight: 700; color: var(--text-dim); text-transform: uppercase; letter-spacing: .06em; padding: 0 0 10px; }
.ns-col-sub { font-size: 10px; font-weight: 400; color: var(--text-dim); margin-left: 4px; text-transform: none; letter-spacing: 0; }
.ns-row-label { font-size: 12px; color: var(--text-muted); padding: 10px 0; border-top: 1px solid var(--border); align-self: center; }
.ns-val { font-size: 20px; font-weight: 700; padding: 10px 0; border-top: 1px solid var(--border); align-self: center; }
.ns-val-pos { color: var(--text); }
.ns-val-neg { color: var(--danger); }
.ns-val-dim { color: var(--text-muted); font-size: 16px; font-weight: 500; }
.ns-var-positive { color: var(--elite); }
.ns-var-negative { color: var(--danger); }

/* ── Gap Analysis ── */
.gap-analysis { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; margin-bottom: 20px; }
.section-title { font-size: 13px; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 16px; }
.gap-row { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.gap-name { font-size: 12px; color: var(--text); width: 240px; flex-shrink: 0; }
.gap-bar-wrap { flex: 1; background: var(--bg); height: 8px; border-radius: 4px; overflow: hidden; }
.gap-bar-fill { height: 100%; border-radius: 4px; }
.gap-bar-fill.active { background: linear-gradient(90deg, var(--purple), var(--pink)); }
.gap-bar-fill.control { background: var(--good); }
.gap-chips { display: flex; gap: 6px; flex-shrink: 0; }
.gap-chip { font-size: 11px; padding: 2px 8px; border-radius: 10px; white-space: nowrap; }
.gap-chip.baseline { background: rgba(96,165,250,.15); color: var(--good); }
.gap-chip.upside { background: rgba(124,58,237,.15); color: #a78bfa; }
.gap-chip.total { background: rgba(236,72,153,.15); color: var(--pink); font-weight: 600; }
.gap-remaining { background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 12px 16px; margin-top: 12px; display: flex; align-items: center; justify-content: space-between; }
.gap-remaining-label { font-size: 12px; color: var(--text-muted); }
.gap-remaining-value { font-size: 16px; font-weight: 700; color: var(--alert); }

/* ── Next Steps ── */
.next-steps { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; margin-bottom: 24px; }
.next-steps-header { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.counter-badge { font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 12px; }
.counter-badge.danger { background: var(--danger-bg); color: var(--danger); }
.counter-badge.alert { background: var(--alert-bg); color: var(--alert); }
.counter-badge.elite { background: var(--elite-bg); color: var(--elite); }
.next-item { display: flex; align-items: flex-start; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--border); }
.next-item:last-child { border-bottom: none; }
.next-badge { font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 8px; white-space: nowrap; flex-shrink: 0; margin-top: 1px; }
.next-badge.DANGER { background: var(--danger-bg); color: var(--danger); }
.next-badge.ALERT { background: var(--alert-bg); color: var(--alert); }
.next-kpi { font-size: 12px; font-weight: 600; color: var(--text); flex: 1; }
.next-action { font-size: 12px; color: var(--text-muted); flex: 2; }

/* ── Building Block Sections ── */
.block-section { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); margin-bottom: 16px; overflow: hidden; }
.block-header { padding: 16px 20px; background: var(--card2); display: flex; align-items: center; gap: 12px; flex-wrap: wrap; cursor: pointer; user-select: none; }
.block-header:hover { background: #22222e; }
.block-name { font-size: 14px; font-weight: 700; color: var(--text); }
.role-badge { font-size: 10px; font-weight: 700; padding: 2px 10px; border-radius: 10px; }
.role-badge.Active { background: rgba(124,58,237,.2); color: #a78bfa; border: 1px solid rgba(124,58,237,.4); }
.role-badge.Control { background: rgba(96,165,250,.15); color: var(--good); border: 1px solid rgba(96,165,250,.3); }
.block-meta { font-size: 11px; color: var(--text-dim); flex: 1; }
.block-contrib { display: flex; gap: 8px; flex-shrink: 0; }
.contrib-chip { font-size: 11px; padding: 2px 10px; border-radius: 10px; }
.contrib-chip.baseline { background: rgba(96,165,250,.1); color: var(--good); }
.contrib-chip.upside { background: rgba(124,58,237,.1); color: #a78bfa; }
.contrib-chip.total { background: rgba(236,72,153,.1); color: var(--pink); font-weight: 600; }
.block-chevron { color: var(--text-dim); font-size: 16px; transition: transform .2s; }
.block-header.collapsed .block-chevron { transform: rotate(-90deg); }
.block-body { padding: 16px 20px; }
.block-body.collapsed { display: none; }
.kpi-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 12px; }

/* ── KPI Cards ── */
.kpi-card { background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 14px; transition: border-color .15s; }
.kpi-card:hover { border-color: var(--purple); }
.kpi-card-top { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 8px; }
.kpi-label { font-size: 12px; font-weight: 600; color: var(--text); line-height: 1.4; flex: 1; padding-right: 8px; }
.badge { font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 8px; white-space: nowrap; flex-shrink: 0; }
.badge.ELITE { background: var(--elite-bg); color: var(--elite); }
.badge.GOOD  { background: var(--good-bg);  color: var(--good);  }
.badge.ALERT { background: var(--alert-bg); color: var(--alert); }
.badge.DANGER{ background: var(--danger-bg);color: var(--danger); }
.badge.NA    { background: rgba(255,255,255,.05); color: var(--text-dim); }
.kpi-values { display: flex; gap: 16px; margin-bottom: 8px; }
.kpi-val { }
.kpi-val-label { font-size: 10px; color: var(--text-dim); text-transform: uppercase; margin-bottom: 2px; }
.kpi-val-num { font-size: 18px; font-weight: 700; }
.kpi-val-num.elite { color: var(--elite); }
.kpi-val-num.good  { color: var(--good);  }
.kpi-val-num.alert { color: var(--alert); }
.kpi-val-num.danger{ color: var(--danger); }
.kpi-delta { font-size: 11px; margin-bottom: 6px; }
.delta-up   { color: var(--elite); }
.delta-down { color: var(--danger); }
.delta-flat { color: var(--text-muted); }
.kpi-target { font-size: 11px; color: var(--text-dim); font-style: italic; margin-bottom: 6px; }
.kpi-action { font-size: 11px; color: var(--alert); background: var(--alert-bg); border-radius: 4px; padding: 4px 8px; line-height: 1.4; }
.kpi-action.danger { color: var(--danger); background: var(--danger-bg); }

/* ── Trend Chart ── */
.trend-section { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; margin-bottom: 20px; }
.trend-tabs { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.trend-tab { padding: 5px 14px; background: transparent; border: 1px solid var(--border); border-radius: 20px; color: var(--text-muted); font-size: 12px; cursor: pointer; transition: all .15s; }
.trend-tab.active { background: var(--purple); border-color: var(--purple); color: #fff; }
#trendChart { max-height: 280px; }

/* ── Weekly Review ── */
#weekly-view { display: none; }
.month-tabs { display: flex; gap: 8px; margin-bottom: 20px; }
.month-tab { padding: 7px 22px; background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text-muted); font-size: 13px; cursor: pointer; transition: all .15s; }
.month-tab:hover { border-color: var(--purple); }
.month-tab.active { background: var(--purple); border-color: var(--purple); color: #fff; }
.weekly-table-wrap { overflow-x: auto; }
table.weekly-table { width: 100%; border-collapse: collapse; font-size: 12px; white-space: nowrap; }
.weekly-table th { background: var(--card2); color: var(--text-muted); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; padding: 10px 12px; text-align: left; border-bottom: 2px solid var(--border); position: sticky; top: 0; }
.weekly-table td { padding: 8px 12px; border-bottom: 1px solid var(--border); vertical-align: top; line-height: 1.5; }
.weekly-table tr:hover td { background: rgba(124,58,237,.05); }
.block-row td { background: #1a1a24 !important; color: var(--text-muted); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.weekly-table td.cell-ELITE { background: rgba(74,222,128,.08); color: var(--elite); font-weight: 600; }
.weekly-table td.cell-GOOD  { background: rgba(96,165,250,.08); color: var(--good); }
.weekly-table td.cell-ALERT { background: rgba(250,204,21,.08); color: var(--alert); font-weight: 600; }
.weekly-table td.cell-DANGER{ background: rgba(248,113,113,.08); color: var(--danger); font-weight: 600; }
.weekly-table td.cell-empty { color: var(--text-dim); text-align: center; }
.weekly-table td.raci-cell { color: var(--text-dim); font-size: 11px; max-width: 180px; white-space: normal; }
.weekly-table td.target-cell { color: var(--text-dim); font-style: italic; max-width: 160px; white-space: normal; }
.data-2025 { color: var(--text-dim); font-size: 11px; font-style: italic; }
.anchor-indicator { display: inline-block; width: 6px; height: 6px; background: var(--pink); border-radius: 50%; margin-left: 4px; vertical-align: middle; title: 'Real data point'; }

/* ── EOY Forecast Card ── */
.eoy-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px 24px; margin-bottom: 20px; }
.eoy-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 16px; gap: 12px; }
.eoy-title { font-size: 13px; font-weight: 600; color: var(--text-muted); }
.eoy-method { font-weight: 400; color: var(--text-dim); }
.eoy-subtitle { font-size: 11px; color: var(--text-dim); margin-top: 4px; }
.eoy-body { display: grid; grid-template-columns: 40% 1fr; gap: 24px; align-items: start; }
@media (max-width: 800px) { .eoy-body { grid-template-columns: 1fr; } }

/* KPI grid */
.eoy-kpis { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.eoy-kpi { background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 12px; }
.eoy-kpi-label { font-size: 11px; color: var(--text-muted); margin-bottom: 6px; }
.eoy-kpi-value-row { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-bottom: 4px; }
.eoy-kpi-value { font-size: 19px; font-weight: 700; }
.eoy-kpi-sub { font-size: 11px; color: var(--text-dim); margin-top: 4px; line-height: 1.4; }
.eoy-dim { color: var(--text-muted); font-size: 19px; font-weight: 700; }
.eoy-pos { color: var(--elite);  font-size: 19px; font-weight: 700; }
.eoy-neg { color: var(--danger); font-size: 19px; font-weight: 700; }
.sub-good { color: var(--elite); }
.sub-bad  { color: var(--danger); }

/* Trajectory chip */
.eoy-chip { font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 10px; white-space: nowrap; }
.chip-up   { background: rgba(74,222,128,.15); color: var(--elite); }
.chip-down { background: rgba(248,113,113,.15); color: var(--danger); }

/* Chart */
.eoy-chart-wrap { position: relative; }
.eoy-hit { cursor: crosshair; }

/* Tooltip */
.eoy-tooltip { display: none; position: absolute; background: #1a1a22; border: 1px solid #2e2e3a; border-radius: 8px; padding: 11px 13px; min-width: 255px; box-shadow: 0 6px 24px rgba(0,0,0,.5); font-size: 12px; z-index: 20; pointer-events: none; }
.eoy-tt-head { font-size: 12px; font-weight: 600; color: var(--text); margin-bottom: 9px; }
.eoy-tt-row  { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 3px 0; }
.eoy-tt-lbl  { color: #94949f; display: flex; align-items: center; gap: 6px; white-space: nowrap; }
.eoy-tt-val  { font-weight: 600; color: var(--text); white-space: nowrap; }
.eoy-tt-sep  { border-top: 1px solid #2e2e3a; margin: 7px 0; }
.tt-pos { color: var(--elite)  !important; }
.tt-neg { color: var(--danger) !important; }

/* Dots in tooltip */
.eoy-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.dot-w    { background: #ffffff; }
.dot-ho-w { background: transparent; border: 1.5px solid #ffffff; }
.dot-y    { background: #facc15; }
.dot-ho-y { background: transparent; border: 1.5px solid #facc15; }
.dot-g    { background: #94949f; }

/* Legend */
.eoy-legend { display: flex; justify-content: flex-end; gap: 14px; margin-top: 6px; }
.eoy-legend-item { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--text-dim); }

/* ── KPI Snapshot ── */
.snap-section { margin: 0 0 28px; }
.snap-section-hdr { font-size: 10px; font-weight: 600; color: var(--text-dim); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 14px; }
.snap-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 960px) { .snap-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .snap-grid { grid-template-columns: 1fr; } }

.snap-card { background: #131319; border: 1px solid #23232c; border-radius: 14px; padding: 18px 20px 14px; display: flex; flex-direction: column; gap: 8px; min-height: 200px; }
.snap-hdr { display: flex; justify-content: space-between; align-items: center; }
.snap-ttl { font-size: 11px; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: .06em; }
.snap-ico { font-size: 15px; }
.snap-val { font-size: 28px; font-weight: 700; color: var(--text); line-height: 1.1; }
.snap-val-s { font-size: 18px !important; }
.snap-dual { display: flex; align-items: flex-end; gap: 14px; }
.snap-val-ga4 { display: flex; flex-direction: column; gap: 2px; }
.snap-src { font-size: 9px; font-weight: 600; color: var(--text-dim); text-transform: uppercase; letter-spacing: .06em; }
.snap-chip { font-size: 12px; font-weight: 700; }
.snap-foot { display: flex; justify-content: space-between; align-items: center; border-top: 1px solid #23232c; padding-top: 9px; margin-top: auto; }
.snap-tinfo { font-size: 11px; color: var(--text-dim); }

/* ── Utilities ── */
.hidden { display: none !important; }
.text-right { text-align: right; }
.mt-4 { margin-top: 16px; }
.text-muted { color: var(--text-muted); }
.text-dim { color: var(--text-dim); }

/* ── Weekly Review Controls ── */
.wr-controls { display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap; }
.wr-sub-toggle { display:flex;gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden; }
.wr-toggle-btn { background:none;border:none;color:var(--text-dim);font-size:12px;padding:5px 14px;cursor:pointer;transition:.15s; }
.wr-toggle-btn.active { background:var(--accent, #7c3aed);color:#fff; }
.wr-month-nav { display:flex;align-items:center;gap:8px; }
.wr-month-nav button { background:none;border:1px solid var(--border);color:var(--text-dim);border-radius:4px;width:24px;height:24px;cursor:pointer;font-size:12px; }
.wr-month-nav button:hover { border-color:var(--purple);color:var(--text); }
#wrMonthLabel { font-size:13px;font-weight:600;color:var(--text);min-width:100px;text-align:center; }
.wr-show-past-btn { background:none;border:1px solid var(--border);color:var(--text-dim);font-size:11px;padding:4px 12px;border-radius:5px;cursor:pointer;transition:.15s; }
.wr-show-past-btn.active { border-color:var(--purple);color:var(--text); }

/* ── Verdict Strip ── */
.wr-verdict-strip { display:flex;gap:8px;padding:10px 16px;flex-wrap:wrap; }
.wr-verdict-badge { display:flex;align-items:center;gap:8px;padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;border:1px solid transparent; }
.wr-verdict-badge.scale { background:rgba(74,222,128,.12);border-color:rgba(74,222,128,.25);color:#4ade80; }
.wr-verdict-badge.stable { background:rgba(96,165,250,.1);border-color:rgba(96,165,250,.2);color:#60a5fa; }
.wr-verdict-badge.investigate { background:rgba(250,204,21,.1);border-color:rgba(250,204,21,.2);color:#facc15; }
.wr-verdict-badge.freeze { background:rgba(248,113,113,.1);border-color:rgba(248,113,113,.2);color:#f87171; }
.wr-verdict-icon { font-size:14px; }

/* ── Table ── */
.wr-table-wrap { overflow-x:auto;padding:0 8px 12px; }
.wr-table { width:100%;border-collapse:collapse;font-size:12px; }
.wr-table th { padding:7px 10px;text-align:center;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:2px solid var(--border);white-space:nowrap;position:sticky;top:0;background:var(--card, #15151c);z-index:2; }
.wr-table th:first-child { text-align:left;width:220px;position:sticky;left:0;z-index:3; }
.wr-table td { padding:0;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:top; }
.wr-table td:first-child { position:sticky;left:0;background:var(--card, #15151c);z-index:1; }

/* Block header row */
.wr-block-hdr td { padding:0!important; }
.wr-block-hdr-inner { display:flex;align-items:center;gap:8px;padding:8px 10px 6px;border-left:4px solid;margin-top:8px; }
.wr-block-icon { font-size:14px; }
.wr-block-title { font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em; }
.wr-block-verdict { font-size:9px;font-weight:700;padding:2px 7px;border-radius:4px;margin-left:auto; }
.wr-block-verdict.scale { background:rgba(74,222,128,.15);color:#4ade80; }
.wr-block-verdict.stable { background:rgba(96,165,250,.12);color:#60a5fa; }
.wr-block-verdict.investigate { background:rgba(250,204,21,.12);color:#facc15; }
.wr-block-verdict.freeze { background:rgba(248,113,113,.12);color:#f87171; }
.wr-block-verdict.na { background:rgba(148,148,159,.1);color:#94949f; }

/* KPI name cell */
.wr-kpi-name { padding:4px 10px;color:var(--text);font-size:12px;cursor:help;border-right:1px solid rgba(255,255,255,.05);min-width:200px; }
.wr-kpi-name:hover { color:#fff; }

/* Data cell: 7D top / 30D bottom */
.wr-cell { padding:4px 8px;min-width:90px;text-align:center;position:relative;border-right:1px solid rgba(255,255,255,.04); }
.wr-cell.current-col { background:rgba(255,255,255,.03);border-left:1px solid rgba(255,255,255,.08);border-right:1px solid rgba(255,255,255,.08); }
.wr-cell.collapsed { display:none; }
.wr-7d { display:block;font-size:12px;font-weight:700;color:#e2e2ec;line-height:1.4; }
.wr-divider { display:block;border-top:1px dashed rgba(255,255,255,.12);margin:2px 0; }
.wr-30d { display:block;font-size:11px;color:#94949f;line-height:1.4; }
.wr-arrow { font-size:10px;margin-left:2px; }
.wr-arrow.up { color:#4ade80; }
.wr-arrow.down { color:#f87171; }

/* Divergence markers */
.wr-cell.diverge-warn::before { content:'⚠';position:absolute;top:2px;left:2px;font-size:8px;color:#facc15;line-height:1; }
.wr-cell.diverge-recovery::before { content:'✦';position:absolute;top:2px;left:2px;font-size:8px;color:#4ade80;line-height:1; }

/* Status colors on cells */
.wr-cell.status-elite { background:rgba(74,222,128,.08); }
.wr-cell.status-good  { background:rgba(74,222,128,.04); }
.wr-cell.status-alert { background:rgba(250,204,21,.06); }
.wr-cell.status-danger{ background:rgba(248,113,113,.08); }
.wr-cell.status-na    { opacity:.5; }
.wr-cell.placeholder  { background:rgba(148,148,159,.04); }

/* Tooltip */
.wr-tooltip { position:fixed;z-index:9999;background:#1a1a22;border:1px solid #2a2a3a;border-radius:8px;padding:10px 14px;font-size:11px;color:var(--text);max-width:260px;pointer-events:none;display:none;box-shadow:0 4px 20px rgba(0,0,0,.6); }
.wr-tooltip-title { font-weight:700;color:#fff;margin-bottom:6px;font-size:12px; }
.wr-tooltip-row { display:flex;justify-content:space-between;gap:12px;padding:2px 0; }
.wr-tooltip-label { color:var(--text-dim); }
.wr-tooltip-val.elite { color:#4ade80; }
.wr-tooltip-val.good  { color:#86efac; }
.wr-tooltip-val.alert { color:#facc15; }
.wr-tooltip-val.danger{ color:#f87171; }
.wr-tooltip-note { margin-top:6px;font-size:10px;color:var(--text-dim);font-style:italic; }

/* Legend */
.wr-legend { display:flex;gap:14px;align-items:center;flex-wrap:wrap;padding:8px 16px 12px;font-size:11px;color:var(--text-dim); }
.wr-leg-item { display:flex;align-items:center;gap:5px; }
.wr-leg-dot { width:9px;height:9px;border-radius:50%; }
.wr-leg-dot.elite { background:#4ade80; }
.wr-leg-dot.good  { background:#86efac; }
.wr-leg-dot.alert { background:#facc15; }
.wr-leg-dot.danger{ background:#f87171; }

/* Partner Panel Dropdown */
.wr-partner-panel { position:absolute;z-index:9999;background:#1a1a22;border:1px solid #2e2e3a;border-radius:8px;padding:0;min-width:400px;max-width:520px;box-shadow:0 8px 32px rgba(0,0,0,.7);display:none; }
.wr-partner-header { display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid #2e2e3a;font-size:12px;font-weight:700;color:#fff; }
.wr-dropdown-btn { background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:10px;padding:0 2px;margin-left:3px;vertical-align:middle; }
.wr-dropdown-btn:hover { color:#fff; }
.wr-tag { font-size:8px;font-weight:700;opacity:.45;margin-right:2px;letter-spacing:.04em; }

/* ── Print / PDF ── */
@media print {
  body { background: #fff; color: #000; }
  .header { position: static; background: #fff; box-shadow: none; }
  .icon-btn, .view-toggle, .datepicker-bar { display: none; }
  .block-body.collapsed { display: block !important; }
  .kpi-card { break-inside: avoid; border: 1px solid #ddd; }
  :root { --bg: #fff; --card: #f8f8f8; --text: #111; --text-muted: #444; }
}
