/* OnCourtLive — Broadcast Hero Theme (full-page) */
/* Load this file LAST (after existing board styles). */

/* Asset paths assume this CSS is located at: web/assets/broadcast/broadcast-hero.css
   and images at: web/assets/broadcast/grain.png and flare.png */

:root{
  --bh-shell-0:#04070f;
  --bh-shell-1:#07101f;
  --bh-shell-2:#0b1730;

  --bh-paper:#ffffff;
  --bh-ink:#0b1220;

  --bh-rule: rgba(15,23,42,.10);
  --bh-rule-strong: rgba(15,23,42,.16);

  --bh-live:#22c55e;
  --bh-live-glow: rgba(34,197,94,.22);

  --bh-grain-opacity:.18;
}

/* Global cinematic shell */
body{
  background:
    radial-gradient(1100px 520px at 18% -10%, rgba(120,120,255,.22), transparent 62%),
    radial-gradient(900px 520px at 82% 0%, rgba(255,110,140,.18), transparent 62%),
    radial-gradient(900px 520px at 60% 120%, rgba(60,240,160,.12), transparent 62%),
    linear-gradient(180deg, var(--bh-shell-1), var(--bh-shell-0) 70%);
  color: var(--bh-ink);
}

.container{
  background: var(--bh-paper);
  position: relative;
  overflow: hidden;
}

/* Film grain on the whole page (subtle) */
.container::before{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events:none;
  z-index: 1;
  opacity: var(--bh-grain-opacity);
  mix-blend-mode: overlay;
  background-image: url("grain.png");
  background-size: 220px 220px;
}

/* Edge vignette */
.container::after{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events:none;
  z-index: 1;
  background:
    radial-gradient(110% 70% at 50% 20%, rgba(0,0,0,0.00) 55%, rgba(0,0,0,0.26) 100%);
  opacity: .45;
}

.container > *{ position: relative; z-index: 2; }

/* Sponsor banner = ticker */
.oc-presenter-bar{
  background:
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(245,248,253,.88));
  border-bottom: 1px solid var(--bh-rule);
  color: rgba(15,23,42,.70);
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 800;
  font-size: 11px;
}

/* Match header = broadcast title plate */
.match-header{
  position: relative;
  background:
    radial-gradient(1200px 260px at 50% 0%, rgba(255,255,255,.14), transparent 70%),
    linear-gradient(135deg, #0a1630 0%, #14335f 55%, #081428 100%);
  border-bottom: 1px solid rgba(255,255,255,.14);
}
.match-header::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    url("flare.png") center -28px / 620px 155px no-repeat,
    linear-gradient(180deg, rgba(255,255,255,.18), transparent 28%);
  opacity: .95;
}
.match-header-brand{
  letter-spacing: .18em;
  opacity: .82;
  font-weight: 800;
  font-size: 10px;
}
.match-header h1{
  letter-spacing: -0.01em;
}
.match-header-meta{ opacity: .82; }

/* Score banner = inset plate */
.score-banner{
  background: linear-gradient(180deg, rgba(255,255,255,1), rgba(248,250,252,1));
  border-bottom: 1px solid var(--bh-rule);
}
.score-number{
  color:#0b1830;
  letter-spacing: -0.04em;
}

/* Section headers = slate */
.section-header{
  color: rgba(15,23,42,.55);
  letter-spacing: .16em;
  font-weight: 800;
  padding-top: 18px;
}

/* Remove app entrance animation */
.court-card{ animation: none !important; }

/* Court header band: COURT dominance */
.broadcast-court-header-band{
  border: 1px solid var(--bh-rule-strong);
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(243,247,252,.96));
  box-shadow: 0 1px 0 rgba(255,255,255,.90) inset, 0 -1px 0 rgba(15,23,42,.06) inset;
}
.broadcast-court-label-main{
  font-size: 16px;
  font-weight: 900;
  letter-spacing: .10em;
}
.broadcast-court-label-slot{
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .18em;
  opacity: .72;
}

/* Status */
.status-badge{
  background: rgba(255,255,255,.82);
  border: 1px solid var(--bh-rule);
}
.status-badge--live{
  background: rgba(34,197,94,.10);
  border-color: rgba(34,197,94,.22);
  color: #15803d;
}
.status-badge--final{
  background: rgba(15,23,42,.06);
  border-color: rgba(15,23,42,.10);
  color: rgba(15,23,42,.58);
}
.live-dot{
  width: 7px;
  height: 7px;
  background: var(--bh-live);
  border-radius: 50%;
  box-shadow: 0 0 0 3px var(--bh-live-glow);
  animation: bh-pulse 1.35s ease-in-out infinite;
}
@keyframes bh-pulse{
  0%,100%{ opacity: 1; transform: scale(1); }
  50%{ opacity: .55; transform: scale(.82); }
}

/* Broadcast matchup row = true plate */
.broadcast-matchup-row-grid{
  border: 1px solid rgba(15,23,42,.16);
  background:
    url("grain.png") 0 0 / 260px 260px repeat,
    radial-gradient(circle at center, rgba(255,255,255,.18) 0%, rgba(255,255,255,0) 62%),
    linear-gradient(180deg, rgba(255,255,255,.60), rgba(255,255,255,0));
  box-shadow:
    0 1px 0 rgba(255,255,255,.88) inset,
    0 -1px 0 rgba(0,0,0,.06) inset,
    0 12px 26px rgba(0,0,0,.10);
}

/* Team sides = cinematic split atmosphere */
.broadcast-team-side{
  position: relative;
  background:
    radial-gradient(780px 260px at 42% 0%, rgba(255,255,255,.10), transparent 65%),
    linear-gradient(135deg, var(--broadcast-team-grad-start) 0%, var(--broadcast-team-grad-end) 100%);
}
.broadcast-team-side::after{
  content:"";
  position:absolute;
  inset: 0;
  pointer-events:none;
  background:
    radial-gradient(420px 180px at 50% 120%, rgba(0,0,0,.22), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.10), transparent 40%);
  opacity: .75;
}

/* Player tiles = glass plate */
.broadcast-player-tile{
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(0,0,0,.22));
  border: 1px solid rgba(255,255,255,.24);
  box-shadow: 0 1px 0 rgba(255,255,255,.10) inset, 0 10px 18px rgba(0,0,0,.18);
  transition: transform .10s ease, filter .10s ease;
}
.broadcast-player-tile:hover{ transform: translateY(-1px); filter: brightness(1.06); }
.broadcast-player-tile:active{ transform: scale(.985); }

.broadcast-player-headshot{
  border: 2px solid rgba(255,255,255,.86);
  box-shadow: 0 10px 18px rgba(0,0,0,.22);
}
.broadcast-player-name{ text-shadow: 0 2px 8px rgba(0,0,0,.26); }
.broadcast-player-cta{ opacity: .94; text-shadow: 0 2px 8px rgba(0,0,0,.22); }

/* Score spine = glossy + center flare */
.broadcast-score-spine{
  background:
    url("flare.png") center 40% / 520px 130px no-repeat,
    radial-gradient(240px 120px at 50% 12%, rgba(255,255,255,.14), transparent 70%),
    linear-gradient(180deg, #071426, #0b1a30 70%, #06101f);
  color: #fff;
}
.broadcast-score-spine::before,
.broadcast-score-spine::after{ background: rgba(255,255,255,.18); }
.broadcast-score-value{ text-shadow: 0 10px 26px rgba(0,0,0,.30); }

/* Modal = same package */
.player-modal-overlay{ background: rgba(3,10,18,0.62); }
.player-modal{ box-shadow: 0 -22px 64px rgba(0,0,0,.32); }
.modal-hero{
  background:
    url("flare.png") center -18px / 560px 140px no-repeat,
    linear-gradient(160deg, var(--modal-team-soft, #e7edf4) 0%, #f9fafb 100%);
}
.modal-hero::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background: linear-gradient(180deg, rgba(255,255,255,.18), transparent 28%);
  opacity: .9;
}
.modal-live-dot{
  background: var(--bh-live);
  box-shadow: 0 0 0 3px var(--bh-live-glow);
  animation: bh-pulse 1.35s ease-in-out infinite;
}
.modal-profile-btn{ box-shadow: 0 10px 22px rgba(0,0,0,.16); }
.modal-share-btn{
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(245,248,253,.92));
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .live-dot,.modal-live-dot{ animation:none !important; }
  .broadcast-player-tile,
  .player-modal,
  .player-modal-overlay{ transition:none !important; }
}

/* ========================================
   BROADCAST V2 ENHANCEMENTS (Comp-Matched)
   ======================================== */

/* V2: Enhanced header with stadium bokeh lights */
.match-header{
  background:
    /* Bokeh stadium lights */
    radial-gradient(circle 8px at 12% 25%, rgba(255,255,255,.85), transparent),
    radial-gradient(circle 6px at 15% 30%, rgba(255,200,180,.75), transparent),
    radial-gradient(circle 10px at 18% 22%, rgba(255,220,200,.80), transparent),
    radial-gradient(circle 7px at 22% 28%, rgba(255,255,255,.85), transparent),
    radial-gradient(circle 9px at 82% 25%, rgba(255,255,255,.85), transparent),
    radial-gradient(circle 7px at 85% 30%, rgba(255,200,180,.75), transparent),
    radial-gradient(circle 11px at 88% 22%, rgba(255,220,200,.80), transparent),
    radial-gradient(circle 6px at 78% 28%, rgba(255,255,255,.85), transparent),
    /* Team color split atmosphere */
    radial-gradient(1200px 300px at 50% 0%, rgba(255,255,255,.18), transparent 72%),
    radial-gradient(900px 420px at 15% -10%, rgba(100,100,255,.20), transparent 65%),
    radial-gradient(900px 420px at 85% -10%, rgba(255,90,120,.18), transparent 65%),
    linear-gradient(90deg,
      rgba(80,50,140,.85) 0%,
      rgba(60,45,120,.80) 30%,
      rgba(50,40,100,.75) 48%,
      rgba(90,30,60,.75) 52%,
      rgba(140,35,65,.80) 70%,
      rgba(170,40,70,.85) 100%
    );
  border-bottom: 2px solid rgba(255,255,255,.24);
  padding: 30px 20px 26px !important;
}

.match-header h1{
  font-weight: 900 !important;
  font-size: 30px !important;
  color: #ffffff !important;
  letter-spacing: 0.03em !important;
  text-shadow:
    0 0 20px rgba(255,255,255,.18),
    0 4px 14px rgba(0,0,0,.45);
}

.match-header-meta{
  color: rgba(255,255,255,.88) !important;
  font-weight: 700 !important;
  text-shadow: 0 2px 8px rgba(0,0,0,.35);
}

.match-header-brand{
  color: rgba(255,255,255,.90) !important;
  text-shadow: 0 2px 6px rgba(0,0,0,.35);
}

/* V2: Score banner with team color split */
.score-banner{
  background:
    radial-gradient(800px 160px at 50% 50%, rgba(255,255,255,.14), transparent 68%),
    linear-gradient(90deg,
      rgba(80,50,140,.82) 0%,
      rgba(70,45,130,.78) 30%,
      rgba(60,40,100,.75) 48%,
      rgba(100,30,60,.75) 52%,
      rgba(150,35,65,.78) 70%,
      rgba(180,40,70,.82) 100%
    );
  border-bottom: 2px solid rgba(255,255,255,.20);
  padding: 19px 20px !important;
}

.score-team-name{
  color: #ffffff !important;
  font-weight: 900 !important;
  letter-spacing: 0.09em !important;
  text-transform: uppercase;
  text-shadow: 0 2px 10px rgba(0,0,0,.38);
}

.score-number{
  color: #ffffff !important;
  font-weight: 900 !important;
  font-size: 44px !important;
  text-shadow:
    0 0 18px rgba(255,255,255,.22),
    0 4px 14px rgba(0,0,0,.42);
}

.score-dash{
  color: rgba(255,255,255,.88) !important;
}

/* V2: Section headers with gradient background */
.section-header{
  background:
    radial-gradient(900px 160px at 50% 50%, rgba(255,255,255,.10), transparent 68%),
    linear-gradient(90deg,
      rgba(70,45,130,.88) 0%,
      rgba(60,40,100,.84) 30%,
      rgba(50,35,90,.80) 48%,
      rgba(90,25,55,.80) 52%,
      rgba(140,30,60,.84) 70%,
      rgba(170,35,65,.88) 100%
    );
  color: rgba(255,255,255,.92) !important;
  font-weight: 900 !important;
  letter-spacing: 0.19em !important;
  padding: 13px 20px !important;
  margin-top: 18px !important;
  margin-bottom: 0 !important;
  text-shadow: 0 2px 8px rgba(0,0,0,.35);
  border-top: 2px solid rgba(255,255,255,.18);
  border-bottom: 2px solid rgba(255,255,255,.18);
}

/* V2: Court header with gradient */
.broadcast-court-header-band{
  background:
    radial-gradient(850px 150px at 50% 50%, rgba(255,255,255,.12), transparent 66%),
    linear-gradient(90deg,
      rgba(80,50,140,.86) 0%,
      rgba(70,45,130,.82) 30%,
      rgba(60,40,100,.78) 48%,
      rgba(100,30,60,.78) 52%,
      rgba(150,35,65,.82) 70%,
      rgba(180,40,70,.86) 100%
    );
  border: 2px solid rgba(255,255,255,.26);
  border-bottom: none;
  box-shadow: 0 2px 0 rgba(255,255,255,.16) inset, 0 6px 12px rgba(0,0,0,.16);
  padding: 15px 17px !important;
  border-radius: 11px 11px 0 0 !important;
}

.broadcast-court-label-main{
  color: rgba(255,255,255,.96) !important;
  text-shadow: 0 2px 8px rgba(0,0,0,.35);
  letter-spacing: 0.13em !important;
}

.broadcast-court-label-slot{
  color: rgba(255,255,255,.88) !important;
  text-shadow: 0 2px 6px rgba(0,0,0,.30);
  letter-spacing: 0.20em !important;
}

/* V2: Unified gradient across entire matchup row */
.broadcast-matchup-row-grid{
  background:
    url("grain.png") 0 0 / 280px 280px repeat,
    radial-gradient(500px 180px at 50% 50%, rgba(255,255,255,.18), transparent 68%),
    radial-gradient(800px 450px at 18% 50%, rgba(120,110,255,.14), transparent 62%),
    radial-gradient(800px 450px at 82% 50%, rgba(255,100,130,.14), transparent 62%),
    linear-gradient(90deg,
      rgba(85,55,145,.90) 0%,
      rgba(75,50,135,.88) 25%,
      rgba(65,45,115,.86) 48%,
      rgba(110,35,70,.86) 52%,
      rgba(155,40,75,.88) 75%,
      rgba(185,45,80,.90) 100%
    );
  border: 2px solid rgba(255,255,255,.28);
  box-shadow:
    0 2px 0 rgba(255,255,255,.20) inset,
    0 -2px 0 rgba(0,0,0,.10) inset,
    0 14px 32px rgba(0,0,0,.18),
    0 6px 14px rgba(0,0,0,.12);
  position: relative;
  overflow: hidden;
}

/* Center flare beam */
.broadcast-matchup-row-grid::before{
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(180deg,
    rgba(255,255,255,.80) 0%,
    rgba(255,220,180,.70) 20%,
    rgba(255,200,150,.55) 50%,
    rgba(255,220,180,.70) 80%,
    rgba(255,255,255,.80) 100%
  );
  transform: translateX(-50%);
  box-shadow:
    0 0 50px 16px rgba(255,220,180,.35),
    0 0 100px 32px rgba(255,200,150,.22),
    0 0 160px 48px rgba(255,180,120,.12);
  pointer-events: none;
  z-index: 1;
}

/* V2: Team sides transparent (gradient is on parent now) */
.broadcast-team-side{
  background: transparent !important;
  z-index: 2;
}

.broadcast-team-side::after{
  background:
    radial-gradient(450px 200px at 50% 115%, rgba(0,0,0,.18), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.06), transparent 45%);
  opacity: .70;
}

/* V2: Enhanced player tiles for gradient background */
.broadcast-player-tile{
  background:
    linear-gradient(180deg, rgba(255,255,255,.12), rgba(0,0,0,.28));
  border: 2px solid rgba(255,255,255,.38);
  box-shadow:
    0 2px 0 rgba(255,255,255,.16) inset,
    0 -2px 0 rgba(0,0,0,.10) inset,
    0 13px 26px rgba(0,0,0,.26);
  border-radius: 10px !important;
}

.broadcast-player-tile:hover{
  transform: translateY(-2px);
  filter: brightness(1.08);
  box-shadow:
    0 2px 0 rgba(255,255,255,.20) inset,
    0 -2px 0 rgba(0,0,0,.10) inset,
    0 16px 32px rgba(0,0,0,.30);
}

.broadcast-player-headshot{
  border: 3px solid rgba(255,255,255,.94);
  box-shadow:
    0 0 0 1px rgba(0,0,0,.14),
    0 13px 26px rgba(0,0,0,.32);
}

.broadcast-player-name{
  color: #ffffff !important;
  font-weight: 900 !important;
  text-shadow:
    0 0 10px rgba(0,0,0,.35),
    0 2px 8px rgba(0,0,0,.45);
}

.broadcast-player-cta{
  color: rgba(255,255,255,.94) !important;
  font-weight: 800 !important;
  text-shadow: 0 2px 10px rgba(0,0,0,.32);
}

/* V2: Enhanced score spine on center flare */
.broadcast-score-spine{
  background:
    url("flare.png") center 42% / 540px 135px no-repeat,
    radial-gradient(260px 130px at 50% 8%, rgba(255,255,255,.16), transparent 72%),
    radial-gradient(180px 250px at 50% 102%, rgba(100,150,255,.10), transparent 66%),
    linear-gradient(180deg, #091a2e, #0e2240 62%, #08151f);
  z-index: 3;
}

.broadcast-score-value{
  font-size: 36px !important;
  font-weight: 900 !important;
  text-shadow:
    0 0 16px rgba(255,255,255,.26),
    0 4px 14px rgba(0,0,0,.45),
    0 10px 28px rgba(0,0,0,.35);
}

/* ========================================
   FINAL COMP LOCK (Red/Blue Broadcast Plate)
   ======================================== */

:root{
  --bh-split-left: #3a246f;
  --bh-split-left-hi: #5e3eaa;
  --bh-split-right: #7d1b31;
  --bh-split-right-hi: #bf3150;
  --bh-panel-ink: #0a1020;
  --bh-metal: #f3f6ff;
  --bh-metal-muted: rgba(236, 241, 255, 0.74);
  --bh-gold: #efcf70;
}

body{
  background:
    radial-gradient(1300px 620px at 16% -8%, rgba(120, 128, 255, 0.24), transparent 62%),
    radial-gradient(1300px 620px at 82% -8%, rgba(255, 105, 146, 0.24), transparent 60%),
    linear-gradient(180deg, #060a14, #04070d 74%);
}

.container{
  max-width: min(980px, calc(100vw - 24px));
  margin: 16px auto 24px;
  min-height: auto;
  border: 1px solid rgba(255,255,255,.26);
  border-radius: 0;
  box-shadow:
    0 28px 64px rgba(0,0,0,.52),
    inset 0 1px 0 rgba(255,255,255,.24);
  background:
    linear-gradient(90deg, rgba(95, 67, 174, 0.16) 0%, rgba(95, 67, 174, 0.04) 47%, rgba(191, 47, 77, 0.04) 53%, rgba(191, 47, 77, 0.16) 100%),
    linear-gradient(180deg, #130d24 0%, #100a1d 100%);
}

.container::before{
  position: absolute;
  opacity: 0.22;
}

.container::after{
  position: absolute;
  opacity: 0.38;
}

.oc-presenter-bar{
  background:
    radial-gradient(640px 110px at 50% -40%, rgba(255,255,255,.26), transparent 72%),
    linear-gradient(90deg, rgba(58, 36, 111, 0.96), rgba(191, 49, 80, 0.96));
  border-bottom: 1px solid rgba(255,255,255,.28);
  color: var(--bh-metal-muted);
  padding: 8px 14px;
  letter-spacing: .11em;
  font-size: 10px;
  font-weight: 700;
}

.match-header{
  padding: 20px 16px 14px !important;
  border-top: 1px solid rgba(255,255,255,.26);
  border-bottom: 1px solid rgba(255,255,255,.30);
  background:
    radial-gradient(760px 220px at 50% -8%, rgba(255,255,255,.28), transparent 72%),
    linear-gradient(90deg, rgba(58, 36, 111, 0.96), rgba(191, 49, 80, 0.96));
}

.match-header::before{
  background:
    radial-gradient(circle 8px at 11% 24%, rgba(255,255,255,.82), transparent 66%),
    radial-gradient(circle 7px at 17% 30%, rgba(255,232,214,.72), transparent 68%),
    radial-gradient(circle 9px at 81% 24%, rgba(255,255,255,.82), transparent 66%),
    radial-gradient(circle 7px at 86% 30%, rgba(255,232,214,.72), transparent 68%),
    url("flare.png") center -26px / 680px 170px no-repeat;
  opacity: .9;
}

.match-header::after{
  content: "";
  position: absolute;
  top: 10px;
  bottom: 10px;
  left: 50%;
  width: 1px;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(255,255,255,.45), rgba(255,245,230,.24), rgba(255,255,255,.45));
  box-shadow: 0 0 10px rgba(255, 235, 210, .18);
  pointer-events: none;
}

.match-header h1{
  font-family: "Arial Black", "Segoe UI", sans-serif;
  font-size: clamp(20px, 3.05vw, 40px) !important;
  font-weight: 900 !important;
  letter-spacing: .018em !important;
  line-height: .98;
  text-transform: uppercase;
  color: #fff !important;
  text-shadow:
    0 0 18px rgba(255,255,255,.20),
    0 5px 16px rgba(0,0,0,.46);
}

.match-title-display{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-align: center;
  flex-wrap: wrap;
}

.match-title-display > span{
  white-space: nowrap;
}

.match-title-vs-group{
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.match-title-vs{
  font-size: .56em;
  letter-spacing: .10em;
  font-weight: 900;
  color: rgba(255,248,238,.94);
  text-shadow: 0 2px 8px rgba(0,0,0,.48);
}

.match-title-logo{
  width: 46px;
  height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.45);
  background: rgba(8, 14, 26, .58);
  box-shadow: 0 8px 14px rgba(0,0,0,.28);
  overflow: hidden;
}

.match-title-logo img{
  width: 74%;
  height: 74%;
  object-fit: contain;
  filter: drop-shadow(0 4px 8px rgba(0,0,0,.42));
}

.match-title-logo .score-team-logo--text{
  width: 100%;
  height: 100%;
  border: 2px solid rgba(255,255,255,.48);
  border-radius: 50%;
  background: rgba(10,14,24,.42) !important;
  color: rgba(245,250,255,.96);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: .02em;
}

.match-title-mark{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-family: "Arial Black", "Segoe UI", sans-serif;
  font-size: 30px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.match-title-mark--washington{
  color: #f2cf7a;
  text-shadow:
    0 1px 0 rgba(32,16,60,.95),
    0 0 10px rgba(112,82,206,.72);
}

.match-title-mark--santaclara{
  color: #fff4f6;
  text-shadow:
    0 1px 0 rgba(85,12,22,.94),
    0 0 12px rgba(194,53,85,.72);
}

.match-title-mark--portlandstate{
  color: #d9f8e5;
  text-shadow:
    0 1px 0 rgba(4,51,31,.95),
    0 0 10px rgba(40,184,114,.68);
}

.match-title-mark--default{
  color: #eef4ff;
  text-shadow:
    0 1px 0 rgba(8,16,34,.94),
    0 0 8px rgba(158,178,222,.62);
}

.match-header-meta{
  color: rgba(246, 250, 255, 0.9) !important;
  font-size: 15px;
  font-weight: 700 !important;
  letter-spacing: .03em;
  text-shadow: 0 3px 10px rgba(0,0,0,.4);
}

.score-banner{
  position: relative;
  background:
    radial-gradient(760px 180px at 50% 20%, rgba(255,255,255,.18), transparent 70%),
    linear-gradient(90deg, rgba(58, 36, 111, 0.94), rgba(191, 49, 80, 0.94));
  border-top: 1px solid rgba(255,255,255,.30);
  border-bottom: 1px solid rgba(255,255,255,.30);
  gap: 10px;
  padding: 11px 14px !important;
}

.score-banner::before{
  display: none;
}

.score-team{
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  grid-template-areas:
    "logo name"
    "logo abbr";
  align-items: center;
  gap: 2px 8px;
  min-width: 0;
}

.score-team:last-child{
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-areas:
    "name logo"
    "abbr logo";
  text-align: right;
}

.score-team-logo{
  grid-area: logo;
  width: 44px;
  height: 44px;
  margin: 0;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.38);
  background: rgba(6, 10, 19, .5);
  box-shadow: 0 8px 14px rgba(0,0,0,.26);
}

.score-team-logo img{
  object-fit: contain;
  padding: 4px;
  filter: drop-shadow(0 3px 6px rgba(0,0,0,.34));
}

.score-team-logo--text{
  width: 100%;
  height: 100%;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.3);
  background: rgba(9, 13, 24, .6) !important;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: .02em;
}

.score-team-name{
  grid-area: name;
  font-size: clamp(15px, 2.2vw, 24px);
  font-weight: 900 !important;
  letter-spacing: .08em !important;
  color: #fff !important;
  text-transform: uppercase;
  text-shadow: 0 3px 10px rgba(0,0,0,.45);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.score-team-abbr{
  grid-area: abbr;
  color: rgba(238, 244, 255, 0.84);
  font-size: 10px;
  letter-spacing: .22em;
  font-weight: 700;
}

.score-vs{
  flex: 0 0 auto;
  gap: 10px;
  padding: 6px 16px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.42);
  background: rgba(5, 9, 17, .72);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.16),
    0 10px 18px rgba(0,0,0,.26);
}

.score-number{
  font-size: clamp(40px, 7.7vw, 64px) !important;
  font-weight: 900 !important;
  color: #fff !important;
  line-height: .9;
}

.score-dash{
  color: rgba(255,255,255,.92) !important;
  font-size: clamp(24px, 5vw, 34px);
}

.section-header{
  margin: 9px 12px 5px !important;
  padding: 8px 12px !important;
  border: 1px solid rgba(255,255,255,.28);
  border-radius: 0;
  background:
    linear-gradient(90deg, rgba(58, 36, 111, 0.96), rgba(191, 49, 80, 0.96));
  color: rgba(246, 250, 255, 0.94) !important;
  letter-spacing: .18em !important;
  font-size: 11px;
  font-weight: 900 !important;
}

.court-cards{
  padding: 0 12px;
}

.court-card{
  margin-bottom: 10px;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

.court-card-header{
  display: none !important;
}

.broadcast-court-header-band{
  margin: 0 !important;
  padding: 7px 12px !important;
  border-radius: 0 !important;
  border: 1px solid rgba(255,255,255,.30);
  border-bottom: 0;
  background:
    linear-gradient(90deg, rgba(58, 36, 111, 0.95), rgba(191, 49, 80, 0.95));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.2);
}

.broadcast-court-label{
  flex-direction: row;
  align-items: baseline;
  gap: 8px;
}

.broadcast-court-label-main{
  font-size: 17px !important;
  letter-spacing: .06em !important;
  color: rgba(248, 252, 255, .96) !important;
  text-shadow: 0 2px 7px rgba(0,0,0,.34);
}

.broadcast-court-label-slot{
  font-size: 11px !important;
  letter-spacing: .14em !important;
  color: rgba(236, 243, 255, .84) !important;
  text-shadow: 0 2px 8px rgba(0,0,0,.36);
}

.status-badge{
  border-radius: 2px;
  border: 1px solid rgba(255,255,255,.34);
  background: rgba(8, 12, 21, .54);
  color: #f4f8ff;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 2px 8px;
}

.status-badge--live{
  background: rgba(34, 197, 94, .22);
  border-color: rgba(134, 239, 172, .72);
  color: #d1fae5;
}

.status-badge--final{
  background: rgba(9, 14, 25, .56);
  border-color: rgba(255,255,255,.3);
  color: rgba(236, 242, 255, .9);
}

.live-dot{
  width: 6px;
  height: 6px;
  box-shadow: 0 0 0 3px rgba(34, 197, 94, .26);
}

.broadcast-matchup-row-grid{
  position: relative;
  min-height: 140px;
  border-radius: 0 !important;
  border: 1px solid rgba(255,255,255,.28);
  border-top: 0;
  grid-template-columns: 1fr var(--broadcast-spine-width, 124px) 1fr;
  background:
    url("grain.png") 0 0 / 240px 240px repeat,
    repeating-linear-gradient(180deg, rgba(255,255,255,.06) 0 1px, rgba(255,255,255,0) 1px 18px),
    radial-gradient(560px 210px at 50% 48%, rgba(255,255,255,.17), transparent 70%),
    radial-gradient(660px 350px at 14% 54%, rgba(94, 62, 170, .45), transparent 68%),
    radial-gradient(660px 350px at 86% 54%, rgba(191, 49, 80, .45), transparent 68%),
    linear-gradient(90deg, rgba(43, 25, 83, .96), rgba(128, 28, 50, .96));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.17),
    0 10px 24px rgba(0,0,0,.28);
}

.broadcast-matchup-row-grid::before{
  width: 1px;
  background: linear-gradient(180deg, rgba(255,255,255,.30), rgba(255,224,190,.16), rgba(255,255,255,.30));
  box-shadow:
    0 0 10px rgba(255,220,180,.14);
}

.broadcast-matchup-row-grid::after{
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 210px;
  height: 86px;
  transform: translate(-50%, -50%);
  background:
    radial-gradient(ellipse at center, rgba(255,206,132,.16) 0%, rgba(255,199,120,.08) 38%, rgba(255,180,110,0) 70%);
  filter: blur(1px);
  pointer-events: none;
  z-index: 1;
}

.broadcast-team-side{
  z-index: 2;
  gap: 7px !important;
  padding: 7px !important;
}

.broadcast-team-side--left{
  border-right: 1px solid rgba(255,255,255,.22);
}

.broadcast-team-side--right{
  border-left: 1px solid rgba(255,255,255,.22);
}

.broadcast-team-side::after{
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), transparent 40%),
    radial-gradient(380px 170px at 50% 115%, rgba(0,0,0,.26), transparent 62%);
}

.broadcast-player-tile{
  border-radius: 0 !important;
  min-height: 116px;
  padding: 8px 7px 0 !important;
  gap: 5px;
  justify-content: flex-start;
  border: 1px solid rgba(255,255,255,.28);
  background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(3,7,16,.36));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.14),
    inset 0 -1px 0 rgba(0,0,0,.18),
    0 8px 18px rgba(0,0,0,.25);
}

.broadcast-player-headshot{
  width: 62px;
  height: 62px;
  border: 2px solid rgba(255,255,255,.9);
  box-shadow:
    0 0 0 1px rgba(7, 11, 22, .28),
    0 8px 14px rgba(0,0,0,.3);
}

.broadcast-player-name{
  font-size: 13px;
  line-height: 1.05;
  max-width: 100%;
  color: #fff !important;
}

.broadcast-player-subline{
  margin-top: -1px;
  font-size: 10px;
  letter-spacing: .02em;
  color: rgba(231, 238, 255, .8);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

.broadcast-player-cta{
  width: calc(100% + 14px);
  margin: 8px -7px 0;
  padding: 6px 8px;
  border-top: 1px solid rgba(255,255,255,.22);
  background: rgba(7, 11, 20, .54);
  color: rgba(240, 246, 255, .94) !important;
  text-shadow: none;
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  text-align: left;
}

.broadcast-score-spine{
  z-index: 3;
  padding: 9px 8px;
  gap: 8px;
  border-left: 1px solid rgba(255,255,255,.26);
  border-right: 1px solid rgba(255,255,255,.26);
  background:
    url("flare.png") center 42% / 620px 160px no-repeat,
    radial-gradient(220px 120px at 50% 8%, rgba(255,255,255,.2), transparent 72%),
    linear-gradient(180deg, #0e1930, #162b4c 62%, #0d172b);
}

.broadcast-score-spine::before,
.broadcast-score-spine::after{
  display: none;
}

.broadcast-score-value{
  font-size: 48px !important;
  letter-spacing: -.04em;
  color: rgba(246, 250, 255, .97) !important;
  text-shadow:
    0 0 16px rgba(255,255,255,.20),
    0 8px 18px rgba(0,0,0,.44);
}

.broadcast-score-value--meta{
  font-size: 22px !important;
  letter-spacing: .1em;
  color: rgba(231, 240, 255, .92) !important;
}

.broadcast-score-sets{
  font-size: 10px;
  line-height: 1.2;
  letter-spacing: .06em;
  opacity: .84;
}

.doubles-point{
  margin: 6px 12px 14px;
  border-radius: 0;
  border: 1px solid rgba(239, 207, 112, .58);
  background: linear-gradient(180deg, #161208, #090705);
  color: var(--bh-gold);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.doubles-point-icon{
  color: rgba(245, 249, 255, .96);
}

.qr-section{
  margin: 20px 12px;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 0;
  background: rgba(10, 14, 26, .45);
  color: rgba(241, 247, 255, .86);
}

@media (max-width: 980px){
  .container{
    max-width: 100%;
    margin: 0;
    border-left: 0;
    border-right: 0;
  }
}

@media (min-width: 1200px){
  .match-header h1{
    white-space: nowrap;
  }

  .match-title-display{
    flex-wrap: nowrap;
  }
}

@media (max-width: 600px){
  .match-header h1{
    font-size: clamp(21px, 6.8vw, 30px) !important;
    line-height: 1.05;
  }

  .match-title-display{
    gap: 7px;
  }

  .match-title-vs-group{
    gap: 5px;
  }

  .match-title-logo{
    width: 28px;
    height: 28px;
  }

  .match-title-logo .score-team-logo--text{
    border-radius: 50%;
    font-size: 12px;
  }

  .match-title-mark{
    font-size: 16px;
  }

  .score-team-name{
    font-size: 13px;
    letter-spacing: .04em !important;
  }

  .score-team-abbr{
    letter-spacing: .12em;
  }

  .score-team-logo{
    width: 32px;
    height: 32px;
  }

  .score-vs{
    min-width: 94px;
    gap: 6px;
    padding: 4px 9px;
  }

  .broadcast-matchup-row-grid{
    min-height: 116px;
    grid-template-columns: 1fr var(--broadcast-spine-width-mobile, 88px) 1fr;
  }

  .broadcast-player-tile{
    min-height: 94px;
  }

  .broadcast-player-headshot{
    width: 46px;
    height: 46px;
  }

  .broadcast-player-subline{
    font-size: 9px;
  }

  .broadcast-score-value{
    font-size: 34px !important;
  }

  .broadcast-score-value--meta{
    font-size: 18px !important;
  }

  .broadcast-court-label-main{
    font-size: 14px !important;
  }

  .broadcast-court-label-slot{
    font-size: 10px !important;
  }
}
