*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#f8f7ff;--color-surface:#fff;--color-surface-alt:#f0eeff;--color-border:#ddd8f0;--color-text:#2d2640;--color-text-muted:#7b7390;--color-primary:#6c5ce7;--color-primary-hover:#5a4bd1;--color-primary-light:#ede9ff;--color-secondary:#00b894;--color-secondary-hover:#00a381;--color-correct:#00b894;--color-correct-bg:#e6fff9;--color-incorrect:#e17055;--color-incorrect-bg:#fff3f0;--color-warning:#fdcb6e;--color-warning-bg:#fffbf0;--color-danger:#d63031;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--font-base:"Segoe UI", system-ui, -apple-system, sans-serif;--font-size-sm:14px;--font-size-base:16px;--font-size-md:18px;--font-size-lg:22px;--font-size-xl:28px;--font-size-2xl:36px;--line-height:1.6;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f;--transition:.2s ease}html,body,#root{height:100%;font-family:var(--font-base);font-size:var(--font-size-base);line-height:var(--line-height);color:var(--color-text);background:var(--color-bg)}.app{flex-direction:column;max-width:640px;min-height:100vh;margin:0 auto;display:flex}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-base);font-size:var(--font-size-md);padding:12px var(--space-lg);min-width:48px;min-height:48px;transition:background var(--transition), transform var(--transition), box-shadow var(--transition);border:none;font-weight:600;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.98)}.btn:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--color-secondary);color:#fff}.btn-secondary:hover{background:var(--color-secondary-hover)}.btn-ghost{color:var(--color-primary);border:1.5px solid var(--color-border);background:0 0}.btn-ghost:hover{background:var(--color-primary-light)}.btn-large{font-size:var(--font-size-lg);padding:16px var(--space-xl);border-radius:var(--radius-lg)}.btn-small{font-size:var(--font-size-sm);padding:8px var(--space-md);min-height:36px}.btn-danger{background:var(--color-danger);color:#fff}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-icon{font-size:1.2em}.home-screen{padding:var(--space-xl) var(--space-lg);align-items:center;gap:var(--space-xl);flex-direction:column;min-height:100vh;display:flex}.home-hero{align-items:center;gap:var(--space-sm);flex-direction:column;display:flex}.home-avatar{font-size:64px;line-height:1}.home-title{font-size:var(--font-size-2xl);color:var(--color-text);text-align:center;font-weight:700}.home-subtitle{font-size:var(--font-size-md);color:var(--color-text-muted)}.home-tokens{align-items:center;gap:var(--space-sm);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-lg);font-weight:700;display:flex}.token-icon{font-size:1.4em}.token-count{color:var(--color-primary)}.token-label{color:var(--color-text-muted);font-weight:400}.home-actions{gap:var(--space-md);flex-direction:column;width:100%;display:flex}.session-preview{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);width:100%;padding:var(--space-lg)}.preview-title{font-size:var(--font-size-md);margin-bottom:var(--space-md);color:var(--color-text-muted);font-weight:600}.preview-steps{gap:var(--space-sm);flex-wrap:wrap;display:flex}.preview-step{background:var(--color-surface-alt);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);flex-direction:column;flex:1;align-items:center;gap:4px;min-width:70px;display:flex}.step-number{color:var(--color-text-muted);font-size:11px;font-weight:700}.step-icon{font-size:24px}.step-label{text-align:center;color:var(--color-text-muted);font-size:11px}.preview-reward{background:var(--color-primary-light);border:1.5px solid var(--color-primary)}.parent-link{color:var(--color-text-muted);margin-top:auto}.session-screen{flex-direction:column;min-height:100vh;padding:0;display:flex}.session-topbar{padding:var(--space-sm) var(--space-lg);background:var(--color-surface);border-bottom:1.5px solid var(--color-border);z-index:10;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.session-topbar-tokens{align-items:center;gap:var(--space-xs);color:var(--color-primary);font-weight:700;display:flex}.session-topbar-name{color:var(--color-text-muted);font-weight:600;font-size:var(--font-size-sm)}.session-map{padding:var(--space-md) var(--space-lg);background:var(--color-surface);border-bottom:1.5px solid var(--color-border)}.progress-bar-wrap{background:var(--color-border);width:100%;height:8px;margin-bottom:var(--space-sm);border-radius:4px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-secondary));border-radius:4px;height:100%;transition:width .4s}.session-map-steps{gap:var(--space-xs);flex-wrap:wrap;align-items:center;display:flex}.map-step{border-radius:var(--radius-sm);width:36px;height:36px;transition:all var(--transition);border:2px solid #0000;justify-content:center;align-items:center;font-size:18px;display:flex}.map-step--done{background:var(--color-correct-bg);border-color:var(--color-correct);color:var(--color-correct);font-size:14px;font-weight:700}.map-step--current{background:var(--color-primary-light);border-color:var(--color-primary);transform:scale(1.1)}.map-step--pending{background:var(--color-surface-alt);border-color:var(--color-border);opacity:.7}.map-step--reward{background:var(--color-primary-light);border-color:var(--color-primary);font-size:20px}.session-map-label{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-sm)}.almost-done{color:var(--color-secondary);font-weight:700}.task-engine{padding:var(--space-lg);gap:var(--space-lg);flex-direction:column;flex:1;display:flex;position:relative}.task-engine--loading{color:var(--color-text-muted);justify-content:center;align-items:center}.task-skill-badge{border-radius:var(--radius-xl);font-size:var(--font-size-sm);text-transform:capitalize;background:var(--color-primary-light);color:var(--color-primary);align-self:flex-start;padding:4px 12px;font-weight:600;display:inline-flex}.task-skill-badge[data-skill=communication]{color:#2980b9;background:#e8f4fd}.task-skill-badge[data-skill=social]{color:#c0392b;background:#fdecea}.task-skill-badge[data-skill=daily_living]{color:#1e8449;background:#e8f8f5}.task-skill-badge[data-skill=emotional_regulation]{color:#b7950b;background:#fef9e7}.task-skill-badge[data-skill=academic]{color:#7b1fa2;background:#f3e5f5}.task-step{justify-content:center;align-items:center;gap:var(--space-xl);text-align:center;padding:var(--space-lg);flex-direction:column;flex:1;animation:.25s fadeInUp;display:flex}.task-step--story{gap:var(--space-2xl)}.task-step-icon{font-size:48px;line-height:1}.story-single-sentence{font-size:var(--font-size-xl);color:var(--color-text);max-width:480px;font-weight:500;line-height:1.5;animation:.3s fadeInUp}.story-progress{gap:var(--space-sm);align-items:center;display:flex}.story-dot{background:var(--color-border);width:8px;height:8px;transition:all var(--transition);border-radius:50%}.story-dot--active{background:var(--color-primary);transform:scale(1.3)}.story-dot--done{background:var(--color-secondary)}.story-continue{width:100%;max-width:320px}.task-step--question{gap:var(--space-xl)}.stimulus-emoji-large{font-size:80px;line-height:1;animation:.2s fadeInUp}.stimulus-text-large{font-size:var(--font-size-xl);color:var(--color-text);max-width:480px;font-weight:600;line-height:1.4}.task-step--answers{justify-content:flex-start;gap:var(--space-md)}.question-reminder{align-items:center;gap:var(--space-sm);background:var(--color-surface-alt);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-sm) var(--space-md);text-align:left;width:100%;display:flex}.question-reminder-emoji{flex-shrink:0;font-size:24px}.question-reminder-text{font-size:var(--font-size-base);color:var(--color-text);font-weight:600;line-height:1.3}.task-stimulus{align-items:center;gap:var(--space-md);text-align:center;padding:var(--space-lg);background:var(--color-surface);border-radius:var(--radius-lg);border:1.5px solid var(--color-border);flex-direction:column;display:flex}.stimulus-emoji{font-size:56px;line-height:1}.stimulus-text{font-size:var(--font-size-lg);color:var(--color-text);font-weight:600;line-height:1.4}.story-narrative{background:var(--color-surface-alt);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg)}.story-icon{margin-bottom:var(--space-md);font-size:32px}.story-sentences{gap:var(--space-sm);flex-direction:column;display:flex}.story-sentence{font-size:var(--font-size-md);color:var(--color-text);line-height:1.6}@keyframes fadeInUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.story-sentence--new{animation:.3s fadeInUp}.story-next{margin-top:var(--space-md);align-self:flex-end}.story-done-cue{margin-top:var(--space-md);font-size:var(--font-size-sm);color:var(--color-text-muted);font-style:italic}.hint-display{align-items:flex-start;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);border-left:4px solid;animation:.25s fadeInUp;display:flex}.hint-display--indirect{border-color:var(--color-warning);background:#fffbf0}.hint-display--direct{background:#e8f4fd;border-color:#3498db}.hint-display--gestural{background:#f3e5f5;border-color:#9b59b6}.hint-display--model{background:var(--color-correct-bg);border-color:var(--color-correct)}.hint-icon{flex-shrink:0;font-size:24px}.hint-content{flex-direction:column;gap:2px;display:flex}.hint-label{font-size:var(--font-size-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:700}.hint-text{font-size:var(--font-size-md);color:var(--color-text)}.answer-options{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.answer-option{align-items:center;gap:var(--space-sm);padding:var(--space-md);border-radius:var(--radius-lg);border:2.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;font-family:var(--font-base);font-size:var(--font-size-base);text-align:center;min-height:80px;transition:all var(--transition);flex-direction:column;display:flex;position:relative}.answer-option:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.answer-option:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}.answer-option--selected{border-color:var(--color-primary);background:var(--color-primary-light)}.answer-option--correct{border-color:var(--color-correct);background:var(--color-correct-bg);cursor:default}.answer-option--incorrect{border-color:var(--color-incorrect);background:var(--color-incorrect-bg);cursor:default}.option-emoji{font-size:32px}.option-label{font-size:var(--font-size-base);font-weight:500}.option-state-icon{font-size:18px;font-weight:700;position:absolute;top:8px;right:8px}.answer-option--correct .option-state-icon{color:var(--color-correct)}.answer-option--incorrect .option-state-icon{color:var(--color-incorrect)}.feedback-overlay{padding:var(--space-lg);z-index:100;background:#2d2640b3;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.feedback-content{background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) var(--radius-lg) var(--radius-lg);padding:var(--space-xl);align-items:center;gap:var(--space-md);width:100%;max-width:480px;box-shadow:var(--shadow-lg);flex-direction:column;display:flex}.feedback-overlay--correct .feedback-content{border-top:4px solid var(--color-correct)}.feedback-overlay--incorrect .feedback-content{border-top:4px solid var(--color-warning)}.feedback-overlay--penalty .feedback-content{border-top:4px solid var(--color-incorrect)}.feedback-icon{font-size:56px}.feedback-title{font-size:var(--font-size-xl);font-weight:700}.feedback-reinforcer{font-size:var(--font-size-base);color:var(--color-text-muted);text-align:center}.feedback-tokens{align-items:center;gap:var(--space-sm);font-size:var(--font-size-lg);font-weight:700;display:flex}.feedback-tokens--gain{color:var(--color-correct)}.feedback-tokens--penalty{color:var(--color-incorrect)}.feedback-free-miss{font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center;font-style:italic}.token-earned-icon{font-size:1.4em}.transition-warning{background:var(--color-warning-bg);border:1.5px solid var(--color-warning);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);font-size:var(--font-size-base);text-align:center;width:100%}.transition-warning--final{background:var(--color-primary-light);border-color:var(--color-primary);font-weight:700}.feedback-next{width:100%;margin-top:var(--space-sm)}.open-world{padding:var(--space-lg);gap:var(--space-xl);flex-direction:column;min-height:100vh;display:flex}.world-header{justify-content:space-between;align-items:center;display:flex}.world-title{font-size:var(--font-size-xl);font-weight:700}.world-tokens{align-items:center;gap:var(--space-sm);color:var(--color-primary);background:var(--color-primary-light);border-radius:var(--radius-xl);padding:6px var(--space-md);font-weight:700;display:flex}.world-intro{color:var(--color-text-muted);font-size:var(--font-size-md)}.world-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));display:grid}.world-item{align-items:center;gap:var(--space-sm);padding:var(--space-md);border-radius:var(--radius-lg);border:1.5px solid var(--color-border);background:var(--color-surface);transition:all var(--transition);flex-direction:column;display:flex}.world-item--unlocked{border-color:var(--color-correct);background:var(--color-correct-bg)}.world-item--affordable{border-color:var(--color-primary)}.world-item--locked{opacity:.7}.world-item-emoji{font-size:48px}.world-item-label{text-align:center;font-weight:600}.world-item-ready{font-size:var(--font-size-sm);color:var(--color-correct);font-weight:700}.world-actions{gap:var(--space-md);flex-direction:column;display:flex}.dashboard-lock{min-height:100vh;padding:var(--space-lg);justify-content:center;align-items:center;display:flex}.dashboard-lock-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-2xl);gap:var(--space-lg);width:100%;max-width:360px;box-shadow:var(--shadow-lg);flex-direction:column;align-items:center;display:flex}.dashboard-lock-card h1{font-size:var(--font-size-xl)}.pin-form{gap:var(--space-md);flex-direction:column;align-items:center;width:100%;display:flex}.pin-input{text-align:center;width:160px;font-size:var(--font-size-xl);padding:var(--space-md);border:2px solid var(--color-border);border-radius:var(--radius-md);letter-spacing:8px}.pin-input--error{border-color:var(--color-danger)}.pin-error{color:var(--color-danger);font-size:var(--font-size-sm)}.parent-dashboard{flex-direction:column;min-height:100vh;display:flex}.dashboard-header{padding:var(--space-lg);background:var(--color-surface);border-bottom:1.5px solid var(--color-border);gap:var(--space-sm);flex-direction:column;display:flex}.dashboard-header h1{font-size:var(--font-size-xl);font-weight:700}.dashboard-child-name{color:var(--color-text-muted)}.dashboard-tabs{border-bottom:1.5px solid var(--color-border);background:var(--color-surface);display:flex}.dashboard-tab{padding:var(--space-md);cursor:pointer;font-size:var(--font-size-base);color:var(--color-text-muted);transition:all var(--transition);background:0 0;border:none;border-bottom:3px solid #0000;flex:1;font-weight:600}.dashboard-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.dashboard-panel{padding:var(--space-lg);overflow-y:auto}.data-panel{gap:var(--space-xl);flex-direction:column;display:flex}.data-panel--empty{padding:var(--space-xl);text-align:center;color:var(--color-text-muted)}.data-section{gap:var(--space-md);flex-direction:column;display:flex}.data-section h2{font-size:var(--font-size-lg);font-weight:700}.data-note{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.6}.data-summary-row{gap:var(--space-md);display:flex}.data-stat{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.stat-value{font-size:var(--font-size-xl);color:var(--color-primary);font-weight:700}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.skill-data-grid{gap:var(--space-md);flex-direction:column;display:flex}.skill-data-card{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);gap:var(--space-sm);flex-direction:column;display:flex}.skill-data-header{align-items:center;gap:var(--space-sm);display:flex}.skill-icon{font-size:20px}.skill-name{flex:1;font-weight:600}.skill-difficulty{font-size:var(--font-size-sm);color:var(--color-text-muted)}.skill-data-stats{gap:var(--space-md);display:flex}.skill-stat{background:var(--color-surface-alt);border-radius:var(--radius-sm);padding:var(--space-sm);flex-direction:column;flex:1;align-items:center;display:flex}.skill-stat-value{font-size:var(--font-size-md);font-weight:700}.skill-stat-label{color:var(--color-text-muted);font-size:11px}.accuracy-bar-wrap{background:var(--color-border);border-radius:4px;height:8px;overflow:hidden}.accuracy-bar-fill{border-radius:4px;height:100%;transition:width .4s}.fill--good{background:var(--color-correct)}.fill--moderate{background:var(--color-warning)}.fill--needs-support{background:var(--color-incorrect)}.prompt-breakdown{gap:var(--space-xs);flex-wrap:wrap;align-items:center;display:flex}.prompt-breakdown-title{font-size:var(--font-size-sm);color:var(--color-text-muted)}.prompt-pill{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:2px 8px;font-size:11px}.trial-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.trial-table th,.trial-table td{padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:1px solid var(--color-border)}.trial-table th{color:var(--color-text-muted);background:var(--color-surface-alt);font-weight:700}.trial-row--correct td:nth-child(2){color:var(--color-correct)}.trial-row--incorrect td:nth-child(2){color:var(--color-incorrect)}.data-disclaimer{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md);font-size:var(--font-size-sm);color:var(--color-text-muted)}.config-panel{gap:var(--space-xl);flex-direction:column;display:flex}.config-section{gap:var(--space-md);flex-direction:column;display:flex}.config-section h2{font-size:var(--font-size-lg);font-weight:700}.config-section--danger{border-top:2px solid var(--color-danger);padding-top:var(--space-lg)}.config-field{gap:var(--space-xs);flex-direction:column;display:flex}.config-field--toggle{align-items:flex-start;gap:var(--space-md);flex-flow:wrap}.config-field--row{gap:var(--space-lg);flex-direction:row}.config-field--row>div{gap:var(--space-xs);flex-direction:column;flex:1;display:flex}.config-field label{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:600}.config-input,.config-select{padding:10px var(--space-md);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:var(--font-base);color:var(--color-text);background:var(--color-surface)}.config-range{width:100%;accent-color:var(--color-primary)}.config-range-value{font-size:var(--font-size-sm);color:var(--color-primary);font-weight:700}.config-checkbox{width:20px;height:20px;accent-color:var(--color-primary);flex-shrink:0;margin-top:2px}.config-note{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.6}.skill-config-card{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);gap:var(--space-md);flex-direction:column;display:flex}.skill-config-header{justify-content:space-between;align-items:center;display:flex}.skill-config-name{font-weight:600;font-size:var(--font-size-md)}.toggle-label{align-items:center;gap:var(--space-sm);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:600;display:flex}.skill-config-fields{gap:var(--space-md);flex-direction:column;display:flex}.onboarding{min-height:100vh;padding:var(--space-lg);background:var(--color-bg);justify-content:center;align-items:center;display:flex}.onboarding-step{align-items:center;gap:var(--space-xl);text-align:center;flex-direction:column;width:100%;max-width:420px;animation:.3s fadeInUp;display:flex}.onboarding-icon{font-size:72px;line-height:1}.onboarding-title{font-size:var(--font-size-2xl);font-weight:700}.onboarding-body{font-size:var(--font-size-md);color:var(--color-text-muted);line-height:1.6}.onboarding-btn{width:100%}.onboarding-error{color:var(--color-danger);font-size:var(--font-size-sm)}.onboarding-input{width:100%;padding:var(--space-md) var(--space-lg);font-size:var(--font-size-xl);text-align:center;border:2.5px solid var(--color-border);border-radius:var(--radius-lg);font-family:var(--font-base);color:var(--color-text);background:var(--color-surface)}.onboarding-input:focus{outline:3px solid var(--color-primary);border-color:var(--color-primary)}.onboarding-input--error{border-color:var(--color-danger)}.avatar-grid{gap:var(--space-md);grid-template-columns:repeat(4,1fr);width:100%;display:grid}.avatar-option{padding:var(--space-md);border-radius:var(--radius-lg);border:2.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;transition:all var(--transition);aspect-ratio:1;justify-content:center;align-items:center;font-size:36px;display:flex}.avatar-option:hover{border-color:var(--color-primary);transform:scale(1.05)}.avatar-option--selected{border-color:var(--color-primary);background:var(--color-primary-light);transform:scale(1.1)}.onboarding-preview{gap:var(--space-md);flex-wrap:wrap;justify-content:center;display:flex}.onboarding-preview-item{align-items:center;gap:var(--space-xs);background:var(--color-surface-alt);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);color:var(--color-text-muted);flex-direction:column;display:flex}.onboarding-preview-item span:first-child{font-size:28px}.home-reward-card{background:var(--color-surface);border:2px solid var(--color-primary);border-radius:var(--radius-lg);width:100%;padding:var(--space-md) var(--space-lg);gap:var(--space-sm);flex-direction:column;display:flex}.home-reward-card--earned{border-color:var(--color-correct);background:var(--color-correct-bg)}.home-reward-header{align-items:center;gap:var(--space-md);display:flex}.home-reward-emoji{flex-shrink:0;font-size:36px}.home-reward-name{font-weight:700;font-size:var(--font-size-md)}.home-reward-sub{font-size:var(--font-size-sm);color:var(--color-text-muted)}.home-reward-earned-badge{color:var(--color-correct);font-weight:700;font-size:var(--font-size-sm);margin-left:auto}.home-reward-bar-wrap{background:var(--color-border);border-radius:5px;height:10px;overflow:hidden}.home-reward-bar-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-secondary));border-radius:5px;height:100%;transition:width .6s}.reward-celebration{padding:var(--space-lg);z-index:200;background:linear-gradient(135deg,#6c5ce7,#00b894);justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.celebration-content{align-items:center;gap:var(--space-xl);text-align:center;flex-direction:column;max-width:400px;display:flex}.celebration-emoji{font-size:96px;line-height:1;animation:.5s bounceIn}.celebration-title{font-size:var(--font-size-2xl);color:#fff;font-weight:700}.celebration-reward-name{font-size:var(--font-size-xl);color:#fff;border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);background:#fff3;font-weight:700}.celebration-subtitle{font-size:var(--font-size-md);color:#ffffffe6;line-height:1.6}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.reward-panel{gap:var(--space-xl);flex-direction:column;display:flex}.reward-card{background:var(--color-surface);border:2px solid var(--color-primary);border-radius:var(--radius-lg);padding:var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex}.reward-card--earned{border-color:var(--color-correct);background:var(--color-correct-bg)}.reward-card-header{align-items:flex-start;gap:var(--space-md);display:flex}.reward-emoji{flex-shrink:0;font-size:40px}.reward-card-info{flex-direction:column;gap:4px;display:flex}.reward-name{font-size:var(--font-size-md);font-weight:700}.reward-target-desc{font-size:var(--font-size-sm);color:var(--color-text-muted)}.reward-progress-wrap{gap:var(--space-xs);flex-direction:column;display:flex}.reward-progress-bar{background:var(--color-border);border-radius:5px;height:10px;overflow:hidden}.reward-progress-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-secondary));border-radius:5px;height:100%;transition:width .6s}.reward-progress-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.reward-earned-banner{justify-content:space-between;align-items:center;gap:var(--space-md);background:var(--color-correct-bg);border:1.5px solid var(--color-correct);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);color:var(--color-correct);flex-wrap:wrap;font-weight:600;display:flex}.reward-delivered-banner{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);color:var(--color-text-muted)}.reward-builder{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);gap:var(--space-lg);flex-direction:column;display:flex}.reward-builder h3{font-size:var(--font-size-lg);font-weight:700}.reward-builder-actions{gap:var(--space-md);display:flex}.emoji-picker{gap:var(--space-sm);flex-wrap:wrap;display:flex}.emoji-option{padding:var(--space-sm);border-radius:var(--radius-md);border:2px solid var(--color-border);background:var(--color-surface);cursor:pointer;transition:all var(--transition);justify-content:center;align-items:center;min-width:44px;min-height:44px;font-size:24px;display:flex}.emoji-option:hover{border-color:var(--color-primary);transform:scale(1.1)}.emoji-option--selected{border-color:var(--color-primary);background:var(--color-primary-light)}.config-input--error{border-color:var(--color-danger)}.chart-container{gap:var(--space-lg);flex-direction:column;display:flex}.chart-skill-row{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-md);gap:var(--space-sm);flex-direction:column;display:flex}.chart-skill-header{align-items:center;gap:var(--space-sm);display:flex}.chart-skill-name{flex:1;font-weight:600}.chart-skill-level{font-size:var(--font-size-sm);color:var(--color-text-muted)}.chart-bar-row{align-items:center;gap:var(--space-sm);display:flex}.chart-bar-track{background:var(--color-border);border-radius:6px;flex:1;height:12px;overflow:hidden}.chart-bar-fill{border-radius:6px;height:100%;transition:width .6s}.chart-bar-label{font-size:var(--font-size-sm);text-align:right;width:36px;font-weight:700}.chart-skill-meta{gap:var(--space-md);color:var(--color-text-muted);flex-wrap:wrap;font-size:11px;display:flex}.sparkline{align-items:flex-end;gap:3px;height:40px;display:flex}.sparkline-bar{background:var(--color-primary);opacity:.6;border-radius:2px 2px 0 0;flex:1;min-width:6px;transition:height .4s}.coins-chart{align-items:flex-end;gap:var(--space-sm);height:100px;padding:var(--space-sm) 0;display:flex}.coins-bar-wrap{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:4px;height:100%;display:flex}.coins-bar{background:linear-gradient(180deg, var(--color-primary), var(--color-secondary));border-radius:4px 4px 0 0;width:100%;min-height:4px;transition:height .4s}.coins-bar-value{color:var(--color-primary);font-size:10px;font-weight:700}.coins-bar-label{color:var(--color-text-muted);font-size:10px}.location-scene{background:var(--scene-bg,var(--color-surface-alt));flex-direction:column;min-height:100vh;display:flex}.scene-header{padding:var(--space-sm) var(--space-lg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1.5px solid var(--color-border);z-index:10;background:#ffffffb3;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.scene-title{font-size:var(--font-size-md);font-weight:700}.scene-body{justify-content:center;align-items:center;gap:var(--space-xl);padding:var(--space-xl) var(--space-lg);text-align:center;flex-direction:column;flex:1;animation:.25s fadeInUp;display:flex}.scene-npc-bubble{align-items:flex-start;gap:var(--space-md);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-lg);text-align:left;max-width:420px;box-shadow:var(--shadow-md);display:flex}.scene-npc-emoji{flex-shrink:0;font-size:48px;line-height:1}.scene-npc-content{gap:var(--space-xs);flex-direction:column;display:flex}.scene-npc-name{font-size:var(--font-size-sm);color:var(--color-primary);font-weight:700}.scene-npc-line{font-size:var(--font-size-md);color:var(--color-text);line-height:1.5;animation:.2s fadeInUp}.scene-dots{gap:var(--space-sm);display:flex}.scene-dot{background:var(--color-border);width:8px;height:8px;transition:all var(--transition);border-radius:50%}.scene-dot--active{background:var(--color-primary);transform:scale(1.3)}.scene-dot--done{background:var(--color-secondary)}.scene-activity-prompt{font-size:var(--font-size-lg);color:var(--color-text);font-weight:600}.scene-activity-options{gap:var(--space-md);flex-direction:column;width:100%;max-width:360px;display:flex}.scene-activity-option{align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;font-size:var(--font-size-md);font-weight:600;font-family:var(--font-base);transition:all var(--transition);min-height:56px;display:flex}.scene-activity-option:hover{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.scene-activity-option:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}.scene-option-emoji{flex-shrink:0;font-size:28px}.scene-option-label{text-align:left;flex:1}.scene-response-actions{gap:var(--space-md);flex-direction:column;width:100%;max-width:320px;display:flex}.reading-lock{gap:var(--space-xs);flex-direction:column;display:flex}.reading-lock-bar-wrap{background:var(--color-border);border-radius:3px;width:100%;height:6px;overflow:hidden}.reading-lock-bar-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-secondary));border-radius:3px;height:100%;transition:width 1s linear}.reading-lock-label{font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center}.answer-options--locked{pointer-events:none}.answer-option--dimmed{opacity:.45;cursor:not-allowed;filter:grayscale(30%)}.reread-nudge{align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--color-warning-bg);border:2px solid var(--color-warning);border-radius:var(--radius-lg);animation:.25s fadeInUp;display:flex}.reread-nudge-icon{flex-shrink:0;font-size:28px}.reread-nudge-text{flex-direction:column;flex:1;gap:2px;display:flex}.reread-nudge-text strong{font-size:var(--font-size-md);color:var(--color-text)}.reread-nudge-text span{font-size:var(--font-size-sm);color:var(--color-text-muted)}.reread-btn{white-space:nowrap;flex-shrink:0}@media (width<=480px){.answer-options{grid-template-columns:1fr}.preview-steps{gap:4px}.preview-step{min-width:52px;padding:var(--space-xs)}.skill-data-stats,.data-summary-row{gap:var(--space-sm)}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
