:root{
  --cream:#F6EDE2;
  --ink:#161616;
  --ink-soft:#1f1e1d;
  --ink-card:#201f1d;
  --coral:#E85E5A;
  --gold:#F6C05D;
  --cream-dim:rgba(246,237,226,0.62);
  --cream-faint:rgba(246,237,226,0.14);
  --line:rgba(246,237,226,0.12);

  --display:'Barlow Condensed', sans-serif;
  --body:'General Sans', 'Inter', sans-serif;
  --mono:'JetBrains Mono', monospace;

  --container: 1120px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--ink);
  color:var(--cream);
  font-family:var(--body);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--coral); color:var(--cream); }
a:focus-visible, button:focus-visible{
  outline:2px solid var(--gold); outline-offset:3px; border-radius:4px;
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.001ms !important;
    scroll-behavior:auto !important;
  }
}

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

/* film-grain atmosphere over the whole page */
.grain{
  pointer-events:none;
  position:fixed; inset:0; z-index:2;
  opacity:0.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  padding:20px 0;
  transition:background .35s ease, border-color .35s ease, padding .35s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(22,22,22,0.82);
  backdrop-filter:blur(14px);
  border-bottom-color:var(--line);
  padding:14px 0;
}
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; }
.nav-brand{
  display:flex; align-items:center; gap:8px; font-family:var(--display); font-weight:700; font-size:22px; letter-spacing:.02em;
  transition:opacity .2s ease;
}
.nav-brand:hover{ opacity:.8; }
.nav-brand .nav-ghost{ width:24px; height:auto; }
.nav-links{ display:flex; align-items:center; gap:28px; font-size:14px; color:var(--cream-dim); }
.nav-links a{ transition:color .2s ease; cursor:pointer; }
.nav-links a:hover{ color:var(--cream); }
.nav-cta{
  padding:9px 18px; border-radius:100px;
  background:var(--cream); color:var(--ink);
  font-weight:600; font-size:13.5px;
  transition:transform .25s cubic-bezier(.34,1.56,.64,1), background .2s ease;
  display:inline-block;
}
.nav-cta:hover{ transform:translateY(-2px); background:var(--gold); }

/* ---------- hero ---------- */
.hero{
  position:relative;
  min-height:100svh;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center;
  padding:120px 24px 100px;
  overflow:hidden;
}
.hero-glow{
  position:absolute; z-index:0; pointer-events:none;
  width:900px; height:900px; border-radius:50%;
  top:-320px; left:50%; transform:translateX(-50%);
  background:radial-gradient(circle, rgba(232,94,90,0.16) 0%, rgba(232,94,90,0) 62%);
}
.hero-glow.gold{
  width:600px;height:600px; top:auto; bottom:-260px; left:60%;
  background:radial-gradient(circle, rgba(246,192,93,0.13) 0%, rgba(246,192,93,0) 65%);
}
.eyebrow{
  position:relative; z-index:1;
  font-family:var(--display); font-style:italic; font-weight:600;
  font-size:clamp(22px,3vw,30px);
  color:var(--cream-dim);
  display:flex; align-items:center; gap:10px; justify-content:center;
  opacity:0; transform:translateY(14px);
  animation:riseIn .7s .05s ease forwards;
}
.eyebrow svg{ width:20px; height:20px; }
.wordmark{
  position:relative; z-index:1;
  font-family:var(--display); font-weight:800;
  font-size:clamp(80px,16vw,190px);
  line-height:.86; letter-spacing:-.02em;
  margin:-10px 0 4px;
  opacity:0; transform:translateY(22px);
  animation:riseIn .8s .18s ease forwards;
}
.hero-stage{
  position:relative; z-index:1;
  width:min(300px,52vw); margin:2px auto 18px;
  opacity:0; transform:translateY(26px) scale(.94);
  animation:riseIn .85s .32s cubic-bezier(.2,.7,.2,1) forwards;
}
.subtitle{
  position:relative; z-index:1;
  max-width:560px; margin:0 auto;
  font-size:clamp(16px,2vw,19px); line-height:1.55;
  color:var(--cream-dim);
  opacity:0; transform:translateY(14px);
  animation:riseIn .7s .48s ease forwards;
}
.hero-ctas{
  position:relative; z-index:1;
  margin-top:26px; display:flex; gap:14px; align-items:center; justify-content:center; flex-wrap:wrap;
  opacity:0; transform:translateY(14px);
  animation:riseIn .7s .6s ease forwards;
}
.btn-primary{
  position:relative;
  padding:15px 30px; border-radius:100px;
  background:var(--coral); color:var(--cream);
  font-weight:600; font-size:16px;
  display:inline-flex; align-items:center; gap:9px;
  transition:transform .35s cubic-bezier(.34,1.56,.64,1), box-shadow .3s ease;
  box-shadow:0 0 0 0 rgba(232,94,90,0.5);
}
.btn-primary:hover{ transform:translateY(-3px) rotate(-1.2deg); box-shadow:0 12px 26px -8px rgba(232,94,90,0.55); }
.btn-primary svg{ width:17px; height:17px; transition:transform .3s ease; }
.btn-primary:hover svg{ transform:translateY(2px); }
.btn-ghost{
  padding:15px 24px; font-size:15px; color:var(--cream-dim);
  border:1px solid var(--line); border-radius:100px;
  transition:color .25s ease, border-color .25s ease, background .25s ease;
}
.btn-ghost:hover{ color:var(--cream); border-color:var(--cream-dim); background:var(--cream-faint); }

/* Product Hunt badge, rebuilt with site tokens instead of the stock embed image */
.ph-badge{
  display:flex; align-items:center; gap:11px; text-align:left;
  padding:8px 22px 8px 12px;
  border:1px solid var(--line); border-radius:100px;
  transition:border-color .25s ease, background .25s ease;
}
.ph-badge:hover{ border-color:var(--coral); background:var(--cream-faint); }
.ph-logo{ width:32px; height:32px; color:var(--coral); flex-shrink:0; }
.ph-kicker{
  display:block; font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--cream-dim); margin-bottom:2px;
}
.ph-name{
  display:block; font-family:var(--display); font-weight:700;
  font-size:20px; line-height:1; color:var(--cream); letter-spacing:.01em;
}
.ph-arrow{ width:11px; height:9px; color:var(--coral); margin-left:4px; flex-shrink:0; }

.scroll-cue{
  position:absolute; bottom:34px; left:0; right:0; margin:0 auto; width:max-content;
  z-index:1; display:flex; flex-direction:column; align-items:center; gap:8px;
  color:var(--cream-dim); font-size:12px; letter-spacing:.14em; text-transform:uppercase;
  opacity:0; animation:riseIn .7s 1s ease forwards;
}
.scroll-cue .line{ width:1px; height:30px; background:linear-gradient(var(--cream-dim), transparent); animation:pulseDown 1.8s ease-in-out infinite; }

@keyframes riseIn{ to{ opacity:1; transform:none; } }
@keyframes pulseDown{ 0%,100%{ opacity:.3; } 50%{ opacity:1; } }

/* ---------- ghost component ---------- */
.ghost-img{ width:100%; height:auto; display:block; }

.ghost-float{ animation:floaty 4.2s ease-in-out infinite; }
@keyframes floaty{ 0%,100%{ transform:translateY(0) rotate(0deg); } 50%{ transform:translateY(-10px) rotate(-1deg); } }

/* whole-image blink: a quick squash instead of toggling drawn eyes */
.ghost-blink{ animation:blink 5.5s ease-in-out infinite; transform-origin:50% 42%; }
@keyframes blink{ 0%,92%,100%{ transform:scaleY(1); } 95%{ transform:scaleY(.96); } }

/* chomp bounce: squash-stretch instead of an animated mouth-open ellipse */
.ghost-chomp{ animation:chompBounce 1.1s ease-in-out infinite; transform-origin:50% 100%; }
@keyframes chompBounce{ 0%,100%{ transform:scaleY(1) scaleX(1); } 50%{ transform:scaleY(.92) scaleX(1.05); } }

/* confused wobble: a head tilt instead of an animated wobble mouth */
.ghost-wobble{ animation:confusedWobble 2.4s ease-in-out infinite; transform-origin:50% 85%; }
@keyframes confusedWobble{ 0%,100%{ transform:rotate(0deg); } 25%{ transform:rotate(-4deg); } 75%{ transform:rotate(4deg); } }

.sparkle{ position:absolute; color:var(--gold); animation:sparkleFloat 3.4s ease-in-out infinite; }
.sparkle svg{ width:100%; height:100%; }
@keyframes sparkleFloat{
  0%,100%{ transform:translateY(0) scale(1) rotate(0deg); opacity:.9; }
  50%{ transform:translateY(-14px) scale(1.18) rotate(14deg); opacity:1; }
}

.hero-scene{ position:relative; }
.hero-scene .sparkle{ width:26px; height:26px; }
.hero-scene .sparkle.s1{ top:2%; left:4%; animation-delay:.2s; }
.hero-scene .sparkle.s2{ top:10%; right:0%; animation-delay:1.1s; }
.hero-scene .sparkle.s3{ bottom:26%; left:-4%; width:18px; height:18px; animation-delay:.7s; }
.hero-scene .heart{ position:absolute; top:16%; right:8%; width:22px; height:22px; color:var(--coral); animation:sparkleFloat 3.8s .4s ease-in-out infinite; }

/* ---------- section shell ---------- */
section{ position:relative; padding:120px 0; }
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal-stagger > *{ opacity:0; transform:translateY(24px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal-stagger.in > *{ opacity:1; transform:none; }
.reveal-stagger.in > *:nth-child(1){ transition-delay:.02s; }
.reveal-stagger.in > *:nth-child(2){ transition-delay:.12s; }
.reveal-stagger.in > *:nth-child(3){ transition-delay:.22s; }
.reveal-stagger.in > *:nth-child(4){ transition-delay:.32s; }

.eyebrow-sm{
  font-family:var(--mono); font-size:12.5px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--coral); margin:0 0 14px; display:flex; align-items:center; gap:9px;
}
.eyebrow-sm::before{ content:''; width:16px; height:1px; background:var(--coral); }
.section-title{
  font-family:var(--display); font-weight:700; font-size:clamp(34px,5vw,58px);
  line-height:1.03; letter-spacing:-.01em; margin:0 0 16px;
}
.section-lede{ font-size:17px; line-height:1.6; color:var(--cream-dim); max-width:480px; }

/* ---------- chaos -> order (signature) ---------- */
.transform-section{ padding-top:60px; }
.transform-head{ text-align:center; max-width:640px; margin:0 auto 64px; }
.transform-head .section-lede{ margin:0 auto; }

.stage{
  position:relative;
  max-width:920px; margin:0 auto;
  border-radius:28px;
  background:linear-gradient(180deg, var(--ink-card), #17110f);
  border:1px solid var(--line);
  padding:56px 40px 44px;
  overflow:hidden;
}
.stage::before{
  content:''; position:absolute; inset:0; z-index:0;
  background:radial-gradient(600px 300px at 50% -10%, rgba(232,94,90,0.12), transparent 60%);
}
.stage-label{
  position:relative; z-index:1;
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--cream-dim); margin-bottom:34px;
}
.stage-label .tag{
  padding:5px 12px; border-radius:100px; border:1px solid var(--line);
  transition:color .4s ease, border-color .4s ease, background .4s ease;
}
.stage.sorted .tag.before{ opacity:.4; }
.stage:not(.sorted) .tag.after{ opacity:.4; }
.stage.sorted .tag.after{ color:var(--ink); background:var(--gold); border-color:var(--gold); opacity:1; }
.stage:not(.sorted) .tag.before{ color:var(--ink); background:var(--coral); border-color:var(--coral); opacity:1; }

.stage-body{ position:relative; z-index:1; min-height:460px; }

.pile{ position:relative; height:460px; }
.chip{
  position:absolute;
  width:74px; height:88px; border-radius:11px;
  background:var(--ink-soft); border:1px solid var(--line);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px;
  font-family:var(--mono); font-size:10.5px; letter-spacing:.04em; color:var(--cream-dim);
  box-shadow:0 14px 26px -14px rgba(0,0,0,0.6);
  transition:opacity .6s ease, transform .7s cubic-bezier(.2,.7,.2,1), top .7s cubic-bezier(.2,.7,.2,1), left .7s cubic-bezier(.2,.7,.2,1);
}
.chip .dot{ width:22px; height:22px; border-radius:6px; }
.chip[data-type="img"] .dot{ background:var(--gold); }
.chip[data-type="zip"] .dot{ background:var(--coral); }
.chip[data-type="doc"] .dot{ background:#7fb3a3; }
.chip[data-type="vid"] .dot{ background:#8aa6d6; }
.chip[data-type="mp3"] .dot{ background:#c893d6; }
.chip[data-type="pdf"] .dot{ background:#e0937b; }

/* scattered pile positions + rotation */
.chip:nth-child(1){ top:6%; left:6%; transform:rotate(-9deg); }
.chip:nth-child(2){ top:2%; left:26%; transform:rotate(6deg); }
.chip:nth-child(3){ top:14%; left:46%; transform:rotate(-4deg); }
.chip:nth-child(4){ top:0%; left:66%; transform:rotate(11deg); }
.chip:nth-child(5){ top:10%; left:84%; transform:rotate(-7deg); }
.chip:nth-child(6){ top:42%; left:12%; transform:rotate(4deg); }
.chip:nth-child(7){ top:46%; left:36%; transform:rotate(-12deg); }
.chip:nth-child(8){ top:38%; left:58%; transform:rotate(8deg); }
.chip:nth-child(9){ top:48%; left:78%; transform:rotate(-3deg); }
.chip:nth-child(10){ top:70%; left:22%; transform:rotate(-6deg); }
.chip:nth-child(11){ top:74%; left:50%; transform:rotate(9deg); }
.chip:nth-child(12){ top:68%; left:70%; transform:rotate(-10deg); }

/* sorted / organized positions, three folder columns */
.stage.sorted .chip{ transition-delay:calc(var(--i) * 55ms); }
.stage.sorted .chip[data-col="1"]{ top:var(--sy); left:8%; transform:rotate(0deg); }
.stage.sorted .chip[data-col="2"]{ top:var(--sy); left:39%; transform:rotate(0deg); }
.stage.sorted .chip[data-col="3"]{ top:var(--sy); left:70%; transform:rotate(0deg); }

.cols{
  position:absolute; z-index:0; inset:0;
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
  opacity:0; transition:opacity .6s ease .1s;
  pointer-events:none;
}
.stage.sorted .cols{ opacity:1; }
.col-card{
  border-radius:16px; border:1px dashed var(--line);
  padding-top:120px;
  display:flex; flex-direction:column; align-items:center;
}
.col-card span{
  font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--cream-dim); margin-top:auto; margin-bottom:14px;
}

.stage-caption{
  position:relative; z-index:1; text-align:center; margin-top:28px;
  font-family:var(--display); font-size:22px; color:var(--cream-dim);
  transition:color .4s ease;
}
.stage.sorted .stage-caption{ color:var(--cream); }

/* ---------- how it works ---------- */
.how{ padding-top:40px; }
.how-head{ max-width:560px; margin:0 0 60px; }
.how-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; position:relative; }
.how-grid::before{
  content:''; position:absolute; top:78px; left:16%; right:16%; height:1px;
  background:repeating-linear-gradient(90deg, var(--line) 0 8px, transparent 8px 16px);
  z-index:0;
}
.how-card{
  position:relative; z-index:1;
  background:var(--ink-card); border:1px solid var(--line); border-radius:20px;
  padding:30px 26px 32px;
  transition:transform .4s cubic-bezier(.2,.7,.2,1), border-color .4s ease;
}
.how-card:hover{ transform:translateY(-6px); border-color:rgba(246,237,226,0.28); }
.how-num{ font-family:var(--mono); font-size:12px; color:var(--coral); letter-spacing:.1em; margin-bottom:18px; }
.how-ghost{ width:88px; margin:0 auto 22px; }
.how-title{ font-family:var(--display); font-weight:700; font-size:23px; margin:0 0 8px; text-align:center; }
.how-desc{ font-size:14.5px; line-height:1.55; color:var(--cream-dim); text-align:center; }

/* ---------- unknown file spotlight ---------- */
.unknown{ background:var(--ink-card); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.unknown-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:64px; align-items:center; }
.unknown-ghost{ width:200px; margin:0 auto; }
.unknown-copy .section-title{ font-size:clamp(30px,4vw,44px); }

.dialog{
  background:var(--ink); border:1px solid var(--line); border-radius:18px;
  padding:26px; box-shadow:0 30px 60px -20px rgba(0,0,0,0.55);
  transform:rotate(1.4deg);
}
.dialog-title{ font-family:var(--display); font-weight:700; font-size:20px; margin:0 0 4px; }
.dialog-sub{ font-size:13.5px; color:var(--cream-dim); margin:0 0 18px; }
.dialog-select{
  display:flex; align-items:center; justify-content:space-between;
  background:var(--ink-soft); border:1px solid var(--line); border-radius:10px;
  padding:12px 14px; font-size:14px; margin-bottom:10px;
}
.dialog-select.active{ border-color:var(--coral); }
.dialog-select .badge{
  font-family:var(--mono); font-size:10.5px; padding:3px 8px; border-radius:100px;
  background:var(--coral); color:var(--cream);
}
.dialog-row{ display:flex; gap:10px; margin-top:18px; }
.dialog-btn{
  flex:1; text-align:center; padding:10px; border-radius:9px; font-size:13.5px; font-weight:600;
  border:1px solid var(--line); color:var(--cream-dim);
}
.dialog-btn.primary{ background:var(--coral); color:var(--cream); border-color:var(--coral); }

.unknown-list{ margin:26px 0 0; padding:0; list-style:none; display:flex; flex-direction:column; gap:14px; }
.unknown-list li{ display:flex; gap:12px; font-size:15px; color:var(--cream-dim); align-items:flex-start; }
.unknown-list svg{ width:18px; height:18px; flex-shrink:0; margin-top:2px; color:var(--gold); }

/* ---------- open source strip ---------- */
.oss{ padding:90px 0; }
.oss-card{
  max-width:920px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
  padding:36px 44px; border-radius:22px;
  background:linear-gradient(120deg, var(--ink-card), var(--ink-soft));
  border:1px solid var(--line);
}
.oss-left{ display:flex; align-items:center; gap:18px; }
.oss-ghost{ width:56px; flex-shrink:0; }
.oss-left h3{ font-family:var(--display); font-weight:700; font-size:24px; margin:0 0 4px; }
.oss-left p{ margin:0; font-size:14px; color:var(--cream-dim); }
.oss-badges{ display:flex; gap:10px; flex-wrap:wrap; }
.oss-badge{
  display:flex; align-items:center; gap:7px;
  font-family:var(--mono); font-size:12.5px; color:var(--cream-dim);
  padding:9px 14px; border-radius:100px; border:1px solid var(--line);
  transition:border-color .25s ease, color .25s ease;
}
.oss-badge:hover{ border-color:var(--gold); color:var(--cream); }
.oss-badge svg{ width:14px; height:14px; }
.oss-badge.sponsor{ border-color:var(--coral); color:var(--coral); }
.oss-badge.sponsor:hover{ background:rgba(232,94,90,0.14); border-color:var(--coral); color:var(--coral); }

/* ---------- install ---------- */
.install{ text-align:center; }
.install .wrap{ max-width:640px; }
.install-ghost{ width:120px; margin:0 auto 8px; }
.install-ctas{ margin-top:30px; display:flex; gap:14px; align-items:center; justify-content:center; flex-wrap:wrap; }
.install-subnote{
  margin:30px 0 0; font-family:var(--mono); font-size:12.5px; letter-spacing:.08em;
  text-transform:uppercase; color:var(--cream-dim);
}
.code-card{
  margin-top:14px; text-align:left;
  background:var(--ink-card); border:1px solid var(--line); border-radius:16px;
  padding:18px 20px; position:relative;
}
.code-card-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.code-dots{ display:flex; gap:6px; }
.code-dots span{ width:10px; height:10px; border-radius:50%; background:var(--line); }
.copy-btn{
  display:flex; align-items:center; gap:6px;
  font-family:var(--mono); font-size:12px; color:var(--cream-dim);
  background:var(--ink-soft); border:1px solid var(--line); border-radius:8px; padding:6px 10px;
  cursor:pointer; transition:color .2s ease, border-color .2s ease;
}
.copy-btn:hover{ color:var(--cream); border-color:var(--gold); }
.copy-btn svg{ width:13px; height:13px; }
.code-card pre{ margin:0; font-family:var(--mono); font-size:14px; line-height:1.7; color:var(--cream); overflow-x:auto; }
.code-card pre .muted{ color:var(--cream-dim); }
.code-card pre .accent{ color:var(--gold); }
.install-note{ margin-top:18px; font-size:13.5px; color:var(--cream-dim); }
.install-note a{ color:var(--gold); border-bottom:1px solid rgba(246,192,93,0.4); }

/* ---------- footer ---------- */
footer{ padding:60px 0 40px; border-top:1px solid var(--line); }
.footer-row{ display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:20px; }
.footer-brand{ display:flex; align-items:center; gap:14px; }
.footer-ghost{ width:46px; opacity:.9; }
.footer-links{ display:flex; gap:22px; font-size:13.5px; color:var(--cream-dim); }
.footer-links a{ transition:color .2s ease; cursor:pointer; }
.footer-links a:hover{ color:var(--cream); }
.footer-credit{ font-size:12.5px; color:var(--cream-dim); }
.footer-credit a{ color:var(--gold); }

/* ---------- cute layer: feed Boo, speech, crumbs ---------- */
.hero-scene{ cursor:pointer; -webkit-tap-highlight-color:transparent; user-select:none; }
.ghost-lean{ will-change:transform; }

.speech{
  position:absolute; z-index:3;
  top:-16px; left:50%; transform:translateX(-50%);
  font-family:var(--mono); font-size:12px; white-space:nowrap;
  color:var(--ink); background:var(--cream);
  padding:7px 13px; border-radius:100px;
  box-shadow:0 8px 20px -8px rgba(0,0,0,0.5);
  animation:speechBob 2.6s ease-in-out infinite;
  transition:opacity .4s ease, transform .4s ease;
}
.speech::after{
  content:''; position:absolute; bottom:-5px; left:50%; transform:translateX(-50%) rotate(45deg);
  width:10px; height:10px; background:var(--cream); border-radius:2px;
}
.speech.hidden{ opacity:0; transform:translateX(-50%) translateY(6px); pointer-events:none; }
@keyframes speechBob{ 0%,100%{ margin-top:0; } 50%{ margin-top:-5px; } }

/* one big gulp: temporarily replaces the idle chomp on the same element */
.ghost-img.gulping{ animation:gulp .45s cubic-bezier(.34,1.56,.64,1); transform-origin:50% 100%; }
@keyframes gulp{
  0%{ transform:scaleY(1) scaleX(1); }
  35%{ transform:scaleY(.78) scaleX(1.14); }
  70%{ transform:scaleY(1.06) scaleX(.96); }
  100%{ transform:scaleY(1) scaleX(1); }
}

.fall-chip{
  position:absolute; z-index:2; left:50%;
  font-family:var(--mono); font-size:11px; color:var(--ink);
  background:var(--gold); padding:5px 10px; border-radius:8px;
  pointer-events:none; white-space:nowrap;
  animation:fallIn .55s cubic-bezier(.5,0,.9,.6) forwards;
}
@keyframes fallIn{
  0%{ top:-12%; transform:translateX(-50%) rotate(-8deg) scale(1); opacity:0; }
  20%{ opacity:1; }
  100%{ top:52%; transform:translateX(-50%) rotate(10deg) scale(.25); opacity:0; }
}

.crumb{
  position:absolute; z-index:2; top:55%; left:50%;
  width:7px; height:7px; border-radius:2px;
  pointer-events:none;
  animation:crumbPop .65s cubic-bezier(.2,.7,.3,1) forwards;
}
@keyframes crumbPop{
  0%{ transform:translate(-50%,-50%) rotate(0deg) scale(1); opacity:1; }
  100%{ transform:translate(calc(-50% + var(--dx)), calc(-50% + var(--dy))) rotate(var(--rot)) scale(.4); opacity:0; }
}

.nomfloat{
  position:absolute; z-index:3; top:30%; left:var(--x,60%);
  font-family:var(--display); font-weight:700; font-size:20px; color:var(--gold);
  pointer-events:none; white-space:nowrap;
  animation:nomRise .9s ease-out forwards;
}
@keyframes nomRise{
  0%{ transform:translateY(0) rotate(-4deg) scale(.7); opacity:0; }
  25%{ opacity:1; }
  100%{ transform:translateY(-46px) rotate(4deg) scale(1.05); opacity:0; }
}

.heart-pop{
  position:absolute; z-index:3; top:20%; left:50%;
  width:26px; height:26px; color:var(--coral);
  pointer-events:none;
  animation:nomRise 1.1s ease-out forwards;
}

/* ---------- cute layer: stage replay ---------- */
.stage-replay{
  position:relative; z-index:1;
  display:block; margin:16px auto 0;
  font-family:var(--mono); font-size:12.5px; letter-spacing:.06em;
  color:var(--cream-dim); background:transparent;
  border:1px solid var(--line); border-radius:100px;
  padding:9px 18px; cursor:pointer;
  opacity:0; transform:translateY(6px);
  transition:opacity .4s ease .3s, transform .4s ease .3s, color .25s ease, border-color .25s ease;
}
.stage.sorted .stage-replay, .stage.replayable .stage-replay{ opacity:1; transform:none; }
.stage-replay:hover{ color:var(--cream); border-color:var(--gold); }
.stage-replay:active{ transform:scale(.96); }

/* ---------- cute layer: playable dialog ---------- */
.dialog-select{ cursor:pointer; transition:border-color .2s ease, background .2s ease, transform .2s ease; }
.dialog-select:hover{ border-color:rgba(246,192,93,0.55); transform:translateX(2px); }
.dialog-btn{ cursor:pointer; background:transparent; font-family:inherit; font-size:13.5px; transition:transform .2s ease, filter .2s ease; }
.dialog-btn:hover{ transform:translateY(-1px); filter:brightness(1.1); }
.dialog.celebrate{ animation:dialogPop .55s cubic-bezier(.34,1.56,.64,1); }
@keyframes dialogPop{
  0%{ transform:rotate(1.4deg) scale(1); }
  40%{ transform:rotate(-1deg) scale(1.035); }
  100%{ transform:rotate(1.4deg) scale(1); }
}
.dialog.shake{ animation:dialogShake .4s ease; }
@keyframes dialogShake{
  0%,100%{ transform:rotate(1.4deg); }
  25%{ transform:rotate(1.4deg) translateX(-6px); }
  75%{ transform:rotate(1.4deg) translateX(6px); }
}

/* ---------- cute layer: flyby easter egg ---------- */
.flyby{
  position:fixed; z-index:80; top:32vh; left:-180px;
  width:130px; pointer-events:none;
  animation:flyAcross 2.8s linear forwards;
}
.flyby img{ width:100%; height:auto; animation:flyBob .7s ease-in-out infinite alternate; }
@keyframes flyAcross{ to{ left:110vw; } }
@keyframes flyBob{ from{ transform:translateY(-8px) rotate(4deg); } to{ transform:translateY(8px) rotate(-3deg); } }

/* ---------- cute layer: sleeping footer ghost ---------- */
.footer-ghost{ position:relative; cursor:pointer; }
.footer-ghost .zzz{
  position:absolute; z-index:1; left:78%; top:-6px;
  font-family:var(--mono); font-size:11px; color:var(--cream-dim);
  opacity:0; animation:zFloat 3s ease-in-out infinite;
  pointer-events:none;
}
.footer-ghost .zzz.z2{ animation-delay:1s; font-size:9px; }
.footer-ghost .zzz.z3{ animation-delay:2s; font-size:8px; }
@keyframes zFloat{
  0%{ opacity:0; transform:translate(0,0); }
  30%{ opacity:.9; }
  100%{ opacity:0; transform:translate(12px,-18px); }
}
.footer-ghost.awake .zzz{ animation:none; opacity:0; }
.bubble-boo{
  position:absolute; z-index:2; top:-30px; left:50%; transform:translateX(-50%);
  font-family:var(--display); font-weight:800; font-size:16px; letter-spacing:.06em;
  color:var(--ink); background:var(--gold); padding:4px 12px; border-radius:100px;
  animation:nomRise 1.2s ease-out forwards; pointer-events:none;
}

/* themed scrollbar, a small wink */
::-webkit-scrollbar{ width:11px; }
::-webkit-scrollbar-track{ background:var(--ink); }
::-webkit-scrollbar-thumb{ background:#3a3733; border-radius:100px; border:3px solid var(--ink); }
::-webkit-scrollbar-thumb:hover{ background:var(--coral); }

/* ---------- responsive ---------- */
@media (max-width:860px){
  .nav-links{ gap:16px; font-size:13px; }
  .nav-links a:not(.nav-cta){ display:none; }

  .how-grid{ grid-template-columns:1fr; gap:18px; }
  .how-grid::before{ display:none; }

  .unknown-grid{ grid-template-columns:1fr; gap:40px; }
  .unknown-ghost{ width:150px; }

  .oss-card{ flex-direction:column; align-items:flex-start; padding:28px; }

  .stage{ padding:36px 18px 30px; }
  .pile{ height:440px; }
  .stage-body{ min-height:440px; }
  .chip{ width:62px; height:76px; font-size:9px; }
  .chip .dot{ width:18px; height:18px; }
  .col-card{ padding-top:80px; }
  .cols{ gap:12px; }

  .footer-row{ flex-direction:column; align-items:flex-start; }
}

@media (max-width:520px){
  .wordmark{ font-size:clamp(72px,24vw,120px); }
  .hero{ padding:120px 20px 60px; }
  section{ padding:80px 0; }
  .stage-label{ font-size:10px; }
  .stage-label .tag{ padding:4px 9px; }
  .dialog{ transform:none; }
  .code-card pre{ font-size:12.5px; }
}

/* keep the hero content clear of the pinned scroll cue on short viewports */
@media (max-height:800px){
  .hero{ padding-top:100px; padding-bottom:90px; }
  .hero-stage{ width:min(230px,44vw); margin:0 auto 12px; }
  .wordmark{ font-size:clamp(70px,13vw,140px); margin:-8px 0 2px; }
  .hero-ctas{ margin-top:18px; }
}
