/* ============================================================
   MADNESS · CRICKET — Shared Shell
   Extracted from Madness Hoops Hub v2.html (locked v02)
   Used by all 17 screens to guarantee zero visual drift.
   ============================================================ */

:root {
  --s0: #0A0A0A; --s1: #111114; --s2: #18181B; --s3: #27272A; --s4: #3F3F46; --s5: #52525B;
  --t1: #FAFAFA; --t2: #A1A1AA; --t3: #71717A;
  --hair: rgba(255,255,255,0.06);
  --soft: rgba(255,255,255,0.10);
  --strong: rgba(255,255,255,0.18);
  --sport: #0EAB6E; --sport-dim: #0BAB6B; --sport-glow: rgba(14, 171, 110, 0.35);
  --pos: #10B981; --neg: #EF4444; --warn: #F59E0B; --info: #3B82F6;
  --gold: #EAB308; --comp: #8B5CF6;
  --display: 'Space Grotesk', system-ui, sans-serif;
  --ui:      'Inter', system-ui, sans-serif;
  --mono:    'JetBrains Mono', 'SF Mono', monospace;
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: #000; }
body {
  font-family: var(--ui); color: var(--t1);
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}

.stage { position: fixed; inset: 0; display: grid; place-items: center; background: #000; }
.frame {
  width: 2560px; height: 1440px; background: var(--s0);
  position: relative; overflow: hidden; transform-origin: center center;
}
@media (max-aspect-ratio: 16/9) { .frame { transform: scale(calc(100vw / 2560)); } }
@media (min-aspect-ratio: 16/9) { .frame { transform: scale(calc(100vh / 1440)); } }

.mono { font-family: var(--mono); font-variant-numeric: tabular-nums; }
.caps { font-family: var(--mono); text-transform: uppercase; letter-spacing: 0.16em; }

/* ============ HEADER (72px) ============ */
.hdr { position: absolute; top: 0; left: 0; right: 0; height: 72px; background: var(--s1); border-bottom: 1px solid var(--hair); display: flex; align-items: center; z-index: 10; }
.hdr .brand { display: flex; align-items: center; gap: 14px; padding: 0 24px; height: 100%; border-right: 1px solid var(--hair); width: 264px; box-sizing: border-box; }
.hdr .mark { width: 44px; height: 44px; background: url("../../../_shared/logos/madness-mark-cube-256.png") center/contain no-repeat; position: relative; flex-shrink: 0; filter: drop-shadow(0 2px 6px rgba(14,171,110,0.30)); }
.hdr .mark::after { content: ''; position: absolute; top: -2px; right: -2px; width: 8px; height: 8px; background: var(--sport); }
.hdr .mark span { display: none; }
.hdr .wm { line-height: 1; font-family: var(--display); }
.hdr .wm .l1 { font-size: 14px; font-weight: 700; letter-spacing: 0.02em; color: var(--t2); }
.hdr .wm .l2 { font-size: 18px; font-weight: 700; letter-spacing: 0.04em; color: var(--sport); text-transform: uppercase; }
.hdr .ctx { display: flex; align-items: center; gap: 28px; padding: 0 32px; flex: 1; height: 100%; }
.hdr .ctx .item { display: flex; flex-direction: column; gap: 2px; }
.hdr .ctx .k { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; color: var(--t3); text-transform: uppercase; }
.hdr .ctx .v { font-family: var(--mono); font-size: 14px; color: var(--t1); font-weight: 600; }
.hdr .ctx .v em { color: var(--sport); font-style: normal; }
.hdr .ctx .sep { width: 1px; height: 32px; background: var(--hair); }
.hdr .ctrls { display: flex; gap: 0; padding-right: 24px; height: 100%; }
.hdr .btn { display: inline-flex; align-items: center; gap: 8px; padding: 0 18px; height: 100%; font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; color: var(--t1); background: transparent; border: none; border-left: 1px solid var(--hair); cursor: pointer; }
.hdr .btn:hover { background: var(--s2); }
.hdr .btn.primary { background: var(--sport); color: #0a0a0a; border-left-color: var(--sport); }
.hdr .btn .arrow { font-family: var(--mono); }

/* ============ SIDEBAR (264px) ============ */
.side { position: absolute; top: 72px; bottom: 0; left: 0; width: 264px; background: var(--s1); border-right: 1px solid var(--hair); display: flex; flex-direction: column; padding: 16px 0 0 0; overflow: hidden; }
.side .grp { padding: 14px 24px 6px; }
.side .grp .lbl { font-family: var(--mono); font-size: 10px; letter-spacing: 0.22em; color: var(--t3); text-transform: uppercase; }
.side .nav { padding: 0 12px; }
.side .nav .it { display: grid; grid-template-columns: 20px 1fr auto; gap: 14px; align-items: center; padding: 10px 14px; font-size: 14px; color: var(--t2); cursor: pointer; border-left: 3px solid transparent; margin-left: -12px; position: relative; }
.side .nav .it:hover { color: var(--t1); background: var(--s2); }
.side .nav .it.active { color: var(--t1); background: var(--s2); border-left-color: var(--sport); font-weight: 600; }
.side .nav .it .ic { width: 18px; height: 18px; color: currentColor; }
.side .nav .it .ic svg { width: 100%; height: 100%; fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.side .nav .it .ct { font-family: var(--mono); font-size: 10px; color: var(--t3); padding: 2px 6px; background: var(--s3); letter-spacing: 0.06em; }
.side .nav .it.active .ct { background: var(--sport); color: #0a0a0a; }

/* ============ MAIN CANVAS ============ */
.main { position: absolute; top: 72px; bottom: 0; left: 264px; right: 0; padding: 24px 24px 52px 24px; display: grid; grid-template-columns: repeat(12, 1fr); grid-auto-rows: min-content; gap: 16px; overflow: hidden; }

/* Crumbs / page title */
.crumbs { grid-column: 1 / -1; display: flex; align-items: center; justify-content: space-between; padding-bottom: 12px; border-bottom: 1px solid var(--hair); margin-bottom: 4px; }
.crumbs .l { display: flex; align-items: center; gap: 18px; }
.crumbs h1 { font-family: var(--display); font-size: 28px; font-weight: 700; letter-spacing: -0.02em; margin: 0; color: var(--t1); }
.crumbs h1 em { color: var(--sport); font-style: normal; }
.crumbs .b { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; color: var(--t3); text-transform: uppercase; }
.crumbs .b strong { color: var(--t1); font-weight: 600; }
.crumbs .right { display: flex; gap: 12px; align-items: stretch; }
.crumb-tile { display: flex; flex-direction: column; gap: 6px; padding: 8px 16px; background: var(--s2); border: 1px solid var(--hair); min-width: 240px; position: relative; }
.crumb-tile .k { font-family: var(--mono); font-size: 9px; letter-spacing: 0.2em; color: var(--t3); text-transform: uppercase; }
.crumb-tile .row { display: flex; align-items: center; gap: 10px; }
.crumb-tile .sub { font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em; color: var(--t2); text-transform: uppercase; }
.crumb-tile.last-result { border-left: 3px solid var(--pos); }
.crumb-tile.last-result .badge { width: 24px; height: 24px; display: grid; place-items: center; font-family: var(--mono); font-size: 12px; font-weight: 700; background: rgba(16,185,129,0.18); color: var(--pos); border: 1px solid rgba(16,185,129,0.4); }
.crumb-tile.last-result .score { font-family: var(--mono); font-size: 22px; font-weight: 700; color: var(--t1); letter-spacing: -0.02em; }
.crumb-tile.last-result .opp { font-size: 13px; color: var(--t2); font-weight: 500; }
.crumb-tile.next-in { border-left: 3px solid var(--sport); }
.crumb-tile.next-in .timer { display: inline-flex; align-items: baseline; font-family: var(--mono); font-size: 22px; font-weight: 700; color: var(--sport); letter-spacing: -0.02em; }
.crumb-tile.next-in .timer .seg { display: inline-block; min-width: 32px; text-align: center; }
.crumb-tile.next-in .timer .sep { color: var(--t3); margin: 0 1px; }

/* Generic panel head, used by every screen */
.panel-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px; border-bottom: 1px solid var(--hair); }
.panel-head h3 { font-family: var(--display); font-size: 16px; font-weight: 700; letter-spacing: -0.01em; margin: 0; display: flex; align-items: center; gap: 10px; }
.panel-head h3::before { content: ''; width: 4px; height: 16px; background: var(--sport); display: inline-block; }
.panel-head .right { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; color: var(--t3); text-transform: uppercase; }
.panel-head .right em { color: var(--sport); font-style: normal; }
.panel-head a { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; color: var(--sport); text-transform: uppercase; font-weight: 600; text-decoration: none; }

/* Footer status bar */
.foot { position: absolute; bottom: 0; left: 264px; right: 0; height: 28px; background: var(--s1); border-top: 1px solid var(--hair); display: flex; align-items: center; gap: 24px; padding: 0 24px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; color: var(--t3); text-transform: uppercase; z-index: 10; }
.foot .it { display: inline-flex; align-items: center; gap: 8px; }
.foot .it strong { color: var(--t1); font-weight: 600; }
.foot .it em { color: var(--sport); font-style: normal; font-weight: 700; }
.foot .it::before { content: ''; width: 4px; height: 4px; background: var(--t3); display: inline-block; }
.foot .right { margin-left: auto; display: flex; gap: 24px; }

/* Console safe-zone outline */
.safe-zone { position: absolute; inset: 5%; border: 1px dashed rgba(242,107,31,0.3); pointer-events: none; display: none; z-index: 100; }
.frame[data-safe="on"] .safe-zone { display: block; }

/* Filmgrain */
.grain { position: absolute; inset: 0; pointer-events: none; opacity: 0.06; mix-blend-mode: overlay; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>"); }
