/* ============================================================
   SMART MONEY SERIES — Stylesheet
   Combined from inline <style> blocks in original app.html.
   Sections: Main app, Admin dashboard, Language switcher
   ============================================================ */

/* ============================================================
   1. MAIN APP STYLES
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}

/* ═══ DESIGN SYSTEM TOKENS ═══ */
:root{
/* Background hierarchy: page → card → raised → input */
--bg:#F0EBE4;--bg-card:#FAFAF8;--bg-raised:#F4F0EA;--bg-input:#EDE8E0;--bg-dark:#1E1928;--bg-dark2:#161220;
/* Text hierarchy */
--ink:#1C1626;--body:#48384E;--mute:#7A6E88;--dim:#AEA6BA;--light:#D8D0E0;
/* Brand colors */
--purple:#6B5A90;--purpleD:#5A4878;--purplePale:rgba(107,90,144,.07);--purpleGlow:rgba(107,90,144,.12);
--gold:#B88A28;--goldBtn:#C89832;--goldPale:rgba(184,138,40,.07);--goldText:#7A5C14;
--green:#28805A;--greenPale:rgba(40,128,90,.07);--greenDk:#1E6848;
--coral:#B82040;--coralPale:rgba(184,32,64,.06);
/* --blue / --bluePale alias to purple by design. Five callsites (Team stat,
   Month badge, My Real Money tile, Investing category color in two places)
   request a "blue" semantic. In default / Sparks / Navigators chromes we want
   them rendered as purple to keep the palette unified. The Builders chrome
   block (line ~561) overrides --blue with a real teal-blue #3B82F6, giving
   Builders users a visually distinct blue without forking the callsites.
   Don't replace the alias with a hard-coded blue in :root — it would break
   the unified-purple feel of the other chromes. */
--blue:var(--purple);--bluePale:var(--purplePale);
/* Borders & shadows */
--border:rgba(0,0,0,.06);--borderH:rgba(0,0,0,.1);
--sh:0 1px 3px rgba(0,0,0,.02),0 4px 12px rgba(107,90,144,.04);
--shH:0 2px 8px rgba(0,0,0,.03),0 8px 24px rgba(107,90,144,.08);
/* Spacing scale: 4 8 12 16 20 24 32 40 48 */
/* Type scale: 11 12 13 14 16 18 22 28 36 */
/* Radius scale: 8 12 16 (cards use 16, buttons 12, small 8) */
--R:16px;--Rm:12px;--Rs:8px;
--serif:'Playfair Display',Georgia,serif;--sans:'DM Sans',system-ui,sans-serif;
--sidebar:250px;
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.65}
::selection{background:var(--purpleGlow)}
.app{display:flex;min-height:100dvh}

/* ═══ SIDEBAR (dark) ═══ */
.sb{width:var(--sidebar);background:var(--bg-dark);border-right:1px solid rgba(255,255,255,.04);display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;z-index:50;overflow-y:auto;scrollbar-width:none}
.sb::-webkit-scrollbar{display:none}
.sb-logo{padding:20px 18px;display:flex;align-items:center;gap:10px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.04)}
.sb-logo-t{font-family:var(--serif);font-weight:700;font-size:14px;line-height:1.15;color:#E8E4E0}
.sb-lbl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:#605870;padding:16px 20px 6px}
.sb-nav{display:flex;flex-direction:column;gap:2px;padding:0 10px}
.sb-i{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--Rm);cursor:pointer;color:#9088A0;font-size:14px;font-weight:500;transition:all .2s}
.sb-i:hover{color:#E0DCE8;background:rgba(255,255,255,.05)}
.sb-i.on{background:rgba(184,138,40,.12);color:var(--gold);font-weight:600;border-radius:12px;box-shadow:inset 3px 0 0 var(--gold)}
.sb-i svg{width:18px;height:18px;flex-shrink:0;opacity:.6}.sb-i.on svg{opacity:1}
.sb-div{height:1px;background:rgba(255,255,255,.04);margin:8px 18px}
.sb-foot{padding:14px 16px;margin-top:auto;border-top:1px solid rgba(255,255,255,.04);display:flex;align-items:center;gap:10px}
.sb-av{width:34px;height:34px;border-radius:12px;background:linear-gradient(135deg,#6B5A90,#5A4878);display:grid;place-items:center;font-size:13px;color:#fff;flex-shrink:0}
.sb-foot .nm{font-weight:600;font-size:13px;color:#E0DCE8}.sb-foot .rl{font-size:11px;color:#8A7E98}
.sb-age{margin:10px 14px;padding:8px 12px;border-radius:var(--Rs);background:rgba(184,138,40,.1);border:1px solid rgba(184,138,40,.06);font-size:11px;color:#C8A030;font-weight:600;text-align:center;transition:all .2s}
.sb-age:hover{background:rgba(184,138,40,.1)}

/* ═══ MOBILE BOTTOM NAV (only visible <720px) ═══ */
.mob-bnav{display:none}
@media(max-width:720px){
  .mob-bnav{
    display:flex;position:fixed;bottom:0;left:0;right:0;z-index:90;
    background:rgba(255,255,255,0.96);
    -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
    border-top:1px solid rgba(0,0,0,0.07);
    padding:6px 4px calc(6px + env(safe-area-inset-bottom)) 4px;
    box-shadow:0 -2px 14px rgba(0,0,0,0.04);
    justify-content:space-around;align-items:stretch;
  }
  .mob-bnav-i{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:2px;padding:6px 4px;min-height:54px;
    background:none;border:none;cursor:pointer;
    color:#6B7280;font-family:var(--sans);font-size:10.5px;font-weight:600;
    border-radius:10px;transition:all .15s ease;
    -webkit-tap-highlight-color:transparent;letter-spacing:.01em;
  }
  .mob-bnav-i:active{transform:scale(0.95)}
  .mob-bnav-i svg{width:22px;height:22px;stroke:currentColor;flex-shrink:0;transition:transform .15s}
  .mob-bnav-i.on{color:var(--gold);font-weight:700}
  .mob-bnav-i.on svg{transform:translateY(-1px) scale(1.05)}
  .mob-bnav-i.on::before{
    content:'';position:absolute;top:0;width:24px;height:3px;background:var(--gold);
    border-radius:0 0 3px 3px;
  }
  .mob-bnav-i{position:relative}
  /* Pad main content so bottom nav doesn't cover it */
  .main{padding-bottom:calc(70px + env(safe-area-inset-bottom)) !important}
  body{padding-bottom:0}
  /* Hide bottom nav on lesson reading screens to maximize content area */
  body.reader-active .mob-bnav{display:none}
}
/* Dark-mode adapt: when nav-chrome (Navigators) or builders-chrome is on, the bottom nav
   stays light to keep CTA contrast obvious */

/* ═══ MAIN AREA (light) ═══ */
.main{margin-left:var(--sidebar);flex:1;min-height:100dvh;display:flex;flex-direction:column}

/* Topbar (dark, matches sidebar) */
.topbar{border-bottom:1px solid rgba(255,255,255,.04);display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:var(--bg-dark);border-bottom:1px solid rgba(255,255,255,.04);position:sticky;top:0;z-index:40}
.topbar h1{font-family:var(--serif);font-size:18px;font-weight:700;color:#E8E4E0}
.topbar h1 em{font-style:normal;color:#C0AAE0}
.top-r{display:flex;align-items:center;gap:8px}
.chip{height:32px;display:flex;align-items:center;gap:4px;padding:0 12px;border-radius:var(--Rs);font-weight:600;font-size:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.04);color:rgba(255,255,255,.65);transition:all .2s}
.chip:hover{background:rgba(255,255,255,.1);color:#fff}
.top-btn{height:32px;padding:0 14px;border-radius:var(--Rs);border:none;font-family:var(--sans);font-weight:600;font-size:12px;cursor:pointer;background:linear-gradient(135deg,var(--purple),#7B60B8);color:#fff;transition:all .25s;box-shadow:0 2px 8px rgba(107,90,144,.2)}
.top-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(107,90,144,.3)}
/* Help button — ghost-style chip on dark topbar / mobile header. Same definition
   applies in both Sparks/Builders default chrome and Navigators navy chrome. */
.help-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:32px;padding:0 12px;border-radius:var(--Rs);border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);color:#fff;font-family:var(--sans);font-weight:600;font-size:12px;cursor:pointer;transition:background .2s,border-color .2s}
.help-btn:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.32)}
.help-btn:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.help-btn i{font-size:14px;line-height:1}
.help-btn-mob{width:40px;height:40px;padding:0;border-radius:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.10);color:#fff;cursor:pointer;display:grid;place-items:center;font-size:18px;transition:background .2s}
.help-btn-mob:hover,.help-btn-mob:active{background:rgba(255,255,255,.16)}
.help-btn-mob:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
/* Chrome-specific overrides — the default ghost-on-dark .help-btn is white text +
   white-translucent fill, which is invisible against the WHITE topbars used by
   Sparks (line ~565) and Builders (line ~650) chromes and the white mob-header
   used by Builders (line ~606). Each light chrome gets a themed fill + dark
   foreground so the icon contrasts properly. */
body.sparks-chrome .help-btn{background:#FEF3C7;border-color:#FDE68A;color:#7C2D12}
body.sparks-chrome .help-btn:hover{background:#FDE68A;border-color:#FBBF24}
body.sparks-chrome .help-btn-mob{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.40);color:#fff}
body.sparks-chrome .help-btn-mob:hover,body.sparks-chrome .help-btn-mob:active{background:rgba(255,255,255,.40)}
body.builders-chrome .help-btn{background:#F1F5F9;border-color:rgba(15,23,42,.12);color:#0F172A}
body.builders-chrome .help-btn:hover{background:#E2E8F0;border-color:rgba(15,23,42,.20)}
body.builders-chrome .help-btn-mob{background:rgba(15,23,42,.06);border-color:rgba(15,23,42,.12);color:#0F172A}
body.builders-chrome .help-btn-mob:hover,body.builders-chrome .help-btn-mob:active{background:rgba(15,23,42,.12)}

/* Page content */
.pg{flex:1;padding:20px 24px 40px;overflow-x:hidden;min-width:0}

/* ═══ ANIMATIONS ═══ */
@keyframes up{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes correct-pulse{0%{box-shadow:0 0 0 0 rgba(40,128,90,.2)}100%{box-shadow:0 0 0 14px rgba(40,128,90,0)}}
@keyframes wrong-shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
@keyframes reward-bounce{0%{opacity:0;transform:scale(.4) translateY(12px)}50%{transform:scale(1.12)}100%{opacity:1;transform:scale(1) translateY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.u{animation:up .45s cubic-bezier(.16,1,.3,1) both}
.u1{animation-delay:.05s}.u2{animation-delay:.1s}.u3{animation-delay:.15s}.u4{animation-delay:.2s}.u5{animation-delay:.25s}

/* ═══ CARDS ═══ */
.card{background:var(--bg-card);border-radius:var(--R);padding:20px;box-shadow:var(--sh);border:1px solid var(--border);transition:all .25s;overflow:hidden;word-wrap:break-word;overflow-wrap:break-word;max-width:100%}
.card:hover{box-shadow:var(--shH);border-color:var(--borderH)}
.ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.pt{font-family:var(--serif);font-weight:700;font-size:16px;color:var(--ink)}
.dg{display:grid;grid-template-columns:1fr 1fr;gap:14px}.dg .full{grid-column:1/-1}

/* ═══ BUTTONS ═══ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:38px;padding:0 18px;border-radius:var(--Rm);border:none;font-family:var(--sans);font-weight:600;font-size:13px;cursor:pointer;transition:all .25s}
.btn:hover{transform:translateY(-1px)}
.bP{background:linear-gradient(135deg,var(--purple),#7B60B8);color:#fff;box-shadow:0 2px 8px rgba(107,90,144,.15)}.bP:hover{box-shadow:0 4px 14px rgba(107,90,144,.25)}
.bG{background:linear-gradient(135deg,var(--goldBtn),#A87820);color:#fff;box-shadow:0 2px 8px rgba(184,138,40,.15)}.bG:hover{box-shadow:0 4px 14px rgba(184,138,40,.25)}
.bS{background:var(--purplePale);color:var(--purple)}.bW{background:var(--bg-card);color:var(--ink);border:1px solid var(--border)}.bW:hover{border-color:var(--borderH)}
.bF{width:100%}.bSm{height:32px;padding:0 14px;font-size:12px}

/* ═══ TABS ═══ */
.tabs{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px;margin-bottom:16px}.tabs::-webkit-scrollbar{display:none}
.tb{padding:8px 16px;border-radius:12px;border:1.5px solid transparent;background:var(--bg-raised);font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;color:var(--mute)}
.tb:hover{color:var(--ink);border-color:var(--borderH);background:var(--bg-raised)}
.tb.on{background:var(--purplePale);color:var(--purple);border-color:rgba(107,90,144,.12)}

/* ═══ PROGRESS BARS ═══ */
.bar{height:6px;background:var(--bg-input);border-radius:8px;overflow:hidden}
.bar-f{height:100%;border-radius:8px;transition:width .6s cubic-bezier(.16,1,.3,1)}

/* ═══ HERO PANEL ═══ */
.hero-p{border-radius:var(--R);padding:28px 24px;background:linear-gradient(145deg,#E6E0D6,#DCD4CA,#D2CCBE);box-shadow:var(--sh);border:1px solid var(--border);grid-column:1/-1;position:relative;overflow:hidden}
.hero-p h2{font-family:var(--serif);font-size:22px;font-weight:700;line-height:1.15;color:var(--ink)}
.hero-float{position:absolute;right:24px;top:50%;transform:translateY(-50%);font-size:48px;animation:float 3.5s ease-in-out infinite;opacity:.3}

/* ═══ FLASHCARDS & OPTIONS ═══ */
.fc-opt{padding:14px 18px;border-radius:var(--Rm);border:1.5px solid var(--border);background:var(--bg-card);font-family:var(--sans);font-weight:500;font-size:14px;cursor:pointer;transition:all .25s;text-align:left;color:var(--ink);line-height:1.5;width:100%;margin-bottom:8px}
.fc-opt:hover:not(:disabled){border-color:var(--purple);background:var(--purplePale);transform:translateX(4px)}
.fc-opt.correct{border-color:var(--green);background:var(--greenPale);color:var(--green);animation:correct-pulse .5s ease}
.fc-opt.wrong{border-color:var(--coral);background:var(--coralPale);color:var(--coral);animation:wrong-shake .3s ease}
.fc-opt.dim{opacity:.2;pointer-events:none}
.fc-fb{padding:14px 16px;border-radius:var(--Rm);font-size:14px;line-height:1.6;margin-top:10px;font-weight:500}
.fc-fb.good{background:var(--greenPale);color:var(--greenDk)}.fc-fb.bad{background:var(--coralPale);color:var(--coral)}

/* ═══ STOCKS ═══ */
.stk{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--Rm);border:1px solid var(--border);margin-bottom:6px;background:var(--bg-card);transition:all .2s}
.stk:hover{background:var(--bg-raised);border-color:var(--borderH)}

/* ═══ CHAT ═══ */
.cm{max-width:84%;padding:10px 14px;border-radius:12px;margin-bottom:6px;font-size:14px;line-height:1.6;animation:up .3s ease;white-space:pre-line}
.cm-u{background:linear-gradient(135deg,var(--purple),#7B60B8);color:#fff;margin-left:auto;border-bottom-right-radius:4px}
.cm-g{background:var(--bg-raised);border:1px solid var(--border);border-bottom-left-radius:4px;color:var(--body)}

/* Floating Goldie widget */
.gw-fab{position:fixed;bottom:20px;right:20px;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,var(--gold),#D4A840);border:3px solid #fff;box-shadow:0 6px 20px rgba(184,138,40,.4);cursor:pointer;display:grid;place-items:center;z-index:9998;transition:transform .25s cubic-bezier(.16,1,.3,1)}
.gw-fab:hover{transform:scale(1.08)}
.gw-fab:active{transform:scale(.95)}
.gw-fab-dot{position:absolute;top:0;right:0;width:14px;height:14px;border-radius:50%;background:var(--coral);border:2px solid #fff;animation:pulse 2s infinite}
.gw-panel{position:fixed;bottom:90px;right:20px;width:360px;max-width:calc(100vw - 32px);height:500px;max-height:calc(100vh - 130px);background:var(--bg-card);border:1px solid var(--border);border-radius:18px;box-shadow:0 16px 48px rgba(0,0,0,.2);z-index:9999;display:flex;flex-direction:column;overflow:hidden;animation:gwSlide .3s cubic-bezier(.16,1,.3,1)}
@keyframes gwSlide{from{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
.gw-header{padding:12px 16px;background:linear-gradient(135deg,var(--gold),#D4A840);color:#fff;display:flex;align-items:center;gap:10px;flex-shrink:0}
.gw-header-title{font-family:var(--serif);font-weight:700;font-size:15px;flex:1}
.gw-close{background:rgba(255,255,255,.2);border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:14px;display:grid;place-items:center}
.gw-close:hover{background:rgba(255,255,255,.3)}
.gw-body{flex:1;overflow-y:auto;padding:14px 14px 6px;display:flex;flex-direction:column;gap:8px}
.gw-footer{padding:10px 12px;border-top:1px solid var(--border);display:flex;gap:6px;flex-shrink:0}
.gw-input{flex:1;height:38px;padding:0 12px;border-radius:19px;border:1.5px solid var(--borderL);background:var(--bg-card);font-family:var(--sans);font-size:13px;color:var(--ink);outline:none}
.gw-input:focus{border-color:var(--purple)}
.gw-send{width:38px;height:38px;border-radius:50%;border:none;background:var(--purple);color:#fff;cursor:pointer;display:grid;place-items:center;font-size:13px;flex-shrink:0}
.gw-send:disabled{opacity:.5;cursor:wait}
.gw-hint{padding:12px;border-radius:12px;background:var(--goldPale);font-size:12px;color:var(--goldText);line-height:1.5}
.gw-suggestion{padding:8px 12px;border-radius:10px;border:1px solid var(--border);background:var(--bg-card);font-size:12px;text-align:left;cursor:pointer;color:var(--body);transition:all .2s;font-family:var(--sans)}
.gw-suggestion:hover{border-color:var(--purple);background:var(--purplePale);color:var(--purple)}
@media(max-width:480px){
.gw-fab{bottom:80px;right:12px;width:52px;height:52px}
.gw-panel{bottom:145px;right:12px;left:12px;width:auto;max-width:none;height:calc(100vh - 170px)}
}
.gw-panel.hidden{display:none}

/* ═══ READER ═══ */
.rdr{position:fixed;inset:0;z-index:200;background:var(--bg);display:flex;flex-direction:column}
.rdr-top{display:flex;align-items:center;padding:10px 16px;gap:10px;border-bottom:1px solid var(--border)}
.rdr-bk{width:36px;height:36px;border-radius:var(--Rs);background:var(--bg-card);border:1px solid var(--border);display:grid;place-items:center;cursor:pointer;font-size:14px;color:var(--ink);transition:all .2s}
.rdr-bk:hover{background:var(--bg-raised);border-color:var(--borderH)}
.rdr-stage{flex:1;display:flex;align-items:center;justify-content:center;padding:8px;position:relative}
.rdr-arr{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);display:grid;place-items:center;cursor:pointer;color:var(--ink);transition:all .25s;z-index:5;box-shadow:var(--sh);font-size:14px}
.rdr-arr:hover{background:var(--bg-raised);transform:translateY(-50%) scale(1.08)}.rdr-arr.off{opacity:.1;pointer-events:none}
.rdr-ctrl{padding:8px 16px max(8px,env(safe-area-inset-bottom));border-top:1px solid var(--border)}
.rdr-bar{height:3px;background:var(--bg-input);border-radius:8px;overflow:hidden;margin-bottom:6px}.rdr-fill{height:100%;background:var(--goldBtn);border-radius:8px;transition:width .4s}
.rdr-dots{display:flex;gap:4px;justify-content:center;flex-wrap:wrap}.rdr-dot{width:7px;height:7px;border-radius:50%;background:var(--dim);cursor:pointer;transition:all .2s}.rdr-dot.on{background:var(--goldBtn);transform:scale(1.4)}

/* ═══ TRACKER INPUT ═══ */
.t-input{width:100%;height:44px;padding:0 14px;border-radius:12px;border:1.5px solid var(--border);background:var(--bg-card);font-family:var(--sans);font-size:14px;color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s}
.t-input:focus{border-color:var(--purple);box-shadow:0 0 0 3px var(--purplePale)}
.t-select{height:40px;padding:0 12px;border-radius:var(--Rm);border:1.5px solid var(--border);background:var(--bg-input);font-family:var(--sans);font-size:13px;color:var(--ink);outline:none;cursor:pointer}

/* ═══ SIMULATION ═══ */
.sim-scene{max-width:700px;animation:up .45s ease both}
.sim-hero{padding:40px 28px;border-radius:16px;text-align:center;position:relative;overflow:hidden}
.sim-title{font-family:var(--serif);font-size:24px;font-weight:700;position:relative;z-index:1;line-height:1.25;color:var(--ink)}
.sim-story{font-size:16px;line-height:1.85;color:var(--body);padding:24px;background:var(--bg-card);border-radius:var(--R);border:1px solid var(--border);margin-top:14px;box-shadow:var(--sh)}
.tts-hl{background:rgba(255,200,60,.15)!important;border-color:rgba(255,180,40,.3)!important;transition:background 0.3s ease}
.tts-bar{display:flex;align-items:center;gap:8px;padding:8px 14px;margin:8px 0;border-radius:22px;background:rgba(0,0,0,.03);border:1.5px solid rgba(0,0,0,.08)}
.tts-bar.on{background:rgba(255,200,60,.08);border-color:rgba(255,180,40,.25)}
.tts-btn{padding:4px 12px;border-radius:16px;border:none;font-size:12px;cursor:pointer;font-family:var(--sans);font-weight:600;transition:all .2s}
.tts-play{background:var(--goldPale);color:var(--gold)}.tts-play:hover{background:var(--gold);color:#fff}
.tts-stop{background:rgba(200,80,60,.1);color:var(--coral)}.tts-stop:hover{background:var(--coral);color:#fff}
.tts-pause{background:rgba(107,90,144,.1);color:var(--purple)}.tts-pause:hover{background:var(--purple);color:#fff}
.tts-speed{width:60px;height:4px;-webkit-appearance:none;appearance:none;border-radius:2px;background:rgba(0,0,0,.12);outline:none;cursor:pointer}
.tts-speed::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--gold);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.step-text[data-tts]{transition:background 0.3s ease;border-radius:8px;padding:2px 4px;margin:-2px -4px}
.sim-opts{display:flex;flex-direction:column;gap:10px;margin-top:16px}
.sim-opt{padding:18px 22px;border-radius:var(--R);border:2px solid var(--border);background:var(--bg-card);font-family:var(--sans);font-weight:600;font-size:15px;cursor:pointer;transition:all .3s;text-align:left;color:var(--ink);line-height:1.5;display:flex;align-items:center;gap:14px;box-shadow:0 1px 4px rgba(0,0,0,.02)}
.sim-opt:hover:not(:disabled){border-color:var(--purple);background:var(--purplePale);transform:translateX(6px);box-shadow:var(--shH)}
.sim-opt.chosen-good{border-color:var(--green);background:var(--greenPale);color:var(--greenDk)}
.sim-opt.chosen-bad{border-color:var(--coral);background:var(--coralPale);color:var(--coral)}
.sim-opt.chosen-dim{opacity:.15;pointer-events:none;transform:scale(.97)}
.sim-opt-letter{width:36px;height:36px;border-radius:var(--Rs);background:var(--bg-input);display:grid;place-items:center;font-weight:700;font-size:14px;flex-shrink:0;color:var(--body)}
.sim-result{padding:20px 22px;border-radius:var(--R);margin-top:14px;font-size:15px;line-height:1.7;font-weight:500;animation:fadeUp .4s ease}
.sim-result.good{background:var(--greenPale);color:var(--greenDk);border:1px solid rgba(40,128,90,.08)}
.sim-result.warn{background:var(--goldPale);color:var(--goldText);border:1px solid rgba(184,138,40,.08)}
.sim-result.bad{background:var(--coralPale);color:var(--coral);border:1px solid rgba(184,32,64,.06)}
.sim-next{width:100%;height:52px;border-radius:var(--R);border:none;font-family:var(--sans);font-weight:700;font-size:16px;cursor:pointer;transition:all .3s;margin-top:16px;background:linear-gradient(135deg,var(--purple),#7B60B8);color:#fff;box-shadow:0 4px 14px rgba(107,90,144,.15)}
.sim-next:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(107,90,144,.25)}
.sim-next.gold{background:linear-gradient(135deg,var(--goldBtn),#A87820);box-shadow:0 4px 14px rgba(184,138,40,.15)}
.sim-reward-bar{display:flex;gap:8px;justify-content:center;margin-top:12px;animation:fadeUp .5s ease .2s both}
.sim-reward{display:inline-flex;align-items:center;gap:5px;padding:7px 16px;border-radius:var(--Rs);font-size:13px;font-weight:700;animation:reward-bounce .5s ease}
.sim-map{display:grid;gap:8px;margin-bottom:18px}
.sim-stage{padding:14px 8px;border-radius:var(--Rm);text-align:center;border:1.5px solid var(--border);background:var(--bg-card);transition:all .3s;cursor:pointer}
.sim-stage:hover{transform:translateY(-3px);box-shadow:var(--shH)}
.sim-stage.active{border-color:var(--purple);background:var(--purpleGlow);box-shadow:0 0 12px rgba(107,90,144,.08)}
.sim-stage.locked{opacity:.25;cursor:not-allowed}
.sim-stage.done{border-color:var(--green);background:var(--greenPale)}
.sim-stage-icon{font-size:24px;margin-bottom:4px}.sim-stage-name{font-family:var(--serif);font-size:11px;font-weight:700}
.sim-biz{padding:20px;border-radius:var(--R);background:linear-gradient(135deg,var(--goldPale),var(--purplePale));border:1px solid var(--border);margin-top:14px}
.sim-biz-stat{display:flex;gap:8px;margin-top:10px}
.sim-biz-s{flex:1;padding:12px 8px;border-radius:var(--Rm);background:var(--bg-card);text-align:center;border:1px solid var(--border)}

/* ═══ LESSONS ═══ */
.lesson-box{background:var(--bg-card);border-radius:16px;box-shadow:var(--sh);border:1px solid var(--border);overflow:hidden;max-width:740px}
.lesson-header{padding:26px 28px;background:linear-gradient(135deg,var(--purplePale),var(--bg-raised));border-bottom:1px solid var(--border);overflow:hidden;word-wrap:break-word}
.lesson-body{padding:26px 28px;overflow-x:hidden;word-wrap:break-word;overflow-wrap:break-word;max-width:100%}
.lesson-step{margin-bottom:22px;animation:fadeUp .4s ease both}
.lesson-video{margin:0 0 22px;animation:fadeUp .4s ease both}
.lesson-video .lv-label{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.lesson-video .lv-tag{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--coral,#d6593c)}
.lesson-video .lv-icon{width:28px;height:28px;border-radius:var(--Rs);display:grid;place-items:center;font-size:14px;background:var(--coral,#d6593c);color:#fff;flex-shrink:0}
.lesson-video .lv-frame{position:relative;width:100%;padding-top:56.25%;border-radius:14px;overflow:hidden;background:#000;box-shadow:0 4px 18px rgba(0,0,0,.12)}
.lesson-video .lv-frame iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
.step-label{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.step-num{width:28px;height:28px;border-radius:var(--Rs);display:grid;place-items:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}
.step-tag{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px}
.step-text{font-size:16px;line-height:1.85;color:var(--body);word-wrap:break-word;overflow-wrap:break-word;max-width:100%}
.step-box{padding:22px;border-radius:var(--Rm);border:1px solid var(--border)}
.decision-box{padding:22px;border-radius:var(--Rm);background:var(--bg-raised);border:1.5px solid var(--borderH);margin:14px 0}
.decision-title{font-family:var(--serif);font-size:18px;font-weight:700;margin-bottom:14px;text-align:center;color:var(--ink)}
.dec-opt{padding:16px 20px;border-radius:var(--Rm);border:2px solid var(--border);background:var(--bg-card);font-family:var(--sans);font-weight:600;font-size:15px;cursor:pointer;transition:all .25s;text-align:left;color:var(--ink);line-height:1.5;width:100%;margin-bottom:8px;display:block}
.dec-opt:hover:not(:disabled){border-color:var(--purple);background:var(--purplePale);transform:translateX(4px)}
.dec-opt.pick-good{border-color:var(--green);background:var(--greenPale);color:var(--greenDk)}
.dec-opt.pick-bad{border-color:var(--coral);background:var(--coralPale);color:var(--coral)}
.dec-opt.pick-dim{opacity:.15;pointer-events:none}
.consequence{padding:16px 18px;border-radius:var(--Rm);margin-top:12px;font-size:15px;line-height:1.65;font-weight:500;animation:fadeUp .3s ease}
.consequence.good{background:var(--greenPale);color:var(--greenDk)}.consequence.bad{background:var(--coralPale);color:var(--coral)}
.reward-pop{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:var(--Rs);font-size:13px;font-weight:700;animation:reward-bounce .5s ease;margin-top:8px}
.reward-coins{background:var(--goldPale);color:var(--gold)}
.reward-xp{background:var(--purplePale);color:var(--purple)}
.lesson-progress{display:flex;align-items:center;gap:4px;justify-content:center;margin-top:16px}
.lp-dot{width:10px;height:10px;border-radius:50%;transition:all .3s}
.lp-dot.done{background:var(--purple);transform:scale(1.1)}
.lp-dot.current{background:var(--goldBtn);transform:scale(1.4);box-shadow:0 0 10px rgba(184,138,40,.2)}
.lp-dot.upcoming{background:var(--dim)}
.sim-unlock{padding:20px;border-radius:var(--Rm);background:var(--purplePale);border:1.5px dashed rgba(107,90,144,.2);text-align:center;margin-top:16px;animation:fadeUp .4s ease}
.sim-unlock h4{font-family:var(--serif);font-size:16px;font-weight:700;color:var(--purple)}
.btn-sim{height:44px;padding:0 26px;border-radius:var(--Rm);border:none;background:linear-gradient(135deg,var(--purple),#7B60B8);color:#fff;font-family:var(--sans);font-weight:700;font-size:14px;cursor:pointer;margin-top:12px;transition:all .25s;box-shadow:0 2px 8px rgba(107,90,144,.15)}
.btn-sim:hover{transform:translateY(-2px);box-shadow:0 4px 14px rgba(107,90,144,.25)}
.continue-btn{width:100%;height:50px;border-radius:var(--Rm);border:none;font-family:var(--sans);font-weight:700;font-size:16px;cursor:pointer;transition:all .3s;margin-top:14px}
.continue-btn:hover{transform:translateY(-3px)}
.continue-btn.purple{background:linear-gradient(135deg,var(--purple),#7B60B8);color:#fff;box-shadow:0 4px 14px rgba(107,90,144,.15)}
.continue-btn.gold{background:linear-gradient(135deg,var(--goldBtn),#A87820);color:#fff;box-shadow:0 4px 14px rgba(184,138,40,.15)}

/* ═══ MODALS ═══ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:flex;align-items:center;justify-content:center;animation:fadeUp .2s ease;backdrop-filter:blur(4px)}
.modal{background:var(--bg-card);border-radius:16px;width:90%;max-width:480px;max-height:85vh;overflow-y:auto;box-shadow:0 16px 48px rgba(0,0,0,.15);border:1px solid var(--border);animation:up .3s ease}
.modal-head{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-head h3{font-family:var(--serif);font-size:18px;font-weight:700}
.modal-close{width:32px;height:32px;border-radius:8px;border:none;background:var(--bg-raised);cursor:pointer;font-size:16px;display:grid;place-items:center;transition:all .2s;color:var(--mute)}
.modal-close:hover{background:var(--coralPale);color:var(--coral)}
.modal-body{padding:24px}
.modal-input{width:100%;height:42px;padding:0 14px;border-radius:12px;border:1.5px solid var(--border);background:var(--bg-input);font-family:var(--sans);font-size:14px;color:var(--ink);outline:none;transition:all .2s;margin-bottom:12px}
.modal-input:focus{border-color:var(--purple);box-shadow:0 0 0 3px rgba(107,90,144,.08)}
.modal-textarea{width:100%;height:100px;padding:12px 14px;border-radius:12px;border:1.5px solid var(--border);background:var(--bg-input);font-family:var(--sans);font-size:14px;color:var(--ink);outline:none;resize:vertical;transition:all .2s;margin-bottom:12px}
.modal-textarea:focus{border-color:var(--purple);box-shadow:0 0 0 3px rgba(107,90,144,.08)}

/* ═══ MINI CHART ═══ */
.mini-chart{display:flex;align-items:flex-end;gap:4px;height:48px;padding:8px 0}
.mini-bar{flex:1;border-radius:8px 4px 0 0;transition:height .5s cubic-bezier(.16,1,.3,1);min-width:8px}

/* ═══ GLOSSARY TOOLTIPS ═══ */
.gterm{border-bottom:1.5px dotted var(--purple);color:var(--purple);cursor:help;position:relative;font-weight:600}
.gterm:hover{color:var(--purpleD)}
.gterm .gtip{display:none;position:fixed;top:auto;bottom:24px;left:50%;transform:translateX(-50%);background:var(--bg-dark);color:#E0DCE8;padding:14px 18px;border-radius:14px;font-size:13px;font-weight:400;line-height:1.55;width:min(440px,calc(100vw - 32px));max-height:60vh;overflow-y:auto;box-shadow:0 8px 32px rgba(0,0,0,.25);z-index:10000;pointer-events:auto;text-align:left}
.gterm:hover .gtip,.gterm.active .gtip{display:block;animation:fadeUp .2s ease}

/* ═══ POLISH ═══ */
*{box-sizing:border-box}
.card,.btn,.dec-opt,.fc-opt,.sim-opt,.stk,.sb-i,.tb{transition:all .25s cubic-bezier(.16,1,.3,1)}
::selection{background:rgba(107,90,144,.2);color:var(--ink)}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(107,90,144,.15);border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:rgba(107,90,144,.25)}

/* ═══ JOURNEY BOARD-GAME MAP ═══ */
.jmap{max-width:660px;margin:0 auto;position:relative;padding:20px 0}
.jmap-row{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:6px}
.jmap-node{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;font-size:20px;cursor:pointer;transition:all .35s;position:relative;border:3px solid var(--border);background:var(--bg-card);z-index:2;flex-shrink:0}
.jmap-node:hover{transform:scale(1.1)}
.jmap-node .jn-num{font-family:var(--serif);font-size:13px;font-weight:800;color:var(--mute)}
.jmap-node .jn-lock{font-size:15px;opacity:.35}
.jmap-node.done{border-color:#C8A030;background:linear-gradient(145deg,#FFF8E0,#F8ECC0);box-shadow:0 0 14px rgba(200,160,48,.3),0 0 3px rgba(200,160,48,.15)}
.jmap-node.done .jn-num{color:#8A6A10}
.jmap-node.current{border-color:var(--purple);background:var(--purplePale);animation:jpulse 2s ease-in-out infinite}
.jmap-node.current .jn-num{color:var(--purple)}
@keyframes jpulse{0%,100%{box-shadow:0 0 0 0 rgba(107,90,144,.25)}50%{box-shadow:0 0 0 12px rgba(107,90,144,0)}}
.jmap-node.locked{opacity:.3;cursor:not-allowed;border-color:var(--dim);background:var(--bg-raised)}
.jmap-node.locked:hover{transform:none}
.jmap-conn{width:24px;height:3px;background:var(--dim);flex-shrink:0;border-radius:4px;margin:0 -1px}
.jmap-conn.done{background:linear-gradient(90deg,#C8A030,#D4B050)}
.jmap-world{padding:14px 0 8px;text-align:center;font-family:var(--serif);font-weight:800;font-size:17px}
.jmap-lbl{position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);white-space:nowrap;font-size:9px;font-weight:700;color:var(--mute);max-width:72px;text-align:center;overflow:hidden;text-overflow:ellipsis}
.world-lili .jmap-world{color:#B87020;background:linear-gradient(90deg,rgba(184,112,32,.05),transparent,rgba(184,112,32,.05));border-radius:12px;padding:10px 16px}
.world-goldie .jmap-world{color:#6B5A90;background:linear-gradient(90deg,rgba(107,90,144,.05),transparent,rgba(107,90,144,.05));border-radius:12px;padding:10px 16px}
.world-lili .jmap-node.current{border-color:#D08830;animation-name:jpulse-l}
@keyframes jpulse-l{0%,100%{box-shadow:0 0 0 0 rgba(208,136,48,.25)}50%{box-shadow:0 0 0 12px rgba(208,136,48,0)}}
.world-goldie .jmap-node.current{border-color:#6B5A90}
.sim-matched{max-width:640px}
.loss-modal{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:9999;display:grid;place-items:center;padding:20px;animation:fadeUp .35s ease}
.loss-inner{max-width:380px;background:var(--bg-card);border-radius:20px;padding:28px;text-align:center;box-shadow:0 12px 48px rgba(0,0,0,.25)}

/* ═══ GOALS SYSTEM ═══ */
.goal-card{padding:16px;border-radius:var(--Rm);border:1.5px solid var(--border);background:var(--bg-card);margin-bottom:10px;transition:all .25s}
.goal-card:hover{border-color:var(--borderH);box-shadow:var(--shH)}
.goal-bar{height:8px;background:var(--bg-input);border-radius:8px;overflow:hidden;margin-top:8px}
.goal-fill{height:100%;border-radius:8px;transition:width .6s cubic-bezier(.16,1,.3,1)}
.goal-prompt{position:fixed;bottom:20px;right:20px;z-index:9000;max-width:320px;background:var(--bg-card);border-radius:16px;box-shadow:0 8px 32px rgba(0,0,0,.15);border:1px solid var(--border);padding:18px;animation:up .4s ease}
.goal-prompt-close{position:absolute;top:8px;right:10px;background:none;border:none;font-size:16px;color:var(--mute);cursor:pointer}
.feedback-modal{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:9999;display:grid;place-items:center;padding:20px;overflow-y:auto}
.feedback-inner{max-width:440px;width:100%;background:var(--bg-card);border-radius:20px;padding:28px;box-shadow:0 12px 48px rgba(0,0,0,.2);max-height:calc(100dvh - 40px);overflow-y:auto;-webkit-overflow-scrolling:touch}
@media(max-width:480px){
.feedback-modal{padding:10px;align-items:flex-start}
.feedback-inner{padding:20px;max-height:calc(100dvh - 20px);border-radius:16px}
}
.feedback-stars{display:flex;gap:6px;justify-content:center;margin:12px 0}
.feedback-star{width:40px;height:40px;border-radius:50%;border:2px solid var(--border);background:var(--bg-card);font-size:20px;cursor:pointer;display:grid;place-items:center;transition:all .2s}
.feedback-star.on{border-color:var(--gold);background:var(--goldPale)}
.feedback-star:hover{transform:scale(1.15)}
.explore-tabs{display:flex;gap:4px;margin-bottom:14px}
.explore-tab{flex:1;padding:10px 8px;border-radius:12px;border:1.5px solid transparent;background:var(--bg-raised);font-family:var(--sans);font-size:12px;font-weight:600;cursor:pointer;text-align:center;color:var(--mute);transition:all .2s}
.explore-tab:hover{color:var(--ink);border-color:var(--borderH)}
.explore-tab.on{background:var(--purplePale);color:var(--purple);border-color:rgba(107,90,144,.12)}
.sandbox-lock{padding:20px;border-radius:16px;border:2px dashed var(--dim);text-align:center;margin:16px 0;background:var(--bg-raised);opacity:.7}
.sandbox-unlock{padding:20px;border-radius:16px;border:2px solid var(--gold);text-align:center;margin:16px 0;background:var(--goldPale);cursor:pointer;transition:all .25s}
.sandbox-unlock:hover{transform:translateY(-2px);box-shadow:var(--shH)}

/* ═══ RESPONSIVE ═══ */

/* ═══ MOBILE NAV ═══ */
.mob-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:var(--bg-dark);border-bottom:1px solid rgba(255,255,255,.06);z-index:200;padding:0 16px;align-items:center;justify-content:space-between}
.mob-header h1{font-family:var(--serif);font-size:16px;font-weight:700;color:#fff;margin:0}
.mob-burger{width:40px;height:40px;border-radius:12px;border:none;background:rgba(255,255,255,.08);color:#fff;font-size:20px;cursor:pointer;display:grid;place-items:center}
.mob-burger:active{background:rgba(255,255,255,.15)}
.mob-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:250;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.mob-overlay.show{display:block}
.sb.mob-open{display:flex!important;position:fixed;top:0;left:0;bottom:0;z-index:300;width:280px;box-shadow:8px 0 32px rgba(0,0,0,.3);animation:slideIn .25s ease}
@keyframes slideIn{from{transform:translateX(-100%)}to{transform:translateX(0)}}
.mob-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:12px;border:none;background:rgba(255,255,255,.08);color:#fff;font-size:18px;cursor:pointer;display:none;place-items:center;z-index:5}

/* ═══ NAVIGATORS CHROME THEME — applies when body.nav-chrome ═══ */
/* Shifts sidebar + top bar + mob header to the navy/amber Navigators aesthetic
   used in the lessons and home. Leaves Sparks/Builders untouched. */
body.nav-chrome{background:#FAF7F2}
body.nav-chrome .sb{background:#0F2A47;border-right:1px solid rgba(255,255,255,.06)}
body.nav-chrome .sb-logo{border-bottom:1px solid rgba(255,255,255,.08);padding:22px 18px}
body.nav-chrome .sb-logo-t{font-family:'Fraunces',serif;font-weight:600;font-size:14px;color:#fff;letter-spacing:-0.01em}
body.nav-chrome .sb-logo-t .sub{color:#FBBF24;font-weight:500;font-style:normal}
body.nav-chrome .sb-brand-mark{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,#D97706,#FBBF24);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:'Fraunces',serif;font-weight:700;font-size:15px;color:#0F2A47;box-shadow:0 4px 12px rgba(217,119,6,.25)}
body.nav-chrome .sb-age{margin:12px 14px;padding:8px 14px;border-radius:100px;background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.2);font-size:10px;color:#FBBF24;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;text-align:center}
body.nav-chrome .sb-age:hover{background:rgba(251,191,36,.18);border-color:rgba(251,191,36,.35)}
body.nav-chrome .sb-lbl{color:rgba(255,255,255,.4);font-size:10px;letter-spacing:.12em;padding:16px 20px 8px;font-weight:700}
body.nav-chrome .sb-i{color:rgba(255,255,255,.65);font-size:13px;font-weight:500;padding:11px 14px;border-radius:10px;transition:all .18s}
body.nav-chrome .sb-i:hover{background:rgba(255,255,255,.06);color:#fff}
body.nav-chrome .sb-i.on{background:rgba(251,191,36,.12);color:#FBBF24;font-weight:600;box-shadow:inset 3px 0 0 #FBBF24}
body.nav-chrome .sb-i.on svg{opacity:1;stroke:#FBBF24}
body.nav-chrome .sb-i svg{opacity:.55}
body.nav-chrome .sb-div{background:rgba(255,255,255,.06);margin:10px 18px}
body.nav-chrome .sb-foot{border-top:1px solid rgba(255,255,255,.08);padding:16px}
body.nav-chrome .sb-av{background:linear-gradient(135deg,#D97706,#FBBF24);color:#0F2A47;font-weight:800;font-family:'Fraunces',serif}
body.nav-chrome .sb-foot .nm{color:#fff;font-size:13px;font-weight:600}
body.nav-chrome .sb-foot .rl{color:rgba(255,255,255,.5);font-size:11px}
/* Top bar — desktop */
body.nav-chrome .topbar{background:rgba(15,42,71,.95);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.08);padding:14px 24px}
body.nav-chrome .topbar h1{font-family:'Fraunces',serif;font-size:17px;font-weight:700;color:#fff;letter-spacing:-0.015em}
body.nav-chrome .topbar h1 em{color:#FBBF24;font-style:italic}
body.nav-chrome .chip{height:30px;padding:0 12px;border-radius:100px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);font-size:11px;font-weight:600;color:rgba(255,255,255,.75)}
body.nav-chrome .chip:hover{background:rgba(255,255,255,.1);color:#fff}
body.nav-chrome .top-btn{background:linear-gradient(135deg,#D97706,#FBBF24);color:#0F2A47;font-weight:700;height:32px;padding:0 14px;border-radius:100px;font-size:11px;letter-spacing:0.02em;box-shadow:0 4px 12px rgba(217,119,6,.3)}
body.nav-chrome .top-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(217,119,6,.4)}
/* Mobile header */
body.nav-chrome .mob-header{background:rgba(15,42,71,.95);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.08)}
body.nav-chrome .mob-header h1{font-family:'Fraunces',serif;color:#fff;font-size:15px}
body.nav-chrome .mob-burger{background:rgba(255,255,255,.08);color:#fff}
body.nav-chrome .mob-burger:active{background:rgba(251,191,36,.18);color:#FBBF24}
/* Page background */
body.nav-chrome .pg{background:#FAF7F2}
body.nav-chrome .main{background:#FAF7F2}
body.nav-chrome .gw-fab{display:none}
body.nav-chrome .gw-panel{display:none}

/* ═══ NAVIGATORS PAGE CONTENT — applies to any page when isTeens ═══ */
/* Cards */
body.nav-chrome .card{background:#fff;border:1px solid #E5E7EB;border-radius:18px;box-shadow:0 2px 8px rgba(15,42,71,.04);transition:all .25s}
body.nav-chrome .card:hover{border-color:#D1D5DB;box-shadow:0 8px 24px rgba(15,42,71,.08)}
/* Typography — serif for anything using var(--serif), Fraunces for pg H1/H2/H3 */
body.nav-chrome .pg h1,body.nav-chrome .pg h2,body.nav-chrome .pg h3,body.nav-chrome .pg h4{font-family:'Fraunces',serif;color:#0F2A47;letter-spacing:-0.02em}
body.nav-chrome .pg h1 em,body.nav-chrome .pg h2 em,body.nav-chrome .pg h3 em{color:#D97706;font-style:italic;font-weight:700}
body.nav-chrome .pg p{color:#374151}
/* Buttons — navy or amber instead of purple */
body.nav-chrome .btn,body.nav-chrome .btn-sim{background:#0F2A47;color:#fff;border-radius:10px;font-weight:600;box-shadow:0 4px 12px rgba(15,42,71,.15)}
body.nav-chrome .btn:hover,body.nav-chrome .btn-sim:hover{background:#1E3A5F;transform:translateY(-1px);box-shadow:0 6px 16px rgba(15,42,71,.22)}
body.nav-chrome .btn.btn-primary,body.nav-chrome .btn-amber{background:linear-gradient(135deg,#D97706,#FBBF24);color:#0F2A47;font-weight:700;box-shadow:0 4px 12px rgba(217,119,6,.25)}
body.nav-chrome .btn.btn-primary:hover,body.nav-chrome .btn-amber:hover{box-shadow:0 6px 16px rgba(217,119,6,.35)}
/* Tabs — amber active instead of purple */
body.nav-chrome .tb{background:#fff;color:#6B7280;border-color:#E5E7EB;border-radius:100px;font-weight:600}
body.nav-chrome .tb:hover{border-color:#D1D5DB;color:#0F2A47;background:#F9FAFB}
body.nav-chrome .tb.on{background:#FEF3C7;color:#B45309;border-color:#D97706}
/* Hero-p (the gradient hero used on several pages) */
body.nav-chrome .hero-p{background:linear-gradient(180deg,#0F2A47,#081A2E);border:none;color:#fff;border-radius:24px;padding:32px 24px;position:relative;overflow:hidden;box-shadow:0 24px 48px -20px rgba(15,42,71,.35)}
body.nav-chrome .hero-p::before{content:'';position:absolute;top:-60px;right:-60px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(217,119,6,.25),transparent 70%);pointer-events:none}
body.nav-chrome .hero-p h2{font-family:'Fraunces',serif;color:#fff;font-size:26px;letter-spacing:-0.025em;font-weight:700;position:relative;z-index:1}
body.nav-chrome .hero-p h2 em{color:#FBBF24;font-style:italic}
body.nav-chrome .hero-p p{color:rgba(255,255,255,.8);font-size:14px;line-height:1.6;margin-top:8px;position:relative;z-index:1}
body.nav-chrome .hero-float{opacity:.15}
/* Stats/tiles in pages — off-white with amber numbers */
body.nav-chrome .stat,body.nav-chrome .stat-tile{background:#fff;border:1px solid #E5E7EB;border-radius:14px}
body.nav-chrome .stat-val,body.nav-chrome .stat-num{color:#0F2A47;font-family:'Fraunces',serif}
/* Inputs */
body.nav-chrome input[type="text"],body.nav-chrome input[type="number"],body.nav-chrome input[type="email"],body.nav-chrome input[type="password"],body.nav-chrome textarea,body.nav-chrome select{background:#fff;border:1.5px solid #E5E7EB;border-radius:10px;font-family:'Inter',sans-serif;color:#0F2A47}
body.nav-chrome input:focus,body.nav-chrome textarea:focus,body.nav-chrome select:focus{border-color:#D97706;outline:none;box-shadow:0 0 0 3px rgba(217,119,6,.1)}
/* Selection color */
body.nav-chrome ::selection{background:rgba(251,191,36,.25)}

/* ═══ SPARKS CHROME THEME — applies when body.sparks-chrome (ages 6-11+) ═══ */
/* Warm-but-grown: cream/amber palette at lower saturation, matched to the Builders/Navigators
   shadow+radius system. No chunky bottom-shadows, no oversized radii, no Fredoka in chrome
   (Moneyville keeps Fredoka in its own scope). White topbar preserved as the Sparks differentiator. */
body.sparks-chrome{
--bg:#FFFBF5;--bg-card:#FFFFFF;--bg-raised:#FEF7E4;--bg-input:#FFFFFF;
--ink:#3D2817;--body:#5E4630;--mute:#9B8470;--dim:#BFA68B;--light:#E8DCC6;
--purple:#D4860E;--purpleD:#A96B0A;--purplePale:rgba(212,134,14,.08);--purpleGlow:rgba(212,134,14,.15);
--border:rgba(160,118,68,.10);--borderH:rgba(160,118,68,.20);
--R:16px;--Rm:12px;--Rs:8px;
--sh:0 1px 2px rgba(120,80,30,.05),0 4px 12px rgba(160,118,68,.06);
--shH:0 8px 24px rgba(160,118,68,.10);
}
body.sparks-chrome{background:linear-gradient(180deg,#FFFBF5,#FEF7E4);min-height:100vh;color:var(--ink)}
body.sparks-chrome .main{background:transparent}
body.sparks-chrome .pg{background:transparent}
/* Sidebar — soft cream, 1px borders, inset-left active state (matches Builders/Navigators) */
body.sparks-chrome .sb{background:#FFFBF5;border-right:1px solid var(--border)}
body.sparks-chrome .sb-logo{border-bottom:1px solid var(--border);padding:22px 18px}
body.sparks-chrome .sb-logo-t{font-family:var(--serif);font-weight:700;font-size:15px;color:var(--ink);letter-spacing:-0.02em}
body.sparks-chrome .sb-logo-t .sub{color:var(--purpleD);font-weight:500;font-style:normal}
body.sparks-chrome .sb-brand-mark{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--purple),var(--purpleD));display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700;font-size:16px;color:#fff;box-shadow:0 4px 12px rgba(212,134,14,.25)}
body.sparks-chrome .sb-age{margin:12px 14px;padding:8px 14px;border-radius:8px;background:rgba(212,134,14,.08);border:1px solid rgba(212,134,14,.18);font-size:10px;color:var(--purpleD);font-weight:700;letter-spacing:0.1em;text-transform:uppercase;text-align:center}
body.sparks-chrome .sb-age:hover{background:rgba(212,134,14,.14);border-color:rgba(212,134,14,.3)}
body.sparks-chrome .sb-lbl{color:var(--mute);font-size:10px;letter-spacing:.14em;padding:18px 20px 8px;font-weight:700}
body.sparks-chrome .sb-i{color:var(--body);font-size:13px;font-weight:500;padding:11px 14px;border-radius:8px;transition:all .18s}
body.sparks-chrome .sb-i:hover{background:rgba(212,134,14,.08);color:var(--ink)}
body.sparks-chrome .sb-i.on{background:rgba(212,134,14,.12);color:var(--purpleD);font-weight:600;box-shadow:inset 3px 0 0 var(--purple)}
body.sparks-chrome .sb-i.on svg{opacity:1;stroke:var(--purpleD)}
body.sparks-chrome .sb-i svg{opacity:.55}
body.sparks-chrome .sb-div{background:var(--border);margin:10px 18px}
body.sparks-chrome .sb-foot{border-top:1px solid var(--border);padding:16px}
body.sparks-chrome .sb-av{background:linear-gradient(135deg,var(--purple),var(--purpleD));color:#fff;font-weight:800}
body.sparks-chrome .sb-foot .nm{color:var(--ink);font-size:13px;font-weight:600}
body.sparks-chrome .sb-foot .rl{color:var(--mute);font-size:11px}
/* Mobile header — clean white, warm 1px border + warm-tinted micro-shadow (distinct from Builders' cool tint) */
body.sparks-chrome .mob-header{background:#fff;border-bottom:1px solid var(--border);box-shadow:0 1px 3px rgba(120,80,30,.04);height:60px}
body.sparks-chrome .mob-header h1{color:var(--ink);font-size:15px;font-weight:600;letter-spacing:-0.01em}
body.sparks-chrome .mob-burger{color:var(--purpleD);background:rgba(212,134,14,.10);border-radius:8px}
body.sparks-chrome .mob-burger:active{background:rgba(212,134,14,.20)}
/* Cards — match Builders/Navigators shape, warm-tinted border */
body.sparks-chrome .card{background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--sh);padding:18px;color:var(--ink);transition:all .22s}
body.sparks-chrome .card:hover{border-color:var(--borderH);box-shadow:var(--shH);transform:translateY(-1px)}
/* Typography — Playfair serif headers (via --serif), default sans body */
body.sparks-chrome .pg h1,body.sparks-chrome .pg h2,body.sparks-chrome .pg h3,body.sparks-chrome .pg h4{font-family:var(--serif);color:var(--ink);font-weight:700;letter-spacing:-0.015em}
body.sparks-chrome .pg h1{font-size:28px}
body.sparks-chrome .pg h2{font-size:22px}
body.sparks-chrome .pg h3{font-size:17px}
body.sparks-chrome .pg p{color:var(--body);line-height:1.6}
/* Buttons — toned amber primary, soft drop-shadow, no chunky bottom-shadow or Fredoka */
body.sparks-chrome .btn,body.sparks-chrome .btn-sim{background:linear-gradient(135deg,var(--purple),var(--purpleD));color:#fff;border-radius:10px;font-weight:600;font-size:13px;letter-spacing:0.01em;height:42px;padding:0 20px;border:none;box-shadow:0 4px 12px rgba(212,134,14,.20)}
body.sparks-chrome .btn:hover,body.sparks-chrome .btn-sim:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(212,134,14,.30)}
body.sparks-chrome .btn.bSm{height:34px;font-size:12px;padding:0 14px}
body.sparks-chrome .btn.bG{background:linear-gradient(135deg,#10B981,#059669);box-shadow:0 4px 12px rgba(5,150,105,.22)}
body.sparks-chrome .btn.bG:hover{box-shadow:0 6px 20px rgba(5,150,105,.32)}
body.sparks-chrome .btn.bP{background:linear-gradient(135deg,#FF5A5F,#E11D48);color:#fff;box-shadow:0 4px 12px rgba(255,90,95,.22)}
body.sparks-chrome .btn.bP:hover{box-shadow:0 6px 20px rgba(255,90,95,.32);background:linear-gradient(135deg,#E11D48,#BE123C)}
body.sparks-chrome .btn.bW{background:#fff;color:var(--ink);border:1.5px solid var(--border);box-shadow:none}
body.sparks-chrome .btn.bW:hover{border-color:var(--borderH);background:var(--bg-raised)}
/* Tabs — pill shape, subtle tinted active (matches Navigators' tinted-active pattern) */
body.sparks-chrome .tb{background:#fff;color:var(--mute);border:1.5px solid var(--border);border-radius:100px;font-weight:600;font-size:13px;padding:8px 14px}
body.sparks-chrome .tb:hover{border-color:var(--borderH);color:var(--ink);background:var(--bg-raised)}
body.sparks-chrome .tb.on{background:var(--purplePale);color:var(--purpleD);border-color:var(--purple)}
/* Hero panel — toned warm gradient (Option A), no sun-circle ornaments, no text-shadow */
body.sparks-chrome .hero-p{background:linear-gradient(135deg,#E5A23D 0%,#C77F15 100%);border:none;color:#fff;border-radius:var(--R);padding:26px 22px;box-shadow:0 6px 20px rgba(160,100,20,.18);position:relative;overflow:hidden}
body.sparks-chrome .hero-p h2{color:#fff;font-size:24px;font-weight:700;position:relative;z-index:1}
body.sparks-chrome .hero-p p{color:rgba(255,255,255,.92);font-size:14px;font-weight:500;line-height:1.6;margin-top:6px;position:relative;z-index:1}
/* Stats / tiles */
body.sparks-chrome .stat,body.sparks-chrome .stat-tile{background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--sh)}
body.sparks-chrome .stat-val,body.sparks-chrome .stat-num{color:var(--ink);font-family:var(--serif);font-weight:700}
/* Inputs */
body.sparks-chrome input[type="text"],body.sparks-chrome input[type="number"],body.sparks-chrome input[type="email"],body.sparks-chrome input[type="password"],body.sparks-chrome textarea,body.sparks-chrome select,body.sparks-chrome .t-input{background:#fff;border:1.5px solid var(--border);border-radius:10px;color:var(--ink);height:42px;padding:0 14px}
body.sparks-chrome input:focus,body.sparks-chrome textarea:focus,body.sparks-chrome select:focus,body.sparks-chrome .t-input:focus{border-color:var(--purple);outline:none;box-shadow:0 0 0 3px rgba(212,134,14,.18)}
/* Selection */
body.sparks-chrome ::selection{background:rgba(212,134,14,.30);color:var(--ink)}
/* Hide adult-only widgets from Sparks */
body.sparks-chrome .gw-fab{display:none}
body.sparks-chrome .gw-panel{display:none}
/* Topbar (desktop) — white preserved as Sparks chrome differentiator, 1px warm border */
body.sparks-chrome .topbar{background:#fff;border-bottom:1px solid var(--border)}
body.sparks-chrome .topbar h1{font-family:var(--serif);color:var(--ink);font-weight:700}

/* ═══ BUILDERS CHROME THEME — applies when body.builders-chrome (ages 12-15) ═══ */
/* Confident teen energy — modern light theme with deep navy + electric teal + warm coral pops. */
/* Soft-light not dark: long reading sessions need warmth; matches Duolingo/Linear/BeReal feel. */
body.builders-chrome{
--bg:#F5F7FA;--bg-card:#FFFFFF;--bg-raised:#EEF2F6;--bg-input:#FFFFFF;
--ink:#0F172A;--body:#334155;--mute:#64748B;--dim:#94A3B8;--light:#CBD5E1;
--purple:#0EA5A4;--purpleD:#0F766E;--purplePale:rgba(14,165,164,.08);--purpleGlow:rgba(14,165,164,.18);
--gold:#F59E0B;--goldBtn:#D97706;--goldPale:rgba(245,158,11,.08);--goldText:#92400E;
--green:#0EA5A4;--greenPale:rgba(14,165,164,.08);--greenDk:#0F766E;
--coral:#FF5A5F;--coralPale:rgba(255,90,95,.08);
--blue:#3B82F6;--bluePale:rgba(59,130,246,.08);
--border:rgba(15,23,42,.08);--borderH:rgba(15,23,42,.16);
--sh:0 1px 2px rgba(15,23,42,.04),0 4px 12px rgba(15,23,42,.04);
--shH:0 8px 24px rgba(15,23,42,.08);
}
body.builders-chrome{background:#F5F7FA;min-height:100vh;color:#0F172A}
body.builders-chrome .main{background:transparent}
body.builders-chrome .pg{background:transparent}
/* Sidebar — clean off-white with deep-navy text (modern productivity feel) */
body.builders-chrome .sb{background:#FFFFFF;border-right:1px solid rgba(15,23,42,.06)}
body.builders-chrome .sb-logo{border-bottom:1px solid rgba(15,23,42,.06);padding:22px 18px}
body.builders-chrome .sb-logo-t{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:15px;color:#0F172A;letter-spacing:-0.02em}
body.builders-chrome .sb-logo-t .sub{color:#0EA5A4;font-weight:500;font-style:normal}
body.builders-chrome .sb-brand-mark{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#14B8A6,#0EA5A4);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:16px;color:#FFFFFF;box-shadow:0 4px 12px rgba(14,165,164,.25)}
body.builders-chrome .sb-age{margin:12px 14px;padding:8px 14px;border-radius:8px;background:rgba(14,165,164,.08);border:1px solid rgba(14,165,164,.18);font-size:10px;color:#0F766E;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;text-align:center}
body.builders-chrome .sb-age:hover{background:rgba(14,165,164,.14);border-color:rgba(14,165,164,.3)}
body.builders-chrome .sb-lbl{color:#94A3B8;font-size:10px;letter-spacing:.14em;padding:18px 20px 8px;font-weight:700;font-family:'Space Grotesk',sans-serif}
body.builders-chrome .sb-i{color:#475569;font-size:13px;font-weight:500;padding:11px 14px;border-radius:8px;font-family:'Inter',sans-serif;transition:all .18s}
body.builders-chrome .sb-i:hover{background:rgba(14,165,164,.06);color:#0F172A}
body.builders-chrome .sb-i.on{background:rgba(14,165,164,.1);color:#0F766E;font-weight:600;box-shadow:inset 3px 0 0 #0EA5A4}
body.builders-chrome .sb-i.on svg{opacity:1;stroke:#0F766E}
body.builders-chrome .sb-i svg{opacity:.55}
body.builders-chrome .sb-div{background:rgba(15,23,42,.06);margin:10px 18px}
body.builders-chrome .sb-foot{border-top:1px solid rgba(15,23,42,.06);padding:16px}
body.builders-chrome .sb-av{background:linear-gradient(135deg,#0EA5A4,#FF5A5F);color:#FFFFFF;font-weight:800;font-family:'Space Grotesk',sans-serif}
body.builders-chrome .sb-foot .nm{color:#0F172A;font-size:13px;font-weight:600}
body.builders-chrome .sb-foot .rl{color:#64748B;font-size:11px}
/* Mobile header — clean white with teal accent (modern, light, teen-confident) */
body.builders-chrome .mob-header{background:#FFFFFF;backdrop-filter:none;border-bottom:1px solid rgba(15,23,42,.08);box-shadow:0 1px 3px rgba(15,23,42,.04)}
body.builders-chrome .mob-header h1{font-family:'Space Grotesk',sans-serif;color:#0F172A;font-size:15px;font-weight:600;letter-spacing:-0.01em}
body.builders-chrome .mob-burger{color:#0F766E;background:rgba(14,165,164,.1);border-radius:8px}
body.builders-chrome .mob-burger:active{background:rgba(14,165,164,.2)}
/* Cards — clean white with subtle shadow on lift */
body.builders-chrome .card{background:#FFFFFF;border:1px solid rgba(15,23,42,.06);border-radius:14px;box-shadow:0 1px 2px rgba(15,23,42,.03);padding:18px;color:#0F172A;transition:all .22s}
body.builders-chrome .card:hover{border-color:rgba(14,165,164,.25);box-shadow:0 8px 24px rgba(15,23,42,.06);transform:translateY(-1px)}
/* Typography — confident geometric */
body.builders-chrome .pg h1,body.builders-chrome .pg h2,body.builders-chrome .pg h3,body.builders-chrome .pg h4{font-family:'Space Grotesk',sans-serif;color:#0F172A;letter-spacing:-0.025em;font-weight:700}
body.builders-chrome .pg h1{font-size:28px}
body.builders-chrome .pg h2{font-size:22px}
body.builders-chrome .pg h3{font-size:17px}
body.builders-chrome .pg p{color:#334155;font-family:'Inter',sans-serif;line-height:1.6}
body.builders-chrome .pg strong{color:#0F172A;font-weight:600}
/* Buttons — solid teal primary, sharp not chunky */
body.builders-chrome .btn,body.builders-chrome .btn-sim{background:linear-gradient(135deg,#14B8A6,#0EA5A4);color:#FFFFFF;border-radius:10px;font-weight:600;font-family:'Space Grotesk',sans-serif;font-size:13px;letter-spacing:0.01em;height:42px;padding:0 20px;border:none;box-shadow:0 4px 12px rgba(14,165,164,.2)}
body.builders-chrome .btn:hover,body.builders-chrome .btn-sim:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(14,165,164,.3);background:linear-gradient(135deg,#0EA5A4,#0F766E)}
body.builders-chrome .btn.bSm{height:34px;font-size:12px;padding:0 14px}
body.builders-chrome .btn.bG{background:linear-gradient(135deg,#14B8A6,#0EA5A4);color:#FFFFFF;box-shadow:0 4px 12px rgba(14,165,164,.2)}
body.builders-chrome .btn.bP{background:linear-gradient(135deg,#FF5A5F,#E11D48);color:#FFFFFF;box-shadow:0 4px 12px rgba(255,90,95,.22)}
body.builders-chrome .btn.bP:hover{box-shadow:0 6px 20px rgba(255,90,95,.32);background:linear-gradient(135deg,#E11D48,#BE123C)}
body.builders-chrome .btn.bW{background:#FFFFFF;color:#0F172A;border:1.5px solid rgba(15,23,42,.12);box-shadow:none}
body.builders-chrome .btn.bW:hover{border-color:#0EA5A4;background:rgba(14,165,164,.04);color:#0F766E}
/* Tabs — pill, modern */
body.builders-chrome .tb{background:#FFFFFF;color:#64748B;border:1px solid rgba(15,23,42,.08);border-radius:100px;font-weight:600;font-family:'Inter',sans-serif;font-size:12px}
body.builders-chrome .tb:hover{border-color:rgba(14,165,164,.3);color:#0F172A;background:rgba(14,165,164,.04)}
body.builders-chrome .tb.on{background:rgba(14,165,164,.1);color:#0F766E;border-color:#0EA5A4}
/* Hero — clean navy gradient with teal/coral accents */
body.builders-chrome .hero-p{background:linear-gradient(135deg,#0F172A 0%,#1E293B 50%,#334155 100%);border:none;color:#FFFFFF;border-radius:18px;padding:30px 24px;position:relative;overflow:hidden;box-shadow:0 12px 32px -8px rgba(15,23,42,.25)}
body.builders-chrome .hero-p::before{content:'';position:absolute;top:-80px;right:-60px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(94,234,212,.22),transparent 70%);pointer-events:none}
body.builders-chrome .hero-p::after{content:'';position:absolute;bottom:-60px;left:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(255,90,95,.15),transparent 70%);pointer-events:none}
body.builders-chrome .hero-p h2{font-family:'Space Grotesk',sans-serif;color:#FFFFFF;font-size:26px;letter-spacing:-0.025em;font-weight:700;position:relative;z-index:1}
body.builders-chrome .hero-p h2 em{color:#5EEAD4;font-style:normal;font-weight:700}
body.builders-chrome .hero-p p{color:rgba(255,255,255,.85);font-family:'Inter',sans-serif;font-size:14px;line-height:1.6;margin-top:8px;position:relative;z-index:1}
/* Stats / tiles */
body.builders-chrome .stat,body.builders-chrome .stat-tile{background:#FFFFFF;border:1px solid rgba(15,23,42,.06);border-radius:12px;box-shadow:0 1px 2px rgba(15,23,42,.03)}
body.builders-chrome .stat-val,body.builders-chrome .stat-num{color:#0F172A;font-family:'Space Grotesk',sans-serif;font-weight:700}
/* Inputs — clean, white, mint focus */
body.builders-chrome input[type="text"],body.builders-chrome input[type="number"],body.builders-chrome input[type="email"],body.builders-chrome input[type="password"],body.builders-chrome textarea,body.builders-chrome select,body.builders-chrome .t-input{background:#FFFFFF;border:1.5px solid rgba(15,23,42,.1);border-radius:8px;font-family:'Inter',sans-serif;color:#0F172A;height:42px;padding:0 14px}
body.builders-chrome input:focus,body.builders-chrome textarea:focus,body.builders-chrome select:focus,body.builders-chrome .t-input:focus{border-color:#0EA5A4;outline:none;box-shadow:0 0 0 3px rgba(14,165,164,.15)}
body.builders-chrome input::placeholder,body.builders-chrome textarea::placeholder{color:#94A3B8}
/* Selection */
body.builders-chrome ::selection{background:rgba(14,165,164,.22);color:#0F172A}
/* Topbar (desktop) */
body.builders-chrome .topbar{background:#FFFFFF;border-bottom:1px solid rgba(15,23,42,.06)}
body.builders-chrome .topbar h1{font-family:'Space Grotesk',sans-serif;color:#0F172A;font-weight:600}
/* Hide adult widgets */
body.builders-chrome .gw-fab{display:none}
body.builders-chrome .gw-panel{display:none}

/* ═══ RESPONSIVE: TABLET (768-1024px) ═══ */
@media(max-width:1024px){
  :root{--sidebar:220px}
  .sb-i span{font-size:12px}
  .topbar h1{font-size:16px}
  .pg{padding:20px 16px}
}

/* ═══ RESPONSIVE: SMALL TABLET / LARGE PHONE (481-767px) ═══ */
@media(max-width:767px){
  .sb{display:none}
  .mob-header{display:flex}
  .mob-close{display:grid}
  .main{margin-left:0;padding-top:56px}
  .topbar{display:none}
  .pg{padding:16px 12px}
  .dg{grid-template-columns:1fr}
  .dg .full{grid-column:1}
  .tabs{gap:2px;margin-bottom:12px}
  .tb{padding:8px 12px;font-size:12px}
  .card{padding:14px}
  .hero-p{padding:16px}
  h2{font-size:20px!important}
  .pt{font-size:14px}
  .step-text{font-size:13px}
  .dec-opt{padding:14px 16px;font-size:14px}
  .sim-opt{padding:14px 16px}
  .sim-story{font-size:14px}
  .btn{min-height:44px;font-size:13px}
  .btn.bSm{min-height:36px}
  .fc-opt{padding:12px 14px;font-size:13px}
  .modal-inner{width:95vw;max-height:90vh;padding:20px}
  .gterm .gtip{left:12px;right:12px;bottom:12px;width:auto;max-width:none;transform:none;border-radius:16px;padding:14px;font-size:12px}
  .sim-unlock{padding:16px}
  .stk{padding:8px 0}
}

/* ═══ RESPONSIVE: MOBILE (320-480px) ═══ */
@media(max-width:480px){
  .pg{padding:12px 10px}
  h2{font-size:18px!important}
  .pt{font-size:13px}
  .tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap}
  .tb{padding:7px 10px;font-size:11px;flex-shrink:0}
  .card{padding:12px;border-radius:12px}
  .dec-opt,.fc-opt,.sim-opt{padding:12px;font-size:13px;border-radius:12px}
  .sim-opt-letter{width:28px;height:28px;font-size:12px}
  .step-box{padding:14px}
  .lesson-step{margin-bottom:12px}
  .modal-inner{width:98vw;padding:16px;border-radius:16px}
  .modal-inner h3{font-size:16px}
  .gterm .gtip{left:12px;right:12px;bottom:12px;width:auto;max-width:none;transform:none;border-radius:16px;padding:14px;font-size:13px}
  .sim-reward-bar{flex-wrap:wrap;gap:4px}
  .sim-reward{font-size:11px;padding:3px 8px}
  .bar{height:8px}
  .consequence{padding:12px;font-size:13px}
  .btn{padding:0 16px}
  .btn.bF{padding:0 20px}
  .t-input{height:40px;font-size:13px}
  .modal-textarea{font-size:13px}
}

/* ═══ TOUCH DEVICE HELPERS ═══ */
@media(hover:none){
  .btn:hover{transform:none;box-shadow:var(--sh)}
  .card:hover{transform:none}
  .sb-i:hover{background:transparent}
  .dec-opt:hover,.fc-opt:hover,.sim-opt:hover{transform:none;border-color:var(--border)}
  .btn:active{transform:scale(.97);opacity:.9}
  .card:active{transform:scale(.99)}
  .dec-opt:active,.fc-opt:active,.sim-opt:active{transform:scale(.98);border-color:var(--purple)}
}

/* ═══ SAFE AREAS (notched phones) ═══ */
@supports(padding:max(0px)){
  .mob-header{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}
  .pg{padding-bottom:max(16px,env(safe-area-inset-bottom))}
}

/* ═══ RESPONSIVE INLINE GRID OVERRIDES ═══ */
@media(max-width:480px){
  [style*="grid-template-columns:repeat(4"]{grid-template-columns:repeat(2,1fr)!important}
  [style*="grid-template-columns:repeat(5"]{grid-template-columns:repeat(2,1fr)!important}
  [style*="grid-template-columns:repeat(6"]{grid-template-columns:repeat(2,1fr)!important}
  [style*="grid-template-columns: repeat(4"]{grid-template-columns:repeat(2,1fr)!important}
  [style*="max-width:720px"],[style*="max-width:680px"],[style*="max-width:600px"],[style*="max-width:540px"],[style*="max-width:480px"],[style*="max-width:460px"],[style*="max-width:400px"]{max-width:100%!important}
  .sb.mob-open{width:85vw;max-width:300px}
}
@media(max-width:767px){
  [style*="grid-template-columns:repeat(6"]{grid-template-columns:repeat(3,1fr)!important}
  [style*="max-width:780px"],[style*="max-width:740px"],[style*="max-width:720px"]{max-width:100%!important}
}

/* ═══ QA RESPONSIVE FIXES ═══ */

/* Fix: Leaderboard 6-col overflow on mobile */
@media(max-width:600px){
  [style*="grid-template-columns:auto 1fr auto auto auto auto"]{
    grid-template-columns:auto 1fr auto auto!important;
    font-size:11px!important;
  }
  [style*="grid-template-columns:auto 1fr auto auto auto auto"] > div:nth-child(6n+5),
  [style*="grid-template-columns:auto 1fr auto auto auto auto"] > div:nth-child(6n+6){
    display:none!important;
  }
}

/* Fix: 2-col form grids stack on small phones */
@media(max-width:480px){
  [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
}

/* Fix: Topbar chips wrap on tablet */
.top-r{flex-wrap:wrap;gap:6px!important;justify-content:flex-end}
@media(max-width:1024px){
  .top-r .top-btn{font-size:11px;padding:0 10px;height:30px}
  .chip{font-size:11px;padding:4px 8px}
}

/* Fix: Sim reward bar wrap */
.sim-reward-bar{flex-wrap:wrap}

/* Fix: Hero CTA text overflow */
@media(max-width:480px){
  [style*="padding:18px 24px"]{padding:14px 16px!important}
  [style*="font-size:28px"]{font-size:22px!important}
  [style*="font-size:22px;font-weight:700"]{font-size:18px!important}
}

/* Fix: Wallet earnings chart overflow */
@media(max-width:480px){
  [style*="min-width:100px"]{min-width:80px!important}
  [style*="min-width:110px"]{min-width:80px!important}
}

/* Fix: Lesson step layout on mobile */
@media(max-width:480px){
  .step-label{gap:8px}
  .step-num{width:28px;height:28px;font-size:12px}
  .lesson-step{padding:0}
  .sim-story{padding:16px;font-size:13px;line-height:1.65}
}

/* Fix: Community partner cards */
@media(max-width:480px){
  [style*="width:40px;height:40px"]{width:36px!important;height:36px!important}
  [style*="width:42px;height:42px"]{width:36px!important;height:36px!important}
}

/* Fix: Subscription pricing cards */
@media(max-width:767px){
  .dg{gap:12px}
}
@media(max-width:480px){
  .dg{gap:8px}
}

/* Fix: Journey timeline on mobile */
@media(max-width:480px){
  [style*="padding-left:32px"]{padding-left:28px!important}
  [style*="position:absolute;left:18px"]{left:14px!important}
  [style*="left:-32px"]{left:-28px!important}
}

/* Fix: Finance dashboard tables on mobile */
@media(max-width:480px){
  [style*="grid-template-columns:1fr 1fr;gap:8px"]{grid-template-columns:1fr!important}
}

/* Fix: Book scroll cards */
@media(max-width:480px){
  [style*="overflow-x:auto"]{-webkit-overflow-scrolling:touch}
}

/* Fix: Age selector on mobile */
@media(max-width:767px){
  .sb.mob-open .sb-age{margin:0 12px}
}

/* Fix: Prevent body scroll when mobile nav open */
body.nav-open{overflow:hidden}

/* ═══ ENHANCED MOBILE UX ═══ */
@media(max-width:767px){
  /* TTS */
  .tts-bar{flex-wrap:wrap;padding:6px 10px;gap:6px}
  .tts-btn{padding:6px 14px;font-size:13px;min-height:36px}
  .tts-speed{width:50px}
  /* Lessons & Sims */
  .sim-hero{padding:16px}
  .sim-title{font-size:18px!important}
  .lesson-header{padding:16px}
  .lesson-header h2{font-size:18px!important}
  .lesson-body{padding:16px}
  .lesson-step{padding:12px}
  .step-label{margin-bottom:6px}
  .sim-next{font-size:14px;padding:12px 20px;width:100%}
  .sim-result{padding:14px;font-size:13px}
  .lp-dot{width:10px;height:10px}
  [style*="max-width:540px"]{max-width:100%!important}
  .sim-matched{padding:0!important}
  /* Journey Map */
  .jmap{padding:0!important}
  .jmap-row{gap:4px!important;flex-wrap:wrap;justify-content:center}
  .jmap-node{width:60px!important;height:60px!important;font-size:11px!important}
  .jmap-node .jmap-lbl{font-size:8px!important;max-width:56px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .jmap-conn{width:12px!important;min-width:12px!important}
  .jmap-world{font-size:13px!important;padding:8px 12px!important}
  /* Community */
  .tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap!important;gap:4px!important}
  .tabs::-webkit-scrollbar{display:none}
  .tb{padding:8px 12px!important;font-size:11px!important;flex-shrink:0;white-space:nowrap}
  /* Mobile header */
  .mob-header{gap:6px;padding:6px 10px;min-height:50px;width:100vw;max-width:100vw;box-sizing:border-box;overflow:hidden}
  .mob-header h1{font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}
  .mob-header > div:last-child{flex-shrink:1;min-width:0;overflow:hidden;max-width:55%}
  .mob-header > div:last-child > div{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;font-size:10px!important}
  .mob-header button{flex-shrink:0}
  /* Save Progress button in header — let it shrink */
  .mob-header [onclick*="fbShowAuth"]{font-size:10px!important;padding:4px 8px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  .mob-burger{width:34px;height:34px;font-size:18px;flex-shrink:0}
  /* Cards */
  .card{padding:12px!important;border-radius:12px}
  /* Sidebar when open on mobile */
  .sb{width:85vw!important;max-width:320px}
  /* Price grids etc */
  [style*="grid-template-columns:repeat(4"]{grid-template-columns:repeat(2,1fr)!important}
  [style*="grid-template-columns:repeat(3"]{grid-template-columns:1fr!important}
  /* General text */
  .sec-title h2{font-size:18px!important}
  .pt{font-size:13px}
  /* Auth/account button */
  [onclick*="fbShowAuth"]{padding:4px 10px!important;font-size:10px!important}
}
@media(max-width:480px){
  /* TTS smaller */
  .tts-bar{border-radius:14px;padding:5px 8px;gap:4px}
  .tts-btn{font-size:11px;padding:4px 8px;border-radius:10px;min-height:32px}
  .tts-speed{width:40px}
  /* Sims */
  .sim-opt{padding:10px;font-size:12px;gap:6px;border-radius:10px}
  .sim-opt-letter{width:24px;height:24px;font-size:10px;border-radius:6px}
  .sim-story{padding:12px;font-size:12px;line-height:1.55}
  .sim-hero{padding:12px;border-radius:12px!important}
  .sim-title{font-size:15px!important}
  /* Lessons */
  .lesson-step .step-text{font-size:12px;line-height:1.55}
  .step-num{width:24px!important;height:24px!important;font-size:12px!important}
  .step-tag{font-size:10px!important}
  .lesson-header{padding:12px!important}
  .lesson-body{padding:12px!important}
  /* Buttons */
  .btn{font-size:12px!important;min-height:40px;padding:0 14px!important;border-radius:10px}
  .btn.bSm{min-height:32px;font-size:11px!important;padding:0 10px!important}
  .btn.bF{padding:0 18px!important}
  /* Journey */
  .jmap-node{width:52px!important;height:52px!important}
  .jmap-node .jmap-lbl{font-size:7px!important;max-width:48px}
  .jmap-conn{width:8px!important;min-width:8px!important}
  /* Community tabs scroll */
  .tb{padding:6px 10px!important;font-size:10px!important}
  /* Forms */
  .t-input,input[type="text"],input[type="email"],input[type="password"]{font-size:14px!important;padding:10px 12px!important;border-radius:10px!important}
  textarea,.modal-textarea{font-size:13px!important}
  /* Auth modal */
  [style*="max-width:380px"]{max-width:100%!important;margin:8px!important;padding:20px!important;border-radius:16px!important}
  /* Partnership dashboard metrics */
  [style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:repeat(2,1fr)!important;gap:6px!important}
  /* Shared biz chat */
  #msg-scroll{height:160px!important}
  /* Page padding */
  .pg{padding:10px 8px!important}
  /* Mobile header */
  .mob-header{padding:4px 8px}
  .mob-header h1{font-size:13px}
  /* Coin display in header */
  .mob-header [style*="font-size:12px"]{font-size:10px!important}
  /* Account/save button */
  [onclick*="fbShowAuth"]{padding:3px 8px!important;font-size:9px!important;border-radius:14px!important}
}
/* Fix overflow globally */
html,body{overflow-x:hidden}
.u,.u2{overflow-x:hidden;word-wrap:break-word}
/* Smooth scroll for tabs */
.tabs{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}
/* Safe areas for notched phones */
@supports(padding:max(0px)){
  .mob-header{padding-left:max(10px,env(safe-area-inset-left));padding-right:max(10px,env(safe-area-inset-right))}
  .pg{padding-bottom:max(12px,env(safe-area-inset-bottom))}
  .sb{padding-bottom:max(16px,env(safe-area-inset-bottom))}
}

/* ═══════════════════════════════════════════════════════════════
   COMPREHENSIVE MOBILE OVERFLOW FIX
   Ensures nothing ever exceeds the viewport width on mobile.
   ═══════════════════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box}
html,body{max-width:100vw;overflow-x:hidden;position:relative}
html{width:100%}
body{width:100%;min-width:0}
#app{max-width:100vw;overflow-x:hidden}
@media(max-width:767px){
  /* Layout chain: every container must be fluid */
  .main,.pg{max-width:100vw;width:100%;min-width:0;overflow-x:hidden}
  /* Grid children must be allowed to shrink */
  .dg{grid-template-columns:1fr 1fr;gap:10px;width:100%}
  .dg > *{min-width:0;max-width:100%;overflow:hidden}
  /* Cards must never exceed their container */
  .card,.hero-p{max-width:100%;width:100%;min-width:0;overflow-wrap:break-word;word-break:break-word}
  /* Lesson box fully fluid on mobile */
  .lesson-box{max-width:100%!important;width:100%;min-width:0}
  .lesson-header,.lesson-body{max-width:100%;min-width:0;overflow-wrap:break-word;word-break:break-word}
  .step-text,.decision-title,.dec-opt{max-width:100%;min-width:0;overflow-wrap:break-word;word-break:break-word;white-space:normal}
  /* Buttons cannot force overflow */
  .btn,.dec-opt,.fc-opt,.sim-opt{max-width:100%;white-space:normal;word-wrap:break-word}
  .btn.bF{width:100%;max-width:100%}
  /* Topbar/mob-header chips cannot push layout wider */
  .top-r{max-width:100%;overflow-x:auto;scrollbar-width:none}
  .top-r::-webkit-scrollbar{display:none}
  /* Force any inline-styled wide max-width down to 100% of parent */
  [style*="max-width:740px"],[style*="max-width:720px"],[style*="max-width:680px"],
  [style*="max-width:600px"],[style*="max-width:560px"],[style*="max-width:540px"],
  [style*="max-width:480px"],[style*="max-width:460px"],[style*="max-width:440px"],
  [style*="max-width:420px"],[style*="max-width:400px"],[style*="max-width:380px"],
  [style*="max-width:360px"],[style*="max-width:340px"],[style*="max-width:320px"]{
    max-width:100%!important
  }
  /* Inline-styled flex rows with large gaps can blow out width */
  [style*="display:flex"][style*="gap"]{max-width:100%;flex-wrap:wrap}
  /* Images and media */
  img,video,iframe,svg{max-width:100%;height:auto}
  /* Tables */
  table{max-width:100%;display:block;overflow-x:auto}
  /* Force all text wrapping */
  p,h1,h2,h3,h4,h5,h6,span,div,a,li{overflow-wrap:break-word;word-wrap:break-word}
  /* Progress bar containers */
  .bar,.bar-f{max-width:100%}
  /* Specific fix for the stats grid on home (Coins/Level/Streak/Badges) */
  .dg [style*="grid-template-columns"]{grid-template-columns:1fr 1fr!important}
}
@media(max-width:480px){
  .dg{gap:8px}
  .card{padding:14px 12px}
  /* Further tighten page padding to buy back horizontal space */
  .pg{padding:12px 10px 40px}
  /* Home 4-stat grid: shrink number font on tiny screens so "278" + label fit */
  [style*="grid-template-columns:repeat(4,1fr)"] .card [style*="font-size:22px;font-weight:700"]{font-size:18px!important}
  [style*="grid-template-columns:repeat(4,1fr)"] .card [style*="font-size:22px;margin-bottom:4px"]{font-size:18px!important}
  [style*="grid-template-columns:repeat(4,1fr)"] .card{padding:12px 6px!important}
}

/* ─── PRACTICE PAGE — refined visual system ──────────────────────────── */
.prac-hero{position:relative;border-radius:18px;padding:22px 24px;margin-bottom:18px;overflow:hidden;color:#fff;background:linear-gradient(135deg,#5E4E7E 0%,#6B5A90 50%,#7B60B8 100%)}
.prac-hero::before{content:'';position:absolute;top:-40%;right:-20%;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.18) 0%,transparent 60%);pointer-events:none}
.prac-hero::after{content:'';position:absolute;bottom:-30%;left:-10%;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(184,138,40,.25) 0%,transparent 60%);pointer-events:none}
.prac-hero .h-eyebrow{font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;opacity:.78;margin-bottom:6px;position:relative;z-index:1}
.prac-hero .h-title{font-family:'Fraunces',var(--serif);font-size:26px;font-weight:700;line-height:1.15;margin-bottom:8px;letter-spacing:-0.01em;position:relative;z-index:1}
.prac-hero .h-sub{font-size:13px;line-height:1.55;opacity:.9;max-width:480px;position:relative;z-index:1}
.prac-tabs{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;padding:4px 2px 8px;margin-bottom:18px;-webkit-overflow-scrolling:touch}
.prac-tabs::-webkit-scrollbar{display:none}
.prac-tab{padding:9px 16px;border-radius:14px;border:1.5px solid var(--borderL);background:var(--bg-card);font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;color:var(--mute);transition:all .2s ease;display:inline-flex;align-items:center;gap:7px;flex-shrink:0}
.prac-tab:hover{border-color:var(--purple);color:var(--purple)}
.prac-tab.on{background:linear-gradient(135deg,var(--purple),#7B60B8);color:#fff;border-color:var(--purpleD);box-shadow:0 3px 10px rgba(107,90,144,.25)}
.prac-tab .ico{font-size:14px;line-height:1}

/* Calculator picker chips */
.calc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-bottom:16px}
.calc-chip{padding:14px 10px;border-radius:14px;border:1.5px solid var(--borderL);background:var(--bg-card);text-align:center;cursor:pointer;transition:all .2s ease;font-family:var(--sans)}
.calc-chip:hover{border-color:var(--purple);transform:translateY(-2px);box-shadow:0 6px 18px rgba(107,90,144,.12)}
.calc-chip.on{background:linear-gradient(135deg,var(--purplePale),var(--goldPale));border-color:var(--purple);box-shadow:0 4px 14px rgba(107,90,144,.18)}
.calc-chip .icon{font-size:24px;display:block;margin-bottom:6px;line-height:1}
.calc-chip .label{font-size:12px;font-weight:700;color:var(--ink);line-height:1.25}
.calc-chip.on .label{color:var(--purpleD)}

/* Calculator card panel */
.calc-card{background:linear-gradient(180deg,var(--bg-card) 0%,var(--bg-raised) 100%);border-radius:18px;padding:24px;border:1px solid var(--border);box-shadow:0 4px 18px rgba(30,25,40,.04)}
.calc-head{display:flex;align-items:center;gap:14px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--borderL)}
.calc-head .h-ico{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,var(--purple),#7B60B8);display:grid;place-items:center;font-size:22px;color:#fff;flex-shrink:0;box-shadow:0 4px 12px rgba(107,90,144,.25)}
.calc-head .h-text .h-t{font-family:'Fraunces',var(--serif);font-size:19px;font-weight:700;color:var(--ink);letter-spacing:-0.005em}
.calc-head .h-text .h-d{font-size:12px;color:var(--mute);margin-top:2px;line-height:1.5}

.calc-input-row{margin-bottom:14px}
.calc-input-row label{display:block;font-size:11px;font-weight:700;color:var(--mute);text-transform:uppercase;letter-spacing:1px;margin-bottom:7px}
.calc-input-row input{width:100%;padding:14px 16px;border-radius:12px;border:1.5px solid var(--border);background:var(--bg-card);font-family:'Fraunces',var(--serif);font-size:18px;font-weight:600;color:var(--ink);outline:none;box-sizing:border-box;transition:all .2s ease}
.calc-input-row input:focus{border-color:var(--purple);box-shadow:0 0 0 4px var(--purpleGlow);background:#fff}

.calc-result{margin-top:18px;padding:20px;border-radius:14px;background:linear-gradient(135deg,rgba(40,128,90,.06),rgba(40,128,90,.12));border:1px solid var(--green);position:relative;overflow:hidden}
.calc-result::before{content:'';position:absolute;top:-30px;right:-30px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(40,128,90,.08) 0%,transparent 70%)}
.calc-result .r-label{font-size:10px;font-weight:700;color:var(--greenDk);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:6px;position:relative}
.calc-result .r-big{font-family:'Fraunces',var(--serif);font-size:38px;font-weight:800;color:var(--greenDk);line-height:1;letter-spacing:-0.02em;position:relative}
.calc-result .r-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px;position:relative}
.calc-result .r-item .r-i-label{font-size:10px;font-weight:600;color:var(--mute);text-transform:uppercase;letter-spacing:1px}
.calc-result .r-item .r-i-val{font-family:'Fraunces',var(--serif);font-weight:700;font-size:18px;color:var(--ink);margin-top:2px}

/* Wisdom card refined */
.wis-card{position:relative;padding:36px 28px 28px;border-radius:20px;background:linear-gradient(135deg,#FEFAF0 0%,#FBF1E0 100%);border:1px solid rgba(184,138,40,.18);overflow:hidden;text-align:center;box-shadow:0 8px 32px rgba(184,138,40,.08)}
.wis-card::before{content:'';position:absolute;top:0;right:0;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(184,138,40,.12) 0%,transparent 65%);pointer-events:none}
.wis-card::after{content:'';position:absolute;bottom:0;left:0;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(107,90,144,.08) 0%,transparent 65%);pointer-events:none}
.wis-quote-mark{font-family:'Fraunces',var(--serif);font-size:80px;line-height:.7;color:var(--gold);opacity:.45;margin-bottom:-10px;position:relative}
.wis-quote{font-family:'Fraunces',var(--serif);font-size:21px;font-weight:500;font-style:italic;line-height:1.45;color:var(--ink);margin-bottom:18px;position:relative;letter-spacing:-0.005em}
.wis-author{display:inline-block;font-family:var(--sans);font-size:11px;font-weight:700;color:var(--gold);letter-spacing:2.5px;text-transform:uppercase;padding:6px 14px;border-radius:8px;background:rgba(184,138,40,.1);position:relative}
.wis-theme-pill{display:inline-block;margin-left:6px;padding:6px 12px;border-radius:8px;background:var(--purplePale);color:var(--purple);font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;position:relative}

/* Trap-spotter game */
.trap-stage{position:relative;border-radius:18px;padding:22px;background:linear-gradient(165deg,#FFF7E8 0%,#FCEBD2 100%);border:1px solid rgba(184,138,40,.2);overflow:hidden;margin-bottom:14px}
.trap-stage::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--coral),var(--gold),var(--green));}
.trap-stage .t-eyebrow{font-size:10px;font-weight:800;color:var(--coral);text-transform:uppercase;letter-spacing:2.5px;margin-bottom:6px;display:flex;align-items:center;gap:7px}
.trap-stage .t-eyebrow::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--coral);animation:trapPulse 1.6s ease-in-out infinite}
@keyframes trapPulse{0%,100%{opacity:.5;transform:scale(.85)}50%{opacity:1;transform:scale(1)}}
.trap-stage .t-title{font-family:'Fraunces',var(--serif);font-size:18px;font-weight:700;color:var(--ink);margin-bottom:14px;line-height:1.3}

/* Mock SMS / chat / ad container */
.trap-mock{background:#fff;border-radius:14px;padding:0;border:1px solid var(--borderL);box-shadow:0 4px 16px rgba(0,0,0,.06);overflow:hidden;margin-bottom:14px}
.trap-mock-bar{padding:9px 14px;background:#f0f0f3;font-size:11px;font-weight:600;color:#666;border-bottom:1px solid var(--borderL);display:flex;align-items:center;gap:8px}
.trap-mock-body{padding:16px;font-family:var(--sans)}
.trap-mock.style-sms .trap-mock-bar{background:linear-gradient(180deg,#f8f8fb,#eeeef2)}
.trap-mock.style-email .trap-mock-bar{background:#e8eaf0}
.trap-mock.style-dm .trap-mock-bar{background:linear-gradient(135deg,#405DE6 0%,#5851DB 50%,#833AB4 100%);color:#fff}
.trap-mock.style-ad{border:2px dashed var(--coral)}
.trap-mock.style-ad .trap-mock-bar{background:#fff5f5;color:var(--coral)}

.trap-options{display:grid;gap:8px}
.trap-opt{padding:14px 16px;border-radius:13px;border:1.5px solid var(--borderL);background:var(--bg-card);font-size:13px;font-weight:500;cursor:pointer;text-align:left;color:var(--ink);line-height:1.5;width:100%;transition:all .25s ease;display:flex;gap:10px;align-items:flex-start;font-family:var(--sans)}
.trap-opt:hover:not(:disabled){border-color:var(--coral);background:var(--coralPale);transform:translateX(4px)}
.trap-opt .num{flex-shrink:0;width:24px;height:24px;border-radius:7px;background:var(--bg-raised);color:var(--mute);font-weight:700;font-size:11px;display:grid;place-items:center;font-family:'Fraunces',var(--serif)}
.trap-opt:hover .num{background:var(--coral);color:#fff}
.trap-opt.correct{border-color:var(--green);background:var(--greenPale);color:var(--greenDk);animation:correct-pulse .5s ease}
.trap-opt.correct .num{background:var(--green);color:#fff}
.trap-opt.wrong{border-color:var(--coral);background:var(--coralPale);color:var(--coral);animation:wrong-shake .3s ease}
.trap-opt.wrong .num{background:var(--coral);color:#fff}
.trap-opt:disabled{cursor:default}
.trap-explain{margin-top:14px;padding:16px 18px;border-radius:13px;background:var(--bg-raised);border-left:4px solid var(--green);font-size:13px;line-height:1.65;color:var(--body)}
.trap-explain.bad{border-left-color:var(--coral);background:var(--coralPale)}
.trap-explain .e-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:6px;color:var(--green)}
.trap-explain.bad .e-label{color:var(--coral)}
.trap-streak{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:10px;background:var(--goldPale);color:var(--goldText);font-size:11px;font-weight:700;letter-spacing:.5px}

/* Flashcard refined */
.fc-shell{position:relative;background:linear-gradient(180deg,var(--bg-card) 0%,var(--bg-raised) 100%);border-radius:18px;padding:24px;border:1px solid var(--border);box-shadow:0 4px 18px rgba(30,25,40,.04)}
.fc-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--borderL)}
.fc-meta .m-cat{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:8px;background:var(--purplePale);color:var(--purple);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px}
.fc-meta .m-prog{font-size:11px;color:var(--mute);font-weight:600}
.fc-q{font-family:'Fraunces',var(--serif);font-size:19px;font-weight:600;line-height:1.4;color:var(--ink);margin-bottom:18px;letter-spacing:-0.005em}

@media(max-width:520px){
  .prac-hero{padding:18px;border-radius:14px}
  .prac-hero .h-title{font-size:22px}
  .calc-grid{grid-template-columns:repeat(2,1fr);gap:6px}
  .calc-chip{padding:11px 8px}
  .calc-chip .icon{font-size:20px}
  .calc-card{padding:18px}
  .calc-head .h-ico{width:38px;height:38px;font-size:18px}
  .calc-result .r-big{font-size:30px}
  .wis-card{padding:28px 20px 22px}
  .wis-quote{font-size:17px}
  .trap-stage{padding:16px}
}

/* ============================================================
   2. ADMIN DASHBOARD STYLES
   ============================================================ */
#sms-admin-fab{position:fixed;bottom:14px;left:14px;z-index:99998;width:38px;height:38px;border-radius:50%;background:#1a2332;color:#E5C375;border:1px solid rgba(229,195,117,.3);display:none;align-items:center;justify-content:center;cursor:pointer;font-size:20px;box-shadow:0 4px 14px rgba(0,0,0,.18);transition:transform .15s ease;-webkit-tap-highlight-color:transparent}
#sms-admin-fab.adm-show{display:flex}
#sms-admin-fab:hover{transform:scale(1.08)}
/* On mobile the bottom-nav (height ~70px, bottom:0) overlaps the FAB.
   Lift the FAB above it so it stays visually accessible. */
@media(max-width:720px){#sms-admin-fab{bottom:80px}}
#sms-admin-overlay{position:fixed;inset:0;z-index:99997;background:#FBF7F0;color:#1A2332;font-family:'Manrope','Inter',system-ui,-apple-system,sans-serif;overflow-y:auto;-webkit-overflow-scrolling:touch;display:none}
#sms-admin-overlay.adm-show{display:block}
.adm-shell{max-width:1320px;margin:0 auto;padding:24px 28px 80px}
.adm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;padding-bottom:18px;border-bottom:1px solid #DCD4C2;flex-wrap:wrap;gap:14px}
.adm-title{font-family:'Fraunces',Georgia,serif;font-size:28px;font-weight:600;letter-spacing:-0.02em;color:#1A2332}
.adm-title em{font-style:italic;color:#B8862A;font-weight:500}
.adm-actions{display:flex;gap:10px;flex-wrap:wrap}
.adm-btn{background:#1A2332;color:#FBF7F0;border:none;padding:9px 16px;border-radius:999px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:transform .15s,background .15s}
.adm-btn:hover{background:#2D3D5C;transform:translateY(-1px)}
.adm-btn-ghost{background:transparent;color:#3D4A5C;border:1px solid #DCD4C2;padding:9px 16px;border-radius:999px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}
.adm-btn-ghost:hover{background:#1A2332;color:#FBF7F0;border-color:#1A2332}
.adm-load{text-align:center;padding:80px 20px;font-family:'Fraunces',serif;font-style:italic;color:#6B7280;font-size:18px}
.adm-empty{text-align:center;padding:60px 20px;color:#6B7280;font-family:'Fraunces',serif;font-style:italic;font-size:16px;background:white;border-radius:6px;border:1px solid #DCD4C2}

/* Section headers */
.adm-sec-head{display:flex;justify-content:space-between;align-items:baseline;margin:0 0 14px;padding-top:6px}
.adm-sec-h{font-family:'Fraunces',serif;font-size:16px;font-weight:600;color:#1A2332;letter-spacing:-0.01em}
.adm-sec-meta{font-size:12px;color:#6B7280;font-style:italic;font-family:'Fraunces',serif}

/* KPIs */
.adm-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;margin-bottom:24px}
.adm-kpi{background:white;border:1px solid #DCD4C2;border-radius:6px;padding:16px 18px;position:relative;overflow:hidden}
.adm-kpi-label{font-size:10.5px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:#6B7280;margin-bottom:8px}
.adm-kpi-value{font-family:'Fraunces',serif;font-size:30px;font-weight:600;letter-spacing:-0.02em;line-height:1;color:#1A2332;margin-bottom:4px}
.adm-kpi-sub{font-size:11.5px;color:#6B7280;font-style:italic;font-family:'Fraunces',serif}
.adm-kpi-accent{position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(180deg,#B8862A,#D6593C)}
.adm-kpi-warn .adm-kpi-accent{background:linear-gradient(180deg,#D6593C,#A8412B)}
.adm-kpi-warn .adm-kpi-value{color:#A8412B}
.adm-kpi-rev .adm-kpi-accent{background:linear-gradient(180deg,#5A7A6B,#2E5A3D)}
.adm-kpi-rev .adm-kpi-value{color:#2E5A3D}

/* Highlight panels */
.adm-panels{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:24px}
@media(max-width:780px){.adm-panels{grid-template-columns:1fr}}
.adm-panel{background:white;border:1px solid #DCD4C2;border-radius:6px;padding:18px 20px}
.adm-panel-title{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-size:16px;font-weight:600;color:#1A2332;margin-bottom:14px;letter-spacing:-0.01em}
.adm-panel-tag{font-size:10px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;padding:2px 8px;border-radius:999px}
.adm-panel-tag-warn{background:rgba(214,89,60,.12);color:#A8412B}
.adm-panel-tag-good{background:rgba(46,139,87,.12);color:#2E5A3D}
.adm-panel-empty{font-size:13px;color:#6B7280;font-style:italic;font-family:'Fraunces',serif;padding:20px 0}
.adm-mini-row{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:8px 0;border-bottom:1px solid rgba(220,212,194,.5);font-size:13px;cursor:pointer;transition:background .12s}
.adm-mini-row:hover{background:#F4ECDC;margin:0 -8px;padding-left:8px;padding-right:8px}
.adm-mini-row:last-child{border-bottom:none}
.adm-mini-name{font-weight:600;color:#1A2332;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.adm-mini-name small{display:block;font-size:11px;color:#6B7280;font-weight:400;font-style:italic;margin-top:1px}
.adm-mini-meta{font-size:11.5px;color:#6B7280;white-space:nowrap}
.adm-mini-stat{font-weight:700;color:#B8862A;white-space:nowrap;font-variant-numeric:tabular-nums}

/* Sparkline / charts */
.adm-spark{background:white;border:1px solid #DCD4C2;border-radius:6px;padding:18px 20px;margin-bottom:24px}
.adm-spark-svg{width:100%;height:90px;display:block}
.adm-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px;margin-bottom:24px}
.adm-chart{background:white;border:1px solid #DCD4C2;border-radius:6px;padding:18px 20px}
.adm-chart-title{font-family:'Fraunces',serif;font-size:15px;font-weight:600;margin-bottom:14px;color:#1A2332;letter-spacing:-0.01em}
.adm-chart-empty{font-size:13px;color:#6B7280;font-style:italic}
.adm-bar-row{display:grid;grid-template-columns:130px 1fr 40px;gap:10px;align-items:center;margin-bottom:8px;font-size:13px}
.adm-bar-label{color:#3D4A5C;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}
.adm-bar-track{height:8px;background:#F4ECDC;border-radius:4px;overflow:hidden}
.adm-bar-fill{height:100%;background:linear-gradient(90deg,#B8862A,#D6593C);border-radius:4px;transition:width .4s ease}
.adm-bar-value{text-align:right;font-weight:700;color:#1A2332;font-variant-numeric:tabular-nums}

/* Lesson funnel */
.adm-funnel{background:white;border:1px solid #DCD4C2;border-radius:6px;padding:18px 20px;margin-bottom:24px}
.adm-funnel-row{display:grid;grid-template-columns:80px 1fr 90px 70px;gap:10px;align-items:center;padding:6px 0;font-size:12.5px;border-bottom:1px solid rgba(220,212,194,.4)}
.adm-funnel-row:last-child{border-bottom:none}
.adm-funnel-lesson{font-weight:600;color:#3D4A5C;font-variant-numeric:tabular-nums}
.adm-funnel-track{height:10px;background:#F4ECDC;border-radius:5px;overflow:hidden;position:relative}
.adm-funnel-fill{height:100%;background:linear-gradient(90deg,#5A7A6B,#B8862A);border-radius:5px;transition:width .4s ease}
.adm-funnel-count{font-weight:700;text-align:right;color:#1A2332;font-variant-numeric:tabular-nums}
.adm-funnel-drop{font-size:11px;text-align:right;color:#A8412B;font-variant-numeric:tabular-nums}
.adm-funnel-drop.ok{color:#6B7280}

/* Filters */
.adm-filters{display:flex;gap:10px;margin-bottom:14px;align-items:center;flex-wrap:wrap}
.adm-filters input,.adm-filters select{padding:9px 14px;border:1px solid #DCD4C2;border-radius:999px;font-family:inherit;font-size:13px;background:white;color:#1A2332;outline:none;transition:border-color .15s}
.adm-filters input{flex:1;min-width:200px}
.adm-filters input:focus,.adm-filters select:focus{border-color:#B8862A}
.adm-count{font-size:12px;color:#6B7280;font-style:italic;font-family:'Fraunces',serif;margin-left:auto}

/* Toast */
.adm-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#1A2332;color:#FBF7F0;padding:12px 20px;border-radius:999px;font-size:13px;font-weight:600;z-index:99999;box-shadow:0 8px 24px rgba(0,0,0,.25);animation:admToast .3s ease}
@keyframes admToast{from{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%,0)}}

/* Table */
.adm-tablewrap{background:white;border:1px solid #DCD4C2;border-radius:6px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.adm-table{width:100%;border-collapse:collapse;font-size:13px;min-width:1080px}
.adm-table thead{background:#F4ECDC;position:sticky;top:0;z-index:1}
.adm-table th{text-align:left;padding:12px 14px;font-size:11px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:#3D4A5C;border-bottom:1px solid #DCD4C2}
.adm-sortable{cursor:pointer;user-select:none;-webkit-user-select:none}
.adm-sortable:hover{color:#B8862A}
.adm-table td{padding:11px 14px;border-bottom:1px solid rgba(220,212,194,.5);color:#1A2332}
.adm-table tbody tr{cursor:pointer;transition:background .12s}
.adm-table tbody tr:hover{background:#F4ECDC}
.adm-table tbody tr.adm-row-warn{background:rgba(214,89,60,.04)}
.adm-table tbody tr.adm-row-warn:hover{background:rgba(214,89,60,.10)}
.adm-table tbody tr.adm-row-paid{background:rgba(46,139,87,.04)}
.adm-table tbody tr.adm-row-paid:hover{background:rgba(46,139,87,.10)}
.adm-cell-mute{color:#6B7280;font-size:12px}
.adm-tag{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:0.02em;background:#F4ECDC;color:#8B6320}
.adm-tag-gh{background:rgba(184,134,42,.15);color:#8B6320}
.adm-tag-ng{background:rgba(46,139,87,.15);color:#2E5A3D}
.adm-tag-w{background:rgba(60,90,140,.15);color:#3C5A8C}
.adm-tag-d{background:rgba(214,89,60,.15);color:#A8412B}
.adm-tag-tier{background:rgba(46,139,87,.12);color:#2E5A3D}
.adm-tag-tier-free{background:rgba(107,114,128,.12);color:#6B7280}
.adm-note-icon{display:inline-block;margin-left:6px;font-size:13px;opacity:.85;cursor:help}

/* Detail modal */
.adm-detail-bg{position:fixed;inset:0;background:rgba(26,35,50,.6);z-index:99999;display:flex;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.adm-detail{background:white;border-radius:8px;max-width:780px;width:100%;max-height:88vh;overflow-y:auto;box-shadow:0 24px 60px rgba(0,0,0,.3);position:relative}
.adm-detail-head{padding:24px 28px 18px;border-bottom:1px solid #DCD4C2;display:flex;justify-content:space-between;align-items:start;gap:16px;position:sticky;top:0;background:white;z-index:1}
.adm-detail-title{font-family:'Fraunces',serif;font-size:22px;font-weight:600;letter-spacing:-0.01em;line-height:1.2}
.adm-detail-sub{font-size:13px;color:#6B7280;margin-top:4px}
.adm-detail-close{background:none;border:none;cursor:pointer;font-size:24px;color:#6B7280;padding:0;line-height:1}
.adm-detail-body{padding:24px 28px}
.adm-section{margin-bottom:24px}
.adm-section-title{font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:#B8862A;margin-bottom:10px;display:flex;justify-content:space-between;align-items:baseline}
.adm-section-title-meta{font-size:11px;font-weight:500;color:#6B7280;font-style:italic;text-transform:none;letter-spacing:0;font-family:Fraunces,serif}
.adm-row{display:grid;grid-template-columns:140px 1fr;gap:10px;padding:8px 0;border-bottom:1px solid rgba(220,212,194,.5);font-size:13.5px}
.adm-row:last-child{border-bottom:none}
.adm-row-key{color:#6B7280;font-weight:500}
.adm-row-val{color:#1A2332;word-break:break-word}
.adm-time-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px}
.adm-time-cell{background:#F4ECDC;border-radius:4px;padding:10px 12px;text-align:center}
.adm-time-cell-label{font-size:10px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:#6B7280;margin-bottom:4px}
.adm-time-cell-val{font-family:'Fraunces',serif;font-size:20px;font-weight:600;color:#1A2332}
.adm-raw{background:#1A2332;color:#D5DBE3;border-radius:4px;padding:14px 16px;font-family:'SF Mono',Monaco,Consolas,monospace;font-size:11.5px;line-height:1.5;max-height:280px;overflow:auto}
.adm-note-textarea{width:100%;min-height:90px;padding:12px 14px;border:1px solid #DCD4C2;border-radius:6px;font-family:inherit;font-size:14px;line-height:1.55;color:#1A2332;background:#FBF7F0;outline:none;resize:vertical;transition:border-color .15s,background .15s;box-sizing:border-box}
.adm-note-textarea:focus{border-color:#B8862A;background:white}

@media(max-width:640px){
  .adm-shell{padding:16px 14px 60px}
  .adm-title{font-size:22px}
  .adm-kpi-value{font-size:26px}
  .adm-detail-head,.adm-detail-body{padding-left:18px;padding-right:18px}
  .adm-row{grid-template-columns:1fr;gap:2px}
  .adm-funnel-row{grid-template-columns:60px 1fr 70px 60px;font-size:11.5px}
}

/* ============================================================
   3. LANGUAGE SWITCHER STYLES
   ============================================================ */
/* Compact, discreet floating button. Idle = slightly faded so it doesn't
   compete with content; full opacity on hover or when menu is open. */
#sms-lang-wrap{position:fixed;bottom:14px;right:14px;z-index:99999;font-family:'Manrope','Inter',system-ui,sans-serif}
#sms-lang-btn{
  display:flex;align-items:center;gap:5px;
  background:linear-gradient(135deg,#6B5A90 0%,#5E4E7E 100%);
  color:#fff;border:none;border-radius:999px;
  padding:6px 11px;font-size:11.5px;font-weight:700;letter-spacing:0.02em;
  cursor:pointer;
  box-shadow:0 2px 8px rgba(94,78,126,0.22),0 1px 3px rgba(0,0,0,0.06);
  transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease;
  font-family:inherit;
  opacity:0.85;
}
#sms-lang-btn:hover,#sms-lang-wrap.open #sms-lang-btn{
  opacity:1;transform:translateY(-1px);
  box-shadow:0 4px 14px rgba(94,78,126,0.32),0 1px 3px rgba(0,0,0,0.08)
}
#sms-lang-btn:active{transform:translateY(0)}
#sms-lang-btn .globe{font-size:12px;line-height:1}
#sms-lang-btn .code{font-size:11px;font-weight:800;letter-spacing:0.06em}
#sms-lang-btn .chev{font-size:8px;opacity:.7;transition:transform .2s}
#sms-lang-wrap.open #sms-lang-btn .chev{transform:rotate(180deg)}
#sms-lang-menu{
  position:absolute;bottom:calc(100% + 8px);right:0;
  background:#fff;border-radius:14px;
  box-shadow:0 10px 32px rgba(30,25,40,0.18),0 2px 6px rgba(0,0,0,0.05);
  padding:6px;min-width:170px;
  display:none;flex-direction:column;
  border:1px solid rgba(30,25,40,0.06);
  animation:smsLangFade .18s ease;
}
#sms-lang-wrap.open #sms-lang-menu{display:flex}
@keyframes smsLangFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.sms-lang-opt{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:9px;
  font-size:13px;font-weight:600;color:#1a2332;
  cursor:pointer;border:none;background:transparent;width:100%;text-align:left;
  font-family:inherit;
  transition:background .15s;
}
.sms-lang-opt:hover{background:rgba(94,78,126,0.08)}
.sms-lang-opt.active{background:rgba(94,78,126,0.12);color:#5E4E7E}
.sms-lang-opt .flag{font-size:18px;line-height:1}
.sms-lang-opt .check{margin-left:auto;font-size:14px;color:#5E4E7E;font-weight:800}

/* Mobile: lift well above the bottom nav (~70px tall + safe-area).
   Stays bottom-right but with extra clearance so it never sits on top of content cards. */
@media(max-width:720px){
  #sms-lang-wrap{
    bottom:calc(78px + env(safe-area-inset-bottom));
    right:12px;
  }
  #sms-lang-btn{padding:6px 10px;font-size:11px}
}
/* Hide on lesson reader screens (where the mobile bottom nav is also hidden) so it can't overlap reading content */
body.reader-active #sms-lang-wrap{display:none}

/* ===== Google Translate banner suppression =====
   Google Translate forcibly sets body{top:40px !important} inline via JS to make
   room for its banner. CSS alone cannot beat inline !important, so the JS
   watchdog in lang-switcher.js handles the runtime override. The CSS below is
   the first line of defence (covers the static cases) and must stay. */
.goog-te-banner-frame,
.goog-te-banner-frame.skiptranslate,
iframe.goog-te-banner-frame,
.skiptranslate > iframe,
.goog-te-ftab,
.goog-tooltip,
.goog-tooltip:hover,
.goog-text-highlight{
  display:none !important;
  visibility:hidden !important;
  height:0 !important;
  pointer-events:none !important;
}
html{margin-top:0 !important}
body{top:0 !important;position:static !important}
/* Off-screen instead of display:none so Google Translate's iframe can still init */
#google_translate_element{position:absolute !important;left:-9999px !important;top:-9999px !important;width:1px !important;height:1px !important;overflow:hidden !important;visibility:hidden !important}

/* ═══ TRACKER (My Real Money) — mobile responsive overrides ═══
   The tracker page uses a lot of inline styles for grids and padding that
   pinch hard on phone widths. These rules tighten things up at narrow
   viewports without touching the desktop layout. */
@media(max-width:480px){
  .tracker-root{padding:0 2px}
  /* Cards run edge-to-edge with comfortable padding */
  .tracker-root .card{padding:14px;border-radius:14px;margin-bottom:10px}
  /* Section headers shrink from 22px → 18px so they don't wrap awkwardly */
  .tracker-root h2{font-size:18px !important;line-height:1.3}
  .tracker-root .pt{font-size:14px}
  /* The "How I Use My Money" 4-column breakdown squashes on phones — go 2x2 */
  .tracker-root [style*="repeat(4,1fr)"]{
    grid-template-columns:repeat(2,1fr) !important;
    gap:8px !important;
  }
  .tracker-root [style*="repeat(3,1fr)"]{gap:6px !important}
  /* Form rows keep 2-column but tighten gap so inputs aren't truncated */
  .tracker-root [style*="grid-template-columns:1fr 1fr"]{gap:6px !important}
  /* The amount/value displays — drop them a notch so big balances fit */
  .tracker-root [style*="font-size:22px"]{font-size:20px !important}
  /* Tabs: ensure scrollable and don't crowd the viewport */
  .tracker-root .tabs{margin-left:-2px;margin-right:-2px;padding:0 2px 4px}
  .tracker-root .tb{padding:7px 12px;font-size:12.5px}
  /* Buttons in quick-action and form rows */
  .tracker-root .btn{font-size:13px}
  /* Currency selector row should stack label above select on tightest screens */
  .tracker-root select.t-select{max-width:100%}
  /* Long balances/labels must wrap, never push the card wider than the screen */
  .tracker-root *{min-width:0}
  /* Intro paragraph leading */
  .tracker-root p{font-size:12.5px;line-height:1.55}
}
/* Slightly tighter still on very narrow phones */
@media(max-width:360px){
  .tracker-root .card{padding:12px}
  .tracker-root [style*="repeat(2,1fr)"]{gap:6px !important}
  .tracker-root [style*="font-size:14px"]{font-size:13px !important}
  .tracker-root [style*="font-size:16px"]{font-size:14px !important}
}
