:root{color:#17212b;background:#f5f7f8;font-family:Inter,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select,textarea{font:inherit}button{border:1px solid #cfd8dc;background:#fff;color:#17212b;min-height:42px;border-radius:8px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:border-color .15s,background .15s,transform .15s}button:hover{border-color:#4d8f92}button:disabled{cursor:not-allowed;opacity:.58}.primary{background:#116a65;color:#fff;border-color:#116a65}.app-shell{min-height:100vh;display:block}.topbar{position:sticky;top:0;z-index:10;min-height:58px;background:#fff;border-bottom:1px solid #dce4e7;display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:12px;padding:0 18px}.topbar-brand{color:#0b5d58;font-size:22px;font-weight:850;letter-spacing:0;text-transform:lowercase}.topbar-title{color:#17212b;font-weight:800;font-size:17px}.topbar-menu{position:relative;display:flex;justify-content:flex-end}.menu-trigger{border-color:transparent;background:transparent}.menu-popover{position:absolute;right:0;top:calc(100% + 10px);width:220px;display:grid;gap:6px;background:#fff;border:1px solid #d9e2e5;border-radius:8px;padding:8px;box-shadow:0 18px 44px #11374424}.menu-popover button{justify-content:flex-start;border-color:transparent;background:transparent;min-height:44px}.menu-popover button.active{background:#e5f2ef;border-color:#b9d8d3;color:#0b5d58;font-weight:700}.menu-user{border-bottom:1px solid #edf1f3;padding:8px 10px 10px}.menu-user strong,.menu-user span{display:block}.menu-user strong{color:#123744}.menu-user span{color:#657681;font-size:13px;margin-top:3px}.logout-button{justify-content:flex-start;margin-top:4px;border-color:#e2e9eb}.brand{display:flex;align-items:center;gap:12px;min-height:52px}.brand-mark{width:42px;height:42px;border-radius:8px;background:#116a65;color:#fff;display:grid;place-items:center;font-weight:800;font-size:22px}.brand strong,.brand span{display:block}.brand span{color:#657681;font-size:13px;margin-top:3px}main{min-width:0;padding:28px}.login-shell{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:min(380px,100%);display:grid;gap:16px;background:#fff;border:1px solid #d9e2e5;border-radius:8px;padding:22px;box-shadow:0 18px 44px #11374414}.login-brand{margin-bottom:2px}.workspace{max-width:1180px;margin:0 auto}header{margin-bottom:20px}h1,h2,p{margin:0}h1{font-size:28px;line-height:1.2}h2{font-size:18px}header p{color:#5f6f7a;margin-top:8px}.toolbar,.search-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px}.file-button{border:1px dashed #92a8ad;background:#fff;border-radius:8px;min-height:44px;padding:0 16px;display:inline-flex;align-items:center;gap:8px;cursor:pointer}.file-button input{display:none}.photo-entry{border-color:#116a65;background:#116a65;color:#fff}.photo-entry:hover{border-color:#0b5d58;background:#0b5d58}.status{padding:12px 14px;border:1px solid #b7d7c5;background:#edf8f2;color:#245d3e;border-radius:8px;margin:12px 0}.status.error{border-color:#e0b5ad;background:#fff1ee;color:#8b2f23}.empty{min-height:220px;display:grid;place-items:center;color:#657681;border:1px dashed #ccd7db;background:#fff;border-radius:8px;padding:24px}.empty-actions{align-content:center;gap:14px;text-align:center}.empty-note{color:#24557f;font-weight:700}.table-wrap{overflow:auto;border:1px solid #d9e2e5;background:#fff;border-radius:8px}table{width:100%;min-width:720px;border-collapse:collapse}th,td{text-align:left;padding:13px 14px;border-bottom:1px solid #edf1f3;vertical-align:top}th{color:#50616b;background:#f9fbfb;font-size:13px}tr:last-child td{border-bottom:0}.word-cell{font-weight:750;color:#123744}.muted{color:#8b9aa3}.split{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(280px,.7fr);gap:16px}.ocr-text{border:1px solid #d9e2e5;background:#fff;border-radius:8px;padding:16px;min-height:280px}.ocr-text pre{white-space:pre-wrap;color:#445660;line-height:1.6}.dictation-page{display:grid;gap:16px}.dictation-page header{margin-bottom:0}.dictation-source-switch{display:flex;flex-wrap:wrap;gap:10px}.dictation-source-switch button,.dictation-source-switch .dictation-source-option{min-height:48px;border:1px solid #d2dde0;background:#fff;color:#344954;font-weight:750}.dictation-source-switch button.active,.dictation-source-switch .dictation-source-option.active{border-color:#116a65;background:#e5f2ef;color:#0b5d58}.dictation-list-header{display:flex;align-items:center;justify-content:space-between;gap:18px;border:1px solid #d9e2e5;border-radius:8px;background:#fff;padding:14px 16px}.dictation-shuffle-option{min-height:40px;display:inline-flex;grid-template-columns:none;flex:0 0 auto;align-items:center;gap:8px;border:1px solid #d9e2e5;border-radius:8px;background:#f9fbfb;padding:0 11px;color:#344954;font-size:13px;font-weight:750;cursor:pointer}.dictation-shuffle-option span{white-space:nowrap}.dictation-list-header strong,.dictation-list-header span{display:block}.dictation-list-header strong{color:#17212b;font-size:18px}.dictation-list-header>div:first-child>span{margin-top:5px;color:#657681;font-size:13px;line-height:1.45}.dictation-list-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.dictation-list-actions .primary{min-height:46px;padding:0 20px;font-weight:800}.selection-checkbox{width:18px;height:18px;min-height:18px;padding:0;accent-color:#116a65}.dictation-table table{min-width:640px}.dictation-table th:first-child,.dictation-table td:first-child{width:70px;text-align:center}.dictation-table th:nth-child(2),.dictation-table td:nth-child(2){width:70px;text-align:center}.dictation-word-cell{width:34%;font-weight:750;color:#123744}.dictation-word-input{width:100%;min-height:40px;font-weight:750;color:#123744}.dictation-word-cell>span{display:block;margin-top:5px;color:#a33b2d;font-size:12px;font-weight:650}.dictation-word-input.invalid{border-color:#c76659;background:#fff8f6}.dictation-row-error{background:snow}body.dictation-focus-mode,body.dictation-focus-mode .app-shell{background:#000}body.dictation-focus-mode .topbar{display:none}body.dictation-focus-mode main{padding:0;background:#000}.dictation-focus{position:relative;min-height:100vh;min-height:100dvh;background:#000;color:#fff}.dictation-exit-button{position:fixed;z-index:2;left:max(22px,env(safe-area-inset-left));top:max(22px,env(safe-area-inset-top));min-height:44px;border-color:#666;background:#555;color:#fff;font-weight:750}.dictation-exit-button:hover{border-color:#777;background:#666}.dictation-focus-center{position:fixed;top:50%;left:50%;width:min(680px,calc(100vw - 40px));display:grid;gap:16px;transform:translate(-50%,-50%)}.dictation-focus-controls{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.28fr) minmax(0,1fr);gap:14px}.dictation-focus-controls button{min-height:68px;border:1px solid #ffffff;border-radius:8px;background:#fff;color:#000;font-size:18px;font-weight:850}.dictation-focus-controls button:hover{border-color:#eee;background:#eee}.dictation-focus-controls button:disabled{border-color:#fff;background:#fff;color:#000;opacity:.28}.dictation-focus-controls .dictation-play-button{min-height:82px;font-size:21px}.dictation-countdown{color:#8d8d8d;font-size:15px;font-weight:650;letter-spacing:.02em;text-align:center}.training-stage{min-height:calc(100vh - 56px);display:grid;place-items:center;padding:20px}.training-card{position:relative;width:min(760px,100%);background:#fff;border:1px solid #d9e2e5;border-radius:8px;padding:28px;box-shadow:0 18px 44px #11374414}.training-ready-stage{min-height:calc(100vh - 86px)}.training-ready{width:min(620px,100%);display:grid;justify-items:center;gap:16px;text-align:center;background:#fff;border:1px solid #d9e2e5;border-radius:8px;padding:46px 28px;box-shadow:0 18px 44px #11374414}.training-ready>span{color:#0b5d58;font-weight:800}.training-ready strong{color:#17212b;font-size:32px;line-height:1.25}.training-ready p{margin:0;color:#647580;line-height:1.6}.start-review-button{min-height:52px;padding:0 24px;font-size:17px;font-weight:800}body.training-focus-mode{background:#000}body.training-focus-mode .topbar{display:none}body.training-focus-mode main{padding:0;background:#000}.focus-stage{min-height:100vh;padding:24px;background:#000}.training-card.focus-card{width:min(1100px,100%);border:0;background:#000;color:#fff;box-shadow:none;padding:36px;text-align:center}.focus-card h1.focus-word{margin:0;color:#fff;font-size:96px;line-height:1.08}.focus-card .advanced-block{width:min(920px,100%);margin:36px auto 0;gap:28px}.focus-card .advanced-prompt{border:0;background:transparent;color:#fff;padding:0;font-size:28px;line-height:1.4}.focus-card .advanced-example{border:0;background:transparent;color:#fff;padding:0;margin:0;font-size:48px;line-height:1.5}.focus-card .auto-speech{border-color:#555;background:#111;color:#fff;text-align:left}.focus-card .auto-speech-indicator{background:#fff;color:#000}.focus-card .auto-speech span{color:#d7d7d7}.focus-card .auto-speech.speaking{border-color:#fff;background:#181818;color:#fff}.focus-card .auto-speech.speaking .auto-speech-indicator{background:#fff;color:#000;box-shadow:0 0 0 5px #fff3}.focus-card .press-record-button{min-height:58px;border-color:#fff;background:#000;color:#fff;padding:0 22px;font-size:18px;font-weight:800}.focus-card .dictation-actions{justify-content:center}.focus-card .native-speech-form{color:#fff;text-align:left}.progress-row{display:flex;justify-content:space-between;color:#647580;font-size:14px}.sound{position:absolute;right:28px;top:64px}.training-mode{display:inline-flex;align-items:center;min-height:28px;margin-top:26px;padding:0 9px;border:1px solid #b9d8d3;border-radius:8px;background:#eaf5f2;color:#0b5d58;font-size:13px;font-weight:750}.training-card h1{font-size:56px;margin-top:12px;overflow-wrap:anywhere}.training-card h1.dictation-title{font-size:42px}.pos{color:#116a65;font-weight:700;margin-top:8px}.example{color:#445660;background:#f4f7f3;border-left:4px solid #8aa65a;padding:14px;margin:22px 0;line-height:1.6}.choices{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.choices button{min-height:62px;justify-content:flex-start;white-space:normal;text-align:left;line-height:1.4}.dictation-form{display:grid;gap:12px}.dictation-form input{min-height:54px;font-size:20px;font-weight:700;letter-spacing:0}.dictation-actions{display:flex;flex-wrap:wrap;gap:10px}.advanced-block{display:grid;gap:14px;margin-top:18px}.advanced-prompt{color:#445660;background:#f7fafb;border:1px solid #d9e2e5;border-radius:8px;padding:14px;font-weight:700}.advanced-example{margin:0;font-size:22px;line-height:1.65;font-weight:650}.advanced-spelling-cue,.advanced-answer-card,.advanced-review-card{background:#fff;border:1px solid #d9e2e5;border-radius:8px;padding:16px}.advanced-spelling-cue,.review-word-row{display:flex;align-items:center;justify-content:space-between;gap:14px}.advanced-spelling-cue span,.advanced-answer-card span,.review-word-row span,.review-line span{display:block;color:#657681;font-size:13px;margin-bottom:6px}.advanced-spelling-cue strong{display:block;color:#123744;font-size:22px;line-height:1.45}.advanced-answer-card strong{display:block;color:#123744;font-size:24px;line-height:1.45}.advanced-review-card{display:grid;gap:14px}.review-word-row strong{display:block;color:#123744;font-size:34px;line-height:1.15;overflow-wrap:anywhere}.review-line p{margin:0;color:#344954;font-size:18px;line-height:1.6}.review-line .review-example{font-size:22px;color:#123744}.recording-button{border-color:#a33b2d;background:#fff1ee;color:#8b2f23}.press-record-button{touch-action:none;-webkit-user-select:none;user-select:none}.press-record-button.recording-button{box-shadow:0 0 0 3px #a33b2d24}.auto-speech{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;border:1px solid #cbdce2;border-radius:8px;background:#f6fbfd;padding:12px 14px;color:#214755}.auto-speech-indicator{width:42px;height:42px;display:grid;place-items:center;border-radius:50%;background:#e2f1f5;color:#1d6177}.auto-speech strong,.auto-speech span{display:block}.auto-speech strong{margin-bottom:4px}.auto-speech span{color:#4f6570;line-height:1.45}.auto-speech-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.auto-speech.speaking{border-color:#a33b2d;background:#fff1ee;color:#8b2f23}.auto-speech.speaking .auto-speech-indicator{background:#ffd8d0;color:#8b2f23;box-shadow:0 0 0 4px #a33b2d1f}.auto-speech.failed,.auto-speech.unavailable{border-color:#e0b5ad;background:#fff7f5}.check-result{display:grid;gap:6px;border-radius:8px;padding:12px 14px;line-height:1.5}.check-result.correct{border:1px solid #b7d7c5;background:#edf8f2;color:#245d3e}.check-result.wrong{border:1px solid #e0b5ad;background:#fff1ee;color:#8b2f23}.meaning-review{display:flex;justify-content:flex-end;margin-top:14px}.hint,.feedback{margin-top:16px;padding:12px 14px;border-radius:8px}.hint{background:#fff8e2;color:#755b18}.feedback{background:#e8f3ff;color:#24557f;font-weight:700}.story{background:#fff;border:1px solid #d9e2e5;border-radius:8px;padding:24px;line-height:1.8;min-height:260px;white-space:pre-wrap}.story-english{font-size:18px}.story-date{color:#657681;font-size:13px;font-weight:750;margin-bottom:10px}.story-bilingual{min-height:180px}.story-translation{border-top:1px solid #e5ebed;color:#51636e;margin-top:18px;padding-top:18px;line-height:1.9}.story-actions{display:flex;gap:10px;margin-top:12px}.story-history{display:flex;flex-wrap:wrap;gap:8px;margin:-4px 0 14px}.story-history button{min-height:36px;padding:0 10px;font-size:13px}.story-history button.active{border-color:#116a65;background:#e5f2ef;color:#0b5d58;font-weight:800}.story-grammar{display:grid;gap:14px;margin-top:20px;border:1px solid #d9e2e5;border-radius:8px;background:#fff;padding:20px}.story-grammar-heading span{color:#0b5d58;font-size:13px;font-weight:800}.story-grammar-heading h2{margin-top:5px;color:#17212b}.story-grammar-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.story-grammar-note{display:grid;gap:9px;border:1px solid #e1e8ea;border-radius:8px;background:#f9fbfb;padding:14px}.story-grammar-note strong{color:#123744;line-height:1.45}.story-grammar-note p{color:#51636e;line-height:1.65}.story-grammar-note code{display:block;border-left:3px solid #8aa65a;background:#f2f6ed;padding:9px 10px;color:#344954;font-family:inherit;line-height:1.55;white-space:normal}mark{background:#ffe58a;color:inherit;padding:0 3px;border-radius:4px}.word-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.word-chips span{background:#fff;border:1px solid #d9e2e5;border-radius:8px;padding:7px 10px;color:#344954}.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-bottom:18px}.admin-grid{grid-template-columns:minmax(320px,.9fr) minmax(0,1.1fr)}.user-admin-panel{align-content:start}.admin-user-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.admin-user-form button{align-self:end}.admin-users-table{margin-top:8px}.admin-users-table table{min-width:980px}.admin-users-table input,.admin-users-table select{width:100%}.panel,.list-panel{background:#fff;border:1px solid #d9e2e5;border-radius:8px;padding:16px}.panel{display:grid;gap:12px}.panel-note{color:#657681;line-height:1.6;font-size:13px}.credit-panel{align-content:start}.credit-balance{display:grid;gap:2px;padding:12px;border:1px solid #d9e2e5;border-radius:8px;background:#f8fbfa}.credit-balance strong{color:#0b5d58;font-size:30px;line-height:1}.credit-balance span{color:#657681;font-size:13px}label{display:grid;gap:6px;color:#4e616b;font-size:14px}input,select,textarea{min-height:42px;border:1px solid #ccd7db;border-radius:8px;padding:0 11px;background:#fff;color:#17212b;min-width:0}textarea{min-height:88px;padding:10px 11px;resize:vertical;line-height:1.5}.native-speech-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:end}.native-speech-form textarea{font-size:18px}.search{min-height:42px;flex:1 1 280px;display:flex;align-items:center;gap:8px;border:1px solid #ccd7db;background:#fff;border-radius:8px;padding:0 11px}.search input{border:0;padding:0;width:100%;outline:0}.actions{display:flex;gap:8px}.icon-only{width:38px;height:38px;min-height:38px;padding:0}.danger{color:#a33b2d}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:820px){.topbar{min-height:54px;padding:0 12px}.topbar-brand{font-size:20px}.topbar-title{font-size:16px}.menu-popover{width:min(220px,calc(100vw - 24px))}.brand{min-height:42px}main{padding:16px}h1{font-size:24px}.split,.settings-grid,.admin-grid,.admin-user-form,.choices,.native-speech-form,.auto-speech,.story-grammar-list{grid-template-columns:1fr}.auto-speech-indicator{justify-self:start}.training-stage{padding:0}.training-card{padding:20px}.training-ready{padding:34px 20px}.training-ready strong{font-size:26px}.focus-stage{padding:18px}.training-card.focus-card{padding:20px 0}.focus-card h1.focus-word{font-size:64px;padding-right:0}.focus-card .advanced-block{margin-top:28px;gap:22px}.focus-card .advanced-prompt{font-size:22px}.focus-card .advanced-example{font-size:34px;line-height:1.5}.training-card h1{font-size:42px;padding-right:44px}.sound{right:20px;top:58px}.training-card h1.dictation-title{font-size:34px}.dictation-list-header{align-items:stretch;flex-direction:column}.dictation-shuffle-option{align-self:flex-start}.dictation-list-actions{justify-content:stretch}.dictation-list-actions button{flex:1 1 auto}.dictation-focus-center{width:calc(100vw - 24px);gap:13px}.dictation-focus-controls{gap:8px}.dictation-focus-controls button{min-height:62px;padding:0 8px;gap:5px;font-size:15px}.dictation-focus-controls .dictation-play-button{min-height:72px;font-size:18px}.dictation-countdown{font-size:14px}.dictation-exit-button{left:max(14px,env(safe-area-inset-left));top:max(14px,env(safe-area-inset-top))}}
