/* ================================================================
   THE GOAT CALCULATOR — midnight court / championship gold
   Palette: ink #0A0C12 · panel #11151E · parquet #B98A5E
            gold #E8B54A · chalk #F2EDE3 · steel #67738A · flag #D4533B
   Type: Archivo Black (display) · Barlow (body) · Barlow Semi Condensed (data)
   ================================================================ */
:root{
  --ink:#0A0C12; --panel:#11151E; --panel2:#161B27; --line:#232A39;
  --parquet:#B98A5E; --gold:#E8B54A; --gold-dim:#9C7A35;
  --chalk:#F2EDE3; --steel:#67738A; --flag:#D4533B; --green:#5FA86B;
  --disp:'Archivo Black',sans-serif; --body:'Barlow',sans-serif; --data:'Barlow Semi Condensed',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--ink);color:var(--chalk);font-family:var(--body);font-size:17px;line-height:1.6;
  background-image:radial-gradient(ellipse 1200px 600px at 50% -200px, rgba(185,138,94,.08), transparent 60%)}
a{color:var(--gold);text-decoration:none}
a:hover{text-decoration:underline}
img,svg{display:block;max-width:100%}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--data);font-weight:600;letter-spacing:.22em;text-transform:uppercase;font-size:12px;color:var(--parquet)}
h1,h2,h3,.disp{font-family:var(--disp);font-weight:400;line-height:1.04;letter-spacing:-.01em;text-transform:uppercase}
h1{font-size:clamp(40px,6.4vw,84px)}
h2{font-size:clamp(28px,3.6vw,46px);margin-bottom:14px}
h3{font-size:20px}
p.lead{font-size:clamp(18px,2vw,22px);color:#C9C2B4;max-width:62ch}
.muted{color:var(--steel)}
.gold{color:var(--gold)}
section{padding:84px 0;border-top:1px solid var(--line)}
section.flush{border-top:none;padding-top:0}

/* nav */
nav.top{position:sticky;top:0;z-index:50;background:rgba(10,12,18,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
nav.top .wrap{display:flex;align-items:center;gap:28px;height:66px}
nav.top .logo{display:flex;align-items:center;gap:11px;font-family:var(--disp);font-size:17px;letter-spacing:.02em;color:var(--chalk);text-transform:uppercase}
nav.top .logo:hover{text-decoration:none}
nav.top .links{margin-left:auto;display:flex;gap:24px;align-items:center}
nav.top .links a{color:#B9B2A4;font-family:var(--data);font-weight:600;font-size:14px;letter-spacing:.06em;text-transform:uppercase}
nav.top .links a:hover{color:var(--gold);text-decoration:none}
nav.top .links a.active{color:var(--gold)}
.btn{display:inline-block;font-family:var(--data);font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  font-size:14px;padding:13px 24px;border-radius:4px;border:1px solid var(--gold);color:var(--ink);
  background:linear-gradient(180deg,#F3C661,#D9A437);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 6px 22px rgba(232,181,74,.25);text-decoration:none}
.btn.ghost{background:transparent;color:var(--gold)}
.btn.small{padding:9px 16px;font-size:12px}
.btn:disabled{opacity:.45;cursor:default;transform:none;box-shadow:none}

/* hero */
.hero{padding:72px 0 64px;border-top:none;position:relative;overflow:hidden}
.hero .court-arc{position:absolute;right:-180px;top:-160px;width:720px;height:720px;border:2px solid rgba(185,138,94,.18);
  border-radius:50%;pointer-events:none}
.hero .court-arc:after{content:"";position:absolute;inset:120px;border:2px solid rgba(185,138,94,.12);border-radius:50%}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:start}
.hero .sub{margin:22px 0 30px}
.ladder{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:22px 22px 16px;position:relative}
.ladder header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.ladder header .t{font-family:var(--data);font-weight:700;letter-spacing:.14em;font-size:12px;text-transform:uppercase;color:var(--parquet)}
.ladder header .live{font-family:var(--data);font-size:11px;letter-spacing:.12em;color:var(--green);text-transform:uppercase}
.ladder header .live:before{content:"●";margin-right:6px;animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.rung{display:grid;grid-template-columns:30px 1fr auto;gap:12px;align-items:center;padding:8px 0;border-top:1px solid var(--line);transition:background .35s}
.rung:first-of-type{border-top:none}
.rung .rk{font-family:var(--disp);font-size:15px;color:var(--steel)}
.rung.r1 .rk{color:var(--gold)}
.rung .nm{font-family:var(--data);font-weight:600;font-size:16px;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rung .nm small{color:var(--steel);font-weight:500;margin-left:8px;font-size:12px}
.rung .bar{grid-column:1/-1;height:5px;border-radius:3px;background:var(--panel2);overflow:hidden;margin-top:-2px}
.rung .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--parquet),var(--gold));transition:width .55s cubic-bezier(.2,.8,.2,1)}
.rung .sc{font-family:var(--data);font-weight:700;font-size:15px;color:var(--gold);font-variant-numeric:tabular-nums}
.lever{margin-top:18px;padding-top:16px;border-top:1px dashed var(--line)}
.lever label{display:flex;justify-content:space-between;font-family:var(--data);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--steel);margin-bottom:8px}
.lever label b{color:var(--gold)}
input[type=range]{width:100%;accent-color:var(--gold);height:4px}
.hero .stats{display:flex;gap:36px;margin-top:34px;flex-wrap:wrap}
.hero .stat .n{font-family:var(--disp);font-size:30px;color:var(--gold)}
.hero .stat .l{font-family:var(--data);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--steel)}

/* cards / how it works */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:36px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:36px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:26px}
.card h3{margin:14px 0 10px;color:var(--chalk)}
.card p{color:#B9B2A4;font-size:15.5px}
.card .tag{font-family:var(--data);font-weight:700;font-size:12px;letter-spacing:.18em;color:var(--parquet);text-transform:uppercase}
.formula{font-family:var(--data);font-weight:600;background:var(--panel2);border:1px solid var(--line);border-radius:6px;
  padding:14px 16px;font-size:14.5px;color:var(--gold);overflow-x:auto;white-space:nowrap;margin-top:12px}

/* pv tier table */
.tiers{width:100%;border-collapse:collapse;font-family:var(--data);margin-top:24px;font-size:15px}
.tiers th{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--parquet);text-align:left;padding:10px 12px;border-bottom:1px solid var(--parquet)}
.tiers td{padding:10px 12px;border-bottom:1px solid var(--line)}
.tiers td.v{color:var(--gold);font-weight:700;font-variant-numeric:tabular-nums}

/* lists showcase */
.chips-demo{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.chip{font-family:var(--data);font-weight:600;font-size:14px;border:1px solid var(--line);color:#C9C2B4;
  background:var(--panel);padding:9px 16px;border-radius:99px;cursor:pointer;transition:all .15s}
.chip:hover,.chip.on{border-color:var(--gold);color:var(--gold);background:rgba(232,181,74,.08)}

/* subscribe band */
.band{background:linear-gradient(135deg,#171206,#221a08 55%,#171206);border:1px solid var(--gold-dim);border-radius:14px;
  padding:46px 44px;display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center}
.band form{display:flex;gap:10px}
.band input[type=email]{flex:1;background:var(--ink);border:1px solid var(--line);color:var(--chalk);
  border-radius:4px;padding:13px 14px;font-family:var(--body);font-size:15px}
.band input[type=email]:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.price-line{font-family:var(--data);color:var(--steel);font-size:13px;letter-spacing:.06em;margin-top:12px}

/* footer */
footer{border-top:1px solid var(--line);padding:44px 0;color:var(--steel);font-size:14px;font-family:var(--data)}
footer .wrap{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}
footer a{color:#9b94a6}

/* =================== CALCULATOR APP =================== */
.app{display:grid;grid-template-columns:316px 1fr;gap:26px;padding:30px 0 80px;align-items:start}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:20px}
.panel h4{font-family:var(--data);font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--parquet);margin-bottom:14px}
.panel + .panel{margin-top:18px}
.ctl{margin-bottom:14px}
.ctl label{display:flex;justify-content:space-between;font-family:var(--data);font-size:13px;font-weight:600;color:#C9C2B4;margin-bottom:5px}
.ctl label b{color:var(--gold);font-variant-numeric:tabular-nums}
select,input[type=text],input[type=number]{width:100%;background:var(--ink);border:1px solid var(--line);color:var(--chalk);
  border-radius:4px;padding:9px 10px;font-family:var(--data);font-size:14px}
select:focus,input:focus{outline:1.5px solid var(--gold)}
.presets{display:flex;flex-wrap:wrap;gap:8px}
.presets .chip{font-size:12.5px;padding:7px 12px}
.poschips{display:flex;gap:6px;flex-wrap:wrap}
.poschips .chip{padding:6px 11px;font-size:12.5px}
.decchips{display:flex;gap:6px;flex-wrap:wrap}
.decchips .chip{padding:5px 9px;font-size:12px}

.list-title{display:flex;align-items:baseline;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:6px}
.list-title h2{margin:0}
.list-sub{color:var(--steel);font-family:var(--data);font-size:13.5px;letter-spacing:.04em;margin-bottom:16px}
table.rank{width:100%;border-collapse:collapse;font-family:var(--data)}
/* The rankings table lives inside an overflow-x wrapper (sideways scroll for
   the 14-column Legacy view), which makes that wrapper the sticky containing
   scrollport — a sticky top offset would permanently displace the header DOWN
   by that amount, burying row #1 underneath it. top:0 keeps the header in its
   natural slot (the wrapper never scrolls vertically, so it can't overlap). */
table.rank th{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--steel);text-align:left;
  padding:9px 10px;border-bottom:1px solid var(--parquet);position:sticky;top:0;background:var(--ink);z-index:5}
table.rank td{padding:10px;border-bottom:1px solid var(--line);font-size:15px;vertical-align:middle}
table.rank tr.player{cursor:pointer}
table.rank tr.player:hover{background:rgba(232,181,74,.05)}
td.rk{font-family:var(--disp);color:var(--steel);width:48px;font-size:15px}
tr:nth-child(-n+3) td.rk{color:var(--gold)}
.medal{display:inline-flex;width:34px;height:34px;border-radius:50%;background:var(--panel2);border:1px solid var(--line);
  align-items:center;justify-content:center;font-family:var(--disp);font-size:12px;color:var(--parquet);margin-right:10px;flex:none}
td.who{display:flex;align-items:center;min-width:200px}
td.who .nm{font-weight:600;letter-spacing:.02em}
td.who .meta{display:block;color:var(--steel);font-size:12px;font-weight:500}
td.num{font-variant-numeric:tabular-nums;font-weight:600}
td.score{color:var(--gold);font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}
.sbar{height:4px;background:var(--panel2);border-radius:2px;overflow:hidden;margin-top:4px;min-width:120px}
.sbar i{display:block;height:100%;background:linear-gradient(90deg,var(--parquet),var(--gold))}
.ringdots{letter-spacing:2px;color:var(--gold);font-size:13px;white-space:nowrap}
tr.detail td{background:var(--panel);padding:18px}
.season-tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.season-tbl th{color:var(--parquet);font-size:11px;letter-spacing:.1em;text-transform:uppercase;text-align:right;padding:6px 8px;border-bottom:1px solid var(--line);position:static;background:transparent}
.season-tbl th:first-child,.season-tbl td:first-child{text-align:left}
.season-tbl td{padding:5px 8px;border-bottom:1px solid #1b2130;text-align:right;font-variant-numeric:tabular-nums}
.season-tbl td.pos{color:var(--green)} .neg{color:var(--flag)}
.detail-actions{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.toolbar input[type=text]{max-width:280px}
.count-note{margin-left:auto;color:var(--steel);font-family:var(--data);font-size:13px}

/* compare + ai */
.drawer{background:var(--panel);border:1px solid var(--gold-dim);border-radius:10px;padding:20px;margin-bottom:20px}
.drawer h4{color:var(--gold)}
.cmp-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:16px;align-items:center;font-family:var(--data)}
.cmp-col{text-align:center}
.cmp-col .big{font-family:var(--disp);font-size:34px;color:var(--gold)}
.cmp-vs{font-family:var(--disp);color:var(--steel);font-size:18px}
.cmp-row{display:grid;grid-template-columns:1fr 110px 1fr;font-size:14px;padding:6px 0;border-top:1px solid var(--line)}
.cmp-row span:first-child{text-align:right;padding-right:14px}
.cmp-row span:last-child{padding-left:14px}
.cmp-row .lbl{text-align:center;color:var(--steel);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;align-self:center}
.cmp-row .win{color:var(--gold);font-weight:700}
.ai-box textarea{width:100%;min-height:74px;background:var(--ink);border:1px solid var(--line);color:var(--chalk);
  border-radius:4px;padding:10px;font-family:var(--body);font-size:15px;resize:vertical}
.ai-out{background:var(--ink);border:1px solid var(--line);border-radius:6px;padding:16px;margin-top:12px;
  font-size:15px;line-height:1.65;color:#D8D2C4;white-space:pre-wrap;display:none}
.spin{display:inline-block;width:14px;height:14px;border:2px solid var(--gold);border-top-color:transparent;border-radius:50%;animation:rot .7s linear infinite;vertical-align:-2px;margin-right:8px}
@keyframes rot{to{transform:rotate(360deg)}}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(5,6,10,.78);display:none;align-items:center;justify-content:center;z-index:90;padding:20px}
.modal-bg.open{display:flex}
.modal{background:var(--panel);border:1px solid var(--gold-dim);border-radius:12px;max-width:560px;width:100%;padding:30px;max-height:88vh;overflow:auto}
.modal h3{color:var(--gold);margin-bottom:8px}
.modal .x{float:right;background:none;border:none;color:var(--steel);font-size:22px;cursor:pointer}
.field{margin-bottom:12px}
.field label{display:block;font-family:var(--data);font-size:12.5px;font-weight:600;letter-spacing:.06em;color:#C9C2B4;margin-bottom:4px;text-transform:uppercase}
.pi-result{background:var(--ink);border:1px solid var(--gold-dim);border-radius:6px;padding:14px;margin-top:14px;font-family:var(--data);display:none}
.pi-result .row{display:flex;justify-content:space-between;padding:4px 0;font-size:14.5px}
.pi-result .row b{color:var(--gold);font-variant-numeric:tabular-nums}
.note{font-size:12.5px;color:var(--steel);margin-top:10px;line-height:1.5}

@media(max-width:980px){
  .hero-grid,.grid3,.grid2,.band,.app{grid-template-columns:1fr}
  nav.top .links a:not(.btn){display:none}
  section{padding:60px 0}
}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}

/* =================== VISUAL UPGRADE: COURT SCENE + TEAM IDENTITY =================== */

/* --- drone-over-the-court hero scene --- */
.hero{min-height:640px}
.court-scene{position:absolute;inset:0;overflow:hidden;z-index:0;perspective:1100px;
  background:radial-gradient(ellipse 70% 55% at 50% 8%, #181320 0%, var(--ink) 62%)}
.hero .wrap{position:relative;z-index:3}
.court-3d{position:absolute;left:50%;top:46%;width:1700px;height:980px;
  transform:translate(-50%,-26%) rotateX(57deg) scale(1.05);
  animation:flyover 26s ease-in-out infinite alternate;will-change:transform;opacity:.92}
@keyframes flyover{
  from{transform:translate(-50%,-26%) rotateX(57deg) translateY(0) scale(1.05)}
  to{transform:translate(-50%,-26%) rotateX(51deg) translateY(-130px) scale(1.24)}}
.court-svg{width:100%;height:100%}
.court-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55;display:none}
.depth-fog{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg, var(--ink) 0%, rgba(10,12,18,.25) 30%, rgba(10,12,18,0) 55%, rgba(10,12,18,.92) 96%)}
.spot{position:absolute;width:560px;height:760px;top:-180px;filter:blur(46px);opacity:.5;z-index:1;
  background:conic-gradient(from 18deg at 50% 0%, transparent 41%, rgba(232,181,74,.16) 50%, transparent 59%);
  mix-blend-mode:screen;pointer-events:none}
.spot.s1{left:6%;transform:rotate(-7deg)} .spot.s2{right:8%;transform:rotate(8deg) scaleX(-1)}
.dust{position:absolute;inset:0;z-index:2;pointer-events:none}
.dust i{position:absolute;width:3px;height:3px;border-radius:50%;background:rgba(232,181,74,.5);
  animation:drift 16s linear infinite;opacity:0}
@keyframes drift{0%{transform:translateY(30px);opacity:0}12%{opacity:.7}88%{opacity:.5}
  100%{transform:translateY(-140px) translateX(24px);opacity:0}}
.vignette{position:absolute;inset:0;z-index:2;pointer-events:none;
  box-shadow:inset 0 0 220px 60px rgba(5,6,10,.85)}

/* --- sitewide texture so nothing is flat black --- */
.court-texture{position:relative}
.court-texture:before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.05;
  background-image:radial-gradient(circle 340px at 110% 50%, transparent 338px, var(--parquet) 339px, var(--parquet) 341px, transparent 342px),
                   radial-gradient(circle 340px at -10% 50%, transparent 338px, var(--parquet) 339px, var(--parquet) 341px, transparent 342px);
}
.grain:after{content:"";position:fixed;inset:0;z-index:99;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E")}

/* --- spinning ball ornament --- */
.ball-orb{position:absolute;right:4%;top:60px;width:170px;height:170px;opacity:.16;pointer-events:none;
  animation:spin 40s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* --- team identity --- */
.medal.tbadge{background:color-mix(in srgb, var(--tc) 16%, var(--panel2));border-color:color-mix(in srgb, var(--tc) 55%, var(--line));
  color:var(--tc);font-size:11px;letter-spacing:.04em}
.medal.tlogo{background:#0E1119;border-color:color-mix(in srgb, var(--tc) 45%, var(--line));padding:4px}
.medal.tlogo img{width:100%;height:100%;object-fit:contain}
.rung .rlogo{width:20px;height:20px;object-fit:contain;flex:none;margin-right:8px;vertical-align:-4px}
.rung .nm{display:flex;align-items:center;min-width:0}
.rung .nm .pn{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
tr.detail td{border-left:3px solid var(--tc,var(--gold))}
.team-pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--data);font-weight:700;font-size:11px;
  color:var(--tc);background:color-mix(in srgb, var(--tc) 12%, transparent);border:1px solid color-mix(in srgb, var(--tc) 40%, transparent);
  border-radius:99px;padding:3px 9px;letter-spacing:.06em}

/* --- motion polish --- */
.rung{transition:transform .5s cubic-bezier(.2,.8,.2,1)}
@keyframes shimmer{0%,100%{box-shadow:0 0 0 0 rgba(232,181,74,0)}50%{box-shadow:0 0 18px 2px rgba(232,181,74,.35)}}
.rung.r1 .sc{animation:shimmer 3.5s ease-in-out infinite;border-radius:4px;padding:0 4px}
.rise{opacity:0;transform:translateY(14px);animation:rise .55s ease forwards}
@keyframes rise{to{opacity:1;transform:none}}
.rung.pop{opacity:0;animation:rise .45s ease forwards}
/* rank-1 medallion shimmer in the ranking table */
table.rank>tbody>tr:first-child .medal{animation:shimmer 3.5s ease-in-out infinite;border-radius:50%}

@media(max-width:980px){.court-3d{width:1150px;height:680px;top:42%}.ball-orb{display:none}}
@media (prefers-reduced-motion: reduce){
  .court-3d{animation:none}.dust i{animation:none;opacity:.3}.rung.r1 .sc{animation:none}
  .ball-orb{animation:none}.rise{animation:none;opacity:1;transform:none}}

/* --- About page: origin-story gallery --- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.gallery figure{margin:0;background:var(--panel);border:1px solid var(--line);border-radius:10px;
  overflow:hidden;display:flex;flex-direction:column;transition:transform .25s ease,border-color .25s ease}
.gallery figure:hover{transform:translateY(-4px);border-color:color-mix(in srgb, var(--gold) 45%, var(--line))}
.gallery .ph{aspect-ratio:4/3;overflow:hidden;background:#0E1119;border-bottom:2px solid var(--parquet)}
.gallery .ph img{width:100%;height:100%;object-fit:cover;display:block}
.gallery figcaption{padding:12px 14px;font-family:var(--data);font-size:13px;line-height:1.45;color:#C9C2B4}
.gallery figcaption b{color:var(--chalk)}
.gallery figure.tall{grid-row:span 2}
.gallery figure.tall .ph{aspect-ratio:3/4;flex:1}
.origin-quote{border-left:3px solid var(--gold);padding:6px 0 6px 18px;margin-top:26px;
  font-family:var(--data);font-size:19px;font-weight:600;color:var(--chalk)}
@media(max-width:860px){.gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.gallery{grid-template-columns:1fr}.gallery figure.tall{grid-row:auto}.gallery figure.tall .ph{aspect-ratio:4/3}}

/* --- NBA NOW ticker --- */
.ticker{position:relative;background:#0D1018;border-bottom:1px solid var(--line);
  overflow:hidden;height:38px;display:none}
.ticker.on{display:block}
.tk-label{position:absolute;left:0;top:0;bottom:0;z-index:2;display:flex;align-items:center;
  padding:0 14px;background:var(--gold);color:#0A0C12;font-family:var(--data);
  font-weight:700;font-size:12px;letter-spacing:.08em}
.tk-label:after{content:"";position:absolute;left:100%;top:0;bottom:0;width:36px;
  background:linear-gradient(90deg,#0D1018,transparent)}
.tk-track{display:inline-flex;align-items:center;height:38px;white-space:nowrap;
  animation:tk-scroll var(--tk-dur,45s) linear infinite;will-change:transform}
.ticker:hover .tk-track{animation-play-state:paused}
@keyframes tk-scroll{to{transform:translateX(-50%)}}
.tk-item{font-family:var(--data);font-size:13.5px;color:var(--chalk);margin-right:34px}
.tk-item i,.tk-item em{font-style:normal;color:var(--steel)}
.tk-item.live em{color:var(--gold)}
.tk-item.live:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;
  background:#E14848;margin-right:7px;animation:tk-pulse 1.6s infinite}
@keyframes tk-pulse{50%{opacity:.3}}
.tk-tag{display:inline-block;background:color-mix(in srgb,var(--gold) 18%,transparent);
  color:var(--gold);border:1px solid color-mix(in srgb,var(--gold) 40%,transparent);
  border-radius:4px;font-size:10px;font-weight:700;padding:1px 6px;margin-right:8px;
  letter-spacing:.08em}
.tk-item a{color:inherit;text-decoration:none}
.tk-item a:hover{color:var(--gold)}
@media (prefers-reduced-motion: reduce){
  .tk-track{animation:none}.ticker.on{overflow-x:auto}}

/* ===================== Global center alignment (site-wide) ===================== */
body{text-align:center}
nav.top .wrap{text-align:left}                 /* nav keeps logo-left / links-right (flex) */
.ticker{text-align:left}                        /* scrolling ticker stays in marquee flow */
p,p.lead,.sub{margin-left:auto;margin-right:auto}
/* center the button / chip / toolbar rows */
.modebar,.decchips,.poschips,.presets,.chips-demo,.curtain-toolbar,.legend,.chips-demo,
.list-title{justify-content:center}
/* center tables and their cell text */
table.rank,.tiers,.season-tbl{margin-left:auto;margin-right:auto}
table.rank th,table.rank td,.tiers th,.tiers td{text-align:center}
.season-tbl th:first-child,.season-tbl td:first-child{text-align:center}
