/* ============================================================
   RUN CLUB SOCIETY — obsidian void · one red accent
   Whisper-weight grotesk · instrument-panel labels · the artifact
   ============================================================ */

:root{
  --void:#0a0d10;
  --void-2:#0e1217;
  --panel:#11161c;
  --accent:#fc2b3a;          /* the shoe's heel red — used sparingly */
  --accent-dim:rgba(252,43,58,.32);
  --paper:#f4f4f4;
  --paper-dim:#8b949b;
  --paper-faint:#566069;
  --line:rgba(244,244,244,.10);
  --line-soft:rgba(244,244,244,.06);
  --maxw:1240px;
  --gut:clamp(1rem,4vw,3rem);
  --ease:cubic-bezier(.16,1,.3,1);
  --font-disp:"Space Grotesk",system-ui,sans-serif;
  --font-body:"Archivo",system-ui,sans-serif;
  --font-mono:"DM Mono",ui-monospace,monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:var(--font-body);
  background:var(--void);
  color:var(--paper);
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}

/* single, cheap baked grain (no fixed blur) */
.grain{
  position:fixed;inset:0;z-index:2;pointer-events:none;opacity:.05;
  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='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
.cursor-glow{
  position:fixed;top:0;left:0;width:480px;height:480px;border-radius:50%;
  transform:translate(-50%,-50%);pointer-events:none;z-index:1;opacity:0;
  background:radial-gradient(circle,rgba(244,244,244,.05),transparent 65%);
  transition:opacity .4s;will-change:transform;
}
@media (hover:hover){.cursor-glow{opacity:1}}
@media (pointer:coarse){.cursor-glow{display:none}}

/* ===== PRELOADER — start-line split timer ===== */
.preloader{position:fixed;inset:0;z-index:100;background:var(--void);display:grid;place-items:center;overflow:hidden}
html:not(.is-loading) .preloader{display:none}
.pre-lanes{position:absolute;inset:0;display:flex;justify-content:space-between;padding:0 6vw;opacity:.4}
.pre-lanes i{width:1px;background:linear-gradient(to bottom,transparent,var(--paper-dim),transparent);transform:scaleY(0);transform-origin:top;animation:laneIn .8s var(--ease) forwards}
.pre-lanes i:nth-child(2){animation-delay:.08s}
.pre-lanes i:nth-child(3){animation-delay:.16s}
.pre-lanes i:nth-child(4){animation-delay:.24s}
.pre-lanes i:nth-child(5){animation-delay:.32s}
@keyframes laneIn{to{transform:scaleY(1)}}
.pre-inner{position:relative;text-align:center}
.pre-word{font-family:var(--font-disp);font-weight:300;font-size:clamp(3rem,12vw,8rem);line-height:.9;letter-spacing:-.02em;display:flex;gap:.02em;justify-content:center}
.pre-word span{display:inline-block;transform:translateY(110%);animation:preUp .6s var(--ease) forwards}
.pre-word em{width:.32em}
.pre-word span:nth-child(1){animation-delay:.05s}
.pre-word span:nth-child(2){animation-delay:.1s}
.pre-word span:nth-child(3){animation-delay:.15s}
.pre-word span:nth-child(5){animation-delay:.25s}
.pre-word span:nth-child(6){animation-delay:.3s}
.pre-word span:nth-child(7){animation-delay:.35s}
.pre-word span:nth-child(8){animation-delay:.4s}
@keyframes preUp{to{transform:translateY(0)}}
.pre-meta{display:flex;justify-content:space-between;align-items:center;margin-top:1.2rem;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.2em;color:var(--paper-dim)}
.pre-tag{color:var(--paper-dim)}
.pre-time{color:var(--paper)}
.pre-time b{font-weight:500;color:var(--accent)}
.preloader.is-done{transform:translateY(-100%);transition:transform .7s var(--ease)}

/* ===== NAV ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem var(--gut);
  transition:background .4s,padding .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{background:rgba(10,13,16,.72);backdrop-filter:blur(12px);border-color:var(--line);padding-top:.7rem;padding-bottom:.7rem}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-disp);font-weight:500;font-size:1.05rem;letter-spacing:.01em}
.brand-mark{border-radius:50%}
.brand-text{line-height:1}
.brand-text em{font-style:normal;color:var(--paper-dim);font-size:.6em;display:block;line-height:1;letter-spacing:.28em;margin-top:.16em;font-weight:400}
.nav-links{display:flex;gap:1.8rem;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase}
.nav-links a{position:relative;padding:.2rem 0;color:var(--paper-dim);transition:color .3s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--accent);transition:width .35s var(--ease)}
.nav-links a:hover{color:var(--paper)}
.nav-links a:hover::after{width:100%}
.nav-cta{
  font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;
  padding:.55rem 1.1rem;border:1px solid var(--line);border-radius:100px;
  color:var(--paper);transition:.3s var(--ease);
}
.nav-cta:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-2px)}
@media (max-width:860px){.nav-links,.nav-cta{display:none}}

/* burger */
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;align-items:flex-end}
.burger span{width:26px;height:2px;background:var(--paper);transition:.3s var(--ease)}
.burger-label{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.2em;color:var(--paper-dim);text-transform:uppercase}
.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-open .burger span:nth-child(2){opacity:0}
.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media (max-width:860px){.burger{display:flex}}

/* ===== FULL-SCREEN MENU ===== */
.menu{position:fixed;inset:0;z-index:55;display:flex;flex-direction:column;justify-content:center;padding:clamp(2rem,8vw,6rem);opacity:0;visibility:hidden;transition:opacity .5s,visibility .5s}
.menu-open .menu{opacity:1;visibility:visible}
.menu-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--void-2),var(--void) 60%);z-index:-1;clip-path:circle(0% at 100% 0%);transition:clip-path .7s var(--ease)}
.menu-open .menu-bg{clip-path:circle(150% at 100% 0%)}
.menu-list a{display:flex;align-items:baseline;gap:1rem;font-family:var(--font-disp);font-weight:300;font-size:clamp(2.4rem,9vw,5rem);line-height:1.05;letter-spacing:-.02em;color:var(--paper);opacity:.5;transition:.4s var(--ease)}
.menu-list a:hover{opacity:1;color:var(--accent);transform:translateX(1rem)}
.menu-list i{font-family:var(--font-mono);font-size:.85rem;color:var(--paper-dim);font-style:normal}
.menu-foot{margin-top:auto;padding-top:2rem;display:flex;flex-wrap:wrap;gap:1.4rem;font-family:var(--font-mono);font-size:.78rem;color:var(--paper-dim);border-top:1px solid var(--line)}
.menu-foot a:hover{color:var(--accent)}

/* ===== shared section heads ===== */
.section--cine{padding:clamp(4.5rem,11vw,10rem) var(--gut);position:relative}
.sec-head{max-width:var(--maxw);margin:0 auto clamp(2.5rem,5vw,4rem)}
.sec-head--left{text-align:left}
.kicker{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--paper-dim);display:inline-flex;align-items:center;gap:.6rem;margin-bottom:1.1rem}
.kicker::before{content:"";width:1.6rem;height:1px;background:var(--accent)}
.banner-title{font-family:var(--font-disp);font-weight:300;font-size:clamp(3rem,12vw,8.5rem);line-height:.9;letter-spacing:-.03em}
.banner-title span{display:block}
.banner-title--alt .banner-sub{color:var(--paper-dim);font-size:.4em;letter-spacing:-.01em;font-weight:400}
.sec-sub{max-width:50ch;margin-top:1.2rem;color:var(--paper-dim);font-size:1.02rem}

/* ===== FULL-SITE BACKGROUND FILM ===== */
.bgfilm{position:fixed;inset:0;z-index:0;overflow:hidden;background:var(--void);pointer-events:none}
.bgfilm-vid{
  position:absolute;top:50%;left:50%;width:100%;height:100%;
  transform:translate(-50%,-50%);object-fit:cover;object-position:center;
}
/* scrim: darken just enough for legible white type, shoe stays clearly visible */
.bgfilm::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(115% 72% at 50% 48%,transparent 34%,rgba(10,13,16,.62) 100%),
    linear-gradient(to bottom,rgba(10,13,16,.42) 0%,transparent 22%,transparent 68%,rgba(10,13,16,.78) 100%);
}
/* content rides above the film */
main,.foot{position:relative;z-index:1}

/* ===== HERO ===== */
.hero{position:relative;min-height:100svh;overflow:hidden}

/* breathing accent bloom centred behind the spinning shoe (GPU: opacity+transform only) */
.hero-bloom{
  position:absolute;top:46%;left:50%;z-index:2;pointer-events:none;
  width:min(78vw,860px);aspect-ratio:1;border-radius:50%;
  transform:translate(-50%,-50%);
  background:radial-gradient(closest-side,rgba(252,43,58,.30),rgba(252,43,58,.10) 46%,transparent 72%);
  filter:blur(8px);
  animation:bloom 6.5s var(--ease) infinite;
  will-change:opacity,transform;
}
@keyframes bloom{
  0%,100%{opacity:.45;transform:translate(-50%,-50%) scale(.92)}
  50%{opacity:.95;transform:translate(-50%,-50%) scale(1.08)}
}

/* colossal ghost index behind everything — drifts slowly */
.hero-ghost{
  position:absolute;top:50%;left:50%;z-index:1;pointer-events:none;
  transform:translate(-50%,-50%);
  font-family:var(--font-disp);font-weight:300;
  font-size:clamp(20rem,58vw,60rem);line-height:.8;letter-spacing:-.04em;
  color:transparent;-webkit-text-stroke:1px rgba(244,244,244,.05);
  user-select:none;white-space:nowrap;
  animation:ghostdrift 18s ease-in-out infinite;
}
@keyframes ghostdrift{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-52%) scale(1.03)}}
@media (max-width:680px){.hero-ghost{font-size:42vw}}

/* instrument-panel labels */
.hud{position:absolute;inset:0;z-index:3;pointer-events:none;font-family:var(--font-mono);text-transform:uppercase}
.hud-i{position:absolute;display:flex;gap:.45rem;align-items:center;font-size:.68rem;letter-spacing:.2em;color:var(--paper-dim)}
.hud-i i{font-style:normal;color:var(--accent)}
.hud-tl{top:6.4rem;left:var(--gut);color:var(--paper)}
.hud-bl{top:7.9rem;left:var(--gut);color:var(--paper-faint);letter-spacing:.16em}
.hud-tr{top:6.4rem;right:var(--gut)}
.hud-br{bottom:2.2rem;right:var(--gut)}
@media (max-width:680px){.hud-bl{display:none}}

/* minimal copy */
.hero-copy{position:absolute;left:var(--gut);bottom:clamp(3rem,9vh,6rem);z-index:4;max-width:min(92vw,640px)}
.eyebrow{display:inline-flex;align-items:center;gap:.55rem;white-space:nowrap;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--paper-dim);margin-bottom:.9rem}
.eyebrow::before{content:"";width:7px;height:7px;background:var(--accent);border-radius:1px}
.hero-title{font-family:var(--font-disp);font-weight:300;font-size:clamp(2.3rem,5.4vw,4.6rem);line-height:.96;letter-spacing:-.035em;margin-bottom:1rem;text-shadow:0 2px 40px rgba(10,13,16,.7)}
.hero-title .line{display:block;overflow:hidden;white-space:nowrap;padding-right:.08em}
.hero-title .line>*,.hero-title .line{will-change:transform}
.hero-title .line--mark{color:var(--paper)}
.hero-sub{max-width:42ch;color:var(--paper-dim);font-size:1rem}
@media (max-width:520px){.hero-title{font-size:clamp(2rem,9vw,2.8rem)}.eyebrow{white-space:normal}}
.hero-sub strong{color:var(--paper);font-weight:500}

.scroll-hint{position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:.6rem;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--paper-dim)}
.scroll-hint i{width:1px;height:40px;background:linear-gradient(var(--accent),transparent);display:block;animation:drop 1.8s var(--ease) infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}60%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@media (max-width:680px){.hero-copy{max-width:88vw}.scroll-hint{display:none}}

/* ===== FILM STAGE — scroll runway over the deconstructing shoe ===== */
.film-stage{position:relative;z-index:1;min-height:185vh;display:flex;flex-direction:column;justify-content:space-between;padding:18vh var(--gut) 14vh}
.film-cap{max-width:34ch}
.film-cap--b{align-self:flex-end;text-align:right;max-width:42ch}
.film-note{font-family:var(--font-mono);font-size:clamp(.82rem,1.4vw,1rem);line-height:1.7;letter-spacing:.02em;color:var(--paper);text-shadow:0 2px 30px rgba(10,13,16,.85)}
@media (max-width:680px){.film-stage{min-height:150vh}.film-cap--b{text-align:left;align-self:flex-start}}

/* btns */
.btn{position:relative;font-family:var(--font-mono);font-size:.82rem;letter-spacing:.06em;padding:.95rem 1.7rem;border-radius:100px;display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;border:1px solid transparent;overflow:hidden;transition:transform .3s var(--ease)}
.btn>span{position:relative;z-index:1}
.btn--solid{background:var(--accent);color:#fff}
.btn--solid::before{content:"";position:absolute;inset:0;background:var(--paper);transform:translateY(101%);transition:transform .4s var(--ease)}
.btn--solid:hover{color:var(--void)}
.btn--solid:hover::before{transform:translateY(0)}
.btn--line{border-color:var(--line);color:var(--paper)}
.btn--line::before{content:"";position:absolute;inset:0;background:var(--paper);transform:translateY(101%);transition:transform .4s var(--ease)}
.btn--line:hover{color:var(--void)}
.btn--line:hover::before{transform:translateY(0)}

/* ===== TICKER — quiet hairline ===== */
.ticker{background:transparent;color:var(--paper-dim);padding:1.1rem 0;overflow:hidden;white-space:nowrap;border-block:1px solid var(--line)}
.ticker-track{display:inline-flex;animation:marq 40s linear infinite;font-family:var(--font-mono);font-size:.82rem;letter-spacing:.22em;text-transform:uppercase}
.ticker-track span{padding-right:1rem}
@keyframes marq{to{transform:translateX(-50%)}}

/* ===== THE DROP — products ===== */
.drop-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.4rem}
.drop-empty{grid-column:1/-1;text-align:center;color:var(--paper-dim);font-family:var(--font-mono)}
.pcard{
  position:relative;background:var(--panel);
  border:1px solid var(--line);border-radius:16px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .5s var(--ease),border-color .5s;
  transform-style:preserve-3d;will-change:transform;
}
.pcard:hover{border-color:rgba(244,244,244,.22);transform:translateY(-6px)}
.pcard-media{position:relative;aspect-ratio:1;background:radial-gradient(circle at 50% 38%,rgba(120,132,144,.16),transparent 62%);display:grid;place-items:center;overflow:hidden}
.pcard-media::after{content:"";position:absolute;inset:auto 0 0 0;height:40%;background:linear-gradient(transparent,rgba(0,0,0,.4))}
.pcard-media img{width:82%;height:82%;object-fit:contain;transition:transform .6s var(--ease);filter:drop-shadow(0 24px 30px rgba(0,0,0,.55));transform:translateZ(40px)}
.pcard:hover .pcard-media img{transform:translateZ(60px) scale(1.06) rotate(-3deg)}
.pcard-bib{position:absolute;top:.8rem;left:.8rem;z-index:2;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.05em;background:var(--paper);color:var(--void);padding:.25rem .55rem;border-radius:4px}
.pcard-only{position:absolute;top:.8rem;right:.8rem;z-index:2;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--accent);padding:.3rem .55rem;border-radius:100px}
.pcard-body{padding:1.1rem 1.2rem 1.3rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.pcard-type{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--paper-dim)}
.pcard-title{font-family:var(--font-disp);font-weight:500;font-size:1.2rem;line-height:1.08;letter-spacing:-.01em}
.pcard-colour{color:var(--paper-dim);font-size:.86rem;margin-top:-.2rem}
.pcard-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:.8rem}
.pcard-price{font-family:var(--font-disp);font-weight:400;font-size:1.4rem;color:var(--paper)}
.pcard-price b{font-size:.62em;color:var(--paper-dim);vertical-align:super;font-weight:400;font-family:var(--font-mono);margin-right:.1em}
.pcard-buy{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.05em;padding:.55rem 1rem;border-radius:100px;background:rgba(244,244,244,.05);border:1px solid var(--line);color:var(--paper);transition:.3s var(--ease)}
.pcard-buy:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.drop-all{display:flex;width:max-content;margin:3rem auto 0}

/* ===== THE CLUB ===== */
.club-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.club-media{position:relative;border-radius:16px;overflow:hidden;will-change:transform;box-shadow:0 40px 80px -30px rgba(0,0,0,.8)}
.club-media img{width:100%;aspect-ratio:4/5;object-fit:cover}
.club-tape{position:absolute;bottom:1rem;left:1rem;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;background:rgba(10,13,16,.72);backdrop-filter:blur(6px);border:1px solid var(--line);color:var(--paper);padding:.4rem .7rem;border-radius:6px}
.scribble-title{font-family:var(--font-disp);font-weight:300;font-size:clamp(2.6rem,7vw,5rem);line-height:.96;letter-spacing:-.03em;margin-bottom:1.2rem}
.scribble-title mark{background:none;color:var(--accent)}
.club-copy p{color:var(--paper-dim);margin-bottom:1rem;max-width:46ch}
.club-points{list-style:none;margin-top:1.6rem;display:flex;flex-direction:column;gap:.7rem}
.club-points li{display:flex;align-items:center;gap:.7rem;font-size:.95rem}
.club-points i{width:16px;height:16px;flex:none;border-radius:50%;border:1px solid var(--paper-dim);position:relative}
.club-points i::after{content:"";position:absolute;inset:4px;border-radius:50%;background:var(--accent)}
@media (max-width:820px){.club-grid{grid-template-columns:1fr}}

/* ===== ETHOS ===== */
.ethos-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.ethos-card{position:relative;padding:2.4rem 1.7rem;border:1px solid var(--line);border-radius:14px;background:var(--void-2);overflow:hidden;transition:border-color .4s,transform .4s var(--ease)}
.ethos-card:hover{border-color:rgba(244,244,244,.2);transform:translateY(-4px)}
.ethos-card--accent{background:linear-gradient(160deg,rgba(252,43,58,.08),var(--void-2));border-color:var(--accent-dim)}
.ethos-no{font-family:var(--font-disp);font-weight:300;font-size:3.2rem;color:transparent;-webkit-text-stroke:1px var(--paper-dim);display:block;line-height:1;margin-bottom:1rem}
.ethos-card--accent .ethos-no{-webkit-text-stroke-color:var(--accent)}
.ethos-card h3{font-family:var(--font-disp);font-weight:500;font-size:1.4rem;letter-spacing:-.01em;margin-bottom:.6rem}
.ethos-card p{color:var(--paper-dim);font-size:.95rem}
@media (max-width:780px){.ethos-grid{grid-template-columns:1fr}}

/* ===== JOIN ===== */
.join{text-align:center}
.join-inner{max-width:680px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.join-title{font-family:var(--font-disp);font-weight:300;font-size:clamp(2.8rem,9vw,6rem);line-height:.92;letter-spacing:-.03em;margin:.4rem 0 1rem}
.join>.join-inner p{color:var(--paper-dim);max-width:46ch;margin-bottom:1.8rem}
.join-form{display:flex;gap:.6rem;width:100%;max-width:460px;flex-wrap:wrap;justify-content:center}
.join-form input{flex:1;min-width:200px;padding:.95rem 1.2rem;border-radius:100px;border:1px solid var(--line);background:rgba(244,244,244,.04);color:var(--paper);font-family:var(--font-mono);font-size:.88rem}
.join-form input:focus{outline:none;border-color:var(--accent)}
.join-note{margin-top:1rem;font-family:var(--font-mono);font-size:.72rem;color:var(--paper-dim)}
.join-note.ok{color:var(--accent)}

/* ===== FOOTER ===== */
.foot{padding:clamp(3rem,6vw,5rem) var(--gut) 2.5rem;border-top:1px solid var(--line)}
.foot-top{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}
.foot-brand{display:flex;align-items:center;gap:.7rem;font-family:var(--font-disp);font-weight:500;font-size:1.2rem}
.foot-brand em{font-style:normal;color:var(--paper-dim);font-size:.55em;display:block;line-height:1;letter-spacing:.26em}
.foot-links{display:flex;gap:1.6rem;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em}
.foot-links a{color:var(--paper-dim);transition:color .3s}
.foot-links a:hover{color:var(--accent)}
.foot-line{max-width:var(--maxw);margin:2rem auto 1.4rem;font-family:var(--font-disp);font-weight:300;font-size:clamp(1.4rem,4vw,2.4rem);line-height:1.12;color:var(--paper);letter-spacing:-.02em}
.foot-meta{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-family:var(--font-mono);font-size:.72rem;color:var(--paper-dim);border-top:1px solid var(--line);padding-top:1.4rem}
.foot-meta a:hover{color:var(--accent)}

/* ===== reveal anim (set by cinema.js) ===== */
[data-cine]{opacity:0;transform:translateY(40px)}
.cine-in [data-cine],[data-cine].cine-in{opacity:1;transform:none}

/* ===== legibility over the background film ===== */
.banner-title,.scribble-title,.join-title,.foot-line{text-shadow:0 2px 40px rgba(10,13,16,.85)}
.sec-sub,.club-copy p,.join-inner p,.kicker{text-shadow:0 1px 18px rgba(10,13,16,.8)}
.ethos-card{background:rgba(14,18,23,.62);backdrop-filter:none}
.ethos-card--accent{background:linear-gradient(160deg,rgba(252,43,58,.12),rgba(14,18,23,.66))}

@media (prefers-reduced-motion:reduce){
  .ticker-track,.scroll-hint i,.hero-bloom,.hero-ghost{animation:none}
  [data-cine]{opacity:1;transform:none}
}
