/* ============================================================
   SHAMS — Unified Design System
   See DESIGN.md and UI-RULES.md for the source of truth.
   ============================================================ */

:root {
  /* Neutrals (90%) */
  --bg:         #FBFBFD;
  --surface:    #FFFFFF;
  --ink:        #1D1D1F;
  --ink-2:      #6E6E73;
  --ink-3:      #86868B;
  --hair:       #D2D2D7;
  --hair-soft:  #E8E8ED;

  /* Single accent (10%) */
  --sun:        #E0921A;
  --sun-soft:   #FFF6E6;

  /* Functional (sparingly) */
  --positive:   #1D9E6B;
  --critical:   #D83A3A;

  /* Spacing (8px grid) */
  --sp-1: 8px;
  --sp-2: 16px;
  --sp-3: 24px;
  --sp-4: 32px;
  --sp-5: 48px;
  --sp-6: 64px;
  --sp-8: 96px;

  /* Radius */
  --r-card: 18px;
  --r-chip: 999px;

  /* Elevation */
  --shadow-s: 0 1px 3px rgba(0,0,0,.04), 0 6px 16px rgba(0,0,0,.04);
  --shadow-m: 0 4px 14px rgba(0,0,0,.06), 0 18px 40px rgba(0,0,0,.06);

  /* Motion */
  --ease: cubic-bezier(.4, 0, .2, 1);

  /* Typography */
  --font: 'Inter Tight', -apple-system, BlinkMacSystemFont, 'SF Pro Display', sans-serif;
  --font-ar: 'Inter Tight', 'Geeza Pro', 'Noto Sans Arabic', var(--font);
  --t-display: clamp(32px, 6vw, 48px);
  --t-heading: clamp(24px, 4vw, 32px);
  --t-body: 16px;
  --t-caption: 14px;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--ink);
  font-size: var(--t-body);
  line-height: 1.5;
  letter-spacing: 0;
  min-height: 100vh;
}

button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
a { color: inherit; text-decoration: none; }
svg { display: block; }
img { max-width: 100%; display: block; }

.num, .stat__num, .kpi__num, [data-num] { font-variant-numeric: tabular-nums; }
.ar { font-family: var(--font-ar); direction: rtl; unicode-bidi: plaintext; }

:focus-visible {
  outline: 2px solid var(--sun);
  outline-offset: 2px;
  border-radius: 4px;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ============================================================
   TYPOGRAPHY — 4 sizes only
   ============================================================ */
h1, .t-display {
  font-size: var(--t-display);
  line-height: 1.1;
  font-weight: 700;
  letter-spacing: -0.03em;
}
h2, .t-heading {
  font-size: var(--t-heading);
  line-height: 1.15;
  font-weight: 700;
  letter-spacing: -0.022em;
}
h3, h4 { font-size: var(--t-body); font-weight: 600; line-height: 1.4; letter-spacing: -0.01em; }
p, .t-body { font-size: var(--t-body); line-height: 1.5; }
.t-caption, small, .meta { font-size: var(--t-caption); line-height: 1.4; }

.eyebrow {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--sun);
}

/* ============================================================
   LAYOUT
   ============================================================ */
.wrap { max-width: 1120px; margin: 0 auto; padding: 0 var(--sp-3); }

.section { padding: var(--sp-8) 0; }
.section--alt { background: var(--surface); }
.section--tight { padding: var(--sp-6) 0; }

@media (max-width: 768px) {
  .section { padding: var(--sp-5) 0; }
  .section--tight { padding: var(--sp-4) 0; }
}

.sec-head { max-width: 680px; margin: 0 auto var(--sp-5); text-align: center; }
.sec-head .eyebrow { display: block; margin-bottom: var(--sp-1); }
.sec-head p { color: var(--ink-2); margin-top: var(--sp-2); max-width: 60ch; margin-inline: auto; }
.sec-head--left { text-align: left; margin-inline: 0; max-width: none; }
.sec-head--left p { margin-inline: 0; }

/* ============================================================
   NAV (sticky top)
   ============================================================ */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  height: 64px;
  background: rgba(251,251,253,0.82);
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  border-bottom: 1px solid var(--hair-soft);
}
.nav__in {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 var(--sp-3);
  height: 100%;
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}
.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  font-size: var(--t-body);
  letter-spacing: -0.02em;
  white-space: nowrap;
  color: var(--ink);
}
.brand__logo {
  width: auto;
  height: 28px;
  color: var(--ink);
  flex: none;
  display: block;
}
.brand__logo--lg { height: 36px; }

.tabs {
  display: inline-flex;
  background: var(--hair-soft);
  border-radius: var(--r-chip);
  padding: 3px;
  gap: 2px;
  margin-left: auto;
  margin-right: auto;
}
.tab {
  font-size: 13px;
  font-weight: 500;
  padding: 7px 16px;
  border-radius: var(--r-chip);
  color: var(--ink-2);
  transition: 200ms var(--ease);
  white-space: nowrap;
}
.tab:hover { color: var(--ink); }
.tab.on {
  background: var(--surface);
  color: var(--ink);
  box-shadow: var(--shadow-s);
}

.nav__meta { font-size: 12px; color: var(--ink-3); display: flex; align-items: center; gap: var(--sp-1); white-space: nowrap; }
.nav__dot { width: 7px; height: 7px; border-radius: 50%; background: var(--positive); }

@media (max-width: 720px) {
  .nav__in { gap: var(--sp-2); }
  .nav__meta { display: none; }
  .tab { padding: 6px 12px; font-size: 12px; }
}

/* ============================================================
   PAGE (tab section)
   ============================================================ */
.page { display: none; }
.page.on { display: block; animation: fadeUp 600ms var(--ease); }
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  padding: var(--sp-8) 0 var(--sp-5);
  text-align: center;
}
.hero .eyebrow { display: block; margin-bottom: var(--sp-2); }
.hero h1 { max-width: 18ch; margin: 0 auto; }
.hero h1 em {
  font-style: normal;
  background: linear-gradient(180deg, var(--ink) 0%, #3a3a3c 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero__sub { margin-top: var(--sp-2); font-size: 18px; color: var(--ink-2); max-width: 60ch; margin-inline: auto; }
.hero--left { text-align: left; padding-top: var(--sp-6); }
.hero--left h1, .hero--left .hero__sub { margin-inline: 0; }
.hero--left h1 { max-width: 22ch; }
.hero--left .hero__sub { max-width: 70ch; }

@media (max-width: 768px) {
  .hero { padding: var(--sp-5) 0 var(--sp-4); }
}

/* ============================================================
   STAT STRIP
   ============================================================ */
.stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  max-width: 880px;
  margin: var(--sp-5) auto 0;
  border-top: 1px solid var(--hair-soft);
}
.stat {
  padding: var(--sp-4) var(--sp-2);
  text-align: center;
  border-right: 1px solid var(--hair-soft);
}
.stat:last-child { border-right: none; }
.stat__num {
  font-size: clamp(28px, 4.5vw, 44px);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.stat__num .approx { font-size: 0.7em; font-weight: 600; color: var(--ink-3); vertical-align: 5%; }
.stat__label { font-size: 12px; color: var(--ink-3); margin-top: var(--sp-1); }

@media (max-width: 640px) {
  .stats { grid-template-columns: repeat(2, 1fr); }
  .stat:nth-child(2) { border-right: none; }
  .stat:nth-child(1), .stat:nth-child(2) { border-bottom: 1px solid var(--hair-soft); }
}

/* ============================================================
   CARD — single primitive
   ============================================================ */
.card {
  background: var(--surface);
  border: 1px solid var(--hair-soft);
  border-radius: var(--r-card);
  box-shadow: var(--shadow-s);
  padding: var(--sp-3);
  transition: box-shadow 400ms var(--ease), transform 400ms var(--ease);
}
.card:hover { box-shadow: var(--shadow-m); }
.card--lg { padding: var(--sp-4); }
.card--sun {
  background: linear-gradient(135deg, var(--sun-soft), var(--surface) 60%);
  border-color: #F0DCAE;
}
.card--lift:hover { transform: translateY(-4px); }

/* ============================================================
   BUTTON — single primitive
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1);
  background: var(--surface);
  border: 1px solid var(--hair);
  color: var(--ink);
  font-size: 13px;
  font-weight: 600;
  padding: 8px 16px;
  border-radius: var(--r-chip);
  transition: 200ms var(--ease);
  white-space: nowrap;
}
.btn:hover { background: var(--hair-soft); }
.btn--accent { background: var(--sun); color: #fff; border-color: var(--sun); }
.btn--accent:hover { background: #c97f10; border-color: #c97f10; }

/* ============================================================
   CHIP
   ============================================================ */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: var(--r-chip);
  background: var(--hair-soft);
  color: var(--ink-2);
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.chip--sun { background: var(--sun-soft); color: #a86a12; }
.chip--positive { background: #E9F7F0; color: var(--positive); }
.chip--critical { background: #FDECEC; color: var(--critical); }
.chip__dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

/* ============================================================
   SUB-TAB
   ============================================================ */
.subtabs {
  display: flex;
  gap: var(--sp-1);
  margin: var(--sp-3) 0 var(--sp-4);
  border-bottom: 1px solid var(--hair-soft);
  overflow-x: auto;
}
.subtab {
  font-size: var(--t-caption);
  font-weight: 500;
  padding: 12px 16px;
  color: var(--ink-2);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: 200ms var(--ease);
  white-space: nowrap;
}
.subtab:hover { color: var(--ink); }
.subtab.on { color: var(--ink); border-bottom-color: var(--sun); }
.subpage { display: none; }
.subpage.on { display: block; animation: fadeUp 400ms var(--ease); }

/* ============================================================
   GRID
   ============================================================ */
.grid { display: grid; gap: var(--sp-3); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) {
  .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}

/* ============================================================
   REVEAL
   ============================================================ */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity 600ms var(--ease), transform 600ms var(--ease); }
.reveal.in { opacity: 1; transform: translateY(0); }

/* ============================================================
   ORGANIZATION
   ============================================================ */
.lead-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-3);
  max-width: 940px;
  margin: 0 auto;
}
@media (max-width: 800px) { .lead-grid { grid-template-columns: 1fr; max-width: 420px; } }

.lead-card { text-align: center; padding: var(--sp-4) var(--sp-3); }
.lead-avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  margin: 0 auto var(--sp-2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 600;
  color: #fff;
  background: var(--ink);
}
.lead-card h3 { font-size: 20px; font-weight: 600; }
.lead-card .role {
  font-size: 11px;
  font-weight: 600;
  color: var(--sun);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.lead-card .desc { font-size: var(--t-caption); color: var(--ink-2); margin-top: var(--sp-1); }

.org-top { text-align: center; margin-bottom: var(--sp-5); }
.org-top__chip {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  background: var(--ink);
  color: #fff;
  padding: var(--sp-2) var(--sp-4);
  border-radius: var(--r-card);
}
.org-top__chip strong { font-size: 18px; font-weight: 600; letter-spacing: -0.02em; }
.org-top__chip span { font-size: 11px; color: rgba(255,255,255,0.6); letter-spacing: 0.08em; text-transform: uppercase; }
.org-stem { width: 1px; height: 32px; background: var(--hair); margin: 0 auto; }

/* ============================================================
   DEPARTMENT CARDS
   ============================================================ */
.dept-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-2);
}
@media (max-width: 900px) { .dept-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .dept-grid { grid-template-columns: 1fr; } }

.dept { padding: 0; overflow: hidden; align-self: start; }
.dept__btn {
  width: 100%;
  text-align: left;
  padding: var(--sp-3);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  font: inherit;
  color: inherit;
}
.dept__top { display: flex; align-items: center; gap: var(--sp-2); }
.dept__mark {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: var(--hair-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  color: var(--ink);
  flex-shrink: 0;
}
.dept__name { font-size: 17px; font-weight: 600; letter-spacing: -0.02em; }
.dept__lead { font-size: 12px; color: var(--ink-2); margin-top: 2px; }
.dept__chev {
  margin-left: auto;
  width: 24px;
  height: 24px;
  color: var(--ink-3);
  transition: transform 400ms var(--ease);
  display: flex;
  align-items: center;
  justify-content: center;
}
.dept.open .dept__chev { transform: rotate(180deg); }

.dept__metrics { display: flex; gap: var(--sp-1); flex-wrap: wrap; }
.metric {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  background: var(--bg);
  border-radius: var(--r-chip);
  padding: 5px 12px;
  font-size: 12px;
}
.metric b { font-size: 13px; font-weight: 600; color: var(--ink); }
.metric span { color: var(--ink-3); }

.dept__detail { display: grid; grid-template-rows: 0fr; transition: grid-template-rows 400ms var(--ease); }
.dept.open .dept__detail { grid-template-rows: 1fr; }
.dept__detail-inner { overflow: hidden; }
.dept__detail-pad { padding: 0 var(--sp-3) var(--sp-3); }
.dept__detail-pad hr { border: none; border-top: 1px solid var(--hair-soft); margin: 0 0 var(--sp-2); }

.subleads { display: flex; flex-direction: column; margin-bottom: var(--sp-2); }
.sublead { display: flex; align-items: center; gap: var(--sp-1); padding: 8px 0; border-bottom: 1px solid var(--hair-soft); }
.sublead:last-child { border-bottom: none; }
.sublead__dot { width: 5px; height: 5px; border-radius: 50%; background: var(--ink-3); flex-shrink: 0; }
.sublead__name { font-size: 13px; font-weight: 600; }
.sublead__title { font-size: 12px; color: var(--ink-2); margin-left: auto; text-align: right; }

.roles-title {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin: var(--sp-1) 0;
}
.roles { display: flex; flex-direction: column; }
.role-row { display: flex; align-items: center; gap: var(--sp-1); padding: 7px 0; }
.role-row__name { font-size: 13px; color: var(--ink); }
.role-row__count {
  margin-left: auto;
  min-width: 28px;
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  color: var(--ink);
  background: var(--hair-soft);
  border-radius: 6px;
  padding: 2px 8px;
  font-variant-numeric: tabular-nums;
}

/* ============================================================
   AI METER
   ============================================================ */
.meter { height: 6px; border-radius: var(--r-chip); background: var(--hair-soft); overflow: hidden; margin-top: var(--sp-1); }
.meter__fill { height: 100%; border-radius: var(--r-chip); background: var(--ink); transition: width 800ms var(--ease); }
.tier-label { font-size: 12px; font-weight: 600; margin-top: 2px; color: var(--ink-2); }
.tier-label.tier-high { color: var(--positive); }
.tier-label.tier-med  { color: var(--sun); }
.tier-label.tier-low  { color: var(--ink-3); }

.ai-legend {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-2);
  max-width: 940px;
  margin: 0 auto var(--sp-5);
}
@media (max-width: 760px) { .ai-legend { grid-template-columns: 1fr; max-width: 440px; } }

.leg__top { display: flex; align-items: center; gap: var(--sp-1); }
.leg__name { font-size: 15px; font-weight: 600; }
.leg__count { margin-left: auto; font-size: 12px; font-weight: 600; color: var(--ink-3); }
.leg p { font-size: 13px; color: var(--ink-2); margin-top: var(--sp-1); }

.wins { display: flex; flex-direction: column; }
.win-row { display: flex; align-items: center; gap: var(--sp-1); padding: 6px 0; font-size: 13px; }
.win-row::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--sun);
  flex-shrink: 0;
}
.ai-note { font-size: 13px; color: var(--ink-2); line-height: 1.55; margin-bottom: var(--sp-2); }

.caveat {
  max-width: 760px;
  margin: var(--sp-5) auto 0;
  padding: var(--sp-3);
  background: var(--surface);
  border: 1px solid var(--hair-soft);
  border-left: 2px solid var(--sun);
  border-radius: 12px;
}
.caveat p { font-size: 13px; color: var(--ink-2); line-height: 1.55; }
.caveat b { color: var(--ink); }

/* ============================================================
   KPI strip
   ============================================================ */
.kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-2);
  margin-top: var(--sp-4);
}
.kpi { padding: var(--sp-3); }
.kpi__lab { font-size: 11px; color: var(--ink-3); font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; }
.kpi__num {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.03em;
  margin-top: var(--sp-1);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.kpi__num small { font-size: 14px; font-weight: 600; color: var(--ink-3); }
.kpi__sub { font-size: 12px; color: var(--ink-2); margin-top: 6px; }
@media (max-width: 900px) { .kpis { grid-template-columns: repeat(2, 1fr); } }

/* ============================================================
   DONUT
   ============================================================ */
.donut-row {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--sp-5);
  align-items: center;
}
@media (max-width: 900px) { .donut-row { grid-template-columns: 1fr; } }

.donut-wrap { position: relative; width: 260px; height: 260px; margin: 0 auto; }
.donut-center { position: absolute; inset: 0; display: grid; place-content: center; text-align: center; pointer-events: none; }
.donut-center .big { font-size: 36px; font-weight: 700; letter-spacing: -0.03em; font-variant-numeric: tabular-nums; }
.donut-center .sm { font-size: 12px; color: var(--ink-2); font-weight: 600; max-width: 130px; margin: 0 auto; }
.donut .seg { cursor: pointer; transition: opacity 200ms; }
.donut .seg.dim { opacity: 0.18; }

.legend { display: flex; flex-direction: column; gap: 4px; }
.leg-item {
  display: grid;
  grid-template-columns: 12px 1fr auto;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-1) var(--sp-2);
  border-radius: 10px;
  cursor: pointer;
  border: 1px solid transparent;
}
.leg-item:hover { background: var(--bg); }
.leg-item.sel { border-color: var(--hair); background: var(--bg); }
.leg-sw { width: 12px; height: 12px; border-radius: 4px; background: var(--ink); }
.leg-name { font-weight: 600; font-size: 13px; }
.leg-name .ex { display: block; font-size: 11px; font-weight: 500; color: var(--ink-3); margin-top: 1px; }
.leg-pct { font-weight: 700; font-size: 15px; font-variant-numeric: tabular-nums; }

.tone-1 { fill: var(--ink); }
.tone-2 { fill: #4b4b4f; }
.tone-3 { fill: #6e6e73; }
.tone-4 { fill: var(--sun); }
.tone-5 { fill: #b8b8bd; }
.tone-6 { fill: #d2d2d7; }
.bg-tone-1 { background: var(--ink); }
.bg-tone-2 { background: #4b4b4f; }
.bg-tone-3 { background: #6e6e73; }
.bg-tone-4 { background: var(--sun); }
.bg-tone-5 { background: #b8b8bd; }
.bg-tone-6 { background: #d2d2d7; }

.filter-note { margin-top: var(--sp-2); font-size: 13px; color: var(--ink-2); min-height: 20px; }
.filter-note b { color: var(--ink); }
.clear-x { cursor: pointer; color: var(--sun); font-weight: 600; margin-left: 4px; }

/* ============================================================
   TIMELINE
   ============================================================ */
.tl-row { display: grid; grid-template-columns: 140px 1fr 56px; align-items: center; gap: var(--sp-2); padding: var(--sp-1) 0; }
.tl-label { font-size: 13px; font-weight: 500; color: var(--ink-2); }
.tl-track { height: 22px; background: var(--hair-soft); border-radius: 7px; overflow: hidden; }
.tl-fill {
  height: 100%;
  background: var(--ink);
  display: flex;
  align-items: center;
  padding-left: 10px;
  font-size: 11px;
  font-weight: 600;
  color: #fff;
  transition: width 1000ms var(--ease);
  border-radius: 7px;
}
.tl-fill--sun { background: var(--sun); }
.tl-val { font-size: 13px; font-weight: 600; text-align: right; font-variant-numeric: tabular-nums; }

.heat-grid { display: flex; flex-wrap: wrap; gap: 4px; margin-top: var(--sp-1); }
.heat-cell {
  width: 26px;
  height: 26px;
  border-radius: 5px;
  background: var(--sun);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 700;
  color: #fff;
  font-variant-numeric: tabular-nums;
  transition: 200ms;
}
.heat-cell:hover { transform: scale(1.18); z-index: 2; }
.heat-leg { display: flex; align-items: center; gap: var(--sp-1); font-size: 11px; color: var(--ink-3); margin-top: var(--sp-2); }
.heat-scale { display: flex; gap: 3px; }
.heat-scale i { width: 16px; height: 11px; border-radius: 3px; background: var(--sun); }

/* ============================================================
   TABLE
   ============================================================ */
.tbl-wrap { overflow-x: auto; border: 1px solid var(--hair-soft); border-radius: 13px; background: var(--surface); }
.tbl-tools { display: flex; gap: var(--sp-1); flex-wrap: wrap; margin-bottom: var(--sp-2); }
table { width: 100%; border-collapse: collapse; font-size: var(--t-caption); }
thead th {
  text-align: left;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-3);
  padding: var(--sp-1) var(--sp-2);
  border-bottom: 1px solid var(--hair);
  white-space: nowrap;
  background: var(--bg);
  cursor: pointer;
}
thead th:hover { color: var(--ink); }
tbody td { padding: 12px var(--sp-2); border-bottom: 1px solid var(--hair-soft); vertical-align: top; }
tbody tr:last-child td { border-bottom: none; }
tbody tr:hover { background: var(--bg); }
tbody tr.win td { background: var(--sun-soft); }

.u-name { font-weight: 600; display: flex; align-items: center; gap: var(--sp-1); }
.u-av {
  width: 26px;
  height: 26px;
  border-radius: 7px;
  background: var(--ink);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
  flex-shrink: 0;
}
.src-tag { font-size: 11px; color: var(--ink-3); font-weight: 500; }
.mono { font-family: 'SF Mono', ui-monospace, Menlo, Monaco, Consolas, monospace; font-variant-numeric: tabular-nums; font-size: 12.5px; color: var(--ink-2); }
.pt-rank { font-family: 'SF Mono', ui-monospace, Menlo, monospace; font-size: 12px; color: var(--ink-3); width: 18px; display: inline-block; }
tr.win .pt-rank { color: var(--sun); }
.pt-hi { color: var(--sun); font-weight: 700; }
tr.win .pt-hi { color: #a86a12; }
.pt-sub { display: block; font-size: 10px; color: var(--ink-3); font-weight: 500; margin-top: 2px; }

/* ============================================================
   ACCORDION
   ============================================================ */
.acc { margin-bottom: var(--sp-1); padding: 0; overflow: hidden; }
.acc-head { display: flex; align-items: center; gap: var(--sp-2); padding: var(--sp-2) var(--sp-3); cursor: pointer; transition: 200ms; }
.acc-head:hover { background: var(--bg); }
.acc-ico {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: var(--hair-soft);
  display: grid;
  place-items: center;
  font-size: 11px;
  font-weight: 700;
  color: var(--ink);
  flex-shrink: 0;
}
.acc-tt { flex: 1; }
.acc-tt h4 { font-size: 15px; }
.acc-tt p { font-size: 13px; color: var(--ink-2); margin-top: 2px; }
.acc-arrow { font-size: 13px; color: var(--ink-3); transition: transform 250ms; }
.acc.open .acc-arrow { transform: rotate(90deg); }
.acc-body { max-height: 0; overflow: hidden; transition: max-height 350ms var(--ease); }
.acc-inner { padding: 0 var(--sp-3) var(--sp-3) 76px; font-size: var(--t-caption); color: var(--ink-2); }
.ex-box { margin-top: var(--sp-2); background: var(--bg); border: 1px solid var(--hair-soft); border-radius: 10px; padding: var(--sp-1) var(--sp-2); font-size: 12px; color: var(--ink-2); }
.ex-box b { color: var(--ink); }
.tip { border-bottom: 1px dotted var(--ink-3); cursor: help; }

/* ============================================================
   CHARTS
   ============================================================ */
.chart-title { font-size: var(--t-body); font-weight: 600; }
.chart-sub { font-size: 13px; color: var(--ink-3); margin-top: 2px; }
.chart-legend { display: flex; gap: var(--sp-2); flex-wrap: wrap; margin-top: var(--sp-1); }
.chart-legend span { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--ink-2); font-weight: 500; }
.chart-legend i { width: 10px; height: 10px; border-radius: 3px; }
canvas { display: block; width: 100%; max-width: 100%; }

/* ============================================================
   REELS
   ============================================================ */
.reel { padding: 0; overflow: hidden; margin-bottom: var(--sp-1); }
.reel-head {
  display: grid;
  grid-template-columns: 32px 1.5fr repeat(4, 0.6fr) 30px;
  gap: var(--sp-1);
  align-items: center;
  padding: 13px var(--sp-2);
  cursor: pointer;
}
.reel-rank { font-family: 'SF Mono', ui-monospace, Menlo, monospace; font-weight: 700; font-size: 14px; color: var(--ink-3); text-align: center; }
.reel-rank.top { color: var(--sun); }
.reel-title { font-size: 13px; font-weight: 500; line-height: 1.4; overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.reel-meta { font-size: 11px; color: var(--ink-3); margin-top: 3px; display: flex; gap: var(--sp-1); }
.reel-m { font-family: 'SF Mono', ui-monospace, Menlo, monospace; font-size: 13px; font-weight: 600; text-align: right; font-variant-numeric: tabular-nums; }
.reel-m small { display: block; font-family: var(--font); font-size: 10px; color: var(--ink-3); font-weight: 500; }
.reel .chev { color: var(--ink-3); transition: transform 250ms; text-align: center; }
.reel.open .chev { transform: rotate(180deg); }
.reel-body { max-height: 0; overflow: hidden; transition: max-height 350ms var(--ease); background: var(--bg); }
.reel.open .reel-body { max-height: 400px; }
.reel-body-in { padding: var(--sp-2) var(--sp-3); display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
.why { font-size: 13px; color: var(--ink-2); line-height: 1.55; }
.why h4 { font-size: 10px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--sun); margin-bottom: 6px; font-weight: 700; }
.metrics-mini { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.mm { background: var(--surface); border: 1px solid var(--hair-soft); border-radius: 8px; padding: 8px 10px; }
.mm .l { font-size: 10px; color: var(--ink-3); font-weight: 500; }
.mm .v { font-size: 14px; font-weight: 700; font-variant-numeric: tabular-nums; margin-top: 2px; }

@media (max-width: 768px) {
  .reel-head { grid-template-columns: 28px 1fr 0.7fr 24px; }
  .reel-head .hide-sm { display: none; }
  .reel-body-in { grid-template-columns: 1fr; }
}

/* ============================================================
   VS BLOCK
   ============================================================ */
.vs { background: var(--ink); color: #fff; border-radius: var(--r-card); padding: var(--sp-4) var(--sp-5); position: relative; overflow: hidden; }
.vs::before {
  content: "";
  position: absolute;
  right: -50px;
  top: -50px;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(224,146,26,0.3), transparent 65%);
}
.vs .k { font-size: 12px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(255,255,255,0.6); position: relative; }
.vs h2 { font-size: var(--t-heading); margin-top: var(--sp-1); color: #fff; max-width: 26ch; position: relative; }
.vs p { margin-top: var(--sp-1); color: rgba(255,255,255,0.75); font-size: var(--t-caption); max-width: 66ch; position: relative; }

.vsbars { margin-top: var(--sp-3); display: grid; gap: var(--sp-2); position: relative; }
.vsrow { display: grid; grid-template-columns: 130px 1fr; gap: var(--sp-2); align-items: center; }
.vsrow .vl { font-size: 12px; color: rgba(255,255,255,0.55); font-weight: 500; }
.vstrack { display: grid; gap: 6px; }
.vsbar {
  height: 22px;
  border-radius: 6px;
  background: rgba(255,255,255,0.18);
  display: flex;
  align-items: center;
  padding: 0 10px;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  font-variant-numeric: tabular-nums;
  position: relative;
  min-width: 58px;
  transition: width 1000ms var(--ease);
}
.vsbar.fb { background: rgba(255,255,255,0.32); }
.vsbar.ig { background: var(--sun); }
.vsbar small { position: absolute; left: 10px; font-size: 10px; font-weight: 500; opacity: 0.85; }
.vsbar b { margin-left: auto; font-weight: 700; }

.analysis {
  margin-top: var(--sp-2);
  background: var(--bg);
  border: 1px solid var(--hair-soft);
  border-left: 2px solid var(--sun);
  border-radius: 12px;
  padding: var(--sp-2);
}
.vs .analysis { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.16); border-left-color: var(--sun); }
.analysis h5 { font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--sun); font-weight: 700; margin-bottom: 6px; }
.analysis p { font-size: 13px; color: var(--ink-2); line-height: 1.6; }
.vs .analysis p { color: rgba(255,255,255,0.75); }
.analysis p + p { margin-top: 6px; }
.analysis b { color: var(--ink); font-weight: 600; }
.vs .analysis b { color: #fff; }
.analysis .lead { color: var(--sun); font-weight: 700; }

/* Primer / glossary callout — neutral, educational.
   Distinct from .analysis (gold) to keep one accent per area. */
.primer {
  margin-top: var(--sp-2);
  background: var(--surface);
  border: 1px solid var(--hair-soft);
  border-left: 2px solid var(--ink-3);
  border-radius: 12px;
  padding: var(--sp-2);
}
.primer h5 {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-3);
  font-weight: 700;
  margin-bottom: 6px;
}
.primer p { font-size: 13px; color: var(--ink-2); line-height: 1.6; }
.primer p + p { margin-top: 6px; }
.primer b { color: var(--ink); font-weight: 600; }
.primer dl { margin-top: var(--sp-1); display: grid; gap: 8px; }
.primer dt { font-size: 12.5px; color: var(--ink); font-weight: 700; }
.primer dd { font-size: 12.5px; color: var(--ink-2); line-height: 1.55; margin-left: 0; }
.primer dd b { color: var(--ink); font-weight: 600; }

/* ============================================================
   POST-TYPE TABLE
   ============================================================ */
.pt-answer {
  display: flex;
  gap: var(--sp-2);
  align-items: flex-start;
  background: var(--sun-soft);
  border: 1px solid #F0DCAE;
  border-radius: 14px;
  padding: var(--sp-2) var(--sp-3);
  margin-bottom: var(--sp-3);
}
.pt-medal { font-size: 24px; line-height: 1; flex: none; color: var(--sun); }
.pt-a-t { font-size: 15px; font-weight: 700; color: var(--ink); line-height: 1.3; }
.pt-a-d { font-size: 13px; color: var(--ink-2); margin-top: 5px; line-height: 1.5; }
.pt-caveat {
  margin-top: var(--sp-3);
  background: var(--sun-soft);
  border: 1px solid #F0DCAE;
  border-left: 2px solid var(--sun);
  border-radius: 12px;
  padding: var(--sp-2);
}
.pt-caveat h5 { font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: #a86a12; font-weight: 700; margin-bottom: 6px; }
.pt-caveat p { font-size: 12px; color: var(--ink-2); line-height: 1.6; }
.pt-caveat b { color: var(--ink); font-weight: 600; }
.provenance { font-size: 11px; color: var(--ink-3); margin-top: var(--sp-2); line-height: 1.5; }
.provenance .mono { color: var(--ink-2); }

/* ============================================================
   COMPETITORS PLAYBOOK
   ============================================================ */
.cpb-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-2); }
@media (max-width: 900px) { .cpb-grid { grid-template-columns: 1fr; } }
.cpb-head { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--sp-1); }
.cpb-handle { font-size: 16px; font-weight: 700; letter-spacing: -0.02em; }
.cpb-meta { font-size: 11px; color: var(--ink-3); font-weight: 500; margin-top: 2px; }
.cpb-tag { font-size: 12.5px; color: var(--ink-2); font-style: italic; margin: 13px 0 11px; line-height: 1.45; }
.cpb-list { list-style: none; display: grid; gap: var(--sp-1); }
.cpb-list li { position: relative; padding-left: 16px; font-size: 12.5px; color: var(--ink-2); line-height: 1.5; }
.cpb-list li::before { content: ""; position: absolute; left: 0; top: 7px; width: 5px; height: 5px; border-radius: 50%; background: var(--sun); }
.cpb-list b { color: var(--ink); font-weight: 600; }

.cpb-steal { display: grid; gap: 2px; margin-top: var(--sp-2); }
.cpb-srow { display: grid; grid-template-columns: 120px 1fr; gap: var(--sp-2); align-items: start; padding: 12px 0; border-bottom: 1px solid var(--hair-soft); }
.cpb-srow:last-child { border-bottom: none; }
.cpb-src { font-size: 10px; font-weight: 700; padding: 4px 9px; border-radius: 7px; text-align: center; background: var(--hair-soft); color: var(--ink); white-space: nowrap; }
.cpb-move { font-size: 13px; color: var(--ink-2); line-height: 1.5; }
.cpb-move b { color: var(--ink); font-weight: 600; }

/* ============================================================
   RECOMMENDATIONS
   ============================================================ */
.reco-card.more { border-top: 2px solid var(--sun); }
.reco-card.less { border-top: 2px solid var(--ink-3); }
.reco-card h3 { font-size: 17px; display: flex; align-items: center; gap: var(--sp-1); margin-bottom: var(--sp-2); }
.reco { padding: var(--sp-1) 0; border-bottom: 1px solid var(--hair-soft); }
.reco:last-child { border-bottom: none; }
.reco .rt { font-size: var(--t-caption); font-weight: 600; display: flex; justify-content: space-between; gap: var(--sp-1); }
.reco .impact { font-size: 11px; font-weight: 700; color: var(--sun); font-variant-numeric: tabular-nums; }
.reco .rd { font-size: 12.5px; color: var(--ink-3); margin-top: 4px; line-height: 1.45; }

/* ============================================================
   TIMING
   ============================================================ */
.tstrip { display: grid; gap: var(--sp-1); }
.trow2 { display: grid; grid-template-columns: 110px 1fr; gap: var(--sp-1); align-items: center; }
.trow2 .tlab { font-size: 12px; font-weight: 600; color: var(--ink-2); white-space: nowrap; }
.tcells { display: grid; grid-template-columns: repeat(24, 1fr); gap: 3px; }
.tcell {
  aspect-ratio: 1/1.15;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 8.5px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  position: relative;
  transition: 200ms;
}
.tcell:hover { transform: scale(1.18); z-index: 3; }
.tcell.tgap { outline: 2px solid var(--sun); outline-offset: 1px; z-index: 2; }
.taxis { display: grid; grid-template-columns: 110px 1fr; gap: var(--sp-1); margin-top: 2px; }
.thours { display: grid; grid-template-columns: repeat(24, 1fr); gap: 3px; }
.thr { font-size: 8px; color: var(--ink-3); text-align: center; }
.tlegend { display: flex; gap: var(--sp-3); flex-wrap: wrap; margin-top: var(--sp-2); }
.tlegend span { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--ink-2); font-weight: 500; }
.tlegend i { width: 22px; height: 12px; border-radius: 3px; }

.tslot { display: flex; flex-direction: column; }
.tslot .th { font-size: 28px; font-weight: 700; letter-spacing: -0.02em; margin-top: var(--sp-1); font-variant-numeric: tabular-nums; }
.tslot .tmeta { font-size: 12.5px; color: var(--ink-2); margin-top: 4px; }
.tcmp { display: grid; gap: var(--sp-1); }
.tcmp-row { display: flex; align-items: center; gap: var(--sp-2); }
.tcmp-row .cl { width: 250px; font-size: 13px; font-weight: 500; color: var(--ink-2); }
.tcmp-bar { flex: 1; height: 28px; background: var(--hair-soft); border-radius: 8px; overflow: hidden; position: relative; }
.tcmp-bar i { display: block; height: 100%; border-radius: 8px; background: var(--sun); transition: width 1000ms var(--ease); }
.tcmp-bar.dim i { background: var(--ink-3); }
.tcmp-bar .lbl { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); font-family: 'SF Mono', ui-monospace, Menlo, monospace; font-size: 12px; font-weight: 700; color: var(--ink); font-variant-numeric: tabular-nums; }

@media (max-width: 768px) {
  .tcell { font-size: 0; }
  .trow2, .taxis { grid-template-columns: 60px 1fr; }
  .tcmp-row { flex-wrap: wrap; }
  .tcmp-row .cl { width: 100%; }
}

/* ============================================================
   VIRAL ENGINE
   ============================================================ */
.ve-battles { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-2); }
@media (max-width: 900px) { .ve-battles { grid-template-columns: 1fr; } }
.ve-battle .n { font-size: 11px; color: var(--sun); font-weight: 700; font-variant-numeric: tabular-nums; }
.ve-battle h4 { font-size: 16px; font-weight: 600; margin: 7px 0 5px; }
.ve-battle p { font-size: 12.5px; color: var(--ink-2); line-height: 1.5; }
.ve-grow {
  display: grid;
  grid-template-columns: 100px 1fr 200px;
  gap: var(--sp-2);
  align-items: start;
  padding: var(--sp-2) 0;
  border-bottom: 1px solid var(--hair-soft);
}
.ve-grow:last-child { border-bottom: none; }
.ve-sev {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 4px 9px;
  border-radius: 6px;
  white-space: nowrap;
  text-align: center;
}
.ve-sev.crit { background: #FDECEC; color: var(--critical); }
.ve-sev.high { background: var(--sun-soft); color: #a86a12; }
.ve-sev.med  { background: var(--hair-soft); color: var(--ink-2); }
.ve-gtitle { font-size: var(--t-caption); font-weight: 600; color: var(--ink); }
.ve-gsub { font-size: 12px; color: var(--ink-2); margin-top: 3px; line-height: 1.5; }
.ve-gprin { font-size: 11px; color: var(--ink-3); font-weight: 500; line-height: 1.4; }

@media (max-width: 768px) {
  .ve-grow { grid-template-columns: 90px 1fr; }
  .ve-gprin { grid-column: 1 / -1; }
}

/* ============================================================
   THEME GRID
   ============================================================ */
.tgrid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-1); }
@media (max-width: 900px) { .tgrid { grid-template-columns: 1fr; } }
.trow {
  display: grid;
  gap: var(--sp-1);
  align-items: center;
  padding: var(--sp-2);
  background: var(--surface);
  border: 1px solid var(--hair-soft);
  border-radius: 12px;
  grid-template-columns: 1.4fr 0.7fr 0.9fr 0.7fr;
  transition: 200ms;
}
.trow:hover { box-shadow: var(--shadow-s); }
.trow.hero-row { border-color: var(--sun); background: linear-gradient(120deg, var(--sun-soft), var(--surface) 60%); }
.trow .tname { font-weight: 600; font-size: 13px; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.trow .m { font-family: 'SF Mono', ui-monospace, Menlo, monospace; font-size: 13px; font-weight: 600; text-align: right; font-variant-numeric: tabular-nums; }
.trow .m small { display: block; font-family: var(--font); font-size: 10px; color: var(--ink-3); font-weight: 500; }
.badge { font-size: 9px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; padding: 3px 7px; border-radius: 5px; background: var(--sun); color: #fff; white-space: nowrap; }
.barcell .bar { height: 5px; border-radius: 3px; background: var(--hair-soft); margin-top: 6px; overflow: hidden; }
.barcell .bar i { display: block; height: 100%; border-radius: 3px; background: var(--sun); }

/* ============================================================
   ANCHOR NAV
   ============================================================ */
.anchor-nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-1);
  padding: var(--sp-2) 0;
  margin-bottom: var(--sp-4);
  border-bottom: 1px solid var(--hair-soft);
  overflow-x: auto;
}
.anchor-nav a {
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink-2);
  padding: 6px 12px;
  border-radius: var(--r-chip);
  transition: 200ms;
  white-space: nowrap;
}
.anchor-nav a:hover { background: var(--hair-soft); color: var(--ink); }
.anchor-nav a.active { background: var(--ink); color: #fff; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot {
  background: var(--surface);
  border-top: 1px solid var(--hair-soft);
  padding: var(--sp-5) 0;
  margin-top: var(--sp-8);
}
.foot__in { text-align: center; max-width: 720px; margin: 0 auto; padding: 0 var(--sp-3); }
.foot p { font-size: 12px; color: var(--ink-3); line-height: 1.6; }
.foot .brand { justify-content: center; margin-bottom: var(--sp-2); }
.foot p + p { margin-top: var(--sp-1); }

/* ============================================================
   UTILITIES
   ============================================================ */
.mt-1 { margin-top: var(--sp-1); }
.mt-2 { margin-top: var(--sp-2); }
.mt-3 { margin-top: var(--sp-3); }
.mt-4 { margin-top: var(--sp-4); }
.text-muted { color: var(--ink-2); }
.text-faint { color: var(--ink-3); }
.tabular { font-variant-numeric: tabular-nums; }
