/* SMHTV viewer — token-driven, RTL-safe (logical properties only). */
/* Display face — self-hosted (no third-party calls), latin-only, ~48KB total.
   Headlines/section labels only; body stays system-ui (fast, zero-cost). */
@font-face{font-family:"Archivo";src:url("fonts/archivo-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Archivo";src:url("fonts/archivo-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Archivo";src:url("fonts/archivo-800.woff2") format("woff2");font-weight:800;font-style:normal;font-display:swap}
:root{
  --bg:#0d0d0f; --surface:#16161a; --line:#26262c; --text:#f4f4f6; --muted:#a0a0aa;
  --primary:var(--brand-primary,#111111);
  --accent:var(--brand-accent,#D9BF69);
  --font:var(--brand-font, Inter, system-ui, sans-serif);
  --display:"Archivo", var(--font);
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.5}
/* Ambient depth — a faint fixed sport backdrop so the dark never reads as flat. */
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:url("posters/stadium-hero.webp") center top/cover no-repeat;opacity:.05}
.site-header,main,.site-footer{position:relative;z-index:1}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.skip-link{position:absolute;inset-block-start:-3rem;inset-inline-start:.75rem;z-index:50;
  background:var(--accent);color:#111;padding:.5rem .9rem;border-radius:.4rem;font-weight:700;transition:inset-block-start .15s}
.skip-link:focus{inset-block-start:.75rem}

.site-header{position:sticky;inset-block-start:0;z-index:20;
  background:rgba(13,13,15,.9);backdrop-filter:blur(10px);border-block-end:1px solid var(--line)}
.header-inner{max-width:78rem;margin-inline:auto;display:flex;align-items:center;gap:1.25rem;
  padding-block:.85rem;padding-inline:1.25rem}
.site-header .brand{font-weight:800;font-size:1.15rem;letter-spacing:.02em;line-height:1.05;flex-shrink:0}
.site-header .brand img{height:30px;width:auto}
.event-mark{display:flex;align-items:center;gap:.45rem;color:var(--muted);min-width:0;flex-shrink:1}
.event-mark:hover{color:var(--text)}
.event-mark .sep{color:var(--line)}
.event-mark .mark-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:700}
.event-mark img{height:24px;width:auto}

.nav{display:flex;align-items:center;gap:1.4rem;margin-inline-end:auto}
.nav a{color:var(--muted);font-weight:600;font-size:.92rem;position:relative;padding-block:.35rem;white-space:nowrap}
.nav a:hover{color:var(--text)}
.nav a.active{color:var(--text)}
.nav a.active::after{content:"";position:absolute;inset-block-end:-.2rem;inset-inline:0;height:2px;background:var(--accent);border-radius:2px}
.live-dot{display:inline-block;width:.45rem;height:.45rem;border-radius:50%;background:#e5484d;margin-inline-start:.35rem;vertical-align:middle;animation:livepulse 1.6s ease-in-out infinite}
@keyframes livepulse{0%,100%{opacity:1}50%{opacity:.35}}

.header-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:2.1rem;height:2.1rem;border-radius:50%;color:var(--muted);transition:background .15s,color .15s}
.icon-btn:hover{background:var(--surface);color:var(--text)}

.lang-menu{position:relative}
.lang-menu summary{list-style:none;cursor:pointer;color:var(--muted);font-size:.8rem;font-weight:700;
  padding:.35rem .55rem;border:1px solid var(--line);border-radius:.45rem;display:flex;align-items:center;gap:.25rem}
.lang-menu summary::-webkit-details-marker{display:none}
.lang-menu summary::after{content:"▾";font-size:.7rem;opacity:.7}
.lang-menu summary:hover{color:var(--text);border-color:var(--muted)}
.lang-menu[open] summary{color:var(--text);border-color:var(--accent)}
.lang-list{position:absolute;inset-block-start:calc(100% + .4rem);inset-inline-end:0;min-width:9rem;
  background:var(--surface);border:1px solid var(--line);border-radius:.55rem;padding:.35rem;
  display:flex;flex-direction:column;box-shadow:0 12px 30px rgba(0,0,0,.45);z-index:30}
.lang-list a{padding:.45rem .6rem;border-radius:.35rem;color:var(--muted);font-size:.88rem}
.lang-list a:hover{background:var(--bg);color:var(--text)}
.lang-list a.active{color:var(--accent);font-weight:600}

.signin-link{color:var(--text);font-weight:600;font-size:.9rem;white-space:nowrap}
.signin-link:hover{color:var(--accent)}
.account-menu{position:relative}
.account-menu summary{list-style:none;cursor:pointer;color:var(--text);font-weight:600;font-size:.85rem;max-width:11rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.account-menu summary::-webkit-details-marker{display:none}
.account-menu summary::after{content:"▾";margin-inline-start:.3rem;color:var(--muted)}
.account-list{position:absolute;inset-inline-end:0;margin-block-start:.5rem;min-width:10rem;background:var(--surface);border:1px solid var(--line);border-radius:.6rem;padding:.4rem;display:flex;flex-direction:column;gap:.2rem;z-index:50;box-shadow:0 10px 30px rgba(0,0,0,.4)}
.account-list a,.account-list button{text-align:start;background:none;border:0;color:var(--text);font:inherit;padding:.5rem .6rem;border-radius:.4rem;cursor:pointer}
.account-list a:hover,.account-list button:hover{background:var(--bg);color:var(--accent)}
/* auth forms (signup / login / settings) */
.auth-form{max-width:26rem;margin-block:1rem 2rem;display:flex;flex-direction:column;gap:.9rem}
.auth-form p{margin:0;display:flex;flex-direction:column;gap:.3rem}
.auth-form label{font-size:.85rem;color:var(--muted)}
.auth-form input[type=email],.auth-form input[type=text],.auth-form input[type=password],.auth-form input[type=date],.auth-form textarea{background:var(--surface);color:var(--text);border:1px solid var(--line);border-radius:.5rem;padding:.55rem .7rem;font:inherit}
.auth-form textarea{min-height:4.5rem;resize:vertical}
.auth-form input:focus-visible,.auth-form textarea:focus-visible{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.auth-form input[type=checkbox]{margin-inline-end:.4rem}
.auth-form .helptext{font-size:.78rem;color:var(--muted)}
.auth-error{color:#e5484d;font-size:.88rem;display:block;text-align:center}
/* Prose paragraphs must NOT inherit the label-over-input flex column from `.auth-form p`,
   or their inline links stack one-per-line (the rushed look). Force normal block flow. */
.auth-form .auth-alt,.auth-form .auth-note{display:block;text-align:center;line-height:1.5;font-size:.85rem;color:var(--muted)}
.auth-alt{margin-block-start:.35rem}
.auth-note{margin-block-start:1rem;padding-block-start:1rem;border-block-start:1px solid var(--line)}
.auth-note a,.auth-alt a{color:var(--accent);font-weight:600}

/* Auth screens (login / signup): a centered card so the form reads as intentional. */
.auth-screen{display:flex;justify-content:center;padding-block:clamp(1.5rem,5vh,3.5rem) 4rem}
.auth-card{width:100%;max-width:27rem;background:var(--surface);border:1px solid var(--line);
  border-radius:1rem;padding:2rem 1.75rem 1.75rem;box-shadow:0 24px 60px -32px rgba(0,0,0,.75)}
.auth-title{font-family:var(--display);font-weight:800;letter-spacing:-.01em;line-height:1.05;
  font-size:clamp(1.5rem,3.5vw,2.1rem);text-align:center;margin:0 0 1.4rem}
.auth-card .auth-form{max-width:none;margin:0}
/* Card bg is --surface, so recess the inputs to --bg for contrast. */
.auth-card .auth-form input[type=email],.auth-card .auth-form input[type=text],
.auth-card .auth-form input[type=password],.auth-card .auth-form input[type=date]{background:var(--bg)}
/* Consent checkboxes sit inline beside their label, not stacked under it. */
.auth-card .auth-form p:has(input[type=checkbox]){flex-direction:row;align-items:center;gap:.5rem}
.auth-card .auth-form p:has(input[type=checkbox]) input[type=checkbox]{order:0;margin:0}
.auth-card .auth-form p:has(input[type=checkbox]) label{order:1;margin:0;color:var(--text)}
/* Flash messages (success/info banners above page content) */
.messages{display:flex;flex-direction:column;gap:.5rem;margin-block-end:1.25rem}
.msg{margin:0;padding:.6rem .9rem;border-radius:.5rem;background:var(--surface);border:1px solid var(--line);border-inline-start:3px solid var(--accent);font-size:.9rem}
.msg-success{border-inline-start-color:#3fb950}
.msg-warning{border-inline-start-color:#d29922}
.msg-error{border-inline-start-color:#e5484d}
/* Profile — social-handle chips + favourite-sport pills (reuse the chrome's surface/line/accent vocabulary) */
.social-links{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.5rem}
.social-links a{display:inline-block;padding:.4rem .8rem;background:var(--surface);border:1px solid var(--line);border-radius:999px;color:var(--text);font-size:.85rem;font-weight:600;transition:border-color .15s,color .15s}
.social-links a:hover{border-color:var(--accent);color:var(--accent)}
.fave-sports{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.5rem}
.fave-sports li{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;background:var(--surface);border:1px solid var(--line);border-radius:999px;font-size:.85rem}
.fave-sports .muted{color:var(--muted);font-size:.78rem;font-weight:600}
/* Profile identity hero — gives the fan a face + their fandom at a glance */
.profile-hero{display:flex;align-items:center;gap:1.25rem;margin-block:.5rem 2.25rem}
.monogram{flex-shrink:0;width:4.5rem;height:4.5rem;border-radius:50%;display:grid;place-items:center;font-size:1.9rem;font-weight:800;color:var(--accent);background:var(--surface);border:2px solid var(--accent)}
.profile-id h1{margin:0;font-size:1.9rem;line-height:1.1}
.profile-sub{margin:.35rem 0 0;color:var(--muted);font-size:.9rem}
.profile-stats{display:flex;flex-wrap:wrap;gap:1.25rem;margin-block-start:.65rem}
.profile-stats span{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.profile-stats strong{color:var(--text);font-size:1.05rem;font-weight:800;margin-inline-end:.2rem}
.profile-section{margin-block:1.75rem;max-width:42rem}
.profile-section .rail-h{margin-block:0 .8rem}

.nav-toggle{display:none}
.burger{display:none;flex-direction:column;gap:.28rem;cursor:pointer;padding:.35rem;margin-inline-start:auto}
.burger span{width:1.4rem;height:2px;background:var(--text);border-radius:2px;transition:transform .2s,opacity .2s}

main{max-width:72rem;margin-inline:auto;padding-inline:1.25rem;padding-block:1.5rem}

.hero{padding-block:2.5rem 1.5rem;border-block-end:1px solid var(--line);margin-block-end:1.5rem}
.hero .eyebrow{color:var(--accent);text-transform:uppercase;letter-spacing:.12em;
  font-size:.78rem;margin:0 0 .4rem}
.hero h1{font-size:clamp(1.8rem,4vw,3rem);margin:0;line-height:1.1}
.hero .dates{color:var(--muted);margin-block-start:.5rem}

/* marquee hero */
.marquee{position:relative;border-radius:.9rem;overflow:hidden;min-height:clamp(16rem,42vw,26rem);display:flex;align-items:flex-end;margin-block-end:2rem;background-size:cover;background-position:center;
  box-shadow:0 24px 70px -34px rgba(0,0,0,.9), 0 0 90px -26px var(--accent)}
.marquee-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.marquee::after{content:"";position:absolute;inset:0;background:linear-gradient(to top, rgba(8,8,10,.94), rgba(8,8,10,.4) 55%, transparent)}
.marquee-body{position:relative;z-index:1;padding:1.5rem 1.5rem 1.75rem;max-width:42rem}
.marquee-body h1{font-size:clamp(1.8rem,4.5vw,3.2rem);margin:.2rem 0 .4rem;line-height:1.05}
.marquee-meta{color:var(--text);margin:0 0 1rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}

.rail{margin-block-end:2.25rem}
.rail h2{font-size:1.15rem;margin:0 0 .9rem}
.cards{list-style:none;margin:0;padding:0;display:grid;gap:1rem;
  grid-template-columns:repeat(auto-fill,minmax(15rem,1fr))}
.card{background:var(--surface);border:1px solid var(--line);border-radius:.8rem;overflow:hidden;transition:transform .15s ease, border-color .15s ease}
.card:hover{transform:translateY(-3px);border-color:var(--accent)}
.card-link{display:block}
.poster{position:relative;display:block;aspect-ratio:16/9;background-size:cover;background-position:center}
.poster-img{width:100%;height:100%;object-fit:cover;display:block}
.poster .badge{position:absolute;inset-block-start:.5rem;inset-inline-start:.5rem;z-index:2}
.poster-play{position:absolute;inset:0;margin:auto;width:3rem;height:3rem;border-radius:50%;background:rgba(0,0,0,.5);opacity:0;transition:opacity .15s ease}
.poster-play::before{content:"";position:absolute;inset:0;margin:auto;width:0;height:0;border-style:solid;border-width:.5rem 0 .5rem .85rem;border-color:transparent transparent transparent #fff}
.card:hover .poster-play{opacity:1}
.card h3{margin:.6rem .85rem .2rem;font-size:1rem;line-height:1.25}
.card .meta,.card .time,.card .excerpt{color:var(--muted);font-size:.85rem;margin:.1rem .85rem}
.card .excerpt{margin-block:.3rem .85rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

.badge{display:inline-block;font-size:.68rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;padding:.18rem .5rem;border-radius:.4rem}
.badge-live{background:#e5484d;color:#fff}
.badge-upcoming{background:#2a2a32;color:var(--accent)}
.badge-replay{background:#2a2a32;color:var(--muted)}
.empty{color:var(--muted)}

.card-link,.row-link{color:inherit;display:block}
.hero-sm{padding-block:1.5rem .75rem}

/* schedule */
.filters{display:flex;gap:1rem;flex-wrap:wrap;margin-block-end:1.5rem}
.filters label{display:flex;flex-direction:column;gap:.3rem;font-size:.78rem;color:var(--muted)}
.filters select{background:var(--surface);color:var(--text);border:1px solid #33333a;border-radius:.4rem;padding:.4rem .55rem;font:inherit}
.day-nav{position:sticky;inset-block-start:0;z-index:5;display:flex;gap:.4rem;overflow-x:auto;
  padding-block:.6rem;margin-block-end:1.25rem;background:var(--bg);border-block-end:1px solid var(--line);
  scrollbar-width:thin}
.day-nav a{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:.1rem;
  padding:.35rem .6rem;border:1px solid var(--line);border-radius:.5rem;color:var(--muted);min-width:3.4rem;text-align:center}
.day-nav a:hover{border-color:var(--accent);color:var(--text)}
.day-nav a .d{font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap}
.day-nav a .dow{font-size:.66rem;text-transform:uppercase;letter-spacing:.04em}
.day{margin-block-end:1.75rem;scroll-margin-block-start:5rem}
.day-h{font-size:1rem;color:var(--accent);margin:0 0 .6rem;letter-spacing:.02em;display:flex;align-items:center;gap:.6rem}
.day-count{font-size:.72rem;font-weight:700;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:1rem;padding:.05rem .5rem}
.rows{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}
.row-link{display:grid;grid-template-columns:4rem 1fr auto auto;gap:.8rem;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:.6rem;padding:.7rem .9rem}
.row-link:hover{border-color:var(--accent)}
.row-time{color:var(--muted);font-variant-numeric:tabular-nums}
.row-venue{color:var(--muted);font-size:.85rem}
@media (max-width:38rem){.row-link{grid-template-columns:3.2rem 1fr auto}.row-venue{display:none}}

/* watch */
.watch{display:grid;gap:1.5rem;max-width:60rem}
.player{width:100%;aspect-ratio:16/9;background:#000;border-radius:.6rem;display:flex;align-items:center;justify-content:center;color:var(--muted);overflow:hidden}
mux-player.player{--media-object-fit:contain}
.player-gated,.player-empty{border:1px solid var(--line);flex-direction:column;gap:.8rem;text-align:center;padding:1rem}
.player-state{margin-block:.6rem 0;color:var(--muted)}
.picker{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-block-start:.9rem}
.picker-label{color:var(--muted);font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;margin-inline-end:.3rem}
.chip{background:var(--surface);color:var(--text);border:1px solid #33333a;border-radius:2rem;padding:.35rem .8rem;font:inherit;font-size:.85rem;cursor:pointer}
.chip-on{border-color:var(--accent);color:var(--accent)}
.btn{display:inline-block;background:var(--accent);color:#111;font-weight:700;padding:.5rem 1rem;border-radius:.5rem}
.back{margin-block-start:1.2rem}
.back a{color:var(--muted)}

/* HTMX loading indicator (G3-lite): visible only while a request is in flight */
.htmx-indicator{opacity:0;transition:opacity .15s;color:var(--accent);font-size:.8rem;align-self:center}
.htmx-request .htmx-indicator,.htmx-request.htmx-indicator{opacity:1}

/* ---- footer ---- */
.site-footer{border-block-start:1px solid var(--line);margin-block-start:4rem;color:var(--muted);
  background:rgba(8,8,10,.55)}
.footer-cols{max-width:78rem;margin-inline:auto;padding-block:2.75rem 2rem;padding-inline:1.25rem;
  display:grid;gap:2rem;grid-template-columns:1.6fr repeat(3, 1fr)}
.footer-brand .brand{font-weight:800;font-size:1.2rem;color:var(--text)}
.footer-brand .brand img{height:32px}
.footer-brand .tagline{margin-block:.75rem 0;max-width:24rem;font-size:.9rem;line-height:1.55}
.footer-col{display:flex;flex-direction:column;gap:.6rem}
.footer-col h3{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text);margin:0 0 .55rem;font-weight:700;position:relative;padding-block-end:.5rem}
.footer-col h3::after{content:"";position:absolute;inset-block-end:0;inset-inline-start:0;width:1.6rem;height:2px;background:var(--accent);border-radius:2px}
.footer-col a{color:var(--muted);font-size:.9rem;text-transform:capitalize;width:fit-content}
.footer-col a:hover{color:var(--accent)}
.site-footer .sponsors{max-width:78rem;margin-inline:auto;padding-block:1.5rem;padding-inline:1.25rem;
  border-block-start:1px solid var(--line);display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center}
.site-footer .sponsors-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.site-footer .sponsors img{height:30px;opacity:.75;filter:grayscale(1);transition:opacity .15s,filter .15s}
.site-footer .sponsors a:hover img{opacity:1;filter:none}
.site-footer .sponsor-name{font-weight:600;color:var(--text)}
.footer-bottom{max-width:78rem;margin-inline:auto;padding-block:1.25rem 1.75rem;padding-inline:1.25rem;
  border-block-start:1px solid var(--line);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer-bottom .footer-note{margin:0;max-width:42rem;font-size:.85rem}
.footer-bottom .copyright{font-size:.82rem;margin:0}

/* ---- responsive: collapse nav into a drawer ---- */
@media (max-width:48rem){
  .burger{display:flex}
  .event-mark{display:none}  /* keep the mobile header tight; identity carries via accent + hero */
  .nav{position:fixed;inset-block-start:0;inset-inline-end:0;block-size:100dvh;inline-size:min(78vw,18rem);
    flex-direction:column;align-items:flex-start;gap:.25rem;margin:0;padding:4.5rem 1.5rem 1.5rem;
    background:var(--surface);border-inline-start:1px solid var(--line);box-shadow:-12px 0 40px rgba(0,0,0,.5);
    transform:translateX(100%);transition:transform .25s ease;z-index:15;overflow-y:auto}
  html[dir=rtl] .nav{transform:translateX(-100%)}
  .nav a{font-size:1.05rem;padding-block:.6rem;inline-size:100%;border-block-end:1px solid var(--line)}
  .nav a.active::after{display:none}
  .nav-toggle:checked ~ .nav{transform:translateX(0)}
  .nav-toggle:checked ~ .burger span:nth-child(1){transform:translateY(.5rem) rotate(45deg)}
  .nav-toggle:checked ~ .burger span:nth-child(2){opacity:0}
  .nav-toggle:checked ~ .burger span:nth-child(3){transform:translateY(-.5rem) rotate(-45deg)}
  .footer-cols{grid-template-columns:1fr 1fr;gap:1.75rem}
  .footer-brand{grid-column:1 / -1}
}
@media (max-width:30rem){
  .footer-cols{grid-template-columns:1fr}
}

/* ---- prose (pages + article detail) ---- */
.prose{max-width:46rem;margin-inline:auto;line-height:1.7}
.prose h1{font-size:clamp(1.6rem,3.5vw,2.4rem)}
.prose img{border-radius:.6rem;margin-block:1rem;max-width:100%}
.article-detail .eyebrow{color:var(--accent);text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;margin:0 0 .3rem}
.article-hero{width:100%;aspect-ratio:16/9;object-fit:cover}
.article-card .article-img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:.5rem;margin-block-end:.6rem}
.article-card .excerpt{color:var(--muted);font-size:.9rem}
.rail-h{font-size:1.05rem;margin:1.5rem 0 .8rem;color:var(--accent)}

/* ---- search ---- */
.searchbar{display:flex;gap:.5rem;margin-block-end:1.5rem;max-width:36rem}
.searchbar input{flex:1;background:var(--surface);color:var(--text);border:1px solid #33333a;border-radius:.5rem;padding:.6rem .8rem;font:inherit}
.searchbar button{background:var(--accent);color:#111;border:0;border-radius:.5rem;padding:.6rem 1rem;font:inherit;font-weight:700;cursor:pointer}

/* ---- medal table ---- */
.medals{width:100%;border-collapse:collapse;margin-block-start:.5rem}
.medals th,.medals td{padding:.6rem .7rem;text-align:center;border-block-end:1px solid var(--line)}
.medals th{color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.medals th.nation,.medals td.nation{text-align:start}
.medals td.nation{font-weight:600}
.medals td.nation .code{color:var(--muted);font-weight:400;font-size:.8rem;margin-inline-start:.35rem}
.medals td.rank,.medals th.rank{color:var(--muted);width:2.5rem}
.medals td.total,.medals th.total{font-weight:700;color:var(--accent)}
.medals tbody tr:hover{background:var(--surface)}
.medals td.nation a{color:var(--text);text-decoration:none}
.medals td.nation a:hover{color:var(--accent)}

/* ---- nations + athletes ---- */
.nation-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(12.5rem,1fr));gap:1.1rem;margin-block-start:.5rem}
.nation-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.8rem 1rem;background:var(--surface);border:1px solid var(--line);border-radius:1rem;text-decoration:none;color:var(--text);text-align:center;transition:border-color .15s,transform .15s,box-shadow .15s}
.nation-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 18px 38px -22px rgba(0,0,0,.7)}
.nation-card .flag{font-size:4.25rem;line-height:1;filter:drop-shadow(0 4px 10px rgba(0,0,0,.4))}
.nation-card .name{font-weight:700;font-size:1.08rem;line-height:1.2}
.nation-card .code{color:var(--accent);font-size:.82rem;font-weight:700;letter-spacing:.1em}
.nation-card .tally{color:var(--muted);font-size:.84rem}
.nation-head,.athlete-head{display:flex;align-items:center;gap:1rem}
.nation-head .flag-lg{font-size:3.5rem;line-height:1}
.nation-head .code,.athlete-head .code{color:var(--muted);font-size:1rem;font-weight:400}
.tally-lg{color:var(--muted);margin-block-start:.3rem}
.athlete-photo{width:5rem;height:5rem;border-radius:50%;object-fit:cover}
.medal-list{list-style:none;padding:0;margin:.5rem 0;display:flex;flex-direction:column;gap:.5rem}
.medal-list li{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.medal-list .who{color:var(--muted);font-size:.9rem}
.badge-gold{background:#e9c463;color:#111}
.badge-silver{background:#cfd2d6;color:#111}
.badge-bronze{background:#cd9b6a;color:#111}
.athlete-list{list-style:none;padding:0;margin:.5rem 0;columns:2}
.athlete-list li{margin-block-end:.4rem}
.results{width:100%;border-collapse:collapse;margin-block-start:.5rem}
.results td{padding:.5rem .6rem;border-block-end:1px solid var(--line)}
.results td.rank{color:var(--muted);width:2.5rem;text-align:center}
.results td.mark{color:var(--muted);text-align:end}
.results .status{font-size:.75rem;text-transform:uppercase}
.tag{font-size:.7rem;background:var(--line);color:var(--muted);padding:.1rem .4rem;border-radius:.3rem;text-transform:uppercase;letter-spacing:.04em}

/* ---- bout-list (the Match layer: A-vs-B contest cards, broadcast scoreboard) ---- */
.bouts{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:.55rem}
/* bout-order group headers (Live now / Upcoming / Completed) on the watch page */
.bout-group-h{display:flex;align-items:center;gap:.5rem;margin:1.1rem 0 .2rem;font-family:var(--display);
  text-transform:uppercase;letter-spacing:.06em;font-size:.74rem;color:var(--muted)}
.bout-group-h .dot-live{width:.5rem;height:.5rem;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 70%,transparent);animation:pulse-live 1.8s ease-out infinite}
@keyframes pulse-live{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 60%,transparent)}70%{box-shadow:0 0 0 .5rem transparent}100%{box-shadow:0 0 0 0 transparent}}
@media (prefers-reduced-motion:reduce){.bout-group-h .dot-live{animation:none}}
.bout{background:var(--surface);border:1px solid var(--line);border-radius:.7rem;padding:.7rem .85rem;
  display:grid;grid-template-columns:1fr auto;grid-template-areas:"meta meta" "sides actions";
  column-gap:.85rem;row-gap:.5rem;align-items:center}
.bout-live{border-color:color-mix(in srgb,var(--accent) 32%,var(--line))}
.bout-meta{grid-area:meta;display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;min-width:0}
.bout-round{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
/* event label on cards shown outside their own session (athlete history, sport-code hub) */
.bout-event{font-family:var(--display);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:16rem}
.bout-event:hover{text-decoration:underline}
/* piste/court/lane label (the feed) on a bout — FencingTV labels every bout with its piste */
.bout-piste{font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);
  border:1px solid var(--line);border-radius:.35rem;padding:.05rem .35rem;white-space:nowrap}
.bout-time{font-size:.72rem;color:var(--muted);font-variant-numeric:tabular-nums}
.bout-sides{grid-area:sides;list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.32rem;min-width:0}
.bout-side{display:flex;align-items:center;gap:.6rem;min-width:0}
.bout-who{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}
.bout-who a{color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bout-flag{font-size:1.1rem;line-height:1;flex:0 0 auto}
.bout-score{font-variant-numeric:tabular-nums;font-weight:700;color:var(--muted);min-width:2.5ch;text-align:end}
.bout-side-win .bout-who a{color:var(--accent);font-weight:700}
.bout-side-win .bout-score{color:var(--text)}
.bout-actions{grid-area:actions;justify-self:end}
.bout-watch{display:inline-block;font-family:var(--display);text-transform:uppercase;letter-spacing:.05em;
  font-size:.78rem;font-weight:700;color:var(--accent);white-space:nowrap}
.bout-watch:hover{text-decoration:underline}
@media (max-width:480px){
  .bout{grid-template-columns:1fr;grid-template-areas:"meta" "sides" "actions"}
  .bout-actions{justify-self:start}
}

/* ---- draw: bracket (elimination) + pools/heats — the Tableau+Pools, generalised ---- */
.bracket{display:flex;gap:1.1rem;overflow-x:auto;padding-bottom:.6rem;scroll-snap-type:x proximity;
  -webkit-overflow-scrolling:touch}
.bracket-col{flex:0 0 clamp(15rem,80vw,19rem);display:flex;flex-direction:column;scroll-snap-align:start}
.bracket-round{font-family:var(--display);text-transform:uppercase;letter-spacing:.07em;font-size:.74rem;
  color:var(--accent);margin:0 0 .5rem;padding-bottom:.4rem;border-bottom:1px solid var(--line)}
/* bracket bouts space out so later (smaller) rounds read as "deeper" in the draw */
.bouts-bracket{flex:1;justify-content:space-around;gap:.7rem}

/* connected single-elim TREE — columns joined by connector lines (the real tableau).
   Per-column space-around means a round of N/2 aligns to the pair-midpoints of N; a vertical
   rail per round + horizontal feed-stubs join them (robust for any number of rounds). */
.bracket-tree{display:flex;overflow-x:auto;padding-bottom:1rem;align-items:stretch;-webkit-overflow-scrolling:touch}
.bt-round{position:relative;display:flex;flex-direction:column;flex:0 0 clamp(15rem,80vw,17.5rem);padding-inline:.9rem}
.bt-round .bracket-round{margin-bottom:.6rem}
.bt-slots{list-style:none;margin:0;padding:0;flex:1;display:flex;flex-direction:column;justify-content:space-around}
/* a bracket slot stacks (meta / sides / action) so the competitor names get the full width */
.bt-slots .bout{position:relative;margin:.4rem 0;grid-template-columns:1fr;
  grid-template-areas:"meta" "sides" "actions"}
.bt-slots .bout-actions{justify-self:start}
/* the round's vertical rail (between this column and the next) */
.bt-round:not(.bt-final)::after{content:"";position:absolute;inset-inline-end:.2rem;top:12%;bottom:12%;
  width:2px;background:var(--line)}
/* feed-stub out of each bout to the rail */
.bt-round:not(.bt-final) .bt-slots .bout::after{content:"";position:absolute;top:50%;inset-inline-start:100%;
  width:.7rem;height:2px;background:var(--line)}
/* feed-stub into each bout from the previous round's rail */
.bt-round:not(:first-child) .bt-slots .bout::before{content:"";position:absolute;top:50%;inset-inline-end:100%;
  width:.7rem;height:2px;background:var(--line)}
.bt-final{justify-content:center}
.bracket-medal-h{margin-top:1.4rem}
/* seed + bye inside a bracket slot */
.bout-seed{display:inline-flex;align-items:center;justify-content:center;min-width:1.35rem;height:1.25rem;
  font-size:.66rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--muted);background:var(--bg);
  border:1px solid var(--line);border-radius:.3rem;flex:0 0 auto}
.bye{color:var(--muted);font-style:italic}
@media (max-width:600px){.bt-round{flex-basis:80vw}}
.pool{margin-top:1.6rem}
.pool-h{font-family:var(--display);text-transform:uppercase;letter-spacing:.05em;font-size:.95rem;
  margin:0 0 .6rem;color:var(--text)}
.pool-standings{width:100%;border-collapse:collapse;margin-bottom:.7rem;font-size:.9rem;
  background:var(--surface);border:1px solid var(--line);border-radius:.6rem;overflow:hidden}
.pool-standings th,.pool-standings td{padding:.45rem .7rem;text-align:start;border-bottom:1px solid var(--line)}
.pool-standings thead th{font-family:var(--display);text-transform:uppercase;letter-spacing:.05em;
  font-size:.68rem;color:var(--muted);background:var(--bg)}
.pool-standings tr:last-child td{border-bottom:0}
.pool-standings .rank{width:2rem;color:var(--muted);font-variant-numeric:tabular-nums}
.pool-standings .num{text-align:end;font-variant-numeric:tabular-nums;width:3ch}
.pool-standings .num.win{color:var(--accent);font-weight:700}
.pool-standings .who a{color:var(--text)}
.pool-standings tr:first-child .who a{color:var(--accent);font-weight:700}

/* ---- heats / races (athletics, swimming) — ranked lane tables, Heats→Semis→Final ---- */
.race-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(18rem,1fr));gap:1rem}
.race{background:var(--surface);border:1px solid var(--line);border-radius:.7rem;padding:.7rem .85rem}
.race-h{font-family:var(--display);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;
  margin:0 0 .5rem;color:var(--text)}
.race-table{width:100%;border-collapse:collapse;font-size:.9rem}
.race-table th,.race-table td{padding:.4rem .5rem;text-align:start;border-bottom:1px solid var(--line)}
.race-table thead th{font-family:var(--display);text-transform:uppercase;letter-spacing:.05em;
  font-size:.66rem;color:var(--muted)}
.race-table tr:last-child td{border-bottom:0}
.race-table .lane{width:2.2rem;color:var(--muted);font-variant-numeric:tabular-nums;text-align:center}
.race-table .time{text-align:end;font-variant-numeric:tabular-nums;white-space:nowrap}
.race-table .pl{width:2.4rem;text-align:end;font-variant-numeric:tabular-nums;color:var(--muted)}
.race-table .who a{color:var(--text)}
.race-table tr.lead .who a,.race-table tr.lead .pl{color:var(--accent);font-weight:700}
.race-table .qual{margin-inline-start:.4rem;font-size:.66rem;font-weight:700;color:var(--accent);
  border:1px solid color-mix(in srgb,var(--accent) 35%,var(--line));border-radius:.3rem;padding:0 .3rem}

/* ---- nation pyramid (the country roll-up per sport code) ---- */
.nation-pyramid{display:grid;grid-template-columns:repeat(auto-fill,minmax(15rem,1fr));gap:.8rem}
.np-group{background:var(--surface);border:1px solid var(--line);border-radius:.7rem;padding:.8rem .9rem}
.np-h{display:flex;align-items:baseline;justify-content:space-between;gap:.6rem;margin:0 0 .55rem;
  font-size:.95rem;font-family:var(--display)}
.np-h>a{display:inline-flex;align-items:baseline;gap:.45rem;color:var(--text)}
.np-h>a:hover{color:var(--accent)}
.np-h .code{font-family:ui-monospace,monospace;font-size:.72rem;font-weight:700;color:var(--accent)}
.np-record{font-family:var(--display);font-size:.7rem;letter-spacing:.04em;color:var(--muted);
  white-space:nowrap;font-weight:600}
.np-athletes{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.3rem}
.np-athletes a{color:var(--muted)}
.np-athletes a:hover{color:var(--accent)}

/* ---- events index (the channel timeline) ---- */
.event-spotlight{position:relative;display:block;border-radius:.9rem;overflow:hidden;margin-block:.5rem 2rem;
  min-height:clamp(11rem,26vw,16rem);display:flex;align-items:flex-end;background-size:cover;background-position:center;
  background-color:var(--surface);border:1px solid var(--line)}
.event-spotlight::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(8,8,10,.92),rgba(8,8,10,.35) 60%,transparent)}
.event-spotlight-body{position:relative;z-index:1;padding:1.5rem}
.event-spotlight-body h2{margin:.4rem 0 .3rem;font-size:clamp(1.4rem,3.5vw,2.2rem);line-height:1.1}
.event-spotlight-body p{margin:0;color:var(--muted)}
.event-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(15rem,1fr));margin-block:.5rem 2rem}
.event-card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:.7rem;padding:1rem 1.1rem;transition:border-color .15s,transform .15s}
.event-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.event-card h3{margin:.5rem 0 .25rem;font-size:1.05rem;line-height:1.2}
.event-card .meta{color:var(--muted);font-size:.85rem;margin:0}
.archive-banner{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:center;justify-content:space-between;
  background:var(--surface);border:1px solid var(--line);border-radius:.6rem;padding:.7rem 1rem;margin-block-end:1.5rem;font-size:.92rem}
.archive-banner a{color:var(--accent);font-weight:600;white-space:nowrap}
.all-events-link{margin-block:1rem 0}
.all-events-link a{color:var(--accent);font-weight:600}

/* ===== /vl flare ===== */

/* Image-backed hero (sport hubs, section headers) — reuses the marquee overlay token. */
.hero-img{position:relative;overflow:hidden;border-radius:.9rem;padding:2.25rem 1.5rem;
  margin-block:.5rem 1.75rem;background-size:cover;background-position:center;min-height:9rem;
  display:flex;flex-direction:column;justify-content:flex-end}
.hero-img::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(8,8,10,.94),rgba(8,8,10,.45) 60%,rgba(8,8,10,.25))}
.hero-img>*{position:relative;z-index:1}
.hero-img.hero-sm{border-block-end:0}

/* Sponsor reel — an auto-scrolling partner band (pure CSS, pauses on hover).
   Edge fade is an alpha mask, not a colour gradient. */
.reel{margin:0;border-block:1px solid var(--line);padding-block:1.6rem;overflow:hidden;
  -webkit-mask-image:linear-gradient(to right,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(to right,transparent,#000 7%,#000 93%,transparent)}
.reel-h{text-align:center;color:var(--accent);font-size:.72rem;text-transform:uppercase;
  letter-spacing:.18em;font-weight:700;margin:0 0 1.15rem;opacity:.85}
.reel-track{display:flex;align-items:center;gap:3.5rem;width:max-content;
  animation:reel 38s linear infinite}
.reel:hover .reel-track{animation-play-state:paused}
.reel-track a,.reel-track span{flex:0 0 auto;color:var(--muted);font-weight:700;font-size:1.15rem;
  letter-spacing:.03em;white-space:nowrap;opacity:.78;transition:opacity .15s,color .15s}
.reel-track a:hover{opacity:1;color:var(--text)}
.reel-track img{height:34px;width:auto;filter:grayscale(1);opacity:.7;transition:filter .15s,opacity .15s}
.reel-track a:hover img{filter:none;opacity:1}
@keyframes reel{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.reel-track{animation:none;flex-wrap:wrap;justify-content:center;width:auto}}

/* ===== Premium broadcaster pass (/vl — luxury 80 / esports 20) ===== */
/* Wow from type + art direction + precise motion. No JS, no gradients-as-colour,
   no glass. Everything below is CSS-only and degrades on weak devices. */

/* Display typography — confident broadcast headlines, system-ui body unchanged. */
.eyebrow{font-family:var(--display);color:var(--accent);text-transform:uppercase;
  letter-spacing:.14em;font-size:.74rem;font-weight:700;margin:0 0 .55rem}
.site-header .brand,.footer-brand .brand{font-family:var(--display);font-weight:800;letter-spacing:.01em}
.hero h1{font-family:var(--display);font-weight:800;letter-spacing:-.01em;line-height:1;
  font-size:clamp(2.2rem,5vw,3.6rem)}
.card h3{font-family:var(--display);font-weight:700;letter-spacing:.005em}
.card .meta,.row-time,.marquee-meta{font-variant-numeric:tabular-nums}

/* Section labels — display caps with a short accent rule (reuses the footer accent-bar idiom). */
.rail h2{font-family:var(--display);text-transform:uppercase;letter-spacing:.05em;font-weight:700;
  font-size:1rem;color:var(--text);display:flex;align-items:center;gap:.65rem}
.rail h2::before{content:"";flex:0 0 auto;inline-size:1.6rem;block-size:3px;
  background:var(--accent);border-radius:2px}

/* Cinematic hero — filmic (drop the gold glow), taller, heavy uppercase display title. */
.marquee{min-height:clamp(20rem,52vw,32rem);border:1px solid var(--line);
  box-shadow:0 30px 80px -42px rgba(0,0,0,.95)}
.marquee::after{background:linear-gradient(to top,rgba(6,6,8,.96),rgba(6,6,8,.45) 58%,rgba(6,6,8,.12))}
.marquee-body{padding:1.75rem 1.75rem 2rem}
.marquee-body h1{font-family:var(--display);font-weight:800;text-transform:uppercase;
  letter-spacing:-.01em;line-height:.95;font-size:clamp(2.2rem,6vw,4.4rem);margin:.15rem 0 .55rem}

/* Consistent image grade — slightly graded by default, wakes to full on hover. */
.poster-img{filter:saturate(.88) contrast(1.05) brightness(.97);transition:filter .3s ease}
.card:hover .poster-img{filter:saturate(1.05) contrast(1.04) brightness(1.02)}
.marquee-img{filter:saturate(.92) contrast(1.05)}

/* Broadcast CTA. */
.btn{font-family:var(--display);text-transform:uppercase;letter-spacing:.06em;font-size:.92rem;
  padding:.62rem 1.3rem;transition:transform .15s ease,filter .15s ease}
.btn:hover{filter:brightness(1.08);transform:translateY(-1px)}

/* Brand focus ring everywhere (a11y + identity). */
a:focus-visible,button:focus-visible,summary:focus-visible,input:focus-visible{
  outline:2px solid var(--accent);outline-offset:2px;border-radius:.25rem}

/* Precise motion — all opt-out under reduced-motion, all degrade if unsupported. */
@media (prefers-reduced-motion:no-preference){
  /* Slow filmic zoom on the hero image. */
  .marquee-img{animation:vl-kenburns 26s ease-out both}
  /* Rails rise as they scroll into view — progressive enhancement, no JS. */
  @supports (animation-timeline:view()){
    .rail{animation:vl-rise linear both;animation-timeline:view();animation-range:entry 0% cover 16%}
  }
}
@keyframes vl-kenburns{from{transform:scale(1.07)}to{transform:scale(1)}}
@keyframes vl-rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* ===== Rollout: extend the broadcaster identity to every viewer surface ===== */
/* Every page title in the display face (covers watch + any title not in a .hero). */
main h1{font-family:var(--display);font-weight:800;letter-spacing:-.01em}
.prose h1,.prose h2,.event-spotlight-body h2{font-family:var(--display);letter-spacing:-.005em}
/* One section-label vocabulary site-wide: display caps + a short accent rule
   (matches the home rails; replaces the all-gold .rail-h text). */
.rail-h{font-family:var(--display);text-transform:uppercase;letter-spacing:.05em;font-weight:700;
  font-size:1rem;color:var(--text);display:flex;align-items:center;gap:.6rem;margin:1.75rem 0 .9rem}
.rail-h::before{content:"";flex:0 0 auto;inline-size:1.4rem;block-size:3px;background:var(--accent);border-radius:2px}
/* Schedule day headers + small labels in the display face for cohesion. */
.day-h{font-family:var(--display);text-transform:uppercase;letter-spacing:.03em}
.medals th,.picker-label,.tag,.sponsors-label,.reel-h,.footer-col h3{font-family:var(--display)}
/* Reveal interior rails/sections as they scroll in, same as home (progressive enhancement). */
@media (prefers-reduced-motion:no-preference){
  @supports (animation-timeline:view()){
    .event-grid,.nation-grid{animation:vl-rise linear both;animation-timeline:view();animation-range:entry 0% cover 16%}
  }
}

/* Bespoke medal icons (generated, transparent) — replace the 🥇🥈🥉 emoji. */
.medal-ico{height:1.15em;width:auto;vertical-align:-.2em;display:inline-block}
.medals th .medal-ico{height:1.5rem;vertical-align:middle}
.tally .medal-ico{height:1em;vertical-align:-.15em}

/* Email-verify banner + deletion-pending notice */
.verify-banner{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:center;justify-content:space-between;
  background:var(--surface);border:1px solid var(--line);border-inline-start:3px solid var(--accent);
  border-radius:.5rem;padding:.6rem .9rem;margin-block-end:1.25rem;font-size:.9rem}
.verify-banner a{color:var(--accent);font-weight:600;white-space:nowrap}
.delete-pending{border:1px solid #d29922;border-radius:.6rem;padding:1rem 1.1rem}
.delete-pending h2{margin-block-start:0}

/* Live: per-sport category shelves — swipeable rows, broadcast 'shelf' pattern. */
.shelf{margin-block-end:1.75rem}
.shelf-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;
  border-block-end:1px solid var(--line);padding-block-end:.5rem;margin-block-end:.9rem}
.shelf-title{font-family:var(--display);text-transform:uppercase;letter-spacing:.03em;font-weight:700;
  font-size:1.1rem;margin:0}
.shelf-more{color:var(--accent);font-weight:600;font-size:.82rem;white-space:nowrap;flex:0 0 auto}
.shelf-more:hover{text-decoration:underline}
.shelf-row{list-style:none;margin:0;padding:0 0 .6rem;display:flex;gap:1rem;overflow-x:auto;
  scroll-snap-type:x proximity;scrollbar-width:thin}
.shelf-row .card{flex:0 0 15rem;scroll-snap-align:start}
.card-time{color:var(--text);font-variant-numeric:tabular-nums}
/* the live matchup line on a /live hub card (the current contest, not just the sport) */
.card-bout{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;margin:.1rem .85rem .85rem;
  font-size:.82rem;color:var(--text)}
.card-bout .cb-side{display:inline-flex;align-items:center;gap:.3rem;min-width:0}
.card-bout .cb-side b{font-variant-numeric:tabular-nums;color:var(--accent)}
.card-bout .vs{color:var(--muted);font-size:.7rem;text-transform:uppercase}
@media (prefers-reduced-motion:no-preference){.shelf-row{scroll-behavior:smooth}}

/* Athletes — face-card grid (ODF) */
.athlete-filters{display:flex;gap:.6rem;flex-wrap:wrap;margin-block:1rem 1.5rem}
.athlete-filters input,.athlete-filters select{background:var(--surface);color:var(--text);border:1px solid var(--line);border-radius:.5rem;padding:.5rem .7rem;font:inherit}
.athlete-filters button{background:var(--accent);color:#111;border:0;border-radius:.5rem;padding:.5rem 1.1rem;font-weight:700;cursor:pointer}
.athlete-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}
.athlete-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.1rem .75rem;background:var(--surface);border:1px solid var(--line);border-radius:.9rem;text-align:center;transition:border-color .15s,transform .15s}
.athlete-card:hover{border-color:var(--accent);transform:translateY(-2px)}
/* world-ranking chip on the face card */
.athlete-card .rank-badge{position:absolute;top:.5rem;inset-inline-start:.5rem;font-family:ui-monospace,monospace;
  font-size:.68rem;font-weight:700;color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,var(--surface));
  border:1px solid color-mix(in srgb,var(--accent) 30%,var(--line));border-radius:.4rem;padding:.08rem .35rem;line-height:1.3}
/* athlete page ranking strip — the visible top of the pyramid (FencingTV 'FD #1 · pts') */
.athlete-rank{display:flex;flex-wrap:wrap;align-items:baseline;gap:.6rem;margin:0 0 .35rem}
.athlete-rank .rank-disc{font-family:var(--display);text-transform:uppercase;letter-spacing:.05em;font-size:.74rem;color:var(--accent)}
.athlete-rank .rank-disc:hover{text-decoration:underline}
.athlete-rank .rank-no{font-family:var(--display);font-size:1.5rem;font-weight:800;line-height:1;color:var(--text)}
.athlete-rank .rank-pts{font-variant-numeric:tabular-nums;color:var(--muted);font-size:.85rem}
.athlete-card .face{width:84px;height:84px;border-radius:50%;overflow:hidden;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--line))}
.athlete-card .face img{width:100%;height:100%;object-fit:cover}
.athlete-card .monogram{font-family:var(--display);font-weight:800;font-size:1.6rem;color:#111}
.athlete-card .a-name{font-weight:600;font-size:.92rem;line-height:1.2}
.athlete-card .a-nation{font-size:.8rem;color:var(--muted)}

/* Sports Codes — ODF Sport→Discipline→Event tree */
.code-tree{display:flex;flex-direction:column;gap:.5rem;max-width:60rem}
.code-sport,.code-disc{border:1px solid var(--line);border-radius:.6rem;background:var(--surface);overflow:hidden}
.code-disc{margin:.5rem .75rem;background:var(--bg)}
.code-tree summary{cursor:pointer;padding:.7rem 1rem;display:flex;align-items:center;gap:.7rem;font-weight:600}
.code-sport>summary{font-family:var(--display);text-transform:uppercase;letter-spacing:.02em}
.code-tree .code{display:inline-block;min-width:3.4rem;font-family:ui-monospace,monospace;font-size:.78rem;font-weight:700;color:var(--accent);background:var(--bg);border:1px solid var(--line);border-radius:.35rem;padding:.1rem .4rem;text-align:center}
.code-events{list-style:none;margin:0;padding:.3rem .9rem .8rem 1.4rem;display:flex;flex-direction:column;gap:.4rem}
.code-events li{display:flex;align-items:center;gap:.7rem;font-size:.9rem;color:var(--muted)}
.code-name{color:var(--text)}
/* index → hub: each code row is a link into its mini-site, keeping the tree's chrome */
.code-link{display:flex;align-items:center;gap:.7rem;color:inherit;flex:1;min-width:0}
.code-link:hover .code-name{color:var(--accent)}

/* ---- sport-code hub (each ODF code as a FencingTV-style competition hub) ---- */
.sportcode-head .crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;font-size:.8rem;color:var(--muted);margin-bottom:.5rem}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--accent)}
.crumbs .sep{opacity:.45}
.sportcode-head h1 .code{display:inline-block;font-family:ui-monospace,monospace;font-size:.6em;font-weight:700;color:var(--accent);background:var(--bg);border:1px solid var(--line);border-radius:.4rem;padding:.12rem .5rem;vertical-align:middle;margin-right:.5rem}
.code-children{list-style:none;padding:0;margin:1rem 0 0;display:flex;flex-wrap:wrap;gap:.5rem}
.code-children a{display:inline-flex;align-items:center;gap:.5rem;background:var(--surface);border:1px solid var(--line);border-radius:.5rem;padding:.35rem .65rem;color:var(--text);font-size:.85rem}
.code-children a:hover{border-color:var(--accent)}
.code-children .code{font-family:ui-monospace,monospace;font-size:.72rem;font-weight:700;color:var(--accent)}

/* Athlete page — bio strip (ODF) */
.athlete-bio{list-style:none;display:flex;flex-wrap:wrap;gap:1.6rem;margin:.8rem 0 0;padding:0}
.athlete-bio li{display:flex;flex-direction:column;gap:.1rem}
.athlete-bio .k{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.athlete-bio .v{font-weight:600}
.athlete-bio .v.code{font-family:ui-monospace,monospace;color:var(--accent)}
