: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)}.app{--side-width: 360px;display:grid;grid-template-columns:1fr 360px;height:100vh;overflow:hidden}.main{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:72px 32px 120px;position:relative;min-height:0;min-width:0;overflow-y:auto;overflow-x:hidden}.controls{position:fixed;bottom:24px;left:calc((100vw - var(--side-width)) / 2);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 - var(--side-width) - 32px));max-width:calc(100vw - var(--side-width) - 32px);flex-wrap:wrap;justify-content:center;font-size:14px}.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 .composer-textarea{color:transparent}.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{position:fixed;top:12px;left:12px;z-index:20;height:38px;padding:0 14px;border-radius:999px;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:0 4px 14px #1a18141a;display:none}.saved-toggle-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:none}.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(1180px,100%);min-height:auto;display:grid;grid-template-columns:minmax(420px,1fr) minmax(340px,.86fr);align-items:start;gap:18px}.paste-shell .error-banner,.paste-shell .info-banner{grid-column:1 / -1;justify-self:center}.paste-shell .paste-reader{grid-column:1;grid-row:1;width:100%;display:flex;flex-direction:column;gap:10px;align-self:start}.paste-shell .session-summary,.paste-shell .cache-toast,.paste-shell .interim,.paste-shell .lookup-empty,.paste-shell .card-stage{grid-column:2;grid-row:1;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(1180px,100%);display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;justify-items:center;gap:12px;margin-bottom:18px}.reader-topbar .input-entry{grid-column:2}.input-entry{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.input-entry-button{min-height:38px;padding:0 14px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--text);color:#fff;border-color:var(--text);font-size:14px;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:#2a261f;border-color:#2a261f;color:#fff}.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{border-left:1px solid var(--border);background:var(--panel);display:flex;flex-direction:column;min-height:0;overflow:hidden}.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}.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}.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}.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}.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{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-head span{color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.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) minmax(300px,340px);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-panel{flex:1;min-height:0;display:flex;overflow:hidden}.input-mode-content{width:100%;min-height:0;padding:16px;display:flex;flex-direction:column;gap:14px;overflow:hidden}.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}.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}.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{display:grid;gap:7px}.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}.input-history-panel{min-width:0;min-height:0;display:flex}.input-history-panel .document-history{width:100%;min-height:0;background:#ffffffa8}.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:32px;height:32px;min-height:32px;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}.card-dismiss:hover,.card-dismiss:focus-visible{background:var(--accent-soft);border-color:#b54a1e52;color:var(--accent)}.card-dismiss svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}.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)}.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{border-left:1px solid var(--border);background:var(--panel);display:flex;flex-direction:column;min-height:0;overflow:hidden}.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:stretch}.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{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}.reading-coach{width:100%;display:grid;gap:12px}.reader-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.reader-progress{display:flex;align-items:baseline;gap:10px;color:var(--muted);font-size:13px}.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}.reading-coach-text{font-size:23px}.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)}.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}.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}.comprehension-head{display:flex;align-items:center;justify-content:space-between}.comprehension-head strong{font-family:var(--serif);font-size:18px}.comprehension-close{min-height:30px;width:30px;padding:0;border:0;background:transparent;color:var(--ink-soft);font-size:15px}.comprehension-prompts{display:inline-flex;gap:3px;padding:3px;width:fit-content;background:var(--panel-alt);border:1px solid var(--border);border-radius:999px}.comprehension-prompts button{min-height:30px;padding:4px 14px;border:0;border-radius:999px;background:transparent;color:var(--ink-soft);font-size:13px;font-weight:600}.comprehension-prompts button.active{background:var(--text);color:#fff}.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;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 buttonSpinner{to{transform:rotate(360deg)}}@media(max-width:640px){.app{--side-width: 0px;grid-template-columns:1fr}.main{padding:64px 12px 136px;justify-content:flex-start}.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:column;align-items:stretch;gap:10px;margin-bottom:14px}.input-entry{width:100%}.input-entry-button{flex:1 1 160px}.input-sheet-backdrop{padding:54px 10px 16px;align-items:stretch}.input-sheet{height:calc(100vh - 70px);max-height:calc(100vh - 70px);padding:14px}.input-sheet-body{grid-template-columns:1fr;grid-template-rows:auto minmax(150px,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}.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{justify-content:center;width:min(100%,420px);align-self:center}.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}.hero h1{font-size:40px}.hero p{font-size:17px}.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:min(56vh,500px);padding:12px 14px;font-size:18px;line-height:1.65}.clickable-text button{padding:2px 4px;border-radius:5px}.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)}.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{display:inline-flex;align-items:center}.drawer-close{display:inline-block}}
