/* ============================================================
   QUANT·A·THON 2026 — Quantum Hackathon Landing
   Design system + styles
   ============================================================ */

:root{
  --bg:        #04081a;
  --bg-2:      #071233;
  --ink:       #eaf1ff;
  --muted:     #93a7cc;
  --muted-2:   #62759b;

  --navy:      #143a78;
  --navy-2:    #0c2350;

  --cyan:      #34c8f4;   /* electric quantum */
  --blue:      #4f8cff;
  --violet:    #8a6bff;
  --accent:    #ef5d3a;   /* coral — from registration form */
  --accent-2:  #ff8a4d;

  --line:      rgba(120,170,255,.14);
  --line-soft: rgba(120,170,255,.08);
  --card:      rgba(255,255,255,.025);
  --card-2:    rgba(255,255,255,.045);

  --glow-cyan: 0 0 60px rgba(52,200,244,.45);
  --glow-coral:0 0 50px rgba(239,93,58,.5);

  --display: "Space Grotesk", system-ui, sans-serif;
  --body:    "Manrope", system-ui, sans-serif;
  --mono:    "Space Mono", ui-monospace, monospace;

  --maxw: 1240px;
  --ease: cubic-bezier(.22,1,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
::selection{ background:var(--cyan); color:#04122b; }

/* ---- ambient page background ---- */
body::before{
  content:""; position:fixed; inset:0; z-index:-2;
  background:
    radial-gradient(900px 700px at 78% -8%, rgba(52,200,244,.16), transparent 60%),
    radial-gradient(800px 700px at 8% 12%, rgba(79,140,255,.13), transparent 55%),
    radial-gradient(1000px 800px at 50% 120%, rgba(239,93,58,.10), transparent 60%),
    linear-gradient(180deg, #04081a 0%, #060e26 45%, #04091d 100%);
}
body::after{
  content:""; position:fixed; inset:0; z-index:-2; opacity:.5;
  background-image:
    linear-gradient(rgba(120,170,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(120,170,255,.05) 1px, transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(circle at 50% 30%, #000 0%, transparent 75%);
          mask-image:radial-gradient(circle at 50% 30%, #000 0%, transparent 75%);
}
#bgCanvas{ position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.9; }

/* ---- layout helpers ---- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
section{ position:relative; }
.eyebrow{
  font-family:var(--mono); font-size:12.5px; letter-spacing:.32em;
  text-transform:uppercase; color:var(--cyan);
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--cyan); opacity:.7; }
.kicker{
  font-family:var(--mono); font-size:12px; letter-spacing:.28em;
  text-transform:uppercase; color:var(--muted-2);
}
h2.head{
  font-family:var(--display); font-weight:700;
  font-size:clamp(30px,4.6vw,58px); line-height:1.03;
  letter-spacing:-.02em; margin:18px 0 0;
}
.lead{ color:var(--muted); font-size:clamp(15px,1.5vw,18px); max-width:60ch; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 28px; transition:background .4s var(--ease), padding .4s var(--ease), border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(6,12,32,.72); backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--line); padding:11px 28px;
}
.brand{ display:flex; align-items:center; gap:13px; }
.brand .logo-chip{  display:grid; place-items:center;  flex:none; 
}
.brand .logo-chip img{ width: 280px; height: 82px; object-fit:contain; }
.brand .bname{ font-family:var(--display); font-weight:700; font-size:16px; letter-spacing:.04em; line-height:1; }
.brand .bsub{ font-family:var(--mono); font-size:10px; letter-spacing:.24em; color:var(--cyan); text-transform:uppercase; }
.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{
  font-size:14px; font-weight:600; color:var(--muted); position:relative; padding:4px 0;
  transition:color .25s;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0;
  background:var(--cyan); transition:width .3s var(--ease);
}
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after{ width:100%; }

.btn{
  font-family:var(--body); font-weight:700; font-size:14.5px;
  display:inline-flex; align-items:center; gap:9px; cursor:pointer;
  border:none; border-radius:999px; padding:13px 26px;
  transition:transform .25s var(--ease), box-shadow .3s, background .3s;
  white-space:nowrap;
}
.btn-primary{
  color:#fff; background:linear-gradient(120deg,var(--accent),var(--accent-2));
  box-shadow:0 10px 30px rgba(239,93,58,.35);
}
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 16px 44px rgba(239,93,58,.5); }
.btn-ghost{
  color:var(--ink); background:rgba(255,255,255,.04);
  border:1px solid var(--line); backdrop-filter:blur(6px);
}
.btn-ghost:hover{ transform:translateY(-3px); border-color:var(--cyan); box-shadow:0 0 30px rgba(52,200,244,.25); }
.btn .arr{ transition:transform .25s var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }

.nav-toggle{ display:none; width:44px; height:44px; border-radius:10px; border:1px solid var(--line);
  background:rgba(255,255,255,.04); cursor:pointer; flex-direction:column; gap:5px; align-items:center; justify-content:center; }
.nav-toggle span{ width:20px; height:2px; background:var(--ink); transition:.3s; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ min-height:100svh; display:flex; align-items:center; padding:120px 0 60px; overflow:hidden; }
.hero .wrap{ position:relative; z-index:3; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:20px; align-items:center; }

/* ---- coded quantum visual (replaces banner image) ---- */
.q-stage{
  position:absolute; right: 2%; top: 60%; transform:translateY(-50%);
  width:min(560px,46vw); aspect-ratio:1; z-index:1; pointer-events:none;
  perspective:1100px; animation:floaty 9s ease-in-out infinite;
}
@keyframes floaty{ 0%,100%{ transform:translateY(-50%) } 50%{ transform:translateY(calc(-50% - 16px)) } }

.q-halo{
  position:absolute; inset:8%; border-radius:50%;
  background:radial-gradient(circle at 50% 50%, rgba(52,200,244,.32), rgba(79,140,255,.14) 45%, transparent 70%);
  filter:blur(6px); animation:halopulse 5s ease-in-out infinite;
}
@keyframes halopulse{ 0%,100%{ opacity:.7; transform:scale(1) } 50%{ opacity:1; transform:scale(1.06) } }

.q-grid-sphere{
  position:absolute; inset:20%; border-radius:50%;
  border:1px solid rgba(120,180,255,.18);
  background:
    repeating-linear-gradient(0deg, transparent 0 11px, rgba(120,180,255,.08) 11px 12px),
    repeating-linear-gradient(90deg, transparent 0 11px, rgba(120,180,255,.06) 11px 12px);
  -webkit-mask-image:radial-gradient(circle at 50% 50%, #000 60%, transparent 72%);
          mask-image:radial-gradient(circle at 50% 50%, #000 60%, transparent 72%);
  box-shadow:inset 0 0 60px rgba(52,160,255,.25);
  animation:spinflat 30s linear infinite;
}
@keyframes spinflat{ to{ transform:rotate(360deg) } }

.q-core{
  position:absolute; left:50%; top:50%; width:21%; aspect-ratio:1; transform:translate(-50%,-50%);
  border-radius:50%;
  background:radial-gradient(circle at 38% 34%, #ffffff, #9fe5ff 32%, #34c8f4 60%, #1f6fd0 100%);
  box-shadow:0 0 40px 6px rgba(52,200,244,.7), 0 0 90px 18px rgba(79,140,255,.4),
             inset -6px -8px 22px rgba(8,30,70,.6);
  animation:corepulse 3.2s ease-in-out infinite;
}
@keyframes corepulse{ 0%,100%{ box-shadow:0 0 40px 6px rgba(52,200,244,.7),0 0 90px 18px rgba(79,140,255,.4),inset -6px -8px 22px rgba(8,30,70,.6) }
  50%{ box-shadow:0 0 56px 10px rgba(52,200,244,.95),0 0 130px 26px rgba(79,140,255,.55),inset -6px -8px 22px rgba(8,30,70,.6) } }

.q-ring{
  position:absolute; inset:4%; border-radius:50%;
  border:1.5px solid rgba(150,200,255,.30); transform-style:preserve-3d;
}
.q-ring::before{
  content:""; position:absolute; inset:-1.5px; border-radius:50%;
  border:2px solid transparent;
  border-top-color:var(--cyan); border-right-color:var(--cyan);
  filter:drop-shadow(0 0 6px var(--cyan));
}
.q-ring .q-node{
  position:absolute; top:-8px; left:50%; width:15px; height:15px; margin-left:-7.5px; border-radius:50%;
  background:radial-gradient(circle at 35% 35%, #fff, var(--accent) 70%);
  box-shadow:0 0 18px 4px var(--accent);
}
.q-ring.r1{ transform:rotateX(64deg) rotateZ(0deg); animation:spinz 7s linear infinite; }
.q-ring.r2{ transform:rotateX(70deg) rotateY(56deg); animation:spinz 11s linear infinite reverse; }
.q-ring.r2::before{ border-top-color:var(--blue); border-right-color:var(--blue); filter:drop-shadow(0 0 6px var(--blue)); }
.q-ring.r2 .q-node{ background:radial-gradient(circle at 35% 35%, #fff, var(--cyan) 70%); box-shadow:0 0 18px 4px var(--cyan); }
.q-ring.r3{ transform:rotateX(56deg) rotateY(-48deg); animation:spinz 9s linear infinite; }
.q-ring.r3::before{ border-top-color:var(--violet); border-right-color:var(--violet); filter:drop-shadow(0 0 6px var(--violet)); }
.q-ring.r3 .q-node{ background:radial-gradient(circle at 35% 35%, #fff, var(--violet) 70%); box-shadow:0 0 18px 4px var(--violet); }
@keyframes spinz{ to{ transform:rotate(360deg); } }

.q-spark{ position:absolute; width:5px; height:5px; border-radius:50%; background:var(--cyan);
  box-shadow:0 0 10px 2px var(--cyan); opacity:.8; animation:twinkle 3s ease-in-out infinite; }
.q-spark.s1{ top:14%; left:24%; animation-delay:.2s; }
.q-spark.s2{ top:30%; right:12%; background:var(--accent); box-shadow:0 0 10px 2px var(--accent); animation-delay:1.1s; }
.q-spark.s3{ bottom:20%; left:16%; background:var(--blue); box-shadow:0 0 10px 2px var(--blue); animation-delay:1.8s; }
.q-spark.s4{ bottom:26%; right:22%; animation-delay:2.4s; }
@keyframes twinkle{ 0%,100%{ opacity:.25; transform:scale(.7) } 50%{ opacity:1; transform:scale(1.2) } }

.assoc{ display:block; align-items:center; gap:14px; flex-wrap:wrap; color:#fff; font-family:var(--mono); font-size:14px; letter-spacing:0em; text-transform:uppercase;margin-top: 10px; }
.assoc b{ color:var(--cyan); font-weight:400; }
.assoc strong{ color:var(--accent); font-weight:400; }

.tag-chip{
  display:inline-flex; align-items:center; gap:9px; margin:22px 0 18px;
  padding:8px 16px; border-radius:999px; border:1px solid var(--line);
  background:rgba(52,200,244,.07); font-size:13px; font-weight:600; color:#bfe6ff;
}
.tag-chip .dot{ width:8px; height:8px; border-radius:50%; background:var(--cyan);
  box-shadow:0 0 12px var(--cyan); animation:pulse 1.8s infinite; }
@keyframes pulse{ 0%,100%{ opacity:1; transform:scale(1) } 50%{ opacity:.4; transform:scale(.7) } }

.title{
  font-family:var(--display); font-weight:700; letter-spacing:-.03em;
  font-size:clamp(40px,3.4vw,104px); line-height:1.3; margin:6px 0;
  background:linear-gradient(176deg,#ffffff 8%,#bfe2ff 40%,#5fb6ef 60%,#e8f5ff 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  filter:drop-shadow(0 4px 30px rgba(52,160,255,.35));
}
.title .yr{
  display: initial; font-size:clamp(54px,3.6vw,140px); letter-spacing:.02em;
  background:linear-gradient(176deg,#ffd9c8,#ef5d3a 55%,#ffb38a);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  filter:drop-shadow(0 4px 24px rgba(239,93,58,.4));
}
.subline{ font-family:var(--display); font-weight:600; font-size:clamp(16px,2vw,23px);
  letter-spacing:.06em; color:var(--ink); margin-top:10px; }
.subline span{ color:var(--cyan); }
.where{ display:flex; gap:10px; flex-wrap:wrap; margin-top:18px; }
.where .pill{ display:inline-flex; align-items:center; gap:8px; font-size:13.5px; font-weight:600; white-space:nowrap;
  color:var(--muted); padding:8px 14px; border-radius:10px; border:1px solid var(--line); background:var(--card); }
.where .pill b{ color:var(--ink); font-weight:700; }

/* countdown */
.countdown{ display:flex; gap:12px; margin:30px 0 26px; flex-wrap:wrap; }
.cd-box{
  position:relative; min-width:92px; padding:16px 14px 12px; text-align:center;
  border-radius:14px; border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(20,40,90,.5), rgba(8,16,40,.4));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
  overflow:hidden;
}
.cd-box::before{ content:""; position:absolute; inset:0 0 auto; height:1px; background:linear-gradient(90deg,transparent,var(--cyan),transparent); opacity:.6; }
.cd-num{ font-family:var(--mono); font-weight:700; font-size:clamp(28px,3.4vw,40px); line-height:1;
  color:#fff; letter-spacing:.02em; }
.cd-lab{ font-family:var(--mono); font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:var(--muted-2); margin-top:8px; }

.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.hero-note{ font-size:13px; color:var(--muted-2); margin-top:16px; }
.hero-note b{ color:var(--cyan); }

.scroll-ind{ position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:4;
  font-family:var(--mono); font-size:10px; letter-spacing:.3em; text-transform:uppercase; color:var(--muted-2);
  display:flex; flex-direction:column; align-items:center; gap:8px; }
.scroll-ind .m{ width:22px; height:36px; border:1.5px solid var(--line); border-radius:12px; position:relative; }
.scroll-ind .m::after{ content:""; position:absolute; left:50%; top:7px; width:4px; height:7px; border-radius:2px;
  background:var(--cyan); transform:translateX(-50%); animation:scrolldot 1.8s infinite; }
@keyframes scrolldot{ 0%{ opacity:0; transform:translate(-50%,0) } 40%{ opacity:1 } 80%{ opacity:0; transform:translate(-50%,12px) } }

/* ============================================================
   MARQUEE
   ============================================================ */
   .marquee-track,
.marquee-track1 {
    white-space: nowrap;
}
.marquee{ border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:linear-gradient(90deg, rgba(52,200,244,.06), rgba(239,93,58,.05));}
  .marquee1 { border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  overflow:hidden; padding:18px 0; }
.marquee-track{ display:flex; gap:42px; width:max-content; animation:scrollx 28s linear infinite; }
.marquee-track1{ display:flex; gap:42px; width:max-content; animation: scrollX 10s linear infinite,
               blink 2s infinite;}
.marquee:hover .marquee-track{ animation-play-state:paused; } 
.marquee1:hover .marquee-track1{ animation-play-state:paused; }
.marquee .it{ font-family:var(--display); font-weight:700; font-size:22px; letter-spacing:.04em;
  color:transparent; -webkit-text-stroke:1px rgba(191,230,255,.55); display:flex; align-items:center; gap:42px; }
  .marquee1 .it 
  {
      
  font-family: var(--display);
  font-weight: 700;
  font-size: 16px; 
  align-items: center;
  gap: 42px;
  display: initial; 
  letter-spacing: .02em;
  background: linear-gradient(176deg,#f77343,#ef5d3a 55%,#f46b40); 
  background-clip: border-box;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  filter: drop-shadow(0 4px 24px rgb(242, 101, 62));
       
  }
.marquee .it .s{ color:var(--accent); -webkit-text-stroke:0; }
.marquee1 .it .s{ color: var(--cyan); -webkit-text-stroke:0;
  padding: 0px 20px; } 
  
  

@keyframes scrollx{ to{ transform:translateX(-50%) } }
@keyframes blink {
    50% {
        opacity:0.2;
    }
}

/* ============================================================
   GENERIC SECTION
   ============================================================ */
.band{ padding:clamp(72px,9vw,120px) 0; }
.sec-head{ max-width:760px; }
.sec-head .lead{ margin-top:18px; }

/* stats */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:54px; }
.stat{ padding:26px 22px; border-radius:16px; border:1px solid var(--line); background:var(--card);
  position:relative; overflow:hidden; transition:transform .35s var(--ease), border-color .35s; }
.stat:hover{ transform:translateY(-6px); border-color:rgba(52,200,244,.4); }
.stat::after{ content:""; position:absolute; right:-30px; top:-30px; width:90px; height:90px; border-radius:50%;
  background:radial-gradient(circle,rgba(52,200,244,.25),transparent 70%); }
.stat .v{ font-family:var(--display); font-weight:700; font-size:clamp(30px,2vw,46px); line-height:1;
  background:linear-gradient(120deg,#fff,#7fc4f4); -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat .l{ color:var(--muted); font-size:13.5px; font-weight:600; margin-top:10px; }

.about-grid{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start; }
.about-grid p{ color:var(--muted); margin-top:18px; font-size:16px; }
.about-grid p strong{ color:var(--ink); font-weight:700; }

/* ============================================================
   TRACKS / HIGHLIGHTS
   ============================================================ */
.track-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:54px; }
.track{
  position:relative; padding:30px 26px 28px; border-radius:18px; overflow:hidden;
  border:1px solid var(--line); background:linear-gradient(180deg,var(--card-2),var(--card));
  transition:transform .4s var(--ease), border-color .4s, box-shadow .4s;
  min-height:230px; display:flex; flex-direction:column;
}
.track:hover{ transform:translateY(-8px); border-color:rgba(52,200,244,.45); box-shadow:0 24px 60px rgba(0,0,0,.4),0 0 0 1px rgba(52,200,244,.15) inset; }
.track .glowspot{ position:absolute; width:200px; height:200px; border-radius:50%; pointer-events:none;
  background:radial-gradient(circle,rgba(52,200,244,.22),transparent 65%); opacity:0; transition:opacity .4s; }
.track:hover .glowspot{ opacity:1; }
.track .idx{ font-family:var(--mono); font-size:12px; letter-spacing:.2em; color:var(--cyan); }
.track .ic{ width:52px; height:52px; margin:6px 0 16px; }
.track h3{ font-family:var(--display); font-weight:700; font-size:21px; letter-spacing:-.01em; }
.track p{ color:var(--muted); font-size:14.5px; margin-top:10px; }
.track .ic svg{ width:100%; height:100%; }

/* ============================================================
   PRIZES
   ============================================================ */
.prize-hero{ text-align:center; position:relative; padding:50px 0 8px; }
.prize-amt{ font-family:var(--display); font-weight:700; letter-spacing:-.02em;
  font-size:clamp(72px,14vw,180px); line-height:.9;
  background:linear-gradient(176deg,#fff 6%,#ffd9c8 40%,#ef5d3a 62%,#ffb38a 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  filter:drop-shadow(0 8px 50px rgba(239,93,58,.4)); }
.prize-sub{ font-family:var(--mono); letter-spacing:.34em; text-transform:uppercase; font-size:13px; color:var(--accent-2); }
.perks{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:54px; }
.perk{ padding:26px 22px; border-radius:16px; border:1px solid var(--line); background:var(--card);
  transition:transform .35s var(--ease),border-color .35s; }
.perk:hover{ transform:translateY(-6px); border-color:rgba(239,93,58,.4); }
.perk .pic{ width:40px; height:40px; margin-bottom:14px; color:var(--accent-2); }
.perk h4{ font-family:var(--display); font-weight:700; font-size:17px; }
.perk p{ color:var(--muted); font-size:13.5px; margin-top:8px; }

/* ============================================================
   TIMELINE
   ============================================================ */
.tl{ margin-top:54px; display:grid; grid-template-columns:1fr 1fr; gap:30px; }
.tl-col{ position:relative; padding:28px; border-radius:18px; border:1px solid var(--line);
  background:linear-gradient(180deg,var(--card-2),transparent); }
.tl-col .day{ display:flex; align-items:baseline; gap:14px; padding-bottom:20px; border-bottom:1px solid var(--line); }
.tl-col .day .n{ font-family:var(--display); font-weight:700; font-size:40px; color:var(--cyan); line-height:1; }
.tl-col .day .d{ font-family:var(--mono); font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }
.tl-step{ display:flex; gap:18px; padding:18px 0; border-bottom:1px solid var(--line-soft); }
.tl-step:last-child{ border-bottom:none; }
.tl-step .tm{ font-family:var(--mono); font-size:12.5px; color:var(--accent-2); min-width:74px; padding-top:2px; }
.tl-step .tx h5{ font-family:var(--display); font-weight:600; font-size:16px; }
.tl-step .tx p{ color:var(--muted); font-size:13.5px; margin-top:3px; }
.tl-note{ font-size:12.5px; color:var(--muted-2); margin-top:18px; font-family:var(--mono); letter-spacing:.04em; }

/* ============================================================
   PARTNERS
   ============================================================ */
.partner-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:48px; }
.partner{ background:#fff; border-radius:16px; padding:30px 24px; display:grid; place-items:center; min-height: 120px;
  transition:transform .35s var(--ease), box-shadow .35s; }
.partner:hover{ transform:translateY(-6px); box-shadow:0 20px 50px rgba(52,160,255,.25); }
.partner img{ max-height:140px; width:auto; object-fit:contain; }
.partner .role{ display:none; }

/* ============================================================
   FINAL CTA
   ============================================================ */
.finalcta{ position:relative; overflow:hidden; border-radius:28px; margin:0 auto;
  padding:clamp(54px,7vw,90px) 40px; text-align:center;
  border:1px solid var(--line);
  background:
    radial-gradient(700px 400px at 50% 0%, rgba(239,93,58,.22), transparent 65%),
    radial-gradient(700px 500px at 50% 120%, rgba(52,200,244,.2), transparent 65%),
    linear-gradient(180deg,#08163a,#060e26); }
.finalcta h2{ font-family:var(--display); font-weight:700; font-size:clamp(34px,5.4vw,68px); line-height:1.02;
  letter-spacing:-.02em; }
.finalcta h2 .g{ background:linear-gradient(120deg,var(--cyan),var(--blue)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.finalcta p{ color:var(--muted); margin:18px auto 32px; max-width:54ch; }
.finalcta .hero-cta{ justify-content:center; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ border-top:1px solid var(--line); padding:64px 0 40px; margin-top:90px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; align-items:start; }
.foot .brand{ margin-bottom:18px; }
.foot p{ color:var(--muted); font-size:14px; max-width:42ch; }
.foot h6{ font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--cyan); margin-bottom:16px; }
.foot ul{ list-style:none; display:flex; flex-direction:column; gap:11px; }
.foot ul a, .foot ul li{ color:var(--muted); font-size:14px; transition:color .25s; }
.foot ul a:hover{ color:var(--ink); }
.foot-bot{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px;
  margin-top:46px; padding-top:24px; border-top:1px solid var(--line); }
.foot-bot small{ color:var(--muted-2); font-size:12.5px; }
.foot-tag{ font-family:var(--mono); font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--cyan); }

/* ============================================================
   REVEAL ANIM — pure CSS scroll-timeline (robust, no JS).
   Content is VISIBLE by default; the entrance only plays as the
   element scrolls through the viewport, so it can never get stuck.
   ============================================================ */
@keyframes revealUp{ from{ opacity:0; transform:translateY(32px); } to{ opacity:1; transform:none; } }

@media (prefers-reduced-motion:no-preference){
  @supports (animation-timeline: view()){
    .reveal{ animation:revealUp both linear; animation-timeline:view(); animation-range:entry 2% entry 30%; }
    .reveal.d1{ animation-range:entry 8% entry 36%; }
    .reveal.d2{ animation-range:entry 14% entry 42%; }
    .reveal.d3{ animation-range:entry 20% entry 48%; }
    .reveal.d4{ animation-range:entry 26% entry 54%; }
    .reveal.d5{ animation-range:entry 32% entry 60%; }
  }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .q-stage{ opacity:.5; width:62vw; right:-6%; }
  .hero-grid{ grid-template-columns:1fr; }
  .stats,.perks,.partner-grid{ grid-template-columns:repeat(2,1fr); }
  .track-grid{ grid-template-columns:repeat(2,1fr); }
  .about-grid,.tl{ grid-template-columns:1fr; gap:30px; }
}
@media (max-width:720px){
  .wrap{ padding:0 20px; }
  .nav-links{ display:none; }
  .nav-toggle{ display:flex; }
  .nav.open .nav-links{
    display:flex; position:absolute; top:100%; left:0; right:0; flex-direction:column; gap:4px;
    padding:18px 24px 24px; background:rgba(6,12,32,.96); backdrop-filter:blur(18px);
    border-bottom:1px solid var(--line); }
  .nav.open .nav-links a{ padding:12px 0; font-size:16px; border-bottom:1px solid var(--line-soft); }
  .hero{ padding:120px 0 70px; }
  .q-stage{ opacity:.28; width:78vw; right:50%; transform:translate(50%,-50%); top:42%; animation:none; }
  .stats,.perks,.partner-grid,.track-grid{ grid-template-columns:1fr 1fr; }
  .countdown{ gap:8px; }
  .cd-box{ min-width:0; flex:1; padding:13px 6px 10px; }
  .nav .btn-primary{ display:none; }
}
@media (max-width:414px){
  .stats,.perks,.partner-grid{ grid-template-columns:1fr; }
  .track-grid{ grid-template-columns:1fr; }
  .title{ font-size: clamp(40px,10vw,80px);  line-height: 1.4;}
  .title .yr  {  font-size: clamp(40px,3.6vw,140px);   }
  .brand .logo-chip img {width: 90%;height: 48px;object-fit: contain;display: block;}
  .brand .logo-chip {flex: revert; }
  .foot h6 {margin-top:16px;}
  .foot-grid {display: flow-root;}
  .tag-chip {font-size: 10px; }
    .hero {
    padding: 40px 0 70px;
  }
  .prize-amt {
        font-size: clamp(52px,14vw,180px);
        line-height: 1.5;
  }
   .marquee-track,
    .marquee-track1 {
        min-width: 200%;
    }

    .marquee .it,
    .marquee1 .it {
        white-space: nowrap;
    }
    .marquee,
.marquee1 {
    position: relative;
    overflow-x: hidden;
}
  .hero-grid {
        margin-top: 40px;
  }
}

@media (max-width:385px){
  .stats,.perks,.partner-grid{ grid-template-columns:1fr; }
  .track-grid{ grid-template-columns:1fr; }
  .title{ font-size: clamp(36px,10vw,80px);  line-height: 1.4;}
  .title .yr  {  font-size: clamp(36px,3.6vw,140px);   }
  .brand .logo-chip img {width: 90%;height: 70px; object-fit: contain;display: block;}
  .brand .logo-chip {flex: revert; }
  .foot h6 {margin-top:16px;}
  .foot-grid {display: flow-root;}
  .tag-chip {font-size: 10px; }
    .hero {
    padding: 40px 0 70px;
  }
  .hero-grid {
      margin-top: 40px;
  } 
  .marquee1 {
     padding: 18px 15px 0px 15px; 
  }
   .marquee-track,
    .marquee-track1 {
        min-width: 200%;
    }
    .marquee,
.marquee1 {
    position: relative;
    overflow-x: hidden;
}

    .marquee .it,
    .marquee1 .it {
        white-space: nowrap;
    }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; }
  .reveal{ opacity:1; transform:none; }
}
