@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&display=swap";
@import "https://fonts.googleapis.com/css2?family=Noto+Serif+Ethiopic:wght@300;400;500;600;700&display=swap";
@font-face{font-family:Benaiah;src:url(/fonts/Benaiah.ttf)format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Abyssinia SIL;src:url(/fonts/AbyssinicaSIL-Regular.ttf)format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:abyssinia regular;src:url("/fonts/abyssinia regular.ttf")format("truetype");font-weight:400;font-style:normal;font-display:swap}.landing-title{color:var(--text-primary);margin-bottom:var(--space-2);letter-spacing:-.02em;text-align:center;font-size:4.5rem;font-weight:600;font-family:var(--font-ethiopic-title)}:root{--bg-primary:#0f0f0f;--bg-secondary:#161616;--bg-tertiary:#1a1a1a;--bg-elevated:#1e1e1e;--bg-hover:#252525;--text-primary:#f0f0f0;--text-secondary:#a0a0a0;--text-muted:#666;--text-disabled:#444;--primary:#6366f1;--primary-hover:#818cf8;--primary-muted:#6366f126;--success:#22c55e;--success-muted:#22c55e26;--warning:#f59e0b;--warning-muted:#f59e0b1a;--danger:#ef4444;--danger-muted:#ef444426;--flag:#fb923c;--flag-muted:#fb923c14;--flag-border:#fb923c40;--border:#ffffff0f;--border-strong:#ffffff1a;--divider:#ffffff0a;--font-ui:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-ethiopic:"Abyssinia SIL","Noto Serif Ethiopic",serif;--font-ethiopic-light:"abyssinia regular","Noto Serif Ethiopic",serif;--font-ethiopic-title:"Benaiah","Abyssinia SIL",serif;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-full:9999px;--transition-fast:.15s ease;--transition-base:.2s ease}@media (prefers-color-scheme:light){:root:not([data-theme=dark]){--bg-primary:#f8f9fa;--bg-secondary:#fff;--bg-tertiary:#f1f3f5;--bg-elevated:#fff;--bg-hover:#e9ecef;--text-primary:#1a1a1a;--text-secondary:#6b7280;--text-muted:#9ca3af;--text-disabled:#d1d5db;--border:#0000000f;--border-strong:#0000001a;--divider:#0000000a;--flag-muted:#fb923c1f;--flag-border:#fb923c59}}:root[data-theme=light]{--bg-primary:#f8f9fa;--bg-secondary:#fff;--bg-tertiary:#f1f3f5;--bg-elevated:#fff;--bg-hover:#e9ecef;--text-primary:#1a1a1a;--text-secondary:#6b7280;--text-muted:#9ca3af;--text-disabled:#d1d5db;--border:#0000000f;--border-strong:#0000001a;--divider:#0000000a;--flag-muted:#fb923c1f;--flag-border:#fb923c59}svg{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light only}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-primary);height:100%;color:var(--text-primary);font-family:var(--font-ui);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.6}.app-container{flex-direction:column;min-height:100vh;display:flex}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}:focus:not(:focus-visible){outline:none}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}::selection{background:var(--primary-muted);color:inherit}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-4);font-family:var(--font-ui);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;font-size:13px;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-save{background:var(--success);color:#fff;padding:var(--space-2)var(--space-5);font-family:var(--font-ethiopic);font-size:14px}.btn-save:hover:not(:disabled){background:#16a34a}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-strong)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--text-muted)}.btn-ghost{width:36px;height:36px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0;display:flex}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.transcribe-btn-icon{cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.transcribe-btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.record-row{justify-content:flex-start;align-items:center;gap:12px;margin-top:4px;padding:8px 0;display:flex}.record-row.recording{background:var(--danger-muted);border-radius:var(--radius-md);justify-content:center;margin:8px 4px 0;padding:8px 12px}.record-btn-circle{border:2px solid var(--text-disabled);cursor:pointer;width:32px;height:32px;transition:all var(--transition-fast);background:0 0;border-radius:50%;justify-content:center;align-items:center;padding:0;display:flex}.record-btn-circle:hover{border-color:var(--danger);transform:scale(1.05)}.record-circle-inner{background:var(--text-disabled);width:18px;height:18px;transition:all var(--transition-fast);border-radius:50%}.record-btn-circle:hover .record-circle-inner{background:var(--danger);transform:scale(1.1)}.record-btn-small{border-radius:var(--radius-sm);cursor:pointer;width:28px;height:28px;transition:all var(--transition-fast);color:var(--text-secondary);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.record-btn-small:hover{background:var(--bg-hover)}.record-btn-small.cancel{color:var(--text-secondary)}.record-btn-small.cancel:hover{color:var(--danger);background:var(--danger-muted)}.record-btn-small.stop{color:var(--danger)}.record-btn-small.stop:hover{background:#ef444433}.record-duration-display{justify-content:center;align-items:center;gap:6px;min-width:60px;display:flex}.record-dot{background:var(--danger);border-radius:50%;width:8px;height:8px;animation:1s ease-in-out infinite record-blink}@keyframes record-blink{0%,to{opacity:1}50%{opacity:.3}}.record-time{font-size:13px;font-family:var(--font-ui);color:var(--danger);font-variant-numeric:tabular-nums;font-weight:500}.record-hint{color:var(--text-muted);font-size:11px}.record-error-text{color:var(--danger);font-size:11px}.record-status-text{color:var(--text-secondary);font-size:11px}.record-device-select{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);max-width:140px;padding:4px 6px;font-size:11px}.fab{bottom:var(--space-6);right:var(--space-6);background:var(--success);color:#fff;cursor:pointer;width:56px;height:56px;transition:all var(--transition-base);z-index:100;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed;box-shadow:0 4px 12px #22c55e66}.fab:hover:not(:disabled){background:#16a34a;transform:scale(1.05);box-shadow:0 6px 16px #22c55e80}.fab:disabled{opacity:.7;cursor:wait}.select{padding:var(--space-2)var(--space-3);padding-right:var(--space-6);background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-ui);cursor:pointer;transition:border-color var(--transition-fast);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;font-size:13px}.select:hover{border-color:var(--text-muted)}.select:focus{border-color:var(--primary)}.header{padding:var(--space-4)var(--space-6);background:var(--bg-secondary);justify-content:space-between;align-items:center;padding-bottom:0;display:flex}.header-title{align-items:center;gap:var(--space-3);display:flex}.header-icon{font-size:20px}.header-title h1{letter-spacing:-.01em;font-size:15px;font-weight:600}.header-back-btn{color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);align-items:center;gap:6px;padding:6px 10px;font-size:14px;font-weight:500;text-decoration:none;display:inline-flex}.header-back-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.header-stats{align-items:center;gap:var(--space-4);display:flex}.header-actions{align-items:center;gap:var(--space-3);display:flex}.icon-link{width:36px;height:36px;color:var(--text-muted);border-radius:var(--radius-md);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.icon-link:hover{color:var(--text-primary);background:var(--bg-secondary)}.stat{color:var(--text-secondary);font-size:12px;font-weight:500}.toolbar{align-items:center;gap:var(--space-4);padding:var(--space-3)var(--space-6);background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:50;display:flex;position:sticky;top:0}.toolbar-group{align-items:center;gap:var(--space-2);display:flex}.toolbar-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;margin-right:var(--space-1);font-size:12px;font-weight:500}.toolbar-stat{color:var(--text-secondary);font-size:13px;font-weight:500;font-family:var(--font-ethiopic-light)}.toolbar-spacer{flex:1}.toolbar-pagination{align-items:center;gap:var(--space-1);display:flex}.page-indicator{color:var(--text-secondary);padding:0 var(--space-2);text-align:center;font-variant-numeric:tabular-nums;min-width:60px;font-size:13px}.segment-control{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:2px;display:flex}.segment-btn{padding:var(--space-1)var(--space-3);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;font-size:12px;font-weight:500}.segment-btn:hover{color:var(--text-primary)}.segment-btn.active{background:var(--bg-elevated);color:var(--text-primary);box-shadow:0 1px 2px #0000001a}.segment-btn.active.pending{color:#eab308;background:#eab30826}.segment-btn.active.reviewed{background:var(--success-muted);color:var(--success)}.segment-btn.active.flagged{background:var(--flag-muted);color:var(--flag)}.segment-btn.active.deleted{background:var(--danger-muted);color:var(--danger)}.status-cell{width:140px}.status-segment{background:var(--bg-tertiary);border-radius:var(--radius-md);gap:2px;padding:2px;display:flex}.status-btn{padding:var(--space-2);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);color:var(--text-muted);background:0 0;border:none;flex:1;font-size:14px}.status-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.status-btn.active{box-shadow:0 1px 2px #0000001a}.status-btn.active.pending{color:#eab308;background:#eab30826}.status-btn.active.reviewed{background:var(--success-muted);color:var(--success)}.status-btn.active.flagged{background:var(--flag-muted);color:var(--flag)}.status-btn.active.deleted{background:var(--danger-muted);color:var(--danger)}.filter-toggle{align-items:center;gap:var(--space-2);cursor:pointer;-webkit-user-select:none;user-select:none;display:flex}.filter-toggle input{width:14px;height:14px;accent-color:var(--primary);cursor:pointer}.filter-toggle-label{color:var(--text-secondary);transition:color var(--transition-fast);align-items:center;font-size:13px;display:flex}.filter-toggle:hover .filter-toggle-label{color:var(--text-primary)}.filter-dropdown-container{height:100%;position:relative}.filter-icon-btn{background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:relative}.filter-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-muted)}.filter-icon-btn.active{background:var(--primary-muted);border-color:var(--primary);color:var(--primary)}.filter-badge{background:var(--primary);color:#fff;border-radius:var(--radius-full);justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:600;display:flex;position:absolute;top:-4px;right:-4px}.filter-dropdown{background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-lg);z-index:100;min-width:200px;animation:.15s dropdownFade;position:absolute;top:calc(100% + 6px);left:0;overflow:hidden;box-shadow:0 8px 24px #00000040}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.filter-dropdown-header{padding:var(--space-3)var(--space-4);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);font-size:11px;font-weight:600;font-family:var(--font-ethiopic)}.filter-dropdown-item{align-items:center;gap:var(--space-3);padding:var(--space-3)var(--space-4);cursor:pointer;transition:background var(--transition-fast);display:flex}.filter-dropdown-item:hover{background:var(--bg-hover)}.filter-dropdown-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.filter-dropdown-icon{color:var(--text-muted);justify-content:center;align-items:center;display:flex}.filter-dropdown-item span:last-child{color:var(--text-primary);font-size:13px}.filter-dropdown-clear{width:100%;padding:var(--space-3);color:var(--text-secondary);background:var(--bg-tertiary);border:none;border-top:1px solid var(--border);cursor:pointer;transition:all var(--transition-fast);font-size:12px;font-weight:500;font-family:var(--font-ethiopic);justify-content:center;align-items:center;display:flex}.filter-dropdown-clear:hover{background:var(--bg-hover);color:var(--danger)}.filter-dropdown-divider{margin:var(--space-2)0;border:none;border-top:1px solid var(--border)}.filter-dropdown-icon.status-pending{color:#eab308}.filter-dropdown-icon.status-reviewed{color:var(--success)}.filter-dropdown-icon.status-flagged{color:var(--flag)}.filter-dropdown-icon.status-deleted{color:var(--danger)}.filter-dropdown-item input[type=radio]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.replace-row{gap:var(--space-2);margin-top:var(--space-2);display:flex}.replace-input{padding:var(--space-2)var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-ethiopic);transition:all var(--transition-fast);flex:1;font-size:13px}.replace-input:focus{border-color:var(--primary);outline:none}.replace-input::placeholder{color:var(--text-muted)}.replace-all-btn{padding:var(--space-2)var(--space-3);white-space:nowrap;font-size:12px}.search-group{flex:1;max-width:300px}.search-input-container{align-items:center;display:flex;position:relative}.search-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:10px}.search-input{width:100%;padding:var(--space-2)var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-ethiopic);transition:all var(--transition-fast);padding-left:36px;padding-right:32px;font-size:14px}.search-input::placeholder{color:var(--text-muted)}.search-input:hover{border-color:var(--text-muted)}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-muted);outline:none}.search-clear{border-radius:var(--radius-sm);width:22px;height:22px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:absolute;right:6px}.search-clear:hover{background:var(--bg-hover);color:var(--text-primary)}.index-tooltip{display:inline-block;position:relative}.index-tooltip:after{content:attr(data-tooltip);background:var(--bg-elevated);color:var(--text-primary);white-space:nowrap;border-radius:var(--radius-md);border:1px solid var(--border-strong);opacity:0;visibility:hidden;z-index:1000;pointer-events:none;margin-left:8px;padding:6px 10px;font-size:12px;font-weight:500;transition:opacity .15s,visibility .15s;position:absolute;top:50%;left:100%;transform:translateY(-50%);box-shadow:0 4px 12px #0003}.index-tooltip:hover:after{opacity:1;visibility:visible}.table-container{background:var(--bg-secondary);border:1px solid var(--border);border-radius:0;overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;padding:var(--space-3)var(--space-4);background:var(--bg-tertiary);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);font-size:11px;font-weight:600}.sortable-header{align-items:center;gap:var(--space-2);cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast);display:flex}.sortable-header:hover{color:var(--text-primary)}.sort-icon{transition:opacity var(--transition-fast);flex-shrink:0}.sort-icon.inactive{opacity:.3}.sort-icon.active{opacity:1;color:var(--primary)}.hash-cell{width:100px;font-family:monospace;font-size:11px}.hash-value{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:2px 6px;display:inline-block}.hash-value:hover{background:var(--bg-hover);border-color:var(--primary);color:var(--primary)}.hash-empty{color:var(--text-muted)}.source-cell{width:120px}.data-table td{padding:var(--space-4);border-bottom:1px solid var(--divider);vertical-align:top}.data-table tr{transition:background var(--transition-fast)}.data-table tr:hover{background:var(--bg-hover)}.data-table tr.row-flagged{background:var(--flag-muted);border-left:3px solid var(--flag)}.data-table tr.row-flagged:hover{background:#fb923c1f}.data-table tr.row-deleted{background:var(--danger-muted);border-left:3px solid var(--danger)}.data-table tr.row-deleted:hover{background:#ef44441f}.data-table tr.row-dup-0{background:#06b6d41f;border-left:3px solid #06b6d4}.data-table tr.row-dup-1{background:#8b5cf61f;border-left:3px solid #8b5cf6}.data-table tr.row-dup-2{background:#f59e0b1f;border-left:3px solid #f59e0b}.data-table tr.row-dup-3{background:#10b9811f;border-left:3px solid #10b981}.data-table tr[class*=row-dup-]:hover{filter:brightness(1.1)}.index-cell{width:50px;color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:12px;font-weight:500}.audio-cell{width:180px}.source-label{margin-top:var(--space-2);color:var(--text-secondary);font-size:11px;font-weight:500;display:block}.sentence-cell{min-width:400px;max-width:600px}.sentence-input{width:100%;padding:var(--space-3);background:var(--bg-primary);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-ethiopic);resize:vertical;min-height:64px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);font-size:16px;line-height:1.8}.sentence-input:hover{border-color:var(--text-muted)}.sentence-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-muted)}.sentence-input.modified{border-color:var(--warning);background:var(--warning-muted)}.sentence-input.status-reviewed{border-color:var(--success);background:var(--success-muted)}.sentence-input.status-flagged{border-color:var(--warning);background:var(--warning-muted)}.actions-cell{width:100px}.actions-group{align-items:center;gap:var(--space-3);display:flex}.action-btn{border:1px solid var(--border-strong);border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex}.action-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-muted)}.flag-btn.active{background:var(--flag-muted);border-color:var(--flag-border);color:var(--flag)}.flag-btn.active:hover{background:#fb923c33}.checkbox-label{border:1px solid var(--border-strong);border-radius:var(--radius-md);cursor:pointer;width:32px;height:32px;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex;position:relative}.checkbox-label:hover{background:var(--bg-hover);border-color:var(--text-muted)}.checkbox-label input{opacity:0;cursor:pointer;position:absolute}.checkbox-label .check-icon{color:var(--text-muted);opacity:.3;transition:all var(--transition-fast)}.checkbox-label:hover .check-icon{opacity:.5}.checkbox-label input:checked~.check-icon{color:var(--success);opacity:1}.checkbox-label:has(input:checked){background:var(--success-muted);border-color:#22c55e4d}.pagination{padding:var(--space-3)var(--space-6);background:var(--bg-secondary);border-top:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.pagination-info{color:var(--text-secondary);font-size:13px}.pagination-controls{align-items:center;gap:2px;display:flex}.page-btn{min-width:32px;height:32px;padding:0 var(--space-2);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;font-size:13px;display:flex}.page-btn:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.page-btn:disabled{opacity:.3;cursor:not-allowed}.page-btn.active{background:var(--primary);color:#fff}.page-numbers{align-items:center;gap:2px;display:flex}.page-num{border-radius:var(--radius-sm);min-width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:0 6px;font-size:12px;font-weight:500;display:flex}.page-num:hover{background:var(--bg-tertiary);color:var(--text-primary)}.page-num.active{background:var(--primary);color:#fff}.page-ellipsis{width:24px;color:var(--text-muted);justify-content:center;align-items:center;font-size:12px;display:flex}.page-jump{border-left:1px solid var(--border);align-items:center;gap:4px;margin-left:8px;padding-left:8px;display:flex}.page-jump-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);width:50px;height:28px;color:var(--text-primary);text-align:center;padding:0 8px;font-size:12px}.page-jump-input:focus{border-color:var(--primary);outline:none}.page-jump-input::placeholder{color:var(--text-muted)}.page-jump-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.page-jump-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.page-jump-input[type=number]{-moz-appearance:textfield}.page-jump-total{color:var(--text-muted);font-size:12px}.status-bar{padding:var(--space-3)var(--space-6);background:var(--bg-tertiary);border-top:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.status-info{align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:13px;display:flex}.status-dot{border-radius:50%;width:8px;height:8px}.status-dot.success{background:var(--success)}.status-dot.warning{background:var(--warning);animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 10px #ef444400}}.status-bar.has-changes{background:var(--warning-muted);border-top-color:var(--warning)}.status-bar.has-changes .status-info{color:var(--warning)}.loading{justify-content:center;align-items:center;gap:var(--space-3);min-height:300px;padding:var(--space-8);color:var(--text-secondary);flex:1;display:flex}.spinner{border:2px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}.spinner-small{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-center{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:20px;min-height:300px;display:flex}.spinner-giant{width:112px;height:112px;position:relative}.spinner-giant-ring{border:2px solid color-mix(in srgb,var(--primary)25%,transparent);border-radius:50%;position:absolute;inset:0}.spinner-giant-icon{width:64px;height:64px;color:var(--primary);margin:auto;animation:1s linear infinite spin;position:absolute;inset:0}.spinner-ring{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.spinner-label{letter-spacing:.03em;color:var(--text-muted);font-size:14px;font-weight:300}.main-content{flex-direction:column;flex:1;display:flex;overflow:auto}.error-banner{align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-6);background:var(--danger-muted);color:var(--danger);border-bottom:1px solid var(--danger);font-size:13px;display:flex}.empty-state{min-height:300px;padding:var(--space-8);color:var(--text-secondary);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.empty-state p:first-of-type{font-family:var(--font-ethiopic);margin-top:var(--space-4);font-size:18px}.toast{bottom:var(--space-6);right:var(--space-6);align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-lg);z-index:1000;font-size:13px;animation:.3s slideIn;display:flex;position:fixed;box-shadow:0 4px 12px #0000004d}.toast.success{border-color:#22c55e4d}.toast.success svg{color:var(--success)}.toast.error{border-color:#ef44444d}.toast.error svg{color:var(--danger)}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.auth-container{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-8);text-align:center;width:100%;max-width:400px}.auth-card h1{font-family:var(--font-ethiopic-title);margin-bottom:var(--space-2);font-size:24px}.auth-card p{color:var(--text-secondary);margin-bottom:var(--space-6)}.audio-native{border-radius:var(--radius-full);background:var(--bg-tertiary);filter:invert()hue-rotate(180deg);width:100%;min-width:250px;max-width:280px;height:40px}@media (prefers-color-scheme:light){:root:not([data-theme=dark]) .audio-native{filter:none}}[data-theme=light] .audio-native{filter:none}.audio-native::-webkit-media-controls-panel{background:0 0}.audio-native::-webkit-media-controls-play-button{filter:brightness(.8)}.audio-native::-webkit-media-controls-mute-button{filter:brightness(.8)}.audio-native::-webkit-media-controls-current-time-display{color:inherit}.audio-native::-webkit-media-controls-time-remaining-display{color:inherit}.checkbox{width:16px;height:16px;accent-color:var(--success);cursor:pointer}.transcription-section{gap:var(--space-2);margin-top:var(--space-2);flex-direction:column;display:flex}.transcribe-btn{background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-md);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.transcribe-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--primary);border-color:var(--primary)}.transcribe-btn:disabled{opacity:.5;cursor:not-allowed}.spinner-tiny{border:2px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin}.transcription-result{align-items:center;gap:var(--space-2);margin-top:var(--space-1);animation:.2s fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.transcription-text{font-family:var(--font-ethiopic);color:var(--text-muted);cursor:pointer;padding:var(--space-1)0;transition:color var(--transition-fast);border-radius:0;flex:1;font-size:14px;line-height:1.6}.transcription-text:hover,.transcription-text:active{color:var(--success);background:0 0}.transcription-loading{align-items:center;gap:var(--space-2);padding:var(--space-1)0;color:var(--text-muted);font-size:12px;display:flex}.reload-transcription-btn{border-radius:var(--radius-md);width:24px;height:24px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);opacity:.6;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.reload-transcription-btn:hover{background:var(--bg-hover);color:var(--primary);opacity:1}.model-select{min-width:80px}.search-replace-unified{background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-lg);transition:all var(--transition-fast);align-items:center;height:38px;display:flex;position:relative}.search-replace-unified:focus-within{border-color:#fff3;box-shadow:0 0 0 3px #ffffff0d}.unified-filter-btn{border:none;border-right:1px solid var(--border);border-radius:var(--radius-lg)0 0 var(--radius-lg);width:38px;height:100%;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.unified-filter-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.unified-filter-btn.active{color:var(--text-primary);background:#ffffff0d}.unified-filter-btn .filter-badge{background:var(--text-muted);min-width:14px;height:14px;color:var(--bg-primary);border-radius:var(--radius-full);justify-content:center;align-items:center;padding:0 3px;font-size:9px;font-weight:600;display:flex;position:absolute;top:4px;right:4px}.unified-search-wrapper{flex:1;align-items:center;min-width:140px;display:flex;position:relative}.unified-search-input{width:100%;height:100%;padding:var(--space-2)var(--space-3);color:var(--text-primary);font-family:var(--font-ethiopic);background:0 0;border:none;padding-right:28px;font-size:13px}.unified-search-input::placeholder{color:var(--text-muted)}.unified-search-input:focus{outline:none}.unified-clear-btn{border-radius:var(--radius-sm);width:20px;height:20px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:absolute;right:4px}.unified-clear-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.unified-divider{background:var(--border);flex-shrink:0;width:1px;height:20px}.unified-replace-wrapper{flex-shrink:0;align-items:center;width:140px;display:flex;position:relative}.unified-replace-input{width:100%;height:100%;padding:var(--space-2)var(--space-3);color:var(--text-primary);font-family:var(--font-ethiopic);background:0 0;border:none;font-size:13px}.unified-replace-input::placeholder{color:var(--text-muted)}.unified-replace-input:focus{outline:none}.unified-replace-btn{border:none;border-left:1px solid var(--border);border-radius:0 var(--radius-lg)var(--radius-lg)0;width:38px;height:100%;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.unified-replace-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-secondary)}.unified-replace-btn:disabled{opacity:.3;cursor:not-allowed}.unified-replace-btn .spinner{animation:1s linear infinite spin}.confirm-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;animation:.2s confirmFadeIn;display:flex;position:fixed;inset:0}@keyframes confirmFadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-lg);min-width:320px;max-width:400px;animation:.2s confirmSlideIn;overflow:hidden;box-shadow:0 20px 50px #0006}@keyframes confirmSlideIn{0%{opacity:0;transform:scale(.95)translateY(-10px)}to{opacity:1;transform:scale(1)translateY(0)}}.confirm-header{padding:var(--space-5)var(--space-5)var(--space-3)}.confirm-title{color:var(--text-primary);margin:0;font-size:16px;font-weight:600}.confirm-body{padding:0 var(--space-5)var(--space-5)}.confirm-message{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.5}.confirm-stats{align-items:center;gap:var(--space-2);margin-top:var(--space-4);padding:var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md);display:flex}.confirm-count{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:20px;font-weight:600}.confirm-count-label{color:var(--text-muted);font-size:13px}.confirm-footer{gap:var(--space-3);padding:var(--space-4)var(--space-5);background:var(--bg-tertiary);border-top:1px solid var(--border);justify-content:flex-end;display:flex}.confirm-btn{padding:var(--space-2)var(--space-4);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;font-size:13px;font-weight:500}.confirm-btn-cancel{color:var(--text-secondary);border:1px solid var(--border-strong);background:0 0}.confirm-btn-cancel:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-muted)}.confirm-btn-confirm{background:var(--text-primary);color:var(--bg-primary)}.confirm-btn-confirm:hover{background:var(--text-secondary)}.search-replace-container{gap:var(--space-2);flex-direction:column;display:flex}.search-filter-group{background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-md);transition:all var(--transition-fast);align-items:center;display:flex}.replace-row-group .replace-input-container{position:relative}.replace-row-group .replace-input{padding:var(--space-2)var(--space-3);color:var(--text-primary);font-family:var(--font-ethiopic);background:0 0;border:none;flex:1;padding-right:32px;font-size:14px}.replace-row-group .replace-input:focus{outline:none}.replace-row-group .replace-input::placeholder{color:var(--text-muted)}.replace-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.replace-row-group .search-input-container{flex:1}.replace-row-group .replace-input{width:240px;padding-left:32px}.replace-all-btn{padding:var(--space-2)var(--space-3);background:var(--primary);color:#fff;border:none;border-left:1px solid var(--border);border-radius:0 var(--radius-md)var(--radius-md)0;min-width:42px;font-size:12px;font-weight:500;font-family:var(--font-ethiopic);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;justify-content:center;align-items:center;display:flex}.replace-all-btn:hover:not(:disabled){background:var(--primary-hover)}.replace-all-btn:disabled{opacity:.5;cursor:not-allowed}.search-filter-group:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-muted)}.search-filter-group .search-input{background:0 0;border:none;width:240px}.search-filter-group .search-input:focus{box-shadow:none;outline:none}.search-filter-group .search-input:hover{border-color:#0000}.search-filter-group .filter-icon-btn{border:none;border-left:1px solid var(--border);background:0 0;border-radius:0;width:36px;height:32px;padding:0}.search-filter-group .filter-icon-btn:hover{background:var(--bg-hover);border-color:#0000;border-left-color:var(--border)}.search-filter-group .filter-icon-btn.active{background:var(--primary-muted);color:var(--primary)}.transcription-match{color:var(--success);font-size:11px;font-family:var(--font-ethiopic);opacity:.9;align-items:center;gap:6px;margin-right:auto;display:flex}.diff-container{font-family:var(--font-ethiopic);flex-wrap:wrap;align-items:flex-end;row-gap:4px;font-size:13px;line-height:1.4;display:flex}.diff-word-wrapper{flex-direction:column;align-items:center;gap:2px;display:inline-flex}.diff-removed-word{color:var(--text-muted);background:var(--bg-tertiary);border-radius:var(--radius-sm);white-space:nowrap;padding:1px 4px;font-size:11px}.diff-char-removed{color:var(--danger);background:var(--danger-muted)}.diff-char-added{color:var(--success);background:var(--success-muted)}.diff-model-word{color:var(--text-secondary)}.diff-added-word{color:var(--text-primary);background:var(--success-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;padding:1px 4px}.diff-added-word:hover{border:1px solid var(--success);background:0 0}.accept-all-btn{border:1px solid var(--border);border-radius:var(--radius-sm);width:20px;height:20px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);margin-left:var(--space-4);opacity:.6;background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.accept-all-btn:hover{background:var(--success-muted);border-color:var(--success);color:var(--success);opacity:1}.icon-btn-toggle{height:36px;color:var(--text-muted);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;padding:0 8px;display:flex}.icon-btn-toggle:hover{color:var(--text-primary);background:var(--bg-secondary)}.icon-btn-toggle.active{color:var(--primary);background:var(--primary-muted);border-color:var(--primary)}.icon-btn-toggle-label{font-size:12px;font-weight:600;font-family:var(--font-ethiopic),var(--font-ui);letter-spacing:-.3px;white-space:nowrap}.diff-add{color:var(--success);background:var(--success-muted);text-decoration:none}.diff-remove{color:var(--danger);background:var(--danger-muted);opacity:.9;text-decoration:line-through}.modal-overlay{z-index:200;background:#000000b3;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-strong);border-radius:var(--radius-lg);width:100%;max-width:420px;animation:.2s slideUp;box-shadow:0 20px 40px #0006}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:var(--space-4)var(--space-5);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.modal-header h2{font-size:16px;font-weight:600;font-family:var(--font-ethiopic)}.modal-close{color:var(--text-muted);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:var(--space-5)}.modal-footer{justify-content:flex-end;gap:var(--space-3);padding:var(--space-4)var(--space-5);border-top:1px solid var(--border);display:flex}.form-group{margin-bottom:var(--space-4)}.form-group label{color:var(--text-secondary);margin-bottom:var(--space-2);font-size:12px;font-weight:500;font-family:var(--font-ethiopic);display:block}.form-input{width:100%;padding:var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-ethiopic);transition:all var(--transition-fast);font-size:15px}.form-input:hover{border-color:var(--text-muted)}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-muted);outline:none}.form-input::placeholder{color:var(--text-muted)}.preview-result{padding:var(--space-3);background:var(--primary-muted);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;font-family:var(--font-ethiopic)}.preview-count{color:var(--primary);font-size:16px;font-weight:600}.result-message{padding:var(--space-3);border-radius:var(--radius-md);font-size:14px;font-family:var(--font-ethiopic)}.result-message.success{background:var(--success-muted);color:var(--success)}.result-message.error{background:var(--danger-muted);color:var(--danger)}.sentence-cell mark{color:inherit;background:#f59e0b4d;border-radius:2px;padding:1px 2px}.wer-cell{text-align:center;width:80px;padding:var(--space-2)}.wer-value{border-radius:var(--radius-sm);font-variant-numeric:tabular-nums;padding:2px 8px;font-size:12px;font-weight:600;display:inline-block}.wer-low{background:var(--success-muted);color:var(--success)}.wer-medium{background:var(--warning-muted);color:var(--warning)}.wer-high{background:var(--danger-muted);color:var(--danger)}.wer-empty{color:var(--text-muted);font-size:12px}.accept-transcription-btn{background:var(--success-muted);border:1px solid var(--success);border-radius:var(--radius-sm);width:24px;height:24px;color:var(--success);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.accept-transcription-btn:hover{background:var(--success);color:#fff}.row-selected{background:var(--primary-muted)!important}.row-selected:hover{background:#6366f133!important}.checkbox-header,.checkbox-cell{text-align:center;vertical-align:middle;width:50px}.row-checkbox{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.mass-actions-bar{align-items:center;gap:var(--space-4);flex:1;animation:.2s slideIn;display:flex}.selection-count{color:var(--primary);background:var(--primary-muted);padding:var(--space-1)var(--space-3);border-radius:var(--radius-full);white-space:nowrap;font-size:13px;font-weight:600}.mass-action-buttons{gap:2px;display:flex}.mass-action-btn{align-items:center;gap:var(--space-1);display:flex}.mass-action-btn span{font-size:11px}.mass-action-btn.danger{color:var(--danger)}.mass-action-btn.danger:hover{background:var(--danger-muted);color:var(--danger)}.clear-selection-btn{padding:var(--space-1)var(--space-2);gap:var(--space-1);font-size:11px}.confirm-btn-danger{background:var(--danger);color:#fff}.confirm-btn-danger:hover{background:#dc2626}:root{--player-bg:#f5f5f7;--player-surface:#fff;--player-surface-elevated:#fff;--player-track-bg:#e8e8ed;--player-progress:#ff375f;--player-progress-glow:#ff375f4d;--player-text:#1d1d1f;--player-text-muted:#86868b;--player-radius:16px;--player-radius-lg:20px;--player-shadow:0 4px 24px #00000014,0 1px 2px #0000000a;--player-shadow-lg:0 8px 40px #0000001f,0 2px 8px #0000000f;--segment-border:#d2d2d7;--segment-marker:#007aff;--segment-marker-active:#5ac8fa;--segment-playhead:#ff375f;--segment-even:#007aff08;--segment-odd:#007aff08;--segment-selected:#5ac8fa26}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--player-bg:#000;--player-surface:#1c1c1e;--player-surface-elevated:#2c2c2e;--player-track-bg:#3a3a3c;--player-text:#f5f5f7;--player-text-muted:#8e8e93;--segment-border:#38383a;--segment-marker:#0a84ff;--segment-marker-active:#5ac8fa;--segment-even:#0a84ff1a;--segment-odd:#0a84ff1a;--player-shadow:0 4px 24px #0006,0 1px 2px #0003;--player-shadow-lg:0 8px 40px #00000080}}:root[data-theme=dark]{--player-bg:#000;--player-surface:#1c1c1e;--player-surface-elevated:#2c2c2e;--player-track-bg:#3a3a3c;--player-text:#f5f5f7;--player-text-muted:#8e8e93;--segment-border:#38383a;--segment-marker:#0a84ff;--segment-marker-active:#5ac8fa;--segment-even:#0a84ff1a;--segment-odd:#0a84ff1a;--player-shadow:0 4px 24px #0006,0 1px 2px #0003;--player-shadow-lg:0 8px 40px #00000080}.scrapper-container{background:var(--player-bg);height:100vh;min-height:100vh;padding:var(--space-6)var(--space-8);opacity:0;flex-direction:column;transition:opacity .4s,transform .4s;display:flex;overflow:hidden;transform:translateY(8px)}.scrapper-container.mounted{opacity:1;transform:translateY(0)}.scrapper-content{flex-direction:column;flex:1;width:100%;max-width:1200px;min-height:0;margin:0 auto;display:flex;overflow:hidden}.scrapper-header{margin-bottom:var(--space-6)}.scrapper-header-row{justify-content:space-between;align-items:center;display:flex}.scrapper-back-btn{color:var(--player-progress);transition:opacity var(--transition-fast);align-items:center;gap:6px;padding:6px 0;font-size:13px;font-weight:500;text-decoration:none;display:inline-flex}.scrapper-back-btn:hover{opacity:.7}.scrapper-editor-back{width:36px;height:36px;color:var(--text-secondary);background:0 0;border-radius:10px;justify-content:center;align-items:center;text-decoration:none;transition:all .2s;display:inline-flex}.scrapper-editor-back:hover{color:var(--text-primary);background:#ffffff14}.scrapper-editor-back svg{flex-shrink:0}.scrapper-hero{align-items:center;gap:var(--space-4);padding:var(--space-2)0;display:flex}.scrapper-icon-wrapper{flex-shrink:0;width:56px;height:56px;position:relative}.scrapper-icon-bg{background:linear-gradient(135deg,var(--player-progress),#ff8c00);opacity:.12;border-radius:14px;position:absolute;inset:0}.scrapper-icon{width:28px;height:28px;color:var(--player-progress);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.scrapper-title{color:var(--player-text);letter-spacing:-.3px;margin-bottom:2px;font-size:24px;font-weight:700}.scrapper-subtitle{color:var(--player-text-muted);font-size:14px;line-height:1.4}.scrapper-input-wrapper{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.recorder-input-layout{overflow:hidden}.scrapper-input-section{background:var(--player-surface);border-radius:var(--player-radius-lg);box-shadow:var(--player-shadow);flex-direction:row;flex-shrink:0;align-items:stretch;gap:24px;width:100%;margin:0 auto;padding:24px 32px;display:flex}.scrapper-input-group{flex-direction:column;flex:1 1 0;min-width:0;display:flex}.scrapper-input-label{color:var(--player-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-2);align-items:center;gap:8px;font-size:11px;font-weight:600;display:flex}.scrapper-url-form{gap:var(--space-2);flex:1;min-height:44px;display:flex}.scrapper-url-input-wrapper{flex:1;position:relative}.scrapper-url-input{border:1.5px solid var(--border);border-radius:var(--radius-lg);background:var(--player-bg);width:100%;height:100%;color:var(--player-text);transition:all var(--transition-fast);padding:12px 40px 12px 14px;font-size:14px}.scrapper-url-input:focus{border-color:var(--player-progress);box-shadow:0 0 0 3px var(--player-progress-glow);outline:none}.scrapper-url-input::placeholder{color:var(--text-muted)}.scrapper-url-clear{background:var(--text-muted);width:18px;height:18px;color:var(--player-surface);cursor:pointer;opacity:.5;transition:opacity var(--transition-fast);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.scrapper-url-clear:hover{opacity:1}.scrapper-submit-btn{background:var(--player-progress);color:#fff;border-radius:var(--radius-lg);cursor:pointer;width:44px;transition:all var(--transition-fast);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.scrapper-submit-btn:hover:not(:disabled){background:#ff1744}.scrapper-submit-btn:active:not(:disabled){transform:scale(.96)}.scrapper-submit-btn:disabled{opacity:.4;cursor:not-allowed}.scrapper-divider{justify-content:center;align-items:center;gap:var(--space-2);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:0 var(--space-1);flex-direction:column;flex-shrink:0;font-size:10px;font-weight:500;display:flex}.scrapper-divider:before,.scrapper-divider:after{content:"";background:var(--border);flex:1;width:1px}.scrapper-dropzone{border:1.5px dashed var(--border-strong);border-radius:var(--player-radius);cursor:pointer;text-align:left;background:0 0;flex-direction:row;flex:1 1 0;justify-content:center;align-items:center;gap:12px;min-width:0;padding:16px 24px;transition:all .2s;display:flex}.scrapper-dropzone:hover{border-color:var(--player-progress);background:#ff375f0a}.scrapper-dropzone.dragover{border-color:var(--player-progress);background:#ff375f14}.scrapper-dropzone-visual{flex-shrink:0}.scrapper-dropzone-icon-ring{background:var(--player-bg);width:36px;height:36px;color:var(--player-text-muted);transition:all var(--transition-fast);border-radius:8px;justify-content:center;align-items:center;display:flex}.scrapper-dropzone:hover .scrapper-dropzone-icon-ring{color:var(--player-progress);background:#ff375f1a}.scrapper-dropzone-icon-ring svg{width:18px;height:18px}.scrapper-dropzone-content{text-align:left}.scrapper-dropzone-text{color:var(--player-text);margin-bottom:1px;font-size:13px}.scrapper-dropzone-text strong{font-weight:600}.scrapper-dropzone-hint{color:var(--text-muted);font-size:11px}@media (max-width:768px){.scrapper-input-section{padding:var(--space-5);flex-direction:column;gap:20px}.scrapper-divider{padding:var(--space-1)0;flex-direction:row}.scrapper-divider:before,.scrapper-divider:after{flex:1;width:auto;height:1px}.scrapper-dropzone{text-align:center;flex-direction:column;flex:none;padding:32px 24px}.scrapper-dropzone-content{text-align:center}}.scrapper-loading-overlay{background:var(--bg);z-index:50;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:fixed;inset:0}.scrapper-progress-bar{background:color-mix(in srgb,var(--primary)15%,transparent);border-radius:2px;width:200px;height:3px;overflow:hidden}.scrapper-progress-fill{background:var(--primary);border-radius:2px;height:100%;transition:width .3s}.scrapper-error{align-items:flex-start;gap:var(--space-3);border-radius:var(--player-radius);padding:var(--space-4);margin-bottom:var(--space-4);cursor:pointer;transition:all var(--transition-fast);background:#ff3b301a;border:1px solid #ff3b3033;display:flex}.scrapper-error:hover{background:#ff3b3024}.scrapper-error-icon-wrapper{color:#ff3b30;background:#ff3b3026;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.scrapper-error-content{flex:1;min-width:0}.scrapper-error-title{color:#ff3b30;margin-bottom:2px;font-size:14px;font-weight:600;display:block}.scrapper-error-text{color:var(--player-text-muted);word-break:break-word;font-size:13px;display:block}.scrapper-error-dismiss{width:28px;height:28px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.scrapper-error-dismiss:hover{color:#ff3b30;background:#ff3b3026}.scrapper-player-fullscreen{background:var(--player-surface);z-index:100;flex-direction:column;display:flex;position:fixed;inset:0}.scrapper-player-topbar{border-bottom:1px solid #8080801a;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 64px 12px 24px;display:flex}.scrapper-player-topbar-actions,.scrapper-player-info{align-items:center;gap:12px;display:flex}.scrapper-player-artwork{background:linear-gradient(135deg,var(--player-progress),#ff8c00);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.scrapper-player-artwork svg{width:18px;height:18px}.scrapper-player-meta{flex-direction:column;gap:1px;display:flex}.scrapper-player-format{color:var(--player-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600}.scrapper-player-duration{color:var(--player-text);font-variant-numeric:tabular-nums;font-size:14px;font-weight:600}.scrapper-player-close{background:var(--player-bg);width:32px;height:32px;color:var(--player-text-muted);cursor:pointer;transition:all var(--transition-fast);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.scrapper-player-close svg{width:16px;height:16px}.scrapper-player-close:hover{color:#ff3b30;background:#ff3b301a}.scrapper-segments-area{flex:1;padding:24px 24px 100px;overflow-y:auto}.segments-empty-fullwidth{text-align:center;height:100%;color:var(--player-text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.segments-empty-fullwidth .segments-empty-icon{background:var(--player-bg);width:80px;height:80px;color:var(--player-text-muted);border-radius:50%;justify-content:center;align-items:center;margin-bottom:20px;display:flex}.segments-empty-fullwidth p{color:var(--player-text);margin-bottom:8px;font-size:16px;font-weight:500}.segments-empty-fullwidth span{color:var(--player-text-muted);font-size:13px}.segments-grid{flex-direction:column;gap:12px;display:flex}.segment-card{background:var(--player-surface-elevated);cursor:pointer;border:1px solid #8080801a;border-radius:12px;padding:16px 20px;transition:all .15s}.segment-card:hover{background:#ffffff14}.segment-card.active{border-color:var(--segment-marker-active);background:#5ac8fa14}.segment-card.playing{border-color:var(--segment-playhead);background:#ff375f14}.segment-card-header{align-items:center;gap:8px;display:flex}.segment-card-header .segment-number{background:var(--player-track-bg);width:28px;height:28px;color:var(--player-text);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.segment-card.playing .segment-number{background:var(--segment-playhead);color:#fff}.segment-card.active .segment-number{background:var(--segment-marker-active);color:#fff}.segment-card-header .segment-times{color:var(--player-text);font-variant-numeric:tabular-nums;font-size:13px;font-weight:500}.segment-card-header .segment-duration{color:var(--player-text-muted);margin-right:auto;font-size:12px}.segment-loop-btn{width:28px;height:28px;color:var(--player-text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.segment-loop-btn:hover{color:var(--segment-playhead);background:#ff375f1a}.segment-loop-btn.active{color:var(--segment-playhead);background:#ff375f26}.segment-sanitize-btn{width:24px;height:24px;color:var(--player-text-muted);cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.segment-card:hover .segment-sanitize-btn{opacity:1}.segment-sanitize-btn:hover{color:#f59e0b;background:#f59e0b26}.segment-crosstalk-btn{width:24px;height:24px;color:var(--player-text-muted);cursor:pointer;opacity:.5;background:0 0;border:none;border-radius:5px;justify-content:center;align-items:center;transition:all .15s;display:flex}.segment-card:hover .segment-crosstalk-btn{opacity:1}.segment-crosstalk-btn:hover{color:#ff9500;background:#ff950026}.segment-crosstalk-btn.active{color:#ff9500;opacity:1;background:#ff950033}.segment-multi-lang-btn{width:24px;height:24px;color:var(--player-text-muted);cursor:pointer;opacity:.5;background:0 0;border:none;border-radius:5px;justify-content:center;align-items:center;transition:all .15s;display:flex}.segment-card:hover .segment-multi-lang-btn{opacity:1}.segment-multi-lang-btn:hover{color:#34c759;background:#34c75926}.segment-multi-lang-btn.active{color:#34c759;opacity:1;background:#34c75933}.segment-card.looping{border-color:var(--segment-playhead);background:#ff375f14}.segment-card.looping .segment-number{background:var(--segment-playhead);color:#fff}.segment-transcribe-btn{color:#0a84ff;cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;min-width:28px;height:28px;min-height:28px;transition:all .15s;display:flex}.segment-transcribe-btn svg{flex-shrink:0;width:14px;height:14px}.segment-transcribe-btn:hover:not(:disabled){background:#0a84ff1a}.segment-transcribe-btn:disabled{opacity:.5;cursor:not-allowed}.segment-transcribe-btn.is-transcribing{color:#ff9f0a}.transcribe-spinner{animation:1s linear infinite spin}.segment-card-transcription{width:100%;font-family:var(--font-ethiopic);color:var(--player-text);resize:vertical;background:0 0;border:none;border-bottom:1px solid #80808033;border-radius:0;outline:none;min-height:40px;margin-top:12px;padding:8px 0;font-size:21px;line-height:1.8}.segment-card-transcription:focus{border-bottom-color:var(--segment-marker)}.segment-card-transcription::placeholder{color:var(--player-text-muted);font-style:italic}.segment-card-footer{align-items:center;gap:8px;margin-top:8px;padding-top:8px;display:flex}.segment-card-footer-spacer{flex:1}.segment-tags-group{flex-wrap:wrap;flex:1;justify-content:center;align-items:center;gap:3px;display:flex}.segment-tag-btn{border:1px solid color-mix(in srgb,var(--border)60%,transparent);color:var(--text-muted);font-size:9px;font-family:var(--font-mono,monospace);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;padding:2px 6px;line-height:1.4;transition:all .15s}.segment-tag-btn:hover{color:var(--primary);border-color:var(--primary);background:color-mix(in srgb,var(--primary)8%,transparent)}.segment-card-footer .segment-delete-btn{width:28px;height:28px;color:var(--player-text-muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.segment-card:hover .segment-card-footer .segment-delete-btn{opacity:1}.segment-card-footer .segment-delete-btn:hover{color:#ff3b30;background:#ff3b301a}.scrapper-player-bottombar{background:var(--player-surface);background:var(--player-bg);border-top:1px solid #8080801a;flex-shrink:0;padding:48px 24px 20px}.apple-player{flex-direction:column;flex:1;align-items:center;padding:8px 0 0;display:flex}.apple-player-track-container{margin-bottom:var(--space-4)}.apple-player-track{background:var(--player-track-bg);cursor:pointer;touch-action:none;border-radius:2px;height:4px;position:relative}.apple-player-track-progress{background:var(--player-progress);border-radius:2px;height:100%;transition:width 50ms linear;position:absolute;top:0;left:0}.apple-player-track-thumb{opacity:0;width:16px;height:16px;transition:all var(--transition-fast);background:#fff;border-radius:50%;position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px #0003,0 0 0 1px #0000000d}.apple-player-track:hover .apple-player-track-thumb,.apple-player-track:active .apple-player-track-thumb{opacity:1;transform:translate(-50%,-50%)scale(1)}.apple-player-track:active .apple-player-track-thumb{transform:translate(-50%,-50%)scale(1.1)}.apple-player-times{color:var(--player-text-muted);font-variant-numeric:tabular-nums;justify-content:space-between;margin-top:10px;font-size:11px;font-weight:500;display:flex}.apple-player-controls{justify-content:center;align-items:center;gap:var(--space-5);display:flex}.apple-player-btn{color:var(--player-text);cursor:pointer;transition:all var(--transition-fast);padding:var(--space-2);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.apple-player-btn:hover{transform:scale(1.06)}.apple-player-btn:active{transform:scale(.94)}.apple-player-btn-play{background:var(--player-progress);color:#fff;width:56px;height:56px;box-shadow:0 3px 12px var(--player-progress-glow)}.apple-player-btn-play svg{width:26px;height:26px}.apple-player-btn-play:hover{box-shadow:0 4px 16px var(--player-progress-glow);background:#ff1744}.apple-player-btn-skip{width:40px;height:40px;color:var(--player-text-muted);background:var(--player-bg);border-radius:50%}.apple-player-btn-skip svg{width:22px;height:22px}.apple-player-btn-skip:hover{color:var(--player-text);background:var(--player-track-bg)}.apple-player-btn-speed{min-width:44px;height:28px;color:var(--player-text-muted);background:var(--player-bg);margin-left:var(--space-3);font-variant-numeric:tabular-nums;border-radius:14px;padding:0 10px;font-size:12px;font-weight:600}.apple-player-btn-speed:hover{color:var(--player-text);background:var(--player-track-bg)}.apple-player-btn-mark{width:40px;height:40px;color:var(--segment-marker);background:var(--player-bg);margin-right:var(--space-3);border-radius:50%}.apple-player-btn-mark:hover{color:#fff;background:var(--segment-marker)}.apple-player-btn-mark:active{transform:scale(.95)}.apple-player-error{color:var(--danger,#e53e3e);text-align:center;padding:4px 8px;font-size:12px}.segment-timeline-wrapper{flex-direction:column;display:flex}.segment-timeline-label{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.segment-timeline-label>span:first-child{color:var(--player-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.segment-timeline-hint{color:var(--text-muted);opacity:.8;font-size:11px}.segment-timeline{cursor:crosshair;border-radius:8px;height:100px;padding-bottom:36px;position:relative;overflow:visible}.segment-waveform{z-index:1;opacity:0;pointer-events:none;transition:opacity .3s;position:absolute;inset:0 0 36px}.segment-waveform.ready{opacity:1}.segment-region{background:var(--segment-even);pointer-events:none;z-index:2;transition:background .2s;position:absolute;top:0;bottom:36px}.segment-region.active{background:var(--segment-selected)}.segment-loop-region{border-left:2px solid var(--segment-playhead);border-right:2px solid var(--segment-playhead);pointer-events:none;z-index:4;background:#ff375f26;position:absolute;top:0;bottom:36px}.segment-playhead{background:var(--segment-playhead);pointer-events:none;z-index:5;width:1px;position:absolute;top:0;bottom:36px;transform:translate(-50%)}.segment-duration-indicator{background:var(--player-surface-elevated);border:2px solid var(--segment-marker);width:32px;height:32px;color:var(--player-text-muted);z-index:10;border-radius:50%;justify-content:center;align-items:center;transition:width .15s,height .15s,top .15s,background .15s,border-color .15s,color .15s;display:flex;position:absolute;top:-28px;transform:translate(-50%)}.segment-duration-indicator.playing{background:var(--segment-marker-active);border-color:var(--segment-marker-active);color:#fff;width:36px;height:36px;top:-30px}.segment-duration-indicator.warning{background:#f59e0b;border-color:#f59e0b;animation:.5s infinite pulse-warning}.segment-duration-indicator.danger{background:#ef4444;border-color:#ef4444;animation:.3s infinite pulse-danger}@keyframes pulse-warning{0%,to{transform:translate(-50%)scale(1)}50%{transform:translate(-50%)scale(1.1)}}@keyframes pulse-danger{0%,to{transform:translate(-50%)scale(1)}50%{transform:translate(-50%)scale(1.15)}}.segment-duration-time{font-variant-numeric:tabular-nums;font-size:11px;font-weight:700}.segment-hover-line{background:var(--segment-marker);pointer-events:none;opacity:.6;z-index:3;width:1px;position:absolute;top:0;bottom:36px;transform:translate(-50%)}.segment-hover-time{color:#fff;white-space:nowrap;pointer-events:none;background:#007affe6;border-radius:6px;padding:4px 10px;font-size:10px;font-weight:600;position:absolute;top:8px;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #0003}.segment-marker{z-index:10;cursor:ew-resize;position:absolute;top:0;bottom:36px;transform:translate(-50%)}.segment-marker-line{background:var(--segment-marker);width:2px;transition:all var(--transition-fast);border-radius:1px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.segment-marker.active .segment-marker-line{background:var(--segment-marker-active);width:3px}.segment-marker.dragging .segment-marker-line{background:var(--segment-marker-active)}.segment-marker-handle{background:var(--segment-marker);border:2px solid var(--player-surface);width:12px;height:12px;transition:all var(--transition-fast);border-radius:50%;position:absolute;top:4px;left:50%;transform:translate(-50%);box-shadow:0 2px 4px #0003}.segment-marker:hover .segment-marker-handle,.segment-marker.active .segment-marker-handle{transform:translate(-50%)scale(1.2)}.segment-marker.active .segment-marker-handle{background:var(--segment-marker-active)}.segment-marker-time{color:#fff;background:var(--segment-marker);white-space:nowrap;opacity:0;transition:all var(--transition-fast);border-radius:4px;padding:2px 6px;font-size:9px;font-weight:600;position:absolute;top:20px;left:50%;transform:translate(-50%);box-shadow:0 2px 6px #0003}.segment-marker:hover .segment-marker-time,.segment-marker.active .segment-marker-time{opacity:1}.segment-marker.active .segment-marker-time{background:var(--segment-marker-active)}.segment-timeline-scale,.segment-scale-marker{display:none}.segment-player-track{z-index:10;pointer-events:auto;padding:6px 0 4px;position:absolute;bottom:0;left:0;right:0}.segment-player-track-bar{background:var(--player-track-bg);cursor:pointer;border-radius:4px;height:8px;position:relative;overflow:hidden}.segment-player-track-progress{background:var(--player-progress);pointer-events:none;border-radius:4px;height:100%;position:absolute;top:0;left:0}.segment-player-track-thumb{display:none}.segment-player-track-times{color:var(--player-text-secondary);font-variant-numeric:tabular-nums;justify-content:space-between;margin-top:4px;font-size:10px;font-weight:500;display:flex}.segments-list-wrapper{border-right:1px solid #80808026;flex-direction:column;grid-row:2/4;display:flex;overflow:hidden}.segments-list-header{padding:var(--space-3)var(--space-4);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.segments-list-title-group{align-items:center;gap:var(--space-2);display:flex}.segments-list-title{color:var(--player-text);font-size:12px;font-weight:600}.segments-list-count{color:var(--segment-marker);background:#007aff1a;border-radius:8px;padding:2px 6px;font-size:10px;font-weight:600}.segments-clear-btn{color:var(--player-text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-weight:500;display:flex}.segments-clear-btn svg{width:12px;height:12px}.segments-clear-btn:hover{color:#ff3b30;background:#ff3b301a}.batch-nav-group{background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--divider);align-items:center;gap:4px;padding:4px;display:flex}.batch-nav-btn{cursor:pointer;width:28px;height:28px;color:var(--text-primary);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.batch-nav-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--accent)}.batch-nav-btn:disabled{opacity:.3;cursor:not-allowed}.batch-nav-btn svg{flex-shrink:0}.batch-nav-counter{color:var(--text-secondary);text-align:center;white-space:nowrap;min-width:50px;padding:0 8px;font-size:11px;font-weight:600}.segments-list{flex:1;overflow-y:auto}.segments-empty{padding:var(--space-6)var(--space-4);text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;display:flex}.segments-empty-icon{width:48px;height:48px;margin-bottom:var(--space-3);background:var(--player-bg);color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;display:flex}.segments-empty-icon svg{width:24px;height:24px}.segments-empty p{color:var(--player-text-muted);margin-bottom:4px;font-size:13px;font-weight:500}.segments-empty span{color:var(--text-muted);font-size:11px;line-height:1.4}.segment-item{align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-4);border-bottom:1px solid var(--divider);cursor:pointer;transition:all var(--transition-fast);display:flex}.segment-item:hover{background:var(--player-bg)}.segment-item.active{background:#30d1581a}.segment-item.playing{background:#ff375f14}.segment-item.playing .segment-number{background:var(--segment-playhead);color:#fff}.segment-item:last-child{border-bottom:none}.segment-number{width:24px;height:24px;color:var(--player-text-muted);background:var(--player-bg);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.segment-item.active .segment-number{background:var(--segment-marker-active);color:#fff}.segment-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.segment-times{color:var(--player-text);font-variant-numeric:tabular-nums;align-items:center;gap:4px;font-size:12px;font-weight:600;display:flex}.segment-arrow{color:var(--text-muted);font-size:10px;font-weight:400}.segment-duration{color:var(--text-muted);font-size:10px;font-weight:500}.segment-delete-btn{width:24px;height:24px;color:var(--text-muted);cursor:pointer;opacity:0;transition:all var(--transition-fast);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.segment-delete-btn svg{width:12px;height:12px}.segment-item:hover .segment-delete-btn{opacity:1}.segment-delete-btn:hover{color:#ff3b30;background:#ff3b301a}@media (max-width:900px){.segments-list-wrapper{border-bottom:1px solid #80808026;border-right:none;grid-row:auto;max-height:200px}}.scrapper-settings-bar{gap:var(--space-4);padding:var(--space-3)var(--space-4);background:var(--bg-elevated);border:1px solid var(--divider);margin-bottom:var(--space-4);border-radius:12px;display:flex}.scrapper-setting{flex-direction:column;gap:4px;display:flex}.scrapper-setting-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600}.scrapper-setting-input{background:var(--player-bg);border:1px solid var(--divider);color:var(--text-primary);width:140px;transition:all var(--transition-fast);border-radius:6px;padding:6px 10px;font-size:13px}.scrapper-setting-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px #30d15826}.scrapper-lang-toggle{background:#ffffff0a;border-radius:8px;gap:2px;padding:3px;display:flex}.scrapper-lang-btn{color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:500;font-family:var(--font-ethiopic);background:0 0;border:none;border-radius:6px;padding:6px 14px;transition:all .2s}.scrapper-lang-btn:hover{color:var(--text-primary)}.scrapper-lang-btn.active{color:var(--text-primary);background:#ffffff1f}.scrapper-topbar-left,.scrapper-topbar-right{align-items:center;gap:12px;display:flex}.scrapper-topbar-settings{align-items:center;gap:8px;display:flex}.scrapper-select-wrapper{align-items:center;display:inline-flex;position:relative}.scrapper-select-wrapper.compact{min-width:80px}.scrapper-select{appearance:none;color:var(--text-primary);cursor:pointer;background:#ffffff0a;border:1px solid #0000;border-radius:8px;min-width:100px;padding:8px 28px 8px 12px;font-size:13px;font-weight:500;transition:all .2s}.scrapper-select:hover{background:#ffffff14}.scrapper-select:focus{background:#ffffff14;border-color:#ffffff1a;outline:none}.scrapper-select option{background:var(--player-surface);color:var(--text-primary);padding:8px 12px}.scrapper-select-icon{pointer-events:none;color:var(--text-secondary);opacity:.6;transition:opacity .2s;position:absolute;right:10px}.scrapper-select-wrapper:hover .scrapper-select-icon{opacity:1}.scrapper-select-wrapper.compact .scrapper-select{min-width:80px;padding:6px 24px 6px 10px;font-size:12px}.scrapper-player-controls-row{justify-content:space-between;align-items:center;gap:16px;display:flex}.scrapper-bottombar-left{align-items:center;gap:8px;min-width:100px;display:flex}.scrapper-bottombar-right{justify-content:flex-end;align-items:center;gap:8px;min-width:100px;display:flex}.scrapper-bottombar-left .scrapper-select{color:var(--text-secondary);min-width:70px;padding:5px 22px 5px 8px;font-size:11px;font-weight:400}.scrapper-bottombar-left .scrapper-select:hover{color:var(--text-primary)}.scrapper-transcribe-all-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;align-items:center;gap:5px;padding:5px 10px;font-size:11px;font-weight:500;transition:all .2s;display:flex}.scrapper-transcribe-all-btn:hover:not(:disabled){color:var(--primary);border-color:var(--primary);background:color-mix(in srgb,var(--primary)8%,transparent)}.scrapper-transcribe-all-btn:disabled{opacity:.5;cursor:not-allowed}.scrapper-clear-btn{width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex}.scrapper-clear-btn:hover{color:#ff3b30;background:#ff3b301a}.scrapper-auto-segment-btn{color:var(--text-secondary);cursor:pointer;background:#ffffff0a;border:1px solid #0000;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:12px;font-weight:500;transition:all .2s;display:flex}.scrapper-auto-segment-btn:hover:not(:disabled){color:var(--text-primary);background:#ffffff14}.scrapper-auto-segment-btn:disabled{opacity:.4;cursor:not-allowed}.scrapper-upload-all-btn{color:var(--text-primary);cursor:pointer;background:#ffffff14;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:12px;font-weight:500;transition:all .2s;display:flex}.scrapper-upload-all-btn:hover:not(:disabled){background:#ffffff24}.scrapper-upload-all-btn:disabled{opacity:.5;cursor:not-allowed}.scrapper-force-upload-btn{color:#ff9500;cursor:pointer;background:#ff95001a;border:1px solid #ff95004d;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.scrapper-force-upload-btn:hover:not(:disabled){background:#ff950033;border-color:#ff950080}.scrapper-force-upload-btn:disabled{opacity:.5;cursor:not-allowed}.scrapper-uploaded-count{color:var(--text-secondary);align-items:center;gap:5px;padding:6px 10px;font-size:12px;font-weight:400;display:flex}.scrapper-spinner{animation:.8s linear infinite scrapper-spin}@keyframes scrapper-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.segment-status-btn{border:1px solid var(--divider);cursor:pointer;opacity:.5;width:22px;height:22px;transition:all var(--transition-fast);background:0 0;border-radius:50%;justify-content:center;align-items:center;display:flex}.segment-status-btn:hover{opacity:1}.segment-status-btn.reviewed{color:var(--accent);border-color:var(--accent)}.segment-status-btn.reviewed.active{background:var(--accent);color:#fff;opacity:1}.segment-status-btn.deleted{color:#ff3b30;border-color:#ff3b30}.segment-status-btn.deleted.active{color:#fff;opacity:1;background:#ff3b30}.segment-uploaded-badge{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:flex}.segment-uploaded-text{color:var(--accent);opacity:.7;flex-shrink:0;font-size:11px}.segment-upload-btn{width:24px;height:24px;color:var(--accent);cursor:pointer;transition:all var(--transition-fast);background:#30d1581a;border:none;border-radius:6px;justify-content:center;align-items:center;display:flex}.segment-upload-btn:hover:not(:disabled){background:var(--accent);color:#fff}.segment-upload-btn:disabled{opacity:.5;cursor:not-allowed}.segment-upload-btn.uploaded{background:#30d15833}.segment-upload-btn.uploading{background:#30d1584d}.segment-card.deleted{opacity:.5;background:#ff3b300d;border-color:#ff3b3033}.segment-card.deleted .segment-card-transcription{color:var(--text-muted);text-decoration:line-through}.scrapper-history-grid{gap:var(--space-6);margin-top:var(--space-6);flex:1;grid-template-columns:1fr 1fr;width:100%;min-height:0;display:grid;overflow:hidden}@media (max-width:768px){.scrapper-history-grid{grid-template-columns:1fr;overflow-y:auto}}.scrapper-history-section{flex-direction:column;min-height:0;display:flex;overflow:hidden}.scrapper-options-row{gap:var(--space-3);margin-top:var(--space-2);display:flex}.scrapper-option{align-items:center;gap:var(--space-2);display:flex}.scrapper-option-label{text-transform:uppercase;letter-spacing:.3px;color:var(--text-muted);font-size:.72rem;font-weight:600}.scrapper-option-select{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;padding:3px 8px;font-size:.8rem}.scrapper-option-select:hover{border-color:var(--border-strong)}.scrapper-option-select:focus{border-color:var(--primary);outline:none}.scrapper-history-count{background:var(--bg-tertiary);color:var(--text-muted);border-radius:999px;margin-left:2px;padding:1px 7px;font-size:.7rem;font-weight:500}.scrapper-history-title{color:var(--text-muted);margin-bottom:var(--space-3);align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.scrapper-history-list{flex-direction:column;flex:1;gap:8px;margin-right:-8px;padding-right:8px;display:flex;overflow-y:auto}.scrapper-history-list::-webkit-scrollbar{width:6px}.scrapper-history-list::-webkit-scrollbar-track{background:0 0}.scrapper-history-list::-webkit-scrollbar-thumb{background:var(--divider);border-radius:3px}.scrapper-history-list::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.scrapper-history-loading{padding:var(--space-4);text-align:center;color:var(--text-muted);font-size:13px}.scrapper-history-item-wrapper{align-items:stretch;gap:8px;display:flex}.scrapper-history-item{padding:var(--space-3);background:var(--bg-tertiary);border:1px solid var(--divider);cursor:pointer;transition:all var(--transition-fast);text-align:left;color:inherit;border-radius:10px;flex-direction:column;flex:1;gap:4px;text-decoration:none;display:flex}.scrapper-history-item:hover:not(:disabled){border-color:var(--border-strong);background:var(--bg-hover)}.scrapper-history-item.all-uploaded,.scrapper-history-item.all-uploaded:hover:not(:disabled){background:var(--success-muted);border-color:var(--success)}.scrapper-history-item.all-uploaded .scrapper-history-item-segments{background:var(--success-muted);color:var(--success);font-weight:600}.scrapper-history-item:disabled{opacity:.6;cursor:not-allowed}.scrapper-history-delete-btn{background:var(--bg-tertiary);border:1px solid var(--divider);width:36px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.scrapper-history-delete-btn:hover:not(:disabled){color:#ff3b30;background:#ff3b301a;border-color:#ff3b30}.scrapper-history-delete-btn:disabled{opacity:.5;cursor:not-allowed}.scrapper-history-item-main{justify-content:space-between;align-items:center;gap:var(--space-2);display:flex}.scrapper-history-item-url{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;font-weight:500;overflow:hidden}.scrapper-history-item-url-link{color:var(--text-primary);align-items:center;gap:4px;text-decoration:none;display:inline-flex}.scrapper-history-item-url-link:hover{color:var(--text-primary)}.scrapper-history-item-url-link svg{opacity:.5;flex-shrink:0;transition:opacity .15s}.scrapper-history-item-url-link:hover svg{opacity:1}.scrapper-history-item-date{color:var(--text-muted);white-space:nowrap;font-size:11px}.scrapper-history-item-meta{gap:var(--space-2);align-items:center;display:flex}.scrapper-history-item-source,.scrapper-history-item-lang,.scrapper-history-item-segments{background:var(--bg-tertiary);color:var(--text-secondary);border-radius:4px;padding:2px 6px;font-size:10px}.scrapper-history-item-source{color:var(--success);background:var(--success-muted)}.scrapper-history-item-lang{font-family:var(--font-ethiopic);color:var(--text-secondary)}.scrapper-toast{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);z-index:1000;border-radius:12px;align-items:center;gap:8px;padding:12px 20px;font-size:13px;font-weight:500;animation:.3s ease-out toast-in;display:flex;position:fixed;bottom:100px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000026}.scrapper-toast.success{border-color:var(--accent)}.scrapper-toast.success svg{color:var(--accent)}.scrapper-toast.error{border-color:#ff3b30}.scrapper-toast.error svg{color:#ff3b30}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.batch-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000bf;animation:.2s ease-out batch-overlay-in;position:fixed;inset:0}@keyframes batch-overlay-in{0%{opacity:0}to{opacity:1}}.batch-modal-content{background:var(--bg-elevated);border:1px solid var(--divider);z-index:1001;border-radius:16px;flex-direction:column;width:min(560px,100vw - 48px);max-height:min(750px,100vh - 64px);animation:.25s ease-out batch-modal-in;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%);box-shadow:0 24px 64px #0006}@keyframes batch-modal-in{0%{opacity:0;transform:translate(-50%,-48%)scale(.96)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.batch-modal-header{border-bottom:1px solid var(--divider);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:20px 24px;display:flex}.batch-modal-header-info{flex:1;min-width:0}.batch-modal-title{color:var(--text-primary);align-items:center;gap:10px;margin:0;font-size:17px;font-weight:600;display:flex}.batch-modal-title svg{color:var(--accent);flex-shrink:0}.batch-modal-title-text{cursor:pointer;border-radius:6px;align-items:center;gap:8px;margin:-4px -8px;padding:4px 8px;transition:background .15s;display:inline-flex}.batch-modal-title-text:hover{background:#ffffff14}.batch-modal-title-edit-icon{color:var(--text-muted);opacity:0;transition:opacity .15s}.batch-modal-title-text:hover .batch-modal-title-edit-icon{opacity:1}.batch-modal-title-edit{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.batch-modal-title-input{background:var(--bg-tertiary);border:1px solid var(--divider);min-width:0;color:var(--text-primary);border-radius:6px;outline:none;flex:1;padding:6px 10px;font-size:15px;font-weight:500;transition:border-color .15s}.batch-modal-title-input:focus{border-color:var(--accent)}.batch-modal-title-save{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:all .15s;display:flex}.batch-modal-title-save:hover:not(:disabled){filter:brightness(1.1)}.batch-modal-title-save:disabled{opacity:.5;cursor:not-allowed}.batch-modal-description{color:var(--text-muted);word-break:break-all;margin-top:6px;font-size:12px}.batch-modal-close{background:var(--bg-tertiary);width:32px;height:32px;color:var(--text-muted);cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;margin-left:16px;transition:all .15s;display:flex}.batch-modal-close:hover{color:var(--text-primary);background:#ffffff1a}.batch-modal-progress{border-bottom:1px solid var(--divider);background:#0003;flex-shrink:0;align-items:center;gap:12px;padding:16px 24px;display:flex}.batch-modal-progress-bar{background:var(--bg-tertiary);border-radius:3px;flex:1;height:6px;overflow:hidden}.batch-modal-progress-fill{background:linear-gradient(90deg,var(--accent),#5ac8fa);border-radius:3px;height:100%;transition:width .3s}.batch-modal-progress-text{color:var(--text-secondary);white-space:nowrap;font-size:12px;font-weight:600}.batch-modal-filters{border-bottom:1px solid var(--divider);flex-shrink:0;align-items:center;gap:12px;padding:12px 24px;display:flex}.batch-modal-search{flex:1;align-items:center;gap:10px;display:flex}.batch-modal-filter-btn{background:var(--bg-tertiary);border:1px solid var(--divider);color:var(--text-muted);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;transition:all .15s;display:flex}.batch-modal-filter-btn:hover{background:var(--bg-hover);border-color:var(--text-muted)}.batch-modal-filter-btn.active{color:#30d158;background:#30d15826;border-color:#30d1584d}.batch-modal-search svg{color:var(--text-muted);flex-shrink:0}.batch-modal-search-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:14px}.batch-modal-search-input::placeholder{color:var(--text-muted)}.batch-modal-search-clear{background:var(--bg-tertiary);width:24px;height:24px;color:var(--text-muted);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex}.batch-modal-search-clear:hover{background:var(--bg-hover);color:var(--text-primary)}.batch-modal-search-results{color:var(--text-muted);background:var(--bg-tertiary);border-bottom:1px solid var(--divider);flex-shrink:0;padding:8px 24px;font-size:12px}.batch-modal-items{flex:1;padding:8px 0;overflow-y:auto}.batch-modal-item{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:12px 24px;transition:background .15s;display:flex}.batch-modal-item:hover{background:#ffffff0d}.batch-modal-item.status-completed .batch-modal-item-title{opacity:.5;color:var(--text-secondary)}.batch-modal-item-status{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.batch-modal-item-status svg{color:var(--text-muted)}.batch-modal-item-status.status-in-progress{background:#ff9f0a26}.batch-modal-item-status.status-in-progress svg{color:#ff9f0a;filter:drop-shadow(0 0 2px #ff9f0a80)}.batch-modal-item-status.status-completed{background:#30d15826}.batch-modal-item-status.status-completed svg{color:#30d158;filter:drop-shadow(0 0 2px #30d15880)}.batch-modal-item-title{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;font-weight:500;overflow:hidden}.batch-modal-item-action{background:var(--accent);opacity:0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:all .15s;display:flex;transform:scale(.9)}.batch-modal-item:hover .batch-modal-item-action{opacity:1;transform:scale(1)}.batch-modal-item-action svg{color:#fff;margin-left:2px}.batch-modal-footer{border-top:1px solid var(--divider);background:#0003;flex-shrink:0;justify-content:flex-end;align-items:center;gap:12px;padding:16px 24px;display:flex}.batch-modal-btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.batch-modal-btn:disabled{opacity:.5;cursor:not-allowed}.batch-modal-btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.batch-modal-btn-secondary:hover:not(:disabled){background:#ffffff26}.batch-modal-btn-danger{color:#ff6961;background:#ff3b3026}.batch-modal-btn-danger:hover:not(:disabled){background:#ff3b3040}.batch-modal-spinner{animation:.8s linear infinite spinner}@media (prefers-color-scheme:light){:root:not([data-theme=dark]) .batch-modal-overlay{background:#0006}:root:not([data-theme=dark]) .batch-modal-content{box-shadow:0 24px 64px #0000001f}:root:not([data-theme=dark]) .batch-modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}:root:not([data-theme=dark]) .batch-modal-progress{background:var(--bg-tertiary)}:root:not([data-theme=dark]) .batch-modal-item:hover{background:var(--bg-hover)}:root:not([data-theme=dark]) .batch-modal-footer{background:var(--bg-tertiary)}:root:not([data-theme=dark]) .batch-modal-btn-secondary:hover:not(:disabled){background:var(--bg-hover)}}.scrapper-history-item-batch{border-left:3px solid var(--accent)}.scrapper-history-item-batch .batch-icon{color:var(--accent);flex-shrink:0;margin-right:4px}.scrapper-history-item-batch-progress{color:var(--text-muted);align-items:center;gap:8px;font-size:11px;font-weight:600;display:flex}.batch-progress-inline{align-items:center;margin-left:auto;display:flex}.batch-progress-bar{background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:3px;width:64px;height:4px;overflow:hidden}.batch-progress-fill{background:var(--success);border-radius:3px;height:100%;transition:width .3s}.scrapper-scanning-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:900;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.scrapper-scanning-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:16px;flex-direction:column;align-items:center;gap:16px;padding:32px 48px;display:flex;box-shadow:0 16px 48px #0003}.scrapper-scanning-text{color:var(--text-secondary);font-size:14px;font-weight:500}.scrapper-sources-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:6px;margin-left:16px;padding:6px 12px;font-size:12px;font-weight:500;transition:all .15s;display:flex}.scrapper-sources-btn:hover{background:var(--bg-hover);border-color:var(--border-strong);color:var(--text-primary)}.scrapper-sources-btn svg{opacity:.7}.scrapper-sources-btn:hover svg{opacity:1}.sources-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000bf;animation:.15s fadeIn;position:fixed;inset:0}.sources-modal-content{background:var(--bg-elevated);border:1px solid var(--border);z-index:1001;border-radius:16px;flex-direction:column;width:90%;max-width:400px;max-height:80vh;animation:.2s modalSlideIn;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%);box-shadow:0 24px 64px #0000004d}.sources-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.sources-modal-title{color:var(--text-primary);align-items:center;gap:10px;margin:0;font-size:16px;font-weight:600;display:flex}.sources-modal-title svg{color:var(--accent)}.sources-modal-close{width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.sources-modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.sources-modal-add{border-bottom:1px solid var(--border);gap:8px;padding:16px 20px;display:flex}.sources-modal-input{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;flex:1;padding:10px 14px;font-size:14px;transition:all .15s}.sources-modal-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.sources-modal-input::placeholder{color:var(--text-muted)}.sources-modal-add-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:10px 16px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.sources-modal-add-btn:hover:not(:disabled){background:var(--accent-hover)}.sources-modal-add-btn:disabled{opacity:.5;cursor:not-allowed}.sources-modal-error{color:#ff3b30;background:#ff3b301a;align-items:center;gap:8px;padding:10px 20px;font-size:13px;display:flex}.sources-modal-list{flex:1;min-height:200px;max-height:300px;padding:8px 0;overflow-y:auto}.sources-modal-loading,.sources-modal-empty{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:40px 20px;font-size:14px;display:flex}.sources-modal-item{justify-content:space-between;align-items:center;padding:10px 20px;transition:background .15s;display:flex}.sources-modal-item:hover{background:var(--bg-hover)}.sources-modal-item-name{color:var(--text-primary);font-size:14px}.sources-modal-item-delete{width:28px;height:28px;color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.sources-modal-item:hover .sources-modal-item-delete{opacity:1}.sources-modal-item-delete:hover{color:#ff3b30;background:#ff3b301a}.sources-modal-item-delete:disabled{opacity:.5;cursor:not-allowed}.sources-modal-footer{border-top:1px solid var(--border);background:var(--bg-tertiary);justify-content:center;align-items:center;padding:12px 20px;display:flex}.sources-modal-count{color:var(--text-muted);font-size:12px}.sources-modal-spinner{animation:.8s linear infinite spinner}.batch-modal-source{align-items:center;gap:8px;margin-left:auto;margin-right:12px;display:flex}.batch-modal-source-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.batch-modal-source-select{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;border-radius:6px;padding:6px 28px 6px 10px;font-size:13px;transition:all .15s}.batch-modal-source-select:hover{border-color:var(--border-strong)}.batch-modal-source-select:focus{border-color:var(--accent);outline:none}.batch-modal-source-select:disabled{opacity:.6;cursor:not-allowed}.batch-modal-source-spinner{flex-shrink:0}.scrapper-history-item.selected{background:var(--primary-muted);border-color:var(--primary)}.text-editor-container{background:var(--bg-primary);flex-direction:column;height:100vh;display:flex}.text-editor-header{background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.text-editor-header-left{align-items:center;gap:16px;display:flex}.text-editor-back-btn{border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;align-items:center;gap:6px;padding:6px 12px;font-size:13px;text-decoration:none;display:flex}.text-editor-back-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.text-editor-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:400px;font-size:14px;font-weight:600;overflow:hidden}.text-editor-meta{color:var(--text-muted);gap:16px;font-size:12px;display:flex}.text-editor-header-right{align-items:center;gap:12px;display:flex}.text-editor-actions{align-items:center;gap:8px;margin-left:8px;display:flex}.text-editor-divider{background:var(--border-strong);width:1px;height:24px;margin:0 8px}.text-editor-action-btn{border-radius:var(--radius-md);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;display:flex}.text-editor-action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.text-editor-action-btn.active{background:var(--bg-tertiary);border-color:var(--border-strong)}.text-editor-action-btn.reviewed:hover,.text-editor-action-btn.reviewed.active{color:var(--success);background:var(--success-muted)}.text-editor-action-btn.reviewed.active{border-color:#22c55e4d}.text-editor-action-btn.flagged:hover,.text-editor-action-btn.flagged.active{color:var(--warning);background:var(--warning-muted)}.text-editor-action-btn.flagged.active{border-color:#f59e0b4d}.text-editor-action-btn.rejected:hover,.text-editor-action-btn.rejected.active{color:var(--danger);background:var(--danger-muted)}.text-editor-action-btn.rejected.active{border-color:#ef44444d}.text-editor-nav-btn{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.text-editor-nav-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.text-editor-nav-btn:disabled{opacity:.4;cursor:not-allowed}.text-editor-save-btn{background:var(--success);border-radius:var(--radius-md);color:#fff;cursor:pointer;transition:all var(--transition-fast);border:none;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;display:flex}.text-editor-save-btn:hover:not(:disabled){background:#16a34a}.text-editor-save-btn:disabled{opacity:.6;cursor:not-allowed}.text-editor-toolbar{background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;padding:8px 24px;display:flex}.text-editor-toolbar-group{border-right:1px solid var(--border);align-items:center;gap:4px;padding-right:8px;display:flex}.text-editor-toolbar-group:last-child{border-right:none}.text-editor-tool-btn{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;gap:4px;padding:6px 10px;font-size:12px;display:flex}.text-editor-tool-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.text-editor-tool-btn.active{background:var(--primary-muted);border-color:var(--primary);color:var(--primary)}.text-editor-main{flex:1;display:flex;overflow:hidden}.text-editor-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);flex-shrink:0;width:280px;overflow-y:auto}.text-editor-sidebar-header{border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);justify-content:space-between;align-items:center;padding:12px 16px;font-size:11px;font-weight:600;display:flex}.text-editor-sidebar-link{color:var(--primary);text-transform:none;letter-spacing:0;transition:opacity var(--transition-fast);align-items:center;gap:4px;font-weight:500;text-decoration:none;display:flex}.text-editor-sidebar-link:hover{opacity:.8}.text-editor-sidebar-actions{align-items:center;gap:8px;display:flex}.text-editor-sidebar-btn{border:1px solid var(--border);border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex}.text-editor-sidebar-btn:hover{background:var(--bg-hover);color:var(--primary);border-color:var(--primary)}.text-editor-sidebar-btn:disabled{opacity:.5;cursor:not-allowed}.text-editor-sidebar-content{color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;padding:8px;font-size:12px;line-height:1.5}.text-editor-paper-wrapper{background:var(--bg-primary);flex:1;justify-content:center;padding:32px;display:flex;overflow-y:auto}.text-editor-paper{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:800px;min-height:1000px;font-family:var(--font-ethiopic);color:var(--text-primary);padding:8px;font-size:18px;line-height:1.8;box-shadow:0 4px 24px #0003}.text-editor-textarea{width:100%;min-height:100%;font-family:var(--font-ethiopic);color:var(--text-primary);resize:none;background:0 0;border:none;outline:none;padding:48px 64px;font-size:18px;line-height:1.8}.text-editor-textarea::placeholder{color:var(--text-disabled)}.text-editor-find-bar{background:var(--bg-tertiary);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 24px;display:flex}.text-editor-find-input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);flex:1;padding:8px 12px;font-size:13px}.text-editor-find-input:focus{border-color:var(--primary);outline:none}.text-editor-find-btn{background:var(--primary);border-radius:var(--radius-md);color:#fff;cursor:pointer;transition:all var(--transition-fast);border:none;padding:8px 16px;font-size:13px}.text-editor-find-btn:hover{background:var(--primary-hover)}.text-editor-find-close{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.text-editor-find-close:hover{background:var(--bg-hover);color:var(--text-primary)}.landing-container{background:var(--bg-primary);min-height:100vh;padding:var(--space-6);justify-content:center;align-items:center;display:flex}.landing-content{text-align:center;width:100%;max-width:900px;animation:.6s ease-out fadeInUp}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.landing-subtitle{color:var(--text-muted);margin-bottom:var(--space-8);text-align:center;letter-spacing:.02em;font-size:.95rem;font-weight:300}.landing-grid{justify-content:center;gap:var(--space-6);flex-wrap:wrap;display:flex}@media (max-width:768px){.landing-grid{align-items:center;gap:var(--space-4);flex-direction:column}}.landing-card{width:260px;padding:var(--space-8)var(--space-6);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;flex-direction:column;align-items:center;text-decoration:none;transition:all .25s;display:flex}.landing-card:hover{border-color:var(--border-strong);transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.card-icon{margin-bottom:var(--space-4);font-size:3.5rem;transition:transform .25s}.landing-card:hover .card-icon{transform:scale(1.15)}.card-title{color:var(--text-primary);margin-bottom:var(--space-2);font-size:1.25rem;font-weight:600}.card-description{color:var(--text-secondary);margin:0;font-size:.875rem;line-height:1.4}.wordings-container{padding:var(--space-4)var(--space-6)var(--space-6);gap:var(--space-4);flex-direction:column;display:flex}.wordings-intro{justify-content:space-between;align-items:flex-start;gap:var(--space-4);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);display:flex}.wordings-title{margin-bottom:var(--space-2);font-size:18px;font-weight:600}.wordings-subtitle{color:var(--text-secondary);max-width:520px;font-size:13px}.wordings-status{align-items:flex-end;gap:var(--space-2);flex-direction:column;display:flex}.wordings-status-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:11px}.wordings-status-value{font-family:var(--font-ethiopic);font-size:16px;font-weight:600}.wordings-group-row{gap:var(--space-2);flex-wrap:wrap;display:flex}.wordings-group-btn{border-radius:var(--radius-md);border:1px solid var(--border-strong);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;align-items:flex-start;gap:2px;padding:10px 12px;display:flex}.wordings-group-btn:hover{border-color:var(--text-muted);color:var(--text-primary)}.wordings-group-btn.active{border-color:var(--primary);background:var(--primary-muted);color:var(--primary)}.wordings-group-label{font-family:var(--font-ethiopic);font-size:14px}.wordings-group-hint{color:inherit;text-transform:uppercase;letter-spacing:.05em;font-size:11px}.wordings-controls{gap:var(--space-4);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.wordings-control label{color:var(--text-secondary);margin-bottom:var(--space-2);font-size:12px;font-weight:500;display:block}.wordings-number{padding:var(--space-2)var(--space-3);font-size:13px}.wordings-toggle{flex-direction:column;justify-content:flex-end;display:flex}.wordings-toggle-btn{border-radius:var(--radius-full);background:var(--bg-tertiary);border:1px solid var(--border-strong);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);align-self:flex-start;padding:6px 12px}.wordings-toggle-btn.active{background:var(--success-muted);color:var(--success);border-color:#22c55e59}.wordings-summary{gap:var(--space-3);color:var(--text-secondary);flex-wrap:wrap;font-size:12px;display:flex}.wordings-empty{text-align:center;padding:var(--space-6);border:1px dashed var(--border);border-radius:var(--radius-lg);color:var(--text-muted);font-size:13px}.wordings-empty-hint{margin-top:var(--space-2);color:var(--text-secondary);font-size:12px}.wordings-results{gap:var(--space-4);flex-direction:column;display:flex}.wording-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);gap:var(--space-3);flex-direction:column;display:flex}.wording-card-header{justify-content:space-between;align-items:flex-start;gap:var(--space-4);display:flex}.wording-title{font-family:var(--font-ethiopic);font-size:18px;font-weight:600}.wording-meta{color:var(--text-muted);font-size:12px}.wording-header-actions{align-items:center;gap:var(--space-2);display:flex}.btn-compact{padding:6px 12px;font-size:12px}.wording-variants{gap:var(--space-2);flex-wrap:wrap;display:flex}.wording-variant-btn{border-radius:var(--radius-full);border:1px solid var(--border-strong);background:var(--bg-tertiary);color:var(--text-primary);font-family:var(--font-ethiopic);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:6px;padding:6px 10px;display:inline-flex}.wording-variant-btn:hover{border-color:var(--text-muted)}.wording-variant-btn.active{background:var(--primary-muted);border-color:var(--primary);color:var(--primary)}.wording-variant-count{background:var(--bg-elevated);border-radius:var(--radius-full);color:var(--text-secondary);padding:2px 6px;font-size:11px}.wording-actions{align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.wording-canonical{align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:12px;display:flex}.wording-canonical-value{font-family:var(--font-ethiopic);color:var(--text-primary);font-weight:600}.wording-custom{align-items:center;gap:var(--space-2);display:flex}.wording-custom-input{width:180px;font-size:13px}.wordings-rule-status-row{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.wordings-rule-status-label{color:var(--text-secondary);margin-right:var(--space-2);font-size:12px;font-weight:500}.wordings-rule-status-btn{border-radius:var(--radius-full);border:1px solid var(--border-strong);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:6px 12px;font-size:12px}.wordings-rule-status-btn:hover{border-color:var(--text-muted);color:var(--text-primary)}.wordings-rule-status-btn.active{font-weight:500}.wordings-rule-status-btn.active.warning{color:var(--warning);background:#eab30826;border-color:#eab30866}.wordings-rule-status-btn.active.success{background:var(--success-muted);color:var(--success);border-color:#22c55e59}.wordings-rule-status-btn.active.muted{background:var(--bg-elevated);border-color:var(--border-strong);color:var(--text-muted)}.wordings-rule-status-btn.active.default{background:var(--primary-muted);border-color:var(--primary);color:var(--primary)}.wordings-cached-badge{border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--text-muted);margin-top:var(--space-2);padding:2px 8px;font-size:11px}.wording-title-row{align-items:center;gap:var(--space-2);display:flex}.wording-status-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full);padding:2px 8px;font-size:10px;font-weight:500}.wording-status-badge.pending{color:var(--warning);background:#eab30826}.wording-status-badge.approved{background:var(--success-muted);color:var(--success)}.wording-status-badge.skipped{background:var(--bg-elevated);color:var(--text-muted)}.wording-card.wording-card-approved{background:#22c55e08;border-color:#22c55e40}.wording-card.wording-card-skipped{opacity:.7}.btn-success{background:var(--success);color:#fff;border:none}.btn-success:hover:not(:disabled){background:#16a34a}.btn-muted{background:var(--bg-tertiary);color:var(--text-muted);border:1px solid var(--border-strong)}.btn-muted:hover:not(:disabled){background:var(--bg-elevated);color:var(--text-secondary)}.variant-page{max-width:900px}.variant-page .header-subtitle{color:var(--text-muted);margin-left:var(--space-2);font-size:13px;font-weight:400}.cache-indicator{border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-muted);border:1px solid var(--border);padding:4px 10px;font-size:11px}.btn-icon{border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;padding:0;display:flex}.btn-icon:hover:not(:disabled){background:var(--bg-elevated);color:var(--text-primary)}.variant-stats-bar{gap:var(--space-6);padding:var(--space-4)var(--space-5);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--space-4);display:flex}.variant-stat{flex-direction:column;gap:2px;display:flex}.variant-stat-value{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:20px;font-weight:600}.variant-stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:11px}.variant-tabs{gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.variant-tab{padding:var(--space-3)var(--space-4);border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;align-items:center;gap:2px;min-width:100px;display:flex}.variant-tab:hover{border-color:var(--border-strong)}.variant-tab.active{background:var(--primary-muted);border-color:var(--primary)}.variant-tab-label{color:var(--text-secondary);font-size:12px;font-weight:500}.variant-tab.active .variant-tab-label{color:var(--primary)}.variant-tab-letters{font-family:var(--font-ethiopic);color:var(--text-primary);font-size:14px}.variant-toolbar{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);flex-wrap:wrap;display:flex}.variant-status-tabs{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-full);gap:2px;padding:3px;display:flex}.variant-status-tab{border-radius:var(--radius-full);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;padding:6px 14px;font-size:12px;font-weight:500}.variant-status-tab:hover{color:var(--text-primary)}.variant-status-tab.active{background:var(--bg-primary);color:var(--text-primary);box-shadow:0 1px 3px #0000001a}.variant-status-tab.active.status-pending{color:var(--warning);background:#eab30826}.variant-status-tab.active.status-approved{background:var(--success-muted);color:var(--success)}.variant-status-tab.active.status-skipped{background:var(--bg-tertiary);color:var(--text-muted)}.btn-ghost{color:var(--text-secondary);cursor:pointer;align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-3);border-radius:var(--radius-md);transition:all var(--transition-fast);background:0 0;border:none;font-size:13px;display:flex}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.variant-filters{gap:var(--space-3);padding:var(--space-4);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));display:grid}.variant-filter{gap:var(--space-1);flex-direction:column;display:flex}.variant-filter label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:11px;font-weight:500}.variant-filter .select,.variant-filter .form-input{padding:var(--space-2);font-size:13px}.variant-filter-toggle{flex-direction:row;justify-content:space-between;align-items:center}.toggle-btn{border-radius:var(--radius-full);background:var(--bg-tertiary);border:1px solid var(--border-strong);cursor:pointer;width:40px;height:22px;transition:all var(--transition-fast);position:relative}.toggle-btn.active{background:var(--primary);border-color:var(--primary)}.toggle-knob{width:16px;height:16px;transition:transform var(--transition-fast);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0003}.toggle-btn.active .toggle-knob{transform:translate(18px)}.variant-content{min-height:200px}.variant-empty{text-align:center;padding:var(--space-8);border:1px dashed var(--border);border-radius:var(--radius-lg)}.variant-empty-icon{margin-bottom:var(--space-3);font-size:48px}.variant-empty-title{color:var(--text-primary);margin-bottom:var(--space-1);font-size:16px;font-weight:500}.variant-empty-hint{color:var(--text-muted);font-size:13px}.variant-list{gap:var(--space-4);flex-direction:column;display:flex}.variant-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-5);gap:var(--space-4);transition:all var(--transition-fast);flex-direction:column;display:flex}.variant-card:hover{border-color:var(--border-strong)}.variant-card.status-approved{background:#22c55e05;border-color:#22c55e4d}.variant-card.status-skipped{opacity:.7}.variant-card-header{justify-content:space-between;align-items:center;display:flex}.variant-card-info{align-items:center;gap:var(--space-3);display:flex}.variant-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full);padding:3px 8px;font-size:10px;font-weight:600}.variant-badge.pending{color:var(--warning);background:#eab30826}.variant-badge.approved{background:var(--success-muted);color:var(--success)}.variant-badge.skipped{background:var(--bg-tertiary);color:var(--text-muted)}.variant-meta{color:var(--text-muted);font-size:12px}.variant-link{border-radius:var(--radius-md);width:28px;height:28px;color:var(--text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.variant-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.variant-question{padding-bottom:var(--space-2);border-bottom:1px solid var(--border);justify-content:space-between;align-items:baseline;display:flex}.variant-question-label{color:var(--text-primary);font-size:15px;font-weight:500}.variant-root{color:var(--text-muted);font-size:12px;font-family:var(--font-ethiopic)}.variant-options{gap:var(--space-2);flex-direction:column;display:flex}.variant-option{align-items:center;gap:var(--space-3);padding:var(--space-3)var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-primary);cursor:pointer;transition:all var(--transition-fast);display:flex}.variant-option:hover{border-color:var(--border-strong);background:var(--bg-secondary)}.variant-option.selected{border-color:var(--primary);background:var(--primary-muted)}.variant-option-radio{border:2px solid var(--border-strong);width:18px;height:18px;transition:all var(--transition-fast);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.variant-option.selected .variant-option-radio{border-color:var(--primary);color:var(--primary)}.variant-option-word{font-family:var(--font-ethiopic);color:var(--text-primary);flex:1;font-size:18px;font-weight:500}.variant-option-count{color:var(--text-muted);background:var(--bg-tertiary);border-radius:var(--radius-full);font-variant-numeric:tabular-nums;padding:2px 8px;font-size:12px}.variant-option-custom{border-style:dashed}.variant-option-custom .variant-option-word{color:var(--text-muted);font-family:inherit;font-size:13px}.variant-custom-input{align-items:center;gap:var(--space-2);padding:var(--space-3);border:1px dashed var(--border-strong);border-radius:var(--radius-lg);background:var(--bg-primary);display:flex}.variant-custom-input .form-input{font-family:var(--font-ethiopic);flex:1;min-width:0}.btn-sm{padding:var(--space-2)var(--space-3);font-size:12px}.btn-outline{border:1px solid var(--border-strong);color:var(--text-primary);background:0 0}.btn-outline:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--text-muted)}.variant-actions{align-items:center;gap:var(--space-3);padding-top:var(--space-4);margin-top:var(--space-2);border-top:1px solid var(--border);flex-wrap:wrap;display:flex}.variant-actions .btn{flex-shrink:0}.variant-actions .btn-primary{font-weight:500}@media (max-width:640px){.variant-stats-bar{justify-content:space-around;gap:var(--space-3);padding:var(--space-3);flex-direction:row}.variant-stat{text-align:center;align-items:center}.variant-tabs{padding-bottom:var(--space-2);-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.variant-tab{min-width:80px;padding:var(--space-2)var(--space-3);flex-shrink:0}.variant-toolbar{align-items:stretch;gap:var(--space-2);flex-direction:column}.variant-status-tabs{justify-content:center;width:100%}.variant-status-tab{text-align:center;flex:1;padding:8px 10px}.variant-filters{grid-template-columns:1fr 1fr}.variant-card{padding:var(--space-4)}.variant-option{padding:var(--space-3)}.variant-option-word{font-size:16px}.variant-actions{gap:var(--space-2);flex-direction:column}.variant-actions .btn{justify-content:center;width:100%}}.variant-page-v2{padding-bottom:80px}.variant-header-v2{padding:var(--space-4)0;margin-bottom:var(--space-4);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.variant-header-left{align-items:center;gap:var(--space-3);display:flex}.variant-back-btn{border-radius:var(--radius-md);width:36px;height:36px;color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.variant-back-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.variant-title-group h1{color:var(--text-primary);margin:0;font-size:20px;font-weight:600;line-height:1.2}.variant-subtitle{color:var(--text-muted);margin-top:2px;font-size:13px}.variant-header-right{align-items:center;gap:var(--space-2);display:flex}.variant-cache-badge{border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-muted);align-items:center;gap:4px;padding:4px 10px;font-size:11px;display:flex}.variant-update-all-btn{border-radius:var(--radius-md);background:var(--success);color:#fff;cursor:pointer;transition:all var(--transition-fast);border:none;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;display:flex}.variant-update-all-btn:hover:not(:disabled){background:var(--success-hover,#16a34a);transform:translateY(-1px)}.variant-update-all-btn:disabled{opacity:.5;cursor:not-allowed}.variant-update-all-btn svg{flex-shrink:0}.bulk-progress-badge{border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary);align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;display:flex}.bulk-progress-badge .spinner-tiny{width:12px;height:12px}.variant-icon-btn{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-secondary);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.variant-icon-btn:hover{border-color:var(--border-strong);color:var(--text-primary)}.variant-icon-btn.active{background:var(--primary-muted);border-color:var(--primary);color:var(--primary)}.variant-icon-btn:disabled{opacity:.5;cursor:not-allowed}.variant-nav-row{justify-content:space-between;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.variant-letter-tabs{gap:var(--space-1);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border);padding:4px;display:flex}.variant-letter-tab{padding:var(--space-2)var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;min-width:70px;display:flex}.variant-letter-tab:hover{background:var(--bg-tertiary)}.variant-letter-tab.active{background:var(--bg-primary);box-shadow:0 1px 3px #0000001a}.variant-letter-chars{font-family:var(--font-ethiopic);color:var(--text-primary);font-size:15px;font-weight:500;line-height:1}.variant-letter-tab.active .variant-letter-chars{color:var(--primary)}.variant-letter-label{text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);font-size:10px}.variant-status-pills{gap:var(--space-2);display:flex}.variant-status-pill{border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;display:flex}.variant-status-pill:hover{border-color:var(--border-strong);color:var(--text-primary)}.variant-status-pill .status-icon{font-size:12px}.variant-status-pill.active{border-color:#0000}.variant-status-pill.active.status-pending{color:var(--warning);background:#eab30826}.variant-status-pill.active.status-approved{background:var(--success-muted);color:var(--success)}.variant-status-pill.active.status-skipped{background:var(--bg-tertiary);color:var(--text-muted)}.variant-status-pill.active.status-all{background:var(--primary-muted);color:var(--primary)}.variant-status-pill .status-count{color:var(--warning);border-radius:var(--radius-full);background:#eab30833;padding:1px 6px;font-size:10px;font-weight:600}.variant-progress-bar{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-3)var(--space-4);margin-bottom:var(--space-4)}.variant-progress-info{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.progress-text{color:var(--text-secondary);font-size:13px}.progress-text strong{color:var(--warning)}.progress-percent{color:var(--text-muted);font-size:12px}.variant-progress-track{background:var(--bg-tertiary);border-radius:var(--radius-full);height:4px;overflow:hidden}.variant-progress-fill{background:linear-gradient(90deg,var(--warning),#f59e0b);border-radius:var(--radius-full);height:100%;transition:width .3s}.variant-filters-v2{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-4)}.variant-filters-grid{gap:var(--space-3);margin-bottom:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(150px,1fr));display:grid}.variant-filter-item{flex-direction:column;gap:4px;display:flex}.variant-filter-item label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:11px;font-weight:500}.variant-filter-item .select,.variant-filter-item .form-input{padding:var(--space-2);font-size:13px}.variant-filter-toggle-row{padding-top:var(--space-3);border-top:1px solid var(--border)}.toggle-label{color:var(--text-secondary);cursor:pointer;justify-content:space-between;align-items:center;font-size:13px;display:flex}.toggle-switch{border-radius:var(--radius-full);background:var(--bg-tertiary);border:1px solid var(--border-strong);cursor:pointer;width:40px;height:22px;transition:all var(--transition-fast);position:relative}.toggle-switch .toggle-knob{background:var(--text-muted);width:16px;height:16px;transition:all var(--transition-fast);border-radius:50%;position:absolute;top:2px;left:2px}.toggle-switch.active{background:var(--primary);border-color:var(--primary)}.toggle-switch.active .toggle-knob{background:#fff;left:20px}.variant-error-banner{align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-4);border-radius:var(--radius-lg);color:var(--error);margin-bottom:var(--space-4);background:#ef44441a;border:1px solid #ef44444d;font-size:13px;display:flex}.variant-content-v2{min-height:300px}.variant-loading{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-8);color:var(--text-muted);flex-direction:column;display:flex}.variant-empty-state{padding:var(--space-8);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.variant-empty-state .empty-icon{color:var(--text-muted);margin-bottom:var(--space-3);opacity:.5}.variant-empty-state .empty-icon svg{stroke:var(--success)}.variant-empty-state h3{color:var(--text-primary);margin:0 0 var(--space-2);font-size:18px;font-weight:600}.variant-empty-state p{color:var(--text-muted);margin:0;font-size:14px}.variant-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(420px,1fr));display:grid}.variant-card-v2{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-4);gap:var(--space-3);transition:all var(--transition-fast);flex-direction:column;display:flex}.variant-card-v2:hover{border-color:var(--border-strong);box-shadow:0 4px 12px #00000014}.variant-card-v2.status-approved{background:linear-gradient(135deg,#22c55e05,#0000);border-color:#22c55e4d}.variant-card-v2.status-skipped{opacity:.7}.variant-card-v2 .card-header{justify-content:space-between;align-items:center;display:flex}.variant-card-v2 .card-meta{color:var(--text-muted);align-items:center;gap:6px;font-size:12px;display:flex}.status-dot{background:var(--text-muted);border-radius:50%;width:8px;height:8px}.status-dot.pending{background:var(--warning)}.status-dot.approved{background:var(--success)}.status-dot.skipped{background:var(--text-muted)}.variant-card-v2 .occurrence-count{color:var(--text-secondary);font-weight:600}.variant-card-v2 .meta-sep{opacity:.5}.variant-card-v2 .card-actions-top{align-items:center;gap:var(--space-2);display:flex}.variant-card-v2 .root-word{font-family:var(--font-ethiopic);color:var(--text-muted);background:var(--bg-tertiary);border-radius:var(--radius-sm);padding:2px 8px;font-size:13px}.variant-card-v2 .card-link{border-radius:var(--radius-md);width:28px;height:28px;color:var(--text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.variant-card-v2 .card-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.variant-selection{gap:var(--space-2);flex-direction:column;display:flex}.variant-selection.vertical{flex-direction:column}.variant-selection.horizontal{gap:var(--space-2);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));display:grid}.variant-choice{padding:var(--space-2)var(--space-3);border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-primary);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;align-items:center;gap:4px;min-width:0;display:flex}.variant-choice:hover{border-color:var(--border-strong);background:var(--bg-secondary)}.variant-choice.selected{background:#6366f114;border-color:#6366f166}.variant-choice .choice-radio{border:2px solid var(--border-strong);width:14px;height:14px;transition:all var(--transition-fast);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:absolute;top:6px;left:6px}.variant-choice{position:relative}.variant-choice.selected .choice-radio{border-color:#818cf8}.variant-choice .radio-dot{background:#818cf8;border-radius:50%;width:6px;height:6px}.variant-choice .choice-word{font-family:var(--font-ethiopic);color:var(--text-primary);text-align:center;word-break:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;font-size:clamp(16px,4vw,22px);font-weight:500;line-height:1.3}.variant-selection.horizontal .choice-word{font-size:clamp(18px,5vw,24px)}.variant-choice .choice-stats{flex-direction:row;justify-content:center;align-items:center;gap:6px;display:flex}.variant-choice .choice-count{color:var(--text-secondary);font-variant-numeric:tabular-nums;background:var(--bg-tertiary);border-radius:var(--radius-sm);padding:1px 6px;font-size:11px;font-weight:600}.variant-choice .choice-percent{color:var(--text-muted);font-size:10px}.variant-choice.custom-choice{padding:var(--space-2);border-style:dashed;justify-content:center}.variant-choice.custom-choice .choice-word{color:var(--text-muted);text-align:center;font-family:inherit;font-size:12px}.variant-choice.custom-choice .choice-word.custom{font-family:inherit}.variant-choice.custom-choice .choice-radio{display:none}.custom-input-row{align-items:center;gap:var(--space-2);padding:var(--space-2);border:1px dashed var(--border-strong);border-radius:var(--radius-lg);background:var(--bg-primary);display:flex}.custom-input-row .form-input{font-family:var(--font-ethiopic);padding:var(--space-2);flex:1;min-width:0;font-size:16px}.btn-inline{padding:var(--space-2)var(--space-3);border-radius:var(--radius-md);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;font-size:12px;font-weight:500;display:flex}.btn-inline:hover{background:var(--bg-secondary);color:var(--text-primary)}.btn-inline.primary{background:var(--primary);color:#fff}.btn-inline.primary:hover{background:var(--primary-hover)}.card-action-bar{padding-top:var(--space-2);border-top:1px solid var(--border);align-items:center;gap:6px;display:flex}.action-btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;flex:1;justify-content:center;align-items:center;gap:4px;padding:5px 10px;font-size:11px;font-weight:500;display:flex}.action-btn svg{width:12px;height:12px}.action-btn.primary{color:#a5b4fc;background:#6366f126;border-color:#6366f14d}.action-btn.primary:hover:not(:disabled){color:#c7d2fe;background:#6366f140;border-color:#6366f180}.action-btn.secondary{color:var(--text-secondary);border:1px solid var(--border-strong);background:#ffffff0d}.action-btn.secondary:hover:not(:disabled){border-color:var(--text-muted);color:var(--text-primary);background:#ffffff1a}.action-btn.ghost{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.action-btn.ghost:hover:not(:disabled){color:var(--text-primary);border-color:var(--border-strong);background:#ffffff0d}.action-btn:disabled{opacity:.5;cursor:not-allowed}.variant-footer{justify-content:center;align-items:center;gap:var(--space-6);padding:var(--space-3)var(--space-4);background:var(--bg-secondary);border-top:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;display:flex;position:fixed;bottom:0;left:0;right:0}.footer-stat{align-items:center;gap:var(--space-2);display:flex}.footer-stat .stat-value{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:14px;font-weight:600}.footer-stat .stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-size:11px}.variant-toast{align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-4);border-radius:var(--radius-lg);z-index:1000;font-size:13px;font-weight:500;animation:.3s toastSlideUp;display:flex;position:fixed;bottom:80px;left:50%;transform:translate(-50%)}.variant-toast.success{background:var(--success);color:#fff}.variant-toast.error{background:var(--error);color:#fff}@keyframes toastSlideUp{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@media (max-width:900px){.variant-grid{grid-template-columns:1fr}}@media (max-width:768px){.variant-nav-row{flex-direction:column;align-items:stretch}.variant-letter-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.variant-status-pills{justify-content:center}.variant-status-pill .status-label{display:none}.variant-status-pill .status-icon{font-size:14px}.variant-header-v2{align-items:flex-start;gap:var(--space-3);flex-direction:column}.variant-header-right{justify-content:flex-end;width:100%}.variant-selection.horizontal{grid-template-columns:1fr}.card-action-bar{flex-wrap:wrap;justify-content:flex-start}}.variant-choice-wrapper{flex-direction:column;gap:4px;min-width:0;display:flex}.variant-choice-wrapper .variant-choice{flex:1;min-width:0}.variant-choice-wrapper .preview-btn{width:100%;height:24px;min-width:unset;align-self:stretch}.preview-btn{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-primary);width:28px;min-width:28px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.preview-btn:hover{border-color:var(--border-strong);background:var(--bg-secondary);color:var(--text-primary)}.preview-popup-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;padding:var(--space-4);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.preview-popup{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-xl);flex-direction:column;width:100%;max-width:600px;max-height:80vh;display:flex;box-shadow:0 20px 40px #0000004d}.preview-popup-header{padding:var(--space-4);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.preview-popup-header h3{align-items:center;gap:var(--space-3);margin:0;font-size:16px;font-weight:600;display:flex}.preview-word{font-family:var(--font-ethiopic);color:var(--text-primary);font-size:20px}.preview-count{color:var(--text-muted);background:var(--bg-tertiary);border-radius:var(--radius-full);padding:2px 8px;font-size:12px;font-weight:400}.preview-close-btn{border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.preview-close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.preview-popup-content{padding:var(--space-4);flex:1;min-height:200px;overflow-y:auto}.preview-loading{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-8);color:var(--text-muted);flex-direction:column;display:flex}.preview-empty{padding:var(--space-8);color:var(--text-muted);justify-content:center;align-items:center;font-size:14px;display:flex}.preview-samples-list{gap:var(--space-2);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.preview-sample-item{justify-content:space-between;align-items:flex-start;gap:var(--space-3);padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border);display:flex}.sample-sentence{font-family:var(--font-ethiopic);color:var(--text-primary);flex:1;font-size:14px;line-height:1.5}.sample-sentence .highlight{color:var(--warning);background:#eab3084d;border-radius:2px;padding:0 2px}.sample-source{color:var(--text-muted);background:var(--bg-tertiary);border-radius:var(--radius-sm);white-space:nowrap;flex-shrink:0;padding:2px 6px;font-size:10px}.preview-popup-footer{padding:var(--space-3)var(--space-4);border-top:1px solid var(--border);color:var(--text-muted);justify-content:space-between;align-items:center;font-size:12px;display:flex}.preview-view-all{color:var(--primary);font-weight:500;text-decoration:none}.preview-view-all:hover{text-decoration:underline}@media (max-width:480px){.variant-page-v2{padding-bottom:100px}.variant-card-v2{padding:var(--space-3)}.variant-choice .choice-word{font-size:16px}.variant-filters-grid{grid-template-columns:1fr 1fr}.variant-footer{gap:var(--space-4)}.footer-stat .stat-label{display:none}}.recorder-container{max-width:900px;padding:var(--space-6);min-height:100vh;margin:0 auto}.recorder-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.recorder-back-link{align-items:center;gap:var(--space-2);color:var(--text-secondary);padding:var(--space-2)var(--space-3);border-radius:var(--radius-md);transition:all var(--transition-fast);font-size:14px;font-weight:500;text-decoration:none;display:flex}.recorder-back-link:hover{color:var(--text-primary);background:var(--bg-tertiary)}.recorder-title{color:var(--text-primary);text-align:center;flex:1;font-size:20px;font-weight:600}.recorder-history-btn{align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:13px;display:flex}.recorder-history-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.recorder-stats{color:var(--text-secondary);font-size:13px}.recorder-toast{top:var(--space-6);right:var(--space-6);padding:var(--space-3)var(--space-5);border-radius:var(--radius-md);z-index:1000;font-size:14px;font-weight:500;animation:.3s slideIn;position:fixed}.recorder-toast-success{background:var(--success);color:#fff}.recorder-toast-error{background:var(--danger);color:#fff}.recorder-input-mode{gap:var(--space-6);flex-direction:column;display:flex}.recorder-url-section{gap:var(--space-2);flex-direction:column;display:flex}.recorder-label{color:var(--text-secondary);font-size:13px;font-weight:500}.recorder-extracted-title{color:var(--primary)}.recorder-url-row{gap:var(--space-2);display:flex}.recorder-url-input{padding:var(--space-3)var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);flex:1;font-size:14px}.recorder-url-input:focus{border-color:var(--primary);outline:none}.recorder-extract-btn{padding:var(--space-3)var(--space-5);background:var(--primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;font-size:14px;font-weight:500}.recorder-extract-btn:hover:not(:disabled){background:var(--primary-hover)}.recorder-extract-btn:disabled{opacity:.5;cursor:not-allowed}.recorder-dropzone{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-8);border:2px dashed var(--border-strong);border-radius:var(--radius-lg);background:var(--bg-tertiary);color:var(--text-muted);transition:all var(--transition-fast);cursor:pointer;flex-direction:column;display:flex;position:relative}.recorder-dropzone:hover,.recorder-dropzone-active{border-color:var(--primary);background:var(--primary-muted);color:var(--primary)}.recorder-file-input{opacity:0;cursor:pointer;position:absolute;inset:0}.recorder-text-section{gap:var(--space-2);flex-direction:column;display:flex}.recorder-textarea{width:100%;padding:var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-ethiopic);resize:vertical;font-size:16px;line-height:1.8}.recorder-proceed-btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-4)var(--space-6);background:var(--success);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);margin-top:var(--space-4);border:none;font-size:16px;font-weight:600;display:flex}.recorder-proceed-btn:hover:not(:disabled){background:#16a34a;transform:translateY(-1px)}.recorder-proceed-btn:disabled{opacity:.5;cursor:not-allowed}.recorder-recording-mode{gap:var(--space-4);flex-direction:column;display:flex}.recorder-segment-counter{text-align:center;color:var(--text-secondary);font-size:14px;font-weight:500}.recorder-segments-list{gap:var(--space-2);max-height:400px;padding:var(--space-2);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border);flex-direction:column;display:flex;overflow-y:auto}.recorder-segment{align-items:flex-start;gap:var(--space-3);padding:var(--space-3)var(--space-4);background:var(--bg-tertiary);border-radius:var(--radius-md);transition:all var(--transition-fast);border:2px solid #0000;display:flex}.recorder-segment-active{background:var(--primary-muted);border-color:var(--primary)}.recorder-segment-number{background:var(--bg-hover);border-radius:var(--radius-full);width:24px;height:24px;color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.recorder-segment-text{font-family:var(--font-ethiopic);color:var(--text-primary);flex:1;font-size:18px;line-height:1.6}.recorder-controls{align-items:center;gap:var(--space-4);padding:var(--space-6);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border);flex-direction:column;display:flex}.recorder-timer{font-variant-numeric:tabular-nums;color:var(--text-primary);letter-spacing:-.02em;font-size:48px;font-weight:300}.recorder-record-btn{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-4)var(--space-8);background:var(--danger);color:#fff;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);border:none;font-size:18px;font-weight:600;display:flex;box-shadow:0 4px 20px #ef444466}.recorder-record-btn:hover{transform:scale(1.02);box-shadow:0 6px 24px #ef444480}.recorder-record-btn-active{background:var(--bg-elevated);color:var(--text-primary);box-shadow:0 2px 10px #0003}.recorder-record-btn-active:hover{background:var(--bg-hover);box-shadow:0 2px 12px #0000004d}.recorder-record-icon{border-radius:var(--radius-full);background:#fff;width:20px;height:20px}.recorder-record-btn-active .recorder-record-icon{background:var(--danger);animation:1s ease-in-out infinite pulse}.recorder-instructions{text-align:center;color:var(--text-muted);font-size:14px}.recorder-instructions kbd{background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-family:var(--font-ui);padding:2px 8px;font-size:12px;font-weight:600;display:inline-block}.recorder-back-btn{padding:var(--space-2)var(--space-4);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;align-self:flex-start;font-size:14px}.recorder-back-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.recorder-processing-mode{justify-content:center;align-items:center;gap:var(--space-4);text-align:center;flex-direction:column;min-height:400px;display:flex}.recorder-processing-spinner{border:3px solid var(--border-strong);border-top-color:var(--primary);border-radius:var(--radius-full);width:48px;height:48px;animation:1s linear infinite spin}.recorder-processing-mode h2{color:var(--text-primary);font-size:20px;font-weight:600}.recorder-processing-mode p{color:var(--text-secondary);font-size:14px}.recorder-processing-stats{color:var(--text-muted);font-size:12px}.recorder-history-sidebar{background:var(--bg-secondary);border-left:1px solid var(--border);width:320px;height:100vh;padding:var(--space-4);z-index:100;animation:.2s slideInRight;position:fixed;top:0;right:0;overflow-y:auto}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.recorder-history-sidebar h3{color:var(--text-primary);margin-bottom:var(--space-4);font-size:14px;font-weight:600}.recorder-history-empty{color:var(--text-muted);font-size:13px}.recorder-history-list{gap:var(--space-2);flex-direction:column;list-style:none;display:flex}.recorder-history-item{padding:var(--space-3);background:var(--bg-tertiary);border-radius:var(--radius-md);transition:all var(--transition-fast);justify-content:space-between;align-items:center;text-decoration:none;display:flex}.recorder-history-item:hover{background:var(--bg-hover)}.recorder-history-title{color:var(--text-primary);font-size:13px;font-weight:500}.recorder-history-status{color:var(--text-muted);text-transform:capitalize;font-size:11px}.recorder-review-controls{justify-content:space-between;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4);padding:var(--space-4);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border);display:flex}.recorder-selection-controls{align-items:center;gap:var(--space-3);display:flex}.recorder-icon-btn{width:30px;height:30px;color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast);background:0 0;border:none;border-radius:999px;justify-content:center;align-items:center;padding:0;display:inline-flex}.recorder-icon-btn:hover:not(:disabled){color:var(--text-primary);background:var(--bg-hover)}.recorder-btn-secondary{padding:var(--space-2)var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:13px}.recorder-review-list{gap:var(--space-2);flex-direction:column;display:flex}.recorder-review-item{align-items:flex-start;gap:var(--space-3);padding:var(--space-3)var(--space-4);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border);transition:all var(--transition-fast);display:flex}.recorder-review-item-right{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.recorder-match-indicator{border-radius:var(--radius-full);flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.recorder-match-indicator.uploaded{color:var(--primary);background:var(--primary-muted)}.recorder-match-indicator.matched{color:var(--success);background:var(--success-muted)}.recorder-match-indicator.unmatched{color:var(--warning);background:var(--warning-muted)}.recorder-match-indicator.pending{color:var(--text-muted);background:var(--bg-tertiary)}.recorder-play-btn{background:var(--bg-tertiary);border-radius:var(--radius-full);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.recorder-play-btn:hover,.recorder-play-btn-active{background:var(--primary);color:#fff}.recorder-review-content{gap:var(--space-1);flex-direction:column;flex:1;min-width:0;display:flex}.recorder-review-original{font-family:var(--font-ethiopic);color:var(--text-primary);font-size:21px;line-height:1.5}.recorder-review-textarea{border-radius:var(--radius);width:100%;padding:var(--space-2);margin:calc(-1*var(--space-2));resize:none;transition:all var(--transition-fast);background:0 0;border:1px solid #0000}.recorder-review-textarea:hover{background:var(--bg-tertiary);border-color:var(--border)}.recorder-review-textarea:focus{background:var(--bg-primary);border-color:var(--primary);outline:none}.recorder-review-textarea:disabled{opacity:.7;cursor:not-allowed}.recorder-review-original strong,.recorder-review-asr strong{color:var(--text-muted);font-weight:500;font-family:var(--font-ui);margin-right:var(--space-2);font-size:11px}.recorder-review-asr{font-family:var(--font-ethiopic);padding:var(--space-2);border-radius:var(--radius-sm);font-size:13px;line-height:1.4}.recorder-review-asr-matched{background:var(--success-muted);color:var(--success)}.recorder-review-asr-unmatched{background:var(--warning-muted);color:var(--warning)}.recorder-review-badges{gap:var(--space-2);flex-shrink:0;display:flex}.recorder-btn-primary{padding:var(--space-3)var(--space-6);background:var(--primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.recorder-btn-primary:hover{background:var(--primary-hover)}.recorder-error{text-align:center;padding:var(--space-8);color:var(--danger);font-size:14px}.recorder-manual-text-btn{align-items:center;gap:var(--space-3);padding:var(--space-6)var(--space-8);background:var(--bg-tertiary);border:2px dashed var(--border-strong);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);flex-direction:column;width:100%;font-size:14px;display:flex}.recorder-manual-text-btn:hover{border-color:var(--primary);background:var(--bg-hover);color:var(--text-primary)}.recorder-manual-text-btn:hover .recorder-manual-text-icon{background:var(--primary);color:#fff}.recorder-input-layout .scrapper-input-section{flex-direction:column;flex-shrink:0}.recorder-input-layout .scrapper-input-group{flex:none;width:100%}.recorder-input-layout .scrapper-divider{width:100%;margin:var(--space-4)0;flex-direction:row}.recorder-input-layout .scrapper-divider:before,.recorder-input-layout .scrapper-divider:after{flex:1;width:auto;height:1px}.recorder-manual-text-icon{background:var(--bg-hover);width:56px;height:56px;color:var(--text-secondary);transition:all var(--transition-base);border-radius:50%;justify-content:center;align-items:center;display:flex}.recorder-textarea-section{gap:var(--space-3);flex-direction:column;display:flex}.recorder-textarea{width:100%;padding:var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);resize:vertical;min-height:180px;font-size:15px;line-height:1.6}.recorder-textarea:focus{border-color:var(--primary);outline:none}.recorder-textarea::placeholder{color:var(--text-tertiary)}.recorder-text-stats{color:var(--text-secondary);text-align:right;font-size:12px}.recorder-textarea-actions{justify-content:flex-end;gap:var(--space-3);display:flex}.recorder-btn-secondary{align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-4);background:var(--bg-tertiary);border:1px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:14px;font-weight:500;display:inline-flex}.recorder-btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary)}.recorder-btn-primary{align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-4);background:var(--primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;font-size:14px;font-weight:600;display:inline-flex}.recorder-btn-primary:hover:not(:disabled){background:var(--primary-hover)}.recorder-btn-primary:disabled{opacity:.5;cursor:not-allowed}.recorder-session-badge{margin-right:var(--space-2);text-transform:uppercase;letter-spacing:.02em;border:1px solid var(--divider);background:var(--bg-tertiary);color:var(--text-secondary);border-radius:999px;align-items:center;padding:2px 6px;font-size:10px;font-weight:600;display:inline-flex}.recorder-session-title-input{font:inherit;border:1px solid var(--divider);background:var(--bg-primary);color:var(--text-primary);border-radius:6px;padding:2px 6px;font-size:13px}.recorder-session-title-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow);outline:none}.recorder-session-title-edit{flex:1;align-items:center;gap:4px;min-width:0;display:flex}.recorder-session-title-edit .recorder-session-title-input{flex:1;min-width:0}.recorder-session-title-save{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.recorder-session-title-save:disabled{opacity:.5;cursor:not-allowed}.recorder-session-source-tag{align-items:center;display:inline-flex}.recorder-session-source-select{border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 3px center;background-repeat:no-repeat;border-radius:4px;max-width:100px;padding:1px 16px 1px 4px;font-size:11px}.recorder-session-source-select:hover{border-color:var(--primary)}.recorder-session-source-select:disabled{opacity:.5;cursor:not-allowed}.recorder-session-actions{gap:var(--space-1);margin-left:auto;display:inline-flex}.recorder-session-badge-completed{background:var(--success-muted);color:var(--success);border-color:var(--success)}.recorder-session-badge-review{background:var(--warning-muted);color:var(--warning);border-color:var(--warning)}.recorder-session-badge-pending{background:var(--bg-tertiary);color:var(--text-secondary);border-color:var(--divider)}.recorder-session-badge-draft{background:var(--bg-tertiary);color:var(--text-muted);border-color:var(--divider)}.recorder-session-url{align-items:center;gap:var(--space-2);flex:1;min-width:0;display:flex;overflow:hidden}.recorder-session-title{white-space:nowrap;text-overflow:ellipsis;max-width:250px;font-weight:500;overflow:hidden}@media (max-width:600px){.recorder-session-title{max-width:120px}}.recorder-sessions{margin-top:var(--space-6);border-top:1px solid var(--border);padding-top:var(--space-5);flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.recorder-sessions-title{align-items:center;gap:var(--space-2);color:var(--text-secondary);margin:0 0 var(--space-4)0;font-size:.85rem;font-weight:600;display:flex}.recorder-sessions-count{background:var(--bg-tertiary);color:var(--text-muted);border-radius:999px;padding:1px 7px;font-size:.7rem;font-weight:500}.recorder-sessions-list{gap:var(--space-2);min-height:0;padding-bottom:var(--space-4);flex-direction:column;flex:1;display:flex;overflow-y:auto}.recorder-sessions-empty{text-align:center;color:var(--text-muted);padding:var(--space-6)0;font-size:.85rem}.recorder-session-row{position:relative}.recorder-session-link{gap:var(--space-2);padding:var(--space-3)var(--space-4);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:inherit;transition:all var(--transition-fast);text-align:left;cursor:pointer;width:100%;font:inherit;flex-direction:column;text-decoration:none;display:flex}.recorder-session-link:hover{border-color:var(--border-strong);background:var(--bg-hover)}.recorder-session-link.completed{border-left:3px solid var(--success)}.recorder-session-link.disabled{opacity:.5;pointer-events:none}.recorder-session-top{justify-content:space-between;align-items:center;gap:var(--space-3);min-width:0;display:flex}.recorder-session-name{align-items:center;gap:var(--space-2);flex:1;min-width:0;display:flex;overflow:hidden}.recorder-session-date{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:.75rem}.recorder-session-bottom{align-items:center;gap:var(--space-3);font-size:.8rem;display:flex}.recorder-session-stat{color:var(--text-muted);font-size:.75rem}.recorder-session-action{border:1px solid var(--border);background:var(--bg-tertiary);width:26px;height:26px;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;padding:0;display:inline-flex}.recorder-session-action:hover{border-color:var(--border-strong);color:var(--text-primary);background:var(--bg-hover)}.recorder-session-action-danger:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-muted)}.recorder-session-action:disabled{opacity:.5;cursor:not-allowed}.scrapper-btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}.recorder-record-layout{flex-direction:column;height:100vh;max-height:100vh;display:flex;overflow:hidden}.recorder-record-layout .scrapper-header{flex-shrink:0}.recorder-segment-counter{text-align:center;padding:var(--space-3);color:var(--text-secondary);background:var(--bg-tertiary);border-radius:var(--radius-md);margin:var(--space-3)0;flex-shrink:0;font-size:13px;font-weight:600}.recorder-segments-scroll{padding:0 var(--space-2);margin-bottom:var(--space-4);flex:1;overflow-y:auto}.recorder-header-single-row .scrapper-header-row{align-items:center;width:100%;display:flex}.recorder-header-title{text-align:center;color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;padding:0 var(--space-3);flex:1;font-size:13px;font-weight:500;overflow:hidden}.sanitize-title-display{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;cursor:pointer;border-radius:var(--radius-sm);max-width:200px;padding:3px var(--space-2);transition:background var(--transition-fast),border-color var(--transition-fast);border:1px solid #0000;font-size:13px;font-weight:500;overflow:hidden}.sanitize-title-display:hover{background:var(--bg-hover);border-color:var(--border)}.sanitize-title-input{color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--primary);border-radius:var(--radius-sm);padding:3px var(--space-2);outline:none;width:180px;font-size:13px;font-weight:500}.sanitize-source-select{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;appearance:none;transition:border-color var(--transition-fast);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 4px center;background-repeat:no-repeat;padding:2px 20px 2px 6px;font-size:12px}.sanitize-source-select:hover{border-color:var(--primary)}.sanitize-source-select:focus{border-color:var(--primary);outline:none}.sanitize-toolbar-sep{background:var(--border);flex-shrink:0;width:1px;height:16px;margin:0 2px}.recorder-header-spacer{flex:1}.recorder-header-controls{align-items:center;gap:var(--space-3);display:flex}.recorder-rules-group{background:var(--primary-muted);border-radius:var(--radius-md);border:1px solid #6366f159;align-items:stretch;display:inline-flex;overflow:hidden}.recorder-rules-btn{align-items:center;gap:var(--space-1);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-right:1px solid #6366f140;border-radius:0;padding:6px 12px;font-size:12px;font-weight:600;display:flex}.recorder-rules-btn:hover{background:#6366f140}.recorder-rules-apply-btn{color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:6px 10px;display:flex}.recorder-rules-apply-btn:hover:not(:disabled){background:#6366f140}.recorder-rules-apply-btn:disabled{opacity:.5;cursor:not-allowed}.recorder-filter-toggle{align-items:center;gap:var(--space-1);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:6px 12px;font-size:12px;font-weight:500;display:flex}.recorder-filter-toggle:hover{border-color:var(--border-strong);color:var(--text-primary)}.recorder-filter-toggle.active{background:var(--warning-muted);border-color:var(--warning);color:var(--warning)}.recorder-rescrap-btn{align-items:center;gap:var(--space-1);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;padding:6px 12px;font-size:12px;font-weight:500;display:flex}.recorder-rescrap-btn:hover{border-color:var(--border-strong);color:var(--text-primary)}.recorder-rescrap-btn:disabled{opacity:.6;cursor:not-allowed}.recorder-rules-overlay{z-index:1100;background:#0a0c12b3;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.recorder-rules-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;flex-direction:column;width:min(480px,92vw);max-height:min(75vh,640px);display:flex;overflow:hidden;box-shadow:0 24px 80px #00000080}.recorder-rules-header{justify-content:space-between;align-items:center;padding:16px 20px 4px;display:flex}.recorder-rules-header h3{color:var(--text-primary);margin:0;font-size:15px;font-weight:600}.recorder-rules-close{width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.recorder-rules-close:hover{color:var(--text-primary);background:#ffffff14}.recorder-rules-tabs{border-bottom:1px solid var(--border);gap:0;padding:0 20px;display:flex}.recorder-rules-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:12px 16px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.recorder-rules-tab:hover{color:var(--text-secondary)}.recorder-rules-tab.active{color:var(--text-primary);border-bottom-color:var(--primary)}.recorder-rules-tab-badge{background:var(--primary);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:600;display:inline-flex}.recorder-rules-body{flex-direction:column;flex:1;gap:16px;padding:16px 20px;display:flex;overflow-y:auto}.recorder-rules-loading{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:13px}.recorder-rules-error{color:#ff6961;background:#ff3b301a;border-radius:8px;padding:10px 12px;font-size:12px}.recorder-rules-options{flex-wrap:wrap;gap:16px;display:flex}.recorder-rule-option{color:var(--text-secondary);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.recorder-rule-option:hover{color:var(--text-primary)}.recorder-rule-option input{accent-color:var(--primary);width:15px;height:15px}.recorder-rules-list{flex-direction:column;gap:8px;display:flex}.recorder-rule-add-row{border-bottom:1px solid var(--border);grid-template-columns:1fr auto 1fr auto;align-items:center;gap:10px;margin-bottom:4px;padding-bottom:12px;display:grid}.recorder-rule-add-btn{background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;white-space:nowrap;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;transition:all .15s;display:inline-flex}.recorder-rule-add-btn:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary)}.recorder-rule-add-btn:disabled{opacity:.4;cursor:not-allowed}.recorder-rule-row{grid-template-columns:1fr auto 1fr auto auto;align-items:center;gap:10px;display:grid}.recorder-rule-input{border:none;border-bottom:1px solid var(--border);color:var(--text-primary);font-size:14px;font-family:var(--font-ethiopic);background:0 0;border-radius:0;padding:8px 0;transition:all .15s}.recorder-rule-input::placeholder{color:var(--text-muted)}.recorder-rule-input:focus{border-bottom-color:var(--primary);outline:none}.recorder-rule-arrow{color:var(--text-muted);opacity:.5;font-size:14px}.recorder-rule-toggle{width:24px;height:24px;color:var(--text-muted);cursor:pointer;opacity:.5;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;transition:all .15s;display:flex}.recorder-rule-toggle:hover{opacity:1}.recorder-rule-toggle.active{color:var(--success);opacity:1}.recorder-rule-remove{width:24px;height:24px;color:var(--text-muted);cursor:pointer;opacity:.4;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;transition:all .15s;display:flex}.recorder-rule-remove:hover{color:#ff6961;opacity:1}.recorder-rule-empty{text-align:center;color:var(--text-muted);padding:32px 12px;font-size:13px}.recorder-rules-preview{flex-direction:column;gap:12px;display:flex}.recorder-rules-preview-empty{text-align:center;color:var(--text-muted);padding:32px 12px;font-size:13px}.recorder-rules-preview-list{flex-direction:column;gap:16px;display:flex}.recorder-rules-preview-item{align-items:flex-start;gap:12px;display:flex}.recorder-rules-preview-index{font-variant-numeric:tabular-nums;color:var(--text-muted);min-width:32px;padding-top:2px;font-size:11px;font-weight:600}.recorder-rules-preview-text{flex-direction:column;flex:1;gap:6px;font-size:13px;line-height:1.5;display:flex}.recorder-rules-preview-before{color:var(--text-muted);-webkit-text-decoration:line-through #fff3;text-decoration:line-through #fff3}.recorder-rules-preview-after{color:var(--text-primary)}.recorder-preview-highlight{color:var(--success);background:#34c75940;border-radius:3px;margin:0 1px;padding:1px 3px}.recorder-rules-preview-more{text-align:center;color:var(--text-muted);padding:8px;font-size:12px}.recorder-rules-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;padding:16px 20px;display:flex}.recorder-rule-action{cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-size:13px;font-weight:600;transition:all .15s}.recorder-rule-action.primary{background:var(--primary);color:#fff}.recorder-rule-action.primary:hover:not(:disabled){background:var(--primary-hover)}.recorder-rule-action:disabled{opacity:.5;cursor:not-allowed}.recorder-controls-sticky{background:var(--bg-primary);border-top:1px solid var(--border-strong);padding:var(--space-4)var(--space-6);align-items:center;gap:var(--space-2);z-index:50;flex-direction:column;padding-top:25px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 30px #00000026}.recorder-timer-large{font-variant-numeric:tabular-nums;color:var(--text-primary);letter-spacing:-.02em;font-size:48px;font-weight:300}.recorder-control-buttons{align-items:center;gap:var(--space-3);display:flex}.recorder-play-all-btn{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-full);width:48px;height:48px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.recorder-play-all-btn:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary)}.recorder-play-all-btn:disabled{opacity:.5;cursor:not-allowed}.recorder-play-all-btn-active{background:var(--primary);color:#fff;border-color:var(--primary)}.recorder-controls-inner{align-items:center;gap:var(--space-3);flex-direction:column;width:100%;max-width:600px;display:flex}.recorder-upload-progress{background:var(--bg-tertiary);height:3px;position:absolute;top:0;left:0;right:0}.recorder-upload-progress-fill{background:var(--success);height:100%;transition:width .3s}.recorder-controls-sticky .recorder-timer{font-variant-numeric:tabular-nums;color:var(--danger);background:var(--danger-muted);padding:var(--space-1)var(--space-2);border-radius:var(--radius);font-size:14px;font-weight:600}.recorder-controls-sticky .recorder-record-btn{min-width:180px;padding:var(--space-4)var(--space-6)}.recorder-controls-sticky .recorder-instructions{text-align:center;color:var(--text-secondary);font-size:13px}.recorder-controls-sticky .recorder-instructions kbd{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px 6px;font-size:11px;font-weight:600}.recorder-bottombar-row{justify-content:space-between;align-items:center;gap:var(--space-4);width:100%;display:flex}.recorder-bottombar-left{justify-content:flex-start;align-items:center;gap:var(--space-3);flex:1;display:flex}.recorder-bottombar-center{align-items:center;gap:var(--space-1);flex-direction:column;display:flex}.recorder-bottombar-center .recorder-instructions{color:var(--text-muted);font-size:11px}.recorder-bottombar-center .recorder-instructions kbd{background:var(--bg-tertiary);border-radius:4px;padding:2px 6px;font-family:inherit;font-size:10px}.recorder-bottombar-right{justify-content:flex-end;align-items:center;gap:var(--space-2);flex:1;display:flex}.recorder-bottombar-row .recorder-record-btn{flex-shrink:0}.recorder-review-mode{gap:var(--space-2);padding:0 var(--space-2);flex-direction:column;flex:1;margin-bottom:75px;padding-bottom:180px;display:flex;overflow-y:auto}.recorder-rerecord-btn{border:1px solid var(--divider);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border-radius:8px;padding:6px 10px;font-size:12px}.recorder-rerecord-btn:hover:not(:disabled){border-color:var(--border-strong);color:var(--text-primary)}.recorder-rerecord-btn:disabled{opacity:.6;cursor:not-allowed}.recorder-icon-btn{border:1px solid var(--divider);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border-radius:8px;justify-content:center;align-items:center;display:flex}.recorder-icon-btn:hover:not(:disabled){border-color:var(--border-strong);color:var(--text-primary);background:var(--bg-tertiary)}.recorder-icon-btn:disabled{opacity:.4;cursor:not-allowed}.recorder-icon-btn-active{background:var(--primary-muted);border-color:var(--primary);color:var(--primary)}.recorder-icon-btn-recording{background:var(--danger);border-color:var(--danger);color:#fff;animation:1.5s ease-in-out infinite pulse}.recorder-exclude-btn{color:var(--text-muted)}.recorder-exclude-btn:hover:not(:disabled){color:var(--danger);border-color:var(--danger)}.recorder-delete-confirm{border-radius:6px;min-width:auto;animation:.3s recorder-delete-pulse;background:var(--danger)!important;border-color:var(--danger)!important;color:#fff!important;padding:2px 8px!important}.recorder-delete-confirm:hover:not(:disabled){background:color-mix(in srgb,var(--danger)85%,#000)!important;color:#fff!important}.recorder-delete-confirm-label{letter-spacing:.02em;white-space:nowrap;padding:2px 8px;font-size:10px;font-weight:600}@keyframes recorder-delete-pulse{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.recorder-review-item-excluded .recorder-review-original{color:var(--text-muted);text-decoration:line-through}.recorder-review-item-excluded .recorder-review-asr{text-decoration:line-through}.recorder-review-item-active{background:var(--primary-muted);border-color:var(--primary)}.recorder-review-item-playing{background:var(--success-muted);border-color:var(--success)}.recorder-review-item-transcribing{background:var(--bg-secondary)}.recorder-review-asr-transcribing{color:var(--primary);font-style:italic;animation:1.5s ease-in-out infinite pulse}.recorder-match-indicator.transcribing{color:var(--primary);background:var(--primary-muted)}.recorder-spinner-icon{animation:1s linear infinite spin}.recorder-review-item-left{align-items:center;gap:var(--space-1);flex-direction:column;flex-shrink:0;display:flex}.recorder-review-item-actions{align-items:center;gap:var(--space-2);display:flex}.recorder-review-item-duration{font-variant-numeric:tabular-nums;color:var(--text-muted);letter-spacing:.02em;text-align:center;min-width:36px;font-size:11px;transition:all .15s}.recorder-review-item-duration-active{color:var(--primary);background:var(--primary-muted);border-radius:4px;padding:2px 6px;font-weight:600}.recorder-record-again-btn{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.recorder-record-again-btn:hover{background:var(--bg-secondary);border-color:var(--danger);color:var(--danger)}.recorder-segment{align-items:flex-start;gap:var(--space-3);padding:var(--space-3)var(--space-4);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-2);transition:all var(--transition-fast);display:flex;box-shadow:0 1px 2px #0000000d}.recorder-segment-active{background:var(--primary-bg);border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.recorder-segment-recorded{border-color:var(--border-strong)}.recorder-segment-number{background:var(--bg-tertiary);width:24px;height:24px;color:var(--text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex}.recorder-segment-active .recorder-segment-number{background:var(--primary);color:#fff}.recorder-segment-text{color:var(--text-primary);flex:1;font-size:15px;line-height:1.5}.recorder-segment-duration{color:var(--text-tertiary);flex-shrink:0;font-size:12px}.recorder-segment-status{flex-shrink:0;font-size:12px}.recorder-transcribing-indicator{color:var(--primary);font-size:11px;animation:1.5s ease-in-out infinite pulse}.recorder-matched-indicator{color:var(--success);font-weight:600}.recorder-unmatched-indicator{color:var(--warning);font-weight:600}.recorder-segment-transcribing{background:var(--primary-muted);border-color:var(--primary)}.recorder-record-btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-5);background:var(--danger);color:#fff;cursor:pointer;transition:all var(--transition-fast);border:none;border-radius:100px;font-size:14px;font-weight:600;display:inline-flex}.recorder-record-btn:hover{background:var(--danger-hover);transform:scale(1.02)}.recorder-record-btn-active{animation:1.5s ease-in-out infinite pulse}.recorder-record-icon{background:#fff;border-radius:50%;width:12px;height:12px}.recorder-record-icon-stop{border-radius:2px}.sanitize-layout{flex-direction:column;flex:1;max-width:none;min-height:0;display:flex;overflow:hidden}.sanitize-body{padding:0 var(--space-4);padding-bottom:var(--space-2);flex:1;min-height:0;overflow:hidden}.sanitize-split-view{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-primary);grid-template-columns:1fr auto 1fr;gap:0;height:100%;display:grid;overflow:hidden}.sanitize-divider{background:var(--border);width:1px}.sanitize-panel{flex-direction:column;min-height:0;display:flex;overflow:hidden}.sanitize-panel-header{align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-4);text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0;font-size:11px;font-weight:600;display:flex}.sanitize-left-toggle{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;overflow:hidden}.sanitize-left-toggle button{text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;padding:3px 10px;font-size:11px;font-weight:600}.sanitize-left-toggle button:not(:last-child){border-right:1px solid var(--border)}.sanitize-left-toggle button:hover:not(:disabled){color:var(--text-primary)}.sanitize-left-toggle button.active{background:var(--primary);color:#fff}.sanitize-left-toggle button:disabled{opacity:.5;cursor:not-allowed}.sanitize-diff-stat{letter-spacing:0;text-transform:none;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:700}.sanitize-diff-stat-removed{color:var(--danger);background:#ef44441f}.sanitize-diff-stat-added{color:var(--success-color,#16a34a);background:#22c55e1f}.sanitize-panel-content{padding:var(--space-4);flex:1;min-height:0;overflow-y:auto}.sanitize-diff-text{font-size:18px;line-height:1.8;font-family:var(--font-ethiopic);color:var(--text-primary);white-space:pre-wrap;word-break:break-word}.sanitize-diff-removed{color:var(--danger);background:#ef444426;border-radius:2px;padding:1px 2px;-webkit-text-decoration:line-through #ef444466;text-decoration:line-through #ef444466}.sanitize-diff-added{color:var(--success-color,#16a34a);background:#22c55e26;border-radius:2px;padding:1px 2px}.sanitize-diff-clickable{cursor:pointer;transition:filter .15s,box-shadow .15s}.sanitize-diff-clickable:hover{filter:brightness(1.15);border-radius:3px;box-shadow:0 0 0 2px #6366f159}.sanitize-rule-popover{z-index:9999;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);width:300px;animation:.15s sanitize-popover-in;position:fixed;overflow:hidden;box-shadow:0 8px 32px #0000002e,0 2px 8px #00000014}.sanitize-rule-popover-header{padding:var(--space-2)var(--space-3);border-bottom:1px solid var(--border);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;justify-content:space-between;align-items:center;font-size:12px;font-weight:600;display:flex}.sanitize-rule-popover-close{color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast);background:0 0;border:none;align-items:center;padding:2px;display:flex}.sanitize-rule-popover-close:hover{color:var(--text-primary)}.sanitize-rule-popover-fields{align-items:flex-end;gap:var(--space-2);padding:var(--space-3);display:flex}.sanitize-rule-popover-field{flex-direction:column;flex:1;gap:4px;display:flex}.sanitize-rule-popover-field label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.03em;font-size:11px;font-weight:500}.sanitize-rule-popover-field input{padding:var(--space-1)var(--space-2);font-size:14px;font-family:var(--font-ethiopic);color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;transition:border-color var(--transition-fast);outline:none}.sanitize-rule-popover-field input:focus{border-color:var(--primary)}.sanitize-rule-popover-arrow{color:var(--text-tertiary);flex-shrink:0;padding-bottom:6px;font-size:14px}.sanitize-rule-popover-add{justify-content:center;align-items:center;gap:var(--space-1);width:calc(100% - var(--space-3)*2);margin:0 var(--space-3)var(--space-3);padding:var(--space-2);color:#fff;background:var(--primary);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),opacity var(--transition-fast);border:none;font-size:13px;font-weight:500;display:flex}.sanitize-rule-popover-add:hover:not(:disabled){background:var(--primary-hover)}.sanitize-rule-popover-add:disabled{opacity:.5;cursor:not-allowed}.sanitize-single-view{height:100%;min-height:0}.sanitize-textarea{width:100%;height:100%;padding:var(--space-4);font-size:18px;line-height:1.8;font-family:var(--font-ethiopic);color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);resize:none;transition:border-color var(--transition-fast);outline:none;font-family:inherit}.sanitize-textarea:focus{border-color:var(--primary)}.sanitize-footer{padding:var(--space-3)var(--space-4);border-top:1px solid var(--border);background:var(--bg-primary);justify-content:space-between;align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.sanitize-footer-left{align-items:center;gap:var(--space-3);display:flex}.sanitize-stats{color:var(--text-tertiary);white-space:nowrap;font-size:12px}.sanitize-config-anchor{position:relative}.sanitize-config-popover{z-index:1000;width:380px;padding:var(--space-4);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-lg);gap:var(--space-3);flex-direction:column;animation:.15s ease-out sanitize-popover-in;display:flex;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 8px 30px #0000001f}@keyframes sanitize-popover-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.sanitize-config-field{gap:var(--space-1);flex-direction:column;display:flex}.sanitize-config-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);font-size:11px;font-weight:600}.sanitize-config-input{padding:var(--space-2)var(--space-3);color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px;font-family:var(--font-ui);transition:border-color var(--transition-fast);outline:none}.sanitize-config-input:focus{border-color:var(--primary)}.sanitize-config-textarea{padding:var(--space-2)var(--space-3);font-size:14px;font-family:var(--font-ui);color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);resize:vertical;min-height:100px;transition:border-color var(--transition-fast);outline:none;font-family:inherit;line-height:1.6}.sanitize-config-textarea:focus{border-color:var(--primary)}.sanitize-config-actions{justify-content:flex-end;gap:var(--space-2);padding-top:var(--space-2);display:flex}.sanitize-empty{color:var(--text-tertiary);flex:1;justify-content:center;align-items:center;font-size:14px;display:flex}.sanitize-gem-hint{color:#fbbf24cc;cursor:help;letter-spacing:.02em;-webkit-user-select:none;user-select:none;margin-left:auto;font-size:11px;font-weight:600}.sanitize-gem-target{cursor:pointer;border-radius:2px;transition:background .1s}.sanitize-gem-target:hover{background:#fbbf241f}.sanitize-gem-marked{background:#fbbf2438;border-bottom:2px solid #fbbf24cc;border-radius:2px 2px 0 0;padding:1px 0}.sanitize-gem-underscore{color:#fbbf24d9;vertical-align:sub;font-size:.65em;font-weight:700}.sanitize-gem-backdrop{z-index:9998;background:#00000073;animation:.15s gem-backdrop-in;position:fixed;inset:0}@keyframes gem-backdrop-in{0%{opacity:0}to{opacity:1}}.sanitize-gem-popover{z-index:9999;background:var(--bg-primary);border-radius:var(--radius-lg);border:1px solid #fbbf2459;width:400px;animation:.15s sanitize-popover-in;position:fixed;overflow:hidden;box-shadow:0 0 0 1px #fbbf241a,0 12px 40px #00000059,0 4px 12px #00000026}.sanitize-gem-popover-header{padding:var(--space-2)var(--space-3);border-bottom:1px solid var(--border);color:#fbbf24e6;text-transform:uppercase;letter-spacing:.04em;background:#fbbf240f;justify-content:space-between;align-items:center;font-size:12px;font-weight:600;display:flex}.sanitize-gem-popover-fields{gap:var(--space-3);padding:var(--space-3);flex-direction:column;display:flex}.sanitize-gem-popover-field{flex-direction:column;gap:4px;display:flex}.sanitize-gem-popover-field label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.03em;font-size:11px;font-weight:500}.sanitize-gem-popover-field input{padding:var(--space-2)var(--space-2);font-size:15px;font-family:var(--font-ethiopic);color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;transition:border-color var(--transition-fast);outline:none}.sanitize-gem-popover-field input:focus{border-color:#fbbf2499}.sanitize-gem-popover-field input[readonly]{opacity:.65;cursor:default}.sanitize-gem-popover-save{justify-content:center;align-items:center;gap:var(--space-1);width:calc(100% - var(--space-3)*2);margin:0 var(--space-3)var(--space-3);padding:var(--space-2);color:#1a1a1a;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),opacity var(--transition-fast);background:#fbbf24d9;border:none;font-size:13px;font-weight:500;display:flex}.sanitize-gem-popover-save:hover:not(:disabled){background:#fbbf24}.sanitize-gem-popover-save:disabled{opacity:.5;cursor:not-allowed}.recorder-rules-btn.active{background:var(--bg-hover);color:var(--primary)}.login-page{background:var(--bg-primary);min-height:100vh;padding:var(--space-4);justify-content:center;align-items:center;display:flex}.login-card{background:var(--bg-secondary);border:1px solid var(--border-strong);text-align:center;border-radius:16px;width:100%;max-width:400px;padding:48px 40px}.login-title{font-family:var(--font-ethiopic-title),serif;color:var(--text-primary);margin:0 0 8px;font-size:4.5rem}.login-subtitle{font-family:var(--font-ethiopic),serif;color:var(--text-secondary);margin:0 0 32px;font-size:.95rem}.login-error{background:var(--danger-muted);color:var(--danger);border-radius:8px;margin-bottom:20px;padding:10px 16px;font-size:.85rem}.login-btn{cursor:pointer;width:100%;transition:var(--transition-base);border:none;border-radius:10px;justify-content:center;align-items:center;gap:12px;padding:12px 24px;font-size:.95rem;font-weight:500;display:flex}.login-btn-google{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-strong)}.login-btn-google:hover{background:var(--bg-hover);border-color:var(--text-muted)}.login-btn-secondary{color:var(--text-secondary);border:1px solid var(--border);background:0 0;margin-top:16px}.login-btn-secondary:hover{background:var(--bg-hover)}.login-pending{margin:24px 0}.login-pending-icon{color:var(--warning);margin-bottom:16px}.login-pending h2{color:var(--text-primary);margin:0 0 8px;font-size:1.2rem}.login-pending p{color:var(--text-secondary);margin:0;font-size:.9rem;line-height:1.5}.login-spinner{border:3px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;margin:0 auto;animation:.8s linear infinite spin}.user-menu{z-index:1000;position:fixed;top:16px;right:16px}.user-menu-trigger{cursor:pointer;transition:var(--transition-fast);background:0 0;border:2px solid #0000;border-radius:50%;padding:0}.user-menu-trigger:hover{border-color:var(--border-strong)}.user-menu-avatar{object-fit:cover;border-radius:50%;width:36px;height:36px;display:block}.user-menu-avatar-fallback{background:var(--primary-muted);color:var(--primary);justify-content:center;align-items:center;font-size:.85rem;font-weight:600;display:flex}.user-menu-dropdown{background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:12px;min-width:220px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 32px #0006}.user-menu-header{flex-direction:column;gap:2px;padding:12px 16px;display:flex}.user-menu-name{color:var(--text-primary);font-size:.9rem;font-weight:500}.user-menu-email{color:var(--text-muted);font-size:.8rem}.user-menu-divider{background:var(--border);height:1px;margin:0}.user-menu-item{width:100%;color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;align-items:center;gap:10px;padding:10px 16px;font-size:.85rem;text-decoration:none;display:flex}.user-menu-item:hover{background:var(--bg-hover);color:var(--text-primary)}.user-menu-item-danger:hover{color:var(--danger)}.user-menu-theme{padding:8px 12px}.user-menu-theme-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:6px;font-size:.7rem;font-weight:600;display:block}.user-menu-theme-options{background:var(--bg-tertiary);border-radius:8px;gap:4px;padding:3px;display:flex}.user-menu-theme-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:4px;padding:5px 8px;font-size:.72rem;font-weight:500;transition:all .15s;display:flex}.user-menu-theme-btn:hover{color:var(--text-secondary)}.user-menu-theme-btn.active{background:var(--bg-secondary);color:var(--text-primary);box-shadow:0 1px 3px #0000001a}.admin-page{background:var(--bg-primary);max-width:1000px;min-height:100vh;margin:0 auto;padding:24px}.admin-header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.admin-back{background:var(--bg-secondary);border:1px solid var(--border);width:36px;height:36px;color:var(--text-secondary);transition:var(--transition-fast);border-radius:10px;justify-content:center;align-items:center;text-decoration:none;display:flex}.admin-back:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-title{color:var(--text-primary);margin:0;font-size:1.3rem;font-weight:600}.admin-table{border-collapse:separate;border-spacing:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;width:100%;overflow:hidden}.admin-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:var(--bg-tertiary);border-bottom:1px solid var(--border);padding:12px 16px;font-size:.75rem;font-weight:600}.admin-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 16px}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-hover)}.admin-user-cell{align-items:center;gap:12px;display:flex}.admin-user-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:32px;height:32px}.admin-user-avatar-fallback{background:var(--primary-muted);width:32px;height:32px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:600;display:flex}.admin-user-info{flex-direction:column;min-width:0;display:flex}.admin-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:500;overflow:hidden}.admin-user-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.admin-badge{cursor:pointer;transition:var(--transition-fast);border:none;border-radius:6px;align-items:center;padding:4px 10px;font-size:.75rem;font-weight:500;display:inline-flex}.admin-badge-approved{background:var(--success-muted);color:var(--success)}.admin-badge-pending{color:var(--warning);background:#f59e0b26}.admin-badge-admin{background:var(--primary-muted);color:var(--primary)}.admin-badge-not-admin{background:var(--bg-tertiary);color:var(--text-muted)}.admin-badge:hover{filter:brightness(1.2)}.admin-badge:disabled{opacity:.5;cursor:not-allowed}.admin-role-checks{gap:8px;display:flex}.admin-role-check{cursor:pointer;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);transition:var(--transition-fast);border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:.75rem;display:flex}.admin-role-check.active{background:var(--primary-muted);color:var(--primary);border-color:var(--primary)}.admin-role-check:hover{border-color:var(--text-muted)}.admin-role-check:disabled{opacity:.5;cursor:not-allowed}.admin-date{color:var(--text-muted);white-space:nowrap;font-size:.8rem}.admin-loading{min-height:60vh;color:var(--text-muted);justify-content:center;align-items:center;padding:64px;display:flex}.admin-toast{z-index:2000;border-radius:8px;padding:10px 20px;font-size:.85rem;animation:.3s slideUp;position:fixed;bottom:24px;right:24px}.admin-toast-success{background:var(--success-muted);color:var(--success);border:1px solid var(--success)}.admin-toast-error{background:var(--danger-muted);color:var(--danger);border:1px solid var(--danger)}
