/* ════════════════════════════════════════════════
   COPPERBELT MARATHON 2026 — styles
   Palette: ink + copper + cream. Restraint over flash.
   ════════════════════════════════════════════════ */

:root{
  --ink:        #0B0B0D;
  --ink-2:      #101013;
  --surface:    #161619;
  --surface-2:  #1C1C21;
  --line:       rgba(199,123,59,.20);
  --line-soft:  rgba(255,255,255,.07);
  --copper:     #C77B3B;
  --copper-br:  #E89E54;
  --copper-dp:  #8A5320;
  --cream:      #F3EEE6;
  --muted:      #9C968C;
  --muted-2:    #6E6A62;
  --grad-copper: linear-gradient(135deg,#E89E54 0%,#C77B3B 48%,#9A5C28 100%);

  --ff-disp: "Space Grotesk", system-ui, sans-serif;
  --ff-body: "Inter", system-ui, sans-serif;
  --ff-mono: "Space Mono", ui-monospace, monospace;

  --wrap: 1160px;
  --r: 16px;
  --r-sm: 11px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--ink);
  color:var(--cream);
  font-family:var(--ff-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
ul{list-style:none}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}

/* ── Type ── */
h1,h2,h3,h4{font-family:var(--ff-disp);font-weight:700;line-height:1.04;letter-spacing:-.02em}
h2{font-size:clamp(2rem,4.2vw,3.1rem)}
h3{font-size:clamp(1.3rem,2.4vw,1.7rem);letter-spacing:-.01em}
p{color:var(--muted)}
.lead{color:var(--cream);font-size:1.15rem;line-height:1.55}
.ink-accent{color:var(--copper-br)}

.eyebrow{
  font-family:var(--ff-mono);
  font-size:.74rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--copper);
  margin-bottom:18px;
}
.eyebrow--center{text-align:center}

/* ── Buttons ── */
.btn{
  font-family:var(--ff-disp);
  font-weight:600;
  font-size:.95rem;
  letter-spacing:.01em;
  border:0;
  cursor:pointer;
  padding:13px 24px;
  border-radius:50px;
  display:inline-flex;
  align-items:center;
  gap:9px;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
  white-space:nowrap;
}
.btn span{transition:transform .25s var(--ease)}
.btn:hover span{transform:translateX(4px)}
.btn--lg{padding:16px 30px;font-size:1.02rem}
.btn--block{width:100%;justify-content:center}
.btn--copper{
  background:var(--grad-copper);
  color:#1a0e04;
  box-shadow:0 6px 24px -8px rgba(199,123,59,.6);
}
.btn--copper:hover{transform:translateY(-2px);box-shadow:0 12px 32px -8px rgba(199,123,59,.7)}
.btn--ghost{
  background:transparent;
  color:var(--cream);
  border:1px solid var(--line);
}
.btn--ghost:hover{border-color:var(--copper);background:rgba(199,123,59,.06);transform:translateY(-2px)}

/* ════ NAV ════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  transition:background .35s var(--ease), border-color .35s var(--ease), backdrop-filter .35s;
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(11,11,13,.82);
  backdrop-filter:blur(14px) saturate(1.2);
  border-bottom-color:var(--line-soft);
}
.nav__inner{max-width:var(--wrap);margin:0 auto;padding:16px 28px;display:flex;align-items:center;gap:28px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--ff-disp);font-weight:700}
/* ── Nav organiser badge ── */
.nav__organiser{
  display:flex;align-items:center;gap:7px;
  border-left:1px solid var(--line-soft);
  padding-left:16px;margin-left:4px;
}
.nav__org-label{
  font-family:var(--ff-mono);font-size:.6rem;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted-2);white-space:nowrap;
}
.nav__org-logo{
  height:32px;width:32px;object-fit:contain;
  border-radius:6px;background:#fff;padding:2px;
}
.foot__org-logo{
  height:44px;width:44px;object-fit:contain;
  border-radius:8px;background:#fff;padding:3px;
  flex:none;
}
.brand__text{font-size:1.05rem;letter-spacing:-.01em;line-height:1}
.brand__year{display:block;font-family:var(--ff-mono);font-weight:400;font-size:.62rem;letter-spacing:.18em;color:var(--copper);text-transform:uppercase;margin-top:3px}
.nav__links{display:flex;gap:26px;margin-left:auto}
.nav__links a{font-size:.92rem;color:var(--muted);transition:color .2s;position:relative}
.nav__links a:hover{color:var(--cream)}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1.5px;background:var(--copper);transition:width .25s var(--ease)}
.nav__links a:hover::after{width:100%}
.nav__cta{padding:10px 20px;font-size:.9rem}
.nav__burger{display:none;background:none;border:0;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.nav__burger span{width:24px;height:2px;background:var(--cream);border-radius:2px;transition:.3s var(--ease)}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ════ HERO ════ */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;
  padding:140px 0 200px;
  overflow:hidden;
  background:
    radial-gradient(120% 80% at 80% -10%, rgba(199,123,59,.16), transparent 55%),
    radial-gradient(90% 60% at 0% 110%, rgba(138,83,32,.12), transparent 60%),
    var(--ink);
}
.hero__grain{
  position:absolute;inset:0;opacity:.5;pointer-events:none;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.4'/%3E%3C/svg%3E");
}
.hero__route{position:absolute;inset:0;pointer-events:none;opacity:.3;z-index:0}
.hero__route svg{width:100%;height:100%}
#routeline{stroke-dasharray:6 10;animation:dash 9s linear infinite}
@keyframes dash{to{stroke-dashoffset:-160}}
.hero__inner{max-width:var(--wrap);margin:0 auto;padding:0 28px;position:relative;z-index:2;width:100%}
.hero__title{
  font-size:clamp(3.1rem,9vw,7.2rem);
  line-height:.96;
  letter-spacing:-.035em;
  margin:8px 0 26px;
}
.hero__title span{display:block}
.hero__title--accent{
  background:var(--grad-copper);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.hero__lede{max-width:560px;font-size:1.18rem;color:var(--cream);opacity:.82;line-height:1.55}
/* hero meta — date / venue / entry */
.hero__meta{
  display:flex;flex-wrap:nowrap;gap:0;
  margin:28px 0 28px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line-soft);
  border-radius:14px;
  overflow:hidden;
  max-width:580px;
}
.hero__meta-item{
  display:flex;align-items:center;gap:10px;
  padding:16px 22px;
  border-right:1px solid var(--line-soft);
  font-family:var(--ff-disp);
  font-size:1rem;
  font-weight:600;
  color:var(--cream);
  flex:1;
  white-space:nowrap;
}
.hero__meta-item:last-child{border-right:0}
.dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--copper);
  box-shadow:0 0 10px var(--copper);
  flex:none;
}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px}

/* distances */
.distances{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  margin-top:54px;
  border:1px solid var(--line-soft);border-radius:var(--r);overflow:hidden;
  background:var(--line-soft);
}
.distance{
  background:var(--ink-2);
  padding:26px 22px;
  display:flex;flex-direction:column;gap:2px;
  transition:background .3s var(--ease);
}
.distance:hover{background:var(--surface)}
.distance__num{font-family:var(--ff-mono);font-weight:700;font-size:2.1rem;color:var(--cream);line-height:1}
.distance__unit{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.2em;color:var(--copper)}
.distance__label{font-size:.86rem;color:var(--muted);margin-top:8px}

/* ── COUNTDOWN — moved inline, big and bold ── */
.countdown{
  position:relative;
  z-index:2;
  margin-top:40px;
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
}
.countdown__label{
  font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--copper);
  white-space:nowrap;
}
.countdown__clocks{display:flex;gap:12px}
.clock{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  background:rgba(199,123,59,.08);
  border:1px solid rgba(199,123,59,.2);
  border-radius:12px;
  padding:16px 20px;
  min-width:72px;
}
.clock span{
  font-family:var(--ff-mono);font-weight:700;
  font-size:clamp(2rem,3.5vw,3rem);
  color:var(--copper-br);line-height:1;
  letter-spacing:-.02em;
}
.clock small{
  font-family:var(--ff-mono);
  font-size:.62rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted-2);
}

/* ════ STATS ════ */
.stats{border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);background:var(--ink-2)}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);padding:0}
.stat{padding:48px 24px;text-align:center;border-right:1px solid var(--line-soft)}
.stat:last-child{border-right:0}
.stat__num{display:block;font-family:var(--ff-mono);font-weight:700;font-size:clamp(2rem,3.6vw,2.9rem);color:var(--cream);line-height:1;letter-spacing:-.02em}
.stat__label{display:block;margin-top:12px;font-size:.82rem;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}

/* ════ SECTIONS ════ */
.section{padding:108px 0}
.section--alt{background:var(--ink-2);border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.sec-head{max-width:720px;margin-bottom:54px}
.sec-head h2{margin-top:4px}
.sec-head__lede{margin-top:18px;font-size:1.08rem;color:var(--muted)}
.sec-head--sub{margin:72px 0 30px}
.subhead{font-size:1.05rem;color:var(--copper);letter-spacing:.04em;text-transform:uppercase;font-family:var(--ff-mono);font-weight:700}

/* about */
.about{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px}
.about__head h2{font-size:clamp(1.9rem,3.4vw,2.7rem)}
.about__body p+p{margin-top:18px}
.pill-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.pill-list li{
  font-family:var(--ff-mono);font-size:.78rem;letter-spacing:.02em;
  padding:8px 15px;border:1px solid var(--line);border-radius:50px;
  color:var(--cream);background:rgba(199,123,59,.04);
  transition:border-color .25s,background .25s;
}
.pill-list li:hover{border-color:var(--copper);background:rgba(199,123,59,.1)}
.pill-list--wide{max-width:900px}

/* event info grid */
.info-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.info-card{
  background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r);
  padding:26px 24px;display:flex;flex-direction:column;gap:8px;
  transition:transform .3s var(--ease),border-color .3s var(--ease);
}
.info-card:hover{transform:translateY(-4px);border-color:var(--line)}
.info-card__k{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--copper)}
.info-card__v{font-family:var(--ff-disp);font-weight:600;font-size:1.18rem;color:var(--cream)}

/* race cards */
.race-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.race-card{
  background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r);
  padding:32px 28px;display:flex;flex-direction:column;
  transition:transform .35s var(--ease),border-color .35s var(--ease),background .35s var(--ease);
  position:relative;overflow:hidden;min-height:240px;
}
.race-card::before{
  content:"";position:absolute;inset:0;border-radius:var(--r);
  background:radial-gradient(120% 80% at 50% -20%,rgba(199,123,59,.16),transparent 60%);
  opacity:0;transition:opacity .35s var(--ease);
}
.race-card:hover{transform:translateY(-6px);border-color:var(--line);background:var(--surface-2)}
.race-card:hover::before{opacity:1}
.race-card__num{display:flex;align-items:baseline;gap:5px;margin-bottom:auto}
.race-card__num b{font-family:var(--ff-mono);font-weight:700;font-size:2.6rem;color:var(--cream);line-height:1;letter-spacing:-.03em}
.race-card__num span{font-family:var(--ff-mono);font-size:.85rem;letter-spacing:.16em;color:var(--copper)}
.race-card h3{margin:22px 0 8px;font-size:1.28rem}
.race-card p{font-size:.92rem;line-height:1.5}
.race-card--feature{background:linear-gradient(160deg,rgba(199,123,59,.14),var(--surface) 55%);border-color:var(--line)}
.race-card--feature .race-card__num b{color:var(--copper-br)}
.race-card__tag{
  position:absolute;top:18px;right:18px;
  font-family:var(--ff-mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  color:#1a0e04;background:var(--grad-copper);padding:5px 11px;border-radius:50px;
}

/* special challenges chips */
.chip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.chip-card{
  background:var(--ink-2);border:1px solid var(--line-soft);border-radius:var(--r-sm);
  padding:26px 24px;transition:transform .3s var(--ease),border-color .3s var(--ease);
}
.chip-card:hover{transform:translateY(-4px);border-color:var(--line)}
.chip-card h4{font-size:1.05rem;margin-bottom:9px;color:var(--cream)}
.chip-card p{font-size:.88rem;line-height:1.45}

/* prize band */
.prize{position:relative;padding:120px 0;text-align:center;overflow:hidden;background:var(--ink)}
.prize__glow{position:absolute;inset:0;background:radial-gradient(60% 80% at 50% 50%,rgba(199,123,59,.18),transparent 65%)}
.prize__inner{position:relative;z-index:2}
.prize__amount{
  font-family:var(--ff-disp);font-weight:700;font-size:clamp(3.6rem,11vw,8rem);line-height:1;
  letter-spacing:-.04em;margin:6px 0 12px;
  background:var(--grad-copper);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.prize__sub{font-family:var(--ff-mono);font-size:.92rem;letter-spacing:.1em;color:var(--cream);text-transform:uppercase}
.prize__list{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:34px;max-width:760px;margin-inline:auto}
.prize__list li{font-family:var(--ff-mono);font-size:.78rem;padding:8px 16px;border:1px solid var(--line);border-radius:50px;color:var(--cream)}

/* registration / package */
.reg{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.reg__left h2{margin:4px 0 18px}
.price{display:flex;align-items:baseline;gap:4px;margin:8px 0 20px}
.price__cur{font-family:var(--ff-mono);font-size:1.6rem;color:var(--copper)}
.price__num{font-family:var(--ff-disp);font-weight:700;font-size:4.4rem;line-height:1;letter-spacing:-.04em;color:var(--cream)}
.price__per{font-family:var(--ff-mono);font-size:.85rem;color:var(--muted);margin-left:6px}
.reg__note{margin-bottom:28px;max-width:420px}
.reg__right{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:38px 36px}
.reg__pkgtitle{font-size:1.05rem;color:var(--copper);font-family:var(--ff-mono);font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:22px}
.pkg{display:grid;grid-template-columns:1fr 1fr;gap:14px 22px}
.pkg li{position:relative;padding-left:28px;font-size:.95rem;color:var(--cream)}
.pkg li::before{
  content:"";position:absolute;left:0;top:2px;width:18px;height:18px;border-radius:50%;
  background:var(--grad-copper);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/13px no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/13px no-repeat;
}

/* merchandise / kit */
.kit-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.kit-card{
  background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r);
  padding:30px 26px;display:flex;flex-direction:column;gap:16px;
  transition:transform .3s var(--ease),border-color .3s var(--ease);
}
.kit-card:hover{transform:translateY(-4px);border-color:var(--line)}
.kit-card__ico{
  display:flex;align-items:center;justify-content:center;
  width:48px;height:48px;border-radius:12px;
  background:rgba(199,123,59,.1);border:1px solid rgba(199,123,59,.2);
  flex:none;
}
.kit-card__ico svg{width:22px;height:22px;color:var(--copper-br);stroke:var(--copper-br)}
.kit-card h4{font-size:1rem;color:var(--cream);font-weight:600}

/* institutional columns */
.cols-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.col-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r-sm);padding:26px 22px;transition:border-color .3s var(--ease)}
.col-card:hover{border-color:var(--line)}
.col-card h4{font-size:.96rem;color:var(--copper-br);margin-bottom:16px;line-height:1.2}
.col-card ul li{font-size:.86rem;color:var(--muted);padding:5px 0;border-top:1px solid var(--line-soft)}
.col-card ul li:first-child{border-top:0}

/* gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.g-tile{
  position:relative;aspect-ratio:4/5;border-radius:var(--r-sm);overflow:hidden;
  border:1px solid var(--line-soft);
  background:
    linear-gradient(160deg,rgba(199,123,59,calc(.1 + (var(--i)%3)*.05)),var(--surface) 70%);
  display:flex;align-items:flex-end;
  transition:transform .35s var(--ease),border-color .35s var(--ease);
}
.g-tile::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 60% at 50% 0,rgba(199,123,59,.12),transparent 60%);opacity:0;transition:opacity .35s}
.g-tile:hover{transform:translateY(-5px);border-color:var(--line)}
.g-tile:hover::after{opacity:1}
.g-tile figcaption{position:relative;z-index:2;padding:18px;font-family:var(--ff-mono);font-size:.76rem;letter-spacing:.06em;color:var(--cream)}

/* discover */
.discover{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px}
.discover__cols{display:grid;grid-template-columns:1fr 1fr;gap:36px}
.discover__block h4{font-size:1.05rem;color:var(--copper);font-family:var(--ff-mono);font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:18px}
.tick li{position:relative;padding:9px 0 9px 26px;border-top:1px solid var(--line-soft);color:var(--cream);font-size:.95rem}
.tick li:first-child{border-top:0}
.tick li::before{content:"›";position:absolute;left:4px;color:var(--copper);font-weight:700}

/* sponsor */
.sponsor{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}
.sponsor__why{background:linear-gradient(160deg,rgba(199,123,59,.1),var(--surface) 55%);border:1px solid var(--line);border-radius:var(--r);padding:40px 38px}
.sponsor__why h3{margin-bottom:24px}
.reach{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}
.reach li{display:flex;flex-direction:column;gap:4px}
.reach b{font-family:var(--ff-mono);font-weight:700;font-size:1.7rem;color:var(--copper-br);line-height:1}
.reach span{font-size:.82rem;color:var(--muted)}
.sponsor__txt{margin-bottom:26px}
.sponsor__sectors{padding-top:6px}
.sponsor__sectors h4{font-family:var(--ff-mono);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--copper);font-size:.85rem;margin-bottom:20px}

/* volunteers */
.volunteers{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.volunteers__intro h2{margin:4px 0 16px}
.volunteers__intro .btn{margin-top:8px}
.vol-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.vol-grid li{
  background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r-sm);
  padding:18px 20px;font-family:var(--ff-disp);font-weight:600;font-size:.98rem;color:var(--cream);
  transition:border-color .3s,transform .3s var(--ease);
}
.vol-grid li:hover{border-color:var(--line);transform:translateX(4px)}

/* news */
.news-list{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.news-item{
  background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--r);
  padding:26px 24px;transition:border-color .3s,transform .3s var(--ease);
}
.news-item:hover{border-color:var(--line);transform:translateY(-3px)}
.news-item__tag{display:inline-block;font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--copper);margin-bottom:12px}
.news-item p{color:var(--cream);font-size:.96rem;line-height:1.5}

/* finale */
.finale{position:relative;padding:130px 0;text-align:center;overflow:hidden;background:var(--ink-2);border-top:1px solid var(--line-soft)}
.finale__glow{position:absolute;inset:0;background:radial-gradient(70% 80% at 50% 30%,rgba(199,123,59,.16),transparent 60%)}
.finale__inner{position:relative;z-index:2}
.finale__title{font-size:clamp(2.2rem,5.5vw,4rem);margin:6px 0 30px}
.finale__meta{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 28px;font-family:var(--ff-mono);font-size:.86rem;color:var(--cream);margin-bottom:36px}
.finale__meta span{display:flex;align-items:center;gap:8px}
.finale__meta svg{color:var(--copper);stroke:var(--copper);flex:none}
.finale__cta{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.finale__contact{margin-top:40px;display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:var(--muted)}
.finale__contact a{color:var(--copper-br)}

/* ── TGM footer credit ── */
.foot__tgm{margin-top:4px;justify-self:end;align-self:end}
.foot__tgm-link{
  display:flex;align-items:center;gap:10px;
  text-decoration:none;
  padding:10px 14px;
  border:1px solid var(--line-soft);
  border-radius:12px;
  transition:border-color .25s,background .25s;
}
.foot__tgm-link:hover{border-color:var(--line);background:rgba(255,255,255,.04)}
.foot__tgm-logo{
  height:40px;width:40px;object-fit:contain;
  border-radius:8px;background:#fff;padding:2px;flex:none;
}
.foot__tgm-text{display:flex;flex-direction:column;gap:1px}
.foot__tgm-text span{font-size:.72rem;color:var(--muted-2)}
/* footer */
.foot{background:var(--ink);border-top:1px solid var(--line-soft);padding:48px 0 40px}
.hero__inner{position:relative;z-index:2}
.countdown{position:relative;z-index:2;overflow:visible}
.countdown__label{white-space:nowrap}
.foot__inner{display:grid;grid-template-columns:1fr auto;gap:24px 40px;align-items:center}
.foot__brand{display:flex;align-items:center;gap:14px}
.foot__brand strong{display:block;font-family:var(--ff-disp);font-size:1rem}
.foot__brand small{display:block;color:var(--muted);font-size:.8rem;margin-top:2px}
.foot__nav{display:flex;gap:22px;flex-wrap:wrap}
.foot__nav a{font-size:.88rem;color:var(--muted);transition:color .2s}
.foot__nav a:hover{color:var(--copper-br)}
.foot__copy{grid-column:1/-1;font-size:.8rem;color:var(--muted-2);border-top:1px solid var(--line-soft);padding-top:24px}
.foot__credit{font-size:.84rem;color:var(--muted);justify-self:end;align-self:end}
.foot__credit a{color:var(--copper-br);font-weight:600}

/* ════ MODAL ════ */
.modal{position:fixed;inset:0;z-index:120;display:none;align-items:center;justify-content:center;padding:20px}
.modal.is-open{display:flex}
.modal__backdrop{position:absolute;inset:0;background:rgba(5,5,7,.78);backdrop-filter:blur(6px);animation:fade .3s var(--ease)}
.modal__panel{
  position:relative;width:100%;max-width:560px;max-height:92vh;overflow-y:auto;
  background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r);
  padding:38px 38px 34px;animation:pop .35s var(--ease);
}
@keyframes fade{from{opacity:0}}
@keyframes pop{from{opacity:0;transform:translateY(20px) scale(.98)}}
.modal__x{position:absolute;top:16px;right:18px;background:none;border:0;color:var(--muted);font-size:1.1rem;cursor:pointer;padding:6px;transition:color .2s}
.modal__x:hover{color:var(--cream)}
.modal__head{margin-bottom:26px}
.modal__head h3{margin-top:2px}
.steps{display:flex;gap:10px;margin-top:20px}
.steps__item{
  flex:1;text-align:center;font-family:var(--ff-mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted-2);padding-bottom:10px;border-bottom:2px solid var(--line-soft);transition:.3s;
}
.steps__item.is-active{color:var(--copper);border-bottom-color:var(--copper)}
.steps__item.is-done{color:var(--cream);border-bottom-color:var(--copper-dp)}

/* form */
.field{margin-bottom:16px;display:flex;flex-direction:column;gap:7px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.field .opt{color:var(--muted-2);text-transform:none;letter-spacing:0}
.field input,.field select,.field textarea{
  background:var(--surface);border:1px solid var(--line-soft);border-radius:10px;
  padding:13px 15px;color:var(--cream);font-family:var(--ff-body);font-size:.96rem;
  transition:border-color .25s,box-shadow .25s;width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--copper);box-shadow:0 0 0 3px rgba(199,123,59,.16);
}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%239C968C' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:40px}
.field textarea{resize:vertical}
.check{display:flex;gap:10px;align-items:flex-start;font-size:.86rem;color:var(--muted);margin:6px 0 20px;cursor:pointer}
.check input{margin-top:3px;accent-color:var(--copper);width:16px;height:16px;flex:none}
.form__err{color:#e8825a;font-size:.85rem;min-height:1.2em;margin-bottom:10px}
.form__err:empty{margin:0;min-height:0}

/* payment tabs — removed, now just pay button */
.pay-ready{padding:4px 0 8px}
.pay-back{margin-top:14px}
.pay-secure{text-align:center;font-size:.78rem;color:var(--muted-2);margin-top:14px}

/* bank fallback (details/summary) */
.bank-fallback{margin-top:20px;border:1px solid var(--line-soft);border-radius:12px;overflow:hidden}
.bank-fallback summary{
  padding:14px 18px;cursor:pointer;font-family:var(--ff-mono);
  font-size:.76rem;letter-spacing:.08em;color:var(--copper);
  text-transform:uppercase;list-style:none;
  display:flex;justify-content:space-between;align-items:center;
}
.bank-fallback summary::after{content:"›";font-size:1.1rem;color:var(--muted)}
.bank-fallback[open] summary::after{transform:rotate(90deg);display:inline-block}
.bank-fallback .va-intro{padding:0 18px;margin-bottom:0}
.bank-fallback .va-card{margin:12px 0 0;border-radius:0;border-left:0;border-right:0;border-bottom:0}

/* virtual account card (used in bank fallback) */
.va-intro{font-size:.88rem;color:var(--muted);line-height:1.5;margin-bottom:12px;padding-top:12px}
.va-intro a{color:var(--copper-br)}
.va-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:12px;overflow:hidden;margin-bottom:14px}
.va-row{display:flex;justify-content:space-between;align-items:center;padding:11px 16px;border-bottom:1px solid var(--line-soft);gap:12px}
.va-row:last-child{border-bottom:0}
.va-row span{font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);flex:none}
.va-row b{font-size:.9rem;color:var(--cream);text-align:right;max-width:65%}
.va-row--accent b{font-family:var(--ff-mono);font-size:1rem;color:var(--copper-br);letter-spacing:.04em}
.va-amt{color:var(--copper-br) !important}
.pay-actions{display:flex;gap:12px;margin-top:6px}
.pay-actions .btn--lg{flex:1;justify-content:center}
.pay-secure{text-align:center;font-size:.78rem;color:var(--muted-2);margin-top:16px}

/* done step */
.step--done{text-align:center;padding:14px 0}
.done__ring{width:78px;height:78px;border-radius:50%;background:var(--grad-copper);display:flex;align-items:center;justify-content:center;margin:6px auto 22px;animation:pop .5s var(--ease)}
.done__ring span{font-size:2rem;color:#1a0e04}
.step--done h3{font-size:1.6rem;margin-bottom:12px}
.done__msg{margin-bottom:24px}
.done__ref{font-family:var(--ff-mono);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:var(--surface);border:1px solid var(--line-soft);border-radius:12px;padding:16px;margin-bottom:24px}
.done__ref b{display:block;margin-top:6px;font-size:1.05rem;color:var(--copper-br);letter-spacing:.04em}

/* loader */
.loader{position:fixed;inset:0;z-index:140;background:rgba(8,8,10,.82);backdrop-filter:blur(4px);display:none;flex-direction:column;align-items:center;justify-content:center;gap:20px}
.loader.is-on{display:flex}
.loader__spin{width:46px;height:46px;border:3px solid var(--line);border-top-color:var(--copper);border-radius:50%;animation:spin .8s linear infinite}
.loader p{font-family:var(--ff-mono);font-size:.85rem;letter-spacing:.1em;color:var(--cream)}
@keyframes spin{to{transform:rotate(360deg)}}

/* ════ REVEAL ANIMATION ════ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.hero .reveal[data-d]{transition-delay:calc(var(--d,0)*70ms)}

/* ════ RESPONSIVE ════ */
@media(max-width:1080px){
  .cols-grid{grid-template-columns:repeat(3,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:900px){
  .nav__links{display:none}
  .nav__burger{display:flex}
  .nav__cta{display:none}
  .nav.is-open .nav__links{
    display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;
    background:var(--ink-2);border-bottom:1px solid var(--line-soft);padding:8px 0;
  }
  .nav.is-open .nav__links a{padding:14px 28px}
  .about,.reg,.sponsor,.volunteers,.discover{grid-template-columns:1fr;gap:36px}
  .distances{grid-template-columns:repeat(2,1fr)}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2n){border-right:0}
  .stat{border-bottom:1px solid var(--line-soft)}
  .info-grid,.race-grid,.chip-grid,.kit-grid{grid-template-columns:repeat(2,1fr)}
  .cols-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .news-list{grid-template-columns:1fr}
  .discover__cols{grid-template-columns:1fr 1fr}
  .reg__right{padding:30px 26px}
}
@media(max-width:560px){
  body{font-size:16px}
  .wrap{padding:0 20px}
  .section{padding:74px 0}
  .hero{padding:120px 0 170px}
  .field-row,.networks,.reach,.pkg{grid-template-columns:1fr}
  .info-grid,.race-grid,.chip-grid,.kit-grid,.cols-grid,.gallery-grid,.vol-grid,.discover__cols{grid-template-columns:1fr}
  .countdown{justify-content:flex-start}
  .countdown__clocks{gap:8px}
  .clock{min-width:60px;padding:10px 12px}
  .clock span{font-size:1.7rem}
  .modal__panel{padding:30px 22px}
  .hero__meta{flex-wrap:wrap;max-width:100%}
  .hero__meta-item{white-space:normal;font-size:.92rem;padding:13px 16px}
  .foot__inner{grid-template-columns:1fr}
  .foot__credit{justify-self:start}
}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
  #routeline{animation:none}
}
