*{margin:0;padding:0;box-sizing:border-box}:root{--bg-dark: #1a1a2e;--bg-sidebar: #16213e;--bg-card: #0f3460;--bg-main: #f0f2f5;--accent: #e94560;--accent-hover: #c73e54;--text-light: #eee;--text-muted: #aaa;--text-dark: #222;--success: #2ecc71;--warning: #f39c12;--danger: #e74c3c;--border: #ddd;--radius: 8px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-main);color:var(--text-dark)}.app{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--bg-sidebar);color:var(--text-light);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0}.sidebar-header{padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{width:52px;height:52px;border-radius:10px;display:block;margin-bottom:10px}.sidebar-header h1{font-size:22px;font-weight:700;letter-spacing:.5px}.sidebar-header .subtitle{font-size:12px;color:var(--text-muted);display:block;margin-top:2px}.sidebar ul{list-style:none;padding:12px 0;flex:1}.sidebar li a{display:block;padding:10px 20px;color:var(--text-muted);text-decoration:none;font-size:14px;transition:all .15s}.sidebar li a:hover{color:var(--text-light);background:#ffffff0d}.sidebar li a.active{color:var(--accent);background:#e945601a;border-left:3px solid var(--accent)}.sidebar-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.1)}.sidebar-footer .version{font-size:11px;color:var(--text-muted)}.processing-indicator{margin:8px 12px;background:#ffffff14;border-radius:var(--radius);overflow:hidden}.processing-indicator-summary{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:none;border:none;color:#fff;cursor:pointer;font-size:12px;text-align:left}.processing-indicator-summary:hover{background:#ffffff0d}.processing-spinner{width:12px;height:12px;border:2px solid rgba(255,255,255,.2);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;flex-shrink:0}.processing-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.processing-pct{color:var(--primary);font-weight:600;font-variant-numeric:tabular-nums}.processing-chevron{font-size:8px;opacity:.5}.processing-details{padding:0 12px 10px}.processing-job{padding:8px 0;border-top:1px solid rgba(255,255,255,.06)}.processing-job-header{display:flex;justify-content:space-between;font-size:11px;color:#fffc;margin-bottom:4px}.processing-job-label{text-transform:capitalize}.processing-job-count{font-variant-numeric:tabular-nums}.processing-job-meta{display:flex;gap:12px;font-size:10px;color:#fff6;font-variant-numeric:tabular-nums}.content{flex:1;margin-left:240px;padding:32px;max-width:1200px}.page-title{font-size:24px;font-weight:600;margin-bottom:24px}.card{background:#fff;border-radius:var(--radius);padding:24px;margin-bottom:20px;box-shadow:0 1px 3px #00000014}.card h2{font-size:16px;font-weight:600;margin-bottom:16px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;border-radius:var(--radius);padding:20px;box-shadow:0 1px 3px #00000014}.stat-card .label{font-size:12px;color:#888;text-transform:uppercase;letter-spacing:.5px}.stat-card .value{font-size:28px;font-weight:700;margin-top:4px}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border);font-size:14px}th{font-weight:600;color:#666;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.btn{display:inline-block;padding:8px 20px;border:none;border-radius:var(--radius);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;text-decoration:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:#e2e8f0;color:var(--text-dark)}.btn-secondary:hover{background:#cbd5e1}.btn-sm{padding:4px 12px;font-size:12px}.btn-danger{background:var(--danger);color:#fff}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:#555}.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:inherit}.form-group textarea{min-height:200px;resize:vertical}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:24px;text-align:center;cursor:pointer;transition:all .15s;background:#fafbfc}.upload-zone:hover{border-color:#93c5fd;background:#f0f7ff}.upload-zone-active{border-color:var(--accent);background:#fff0f3;border-style:solid}.upload-zone-extracting{cursor:wait;opacity:.8}.upload-zone-content{display:flex;flex-direction:column;align-items:center;gap:6px;font-size:14px;color:#666}.upload-zone-icon{font-size:28px;margin-bottom:4px}.upload-zone-hint{font-size:12px;color:#999}.upload-zone-filename{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:13px;color:#065f46;background:#d1fae5;padding:6px 12px;border-radius:var(--radius)}.upload-zone-clear{margin-left:auto;background:none;border:none;color:#888;font-size:12px;cursor:pointer;text-decoration:underline}.upload-zone-clear:hover{color:var(--danger)}.upload-spinner{width:24px;height:24px;border:3px solid #e2e8f0;border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}.badge-success{background:#d4edda;color:#155724}.badge-warning{background:#fff3cd;color:#856404}.badge-danger{background:#f8d7da;color:#721c24}.badge-info{background:#d1ecf1;color:#0c5460}.badge-muted{background:#e2e8f0;color:#555}.progress-bar{width:100%;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--success);border-radius:4px;transition:width .3s}.side-by-side{display:grid;grid-template-columns:1fr 1fr;gap:16px}.side-by-side.three-col{grid-template-columns:1fr 1fr 1fr}.text-panel{background:#f8f9fa;border:1px solid var(--border);border-radius:var(--radius);padding:16px;font-size:14px;line-height:1.7;max-height:600px;overflow-y:auto}.text-panel h3{font-size:12px;text-transform:uppercase;color:#888;margin-bottom:12px;letter-spacing:.5px}.lang-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}.lang-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;cursor:pointer}.lang-item:hover{background:#f0f2f5}.lang-item input[type=checkbox]{cursor:pointer}.lang-item .tier{font-size:10px;color:#888;margin-left:auto}.score-high{color:var(--success);font-weight:700}.score-medium{color:var(--warning);font-weight:700}.score-low{color:var(--danger);font-weight:700}.empty-state{text-align:center;padding:48px;color:#888}.empty-state p{margin-top:8px;font-size:14px}.clickable-row{cursor:pointer}.clickable-row:hover{background:#f8f9fa}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 12px #0000001f;min-width:220px;z-index:100}.dropdown-item{display:block;padding:8px 16px;font-size:13px;color:var(--text-dark);text-decoration:none;cursor:pointer}.dropdown-item:hover{background:#f0f2f5}.dropdown-header{padding:4px 16px;font-size:11px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px}.batch-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;margin-bottom:12px;background:#eef2ff;border:1px solid #c7d2fe;border-radius:var(--radius)}.batch-bar-count{font-size:13px;font-weight:600;color:#4338ca}.sortable-th{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.sortable-th:hover{color:var(--accent)}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-sidebar)}.auth-card{background:#fff;border-radius:12px;padding:40px;width:100%;max-width:400px;box-shadow:0 8px 32px #0003}.auth-header{text-align:center;margin-bottom:28px}.auth-logo{width:64px;height:64px;border-radius:12px;margin-bottom:12px}.auth-header h1{font-size:24px;font-weight:700;color:var(--text-dark)}.auth-subtitle{font-size:13px;color:#888;display:block;margin-top:4px}.auth-error{background:#f8d7da;color:#721c24;padding:10px 14px;border-radius:var(--radius);font-size:13px;margin-bottom:16px}.auth-submit{width:100%;padding:10px;margin-top:8px}.auth-link{color:var(--accent);text-decoration:none;font-size:13px}.auth-link:hover{text-decoration:underline}.password-input-wrapper{position:relative}.password-input-wrapper input{width:100%;padding-right:40px}.password-toggle{position:absolute;top:0;right:0;width:38px;height:100%;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:#999;transition:color .15s}.password-toggle:hover{color:#555}.password-hint{display:block;color:#888;font-size:11px;margin-top:4px}.auth-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.auth-spinner{width:36px;height:36px;border:3px solid #e2e8f0;border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sidebar-user{padding:12px 20px;border-top:1px solid rgba(255,255,255,.1)}.sidebar-user-info{margin-bottom:8px}.sidebar-user-name{display:block;font-size:13px;font-weight:600;color:var(--text-light)}.sidebar-user-role{display:block;font-size:11px;color:var(--text-muted);margin-top:2px}.btn-signout{display:block;width:100%;padding:6px 12px;background:#ffffff14;color:var(--text-muted);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);font-size:12px;cursor:pointer;transition:all .15s}.btn-signout:hover{background:#ffffff26;color:var(--text-light)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;padding:28px;width:100%;max-width:440px;box-shadow:0 8px 32px #0003}.modal-title{font-size:18px;font-weight:600;margin-bottom:8px}.modal-message{font-size:14px;color:#555;margin-bottom:20px;line-height:1.5}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.admin-header h1{font-size:24px;font-weight:600}.tab-bar{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:24px}.tab-item{padding:10px 20px;font-size:14px;font-weight:500;color:#888;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;background:none;border-top:none;border-left:none;border-right:none}.tab-item:hover{color:var(--text-dark)}.tab-item.active{color:var(--accent);border-bottom-color:var(--accent)}.profile-card{display:flex;gap:24px;align-items:flex-start}.profile-avatar-section{text-align:center}.profile-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;background:#e2e8f0;display:block}.profile-avatar-placeholder{width:96px;height:96px;border-radius:50%;background:var(--bg-card);color:#fff;display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:700}.profile-upload-btn{margin-top:8px;font-size:12px;color:var(--accent);background:none;border:none;cursor:pointer;text-decoration:underline}.profile-upload-btn:hover{color:var(--accent-hover)}.profile-info{flex:1}.profile-name{font-size:22px;font-weight:700;margin-bottom:4px}.profile-email{font-size:14px;color:#888;margin-bottom:12px}.profile-meta{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:#666}.profile-meta span{display:flex;align-items:center;gap:4px}.invite-link-box{background:#f0fdf4;border:1px solid #86efac;border-radius:var(--radius);padding:12px 16px;margin:12px 0;display:flex;align-items:center;gap:8px}.invite-link-box code{flex:1;font-size:12px;word-break:break-all;color:#166534}.copy-btn{padding:4px 10px;font-size:12px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;white-space:nowrap;transition:all .15s}.copy-btn:hover{background:#f0f2f5}.temp-password-box{background:#fffbeb;border:1px solid #fcd34d;border-radius:var(--radius);padding:12px 16px;margin:12px 0;display:flex;align-items:center;gap:8px}.temp-password-box code{flex:1;font-size:16px;font-weight:600;letter-spacing:1px;color:#92400e}.badge-role-super_admin{background:#ede9fe;color:#5b21b6}.badge-role-admin{background:#dbeafe;color:#1e40af}.badge-role-contributor{background:#d1fae5;color:#065f46}.badge-role-viewer{background:#e2e8f0;color:#555}.sidebar-section-label{padding:16px 20px 6px;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#ffffff4d}.sidebar-user-link{display:block;text-decoration:none;color:inherit}.sidebar-user-link:hover .sidebar-user-name{color:var(--accent)}.inline-form-row{display:flex;gap:8px;align-items:flex-end;margin-bottom:20px}.inline-form-row .form-group{margin-bottom:0}.inline-form-row .form-group.flex-1{flex:1}.inline-form-row select{padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:inherit;background:#fff}.chunk-text{cursor:pointer;padding:6px 8px;border-radius:var(--radius);border:1px solid transparent;transition:all .15s;position:relative}.chunk-text:hover{background:#f0f7ff;border-color:#93c5fd}.chunk-edited{border-left:3px solid #818cf8}.badge-edited{display:inline-block;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:600;background:#ede9fe;color:#6d28d9;margin-right:6px;vertical-align:middle}.chunk-editor{border:2px solid #93c5fd;border-radius:var(--radius);padding:8px;background:#fff}.chunk-editor textarea{width:100%;padding:8px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:inherit;line-height:1.6;resize:vertical;min-height:80px}.chunk-editor-actions{display:flex;align-items:center;gap:8px;margin-top:8px}.glossary-section{border-left:4px solid #818cf8}.glossary-add-form{display:flex;gap:8px;align-items:center;margin-bottom:4px}.glossary-add-form input{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;flex:1}.glossary-tags{display:flex;flex-wrap:wrap;gap:6px}.glossary-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#f0f7ff;border:1px solid #bfdbfe;border-radius:16px;font-size:12px}.glossary-tag-org{background:#f5f5f5;border-color:#ddd}.glossary-tag-en{font-weight:600;color:var(--text-dark)}.glossary-tag-arrow{color:#888}.glossary-tag-target{color:#1e40af}.glossary-tag-notes{color:#888;font-size:11px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.glossary-tag-delete{background:none;border:none;color:#888;cursor:pointer;font-size:14px;padding:0 2px;line-height:1}.glossary-tag-delete:hover{color:var(--danger)}.searchable-select{position:relative}.searchable-select-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;font-size:14px;font-family:inherit;cursor:pointer;color:var(--text-dark);transition:border-color .15s;text-align:left}.searchable-select-trigger:hover{border-color:#93c5fd}.searchable-select-value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.searchable-select-arrow{flex-shrink:0;margin-left:8px;color:#888}.searchable-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px #0000001f;z-index:200;min-width:200px}.searchable-select-search{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);color:#888}.searchable-select-search input{flex:1;border:none;outline:none;font-size:13px;font-family:inherit;padding:0;background:transparent}.searchable-select-options{max-height:240px;overflow-y:auto;padding:4px 0}.searchable-select-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 12px;border:none;background:none;font-size:13px;font-family:inherit;cursor:pointer;color:var(--text-dark);text-align:left;transition:background .1s}.searchable-select-option:hover{background:#f0f2f5}.searchable-select-option.selected{background:#eff6ff;color:#1d4ed8;font-weight:600}.searchable-select-option-label{flex:1}.searchable-select-option-sub{font-size:11px;color:#888;margin-left:8px}.searchable-select-empty{padding:12px;text-align:center;color:#888;font-size:13px}.glossary-form-grid{display:grid;grid-template-columns:1fr 180px 1fr 1fr auto;gap:12px;align-items:end}.lang-summary-pills{display:flex;flex-wrap:wrap;gap:8px}.lang-summary-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--border);border-radius:20px;background:#fff;font-size:13px;cursor:pointer;transition:all .15s;font-family:inherit}.lang-summary-pill:hover{border-color:#93c5fd;background:#f0f7ff}.lang-summary-pill.active{border-color:#3b82f6;background:#eff6ff;color:#1d4ed8}.lang-summary-name{font-weight:500}.lang-summary-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:#e2e8f0;font-size:11px;font-weight:600;color:#555}.lang-summary-pill.active .lang-summary-count{background:#3b82f6;color:#fff}.help-card{border-left:4px solid #3b82f6;background:#fafbff}.help-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.help-example{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px}.help-example-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#888;margin-bottom:10px}.help-example-row{display:flex;align-items:center;gap:6px;margin-bottom:6px;font-size:13px}.help-term{font-weight:600;color:var(--text-dark)}.help-arrow{color:#888}.help-translation{color:#1e40af}.help-lang{margin-left:auto;font-size:11px;color:#888;padding:1px 6px;background:#f0f2f5;border-radius:4px}.source-audio-player{width:100%;height:32px;margin-top:6px;border-radius:var(--radius)}.source-audio-player::-webkit-media-controls-panel{background:#f7f8fa}.dropdown-divider{height:1px;background:#eee;margin:4px 0}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;max-width:400px}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius);box-shadow:0 4px 16px #00000026;font-size:13px;line-height:1.4;animation:toast-in .25s ease-out}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.toast-success{background:#d1fae5;color:#065f46;border-left:4px solid var(--success)}.toast-error{background:#fee2e2;color:#991b1b;border-left:4px solid var(--danger)}.toast-warning{background:#fef3c7;color:#92400e;border-left:4px solid var(--warning)}.toast-info{background:#dbeafe;color:#1e40af;border-left:4px solid #3b82f6}.toast-message{flex:1}.toast-dismiss{background:none;border:none;font-size:18px;cursor:pointer;color:inherit;opacity:.6;padding:0 2px;line-height:1}.toast-dismiss:hover{opacity:1}.stuck-warning{display:flex;align-items:center;gap:10px;padding:10px 16px;margin-bottom:16px;background:#fef3c7;border:1px solid #fcd34d;border-radius:var(--radius);font-size:13px;color:#92400e}.stuck-warning-icon{font-size:16px;flex-shrink:0}.processing-banner{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;margin-bottom:16px;background:#e8f4fd;border:1px solid #90cdf4;border-radius:var(--radius);font-size:13px;color:#1a365d}.mt-16{margin-top:16px}.mb-16{margin-bottom:16px}.gap-8{gap:8px}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.reader-page{min-height:100vh;background:var(--reader-bg, #faf9f7);color:var(--reader-text, #2d2d2d);display:flex;flex-direction:column}.reader-progress-bar{position:fixed;top:0;left:0;height:3px;background:var(--reader-progress, #3b82f6);z-index:200;transition:width .08s linear;pointer-events:none}.reader-header{background:var(--reader-header-bg, #1e293b);color:var(--reader-header-text, #f1f5f9);position:sticky;top:0;z-index:100}.reader-header-inner{max-width:var(--reader-max-width, 720px);margin:0 auto;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}.reader-title{font-size:18px;font-weight:600;margin:0;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reader-header-controls{display:flex;align-items:center;gap:10px;flex-shrink:0}.reader-lang-select{padding:6px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:inherit;font-size:14px;cursor:pointer}.reader-lang-select option{background:var(--reader-header-bg);color:var(--reader-header-text)}.reader-lang-badge{font-size:13px;padding:4px 12px;border-radius:20px;background:#ffffff1a;white-space:nowrap}.reader-settings-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:inherit;border-radius:6px;padding:6px 12px;font-size:14px;font-weight:600;cursor:pointer;line-height:1}.reader-settings-btn:hover{background:#fff3}.reader-settings-panel{max-width:var(--reader-max-width, 720px);margin:0 auto;padding:10px 24px 14px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-wrap:wrap;gap:8px 20px;align-items:center;width:100%}.reader-settings-row{display:flex;align-items:center;gap:8px}.reader-settings-label{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:#ffffff73;min-width:36px}.reader-settings-group{display:flex;align-items:center;gap:3px}.reader-settings-value{font-size:13px;min-width:36px;text-align:center;color:#ffffffa6}.reader-settings-btn--sm{padding:4px 10px;font-size:12px;font-weight:400;background:#ffffff12;border-color:#ffffff21}.reader-settings-btn--sm:hover{background:#ffffff2b}.reader-settings-btn--sm.active{background:#ffffff38;border-color:#ffffff73;font-weight:600}.reader-settings-btn--sm:disabled{opacity:.3;cursor:default}.reader-container{max-width:var(--reader-max-width, 720px);margin:0 auto;padding:40px 24px;width:100%;flex:1}.reader-loading{color:var(--reader-meta, #888);text-align:center;padding:48px 0}.reader-error{text-align:center;padding:64px 0}.reader-error h1{font-size:24px;margin-bottom:8px}.reader-error p{color:var(--reader-meta, #888);font-size:16px}.reader-body{font-size:var(--reader-font-size, 17px);line-height:1.85}.reader-chunk{margin-bottom:36px}.reader-text p{color:var(--reader-text, #2d2d2d);margin-bottom:1em}.reader-text p:last-child{margin-bottom:0}.reader-chunk-divider{height:1px;background:var(--reader-border, #e8e4df);margin:8px 0 0;opacity:.5}.reader-audio{display:block;width:100%;margin-top:14px;border-radius:6px;opacity:.85}.reader-footer{text-align:center;padding:24px;color:var(--reader-meta, #999);font-size:12px;border-top:1px solid var(--reader-border, #eee)}@media(max-width:600px){.reader-header-inner{padding:10px 16px}.reader-title{font-size:15px}.reader-container{padding:24px 16px}.reader-settings-panel{padding:8px 16px 12px;gap:8px 14px}}.library-page{min-height:100vh;background:#f0f2f5;display:flex;flex-direction:column}.library-header{background:#1e293b;color:#f1f5f9;position:sticky;top:0;z-index:100}.library-header-inner{max-width:960px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}.library-title{font-size:20px;font-weight:600;margin:0}.library-header-controls{display:flex;align-items:center;gap:12px}.library-user-name{font-size:14px;color:#ffffffb3}.library-container{max-width:960px;margin:0 auto;padding:32px 24px;width:100%;flex:1}.library-empty{text-align:center;padding:64px 16px;color:#666}.library-empty h2{font-size:22px;color:#333;margin-bottom:12px}.library-empty p{font-size:15px;line-height:1.6;max-width:480px;margin:0 auto}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.library-card{background:#fff;border-radius:10px;padding:24px;box-shadow:0 1px 4px #00000014;display:flex;flex-direction:column;gap:16px}.library-card-body{flex:1}.library-card-title{font-size:17px;font-weight:600;color:#1a1a2e;margin:0 0 8px}.library-card-meta{font-size:13px;color:#888;display:flex;align-items:center;gap:8px}.library-card-lang{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;background:#e8e4f0;color:#5a4b8a}.library-card-actions{display:flex;gap:8px}.library-card-read{flex:1;text-align:center;text-decoration:none;padding:8px 16px;font-size:14px}.library-card-remove{padding:8px 12px;font-size:13px}.auth-footer-link{text-align:center;margin-top:20px;font-size:14px;color:#666}.auth-footer-link a{color:var(--accent);text-decoration:none;font-weight:600}.auth-footer-link a:hover{text-decoration:underline}.save-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:inherit;border-radius:6px;padding:6px 12px;font-size:13px;cursor:pointer;line-height:1;display:flex;align-items:center;gap:5px}.save-btn:hover{background:#fff3}.save-btn.saved{opacity:.6;cursor:default}.save-prompt{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;color:#333;border-radius:8px;padding:16px;box-shadow:0 4px 20px #0003;min-width:240px;z-index:200;text-align:center}.save-prompt p{font-size:14px;margin:0 0 12px;line-height:1.4}.save-prompt-actions{display:flex;gap:8px;justify-content:center}.save-prompt-actions a{padding:6px 14px;border-radius:6px;font-size:13px;text-decoration:none;font-weight:600}.save-prompt-actions .btn-primary{background:var(--accent);color:#fff}.save-prompt-actions .btn-secondary{background:#e2e8f0;color:#333}@media(max-width:600px){.library-header-inner{padding:10px 16px}.library-title{font-size:17px}.library-container{padding:20px 16px}.library-grid{grid-template-columns:1fr}}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.hamburger-btn{display:none;position:fixed;top:12px;left:12px;z-index:600;width:40px;height:40px;align-items:center;justify-content:center;background:var(--bg-sidebar);border:none;border-radius:var(--radius);cursor:pointer;color:var(--text-light);font-size:20px}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:499}@media(max-width:768px){.sidebar{transform:translate(-240px);transition:transform .25s ease;z-index:500}.app.sidebar-open .sidebar{transform:translate(0)}.app.sidebar-open .sidebar-overlay{display:block}.content{margin-left:0;padding:64px 16px 16px;max-width:100%}.hamburger-btn{display:flex}.flex.justify-between{flex-wrap:wrap;gap:8px}.flex.gap-8{flex-wrap:wrap}.auth-card{padding:24px 20px}.toast-container{right:12px;left:12px;max-width:none;bottom:16px}.batch-bar{flex-direction:column;align-items:flex-start;gap:8px}.inline-form-row{flex-wrap:wrap}.inline-form-row .form-group.flex-1{flex:1 1 100%}.glossary-add-form{flex-wrap:wrap}.profile-card{flex-direction:column;align-items:center;text-align:center}.profile-info{width:100%}}@media(max-width:640px){.side-by-side,.side-by-side.three-col{grid-template-columns:1fr}.glossary-form-grid{grid-template-columns:1fr 1fr}.help-grid{grid-template-columns:1fr}.card{padding:16px}.page-title{font-size:20px;margin-bottom:16px}}@media(max-width:480px){.content{padding:64px 12px 12px}.admin-header{flex-direction:column;align-items:flex-start;gap:12px}.stat-card .value{font-size:22px}.tab-bar{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-item{white-space:nowrap;padding:10px 14px}}
