*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#faf7ff;--surface:#fff;--surface2:#ede8f5;--accent:#e94560;--accent2:#f5a623;--action-gradient:linear-gradient(135deg, #ff7f87, #ffc06a);--action-gradient-horizontal:linear-gradient(90deg, #ff7f87, #ffc06a);--action-shadow:#d95f69;--text:#3a2d5c;--text-muted:#8878a9;--radius:16px;--radius-sm:10px;--shadow:0 8px 32px #64508c1f;font-family:Nunito,Segoe UI,system-ui,sans-serif}body{background:var(--bg);color:var(--text);min-height:100dvh;margin:0;overflow-y:scroll}.app-layout{justify-content:center;min-height:100dvh;display:flex}.app-layout-dashboard{align-items:center;padding:32px}.app-root{box-sizing:border-box;flex-direction:column;width:480px;max-width:100%;min-height:100dvh;padding:16px;display:flex}.dashboard-shell{background:#ffffffd1;border:1px solid #ede8f5e6;border-radius:34px;grid-template-columns:132px minmax(0,1fr);gap:28px;width:min(1280px,100%);min-height:min(820px,100dvh - 64px);padding:28px;display:grid;box-shadow:0 26px 80px #64508c29}.dashboard-main{flex-direction:column;gap:24px;min-width:0;display:flex}.dashboard-shell-practice,.dashboard-shell-placement,.dashboard-shell-complete{min-height:min(820px,100dvh - 64px)}.dashboard-shell-practice .dashboard-main,.dashboard-shell-placement .dashboard-main,.dashboard-shell-complete .dashboard-main{justify-content:flex-start}.dashboard-header{justify-content:space-between;align-items:center;gap:20px;min-height:72px;display:flex}.dashboard-header h1{color:var(--text);font-size:2.15rem;font-weight:900;line-height:1.05}.dashboard-title-group{min-width:0}.dashboard-title-row{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.dashboard-kicker{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;font-size:.8rem;font-weight:900}.dashboard-header-balance{min-width:92px;color:var(--text);background:#fff7e0;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:12px 18px;font-weight:900;display:flex;box-shadow:0 8px 22px #f5a62326}.dashboard-header-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px;display:flex}.account-panel{background:var(--surface);border:1px solid var(--surface2);border-radius:999px;align-items:center;gap:10px;min-height:46px;padding:7px 9px 7px 14px;display:flex;box-shadow:0 8px 22px #64508c14}.account-panel-compact{padding-right:14px}.account-summary{flex-direction:column;gap:2px;min-width:0;display:flex}.account-status{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;font-size:.66rem;font-weight:900;line-height:1}.account-status-synced{color:#2f8f5b}.account-status-error{color:var(--accent)}.account-email,.account-error{max-width:180px;color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:.74rem;font-weight:800;line-height:1.15;overflow:hidden}.account-error{color:var(--accent)}.account-login-row{align-items:center;gap:6px;display:flex}.account-email-input{border:1px solid var(--surface2);background:var(--bg);width:150px;color:var(--text);font:inherit;border-radius:999px;outline:none;padding:8px 11px;font-size:.8rem;font-weight:800}.account-email-input:focus{border-color:var(--accent2)}.account-link-button{background:var(--surface2);color:var(--text);white-space:nowrap;border-radius:999px;padding:8px 12px;font-size:.76rem;font-weight:900}.account-link-button:hover:not(:disabled){background:#e4ddec}.dashboard-restart-btn{background:var(--surface2);color:var(--text-muted);border-radius:999px;padding:8px 16px;font-size:.84rem;font-weight:900}.dashboard-restart-btn:hover:not(:disabled){color:var(--text);background:#e4ddec}.tab-nav{min-height:100%;box-shadow:inset 0 0 0 1px var(--surface2);background:#fff;border-radius:28px;flex-direction:column;align-items:center;gap:12px;padding:24px 12px;display:flex}.tab-nav-brand{background:var(--action-gradient);color:#fff;border-radius:18px;place-items:center;width:54px;height:54px;display:grid;box-shadow:0 10px 24px #7c4dff38}.tab-nav-logo{font-size:1.45rem;font-weight:900}.tab-nav-list{flex-direction:column;gap:12px;width:100%;display:flex}.tab-nav-button{width:100%;min-height:76px;color:var(--text-muted);background:0 0;border-radius:22px;flex-direction:column;justify-content:center;align-items:center;gap:7px;font-size:.76rem;display:flex}.tab-nav-button:hover{background:var(--bg);color:var(--text)}.tab-nav-button-active{color:var(--accent2);background:#fff4d9;box-shadow:inset 0 0 0 2px #f5a62333}.tab-nav-icon{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:30px;height:30px}.tab-nav-label{font-weight:900}button{cursor:pointer;border:none;font-family:inherit;font-weight:700;transition:transform .1s,opacity .1s}button:active{transform:scale(.96)}button:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-primary{background:var(--action-gradient);color:#fff;border-radius:var(--radius);width:100%;box-shadow:0 4px 0 var(--action-shadow);margin-top:12px;padding:14px 28px;font-size:1.1rem}.btn-primary:active{box-shadow:none;transform:translateY(4px)}.btn-secondary{background:var(--surface2);color:var(--text);border-radius:var(--radius);flex:1;padding:12px 24px;font-size:1rem}.btn-ghost{color:var(--text-muted);border-radius:var(--radius);background:0 0;flex:1;padding:12px 24px;font-size:1rem}.btn-play{background:var(--action-gradient);color:#fff;width:fit-content;box-shadow:0 4px 0 var(--action-shadow);border-radius:999px;align-self:center;padding:13px 22px;font-size:1rem}.btn-play:active{box-shadow:none;transform:translateY(4px)}.home-card,.placement-card,.session-card,.complete-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--surface2);padding:24px}.level-badge{color:#fff;letter-spacing:.04em;text-transform:uppercase;border-radius:999px;padding:6px 16px;font-size:.85rem;font-weight:800;display:inline-block}.level-badge.large{padding:8px 20px;font-size:1rem}.spell-input{border-radius:var(--radius);border:3px solid var(--surface2);background:var(--bg);width:100%;color:var(--text);text-align:center;letter-spacing:.08em;outline:none;padding:16px 20px;font-family:inherit;font-size:1.5rem;font-weight:700;transition:border-color .2s,transform .1s}.spell-input:focus{border-color:var(--accent2)}.spell-input.input-correct{background:#edf7ed;border-color:#4caf50;animation:.4s pulse-green}.spell-input.input-wrong{border-color:var(--accent);background:#fdeef0;animation:.35s shake}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}@keyframes pulse-green{0%{transform:scale(1)}50%{transform:scale(1.03)}to{transform:scale(1)}}.feedback-correct{color:#4caf50;text-align:center;font-size:1.4rem;font-weight:800;animation:.3s pop}.feedback-correct.large{margin-top:8px;font-size:2rem}.feedback-wrong{color:var(--accent);text-align:center;margin-top:8px;font-size:1rem}@keyframes pop{0%{opacity:0;transform:scale(.7)}70%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.progress-bar-track{background:var(--surface);border-radius:999px;width:100%;height:8px;margin-bottom:16px;overflow:hidden}.progress-bar-fill{border-radius:999px;height:100%;transition:width .4s}.score-trail,.placement-progress{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:20px;display:flex}.score-dot,.progress-dot{background:var(--surface2);border-radius:50%;width:14px;height:14px;transition:background .3s,transform .2s}.score-active,.dot-active{transform:scale(1.3);background:var(--accent2)!important}.score-pending,.dot-pending{background:var(--surface2)}.score-done,.dot-done{background:#4caf50}.syllable-display{flex-wrap:wrap;justify-content:center;align-items:center;gap:2px;margin:24px 0;display:flex}.syllable-block{color:var(--text);letter-spacing:.02em;font-size:2.8rem;font-weight:900}.syllable-dot{color:var(--accent2);margin:0 4px;font-size:2rem;font-weight:900}.heart-badge{color:var(--accent);margin-left:8px;font-size:1.6rem}.syllable-chip{background:var(--surface2);border-radius:var(--radius-sm);margin:4px;padding:8px 14px;font-size:1.6rem;font-weight:800;display:inline-block}.hint-box{border-radius:var(--radius);border:2px solid;margin-top:16px;padding:16px;animation:.3s pop}.hint-pattern{border-color:var(--accent2);background:#fef8ec}.hint-heart{border-color:var(--accent);background:#fdeef0}.hint-syllables{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:10px;display:flex}.hint-syllable-block{background:var(--bg);border-radius:var(--radius-sm);border:2px solid var(--accent2);gap:6px;padding:6px 10px;font-size:1.4rem;font-weight:800;display:inline-flex}.hint-letter-revealed{color:var(--accent2)}.hint-letter-blank{color:var(--text-muted);opacity:.5}.hint-text{color:var(--text-muted);text-align:center;font-size:.95rem;line-height:1.5}.hint-toggle{color:var(--text-muted);border-radius:var(--radius-sm);border:1px dashed var(--surface2);background:0 0;width:100%;margin-top:12px;padding:8px;font-size:.9rem}.word-clue-area{justify-content:center;align-items:center;gap:16px;margin:20px 0 8px;display:flex;position:relative}.word-illustration{filter:drop-shadow(0 4px 8px #64508c26);font-size:5rem;line-height:1;animation:.4s pop}.speak-btn-small{background:var(--surface2);border:2px solid #0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;transition:border-color .2s,background .2s,transform .1s;display:flex}.speak-btn-small:hover{border-color:var(--accent2)}.speak-btn-small-active{border-color:var(--accent2);background:#fef8ec;animation:.8s infinite pulse-speak}.word-meta{flex-direction:column;align-items:center;gap:6px;margin-bottom:16px;display:flex}@keyframes pulse-speak{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.syllable-count-hint{align-items:center;gap:8px;display:flex}.syllable-pip{background:var(--accent2);opacity:.7;border-radius:50%;width:12px;height:12px;display:inline-block}.syllable-count-label{color:var(--text-muted);font-size:.8rem;font-weight:600}.heart-word-notice{color:var(--accent);font-size:.85rem;font-weight:700}.pattern-label{color:var(--text-muted);text-align:center;letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px;font-size:.85rem;font-weight:600}.session-screen{flex-direction:column;gap:16px;width:100%;display:flex}.dashboard-shell-practice .session-screen{align-self:center;gap:18px;max-width:640px;padding-top:4px}.dashboard-shell-practice .session-card{padding:28px}.dashboard-shell-practice .progress-bar-track{align-self:center;max-width:560px;margin-bottom:4px}.dashboard-shell-practice .word-clue-area{margin:26px 0 14px}.dashboard-shell-practice .spell-input{font-size:1.7rem}.dashboard-shell-practice .score-trail,.dashboard-shell-practice .debug-panel{align-self:center;max-width:560px}.session-level-row{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.session-counter{color:var(--text-muted);font-size:.9rem;font-weight:700}.session-form{flex-direction:column;gap:10px;display:flex}.wrong-actions{gap:10px;margin-top:4px;display:flex}.placement-screen{flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:100dvh;display:flex}.placement-header{text-align:center;margin-bottom:24px}.placement-sub{color:var(--text-muted);margin-top:8px;font-size:.95rem}.placement-word-area{text-align:center;margin-bottom:24px}.placement-instruction{color:var(--text-muted);margin-bottom:12px;font-size:.9rem}.placement-syllables{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:10px;display:flex}.placement-hint-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.8rem}.placement-form{flex-direction:column;gap:12px;display:flex}.placement-card{width:100%;max-width:440px}.dashboard-shell-placement .placement-screen{justify-content:flex-start;gap:18px;min-height:auto;padding-top:8px}.dashboard-shell-placement .placement-card{max-width:640px;padding:28px}.dashboard-shell-placement .placement-header{margin-bottom:28px}.dashboard-shell-placement .placement-word-area{margin-bottom:26px}.dashboard-shell-placement .placement-form{gap:14px}.dashboard-shell-placement .spell-input{font-size:1.55rem}.dashboard-shell-placement .placement-progress{margin-top:20px}.dashboard-shell-placement .debug-panel{width:100%;max-width:640px}.home-screen{flex-direction:column;gap:20px;width:100%;padding-top:16px;display:flex}.home-header{text-align:center;margin-bottom:12px}.home-logo{letter-spacing:-.02em;background:var(--action-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.8rem;font-weight:900}.home-greeting{color:var(--text-muted);margin-top:4px;font-size:1rem}.card-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:14px;font-size:.8rem;font-weight:700}.level-description{color:var(--text-muted);min-height:3em;margin-top:10px;font-size:.9rem;line-height:1.5}.level-card{border:2px solid;align-self:stretch}.level-picker{flex-wrap:wrap;justify-content:center;gap:16px;margin-top:16px;display:flex}.level-pip{background:var(--surface2);border:2px solid #0000;border-radius:50%;width:24px;height:24px;transition:transform .15s}.level-pip:hover{transform:scale(1.15)}.level-pip-active{border-color:var(--text);transform:scale(1.15)!important}.todays-levels-card{align-self:stretch}.todays-levels-list{flex-direction:column;gap:10px;display:flex}.todays-level-item{align-items:center;gap:12px;display:flex}.todays-level-dot{border-radius:50%;flex-shrink:0;width:20px;height:20px}.todays-level-name{color:var(--text);font-size:.95rem;font-weight:600}.home-footer{color:var(--text-muted);text-align:center;margin-top:-8px;font-size:.85rem}.home-practice-hero{background:linear-gradient(135deg,#fffffff5,#fff8ecfa);border-color:#f5a62347;grid-template-columns:minmax(0,1fr) 320px;align-items:stretch;gap:22px;padding:30px;display:grid}.home-practice-copy{flex-direction:column;justify-content:flex-start;gap:18px;display:flex}.home-session-pill{color:#a56500;letter-spacing:.08em;text-transform:uppercase;background:#fef3d6;border-radius:999px;width:fit-content;padding:7px 14px;font-size:.78rem;font-weight:900}.home-practice-copy h2{color:var(--text);font-size:2.15rem;font-weight:900;line-height:1.05}.home-practice-copy p{max-width:520px;color:var(--text-muted);font-size:1rem;font-weight:700;line-height:1.5}.home-practice-hero .todays-levels-list{grid-template-columns:repeat(2,minmax(160px,1fr));gap:14px;margin-top:4px;display:grid}.home-practice-hero .todays-level-item{border:1px solid var(--surface2);background:#fff;border-radius:16px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;min-height:104px;padding:18px;display:grid;box-shadow:0 10px 26px #64508c0f}.todays-level-detail{color:var(--text-muted);margin-top:5px;font-size:.78rem;font-weight:800;line-height:1.25;display:block}.todays-level-count{color:#a56500;white-space:nowrap;background:#fef3d6;border-radius:999px;justify-self:end;padding:7px 10px;font-size:.78rem}.home-practice-action{text-align:center;background:radial-gradient(circle at 50% 24%,#f5a62338,#0000 42%),#fff;border:1px solid #f5a6233d;border-radius:24px;flex-direction:column;justify-content:center;align-items:center;gap:22px;padding:32px 22px;display:flex;box-shadow:0 16px 36px #64508c1a}.home-avatar-focus{flex-direction:column;align-items:center;gap:14px;display:flex}.home-avatar-focus .avatar-container{border-radius:30px;overflow:hidden}.home-avatar-name{color:var(--text);font-size:1.15rem;font-weight:900}.home-avatar-sub{color:var(--text-muted);margin-top:3px;font-size:.85rem;font-weight:800}.tab-placeholder-grid{grid-template-columns:1fr 1fr;gap:18px;display:grid}.tab-placeholder-card,.shopping-placeholder-card{grid-column:1/-1}.tab-placeholder-card h2,.shopping-placeholder-card h2{margin-bottom:8px;font-size:1.45rem;font-weight:900}.tab-placeholder-card p,.shopping-placeholder-card p,.tab-metric-card p{color:var(--text-muted);font-size:.95rem;line-height:1.5}.shopping-placeholder-card{align-items:center;gap:24px;display:flex}.tab-metric-card{flex-direction:column;gap:8px;display:flex}.tab-metric-card strong{color:var(--text);font-size:2rem}.tab-metric-label{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;font-size:.75rem;font-weight:900}.progress-tab{grid-template-columns:1fr 1fr;gap:18px;display:grid}.progress-week-card,.progress-reward-card,.recent-sessions-card,.level-summary-card{grid-column:1/-1}.progress-section-title{color:var(--text);margin-bottom:14px;font-size:1.1rem;font-weight:900}.progress-streak-card{min-height:156px}.recent-session-list{flex-direction:column;gap:10px;display:flex}.recent-session-row{border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--surface2);grid-template-columns:18px minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px;display:grid}.recent-session-dot{border-radius:50%;width:14px;height:14px}.recent-session-row div{flex-direction:column;gap:3px;min-width:0;display:flex}.recent-session-row strong{color:var(--text);font-size:.95rem}.recent-session-row span{color:var(--text-muted);font-size:.85rem;font-weight:700}.recent-session-score{color:var(--accent2)!important;font-weight:900!important}.empty-state-text{color:var(--text-muted);line-height:1.5}.level-summary-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.level-summary-row{border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--surface2);grid-template-columns:16px minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px;display:grid}.level-summary-color{border-radius:999px;width:14px;height:36px}.level-summary-row div{flex-direction:column;gap:3px;min-width:0;display:flex}.level-summary-row strong{color:var(--text);font-size:.92rem}.level-summary-row span{color:var(--text-muted);font-size:.82rem;font-weight:700}.level-summary-score{color:var(--accent2)!important;font-size:1rem!important;font-weight:900!important}.progress-week-card,.progress-reward-card{grid-column:auto}.progress-week-card .week-grid{min-height:90px}.progress-reward-card{justify-content:space-between}.reward-card{background:linear-gradient(#fff,#fffaf0);border-color:#f5a62373;flex-direction:column;gap:12px;display:flex}.reward-headline{color:var(--text);font-size:1.25rem;font-weight:900}.reward-meter{background:#f2e9df;border:1px solid #f5a62359;border-radius:999px;height:12px;overflow:hidden}.reward-meter-fill{border-radius:inherit;background:var(--action-gradient-horizontal);height:100%;transition:width .35s}.reward-details{color:var(--text-muted);justify-content:space-between;gap:10px;font-size:.78rem;font-weight:800;display:flex}.reward-card-compact{padding:20px 24px}.debug-panel{border-radius:var(--radius);background:#ffffff94;border:1px dashed #8878a973;margin-top:16px;padding:10px 12px}.debug-toggle{color:var(--text-muted);text-align:center;cursor:pointer;opacity:.5;font-size:.75rem;list-style:none}.debug-toggle:hover{opacity:1}.debug-actions{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.debug-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin:10px 0 4px;font-size:.7rem;font-weight:700}.debug-day-grid{flex-wrap:wrap;gap:6px;display:flex}.btn-debug{border-radius:var(--radius-sm);background:var(--surface2);color:var(--text-muted);padding:8px 6px;font-size:.75rem;font-weight:700}.btn-debug-active{outline:2px solid var(--accent2)}.btn-debug-danger{color:var(--accent)}.debug-control-row{grid-template-columns:1fr 92px;gap:8px;margin-top:6px;display:grid}.debug-field{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;flex-direction:column;gap:4px;font-size:.68rem;font-weight:800;display:flex}.debug-field select{border:2px solid var(--surface2);border-radius:var(--radius-sm);background:var(--surface);width:100%;color:var(--text);font:inherit;text-transform:none;letter-spacing:0;outline:none;padding:8px;font-size:.78rem;font-weight:800}.debug-field select:focus{border-color:var(--accent2)}.debug-state-tools{border-top:1px solid var(--surface2);margin-top:12px;padding-top:10px}.debug-checkbox{color:var(--text-muted);align-items:center;gap:8px;font-size:.76rem;font-weight:800;display:flex}.debug-checkbox input{width:16px;height:16px}.lab-banner{border-radius:var(--radius-sm);color:#386580;text-align:center;background:#eef7ff;border:2px solid #9ed0ee;width:100%;padding:10px 12px;font-size:.84rem;font-weight:800}.lab-banner-complete{margin-top:-4px}.week-grid{gap:8px;margin-bottom:12px;display:flex}.week-day{border-radius:var(--radius-sm);background:var(--bg);border:2px solid var(--surface2);flex-direction:column;flex:1;align-items:center;gap:4px;padding:8px 4px;transition:border-color .2s;display:flex}.week-day-done{background:#edf7ed;border-color:#4caf50}.week-day-today{border-color:var(--accent2)!important}.week-day-label{color:var(--text-muted);text-transform:uppercase;font-size:.7rem;font-weight:800}.week-day-icon{font-size:1rem}.week-status{color:var(--text-muted);text-align:center;font-size:.85rem}.week-section{margin-top:16px}.week-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:10px;font-size:.8rem;font-weight:700}.streak-badge{background:var(--action-gradient);color:#fff;text-align:center;border-radius:999px;margin-top:12px;padding:8px 20px;font-size:.95rem;font-weight:800;animation:.4s pop;display:inline-block}.streak-badge.inline{width:100%;margin-top:8px}.complete-screen{justify-content:center;align-items:center;width:100%;min-height:100dvh;display:flex}.dashboard-shell-complete .complete-screen{min-height:auto;padding-top:12px}.dashboard-shell-complete .complete-card{max-width:680px}.complete-card{text-align:center;flex-direction:column;gap:16px;width:100%;display:flex}.star-row{justify-content:center;gap:12px;margin-bottom:4px;display:flex}.star{font-size:2.5rem;transition:transform .2s}.star-lit{color:var(--accent2);animation:.4s pop}.star-dim{color:var(--surface2)}.complete-title{font-size:1.6rem;font-weight:900}.complete-score{color:var(--text-muted);font-size:1rem}.complete-actions{flex-direction:column;gap:12px;margin-top:8px;display:flex}.coins-earned{border:2px solid var(--accent2);border-radius:var(--radius);background:linear-gradient(135deg,#fef8ec,#fff7e0);padding:16px;animation:.4s pop}.coins-earned-row{flex-wrap:wrap;justify-content:center;gap:16px;font-size:1.1rem;font-weight:800;display:flex}.coin-pop-item{animation:.4s pop}.coin-pop-delay-1{animation-delay:.15s;animation-fill-mode:backwards}.coin-pop-delay-2{animation-delay:.3s;animation-fill-mode:backwards}.coins-total{color:var(--text-muted);margin-top:8px;font-size:.9rem;font-weight:700}.shop-home-btn{margin-top:-8px}.sidebar{flex-direction:column;flex-shrink:0;align-items:center;gap:12px;width:120px;height:100dvh;padding:20px 8px;display:flex;position:sticky;top:0}.sidebar-avatar{cursor:pointer;transition:transform .2s}.sidebar-avatar:hover{transform:scale(1.05)}.sidebar-coins{cursor:pointer;color:var(--text);align-items:center;gap:4px;font-size:.9rem;font-weight:800;transition:transform .1s;display:flex}.sidebar-coins:hover{transform:scale(1.05)}.coin-icon{font-size:1.1rem}.coin-count{font-variant-numeric:tabular-nums}.sidebar-shop-btn{background:var(--action-gradient);color:#fff;border-radius:var(--radius-sm);letter-spacing:.04em;text-transform:uppercase;text-align:center;width:100%;padding:8px 16px;font-size:.8rem;font-weight:800}@media (width<=600px){.sidebar{width:70px;padding:12px 4px}.sidebar-shop-btn{padding:6px 4px;font-size:.65rem}.sidebar-coins{font-size:.75rem}.reward-details{flex-direction:column}}@media (width<=1040px){.app-layout-dashboard{align-items:stretch;padding:18px}.dashboard-shell{grid-template-columns:104px minmax(0,1fr);min-height:calc(100dvh - 36px)}.home-practice-hero{grid-template-columns:1fr}.home-practice-action{min-height:300px}.shop-screen{grid-template-columns:260px minmax(0,1fr)}}@media (width<=760px){.app-layout-dashboard{padding:10px}.dashboard-shell{border-radius:24px;grid-template-columns:1fr;gap:18px;padding:16px}.tab-nav{flex-direction:row;justify-content:space-between;min-height:auto;padding:10px}.tab-nav-brand{display:none}.tab-nav-list{flex-direction:row}.tab-nav-button{border-radius:16px;min-height:60px}.dashboard-header{flex-direction:column;align-items:flex-start}.dashboard-header-actions{justify-content:space-between;width:100%}.dashboard-header h1{font-size:1.75rem}.account-panel{border-radius:18px}.account-form{flex-direction:column;align-items:stretch;width:100%}.account-login-row{width:100%}.account-email-input{width:100%;min-width:0}.tab-placeholder-grid,.progress-tab,.level-summary-grid{grid-template-columns:1fr}.home-practice-hero{min-height:auto;padding:22px}.home-practice-copy h2{font-size:1.7rem}.home-practice-hero .todays-levels-list{grid-template-columns:1fr}.home-practice-action{display:flex}.shop-screen{flex-direction:column;display:flex}.shop-preview{position:static}.shop-buy-bar,.shop-filters,.shop-grid{grid-area:auto}.shopping-placeholder-card{text-align:center;flex-direction:column;align-items:center}}.avatar-container{justify-content:center;align-items:center;display:flex;position:relative}.avatar-layer{object-fit:contain;width:100%;height:100%;position:absolute;top:0;left:0}.avatar-base{z-index:1}.avatar-layer:not(.avatar-base){z-index:2}.avatar-emoji-fallback{z-index:0;font-size:3rem;position:absolute}@keyframes avatar-idle{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.avatar-idle{animation:2s ease-in-out infinite avatar-idle}@keyframes avatar-jump{0%{transform:translateY(0)scale(1)}30%{transform:translateY(-20px)scale(1.05)}50%{transform:translateY(-25px)scale(1.08)}70%{transform:translateY(-10px)scale(1.03)}to{transform:translateY(0)scale(1)}}.avatar-jump{animation:.6s ease-out avatar-jump}.shop-screen{grid-template-rows:auto auto 1fr;grid-template-columns:minmax(300px,360px) minmax(0,1fr);align-items:start;gap:18px 36px;width:100%;padding-top:4px;display:grid}.shop-header{grid-column:1/-1;justify-content:space-between;align-items:center;gap:14px;display:flex}.shop-title{font-size:1.4rem;font-weight:900}.shop-balance{color:var(--text);font-size:1.1rem;font-weight:800}.shop-preview{box-shadow:none;background:0 0;border:0;border-radius:0;flex-direction:column;grid-area:1/1/span 3;justify-content:center;align-items:center;gap:18px;padding:4px 18px 0;display:flex;position:sticky;top:24px}.shop-preview .avatar-container{border-radius:38px;overflow:hidden;box-shadow:0 20px 48px #64508c24}.shop-preview-copy{text-align:center;flex-direction:column;gap:6px;display:flex}.shop-preview-copy strong{color:var(--text);font-size:1.1rem}.shop-preview-copy p,.equipped-panel p{color:var(--text-muted);font-size:.82rem;font-weight:700;line-height:1.45}.equipped-panel{border:1px solid var(--surface2);background:#fff;border-radius:18px;flex-direction:column;gap:10px;width:100%;padding:16px;display:flex;box-shadow:0 12px 28px #64508c14}.equipped-list{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.equipped-chip{color:var(--text);background:#fef8ec;border:1px solid #f5a62359;border-radius:999px;align-items:center;gap:6px;padding:7px 10px;font-size:.72rem;font-weight:900;display:inline-flex}.shop-buy-bar{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border:2px solid var(--accent2);grid-area:2/2;justify-content:space-between;align-items:center;padding:12px 16px;animation:.3s pop;display:flex}.shop-buy-name{font-size:1rem;font-weight:700}.shop-buy-btn{white-space:nowrap;width:auto;margin-top:0;padding:10px 20px;font-size:.9rem}.shop-filters{flex-wrap:wrap;grid-area:1/2;gap:8px;display:flex}.shop-filter-btn{color:var(--text-muted);border:1px solid var(--surface2);background:#fff;border-radius:999px;padding:9px 13px;font-size:.78rem;font-weight:900}.shop-filter-btn:hover,.shop-filter-btn-active{color:var(--accent2);background:#fff4d9;border-color:#f5a62373}.shop-grid{grid-area:3/2;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;display:grid}.shop-card{background:var(--surface);border-radius:var(--radius);text-align:center;cursor:pointer;border:2px solid var(--surface2);flex-direction:column;align-items:center;gap:6px;min-height:132px;padding:16px 10px;transition:border-color .2s,transform .1s;display:flex}.shop-card:hover{transform:scale(1.02)}.shop-card:active{transform:scale(.98)}.shop-card-owned{background:#f6fbf6;border-color:#4caf50}.shop-card-equipped{border-color:var(--accent2);background:#fef8ec}.shop-card-preview{border-color:var(--accent2);border-style:dashed}.shop-card-locked{opacity:.55}.shop-card-emoji{font-size:2.2rem}.shop-card-art{object-fit:contain;width:78px;height:78px;display:block}.shop-card-name{color:var(--text);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:700}.shop-card-price{color:var(--text-muted);font-size:.8rem;font-weight:800}.shop-card-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:999px;padding:2px 10px;font-size:.65rem;font-weight:800}.badge-equipped{background:var(--accent2);color:#fff}.badge-owned{color:#fff;background:#4caf50}@keyframes coin-shimmer{0%{background:0 0}20%{background:#f5a62333}to{background:0 0}}.coin-earned-shimmer{border-radius:var(--radius-sm);animation:1s ease-out coin-shimmer}
