/* ============================================================
   AWRE KEYNOTE — Linear/Raycast type system + WebGL background
   One scroll. Eight beats. Punchy colour per section, no italics.
   Type: Inter, set tight. Labels: Spline Sans Mono.
   ============================================================ */

:root{
  /* deep ground */
  --bg:#0a0a0e;
  --bg2:#101016;
  --panel:#15151d;
  --panel-2:#1b1b25;
  --line:rgba(232,232,245,.10);
  --line-2:rgba(232,232,245,.06);
  --ink:#F3F3F6;
  --dim:#9b9bab;
  --faint:#5c5c6b;

  /* punchy section palette */
  --red:#FF4438;    --redb:#FF6A5E;
  --blue:#3D7BFF;   --blueb:#6E9DFF;
  --green:#13D183;  --greenb:#43E6A2;
  --orange:#FF8A00; --orangeb:#FFAE4D;
  --violet:#7C6BFF; --violetb:#9B8CFF;

  /* parallax field colours (retinted by moods) */
  --fld1:#FF4438;--fld2:#FF8A00;--fld3:#13D183;--fld4:#3D7BFF;--fld5:#7C6BFF;

  /* semantic anchors */
  --mint:var(--green);
  --gold:var(--orange);

  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --display:'Space Grotesk','Inter',sans-serif;
  --mono:'Spline Sans Mono',ui-monospace,monospace;

  /* punchy 4-colour gradient (red orange green blue) */
  --grad-punch:linear-gradient(100deg,#FF4438 0%,#FF8A00 30%,#13D183 62%,#3D7BFF 100%);
  --grad-blue:linear-gradient(135deg,#6E9DFF,#3D7BFF);
  --grad-warm:linear-gradient(120deg,#FF8A00,#FF4438 70%);

  --accent:var(--blueb);  /* per-beat, overridden below */
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);font-family:var(--sans);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;font-size:17px;line-height:1.5;position:relative;
  font-feature-settings:"cv11","ss01";
}
::selection{background:var(--blue);color:#fff}
a{color:inherit}

/* playful 3D parallax field (replaces the aurora) */
#field{position:fixed;inset:-6%;z-index:0;pointer-events:none;perspective:1100px;overflow:hidden}
#field::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 45% at 50% 8%,rgba(124,107,255,.10),transparent 70%)}
.fl-stage{position:absolute;inset:0;transform-style:preserve-3d;will-change:transform}
.fl-layer{position:absolute;left:0;right:0;top:0;height:310vh;will-change:transform}
.fl{position:absolute;--c:var(--fld1)}
.fl-orb{border-radius:50%;background:radial-gradient(circle at 35% 35%,var(--c),transparent 68%);filter:blur(34px);opacity:.32}
.fl-ring{border-radius:50%;border:2px solid var(--c);opacity:.5}
.fl-dot{border-radius:50%;background:var(--c);opacity:.85;box-shadow:0 0 14px var(--c)}
.fl-plus{background:linear-gradient(var(--c),var(--c)) center/100% 2.5px no-repeat,linear-gradient(var(--c),var(--c)) center/2.5px 100% no-repeat;opacity:.6}
.fl-sq{border:2px solid var(--c);border-radius:4px;transform:rotate(45deg);opacity:.45}
.fl-thread{background:linear-gradient(to bottom,transparent,var(--c) 30%,var(--c) 70%,transparent);border-radius:2px;opacity:.5}
@keyframes flBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
section.beat{will-change:transform}

/* filmic grain */
body::after{
  content:"";position:fixed;inset:-50%;z-index:50;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 9s steps(10) infinite;
}
@keyframes grain{0%,100%{transform:translate(0,0)}10%{transform:translate(-3%,2%)}30%{transform:translate(2%,-4%)}50%{transform:translate(-4%,-2%)}70%{transform:translate(3%,3%)}90%{transform:translate(-2%,4%)}}

/* scroll progress */
#progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:100;background:var(--grad-punch);transition:width .1s linear}

/* nav */
nav{position:fixed;top:0;left:0;right:0;z-index:90;display:flex;justify-content:space-between;align-items:center;
  padding:20px clamp(20px,4vw,52px);background:linear-gradient(to bottom,rgba(10,10,14,.88),transparent)}
nav .mark{font-weight:700;font-size:21px;letter-spacing:-.03em}
nav .mark i{font-style:normal;background:var(--grad-punch);-webkit-background-clip:text;background-clip:text;color:transparent}
nav .join{font-size:14px;font-weight:600;letter-spacing:-.01em;text-decoration:none;color:var(--ink);
  border:1px solid rgba(232,232,245,.22);border-radius:10px;padding:9px 18px;transition:all .3s cubic-bezier(.2,.7,.2,1)}
nav .join:hover{background:var(--grad-blue);border-color:transparent;color:#fff;box-shadow:0 8px 26px -8px rgba(61,123,255,.6)}

/* shared beat scaffold */
.beat{min-height:100vh;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1;
  padding:14vh clamp(20px,6vw,80px);max-width:1240px;margin:0 auto}
/* iter-7: on phones + tablets, the 100vh + 14vh padding + flex-center combo left huge blank
   bands between short sections (reads as buggy). Let beats size to content with a comfortable
   floor instead of forcing every beat to fill the viewport. */
@media(max-width:1024px){
  .beat{min-height:auto;padding:11vh clamp(20px,5vw,40px);justify-content:flex-start}
}
@media(max-width:640px){
  .beat{padding:9vh 22px}
}
.kick{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:26px;
  display:inline-flex;align-items:center;gap:10px;font-weight:500;white-space:nowrap;max-width:100%}
@media(max-width:560px){.kick{white-space:normal}}
.kick::before{content:none}
h1,h2{font-weight:680;letter-spacing:-.035em;line-height:1.04}
.sub{color:var(--dim);font-size:clamp(17px,1.6vw,21px);line-height:1.55;max-width:54ch;font-weight:400}
em{font-style:normal}
.grad{background:var(--grad-punch);-webkit-background-clip:text;background-clip:text;color:transparent}

/* scroll reveal — springy, playful */
.rv{opacity:0;transform:translateY(42px) scale(.96);transition:opacity .7s ease,transform .95s cubic-bezier(.34,1.45,.4,1)}
.rv.in{opacity:1;transform:none}
.rv.dl1{transition-delay:.1s}.rv.dl2{transition-delay:.22s}.rv.dl3{transition-delay:.36s}.rv.dl4{transition-delay:.52s}
/* iter-7: hero is the first impression — kill the latent feel with shorter delays + faster ease */
#hero .rv{transition:opacity .45s ease,transform .55s cubic-bezier(.2,.7,.2,1)}
#hero .rv.dl1{transition-delay:.04s}
#hero .rv.dl2{transition-delay:.14s}
#hero .rv.dl3{transition-delay:.26s}

/* ============ BEAT 0 — HERO (blue) ============ */
#hero{--accent:var(--blueb);min-height:100vh;text-align:center;align-items:center;justify-content:center}
#hero h1{font-size:clamp(44px,7.4vw,108px);line-height:1.0;max-width:15ch;font-weight:720;letter-spacing:-.045em}
#hero h1 b{font-weight:720;background:var(--grad-blue);-webkit-background-clip:text;background-clip:text;color:transparent}
#hero .sub{margin:32px auto 0;text-align:center}
#hero .kick{justify-content:center}
#hero .cue{position:absolute;bottom:5vh;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--faint);font-family:var(--mono);font-size:11.5px;letter-spacing:.22em;text-transform:uppercase}
#hero .cue .ln{width:1px;height:52px;background:linear-gradient(var(--blueb),transparent);animation:cue 2.4s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.4}50%{transform:scaleY(1);opacity:1}}
.dust{position:absolute;inset:0;overflow:hidden;pointer-events:none}
/* iter-7: bump dust prominence — reviewers were missing the problem-thoughts behind hero */
.dust span{position:absolute;font-family:var(--mono);font-size:14px;font-weight:500;white-space:nowrap;opacity:0;animation:drift var(--t,26s) linear infinite;animation-delay:var(--d,0s)}
@keyframes drift{0%{opacity:0;transform:translateY(16px)}12%{opacity:var(--o,.16)}82%{opacity:var(--o,.16)}100%{opacity:0;transform:translateY(-58px)}}

/* ============ BEAT 1 — TUESDAY (red) ============ */
#tuesday{--accent:var(--redb)}
#tuesday .stagegrid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,72px);align-items:center;margin-top:5vh}
@media(max-width:880px){#tuesday .stagegrid{grid-template-columns:1fr}}
#tuesday h2{font-size:clamp(34px,4.6vw,62px);line-height:1.04;max-width:17ch}
#tuesday .punch{margin-top:28px;font-size:clamp(19px,2vw,25px);color:var(--dim);line-height:1.45;max-width:40ch;font-weight:450;
  opacity:0;transform:translateY(14px);transition:all .9s ease .2s}
#tuesday .punch.show{opacity:1;transform:none}
#tuesday .punch b{color:var(--redb);font-weight:600}
.feedwrap{position:relative;border:1px solid var(--line);border-radius:18px;background:rgba(16,16,22,.72);backdrop-filter:blur(8px);overflow:hidden;height:430px;
  box-shadow:0 40px 90px -40px rgba(255,68,56,.22),0 30px 60px -40px rgba(0,0,0,.8)}
.feedhead{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:12px;color:var(--dim)}
.feedhead .clock{font-size:21px;color:var(--ink);font-weight:500;font-variant-numeric:tabular-nums}
.feedhead .shipped{color:var(--red)}
.feed{position:absolute;inset:53px 0 0 0;padding:14px 16px;display:flex;flex-direction:column;gap:9px;overflow:hidden}
.msg{background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:10px 13px;font-size:13.5px;line-height:1.4;color:var(--dim);flex-shrink:0;
  opacity:0;transform:translateY(-14px);transition:opacity .45s,transform .45s cubic-bezier(.2,.7,.2,1)}
.msg.in{opacity:1;transform:none}
.msg .who{font-family:var(--mono);font-size:11px;letter-spacing:.02em;margin-bottom:3px;display:flex;justify-content:space-between;color:var(--blueb);font-weight:500}
.msg .who .t{color:var(--faint)}
/* colourful noise — punchy voices */
.msg:nth-child(4n+1) .who{color:var(--redb)}     .msg:nth-child(4n+1){border-color:rgba(255,68,56,.26)}
.msg:nth-child(4n+2) .who{color:var(--orangeb)}  .msg:nth-child(4n+2){border-color:rgba(255,138,0,.26)}
.msg:nth-child(4n+3) .who{color:var(--greenb)}   .msg:nth-child(4n+3){border-color:rgba(19,209,131,.24)}
.msg:nth-child(4n+4) .who{color:var(--blueb)}    .msg:nth-child(4n+4){border-color:rgba(61,123,255,.26)}
.feed::after{content:"";position:absolute;left:0;right:0;bottom:0;height:120px;background:linear-gradient(transparent,#0c0c12);pointer-events:none}

/* ============ BEAT 2 — PROMISES (orange) ============ */
#promises{--accent:var(--orangeb);text-align:center;align-items:center}
#promises h2{font-size:clamp(36px,5.4vw,74px);line-height:1.03;letter-spacing:-.04em}
#promises h2 .n{font-variant-numeric:tabular-nums;background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;color:transparent}
#promises .chipfield{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;max-width:880px;margin:6vh auto 0;perspective:600px}
.chip{font-family:var(--mono);font-size:12.5px;background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:8px 15px;white-space:nowrap;color:var(--dim);
  opacity:0;transform:translateY(22px) scale(.85);transition:opacity .5s,transform .65s cubic-bezier(.34,1.6,.45,1),border-color .4s,color .4s}
.chip.in{opacity:1;transform:none}
.chip:nth-child(4n+1){color:var(--redb);border-color:rgba(255,68,56,.4)}
.chip:nth-child(4n+2){color:var(--orangeb);border-color:rgba(255,138,0,.42)}
.chip:nth-child(4n+3){color:var(--greenb);border-color:rgba(19,209,131,.38)}
.chip:nth-child(4n+4){color:var(--blueb);border-color:rgba(61,123,255,.4)}
.chip.drop{animation:fall 1.3s cubic-bezier(.5,0,.8,.4) forwards;border-color:rgba(255,68,56,.75)!important;color:var(--red)!important}
@keyframes fall{0%{opacity:1;transform:none}25%{transform:translateY(6px) rotate(-2deg)}100%{opacity:0;transform:translateY(46vh) rotate(var(--rot,10deg)) scale(.85)}}
#promises .tally{margin-top:5vh;font-size:clamp(20px,2.2vw,28px);color:var(--dim);font-weight:450;opacity:0;transform:translateY(14px);transition:all .9s ease}
#promises .tally.show{opacity:1;transform:none}
#promises .tally b{color:var(--red);font-weight:700}
#promises .cost{margin-top:11vh;opacity:0;transform:translateY(18px);transition:opacity .5s ease,transform .55s cubic-bezier(.2,.7,.2,1)}
#promises .cost.show{opacity:1;transform:none}
#promises .cost .big{font-weight:740;font-size:clamp(64px,11vw,164px);line-height:1;letter-spacing:-.05em;font-variant-numeric:tabular-nums;
  background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 70px rgba(255,68,56,.22))}
#promises .cost .why{margin:22px auto 0;color:var(--dim);font-size:clamp(16px,1.5vw,19px);max-width:46ch;line-height:1.6}
#promises .cost .why b{color:var(--ink);font-weight:600}
#promises .cost .src{margin-top:14px;font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}

/* ============ BEAT 3 — REVEAL (green) ============ */
#reveal{--accent:var(--greenb);min-height:130vh;text-align:center;align-items:center;justify-content:center}
#reveal .pre{font-weight:480;font-size:clamp(24px,3vw,40px);line-height:1.3;color:var(--dim);max-width:26ch;margin:0 auto;letter-spacing:-.02em}
#reveal .pre b{color:var(--ink);font-weight:680}
#reveal .meet{margin-top:10vh;font-weight:740;font-size:clamp(58px,10vw,150px);letter-spacing:-.05em;line-height:1}
#reveal .meet i{font-style:normal;background:var(--grad-punch);-webkit-background-clip:text;background-clip:text;color:transparent;background-size:200% auto;animation:hue 9s ease infinite}
@keyframes hue{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
#reveal .halo{width:11px;height:11px;border-radius:50%;background:#fff;margin:7vh auto 0;position:relative;animation:breathe 3.4s ease-in-out infinite}
#reveal .halo::before,#reveal .halo::after{content:"";position:absolute;inset:-16px;border-radius:50%;border:1.5px solid rgba(19,209,131,.5);animation:ripple 3.4s ease-out infinite}
#reveal .halo::after{animation-delay:1.7s;border-color:rgba(61,123,255,.5)}
@keyframes breathe{0%,100%{box-shadow:0 0 20px 3px rgba(19,209,131,.6),0 0 40px 8px rgba(61,123,255,.3)}50%{box-shadow:0 0 40px 10px rgba(255,138,0,.45),0 0 70px 18px rgba(255,68,56,.3)}}
@keyframes ripple{0%{transform:scale(.4);opacity:.85}100%{transform:scale(3.6);opacity:0}}
#reveal .after{margin-top:7vh;color:var(--dim);font-size:clamp(17px,1.6vw,21px);max-width:46ch;line-height:1.6}

/* ============ BEAT 4 — DEMO (blue) ============ */
#demo{--accent:var(--blueb)}
#demo h2{font-size:clamp(32px,4.4vw,58px);line-height:1.05;max-width:20ch}
.theater{margin-top:6vh;border:1px solid var(--line);border-radius:20px;background:rgba(16,16,22,.78);backdrop-filter:blur(8px);box-shadow:0 60px 130px -50px rgba(61,123,255,.3),0 40px 80px -50px rgba(0,0,0,.85);overflow:hidden}
/* iter-7: theater is the demo's anchor — pure fade, no transform / no delay.
   Any translateY on a 500px-tall card mid-scroll reads as the page jerking. */
#demo .theater.rv{transform:none;transition:opacity .5s ease;transition-delay:0s!important}
#demo .theater.rv.in{transform:none}
.thead{display:flex;align-items:center;gap:8px;padding:13px 18px;border-bottom:1px solid var(--line)}
.thead .dot{width:9px;height:9px;border-radius:50%}
.thead .dot:nth-child(1){background:var(--red)}.thead .dot:nth-child(2){background:var(--orange)}.thead .dot:nth-child(3){background:var(--green)}
.thead .ttl{margin-left:8px;font-family:var(--mono);font-size:12px;color:var(--dim);letter-spacing:.06em}
.thead .day{margin-left:auto;font-family:var(--mono);font-size:12px;color:var(--blueb);letter-spacing:.1em;transition:color .5s}
.stage{position:relative;height:480px;padding:26px clamp(16px,3vw,34px)}
@media(max-width:640px){.stage{height:560px}}
.scene{position:absolute;inset:26px clamp(16px,3vw,34px);opacity:0;transform:translateY(16px);transition:opacity .7s,transform .7s cubic-bezier(.2,.7,.2,1);pointer-events:none}
.scene.on{opacity:1;transform:none}
.slackmsg{max-width:520px;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px 19px}
.slackmsg .who{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.slackmsg .av{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#6E9DFF,#3D7BFF);display:grid;place-items:center;font-weight:700;font-size:13px;color:#08122e}
.slackmsg .nm{font-weight:600;font-size:14.5px}
.slackmsg .tm{font-family:var(--mono);font-size:11px;color:var(--faint)}
.slackmsg .txt{font-size:15.5px;line-height:1.5;color:var(--ink)}
.slackmsg .txt mark{background:transparent;color:inherit;border-radius:4px;padding:1px 3px;transition:background .8s,color .8s}
.slackmsg .txt mark.lit{background:rgba(61,123,255,.2);color:var(--blueb)}
.yousaid{margin-top:14px;max-width:520px;display:flex;gap:10px;align-items:flex-start;opacity:0;transform:translateY(10px);transition:all .6s ease}
.yousaid.on{opacity:1;transform:none}
.yousaid .av{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#FFAE4D,#FF8A00);display:grid;place-items:center;font-weight:700;font-size:13px;color:#2a1900;flex-shrink:0}
.yousaid .bub{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:12px 16px;font-size:15px;color:var(--dim)}
.yousaid .bub b{color:var(--ink);font-weight:600}
.catchcard{max-width:480px;margin:0 auto;background:linear-gradient(160deg,rgba(255,138,0,.10),var(--bg2));border:1px solid rgba(255,138,0,.45);border-radius:16px;padding:20px 22px;box-shadow:0 24px 70px -24px rgba(255,138,0,.3)}
.catchcard .lab{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);display:flex;align-items:center;gap:9px;margin-bottom:12px}
.catchcard .lab::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--orange);box-shadow:0 0 12px rgba(255,138,0,.9)}
.catchcard .what{font-size:17px;font-weight:600;line-height:1.45;color:var(--ink)}
.catchcard .meta{display:flex;gap:18px;flex-wrap:wrap;margin-top:14px;padding-top:13px;border-top:1px solid rgba(255,138,0,.18);font-family:var(--mono);font-size:12px;color:var(--dim)}
.catchcard .meta b{color:var(--ink);font-weight:500}
.threadline{width:1px;margin:10px auto;background:linear-gradient(var(--orange),transparent);height:0;transition:height .9s ease}
.threadline.grow{height:44px}
.filedrow{display:flex;justify-content:center;gap:8px;font-family:var(--mono);font-size:12px;color:var(--faint);opacity:0;transition:opacity .7s ease;text-align:center}
.filedrow.on{opacity:1}
.filedrow b{color:var(--orange);font-weight:500}
.surface{max-width:560px;margin:0 auto;background:linear-gradient(160deg,rgba(19,209,131,.08),var(--panel));border:1px solid rgba(19,209,131,.42);border-radius:16px;padding:21px 24px;box-shadow:0 24px 80px -24px rgba(19,209,131,.28)}
.surface .lab{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--green);display:flex;align-items:center;gap:9px;margin-bottom:13px}
.surface .lab::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 12px rgba(19,209,131,.9)}
.surface .say{font-size:clamp(17px,1.8vw,21px);line-height:1.5;color:var(--ink);font-weight:450;letter-spacing:-.01em}
.surface .say b{color:var(--green);font-weight:600}
.surface .attach{margin-top:15px;border:1px dashed rgba(232,232,245,.22);border-radius:11px;padding:11px 15px;display:flex;align-items:center;gap:11px;font-family:var(--mono);font-size:12.5px;color:var(--dim)}
.surface .attach .ic{color:var(--green)}
.surface .acts{display:flex;gap:10px;margin-top:17px}
.surface .acts button{font-family:var(--sans);font-size:13.5px;font-weight:600;padding:9px 18px;border-radius:9px;cursor:pointer;border:1px solid rgba(232,232,245,.22);background:transparent;color:var(--dim)}
.surface .acts .go{background:var(--green);border-color:var(--green);color:#04271a;animation:nudge 2.2s ease-in-out infinite}
@keyframes nudge{0%,100%{box-shadow:0 0 0 0 rgba(19,209,131,.5)}50%{box-shadow:0 0 0 10px rgba(19,209,131,0)}}
.caps{display:flex;gap:0;border-top:1px solid var(--line)}
.cap{flex:1;padding:17px 18px;font-size:13.5px;line-height:1.45;color:var(--faint);border-right:1px solid var(--line);transition:color .5s;position:relative}
.cap:last-child{border-right:none}
.cap::before{content:"";position:absolute;top:-1px;left:0;height:2px;width:0;transition:width .5s}
.cap#cp1::before{background:var(--blueb)}.cap#cp2::before{background:var(--orange)}.cap#cp3::before{background:var(--green)}
.cap.live{color:var(--ink)}
.cap.live::before{width:100%}
.cap .n{font-family:var(--mono);font-size:11px;letter-spacing:.16em;display:block;margin-bottom:5px}
.cap#cp1 .n{color:var(--blueb)}.cap#cp2 .n{color:var(--orange)}.cap#cp3 .n{color:var(--green)}
@media(max-width:640px){.caps{flex-direction:column}.cap{border-right:none;border-bottom:1px solid var(--line)}}
#demo .wedge{margin-top:7vh;text-align:center;font-weight:600;font-size:clamp(28px,4vw,52px);line-height:1.2;letter-spacing:-.03em}
#demo .wedge i{background:var(--grad-blue);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:normal}

/* ============ BEAT 5 — SAME WEEK TWICE (green) ============ */
#twice{--accent:var(--greenb)}
#twice h2{font-size:clamp(32px,4.4vw,58px);line-height:1.04}
.weeks{display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,2.5vw,28px);margin-top:6vh}
@media(max-width:760px){.weeks{grid-template-columns:1fr}}
.lane{border:1px solid var(--line);border-radius:18px;background:rgba(16,16,22,.7);backdrop-filter:blur(6px);padding:22px 22px 26px;position:relative;overflow:hidden}
.lane#lane-a{border-color:rgba(255,68,56,.28);box-shadow:0 30px 70px -40px rgba(255,68,56,.2)}
.lane.with{border-color:rgba(19,209,131,.34);box-shadow:0 30px 70px -40px rgba(19,209,131,.24)}
.lane .lt{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim);margin-bottom:20px}
.lane#lane-a .lt{color:var(--red)}
.lane.with .lt{color:var(--green)}
.lane .score{font-size:19px;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:0}
.lane .score .of{color:var(--faint)}
.days{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.day{font-family:var(--mono);font-size:10.5px;color:var(--faint);text-align:center;letter-spacing:.1em}
.lane .track{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:9px;min-height:172px;align-items:start}
.pcol{display:flex;flex-direction:column;gap:7px}
.pdot{height:26px;border-radius:7px;border:1px solid var(--line);background:var(--panel);display:grid;place-items:center;font-family:var(--mono);font-size:10px;color:var(--dim);
  opacity:0;transform:scale(.85);transition:all .5s cubic-bezier(.2,.7,.2,1)}
.pdot.in{opacity:1;transform:none}
.pdot.dead{border-color:rgba(255,68,56,.45);color:var(--red);text-decoration:line-through;opacity:.4;transform:scale(.94) rotate(-1.5deg)}
.pdot.kept{border-color:rgba(19,209,131,.5);color:var(--green);background:rgba(19,209,131,.08)}
.lane .verdict{margin-top:18px;font-size:16px;color:var(--faint);transition:color .5s;font-weight:450}
.lane#lane-a .verdict.show{color:var(--red)}
.lane.with .verdict.show{color:var(--green)}
.hundred{margin-top:13vh;text-align:center}
.hundred .small{font-weight:480;font-size:clamp(24px,3vw,40px);color:var(--dim);line-height:1.25;letter-spacing:-.02em}
.hundred .small b{color:var(--ink);font-weight:680}
.hundred .meganum{font-weight:760;font-size:clamp(120px,24vw,340px);line-height:.95;letter-spacing:-.06em;font-variant-numeric:tabular-nums;margin-top:3vh;
  background:var(--grad-punch);-webkit-background-clip:text;background-clip:text;color:transparent;background-size:200% auto;animation:hue 8s ease infinite;filter:drop-shadow(0 0 70px rgba(61,123,255,.3))}
.hundred .runline{font-weight:600;font-size:clamp(26px,3.4vw,46px);margin-top:1vh;line-height:1.2;letter-spacing:-.03em}
.hundred .runline i{background:var(--grad-punch);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:normal}
.hundred .how{margin:5vh auto 0;color:var(--dim);font-size:clamp(16px,1.55vw,20px);max-width:46ch;line-height:1.65}
.hundred .how b{color:var(--ink);font-weight:600}

/* ============ BEAT 6 — COVENANT (orange) ============ */
#covenant{--accent:var(--orangeb);text-align:center;align-items:center}
#covenant h2{font-size:clamp(32px,4.6vw,60px);line-height:1.08;max-width:18ch}
#covenant h2 em{background:var(--grad-punch);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:normal}
.vows{margin-top:7vh;display:grid;gap:0;max-width:740px;width:100%;border-top:1px solid var(--line)}
.vow{padding:32px 8px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;gap:26px;text-align:left}
.vow .no{font-family:var(--mono);font-size:12px;letter-spacing:.16em;padding-top:9px;flex-shrink:0}
.vow:nth-child(1) .no{color:var(--red)}.vow:nth-child(2) .no{color:var(--orange)}.vow:nth-child(3) .no{color:var(--green)}
.vow .vt{font-weight:560;font-size:clamp(20px,2.3vw,28px);line-height:1.3;color:var(--ink);letter-spacing:-.02em}
.vow .vt b{font-weight:680}
.vow:nth-child(1) .vt b{color:var(--redb)}.vow:nth-child(2) .vt b{color:var(--orangeb)}.vow:nth-child(3) .vt b{color:var(--greenb)}
.vow .vd{margin-top:8px;color:var(--dim);font-size:15.5px;line-height:1.55;max-width:52ch}
#covenant .creed{margin-top:8vh;font-weight:480;font-size:clamp(22px,2.8vw,36px);color:var(--dim);letter-spacing:-.02em}
#covenant .creed b{color:var(--ink);font-weight:700}

/* ============ BEAT 7 — CLOSE (blue) ============ */
#close{--accent:var(--blueb);text-align:center;align-items:center;min-height:110vh}
#close h2{font-size:clamp(44px,8vw,112px);line-height:1.0;font-weight:740;letter-spacing:-.045em}
#close h2 i{background:var(--grad-punch);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:normal;background-size:200% auto;animation:hue 9s ease infinite}
#close .sub{margin:28px auto 0;text-align:center}
#close .sub b{color:var(--blueb);font-weight:600}
.wl{margin-top:6vh;display:flex;gap:10px;width:min(520px,92vw)}
.wl input{flex:1;background:rgba(16,16,22,.8);border:1px solid rgba(232,232,245,.22);border-radius:13px;padding:17px 20px;font-family:var(--sans);font-size:16px;color:var(--ink);outline:none;transition:border-color .3s,box-shadow .3s}
.wl input::placeholder{color:var(--faint)}
.wl input:focus{border-color:var(--blueb);box-shadow:0 0 0 3px rgba(61,123,255,.22)}
.wl button{font-family:var(--sans);font-size:16px;font-weight:700;letter-spacing:-.01em;color:#fff;background:var(--grad-blue);border:none;border-radius:13px;padding:17px 28px;cursor:pointer;white-space:nowrap;transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .3s}
.wl button:hover{transform:translateY(-2px);box-shadow:0 16px 44px -10px rgba(61,123,255,.6)}
.wl.done input{border-color:var(--green)}
.wl.done button{background:var(--green);color:#04271a}
#close .fine{margin-top:22px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--faint)}
#close .sig{margin-top:13vh;font-size:16px;color:var(--faint);font-weight:450}
footer{position:relative;z-index:1;padding:30px;text-align:center;font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;color:var(--faint);border-top:1px solid var(--line)}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none!important;transition-duration:.01s!important}
  html{scroll-behavior:auto}
}

/* === Light theme === */
html[data-ktheme="light"]{
  --bg:#f3f3f7;--bg2:#ffffff;--panel:#ffffff;--panel-2:#f3f3f7;
  --line:rgba(20,20,32,.12);--line-2:rgba(20,20,32,.06);
  --ink:#16161d;--dim:#55555f;--faint:#9a9aa8;
}
html[data-ktheme="light"] body::after{opacity:.025}
html[data-ktheme="light"] #field{opacity:.5}
html[data-ktheme="light"] nav{background:linear-gradient(to bottom,rgba(243,243,247,.9),transparent)}
html[data-ktheme="light"] .feedwrap,
html[data-ktheme="light"] .theater,
html[data-ktheme="light"] .lane{background:rgba(255,255,255,.74)}
html[data-ktheme="light"] .wl input{background:rgba(255,255,255,.86)}
html[data-ktheme="light"] .feed::after{background:linear-gradient(transparent,#ffffff)}
html[data-ktheme="light"] .msg,
html[data-ktheme="light"] .chip,
html[data-ktheme="light"] .pdot,
html[data-ktheme="light"] .slackmsg,
html[data-ktheme="light"] .yousaid .bub{background:#ffffff}

/* === Colour moods (recolour the big gradients) === */
html[data-kmood="cool"]{--grad-punch:linear-gradient(100deg,#46D4EA,#3D7BFF 60%,#7C6BFF);--grad-warm:var(--grad-blue);--fld1:#46D4EA;--fld2:#3D7BFF;--fld3:#7C6BFF;--fld4:#6E9DFF;--fld5:#46D4EA}
html[data-kmood="warm"]{--grad-punch:linear-gradient(100deg,#FF4438,#FF8A00 70%,#FFAE4D);--grad-blue:linear-gradient(135deg,#FFAE4D,#FF8A00);--fld1:#FF4438;--fld2:#FF8A00;--fld3:#FFAE4D;--fld4:#FF6A5E;--fld5:#FF8A00}
html[data-kmood="green"]{--grad-punch:linear-gradient(100deg,#13D183,#0FBE9A 55%,#3D7BFF);--grad-warm:linear-gradient(120deg,#43E6A2,#13D183);--fld1:#13D183;--fld2:#43E6A2;--fld3:#0FBE9A;--fld4:#3D7BFF;--fld5:#13D183}

/* === Floating theme control (bottom-right) === */
#ktheme{position:fixed;right:20px;bottom:20px;z-index:95;display:flex;align-items:center;gap:12px;
  padding:9px 12px;border-radius:14px;background:rgba(20,20,28,.62);border:1px solid var(--line);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 16px 40px -16px rgba(0,0,0,.6)}
html[data-ktheme="light"] #ktheme{background:rgba(255,255,255,.7);box-shadow:0 16px 40px -18px rgba(20,20,40,.28)}
#ktheme .kt-mode{width:34px;height:34px;display:grid;place-items:center;border-radius:9px;cursor:pointer;
  border:1px solid var(--line);background:transparent;color:var(--ink);transition:background .2s,transform .12s}
#ktheme .kt-mode:hover{background:var(--line-2)}
#ktheme .kt-mode:active{transform:scale(.94)}
#ktheme .kt-sep{width:1px;height:22px;background:var(--line)}
#ktheme .kt-moods{display:flex;gap:8px}
#ktheme .kt-dot{width:18px;height:18px;padding:0;border-radius:50%;cursor:pointer;border:none;
  box-shadow:0 0 0 1px var(--line);transition:transform .12s,box-shadow .15s}
#ktheme .kt-dot:hover{transform:scale(1.12)}
#ktheme .kt-dot.on{box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--ink)}
#ktheme .kt-spectrum{background:conic-gradient(from 210deg,#FF4438,#FF8A00,#13D183,#3D7BFF,#7C6BFF,#FF4438)}
@media(max-width:560px){#ktheme{right:12px;bottom:12px;padding:8px 10px;gap:9px}}

/* === Headings — distinct display face, never hyphenate, balanced wrap === */
nav .mark,
h1,h2,
#hero h1,#hero h1 b,
#reveal .meet,#reveal .meet i,
#promises h2,#promises .cost .big,
#demo h2,#demo .wedge,#demo .wedge i,
.hundred .small,.hundred .runline,.hundred .runline i,.hundred .meganum,
.vow .vt,.vow .vt b,#covenant h2,#covenant h2 em,#covenant .creed,
#close h2,#close h2 i,#tuesday h2,#twice h2{
  font-family:var(--display);
  -webkit-hyphens:none;hyphens:none;
  overflow-wrap:normal;word-break:keep-all;
  text-wrap:balance;
}
h1,h2{font-weight:600;letter-spacing:-.02em;line-height:1.08}
#hero h1{font-weight:600;letter-spacing:-.02em;line-height:1.06;max-width:18ch}
#hero h1 b{font-weight:600}
#tuesday h2{letter-spacing:-.02em}
#promises h2{letter-spacing:-.022em}
#promises .cost .big{font-weight:700;letter-spacing:-.03em}
#reveal .meet{font-weight:600;letter-spacing:-.025em}
#demo .wedge{font-weight:600;letter-spacing:-.018em}
#twice h2{letter-spacing:-.02em}
.hundred .small{font-weight:500;letter-spacing:-.012em}
.hundred .runline{font-weight:600;letter-spacing:-.018em}
.hundred .meganum{font-weight:700;letter-spacing:-.04em}
.vow .vt{font-weight:600;letter-spacing:-.012em}
.vow .vt b{font-weight:700}
#covenant .creed{font-weight:500;letter-spacing:-.012em}
#close h2{font-weight:600;letter-spacing:-.022em}
nav .mark{font-weight:700;letter-spacing:-.03em}

/* ============ SOLID POSTER MODE — punchy solid colour per section ============ */
body{background:#2E5FE3}
#progress{background:rgba(255,255,255,.92)}

/* kill every gradient text — solid accent words instead */
.grad,#hero h1 b,#reveal .meet i,#close h2 i,#demo .wedge i,.hundred .runline i,.hundred .meganum,#promises .cost .big,#promises h2 .n,nav .mark i,#covenant h2 em{
  background:none!important;-webkit-background-clip:border-box!important;background-clip:border-box!important;
  color:var(--aw,#FFC53D)!important;animation:none!important;filter:none!important}
.wl button{background:#3D7BFF}
.wl.done button{background:#13D183}
nav .join:hover{background:#FFC53D;border-color:#FFC53D;color:#16161d;box-shadow:none}
#hero .cue .ln{background:rgba(255,255,255,.6)}
.dust span{color:rgba(255,255,255,.6)!important}

/* per-section accents (dark mode) */
#hero{--accent:#FFC53D;--aw:#FFC53D}
#tuesday{--accent:#FFD34D;--aw:#FFD34D}
#tuesday .punch b{color:#FFD34D}
#tuesday .feedwrap{box-shadow:0 40px 90px -40px rgba(0,0,0,.5)}
#promises{--aw:#FF8A00}
#reveal{--accent:#FFD34D;--aw:#FFC53D}
#demo{--aw:#6E9DFF}
#twice{--accent:#FFC53D;--aw:#FFC53D;--dim:rgba(255,255,255,.82);--faint:rgba(255,255,255,.55)}
#covenant{--accent:#FFD34D;--aw:#fff}
#covenant .vow .no{color:#FFD34D}
#covenant .vow .vt b{color:#FFD34D}
#close{--aw:#5B9BFF}
html:not([data-ktheme="light"]) #hero,html:not([data-ktheme="light"]) #tuesday,html:not([data-ktheme="light"]) #twice,html:not([data-ktheme="light"]) #reveal,html:not([data-ktheme="light"]) #covenant{
  --dim:rgba(255,255,255,.84);--faint:rgba(255,255,255,.58);--line:rgba(255,255,255,.2)}

/* parallax shapes → white confetti over the solid colours */
#field::before{content:none}
.fl-orb{display:none}
.fl-ring{border-color:rgba(255,255,255,.55)}
.fl-dot{background:rgba(255,255,255,.9);box-shadow:0 0 14px rgba(255,255,255,.5)}
.fl-plus{background:linear-gradient(rgba(255,255,255,.6),rgba(255,255,255,.6)) center/100% 2.5px no-repeat,linear-gradient(rgba(255,255,255,.6),rgba(255,255,255,.6)) center/2.5px 100% no-repeat}
.fl-sq{border-color:rgba(255,255,255,.5)}
.fl-thread{background:linear-gradient(to bottom,transparent,rgba(255,255,255,.5) 30%,rgba(255,255,255,.5) 70%,transparent)}
html[data-ktheme="light"] .fl-thread{background:linear-gradient(to bottom,transparent,rgba(20,20,35,.3) 30%,rgba(20,20,35,.3) 70%,transparent)}
html[data-ktheme="light"] .fl-ring{border-color:rgba(20,20,35,.3)}
html[data-ktheme="light"] .fl-dot{background:rgba(20,20,35,.45);box-shadow:none}
html[data-ktheme="light"] .fl-plus{background:linear-gradient(rgba(20,20,35,.35),rgba(20,20,35,.35)) center/100% 2.5px no-repeat,linear-gradient(rgba(20,20,35,.35),rgba(20,20,35,.35)) center/2.5px 100% no-repeat}
html[data-ktheme="light"] .fl-sq{border-color:rgba(20,20,35,.3)}

/* light theme — pastel grounds, deep accents */
html[data-ktheme="light"] #hero{--accent:#1D49D6;--aw:#1D49D6}
html[data-ktheme="light"] #tuesday{--accent:#C22A1F;--aw:#C22A1F}
html[data-ktheme="light"] #tuesday .punch b{color:#C22A1F}
html[data-ktheme="light"] #promises{--aw:#D96400}
html[data-ktheme="light"] #reveal{--aw:#0A7A4B;--accent:#0A7A4B}
html[data-ktheme="light"] #demo{--aw:#2E5FE3}
html[data-ktheme="light"] #twice{--accent:#4636D6;--aw:#4636D6;--dim:rgba(22,22,40,.7);--faint:rgba(22,22,40,.45)}
html[data-ktheme="light"] #covenant{--aw:#8a4a00}
html[data-ktheme="light"] #covenant .vow .no{color:#8a4a00}
html[data-ktheme="light"] #covenant .vow .vt b{color:#B55400}
html[data-ktheme="light"] #close{--aw:#2E5FE3}
