:root{color:#263238;background:#fff8e8;font-family:Inter,PingFang SC,Microsoft YaHei,Noto Sans SC,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--primary: #ff7a1a;--primary-dark: #e75c00;--secondary: #2677ff;--ink: #263238;--muted: #637381;--card: rgba(255, 255, 255, .92);--border: rgba(255, 152, 0, .18);--shadow: 0 20px 55px rgba(121, 73, 20, .14);--radius: 28px}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top left,rgba(255,213,79,.38),transparent 32rem),radial-gradient(circle at bottom right,rgba(97,218,251,.3),transparent 26rem),linear-gradient(135deg,#fff8e8,#eef8ff)}button,input{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.app-shell{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:22px 0 32px}.app-header{position:sticky;top:12px;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px;margin-bottom:28px;border:1px solid rgba(255,255,255,.72);border-radius:999px;background:#ffffffb8;box-shadow:0 12px 30px #603f1014;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.brand-button,.app-header nav button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;color:var(--ink);background:transparent}.brand-button{padding:10px 16px;font-weight:900;font-size:1.05rem}.app-header nav{display:flex;gap:8px}.account-area{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.account-name,.sync-pill{display:inline-flex;align-items:center;min-height:32px;padding:6px 10px;border-radius:999px;font-size:.82rem;font-weight:900}.account-name{color:#1f2933;background:#ffffffd6}.sync-pill{color:#52606d;background:#f4f7fbeb}.sync-pill.saved{color:#14532d;background:#dcfce7}.sync-pill.syncing,.sync-pill.loading{color:#744500;background:#fff0c2}.sync-pill.error{color:#9f1239;background:#ffe4e6}.login-panel{display:grid;grid-template-columns:minmax(180px,1fr) minmax(180px,1fr) auto;gap:12px;align-items:end;margin:-10px 0 22px}.login-panel label{display:grid;gap:6px;color:#52606d;font-size:.88rem;font-weight:900}.login-panel input{width:100%;min-height:44px;padding:0 14px;border:2px solid rgba(255,152,0,.24);border-radius:16px;outline:none;color:#1f2933;background:#fffdf5;font-weight:800}.login-panel input:focus{border-color:var(--primary);box-shadow:0 0 0 4px #ff7a1a1f}.login-error{margin:0;color:#b91c1c;font-weight:900}.app-header nav button{position:relative;padding:10px 16px;color:#52606d;font-weight:700}.app-header nav button.nav-active,.app-header nav button:hover{color:#fff;background:var(--primary)}.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:999px;color:#fff;background:#e53935;font-size:.8rem}.hero-card,.panel,.practice-card,.feature-card,.stat-card,.mistake-card,.level-tile{border:1px solid var(--border);border-radius:var(--radius);background:var(--card);box-shadow:var(--shadow)}.hero-card{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(280px,.8fr);gap:28px;min-height:360px;padding:clamp(28px,5vw,58px);overflow:hidden}.eyebrow{margin:0 0 8px;color:var(--primary-dark);font-size:.86rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase}h1,h2,p{margin-top:0}h1{margin-bottom:14px;color:#1f2933;font-size:clamp(2.4rem,8vw,5.6rem);line-height:.95}h2{color:#1f2933}.hero-description,.page-topbar p,.panel p,.feature-card p,.stat-card small,.mistake-content p,.result-page p{color:var(--muted);line-height:1.8}.hero-actions,.result-actions,.panel-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.primary-button,.secondary-button,.ghost-button,.listen-button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:12px 20px;border-radius:999px;font-weight:900;transition:transform .16s ease,box-shadow .16s ease,background-color .16s ease}.primary-button{color:#fff;background:linear-gradient(135deg,var(--primary),#ffb300);box-shadow:0 12px 24px #ff7a1a47}.primary-button:hover:not(:disabled),.secondary-button:hover:not(:disabled),.ghost-button:hover:not(:disabled),.listen-button:hover:not(:disabled){transform:translateY(-2px)}.secondary-button{color:#fff;background:linear-gradient(135deg,#2677ff,#36c5f0);box-shadow:0 12px 24px #2677ff33}.ghost-button{color:#44505c;background:#ffffffc7;border:1px solid rgba(67,90,111,.12)}.ghost-button.danger{color:#c62828}.large{min-height:58px;padding:16px 26px;font-size:1.08rem}.small{min-height:36px;padding:8px 12px;font-size:.88rem}.train-illustration{position:relative;display:grid;place-items:center;min-height:250px;border-radius:36px;background:radial-gradient(circle at 50% 30%,rgba(255,255,255,.9),transparent 36%),linear-gradient(145deg,#d9f6ff,#fff1bd)}.engine{filter:drop-shadow(0 20px 15px rgba(0,0,0,.15));font-size:clamp(5rem,16vw,9rem);animation:float 2.4s ease-in-out infinite}.rail{position:absolute;bottom:38px;color:#5a42236b;font-weight:900}.smoke{position:absolute;font-size:2.1rem;opacity:.75}.smoke-one{top:44px;left:24%}.smoke-two{top:70px;right:26%}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.stats-grid,.feature-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin:22px 0}.feature-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.stat-card,.feature-card,.panel{padding:24px}.stat-card span,.stat-card small{display:block}.stat-card span{color:#6b7280;font-weight:800}.stat-card strong{display:block;margin:8px 0;color:var(--secondary);font-size:2.4rem;line-height:1}.feature-icon{display:inline-grid;place-items:center;width:58px;height:58px;margin-bottom:14px;border-radius:20px;background:#fff0c2;font-size:1.8rem}.quick-actions,.progress-actions,.mistake-summary-panel{display:flex;align-items:center;justify-content:space-between;gap:18px}.page-topbar{display:flex;gap:20px;align-items:flex-start;margin-bottom:22px}.page-topbar h1{margin-bottom:8px;font-size:clamp(2rem,5vw,4rem)}.practice-page{max-width:980px;margin:0 auto}.train-track{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin:20px 0}.train-car{position:relative;display:flex;align-items:center;justify-content:center;min-height:96px;border:3px solid #ffd36b;border-radius:28px;color:#8a5b00;background:#fff7d1;font-size:2.2rem;transition:transform .18s ease,background-color .18s ease}.train-car.current{color:#fff;background:linear-gradient(135deg,#ff7a1a,#ffc400);transform:translateY(-4px)}.train-car.done{border-color:#75d69c;color:#166534;background:#dbffe8}.train-car.locked{opacity:.68}.train-car-index{position:absolute;top:10px;left:14px;display:inline-grid;place-items:center;width:26px;height:26px;border-radius:50%;color:#fff;background:#26323838;font-size:.85rem;font-weight:900}.practice-card{display:grid;grid-template-columns:minmax(260px,.8fr) minmax(300px,1.2fr);gap:28px;padding:clamp(24px,5vw,42px)}.character-stage,.answer-panel{display:flex;flex-direction:column;justify-content:center}.character-stage{align-items:center;border-radius:30px;background:linear-gradient(160deg,#fff3c4,#e2f7ff);padding:24px}.current-step{color:#7a5c00;font-weight:900}.big-character{margin:16px 0;color:#17212b;font-family:KaiTi,STKaiti,serif;font-size:clamp(7rem,22vw,12rem);font-weight:900;line-height:1}.listen-button{color:#744500;background:#fff;border:2px solid #ffd36b}.answer-panel label{margin-bottom:12px;color:#1f2933;font-size:1.35rem;font-weight:900}.input-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px}.input-row input{width:100%;min-height:60px;padding:0 18px;border:3px solid #ffd36b;border-radius:20px;outline:none;color:#1f2933;background:#fffdf5;font-size:1.45rem;font-weight:800}.input-row input:focus{border-color:var(--primary);box-shadow:0 0 0 5px #ff7a1a24}.feedback{min-height:44px;margin:16px 0 4px;padding:14px 16px;border-radius:18px;font-weight:900}.feedback.idle{color:#52606d;background:#f4f7fb}.feedback.success{color:#14532d;background:#dcfce7}.feedback.error{color:#9f1239;background:#ffe4e6}.tiny-note{margin:8px 0 0;color:#7c8794;font-size:.9rem}.result-page{max-width:800px;margin:40px auto;text-align:center}.result-page h1{font-size:clamp(2.2rem,6vw,4.6rem)}.result-stars{margin:18px 0;font-size:clamp(2.4rem,8vw,4.5rem);letter-spacing:.1em}.level-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:24px 0}.summary-character{padding:18px;border-radius:20px;background:#fff7d1}.summary-character strong,.summary-character span{display:block}.summary-character strong{font-family:KaiTi,STKaiti,serif;font-size:3rem}.summary-character span{color:#7a5c00;font-weight:900}.warm-note{display:inline-block;padding:12px 16px;border-radius:999px;background:#fff0c2;color:#744500!important;font-weight:900}.result-actions{justify-content:center;margin-top:24px}.mistake-list{display:grid;gap:16px}.admin-history-list{display:grid;gap:18px}.admin-history-card{display:grid;gap:16px}.admin-history-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.admin-history-header h2{margin-bottom:6px}.admin-history-header p{margin-bottom:0;color:var(--muted)}.admin-mistake-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.admin-mistake-item{display:grid;gap:6px;min-height:128px;padding:14px;border:1px solid rgba(255,152,0,.18);border-radius:18px;background:#fffdf5}.admin-mistake-item.hidden{opacity:.66;background:#f4f7fb}.admin-mistake-item strong{font-family:KaiTi,STKaiti,serif;font-size:2.2rem;line-height:1}.admin-mistake-item span{color:#1f2933;font-weight:900}.admin-mistake-item small{color:var(--muted);line-height:1.4}.mistake-card{display:grid;grid-template-columns:110px minmax(0,1fr) auto;gap:18px;align-items:center;padding:20px}.mistake-card.mastered{opacity:.72}.mistake-character{display:grid;place-items:center;width:96px;height:96px;border-radius:28px;color:#fff;background:linear-gradient(135deg,#ff7a1a,#ffc400);font-family:KaiTi,STKaiti,serif;font-size:4rem;font-weight:900}.mistake-title-row,.mistake-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.mistake-title-row h2{margin-bottom:0}.status-pill{padding:6px 10px;border-radius:999px;font-size:.82rem;font-weight:900}.status-pill.todo{color:#9f1239;background:#ffe4e6}.status-pill.done{color:#14532d;background:#dcfce7}.mistake-actions{justify-content:flex-end}.empty-state{text-align:center}.level-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-top:22px}.level-tile{display:flex;flex-direction:column;gap:8px;min-height:128px;padding:18px;text-align:left}.level-tile:hover:not(:disabled){transform:translateY(-3px)}.level-tile span{color:#6b7280;font-weight:900}.level-tile strong{min-height:30px;color:#1f2933;font-size:1.28rem}.level-tile small{color:#f59e0b;font-weight:900}.level-tile.locked{box-shadow:none;filter:grayscale(.5)}.level-tile.completed{border-color:#2677ff47}.app-footer{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-top:34px;color:#7c8794;font-size:.92rem}.theme-train{--primary: #ff7a1a;--primary-dark: #e75c00;--secondary: #2677ff;--theme-a: #ff7a1a;--theme-b: #ffc400;--theme-soft: #fff3c4;--theme-ink: #744500}.theme-monster{--primary: #7c3aed;--primary-dark: #5b21b6;--secondary: #10b981;--theme-a: #7c3aed;--theme-b: #34d399;--theme-soft: #ede9fe;--theme-ink: #3b0764}.theme-garden{--primary: #16a34a;--primary-dark: #15803d;--secondary: #f59e0b;--theme-a: #16a34a;--theme-b: #facc15;--theme-soft: #dcfce7;--theme-ink: #14532d}.theme-space{--primary: #2563eb;--primary-dark: #1d4ed8;--secondary: #8b5cf6;--theme-a: #2563eb;--theme-b: #a78bfa;--theme-soft: #dbeafe;--theme-ink: #172554}.theme-illustration{background:radial-gradient(circle at 50% 30%,rgba(255,255,255,.92),transparent 36%),linear-gradient(145deg,var(--theme-soft),rgba(255,255,255,.82))}.style-panel{display:grid;gap:18px;margin:22px 0}.section-heading h2{margin-bottom:8px}.style-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.style-card{position:relative;display:flex;min-height:190px;flex-direction:column;align-items:flex-start;gap:10px;padding:18px;overflow:hidden;border:2px solid rgba(255,255,255,.92);border-radius:24px;color:var(--theme-ink);background:radial-gradient(circle at top right,rgba(255,255,255,.82),transparent 36%),linear-gradient(145deg,var(--theme-soft),rgba(255,255,255,.92));box-shadow:0 14px 32px #49350f1a;text-align:left}.style-card:hover:not(:disabled),.style-card.selected{border-color:var(--theme-a);transform:translateY(-3px)}.style-card.selected:after{content:"✓";position:absolute;top:14px;right:14px;display:grid;place-items:center;width:30px;height:30px;border-radius:999px;color:#fff;background:var(--theme-a);font-weight:900}.style-card-icon{font-size:2.7rem;filter:drop-shadow(0 12px 10px rgba(0,0,0,.12))}.style-card strong{color:#1f2933;font-size:1.12rem}.style-card small{color:#536171;line-height:1.6}.style-selected-label{margin-top:auto;padding:7px 12px;border-radius:999px;color:#fff;background:linear-gradient(135deg,var(--theme-a),var(--theme-b));font-size:.82rem;font-weight:900}.train-car{flex-direction:column;gap:4px;color:var(--theme-ink);background:var(--theme-soft)}.train-car.current{background:linear-gradient(135deg,var(--theme-a),var(--theme-b))}.train-car-icon{font-size:1.3rem;line-height:1}.train-car small{color:currentColor;font-size:.82rem;font-weight:900;opacity:.82}.theme-monster .character-stage,.theme-garden .character-stage,.theme-space .character-stage,.theme-train .character-stage{background:linear-gradient(160deg,var(--theme-soft),rgba(255,255,255,.92))}.theme-monster .big-character,.theme-garden .big-character,.theme-space .big-character,.theme-train .big-character{text-shadow:0 12px 24px rgba(38,50,56,.08)}.theme-monster .listen-button,.theme-garden .listen-button,.theme-space .listen-button,.theme-train .listen-button{color:var(--theme-ink);border-color:var(--theme-b)}.theme-monster .summary-character,.theme-garden .summary-character,.theme-space .summary-character,.theme-train .summary-character{background:var(--theme-soft)}.theme-monster .mistake-character,.theme-garden .mistake-character,.theme-space .mistake-character,.theme-train .mistake-character{background:linear-gradient(135deg,var(--theme-a),var(--theme-b))}@media (max-width: 900px){.hero-card,.practice-card{grid-template-columns:1fr}.stats-grid,.feature-grid,.style-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.level-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-mistake-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.mistake-card{grid-template-columns:90px minmax(0,1fr)}.mistake-actions{grid-column:1 / -1;justify-content:flex-start}}@media (max-width: 640px){.app-shell{width:min(100% - 20px,1180px);padding-top:10px}.app-header{align-items:stretch;flex-direction:column;border-radius:24px}.app-header nav{display:grid;grid-template-columns:repeat(3,1fr)}.account-area{justify-content:stretch}.account-area>*{flex:1 1 auto;justify-content:center}.login-panel{grid-template-columns:1fr;margin-top:-12px}.app-header nav button,.brand-button{width:100%}.stats-grid,.feature-grid,.style-grid,.train-track,.level-summary,.level-grid,.input-row{grid-template-columns:1fr}.quick-actions,.progress-actions,.mistake-summary-panel,.admin-history-header,.page-topbar{align-items:stretch;flex-direction:column}.admin-mistake-grid,.mistake-card{grid-template-columns:1fr}.mistake-character{width:100%}}
