:root{color-scheme:light;font-family:Inter,PingFang SC,Microsoft YaHei,Noto Sans CJK SC,system-ui,sans-serif;--bg: #eef4f8;--surface: #ffffff;--surface-strong: #f8fbfb;--text: #132322;--muted: #647483;--line: #cfe0ef;--accent: #1f78cf;--accent-strong: #175d96;--blue: #2f6fd6;--danger: #d4483e;--warning: #f3b13c;--success: #18865d;--shadow: 0 20px 48px rgba(16, 51, 51, .14)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;background:linear-gradient(180deg,#edf4f8f5,#f6fafcfa);color:var(--text)}button{font:inherit}img,video{max-width:100%;display:block}.app-shell{width:min(1180px,100%);min-height:100vh;margin:0 auto;padding:20px;display:flex;flex-direction:column;gap:18px}.app-header{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:start}.brand{margin:0 0 6px;color:var(--accent-strong);font-size:15px;font-weight:700}h1,h2,p{margin-top:0}h1{margin-bottom:0;font-size:34px;line-height:1.12;letter-spacing:0}.learner-line{margin:10px 0 0;color:var(--muted);font-size:18px;line-height:1.2;font-weight:800}.header-status{min-width:208px;display:grid;justify-items:end;gap:9px}.header-status strong{color:#385166;font-size:28px;line-height:1}.mini-progress{width:168px;height:16px;overflow:hidden;border-radius:999px;background:#dbe8f4}.mini-progress span{display:block;height:100%;border-radius:inherit;background:var(--accent)}.exit-button{min-height:48px;padding:0 22px;display:inline-flex;align-items:center;gap:9px;border:2px solid var(--line);border-radius:8px;color:#385166;background:var(--surface);font-size:20px;font-weight:900;cursor:pointer}h2{font-size:46px;line-height:1.08;letter-spacing:0}.progress-shell{grid-column:1 / -1;display:flex;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.progress-shell::-webkit-scrollbar{display:none}.progress-step{min-height:42px;flex:0 0 auto;min-width:86px;padding:0 18px;display:grid;place-items:center;border:1px solid var(--line);border-radius:8px;color:var(--muted);background:#ffffff94;font-size:15px;font-weight:700;font-family:inherit}.progress-step.active{color:#fff;background:var(--accent);border-color:var(--accent)}button.progress-step{cursor:pointer}button.progress-step:hover{color:var(--accent-strong);border-color:#287dd480;background:#fff}button.progress-step.active:hover{color:#fff;background:var(--accent-strong);border-color:var(--accent-strong)}.cover-layout,.lesson-layout,.complete-layout{flex:1}.cover-layout{display:grid;grid-template-columns:minmax(300px,.9fr) minmax(420px,1.1fr);align-items:stretch;gap:24px}.cover-copy,.cover-scene,.video-panel,.prompt-panel,.scene-stage,.quiz-panel,.complete-summary{border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}.cover-copy{padding:36px;display:flex;flex-direction:column;justify-content:center}.cover-copy p{color:var(--muted);font-size:22px;line-height:1.65}.cover-scene{overflow:hidden;display:flex;align-items:stretch;min-height:520px}.cover-scene img{width:100%;height:100%;object-fit:cover}.character-strip{display:flex;flex-wrap:wrap;gap:10px;margin:24px 0 32px}.character-strip span{width:56px;aspect-ratio:1;display:grid;place-items:center;border-radius:8px;color:var(--accent-strong);background:#e6f4f2;font-size:28px;font-weight:900}.primary-button,.secondary-button,.choice-button,.audio-button,.option-select-button,.option-audio-button,.text-button,.character-choice{border:0;cursor:pointer;transition:transform .16s ease,background-color .16s ease,border-color .16s ease}.primary-button,.secondary-button{min-height:64px;display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:8px;font-size:24px;font-weight:800}.primary-button{width:min(320px,100%);color:#fff;background:var(--accent)}.primary-button:disabled{color:#6a7b88;background:#d6e4ee;cursor:not-allowed}.secondary-button{padding:0 28px;color:#fff;background:var(--blue)}.primary-button:hover,.secondary-button:hover,.choice-button:hover,.audio-button:hover,.option-select-button:hover,.option-audio-button:hover,.character-choice:hover,.text-button:hover{transform:translateY(-1px)}.primary-button:disabled:hover{transform:none}.platform-status{margin:-12px 0 20px;padding:12px 14px;border-radius:8px;font-size:17px;line-height:1.45;font-weight:800}.platform-status.ok{color:var(--success);background:#e9f7f0}.platform-status.warning{color:#7b4b08;background:#fff5da}.lesson-layout{display:flex;flex-direction:column;gap:16px}.prompt-panel{padding:20px 22px;display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;border-left:8px solid var(--accent)}.prompt-panel.correct{border-left-color:var(--success)}.prompt-panel.error{border-left-color:var(--danger)}.prompt-text{margin-bottom:6px;font-size:30px;line-height:1.24;font-weight:900}.feedback-text{margin-bottom:0;color:var(--muted);font-size:18px;line-height:1.45;font-weight:700}.audio-button{min-height:56px;padding:0 18px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:8px;color:var(--accent-strong);background:#e7f4f2;font-size:18px;font-weight:800;white-space:nowrap}.video-panel{overflow:hidden;background:#0e2424}.video-panel video{width:100%;aspect-ratio:16 / 9;background:#0e2424}.video-home-layout{flex:1;display:flex;flex-direction:column;gap:18px}.autoplay-toggle{min-height:74px;padding:0 28px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;border:2px solid var(--line);border-radius:8px;color:var(--text);background:#f6fbff;font-size:24px;cursor:pointer}.autoplay-toggle strong{text-align:left;font-size:22px}.autoplay-toggle>span:last-child{color:var(--accent-strong);font-weight:900}.check-box{width:42px;aspect-ratio:1;display:grid;place-items:center;border-radius:6px;color:#fff;background:#c9d7e4;font-size:30px;font-weight:900;line-height:1}.check-box.checked{background:var(--accent)}.video-copy-panel{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:22px}.video-copy-panel h2{margin-bottom:14px}.video-copy-panel p{margin-bottom:0;color:var(--muted);font-size:25px;line-height:1.58;font-weight:700}.play-video-button,.video-sound-button,.practice-entry-button{border:0;border-radius:8px;cursor:pointer;transition:transform .16s ease,background-color .16s ease,color .16s ease}.play-video-button{min-height:86px;padding:0 34px;display:inline-flex;align-items:center;justify-content:center;gap:12px;color:var(--accent-strong);background:#e4f0fb;font-size:28px;font-weight:900;white-space:nowrap}.video-sound-button{min-height:72px;padding:0 28px;justify-self:center;display:inline-flex;align-items:center;justify-content:center;gap:10px;color:#fff;background:var(--blue);font-size:24px;font-weight:900}.practice-entry-button{min-height:88px;display:inline-flex;align-items:center;justify-content:center;gap:12px;color:#fff;background:var(--accent);font-size:28px;font-weight:900}.practice-entry-button:disabled{color:#6a7b88;background:#d6e4ee;cursor:not-allowed}.play-video-button:hover,.video-sound-button:hover,.practice-entry-button:not(:disabled):hover,.exit-button:hover,.autoplay-toggle:hover{transform:translateY(-1px)}.video-gate-note{margin:-4px 0 0;color:var(--muted);text-align:center;font-size:18px;font-weight:800}.video-playback-hint{margin:-4px 0 0;padding:14px 16px;border:1px solid rgba(31,120,207,.25);border-radius:8px;color:var(--blue);background:#eef7ff;text-align:center;font-size:18px;font-weight:800}.hidden-replay{display:none}.action-row{display:flex;justify-content:flex-end}.scene-stage{position:relative;overflow:hidden;min-height:420px;background:var(--surface-strong)}.scene-stage img{width:100%;height:100%;min-height:420px;object-fit:cover}.scene-stage.object-stage{aspect-ratio:1672 / 941;min-height:0}.scene-stage.object-stage img{height:100%;min-height:0;object-fit:contain}.object-stage .hotspot{position:absolute;border:3px solid transparent;border-radius:8px;background:#ffffff03}.object-stage .hotspot:focus-visible,.object-stage .hotspot.assist{outline:none;border-color:var(--warning);background:#f3b13c2e;box-shadow:0 0 0 5px #f3b13c3d}.object-stage .hotspot.found{border-color:var(--success);background:#18865d2e;box-shadow:0 0 0 5px #18865d38}.object-stage .hotspot:disabled{cursor:default}.object-word-card{position:absolute;z-index:3;min-width:118px;padding:14px 18px 12px;display:grid;justify-items:center;gap:4px;border:3px solid rgba(24,134,93,.6);border-radius:8px;color:var(--text);background:#fffffff5;box-shadow:0 16px 34px #10333338}.object-word-card strong{font-size:68px;line-height:.95;font-weight:900}.object-word-card span{color:var(--accent-strong);font-size:22px;line-height:1;font-weight:900}.assist-note{margin:-4px 0 0;padding:14px 18px;border:1px solid rgba(243,177,60,.55);border-radius:8px;color:#7b4b08;background:#fff5da;font-size:18px;font-weight:800}.character-board{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.character-choice{min-height:230px;display:grid;grid-template-rows:minmax(0,1fr) auto;gap:10px;border:2px solid var(--line);border-radius:8px;color:var(--text);background:var(--surface);box-shadow:var(--shadow)}.option-select-button{width:100%;min-height:0;padding:10px;display:grid;place-items:center;gap:6px;border:0;border-radius:8px;color:inherit;background:transparent;font:inherit;font-weight:inherit}.character-choice .option-select-button{min-height:150px}.character-choice .option-label{font-size:92px;line-height:1;font-weight:900}.character-choice small{margin-top:-34px;color:var(--accent-strong);font-size:22px;font-weight:900}.character-choice.assist,.choice-button.assist{border-color:var(--warning);background:#fff7df;box-shadow:0 0 0 5px #f3b13c33,var(--shadow)}.choice-grid{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:16px}.choice-button{min-height:120px;padding:14px;border:2px solid var(--line);border-radius:8px;color:var(--text);background:var(--surface);box-shadow:var(--shadow);font-size:34px;font-weight:900}.option-card{display:grid;grid-template-rows:1fr auto}.choice-button.option-card{gap:10px}.choice-button .option-select-button{min-height:54px;font-size:inherit}.choice-button .option-label{display:block}.option-audio-button{width:100%;min-height:38px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;gap:6px;border:0;border-radius:8px;color:var(--accent-strong);background:#e7f4f2;font-size:16px;font-weight:900}.option-audio-button:focus-visible{outline:3px solid rgba(31,120,207,.35);outline-offset:2px}.review-label{margin:0;padding:12px 16px;border:1px solid var(--line);border-radius:8px;color:var(--accent-strong);background:#edf7ff;font-size:18px;font-weight:900}.quiz-panel{padding:32px}.quiz-panel p{margin:0;font-size:42px;line-height:1.4;font-weight:900}mark{padding:2px 6px;border-radius:6px;color:#fff;background:var(--accent)}.complete-layout{display:grid;place-items:center}.complete-summary{width:min(760px,100%);padding:36px;text-align:center}.complete-summary svg{color:var(--success)}.complete-summary h2{margin:18px 0 12px;font-size:40px}.complete-summary p{color:var(--muted);font-size:22px;line-height:1.6}.complete-summary dl{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:28px 0 0}.complete-summary dl div{padding:16px;border:1px solid var(--line);border-radius:8px;background:var(--surface-strong)}.complete-summary dt{color:var(--muted);font-size:15px;font-weight:800}.complete-summary dd{margin:6px 0 0;font-size:34px;font-weight:900}.completion-sync{width:min(420px,100%);margin:22px auto 0;padding:12px 16px;border-radius:8px;font-size:17px;font-weight:800}.completion-sync.syncing,.completion-sync.idle{color:var(--accent-strong);background:#edf7ff}.completion-sync.synced{color:var(--success);background:#e9f7f0}.completion-sync.failed{color:#8a1f1f;background:#fff0f0}.complete-actions{margin-top:24px;display:flex;flex-wrap:wrap;justify-content:center;gap:12px}.complete-link{text-decoration:none}.app-footer{min-height:44px;flex-wrap:wrap;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--muted);font-size:15px;font-weight:700}.platform-sync{padding:5px 9px;border-radius:8px;background:#edf7ff;color:var(--accent-strong);font-weight:800}.platform-sync.warning,.platform-sync.blocked{color:#7b4b08;background:#fff5da}.platform-sync.synced{color:var(--success);background:#e9f7f0}.text-button{margin-left:8px;display:inline-flex;align-items:center;gap:6px;color:var(--accent-strong);background:transparent;font-size:15px;font-weight:800}@media(max-width:860px){.app-shell{padding:14px;gap:14px}.app-header,.cover-layout,.video-copy-panel{grid-template-columns:1fr}.header-status{width:100%;min-width:0;justify-items:stretch}.header-status strong{justify-self:end}.mini-progress,.exit-button,.play-video-button{width:100%}h1{font-size:28px}h2{font-size:36px}.cover-copy{padding:24px}.cover-copy p{font-size:19px}.cover-scene{min-height:320px}.prompt-panel{grid-template-columns:1fr}.video-copy-panel p{font-size:22px}.practice-entry-button{min-height:76px;font-size:24px}.prompt-text{font-size:27px}.scene-stage,.scene-stage img{min-height:310px}.character-board{grid-template-columns:1fr}.character-choice{min-height:168px}.character-choice .option-select-button{min-height:104px}.character-choice .option-label{font-size:76px}.choice-grid{grid-template-columns:1fr}.quiz-panel{padding:24px}.quiz-panel p{font-size:32px}.complete-summary dl{grid-template-columns:1fr}}@media(max-width:460px){.app-shell{padding:10px}.progress-step{min-height:38px;font-size:14px}.autoplay-toggle{min-height:64px;padding:0 18px;gap:12px;font-size:20px}.autoplay-toggle strong{font-size:20px}.check-box{width:36px;font-size:25px}.play-video-button,.practice-entry-button{font-size:22px}.prompt-text{font-size:24px}.feedback-text,.assist-note{font-size:16px}.scene-stage,.scene-stage img{min-height:260px}.choice-button{min-height:112px;font-size:30px}.object-word-card{min-width:92px;padding:10px 14px}.object-word-card strong{font-size:50px}.object-word-card span{font-size:18px}.character-strip span{width:48px;font-size:24px}}.character-strip span.needs-review{color:#7b4b08;background:#fff5da;box-shadow:0 0 0 3px #f3b13c38}.review-dashboard{display:grid;grid-template-columns:minmax(280px,.8fr) minmax(420px,1.2fr);gap:16px}.review-card{padding:22px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}.review-card h2{margin-bottom:12px;font-size:28px}.review-grid,.stat-table,.task-audit-list,.event-list{display:grid;gap:10px}.review-grid{grid-template-columns:auto minmax(0,1fr)}.review-grid span,.review-card p,.stat-row span{color:var(--muted);font-weight:700}.stat-row{display:grid;grid-template-columns:42px repeat(5,minmax(76px,1fr));gap:8px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--surface-strong)}.task-audit-list article{padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface-strong)}.task-audit-list p{margin:6px 0 0;line-height:1.45}.event-list code{display:block;overflow-wrap:anywhere;padding:10px;border-radius:8px;background:#eef4f8;color:#213547;font-size:12px;line-height:1.45}
