/* ═══════════════════════════════════════════════
   THE COMPOUNDING CHRONICLES — Dream Edition
   dream.css · Complete Design System
═══════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@700;800&family=DM+Sans:opsz,wght@9..40,400;9..40,500&display=swap');

:root {
  --void:    #05050F;
  --deep:    #0A0A1E;
  --surface: #12122A;
  --card:    #181830;
  --border:  rgba(255,255,255,.07);
  --gold:    #F5A800;
  --gold2:   #BF6D00;
  --glow:    rgba(245,168,0,.18);
  --text:    #FFF8EE;
  --dim:     rgba(255,248,238,.5);
  --mute:    rgba(255,248,238,.28);
  --good:    #2ECC71; --good-g: rgba(46,204,113,.12);
  --bad:     #E74C3C; --bad-g:  rgba(231,76,60,.12);
  --mid:     #F39C12; --mid-g:  rgba(243,156,18,.12);
  --pu:      #7B68EE;
}

*{box-sizing:border-box;margin:0;padding:0;}
html,body{
  height:100%;background:var(--void);
  color:var(--text);font-family:'DM Sans',sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow:hidden;
  user-select:none;-webkit-user-select:none;
}
.syne{font-family:'Syne',sans-serif;}

/* ── APP SHELL ──────────────────────────── */
#app{
  position:fixed;inset:0;
  display:flex;flex-direction:column;
  overflow:hidden;
}
@media(min-width:500px){
  body{display:flex;align-items:flex-start;justify-content:center;}
  #app{position:relative;width:420px;min-height:100vh;box-shadow:0 0 120px rgba(0,0,0,.9);}
  .choice-drawer,.outcome-sheet,.sleep-screen,.cold-open,.creation-screen,.ending-screen{
    max-width:420px!important;left:50%!important;right:auto!important;
    transform:translateX(-50%) !important;
    width:420px!important;
  }
  .choice-drawer.open{transform:translateX(-50%) translateY(0)!important;}
  .choice-drawer:not(.open){transform:translateX(-50%) translateY(105%)!important;}
}

/* ── SCENE AREA ─────────────────────────── */
.scene-area{
  position:absolute;inset:0;
  overflow:hidden;
}
.scene-area::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 35%,transparent 35%,rgba(5,5,15,.75) 100%);
  pointer-events:none;z-index:2;
}

/* ── SCENE BACKGROUNDS ──────────────────── */
.sc-notif   {background:radial-gradient(ellipse at 50% 30%,#181838 0%,var(--void) 100%);}
.sc-wa      {background:linear-gradient(180deg,#0A1A10 0%,var(--void) 100%);}
.sc-family  {background:radial-gradient(ellipse at 50% 50%,#1F1A0A 0%,var(--void) 100%);}
.sc-call    {background:linear-gradient(180deg,#0A0A28 0%,var(--void) 100%);}
.sc-market  {background:radial-gradient(ellipse at 50% 40%,#200808 0%,var(--void) 100%);}
.sc-night   {background:var(--void);}
.sc-dream   {background:linear-gradient(180deg,#0C0C2A 0%,var(--void) 100%);}

/* ── NIGHTMARE CREEP ────────────────────── */
#nightmare{
  position:fixed;inset:0;pointer-events:none;z-index:90;
  transition:box-shadow 3s ease;
}
#nightmare.n1{box-shadow:inset 0 0 50px 8px rgba(231,76,60,.06);}
#nightmare.n2{box-shadow:inset 0 0 80px 20px rgba(231,76,60,.16);}
#nightmare.n3{box-shadow:inset 0 0 110px 35px rgba(231,76,60,.28);}

/* ── TOP HUD ────────────────────────────── */
.hud{
  position:absolute;top:0;left:0;right:0;z-index:20;
  padding:12px 16px 6px;
  background:linear-gradient(180deg,rgba(5,5,15,.95) 0%,transparent 100%);
  display:flex;align-items:center;gap:8px;
}
.hud-chapter{font-size:10px;color:var(--mute);letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;}
.hud-pips{display:flex;gap:3px;flex:1;}
.hud-pip{flex:1;height:2px;border-radius:1px;background:rgba(255,255,255,.1);transition:background .4s;}
.hud-pip.d{background:var(--gold2);}
.hud-pip.a{background:var(--gold);box-shadow:0 0 6px var(--gold);}
.hud-age{
  font-family:'Syne',sans-serif;font-size:10px;font-weight:800;
  color:var(--gold);letter-spacing:.05em;
  background:rgba(245,168,0,.1);border:1px solid rgba(245,168,0,.2);
  border-radius:999px;padding:3px 9px;white-space:nowrap;
}

/* ── METERS ─────────────────────────────── */
.meters-row{
  position:absolute;top:38px;left:0;right:0;z-index:20;
  display:flex;gap:5px;padding:0 16px;
}
.mr-item{display:flex;align-items:center;gap:3px;flex:1;}
.mr-icon{font-size:9px;opacity:.6;}
.mr-track{flex:1;height:2px;background:rgba(255,255,255,.08);border-radius:1px;overflow:hidden;}
.mr-fill{height:100%;border-radius:1px;transition:width 1.2s ease;}
.mrf-w{background:linear-gradient(90deg,#27AE60,#2ECC71);}
.mrf-m{background:linear-gradient(90deg,var(--gold2),var(--gold));}
.mrf-e{background:linear-gradient(90deg,#2980B9,#3498DB);}
.mrf-b{background:linear-gradient(90deg,#8E44AD,#9B59B6);}

/* ── DREAM TREE ─────────────────────────── */
.dream-tree{
  position:absolute;bottom:12px;right:12px;z-index:3;
  opacity:.35;pointer-events:none;
  transition:opacity 2s ease;
}

/* ── NOTIFICATION SCENE ─────────────────── */
.notif-phone{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-54%);
  width:min(240px,68vw);
  background:#14143A;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.08);
  overflow:hidden;
  box-shadow:0 24px 80px rgba(0,0,0,.7),0 0 0 1px rgba(245,168,0,.08);
  z-index:5;
  animation:phoneIn .8s cubic-bezier(.34,1.56,.64,1) .4s both;
}
@keyframes phoneIn{from{transform:translate(-50%,-48%);opacity:0}to{transform:translate(-50%,-54%);opacity:1}}
.np-statusbar{display:flex;justify-content:space-between;padding:8px 14px 2px;font-size:9px;color:rgba(255,255,255,.35);}
.np-time{font-family:'Syne',sans-serif;font-size:42px;font-weight:800;color:#fff;text-align:center;padding:2px 0 8px;letter-spacing:-.02em;}
.np-lock{text-align:center;font-size:18px;opacity:.4;margin-bottom:6px;}
.np-banner{
  margin:8px;background:rgba(255,255,255,.05);
  border-radius:14px;padding:10px 12px;
  display:flex;gap:9px;align-items:flex-start;
  border:1px solid rgba(255,255,255,.07);
  animation:bannerIn .5s cubic-bezier(.34,1.56,.64,1) 1.2s both;
}
@keyframes bannerIn{from{transform:translateY(-6px);opacity:0}to{transform:translateY(0);opacity:1}}
.np-bicon{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,#1A6B3A,#0F4A28);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}
.np-bapp{font-size:9px;color:rgba(255,255,255,.38);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px;}
.np-btitle{font-size:11px;font-weight:600;color:#fff;margin-bottom:1px;}
.np-bbody{font-size:10px;color:rgba(255,255,255,.5);}
.np-amount{
  font-family:'Syne',sans-serif;font-size:28px;font-weight:800;
  color:var(--gold);text-align:center;padding:10px;
  text-shadow:0 0 30px rgba(245,168,0,.4);
}
.np-swipe{font-size:10px;color:rgba(255,255,255,.2);text-align:center;padding:0 12px 12px;}

/* ── WHATSAPP SCENE ─────────────────────── */
.wa-wrap{position:absolute;inset:0;display:flex;flex-direction:column;z-index:5;}
.wa-hdr{
  background:rgba(7,94,84,.92);backdrop-filter:blur(10px);
  padding:10px 14px;display:flex;align-items:center;gap:10px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.wa-av{
  width:32px;height:32px;border-radius:50%;
  background:#128C7E;display:flex;align-items:center;justify-content:center;
  font-family:'Syne',sans-serif;font-size:12px;font-weight:800;color:#fff;flex-shrink:0;
}
.wa-info{}
.wa-name{font-size:13px;font-weight:600;color:#fff;}
.wa-stat{font-size:10px;color:rgba(255,255,255,.5);}
.wa-msgs{
  flex:1;padding:10px 12px;
  display:flex;flex-direction:column;gap:5px;
  overflow-y:auto;overflow-x:hidden;
  background:rgba(0,0,0,.25);
}
.wa-msg{
  max-width:82%;padding:8px 12px;
  font-size:12.5px;line-height:1.45;
  color:var(--text);
  animation:msgPop .2s cubic-bezier(.34,1.56,.64,1);
}
@keyframes msgPop{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
.wa-msg.r{
  align-self:flex-start;
  background:rgba(18,140,126,.22);
  border-radius:4px 14px 14px 14px;
  border:1px solid rgba(18,140,126,.25);
}
.wa-msg.y{
  align-self:flex-end;
  background:rgba(245,168,0,.14);
  border-radius:14px 4px 14px 14px;
  border:1px solid rgba(245,168,0,.18);
}
.wa-msg.s{
  align-self:center;font-size:10px;
  color:rgba(255,255,255,.25);background:none;border:none;
}
.wa-time{font-size:9px;color:rgba(255,255,255,.25);text-align:right;margin-top:2px;}
.typing-ind{
  align-self:flex-start;
  background:rgba(18,140,126,.2);
  border:1px solid rgba(18,140,126,.2);
  border-radius:4px 14px 14px 14px;
  padding:10px 14px;display:flex;gap:4px;align-items:center;
}
.typing-ind span{
  width:5px;height:5px;border-radius:50%;
  background:rgba(255,255,255,.35);
  animation:tdot 1s ease-in-out infinite;
}
.typing-ind span:nth-child(2){animation-delay:.15s;}
.typing-ind span:nth-child(3){animation-delay:.3s;}
@keyframes tdot{0%,100%{transform:translateY(0);opacity:.35}50%{transform:translateY(-4px);opacity:1}}

/* ── FAMILY SCENE ───────────────────────── */
.family-bubble{
  position:absolute;
  background:rgba(245,168,0,.08);
  border:1px solid rgba(245,168,0,.15);
  border-radius:16px;padding:10px 14px;
  max-width:155px;font-size:12px;
  color:var(--text);line-height:1.4;z-index:5;
  animation:famPop .4s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes famPop{from{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}
.fb-who{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--gold);margin-bottom:3px;font-weight:700;}
.family-chaos-label{
  position:absolute;bottom:20%;left:50%;transform:translateX(-50%);
  font-size:12px;color:var(--dim);z-index:6;text-align:center;
  width:200px;line-height:1.5;
}

/* ── PHONE CALL SCENE ───────────────────── */
.call-wrap{
  position:absolute;inset:0;z-index:5;
  display:flex;flex-direction:column;align-items:center;
  padding-top:55px;
}
.call-who{font-size:10px;color:var(--mute);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px;}
.call-name{font-family:'Syne',sans-serif;font-size:26px;font-weight:800;color:var(--text);margin-bottom:6px;}
.call-status{font-size:12px;color:var(--dim);margin-bottom:20px;}
.call-av{
  width:76px;height:76px;border-radius:50%;
  background:linear-gradient(135deg,#0F6E56,#085041);
  display:flex;align-items:center;justify-content:center;
  font-family:'Syne',sans-serif;font-size:26px;font-weight:800;color:#fff;
  animation:callPulse 2s ease-in-out infinite;margin-bottom:16px;
}
@keyframes callPulse{0%,100%{box-shadow:0 0 0 0 rgba(15,110,86,.4)}50%{box-shadow:0 0 0 18px rgba(15,110,86,0)}}
.call-transcript{
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  border-radius:16px;padding:14px 18px;font-size:12.5px;
  color:var(--dim);line-height:1.65;text-align:center;
  max-width:280px;margin-top:4px;
}

/* ── MARKET CRASH SCENE ─────────────────── */
.mkt-wrap{position:absolute;inset:0;z-index:5;padding:60px 20px 20px;display:flex;flex-direction:column;gap:10px;}
.mkt-ticker{font-size:10px;color:rgba(255,255,255,.25);text-transform:uppercase;letter-spacing:.15em;}
.mkt-big{
  font-family:'Syne',sans-serif;font-size:68px;font-weight:800;
  color:var(--bad);line-height:1;
  text-shadow:0 0 50px rgba(231,76,60,.6);
  animation:redFlick .6s ease-in-out infinite alternate;
}
@keyframes redFlick{from{opacity:1}to{opacity:.75}}
.mkt-lbl{font-size:12px;color:rgba(255,255,255,.35);}
.mkt-port{
  background:rgba(231,76,60,.07);border:1px solid rgba(231,76,60,.18);
  border-radius:12px;padding:12px 16px;
}
.mp-r{display:flex;justify-content:space-between;margin-bottom:3px;}
.mp-l{font-size:11px;color:var(--dim);}
.mp-v{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;color:var(--bad);}
.mp-v.was{color:var(--mute);text-decoration:line-through;font-size:11px;}
.mkt-news{
  font-size:10px;color:rgba(255,255,255,.18);text-transform:uppercase;
  letter-spacing:.06em;overflow:hidden;white-space:nowrap;
  animation:newsRoll 14s linear infinite;
}
@keyframes newsRoll{from{transform:translateX(100%)}to{transform:translateX(-200%)}}

/* ── LATE NIGHT SCENE ───────────────────── */
.ln-wrap{
  position:absolute;inset:0;z-index:5;
  display:flex;flex-direction:column;align-items:center;
  padding:50px 24px 16px;
}
.ln-time{font-size:10px;color:var(--mute);letter-spacing:.1em;margin-bottom:18px;}
.ln-msgs{width:100%;max-width:290px;display:flex;flex-direction:column;gap:7px;}
.ln-msg{
  padding:9px 13px;border-radius:14px;
  font-size:12.5px;line-height:1.5;color:var(--text);
  animation:msgPop .2s cubic-bezier(.34,1.56,.64,1);
}
.ln-msg.r{
  align-self:flex-start;
  background:rgba(255,255,255,.05);border:1px solid var(--border);
  border-radius:4px 14px 14px 14px;
}
.ln-msg.y{
  align-self:flex-end;
  background:rgba(245,168,0,.09);border:1px solid rgba(245,168,0,.15);
  border-radius:14px 4px 14px 14px;
}
.ln-typing{
  align-self:flex-start;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  border-radius:4px 14px 14px 14px;
  padding:11px 14px;display:flex;gap:4px;align-items:center;
}
.ln-typing span{width:5px;height:5px;border-radius:50%;background:var(--mute);animation:tdot 1s ease-in-out infinite;}
.ln-typing span:nth-child(2){animation-delay:.15s;}
.ln-typing span:nth-child(3){animation-delay:.3s;}

/* ── CHOICE DRAWER ──────────────────────── */
.choice-drawer{
  position:fixed;bottom:0;left:0;right:0;
  background:var(--surface);
  border-radius:22px 22px 0 0;
  border-top:1px solid var(--border);
  padding:14px 16px 32px;
  transform:translateY(105%);
  transition:transform .5s cubic-bezier(.34,1.56,.64,1);
  z-index:50;
  max-height:58vh;overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.choice-drawer.open{transform:translateY(0);}
.cd-handle{width:34px;height:3px;background:var(--border);border-radius:2px;margin:0 auto 13px;}
.cd-prompt{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--mute);text-align:center;margin-bottom:11px;}
.dc{
  display:flex;align-items:center;gap:12px;
  width:100%;background:var(--card);
  border:1px solid var(--border);border-radius:16px;
  padding:13px 14px;margin-bottom:8px;cursor:pointer;
  text-align:left;color:var(--text);
  transition:all .18s cubic-bezier(.34,1.56,.64,1);
  position:relative;overflow:hidden;
}
.dc::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--glow),transparent);opacity:0;transition:opacity .2s;}
.dc:hover::before{opacity:1;}
.dc:active{transform:scale(.98);}
.dc:disabled{opacity:.35;cursor:default;pointer-events:none;}
.dc.s-good{border-color:var(--good);background:var(--good-g);}
.dc.s-bad {border-color:var(--bad);background:var(--bad-g);}
.dc.s-mid {border-color:var(--mid);background:var(--mid-g);}
.dc.fading{opacity:.25;transform:scale(.97);}
.dc-l{
  width:28px;height:28px;border-radius:50%;flex-shrink:0;
  background:rgba(245,168,0,.1);border:1px solid rgba(245,168,0,.25);
  display:flex;align-items:center;justify-content:center;
  font-family:'Syne',sans-serif;font-size:11px;font-weight:800;color:var(--gold);
  transition:all .2s;
}
.dc.s-good .dc-l{background:rgba(46,204,113,.2);border-color:var(--good);color:var(--good);}
.dc.s-bad  .dc-l{background:rgba(231,76,60,.2);border-color:var(--bad);color:var(--bad);}
.dc-body{flex:1;}
.dc-title{font-size:13.5px;font-weight:500;color:var(--text);margin-bottom:2px;line-height:1.3;}
.dc-sub{font-size:11px;color:var(--dim);line-height:1.38;}
.dc-tag{
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  padding:2px 7px;border-radius:999px;margin-top:5px;display:inline-block;
}
.dct-s{background:rgba(46,204,113,.1);color:var(--good);}
.dct-r{background:rgba(231,76,60,.1);color:var(--bad);}
.dct-b{background:rgba(245,168,0,.1);color:var(--gold);}

/* ── OUTCOME SHEET ──────────────────────── */
.outcome-sheet{
  position:fixed;inset:0;
  background:rgba(5,5,15,.97);
  z-index:70;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:32px 24px;
  opacity:0;pointer-events:none;
  transition:opacity .35s ease;
  text-align:center;
}
.outcome-sheet.visible{opacity:1;pointer-events:all;}
.os-icon{font-size:44px;margin-bottom:14px;animation:bounce .5s cubic-bezier(.34,1.56,.64,1);}
@keyframes bounce{from{transform:scale(0)}to{transform:scale(1)}}
.os-text{
  font-size:14.5px;line-height:1.78;color:var(--dim);
  max-width:310px;margin-bottom:18px;
}
.os-text b,.os-text strong{color:var(--text);}
.os-text .amt{font-family:'Syne',sans-serif;font-weight:700;color:var(--gold);}
.os-deltas{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;justify-content:center;}
.os-d{
  background:var(--card);border:1px solid var(--border);
  border-radius:10px;padding:8px 12px;text-align:center;min-width:56px;
}
.os-d-icon{font-size:12px;margin-bottom:3px;}
.os-d-val{font-family:'Syne',sans-serif;font-size:13px;font-weight:800;}
.os-d-val.up{color:var(--good);}
.os-d-val.dn{color:var(--bad);}
.os-d-val.ne{color:var(--mute);}
.os-concept{
  background:rgba(123,104,238,.08);border:1px solid rgba(123,104,238,.18);
  border-radius:12px;padding:11px 16px;font-size:12px;
  color:rgba(255,255,255,.55);line-height:1.65;max-width:300px;margin-bottom:12px;
}
.os-flash{
  font-size:11px;font-style:italic;color:var(--mute);
  max-width:280px;line-height:1.6;margin-bottom:10px;
}
.os-flash::before{content:'↪ ';color:var(--gold2);}
.os-skip{font-size:11px;color:var(--mute);margin-top:8px;letter-spacing:.04em;}
.os-timer{width:120px;height:2px;background:rgba(255,255,255,.1);border-radius:1px;overflow:hidden;margin-top:12px;}
.os-timer-fill{height:100%;background:var(--gold);width:100%;border-radius:1px;transition:width linear;}

/* ── SLEEP / LEVEL TRANSITION ───────────── */
.sleep-screen{
  position:fixed;inset:0;background:var(--void);z-index:150;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .6s ease;
  padding:24px;text-align:center;
}
.sleep-screen.vis{opacity:1;pointer-events:all;}
.sleep-stars{position:absolute;inset:0;overflow:hidden;pointer-events:none;}
.star{position:absolute;border-radius:50%;background:#fff;animation:twink 2s ease-in-out infinite;}
@keyframes twink{0%,100%{opacity:.08}50%{opacity:.7}}
.sl-level{font-size:10px;font-weight:800;color:var(--gold);letter-spacing:.2em;text-transform:uppercase;margin-bottom:10px;}
.sl-title{font-family:'Syne',sans-serif;font-size:26px;font-weight:800;color:var(--text);margin-bottom:8px;line-height:1.1;}
.sl-sub{font-size:13px;color:var(--dim);line-height:1.65;margin-bottom:28px;max-width:280px;}
.sl-tips{width:100%;max-width:300px;margin-bottom:28px;}
.sl-tip{
  display:flex;align-items:flex-start;gap:10px;
  background:rgba(255,255,255,.03);border:1px solid var(--border);
  border-radius:12px;padding:11px 13px;margin-bottom:7px;
  font-size:12px;color:var(--dim);line-height:1.5;text-align:left;
}
.sl-tip-icon{font-size:15px;flex-shrink:0;margin-top:1px;}
.sl-btn{
  background:none;border:1px solid rgba(245,168,0,.3);
  color:var(--gold);font-family:'Syne',sans-serif;
  font-size:13px;font-weight:800;letter-spacing:.05em;
  padding:13px 32px;border-radius:999px;cursor:pointer;
  transition:all .2s;
}
.sl-btn:hover{background:rgba(245,168,0,.08);border-color:var(--gold);}

/* ── COLD OPEN ──────────────────────────── */
.cold-open{
  position:fixed;inset:0;background:#000;z-index:300;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.co-notif{
  background:rgba(255,255,255,.08);backdrop-filter:blur(20px);
  border-radius:18px;padding:14px 18px;
  display:flex;gap:12px;align-items:flex-start;
  max-width:280px;
  border:1px solid rgba(255,255,255,.1);
  opacity:0;transform:translateY(-10px);
  transition:opacity .8s ease,transform .8s ease;
  margin-bottom:20px;
}
.co-notif.vis{opacity:1;transform:translateY(0);}
.co-ni{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,#1A6B3A,#0F4A28);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.co-nb{font-size:10px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px;}
.co-nt{font-size:13px;font-weight:600;color:#fff;}
.co-na{font-family:'Syne',sans-serif;font-size:20px;font-weight:800;color:var(--gold);}
.co-text{
  font-size:14px;color:rgba(255,255,255,.45);
  text-align:center;line-height:1.85;max-width:240px;
  opacity:0;transition:opacity .8s ease;
}
.co-text.vis{opacity:1;}
.co-title{
  font-family:'Syne',sans-serif;font-size:22px;font-weight:800;
  color:var(--gold);opacity:0;transition:opacity .8s ease;
  text-align:center;margin-bottom:8px;
}
.co-title.vis{opacity:1;}
.co-tap{
  font-size:11px;color:rgba(255,255,255,.2);letter-spacing:.12em;
  text-transform:uppercase;margin-top:20px;
  animation:tapPulse 2s ease-in-out infinite;
}
@keyframes tapPulse{0%,100%{opacity:.2}50%{opacity:.55}}

/* ── CHARACTER CREATION ─────────────────── */
.creation-screen{
  position:fixed;inset:0;background:var(--deep);z-index:250;
  display:flex;flex-direction:column;padding:44px 24px 32px;
  overflow-y:auto;opacity:0;pointer-events:none;
  transition:opacity .5s ease;-webkit-overflow-scrolling:touch;
}
.creation-screen.vis{opacity:1;pointer-events:all;}
.cs-title{font-family:'Syne',sans-serif;font-size:24px;font-weight:800;color:var(--text);margin-bottom:6px;}
.cs-sub{font-size:13px;color:var(--dim);margin-bottom:28px;line-height:1.65;}
.cs-lbl{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--mute);margin-bottom:10px;}
.cs-input{
  width:100%;background:var(--card);border:1px solid var(--border);
  border-radius:14px;padding:14px 16px;font-family:'Syne',sans-serif;
  font-size:18px;font-weight:700;color:var(--text);outline:none;
  transition:border-color .2s;margin-bottom:28px;
}
.cs-input:focus{border-color:rgba(245,168,0,.45);}
.cs-input::placeholder{color:var(--mute);font-weight:400;font-family:'DM Sans',sans-serif;}
.bs-opt{
  display:flex;gap:14px;background:var(--card);
  border:1px solid var(--border);border-radius:18px;
  padding:16px;margin-bottom:10px;cursor:pointer;transition:all .2s;
}
.bs-opt.sel{border-color:rgba(245,168,0,.38);background:rgba(245,168,0,.04);}
.bs-icon{font-size:24px;flex-shrink:0;margin-top:2px;}
.bs-title{font-size:14px;font-weight:500;color:var(--text);margin-bottom:3px;}
.bs-desc{font-size:12px;color:var(--dim);line-height:1.45;}
.bs-tags{display:flex;gap:5px;margin-top:6px;flex-wrap:wrap;}
.bs-tag{font-size:10px;padding:2px 8px;border-radius:999px;background:rgba(255,255,255,.06);color:var(--mute);}
.cs-btn{
  display:block;width:100%;padding:16px;
  background:var(--gold);color:#1A0F00;
  font-family:'Syne',sans-serif;font-size:15px;font-weight:800;
  border:none;border-radius:16px;cursor:pointer;margin-top:20px;
  letter-spacing:.02em;
  box-shadow:0 4px 24px rgba(245,168,0,.3);transition:all .15s;
}
.cs-btn:hover{box-shadow:0 6px 32px rgba(245,168,0,.5);transform:translateY(-1px);}

/* ── ENDING SCREEN ──────────────────────── */
.ending-screen{
  position:fixed;inset:0;background:var(--deep);z-index:150;
  overflow-y:auto;padding:0;-webkit-overflow-scrolling:touch;
}
.es-scene{
  min-height:45vmax;display:flex;align-items:flex-end;
  justify-content:space-around;padding:20px 20px 0;
}
.es-header{text-align:center;padding:20px 20px 14px;}
.es-age{display:inline-block;font-size:10px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);background:rgba(245,168,0,.1);border:1px solid rgba(245,168,0,.2);border-radius:999px;padding:4px 12px;margin-bottom:14px;}
.ending-badge{display:inline-block;font-family:'Syne',sans-serif;font-size:18px;font-weight:800;padding:8px 20px;border-radius:999px;margin-bottom:12px;}
.es-title{font-family:'Syne',sans-serif;font-size:28px;font-weight:800;line-height:1.05;letter-spacing:-.01em;margin-bottom:8px;}
.es-tagline{font-size:13px;color:var(--dim);line-height:1.65;margin-bottom:20px;}
.story-panel{
  background:var(--card);border:1px solid var(--border);border-radius:18px;
  padding:16px;margin:0 16px 10px;
  animation:panelIn .5s ease both;
}
@keyframes panelIn{from{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}
.sp-eyebrow{font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--gold2);margin-bottom:6px;display:flex;align-items:center;gap:5px;}
.sp-text{font-size:13px;line-height:1.78;color:var(--dim);}
.sp-text b{color:var(--text);}
.the-line{
  background:var(--gold);border-radius:18px;
  padding:18px 20px;margin:0 16px 10px;
  font-family:'Syne',sans-serif;font-size:15px;font-weight:800;
  color:#1A0F00;line-height:1.45;text-align:center;
  animation:panelIn .5s ease .4s both;
}
.es-report{padding:0 16px 12px;}
.rc{
  background:linear-gradient(160deg,#0A0A2A,#14142E);
  border:1px solid rgba(245,168,0,.18);border-radius:18px;
  padding:20px;position:relative;overflow:hidden;
}
.rc::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold2),var(--gold));}
.rc-hdr{text-align:center;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--border);}
.rc-label{font-size:10px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:4px;}
.rc-name{font-family:'Syne',sans-serif;font-size:18px;font-weight:800;color:var(--text);}
.rc-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.rc-rl{font-size:12px;color:var(--dim);display:flex;align-items:center;gap:6px;}
.rc-grade{font-family:'Syne',sans-serif;font-size:20px;font-weight:800;}
.rcg-A{color:#2ECC71;} .rcg-B{color:var(--gold);} .rcg-C{color:#E67E22;} .rcg-D{color:var(--bad);}
.rc-remark{font-size:12px;color:var(--dim);font-style:italic;text-align:center;margin-top:14px;padding-top:12px;border-top:1px solid var(--border);line-height:1.65;}
.rc-stamp{
  position:absolute;top:18px;right:18px;
  width:50px;height:50px;border-radius:50%;border:2px solid;
  display:flex;align-items:center;justify-content:center;
  font-family:'Syne',sans-serif;font-size:9px;font-weight:800;
  text-transform:uppercase;letter-spacing:.04em;
  transform:rotate(-12deg);text-align:center;line-height:1.2;
}
.rcs-good{border-color:var(--good);color:var(--good);}
.rcs-ok{border-color:var(--gold);color:var(--gold);}
.rcs-bad{border-color:var(--bad);color:var(--bad);}
.es-cta-wrap{
  background:var(--surface);border-radius:18px;
  padding:20px;margin:0 16px 10px;text-align:center;
}
.es-cta-title{font-family:'Syne',sans-serif;font-size:11px;font-weight:800;color:var(--mute);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;}
.es-eq{font-family:'Syne',sans-serif;font-size:24px;font-weight:800;color:var(--text);margin-bottom:6px;}
.es-eq span{color:var(--gold);}
.es-cta-sub{font-size:12px;color:var(--dim);line-height:1.6;margin-bottom:16px;}
.cta-btn{
  display:block;width:100%;padding:15px;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:#1A0F00;font-family:'Syne',sans-serif;
  font-size:14px;font-weight:800;border:none;border-radius:14px;
  cursor:pointer;letter-spacing:.02em;
  box-shadow:0 4px 20px rgba(245,168,0,.3);transition:all .15s;
}
.cta-btn:hover{box-shadow:0 6px 30px rgba(245,168,0,.5);}
.replay-btn{
  display:block;width:calc(100%-32px);margin:0 16px;padding:13px;
  background:none;border:1px solid var(--border);border-radius:14px;
  font-size:13px;color:var(--dim);cursor:pointer;text-align:center;
  transition:background .15s;margin-bottom:16px;
}
.replay-btn:hover{background:rgba(255,255,255,.04);}
.disc{font-size:10px;color:var(--mute);text-align:center;padding:0 24px 8px;line-height:1.7;}

/* ── CHAPTER TRANSITIONS ────────────────── */
.chapter-enter{animation:chIn .45s ease both;}
.chapter-exit{animation:chOut .35s ease both;}
@keyframes chIn{from{opacity:0;transform:scale(1.03);filter:blur(3px)}to{opacity:1;transform:scale(1);filter:blur(0)}}
@keyframes chOut{from{opacity:1}to{opacity:0;transform:scale(.97);filter:blur(3px)}}
