:root{--brand-50: #eef6ff;--brand-100: #d8eaff;--brand-300: #7ab6ff;--brand-500: #2e7dff;--brand-600: #1f66e0;--brand-700: #174fb3;--ink-900: #0f1420;--ink-700: #2a3142;--ink-500: #5b6477;--ink-300: #a0a8ba;--ink-200: #c7cedd;--ink-100: #e7ebf3;--ink-50: #f5f7fb;--paper: #ffffff;--success: #1fa35a;--warning: #d68200;--danger: #d14343;--sunshine: #ffcb3d;--sunshine-300: #ffdd7a;--sunshine-100: #fff3cc;--mint: #35d29d;--mint-300: #7ee3bd;--mint-100: #d6f6ea;--grape: #a377ff;--grape-300: #c4a7ff;--grape-100: #ece1ff;--coral: #ff7a7a;--coral-100: #ffe0e0;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, "Helvetica Neue", Arial, sans-serif;--font-display: "Fredoka", "Nunito", "Inter", sans-serif;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 22px;--radius-pill: 9999px;--shadow-tile: 0 4px 0 0 rgba(15, 20, 32, .08), 0 6px 14px rgba(15, 20, 32, .08);--shadow-tile-hover: 0 6px 0 0 rgba(15, 20, 32, .1), 0 10px 20px rgba(15, 20, 32, .1);--shadow-tile-active: 0 1px 0 0 rgba(15, 20, 32, .08), 0 2px 6px rgba(15, 20, 32, .06);--shadow-float: 0 18px 40px rgba(15, 20, 32, .12)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:var(--font-sans);color:var(--ink-900);background:var(--ink-50);-webkit-font-smoothing:antialiased}button{font:inherit;cursor:pointer;border:0;border-radius:var(--radius-md);padding:10px 16px;background:var(--brand-500);color:#fff;font-weight:600;transition:background .12s ease,transform 80ms ease}button:hover{background:var(--brand-600)}button:active{transform:translateY(1px)}button:disabled{background:var(--ink-300);cursor:not-allowed}button.ghost{background:transparent;color:var(--ink-700)}button.ghost:hover{background:var(--ink-100)}button.ghost.danger{color:var(--danger)}button.pill{border-radius:var(--radius-pill);padding:8px 14px}a{color:var(--brand-600);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3{margin:0;font-weight:700;letter-spacing:-.25px}input[type=text],input[type=email]{font:inherit;border:1px solid var(--ink-200);border-radius:var(--radius-md);padding:10px 12px;background:var(--paper);color:var(--ink-900);width:100%}input[type=text]:focus,input[type=email]:focus{outline:none;border-color:var(--brand-500);box-shadow:0 0 0 3px var(--brand-100)}label{display:block;font-size:14px;color:var(--ink-700);margin-bottom:6px;font-weight:500}.page{min-height:100%;padding:24px;max-width:960px;margin:0 auto}.card{background:var(--paper);border:1px solid var(--ink-100);border-radius:var(--radius-lg);padding:20px;box-shadow:0 1px 2px #0f14200a}.stack{display:flex;flex-direction:column;gap:16px}.stack-sm{display:flex;flex-direction:column;gap:8px}.row{display:flex;align-items:center;gap:12px}.spacer{flex:1}.muted{color:var(--ink-500);font-size:14px}.danger{color:var(--danger)}.success{color:var(--success)}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f14207a;display:grid;place-items:center;padding:24px;z-index:50}.dialog{background:var(--paper);border-radius:var(--radius-xl);padding:24px;max-width:480px;width:100%;box-shadow:0 20px 40px #0f142040}:root{--g-bg: oklch(.22 .06 285);--g-bg2: oklch(.32 .1 285);--g-surface: oklch(.3 .06 285);--g-ink: #ffffff;--g-ink-soft: oklch(.78 .04 285);--g-accent: oklch(.82 .18 95);--g-accent-ink: oklch(.3 .1 95);--g-good: oklch(.8 .2 150);--g-warn: oklch(.72 .2 28);--g-star: oklch(.85 .18 85);--g-mascot-a: oklch(.75 .18 320);--g-mascot-b: oklch(.75 .18 200);--g-shadow-dark: 0 12px 0 oklch(.14 .05 285), 0 20px 40px -10px oklch(.1 .05 285 / .7);--g-radius: 24px}.play-page{min-height:100%;padding:24px 20px 40px;display:flex;flex-direction:column;align-items:center;gap:14px;font-family:var(--font-sans);color:var(--g-ink);position:relative;overflow:hidden;background:radial-gradient(120% 80% at 50% 0%,var(--g-bg2),var(--g-bg) 65%)}.play-stars{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.play-stars span{position:absolute;width:2px;height:2px;border-radius:50%;background:#fff;animation:star-twinkle 3s ease-in-out infinite}.play-page>*:not(.play-stars){position:relative;z-index:1}.g-chrome{width:100%;display:flex;align-items:center;gap:8px;padding-top:4px}.g-streak{display:inline-flex;align-items:center;gap:4px;background:#0000004d;padding:5px 10px;border-radius:var(--radius-pill);font-family:var(--font-display);font-weight:700;font-size:13px;border:1px solid rgba(255,255,255,.1)}.g-xp{flex:1;display:flex;align-items:center;gap:10px}.g-xp-level{width:34px;height:34px;border-radius:50%;background:var(--g-accent);color:var(--g-accent-ink);display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:16px;box-shadow:0 3px 0 var(--g-accent-ink);flex-shrink:0}.g-xp-bar{flex:1;height:14px;background:#00000059;border-radius:var(--radius-pill);overflow:hidden;border:2px solid rgba(255,255,255,.15)}.g-xp-fill{height:100%;background:linear-gradient(90deg,var(--g-accent),oklch(.85 .18 60));border-radius:var(--radius-pill);box-shadow:inset 0 -3px #382d0066;box-shadow:inset 0 -3px oklch(.3 .1 95 / .4);transition:width .5s ease}.g-hearts{display:flex;gap:2px}.g-heart svg{display:block}.chapter{display:flex;flex-direction:column;align-items:center;gap:2px;margin-top:4px}.chapter-eyebrow{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--g-ink-soft)}.chapter-title{font-family:var(--font-display);font-size:28px;font-weight:700;letter-spacing:1px;color:var(--g-accent);text-shadow:0 3px 0 var(--g-accent-ink);line-height:1;text-transform:uppercase}.mascot-wrap{position:relative;display:inline-block}.speak-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;font-family:var(--font-display);font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--g-accent-ink);background:var(--g-accent);border:0;border-radius:var(--radius-pill);box-shadow:0 4px 0 var(--g-accent-ink);transition:transform 80ms ease,box-shadow 80ms ease}.speak-btn:hover{background:var(--g-accent);transform:translateY(-1px);box-shadow:0 5px 0 var(--g-accent-ink)}.speak-btn:active{transform:translateY(3px);box-shadow:0 1px 0 var(--g-accent-ink)}.speak-row{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.speak-btn:disabled{opacity:.85;cursor:default;transform:none}.speak-btn:disabled:hover{transform:none;box-shadow:0 4px 0 var(--g-accent-ink)}.speak-spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--g-accent-ink);border-right-color:transparent;border-radius:50%;animation:speak-spin .75s linear infinite}@keyframes speak-spin{to{transform:rotate(360deg)}}.coach-panel{width:min(560px,90vw);padding:14px 18px;margin:8px auto 0;border-radius:var(--radius-md);background:color-mix(in srgb,var(--g-accent-ink) 6%,transparent);color:var(--g-ink-soft);display:grid;gap:6px;text-align:left}.coach-sentence{margin:0;font-size:14px;line-height:1.4}.coach-loading{display:flex;align-items:center;gap:8px;margin:0;font-size:14px;font-style:italic}.coach-audio-loading{display:flex;align-items:center;gap:8px;margin:4px 0 0;font-size:13px;font-style:italic;color:var(--g-ink-soft);opacity:.85}.coach-error{margin:0;font-size:13px;color:var(--danger)}.speak-prompt{font-family:var(--font-display);font-size:11px;letter-spacing:1.5px;color:var(--g-ink-soft);text-transform:uppercase;margin:0}.slot-row{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}.slot{width:62px;height:62px;padding:0;border-radius:18px;background:#ffffff0d;border:3px dashed rgba(255,255,255,.2);color:var(--g-ink);display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:30px;transition:transform .18s ease,background .18s ease,border-color .18s ease;cursor:pointer}.slot--filled{background:#fff;color:#1a1020;border:3px solid rgba(255,255,255,.9);animation:tile-pop .22s cubic-bezier(.34,1.56,.64,1)}.slot--active{border:3px dashed var(--g-accent)}.tile-row{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;max-width:300px}.tile{width:56px;height:56px;padding:0;border-radius:16px;background:#fff;color:#1a1020;font-family:var(--font-display);font-weight:700;font-size:28px;border:0;box-shadow:0 5px #6f717d;transition:transform 80ms ease,box-shadow 80ms ease;cursor:pointer}.tile:hover{background:#fff;transform:translateY(-1px)}.tile:active{transform:translateY(4px);box-shadow:0 1px #6f717d}.tile--used,.tile:disabled{background:transparent;color:transparent;border:2px dashed rgba(255,255,255,.15);box-shadow:none;cursor:default;transform:none}.check-btn{margin-top:auto;width:100%;padding:14px 22px;font-family:var(--font-display);font-size:17px;font-weight:700;letter-spacing:.5px;color:var(--g-accent-ink);background:var(--g-accent);border:0;border-radius:var(--radius-pill);box-shadow:0 4px 0 var(--g-accent-ink);transition:transform 80ms ease,box-shadow 80ms ease}.check-btn:hover{background:var(--g-accent);transform:translateY(-1px);box-shadow:0 5px 0 var(--g-accent-ink)}.check-btn:active{transform:translateY(3px);box-shadow:0 1px 0 var(--g-accent-ink)}.check-btn:disabled{background:#ffffff1f;color:#ffffff59;box-shadow:none;cursor:not-allowed;transform:none}.play-card{width:100%;max-width:340px;margin:auto 0;padding:28px 22px;background:var(--g-surface);border-radius:var(--g-radius);border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px #ffffff14,0 12px #00000059;display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;animation:bounce-in .42s cubic-bezier(.34,1.56,.64,1)}.play-title{font-family:var(--font-display);font-size:32px;font-weight:700;letter-spacing:.5px;color:var(--g-ink);line-height:1.05;margin:0}.play-body{margin:0;font-size:15px;color:var(--g-ink-soft)}.play-body strong{color:#fff;font-weight:800;letter-spacing:.5px}.start-btn,.next-btn{width:100%;padding:14px 22px;font-family:var(--font-display);font-size:17px;font-weight:700;letter-spacing:.5px;color:var(--g-accent-ink);background:var(--g-accent);border:0;border-radius:var(--radius-pill);box-shadow:0 4px 0 var(--g-accent-ink);transition:transform 80ms ease,box-shadow 80ms ease;display:inline-flex;align-items:center;justify-content:center;gap:8px}.start-btn:hover,.next-btn:hover{background:var(--g-accent);transform:translateY(-1px);box-shadow:0 5px 0 var(--g-accent-ink)}.start-btn:active,.next-btn:active{transform:translateY(3px);box-shadow:0 1px 0 var(--g-accent-ink)}.celebrate{flex:1;min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:32px 24px;position:relative}.celebrate-burst{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 45%,oklch(.82 .18 95 / .25),transparent 50%);pointer-events:none}.celebrate-mascot{position:relative}.celebrate-rays span{position:absolute;left:50%;top:50%;width:3px;height:60px;background:#e6c10080;background:oklch(.82 .18 95 / .5);border-radius:4px;transform-origin:center}.celebrate-title{font-family:var(--font-display);font-weight:700;font-size:44px;line-height:1;color:var(--g-accent);text-shadow:0 4px 0 var(--g-accent-ink),0 8px 20px oklch(.3 .1 95 / .5);transform:rotate(-3deg);margin:0}.celebrate-xp{display:inline-flex;align-items:center;gap:10px;background:#0000004d;padding:10px 20px;border-radius:var(--radius-pill);border:2px solid var(--g-accent);font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--g-accent)}.celebrate-stars{display:flex;gap:6px;align-items:flex-end;color:var(--g-star)}.celebrate--miss .celebrate-title{color:var(--g-warn);text-shadow:0 4px 0 oklch(.35 .12 28),0 8px 20px oklch(.25 .1 28 / .5)}.celebrate--miss .celebrate-xp{border-color:var(--g-warn);color:var(--g-warn)}.confetti{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:10}.confetti span{position:absolute;top:-20px;width:10px;height:10px;border-radius:2px;animation:confetti-fall 1.6s ease-in forwards}@keyframes star-twinkle{0%,to{opacity:.2}50%{opacity:.9}}@keyframes tile-pop{0%{transform:scale(.6)}60%{transform:scale(1.12)}to{transform:scale(1)}}@keyframes bounce-in{0%{opacity:0;transform:scale(.85) translateY(10px)}60%{opacity:1;transform:scale(1.04) translateY(0)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes confetti-fall{0%{transform:translateY(-20px) rotate(0);opacity:1}to{transform:translateY(120vh) rotate(720deg);opacity:.2}}@keyframes mascot-idle{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-4px) rotate(-1deg)}}@keyframes mascot-bob{0%,to{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-8px) rotate(3deg)}}@keyframes mascot-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}@keyframes mascot-cheer{0%,to{transform:translateY(0) rotate(-6deg)}25%{transform:translateY(-14px) rotate(4deg)}75%{transform:translateY(-6px) rotate(-2deg)}}@keyframes mascot-blink{0%,92%,to{transform:scaleY(1)}95%{transform:scaleY(.1)}}@keyframes mascot-ear{0%,to{transform:rotate(-8deg)}50%{transform:rotate(4deg)}}@media(prefers-reduced-motion:reduce){.play-stars span,.slot--filled,.play-card,.confetti span,.mascot-body,.mascot-ear,.mascot-eye{animation:none!important}}
