:root{--bg: #faf6ef;--panel: #ffffff;--panel-alt: #fdf2eb;--border: #e6dfd2;--text: #1a1814;--ink-soft: #4a4640;--muted: #8a847d;--accent: #b54a1e;--accent-soft: #fdf2eb;--danger: #c43a2a;--serif: "Crimson Pro", Georgia, "Times New Roman", serif;--sans: "Inter", -apple-system, BlinkMacSystemFont, system-ui, "Segoe UI", Helvetica, Arial, sans-serif;font-family:var(--sans);color-scheme:light}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text)}button{font:inherit;font-weight:500;color:var(--text);background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:9px 16px;min-height:36px;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease,transform .08s ease}button:hover{background:var(--panel-alt);border-color:var(--muted)}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:active{transform:translateY(1px)}button:disabled{opacity:.55;cursor:not-allowed;transform:none}button:disabled:hover{background:var(--panel);border-color:var(--border)}input,textarea{font:inherit;color:var(--text);background:var(--panel);border:1px solid var(--border);border-radius:8px}input:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:2px}input::placeholder,textarea::placeholder{color:var(--muted)}button.primary{background:var(--accent);border-color:var(--accent);color:#fff}button.primary:hover{background:#9c3f17;border-color:#9c3f17;color:#fff}button.primary:disabled:hover{background:var(--accent);border-color:var(--accent)}button.danger{color:var(--danger);border-color:var(--border)}button.danger:hover{background:var(--accent-soft);border-color:var(--danger);color:var(--danger)}button.link{background:transparent;border:0;color:var(--ink-soft);text-decoration:underline;padding:6px 8px;min-height:0}button.link:hover{background:transparent;color:var(--accent)}.public-active-page{min-height:100vh;background:var(--bg);color:var(--text);overflow-x:hidden}.public-active-nav{width:min(1120px,calc(100vw - 32px));margin:0 auto;padding:22px 0;display:flex;align-items:center;justify-content:space-between;gap:16px}.public-active-brand{font-family:var(--serif);font-size:25px;font-weight:600;color:var(--text);text-decoration:none}.public-active-signin{color:var(--ink-soft);text-decoration:none;font-size:14px}.public-active-hero{width:min(1120px,calc(100vw - 32px));margin:0 auto;min-height:calc(100vh - 86px);display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.82fr);gap:34px;align-items:center;padding:40px 0 72px}.public-active-copy{display:grid;gap:18px}.public-active-kicker{color:var(--accent);font-size:13px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.public-active-copy h1{margin:0;max-width:700px;font-family:var(--serif);font-size:clamp(44px,6vw,74px);line-height:.98;font-weight:600}.public-active-copy p{max-width:640px;margin:0;color:var(--ink-soft);font-size:18px;line-height:1.58}.public-active-lang{display:flex;gap:10px;flex-wrap:wrap}.public-active-lang span,.public-active-lang strong{display:inline-flex;align-items:center;min-height:38px;padding:8px 12px;border:1px solid var(--border);border-radius:8px;background:var(--panel);color:var(--ink-soft);font-size:14px}.public-active-lang strong{color:var(--text);background:#eef7f5;border-color:#bedbd4}.public-active-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.public-active-primary,.public-active-secondary{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:12px 18px;border-radius:8px;font-weight:600;text-decoration:none}.public-active-primary{background:var(--accent);border:1px solid var(--accent);color:#fff;box-shadow:inset 0 -2px #0000002e}.public-active-primary:hover{background:#9c3f17;border-color:#9c3f17;color:#fff}.public-active-secondary{background:var(--panel);border:1px solid rgba(26,24,20,.18);color:var(--text)}.public-active-secondary:hover{background:var(--panel-alt)}.public-active-preview{display:grid;gap:14px}.public-preview-reader,.public-preview-card{border:1px solid var(--border);border-radius:8px;background:var(--panel);box-shadow:0 14px 42px -34px #1a181475}.public-preview-reader{min-height:310px;display:grid;align-content:center;gap:26px;padding:28px}.public-preview-reader>span,.public-preview-card>span{color:#2f6f68;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.public-preview-reader p{margin:0;font-family:var(--serif);font-size:clamp(30px,4vw,46px);line-height:1.28}.public-preview-reader mark{border-radius:7px;background:#eef7f5;color:var(--text);padding:0 5px}.public-preview-reader button{display:inline;min-height:0;padding:0 5px;border:0;border-radius:7px;background:var(--accent-soft);color:var(--text);font:inherit;cursor:default}.public-preview-card{display:grid;gap:8px;padding:20px;border-left:4px solid #2f5f8f}.public-preview-card strong{font-size:18px;line-height:1.4}.public-preview-card small{color:var(--ink-soft);font-size:14px}.public-active-method{width:min(1120px,calc(100vw - 32px));margin:0 auto;padding:0 0 72px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.public-active-method article{min-height:190px;display:grid;align-content:start;gap:10px;padding:18px;border:1px solid var(--border);border-radius:8px;background:var(--panel)}.public-active-method span{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--text);color:#fff;font-size:13px;font-weight:800}.public-active-method article:nth-child(2) span{background:#2f6f68}.public-active-method article:nth-child(3) span{background:#2f5f8f}.public-active-method article:nth-child(4) span{background:var(--accent)}.public-active-method h2{margin:0;font-family:var(--serif);font-size:27px;line-height:1.1}.public-active-method p,.public-active-stack p{margin:0;color:var(--ink-soft);line-height:1.55}.public-active-stack{width:min(760px,calc(100vw - 32px));margin:0 auto;padding:72px 0 96px;display:grid;justify-items:start;gap:16px;border-top:1px solid var(--border)}.public-active-stack h2{margin:0;font-family:var(--serif);font-size:clamp(34px,4vw,52px);line-height:1.05}@media(max-width:880px){.public-active-hero{min-height:0;grid-template-columns:1fr}.public-active-method{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:560px){.public-active-nav,.public-active-hero,.public-active-method,.public-active-stack{width:min(100vw - 24px,1120px)}.public-active-hero{padding-top:22px;gap:24px}.public-active-copy h1{font-size:42px}.public-active-copy p{font-size:16px}.public-active-actions,.public-active-primary,.public-active-secondary{width:100%}.public-preview-reader{min-height:240px;padding:20px}.public-active-method{grid-template-columns:1fr}.public-active-method article{min-height:0}}.app{--side-width: 0px;display:grid;grid-template-columns:1fr;height:100vh;overflow:hidden}.main{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:54px 32px 112px;position:relative;min-height:0;min-width:0;overflow-y:auto;overflow-x:hidden}.controls{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;gap:8px;align-items:center;z-index:10;padding:8px;background:#ffffffeb;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:20px;box-shadow:0 8px 24px #1a18141f;width:min(840px,calc(100vw - 32px));max-width:calc(100vw - 32px);flex-wrap:wrap;justify-content:center;font-size:14px}.controls.reading-composer{width:min(620px,calc(100vw - 32px));padding:6px;border-radius:16px}.controls.reading-composer .typed-lookup{flex:1 1 auto;min-width:0}.controls.reading-composer .composer-form,.controls.reading-composer .composer-input-wrap{width:100%}.controls.reading-composer .composer-textarea::placeholder{text-align:left}.controls.reading-composer .mic-button{display:none}.controls>*{min-height:40px;display:inline-flex;align-items:center}.controls button{border-radius:12px;min-height:40px;height:40px;padding:0 14px;font-size:14px;font-weight:500;border:1px solid transparent;background:transparent;color:var(--ink-soft)}.controls button:hover{background:var(--panel-alt);border-color:var(--border);color:var(--text)}.controls button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.controls button:active{transform:translateY(1px)}.controls button:disabled{opacity:.42;cursor:default}.controls button:disabled:hover{background:transparent;border-color:transparent;color:var(--ink-soft)}.controls button.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:inset 0 -2px #0000002e}.controls button.primary:hover{background:#9c3f17;border-color:#9c3f17;color:#fff;box-shadow:inset 0 -2px #00000038}.typed-lookup{display:flex;align-items:center;gap:6px;min-height:40px;flex:1 1 420px;min-width:280px}.composer-input-wrap{position:relative;flex:1 1 auto;min-width:0;min-height:40px}.composer-input-wrap.idle-hint:not(:focus-within) .composer-textarea{animation:composerIdleBlink 2.4s ease-in-out infinite}.typed-lookup .composer-textarea{width:100%;min-width:0;min-height:40px;max-height:96px;border-radius:14px;padding:9px 12px;font-size:14px;line-height:20px;background:var(--panel-alt);resize:none;overflow-y:auto}.composer-input-wrap.is-listening.has-interim,.composer-input-wrap.is-listening.has-interim .composer-textarea{min-height:72px}.composer-input-wrap.is-listening:not(.has-typed) .composer-textarea{color:transparent}.composer-input-wrap.is-listening:not(.has-typed) .composer-textarea::placeholder{color:transparent}.composer-input-wrap.is-listening.has-typed .listening-overlay{display:none}.listening-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;gap:9px;padding:0 12px;color:var(--ink-soft);pointer-events:none;overflow:hidden}.composer-input-wrap.has-interim .listening-overlay{align-items:flex-start;padding-top:9px}.listening-text{min-width:0;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;white-space:normal;overflow-wrap:anywhere;color:var(--text);line-height:20px;animation:listeningTextIn .22s ease-out both}.listening-pulse{display:inline-flex;align-items:center;gap:3px}.listening-pulse span{width:4px;height:4px;border-radius:999px;background:var(--accent);opacity:.45;animation:listeningDot 1.25s ease-in-out infinite}.listening-pulse span:nth-child(2){animation-delay:.16s}.listening-pulse span:nth-child(3){animation-delay:.32s}.typed-lookup button{white-space:nowrap}.typed-lookup .lookup-submit{display:inline-flex}.controls button.enter-button{width:40px;padding:0;align-items:center;justify-content:center;flex:0 0 40px}.controls button.enter-button svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.controls button.mic-button{background:var(--text);border-color:var(--text);color:#fff;min-width:108px;width:auto;padding:0 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;flex:0 0 auto;line-height:0;font-weight:700}.controls button.mic-button:hover{background:#3b332b;border-color:#3b332b;color:#fff}.controls button.mic-button.listening{background:var(--danger);border-color:var(--danger)}.controls button.mic-button .mic-icon{width:19px;height:19px;display:block;flex:0 0 auto}.controls button.mic-button span{line-height:1}.controls button.short-listen-button{min-width:104px;padding:0 11px;display:inline-flex;flex:0 0 auto;align-items:center;justify-content:center;gap:7px;border-color:#75655257;background:#ffffffd1;color:var(--ink-soft);font-weight:700}.controls button.short-listen-button:hover{background:var(--panel-alt);border-color:#b54a1e57;color:var(--text)}.controls button.short-listen-button.listening{background:var(--accent);border-color:var(--accent);color:#fff}.controls button.short-listen-button.processing{border-color:#c08a1a6b;background:#fff7dc;color:#7a5614}.controls button.short-listen-button:disabled{opacity:.46;cursor:default}.short-listen-main,.short-listen-key{line-height:1}.short-listen-key{padding:3px 6px;border:1px solid currentColor;border-radius:6px;font-size:11px;opacity:.78}.voice-shortcut-hint{min-height:40px;padding:0 10px;border-left:1px solid var(--border);color:var(--muted);font-size:12px;gap:5px;white-space:nowrap}.voice-shortcut-hint kbd{min-width:0;padding:2px 5px;border:1px solid var(--border);border-radius:5px;background:var(--panel-alt);color:var(--ink-soft);font-family:var(--sans);font-size:11px;line-height:1}.controls button.danger{color:var(--danger);border-color:#c43a2a59;background:transparent}.controls button.danger:hover{background:#c43a2a14;border-color:var(--danger);color:var(--danger)}.controls .status-pill{background:transparent;border:0;padding:0 8px;height:40px;font-size:13px;color:var(--ink-soft)}.controls .meter{background:transparent;border:0;padding:0 8px;height:40px;gap:8px}.saved-toggle-top,.anki-export-top{justify-self:start;height:36px;padding:0 10px 0 12px;gap:8px;border-radius:10px;background:#ffffffeb;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);font-size:13px;font-weight:500;color:var(--ink-soft);box-shadow:none;display:inline-flex;align-items:center;white-space:nowrap}.anki-export-top svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.history-count{min-width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;padding:0 6px;border-radius:999px;background:var(--panel-alt);color:var(--text);font-size:12px;font-weight:800}.saved-toggle-top:hover,.anki-export-top:hover{background:#fdf2ebeb;border-color:var(--muted);color:var(--text)}.meter{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:var(--panel);border:1px solid var(--border);border-radius:999px;font-size:12px;color:var(--ink-soft);flex:0 0 auto}.meter-bar{width:80px;height:6px;border-radius:3px;background:var(--panel-alt);overflow:hidden;position:relative;flex:0 0 auto}.meter-fill{height:100%;background:linear-gradient(90deg,#2f8a3f 0%,#c08a1a 70%,var(--danger) 95%);transition:width 80ms linear}.meter.silent{color:var(--danger)}.meter-silent{visibility:hidden}.meter.silent .meter-silent{visibility:visible}.gear{background:var(--panel);border:1px solid var(--border);border-radius:999px;width:32px;height:32px;font-size:16px;line-height:1;display:inline-flex;align-items:center;justify-content:center;padding:0;cursor:pointer;color:var(--ink-soft)}.gear:hover{color:var(--accent);border-color:var(--muted)}.history-head-actions{display:inline-flex;gap:6px;align-items:center}.drawer-close{display:inline-flex}.user-menu{position:absolute;top:16px;right:16px;z-index:20}.reader-shell{width:min(900px,100%);min-height:100%;display:flex;flex-direction:column;align-items:center;gap:18px}.reader-shell.paste-shell{width:min(920px,100%);min-height:auto;display:flex;flex-direction:column;align-items:center;gap:18px}.paste-shell .error-banner,.paste-shell .info-banner{justify-self:center}.paste-shell .paste-reader{width:min(760px,100%);display:flex;flex-direction:column;gap:12px;align-self:center}.paste-shell .session-summary,.paste-shell .cache-toast,.paste-shell .interim,.paste-shell .lookup-empty{width:100%;align-self:start;margin-top:0}.reader-shell.paste-shell.source-input-shell{width:min(900px,100%);min-height:auto;display:flex;flex-direction:column;align-items:center}.source-input-shell .paste-reader{display:flex;width:min(760px,100%)}.reader-shell.repair-shell{width:min(1180px,100%);min-height:auto;display:grid;grid-template-columns:minmax(360px,1fr) minmax(340px,.86fr);align-items:start;gap:18px}.repair-shell .error-banner,.repair-shell .info-banner{grid-column:1 / -1;justify-self:center}.repair-shell .repair-reader,.repair-shell .lookup-empty{grid-column:1;grid-row:2;width:100%;align-self:start}.repair-shell .card-stage{grid-column:2;grid-row:2;width:100%;align-self:start}.reader-topbar{width:min(920px,100%);display:grid;grid-template-columns:auto auto auto auto minmax(0,1fr);align-items:center;justify-items:start;gap:8px;margin-bottom:12px}.reader-topbar .input-entry{grid-column:3}.input-entry{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.input-entry-button{min-height:36px;padding:0 12px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#fffc;color:var(--text);border-color:var(--border);font-size:13px;font-weight:600;white-space:nowrap}.input-entry-button svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.input-entry-button:hover{background:#fff;border-color:var(--muted);color:var(--text)}.topbar-book-button{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 12px;border-radius:10px;background:#ffffffbd;border-color:var(--border);color:var(--ink-soft);font-size:13px;font-weight:700;white-space:nowrap}.topbar-book-button:hover{background:#fff;border-color:#b54a1e4d;color:var(--accent)}.topbar-book-button svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linejoin:round}.input-entry-short-label{display:none}.reader-tool-row{grid-column:3;justify-self:start;min-width:0;display:inline-flex;align-items:center;justify-content:center;gap:0;padding:4px;background:var(--panel);border:1px solid var(--border);border-radius:12px;box-shadow:0 6px 18px #1a18140a}.reader-mode-tabs{display:inline-flex;gap:4px;padding:4px;background:var(--panel);border:1px solid var(--border);border-radius:12px;box-shadow:0 6px 18px #1a18140d}.reader-mode-tabs button{min-height:34px;padding:0 14px;border:0;border-radius:8px;background:transparent;color:var(--ink-soft);font-size:14px}.source-tabs button{display:inline-flex;align-items:center;justify-content:center;gap:7px}.source-tabs button svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto}.source-tabs button span{min-width:0}.reader-mode-tabs button.active,.reader-mode-tabs button[aria-selected=true]{background:var(--text);color:#fff}.source-tabs{flex-wrap:wrap;justify-content:center}.auto-audio-toggle{min-height:34px;padding:0 10px;border:0;border-radius:8px;display:inline-flex;align-items:center;gap:6px;background:transparent;color:var(--ink-soft);font-size:13px;white-space:nowrap}.auto-audio-toggle:hover{background:var(--panel-alt);color:var(--text)}.auto-audio-toggle.active{background:var(--text);color:#fff}.auto-audio-toggle.active:hover{background:#2a261f;color:#fff}.toggle-track{width:30px;height:18px;padding:2px;border-radius:999px;display:inline-flex;align-items:center;justify-content:flex-start;background:#8a847d40;box-shadow:inset 0 0 0 1px #7565522e;flex:0 0 auto}.toggle-track span{width:14px;height:14px;border-radius:999px;background:var(--panel);box-shadow:0 1px 3px #1a181438;transform:translate(0);transition:transform .16s ease}.auto-audio-toggle.active .toggle-track{background:#ffffff52;box-shadow:inset 0 0 0 1px #ffffff42}.auto-audio-toggle.active .toggle-track span{transform:translate(12px);background:#fff}.auto-audio-select{min-height:34px;width:min(190px,28vw);max-width:190px;padding:0 28px 0 10px;border:0;border-left:1px solid var(--border);border-radius:0 8px 8px 0;background:transparent;color:var(--ink-soft);font:inherit;font-size:13px}.auto-audio-select:disabled{opacity:.48}.auto-audio-stop{min-height:34px;padding:0 10px;border:0;border-left:1px solid var(--border);border-radius:0 8px 8px 0;display:inline-flex;align-items:center;gap:6px;background:#fff7f1;color:var(--accent);font-size:13px;font-weight:700}.auto-audio-stop:hover{background:var(--accent-soft);color:var(--accent)}.auto-audio-stop svg{width:14px;height:14px;fill:currentColor;flex:0 0 auto}.user-menu-trigger{width:36px;height:36px;border-radius:999px;background:var(--panel);border:1px solid var(--border);color:var(--text);font-family:var(--serif);font-size:16px;font-weight:600;cursor:pointer;padding:0;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.user-menu-trigger:hover{background:var(--panel-alt);border-color:var(--muted)}.user-menu-panel{position:absolute;top:44px;right:0;min-width:200px;background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:0 12px 32px #1a18141a;padding:6px;display:flex;flex-direction:column;gap:2px;animation:cardFadeUp .18s ease-out}.user-menu-email{font-size:12px;color:var(--muted);padding:8px 12px 6px;border-bottom:1px solid var(--border);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-item{display:block;padding:8px 12px;border-radius:4px;color:var(--text);background:transparent;border:0;font:inherit;font-size:14px;font-weight:500;text-align:left;text-decoration:none;cursor:pointer;width:100%}.user-menu-item:hover{background:var(--panel-alt)}.user-menu-divider{height:1px;background:var(--border);margin:4px 0}.user-menu-danger{color:var(--danger)}.user-menu-danger:hover{background:var(--accent-soft)}.settings-drawer{position:fixed;top:64px;right:16px;bottom:24px;width:min(380px,calc(100vw - 32px));border:1px solid var(--border);border-radius:8px;background:var(--panel);display:flex;flex-direction:column;min-height:0;overflow:hidden;box-shadow:0 18px 48px #1a18142e;transform:translate(calc(100% + 32px));transition:transform .22s ease-out;z-index:55}.settings-drawer[data-open=true]{transform:translate(0)}.settings-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);gap:8px}.settings-head h2{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:500}.nudge-cta,.walk-review,.reader-extra-link,.simple-back-button,.answer-swap-question,.paper-listen-action,.paper-short-action,.paper-quiz-action,.paper-book-back,.source-action-button,.review-correct-button{display:inline-flex;align-items:center;justify-content:center;gap:8px}.nudge-cta>svg,.walk-review>svg,.reader-extra-link>svg,.simple-back-button>svg,.answer-swap-question>svg,.paper-listen-action>svg,.paper-short-action>svg,.paper-quiz-action>svg,.paper-book-back>svg,.source-action-button>svg,.review-correct-button>svg,.paper-placeholder-icon>svg,.paper-transcript-cancel>svg,.transcript-cancel>svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto;pointer-events:none}.settings-head-actions{display:inline-flex;gap:6px}.settings-head-actions button.ghost{background:transparent;border:1px solid var(--border);color:var(--ink-soft);padding:4px 10px;font-size:12px;border-radius:4px;cursor:pointer}.settings-head-actions button.ghost:hover{color:var(--text);border-color:var(--muted)}.settings-list{flex:1;overflow-y:auto;padding:12px 0}.settings-list section{padding:4px 20px 16px}.settings-list h3{margin:14px 0 10px;font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:500}.setting-row{display:flex;flex-direction:column;gap:6px;padding:10px 0;border-bottom:1px solid var(--border)}.setting-row label{font-size:13px;font-weight:500;color:var(--text);display:flex;justify-content:space-between;align-items:center;gap:6px}.setting-row input[type=range]{width:100%;accent-color:var(--accent)}.setting-hint{font-size:12px;color:var(--ink-soft);line-height:1.45}.reset-one{background:transparent;border:0;color:var(--muted);cursor:pointer;font-size:14px;padding:0 4px;line-height:1}.reset-one:hover{color:var(--accent)}.settings-error{margin:12px 20px;padding:8px 12px;background:#fbeae6;border:1px solid var(--danger);color:var(--danger);border-radius:6px;font-size:13px}.status-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:var(--panel);border:1px solid var(--border);font-size:13px;color:var(--ink-soft)}.dot{width:8px;height:8px;border-radius:50%;background:var(--muted)}.dot.live{background:#2f8a3f;box-shadow:0 0 8px #2f8a3f55}.dot.paused,.dot.muted{background:#c08a1a}.hero{text-align:center;color:var(--ink-soft);max-width:720px}.hero h1{margin:0 0 16px;color:var(--text);font-family:var(--serif);font-size:64px;font-weight:600;letter-spacing:-.02em;line-height:1.05}.hero p{margin:8px 0;font-size:20px;line-height:1.5;color:var(--ink-soft)}.hero kbd{background:var(--panel);border:1px solid var(--border);border-radius:4px;padding:2px 6px;font-size:12px;font-family:ui-monospace,monospace;color:var(--text)}.reader-hero{margin:auto 0}.learning-loop-home{width:min(560px,100%);min-height:min(680px,calc(100vh - 160px));display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:18px;padding:24px 22px;border:1px solid rgba(117,101,82,.18);border-radius:22px;background:#ffffff8a;box-shadow:0 18px 54px #1a181414;text-align:left}.wordzam-mark{align-self:flex-start;min-height:26px;display:inline-flex;align-items:center;padding:0 9px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:12px;font-weight:850}.learning-loop-home h1{max-width:430px;margin:8px 0;font-family:var(--sans);font-size:52px;font-weight:900;letter-spacing:0;line-height:.98}.quest-choice-list{display:grid;gap:10px}.quest-choice-card{min-height:96px;display:grid;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:12px;padding:14px;border:1px solid rgba(117,101,82,.18);border-radius:14px;background:#ffffffc7;color:var(--text);text-align:left;box-shadow:0 10px 24px #1a18140d}.quest-choice-card.primary{border-color:#b54a1e3d;background:#fff9f4eb}.quest-choice-card:hover{border-color:#b54a1e5c;transform:translateY(-1px)}.quest-choice-icon{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;background:var(--accent-soft);color:var(--accent)}.quest-choice-icon svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.quest-choice-card strong{display:block;color:var(--text);font-size:17px;line-height:1.15}.quest-choice-card small{display:block;margin-top:4px;color:var(--ink-soft);font-size:13px;line-height:1.35}.quest-bottom-cta{margin-top:auto;width:100%;min-height:52px;border-radius:12px;border:0;background:var(--accent);color:#fff;font-size:15px;font-weight:850;box-shadow:0 10px 22px #b54a1e38}.quest-bottom-cta:hover{background:#a74319}.reader-hero.book-ready{animation:cardFadeUp .2s ease-out both}.physical-book-ready{display:grid;justify-items:center;gap:10px}.physical-book-ready h1{margin-bottom:4px}.physical-book-ready-icon{width:62px;height:62px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent)}.physical-book-ready-icon svg{width:26px;height:26px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.paper-book-session{width:min(760px,100%);margin:0 auto;display:grid;justify-items:center;gap:14px;padding:22px 18px 26px}.paper-book-session.lookup-step{min-height:min(700px,calc(100vh - 150px));display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding-bottom:120px}.paper-book-session.quiz-step{width:min(680px,100%)}.paper-book-steps{width:min(430px,100%);display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:5px;padding:4px;border:1px solid rgba(117,101,82,.18);border-radius:999px;background:#ffffffc2}.paper-book-steps button{min-width:0;min-height:34px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 10px;border:0;border-radius:999px;background:transparent;color:var(--ink-soft);font-size:12px;font-weight:850}.paper-book-steps button.active{background:var(--text);color:#fff}.paper-book-steps span{width:19px;height:19px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#ffffff29;font-size:11px}.paper-book-copy{display:grid;justify-items:center;gap:8px;text-align:center}.mode-pill{min-height:24px;display:inline-flex;align-items:center;padding:0 9px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:11px;font-weight:850}.paper-book-copy h1{max-width:430px;margin:0;color:var(--text);font-family:var(--sans);font-size:38px;font-weight:900;letter-spacing:0;line-height:1.02}.paper-book-copy p{max-width:420px;margin:0;color:var(--ink-soft);font-size:14px;line-height:1.45}.paper-lookup-space{width:100%;min-height:260px;display:grid;gap:14px;place-items:center;align-self:stretch;flex:1 1 auto;padding:16px 0}.paper-transcript{width:min(640px,100%);position:relative;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:12px;padding:18px 20px;border:1px solid rgba(117,101,82,.18);border-radius:16px;background:#ffffff9e;color:var(--ink-soft);font-family:var(--serif);font-size:30px;font-style:italic;line-height:1.35;overflow-wrap:anywhere;box-shadow:0 14px 34px #1a18140f}.paper-transcript-cancel{width:44px;height:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;padding:0;border-radius:999px;background:#fff;border-color:#7565522e;color:var(--ink-soft)}.paper-listening-placeholder{width:min(430px,100%);display:grid;justify-items:center;gap:8px;padding:22px;color:var(--ink-soft);text-align:center}.paper-placeholder-icon{width:54px;height:54px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#ffffffbd;border:1px solid rgba(117,101,82,.18);color:var(--accent)}.paper-placeholder-button{cursor:pointer;box-shadow:0 10px 24px #1a181414}.paper-placeholder-button:hover{border-color:#b54a1e57;background:#fff7f2}.paper-placeholder-icon svg{width:24px;height:24px}.paper-listening-placeholder strong{color:var(--text);font-size:18px}.paper-listening-placeholder small{color:var(--muted);font-size:13px}.paper-listening-placeholder.live .paper-placeholder-icon{background:var(--text);border-color:var(--text);color:#fff;box-shadow:0 0 0 9px #b54a1e1f}.compact-paper-copy h1{font-size:32px}.compact-paper-copy p{max-width:360px}.paper-mic-button{width:118px;height:118px;display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;background:var(--accent);color:#fff;box-shadow:0 18px 34px #b54a1e47}.paper-mic-button svg{width:42px;height:42px}.paper-mic-button.listening{background:var(--text);box-shadow:0 0 0 10px #b54a1e21,0 18px 34px #1a181438}.paper-mic-status{min-height:28px;display:inline-flex;align-items:center;padding:0 12px;border-radius:999px;background:#ffffffc2;color:var(--ink-soft);font-size:13px;font-weight:750}.paper-mic-status.live{color:var(--accent)}.paper-word-strip{width:min(620px,100%);display:flex;justify-content:center;flex-wrap:wrap;gap:7px}.paper-word-strip button{min-height:31px;display:inline-flex;align-items:baseline;gap:7px;padding:4px 10px;border-radius:999px;background:#def4e8e6;border-color:#2a7a4f2e;color:#195434;font-size:13px;font-weight:800}.paper-word-strip small{color:#195434b8;font-size:12px;font-weight:600}.paper-empty-words{margin:0;color:var(--muted);font-size:13px}.paper-card-stage{width:min(620px,100%);display:flex;justify-content:center}.paper-card-stage .card{position:relative;top:auto;left:auto;right:auto;bottom:auto;width:100%;transform:none;margin:0;padding:28px 30px;animation:cardFadeUp .22s cubic-bezier(.16,1,.3,1)}.paper-lookup-dock{position:fixed;left:50%;bottom:calc(24px + env(safe-area-inset-bottom,0px));z-index:36;width:min(780px,calc(100vw - 32px));transform:translate(-50%);display:grid;grid-template-columns:minmax(0,1fr) auto auto auto;align-items:center;gap:8px;padding:8px;border:1px solid rgba(117,101,82,.2);border-radius:18px;background:#ffffffd6;box-shadow:0 18px 42px #1a18141a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.paper-lookup-input-wrap{min-width:0;display:grid;grid-template-columns:minmax(0,1fr) 42px;align-items:center;gap:6px}.paper-lookup-input-wrap textarea{width:100%;min-height:46px;max-height:96px;resize:none;padding:12px 14px;border-radius:12px;background:#fff;color:var(--text);font-size:15px;line-height:1.35;box-shadow:none}.paper-lookup-input-wrap .enter-button{width:42px;min-height:42px}.paper-listen-action,.paper-short-action,.paper-quiz-action{min-height:46px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;border-radius:12px;font-size:13px;font-weight:850;white-space:nowrap}.paper-listen-action{background:var(--text);border-color:var(--text);color:#fff}.paper-listen-action.listening{background:var(--accent);border-color:var(--accent)}.paper-listen-action svg{width:18px;height:18px}.paper-short-action{background:#fff;border-color:#75655238;color:var(--ink-soft)}.paper-short-action.listening{background:var(--accent);border-color:var(--accent);color:#fff}.paper-short-action.processing{background:var(--accent-soft);border-color:#b54a1e38;color:var(--accent)}.paper-short-action:disabled{opacity:.45;cursor:not-allowed}.paper-short-action svg{width:17px;height:17px}.paper-quiz-action{background:var(--accent-soft);border-color:#b54a1e38;color:var(--accent)}.paper-book-next,.paper-book-back{min-width:min(260px,100%)}.paper-quiz-card{width:100%;display:grid;gap:12px;margin-top:4px;padding:16px;border:1px solid rgba(117,101,82,.18);border-radius:14px;background:#ffffffc7;box-shadow:0 12px 30px #1a18140f}.paper-quiz-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.paper-quiz-head>div:first-child{display:grid;gap:2px}.paper-quiz-head span{color:var(--accent);font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.paper-quiz-head strong{color:var(--text);font-size:20px}.compact-level-tabs{transform:none}.paper-question{margin:0;color:var(--text);font-size:18px;font-weight:800;line-height:1.28}.paper-answer-helpers{padding:0}.paper-quiz-card textarea{width:100%;min-height:112px;resize:vertical;padding:13px;border-radius:10px;background:#fff;font-size:15px;line-height:1.45}.paper-review-wrap{width:100%;display:grid;gap:10px}.controls.paper-composer{width:min(480px,calc(100vw - 32px))}.controls.paper-composer .mic-button,.controls.paper-composer .short-listen-button,.controls.paper-composer .status-pill,.controls.paper-composer .meter{display:none}.hero-source-actions{margin-top:26px;display:inline-flex;flex-wrap:wrap;justify-content:center;gap:8px}.hero-source-actions button{min-height:36px;padding:0 12px;border-radius:8px;background:#ffffffb8;color:var(--ink-soft);font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:7px}.hero-source-actions button svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.hero-source-actions button:hover,.hero-source-actions button.active{background:var(--text);border-color:var(--text);color:#fff}.hero-source-actions button.secondary{background:transparent;border-style:dashed}.input-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:45;padding:72px 20px 24px;display:flex;align-items:flex-start;justify-content:center;background:#1a181447;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);overflow:hidden}.input-sheet{position:relative;width:min(1120px,100%);height:min(760px,calc(100vh - 96px));max-height:calc(100vh - 96px);overflow:hidden;padding:18px;border:1px solid rgba(117,101,82,.24);border-radius:10px;background:#faf8f3fa;box-shadow:0 24px 70px #1a181433;animation:cardFadeUp .2s ease-out;display:flex;flex-direction:column}.input-sheet-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:4px 2px 16px}.input-sheet-actions{display:inline-flex;align-items:center;gap:8px}.input-history-toggle{min-height:34px;display:inline-flex;align-items:center;gap:7px;padding:0 12px;border-radius:999px;border:1px solid rgba(117,101,82,.22);background:#ffffffb8;color:var(--ink-soft);font-size:13px;font-weight:800}.input-history-toggle span{min-width:20px;min-height:20px;display:inline-flex;align-items:center;justify-content:center;padding:0 6px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:11px;letter-spacing:0;text-transform:none}.input-sheet-head span{color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.input-sheet-head .input-history-toggle span{color:var(--accent);font-size:11px;letter-spacing:0;text-transform:none}.input-sheet-head h2{margin:3px 0 0;color:var(--text);font-size:22px;line-height:1.15}.input-sheet-close{width:34px;height:34px;min-height:34px;padding:0;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#ffffffb8;color:var(--muted)}.input-sheet-close svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}.input-sheet-body{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr);gap:14px;align-items:stretch}.input-workspace{min-width:0;min-height:450px;border:1px solid rgba(117,101,82,.22);border-radius:8px;background:#ffffffad;display:flex;flex-direction:column;overflow:hidden}.input-mode-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;padding:6px;border-bottom:1px solid rgba(117,101,82,.18);background:#ffffff94}.input-mode-tabs button{min-width:0;min-height:42px;padding:0 10px;border:0;border-radius:7px;background:transparent;color:var(--ink-soft);display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px}.input-mode-tabs button:hover{background:var(--panel-alt);color:var(--text)}.input-mode-tabs button[aria-selected=true]{background:var(--text);color:#fff}.input-mode-tabs svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto}.input-mode-tabs span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.input-mode-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:8px;border-bottom:1px solid rgba(117,101,82,.18);background:#ffffff94}.input-mode-grid button{min-width:0;min-height:86px;display:grid;grid-template-columns:38px minmax(0,1fr);align-items:center;gap:10px;padding:12px;border:1px solid rgba(117,101,82,.16);border-radius:12px;background:#ffffffb8;color:var(--text);text-align:left}.input-mode-grid button:hover{border-color:#b54a1e47;background:#fff}.input-mode-grid button[aria-selected=true]{border-color:#b54a1e6b;background:var(--accent-soft)}.input-mode-card-icon{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:11px;background:#fff;color:var(--accent)}.input-mode-card-icon svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.input-mode-grid strong,.input-mode-grid small{display:block;min-width:0}.input-mode-grid strong{color:var(--text);font-size:14px;line-height:1.15}.input-mode-grid small{margin-top:3px;color:var(--ink-soft);font-size:12px;line-height:1.3}.input-mode-panel{flex:1;min-height:0;display:flex;overflow:auto}.input-mode-content{width:100%;min-height:0;padding:16px;display:flex;flex-direction:column;gap:14px;overflow:auto}.input-mode-content.practice-choice{background:#fffcf57a}.book-mode-copy{flex:1;min-height:230px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--ink-soft)}.book-mode-copy h3{margin:12px 0 0;color:var(--text);font-size:20px;line-height:1.2}.book-mode-copy p{max-width:360px;margin:8px 0 0;color:var(--ink-soft);font-size:14px;line-height:1.45}.compact-import-copy{flex:0 1 auto;min-height:170px}.book-mode-icon{width:54px;height:54px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent)}.book-mode-icon svg,.source-action-button .button-icon,.source-action-button>svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.practice-field{display:grid;gap:7px}.import-mode-note{display:grid;gap:3px;padding:12px 13px;border:1px solid rgba(117,101,82,.16);border-radius:10px;background:#ffffffb8}.import-mode-note strong{color:var(--text);font-size:15px}.import-mode-note span{color:var(--ink-soft);font-size:13px;line-height:1.35}.practice-label,.practice-seed span{color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.practice-seed small{margin-top:-3px;color:var(--muted);font-size:12px;font-weight:500;line-height:1.35}.practice-level-tabs{display:inline-flex;gap:4px;padding:4px;border:1px solid var(--border);border-radius:9px;background:#ffffffb8;width:fit-content;max-width:100%}.practice-level-tabs button{min-height:30px;min-width:40px;padding:0 9px;border:0;border-radius:6px;background:transparent;color:var(--ink-soft);font-size:13px;font-weight:700}.practice-level-tabs button[aria-selected=true]{background:var(--text);color:#fff}.topic-chip-list{display:flex;flex-wrap:wrap;gap:6px}.topic-chip-list button{min-height:30px;padding:0 9px;border-radius:999px;background:#ffffffb8;color:var(--ink-soft);font-size:13px}.topic-chip-list button.active{background:var(--accent-soft);border-color:#b54a1e52;color:var(--accent)}.practice-seed,.article-url-field{display:grid;gap:7px}.article-url-field span{color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.article-url-field input{width:100%;min-height:46px;padding:0 12px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--text);font:inherit;box-shadow:none}.article-url-field input:focus{outline:2px solid rgba(181,74,30,.18);border-color:#b54a1e6b}.practice-seed textarea,.paste-draft{width:100%;resize:vertical;padding:11px 12px;border-radius:8px;line-height:1.45;box-shadow:none}.practice-seed textarea{min-height:82px}.paste-draft{min-height:230px}.input-action-footer{position:sticky;bottom:-16px;z-index:3;margin:auto -16px -16px;padding:12px 16px 16px;min-height:44px;display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:8px;border-top:1px solid rgba(117,101,82,.16);background:linear-gradient(to bottom,#faf8f3d6,#faf8f3fa 34%);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.input-action-footer .source-action-button{min-width:164px}.source-action-button.primary-action{background:var(--text);border-color:var(--text);color:#fff}.source-action-button.primary-action:hover{background:#2a261f;border-color:#2a261f;color:#fff}.source-action-button.primary-action:disabled{opacity:.5}.source-action-button.primary-action:disabled:hover{background:var(--text);border-color:var(--text);color:#fff}.anki-export-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;padding:72px 16px 22px;display:flex;align-items:flex-start;justify-content:center;background:#1a18144d;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);overflow:hidden}.anki-export-screen{width:min(720px,100%);height:min(720px,calc(100vh - 94px));max-height:calc(100vh - 94px);padding:16px;border:1px solid rgba(117,101,82,.24);border-radius:10px;background:#faf8f3fa;box-shadow:0 24px 70px #1a181433;display:flex;flex-direction:column;gap:12px;animation:cardFadeUp .2s ease-out;overflow:hidden}.anki-export-head{display:flex;align-items:center;justify-content:space-between;gap:14px}.anki-export-head span{color:var(--muted);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.anki-export-head h2{margin:2px 0 0;color:var(--text);font-size:22px;line-height:1.15}.anki-export-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border:1px solid rgba(117,101,82,.16);border-radius:8px;background:#ffffffb8}.anki-export-toolbar>span{color:var(--ink-soft);font-size:13px;font-weight:700}.anki-export-toolbar>div{display:flex;gap:6px}.anki-export-toolbar button{min-height:30px;padding:0 9px;border-radius:7px;background:#fff;color:var(--ink-soft);font-size:12px;font-weight:700}.anki-export-list{flex:1;min-height:0;display:grid;align-content:start;gap:8px;overflow:auto;padding-right:2px}.anki-export-row{display:grid;grid-template-columns:22px minmax(0,1fr);gap:10px;align-items:start;padding:10px;border:1px solid rgba(117,101,82,.16);border-radius:8px;background:#fff;cursor:pointer}.anki-export-row input{margin-top:3px;accent-color:var(--accent)}.anki-export-card-copy{min-width:0;display:grid;gap:3px}.anki-export-card-copy strong{color:var(--text);font-size:15px;line-height:1.25}.anki-export-card-copy span{color:var(--accent);font-size:13px;font-weight:750}.anki-export-card-copy small{color:var(--ink-soft);font-size:12px;line-height:1.35}.anki-export-empty{padding:26px 14px;border:1px dashed rgba(117,101,82,.24);border-radius:8px;background:#ffffff9e;color:var(--ink-soft);text-align:center;font-size:14px}.anki-export-footer{display:flex;justify-content:flex-end;gap:8px;padding-top:2px}.anki-export-footer .nudge-cta:disabled{opacity:.45;cursor:not-allowed}.input-history-panel{min-width:0;min-height:0;display:flex}.input-history-panel .document-history{width:100%;min-height:0;background:#ffffffa8}.input-history-popover{position:absolute;inset:64px 18px 18px auto;z-index:6;width:min(360px,calc(100% - 36px));display:flex;align-items:stretch;justify-content:flex-end;pointer-events:none}.input-history-panel.floating{pointer-events:auto;display:grid;grid-template-rows:auto minmax(0,1fr);gap:8px;padding:10px;border:1px solid rgba(117,101,82,.22);border-radius:12px;background:#faf8f3fa;box-shadow:0 18px 48px #1a18142e}.input-history-panel.floating .document-history{min-height:0;overflow:hidden}.input-history-close{justify-self:end;min-height:30px;padding:0 10px;border-radius:999px;background:#fff;color:var(--ink-soft);font-size:12px;font-weight:800}.paste-reader{width:min(760px,100%);display:flex;flex-direction:column;gap:12px}.paste-reader-head{display:flex;align-items:center;justify-content:flex-start;gap:12px}.paste-reader-actions{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.paste-reader-head button{min-height:30px;padding:5px 10px;border-radius:6px;font-size:12px;color:var(--ink-soft)}.paste-reader-head button.photo-upload-button{min-width:118px;display:inline-flex;align-items:center;justify-content:center;gap:7px}.photo-upload-button .button-icon{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto}.photo-upload-button.is-loading,.source-action-button.is-loading{color:var(--accent);background:var(--accent-soft);border-color:#b54a1e52}.photo-upload-button .button-spinner,.source-action-button .button-spinner{width:15px;height:15px;border-radius:50%;border:2px solid rgba(181,74,30,.24);border-top-color:var(--accent);flex:0 0 auto;animation:buttonSpinner .8s linear infinite}.paste-tabs,.demo-level-tabs{display:inline-flex;gap:4px;padding:4px;background:#ffffffb3;border:1px solid var(--border);border-radius:10px;max-width:100%}.paste-tabs button,.demo-level-tabs button{min-height:30px;padding:0 10px;border:0;border-radius:7px;background:transparent;color:var(--ink-soft);white-space:nowrap}.paste-tabs button[aria-selected=true],.demo-level-tabs button[aria-selected=true]{background:var(--text);color:#fff}.paste-tabs button:disabled{opacity:.42}.demo-level-tabs button{min-width:44px;padding:0 10px;font-weight:600}.paste-reader textarea{width:100%;min-height:180px;max-height:min(55vh,520px);resize:vertical;padding:12px 14px;line-height:1.45;box-shadow:0 8px 24px #1a18140f}.paste-input-stack{display:grid;gap:12px}.source-input-panel{min-height:180px;padding:22px;display:flex;align-items:center;justify-content:center;border:1px dashed rgba(117,101,82,.34);border-radius:8px;background:#ffffff94;box-shadow:0 8px 24px #1a18140a}.source-action-button{min-height:42px;padding:0 16px;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:14px;color:var(--text);background:var(--panel)}.source-action-button.photo-upload-button{min-width:148px}.preview-stack{display:grid;gap:0}.clickable-text{min-height:260px;max-height:min(68vh,680px);resize:vertical;overflow-y:auto;padding:14px 16px;background:#ffffffc7;border:1px solid var(--border);border-radius:8px;font-family:var(--serif);font-size:20px;line-height:1.56;white-space:pre-wrap;overflow-wrap:anywhere;box-shadow:0 8px 24px #1a18140f;overscroll-behavior:contain;touch-action:pan-y}.clickable-text button{display:inline;min-height:0;padding:1px 2px;margin:0;border:0;border-radius:4px;background:transparent;font-family:inherit;font-size:inherit;font-weight:inherit;color:var(--text);line-height:inherit;touch-action:manipulation;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.clickable-text button:hover{background:var(--accent-soft);color:var(--accent)}.clickable-text button.read{background:#e6f4df;color:#244f2d}.clickable-text button.needs-practice{background:#ffe3dc;color:#8f2e22;box-shadow:inset 0 -2px #c43a2a59}.clickable-text.is-selecting{cursor:crosshair;touch-action:none;user-select:none;-webkit-user-select:none}.clickable-text.is-selecting button{touch-action:none}.clickable-text button.selected{background:var(--accent-soft);color:var(--accent);box-shadow:0 0 0 1px #b54a1e29}.clickable-text button.spoken{background:#fff1a8;color:var(--text);box-shadow:inset 0 -2px #c08a1a6b}.clickable-text button.selected.spoken{background:var(--accent-soft);color:var(--accent);box-shadow:0 0 0 1px #b54a1e29,inset 0 -2px #c08a1a59}.clickable-empty{color:var(--muted);font-family:var(--sans);font-size:15px;font-style:italic}.session-summary{width:min(680px,100%);background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:14px;box-shadow:0 12px 30px #1a18141f;animation:cardFadeUp .18s ease-out}.session-summary div{display:flex;justify-content:space-between;gap:12px;align-items:baseline}.session-summary strong{font-size:14px;color:var(--text)}.session-summary span,.session-summary p{font-size:13px;color:var(--ink-soft)}.session-summary p{margin:10px 0 12px;line-height:1.4}.session-summary button{min-height:32px;padding:5px 10px;border-radius:6px;font-size:13px}.interim{width:min(760px,100%);padding:0;text-align:left;font-family:var(--serif);font-size:28px;font-weight:400;font-style:italic;letter-spacing:-.005em;line-height:1.35;color:var(--ink-soft);pointer-events:none;overflow-wrap:anywhere;animation:cardFadeUp .18s ease-out both}.interim.placeholder{opacity:.42;color:var(--muted)}.card-stage{width:min(900px,100%);min-height:0;display:flex;justify-content:center}.lookup-empty{min-height:220px;display:flex;align-items:center;justify-content:center;padding:24px;border:1px dashed var(--border);border-radius:10px;background:#ffffff7a;color:var(--muted);font-size:14px;text-align:center}.card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(1100px,calc(100% - 80px));min-width:0;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:44px 56px;box-shadow:0 24px 60px #1a18141f,0 4px 14px #1a18140f;animation:cardSlideUp .44s cubic-bezier(.22,1.2,.36,1);transform-origin:50% 60%}.card.partial{border-color:var(--accent);box-shadow:0 24px 60px #b54a1e2e,0 0 0 1px var(--accent-soft)}.card .placeholder{opacity:.4}.card.fading-out{animation:cardFadeOut .34s cubic-bezier(.55,0,.7,.2) forwards;pointer-events:none;z-index:0}.card.fading-out .head,.card.fading-out .form-line,.card.fading-out .translation,.card.fading-out .example,.card.fading-out .source-de,.card.fading-out .hardest-word-block{animation:none;opacity:1;transform:none}.card:not(.fading-out){z-index:1}.card-dismiss{position:absolute;top:12px;right:12px;width:38px;height:38px;min-height:38px;padding:0;border-radius:999px;border:1px solid rgba(117,101,82,.22);background:#ffffffbd;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;z-index:6;touch-action:manipulation}.card-dismiss:hover,.card-dismiss:focus-visible{background:var(--accent-soft);border-color:#b54a1e52;color:var(--accent)}.card-dismiss svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;pointer-events:none}.card-stage .card{position:relative;top:auto;left:auto;right:auto;bottom:auto;transform:none;width:min(900px,100%);margin:0;padding:34px 40px;animation:cardFadeUp .22s cubic-bezier(.16,1,.3,1)}.lookup-popover-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:42;background:transparent}.lookup-popover{position:fixed;top:96px;left:50%;width:min(420px,calc(100vw - 24px));transform:translate(-50%);z-index:43}.lookup-popover .card{position:relative;top:auto;left:auto;right:auto;bottom:auto;transform:none;width:100%;max-height:min(66vh,620px);overflow-y:auto;margin:0;padding:24px;border-radius:10px;box-shadow:0 18px 42px #1a18142e,0 4px 12px #1a181414;animation:cardFadeUp .18s cubic-bezier(.16,1,.3,1)}.lookup-popover .card .surface{font-size:clamp(26px,5vw,38px)}.lookup-popover .card .translation,.lookup-popover .card .example{font-size:14px}.book-lookup-tray{width:min(720px,100%);display:grid;gap:10px;padding:14px;border:1px solid var(--border);border-radius:10px;background:#ffffffad;box-shadow:0 10px 28px #1a181414}.book-lookup-tray>span{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}.book-lookup-tray>div{display:flex;gap:8px;flex-wrap:wrap}.book-lookup-chip{min-height:34px;display:inline-flex;align-items:baseline;gap:7px;padding:5px 10px;border-radius:999px;background:#fff;color:var(--text);font-size:13px}.book-lookup-chip small{color:var(--muted);font-size:12px}.card .head,.card .form-line,.card .translation,.card .example,.card .source-de,.card .hardest-word-block{animation:cardFadeUp .4s cubic-bezier(.16,1,.3,1) both}.card .head{animation-delay:.04s}.card .form-line{animation-delay:.12s}.card .translation,.card .source-de{animation-delay:.18s}.card .example{animation-delay:.28s}.card .hardest-word-block{animation-delay:.34s}@keyframes cardFadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes listeningDot{0%,to{opacity:.35;transform:translateY(0)}45%{opacity:1;transform:translateY(-2px)}}@keyframes listeningTextIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes composerIdleBlink{0%,to{border-color:var(--border);box-shadow:0 0 #b54a1e00}45%{border-color:#b54a1e75;box-shadow:0 0 0 3px #b54a1e12}}@keyframes interimFadeUp{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,calc(-50% + 12px))}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes cardSlideUp{0%{opacity:0;transform:translate(-50%,calc(-50% + 36px)) scale(.92)}60%{opacity:1}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes cardFadeOut{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,calc(-50% - 24px)) scale(.96)}}@keyframes cardSlideUpMobile{0%{opacity:0;transform:translateY(28px) scale(.94)}60%{opacity:1}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes cardFadeOutMobile{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-14px) scale(.97)}}.card .head{display:flex;align-items:baseline;gap:20px;flex-wrap:wrap;min-width:0}.card .article{color:var(--accent);font-family:var(--serif);font-weight:600;font-size:56px;letter-spacing:-.01em}.card .surface{font-family:var(--serif);font-size:76px;font-weight:600;letter-spacing:-.02em;line-height:1.05;color:var(--text);min-width:0;max-width:100%;overflow-wrap:anywhere;word-break:break-word}.surface-with-audio{display:inline-flex;align-items:center;flex-wrap:wrap;gap:8px;min-width:0;max-width:100%}.card .pos{font-size:13px;text-transform:uppercase;color:var(--accent);letter-spacing:.1em;background:var(--accent-soft);padding:5px 12px;border-radius:999px;align-self:center;font-weight:500}.card .form-line{display:flex;align-items:center;gap:16px;margin-top:14px;flex-wrap:wrap;font-size:22px;color:var(--ink-soft)}.card .form-tag{background:var(--panel-alt);border:1px solid var(--border);color:var(--accent);padding:5px 12px;border-radius:6px;font-size:16px;font-weight:500;letter-spacing:.01em}.card .lemma-ref{display:inline-flex;flex-wrap:wrap;gap:8px;font-family:var(--serif);font-size:22px;color:var(--ink-soft);min-width:0;overflow-wrap:anywhere;word-break:break-word}.card .lemma-ref .article{font-weight:500;font-size:22px;font-family:var(--serif)}.card .translation{margin-top:20px;font-size:38px;font-weight:500;color:var(--text);line-height:1.2;letter-spacing:-.01em;overflow-wrap:anywhere;word-break:break-word}.card .example{margin-top:28px;padding-top:20px;border-top:1px solid var(--border);color:var(--ink-soft);font-size:20px;line-height:1.5;overflow-wrap:anywhere;word-break:break-word}.card .example .de{font-family:var(--serif);color:var(--text);margin-bottom:6px;font-size:22px}.card .sentence-translation{font-family:var(--serif);font-size:52px;font-weight:500;line-height:1.12;letter-spacing:-.01em;color:var(--text)}.card .source-de{margin-top:14px;font-family:var(--serif);font-size:24px;font-weight:400;color:var(--ink-soft);line-height:1.4;font-style:italic;overflow-wrap:anywhere;word-break:break-word}.source-with-audio{display:flex;align-items:flex-start;gap:8px}.source-with-audio>span:first-child{min-width:0;flex:1 1 auto}.translation-audio-wrap{width:100%}.word-source-context{margin-top:14px;font-size:22px}.translation-with-audio{display:flex;align-items:center;gap:10px;min-width:0}.translation-with-audio>span:first-child{min-width:0;flex:1 1 auto}.card .hardest-word-block{margin-top:28px;padding-top:22px;border-top:1px solid var(--border)}.card .hardest-word-label{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:12px;font-weight:500}.card .compact-word{color:var(--text)}.card .compact-head{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;min-width:0}.card .compact-article{color:var(--accent);font-family:var(--serif);font-weight:600;font-size:28px}.card .compact-surface{font-family:var(--serif);font-size:36px;font-weight:600;letter-spacing:-.01em;line-height:1.1;color:var(--text);min-width:0;max-width:100%;overflow-wrap:anywhere;word-break:break-word}.compact-surface-with-audio{display:inline-flex;align-items:center;flex-wrap:wrap;gap:6px;min-width:0;max-width:100%}.card .compact-pos{font-size:11px;text-transform:uppercase;color:var(--accent);letter-spacing:.1em;background:var(--accent-soft);padding:3px 10px;border-radius:999px;align-self:center;font-weight:500}.card .compact-form{display:flex;align-items:center;gap:10px;margin-top:8px;flex-wrap:wrap;font-size:16px;color:var(--ink-soft)}.card .compact-form .form-tag{font-size:13px;padding:3px 10px}.card .compact-form .lemma-ref,.card .compact-form .lemma-ref .article{font-size:16px;font-family:var(--serif)}.card .compact-translation{margin-top:10px;font-size:22px;font-weight:500;color:var(--text);overflow-wrap:anywhere;word-break:break-word}.card .compact-example{margin-top:12px;color:var(--ink-soft);font-size:15px;line-height:1.5;overflow-wrap:anywhere;word-break:break-word}.card .compact-example .de{color:var(--text);font-family:var(--serif);font-size:16px;margin-bottom:2px}.card-actions{display:flex;align-items:center;gap:8px;margin-top:28px;padding-top:18px;border-top:1px solid var(--border)}.card-action{min-height:34px;padding:6px 12px;border-radius:999px;font-size:13px;color:var(--ink-soft)}.card-action.selected{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.audio-word-button{width:34px;height:34px;min-height:34px;padding:0;border:1px solid rgba(181,74,30,.28);border-radius:999px;background:#fff7f1;color:var(--accent);display:inline-flex;align-items:center;justify-content:center;align-self:center;flex:0 0 auto;box-shadow:0 2px 8px #b54a1e14}.audio-word-button:hover{background:var(--accent-soft);border-color:#b54a1e7a;color:var(--accent)}.audio-word-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.audio-word-button .speaker-icon{width:21px;height:21px;flex:0 0 auto}.audio-word-button.phrase-audio{width:auto;min-width:max-content;height:32px;min-height:32px;padding:0 10px;gap:6px;align-self:flex-start;flex:0 0 auto;border-color:#b54a1e57;font-family:var(--sans);font-size:12px;font-style:normal;font-weight:700;line-height:1;white-space:nowrap}.audio-word-button.native-audio{width:34px;min-width:34px;height:34px;min-height:34px;padding:0;align-self:center;border-color:#49679747;background:#f4f8ff;color:#496797}.audio-word-button.native-audio:hover{border-color:#49679775;background:#eaf2ff;color:#36537f}.audio-word-button.native-audio.compact-audio{width:30px;min-width:30px;height:30px;min-height:30px}.audio-word-button.phrase-audio .speaker-icon{width:17px;height:17px}.audio-word-button .audio-label{line-height:1;white-space:nowrap;word-break:normal;overflow-wrap:normal}.audio-word-button.compact-audio{width:30px;height:30px;min-height:30px}.audio-word-button.compact-audio .speaker-icon{width:18px;height:18px}.audio-word-button.is-playing{background:var(--accent);border-color:var(--accent);color:#fff}.audio-word-button.native-audio.is-playing{background:#496797;border-color:#496797;color:#fff}.audio-word-button.is-playing .speaker-icon{animation:audioPulse .9s ease-in-out infinite}.audio-word-button.is-playing .stop-icon{animation:none}.history{position:fixed;top:64px;right:16px;bottom:24px;width:min(380px,calc(100vw - 32px));border:1px solid var(--border);border-radius:8px;background:var(--panel);display:flex;flex-direction:column;min-height:0;overflow:hidden;box-shadow:0 18px 48px #1a18142e;transform:translate(calc(100% + 32px));transition:transform .22s ease-out;z-index:55}.history[data-open=true]{transform:translate(0)}.history-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);gap:8px;background:var(--panel)}.history h2{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:500}.history-clear{font-size:12px;padding:4px 10px;border-radius:4px;color:var(--muted);background:transparent;border:1px solid var(--border);cursor:pointer}.history-clear:hover{color:var(--danger);border-color:var(--danger);background:var(--accent-soft)}.history-list{flex:1;overflow-y:auto;padding:8px 0}.history-empty{padding:20px;color:var(--muted);font-size:14px;font-style:italic}.history-item{width:100%;background:transparent;border:0;border-radius:0;text-align:left;padding:12px 20px;cursor:pointer;display:flex;flex-direction:column;gap:2px;border-bottom:1px solid var(--border)}.history-item:hover{background:var(--panel-alt)}.history-item .lemma{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--text);letter-spacing:-.01em}.history-item .meta{font-size:13px;color:var(--ink-soft)}.document-history{background:#ffffff7a;border:1px solid rgba(117,101,82,.22);border-radius:8px;overflow:hidden;box-shadow:none;display:flex;flex-direction:column;min-height:0}.document-history-head{padding:12px 14px;border-bottom:1px solid rgba(117,101,82,.18);background:#ffffff94}.document-history-head h2{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}.document-history-list{min-height:0;max-height:430px;overflow-y:auto}.input-history-panel .document-history-list{max-height:none;flex:1}.document-history-empty{padding:14px 12px;color:var(--muted);font-size:13px;font-style:italic}.document-history-row{position:relative;border-bottom:1px solid var(--border)}.document-history-row:last-child{border-bottom:0}.document-history-row.active{background:var(--panel-alt)}.document-history-item{width:100%;min-height:0;padding:11px 42px 11px 12px;border:0;border-radius:0;background:transparent;text-align:left;display:grid;grid-template-columns:30px minmax(0,1fr);align-items:start;gap:9px}.document-history-item:hover{background:var(--panel-alt)}.document-history-source-icon{width:30px;height:30px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent)}.document-history-source-icon svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.document-history-copy{min-width:0;display:grid;gap:3px}.document-history-title{color:var(--text);font-size:13px;font-weight:600}.document-history-meta,.document-history-preview{color:var(--muted);font-size:12px;line-height:1.35}.document-history-preview{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.document-history-delete{position:absolute;top:10px;right:9px;width:26px;height:26px;min-height:26px;padding:0;border-radius:50%;color:var(--muted);background:transparent}.document-history-delete svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.document-history-delete:hover{color:var(--danger);border-color:#c43a2a4d;background:#c43a2a0f}.error-banner{width:min(680px,100%);background:#fbeae6;border:1px solid var(--danger);color:var(--danger);padding:8px 14px;border-radius:6px;font-size:13px;font-weight:500}.cache-toast{background:var(--panel);border:1px solid var(--border);color:var(--ink-soft);padding:8px 16px;border-radius:999px;font-size:14px;animation:slideUp .18s ease-out;box-shadow:0 4px 12px #1a18140f}.info-banner{width:min(680px,100%);background:var(--panel);border:1px solid var(--accent);color:var(--text);padding:10px 16px;border-radius:8px;font-size:14px;z-index:30;display:inline-flex;align-items:center;gap:12px;box-shadow:0 4px 14px #1a181414}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a181473;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;animation:cardFadeUp .18s ease-out}.modal{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:28px 32px;max-width:460px;width:100%;box-shadow:0 20px 60px #1a181440}.modal h2{margin:0 0 12px;font-family:var(--serif);font-size:28px;font-weight:600;letter-spacing:-.01em;color:var(--text)}.modal p{margin:0 0 12px;color:var(--ink-soft);line-height:1.5;font-size:15px}.modal p.upsell{background:var(--panel-alt);border:1px solid var(--border);padding:12px 14px;border-radius:8px;color:var(--text)}.modal .price-line{display:inline-flex;align-items:baseline;gap:10px;margin-left:8px}.modal .price-line span{color:var(--muted);font-size:13px;text-decoration:line-through}.modal-actions{display:flex;align-items:center;gap:12px;margin-top:18px;flex-wrap:wrap}.icon{display:inline-block;width:1em;height:1em;vertical-align:-.15em;flex-shrink:0}.reading-main{align-items:center}.coach-shell{width:min(1180px,100%);align-self:center;gap:16px}.import-panel{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:stretch;width:100%;padding:12px;background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 20px #1a18140d}.import-fields{display:grid;gap:8px;min-width:0}.import-fields input,.import-fields textarea{width:100%;padding:10px 12px}.import-fields textarea{min-height:92px;resize:vertical;line-height:1.45}.import-actions{display:flex;flex-direction:column;gap:8px;align-items:stretch;justify-content:flex-start}.import-actions button{white-space:nowrap}.coach-reader{width:100%;display:grid;gap:12px;background:transparent}.repair-reader{width:100%;display:grid;gap:12px}.repair-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding:10px 12px;background:var(--panel);border:1px solid var(--border);border-radius:8px}.repair-head div{display:grid;gap:2px}.repair-head span{color:var(--muted);font-size:12px}.repair-head strong{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--text)}.repair-head button{min-height:32px;padding:5px 10px;border-radius:6px;font-size:12px}.document-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px}.document-head h1{margin:0;font-family:var(--serif);font-size:34px;font-weight:600;line-height:1.05}.document-head span{display:inline-block;margin-top:6px;color:var(--muted);font-size:14px}.document-head strong{font-size:30px;font-family:var(--serif);color:var(--accent)}.read-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:8px;background:#ffffffdb;border:1px solid var(--border);border-radius:12px}.read-bar button{min-height:38px}.read-bar .mic-button{background:var(--text);border-color:var(--text);color:#fff;width:40px;padding:0;display:inline-flex;align-items:center;justify-content:center;flex:0 0 40px}.read-bar .mic-button:hover{background:#3b332b;border-color:#3b332b;color:#fff}.read-bar .mic-button.listening{background:var(--danger);border-color:var(--danger)}.read-bar .mic-icon{width:19px;height:19px}.repair-toggle{min-height:38px;display:inline-flex;align-items:center;gap:8px;padding:0 10px;color:var(--ink-soft);font-size:14px}.repair-toggle input{width:16px;height:16px;accent-color:var(--accent)}.paragraph-list{display:grid;gap:12px}.reading-paragraph{border:1px solid var(--border);background:var(--panel);border-radius:8px;padding:14px 16px 16px}.reading-paragraph.active{border-color:#b54a1e8c;box-shadow:0 10px 24px #1a181412}.paragraph-actions{display:flex;align-items:center;justify-content:flex-end;margin-bottom:8px}.paragraph-actions button{min-height:30px;padding:0 10px;font-size:12px;color:var(--ink-soft)}.reading-paragraph p{margin:0;font-family:var(--serif);font-size:25px;line-height:1.72}.reader-word{display:inline;min-height:0;padding:1px 3px 2px;margin:0 1px;border:0;border-radius:5px;background:transparent;color:inherit;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:inherit;vertical-align:baseline}.reader-word:hover{background:var(--panel-alt);color:var(--text)}.reader-word.current{background:#fff1a8;box-shadow:inset 0 -2px #c08a1a6b}.reader-word.read{background:#e6f4df;color:#244f2d}.reader-word.needs_practice{background:#ffe3dc;color:#8f2e22;box-shadow:inset 0 -2px #c43a2a59}.transcript-line{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;color:var(--ink-soft);font-size:14px;line-height:1.5;padding:10px 12px;background:var(--panel-alt);border:1px solid var(--border);border-radius:8px;overflow-wrap:anywhere}.transcript-cancel{width:40px;height:40px;min-height:40px;display:inline-flex;align-items:center;justify-content:center;padding:0;border-radius:999px;background:#fff;color:var(--ink-soft)}.reading-coach{width:100%;display:grid;gap:12px}.reader-controls{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.reader-progress{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px;color:var(--muted);font-size:12px;font-weight:650}.reader-progress strong{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--accent)}.reader-mode-toggle{display:inline-flex;gap:3px;padding:3px;background:var(--panel-alt);border:1px solid var(--border);border-radius:999px}.reader-mode-toggle button{min-height:30px;padding:4px 14px;border:0;border-radius:999px;background:transparent;color:var(--ink-soft);font-size:13px;font-weight:600}.reader-mode-toggle button.active{background:var(--text);color:#fff}.guided-reader-head{flex-direction:column;align-items:center;justify-content:center;gap:8px}.guided-reader-head .reader-progress{justify-content:center;text-align:center}.guided-reader-head .reader-flow-actions{width:100%;justify-content:center}.guided-reader-head .reader-task-list{justify-content:center}.reader-part-strip{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(0,1fr);gap:6px;width:100%;align-items:center}.reader-part-segment{min-width:0;min-height:14px;padding:0;border:0;border-radius:999px;background:transparent;box-shadow:none;position:relative;overflow:hidden}.reader-part-segment:before,.reader-part-segment:after{content:"";display:block;height:4px;border-radius:999px}.reader-part-segment:before{width:100%;background:#75655238}.reader-part-segment:after{position:absolute;top:5px;left:0;width:var(--reader-part-progress, 0%);background:var(--accent);transition:width .18s ease}.reader-part-segment span{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.reader-part-segment:hover:before{background:#75655252}.reader-part-segment.active:after,.reader-part-segment.complete:after{box-shadow:0 0 0 1px #b54a1e0d}.reader-flow-actions{display:inline-flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;min-width:0}.reader-task-list{display:inline-flex;align-items:center;justify-content:flex-end;gap:5px;flex-wrap:wrap;padding:4px;border:1px solid rgba(117,101,82,.14);border-radius:12px;background:#ffffff85}.reader-task-list button{min-height:32px;display:inline-flex;align-items:center;gap:6px;padding:3px 8px 3px 4px;border:1px solid transparent;border-radius:8px;background:#ffffffa3;color:var(--ink-soft);font-size:12px;font-weight:800}.reader-task-list button.checked{border-color:#244f2d24;background:#e6f4dfc7;color:#244f2d}.task-check{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid rgba(117,101,82,.24);background:var(--panel-alt);color:var(--muted);font-size:11px;font-weight:900}.reader-task-list button.checked .task-check{background:#244f2d;border-color:#244f2d;color:#fff}.read-mode-toggle{min-height:32px;padding:0 10px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--ink-soft);font-size:12px;font-weight:750}.session-stepper{display:inline-flex;gap:3px;padding:3px;background:var(--panel);border:1px solid var(--border);border-radius:12px;box-shadow:none}.session-stepper button{min-height:32px;display:inline-flex;align-items:center;gap:6px;padding:3px 9px 3px 5px;border:0;border-radius:9px;background:transparent;color:var(--ink-soft);font-size:12px;font-weight:700}.session-stepper button>span{width:21px;height:21px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--panel-alt);color:var(--muted);font-size:12px}.session-stepper button.complete>span{background:#e6f4df;color:#244f2d}.session-stepper button.active{background:var(--text);color:#fff}.session-stepper button.active>span{background:#ffffff2e;color:#fff}.session-stepper button:disabled{opacity:.42}.reading-coach-text{font-size:21px;line-height:1.68}.paste-reader .clickable-text{min-height:auto;max-height:none;resize:none;overflow:visible;padding:22px 24px;background:#ffffffb8;border:1px solid rgba(117,101,82,.2);border-radius:14px;box-shadow:0 10px 28px #1a18140f;overflow-wrap:normal}.paste-reader .clickable-text button{padding:0 1px}.reading-coach-text .reader-word{cursor:pointer}.reader-word.sentence-active{background:var(--accent-soft);color:var(--accent)}.sentence-reveal{display:block;margin:6px 0 8px;padding:8px 12px;background:var(--accent-soft);border-left:3px solid var(--accent);border-radius:6px;font-family:var(--sans);font-size:15px;line-height:1.45;color:var(--text);white-space:normal}.paragraph-pager{display:flex;align-items:center;justify-content:center;gap:12px}.paragraph-pager .pager-nav{min-height:38px;padding:0 18px;font-size:14px}.paragraph-pager .pager-nav:disabled{opacity:.4;cursor:default}.paragraph-pager .reader-reset{min-height:34px;padding:0 12px;font-size:12px;color:var(--ink-soft)}.book-pager{display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 12px;background:var(--panel-alt);border:1px solid var(--border);border-radius:10px}.book-pager-label{font-size:13px;font-weight:600;color:var(--text)}.pager-label{min-width:120px;text-align:center;font-size:13px;font-weight:600;color:var(--text)}.pager-keys-hint{text-align:center;font-size:11px;color:var(--muted)}.part-pager{margin-top:-2px}.book-nav{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:8px;padding:12px 16px;background:var(--accent-soft);border:1px solid rgba(181,74,30,.28);border-radius:12px}.book-nav-title{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--accent)}.book-nav-icon{width:16px;height:16px;fill:none;stroke:var(--accent);stroke-width:1.6;stroke-linejoin:round}.book-nav-row{display:flex;align-items:center;gap:12px}.book-page-btn{min-height:36px;padding:0 14px;border-radius:999px;border:1px solid rgba(181,74,30,.4);background:#fff;color:var(--accent);font-size:13px;font-weight:600}.book-page-btn:disabled{opacity:.4;cursor:default}.book-nav-caption{max-width:380px;text-align:center;font-size:12px;color:var(--ink-soft)}.reader-nudge,.sentence-walk{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:12px;padding:10px 14px;background:var(--panel-alt);border:1px solid var(--border);border-radius:10px;font-size:14px;color:var(--ink-soft)}.nudge-cta{min-height:36px;padding:0 16px;border:0;border-radius:999px;background:var(--text);color:#fff;font-size:13px;font-weight:600}.nudge-cta:hover{background:#3b332b}.guided-step-card{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:14px 16px;background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:0 10px 26px #1a18140f}.guided-step-copy{min-width:220px;display:grid;gap:3px;flex:1 1 320px}.guided-step-copy strong{font-family:var(--serif);font-size:18px;color:var(--text)}.guided-step-copy span{color:var(--ink-soft);font-size:14px;line-height:1.45}.guided-step-actions{display:inline-flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.read-step-actions{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.reader-layout-top{display:flex;justify-content:center}.reading-plan-card{display:grid;grid-template-columns:minmax(0,1.2fr) auto auto;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:#ffffffc7}.reading-plan-card>div:first-child{display:grid;gap:2px}.reading-plan-card strong{color:var(--text);font-size:15px}.reading-plan-card span{color:var(--ink-soft);font-size:13px}.reading-plan-steps{display:inline-flex;flex-wrap:wrap;gap:5px;justify-content:center}.reading-plan-steps span{min-height:26px;display:inline-flex;align-items:center;padding:0 9px;border-radius:999px;background:var(--panel-alt);color:var(--text);font-size:12px;font-weight:800}.read-layout-toggle{display:inline-flex;gap:3px;padding:3px;border:1px solid var(--border);border-radius:999px;background:#fff}.read-layout-toggle button{min-height:30px;padding:0 10px;border:0;border-radius:999px;background:transparent;color:var(--ink-soft);font-size:12px;font-weight:800}.read-layout-toggle button[aria-pressed=true]{background:var(--text);color:#fff}.words-step-panel{width:min(680px,100%);margin:0 auto;display:grid;gap:12px;padding:16px;border:1px solid var(--border);border-radius:10px;background:var(--panel);box-shadow:0 10px 26px #1a18140f}.words-step-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.words-step-head>div{display:grid;gap:2px}.words-step-head strong{font-family:var(--serif);color:var(--text);font-size:20px}.words-step-head span,.words-step-empty{color:var(--ink-soft);font-size:13px}.words-step-empty{margin:0}.words-step-list{display:flex;flex-wrap:wrap;gap:8px}.words-step-chip{min-height:38px;display:inline-flex;align-items:baseline;gap:7px;padding:6px 11px;border-radius:999px;background:var(--accent-soft);border-color:#b54a1e3d;color:var(--text);font-size:14px;font-weight:800}.words-step-chip small{max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted);font-size:12px;font-weight:600}.words-step-chip.used{background:#e6f4df;border-color:#244f2d47;color:#244f2d}.say-step-card{background:var(--accent-soft);border-color:#b54a1e3d}.walk-progress{font-weight:600;color:var(--text)}.walk-actions{display:inline-flex;align-items:center;gap:8px}.walk-review{min-height:36px;padding:0 14px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--ink-soft);font-size:13px}.walk-play{min-height:36px;width:36px;padding:0;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--accent);font-size:15px}.walk-play:disabled{opacity:.4;cursor:default}.walk-done{color:var(--text);font-weight:600}.reader-hint{text-align:center;font-size:13px;color:var(--ink-soft);padding:2px 0}.reader-extras{display:flex;justify-content:center}.reader-extra-link{min-height:32px;padding:4px 12px;border:0;background:transparent;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer}.reader-extra-link:hover{text-decoration:underline}.read-aloud-callout{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:12px;padding:12px 16px;background:var(--accent-soft);border:1px solid rgba(181,74,30,.25);border-radius:10px;font-size:14px;color:var(--text)}.read-aloud-live{font-weight:600;color:var(--accent)}.read-aloud-dismiss{min-height:28px;width:28px;padding:0;border:0;background:transparent;color:var(--ink-soft);font-size:13px;cursor:pointer}.read-aloud-dismiss:hover{color:var(--text)}.wordzam-widget{font-family:var(--sans)}.widget-level-row{display:flex;align-items:center;gap:6px;margin-bottom:12px;flex-wrap:wrap}.widget-level-label{margin-right:4px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--ink-soft)}.widget-newtext{margin-left:auto;min-height:32px;padding:0 12px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--ink-soft);font-size:13px;font-weight:600;cursor:pointer}.widget-newtext:disabled{opacity:.5;cursor:default}.widget-loading{padding:48px 12px;text-align:center;color:var(--muted);font-size:15px}.widget-error{margin-bottom:12px;padding:10px 14px;border-radius:10px;background:var(--accent-soft);color:var(--accent);font-size:14px}.reader-composer{display:flex;gap:8px;align-items:center;margin-top:4px}.reader-composer-input{flex:1 1 auto;min-width:0;min-height:44px;padding:0 16px;border:1px solid var(--border);border-radius:999px;background:#fff;font-size:15px;color:var(--text)}.reader-composer-input:focus{outline:none;border-color:var(--accent)}.reader-composer-mic,.reader-composer-send{flex:0 0 auto;width:44px;height:44px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:18px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.reader-composer-send{background:var(--text);border-color:var(--text);color:#fff}.reader-composer-mic.recording{background:var(--accent);border-color:var(--accent);color:#fff}.reader-composer-mic:disabled,.reader-composer-send:disabled{opacity:.5;cursor:default}.read-aloud-error{color:var(--accent);font-size:14px;padding:4px 2px}.widget-remaining{margin:-4px 0 10px;font-size:13px;color:var(--muted)}.widget-cap{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:14px;padding:16px 18px;border-radius:14px;background:var(--text);color:#fff}.widget-cap-text{display:flex;flex-direction:column;gap:3px;flex:1 1 240px}.widget-cap-text strong{font-size:16px}.widget-cap-text span{font-size:14px;opacity:.85}.widget-cap-cta{flex:0 0 auto;display:inline-block;padding:11px 18px;border-radius:999px;background:#fff;color:var(--text);font-weight:600;font-size:14px;text-decoration:none;white-space:nowrap}.widget-level-row button{min-height:32px;padding:0 12px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--ink-soft);font-size:13px;font-weight:600}.widget-level-row button.active{background:var(--text);border-color:var(--text);color:#fff}.wordzam-widget .card-stage--placeholder{display:none;min-height:180px;align-items:center;justify-content:center;padding:24px;border:1px dashed var(--border);border-radius:14px;background:#fff6;color:var(--muted);font-size:14px;line-height:1.45;text-align:center}@media(min-width:720px){.wordzam-widget .reading-coach{grid-template-columns:minmax(0,1fr) 360px;column-gap:24px;align-items:start}.wordzam-widget .reading-coach>*{grid-column:1}.wordzam-widget .reading-coach>.reader-controls{grid-column:1 / -1}.wordzam-widget .reading-coach>.card-stage{grid-column:2;grid-row:2;align-self:start;position:sticky;top:8px;width:100%;margin:0}.wordzam-widget .card-stage--placeholder{display:flex}.wordzam-widget .card-stage .card{padding:26px 24px}}.pager-arrow{min-width:44px;font-size:18px;line-height:1}.comprehension-panel{display:grid;gap:10px;padding:14px 16px;background:var(--panel);border:1px solid var(--border);border-radius:10px}.simple-answer-panel{width:min(680px,100%);margin:0 auto;padding:0;gap:12px;border:0;background:transparent}.simple-answer-top{min-height:32px;display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--muted);font-size:12px;font-weight:700}.simple-back-button{min-height:32px;padding:0 10px;border:0;background:transparent;color:var(--ink-soft);font-size:13px;font-weight:700}.simple-back-button:hover{background:var(--panel-alt)}.answer-question-card,.answer-input-card{display:grid;gap:12px;padding:18px;border:1px solid var(--border);border-radius:10px;background:var(--panel);box-shadow:0 10px 26px #1a18140f}.answer-question-card>span{color:var(--accent);font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.answer-question-card p{margin:0;color:var(--text);font-size:22px;line-height:1.3;font-weight:750}.answer-swap-question{width:fit-content;min-height:32px;padding:0 12px;border-radius:999px;background:var(--panel-alt);color:var(--ink-soft);font-size:13px;font-weight:700}.answer-helper-strip{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:0 4px}.answer-helper-strip>span{color:var(--muted);font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.answer-helper-strip>div{display:flex;flex-wrap:wrap;gap:6px}.answer-helper-chip{min-height:30px;padding:0 10px;border-radius:999px;background:#fff;border-color:#b54a1e38;color:var(--text);font-size:13px;font-weight:750}.answer-helper-chip.used{background:#e6f4df;border-color:#244f2d47;color:#244f2d}.answer-input-card label{color:var(--text);font-size:13px;font-weight:850}.answer-input-card textarea{width:100%;min-height:124px;max-height:220px;resize:vertical;padding:14px;border-radius:10px;background:#fff;line-height:1.45;font-size:16px}.answer-action-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.answer-action-row button{width:100%;min-height:42px}.review-panel{width:min(720px,100%);margin:0 auto;gap:10px;padding:0;border:0;background:transparent}.review-panel .comprehension-head{padding:0 2px}.review-section{display:grid;gap:10px;padding:12px;border:1px solid rgba(117,101,82,.18);border-radius:16px;background:#ffffff94;box-shadow:0 10px 26px #1a18140a}.review-next-section{background:#fff7f2b8;border-color:#b54a1e2e}.review-section-head{display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;align-items:center}.review-section-icon{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--text);color:#fff;font-size:14px;font-weight:900}.review-section-head strong{display:block;color:var(--text);font-size:16px}.review-section-head span:not(.review-section-icon){color:var(--ink-soft);font-size:12px;line-height:1.35}.review-answer-card,.review-summary-card,.review-card,.review-rewrite-card,.review-pattern-card{display:grid;gap:9px;padding:13px 14px;border:1px solid var(--border);border-radius:12px;background:var(--panel);box-shadow:0 8px 20px #1a18140d}.review-hero-card{grid-template-columns:38px minmax(0,1fr);align-items:start;background:#f3fbf1;border-color:#2477402e;color:var(--text)}.review-icon{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#2f7a45;color:#fff;font-size:18px;font-weight:900}.review-mini-icon{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;margin-right:6px;border-radius:999px;background:var(--panel-alt);color:currentColor;font-size:12px;font-weight:900}.review-answer-card>span,.review-answer-head>span,.review-summary-card>span,.review-card>span,.review-rewrite-card>span,.review-pattern-card>span{display:inline-flex;align-items:center;font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.review-answer-card>span,.review-answer-head>span,.review-summary-card>span,.review-rewrite-card>span,.review-pattern-card>span{color:var(--accent)}.review-answer-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.review-correct-button{min-height:30px;padding:0 11px;border-radius:999px;background:var(--accent-soft);border-color:#b54a1e38;color:var(--accent);font-size:12px;font-weight:850}.review-answer-card p,.review-summary-card p,.review-rewrite-card p,.review-pattern-card p{margin:0;color:var(--text);font-size:15px;line-height:1.5}.review-hero-card p,.review-hero-card>div>span{color:var(--text)}.review-hero-card>div>span{display:block;margin-bottom:4px;font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#2f6b3a;opacity:1}.review-answer-card p{font-size:14px;font-weight:650}.review-corrected-answer{display:grid;gap:6px;padding:10px 11px;border-radius:10px;background:#fff7f2;border:1px solid rgba(181,74,30,.18)}.review-corrected-answer span{color:var(--accent);font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.review-corrected-answer p{margin:0;color:var(--text);font-size:15px;font-weight:800;line-height:1.45}.review-loading-card{display:grid;grid-template-columns:32px minmax(0,1fr);align-items:center;gap:10px;padding:12px 13px;border:1px solid rgba(117,101,82,.16);border-radius:12px;background:#ffffffd1;color:var(--ink-soft)}.review-loading-card strong{display:block;color:var(--text);font-size:14px}.review-loading-card span:not(.review-loading-dot){display:block;margin-top:2px;font-size:12px;line-height:1.35}.review-loading-dot{width:14px;height:14px;justify-self:center;border-radius:999px;background:var(--accent);box-shadow:0 0 #b54a1e3d;animation:reviewPulse 1.1s ease-out infinite}.review-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.review-card.good>span{color:#2f6b3a}.review-card.fix>span{color:var(--accent)}.review-card ul{margin:0;padding-left:0;display:grid;gap:8px;color:var(--text);font-size:14px;line-height:1.42;list-style:none}.review-card li{position:relative;padding-left:16px}.review-card li:before{content:"";position:absolute;top:.62em;left:0;width:6px;height:6px;border-radius:999px;background:currentColor;opacity:.45}.review-rewrite-card{background:#fff7f2;border-color:#b54a1e40}.review-rewrite-card p{font-size:16px;font-weight:750}.review-bottom-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.review-pattern-card{grid-column:1 / -1}.review-pattern-card p{width:fit-content;max-width:100%;padding:8px 10px;border-radius:8px;background:var(--panel-alt);font-weight:750;overflow-wrap:anywhere}.review-pattern-example{display:grid;gap:5px;padding:10px;border-radius:10px;background:#fff7f2;border:1px solid rgba(181,74,30,.16)}.review-pattern-example span{color:var(--accent);font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.review-pattern-example p{width:auto;padding:0;background:transparent;font-size:14px}.comprehension-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.comprehension-head>div{display:grid;gap:2px}.comprehension-head strong{font-family:var(--serif);font-size:18px}.comprehension-head span{color:var(--ink-soft);font-size:13px}.comprehension-close{min-height:30px;width:30px;padding:0;border:0;background:transparent;color:var(--ink-soft);font-size:15px}.helper-word-panel{display:grid;gap:8px;padding:10px;border:1px solid rgba(181,74,30,.2);border-radius:10px;background:var(--accent-soft)}.review-words-card{align-content:start;min-height:100%;background:#fff;border-color:#b54a1e2e}.looked-up-review-card{background:#f8fcf7;border-color:#244f2d33}.helper-word-label{font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}.helper-word-list{display:flex;flex-wrap:wrap;gap:8px}.helper-word-chip{min-height:34px;display:inline-flex;align-items:baseline;gap:7px;padding:5px 10px;border-radius:999px;background:#fff;border-color:#75655233;color:var(--text);font-size:13px;font-weight:700}.helper-word-chip small{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted);font-size:12px;font-weight:500}.helper-word-chip.missed{border-color:#c43a2a52;box-shadow:inset 0 -2px #c43a2a38}.helper-word-chip.suggested{border-style:dashed}.helper-word-chip.looked-up{border-color:#244f2d40;box-shadow:inset 0 -2px #244f2d1f}.helper-word-chip.used{background:#e6f4df;border-color:#244f2d47;color:#244f2d}.comprehension-prompt-text{margin:0;font-size:14px;color:var(--text)}.comprehension-transcript{padding:8px 12px;background:var(--panel-alt);border-radius:8px;font-size:14px;color:var(--text);overflow-wrap:anywhere}.comprehension-feedback{padding:10px 12px;background:var(--accent-soft);border-left:3px solid var(--accent);border-radius:6px;font-size:14px;line-height:1.45;color:var(--text)}.comprehension-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.history-item-wrap{position:relative;border-bottom:1px solid var(--border)}.history-item-wrap.active{background:var(--panel-alt)}.history-item-wrap .history-item{border-bottom:0;padding-right:44px}.history-preview{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-top:5px;color:var(--muted);font-size:12px;line-height:1.35;white-space:normal}.history-delete{position:absolute;top:12px;right:10px;width:26px;height:26px;min-height:26px;padding:0;border-radius:50%;font-size:12px;color:var(--muted);background:transparent}.history-delete svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.history-delete:hover{color:var(--danger);border-color:#c43a2a4d;background:#c43a2a0f}@keyframes audioPulse{0%,to{transform:scale(1);opacity:.75}50%{transform:scale(1.12);opacity:1}}@keyframes reviewPulse{0%{transform:scale(.84);box-shadow:0 0 #b54a1e47}70%{transform:scale(1);box-shadow:0 0 0 9px #b54a1e00}to{transform:scale(.84);box-shadow:0 0 #b54a1e00}}@keyframes buttonSpinner{to{transform:rotate(360deg)}}@media(max-width:640px){.app{--side-width: 0px;grid-template-columns:1fr}.main{padding:18px 12px 108px;justify-content:flex-start}.main.reading-main,.main.book-main{height:100vh;min-height:0;overflow:hidden}.main.reading-main{padding-bottom:calc(76px + env(safe-area-inset-bottom,0px))}.main.book-main{padding-bottom:calc(92px + env(safe-area-inset-bottom,0px))}.main.reading-main .reader-topbar,.main.book-main .reader-topbar{flex:0 0 auto}.main.reading-main .reader-shell,.main.book-main .reader-shell{flex:1 1 auto;min-height:0;overflow:hidden}.main.reading-main .reader-shell.paste-shell{align-items:stretch}.main.reading-main .paste-reader.reading-coach{flex:1 1 auto;min-height:0;height:100%;overflow:hidden;gap:8px}.main.reading-main .reader-controls,.main.reading-main .reader-layout-top,.main.reading-main .reader-part-strip,.main.reading-main .read-step-actions,.main.reading-main .paragraph-pager,.main.reading-main .book-nav{flex:0 0 auto}.main.reading-main .reading-coach-text,.main.reading-main .simple-answer-panel,.main.reading-main .review-panel{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.main.selecting-words,.main.selecting-words .reading-coach-text{overscroll-behavior:none}.main.selecting-words .reading-coach-text{overflow:hidden;touch-action:none}.main.book-main .paper-book-session{height:100%;min-height:0;overflow:hidden}.main.book-main .paper-book-session.lookup-step{display:flex;flex-direction:column}.main.book-main .paper-lookup-space{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.main.book-main .paper-word-strip{flex:0 0 auto;max-height:82px;overflow-y:auto;padding-bottom:2px}.main.book-main .paper-book-session.quiz-step{overflow-y:auto;-webkit-overflow-scrolling:touch}.controls{bottom:calc(16px + env(safe-area-inset-bottom,0px));gap:6px;padding:6px;width:calc(100% - 16px);max-width:calc(100% - 16px);flex-wrap:wrap;border-radius:18px}.controls button{padding:0 14px}.controls .status-pill{padding:0 8px}.controls .meter{padding:0 6px}.typed-lookup{order:-1;width:100%;flex-basis:100%}.typed-lookup .composer-textarea{min-width:0;flex:1;width:auto}.composer-input-wrap{flex:1 1 auto}.typed-lookup button{flex:0 0 auto}.controls button.mic-button{min-width:92px;padding:0 11px}.controls button.short-listen-button{min-width:98px;padding:0 9px}.short-listen-key{padding:3px 5px}.voice-shortcut-hint{display:none}.typed-lookup .lookup-submit{display:inline-flex}.meter{padding:4px 8px;gap:0}.meter-label,.meter-silent{display:none}.meter-bar{width:44px}.user-menu{top:12px;right:12px}.reader-shell{gap:14px}.coach-shell{width:100%}.import-panel{grid-template-columns:1fr}.import-actions{flex-direction:row;flex-wrap:wrap}.import-actions button{flex:1 1 120px}.document-head{align-items:flex-start}.document-head h1{font-size:28px}.read-bar{align-items:stretch}.reading-paragraph{padding:12px}.reading-paragraph p{font-size:22px;line-height:1.68}.reader-shell.paste-shell,.reader-shell.repair-shell{width:100%;display:flex;flex-direction:column;align-items:center}.reader-shell.paste-shell .paste-reader{display:flex}.reader-shell.paste-shell .paste-reader-head,.reader-shell.paste-shell .paste-reader textarea,.reader-shell.paste-shell .paste-reader .paste-input-stack,.reader-shell.paste-shell .paste-reader .clickable-text,.reader-shell.paste-shell .lookup-empty,.reader-shell.paste-shell .card-stage,.reader-shell.repair-shell .repair-reader,.reader-shell.repair-shell .lookup-empty,.reader-shell.repair-shell .card-stage{width:100%}.reader-shell.paste-shell .session-summary,.reader-shell.paste-shell .cache-toast,.reader-shell.paste-shell .interim,.reader-shell.paste-shell .lookup-empty,.reader-shell.paste-shell .card-stage{margin-top:0}.reader-topbar{width:100%;display:flex;flex-direction:row;align-items:center;gap:8px;margin-bottom:8px;padding-right:54px}.input-entry{width:auto}.input-entry-button{flex:0 0 auto;min-height:36px}.input-entry-full-label{display:none}.input-entry-short-label{display:inline}.topbar-book-button{width:38px;min-height:36px;flex:0 0 38px;padding:0;gap:0}.topbar-book-button span{display:none}.saved-toggle-top,.anki-export-top{align-self:center;flex:0 0 auto}.reader-controls{gap:8px}.reader-progress{width:100%;font-size:12px}.reader-flow-actions{width:100%}.reader-task-list{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;padding:6px}.reader-task-list button{justify-content:flex-start;padding-right:8px;min-height:34px}.reader-task-list button span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reader-layout-top{justify-content:center}.reading-plan-card{grid-template-columns:1fr;align-items:stretch}.reading-plan-steps{justify-content:flex-start}.read-layout-toggle{width:100%}.read-layout-toggle button{flex:1}.session-stepper{flex:1 1 260px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr))}.session-stepper button{justify-content:center;gap:5px;padding:3px 5px;font-size:12px}.session-stepper button>span{width:20px;height:20px}.input-sheet-backdrop{padding:54px 10px 16px;align-items:stretch}.input-sheet{height:calc(100vh - 70px);max-height:calc(100vh - 70px);padding:14px}.anki-export-backdrop{padding:54px 10px 16px;align-items:stretch}.anki-export-screen{height:calc(100vh - 70px);max-height:calc(100vh - 70px);padding:14px}.anki-export-toolbar{align-items:stretch;flex-direction:column}.anki-export-toolbar>div,.anki-export-footer{width:100%}.anki-export-toolbar button,.anki-export-footer button{flex:1}.input-sheet-body{grid-template-columns:1fr;grid-template-rows:minmax(0,1fr);overflow:hidden}.input-workspace{min-height:0}.input-mode-tabs{grid-template-columns:repeat(4,minmax(0,1fr))}.input-mode-tabs button{justify-content:center;padding:0 6px;font-size:12px;gap:5px}.input-mode-tabs svg{width:15px;height:15px}.input-mode-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;padding:6px}.input-mode-grid button{min-height:72px;grid-template-columns:32px minmax(0,1fr);justify-items:stretch;gap:8px;padding:10px}.input-mode-card-icon{width:32px;height:32px}.input-mode-grid strong{font-size:13px}.input-mode-grid small{font-size:11px}.input-mode-panel,.input-mode-content{overflow:auto}.input-history-popover{top:58px;right:10px;bottom:10px;left:10px;width:auto}.practice-level-tabs{width:100%}.practice-level-tabs button{flex:1}.input-action-footer{flex-direction:column;align-items:stretch}.input-action-footer .source-action-button{width:100%;min-width:0}.input-history-panel .document-history-list{max-height:none}.source-selector{width:100%}.reader-tool-row{display:none}.auto-audio-toggle{flex:0 0 auto}.auto-audio-select{flex:1 1 0;width:auto;min-width:0;max-width:none}.reader-mode-tabs{width:100%}.reader-mode-tabs button{flex:1}.source-tabs button{flex:1 1 140px}.words-step-head{align-items:stretch;flex-direction:column}.review-grid,.review-bottom-grid{grid-template-columns:1fr}.answer-question-card,.answer-input-card{gap:10px;padding:14px}.answer-question-card p{font-size:20px}.answer-input-card textarea{min-height:96px;max-height:132px}.main.reading-main .answer-action-row,.main.reading-main .comprehension-actions{position:sticky;bottom:0;z-index:3;padding-top:8px;background:linear-gradient(to bottom,rgba(249,245,239,0),var(--bg) 42%)}.hero h1{font-size:40px}.hero p{font-size:17px}.learning-loop-home{min-height:calc(100vh - 116px);padding:18px 14px;border-radius:18px}.learning-loop-home h1{font-size:40px}.quest-choice-card{min-height:88px;padding:12px}.paper-book-session{padding:12px 0 22px}.paper-book-session.lookup-step{min-height:calc(100vh - 132px);padding-bottom:104px}.main.book-main .paper-book-session.lookup-step{min-height:0}.paper-book-steps{width:100%}.paper-book-copy h1{font-size:32px}.compact-paper-copy h1{font-size:30px}.paper-lookup-space{min-height:220px;padding:8px 0}.paper-transcript{padding:16px;font-size:24px}.paper-card-stage,.paper-lookup-dock{width:100%}.paper-card-stage .card{padding:24px 22px}.paper-lookup-dock{width:calc(100vw - 18px);bottom:calc(10px + env(safe-area-inset-bottom,0px));grid-template-columns:minmax(0,1fr) 46px 46px 58px;gap:6px;padding:6px;border-radius:16px}.paper-lookup-input-wrap{grid-template-columns:minmax(0,1fr) 40px}.paper-lookup-input-wrap textarea{min-height:44px;padding:10px 11px;font-size:14px}.paper-lookup-input-wrap .enter-button{width:40px;min-height:40px}.paper-listen-action,.paper-short-action,.paper-quiz-action{min-height:44px;padding:0 9px;border-radius:12px;font-size:12px}.paper-listen-action span,.paper-short-action span{display:none}.paper-listen-action svg,.paper-short-action svg{width:19px;height:19px}.paper-quiz-head{align-items:stretch}.paper-quiz-head .practice-level-tabs,.paste-reader{width:100%}.paste-reader-head{align-items:stretch;flex-direction:column}.paste-reader-actions{justify-content:stretch}.paste-reader-actions button{flex:1 1 120px}.paste-reader textarea{min-height:170px;max-height:min(48vh,420px)}.source-input-panel{min-height:170px;padding:18px}.clickable-text{min-height:220px;max-height:none;padding:8px 2px 12px;font-size:19px;line-height:1.72;overflow:visible}.paste-reader .clickable-text{padding:16px 14px;background:#ffffffbd;border:1px solid rgba(117,101,82,.18);border-radius:14px;box-shadow:0 8px 22px #1a18140d}.clickable-text button{padding:0 1px;border-radius:5px}.read-step-actions{justify-content:stretch}.read-step-actions button{flex:1 1 120px;min-height:42px}.controls.reading-composer{flex-wrap:nowrap;align-items:center;width:calc(100% - 18px);max-width:calc(100% - 18px);bottom:calc(10px + env(safe-area-inset-bottom,0px));border-radius:16px}.controls.reading-composer .typed-lookup{order:0;flex:1 1 auto;min-width:0}.controls.reading-composer .typed-lookup .composer-textarea{width:100%;min-height:40px;height:40px;padding:0 12px;white-space:nowrap}.controls.reading-composer .composer-input-wrap{min-height:40px}.controls.reading-composer .lookup-submit{flex:0 0 40px;width:40px;height:40px}.session-summary{width:auto}.interim{font-size:20px;width:100%;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;max-height:calc(1.35em * 3)}.lookup-empty{min-height:160px;width:100%}.card{position:absolute;top:330px;left:8px;right:8px;bottom:auto;width:auto;transform:none;padding:22px 20px;margin:0;animation:cardSlideUpMobile .36s cubic-bezier(.22,1.2,.36,1)}.card-stage .card{position:relative;top:auto;left:auto;right:auto;width:100%;padding:22px 20px;animation:cardFadeUp .22s cubic-bezier(.16,1,.3,1)}.paper-card-stage .card{position:relative;top:auto;left:auto;right:auto;width:100%;padding:24px 22px;animation:cardFadeUp .22s cubic-bezier(.16,1,.3,1)}.card-dismiss{top:10px;right:10px;width:48px;height:48px;min-height:48px}.card.fading-out{animation:cardFadeOutMobile .32s cubic-bezier(.55,0,.7,.2) forwards}.card .article{font-size:36px}.card .surface{font-size:44px}.card .translation{font-size:24px}.card .form-line{font-size:16px}.card .sentence-translation{font-size:30px}.card .source-de{font-size:17px}.card .example{font-size:16px}.card .example .de{font-size:17px}.card .compact-surface{font-size:26px}.card .compact-article{font-size:22px}.card .compact-translation{font-size:18px}.history,.settings-drawer{position:fixed;left:0;right:0;bottom:0;top:auto;max-height:65vh;border-left:0;border-top:1px solid var(--border);border-radius:14px 14px 0 0;box-shadow:0 -8px 24px #1a18142e;z-index:50;transform:translateY(100%);transition:transform .22s ease-out}.history[data-open=true],.settings-drawer[data-open=true]{transform:translateY(0)}.modal{padding:22px 20px}.modal h2{font-size:22px}.saved-toggle-top{align-self:flex-start}.drawer-close{display:inline-block}}
