*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--yellow:#fffde7;--orange:#ffb347;--coral:#ff6b6b;--teal:#00897b;--teal-light:#b2dfdb;--purple:#ce93d8;--purple-light:#f3e5f5;--bg:#fff8e1;--text:#333;--radius:20px;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px)}html,body,#root{width:100%;height:100%;overflow:hidden}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;overscroll-behavior:none;font-family:Nunito,sans-serif}h1,h2,h3{font-family:Fredoka One,cursive}button{cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;outline:none;font-family:Nunito,sans-serif}.screen{width:100%;height:100%;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom);flex-direction:column;display:flex}.hero-section{text-align:center;padding:8px 0 4px}.hero-mascot{margin-bottom:4px;font-size:56px;display:block}.hero-title{color:var(--coral);margin-bottom:6px;font-size:30px}.hero-tagline{color:#666;max-width:320px;margin:0 auto 10px;font-size:14px;line-height:1.5}.hero-subjects{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.hero-pill{color:var(--teal);background:var(--teal-light);border-radius:12px;padding:4px 12px;font-size:13px;font-weight:700}.home-pick-label{color:#999;margin-bottom:2px;font-size:13px;font-weight:600}.home-links{align-items:center;gap:4px;margin-top:4px;display:flex}.home-link-dot{color:#ccc;font-size:16px}.home-screen{-webkit-overflow-scrolling:touch;background:linear-gradient(160deg,#fff8e1 0%,#ffecb3 50%,#ffe0b2 100%);align-items:center;gap:16px;padding:24px 16px;overflow-y:auto}.home-header{align-items:center;gap:16px;width:100%;max-width:420px;display:flex}.home-mascot{font-size:52px}.home-heading{color:var(--coral);margin-bottom:2px;font-size:26px}.home-sub{color:#666;font-size:15px}.topic-list{flex-direction:column;gap:12px;width:100%;max-width:420px;display:flex}.topic-card{text-align:left;background:#fff;border-radius:20px;align-items:center;gap:14px;padding:18px 16px;transition:transform .15s;display:flex;box-shadow:0 2px 10px #0000000f}.topic-card:active{transform:scale(.98)}.topic-icon{flex-shrink:0;font-size:36px}.level-icon{background:linear-gradient(135deg, var(--coral), var(--orange));color:#fff;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-family:Fredoka One,cursive;font-size:28px;display:flex}.topic-info{flex:1;min-width:0}.topic-title{color:var(--text);margin-bottom:2px;font-size:18px}.topic-desc{color:#999;margin-bottom:4px;font-size:13px}.topic-stars{color:var(--orange);font-size:13px;font-weight:700}.topic-arrow{color:#ccc;flex-shrink:0;font-size:24px;font-weight:700}.intro-screen{text-align:center;background:linear-gradient(160deg,#fff8e1 0%,#ffecb3 50%,#ffe0b2 100%);justify-content:center;align-items:center;gap:20px;padding:24px}.intro-header{align-items:center;gap:12px;display:flex}.intro-mascot{font-size:40px}.intro-title{color:var(--coral);font-size:24px}.intro-content{background:#fff;border-radius:24px;width:100%;max-width:380px;padding:24px 20px;box-shadow:0 2px 12px #00000014}.intro-clock{justify-content:center;margin-bottom:16px;display:flex}.intro-emoji{margin-bottom:12px;font-size:28px;line-height:1.6}.intro-text{color:var(--text);font-size:18px;line-height:1.6}.intro-dots{gap:8px;display:flex}.intro-dot{background:#ddd;border-radius:50%;width:10px;height:10px}.intro-dot-active{background:var(--orange)}.intro-actions{align-items:center;gap:12px;display:flex}.intro-back-btn{color:var(--teal);background:0 0;padding:12px 20px;font-size:16px;font-weight:700}.intro-next-btn{padding:14px 36px;font-size:18px}.welcome-screen{-webkit-overflow-scrolling:touch;background:linear-gradient(160deg,#fff8e1 0%,#ffecb3 50%,#ffe0b2 100%);align-items:center;gap:12px;padding:20px 16px;overflow-y:auto}.welcome-header{text-align:left;align-items:center;gap:16px;width:100%;max-width:420px;display:flex}.welcome-heading{color:var(--coral);margin-bottom:2px;font-size:28px}.welcome-sub{color:#666;font-size:15px}.welcome-progress{color:var(--teal);background:#fff;border-radius:20px;gap:20px;padding:10px 24px;font-size:15px;font-weight:700;display:flex;box-shadow:0 2px 8px #00000014}.module-list{flex-direction:column;gap:10px;width:100%;max-width:420px;display:flex}.module-card{text-align:left;background:#fff;border-radius:18px;align-items:center;gap:12px;padding:14px 16px;display:flex;box-shadow:0 2px 8px #0000000f}.module-locked{opacity:.5}.module-info{flex:1;min-width:0}.module-title-row{align-items:center;gap:8px;margin-bottom:2px;display:flex}.module-number{background:var(--orange);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-family:Fredoka One,cursive;font-size:14px;display:flex}.module-title{color:var(--text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:16px;overflow:hidden}.module-stars{color:var(--orange);flex-shrink:0;margin-left:auto;font-size:13px;font-weight:700}.module-desc{color:#999;margin-bottom:6px;font-size:13px}.module-video-btn{text-align:left;color:var(--teal);background:0 0;padding:0;font-size:13px;font-weight:700}.module-video-btn.no-video{color:var(--coral)}.module-video-edit{flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px;display:flex}.mv-input{background:#fafafa;border:2px solid #eee;border-radius:10px;outline:none;flex:1;min-width:120px;padding:6px 10px;font-family:Nunito,sans-serif;font-size:13px}.mv-input:focus{border-color:var(--teal)}.mv-save{background:var(--teal);color:#fff;border-radius:10px;padding:6px 12px;font-size:13px;font-weight:700}.mv-cancel{color:#ccc;background:0 0;padding:4px;font-size:16px}.mv-error{color:var(--coral);width:100%;font-size:13px}.module-play-btn{background:var(--teal);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;transition:transform .15s;display:flex;box-shadow:0 2px 8px #00897b4d}.module-play-btn:active{transform:scale(.92)}.module-lock{color:#ccc;text-align:center;flex-shrink:0;font-size:13px;font-weight:700}.module-completed{border:2px solid #c8e6c9}.module-number-done{background:#4caf50}.module-redo-btn{background:var(--orange);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;transition:transform .15s;display:flex;box-shadow:0 2px 8px #ffb3474d}.module-redo-btn:active{transform:scale(.92)}.btn-primary{background:linear-gradient(135deg, var(--coral), #ff8a65);color:#fff;border-radius:50px;min-height:56px;padding:16px 48px;font-family:Fredoka One,cursive;font-size:22px;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 16px #ff6b6b66}.btn-primary:active{transform:scale(.96);box-shadow:0 2px 8px #ff6b6b4d}.chat-screen{background:#fafafa}.chat-topbar{padding:12px 16px;padding-top:calc(12px + var(--safe-top));z-index:10;background:#fff;border-bottom:2px solid #fff3e0;align-items:center;gap:12px;min-height:56px;display:flex;position:sticky;top:0}.back-btn{min-width:44px;min-height:44px;color:var(--teal);background:0 0;padding:8px 12px;font-size:24px;font-weight:700}.topbar-mascot{font-size:18px;font-weight:700}.topbar-topic{color:#fff;background:var(--teal);text-overflow:ellipsis;white-space:nowrap;border-radius:12px;max-width:160px;margin-left:auto;padding:4px 12px;font-size:13px;font-weight:700;overflow:hidden}.chat-progress-bar{background:#fff;border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:6px 16px;font-size:13px;display:flex}.chat-stars{font-weight:800}.chat-reward-hint{color:#999;font-size:13px}.chat-messages{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;gap:10px;padding:12px 12px 8px;display:flex;overflow-y:auto}.chat-bubble-row{align-items:flex-end;gap:8px;animation:.3s fadeSlideIn;display:flex}.chat-bubble-row.koko{align-self:flex-start}.chat-bubble-row.student{flex-direction:row-reverse;align-self:flex-end}.avatar{flex-shrink:0;font-size:28px}.chat-bubble{border-radius:var(--radius);word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;white-space:pre-wrap;max-width:85%;padding:12px 16px;font-size:16px;line-height:1.5}.bubble-koko{background:#fff;border-bottom-left-radius:4px;box-shadow:0 1px 4px #0000000f}.bubble-student{background:var(--teal);color:#fff;border-bottom-right-radius:4px}.bubble-clock{justify-content:center;margin:8px 0;display:flex}.speak-btn{min-width:unset;opacity:.5;vertical-align:middle;background:0 0;min-height:40px;margin-left:6px;padding:2px 4px;font-size:16px;transition:opacity .15s;display:inline}.speak-btn:active{opacity:1}.login-actions{flex-direction:column;align-items:center;gap:8px;margin-top:16px;display:flex}.video-tip-banner{border:2px solid var(--orange);background:#fff3e0;border-radius:16px;align-items:center;gap:12px;width:100%;max-width:420px;padding:12px 16px;display:flex}.video-tip-text{color:#555;flex:1;font-size:13px;line-height:1.5}.video-tip-dismiss{background:var(--orange);color:#fff;border-radius:10px;flex-shrink:0;padding:6px 14px;font-size:13px;font-weight:700}.ad-slot{flex-shrink:0;justify-content:center;width:100%;max-width:420px;padding:8px 0;display:flex}.ad-placeholder{background:#f0f0f0;border-radius:8px;width:320px;height:50px}.reset-topic-btn{color:var(--coral);background:0 0;margin-top:8px;padding:8px;font-size:13px;font-weight:600;text-decoration:underline}.about-link{color:#999;background:0 0;margin-top:8px;padding:8px;font-size:13px;font-weight:600;text-decoration:underline}.about-screen{background:#fafafa}.about-topbar{padding:12px 16px;padding-top:calc(12px + var(--safe-top));background:#fff;border-bottom:2px solid #fff3e0;align-items:center;gap:12px;min-height:56px;display:flex}.about-content{-webkit-overflow-scrolling:touch;flex:1;padding:20px 16px;overflow-y:auto}.about-section{margin-bottom:24px}.about-section h2{color:var(--coral);margin-bottom:8px;font-size:20px}.about-section p{color:#555;margin-bottom:8px;font-size:15px;line-height:1.7}.about-list{flex-direction:column;gap:10px;margin-top:8px;list-style:none;display:flex}.about-list li{color:#555;padding-left:16px;font-size:14px;line-height:1.6;position:relative}.about-list li:before{content:"•";color:var(--orange);font-weight:700;position:absolute;left:0}.about-footer{text-align:center;color:#999;padding:24px 0;font-size:14px}.about-mascot{margin-bottom:8px;font-size:40px;display:block}.module-done-bar{padding:16px;padding-bottom:calc(16px + var(--safe-bottom));background:#fff;border-top:2px solid #fff3e0;flex-direction:column;align-items:center;gap:8px;display:flex}.confirm-cancel{color:#999;background:0 0;margin-top:12px;padding:8px;font-size:14px;font-weight:700;text-decoration:underline}.choice-buttons{padding:12px 16px;padding-bottom:calc(12px + var(--safe-bottom));background:#fff;border-top:2px solid #fff3e0;flex-direction:column;gap:12px;display:flex}.choice-btn{border:3px solid var(--orange);width:100%;color:var(--text);background:#fff;border-radius:16px;min-height:56px;padding:16px;font-family:Fredoka One,cursive;font-size:20px;transition:background .15s,border-color .15s,transform .1s}.choice-btn:active{transform:scale(.97)}.choice-btn:disabled{opacity:.7}.choice-label{background:var(--orange);color:#fff;text-align:center;vertical-align:middle;border-radius:50%;width:26px;height:26px;margin-right:8px;font-family:Nunito,sans-serif;font-size:14px;font-weight:800;line-height:26px;display:inline-block}.choice-correct{color:#2e7d32;background:#c8e6c9;border-color:#4caf50}.choice-wrong{color:#c62828;background:#ffcdd2;border-color:#e53935}.reward-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;padding:24px;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.reward-modal{text-align:center;background:#fff;border-radius:28px;width:100%;max-width:400px;padding:28px 24px;animation:.4s scaleIn}.reward-emojis{margin-bottom:8px;font-size:48px}.reward-title{color:var(--coral);margin-bottom:4px;font-size:24px}.reward-subtitle{color:#666;margin-bottom:16px;font-size:16px}.reward-dismiss{padding:14px 36px;font-size:18px}.reward-video{border-radius:16px;margin-bottom:20px;overflow:hidden}.reward-video iframe{display:block}.privacy-notice{color:#999;text-align:center;max-width:320px;margin-top:12px;font-size:11px;line-height:1.5}.child-picker-screen{-webkit-overflow-scrolling:touch;background:linear-gradient(160deg,#fff8e1 0%,#ffecb3 50%,#ffe0b2 100%);align-items:center;gap:16px;padding:32px 16px;overflow-y:auto}.child-picker-header{text-align:center}.child-picker-title{color:var(--text);margin-top:8px;font-family:Fredoka One,cursive;font-size:22px}.child-list{flex-direction:column;gap:10px;width:100%;max-width:360px;display:flex}.child-card{cursor:pointer;background:#fff;border-radius:18px;align-items:center;gap:14px;padding:16px 18px;transition:transform .1s;display:flex;box-shadow:0 2px 8px #00000014}.child-card:active{transform:scale(.97)}.child-avatar{font-size:36px}.child-name{color:var(--text);flex:1;font-size:18px;font-weight:700}.child-edit-btn{opacity:.5;background:0 0;padding:6px;font-size:16px}.child-add-btn{width:100%;max-width:360px;padding:14px;font-size:16px}.child-form{background:#fff;border-radius:18px;width:100%;max-width:360px;padding:20px;box-shadow:0 2px 8px #00000014}.child-form-title{color:var(--text);margin-bottom:12px;font-family:Fredoka One,cursive;font-size:18px}.avatar-picker{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.avatar-option{cursor:pointer;background:0 0;border:2px solid #0000;border-radius:12px;padding:6px;font-size:28px}.avatar-selected{border-color:var(--teal);background:var(--teal-light)}.child-name-input{border:2px solid #ddd;border-radius:14px;width:100%;margin-bottom:12px;padding:12px 14px;font-family:Nunito,sans-serif;font-size:16px}.child-name-input:focus{border-color:var(--teal);outline:none}.child-form-actions{align-items:center;gap:8px;display:flex}.child-cancel-btn{color:#999;background:0 0;padding:10px 16px;font-size:14px;font-weight:700}.child-delete-btn{color:var(--coral);background:0 0;margin-left:auto;padding:10px 16px;font-size:14px;font-weight:700}.child-signout{margin-top:auto;padding-top:16px}.dashboard-screen{-webkit-overflow-scrolling:touch;background:linear-gradient(160deg,#fff8e1 0%,#ffecb3 50%,#ffe0b2 100%);align-items:center;gap:16px;padding:20px 16px;overflow-y:auto}.dash-header{align-items:center;gap:12px;width:100%;max-width:420px;display:flex}.dash-title{color:var(--text);font-family:Fredoka One,cursive;font-size:20px}.dash-loading{color:#999;margin-top:40px}.dash-overview{gap:10px;width:100%;max-width:420px;display:flex}.dash-card{text-align:center;background:#fff;border-radius:16px;flex:1;padding:16px 12px;box-shadow:0 2px 8px #00000014}.dash-card-value{color:var(--teal);font-family:Fredoka One,cursive;font-size:20px;display:block}.dash-card-label{color:#999;margin-top:4px;font-size:13px;display:block}.dash-section{background:#fff;border-radius:16px;width:100%;max-width:420px;padding:16px;box-shadow:0 2px 8px #00000014}.dash-section-title{color:var(--text);margin-bottom:4px;font-family:Fredoka One,cursive;font-size:16px}.dash-section-desc{color:#999;margin-bottom:12px;font-size:13px;line-height:1.4}.dash-trend-up{color:var(--teal);font-family:Nunito,sans-serif;font-size:14px}.dash-trend-down{color:var(--orange);font-family:Nunito,sans-serif;font-size:14px}.dash-chart{align-items:flex-end;gap:12px;height:120px;display:flex}.dash-bar-col{flex-direction:column;flex:1;align-items:center;gap:4px;height:100%;display:flex}.dash-bar-label{color:var(--teal);font-size:13px;font-weight:700}.dash-bar-track{background:#f0f0f0;border-radius:8px;flex:1;align-items:flex-end;width:100%;max-width:40px;display:flex;overflow:hidden}.dash-bar-fill{background:linear-gradient(180deg, var(--teal) 0%, var(--teal-light) 100%);border-radius:8px;width:100%;min-height:4px;transition:height .3s}.dash-bar-week{color:#999;font-size:11px}.dash-weak-item{align-items:center;gap:10px;margin-bottom:10px;display:flex}.dash-weak-topic{min-width:100px;color:var(--text);font-size:14px;font-weight:600}.dash-weak-bar-track{background:#f0f0f0;border-radius:5px;flex:1;height:10px;overflow:hidden}.dash-weak-bar-fill{background:var(--orange);border-radius:5px;height:100%;transition:width .3s}.dash-weak-pct{color:var(--text);text-align:right;min-width:36px;font-size:14px;font-weight:700}.dash-recent-list{flex-direction:column;gap:8px;display:flex}.dash-recent-item{border-bottom:1px solid #f0f0f0;align-items:center;gap:8px;padding:8px 0;display:flex}.dash-recent-title{color:var(--text);flex:1;font-size:14px}.dash-recent-score{color:var(--teal);font-size:14px;font-weight:700}.dash-recent-date{color:#999;text-align:right;min-width:50px;font-size:13px}.dash-empty{text-align:center;color:#999;padding:40px 16px}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.clock-svg{filter:drop-shadow(0 2px 6px #0000001a);display:block}button:focus-visible{outline:3px solid var(--teal);outline-offset:2px}@media (hover:hover){.btn-primary:hover{filter:brightness(.95)}.choice-btn:hover{border-color:var(--teal)}.topic-card:hover{box-shadow:0 4px 12px #0000001a}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media (width<=420px){.hero-title{font-size:26px}.hero-tagline{max-width:90vw}.module-video-edit{flex-direction:column;gap:8px}.mv-input{width:100%;min-width:unset}.chat-bubble{max-width:90%}.ad-placeholder{width:280px;height:40px}}@media (height<=500px) and (orientation:landscape){.chat-topbar{padding:4px 12px;padding-top:calc(4px + var(--safe-top));gap:8px;min-height:36px}.topbar-mascot{font-size:14px}.topbar-topic{font-size:13px}.chat-progress-bar{padding:2px 12px;font-size:12px}.choice-buttons{padding:6px 12px;padding-bottom:calc(6px + var(--safe-bottom));grid-template-columns:1fr 1fr;gap:6px;display:grid}.choice-btn{border-width:2px;border-radius:12px;min-height:40px;padding:8px 10px;font-size:15px}.choice-label{width:20px;height:20px;margin-right:4px;font-size:11px;line-height:20px}.module-done-bar{padding:8px;padding-bottom:calc(8px + var(--safe-bottom));flex-direction:row;justify-content:center;gap:12px}.chat-messages{gap:6px;padding:6px 10px 4px}.chat-bubble{padding:8px 12px;font-size:15px}}
