/* ============================================================
   SHIFT HAPPENS — cosmic festival site
   Variants: a=Deep Space · b=Aurora Fog · c=Solar Flare
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:auto}
:root{
  /* brand constants */
  --gold:#FFC21A;
  --blue:#2E7CF6; --violet:#7A4DFF; --magenta:#FF3CAC; --orange:#FF5A1F; --red:#FF5A3C; --green:#27E5A6; --cream:#F4ECDD;
  --text:#F3EFE6; --dim:#9a93b0;
  /* defaults (overridden per variant) */
  --void:#070512; --ink:#0c0a1c; --panel:rgba(255,255,255,.035); --line:rgba(255,255,255,.10);
  --accent:#FF3CAC; --accent2:#27E5A6; --accent3:#2E7CF6;
  --glow:255,194,26;             /* smiley halo rgb */
  --grad:linear-gradient(100deg,var(--blue),var(--violet),var(--magenta),var(--orange),var(--gold));
  --wm-glow:rgba(122,77,255,.55);
  --speed:1;
  --maxw:1280px; --pad:clamp(20px,5vw,84px);
}

/* ---------- VARIANT A · DEEP SPACE ---------- */
html[data-variant="a"]{
  --void:#03030a; --ink:#070710; --line:rgba(255,255,255,.08);
  --accent:#2E7CF6; --accent2:#FF5A1F; --accent3:#7A4DFF;
  --glow:255,200,40;
  --grad:linear-gradient(100deg,#3a8bff,#7a4dff,#ff3cac,#ffc21a);
  --wm-glow:rgba(46,124,246,.5);
  --speed:1.25;
}
/* ---------- VARIANT B · AURORA FOG ---------- */
html[data-variant="b"]{
  --void:#070512; --ink:#0c0a1c;
  --accent:#FF3CAC; --accent2:#27E5A6; --accent3:#2E7CF6;
  --glow:255,194,26;
  --grad:linear-gradient(100deg,#27e5a6,#2e7cf6,#7a4dff,#ff3cac,#ffc21a);
  --wm-glow:rgba(255,60,172,.5);
  --speed:1;
}
/* ---------- VARIANT C · SOLAR FLARE ---------- */
html[data-variant="c"]{
  --void:#0b0604; --ink:#140a06;
  --accent:#FFC21A; --accent2:#FF5A1F; --accent3:#FF3CAC;
  --glow:255,170,30;
  --grad:linear-gradient(100deg,#ffc21a,#ff5a1f,#ff3cac,#7a4dff);
  --wm-glow:rgba(255,120,30,.6);
  --speed:.8;
}

body{
  background:var(--void);
  color:var(--text);
  font-family:'Space Grotesk',system-ui,sans-serif;
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  transition:background-color .7s ease;
}
body.locked{overflow:hidden;height:100vh}
.mono{font-family:'Space Mono',monospace}
em{font-style:normal;color:var(--gold)}
.grad{
  background:var(--grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.dim{color:var(--dim)}
a{color:inherit;text-decoration:none}
img,svg{display:block}

/* ============ COSMIC BACKGROUND LAYERS ============ */
#nebula{position:fixed;inset:0;width:100%;height:100%;z-index:-3;display:block;
  background:radial-gradient(120% 90% at 50% 18%, #1a1140 0%, var(--void) 55%, #000 100%);
  transition:background .7s ease;}
.grain{position:fixed;inset:-50%;z-index:-2;pointer-events:none;opacity:.045;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='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 7s steps(6) infinite;}
@keyframes grain{0%{transform:translate(0,0)}20%{transform:translate(-4%,3%)}40%{transform:translate(3%,-4%)}60%{transform:translate(-3%,2%)}80%{transform:translate(2%,4%)}100%{transform:translate(0,0)}}
.vignette{position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(ellipse 90% 75% at 50% 42%, transparent 40%, rgba(0,0,0,.55) 100%);}
.cursor-glow{position:fixed;top:0;left:0;width:460px;height:460px;border-radius:50%;z-index:0;pointer-events:none;
  transform:translate(-50%,-50%);opacity:0;transition:opacity .4s;
  background:radial-gradient(circle, rgba(var(--glow),.10) 0%, transparent 65%);mix-blend-mode:screen;}
@media (hover:hover){.cursor-glow{opacity:1}}

/* ============ SMILEY ============ */
.sm-face{fill:var(--gold)}
.sm-feat{stroke:#0a0a0a;stroke-width:13}
.hero-smiley,.invite-smiley{width:100%;height:100%;
  filter:drop-shadow(0 0 26px rgba(var(--glow),.85)) drop-shadow(0 0 70px rgba(var(--glow),.45));}

/* ============ LOADER ============ */
#loader{position:fixed;inset:0;z-index:200;background:var(--void);display:grid;place-items:center;
  transition:opacity .8s ease,visibility .8s;}
#loader.done{opacity:0;visibility:hidden}
.loader-core{display:grid;justify-items:center;gap:22px;width:min(80vw,440px)}
.loader-smiley{width:92px;height:92px;filter:drop-shadow(0 0 24px rgba(var(--glow),.8));
  animation:spinwink 2.4s ease-in-out infinite}
@keyframes spinwink{0%,100%{transform:rotate(-6deg) scale(1)}50%{transform:rotate(6deg) scale(1.06)}}
.loader-word{font-family:'Archivo';font-weight:900;font-style:italic;letter-spacing:.04em;font-size:clamp(18px,4vw,26px);
  background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.loader-bar{width:100%;height:2px;background:var(--line);overflow:hidden;border-radius:2px}
.loader-bar span{display:block;height:100%;width:0;background:var(--grad)}
.loader-pct{color:var(--dim);font-size:12px;letter-spacing:.3em}

/* ============ VARIANT SWITCHER ============ */
.switcher{position:fixed;z-index:90;right:clamp(14px,2vw,26px);top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;gap:8px;align-items:flex-end;}
.switcher-label{font-size:9px;letter-spacing:.35em;color:var(--dim);writing-mode:vertical-rl;transform:rotate(180deg);margin-bottom:6px}
.switcher button{display:flex;align-items:center;gap:0;cursor:pointer;border:1px solid var(--line);
  background:rgba(10,8,20,.5);backdrop-filter:blur(10px);color:var(--text);border-radius:40px;
  padding:7px;height:36px;width:36px;overflow:hidden;transition:width .35s cubic-bezier(.2,.7,.2,1),background .3s,border-color .3s;}
.switcher button b{font-family:'Archivo';font-weight:900;font-size:13px;flex:0 0 22px;text-align:center}
.switcher button i{font-style:normal;font-family:'Space Mono';font-size:10px;letter-spacing:.08em;white-space:nowrap;opacity:0;transition:opacity .3s;padding-right:8px}
.switcher button:hover{width:148px}
.switcher button:hover i{opacity:.85}
.switcher button.on{border-color:transparent;background:var(--grad);color:#0a0712}
.switcher button.on i{opacity:0}
.switcher button.on:hover i{opacity:1}
.switcher button.on b{color:#0a0712}

/* ============ NAV ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);transition:padding .4s,background .4s,backdrop-filter .4s;}
.nav.scrolled{padding:11px var(--pad);background:rgba(7,5,18,.55);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-mark{display:flex;align-items:center;gap:11px;font-family:'Archivo';font-weight:900;font-style:italic;font-size:14px;letter-spacing:.02em}
.nav-smiley{width:30px;height:30px;flex:0 0 30px;filter:drop-shadow(0 0 8px rgba(var(--glow),.7))}
.nav-links{display:flex;gap:30px}
.nav-links a{font-size:13px;color:var(--dim);position:relative;transition:color .3s}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-5px;width:0;height:1px;background:var(--accent);transition:width .3s}
.nav-links a:hover{color:var(--text)}.nav-links a:hover::after{width:100%}
.nav-cta{font-size:13px;font-weight:700;padding:10px 20px;border:1px solid var(--accent);border-radius:40px;
  color:var(--text);position:relative;overflow:hidden;transition:color .3s}
.nav-cta::before{content:'';position:absolute;inset:0;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.4,.6,.2,1);z-index:-1}
.nav-cta:hover{color:#0a0712}.nav-cta:hover::before{transform:scaleX(1)}

/* ============ TYPE SCALE ============ */
.eyebrow{font-size:clamp(10px,1.4vw,12px);letter-spacing:.3em;color:var(--accent);margin-bottom:22px}
.big{font-family:'Anton',sans-serif;font-weight:400;line-height:.96;letter-spacing:.005em;
  font-size:clamp(2.4rem,7vw,6rem);text-transform:uppercase;}
.huge{font-family:'Anton',sans-serif;line-height:.92;text-transform:uppercase;font-size:clamp(3rem,12vw,10rem)}
.lede{font-size:clamp(1.05rem,1.8vw,1.4rem);max-width:62ch;color:#d7d1e4;margin-top:26px;line-height:1.6}
section{position:relative;padding:clamp(90px,13vh,170px) var(--pad);max-width:var(--maxw);margin:0 auto}

/* ============ HERO ============ */
.hero{min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  padding-top:80px;padding-bottom:78px;max-width:none}
.hero-meta-top{position:absolute;top:82px;display:flex;gap:14px;font-size:11px;letter-spacing:.28em;color:var(--dim)}
.hero-meta-top .dot{color:var(--accent);font-size:7px;align-self:center}
.hero-portal{position:relative;width:clamp(80px,10vw,124px);aspect-ratio:1;margin-bottom:min(2.5vh,16px)}
.portal-halo{position:absolute;inset:-55%;border-radius:50%;z-index:-1;
  background:radial-gradient(circle,rgba(var(--glow),.55) 0%,rgba(var(--glow),.12) 38%,transparent 68%);
  animation:breathe 6s ease-in-out infinite;filter:blur(6px)}
@keyframes breathe{0%,100%{transform:scale(1);opacity:.9}50%{transform:scale(1.14);opacity:1}}

/* speed-blur spectrum wordmark */
.wordmark{display:flex;flex-direction:column;align-items:center;line-height:.82}
.w-shift{position:relative;font-family:'Archivo';font-weight:900;font-style:italic;
  font-size:clamp(3rem,12.5vw,10.5rem);letter-spacing:-.02em;
  background:linear-gradient(96deg,#2e7cf6 6%,#7a4dff 30%,#ff3cac 52%,#ff5a3c 72%,#ffc21a 96%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 4px 30px var(--wm-glow));}
.w-shift::before,.w-shift::after{content:attr(data-text);position:absolute;inset:0;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;z-index:-1}
.w-shift::before{background:linear-gradient(96deg,#2e7cf6,#ff3cac,#ffc21a);
  transform:translateX(-.07em) scaleX(1.05);filter:blur(9px);opacity:.55}
.w-shift::after{background:linear-gradient(96deg,#2e7cf6,#ffc21a);
  transform:translateX(-.18em) scaleX(1.12);filter:blur(22px);opacity:.3}
.w-happens{font-family:'Anton';font-size:clamp(1.7rem,7.2vw,5.9rem);letter-spacing:.01em;color:var(--gold);
  -webkit-text-fill-color:var(--gold);
  text-shadow:0 0 28px rgba(var(--glow),.5),0 0 4px rgba(var(--glow),.6);
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='80'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.012 .14' numOctaves='2' seed='7'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 -1.1 1.05'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' fill='white'/%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='.32'/%3E%3C/svg%3E");
  -webkit-mask-size:cover;mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='80'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.012 .14' numOctaves='2' seed='7'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 -1.1 1.05'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' fill='white'/%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='.32'/%3E%3C/svg%3E");mask-size:cover}

.hero-tag{font-family:'Fraunces',serif;font-style:italic;font-size:clamp(1.05rem,2.2vw,1.6rem);
  color:var(--cream);margin-top:20px;max-width:22ch;line-height:1.32}
.hero-when{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;font-size:clamp(10px,1.5vw,13px);
  letter-spacing:.26em;color:var(--dim);margin-top:16px}
.hero-when .sep{color:var(--accent)}

/* countdown */
.countdown{display:flex;gap:clamp(14px,3vw,38px);margin-top:18px}
.cd-unit{display:grid;justify-items:center;gap:5px}
.cd-unit b{font-family:'Archivo';font-weight:900;font-size:clamp(1.5rem,4vw,2.8rem);line-height:1;
  font-variant-numeric:tabular-nums;color:var(--text);text-shadow:0 0 22px rgba(var(--glow),.3)}
.cd-unit i{font-style:normal;font-size:10px;letter-spacing:.25em;color:var(--dim);text-transform:uppercase}

.hero-pillars{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(10px,2.4vw,30px);margin-top:24px;
  font-size:clamp(9px,1.3vw,11px);letter-spacing:.22em;color:var(--dim)}
.hero-pillars span{position:relative}
.hero-pillars span+span::before{content:'✺';position:absolute;left:calc(-1*clamp(8px,1.3vw,17px));color:var(--accent);opacity:.6}

.scroll-cue{position:absolute;bottom:22px;display:grid;justify-items:center;gap:8px;font-size:9px;letter-spacing:.3em;color:var(--dim)}
.cue-line{width:1px;height:36px;background:linear-gradient(var(--accent),transparent);animation:cue 2.2s ease-in-out infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ============ MANIFESTO ============ */
.manifesto{text-align:center;display:grid;justify-items:center}
.manifesto .big{margin-bottom:6px}
.chain{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:clamp(10px,2.5vw,30px);position:relative;
  margin:66px 0 60px;max-width:900px}
.chain-line{position:absolute;top:8px;left:5%;right:5%;height:1px;background:var(--line);z-index:0}
.node{position:relative;display:grid;justify-items:center;gap:14px;z-index:1}
.node-dot{width:16px;height:16px;border-radius:50%;background:var(--ink);border:1px solid var(--line);transition:all .5s}
.node b{font-family:'Space Grotesk';font-weight:700;font-size:clamp(12px,1.6vw,16px);letter-spacing:.01em}
.node.lit .node-dot{background:var(--accent);border-color:var(--accent);box-shadow:0 0 16px var(--accent),0 0 40px rgba(var(--glow),.4);transform:scale(1.25)}
.node:last-child.lit .node-dot{background:var(--gold);box-shadow:0 0 22px var(--gold),0 0 56px rgba(var(--glow),.6)}
.cheeky{margin-top:18px}
.cheeky p{font-family:'Fraunces',serif;font-style:italic;font-size:clamp(1.4rem,4vw,2.8rem);line-height:1.25;color:var(--cream)}

/* ============ NEEDLE / PROOF ============ */
.needle-head{max-width:none}
.proof{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.6vw,22px);margin-top:60px}
.proof-card{border:1px solid var(--line);border-radius:16px;padding:clamp(20px,2.6vw,34px);background:var(--panel);
  backdrop-filter:blur(6px);position:relative;overflow:hidden;transition:border-color .4s,transform .4s}
.proof-card::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 0% 0%,rgba(var(--glow),.10),transparent 60%);opacity:0;transition:opacity .4s}
.proof-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.proof-card:hover::before{opacity:1}
.proof-card b{display:block;font-family:'Archivo';font-weight:900;font-size:clamp(2.2rem,4.6vw,3.6rem);line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  font-variant-numeric:tabular-nums}
.proof-card span{display:block;margin-top:12px;color:var(--dim);font-size:clamp(.82rem,1.3vw,.98rem)}
.proof-foot{margin-top:26px;font-size:11px;letter-spacing:.18em;color:var(--dim)}

/* ============ LINEAGE ============ */
.lineage{max-width:none;padding-right:0}
.lineage-intro{max-width:var(--maxw);margin:0 auto;padding-right:var(--pad)}
.track-wrap{margin-top:64px;overflow:hidden}
.track{display:flex;gap:22px;padding:6px var(--pad) 30px;width:max-content}
.era{flex:0 0 clamp(220px,26vw,300px);border:1px solid var(--line);border-radius:18px;padding:28px 26px;
  background:linear-gradient(160deg,var(--panel),transparent);min-height:230px;display:flex;flex-direction:column;
  transition:border-color .4s,transform .4s;position:relative;overflow:hidden}
.era::after{content:'';position:absolute;left:26px;bottom:24px;width:34px;height:34px;border-radius:50%;
  background:radial-gradient(circle,var(--accent),transparent 70%);opacity:.25;transition:opacity .4s}
.era:hover{border-color:var(--accent);transform:translateY(-6px)}
.era:hover::after{opacity:.7}
.era-yr{font-size:12px;letter-spacing:.2em;color:var(--accent)}
.era h3{font-family:'Anton';font-size:clamp(1.4rem,2.4vw,2rem);text-transform:uppercase;margin:14px 0 10px;line-height:1}
.era p{color:var(--dim);font-size:.95rem;margin-top:auto}
.era.now{background:var(--grad);border-color:transparent}
.era.now .era-yr,.era.now p{color:#0a0712;opacity:.85}
.era.now h3{color:#0a0712}
.era.now::after{display:none}

/* ============ EXPERIENCE ============ */
.experience{text-align:center;display:grid;justify-items:center}
.equation{display:flex;align-items:stretch;justify-content:center;flex-wrap:wrap;gap:14px;margin:54px 0 40px}
.eq{border:1px solid var(--line);border-radius:14px;padding:22px 26px;min-width:150px;background:var(--panel);display:grid;gap:6px;align-content:center;transition:border-color .4s,transform .4s}
.eq:hover{border-color:var(--accent);transform:translateY(-4px)}
.eq b{font-family:'Anton';font-size:clamp(1.1rem,2vw,1.5rem);text-transform:uppercase;line-height:1}
.eq span{font-size:12px;color:var(--dim);letter-spacing:.04em}
.eq-op{font-family:'Anton';font-size:2rem;color:var(--accent);align-self:center}
.eq-sum{background:var(--grad);border-color:transparent}
.eq-sum b,.eq-sum span{color:#0a0712}.eq-sum span{opacity:.8}

/* ============ PILLARS ============ */
.pillars{text-align:center}
.pillar-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:60px}
.pillar{border:1px solid var(--line);border-radius:18px;padding:34px 20px;background:var(--panel);
  display:grid;gap:14px;justify-items:center;text-align:center;transition:border-color .4s,transform .4s,background .4s;position:relative;overflow:hidden}
.pillar::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% -20%,rgba(var(--glow),.16),transparent 60%);opacity:0;transition:opacity .4s}
.pillar:hover{transform:translateY(-8px);border-color:var(--accent)}
.pillar:hover::before{opacity:1}
.p-ico{font-size:1.9rem;width:62px;height:62px;display:grid;place-items:center;border-radius:50%;
  border:1px solid var(--line);background:var(--ink);filter:drop-shadow(0 0 10px rgba(var(--glow),.3))}
.pillar h3{font-family:'Anton';font-size:1.25rem;text-transform:uppercase;letter-spacing:.02em}
.pillar p{color:var(--dim);font-size:.86rem;line-height:1.45}

/* ============ DAYS ============ */
.days .day-list{margin-top:54px;border-top:1px solid var(--line)}
.day{display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:clamp(14px,3vw,40px);
  padding:clamp(22px,3vw,38px) 6px;border-bottom:1px solid var(--line);transition:background .4s,padding-left .4s;position:relative}
.day::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--grad);transform:scaleY(0);transform-origin:top;transition:transform .45s}
.day:hover{background:rgba(255,255,255,.02);padding-left:22px}
.day:hover::before{transform:scaleY(1)}
.day-n{font-size:clamp(1.4rem,3vw,2.2rem);color:var(--accent);font-weight:700}
.day h3{font-family:'Anton';font-size:clamp(1.5rem,3.4vw,2.6rem);text-transform:uppercase;line-height:1}
.day-q{display:none}
.day:hover .day-q,.day:focus-within .day-q{display:block}
.day-q{font-family:'Fraunces',serif;font-style:italic;color:var(--cream);font-size:1.05rem;margin-top:8px}
.day-tag{font-size:10px;letter-spacing:.18em;color:var(--dim);text-align:right;max-width:200px;justify-self:end}

/* ============ NIGHTS ============ */
.nights{max-width:none}
.nights-head{max-width:var(--maxw);margin:0 auto}
.night-list{max-width:var(--maxw);margin:60px auto 0;display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.night{border:1px solid var(--line);border-radius:18px;padding:clamp(24px,3vw,38px);background:var(--panel);
  position:relative;overflow:hidden;transition:border-color .4s,transform .4s}
.night:last-child{grid-column:1/-1}
.night::after{content:'';position:absolute;right:-30px;top:-30px;width:140px;height:140px;border-radius:50%;
  background:radial-gradient(circle,rgba(var(--glow),.22),transparent 65%);opacity:.4;transition:all .5s}
.night:hover{border-color:var(--accent);transform:translateY(-5px)}
.night:hover::after{opacity:.9;transform:scale(1.3)}
.night-day{font-size:12px;letter-spacing:.28em;color:var(--accent)}
.night h3{font-family:'Anton';font-size:clamp(1.4rem,2.6vw,2.1rem);text-transform:uppercase;margin:12px 0 10px;line-height:1.02}
.night p{color:var(--dim);font-size:.96rem;max-width:46ch;position:relative;z-index:1}

/* ============ RHYTHM ============ */
.rhythm{text-align:center}
.rhythm-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin:58px 0 50px;text-align:left}
.beat{border:1px solid var(--line);border-radius:16px;padding:26px 22px;background:var(--panel);
  display:grid;gap:10px;align-content:start;transition:border-color .4s,transform .4s;min-height:210px}
.beat:hover{border-color:var(--accent);transform:translateY(-6px)}
.beat-t{font-size:10px;letter-spacing:.22em;color:var(--accent)}
.beat h3{font-family:'Anton';font-size:1.15rem;text-transform:uppercase;line-height:1.05}
.beat p{color:var(--dim);font-size:.84rem;line-height:1.45}
.debate-ticker{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:18px 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.ticker-row{display:flex;gap:34px;white-space:nowrap;width:max-content;animation:ticker 38s linear infinite;font-family:'Fraunces',serif;font-style:italic;font-size:clamp(1rem,2vw,1.5rem);color:var(--cream)}
.ticker-row .tk-dot{color:var(--accent);font-style:normal}
@keyframes ticker{to{transform:translateX(-50%)}}

/* ============ CIVIC ============ */
.civic{max-width:none;background:linear-gradient(180deg,transparent,rgba(255,255,255,.018),transparent)}
.civic-inner{max-width:var(--maxw);margin:0 auto;text-align:center;display:grid;justify-items:center}
.civic-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:11px;margin-top:42px;max-width:780px}
.civic-tags span{border:1px solid var(--line);border-radius:40px;padding:9px 18px;font-size:.82rem;color:var(--dim);
  font-family:'Space Mono';transition:all .3s}
.civic-tags span:hover{border-color:var(--accent);color:var(--text)}

/* ============ INVITE ============ */
.invite{text-align:center;display:grid;justify-items:center;overflow:hidden}
.invite-portal{position:relative;width:clamp(86px,11vw,130px);aspect-ratio:1;margin-bottom:26px}
.invite-q{font-family:'Fraunces',serif;font-style:italic;font-size:clamp(1.3rem,3.4vw,2.4rem);color:var(--cream);margin-top:20px}
.signup{display:flex;gap:10px;margin:42px 0 24px;width:min(94vw,520px);flex-wrap:wrap;justify-content:center}
.signup input{flex:1;min-width:220px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:40px;
  padding:16px 24px;color:var(--text);font-family:'Space Grotesk';font-size:1rem;transition:border-color .3s}
.signup input:focus{outline:none;border-color:var(--accent)}
.signup input::placeholder{color:var(--dim)}
.signup button,.nav-cta{cursor:pointer}
.signup button{border:none;border-radius:40px;padding:16px 30px;font-family:'Space Grotesk';font-weight:700;font-size:1rem;
  color:#0a0712;background:var(--grad);position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s}
.signup button:hover{box-shadow:0 0 34px rgba(var(--glow),.55)}
.signup.sent input{border-color:var(--green)}
.invite-roles{font-size:clamp(9px,1.3vw,11px);letter-spacing:.2em;color:var(--dim);margin-top:8px;max-width:60ch;line-height:2}
.invite-contact{color:var(--dim);margin-top:20px;font-size:.95rem}
.invite-contact a{color:var(--gold);border-bottom:1px solid rgba(255,194,26,.4)}

/* ============ FOOTER ============ */
.foot{padding:80px var(--pad) 50px;border-top:1px solid var(--line);position:relative;max-width:var(--maxw);margin:0 auto}
.foot-banner{display:flex;flex-wrap:wrap;gap:clamp(14px,5vw,60px);justify-content:center;font-family:'Anton';
  font-size:clamp(1.6rem,6vw,4rem);text-transform:uppercase;color:transparent;-webkit-text-stroke:1px var(--dim);letter-spacing:.02em}
.foot-banner span{transition:color .3s,-webkit-text-stroke-color .3s}
.foot-banner span:hover{color:var(--gold);-webkit-text-stroke-color:var(--gold)}
.foot-quote{text-align:center;margin:50px auto;max-width:30ch}
.foot-quote{font-family:'Fraunces',serif;font-style:italic;font-size:clamp(1.2rem,3vw,2rem);color:var(--cream)}
.foot-quote cite{display:block;font-size:.8rem;color:var(--dim);font-style:normal;margin-top:14px;letter-spacing:.1em}
.foot-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:30px;align-items:start;margin-top:50px;padding-top:34px;border-top:1px solid var(--line)}
.foot-mark{display:flex;gap:12px;align-items:center}
.foot-mark .nav-smiley{width:42px;height:42px;flex:0 0 42px}
.foot-mark p{font-family:'Archivo';font-weight:900;font-style:italic;font-size:14px;line-height:1.5}
.foot-mark span{font-weight:400;font-style:normal;font-size:10px;letter-spacing:.18em;color:var(--dim)}
.foot-motif{display:grid;gap:8px;font-size:11px;letter-spacing:.2em;color:var(--dim);justify-items:center;text-align:center}
.foot-motif .alive{color:var(--accent)}
.foot-by{text-align:right}
.foot-by p{font-size:11px;letter-spacing:.14em;color:var(--dim);line-height:1.7}
.foot-credit{margin-top:16px;color:var(--gold)!important}

/* ============ REVEAL (only when JS+GSAP ready) ============ */
html.anim-ready .reveal{opacity:0}

/* ============ RESPONSIVE ============ */
@media(max-width:1000px){
  .proof{grid-template-columns:repeat(2,1fr)}
  .pillar-grid{grid-template-columns:repeat(2,1fr)}
  .rhythm-grid{grid-template-columns:repeat(2,1fr)}
  .nav-links{display:none}
}
@media(max-width:760px){
  .switcher{flex-direction:row;top:auto;bottom:16px;right:50%;transform:translateX(50%);background:rgba(10,8,20,.6);backdrop-filter:blur(12px);padding:7px;border-radius:40px}
  .switcher-label{display:none}
  .switcher button{height:34px}
  .switcher button:hover{width:36px}.switcher button:hover i{opacity:0}
  .switcher button.on{width:120px}.switcher button.on i{opacity:1}
  .night-list{grid-template-columns:1fr}
  .day{grid-template-columns:54px 1fr;gap:16px}
  .day-tag{display:none}
  .day-q{display:block}
  .foot-grid{grid-template-columns:1fr;text-align:center;gap:34px}
  .foot-by,.foot-mark{text-align:center;justify-content:center}
  .foot-by{order:3}
  .chain{gap:18px 14px}
}
@media(max-width:480px){
  .proof{grid-template-columns:1fr}
  .pillar-grid,.rhythm-grid{grid-template-columns:1fr}
  .hero-meta-top{top:74px}
}
@media(max-height:780px) and (min-width:761px){
  .hero-pillars{display:none}
  .hero{padding-top:72px}
  .hero-portal{width:clamp(82px,9vw,120px)}
}

/* ============ REDUCED MOTION ============ */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  html.anim-ready .reveal{opacity:1!important}
  .portal-halo{animation:none}
  .ticker-row{animation:none}
  .wordmark::after{display:none}
  .w-shift.glitching{animation:none}
}

/* ============ LIVING / MAGIC — the SHIFT HAPPENS moment ============ */
/* spectrum gradient breathes wherever it appears */
@keyframes holoflow{from{background-position:0% 50%}to{background-position:100% 50%}}
.grad,.w-shift,.era.now,.eq-sum,.signup button,.loader-word,.switcher button.on{
  background-size:220% 100%;animation:holoflow 7s ease-in-out infinite alternate}
.w-shift{animation-duration:5s}
.w-shift::before,.w-shift::after{background-size:220% 100%;animation:holoflow 5s ease-in-out infinite alternate;transition:transform .45s cubic-bezier(.2,.8,.2,1)}

/* gummy wordmark + diagonal light-sweep */
.wordmark{position:relative;transform-style:preserve-3d;will-change:transform}
.wordmark::after{content:"";position:absolute;inset:-16% -10%;pointer-events:none;z-index:3;
  background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.5) 50%,transparent 60%);
  transform:translateX(-180%) skewX(-12deg);mix-blend-mode:screen;
  animation:sheen 7s ease-in-out 1.8s infinite}
@keyframes sheen{0%{transform:translateX(-180%) skewX(-12deg)}24%{transform:translateX(180%) skewX(-12deg)}100%{transform:translateX(180%) skewX(-12deg)}}
.wordmark:hover .w-shift::before{transform:translateX(-.17em) scaleX(1.1)}
.wordmark:hover .w-shift::after{transform:translateX(-.32em) scaleX(1.2)}

/* SHIFT literally shifts — chromatic glitch */
@keyframes glitchpulse{
  0%{transform:translateX(0) skewX(0)}
  20%{transform:translateX(-6px) skewX(-5deg);filter:drop-shadow(5px 0 0 var(--magenta)) drop-shadow(-5px 0 0 var(--blue)) drop-shadow(0 4px 30px var(--wm-glow))}
  45%{transform:translateX(6px) skewX(4deg)}
  70%{transform:translateX(-3px) skewX(-2deg);filter:drop-shadow(4px 0 0 var(--green)) drop-shadow(-4px 0 0 var(--orange)) drop-shadow(0 4px 30px var(--wm-glow))}
  100%{transform:translateX(0) skewX(0);filter:drop-shadow(0 4px 30px var(--wm-glow))}}
.w-shift.glitching{animation:holoflow 5s ease-in-out infinite alternate,glitchpulse .42s steps(3) 1}

/* gummy smiley portal */
.hero-portal{cursor:pointer;transition:transform .55s cubic-bezier(.34,1.56,.64,1)}
.hero-portal:hover{transform:scale(1.07)}
.hero-portal:active{transform:scale(.93)}

/* NOW · SHIFT HAPPENS — pulsing climax of the timeline */
.era.now{animation:holoflow 5s ease-in-out infinite alternate,nowpulse 3.2s ease-in-out infinite}
@keyframes nowpulse{0%,100%{box-shadow:0 0 0 0 rgba(var(--glow),0)}50%{box-shadow:0 0 48px 2px rgba(var(--glow),.5)}}
