:root{color-scheme:light;--bg-a: #f6f2ea;--bg-b: #e9ddc7;--surface-1: rgba(255, 255, 255, .88);--surface-2: rgba(252, 248, 238, .86);--text: #1f2b25;--muted: #5a645f;--accent: #1f6b58;--accent-strong: #14483b;--border: rgba(31, 43, 37, .12);--shadow-lg: 0 26px 60px rgba(24, 32, 27, .14);--shadow-sm: 0 8px 20px rgba(24, 32, 27, .08)}:root[data-theme=dark]{color-scheme:dark;--bg-a: #0f151a;--bg-b: #1a232b;--surface-1: rgba(22, 30, 37, .9);--surface-2: rgba(28, 37, 46, .88);--text: #e8f1f3;--muted: #a8bac1;--accent: #3ca889;--accent-strong: #2b7a64;--border: rgba(168, 186, 193, .2);--shadow-lg: 0 26px 60px rgba(0, 0, 0, .35);--shadow-sm: 0 8px 20px rgba(0, 0, 0, .24)}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Avenir Next,Segoe UI Variable,Nunito Sans,Helvetica Neue,sans-serif;color:var(--text);background:radial-gradient(circle at 15% 20%,rgba(31,107,88,.24),transparent 32%),radial-gradient(circle at 88% 74%,rgba(20,72,59,.2),transparent 34%),linear-gradient(135deg,var(--bg-a),var(--bg-b))}.app-shell{width:min(1180px,94vw);margin:26px auto 44px;display:grid;gap:16px}.topbar{padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px;position:sticky;top:12px;z-index:10}.topbar h1{margin:0;font-family:Fraunces,Iowan Old Style,Palatino Linotype,serif;font-size:clamp(1.9rem,3.8vw,3.2rem);line-height:.98;letter-spacing:-.015em}.kicker{margin:0;letter-spacing:.16em;text-transform:uppercase;font-size:.75rem;color:var(--muted)}.subtitle{margin:8px 0 0;max-width:640px;color:var(--muted);font-size:.98rem}.topbar-meta{display:flex;flex-direction:column;align-items:flex-end;gap:10px}.card{border:1px solid var(--border);border-radius:18px;background:var(--surface-1);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.controls{padding:20px;display:grid;gap:16px}.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.setting-panel{border:1px solid var(--border);border-radius:14px;background:var(--surface-2);padding:14px;box-shadow:var(--shadow-sm)}.panel-title{margin:0 0 12px;font-size:.96rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.grid-2{display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr))}.field-label{display:block;margin-bottom:7px;font-weight:700;font-size:.92rem}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}input[type=file],input[type=text],select,textarea,button{font:inherit}select,input[type=text],textarea,input[type=file]{width:100%;border-radius:11px;border:1px solid var(--border);padding:10px 11px;background:#ffffffd1}.dropzone{border:1.5px dashed rgba(31,107,88,.4);background:linear-gradient(180deg,#f8fffcd9,#ffffffb3);border-radius:14px;padding:18px;text-align:center;cursor:pointer;transition:border-color .14s ease,transform .14s ease,box-shadow .14s ease}.dropzone:hover,.dropzone:focus-visible{border-color:#1f6b58cc;box-shadow:0 0 0 3px #1f6b5824;transform:translateY(-1px);outline:none}.dropzone.is-active{border-color:#1f6b58f2;background:linear-gradient(180deg,#e7faf4e6,#f6fffbdb)}.dropzone-title{margin:0;font-weight:700;font-size:.98rem}.dropzone-subtitle{margin:6px 0 0;color:var(--muted);font-size:.9rem}.chips{min-height:40px;border:1px solid var(--border);border-radius:11px;background:#ffffffbf;padding:7px;display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.chip{display:inline-flex;align-items:center;gap:7px;border-radius:999px;border:1px solid rgba(31,107,88,.32);background:#1f6b5817;color:#184d40;padding:4px 9px;font-size:.8rem;font-weight:700}.language-toolbar{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:10px}.tertiary{border-radius:999px;border:1px solid var(--border);background:#ffffffd1;color:var(--muted);padding:5px 11px;font-size:.8rem;font-weight:700}.theme-toggle{min-width:112px}.chip button{border:0;border-radius:999px;width:18px;height:18px;padding:0;line-height:18px;background:#14483b24;color:#184d40;font-size:.75rem;cursor:pointer}.chip-empty{color:var(--muted);font-size:.85rem}.advanced-select{margin-top:8px;border:1px solid var(--border);border-radius:10px;background:#ffffff8c;padding:8px}.advanced-select>summary{cursor:pointer;color:var(--muted);font-size:.86rem;font-weight:700;list-style:none}.advanced-select>summary::-webkit-details-marker{display:none}.advanced-select>summary:before{content:"+ "}.advanced-select[open]>summary:before{content:"- "}select:focus,input[type=text]:focus,textarea:focus,input[type=file]:focus{outline:2px solid rgba(31,107,88,.35);border-color:#1f6b5873}textarea{min-height:390px;resize:vertical}.hint,.muted{color:var(--muted);font-size:.88rem}.hint{margin:6px 0 0}.inline{display:flex;gap:8px}.check-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}.check-row input[type=range]{flex:1}.job-summary{border:1px dashed var(--border);background:#ffffffc2;border-radius:12px;min-height:72px;padding:10px;color:var(--muted)}.control-footer{display:grid;gap:12px}.actions{display:flex;gap:8px;flex-wrap:wrap}button{border:0;border-radius:999px;padding:10px 15px;background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#f7fff9;font-weight:700;cursor:pointer}.primary-button{padding:12px 20px;min-width:130px;box-shadow:0 10px 18px #1f6b5840}button.ghost{border:1px solid var(--border);background:#fffc;color:var(--text)}button:disabled{cursor:not-allowed;opacity:.62}.progress-wrap{display:grid;gap:6px}.progress-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.progress-track{height:11px;width:100%;border-radius:999px;overflow:hidden;background:#21302a14}.progress-bar{height:100%;width:0;background:linear-gradient(90deg,#3f8b76,#2f6d5b);transition:width .15s ease}.output{padding:20px}.output-actions{display:flex;gap:8px}.results-toolbar{position:sticky;top:82px;z-index:8;margin-bottom:10px;border:1px solid var(--border);border-radius:12px;background:#ffffffe0;box-shadow:var(--shadow-sm);padding:10px;display:flex;align-items:center;justify-content:space-between;gap:12px}.tabs{display:inline-flex;gap:8px}.tab-button{border-radius:999px;border:1px solid var(--border);background:#ffffffb8;color:var(--text);padding:7px 12px;font-size:.86rem;font-weight:700}.tab-button.active{border-color:#1f6b586b;background:#1f6b5829;color:#184d40}.results-content{display:grid}.result-panel{display:none}.result-panel.is-active{display:block}.confidence-filter{min-width:260px}.confidence-filter-row{display:flex;align-items:center;gap:10px}.page-results{border:1px solid var(--border);border-radius:12px;background:#ffffffbd;min-height:360px;max-height:72vh;overflow:auto;padding:10px}.page-card{border:1px solid var(--border);border-radius:10px;background:#ffffffd9;margin-bottom:10px;padding:8px}.page-head{display:flex;justify-content:space-between;align-items:center;gap:6px;margin-bottom:6px;font-size:.9rem}.page-thumb{width:100%;max-height:160px;object-fit:contain;border-radius:8px;border:1px solid var(--border);margin-bottom:6px;background:#fff}.page-text{margin:0;white-space:pre-wrap;font-size:.9rem;line-height:1.4;color:#243129}.page-confidence{font-size:.8rem;color:var(--muted)}.state-chip{display:inline-flex;align-items:center;justify-content:center;min-width:98px;border-radius:999px;border:1px solid transparent;padding:6px 11px;font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.state-ready{background:#1b5c4b1f;border-color:#1b5c4b40;color:#1b5c4b}.state-running{background:#b0812424;border-color:#b081244d;color:#7b570f}.state-done{background:#247c3c29;border-color:#247c3c42;color:#1d6f36}.state-error{background:#a62a2a24;border-color:#a62a2a40;color:#8c2525}:root[data-theme=dark] button.ghost,:root[data-theme=dark] .tertiary,:root[data-theme=dark] .tab-button{background:#222d38d1;color:var(--text)}:root[data-theme=dark] .dropzone{background:linear-gradient(180deg,#293842e0,#1c272fd9)}:root[data-theme=dark] select,:root[data-theme=dark] input[type=text],:root[data-theme=dark] textarea,:root[data-theme=dark] input[type=file],:root[data-theme=dark] .chips,:root[data-theme=dark] .advanced-select,:root[data-theme=dark] .page-results,:root[data-theme=dark] .job-summary,:root[data-theme=dark] .results-toolbar{background:#1e2831db;color:var(--text)}:root[data-theme=dark] .chip{background:#3ca8892e;border-color:#3ca88961;color:#c9f3e7}:root[data-theme=dark] .chip button{background:#c9f3e729;color:#d9f7ee}:root[data-theme=dark] .page-card{background:#232f39e0}:root[data-theme=dark] .page-text{color:#dbe5e8}:root[data-theme=dark] .state-ready{background:#4cd4ac29;border-color:#4cd4ac59;color:#a4f7df}:root[data-theme=dark] .state-running{background:#ffbe5933;border-color:#ffbe595c;color:#ffd99b}:root[data-theme=dark] .state-done{background:#5bcb8338;border-color:#5bcb835c;color:#b5f1c7}:root[data-theme=dark] .state-error{background:#f06c6c33;border-color:#f06c6c59;color:#ffc0c0}.output-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.output-head h2{margin:0 0 10px}@media(max-width:860px){.settings-grid,.grid-2{grid-template-columns:1fr}.topbar{position:static;flex-direction:column;align-items:flex-start;gap:14px}.topbar-meta{width:100%;align-items:stretch}.primary-button,.actions{width:100%}.actions button{flex:1}.results-layout{grid-template-columns:1fr}.results-toolbar{position:static;flex-direction:column;align-items:stretch}.confidence-filter{min-width:0}.output-head{flex-direction:column;align-items:flex-start}}
