/* ============================================================
   Ben Özdemir — Kart Racing · Sponsorship
   Custom theme. Loaded AFTER Bootstrap so it wins on shared
   selectors (body, .container, etc.). Bootstrap handles the
   responsive grid; this file owns the visual identity.
   ============================================================ */

:root{
  --asphalt:#0E0E12;
  --asphalt-2:#14141A;
  --carbon:#1A1A22;
  --line:rgba(255,255,255,.10);
  --line-soft:rgba(255,255,255,.06);
  --bone:#F4F3F0;
  --muted:#9A9AA6;
  --purple:#9B5CFF;       /* timing "fastest" */
  --purple-soft:rgba(155,92,255,.18);
  --purple-glow:rgba(155,92,255,.45);
  --kerb:#E5301B;         /* kerb / rumble-strip red */
  --max:1180px;
  --display:"Saira",system-ui,sans-serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--asphalt);color:var(--bone);
  font-family:var(--body);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---- container: cap Bootstrap's container to the design width ---- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}

/* ---- shared bits ---- */
.mono{font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em}
.eyebrow{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--muted);display:inline-flex;
  align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--purple)}

.kerb{
  height:10px;width:100%;
  background:repeating-linear-gradient(135deg,var(--kerb) 0 22px,#fff 22px 44px);
  opacity:.92;
}

section{position:relative}
.pad{padding:108px 0}
h2.title{
  font-family:var(--display);font-weight:900;line-height:.98;
  font-size:clamp(2.1rem,5.4vw,3.6rem);letter-spacing:-.02em;margin:.5rem 0 0;
  text-transform:uppercase;
}

/* ---- top bar ---- */
header.bar{
  position:fixed;inset:0 0 auto 0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  min-height:82px;padding:14px 28px;backdrop-filter:blur(10px);
  background:linear-gradient(var(--asphalt),rgba(14,14,18,.4));
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s;
}
header.bar.scrolled{border-bottom-color:var(--line);background:rgba(14,14,18,.86)}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:900;letter-spacing:.02em}
.brand .mark{
  width:34px;height:34px;border-radius:6px;display:block;flex:0 0 auto;
}
.site-logo{
  width:clamp(180px,18vw,280px);height:auto;max-height:58px;
  display:block;object-fit:contain;flex:0 0 auto;
}
.brand b{font-size:1.02rem}
.brand .tag{color:var(--muted);font-family:var(--mono);font-weight:500;font-size:.62rem;letter-spacing:.22em;text-transform:uppercase}
.btn{
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.14em;
  font-size:.74rem;font-weight:700;cursor:pointer;
  padding:12px 20px;border-radius:999px;border:1px solid var(--purple);
  color:var(--bone);background:var(--purple-soft);transition:.2s;white-space:nowrap;
  display:inline-block;
}
.btn:hover{background:var(--purple);color:#0c0710;box-shadow:0 0 30px var(--purple-glow)}
.btn.ghost{border-color:var(--line);background:transparent}
.btn.ghost:hover{border-color:var(--bone);box-shadow:none;background:transparent;color:var(--bone)}
@media(max-width:620px){.brand .tag{display:none}}

/* ---- announcement banner ---- */
.announce{
  position:fixed;top:82px;left:0;right:0;z-index:45;
  background:linear-gradient(90deg,var(--purple),#7033cc);
  color:#fff;
  transform:translateY(-100%);transition:transform .35s ease;
  pointer-events:none;
}
.announce.visible{transform:none;pointer-events:auto}
.announce-inner{
  display:flex;align-items:center;gap:16px;
  min-height:42px;padding:8px 28px;
}
.announce-text{
  flex:1;margin:0;
  font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;
  text-transform:uppercase;color:rgba(255,255,255,.92);
}
.announce-cta{
  font-family:var(--mono);font-size:.66rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:#fff;
  text-decoration:underline;text-underline-offset:3px;white-space:nowrap;
}
.announce-close{
  background:none;border:none;color:rgba(255,255,255,.65);
  cursor:pointer;font-size:1rem;line-height:1;padding:4px 6px;
  flex:0 0 auto;transition:color .15s;
}
.announce-close:hover{color:#fff}
body.has-banner .hero{padding-top:140px;transition:padding-top .35s ease}
@media(max-width:620px){
  .announce-text{font-size:.6rem;letter-spacing:.07em}
}

/* ---- hero ---- */
.hero{min-height:100svh;display:flex;align-items:center;padding:96px 0 clamp(72px,8vh,118px);overflow:hidden}
.hero::before{ /* speed lines */
  content:"";position:absolute;inset:0;z-index:0;opacity:.5;
  background:
    radial-gradient(120% 80% at 80% 10%,var(--purple-soft),transparent 55%),
    repeating-linear-gradient(115deg,transparent 0 38px,rgba(255,255,255,.018) 38px 39px);
  pointer-events:none;
}
.ghostnum{
  position:absolute;right:-4vw;bottom:-8vh;z-index:0;
  font-family:var(--display);font-weight:900;font-size:48vw;line-height:.7;
  color:transparent;-webkit-text-stroke:2px rgba(255,255,255,.05);
  user-select:none;pointer-events:none;
}
.hero .wrap{position:relative;z-index:2;width:100%}

/* start lights */
.gantry{display:flex;gap:10px;margin-bottom:30px}
.pod{width:34px;height:46px;border-radius:7px;background:#0a0a0e;
  border:1px solid var(--line);display:grid;grid-template-rows:1fr 1fr;gap:4px;padding:5px}
.pod i{border-radius:50%;background:#240606;display:block}
.pod.lit i{background:var(--kerb);box-shadow:0 0 12px rgba(229,48,27,.9)}
.pod.go i{background:#2fd071;box-shadow:0 0 14px rgba(47,208,113,.9)}
@media(max-width:520px){.pod{width:26px;height:36px}}

.h-kick{display:block;margin-bottom:18px}
h1{
  font-family:var(--display);font-weight:900;letter-spacing:-.025em;line-height:.9;
  margin:0;text-transform:uppercase;font-size:clamp(3.1rem,12vw,8.2rem);
}
h1 .lo{display:block;color:var(--muted);-webkit-text-stroke:0}
.lede{max-width:560px;margin:26px 0 6px;font-size:clamp(1.05rem,2.2vw,1.32rem);color:#d7d7dd}
.lede b{color:var(--bone);font-weight:700}
.hero .cta{display:flex;flex-wrap:wrap;gap:14px;margin:34px 0 clamp(44px,6vh,84px)}
.hero .btn{padding:15px 26px;font-size:.78rem}
.home-hero-video{
  position:absolute;left:min(54vw,760px);right:auto;top:52%;transform:translateY(-45%);
  width:min(40vw,560px);border:1px solid var(--line);border-radius:18px;
  overflow:hidden;background:#000;box-shadow:0 26px 80px rgba(0,0,0,.55);z-index:1;
}
.hero h1,.hero .lede,.hero .cta{position:relative;z-index:2}
@media(min-width:1041px){
  .hero h1,.hero .lede,.hero .cta{max-width:52%}
}
.home-hero-video video{display:block;width:100%;aspect-ratio:16/9;object-fit:cover;background:#000;object-position:center}
@media(max-width:1180px) and (min-width:1041px){
  .home-hero-video{left:55vw;width:min(38vw,500px)}
}
@media(max-width:1040px){
  .hero{padding-bottom:64px}
  .home-hero-video{position:relative;left:auto;right:auto;top:auto;transform:none;width:100%;max-width:720px;margin-top:34px}
  h1 .lo,.lede{max-width:720px}
  .hero h1,.hero .lede,.hero .cta{max-width:720px}
  .hero .cta{margin-bottom:36px}
}

/* reveal */
.rv{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .rv{opacity:1;transform:none;transition:none}
  .pod i{background:#240606}
  html{scroll-behavior:auto}
}

/* ---- profile strip ---- */
.strip{border-block:1px solid var(--line);background:var(--asphalt-2)}
.cell{padding:30px 26px;border-left:1px solid var(--line-soft);height:100%}
.cell .k{font-family:var(--mono);font-size:.64rem;letter-spacing:.2em;color:var(--muted);text-transform:uppercase}
.cell .v{font-family:var(--display);font-weight:800;font-size:1.5rem;margin-top:8px;line-height:1.05}
/* borders tuned for the Bootstrap grid (2-up on mobile, 4-up from md) */
.strip [class*="col-"]:first-child .cell{border-left:0}
@media(max-width:767.98px){
  .strip [class*="col-"]:nth-child(odd) .cell{border-left:0}
  .strip [class*="col-"]:nth-child(n+3) .cell{border-top:1px solid var(--line-soft)}
}
@media(min-width:768px){
  .strip [class*="col-"]:first-child .cell{border-left:0}
}

/* ---- thesis ---- */
.thesis h2{font-family:var(--display);font-weight:900;text-transform:uppercase;line-height:.96;
  letter-spacing:-.02em;font-size:clamp(2.3rem,6vw,4.4rem);margin:14px 0 0}
.thesis h2 em{font-style:normal;color:var(--purple)}
.thesis p{color:#cfcfd6;font-size:1.08rem}
.fire{
  font-family:var(--mono);font-size:.8rem;letter-spacing:.1em;color:var(--kerb);
  border:1px solid rgba(229,48,27,.45);border-radius:8px;padding:14px 16px;
  text-transform:uppercase;background:rgba(229,48,27,.06);
}

/* ---- results / timing board ---- */
.board{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-top:42px}
.row-t{display:grid;grid-template-columns:96px 1fr auto;gap:18px;align-items:center;
  padding:20px 22px;border-top:1px solid var(--line-soft);background:var(--carbon)}
.row-t:first-child{border-top:0}
.row-t:hover{background:#20202a}
.row-t .yr{font-family:var(--mono);font-size:.78rem;letter-spacing:.12em;color:var(--muted)}
.row-t .ev{font-family:var(--display);font-weight:700;font-size:1.12rem;line-height:1.2}
.row-t .ev small{display:block;font-family:var(--body);font-weight:400;font-size:.86rem;color:var(--muted);letter-spacing:0;text-transform:none;margin-top:3px}
.pos{font-family:var(--display);font-weight:900;font-size:1.05rem;padding:6px 12px;border-radius:7px;white-space:nowrap;
  background:rgba(255,255,255,.06);border:1px solid var(--line)}
.pos.p3{color:#e8a13c;border-color:rgba(232,161,60,.5);background:rgba(232,161,60,.08)}
.pos.p4{color:#cdd2da}
.pos.win{color:#2fd071;border-color:rgba(47,208,113,.5);background:rgba(47,208,113,.08)}
.pos.fast{ /* the purple "fastest" treatment */
  color:#0c0710;background:var(--purple);border-color:var(--purple);
  box-shadow:0 0 24px var(--purple-glow);
}
@media(max-width:600px){
  .row-t{grid-template-columns:1fr auto;gap:6px 14px}
  .row-t .yr{grid-column:1/-1}
}
.legend{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;color:var(--muted);
  text-transform:uppercase;margin-top:18px;display:flex;align-items:center;gap:8px}
.legend b{color:var(--purple)}
.result-feature{
  margin-top:30px;padding:26px 28px;border:1px solid var(--line);
  border-radius:14px;background:linear-gradient(135deg,rgba(155,92,255,.14),rgba(255,255,255,.035));
}
.result-feature h3{
  font-family:var(--display);font-size:clamp(1.25rem,2.6vw,1.8rem);
  line-height:1.12;text-transform:uppercase;margin:16px 0 10px;color:var(--bone);
}
.result-feature p{color:#d4d4dc;margin:0;font-size:1.04rem;max-width:78ch}

/* ---- gallery / onboard footage ---- */
.gallery{background:var(--asphalt-2);border-block:1px solid var(--line)}
.vid{
  position:relative;display:block;width:100%;border:1px solid var(--line);
  border-radius:12px;overflow:hidden;background:var(--carbon);
  aspect-ratio:16/9;cursor:pointer;transition:.22s;padding:0;
}
.vid:hover{border-color:var(--purple);box-shadow:0 16px 40px rgba(0,0,0,.4);transform:translateY(-4px)}
.vid img{width:100%;height:100%;object-fit:cover;opacity:.82;transition:opacity .22s}
.vid:hover img{opacity:1}
.vid iframe{width:100%;height:100%;border:0;display:block}
.vid .play{
  position:absolute;inset:0;display:grid;place-items:center;pointer-events:none;
}
.vid .play svg{width:60px;height:60px;filter:drop-shadow(0 4px 18px rgba(0,0,0,.6));transition:transform .2s}
.vid:hover .play svg{transform:scale(1.08)}
.vid figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:30px 16px 14px;pointer-events:none;
  background:linear-gradient(transparent,rgba(10,10,14,.92));
}
.vid .v-title{font-family:var(--display);font-weight:700;font-size:1.02rem;text-transform:uppercase;letter-spacing:.01em;line-height:1.15}
.vid .v-meta{font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;color:var(--muted);text-transform:uppercase;margin-top:6px}
.vid:focus-visible{outline:2px solid var(--purple);outline-offset:3px}

/* self-hosted video cards */
.vid--video .vid-media{width:100%;height:100%;object-fit:cover;display:block;background:#000;opacity:.85;transition:opacity .22s}
.vid--video:hover .vid-media{opacity:1}
.vid--video.playing .vid-media{opacity:1;object-fit:contain;background:#000}
.vid-play{
  position:absolute;inset:0;width:100%;height:100%;border:0;background:transparent;
  cursor:pointer;display:grid;place-items:center;padding:0;
}
.vid-play .play svg{width:60px;height:60px;filter:drop-shadow(0 4px 18px rgba(0,0,0,.6));transition:transform .2s}
.vid--video:hover .vid-play .play svg{transform:scale(1.08)}
.vid-play:focus-visible{outline:2px solid var(--purple);outline-offset:3px}
.vid.playing .vid-play,
.vid.playing figcaption{display:none}

.vid--bad{cursor:default;display:grid;place-items:center;text-align:center;background:var(--carbon)}
.vid--bad:hover{transform:none;border-color:var(--line);box-shadow:none}
.vid--bad .play{display:none}
.bad-note{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--kerb);line-height:1.7;padding:20px;
}
.bad-note span{color:var(--muted);font-size:.62rem;letter-spacing:.1em}
.gallery .empty{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;color:var(--muted);
  text-transform:uppercase;border:1px dashed var(--line);border-radius:12px;
  padding:40px;text-align:center;margin-top:42px;
}

/* ---- off track ---- */
.off{background:var(--asphalt-2);border-block:1px solid var(--line)}
.off .badge{font-family:var(--display);font-weight:900;font-size:3rem;line-height:1;
  text-transform:uppercase;color:var(--purple);writing-mode:vertical-rl;transform:rotate(180deg);letter-spacing:.04em}
.off p{font-size:1.1rem;color:#d4d4db;margin:14px 0 0;max-width:62ch}
.off-copy{font-size:1.1rem;color:#d4d4db;max-width:72ch}
.off-copy p{max-width:72ch}
.off-copy ul{margin:16px 0 20px;padding-left:1.25rem;color:#d4d4db;columns:2;column-gap:38px}
.off-copy li{break-inside:avoid;margin:0 0 8px}
@media(max-width:680px){.off .badge{writing-mode:horizontal-tb;transform:none;font-size:1rem;letter-spacing:.24em;font-family:var(--mono)}}

/* ---- sponsor ---- */
.sponsor{background:
    radial-gradient(80% 60% at 50% 0%,var(--purple-soft),transparent 60%),var(--asphalt)}
.card{background:var(--carbon);border:1px solid var(--line);border-radius:12px;padding:24px;
  transition:.22s;position:relative;height:100%;color:var(--bone)}
.card:hover{transform:translateY(-4px);border-color:var(--purple);box-shadow:0 16px 40px rgba(0,0,0,.4)}
.card .tick{color:var(--purple);font-family:var(--mono);font-weight:700;font-size:.9rem}
.card h3{color:var(--bone);font-family:var(--display);font-weight:700;font-size:1.06rem;line-height:1.25;margin:14px 0 0;text-transform:uppercase;letter-spacing:.01em}
.sponsor-tax{
  margin-top:28px;padding:26px 28px;border-radius:14px;border:1px solid rgba(229,48,27,.42);
  background:rgba(229,48,27,.075);max-width:880px;
}
.sponsor-tax h3{
  font-family:var(--display);font-size:1.28rem;line-height:1.1;text-transform:uppercase;margin:0;color:var(--bone);
}
.sponsor-tax p{margin:12px 0 0;color:#d4d4dc;font-size:1.02rem;max-width:82ch}
.partners.pad{padding-top:64px;padding-bottom:84px}
.partners h2.title{font-size:clamp(1.65rem,4.2vw,2.8rem);margin-top:.35rem}
.media-intro{color:#cfcfd6;margin:12px auto 0;font-size:1rem;max-width:58ch;text-align:center;line-height:1.45}
.media-channel-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin:18px auto 0;max-width:860px}
.media-channel{
  border:1px solid var(--line);border-radius:999px;padding:8px 11px;background:rgba(255,255,255,.05);
  font-family:var(--mono);font-size:.58rem;letter-spacing:.11em;text-transform:uppercase;color:var(--bone);
  min-height:38px;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.18;
}
@media(max-width:900px){.media-channel-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.media-channel-grid{grid-template-columns:1fr}.off-copy ul{columns:1}}

/* ---- news section ---- */
.news-section{background:var(--asphalt-2)}
.news-card{
  background:var(--carbon);border:1px solid var(--line);border-radius:12px;
  padding:28px;height:100%;display:flex;flex-direction:column;gap:14px;
  transition:.22s;
}
.news-card:hover{border-color:var(--purple);transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.4)}
.news-card-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.news-cat{
  font-family:var(--mono);font-size:.58rem;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--purple);
}
.news-date{
  font-family:var(--mono);font-size:.58rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted);
}
.news-card-title{
  font-family:var(--display);font-weight:800;font-size:1.1rem;line-height:1.2;
  text-transform:uppercase;letter-spacing:.01em;color:var(--bone);margin:0;
}
.news-card-body{color:#cfcfd6;font-size:.98rem;line-height:1.6;margin:0;flex:1}
.news-card-link{
  display:inline-block;margin-top:4px;
  font-family:var(--mono);font-size:.66rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--purple);
  text-decoration:underline;text-underline-offset:3px;
}
.news-card-link:hover{color:#fff}

/* ---- current sponsors ---- */
.current-sponsors{background:var(--asphalt)}
.sponsor-showcase{display:flex;justify-content:center;margin-top:48px}
.sponsor-card-feature{
  display:flex;flex-direction:column;align-items:center;gap:20px;
  background:var(--carbon);border:1px solid var(--purple);border-radius:16px;
  padding:36px 40px;max-width:340px;width:100%;
  box-shadow:0 0 40px rgba(106,0,244,.18);
  position:relative;
}
.sponsor-founding-badge{
  display:inline-block;padding:5px 14px;border-radius:999px;
  background:linear-gradient(90deg,#c8960a,#f0c030);
  color:#0a0a0f;font-family:var(--mono);font-size:.58rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;text-align: center;
}
.sponsor-logo-img{
  max-height:200px;width:auto;max-width:100%;object-fit:contain;border-radius:6px;
}
.sponsor-partner-name{
  font-family:var(--display);font-weight:800;font-size:1.3rem;
  color:var(--bone);text-transform:uppercase;letter-spacing:.04em;margin:0;
}
.sponsor-partner-tagline{
  font-family:var(--mono);font-size:.72rem;color:#9898a6;
  letter-spacing:.1em;text-transform:uppercase;margin:0;text-align:center;
}

/* ---- contact ---- */
.contact{background:var(--asphalt-2);border-top:1px solid var(--line)}
.clist{margin-top:30px;display:flex;flex-direction:column;gap:2px}
.cl{display:flex;align-items:baseline;justify-content:space-between;gap:20px;
  padding:18px 0;border-bottom:1px solid var(--line-soft)}
.cl .lab{font-family:var(--mono);font-size:.66rem;letter-spacing:.2em;color:var(--muted);text-transform:uppercase}
.cl .val{font-family:var(--display);font-weight:700;font-size:1.16rem;transition:color .2s}
a.cl:hover .val{color:var(--purple)}
.pill{display:inline-block;font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--kerb);border:1px solid rgba(229,48,27,.4);
  border-radius:999px;padding:7px 14px;margin-bottom:8px}
.contact .lede{color:#cfcfd6;margin-top:18px}

footer{padding:40px 0;text-align:center}
footer .mono{font-size:.66rem;color:var(--muted)}
footer a:hover{color:var(--purple)}

/* ============================================================
   Header actions: nav link + language toggle  (added)
   ============================================================ */
.bar-actions{display:flex;align-items:center;gap:14px}
.navlink{
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.14em;
  font-size:.74rem;font-weight:700;color:var(--muted);transition:color .2s;
}
.navlink:hover{color:var(--bone)}
.lang{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden}
.lang button{
  font-family:var(--mono);font-weight:700;font-size:.68rem;letter-spacing:.1em;
  background:transparent;color:var(--muted);border:0;cursor:pointer;
  padding:7px 11px;transition:.18s;
}
.lang button:hover{color:var(--bone)}
.lang button.active{background:var(--purple);color:#0c0710}
.lang button:focus-visible{outline:2px solid var(--purple);outline-offset:2px}
@media(max-width:720px){
  header.bar{min-height:74px;padding:12px 16px}
  .site-logo{width:150px;max-height:46px}
}
@media(max-width:560px){
  .bar-actions{gap:8px}
  .navlink{display:none}
  .bar-actions .btn{padding:10px 12px;font-size:.62rem;letter-spacing:.08em}
  .lang button{padding:7px 9px;font-size:.62rem}
}
@media(max-width:410px){
  .site-logo{width:128px}
  .bar-actions .btn{display:none}
}

/* ============================================================
   Gallery page  (added)
   ============================================================ */
.gp-hero{padding-top:120px}
.gp-title{
  font-family:var(--display);font-weight:900;text-transform:uppercase;
  letter-spacing:-.02em;line-height:.98;margin:.4rem 0 0;
  font-size:clamp(2.4rem,7vw,4.6rem);
}
.hero-video{margin-top:36px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#000}
.hero-video video{display:block;width:100%;height:auto;aspect-ratio:16/9;object-fit:cover;background:#000}

/* image grid */
.shot{
  display:block;width:100%;padding:0;border:1px solid var(--line);border-radius:10px;
  overflow:hidden;background:var(--carbon);cursor:pointer;aspect-ratio:3/2;transition:.2s;
}
.shot img{width:100%;height:100%;object-fit:cover;opacity:.9;transition:.25s}
.shot:hover{border-color:var(--purple);transform:translateY(-3px);box-shadow:0 14px 34px rgba(0,0,0,.4)}
.shot:hover img{opacity:1;transform:scale(1.04)}
.shot:focus-visible{outline:2px solid var(--purple);outline-offset:3px}

/* lightbox */
.lightbox{
  position:fixed;inset:0;z-index:200;display:none;place-items:center;
  background:rgba(8,8,11,.94);backdrop-filter:blur(6px);padding:5vmin;
}
.lightbox.open{display:grid}
.lightbox .lb-img{max-width:92vw;max-height:84vh;border-radius:8px;
  box-shadow:0 24px 80px rgba(0,0,0,.6);object-fit:contain}
.lightbox .lb-cap{position:absolute;bottom:18px;left:0;right:0;text-align:center;
  font-size:.7rem;color:var(--muted)}
.lb-close,.lb-nav{
  position:absolute;background:rgba(20,20,26,.7);color:var(--bone);
  border:1px solid var(--line);cursor:pointer;border-radius:999px;
  display:grid;place-items:center;transition:.18s;line-height:1;
}
.lb-close{top:18px;right:18px;width:46px;height:46px;font-size:1.7rem}
.lb-nav{top:50%;transform:translateY(-50%);width:54px;height:54px;font-size:2rem;font-family:var(--display)}
.lb-prev{left:max(18px,2vw)}
.lb-next{right:max(18px,2vw)}
.lb-close:hover,.lb-nav:hover{background:var(--purple);color:#0c0710;border-color:var(--purple)}
.lb-close:focus-visible,.lb-nav:focus-visible{outline:2px solid var(--purple);outline-offset:2px}
@media(max-width:560px){
  .lb-nav{width:44px;height:44px;font-size:1.6rem}
  .lightbox .lb-img{max-height:76vh}
}

/* ============================================================
   Media partner logo strip, footer  (added)
   ============================================================ */


/* partner logo marquee */
.logo-carousel-group{margin-top:24px}
.logo-carousel-group + .logo-carousel-group{margin-top:20px}
.logo-carousel-title{
  font-family:var(--mono);font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);
  text-align:center;margin:0 0 14px;font-weight:800;
}
@media(max-width:560px){
  .partners.pad{padding-top:54px;padding-bottom:72px}
  .logo-carousel-group{margin-top:20px}
  .logo-carousel-group + .logo-carousel-group{margin-top:18px}
  .logo-carousel-title{font-size:.68rem;letter-spacing:.18em;padding:0 18px}
}
.logo-strip{
  overflow:hidden;position:relative;padding:10px 0 14px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
}
.logo-track{display:flex;width:max-content;gap:16px;align-items:center;animation:logoscroll 42s linear infinite}
.logo-strip:hover .logo-track{animation-play-state:paused}
.logo-cell{
  flex:0 0 auto;height:82px;width:188px;display:flex;align-items:center;justify-content:center;padding:14px 16px;
  background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:10px;overflow:hidden;
}
.logo-cell img{display:block;max-height:100%;max-width:100%;object-fit:contain;object-position:center;margin:auto}
@keyframes logoscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){
  .logo-track{animation:none;flex-wrap:wrap;justify-content:center;width:auto}
  .logo-strip{-webkit-mask-image:none;mask-image:none}
}

/* footer */
.site-footer{background:var(--asphalt-2);border-top:1px solid var(--line);padding:72px 0 28px;text-align:left}
.site-footer > .wrap{max-width:none;width:100%;padding-left:28px;padding-right:28px}
.footer-grid{display:grid;grid-template-columns:minmax(220px,1.25fr) minmax(210px,1.05fr) minmax(150px,.75fr) minmax(160px,.75fr) minmax(150px,.75fr);gap:clamp(24px,4vw,72px);align-items:start}
.footer-col{min-width:0;text-align:left}
.footer-logo-col{display:flex;align-items:flex-start;justify-content:flex-start}
.foot-brand{display:inline-flex;align-items:center;justify-content:flex-start;gap:12px;font-family:var(--display);font-weight:900;margin:0}
.foot-brand .site-logo{width:min(300px,78vw);max-height:76px}
.foot-brand b{font-size:1.02rem}
.site-footer h4{font-family:var(--display);font-weight:800;text-transform:uppercase;letter-spacing:.05em;font-size:.86rem;margin:0 0 12px;color:var(--bone)}
.site-footer p{color:var(--muted);font-size:.95rem;margin:0;max-width:30ch;line-height:1.55}
.foot-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.foot-links a,.site-footer p a{color:var(--muted);font-size:.95rem;transition:color .2s}
.foot-links a:hover,.site-footer p a:hover{color:var(--purple)}
.foot-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;margin-top:50px;padding-top:22px;border-top:1px solid var(--line-soft);color:var(--muted);font-size:.62rem}
@media(max-width:1100px){
  .footer-grid{grid-template-columns:1.2fr 1fr 1fr;gap:34px}
  .footer-logo-col{grid-column:1 / -1}
}
@media(max-width:760px){
  .site-footer{text-align:left}
  .site-footer > .wrap{padding-left:16px;padding-right:16px}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .foot-brand .site-logo{width:min(260px,76vw)}
  .foot-bottom{flex-direction:column;align-items:flex-start;margin-top:38px}
}


/* ============================================================
   Legal pages (imprint / privacy / cookies)
   ============================================================ */
.legal{padding:120px 0 96px}
.legal .wrap{max-width:880px}
.legal .lead{color:#cfcfd6;font-size:1.08rem;max-width:64ch;margin:18px 0 0}
.legal-body{margin-top:46px;color:#d4d4dc;font-size:1rem;line-height:1.72}
.legal-body h2{
  font-family:var(--display);font-weight:800;text-transform:uppercase;
  letter-spacing:.02em;font-size:1.18rem;line-height:1.1;
  color:var(--bone);margin:42px 0 14px;padding-top:22px;
  border-top:1px solid var(--line-soft);
}
.legal-body h2:first-child{border-top:0;padding-top:0;margin-top:0}
.legal-body h3{
  font-family:var(--display);font-weight:700;font-size:1.02rem;
  color:var(--bone);margin:26px 0 8px;
}
.legal-body p{margin:0 0 14px}
.legal-body ul{margin:0 0 16px;padding-left:20px}
.legal-body li{margin:0 0 7px}
.legal-body a{color:var(--purple);word-break:break-word}
.legal-body a:hover{text-decoration:underline}
.legal-body strong{color:var(--bone);font-weight:700}
.legal-body .dl{
  display:grid;grid-template-columns:max-content 1fr;gap:6px 22px;
  margin:0 0 18px;font-size:.98rem;
}
.legal-body .dl dt{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);padding-top:3px}
.legal-body .dl dd{margin:0;color:var(--bone)}
.legal-table{width:100%;border-collapse:collapse;margin:8px 0 18px;font-size:.92rem}
.legal-table th,.legal-table td{
  text-align:left;padding:9px 12px;border:1px solid var(--line);vertical-align:top;
}
.legal-table th{
  font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);background:var(--asphalt-2);font-weight:500;white-space:nowrap;
}
.legal-table td:first-child{font-family:var(--mono);color:var(--bone);white-space:nowrap}
.legal .cookie-block{
  border:1px solid var(--line);border-radius:14px;padding:22px 24px;margin:16px 0;
  background:var(--asphalt-2);
}
.legal .cookie-block h3{margin-top:0}
.legal .updated{color:var(--muted);font-size:.85rem;font-family:var(--mono);
  letter-spacing:.08em;margin-top:40px}
@media (max-width:560px){
  .legal-body .dl{grid-template-columns:1fr;gap:2px}
  .legal-body .dl dd{margin-bottom:10px}
  .legal-table{display:block;overflow-x:auto;white-space:nowrap}
}

/* ---- 404 page ---- */
.not-found{
  min-height:70svh;
  display:flex;
  align-items:center;
  padding:150px 0 90px;
  background:
    radial-gradient(90% 80% at 80% 18%, var(--purple-soft), transparent 58%),
    repeating-linear-gradient(115deg, transparent 0 38px, rgba(255,255,255,.018) 38px 39px);
}
.not-found p{
  max-width:680px;
  margin:24px 0 0;
  color:#d4d4dc;
  font-size:1.1rem;
}
.not-found .cta{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:34px;
}

/* ============================================================
   Cookie consent banner
   ============================================================ */
.foot-link-button{
  appearance:none;
  border:0;
  background:transparent;
  color:inherit;
  padding:0;
  font:inherit;
  text-align:left;
  cursor:pointer;
}
.foot-link-button:hover,
.foot-link-button:focus-visible{
  text-decoration:underline;
}
.cookie-consent{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:9999;
  padding:16px;
  pointer-events:none;
}
.cookie-consent__panel{
  width:min(1120px, 100%);
  margin:0 auto;
  padding:18px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:22px;
  background:rgba(14,14,18,.96);
  box-shadow:0 24px 70px rgba(0,0,0,.42);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  pointer-events:auto;
  backdrop-filter:blur(16px);
}
.cookie-consent__copy{
  max-width:760px;
}
.cookie-consent__copy strong{
  display:block;
  color:#fff;
  font-family:"Saira", system-ui, sans-serif;
  font-size:1.05rem;
  letter-spacing:.02em;
  text-transform:uppercase;
  margin-bottom:6px;
}
.cookie-consent__copy p{
  margin:0 0 6px;
  color:rgba(255,255,255,.76);
  font-size:.95rem;
  line-height:1.45;
}
.cookie-consent__copy a{
  color:#fff;
  text-decoration:underline;
  text-underline-offset:3px;
}
.cookie-consent__actions{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:10px;
  min-width:280px;
}
.cookie-consent__actions .btn{
  white-space:nowrap;
}
@media (max-width: 760px){
  .cookie-consent{padding:10px}
  .cookie-consent__panel{
    align-items:stretch;
    flex-direction:column;
    border-radius:18px;
  }
  .cookie-consent__actions{
    min-width:0;
    justify-content:stretch;
  }
  .cookie-consent__actions .btn{
    width:100%;
  }
}

.result-feature .source-link{margin-top:14px!important;font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.result-feature .source-link a{color:var(--bone);text-decoration:underline;text-underline-offset:4px}
.result-feature .source-link a:hover{color:var(--purple)}

/* ============================================================
   Mobile polish: results board + person section
   ============================================================ */
@media (max-width: 680px){
  .board{
    overflow:hidden;
  }

  .row-t{
    grid-template-columns:1fr;
    gap:10px;
    align-items:start;
  }

  .row-t .ev{
    min-width:0;
  }

  .row-t .pos{
    justify-self:start;
    max-width:100%;
  }

  .row-t .pos.fast{
    width:100%;
    white-space:normal;
    text-align:center;
    line-height:1.15;
    padding:12px 14px;
  }

  .off > .wrap > .row{
    display:block;
  }

  .off > .wrap > .row > .col-auto,
  .off > .wrap > .row > .col{
    width:100%;
    max-width:100%;
    flex:0 0 100%;
  }

  .off .badge{
    display:block;
    margin:0 0 18px;
  }

  .off-copy,
  .off-copy p{
    max-width:100%;
  }

  .off-copy ul{
    columns:1;
    column-gap:0;
    padding-left:1.25rem;
  }
}
