*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #FDF6F0;--card-bg: #FFFFFF;--card-border: #B8C4D0;--card-border-hover: #8FA3B4;--shapes: #FCE4EE;--colours: #FFF3D4;--numbers: #D8F2E8;--letters: #E4E0FF;--primary: #5C50A8;--muted: #9B90C8;--heading: #3D3578;--danger: #D94F5C;--radius: 16px;--radius-sm: 10px}html,body{font-family:Quicksand,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:#333;height:100dvh;overflow:hidden;position:fixed;width:100%;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;overscroll-behavior:none}#root{height:100dvh;overflow:hidden}h1,h2,h3{color:var(--heading);font-weight:700}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border:2px solid var(--card-border);border-radius:var(--radius-sm);background:var(--card-bg);font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;color:#333}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:active{background:#4a3f8f}.btn-large{padding:16px 32px;font-size:18px;width:100%;border-radius:var(--radius)}.btn-small{padding:6px 14px;font-size:13px}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-google{display:flex;align-items:center;justify-content:center;width:100%;padding:14px;font-size:16px;font-weight:600}.btn-guest{width:100%;background:var(--bg);border-color:var(--card-border);color:var(--muted);font-weight:600}.btn-link{background:none;border:none;color:var(--primary);cursor:pointer;font-size:14px;font-weight:600;text-decoration:underline;padding:0}.icon-btn{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--card-bg);border:2px solid var(--card-border);cursor:pointer;color:var(--heading);flex-shrink:0}.input{width:100%;padding:14px 16px;border:2px solid var(--card-border);border-radius:var(--radius-sm);font-size:16px;background:var(--card-bg);transition:border-color .2s;color:#333}.input:focus{outline:none;border-color:var(--primary)}input,textarea{-webkit-user-select:text;user-select:text}.input-large{font-size:20px;padding:16px 20px;text-align:center}select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239B90C8' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}.long-press-btn{position:relative;touch-action:none;-webkit-user-select:none;user-select:none}.long-press-ring{position:absolute;width:160px;height:160px;top:50%;left:50%;margin-top:-80px;margin-left:-80px;border-radius:50%;background:#5c50a840;pointer-events:none;z-index:-1;transform-origin:center}.long-press-hint{position:absolute;left:50%;transform:translate(-50%);background:var(--heading);color:#fff;padding:4px 10px;border-radius:6px;font-size:12px;white-space:nowrap;z-index:100;top:calc(100% + 8px)}.long-press-hint.long-press-hint-above{top:auto;bottom:calc(100% + 8px)}.loading-page{display:flex;align-items:center;justify-content:center;height:100dvh;color:var(--muted);font-size:18px;overflow:hidden}.desktop-splash-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.desktop-splash-card{background:var(--card-bg);border-radius:var(--radius);padding:40px;max-width:420px;text-align:center}.desktop-splash-card h2{margin-bottom:12px}.desktop-splash-card p{margin-bottom:24px;color:#666;line-height:1.5}.login-page{display:flex;align-items:center;justify-content:center;height:100dvh;padding:24px;overflow:hidden}.login-card{background:var(--card-bg);border-radius:var(--radius);padding:40px 32px;width:100%;max-width:400px;text-align:center;box-shadow:0 2px 20px #0000000f}.login-title{font-size:28px;margin-bottom:8px}.login-subtitle{color:var(--muted);margin-bottom:28px;font-size:15px}.login-divider{display:flex;align-items:center;margin:20px 0;color:var(--muted);font-size:13px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--card-border)}.login-divider span{padding:0 12px}.login-form{display:flex;flex-direction:column;gap:12px}.login-error{color:var(--danger);font-size:14px;margin-top:12px}.login-message{color:#2a9d4e;font-size:14px;margin-top:12px}.guest-note{color:var(--muted);font-size:12px;margin-top:8px}.guest-banner{background:#fff3d4;padding:10px 16px;text-align:center;font-size:13px;color:#6b5a00;border-bottom:1px solid #e8d9a0}.onboarding-page{height:100dvh;display:flex;flex-direction:column;align-items:center;padding:40px 24px;overflow-y:auto;-webkit-overflow-scrolling:touch}.onboarding-progress{display:flex;gap:8px;margin-bottom:32px}.progress-dot{width:10px;height:10px;border-radius:50%;background:var(--card-border);transition:background .3s}.progress-dot-active{background:var(--primary)}.onboarding-content{width:100%;max-width:480px}.onboarding-step{display:flex;flex-direction:column;align-items:center;gap:24px;text-align:center}.onboarding-step h1{font-size:26px}.onboarding-step h2{font-size:22px}.onboarding-desc{color:var(--muted);font-size:15px}.onboarding-philosophy{display:flex;flex-direction:column;gap:20px;text-align:left;width:100%}.philosophy-item{display:flex;gap:14px;align-items:flex-start}.philosophy-icon{font-size:24px;color:var(--primary);flex-shrink:0;width:32px;text-align:center}.philosophy-item strong{display:block;margin-bottom:4px;color:var(--heading)}.philosophy-item p{font-size:14px;color:#666;line-height:1.5}.mode-cards{display:flex;flex-direction:column;gap:12px;width:100%;align-items:stretch}.mode-card{background:var(--card-bg);border:2px solid var(--card-border);border-radius:var(--radius);padding:20px;text-align:left;cursor:pointer;transition:border-color .2s;width:100%}.mode-card h3{margin-bottom:6px;font-size:18px}.mode-card p{font-size:14px;color:#666;line-height:1.5}.mode-card-selected{border-color:var(--primary);background:#f4f2ff}.mode-badge{display:inline-block;background:var(--letters);color:var(--primary);font-size:11px;font-weight:700;padding:2px 8px;border-radius:6px;margin-bottom:6px}.age-selectors{display:flex;gap:12px;width:100%}.select-group{flex:1;text-align:left}.select-group label{display:block;font-size:13px;font-weight:600;color:var(--heading);margin-bottom:6px}.home-page{height:100dvh;max-width:600px;margin:0 auto;display:flex;flex-direction:column;overflow:hidden}.home-header{display:flex;align-items:center;justify-content:space-between;padding:16px;gap:12px;border-bottom:1px solid var(--card-border);background:var(--card-bg);position:sticky;top:0;z-index:20}.category-dropdown-trigger{flex:1;display:flex;align-items:center;justify-content:center;padding:10px 16px;border:2px solid var(--card-border);border-radius:var(--radius-sm);background:var(--card-bg);font-size:16px;font-weight:600;color:var(--heading);cursor:pointer}.category-dropdown{position:sticky;top:81px;z-index:15;background:var(--card-bg);border-bottom:1px solid var(--card-border);padding:12px 16px;display:flex;flex-direction:column;gap:8px}.category-option{padding:14px 18px;border:2px solid var(--card-border);border-radius:var(--radius-sm);font-size:16px;font-weight:600;cursor:pointer;text-align:center;background:var(--card-bg);display:flex;align-items:center;justify-content:center;gap:8px}.category-option-active{border-color:var(--primary)}.category-option-disabled{opacity:.6;cursor:default}.coming-soon-badge{font-size:11px;background:var(--colours);color:#6b5a00;padding:2px 8px;border-radius:6px;font-weight:600}.lesson-list{padding:16px;display:flex;flex-direction:column;gap:12px;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.lesson-card{display:flex;align-items:center;gap:14px;background:var(--card-bg);border:2px solid var(--card-border);border-radius:var(--radius);padding:16px;transition:border-color .2s}.lesson-card:active{border-color:var(--card-border-hover)}.lesson-card-not-started{opacity:.6}.lesson-number{width:44px;height:44px;border-radius:50%;background:var(--heading);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}.lesson-info{flex:1;display:flex;flex-direction:column}.lesson-name{font-weight:600;font-size:16px;color:var(--heading)}.lesson-mode{font-size:13px;color:var(--muted);text-transform:capitalize}.lesson-progress-badge{background:var(--numbers);color:#1a6b3a;font-size:13px;font-weight:700;padding:4px 10px;border-radius:8px}.lesson-not-started-badge{background:var(--bg);color:var(--muted);font-size:12px;font-weight:600;padding:4px 10px;border-radius:8px;border:1px solid var(--card-border)}.coming-soon-message{text-align:center;padding:40px 20px;color:var(--muted)}.coming-soon-message h3{margin-bottom:8px;color:var(--heading)}.lesson-page{height:100dvh;display:flex;flex-direction:column;max-width:700px;margin:0 auto;overflow:hidden}.lesson-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;gap:12px;position:relative;z-index:60}.page-title{font-size:20px;text-align:center;flex:1}.lesson-counter{font-size:14px;color:var(--muted);font-weight:600}.lesson-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 12px;position:relative;z-index:60}.shape-display{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%}.shape-label{font-size:32px;color:var(--heading)}.shape-hint{font-size:14px;color:var(--muted)}.shape-glow{padding:16px}.lesson-page-glow{position:relative}.lesson-page-glow:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:50;border:4px solid transparent;border-radius:0;background:conic-gradient(from var(--glow-angle, 0deg) at 50% 50%,rgba(92,80,168,0) 0%,rgba(92,80,168,.5) 10%,rgba(228,224,255,.8) 15%,rgba(252,228,238,.6) 25%,rgba(92,80,168,0) 35%,rgba(92,80,168,0) 50%,rgba(216,242,232,.6) 60%,rgba(228,224,255,.8) 65%,rgba(92,80,168,.5) 70%,rgba(92,80,168,0) 80%,rgba(255,243,212,.6) 90%,rgba(92,80,168,0) 100%) border-box;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;padding:5px;animation:glowRotate 4s linear infinite,glowPulse 2s ease-in-out infinite}.lesson-page-glow:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:51;background-image:radial-gradient(2px 2px at 10% 5%,rgba(255,255,255,.9) 50%,transparent 100%),radial-gradient(2px 2px at 25% 2%,rgba(228,224,255,.8) 50%,transparent 100%),radial-gradient(3px 3px at 50% 1%,rgba(255,255,255,.9) 50%,transparent 100%),radial-gradient(2px 2px at 75% 3%,rgba(252,228,238,.8) 50%,transparent 100%),radial-gradient(2px 2px at 90% 6%,rgba(255,255,255,.9) 50%,transparent 100%),radial-gradient(2px 2px at 95% 30%,rgba(228,224,255,.8) 50%,transparent 100%),radial-gradient(3px 3px at 97% 50%,rgba(255,255,255,.9) 50%,transparent 100%),radial-gradient(2px 2px at 95% 70%,rgba(216,242,232,.8) 50%,transparent 100%),radial-gradient(2px 2px at 90% 94%,rgba(255,255,255,.9) 50%,transparent 100%),radial-gradient(3px 3px at 70% 98%,rgba(255,243,212,.8) 50%,transparent 100%),radial-gradient(2px 2px at 50% 99%,rgba(255,255,255,.9) 50%,transparent 100%),radial-gradient(2px 2px at 30% 97%,rgba(228,224,255,.8) 50%,transparent 100%),radial-gradient(2px 2px at 10% 95%,rgba(255,255,255,.9) 50%,transparent 100%),radial-gradient(3px 3px at 3% 70%,rgba(252,228,238,.8) 50%,transparent 100%),radial-gradient(2px 2px at 2% 50%,rgba(255,255,255,.9) 50%,transparent 100%),radial-gradient(2px 2px at 5% 30%,rgba(216,242,232,.8) 50%,transparent 100%);animation:glowStars 3s ease-in-out infinite}@keyframes glowRotate{to{--glow-angle: 360deg}}@keyframes glowPulse{0%,to{opacity:.7}50%{opacity:1}}@keyframes glowStars{0%,to{opacity:.4}50%{opacity:1}}@property --glow-angle{syntax: "<angle>"; initial-value: 0deg; inherits: false;}.lesson-controls{display:flex;justify-content:center;gap:24px;padding:12px;padding-bottom:max(12px,env(safe-area-inset-bottom));position:relative;z-index:60}.super-tick-area{position:absolute;left:12px;bottom:max(12px,env(safe-area-inset-bottom))}.control-super-tick{width:44px!important;height:44px!important;min-width:44px!important;min-height:44px!important;border-radius:10px!important;background:#e4e0ff!important;border-color:#9b90c8!important;opacity:.7}.control-super-tick:hover{opacity:1}.control-btn{width:80px;height:80px;border-radius:20px;display:flex;align-items:center;justify-content:center;border:2px solid var(--card-border);background:var(--card-bg);cursor:pointer;color:var(--heading);position:relative;overflow:hidden;touch-action:none;-webkit-user-select:none;user-select:none}.control-tick{border-color:#2a9d4e;color:#2a9d4e}.control-dot{border-color:var(--muted);color:var(--muted)}.control-arrow{border-color:var(--primary);color:var(--primary)}.control-disabled{opacity:.3;cursor:default}.lesson-complete-page{height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:24px;text-align:center;overflow:hidden}.settings-page{height:100dvh;max-width:600px;margin:0 auto;overflow-y:auto;-webkit-overflow-scrolling:touch}.settings-content{padding:24px 16px}.settings-profile-name{font-size:16px;color:var(--muted);margin-bottom:24px;text-align:center}.setting-group{margin-bottom:24px}.setting-label{display:block;font-size:14px;font-weight:700;color:var(--heading);margin-bottom:10px}.setting-options{display:flex;gap:10px;align-items:stretch}.setting-option{flex:1;padding:14px;border:2px solid var(--card-border);border-radius:var(--radius-sm);background:var(--card-bg);cursor:pointer;font-size:15px;font-weight:600;text-align:center}.setting-option-active{border-color:var(--primary);background:#f4f2ff}.setting-rec{display:block;font-size:11px;color:var(--muted);font-weight:400;margin-top:4px}.age-group-display{padding:14px;background:var(--bg);border-radius:var(--radius-sm);font-weight:600;color:var(--heading);display:flex;align-items:center}.profiles-page{height:100dvh;max-width:600px;margin:0 auto;overflow-y:auto;-webkit-overflow-scrolling:touch}.profiles-list{padding:16px;display:flex;flex-direction:column;gap:10px}.profile-card{display:flex;align-items:center;background:var(--card-bg);border:2px solid var(--card-border);border-radius:var(--radius);overflow:hidden}.profile-card-active{border-color:var(--primary)}.profile-card-main{flex:1;display:flex;align-items:center;gap:12px;padding:14px 16px;background:none;border:none;cursor:pointer;text-align:left}.profile-avatar{width:40px;height:40px;border-radius:50%;background:var(--letters);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}.profile-details{flex:1;display:flex;flex-direction:column}.profile-details strong{color:var(--heading);font-size:16px}.profile-age{font-size:13px;color:var(--muted)}.profile-active-badge{background:var(--numbers);color:#1a6b3a;font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px}.profile-delete-btn{padding:14px;background:none;border:none;border-left:1px solid var(--card-border);cursor:pointer;color:var(--muted)}.profile-delete-btn:hover{color:var(--danger)}.profile-delete-confirm{display:flex;align-items:center;gap:8px;padding:8px 12px;border-left:1px solid var(--card-border);font-size:13px;color:var(--danger);font-weight:600}.add-profile-btn{margin:16px;width:calc(100% - 32px)}.add-profile-form{padding:24px 16px;display:flex;flex-direction:column;gap:14px}.add-profile-form h3{text-align:center}.add-profile-actions{display:flex;gap:10px}.add-profile-actions .btn{flex:1}@media(min-width:768px){.mode-cards{flex-direction:row;align-items:stretch}.mode-card{flex:1;display:flex;flex-direction:column}.setting-options{align-items:stretch}.setting-option{display:flex;flex-direction:column;align-items:center;justify-content:flex-start}}.phonics-display{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.phonics-letter{font-size:120px;font-weight:800;color:var(--heading);line-height:1}.phonics-capital{font-size:80px;color:var(--muted);font-weight:600}.phonics-illustration{font-size:64px;line-height:1}.phonics-word{font-size:24px;color:var(--heading);font-weight:600}.phonics-hint{font-size:20px;color:var(--muted)}.digraph-display{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%}.digraph-letters{font-size:100px;font-weight:800;color:var(--heading);line-height:1;letter-spacing:4px}.digraph-hint{font-size:22px;color:var(--muted)}.digraph-example{font-size:18px;color:#6b6196}.button-guide{display:flex;flex-direction:column;gap:16px;width:100%;margin:8px 0}.button-guide-item{display:flex;align-items:center;gap:16px}.button-guide-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.button-guide-text{text-align:left}.button-guide-text strong{color:var(--heading);font-size:16px}.button-guide-text p{color:var(--muted);font-size:14px;margin:2px 0 0;line-height:1.4}
