/* base.css — CSS variables, reset, shared elements (modals, topbar, overlay) */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;600;700;800;900&family=Playfair+Display:ital,wght@1,700;1,900&family=Space+Grotesk:wght@500;700;800;900&display=swap');

/* ── Splash Intro ─────────────────────────────────────────────── */
.splash-intro{position:fixed;inset:0;z-index:9999;
  background:var(--bg);display:flex;flex-direction:column;
  align-items:center;justify-content:center;overflow:hidden;
  transition:opacity .5s ease,visibility .5s ease}
.splash-intro.hidden{opacity:0;visibility:hidden;pointer-events:none}

/* Grid pattern */
.splash-grid{position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size:44px 44px;opacity:.35}

/* Center content */
.splash-content{position:relative;z-index:2;text-align:center;
  animation:splashFadeUp .6s .1s both cubic-bezier(.22,1,.36,1)}
.splash-name{font-family:'Playfair Display',serif;font-style:italic;font-weight:900;
  font-size:48px;color:var(--text);letter-spacing:-.5px;line-height:1;margin-bottom:20px}
.splash-slogan{font-family:'Outfit',sans-serif;font-size:22px;font-weight:700;
  color:var(--text);text-align:center;line-height:1.55}
.splash-tag{background:var(--text);color:var(--bg);
  padding:2px 10px;border-radius:8px;display:inline-block}

/* Dot decorations */
.splash-dot{position:absolute;border-radius:50%;z-index:1;opacity:.7}
.sd1{width:14px;height:14px;background:#E8674A;top:30%;left:8%;animation:splashFloat 3.5s ease-in-out infinite}
.sd2{width:10px;height:10px;background:#5BBF70;top:25%;right:10%;animation:splashFloat 4s .4s ease-in-out infinite}
.sd3{width:12px;height:12px;background:#5B8FE8;top:55%;left:6%;animation:splashFloat 3.8s .2s ease-in-out infinite}
.sd4{width:8px;height:8px;background:#F5C840;top:50%;right:7%;animation:splashFloat 4.3s .6s ease-in-out infinite}
.sd5{width:16px;height:16px;background:#E85A8A;bottom:35%;left:12%;animation:splashFloat 3.6s .1s ease-in-out infinite}
.sd6{width:11px;height:11px;background:#E8674A;bottom:30%;right:11%;animation:splashFloat 4.1s .7s ease-in-out infinite}

/* Footer */
.splash-footer{position:absolute;bottom:calc(28px + var(--sab,0px));
  font-family:'Playfair Display',serif;font-style:italic;font-weight:700;
  font-size:13px;color:var(--text2);z-index:2;
  animation:splashFadeUp .6s .3s both cubic-bezier(.22,1,.36,1)}

@keyframes splashFadeUp{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes splashFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
:root{
  --bg:#F7F1E8;--bg2:#EEE3CF;--card:#FFF9F2;--text:#1E1A14;--text2:#7A6A54;
  --border:rgba(0,0,0,.14);--primary:#E8674A;--primary2:#F5967C;
  --grad:linear-gradient(135deg,#E8674A,#F5967C);
  --green:#5BBF70;--yellow:#F5C840;--red:#E85A5A;--gold:#FFB703;
  --shadow:0 2px 16px rgba(180,100,60,.12);
  --btn-game:#EBE0CC;
  /* Level card */
  --lcard-bg:var(--bg);--lcard-border:rgba(0,0,0,.25);
  --lcard-text:#000;--lcard-sub:rgba(0,0,0,.4);--lcard-lk-num:var(--text);
  --sat: env(safe-area-inset-top, 0px);
  --sab: env(safe-area-inset-bottom, 0px);
}
.dark{
  --bg:#111118;--bg2:#17171F;--card:#1D1D28;--text:#F0EAE0;--text2:#9A8F82;
  --border:rgba(255,255,255,.14);--primary:#F47B68;--primary2:#F5A090;
  --grad:linear-gradient(135deg,#F47B68,#F5A090);--btn-game:#1D1D28;
  --shadow:0 2px 16px rgba(0,0,0,.5);
  /* Level card */
  --lcard-bg:var(--bg);--lcard-border:rgba(255,255,255,.25);
  --lcard-text:#fff;--lcard-sub:rgba(255,255,255,.4);--lcard-lk-num:var(--text);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{height:100%}
body{font-family:'Outfit',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);display:flex;justify-content:center;height:100%;overflow:hidden;-webkit-text-size-adjust:100%;text-size-adjust:100%}
#app{width:100%;max-width:420px;height:100%;background:var(--bg);position:relative;display:flex;flex-direction:column;overflow:hidden;transition:background .3s}
@media(min-width:600px){#app{max-width:560px}}
@media(min-width:768px){#app{max-width:680px}}
@media(min-width:1024px){#app{max-width:860px;box-shadow:0 0 0 1px rgba(0,0,0,.12),0 24px 80px rgba(0,0,0,.28)}}
@media(min-width:1366px){#app{max-width:1020px}}

/* Topbar (shared by levels/game/settings) */
.topbar{display:flex;align-items:center;padding:13px 14px;
  padding-top:calc(13px + var(--sat));
  background:transparent;gap:9px;flex-shrink:0}
.topbar h2{flex:1;font-size:18px;font-weight:800;text-align:center;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.back{width:38px;height:38px;border:none;background:transparent;border-radius:11px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;color:var(--text);padding:0;flex-shrink:0}
@media(min-width:768px){
  .topbar{padding:16px 20px;padding-top:calc(16px + var(--sat));gap:12px}
  .topbar h2{font-size:22px}
  .back{width:46px;height:46px;font-size:22px;border-radius:14px}
}
@media(min-width:1024px){
  .topbar{padding:20px 28px;padding-top:calc(20px + var(--sat));gap:16px}
  .topbar h2{font-size:26px}
  .back{width:54px;height:54px;font-size:26px;border-radius:16px}
}

/* Save indicator — hidden from players */
.save-ind{display:none}

/* Overlay + modal (shared) */
.ov{position:fixed;inset:0;background:rgba(20,15,50,.82);display:flex;align-items:center;justify-content:center;z-index:200;padding:18px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:ovFadeIn .2s ease}
@keyframes ovFadeIn{from{opacity:0}to{opacity:1}}
.modal{background:var(--card);border-radius:22px;padding:22px 18px;width:100%;max-width:310px;text-align:center;animation:popIn .22s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden;will-change:transform,opacity}
@media(min-width:768px){.modal{max-width:380px;padding:26px 24px;border-radius:26px}}
@media(min-width:1024px){.modal{max-width:440px}}
@keyframes popIn{0%{transform:scale(.8) translateY(16px);opacity:0}100%{transform:scale(1) translateY(0);opacity:1}}
.modal h3{font-size:20px;font-weight:900;color:var(--text);margin-bottom:6px}
.modal p{font-size:13px;color:var(--text2);line-height:1.55}
.m-btns{display:flex;flex-direction:column;gap:7px;margin-top:12px;position:relative}
.mbtn{padding:13px;border:none;border-radius:13px;font-size:14px;font-weight:700;cursor:pointer;width:100%;transition:transform .1s}
.mbtn:active{transform:scale(.97)}
.mbtn.pr{background:var(--grad);color:#fff}
.mbtn.sc{background:var(--bg2);color:var(--text2)}
.mbtn.gn{background:var(--green);color:#fff}

/* Ad progress bar */
.ad-prog{width:100%;height:7px;background:var(--bg2);border-radius:4px;margin:14px 0;overflow:hidden}
.ad-fill{height:100%;width:0;background:linear-gradient(90deg,var(--primary),var(--primary2));border-radius:4px}

/* Hint shop packages */
.hint-pkg{background:var(--card);border-radius:16px;padding:14px;margin-bottom:10px;border:2px solid var(--border);position:relative;overflow:hidden;cursor:pointer;transition:border-color .15s,transform .12s}
.hint-pkg:active{transform:scale(.98)}
.hint-pkg.popular{border-color:var(--primary)}
.hint-pkg.best{border-color:var(--yellow)}
.pkg-tag{position:absolute;top:0;right:0;padding:4px 12px;font-size:10px;font-weight:800;color:#fff;border-radius:0 14px 0 10px}
.pkg-tag.hot{background:var(--primary)}
.pkg-tag.best-val{background:linear-gradient(135deg,#FFB703,#FF9F1C)}
.pkg-row{display:flex;align-items:center;gap:12px}
.pkg-icon{font-size:28px}
.pkg-info{flex:1}
.pkg-name{font-size:15px;font-weight:800;color:var(--text)}
.pkg-save{font-size:11px;color:var(--green);font-weight:700;margin-top:2px}
.pkg-price{text-align:right}
.pkg-amount{font-size:18px;font-weight:900;color:var(--primary)}
.pkg-per{font-size:10px;color:var(--text2);margin-top:1px}

/* Confetti canvas inside win modal */
#win-cf{position:absolute;inset:0;pointer-events:none;border-radius:22px}

/* ── WIN MODAL (legacy — world complete still uses this) ── */
.win-modal{padding:28px 20px 24px}
.win-emoji{font-size:68px;line-height:1;display:block;margin-bottom:6px;animation:winPop .7s cubic-bezier(.34,1.56,.64,1)}
@keyframes winPop{0%{transform:scale(0) rotate(-20deg);opacity:0}100%{transform:scale(1) rotate(0);opacity:1}}
.win-stars{font-size:30px;letter-spacing:6px;margin:4px 0 10px}
.win-ch-info{font-size:12px;color:var(--text2);background:var(--bg2);border-radius:20px;padding:5px 14px;display:inline-block;margin:6px 0 10px}
.win-unlock{background:var(--bg2);border-radius:12px;padding:10px 14px;font-size:13px;font-weight:700;color:var(--primary);margin:4px 0 0}
.win-unlock-streak{background:var(--bg2);color:var(--green)}

/* ── WIN FULL-SCREEN — base = light ── */
.ov.ov-win{position:fixed;inset:0;height:100%;background:rgba(240,236,230,.92);backdrop-filter:blur(14px);overflow-y:auto}
.win-full{width:100%;max-width:360px;text-align:center;display:flex;flex-direction:column;align-items:center;padding:24px 8px;animation:winFadeUp .45s cubic-bezier(.22,1,.36,1)}
@keyframes winFadeUp{from{transform:translateY(28px);opacity:0}to{transform:translateY(0);opacity:1}}
.win-full-chip{background:rgba(0,0,0,.08);color:rgba(0,0,0,.5);font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;border-radius:20px;padding:5px 14px;margin-bottom:32px}
.win-full-emoji{font-size:82px;line-height:1;display:block;margin-bottom:22px;animation:winPop .7s cubic-bezier(.34,1.56,.64,1)}
.win-full-title{font-family:'Playfair Display',serif;font-size:40px;font-weight:900;font-style:italic;color:var(--text);letter-spacing:-.5px;line-height:1.1;margin-bottom:12px}
.win-full-sub{font-size:15px;color:var(--text2);line-height:1.6;margin-bottom:28px;max-width:270px}
.win-full-badges{display:flex;flex-direction:column;gap:8px;width:100%;margin-bottom:24px}
.win-full-badge{background:rgba(0,0,0,.05);border:1px solid rgba(0,0,0,.1);border-radius:12px;padding:10px 16px;font-size:13px;font-weight:600;color:var(--text)}
.win-full-btns{display:flex;flex-direction:column;gap:10px;width:100%}
.win-full-btns .mbtn{width:100%;padding:15px;font-size:15px;border-radius:16px}
.win-full-btns .mbtn.sc{background:rgba(0,0,0,.07);color:var(--text)}
/* ── WIN — dark mode overrides ── */
body.dark .ov.ov-win{background:rgba(12,8,28,.88)}
body.dark .win-full-chip{background:rgba(255,255,255,.12);color:rgba(255,255,255,.65)}
body.dark .win-full-title{color:#fff}
body.dark .win-full-sub{color:rgba(255,255,255,.6)}
body.dark .win-full-badge{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:#fff}
body.dark .win-full-btns .mbtn.sc{background:rgba(255,255,255,.12);color:rgba(255,255,255,.8)}
@media(min-width:768px){
  .win-full{max-width:420px}
  .win-full-title{font-size:44px}
  .win-full-sub{font-size:16px}
  .win-full-emoji{font-size:96px}
  .win-full-btns .mbtn{padding:17px;font-size:16px}
}

/* ── HINT BOTTOM SHEET ── */
.ov-bottom{align-items:flex-end;padding:0}
.hint-sheet{background:var(--card);border-radius:24px 24px 0 0;width:100%;max-width:420px;animation:slideUp .3s cubic-bezier(.34,1.2,.64,1);will-change:transform,opacity}
@media(min-width:768px){.hint-sheet{max-width:600px;border-radius:28px 28px 0 0}}
@media(min-width:1024px){.hint-sheet{max-width:720px}}
@keyframes slideUp{from{transform:translateY(80px);opacity:0}to{transform:translateY(0);opacity:1}}
.sheet-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:12px auto 0}
.sheet-inner{padding:18px 20px 36px}
.sheet-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}
.sheet-icon{font-size:40px;line-height:1}
.sheet-title{font-size:18px;font-weight:900;color:var(--text);margin-bottom:3px}
.sheet-sub{font-size:12px;color:var(--text2);line-height:1.4}
/* ── Hint shop — THEME-ADAPTIVE: theo dark/light của app ──── */
.hs-modal{background:var(--bg);border-radius:24px 24px 0 0;position:relative}
.hs-modal.hint-sheet{background:var(--bg)}
.hs-close{position:absolute;top:16px;right:16px;width:34px;height:34px;min-width:34px;min-height:34px;border-radius:50%;border:none;background:transparent;color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}
.hs-center{display:flex;flex-direction:column;align-items:center;text-align:center;padding:28px 28px 44px;font-family:'Outfit',sans-serif}
.hs-icon{color:var(--text);margin-bottom:12px}
.hs-title{font-size:24px;font-weight:900;color:var(--text);margin-bottom:8px;letter-spacing:-.3px;font-family:'Space Grotesk',sans-serif}
.hs-sub{font-size:13px;color:var(--text2);margin-bottom:24px;line-height:1.55;text-align:center}
.hs-ad-btn{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--card);color:var(--text);border:1.5px solid var(--border);font-size:15px;font-weight:700;width:100%;border-radius:14px;font-family:'Outfit',sans-serif}
.hs-sep{font-size:13px;color:var(--text2);margin:16px 0 10px;font-family:'Outfit',sans-serif}
.hs-prem-btn{background:transparent;color:var(--text);border:1.5px solid var(--primary);font-size:15px;font-weight:700;width:100%;border-radius:14px;font-family:'Outfit',sans-serif}
.hs-prem-name{font-style:italic;color:var(--primary);font-weight:900}
/* ────────────────────────────────────────────────────────── */
.hint-pkgs{display:flex;flex-direction:column;gap:9px;margin-bottom:14px}
.hint-pkg2{display:flex;align-items:center;justify-content:space-between;background:var(--bg2);border-radius:16px;padding:14px 16px;cursor:pointer;border:2px solid transparent;transition:border-color .15s,transform .1s;position:relative;overflow:hidden}
.hint-pkg2:active{transform:scale(.98)}
.hint-pkg2.popular2{border-color:var(--primary);background:linear-gradient(135deg,rgba(232,103,74,.07),rgba(245,150,124,.07))}
.hint-pkg2.best2{border-color:var(--yellow);background:linear-gradient(135deg,rgba(255,183,3,.07),rgba(255,159,28,.07))}
.pkg2-tag{position:absolute;top:0;right:0;font-size:10px;font-weight:800;color:#fff;background:var(--primary);padding:4px 11px;border-radius:0 14px 0 9px}
.pkg2-tag.best-tag{background:linear-gradient(135deg,#FFB703,#FF9F1C);color:#2A1808}
.pkg2-left{display:flex;align-items:center;gap:10px}
.pkg2-icon{font-size:24px}
/* fixed-width icon box — prevents text shifting between 1/2/3 emoji packages */
.pkg2-icon-box{width:60px;height:40px;display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;letter-spacing:-1px}
.pkg2-name{font-size:14px;font-weight:800;color:var(--text)}
.pkg2-qty{font-size:11px;color:var(--text2);margin-top:2px}
.pkg2-price{font-size:17px;font-weight:900;color:var(--text)}

/* ── PREMIUM TEASER ROW (inside hint sheet) ──────────────────── */
.prem-teaser{display:flex;align-items:center;gap:12px;
  background:linear-gradient(135deg,rgba(245,198,64,.1),rgba(244,123,104,.08));
  border:1.5px solid rgba(245,198,64,.3);border-radius:16px;
  padding:14px 16px;margin-bottom:12px;cursor:pointer;transition:opacity .15s}
.prem-teaser:active{opacity:.7}
.pt-left{display:flex;align-items:center;gap:10px;flex:1}
.pt-icon{font-size:28px;line-height:1}
.pt-title{font-size:14px;font-weight:800;color:var(--text)}
.pt-sub{font-size:11px;color:var(--text2);margin-top:1px;font-weight:600}
.pt-arrow{font-size:16px;color:var(--primary2)}

/* ── PREMIUM FULL-SCREEN OVERLAY ─────────────────────────────── */
.ov.ov-prem{position:fixed;inset:0;background:var(--bg);backdrop-filter:none;
  align-items:flex-start;padding:0;overflow-y:auto}
.prem-full{width:100%;min-height:100%;display:flex;flex-direction:column;
  padding:calc(20px + var(--sat,0px)) 20px calc(32px + var(--sab,0px));
  box-sizing:border-box;max-width:480px;margin:0 auto}
.prem-x{position:fixed;top:calc(18px + var(--sat,0px));left:18px;
  background:none;border:none;color:var(--text);cursor:pointer;padding:6px;
  z-index:10;opacity:.85;transition:opacity .15s}
.prem-x:active{opacity:.4}
@media(min-width:600px){.prem-x{left:calc(50% - 220px)}}

/* ── PREMIUM SHEET V2 ────────────────────────────────────────── */
.pv2-hdr{text-align:center;margin:16px 0 0;padding-top:0}
.pv2-app{font-size:13px;font-style:italic;color:var(--text2);font-weight:600;letter-spacing:.5px;margin-bottom:4px}
.pv2-name{font-family:'Playfair Display',serif;font-size:40px;font-weight:900;font-style:italic;
  color:var(--primary);line-height:1.1;letter-spacing:-.5px}

/* Feature comparison card */
.pv2-feat-card{background:var(--card);border-radius:20px;overflow:hidden;margin-bottom:20px;
  border:2px solid var(--border);position:relative}
/* Single continuous border around the ∞ column */
.pv2-feat-card::after{content:'';position:absolute;
  top:8px;bottom:8px;right:8px;width:62px;
  border:2.5px solid var(--primary);border-radius:13px;
  background:rgba(232,103,74,.06);pointer-events:none}
.pv2-feat-hdr{display:flex;align-items:center;padding:12px 16px 10px}
.pv2-fh-space{flex:1}
.pv2-fh-free{width:52px;text-align:center;font-size:11px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.4px}
.pv2-fh-prem{width:58px;text-align:center;font-size:22px;font-weight:900;color:var(--primary);padding:4px 0;position:relative;z-index:1}
.pv2-feat-row{display:flex;align-items:center;padding:12px 16px}
.pv2-fr-badge{width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-right:12px;color:var(--text)}
.pv2-fr-text{flex:1}
.pv2-fr-name{font-size:13px;font-weight:700;color:var(--text)}
.pv2-fr-sub{font-size:11px;color:var(--text2);margin-top:2px}
.pv2-fr-free{width:52px;text-align:center;font-size:16px;color:var(--text2);font-weight:600}
.pv2-fr-prem{width:58px;text-align:center;font-size:14px;font-weight:800;color:var(--primary);position:relative;z-index:1}

/* CTA + footer */
.pv2-spacer{flex:1;min-height:16px}
.pv2-cta{width:100%;padding:17px;border:none;border-radius:16px;
  background:var(--grad);
  color:#fff;font-size:17px;font-weight:800;cursor:pointer;
  letter-spacing:.2px;margin-bottom:10px;
  font-family:'Space Grotesk',sans-serif;transition:opacity .15s}
.pv2-cta:active{opacity:.82}
.pv2-footer-txt{text-align:center;font-size:11px;color:var(--text2);font-weight:600;line-height:1.6}

/* Plan selection screen */
.pv2-join-title{font-size:20px;font-weight:900;text-align:center;color:var(--text);
  margin-top:20px;margin-bottom:6px;font-family:'Space Grotesk',sans-serif}
.pv2-join-sub{font-size:12px;color:var(--text2);text-align:center;margin-bottom:0;line-height:1.5}
.pv2-plans{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.pv2-plan{display:flex;flex-direction:column;justify-content:center;
  background:var(--bg2);border:2px solid var(--border);
  border-radius:18px;padding:26px 20px;min-height:96px;cursor:pointer;position:relative;
  transition:all .2s;overflow:visible}
/* Annual card: extra top padding so badge doesn't overlap content */
.pv2-plan-annual{padding-top:30px}
.pv2-plan:active{transform:scale(.98)}
/* Selected plan — full gradient like demo */
.pv2-plan.pv2-sel{border-color:transparent;
  background:linear-gradient(135deg,#F47B68,#F5A090)}
.pv2-plan.pv2-sel .pv2-plan-label{color:#fff}
.pv2-plan.pv2-sel .pv2-plan-detail{color:rgba(255,255,255,.75)}
.pv2-plan.pv2-sel .pv2-plan-mo{color:#fff}
/* Badge — floating tag above card top-left corner */
.pv2-plan-badge{position:absolute;top:-13px;left:14px;
  background:rgba(0,0,0,.65);
  color:#fff;font-size:11px;font-weight:700;letter-spacing:.2px;
  padding:4px 12px;border-radius:10px;
  white-space:nowrap;pointer-events:none;backdrop-filter:blur(4px)}
/* Row: label-left | price | checkmark */
.pv2-plan-row{display:flex;align-items:center;gap:12px}
.pv2-plan-left{flex:1}
.pv2-plan-label{font-size:16px;font-weight:800;color:var(--text)}
.pv2-plan-detail{font-size:12px;color:var(--text2);margin-top:3px;font-weight:600}
.pv2-plan-mo{font-size:15px;font-weight:900;color:var(--text);white-space:nowrap}
.pv2-plan-chk{width:24px;height:24px;border-radius:50%;
  border:2px solid var(--border);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:900;transition:all .2s}
.pv2-plan.pv2-sel .pv2-plan-chk{background:rgba(0,0,0,.18);border-color:rgba(255,255,255,.35);color:#fff}
.pv2-divider{display:flex;align-items:center;gap:10px;margin:4px 0;
  color:var(--text2);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.pv2-divider::before,.pv2-divider::after{content:'';flex:1;height:1px;background:var(--border)}

/* Legacy — kept for restore/applyFullGame success modal */
.prem-cta{background:var(--grad);font-size:16px;font-weight:900;letter-spacing:.3px;margin-bottom:10px}
.prem-footer{text-align:center;font-size:10px;color:var(--text2);font-weight:600}

/* ── STREAK FULL-PAGE SCREEN ─────────────────────────────────── */
.streak-screen{
  background:var(--bg);
  width:100%;min-height:100%;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:0 32px;
  position:relative;
}
.sc-date{
  font-size:20px;font-weight:500;color:var(--text);
  padding-top:calc(52px + env(safe-area-inset-top,0px));
  letter-spacing:.1px;align-self:stretch;
  font-family:'Playfair Display',serif;font-style:italic;
}
.sc-hero{
  flex:1;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:6px;
}
.sc-crown{color:var(--text);margin-bottom:8px;animation:scCrownPop .7s cubic-bezier(.34,1.56,.64,1)}
@keyframes scCrownPop{0%{transform:scale(0);opacity:0}100%{transform:scale(1);opacity:1}}
.sc-count{font-size:100px;font-weight:900;line-height:1;color:var(--text);
  font-family:'Space Grotesk',sans-serif;
  animation:scCrownPop .8s .1s cubic-bezier(.34,1.56,.64,1) both}
.sc-msg{font-size:22px;font-weight:600;color:var(--text);
  letter-spacing:.1px;
  font-family:'Playfair Display',serif}
.sc-cal-area{
  width:100%;display:flex;flex-direction:column;align-items:center;
  padding-bottom:calc(40px + env(safe-area-inset-bottom,0px));
  gap:24px;
}
.sc-continue{
  background:transparent;color:var(--text);
  border:2.5px solid var(--border);border-radius:16px;
  font-size:16px;font-weight:700;letter-spacing:.5px;
  padding:16px 0;cursor:pointer;
  width:100%;font-family:'Space Grotesk',sans-serif;
  transition:transform .12s,opacity .15s}
.sc-continue:active{transform:scale(.96);opacity:.85}

/* Weekly calendar (streak screen) */
.sc-week{display:flex;gap:6px;justify-content:center;margin-bottom:0;width:100%}
.sc-week-modal{margin-bottom:0}
.sc-day{display:flex;flex-direction:column;align-items:center;gap:5px;flex:1}
.sc-day-lbl{font-size:9px;font-weight:700;color:var(--text2);
  text-transform:uppercase;letter-spacing:.3px;font-family:'Space Grotesk',sans-serif}
.sc-day-dot{width:36px;height:36px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;color:var(--text);
  background:transparent;border:1.5px solid var(--border)}
.sc-day-num{font-size:11px;font-weight:600;color:var(--text2);
  font-family:'Space Grotesk',sans-serif}
.sc-day.sc-played .sc-day-dot{background:var(--card);border-color:var(--text)}
.sc-day.sc-played .sc-day-num{color:var(--text);font-weight:700}
/* streak screen: today không dùng viền primary — để hoà với màu chủ đạo */
.sc-day.sc-today .sc-day-dot{border-color:var(--text2)}
.sc-day.sc-today.sc-played .sc-day-dot{border-color:var(--text)}
.sc-day.sc-today .sc-day-lbl{color:var(--text)}
.sc-day.sc-today .sc-day-num{color:var(--text);font-weight:700}
.sc-day.sc-future .sc-day-dot{opacity:.25}

/* Modal variant */
.sc-week-modal .sc-day-lbl{color:var(--text2)}
.sc-week-modal .sc-day-dot{background:var(--bg2);border-color:var(--border)}
.sc-week-modal .sc-day.sc-played .sc-day-dot{background:var(--card);border-color:var(--text2)}
.sc-week-modal .sc-day.sc-today .sc-day-dot{border-color:var(--primary)}
.sc-week-modal .sc-day.sc-today .sc-day-lbl{color:var(--text)}
.sc-week-modal .sc-day.sc-future .sc-day-dot{opacity:.3}

/* Dark mode — calendar dots */
body.dark .hint-sheet{background:#252535}
body.dark .sc-day-dot{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.12)}
body.dark .sc-day.sc-played .sc-day-dot{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.35)}
body.dark .sc-week-modal .sc-day-dot{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.12)}
body.dark .sc-week-modal .sc-day.sc-played .sc-day-dot{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.35)}

/* ── Streak modal ─────────────────────────────────────────── */
.streak-modal{max-width:360px;padding:28px 16px 22px;position:relative}
.streak-modal-close{
  position:absolute;top:14px;left:14px;
  background:none;border:none;cursor:pointer;
  font-size:16px;color:var(--text2);padding:6px;line-height:1;
}
.streak-modal-close:active{opacity:.5}
.streak-modal-title{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:28px;font-weight:900;color:var(--text);
  text-align:center;letter-spacing:-.3px;margin-bottom:0;
}
.streak-modal-desc{
  font-size:13px;color:var(--text2);font-weight:600;
  text-align:center;line-height:1.5;margin-bottom:18px;
  padding:0 8px;
}
.streak-modal-btn{
  width:100%;padding:15px;border:none;border-radius:16px;
  background:var(--text);color:var(--bg);
  font-size:16px;font-weight:800;cursor:pointer;
  font-family:'Space Grotesk',sans-serif;letter-spacing:.2px;
  transition:opacity .15s;
}
.streak-modal-btn:active{opacity:.8}

/* ── STREAK ICON BUTTON (shared by all header bars) ─────────── */
.streak-icon-btn{display:flex;align-items:center;gap:4px;
  background:none;border:none;cursor:pointer;
  padding:7px 10px;border-radius:12px;
  font-size:14px;line-height:1;transition:opacity .15s;flex-shrink:0}
.streak-icon-btn:active{opacity:.5}
.streak-icon-btn .si-cnt{font-size:13px;font-weight:900;color:var(--gold)}

/* ── WIN FEEDBACK widget ──────────────────────────────────────── */
.wf-feedback{margin-top:20px;text-align:center}
.wf-fb-lbl{font-size:12px;color:var(--text2);font-weight:600;margin-bottom:8px;letter-spacing:.2px}
.wf-fb-row{display:flex;gap:10px;justify-content:center}
.wf-fb-btn{width:48px;height:48px;border-radius:14px;border:1.5px solid var(--border);
  background:var(--bg2);font-size:22px;cursor:pointer;transition:all .15s;
  display:flex;align-items:center;justify-content:center}
.wf-fb-btn:active{transform:scale(.88)}
.wf-fb-btn.wf-fb-sel{border-color:var(--primary);background:rgba(232,103,74,.12);
  transform:scale(1.1)}

/* ── Typography — Space Grotesk cho tiêu đề ─────────────────── */
.h-title,.g-top h2,.topbar h2,.world-name,.ch-name,.hs-title,.prem-hdr-title,.modal h3{font-family:'Space Grotesk',sans-serif}
