:root{--purple:#7c5cfc;--purple-dark:#5b3fd6;--pink:#ff6fb5;--yellow:#ffc83d;--green:#36d399;--green-dark:#1f9e72;--blue:#38bdf8;--coral:#ff8a5b;--ink:#2b2350;--ink-soft:#6b6390;--card:#ffffff;--bg-1:#fff0f6;--bg-2:#eef0ff;--shadow:0 10px 30px rgba(91,63,214,0.15);--shadow-sm:0 6px 16px rgba(91,63,214,0.12)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body,html{margin:0;padding:0;min-height:100%}body{font-family:Fredoka,system-ui,-apple-system,sans-serif;color:var(--ink);background:linear-gradient(160deg,var(--bg-1) 0,var(--bg-2) 100%);background-attachment:fixed}button{font-family:inherit;cursor:pointer;border:none}.app{max-width:460px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;padding:16px 16px 90px;position:relative}.topbar{justify-content:space-between;margin-bottom:18px}.brand,.topbar{display:flex;align-items:center}.brand{gap:10px}.mascot{width:44px;height:44px;border-radius:50%;background:var(--purple);display:grid;place-items:center;position:relative;box-shadow:var(--shadow-sm)}.mascot:after,.mascot:before{content:"";position:absolute;top:16px;width:7px;height:7px;border-radius:50%;background:#fff}.mascot:before{left:12px}.mascot:after{right:12px}.mascot .smile{position:absolute;bottom:11px;width:16px;height:8px;border-bottom:3px solid #fff;border-radius:0 0 16px 16px}.brand{text-decoration:none}.brand h1{font-size:24px;margin:0;font-weight:700}.brand-tale{color:var(--purple-dark)}.brand-bud{color:var(--pink)}.stars{display:inline-flex;align-items:center;gap:5px;background:var(--yellow);color:#7a5200;font-weight:600;padding:7px 14px;border-radius:999px;font-size:16px;box-shadow:var(--shadow-sm)}.bubble{background:#efeaff;color:var(--purple-dark);border-radius:20px;padding:14px 18px;font-size:18px;font-weight:500;line-height:1.4}.bubble,.hero{margin-bottom:18px}.hero{background:#eaf4ff;border-radius:28px;padding:26px 16px;display:flex;flex-direction:column;align-items:center;gap:12px}.mic-btn{width:116px;height:116px;border-radius:50%;background:var(--purple);color:#fff;display:grid;place-items:center;box-shadow:0 12px 26px rgba(124,92,252,.45);transition:transform .12s ease}.mic-btn:active{transform:scale(.94)}.mic-btn svg{width:52px;height:52px}.mic-btn.listening{background:var(--pink);animation:pulse 1.1s infinite}@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,111,181,.55)}70%{box-shadow:0 0 0 22px rgba(255,111,181,0)}to{box-shadow:0 0 0 0 rgba(255,111,181,0)}}.hero .label{font-size:20px;font-weight:600;color:var(--purple-dark)}.hero .hint,.muted-center{font-size:15px;color:var(--ink-soft)}.muted-center{text-align:center;margin:6px 0 12px}.inputs-row{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:10px;gap:10px;margin-bottom:14px}.input-card{background:var(--card);border-radius:18px;padding:14px 6px;display:flex;flex-direction:column;align-items:center;gap:8px;box-shadow:var(--shadow-sm);transition:transform .12s ease}.input-card:active{transform:scale(.96)}.input-card svg{width:28px;height:28px}.input-card span{font-size:14px;font-weight:500}.ic-green{color:var(--green-dark)}.ic-yellow{color:#c98800}.ic-purple{color:var(--purple)}.input-card .soon{font-size:11px;color:var(--ink-soft);background:#f0eefc;padding:1px 8px;border-radius:999px}.text-row{display:flex;gap:8px;margin-bottom:8px}.text-row input{flex:1 1;font-family:inherit;font-size:17px;padding:14px 16px;border-radius:16px;border:2px solid #e6e2fb;outline:none;color:var(--ink)}.text-row input:focus{border-color:var(--purple)}.big-btn{width:100%;font-size:19px;font-weight:600;color:#fff;background:var(--green);padding:16px;border-radius:18px;box-shadow:0 8px 0 var(--green-dark);transition:transform .08s ease,box-shadow .08s ease}.big-btn:active{transform:translateY(4px);box-shadow:0 4px 0 var(--green-dark)}.big-btn:disabled{opacity:.6;box-shadow:0 8px 0 var(--green-dark)}.big-btn.purple{background:var(--purple);box-shadow:0 8px 0 var(--purple-dark)}.big-btn.purple:active{box-shadow:0 4px 0 var(--purple-dark)}.icon-btn{background:#efeaff;color:var(--purple-dark);width:52px;border-radius:16px;display:grid;place-items:center}.icon-btn svg{width:26px;height:26px}.story-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.story-head h2{font-size:22px;margin:0;color:var(--purple-dark)}.page-count{color:var(--ink-soft);font-size:15px}.story-back{align-self:flex-start;background:#fff;color:var(--purple);font-weight:600;font-size:14px;padding:7px 16px;border-radius:999px;box-shadow:var(--shadow-sm);margin-bottom:10px}.story-back:active{transform:translateY(2px)}.top-nav{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.nav-btn{background:var(--green);color:#fff;font-weight:600;font-size:15px;padding:8px 16px;border-radius:999px;box-shadow:0 4px 0 var(--green-dark)}.nav-btn.purple{background:var(--purple);box-shadow:0 4px 0 var(--purple-dark)}.nav-btn:disabled{opacity:.4}.nav-btn:active{transform:translateY(2px)}.nav-spacer{width:92px}.illustration{width:100%;aspect-ratio:4/3;border-radius:22px;background:#e7f0ff;display:grid;place-items:center;overflow:hidden;margin-bottom:16px;box-shadow:var(--shadow-sm)}.illustration img{width:100%;height:100%;object-fit:cover}.illustration .ph{color:var(--blue)}.illustration .ph svg{width:64px;height:64px}.story-text{font-size:26px;line-height:1.7;font-weight:500;margin-bottom:18px;min-height:90px}.story-text .w{padding:1px 4px;border-radius:8px;transition:background .15s ease,color .15s ease;cursor:pointer}.tap-hint{text-align:center;font-size:14px;color:var(--ink-soft);margin-bottom:12px;min-height:20px}.word-trans{display:inline-flex;align-items:center;gap:4px;background:#efeaff;color:var(--purple-dark);font-weight:600;padding:4px 12px;border-radius:999px}.word-trans-to{color:var(--green-dark)}.practice-panel{background:#fff6e0;border-radius:16px;padding:14px;margin-top:12px}.practice-title{font-size:14px;font-weight:600;color:#946800;margin-bottom:10px;text-align:center}.practice-words{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.practice-word{background:#fff;color:var(--coral);font-weight:600;font-size:16px;padding:8px 14px;border-radius:999px;box-shadow:var(--shadow-sm)}.story-text .w.active{background:var(--purple);color:#fff}.story-text .w.done{color:var(--green-dark)}.story-text .w.miss{color:var(--coral);-webkit-text-decoration:underline wavy var(--coral);text-decoration:underline wavy var(--coral)}.story-text .w.hint{background:var(--yellow);color:#7a5200;animation:hintpulse .8s infinite}.story-text .w.tappable{cursor:pointer;background:var(--bg-accent,#eaf4ff);outline:2px dashed var(--blue)}@keyframes hintpulse{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}.retry-inline{background:#fff;color:var(--purple-dark);font-size:14px;padding:6px 12px;border-radius:999px}.retry-inline,.streak-pill{margin-left:auto;font-weight:600}.streak-pill{font-size:15px;color:var(--coral)}.chart{gap:6px;height:110px;background:var(--card);border-radius:14px;padding:12px;box-shadow:var(--shadow-sm)}.chart,.chart-bar{display:flex;align-items:flex-end}.chart-bar{flex:1 1;height:100%}.chart-fill{width:100%;background:var(--green);border-radius:6px 6px 0 0;min-height:4px}.listen-bar{display:flex;align-items:center;gap:10px;background:#e7faf1;color:var(--green-dark);border-radius:16px;padding:12px 14px;font-weight:600;font-size:16px;margin-bottom:14px}.listen-bar svg{width:22px;height:22px}.eq{margin-left:auto;display:flex;gap:3px;align-items:flex-end;height:20px}.eq span{width:4px;background:var(--green);border-radius:2px;animation:eq .9s ease-in-out infinite}.eq span:nth-child(2){animation-delay:.15s}.eq span:nth-child(3){animation-delay:.3s}.eq span:nth-child(4){animation-delay:.45s}@keyframes eq{0%,to{height:6px}50%{height:20px}}.controls{display:flex;gap:10px;margin-bottom:12px}.controls .big-btn{flex:1 1}.stat-row{display:flex;gap:10px}.stat{flex:1 1;background:var(--card);border-radius:14px;padding:10px 12px;box-shadow:var(--shadow-sm)}.stat .k{font-size:13px;color:var(--ink-soft)}.stat .v{font-size:22px;font-weight:700;color:var(--ink)}.stat .v.good{color:var(--green-dark)}.parent-head{display:flex;align-items:center;gap:8px;margin-bottom:14px}.parent-head svg{width:22px;height:22px;color:var(--purple)}.parent-head h2{font-size:20px;margin:0;color:var(--purple-dark)}.metric-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.metric{background:var(--card);border-radius:16px;padding:16px;box-shadow:var(--shadow-sm)}.metric .k{font-size:14px;color:var(--ink-soft)}.metric .v{font-size:30px;font-weight:700;margin-top:4px}.metric .v.good{color:var(--green-dark)}.tabbar{position:fixed;bottom:0;left:0;right:0;max-width:460px;margin:0 auto;background:#fff;border-top:1px solid #efeafc;display:flex;justify-content:space-around;padding:10px 0 14px;box-shadow:0 -6px 20px rgba(91,63,214,.06)}.tabbar button{background:none;color:var(--ink-soft);display:flex;flex-direction:column;align-items:center;gap:2px;font-size:11px;font-weight:500;flex:1 1}.tabbar button svg{width:22px;height:22px}.tabbar button.active{color:var(--purple)}.note{background:#fff6e6;color:#946800}.banner,.note{border-radius:14px;padding:10px 14px;font-size:14px;margin-bottom:14px;text-align:center}.banner{background:#ffeef5;color:#c43e7f}.loading{display:flex;flex-direction:column;align-items:center;gap:14px;padding:40px 0;color:var(--purple-dark);font-size:18px;font-weight:500}.spinner{width:48px;height:48px;border:5px solid #e6e2fb;border-top:5px solid var(--purple);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.center-col{display:flex;flex-direction:column;flex:1 1}.center-col>*{flex-shrink:0}.spacer{flex:1 1}.num-row{display:flex;flex-wrap:wrap;gap:8px}.num-pill{background:#fff;color:var(--ink);font-weight:600;font-size:15px;min-width:44px;padding:8px 12px;border-radius:12px;box-shadow:var(--shadow-sm);border:2px solid transparent}.num-pill.sel{border-color:var(--purple);background:#efeaff;color:var(--purple-dark)}.access-row{display:flex;align-items:center;justify-content:space-between;background:var(--card);border-radius:14px;padding:12px 16px;box-shadow:var(--shadow-sm);margin-bottom:8px;font-size:16px;font-weight:500;color:var(--ink);cursor:pointer}body.dys{letter-spacing:.04em;word-spacing:.14em}body.dys .bubble,body.dys .buddy-line,body.dys .story-text{line-height:2;font-family:Trebuchet MS,Verdana,sans-serif}body.dys .story-text{letter-spacing:.06em}body.bigtext .story-text{font-size:30px}body.bigtext .bubble,body.bigtext .buddy-line{font-size:19px}body.bigtext .choice-btn,body.bigtext .word-opt{font-size:22px}.draw-card{background:#fff;border-radius:24px;padding:18px;width:92%;max-width:360px;box-shadow:var(--shadow);position:relative;z-index:2}.draw-title{text-align:center;font-size:18px;font-weight:600;color:var(--purple-dark);margin-bottom:12px}.draw-canvas{width:100%;height:auto;border-radius:16px;border:2px solid #e6e2fb;touch-action:none;background:#fff;display:block}.draw-colors{display:flex;gap:8px;justify-content:center;margin:12px 0;flex-wrap:wrap}.draw-color{width:30px;height:30px;border-radius:50%;box-shadow:var(--shadow-sm);border:3px solid transparent}.draw-color.on{border-color:var(--ink);transform:scale(1.1)}.draw-card .controls .big-btn{font-size:16px}.help-steps{display:flex;flex-direction:column;gap:10px}.help-step{display:flex;align-items:center;gap:12px;background:var(--card);border-radius:16px;padding:12px 14px;box-shadow:var(--shadow-sm)}.help-n{width:26px;height:26px;border-radius:50%;background:var(--purple);color:#fff;font-weight:700;font-size:14px;display:grid;place-items:center;flex-shrink:0}.help-emoji{font-size:26px;flex-shrink:0}.help-text{font-size:15px;color:var(--ink);line-height:1.4}.help-tips{margin-top:16px;display:flex;flex-direction:column;gap:8px}.help-tip{background:#f3f0ff;color:var(--purple-dark)}.help-tip,.install-banner{border-radius:14px;padding:10px 14px;font-size:14px}.install-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--purple);color:#fff;margin-bottom:14px;font-weight:500}.install-btn{background:#fff;color:var(--purple-dark);font-weight:600;font-size:14px;padding:7px 14px;border-radius:999px}.install-x{background:rgba(255,255,255,.25);color:#fff;width:30px;height:30px;border-radius:50%;font-size:14px}.toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%);background:var(--ink);color:#fff;font-size:15px;font-weight:500;padding:12px 18px;border-radius:14px;box-shadow:var(--shadow);z-index:60;max-width:90%;text-align:center;animation:toastin .2s ease}@keyframes toastin{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.lp{max-width:1000px;margin:0 auto;padding:0 20px 40px}.lp-nav{justify-content:space-between;padding:18px 0}.lp-brand,.lp-nav{display:flex;align-items:center}.lp-brand{gap:10px;font-size:24px;font-weight:700;color:var(--purple-dark)}.lp-logo{width:40px;height:40px;border-radius:50%;background:var(--purple);position:relative}.lp-logo:after,.lp-logo:before{content:"";position:absolute;top:14px;width:6px;height:6px;border-radius:50%;background:#fff}.lp-logo:before{left:11px}.lp-logo:after{right:11px}.lp-logo-smile{position:absolute;bottom:10px;left:12px;width:14px;height:7px;border-bottom:3px solid #fff;border-radius:0 0 14px 14px}.lp-nav-btn{background:var(--purple);color:#fff;text-decoration:none;font-weight:600;padding:10px 22px;border-radius:999px}.lp-nav-right{display:flex;align-items:center;gap:12px}.lp-lang{display:inline-flex;background:#efeaff;border-radius:999px;padding:3px}.lp-lang-btn{background:transparent;color:var(--purple-dark);font-weight:700;font-size:13px;padding:6px 12px;border-radius:999px}.lp-lang-btn.on{background:var(--purple);color:#fff}.lp-hero{text-align:center;padding:40px 0 30px}.lp-h1{font-size:40px;line-height:1.15;color:var(--ink);max-width:760px;margin:0 auto 18px}.lp-sub{font-size:19px;color:var(--ink-soft);max-width:620px;margin:0 auto 26px;line-height:1.6}.lp-cta{display:inline-block;background:var(--green);color:#fff;text-decoration:none;font-size:20px;font-weight:700;padding:16px 38px;border-radius:999px;box-shadow:0 8px 0 var(--green-dark)}.lp-cta-light{background:#fff;color:var(--purple-dark);box-shadow:0 8px 0 rgba(0,0,0,.15)}.lp-note{font-size:14px;color:var(--ink-soft);margin-top:16px}.lp-section{padding:40px 0}.lp-alt{background:#fff;border-radius:28px;padding:40px 24px}.lp-h2{font-size:30px;text-align:center;color:var(--purple-dark);margin:0 0 28px}.lp-section-sub{text-align:center;color:var(--ink-soft);font-size:16px;max-width:560px;margin:-16px auto 26px;line-height:1.5}.lp-books{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:18px;gap:18px;max-width:900px;margin:0 auto}.lp-book{display:flex;flex-direction:column;text-decoration:none;background:#fff;border-radius:18px;padding:10px;box-shadow:var(--shadow-sm);transition:transform .12s ease,box-shadow .12s ease}.lp-book:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.lp-book-cover{display:block;border-radius:12px;overflow:hidden;aspect-ratio:4/3;background:#f1eefc}.lp-book-cover img{width:100%;height:100%;object-fit:cover;display:block}.lp-book-title{font-size:15px;font-weight:600;color:var(--ink);margin-top:10px}.lp-book-age{font-size:12px;color:var(--purple);font-weight:600;margin-top:2px}.demo-cta{text-align:center;margin-top:22px;padding-bottom:10px}.demo-cta p{color:var(--ink-soft);font-size:14px;margin:0 0 12px}.lp-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:18px;gap:18px}.lp-step{background:#fff;border-radius:20px;padding:24px;box-shadow:var(--shadow-sm)}.lp-step-n{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;background:var(--purple);color:#fff;font-weight:700;font-size:18px;margin-bottom:12px}.lp-step h3{font-size:19px;margin:0 0 6px;color:var(--ink)}.lp-step p{font-size:15px;color:var(--ink-soft);line-height:1.5;margin:0}.lp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));grid-gap:16px;gap:16px}.lp-feat{padding:18px;border-radius:18px;background:#f7f6ff}.lp-feat span{font-size:32px}.lp-feat h3{font-size:18px;margin:8px 0 4px;color:var(--ink)}.lp-feat p{font-size:14px;color:var(--ink-soft);line-height:1.5;margin:0}.lp-why{max-width:680px;margin:0 auto;display:flex;flex-direction:column;gap:14px}.lp-why p{font-size:17px;color:var(--ink);line-height:1.6;background:#fff;padding:16px 20px;border-radius:16px;box-shadow:var(--shadow-sm);margin:0}.lp-why strong{color:var(--purple-dark)}.lp-final{text-align:center;background:var(--purple);border-radius:28px;padding:50px 24px;margin:20px 0}.lp-footer{padding-top:30px;border-top:1px solid #e6e2fb;color:var(--ink-soft);font-size:14px}.lp-foot-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:20px;gap:20px;margin-bottom:20px}.lp-foot-col{display:flex;flex-direction:column;gap:6px}.lp-foot-h{font-weight:600;color:var(--purple-dark);margin-bottom:2px}.lp-foot-tag{margin:0}.lp-foot-col a{color:var(--ink-soft);text-decoration:none}.lp-foot-col a:hover{color:var(--purple)}.lp-foot-bottom{text-align:center;padding-top:12px;border-top:1px solid #f0eefc}.legal{max-width:720px;margin:0 auto;padding:24px 20px 60px;color:var(--ink);line-height:1.7}.legal-back{display:inline-block;font-weight:600;text-decoration:none;margin-bottom:16px}.legal h1,.legal-back{color:var(--purple-dark)}.legal h1{font-size:30px;margin:0 0 4px}.legal h2{font-size:20px;color:var(--ink);margin:26px 0 8px}.legal-date{color:var(--ink-soft);font-size:14px;margin:0 0 18px}.legal li,.legal p{font-size:16px}.legal ul{padding-left:20px}.legal a{color:var(--purple)}.legal-foot{margin-top:30px;padding-top:16px;border-top:1px solid #e6e2fb;font-size:14px}@media (max-width:640px){.lp-h1{font-size:30px}.lp-h2{font-size:24px}}.lang-toggle{background:#efeaff;color:var(--purple-dark);font-weight:700;font-size:14px;padding:8px 12px;border-radius:999px;box-shadow:var(--shadow-sm)}.onb{display:flex;flex-direction:column;flex:1 1;padding-top:10px}.onb-mascot{width:72px;height:72px;border-radius:50%;background:var(--purple);position:relative;margin:6px auto 10px;box-shadow:var(--shadow)}.onb-mascot:after,.onb-mascot:before{content:"";position:absolute;top:28px;width:10px;height:10px;border-radius:50%;background:#fff}.onb-mascot:before{left:20px}.onb-mascot:after{right:20px}.onb-mascot .smile{position:absolute;bottom:18px;left:26px;width:20px;height:10px;border-bottom:3px solid #fff;border-radius:0 0 16px 16px}.onb-avatar{display:grid;place-items:center;margin:6px auto 10px}.onb-title{text-align:center;font-size:26px;margin:0;color:var(--purple-dark)}.onb-sub{text-align:center;color:var(--ink-soft);font-size:16px;margin:6px 0 18px}.onb-label{font-size:16px;font-weight:600;color:var(--ink);margin:14px 0 8px}.onb-input{font-family:inherit;font-size:18px;padding:14px 16px;border-radius:16px;border:2px solid #e6e2fb;outline:none;color:var(--ink)}.onb-input:focus{border-color:var(--purple)}.onb-hint{font-size:14px;color:var(--ink-soft);margin:8px 0 18px}.age-row{display:flex;gap:8px;flex-wrap:wrap}.age-pill{width:48px;height:48px;border-radius:50%;background:#fff;color:var(--ink);font-size:18px;font-weight:600;box-shadow:var(--shadow-sm)}.age-pill.sel{background:var(--purple);color:#fff}.profiles-list{display:flex;flex-direction:column;gap:8px}.profile-row{gap:8px}.profile-pick,.profile-row{display:flex;align-items:center}.profile-pick{flex:1 1;gap:10px;background:#fff;border-radius:14px;padding:8px 12px;box-shadow:var(--shadow-sm);border:2px solid transparent;text-align:left}.profile-row.active .profile-pick{border-color:var(--purple);background:#f3f0ff}.profile-name{flex:1 1;font-size:16px;font-weight:600;color:var(--ink)}.profile-badge{font-size:11px;font-weight:700;color:var(--purple-dark);background:#e7e0ff;padding:3px 8px;border-radius:999px}.profile-act{background:#fff;border-radius:12px;padding:8px 10px;box-shadow:var(--shadow-sm);font-size:16px}.profile-act:active{transform:translateY(2px)}.account-box{background:var(--card);border-radius:16px;padding:12px 14px;box-shadow:var(--shadow-sm)}.account-email{font-size:14px;color:var(--ink);font-weight:600;margin-bottom:10px;word-break:break-all}.account-actions{display:flex;gap:8px}.account-btn{flex:1 1;background:var(--purple);color:#fff;font-weight:600;font-size:14px;padding:10px;border-radius:12px;box-shadow:var(--shadow-sm)}.account-btn.ghost{background:#eee;color:#777}.auth-overlay{position:fixed;inset:0;background:rgba(43,35,80,.45);display:flex;align-items:center;justify-content:center;padding:20px;z-index:50}.auth-card{background:#fff;border-radius:22px;padding:22px;width:100%;max-width:380px;position:relative;box-shadow:var(--shadow)}.auth-x{position:absolute;top:12px;right:14px;background:none;font-size:18px;color:var(--ink-soft)}.auth-title{font-size:22px;color:var(--ink);margin:0 0 6px}.auth-sub{font-size:14px;color:var(--ink-soft);margin:0 0 16px;line-height:1.4}.auth-input{width:100%;box-sizing:border-box;font-family:inherit;font-size:16px;padding:13px 14px;border:2px solid #e6e2fb;border-radius:14px;margin-bottom:10px}.auth-input:focus{outline:none;border-color:var(--purple)}.auth-error{color:#b3261e}.auth-error,.auth-info{font-size:14px;margin-bottom:8px}.auth-info{color:#1f9e72}.auth-switch{display:block;width:100%;text-align:center;background:none;color:var(--purple);font-weight:600;font-size:14px;margin-top:14px}.style-row{display:flex;gap:10px;overflow-x:auto;padding:2px 2px 8px;margin-bottom:8px;-webkit-overflow-scrolling:touch}.style-row .style-card{flex:0 0 92px}.style-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));grid-gap:10px;gap:10px}.style-card{background:#fff;border-radius:14px;padding:6px;box-shadow:var(--shadow-sm);border:3px solid transparent;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer}.style-card.sel{border-color:var(--purple)}.style-card img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:10px;display:block;background:#f1eefc}.style-card span{font-size:11px;font-weight:600;color:var(--ink);text-align:center;line-height:1.15}.voice-select{width:100%;box-sizing:border-box;font-family:inherit;font-size:15px;padding:12px 14px;border-radius:14px;border:2px solid #e6e2fb;background:#fff;color:var(--ink)}.voice-select:focus{outline:none;border-color:var(--purple)}.lang-row{display:flex;gap:10px}.lang-pill{flex:1 1;padding:12px;border-radius:14px;background:#fff;color:var(--ink);font-size:16px;font-weight:600;box-shadow:var(--shadow-sm)}.lang-pill.sel{background:var(--purple);color:#fff}.onb .big-btn{margin-top:20px}.onb-parent{margin-top:18px;background:#f3f0ff;border-radius:18px;padding:14px 16px}.onb-parent-tag{display:block;width:-moz-fit-content;width:fit-content;background:var(--purple);color:#fff;font-size:12px;font-weight:600;padding:3px 12px;border-radius:999px;margin-bottom:8px}.onb-parent .onb-label:first-of-type{margin-top:0}.pick-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:8px;gap:8px}.pick-chip{display:flex;align-items:center;justify-content:center;gap:4px;background:#fff;color:var(--ink);font-size:12.5px;font-weight:500;padding:9px 6px;border-radius:14px;box-shadow:var(--shadow-sm);border:2px solid transparent;text-align:center;line-height:1.15;min-height:42px}.pick-chip.sel{border-color:var(--purple);background:#efeaff;color:var(--purple-dark)}.value-banner{display:flex;align-items:center;gap:8px;background:#fff6e0;color:#946800;border-radius:16px;padding:12px 14px;font-size:16px;font-weight:600;margin-top:14px}.value-star{font-size:22px}.values-list{display:flex;flex-direction:column;gap:8px}.value-row{display:flex;align-items:center;gap:10px;background:var(--card);border-radius:14px;padding:10px 14px;box-shadow:var(--shadow-sm)}.value-ico{font-size:22px}.value-lbl{flex:1 1;font-size:16px;font-weight:500;color:var(--ink)}.value-count{font-size:16px;font-weight:700;color:var(--purple)}.consent-box{background:#f3f0ff;border-radius:16px;padding:16px 18px;margin:8px 0 18px}.consent-box p{line-height:1.6;margin:0}.consent-box p,.consent-check{font-size:16px;color:var(--ink)}.consent-check{display:flex;align-items:flex-start;gap:10px;cursor:pointer}.consent-check input{width:22px;height:22px;margin-top:2px;flex-shrink:0}.plan-note{text-align:center;font-size:13px;color:var(--ink-soft);margin:8px 0 0}.daily-card{background:var(--card);border-radius:16px;padding:14px 16px;box-shadow:var(--shadow-sm)}.daily-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.daily-label{font-size:16px;font-weight:600;color:var(--ink)}.daily-challenge{font-size:14px;color:var(--purple-dark);margin-top:8px;font-weight:500}.value-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px;margin-bottom:6px}.value-medal{position:relative;background:var(--card);border-radius:16px;padding:14px 8px;text-align:center;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;gap:4px}.value-medal.locked{opacity:.5}.value-medal-ico{font-size:28px}.value-medal-name{font-size:12px;font-weight:600;color:var(--ink);line-height:1.2}.value-medal-n{position:absolute;top:6px;right:8px;font-size:11px;font-weight:700;color:var(--purple-dark);background:#efeaff;padding:1px 6px;border-radius:999px}.sticker-grid{display:grid;grid-template-columns:repeat(8,1fr);grid-gap:8px;gap:8px}.sticker{aspect-ratio:1;display:grid;place-items:center;font-size:26px;background:var(--card);border-radius:14px;box-shadow:var(--shadow-sm)}.sticker.locked{opacity:.4}.path{flex-direction:column;margin:16px 0 6px;padding-left:4px}.lvl,.path{display:flex}.lvl{gap:14px}.lvl-rail{display:flex;flex-direction:column;align-items:center;align-self:stretch}.lvl-dot{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-size:22px;font-weight:700;color:#fff;flex-shrink:0;z-index:1;box-shadow:0 4px 0 rgba(0,0,0,.12)}.lvl-line{width:4px;flex:1 1;min-height:18px;background:#e3def7;border-radius:2px;margin:3px 0}.lvl-body{padding:9px 0 18px}.lvl-goal{align-self:center;margin-left:auto;flex-shrink:0;font-size:14px;font-weight:700;color:var(--ink-soft);background:#f0edfb;padding:6px 12px;border-radius:999px}.lvl-goal.got{background:#fff3d4;color:#9a6700;box-shadow:0 2px 0 #f0dca8}.section-hint{font-size:13px;color:var(--ink-soft);margin:-4px 0 12px;line-height:1.4}.lvl-name{font-size:15px;font-weight:700;color:var(--ink)}.lvl-desc{font-size:13px;color:var(--ink-soft);margin-top:1px}.lvl.done .lvl-dot{box-shadow:0 4px 0 var(--green-dark)}.lvl.done .lvl-dot,.lvl.done .lvl-line{background:var(--green)}.lvl.current .lvl-dot{background:var(--yellow);color:#7a5200;box-shadow:0 4px 0 #d99e1f;animation:bounce 1.4s infinite}.lvl.current .lvl-name{color:var(--purple-dark)}.lvl.locked .lvl-dot{background:#d8d3ee;box-shadow:0 4px 0 #c4bde6}.lvl.locked .lvl-desc,.lvl.locked .lvl-name{color:var(--ink-soft)}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.level-card{background:var(--card);border-radius:18px;padding:16px;box-shadow:var(--shadow-sm);position:relative}.level-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.level-badge{background:var(--purple);color:#fff;font-weight:600;padding:6px 14px;border-radius:999px;font-size:16px}.xp-track{height:16px;background:#efeafc;overflow:hidden}.xp-fill,.xp-track{border-radius:999px}.xp-fill{height:100%;background:var(--green);transition:width .4s ease}.xp-text{text-align:right;font-size:13px;color:var(--ink-soft);margin-top:6px}.streak{position:absolute;top:14px;right:110px;font-size:15px;font-weight:600;color:var(--coral)}.badge-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:10px;gap:10px}.badge-card{background:var(--card);border-radius:16px;padding:14px 8px;text-align:center;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;gap:4px}.badge-card.locked{opacity:.55}.badge-icon{font-size:30px}.badge-name{font-size:13px;font-weight:600;color:var(--ink)}.badge-desc{font-size:11px;color:var(--ink-soft);line-height:1.3}.celebrate{position:fixed;inset:0;background:rgba(43,35,80,.55);display:grid;place-items:center;z-index:50;overflow:hidden}.celebrate-card{background:#fff;border-radius:26px;padding:28px 26px;width:84%;max-width:340px;text-align:center;box-shadow:var(--shadow);position:relative;z-index:2}.celebrate-emoji{font-size:54px}.celebrate-card h2{font-size:28px;margin:6px 0;color:var(--purple-dark)}.reward-stars{font-size:22px;font-weight:700;color:#c98800;background:#fff6e0;display:inline-block;padding:6px 18px;border-radius:999px;margin:6px 0 4px}.level-up{font-size:17px;font-weight:600;color:var(--green-dark);margin:10px 0}.new-badges{margin:14px 0}.new-badge-title{font-size:15px;color:var(--ink-soft);margin-bottom:8px}.badge-chip{display:inline-flex;align-items:center;gap:8px;background:#efeaff;color:var(--purple-dark);padding:8px 14px;border-radius:999px;font-weight:600;margin:4px}.badge-chip .badge-icon{font-size:22px}.celebrate-card .big-btn{margin-top:12px}.comp-head{font-size:14px;font-weight:600;color:var(--ink-soft);margin-bottom:8px}.comp-q{font-size:20px;font-weight:600;color:var(--purple-dark);margin-bottom:16px;line-height:1.4}.tier-list{display:flex;flex-direction:column;gap:12px}.tier-card{border-radius:18px;padding:16px;box-shadow:var(--shadow-sm);position:relative}.tier-card.rec{border:3px solid var(--purple)}.tier-badge{position:absolute;top:-10px;right:16px;background:var(--purple);color:#fff;font-size:12px;font-weight:600;padding:4px 12px;border-radius:999px}.tier-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:10px}.tier-name{font-size:20px;font-weight:700;color:var(--ink)}.tier-price{font-size:22px;font-weight:700;color:var(--purple-dark)}.tier-per{font-size:13px;font-weight:500;color:var(--ink-soft)}.tier-features{list-style:none;padding:0;margin:0 0 12px}.tier-features li{font-size:15px;color:var(--ink);padding:3px 0}.tier-btn{width:100%;font-size:16px;font-weight:600;color:#fff;background:var(--purple);padding:12px;border-radius:14px}.tier-btn.current{background:#fff;color:var(--ink-soft);box-shadow:inset 0 0 0 2px #e6e2fb}.lib-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}.lib-age-head{font-size:14px;font-weight:600;color:var(--ink-soft);margin:16px 0 8px}.consent-art{width:100%;border-radius:22px;margin:6px 0;display:block}.book-card,.consent-art{box-shadow:var(--shadow-sm)}.book-card{background:var(--card);border-radius:16px;overflow:hidden;display:flex;flex-direction:column}.book-cover{aspect-ratio:4/3;background:#e7f0ff;display:grid;place-items:center;overflow:hidden;cursor:pointer}.book-cover img{width:100%;height:100%;object-fit:cover}.book-ph{font-size:40px}.book-title{font-size:14px;font-weight:600;color:var(--ink);padding:8px 10px 2px;line-height:1.3}.book-stars{padding:0 10px;font-size:14px;color:#d8d3ee}.book-stars .on{color:var(--yellow)}.book-actions{display:flex;gap:6px;padding:8px 10px 10px}.book-open{flex:1 1;background:var(--purple);color:#fff;font-weight:600;font-size:14px;padding:8px;border-radius:12px}.book-del{background:#f1eff8;color:#888;font-size:16px;padding:8px 12px;border-radius:12px}.save-panel{margin-top:14px;background:#f7f6ff;border-radius:16px;padding:14px}.save-rate{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;font-size:16px;font-weight:500;color:var(--ink)}.rate-stars{display:flex;gap:4px}.rate-stars button{background:none;font-size:28px;color:#d8d3ee;line-height:1}.rate-stars button.on{color:var(--yellow)}.saved-tag{text-align:center;font-size:16px;font-weight:600;color:var(--green-dark);padding:8px}.share-box{margin-top:12px}.share-btn{width:100%;background:var(--blue);color:#fff;font-weight:600;font-size:16px;padding:12px;border-radius:14px}.share-done{text-align:center;font-weight:600;color:var(--blue)}.share-url{word-break:break-all;margin-top:4px;font-weight:400}.share-note,.share-url{font-size:12px;color:var(--ink-soft)}.share-note{text-align:center;margin-top:8px}.shared{max-width:640px;margin:0 auto;padding:16px 16px 60px}.shared-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.shared-title{font-size:30px;color:var(--purple-dark);text-align:center;margin:10px 0 24px}.shared-page{margin-bottom:28px}.shared-img{width:100%;border-radius:20px;box-shadow:var(--shadow-sm);display:block}.shared-text{font-size:22px;line-height:1.7;color:var(--ink);margin-top:14px}.shared-cta{text-align:center;background:#fff;border-radius:20px;padding:24px;box-shadow:var(--shadow-sm);margin-top:20px}.shared-cta p{font-size:16px;color:var(--ink-soft);margin:0 0 16px}.game-tabs{display:flex;gap:8px;margin-bottom:14px}.game-tab{flex:1 1;padding:10px;border-radius:14px;background:#fff;color:var(--ink-soft);font-size:15px;font-weight:600;box-shadow:var(--shadow-sm)}.game-tab.sel{background:var(--purple);color:#fff}.game-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px;align-items:stretch}.game-card{display:flex;flex-direction:column;align-items:center;gap:4px;min-height:200px;padding:18px 10px;border-radius:18px;box-shadow:var(--shadow-sm);text-align:center}.game-card.locked{opacity:.6}.game-icon{font-size:36px}.game-name{font-size:17px;font-weight:600;color:var(--ink)}.game-desc{font-size:12px;color:var(--ink-soft);line-height:1.3;min-height:31px;display:flex;align-items:center}.game-cta{margin-top:auto;font-size:13px;font-weight:600;color:var(--purple);background:#fff;padding:4px 14px;border-radius:999px}.mole-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:12px;gap:12px;margin:18px 0}.mole-hole{aspect-ratio:1/1;border-radius:50%;background:#d8c3a5;box-shadow:inset 0 -8px 0 rgba(0,0,0,.12);display:flex;align-items:center;justify-content:center;font-size:40px;overflow:hidden}.mole-hole.up{background:#c9ad88}.mole-hole.up .mole{animation:molepop .12s ease-out}@keyframes molepop{0%{transform:translateY(45%) scale(.5)}to{transform:translateY(0) scale(1)}}.balloon-target{text-align:center;font-size:18px;font-weight:600;color:var(--ink);margin:6px 0 14px;display:flex;align-items:center;justify-content:center;gap:8px}.balloon-chip{width:22px;height:22px;border-radius:50%;display:inline-block}.balloon-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:14px;gap:14px;margin:8px 0}.balloon{position:relative;aspect-ratio:3/4;border-radius:50% 50% 50% 50%/45% 45% 55% 55%;box-shadow:inset -6px -8px 0 rgba(0,0,0,.12);transition:transform .12s,opacity .25s}.balloon:active{transform:scale(.92)}.balloon-knot{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:8px solid rgba(0,0,0,.18)}.balloon.gone{opacity:0;transform:scale(.3);pointer-events:none}.math-q{font-size:44px;font-weight:700;color:var(--purple-dark);margin:24px 0}.caps-q,.math-q{text-align:center}.caps-q{font-size:18px;font-weight:600;color:var(--ink);margin-top:16px}.caps-show{text-align:center;font-size:96px;font-weight:800;line-height:1;color:var(--purple-dark);margin:6px 0 18px}.spell-emoji{font-size:72px;text-align:center;margin:10px 0 4px}.spell-slots{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:10px 0 18px}.spell-slots.shake{animation:shake .3s}.spell-slot{width:42px;height:50px;border-radius:12px;background:#f3f0ff;border:2px dashed #d8d3ee;display:grid;place-items:center;font-size:26px;font-weight:700;color:var(--purple-dark)}.spell-slot.filled{background:var(--green);border:none;color:#fff}.spell-pool{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.spell-chip{width:50px;height:56px;border-radius:14px;background:#fff;font-size:26px;font-weight:700;color:var(--ink);box-shadow:0 5px 0 #e6e2fb}.spell-chip:active{transform:translateY(3px);box-shadow:0 2px 0 #e6e2fb}.spell-chip:disabled{opacity:.3;box-shadow:none}.trans-prompt{text-align:center;margin:14px 0 20px}.trans-emoji{font-size:72px;display:block}.trans-word{font-size:30px;font-weight:700;color:var(--purple-dark)}.trans-q,.trans-word{display:block;margin-top:6px}.trans-q{font-size:15px;color:var(--ink-soft)}.rps-arena{display:flex;align-items:center;justify-content:space-around;margin:18px 0}.rps-side{text-align:center}.rps-who{font-size:13px;color:var(--ink-soft);font-weight:600}.rps-hand{font-size:56px}.rps-vs{font-size:18px;font-weight:700;color:var(--purple-dark)}.rps-moves{display:flex;gap:12px;justify-content:center}.rps-btn{font-size:44px;background:#fff;border-radius:18px;padding:10px 16px;box-shadow:0 6px 0 #e6e2fb}.rps-btn:active{transform:translateY(3px);box-shadow:0 3px 0 #e6e2fb}.rps-btn:disabled{opacity:.5}.guess-hint{text-align:center;font-size:20px;font-weight:700;color:var(--purple-dark);margin:14px 0;min-height:26px}.guess-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:8px;gap:8px}.guess-num{aspect-ratio:1;border-radius:12px;background:#fff;font-size:18px;font-weight:700;color:var(--ink);box-shadow:0 4px 0 #e6e2fb}.guess-num:active{transform:translateY(2px)}.guess-num.off{opacity:.2;box-shadow:none}.missing-set{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;font-size:46px;margin:16px 0}.missing-set.faded{opacity:.85}.missing-opts{display:flex;gap:12px;justify-content:center;margin-top:10px}.missing-opt{font-size:44px;background:#fff;border-radius:16px;padding:8px 12px;box-shadow:0 6px 0 #e6e2fb}.missing-opt.ok{background:var(--green);box-shadow:0 6px 0 var(--green-dark)}.missing-opt.no{background:#ffd9d9;box-shadow:0 6px 0 #f0b0b0}.reaction-pad{width:100%;min-height:220px;border-radius:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;margin:8px 0;transition:background .1s}.reaction-pad.wait{background:#ff6b6b}.reaction-pad.go{background:var(--green)}.reaction-pad.early{background:#ffc83d}.reaction-emoji{font-size:64px}.reaction-text{font-size:24px;font-weight:800;color:#fff}.ttt-board{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px;max-width:300px;margin:16px auto}.ttt-cell{aspect-ratio:1;border-radius:16px;background:#fff;font-size:44px;display:grid;place-items:center;box-shadow:var(--shadow-sm)}.ttt-cell:disabled{cursor:default}.ttt-result{text-align:center;font-size:22px;font-weight:800;margin-top:12px;color:var(--purple-dark)}.ttt-result.lose{color:var(--ink-soft)}.math-opts{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:12px;gap:12px}.math-opt{font-size:28px;font-weight:700;color:var(--ink);background:#fff;padding:18px 0;border-radius:18px;box-shadow:0 6px 0 #e6e2fb}.math-opt:active{transform:translateY(3px)}.math-opt.ok{background:var(--green);color:#fff;box-shadow:0 6px 0 var(--green-dark)}.math-opt.no{background:#ffd9d9;color:#a32d2d;box-shadow:0 6px 0 #f0b0b0}.game-done{text-align:center;padding:30px 0}.game-done h2{font-size:26px;color:var(--purple-dark);margin:6px 0}.simon-state{text-align:center;font-size:18px;font-weight:600;color:var(--purple-dark);margin:14px 0}.simon-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px;max-width:320px;margin:0 auto}.simon-pad{aspect-ratio:1;border-radius:20px;opacity:.55;box-shadow:var(--shadow-sm);transition:opacity .1s ease,transform .1s ease}.simon-pad.on{opacity:1;transform:scale(1.05);box-shadow:0 0 0 5px rgba(255,255,255,.6),var(--shadow)}.surprise-banner{background:var(--yellow);color:#7a5200;font-weight:700;font-size:18px;padding:10px 16px;border-radius:14px;margin:10px 0;animation:bounce 1s infinite}.rhyme-q{font-size:24px;font-weight:700;color:var(--purple-dark);text-align:center;margin:22px 0}.order-line{min-height:56px;background:#f3f0ff;border-radius:16px;padding:12px;display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:center;margin-bottom:16px}.order-line.wrong{background:#ffd9d9;animation:shake .3s}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}.order-empty{color:var(--ink-soft);font-size:20px}.order-built{background:var(--green);color:#fff;font-weight:600;font-size:18px;padding:8px 14px;border-radius:12px}.order-pool{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.order-chip{background:#fff;color:var(--ink);font-weight:600;font-size:18px;padding:10px 16px;border-radius:14px;box-shadow:0 5px 0 #e6e2fb}.order-chip:disabled{opacity:.35;box-shadow:none}.syl-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:8px}.syl-chip{background:var(--purple);color:#fff;font-size:28px;font-weight:700;padding:14px 20px;border-radius:16px;box-shadow:0 6px 0 var(--purple-dark)}.syl-chip:active{transform:translateY(3px);box-shadow:0 3px 0 var(--purple-dark)}.vocab-card{background:var(--card);border-radius:22px;padding:24px;text-align:center;box-shadow:var(--shadow);margin:16px 0;cursor:pointer}.vocab-emoji{font-size:80px}.vocab-word{font-size:30px;font-weight:700;color:var(--purple-dark);margin-top:8px}.vocab-trans{font-size:18px;color:var(--ink-soft);margin-top:4px}.vocab-hint{font-size:13px;color:var(--ink-soft);margin-top:12px}.word-emoji{font-size:96px;text-align:center;margin:16px 0 22px}.word-opts{display:flex;flex-direction:column;gap:12px}.word-opt{font-size:22px;font-weight:600;color:var(--ink);background:#fff;padding:16px;border-radius:16px;box-shadow:0 6px 0 #e6e2fb}.word-opt:active{transform:translateY(3px)}.word-opt.ok{background:var(--green);color:#fff;box-shadow:0 6px 0 var(--green-dark)}.word-opt.no{background:#ffd9d9;color:#a32d2d;box-shadow:0 6px 0 #f0b0b0}.mem-grid{display:grid;grid-gap:10px;gap:10px;margin-top:10px}.mem-grid.cols3{grid-template-columns:repeat(3,1fr)}.mem-grid.cols4{grid-template-columns:repeat(4,1fr)}.mem-card{aspect-ratio:1;border-radius:16px;background:var(--purple);color:#fff;font-size:34px;display:grid;place-items:center;box-shadow:var(--shadow-sm)}.mem-card.up{background:#fff}.mem-card.matched{background:var(--green)}.mem-card span{line-height:1}.choices{margin-top:14px}.choices-q{font-size:17px;color:var(--purple-dark);text-align:center}.choice-btn,.choices-q{font-weight:600;margin-bottom:10px}.choice-btn{width:100%;font-size:18px;color:#fff;padding:16px;border-radius:18px;box-shadow:0 6px 0 rgba(0,0,0,.12);transition:transform .08s ease}.choice-btn:active{transform:translateY(3px)}.choice-btn.c0{background:var(--blue)}.choice-btn.c1{background:var(--coral)}.choice-btn:disabled{opacity:.6}.hero-toggle{display:flex;align-items:center;gap:12px;width:100%;background:#fff;border:2px solid #e6e2fb;border-radius:18px;padding:12px 14px;margin-bottom:12px;text-align:left}.hero-toggle.on{border-color:var(--purple);background:#f3f0ff}.hero-star{width:38px;height:38px;border-radius:50%;background:var(--yellow);color:#7a5200;display:grid;place-items:center;flex-shrink:0}.hero-star svg{width:22px;height:22px}.hero-text{flex:1 1;display:flex;flex-direction:column}.hero-title{font-size:16px;font-weight:600;color:var(--ink)}.hero-sub{font-size:13px;color:var(--purple);font-weight:500}.hero-switch{width:48px;height:28px;border-radius:999px;background:#d8d3ee;flex-shrink:0;position:relative;transition:background .15s ease}.hero-switch span{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;transition:left .15s ease}.hero-switch.on{background:var(--purple)}.hero-switch.on span{left:23px}.buddy-row{display:flex;align-items:center;gap:10px;background:#efeaff;border-radius:20px;padding:10px 12px;margin-bottom:18px}.buddy-av{flex-shrink:0;animation:bob 2.6s ease-in-out infinite}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.celebrate-card .buddy-av{animation:bounce 1s ease-in-out infinite}.illustration img{animation:fadein .4s ease}@keyframes fadein{0%{opacity:0}to{opacity:1}}.buddy-bubble{flex:1 1;min-width:0}.buddy-name{font-size:13px;font-weight:600;color:var(--purple)}.buddy-line{font-size:16px;font-weight:500;color:var(--purple-dark);line-height:1.4}.buddy-speak{flex-shrink:0;width:40px;height:40px;border-radius:50%;background:#fff;color:var(--purple);display:grid;place-items:center;box-shadow:var(--shadow-sm)}.celebrate-card .buddy-row{background:#f3f0ff;margin:12px 0;text-align:left}.avatar-grid{display:flex;gap:10px}.avatar-pick{flex:1 1;background:#fff;border-radius:16px;padding:8px 4px;display:flex;flex-direction:column;align-items:center;gap:4px;box-shadow:var(--shadow-sm);border:3px solid transparent}.avatar-pick.sel{border-color:var(--purple);background:#f3f0ff}.avatar-name{font-size:12px;font-weight:600;color:var(--ink)}.confetti{position:absolute;inset:0;pointer-events:none;z-index:1}.confetti span{position:absolute;top:-20px;width:10px;height:14px;border-radius:2px;animation:fall 2.4s linear infinite}@keyframes fall{0%{transform:translateY(-20px) rotate(0deg);opacity:1}to{transform:translateY(105vh) rotate(540deg);opacity:.9}}.admin{max-width:900px;margin:0 auto;padding:28px 18px 60px;color:var(--ink)}.admin-head{display:flex;align-items:center;justify-content:space-between}.admin h1{font-size:26px;color:var(--purple-dark);margin:0}.admin-link{color:var(--purple);font-weight:600;text-decoration:none}.admin-sub{color:var(--ink-soft);font-size:14px;margin:8px 0 18px}.admin-table{display:flex;flex-direction:column;gap:6px}.admin-row{display:grid;grid-template-columns:2fr 1fr .8fr 1fr 1fr;align-items:center;grid-gap:8px;gap:8px;background:#fff;border-radius:12px;padding:10px 12px;box-shadow:var(--shadow-sm);font-size:14px}.admin-thead{background:transparent;box-shadow:none;font-weight:700;color:var(--ink-soft);font-size:12px}.admin-row.saving{opacity:.55}.admin-email{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.admin-row input,.admin-row select{font-family:inherit;font-size:14px}.admin-date{color:var(--ink-soft);font-size:12px}.admin code{background:#efeaff;padding:2px 6px;border-radius:6px;font-size:13px}.admin-diag{background:#fff;border-radius:12px;padding:14px 16px;box-shadow:var(--shadow-sm);margin:14px 0;font-size:14px;line-height:1.6;color:var(--ink)}.admin-save{font-size:14px;font-weight:600;margin:8px 0 12px}.admin-nav{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 18px}.admin-tab{background:#fff;color:var(--ink-soft);font-weight:600;font-size:14px;padding:9px 16px;border-radius:999px;box-shadow:var(--shadow-sm)}.admin-tab.sel{background:var(--purple);color:#fff}.admin-card{background:#fff;border-radius:16px;padding:18px 20px;box-shadow:var(--shadow-sm);margin-bottom:14px}.admin-card h2{font-size:18px;color:var(--purple-dark);margin:0 0 10px}.admin-card h3{font-size:15px;color:var(--ink);margin:0 0 8px}.admin-card p{margin:4px 0;font-size:14px}.admin-muted{color:var(--ink-soft);font-size:13px;line-height:1.5}.admin-search{width:100%;box-sizing:border-box;font-family:inherit;font-size:15px;padding:11px 14px;border:2px solid #e6e2fb;border-radius:12px;margin-bottom:12px}.admin-search:focus{outline:none;border-color:var(--purple)}.admin-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:12px;gap:12px;margin-bottom:14px}.admin-metric{background:#fff;border-radius:16px;padding:16px;box-shadow:var(--shadow-sm);text-align:center}.admin-metric-v{font-size:30px;font-weight:800;color:var(--purple-dark)}.admin-metric-k{font-size:13px;color:var(--ink-soft);margin-top:2px}.admin-bar-row{display:grid;grid-template-columns:70px 1fr 30px;align-items:center;grid-gap:10px;gap:10px;margin:6px 0;font-size:14px}.admin-bar{height:12px;background:#efeaff;border-radius:999px;overflow:hidden}.admin-bar span{display:block;height:100%;background:var(--purple);border-radius:999px}.admin-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.admin-field span{font-size:14px;font-weight:600}.admin-field input{font-family:inherit;font-size:15px;padding:10px 12px;border:2px solid #e6e2fb;border-radius:12px}.admin-toggle-row{display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:600;padding:10px 0}@media (max-width:560px){.admin-row{grid-template-columns:1.6fr .9fr .6fr .9fr}.admin-date,.admin-thead span:last-child{display:none}}@media (min-width:720px){.app{padding:22px 24px 104px}.app,.tabbar{max-width:640px}.lib-grid{grid-template-columns:repeat(3,1fr)}.metric-grid{grid-template-columns:repeat(4,1fr)}.tabbar button{font-size:12px}.tabbar button svg{width:24px;height:24px}}@media (min-width:1040px){.app,.tabbar{max-width:720px}}