:root{
  --navy:#0a2342; --navy2:#0e2f54; --royal:#2f74d0; --blue:#1f5fc4; --sky:#7fb1f0;
  --paper:#f4f7fc; --ink:#0c2240; --muted:rgba(255,255,255,.74); --line:rgba(255,255,255,.16);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:#fff;background:var(--navy);-webkit-font-smoothing:antialiased;overflow-x:hidden}
.wrap{max-width:1240px;margin:0 auto;padding:0 28px}
a{color:inherit;text-decoration:none}
section{position:relative}
.eyebrow{font-family:'Oswald';font-weight:600;letter-spacing:.22em;text-transform:uppercase;font-size:13px;color:var(--sky);margin-bottom:14px}
.sec-eyebrow{font-family:'Oswald';font-weight:600;letter-spacing:.22em;text-transform:uppercase;font-size:13px;color:var(--royal);text-align:center;margin-bottom:10px}
.sec-h{font-family:'Anton';text-transform:uppercase;font-size:clamp(34px,5vw,60px);line-height:1;text-align:center;margin-bottom:8px}
.sec-sub{text-align:center;font-size:17px;max-width:660px;margin:0 auto 46px;line-height:1.6}
.on-light .sec-h{color:var(--navy)} .on-light .sec-sub{color:#4a5b71}
.on-dark .sec-h{color:#fff} .on-dark .sec-sub{color:#cdd9ea}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Oswald';font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-size:14px;border-radius:9px;padding:12px 22px;cursor:pointer;border:0;transition:transform .15s,background .2s,box-shadow .2s,color .2s}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--royal);color:#fff;box-shadow:0 8px 22px rgba(47,116,208,.36)}
.btn-primary:hover{background:var(--blue)}
.btn-white{background:#fff;color:var(--navy)}
.btn-white:hover{background:#e8f0fb}
.btn-ghost{background:rgba(255,255,255,.07);color:#fff;border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.14)}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid rgba(12,34,64,.25)}
.btn-outline:hover{border-color:var(--navy);background:rgba(12,34,64,.05)}

/* ---------- NAV + TICKER ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .3s,box-shadow .3s,padding .3s;padding:16px 0}
header.scrolled{background:rgba(8,26,48,.95);backdrop-filter:blur(8px);box-shadow:0 1px 0 var(--line);padding:9px 0}
.nav{display:flex;align-items:center;gap:26px}
.brand{display:flex;align-items:center;gap:12px;font-family:'Oswald';font-weight:700;letter-spacing:.04em;font-size:19px;color:#fff}
.brand img{height:42px;width:auto;display:block}
.nav-links{display:flex;gap:22px;margin-left:auto;font-family:'Oswald';font-weight:500;font-size:14px;letter-spacing:.05em;text-transform:uppercase}
.nav-links a{color:var(--muted);transition:color .2s}.nav-links a:hover{color:#fff}
.ticker{position:fixed;top:74px;left:0;right:0;z-index:55;background:var(--royal);color:#fff;overflow:hidden;white-space:nowrap;transition:top .3s}
header.scrolled + .ticker{top:54px}
.ticker-track{display:inline-flex;font-family:'Oswald';font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:13px;padding:7px 0;animation:scroll 34s linear infinite}
.ticker-track span{padding:0 26px;position:relative}
.ticker-track span::after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:5px;height:5px;border-radius:50%;background:#fff;opacity:.5}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- HERO ---------- */
.hero{min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;background:var(--navy);background-size:cover;background-position:center}
.hero-bg video{width:100%;height:100%;object-fit:cover;object-position:center}
.yt-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.yt-bg iframe{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100vw;height:56.25vw;min-height:100vh;min-width:177.78vh;pointer-events:none;border:0}
.hero-bg::after{content:"";position:absolute;inset:0;background:
   linear-gradient(105deg, var(--navy) 6%, rgba(10,35,66,.86) 40%, rgba(10,35,66,.5) 75%),
   linear-gradient(0deg, rgba(10,35,66,.85), transparent 40%)}
.hero-inner{position:relative;z-index:3;padding:150px 0 90px}
h1{font-family:'Anton';font-weight:400;line-height:.9;letter-spacing:.01em;text-transform:uppercase;font-size:clamp(58px,9vw,128px);margin-bottom:10px}
h1 .yr{color:var(--sky);background:linear-gradient(100deg,var(--sky) 28%,#fff 50%,var(--sky) 72%);background-size:220% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:sheen 5.5s ease-in-out infinite}
@keyframes sheen{0%,100%{background-position:120% 0}50%{background-position:-20% 0}}
.tag{font-family:'Oswald';font-weight:500;font-size:clamp(18px,2.3vw,27px);letter-spacing:.02em;color:#dbe6f5;margin-bottom:36px;max-width:640px}
.tag em{font-style:italic;color:#fff}
.cd-label{font-family:'Oswald';font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:12px;color:var(--muted);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.pulse{width:9px;height:9px;border-radius:50%;background:var(--sky);box-shadow:0 0 0 0 rgba(127,177,240,.6);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(127,177,240,.55)}70%{box-shadow:0 0 0 13px rgba(127,177,240,0)}100%{box-shadow:0 0 0 0 rgba(127,177,240,0)}}
.cd{display:flex;gap:12px;margin-bottom:40px}
.cd .cell{background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:13px;padding:15px 0;min-width:90px;text-align:center;backdrop-filter:blur(2px)}
.cd .num{font-family:'Oswald';font-weight:700;font-size:46px;line-height:1;font-variant-numeric:tabular-nums}
.cd .lab{font-family:'Oswald';font-weight:500;letter-spacing:.16em;text-transform:uppercase;font-size:11px;color:var(--muted);margin-top:6px}
.cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.play-ico{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#fff;color:var(--navy);font-size:10px;padding-left:2px}

/* ---------- CAUSE ---------- */
.cause{background:#fff;color:var(--ink);padding:96px 0}
.cause-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:56px;align-items:center}
.cause h2{font-family:'Anton';text-transform:uppercase;font-size:clamp(32px,4.6vw,54px);line-height:1;color:var(--navy);margin-bottom:20px}
.cause p{font-size:18px;line-height:1.75;color:#3c4d63;margin-bottom:26px}
.values{display:flex;gap:10px;flex-wrap:wrap}
.value{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:14px;color:var(--royal);background:#eaf2fd;border-radius:30px;padding:9px 18px}
.crest-card{background:var(--navy);border-radius:20px;padding:34px;text-align:center;box-shadow:0 24px 50px rgba(10,35,66,.25)}
.crest-card img{width:100%;max-width:300px;border-radius:12px}

/* ---------- GIVE ---------- */
.give{background:#fff;color:var(--ink);padding:92px 0}
.ways{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:40px}
.way{background:var(--paper);border:1px solid #e3e9f1;border-radius:14px;padding:24px 22px}
.way h4{font-family:'Oswald';font-weight:600;font-size:18px;color:var(--navy);margin-bottom:8px;text-transform:uppercase;letter-spacing:.03em}
.way p{font-size:14px;color:#52617a;line-height:1.6}
.contact{background:var(--paper);color:var(--ink);padding:84px 0}

/* ---------- GAME DAY ---------- */
.gameday{background:var(--navy);padding:96px 0}
.games{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:40px}
.game{background:linear-gradient(180deg,var(--navy2),rgba(14,47,84,.4));border:1px solid var(--line);border-radius:16px;padding:30px 26px;transition:transform .2s,border-color .2s}
.game:hover{transform:translateY(-6px);border-color:var(--sky)}
.game .time{font-family:'Oswald';font-weight:700;font-size:40px;color:var(--sky);line-height:1}
.game .gt{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:21px;margin:10px 0 6px}
.game .gs{color:#aebfd6;font-size:14px}
.gd-meta{display:flex;gap:14px;justify-content:center;align-items:center;flex-wrap:wrap;color:#cdd9ea}
.gd-where{font-family:'Oswald';font-weight:500;letter-spacing:.04em;font-size:16px}

/* ---------- CHALLENGE ---------- */
.challenge{background:var(--paper);color:var(--ink);padding:96px 0}
.thermo{max-width:760px;margin:0 auto 48px}
.thermo-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px;font-family:'Oswald';font-weight:600}
.thermo-raised{font-size:27px;color:var(--navy)} .thermo-raised b{color:var(--royal)}
.thermo-goal{font-size:15px;color:#6a7a8f;letter-spacing:.04em;text-transform:uppercase}
.thermo-track{height:18px;border-radius:10px;background:#e1e8f2;overflow:hidden}
.thermo-fill{height:100%;width:0;border-radius:10px;background:linear-gradient(90deg,var(--sky),var(--royal),var(--navy));transition:width 1.6s cubic-bezier(.2,.7,.2,1)}
.board{max-width:820px;margin:0 auto}
.row{display:flex;align-items:center;gap:18px;padding:16px 0;border-bottom:1px solid #e3e9f1}
.rank{font-family:'Anton';font-size:30px;width:32px;color:#b9c6d8;text-align:center}
.team{width:150px;flex:none}
.team .name{font-family:'Oswald';font-weight:600;font-size:18px;color:var(--navy);text-transform:uppercase;letter-spacing:.03em}
.team .meta{font-size:12px;color:#8a98aa}
.bar-wrap{flex:1;height:26px;background:#e9eef6;border-radius:8px;overflow:hidden}
.bar{height:100%;width:0;border-radius:8px;transition:width 1.5s cubic-bezier(.2,.7,.2,1)}
.amt{font-family:'Oswald';font-weight:700;font-size:20px;width:96px;text-align:right;color:var(--navy);font-variant-numeric:tabular-nums}
.center-cta{text-align:center;margin-top:46px}

/* ---------- SPIRIT WEEK ---------- */
.spirit{background:#fff;color:var(--ink);padding:96px 0}
.days{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.day{background:var(--paper);border:1px solid #e3e9f1;border-radius:16px;padding:26px 18px;text-align:center;transition:transform .2s}
.day:hover{transform:translateY(-5px)}
.day .dnum{width:42px;height:42px;border-radius:50%;background:#e7f0fc;color:var(--royal);font-family:'Oswald';font-weight:700;font-size:18px;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.day .dname{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#8a98aa;font-size:13px;margin-bottom:6px}
.day .dtheme{font-family:'Oswald';font-weight:600;font-size:18px;color:var(--navy)}
.day.today{background:var(--royal);border-color:var(--royal);transform:translateY(-5px);box-shadow:0 16px 34px rgba(47,116,208,.34)}
.day.today .dnum{background:#fff;color:var(--royal)} .day.today .dname{color:rgba(255,255,255,.85)} .day.today .dtheme{color:#fff}
.day .badge{display:inline-block;margin-top:10px;font-family:'Oswald';font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#a7b4c4}
.day.today .badge{color:#fff}

/* ---------- GEAR ---------- */
.gear{background:var(--navy2);padding:92px 0;overflow:hidden}
.gear::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(127,177,240,.18),transparent 70%);top:-160px;right:-120px}
.gear-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;position:relative}
.gear-grid img{width:100%;max-width:420px;display:block;margin:0 auto;filter:drop-shadow(0 22px 40px rgba(0,0,0,.45));animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.gear h2{font-family:'Anton';text-transform:uppercase;font-size:clamp(32px,4.4vw,52px);line-height:1;margin-bottom:14px}
.gear p{color:#cdd9ea;font-size:17px;margin-bottom:24px;max-width:460px}
.price-chips{display:flex;gap:12px;margin-bottom:28px}
.pchip{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:14px;background:rgba(255,255,255,.07);border:1px solid var(--line);border-radius:10px;padding:12px 18px}
.pchip b{color:var(--sky);font-size:22px;display:block;font-weight:700}

/* ---------- GALLERY ---------- */
.gallery{background:var(--paper);color:var(--ink);padding:96px 0}
.grid{columns:4;column-gap:12px}
.grid img{width:100%;margin-bottom:12px;border-radius:10px;display:block;cursor:pointer;transition:transform .25s,box-shadow .25s;break-inside:avoid}
.grid img:hover{transform:scale(1.02);box-shadow:0 14px 30px rgba(10,35,66,.22)}

/* ---------- SPONSORS ---------- */
.sponsors{background:var(--navy);padding:90px 0}
.sgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:40px}
.sponsor{aspect-ratio:3/2;background:rgba(255,255,255,.05);border:1px dashed var(--line);border-radius:14px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.45);font-family:'Oswald';letter-spacing:.06em;text-transform:uppercase;font-size:14px}
.sponsor img{max-width:72%;max-height:60%;object-fit:contain}

/* ---------- VOLUNTEER ---------- */
.volunteer{background:linear-gradient(120deg,var(--royal),var(--blue));padding:84px 0;text-align:center}
.volunteer h2{font-family:'Anton';text-transform:uppercase;font-size:clamp(32px,5vw,56px);line-height:1;margin-bottom:14px}
.volunteer p{color:#eaf2ff;font-size:18px;max-width:560px;margin:0 auto 28px}

/* ---------- FOOTER ---------- */
footer{background:#071a30;padding:46px 0;text-align:center}
footer img{height:46px;margin-bottom:14px}
.f-links{display:flex;gap:22px;justify-content:center;flex-wrap:wrap;font-family:'Oswald';letter-spacing:.06em;text-transform:uppercase;font-size:13px;color:var(--muted);margin-bottom:14px}
.f-links a:hover{color:#fff}
.f-note{font-size:12px;color:rgba(255,255,255,.4);max-width:560px;margin:0 auto}
.f-note code{color:var(--sky)}

/* ---------- reveal + modal + lightbox ---------- */
.rise{opacity:0;transform:translateY(26px);animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards}
.d1{animation-delay:.05s}.d2{animation-delay:.18s}.d3{animation-delay:.31s}.d4{animation-delay:.44s}.d5{animation-delay:.57s}
@keyframes rise{to{opacity:1;transform:none}}
.reveal{opacity:0;transform:translateY(34px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.modal{position:fixed;inset:0;z-index:100;background:rgba(4,14,28,.9);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:24px}
.modal.open{display:flex;animation:fade .25s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal-box{width:min(960px,100%);aspect-ratio:16/9;background:#000;border-radius:14px;overflow:hidden;position:relative;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.modal-box iframe{width:100%;height:100%;border:0}
.modal-msg{display:flex;align-items:center;justify-content:center;height:100%;text-align:center;color:#cdd9ea;font-size:16px;padding:40px;line-height:1.7}
.modal-msg b{color:var(--sky)}
.modal-x{position:absolute;top:-46px;right:0;background:transparent;border:0;color:#fff;font-size:30px;cursor:pointer;font-family:'Oswald'}
.lb{position:fixed;inset:0;z-index:110;background:rgba(5,15,30,.94);display:none;align-items:center;justify-content:center}
.lb.open{display:flex;animation:fade .2s ease}
.lb img{max-width:90vw;max-height:86vh;border-radius:10px}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:0;color:#fff;width:52px;height:52px;border-radius:50%;font-size:24px;cursor:pointer}
.lb-nav:hover{background:rgba(255,255,255,.24)} .lb-prev{left:24px}.lb-next{right:24px}
.lb-x{position:absolute;top:22px;right:26px;background:transparent;border:0;color:#fff;font-size:34px;cursor:pointer}

/* ---------- SUBPAGES (slug pages) ---------- */
.page-head{background:var(--navy);color:#fff;padding:150px 0 70px;text-align:center;position:relative;overflow:hidden}
.page-head::before{content:"";position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(47,116,208,.22),transparent 70%);top:-200px;left:50%;transform:translateX(-50%)}
.page-head .inner{position:relative;z-index:2}
.page-head .eyebrow{color:var(--sky);text-align:center}
.page-head h1{font-family:'Anton';text-transform:uppercase;font-size:clamp(40px,6.5vw,82px);line-height:.95}
.page-head p{color:#cdd9ea;max-width:640px;margin:14px auto 0;font-size:17px;line-height:1.65}
.section{padding:84px 0}
.section.light{background:#fff;color:var(--ink)}
.section.paper{background:var(--paper);color:var(--ink)}
.section.dark{background:var(--navy2)}
.lede{max-width:720px;margin:0 auto 40px;text-align:center;font-size:18px;line-height:1.7;color:#3c4d63}
.baskets{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.basket{background:#fff;border:1px solid #e3e9f1;border-radius:16px;padding:26px 24px;transition:transform .2s,box-shadow .2s}
.basket:hover{transform:translateY(-6px);box-shadow:0 18px 38px rgba(10,35,66,.16)}
.basket .bval{font-family:'Oswald';font-weight:700;color:var(--royal);font-size:14px;letter-spacing:.06em;text-transform:uppercase}
.basket h3{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--navy);font-size:21px;margin:6px 0 8px}
.basket p{color:#52617a;font-size:15px;line-height:1.55}
.note{text-align:center;color:#52617a;max-width:660px;margin:38px auto 0;font-size:15px;line-height:1.6}
.video-frame{max-width:960px;margin:0 auto;aspect-ratio:16/9;border-radius:16px;overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.4);background:#000}
.video-frame iframe{width:100%;height:100%;border:0}

@media (max-width:980px){
  .cause-grid,.gear-grid{grid-template-columns:1fr;gap:32px;text-align:center}
  .gear-grid .gear-copy{order:2} .price-chips{justify-content:center}
  .games{grid-template-columns:1fr} .grid{columns:3} .sgrid{grid-template-columns:repeat(3,1fr)}
  .crest-card{max-width:380px;margin:0 auto}
  .baskets{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .nav-links{display:none} .ticker{top:66px}
  .hero-inner{padding:130px 0 70px} .hero-bg::after{background:linear-gradient(0deg,var(--navy) 12%,rgba(10,35,66,.45) 70%)}
  .cd .cell{min-width:0;flex:1} .cd .num{font-size:34px}
  .days{grid-template-columns:repeat(2,1fr)} .grid{columns:2} .sgrid{grid-template-columns:repeat(2,1fr)}
  .baskets{grid-template-columns:1fr}
}
