/* =====================================================================
   STARDUST / 宝宝  —  stylesheet
   Two worlds in one file:
     1) the ARCADE PORTAL (the disguise) — neon, techy, "a real game site"
     2) the EXPERIENCE (the surprise)     — moonlit, cinematic, tender
   You don't need to edit this. All wording lives in content.js.
   ===================================================================== */

:root{
  --font-ui: "Segoe UI", system-ui, -apple-system, "PingFang SC", "Microsoft YaHei", "Hiragino Sans GB", sans-serif;
  --font-serif: "Cormorant Garamond", Georgia, "Times New Roman", "Songti SC", "STSong", "Noto Serif SC", serif;

  /* arcade palette */
  --p-bg:#070912;
  --p-bg2:#0a0e1c;
  --p-panel:#0f1426;
  --p-panel2:#161d36;
  --p-line:rgba(255,255,255,.08);
  --p-text:#dfe6ff;
  --p-dim:#8a93b8;
  --cyan:#36e6e0;
  --mag:#ff5ea0;
  --vio:#9d7bff;
  --yel:#ffd36b;
  --grn:#5be37a;

  /* night palette */
  --n0:#06061a;
  --n1:#0c0a26;
  --n2:#15123f;
  --moon:#f6e7bd;
  --moon2:#fff8e6;
  --rose:#f7b2c4;
  --lav:#cdb8ff;
  --ink:#ece8ff;
  --muted:rgba(236,232,255,.66);
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;}
body{
  margin:0;background:var(--p-bg);color:var(--p-text);
  font-family:var(--font-ui);overflow:hidden;
  text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;
}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit;}
img{display:block;max-width:100%;}

/* screen switching */
.screen{position:fixed;inset:0;}
.hidden{display:none !important;}
.fade-out{animation:fadeOut .8s ease forwards;}
.fade-in{animation:fadeIn 1s ease forwards;}
@keyframes fadeOut{to{opacity:0;}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}

/* =====================================================================
   1) ARCADE PORTAL
   ===================================================================== */
#portal{
  position:fixed;inset:0;display:flex;flex-direction:column;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(157,123,255,.18), transparent 60%),
    radial-gradient(900px 500px at 10% 110%, rgba(54,230,224,.12), transparent 60%),
    linear-gradient(180deg,#070912,#05060f);
  color:var(--p-text);
}

/* top nav */
.pt-top{
  display:flex;align-items:center;gap:18px;padding:12px 20px;
  border-bottom:1px solid var(--p-line);
  background:linear-gradient(180deg,rgba(13,18,38,.9),rgba(13,18,38,.5));
  backdrop-filter:blur(8px);position:relative;z-index:5;
}
.pt-logo{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.06em;}
.pt-logo .mark{
  width:30px;height:30px;border-radius:9px;display:grid;place-items:center;
  background:conic-gradient(from 200deg,var(--cyan),var(--vio),var(--mag),var(--cyan));
  box-shadow:0 0 18px rgba(157,123,255,.6);color:#06070f;font-size:18px;
}
.pt-logo b{background:linear-gradient(90deg,#fff,#bcd0ff);-webkit-background-clip:text;background-clip:text;color:transparent;}
.pt-logo small{display:block;font-weight:600;font-size:10px;letter-spacing:.18em;color:var(--p-dim);text-transform:uppercase;}
.pt-nav{display:flex;gap:6px;margin-left:8px;}
.pt-nav a{padding:7px 13px;border-radius:9px;color:var(--p-dim);font-size:13px;font-weight:600;text-decoration:none;}
.pt-nav a.active,.pt-nav a:hover{color:#fff;background:rgba(255,255,255,.06);}
.pt-search{
  margin-left:auto;display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.05);
  border:1px solid var(--p-line);border-radius:10px;padding:7px 12px;color:var(--p-dim);font-size:13px;min-width:160px;
}
.pt-icons{display:flex;gap:8px;}
.pt-icons button{
  width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.05);
  border:1px solid var(--p-line);display:grid;place-items:center;font-size:16px;color:var(--p-text);
  transition:.15s;
}
.pt-icons button:hover{background:rgba(255,255,255,.12);}

/* body layout: stage + sidebar */
.pt-body{flex:1;display:flex;min-height:0;}
.pt-stage{
  flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;
  padding:18px 18px 10px;gap:12px;overflow:hidden;position:relative;
}
.pt-titlebar{width:100%;max-width:980px;display:flex;align-items:flex-end;gap:14px;}
.pt-gtitle{font-weight:800;font-size:clamp(20px,3.4vw,30px);letter-spacing:.04em;
  background:linear-gradient(92deg,var(--cyan),#cfe6ff 40%,var(--mag));-webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 30px rgba(255,94,160,.25);}
.pt-gtag{font-size:12px;color:var(--p-dim);padding-bottom:5px;}
.pt-meta{margin-left:auto;display:flex;gap:16px;align-items:center;padding-bottom:4px;color:var(--p-dim);font-size:12px;}
.pt-stars{color:var(--yel);letter-spacing:2px;}

/* the game frame */
.pt-frame{
  position:relative;width:100%;max-width:980px;flex:1;min-height:0;
  border-radius:16px;overflow:hidden;border:1px solid rgba(157,123,255,.25);
  background:#05060f;
  box-shadow:0 30px 80px rgba(0,0,0,.6), inset 0 0 0 1px rgba(255,255,255,.03), 0 0 60px rgba(54,230,224,.06);
}
#game-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;touch-action:none;}

/* HUD */
.hud{
  position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:18px;
  padding:12px 16px;font-weight:700;font-size:13px;letter-spacing:.08em;
  pointer-events:none;z-index:3;
  background:linear-gradient(180deg,rgba(5,6,15,.65),transparent);
}
.hud .stat{display:flex;flex-direction:column;line-height:1.1;}
.hud .stat span{font-size:10px;color:var(--p-dim);letter-spacing:.12em;font-weight:600;}
.hud .stat b{font-size:17px;color:#fff;}
.hud .balls{margin-left:auto;display:flex;gap:6px;align-items:center;}
.hud .ball-dot{width:11px;height:11px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#fff,var(--cyan));box-shadow:0 0 10px var(--cyan);}
.hud .ball-dot.off{background:#26304d;box-shadow:none;}
.hud .combo{color:var(--yel);text-shadow:0 0 12px rgba(255,211,107,.6);min-width:54px;text-align:right;opacity:0;transition:.2s;}
.hud .combo.show{opacity:1;}

/* overlays inside the frame */
.pt-overlay{
  position:absolute;inset:0;z-index:4;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;gap:18px;padding:24px;
  background:radial-gradient(700px 400px at 50% 40%,rgba(20,29,54,.65),rgba(5,6,15,.92));
  backdrop-filter:blur(2px);
}
.pt-overlay.gone{display:none;}
.ov-badge{font-size:11px;letter-spacing:.25em;color:var(--cyan);text-transform:uppercase;
  border:1px solid rgba(54,230,224,.4);padding:5px 12px;border-radius:999px;}
.ov-title{font-weight:800;font-size:clamp(28px,6vw,52px);letter-spacing:.04em;
  background:linear-gradient(92deg,#fff,#bcd0ff);-webkit-background-clip:text;background-clip:text;color:transparent;}
.ov-sub{max-width:440px;color:var(--p-dim);font-size:14px;line-height:1.6;}
.btn-play{
  margin-top:6px;display:inline-flex;align-items:center;gap:10px;
  padding:15px 34px;border-radius:14px;font-weight:800;font-size:17px;letter-spacing:.06em;color:#05060f;
  background:linear-gradient(92deg,var(--cyan),#a6f0ff 30%,var(--vio));
  box-shadow:0 14px 40px rgba(54,230,224,.35), 0 0 0 1px rgba(255,255,255,.2) inset;
  transition:transform .12s ease, box-shadow .2s;
}
.btn-play:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 18px 50px rgba(157,123,255,.5);}
.btn-play:active{transform:translateY(0) scale(.99);}
.btn-ghost{
  padding:11px 22px;border-radius:11px;font-weight:700;color:#dfe6ff;
  background:rgba(255,255,255,.06);border:1px solid var(--p-line);
}
.btn-ghost:hover{background:rgba(255,255,255,.12);}

/* fake loading bar */
.ld-wrap{width:min(420px,80%);}
.ld-track{height:8px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden;}
.ld-fill{height:100%;width:0;border-radius:99px;
  background:linear-gradient(90deg,var(--cyan),var(--vio),var(--mag));box-shadow:0 0 16px rgba(157,123,255,.7);}
.ld-pct{margin-top:8px;font-size:12px;color:var(--p-dim);letter-spacing:.1em;}

/* center toast (LEVEL CLEAR etc.) */
.toast{
  position:absolute;left:50%;top:46%;transform:translate(-50%,-50%) scale(.8);
  z-index:4;font-weight:800;font-size:clamp(26px,6vw,46px);letter-spacing:.06em;text-align:center;
  color:#fff;text-shadow:0 0 30px rgba(54,230,224,.8);opacity:0;pointer-events:none;
}
.toast.pop{animation:toastPop 1.3s ease forwards;}
@keyframes toastPop{
  0%{opacity:0;transform:translate(-50%,-50%) scale(.7);}
  18%{opacity:1;transform:translate(-50%,-50%) scale(1.06);}
  78%{opacity:1;transform:translate(-50%,-50%) scale(1);}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1.04);}
}

/* sidebar — fake "more games" */
.pt-side{
  width:248px;flex-shrink:0;border-left:1px solid var(--p-line);
  background:linear-gradient(180deg,rgba(13,18,38,.6),rgba(8,11,24,.6));
  padding:16px 14px;overflow:auto;
}
.pt-side h4{margin:4px 4px 12px;font-size:12px;letter-spacing:.14em;color:var(--p-dim);text-transform:uppercase;}
.gcard{display:flex;gap:11px;align-items:center;padding:9px;border-radius:12px;margin-bottom:6px;transition:.15s;cursor:pointer;}
.gcard:hover{background:rgba(255,255,255,.06);}
.gcard .thumb{width:52px;height:52px;border-radius:11px;flex-shrink:0;box-shadow:0 6px 16px rgba(0,0,0,.4);}
.gcard .gi b{display:block;font-size:13px;color:#eaf0ff;}
.gcard .gi small{font-size:11px;color:var(--p-dim);}
.gcard .gi .mini-stars{color:var(--yel);font-size:10px;letter-spacing:1px;}

.pt-foot{
  padding:9px 20px;border-top:1px solid var(--p-line);color:var(--p-dim);font-size:11px;
  display:flex;align-items:center;gap:14px;letter-spacing:.04em;
}
.pt-foot .dot{width:4px;height:4px;border-radius:50%;background:var(--p-dim);}

/* =====================================================================
   TRANSFORM bridge
   ===================================================================== */
#flash{position:fixed;inset:0;background:#fff;opacity:0;pointer-events:none;z-index:60;}
#flash.boom{animation:boom 1.5s ease forwards;}
@keyframes boom{0%{opacity:0;}22%{opacity:1;}100%{opacity:0;}}

/* =====================================================================
   2) THE EXPERIENCE
   ===================================================================== */
#exp{
  position:fixed;inset:0;overflow:hidden;color:var(--ink);
  background:
    radial-gradient(1100px 700px at 78% -8%, rgba(205,184,255,.16), transparent 60%),
    radial-gradient(900px 700px at 12% 108%, rgba(247,178,196,.12), transparent 60%),
    linear-gradient(180deg,var(--n0),var(--n1) 55%,var(--n2));
}
#stars-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
#exp-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;
  transition:opacity 2s ease;z-index:0;mix-blend-mode:screen;pointer-events:none;}
#exp-video.show{opacity:.5;}

/* top controls */
.exp-top{position:absolute;top:0;right:0;z-index:30;display:flex;gap:8px;padding:16px;}
.exp-top button{
  padding:8px 14px;border-radius:11px;font-size:13px;font-weight:600;color:var(--ink);
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(6px);transition:.15s;
}
.exp-top button:hover{background:rgba(255,255,255,.16);}

/* scenes */
.scene{
  position:absolute;inset:0;z-index:10;display:block;text-align:center;
  opacity:0;visibility:hidden;transition:opacity .9s ease;overflow-y:auto;-webkit-overflow-scrolling:touch;
}
.scene.active{opacity:1;visibility:visible;}
.scene-inner{width:100%;max-width:680px;min-height:100%;box-sizing:border-box;margin:0 auto;padding:48px 22px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;}

/* typography */
.kicker{font-size:13px;letter-spacing:.28em;text-transform:uppercase;color:var(--lav);opacity:.85;}
.serif{font-family:var(--font-serif);}
h1.big{font-family:var(--font-serif);font-weight:600;line-height:1.05;margin:0;
  font-size:clamp(44px,12vw,104px);
  background:linear-gradient(180deg,var(--moon2),var(--moon) 55%,#e9c98f);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 60px rgba(246,231,189,.25);}
h2.title{font-family:var(--font-serif);font-weight:600;margin:0;font-size:clamp(28px,6vw,48px);color:var(--moon2);}
p.lead{font-size:clamp(16px,2.4vw,20px);line-height:1.7;color:var(--ink);margin:0;}
p.soft{color:var(--muted);line-height:1.7;margin:0;font-size:clamp(15px,2vw,17px);}
.whisper{font-family:var(--font-serif);font-style:italic;color:var(--lav);font-size:clamp(17px,2.6vw,22px);line-height:1.6;}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:9px;padding:14px 28px;border-radius:999px;
  font-weight:600;font-size:16px;letter-spacing:.02em;color:#1a1330;
  background:linear-gradient(92deg,var(--moon2),var(--moon) 55%,var(--rose));
  box-shadow:0 14px 40px rgba(246,231,189,.22), 0 0 0 1px rgba(255,255,255,.35) inset;
  transition:transform .14s ease, box-shadow .2s;
}
.btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 18px 52px rgba(247,178,196,.4);}
.btn:active{transform:translateY(0);}
.btn.outline{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.2);color:var(--ink);box-shadow:none;}
.btn.outline:hover{background:rgba(255,255,255,.14);}
.tap-hint{color:var(--muted);font-size:13px;letter-spacing:.06em;animation:breathe 2.6s ease-in-out infinite;}
@keyframes breathe{0%,100%{opacity:.5;}50%{opacity:1;}}

/* the moon */
.moon{
  width:clamp(120px,30vw,210px);aspect-ratio:1;border-radius:50%;position:relative;
  background:
    radial-gradient(circle at 38% 34%, #fffdf4, var(--moon) 45%, #d9bd86 78%, #c4a36a);
  box-shadow:0 0 80px 12px rgba(246,231,189,.45), inset -18px -14px 40px rgba(120,95,55,.45);
  animation:moonFloat 7s ease-in-out infinite;
}
.moon::after{content:"";position:absolute;inset:-40%;border-radius:50%;
  background:radial-gradient(circle,rgba(246,231,189,.22),transparent 62%);pointer-events:none;}
@keyframes moonFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}

/* gate video frame */
.gate-stage{position:relative;width:min(560px,86vw);border-radius:24px;overflow:hidden;
  border:1px solid rgba(255,255,255,.12);box-shadow:0 30px 90px rgba(0,0,0,.55);}
.gate-stage video{width:100%;display:block;height:300px;object-fit:cover;}
.gate-vibe{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,6,26,.1),rgba(8,6,26,.85));
  display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:14px;padding:26px;}

.story-video-frame{width:min(720px,94vw);border-radius:22px;overflow:hidden;
  border:1px solid rgba(255,255,255,.16);background:#050712;
  box-shadow:0 30px 90px rgba(0,0,0,.62),0 0 70px rgba(246,231,189,.14);}
.story-video-frame video{width:100%;display:block;aspect-ratio:16/9;object-fit:contain;background:#050712;}

/* ---- birthday reveal ---- */
.bd-name{font-family:var(--font-serif);font-size:clamp(40px,9vw,84px);color:var(--moon2);margin:6px 0;}
.confetti-layer{position:absolute;inset:0;z-index:20;pointer-events:none;overflow:hidden;}
.confetti{position:absolute;top:-20px;width:10px;height:14px;border-radius:2px;opacity:.95;animation:fall linear forwards;}
@keyframes fall{to{transform:translateY(110vh) rotate(720deg);opacity:.9;}}
.photo-frame{width:min(280px,72vw);border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.16);
  box-shadow:0 20px 60px rgba(0,0,0,.5);background:rgba(255,255,255,.04);}
.photo-frame img{width:100%;display:block;}

/* ---- discord ---- */
.dc{width:min(560px,92vw);background:#313338;border-radius:16px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.6);text-align:left;border:1px solid rgba(0,0,0,.4);}
.dc-head{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#2b2d31;border-bottom:1px solid rgba(0,0,0,.3);color:#dbdee1;font-weight:600;font-size:14px;}
.dc-head .hash{color:#80848e;font-size:20px;}
.dc-head small{margin-left:auto;color:#80848e;font-weight:500;font-size:12px;}
.dc-body{padding:14px 16px;height:340px;overflow:auto;display:flex;flex-direction:column;gap:14px;background:#313338;}
.dc-msg{display:flex;gap:12px;animation:popIn .35s ease both;}
.dc-ava{width:40px;height:40px;border-radius:50%;flex-shrink:0;}
.dc-c .nm{font-weight:600;color:#fff;font-size:15px;}
.dc-c .nm time{color:#949ba4;font-weight:500;font-size:11px;margin-left:8px;}
.dc-c .tx{color:#dbdee1;font-size:14.5px;line-height:1.45;white-space:pre-line;margin-top:2px;}
.dc-react{display:inline-flex;align-items:center;gap:5px;margin-top:6px;background:#2b2d31;border:1px solid #3f4248;
  border-radius:8px;padding:2px 8px;font-size:12px;color:#dbdee1;}
@keyframes popIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

/* ---- the box / necklace ---- */
.giftbox{width:min(280px,70vw);aspect-ratio:1;position:relative;cursor:pointer;user-select:none;}
.box-base{position:absolute;left:8%;right:8%;bottom:0;height:62%;border-radius:14px;
  background:linear-gradient(160deg,#3a2c5e,#241a45);box-shadow:0 24px 60px rgba(0,0,0,.5), inset 0 2px 0 rgba(255,255,255,.12);}
.box-lid{position:absolute;left:2%;right:2%;top:14%;height:26%;border-radius:12px;transform-origin:center bottom;
  background:linear-gradient(160deg,#4a3a72,#2e2255);box-shadow:0 12px 30px rgba(0,0,0,.5), inset 0 2px 0 rgba(255,255,255,.14);z-index:3;transition:transform .2s;}
.box-rib-v{position:absolute;left:46%;top:8%;width:8%;height:70%;background:linear-gradient(90deg,var(--rose),#e98aa6);z-index:4;border-radius:4px;}
.box-rib-h{position:absolute;left:8%;right:8%;top:34%;height:9%;background:linear-gradient(180deg,var(--rose),#e98aa6);z-index:2;border-radius:4px;}
.box-bow{position:absolute;left:50%;top:6%;transform:translateX(-50%);font-size:42px;z-index:5;filter:drop-shadow(0 4px 8px rgba(0,0,0,.4));}
.giftbox.shake{animation:boxShake .5s ease-in-out infinite;}
@keyframes boxShake{0%,100%{transform:rotate(0);}25%{transform:rotate(-4deg);}75%{transform:rotate(4deg);}}
.giftbox.open .box-lid{transform:translateY(-130%) rotate(-16deg);}
.necklace-reveal{width:min(330px,80vw);border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.16);
  box-shadow:0 0 70px rgba(246,231,189,.4), 0 24px 70px rgba(0,0,0,.5);animation:revealPop .9s ease both;}
@keyframes revealPop{0%{opacity:0;transform:scale(.7);}60%{transform:scale(1.04);}100%{opacity:1;transform:scale(1);}}

/* ---- gifts ---- */
.gift-grid{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;width:100%;}
.gift{width:min(200px,42vw);background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:14px;display:flex;flex-direction:column;
  align-items:center;gap:10px;cursor:pointer;transition:transform .2s, box-shadow .2s;position:relative;overflow:hidden;}
.gift:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(0,0,0,.4);}
.gift .wrap-cover{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(160deg,#4a3a72,#241a45);transition:opacity .5s, transform .6s;}
.gift .wrap-cover .ribbon{position:absolute;left:46%;top:0;bottom:0;width:8%;background:linear-gradient(90deg,var(--rose),#e98aa6);}
.gift .wrap-cover .ribbon.h{left:0;right:0;top:46%;bottom:auto;width:auto;height:8%;background:linear-gradient(180deg,var(--rose),#e98aa6);}
.gift .wrap-cover .bow{font-size:34px;z-index:2;}
.gift .wrap-cover .lbl{position:absolute;bottom:14px;font-size:12px;color:#fff;letter-spacing:.1em;opacity:.9;z-index:2;}
.gift.opened .wrap-cover{opacity:0;transform:translateY(-8%) scale(1.05);pointer-events:none;}
.gift .art{width:140px;height:140px;}
.gift .gname{font-family:var(--font-serif);font-size:18px;color:var(--moon2);text-align:center;line-height:1.2;}
.gift-caption{max-width:560px;min-height:1.2em;}
.gift-thumbs{display:flex;gap:10px;justify-content:center;margin-top:4px;}
.gift-thumbs .t{width:46px;height:46px;border-radius:12px;border:1px solid rgba(255,255,255,.14);opacity:.5;cursor:pointer;
  display:grid;place-items:center;transition:.15s;background:rgba(255,255,255,.04);overflow:hidden;}
.gift-thumbs .t.active,.gift-thumbs .t:hover{opacity:1;border-color:var(--moon);box-shadow:0 0 16px rgba(246,231,189,.4);}
.gift-thumbs .t svg,.gift-thumbs .t img{width:100%;height:100%;}

/* dog spinner */
.spinner-stage{display:flex;flex-direction:column;align-items:center;gap:12px;}
.spinner{width:min(220px,60vw);aspect-ratio:1;position:relative;}
.spin-wheel{position:absolute;inset:0;transition:transform 1.1s cubic-bezier(.2,.8,.15,1);}
.slap-count{font-family:var(--font-serif);font-size:22px;color:var(--rose);}

/* ---- deliveries / countdown ---- */
.deliv-card{width:min(440px,92vw);background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:26px;display:flex;flex-direction:column;align-items:center;gap:14px;}
.deliv-emoji{font-size:54px;filter:drop-shadow(0 8px 18px rgba(0,0,0,.4));animation:moonFloat 4s ease-in-out infinite;}
.countdown{display:flex;gap:10px;font-family:var(--font-serif);}
.cd-unit{min-width:62px;background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:10px 6px;}
.cd-unit b{display:block;font-size:30px;color:var(--moon2);line-height:1;}
.cd-unit span{font-size:10px;letter-spacing:.16em;color:var(--muted);text-transform:uppercase;}
.cd-arrived{color:var(--grn,#9ff5b0);font-weight:600;}
.candle{width:14px;height:54px;margin:0 auto;background:linear-gradient(180deg,#ffe9b0,#e9b96a);border-radius:6px;position:relative;}
.flame{position:absolute;top:-22px;left:50%;transform:translateX(-50%);width:16px;height:24px;border-radius:50% 50% 50% 50%/60% 60% 40% 40%;
  background:radial-gradient(circle at 50% 70%,#fff7c2,#ffb347 55%,#ff6a00);box-shadow:0 0 20px #ffae3c;animation:flick .25s infinite alternate;transform-origin:bottom;}
.flame.out{opacity:0;transition:opacity .4s;}
@keyframes flick{from{transform:translateX(-50%) scale(1);}to{transform:translateX(-52%) scale(1.08,.94);}}

/* ---- letter ---- */
.letter{width:min(620px,92vw);background:linear-gradient(180deg,rgba(255,250,240,.97),rgba(252,244,232,.95));
  color:#2a2342;border-radius:14px;padding:clamp(26px,5vw,52px);text-align:left;font-family:var(--font-serif);
  box-shadow:0 40px 100px rgba(0,0,0,.55);line-height:1.85;position:relative;}
.letter h3{font-size:clamp(24px,5vw,34px);margin:0 0 18px;color:#5a3d6b;font-weight:600;}
.letter p{font-size:clamp(16px,2.4vw,19px);margin:0 0 16px;opacity:0;transform:translateY(8px);}
.letter p.in{animation:lineIn .9s ease forwards;}
@keyframes lineIn{to{opacity:1;transform:none;}}
.letter .sign{margin-top:22px;font-style:italic;color:#7a5a86;}
.letter .sign b{display:block;font-style:normal;font-size:20px;color:#5a3d6b;}

/* ---- end ---- */
.end-line{font-family:var(--font-serif);font-size:clamp(26px,5vw,42px);color:var(--moon2);}

/* generic helpers */
.center-col{display:flex;flex-direction:column;align-items:center;gap:16px;}
.spark{position:absolute;width:6px;height:6px;border-radius:50%;background:#fff;pointer-events:none;box-shadow:0 0 8px #fff;}
.row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;}

/* responsive */
@media (max-width:880px){
  .pt-side{display:none;}
  .pt-nav{display:none;}
  .pt-search{display:none;}
}
@media (max-width:560px){
  .pt-stage{padding:12px 10px 6px;}
  .hud{gap:12px;padding:10px;}
  .dc-body{height:300px;}
  .gate-stage video{height:230px;}
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001s !important;}
  .scene{transition:opacity .4s;}
}

/* ===== real gift photos ===== */
.real-photo{width:100%;height:100%;object-fit:contain;border-radius:12px;background:rgba(2,6,18,.45);}
.gift .art{display:flex;align-items:center;justify-content:center;overflow:hidden;}
.gift .art img,.gift .art svg{width:100%;height:100%;object-fit:contain;}
.necklace-reveal{background:#0b1430;}
.necklace-reveal .real-photo{background:#0b1430;}

/* ===== her palette: deep blue/black, emerald + blue + white, soft pink ===== */
:root{ --n0:#04060f; --n1:#081024; --n2:#0c1b34; --lav:#9fd0ff; --rose:#ff9bb4; }
#exp{ background:
  radial-gradient(1100px 700px at 78% -8%, rgba(52,214,168,.16), transparent 60%),
  radial-gradient(900px 700px at 12% 108%, rgba(74,139,255,.16), transparent 60%),
  linear-gradient(180deg,#04060f,#081024 55%,#0c1b34); }
h1.big{ background:linear-gradient(180deg,#ffffff,#bfe7ff 50%,#7af0c4); -webkit-background-clip:text; background-clip:text; color:transparent; text-shadow:0 0 60px rgba(74,139,255,.30); }
h2.title{ color:#eaf4ff; }
.kicker{ color:#7af0c4; }
.whisper{ color:#a8d6ff; }
.btn{ color:#06241d; background:linear-gradient(92deg,#eafff8,#a9ecff 45%,#67e6b4); box-shadow:0 14px 40px rgba(52,214,168,.26), 0 0 0 1px rgba(255,255,255,.35) inset; }
.btn:hover{ box-shadow:0 18px 52px rgba(74,139,255,.42); }
.bd-name,.end-line{ color:#eaf4ff; }

/* ===== dog slap flip-book toy ===== */
.dog-toy{width:min(260px,72vw);margin:2px auto;}
.dog-toy .frame{background:linear-gradient(180deg,#caa46a,#a9824a);padding:14px;border-radius:16px;
  box-shadow:0 18px 50px rgba(0,0,0,.5), inset 0 2px 0 rgba(255,255,255,.3);position:relative;}
.dog-toy .frame::after{content:"";position:absolute;right:-14px;top:50%;width:26px;height:10px;border-radius:6px;
  background:linear-gradient(180deg,#caa46a,#8c6a3c);transform:translateY(-50%);box-shadow:2px 0 6px rgba(0,0,0,.4);}
.dog-toy .paper{background:#fffdf7;border-radius:9px;overflow:hidden;border:1px solid #d9c39a;}
.dog-toy .cap{margin-top:8px;font-size:12px;color:var(--muted);text-align:center;letter-spacing:.04em;}

/* ===== photo gallery ===== */
.gallery{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;}
.gallery img{width:118px;height:150px;object-fit:cover;border-radius:14px;border:1px solid rgba(255,255,255,.18);
  box-shadow:0 12px 30px rgba(0,0,0,.45);transition:transform .25s;}
.gallery img:hover{transform:translateY(-4px) scale(1.03);}
.photo-frame img{object-fit:cover;max-height:360px;}

/* uploaded dog frames flip */
.dogflip{position:relative;width:100%;padding-top:82%;}
.dogflip .df{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;}
.dogflip .df1{animation:dfk .18s steps(1) infinite}
.dogflip .df2{animation:dfk2 .18s steps(1) infinite}
@keyframes dfk{0%,49%{opacity:1}50%,100%{opacity:0}}
@keyframes dfk2{0%,49%{opacity:0}50%,100%{opacity:1}}

/* ===== HAPPY BIRTHDAY letter tray (in the game) ===== */
.letter-tray{position:absolute;left:0;right:0;bottom:8px;display:flex;gap:4px;justify-content:center;flex-wrap:wrap;z-index:3;pointer-events:none;padding:0 10px;}
.letter-tray .lt{width:22px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;
  background:rgba(255,255,255,.06);color:#46506e;border:1px solid rgba(255,255,255,.12);transition:.25s;}
.letter-tray .lt.on{background:linear-gradient(180deg,#fff4cf,#ffd36b);color:#7a4d12;box-shadow:0 0 14px rgba(255,211,107,.75);transform:translateY(-2px);}
.letter-tray .lt-sp{width:10px;}
@media(max-width:560px){ .letter-tray .lt{width:18px;height:22px;font-size:12px;} }

/* ===== gift "earn it" interactions ===== */
.earn-badge{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:50%;
  background:linear-gradient(180deg,#7af0c4,#34d6a8);color:#06231c;font-weight:800;font-size:14px;z-index:4;
  display:none;align-items:center;justify-content:center;box-shadow:0 0 14px rgba(91,227,176,.75);}
.gift.earned .earn-badge{display:flex;}
.gift-task{margin-top:8px;width:100%;}
.slap-time{font-family:var(--font-serif);font-size:18px;color:var(--rose);}
.pair-dots{display:flex;gap:10px;justify-content:center;margin:8px 0;}
.pair-dot{width:14px;height:14px;border-radius:50%;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);transition:.2s;}
.pair-dot.on{background:linear-gradient(180deg,#7af0c4,#34d6a8);box-shadow:0 0 12px rgba(91,227,176,.8);transform:scale(1.15);}
.hearts-host{position:relative;height:0;width:100%;}
.fheart{position:absolute;bottom:0;font-size:20px;color:#ff6f9c;animation:floatUp 1.6s ease-out forwards;pointer-events:none;}
@keyframes floatUp{0%{opacity:0;transform:translateY(0) scale(.6)}20%{opacity:1}100%{opacity:0;transform:translateY(-120px) scale(1.15)}}

/* ===== sidebar game icons ===== */
.gcard .thumb{overflow:hidden;}
.gcard .thumb svg{width:100%;height:100%;display:block;}

/* ===== small polish ===== */
p.lead{max-width:600px;}
.gift-caption{margin-top:10px;}
.kicker{margin-bottom:2px;}

/* ===== gift modal + wrapped cards (hidden until unlocked) ===== */
.gmodal{position:fixed;inset:0;z-index:60;background:rgba(4,6,15,.82);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease;}
.gmodal-box{width:min(420px,92vw);max-height:90vh;overflow-y:auto;text-align:center;
  background:linear-gradient(180deg,#111a3e,#0b1228);border:1px solid rgba(255,255,255,.14);border-radius:22px;
  padding:26px;display:flex;flex-direction:column;align-items:center;gap:14px;box-shadow:0 30px 90px rgba(0,0,0,.6);}
.gbox-wrap{font-size:46px;animation:moonFloat 3s ease-in-out infinite;}
.greveal{width:min(260px,70vw);border-radius:16px;overflow:hidden;animation:revealPop .8s both;box-shadow:0 0 50px rgba(122,240,196,.25);}
.greveal .real-photo,.greveal img{border-radius:16px;}
.gtitle{font-family:var(--font-serif);font-size:clamp(22px,5vw,30px);color:var(--moon2);margin:2px 0 0;}
.gmsg{max-width:360px;}

.gift.wrapped{cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:198px;position:relative;}
.gift-wrap{position:relative;width:124px;height:124px;border-radius:16px;background:linear-gradient(160deg,#2a3a72,#16204a);
  box-shadow:0 16px 40px rgba(0,0,0,.45), inset 0 2px 0 rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;transition:transform .2s;}
.gift.wrapped:hover .gift-wrap{transform:translateY(-4px) scale(1.04) rotate(-1deg);}
.gift-wrap .ribbon{position:absolute;left:46%;top:0;bottom:0;width:8%;background:linear-gradient(90deg,var(--rose),#e98aa6);}
.gift-wrap .ribbon.h{left:0;right:0;top:46%;bottom:auto;height:8%;width:auto;background:linear-gradient(180deg,var(--rose),#e98aa6);}
.gift-wrap .bow{font-size:36px;z-index:2;filter:drop-shadow(0 3px 6px rgba(0,0,0,.4));}
.gift-wrap .qn{position:absolute;bottom:6px;right:9px;font-size:11px;color:rgba(255,255,255,.45);}
.gift-thumb{display:none;width:124px;height:124px;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.16);background:#0b1430;}
.gift-thumb svg,.gift-thumb img{width:100%;height:100%;object-fit:contain;}
.gift.earned .gift-wrap{display:none;}
.gift.earned .gift-thumb{display:block;animation:revealPop .6s both;}
.wrap-lbl{font-size:13px;color:var(--muted);letter-spacing:.03em;}
.gift.earned .wrap-lbl{color:var(--moon);}

/* ===== drifting petals + wish moon ===== */
.petal{position:absolute;top:-24px;width:11px;height:11px;border-radius:62% 0 62% 0;
  background:linear-gradient(180deg,#ffd6e2,#ff9fb6);animation:petalFall linear infinite;pointer-events:none;
  will-change:transform;transform:translate3d(0,-24px,0);}
@keyframes petalFall{0%{transform:translate3d(0,-24px,0) rotate(0)}50%{transform:translate3d(18px,45vh,0) rotate(160deg)}100%{transform:translate3d(-8px,106vh,0) rotate(320deg)}}
.moon.wish{cursor:pointer;transition:transform .2s, box-shadow .2s;}
.moon.wish:hover{transform:scale(1.05);box-shadow:0 0 100px 16px rgba(246,231,189,.6), inset -18px -14px 40px rgba(120,95,55,.45);}
.moon.wish:active{transform:scale(.98);}
