:root{--bg:#0b1120;--surface:#151d2e;--surface2:#1c2840;--border:#243049;--text:#e2e8f0;--text-dim:#7a8ba8;--accent:#3b82f6;--accent-hover:#2563eb;--green:#22c55e;--red:#ef4444;--yellow:#f59e0b;--purple:#a78bfa;--radius:10px;--sidebar-w:220px;--sidebar-w-collapsed:56px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text)}.app-shell,body{min-height:100vh}.app-shell,.sidebar{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;z-index:120;transition:width .2s ease;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-w-collapsed)}.sidebar-top{justify-content:space-between;padding:.75rem;border-bottom:1px solid var(--border);min-height:56px}.sidebar-logo,.sidebar-top{display:flex;align-items:center}.sidebar-logo{text-decoration:none;color:inherit;overflow:hidden;white-space:nowrap}.sidebar-logo h1{font-size:1.1rem;font-weight:700;letter-spacing:-.02em}.sidebar-logo h1 span,.sidebar-logo-icon{color:var(--accent)}.sidebar-logo-icon{font-size:.85rem;font-weight:800;letter-spacing:-.04em}.sidebar-toggle{background:none;border:none;color:var(--text-dim);font-size:1rem;cursor:pointer;padding:.2rem .35rem;border-radius:4px;transition:background .2s,color .2s;flex-shrink:0}.sidebar-toggle:hover{background:var(--surface2);color:var(--text)}.sidebar-nav{flex:1 1;display:flex;flex-direction:column;gap:2px;padding:.5rem;overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:.65rem;padding:.6rem .7rem;border-radius:6px;color:var(--text-dim);text-decoration:none;font-size:.88rem;font-weight:500;white-space:nowrap;transition:background .15s,color .15s}.sidebar-link:hover{background:var(--surface2);color:var(--text)}.sidebar-link.active{background:#3b82f614;color:var(--accent)}.sidebar-link-icon{font-size:1.05rem;flex-shrink:0;width:24px;text-align:center}.sidebar-link-label{overflow:hidden;text-overflow:ellipsis}.sidebar-bottom{padding:.65rem .75rem;border-top:1px solid var(--border)}.sidebar-status{display:flex;align-items:center;gap:.45rem;font-size:.78rem;color:var(--text-dim)}.ws-dot{width:8px;height:8px;border-radius:50%;background:var(--red);transition:background .3s;flex-shrink:0}.ws-dot.connected{background:var(--green)}.main-content{flex:1 1;margin-left:var(--sidebar-w);min-height:100vh;transition:margin-left .2s ease}.app-shell:has(.sidebar.collapsed) .main-content,.sidebar.collapsed~.main-content{margin-left:var(--sidebar-w-collapsed)}.header{background:var(--surface);border-bottom:1px solid var(--border);padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header h1{font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.header h1 span{color:var(--accent)}.ws-indicator{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--text-dim)}.container{max-width:1400px;margin:0 auto;padding:1.25rem}.dash-row-1{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem;margin-bottom:1rem}.dash-col-streams{display:flex;flex-direction:column}.dash-col-streams>.card,.dash-col-streams>.card>.card-body{flex:1 1;display:flex;flex-direction:column}.dash-col-streams>.card>.card-body{overflow:hidden}.dash-col-streams .stream-list{flex:1 1;overflow-y:auto;max-height:none}.dash-col-streams .stream-list::-webkit-scrollbar{width:6px}.dash-col-streams .stream-list::-webkit-scrollbar-track{background:transparent}.dash-col-streams .stream-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.dash-col-config{display:flex;flex-direction:column;gap:1rem}.dash-row-2{margin-bottom:1rem}.top-row{grid-template-columns:1fr 1fr;grid-gap:1rem;margin-bottom:1rem}.bottom-row,.top-row{display:grid;gap:1rem}.bottom-row{grid-template-columns:1fr;grid-gap:1rem}@media (max-width:1000px){.bottom-row,.dash-row-1,.top-row{grid-template-columns:1fr}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column}.card-head{padding:.75rem 1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-head h2{font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}.card-head .badge{font-size:.7rem;background:var(--surface2);border:1px solid var(--border);padding:2px 8px;border-radius:99px;color:var(--text-dim)}.card-body{padding:1rem;flex:1 1}.form-row{display:flex;gap:.5rem;margin-bottom:.75rem}.form-row input{flex:1 1;padding:.55rem .75rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.85rem;transition:border-color .2s;outline:none}.form-row input:focus{border-color:var(--accent)}.form-row input::placeholder{color:var(--text-dim)}.btn{padding:.55rem 1rem;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s,transform .1s,opacity .2s;white-space:nowrap}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-danger{background:transparent;color:var(--red);border:1px solid #ef444444}.btn-danger:hover:not(:disabled){background:#ef444418}.btn-sm{padding:.3rem .6rem;font-size:.75rem}.btn-clear{background:transparent;color:var(--text-dim);border:1px solid var(--border)}.btn-clear:hover,.btn-secondary{background:var(--surface2)}.btn-secondary{color:var(--text-dim);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border);color:var(--text)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.stream-list{list-style:none}.stream-item{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;border-radius:6px;margin-bottom:.35rem;background:var(--bg);border:1px solid transparent;transition:border-color .2s}.stream-item:hover{border-color:var(--border)}.stream-info{display:flex;align-items:center;gap:.5rem;min-width:0}.stream-name{font-weight:600;font-size:.85rem}.stream-name,.stream-url{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stream-url{font-size:.7rem;color:var(--text-dim);max-width:200px}.status-pill{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:99px}.status-running{background:#22c55e20;color:var(--green)}.status-stopped{background:#ef444420;color:var(--red)}.status-reconnecting{background:#f59e0b20;color:var(--yellow)}.empty-state{text-align:center;padding:1.5rem;color:var(--text-dim);font-size:.85rem}.kw-tags{display:flex;flex-wrap:wrap;gap:.35rem}.kw-tag{display:inline-flex;align-items:center;gap:.3rem;background:var(--surface2);border:1px solid var(--border);padding:.2rem .6rem;border-radius:99px;font-size:.8rem;color:var(--purple);font-weight:500}.kw-tag .remove{cursor:pointer;color:var(--text-dim);font-size:.7rem;margin-left:2px}.kw-tag .remove:hover{color:var(--red)}.kw-dupe-warning{color:var(--orange,#f59e0b);font-size:.75rem;padding:.25rem .5rem;background:rgba(245,158,11,.1);border-radius:4px;margin-top:.25rem}.transcript-scroll{max-height:400px;overflow-y:auto;scroll-behavior:smooth}.transcript-scroll::-webkit-scrollbar{width:6px}.transcript-scroll::-webkit-scrollbar-track{background:transparent}.transcript-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.t-line{padding:.5rem .6rem;border-bottom:1px solid #1a2438;font-size:.84rem;line-height:1.5;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.t-line .t-name{color:var(--accent);font-weight:700;margin-right:.4rem}.t-line .t-time{color:var(--text-dim);font-size:.7rem;margin-right:.4rem}.t-line.t-error{color:var(--red);background:#ef44440a;border-left:3px solid var(--red);white-space:pre-wrap;font-size:.78rem}mark{background:#facc1533;color:#fde047;padding:1px 3px;border-radius:3px;font-weight:600}.matches-scroll{max-height:400px;overflow-y:auto}.matches-scroll::-webkit-scrollbar{width:6px}.matches-scroll::-webkit-scrollbar-track{background:transparent}.matches-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.m-item{margin-bottom:.4rem}.m-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.m-kw{background:#a78bfa22;color:var(--purple);font-weight:700;font-size:.8rem;padding:2px 8px;border-radius:4px}.m-stream{font-size:.8rem;color:var(--accent);font-weight:600}.m-time{font-size:.7rem;margin-left:auto}.m-text,.m-time{color:var(--text-dim)}.m-text{font-size:.82rem;line-height:1.4}.ffmpeg-scroll{max-height:250px;overflow-y:auto;font-family:Cascadia Code,Fira Code,Consolas,monospace;font-size:.75rem;line-height:1.6;background:#0a0e1a;border-radius:0 0 var(--radius) var(--radius)}.ffmpeg-scroll::-webkit-scrollbar{width:6px}.ffmpeg-scroll::-webkit-scrollbar-track{background:transparent}.ffmpeg-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.ff-line{padding:.2rem .6rem;border-bottom:1px solid #111827;color:#8b9dc3;white-space:pre-wrap;word-break:break-all}.ff-line .ff-time{color:#4b5563;margin-right:.4rem}.ff-line .ff-stream{color:var(--yellow);font-weight:600;margin-right:.4rem}.ff-line.ff-error{color:var(--red)}.ff-line.ff-warn{color:var(--yellow)}.ffmpeg-filter{display:flex;align-items:center;gap:.5rem}.ffmpeg-filter select{padding:.2rem .4rem;border-radius:4px;border:1px solid var(--border);background:var(--bg);color:var(--text-dim);font-size:.72rem;outline:none}.toast-container{position:fixed;top:1rem;right:1.5rem;z-index:200;display:flex;flex-direction:column;gap:.5rem}.toast{background:var(--surface);border:1px solid var(--purple);border-radius:8px;padding:.6rem 1rem;font-size:.82rem;box-shadow:0 8px 24px #0005;animation:slideIn .3s ease,fadeOut .3s ease 4s forwards;max-width:350px}@keyframes slideIn{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:none}}@keyframes fadeOut{to{opacity:0;transform:translateX(30px)}}.toast strong{color:var(--purple)}.header-left,.header-right{display:flex;align-items:center;gap:1.5rem}.logo{text-decoration:none;color:inherit}.logo:hover h1{opacity:.9}.queue-status{display:flex;gap:1rem}.queue-item{display:flex;flex-direction:column;align-items:center}.queue-label{font-size:.65rem;text-transform:uppercase;color:var(--text-dim);letter-spacing:.05em}.queue-value{font-size:1.1rem;font-weight:700;color:var(--text)}.queue-value.pending{color:var(--yellow)}.stream-link{flex:1 1;display:flex;flex-direction:column;gap:.25rem;text-decoration:none;color:inherit;min-width:0}.stream-link:hover .stream-name{color:var(--accent)}.stream-actions{display:flex;gap:.35rem;margin-left:1rem;flex-shrink:0}.worker-badge{font-size:.6rem;background:var(--surface2);color:var(--text-dim);padding:2px 6px;border-radius:4px;font-family:monospace}.btn-success{background:var(--green);color:#fff}.btn-success:hover{background:#16a34a}.btn-warning{background:var(--yellow);color:#000}.btn-warning:hover{background:#d97706}.detail-page{min-height:100vh;background:var(--bg)}.detail-loading,.detail-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:1rem;color:var(--text-dim)}.detail-header{background:var(--surface);border-bottom:1px solid var(--border);padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;position:-webkit-sticky;position:sticky;top:0;z-index:100}.detail-header-left,.detail-header-right{display:flex;align-items:center;gap:1rem}.back-link{color:var(--text-dim);text-decoration:none;font-size:.85rem;padding:.35rem .6rem;border-radius:4px;transition:all .2s}.back-link:hover{color:var(--text);background:var(--surface2)}.detail-header h1{font-size:1.25rem;font-weight:700}.detail-actions{padding:1rem 1.5rem;gap:.5rem}.detail-actions,.detail-tabs{max-width:1400px;margin:0 auto;display:flex}.detail-tabs{padding:0 1.5rem;gap:.25rem;border-bottom:1px solid var(--border)}.tab{padding:.75rem 1.25rem;background:transparent;border:none;color:var(--text-dim);font-size:.85rem;font-weight:500;cursor:pointer;position:relative;transition:color .2s}.tab:hover{color:var(--text)}.tab.active{color:var(--accent)}.tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--accent)}.detail-content{max-width:1400px;margin:0 auto;padding:1.5rem}.overview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));grid-gap:1rem;gap:1rem}.info-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item label{font-size:.7rem;text-transform:uppercase;color:var(--text-dim);letter-spacing:.05em}.info-item span{font-size:.9rem;word-break:break-all}.url-text{font-family:monospace;font-size:.8rem;color:var(--accent)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:1rem;gap:1rem}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem;background:var(--bg);border-radius:8px}.stat-value{font-size:1.5rem;font-weight:700;color:var(--accent)}.stat-label{font-size:.7rem;text-transform:uppercase;color:var(--text-dim)}.audio-player{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--surface2);border-bottom:1px solid var(--border)}.audio-player audio{flex:1 1;height:32px}.audio-list{max-height:400px;overflow-y:auto}.audio-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border);transition:background .2s}.audio-item:hover{background:var(--surface2)}.audio-info{display:flex;flex-direction:column;gap:.2rem}.audio-name{font-size:.85rem;font-weight:500}.audio-meta{font-size:.7rem;color:var(--text-dim)}.video-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.video-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:90%;max-width:900px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;box-shadow:0 20px 60px #0008}.video-modal-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border)}.video-modal-header h3{font-size:.95rem;font-weight:600}.video-modal-actions{display:flex;align-items:center;gap:.5rem}.video-modal-close{background:none;border:none;color:var(--text-dim);font-size:1.5rem;cursor:pointer;padding:0 .25rem;line-height:1;transition:color .2s}.video-modal-close:hover{color:var(--text)}.video-modal-body{background:#000;position:relative}.video-player{width:100%;max-height:60vh;display:block}.video-error,.video-loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-dim);font-size:.9rem}.video-error{color:var(--red)}.video-modal-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:.75rem;gap:.75rem;padding:1rem;border-top:1px solid var(--border)}.video-info-item{display:flex;flex-direction:column;gap:.15rem}.video-info-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}.video-info-item span:last-child{font-size:.85rem}.clips-list{max-height:500px;overflow-y:auto}.clips-list::-webkit-scrollbar{width:6px}.clips-list::-webkit-scrollbar-track{background:transparent}.clips-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.clip-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border);transition:background .2s}.clip-item:hover{background:var(--surface2)}.clip-info{display:flex;flex-direction:column;gap:.3rem}.clip-header{display:flex;align-items:center;gap:.5rem}.clip-status{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:99px}.clip-status-ready{background:#22c55e20;color:var(--green)}.clip-status-pending,.clip-status-processing{background:#f59e0b20;color:var(--yellow)}.clip-status-failed{background:#ef444420;color:var(--red)}.clip-time{font-size:.85rem;font-weight:500}.clip-meta{font-size:.7rem;color:var(--text-dim)}.clip-actions{display:flex;gap:.35rem;flex-shrink:0}.clip-processing{font-size:.7rem;color:var(--yellow);font-weight:500;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.header-nav{display:flex;align-items:center;gap:.25rem}.nav-link{padding:.35rem .75rem;border-radius:6px;font-size:.85rem;font-weight:500;color:var(--text-dim);text-decoration:none;transition:color .2s,background .2s}.nav-link:hover{color:var(--text);background:var(--surface2)}.nav-link.active{color:var(--accent);background:#3b82f611}.fp-page{max-width:900px;margin:2rem auto;padding:0 1.5rem}.fp-page h1{font-size:1.4rem;font-weight:700;margin-bottom:.25rem}.fp-page .subtitle{color:var(--text-dim);font-size:.85rem}.fp-page .subtitle,.fp-upload-card{margin-bottom:1.5rem}.fp-upload-form{display:flex;flex-direction:column;gap:.75rem}.fp-form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem}.fp-form-group{display:flex;flex-direction:column;gap:.35rem}.fp-form-group label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}.fp-form-group input,.fp-form-group select{padding:.55rem .75rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.85rem;outline:none;transition:border-color .2s}.fp-form-group input:focus,.fp-form-group select:focus{border-color:var(--accent)}.fp-file-input{cursor:pointer}.fp-file-input::-webkit-file-upload-button{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);padding:.3rem .65rem;border-radius:4px;font-size:.8rem;cursor:pointer;margin-right:.5rem;-webkit-transition:background .2s;transition:background .2s}.fp-file-input::file-selector-button{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);padding:.3rem .65rem;border-radius:4px;font-size:.8rem;cursor:pointer;margin-right:.5rem;transition:background .2s}.fp-file-input::-webkit-file-upload-button:hover{background:var(--border)}.fp-file-input::file-selector-button:hover{background:var(--border)}.fp-upload-progress{font-size:.82rem;color:var(--yellow);padding:.5rem 0}.fp-upload-error{color:var(--red);background:#ef444410}.fp-upload-error,.fp-upload-success{font-size:.82rem;border-radius:4px;padding:.5rem .75rem}.fp-upload-success{color:var(--green);background:#22c55e10}.fp-list{display:flex;flex-direction:column;gap:.5rem}.fp-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--bg);border:1px solid var(--border);border-radius:8px;transition:border-color .2s}.fp-item:hover{border-color:var(--accent)}.fp-icon{width:36px;height:36px;border-radius:8px;background:#3b82f614;border:1px solid #3b82f630;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.fp-meta{flex:1 1;min-width:0}.fp-name{font-weight:600;font-size:.9rem}.fp-details{display:flex;gap:.75rem;margin-top:.2rem;font-size:.72rem;color:var(--text-dim)}.fp-category{background:#a78bfa22;color:var(--purple);font-size:.65rem;font-weight:600;padding:2px 7px;border-radius:99px;text-transform:uppercase;letter-spacing:.04em}.fp-stat{display:flex;align-items:center;gap:.25rem}.fp-audio{width:100%;max-width:520px;height:32px;margin-top:.55rem;display:block}.fp-audio-missing{margin-top:.45rem;color:var(--text-dim);font-size:.72rem}.t-lang-badge{display:inline-block;padding:1px 5px;margin-right:4px;background:#334155;color:#94a3b8;border-radius:4px;font-size:.65rem;font-family:monospace;vertical-align:middle}.clip-thumbnail{width:120px;height:68px;object-fit:cover;border-radius:4px;flex-shrink:0}@media (max-width:768px){.header{flex-direction:column;gap:.75rem;padding:.75rem 1rem}.header-left,.header-right{width:100%;justify-content:center}.detail-header{flex-direction:column;gap:.75rem}.detail-header-left,.detail-header-right{width:100%;justify-content:center}.overview-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.info-grid{grid-template-columns:1fr}.detail-tabs{overflow-x:auto}}.clips-page{max-width:1400px;margin:0 auto;padding:1.5rem}.clips-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.25rem;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.clips-search{flex:1 1;min-width:200px}.clips-search-input{width:100%;padding:.6rem 1rem;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.9rem;outline:none;transition:border-color .2s}.clips-search-input:focus{border-color:var(--accent)}.clips-search-input::placeholder{color:var(--text-dim)}.clips-filters{display:flex;flex-wrap:wrap;gap:.5rem}.filter-select{padding:.5rem .75rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.82rem;outline:none;cursor:pointer;transition:border-color .2s}.filter-select:focus{border-color:var(--accent)}.filter-select option{background:var(--surface)}.clips-count{font-size:.85rem;color:var(--text-dim);margin-bottom:1rem}.clips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1.25rem;gap:1.25rem}.clips-empty,.clips-loading{grid-column:1/-1;text-align:center;padding:3rem 1.5rem;color:var(--text-dim);font-size:.9rem}.clip-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:transform .2s,border-color .2s,box-shadow .2s}.clip-card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 8px 24px #0004}.clip-card .clip-thumbnail{position:relative;width:100%;height:0;padding-bottom:56.25%;background:#0a0e1a}.clip-card .clip-thumbnail img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.clip-card .clip-thumbnail-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:var(--text-dim)}.clip-duration{position:absolute;bottom:8px;right:8px;background:rgba(0,0,0,.8);color:#fff;padding:2px 6px;border-radius:4px;font-size:.75rem;font-weight:600}.clip-sentiment-badge{right:8px;width:28px;height:28px;border-radius:50%}.clip-favorite-toggle,.clip-sentiment-badge{position:absolute;top:8px;display:flex;align-items:center;justify-content:center;font-size:1rem}.clip-favorite-toggle{left:8px;width:32px;height:32px;border:1px solid rgba(255,255,255,.22);border-radius:50%;background:rgba(0,0,0,.72);color:#fff;cursor:pointer;line-height:1;transition:color .2s,border-color .2s,background .2s}.clip-favorite-toggle:hover{background:rgba(0,0,0,.88);border-color:rgba(255,255,255,.42)}.clip-favorite-toggle.is-favorite{color:#facc15;border-color:#facc1588}.clip-favorite-toggle--modal{position:static;width:34px;height:34px;background:var(--surface2);border-color:var(--border)}.clips-inline-error{margin-top:.45rem;color:var(--red);font-size:.78rem}.clip-card .clip-info{padding:.75rem}.clip-card .clip-title{font-size:.9rem;font-weight:600;line-height:1.3;margin-bottom:.4rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.clip-card .clip-meta{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--text-dim);margin-bottom:.3rem}.clip-card .clip-channel{color:var(--accent);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.clip-card .clip-category{background:#a78bfa22;color:var(--purple);padding:1px 6px;border-radius:99px;font-size:.65rem;font-weight:600;text-transform:uppercase}.clip-card .clip-meta-bottom{display:flex;align-items:center;gap:.6rem;font-size:.7rem;color:var(--text-dim)}.clip-card .clip-lang{background:#334155;color:#94a3b8;padding:1px 5px;border-radius:4px;font-size:.6rem;font-family:monospace}.clip-card .clip-size,.clip-card .clip-time{white-space:nowrap}.clip-match-type{font-size:.65rem;padding:.1rem .4rem;border-radius:.25rem;font-weight:500;text-transform:capitalize}.clip-match-type--keyword{background:#3b82f618;color:#60a5fa}.clip-match-type--fingerprint{background:#a855f718;color:#c084fc}.video-modal-large{max-width:1100px}.video-modal-large .video-player{max-height:65vh}.video-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:.6rem;gap:.6rem}.video-context{grid-column:1/-1;margin-top:.5rem;padding-top:.75rem;border-top:1px solid var(--border)}.video-context p{font-size:.85rem;color:var(--text-dim);line-height:1.5;margin-top:.35rem}.stats-page{max-width:1200px;margin:0 auto;padding:1.5rem}.stats-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.stats-header h1{font-size:1.4rem;font-weight:700}.stats-controls{display:flex;align-items:center;gap:1rem}.auto-refresh-toggle{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-dim);cursor:pointer}.auto-refresh-toggle input{cursor:pointer}.last-refresh{font-size:.75rem;color:var(--text-dim)}.stats-loading{text-align:center;padding:3rem;color:var(--text-dim)}.stats-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;gap:1rem}.stat-card,.stat-card-icon{display:flex;align-items:center}.stat-card-icon{font-size:1.5rem;width:48px;height:48px;justify-content:center;background:var(--surface2);border-radius:10px;flex-shrink:0}.stat-card-content{flex:1 1;min-width:0}.stat-card-value{font-size:1.5rem;font-weight:700;color:var(--text);line-height:1.2}.stat-card-total{font-size:.9rem;font-weight:400;color:var(--text-dim);margin-left:.25rem}.stat-card-label{font-size:.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.03em;margin-top:.15rem}.stats-card{margin-bottom:1rem}.workers-list{display:flex;flex-direction:column}.worker-item{padding:1rem;border-bottom:1px solid var(--border)}.worker-item:last-child{border-bottom:none}.worker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.worker-id{font-family:monospace;font-size:.85rem;font-weight:600;color:var(--accent)}.worker-stream-count{font-size:.75rem;color:var(--text-dim);background:var(--surface2);padding:2px 8px;border-radius:99px}.worker-streams{display:flex;flex-direction:column;gap:.35rem;padding-left:.5rem;border-left:2px solid var(--border);margin-left:.25rem}.worker-stream-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem;padding:.25rem 0}.worker-stream-item .stream-name{font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.stream-category-sm{font-size:.6rem;background:#a78bfa22;color:var(--purple);padding:1px 5px;border-radius:99px;text-transform:uppercase}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.status-running{background:var(--green)}.status-dot.status-stopped{background:var(--red)}.status-dot.status-reconnecting{background:var(--yellow)}.stream-heartbeat{font-size:.7rem;color:var(--text-dim);margin-left:auto}.queue-stats{display:flex;gap:2rem}.queue-stat{display:flex;flex-direction:column;gap:.25rem}.queue-stat-label{font-size:.75rem;color:var(--text-dim);text-transform:uppercase}.queue-stat-value{font-size:1.25rem;font-weight:700;color:var(--accent)}.status-distribution{display:flex;flex-direction:column;gap:.75rem}.status-bar-item{display:flex;align-items:center;gap:.75rem}.status-bar-item .status-pill{min-width:100px;text-align:center}.status-bar{flex:1 1;height:8px;background:var(--surface2);border-radius:4px;overflow:hidden}.status-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.status-bar-fill.status-running{background:var(--green)}.status-bar-fill.status-stopped{background:var(--red)}.status-bar-fill.status-reconnecting{background:var(--yellow)}.status-count{font-size:.85rem;font-weight:600;min-width:30px;text-align:right}.current-usage{margin-bottom:1.5rem}.current-usage h3,.predictions-table-container h3{font-size:.9rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.75rem}.usage-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:1rem;gap:1rem}.usage-item{display:flex;flex-direction:column;gap:.2rem;padding:.75rem;background:var(--bg);border-radius:8px}.usage-label{font-size:.7rem;color:var(--text-dim);text-transform:uppercase}.usage-value{font-size:1.1rem;font-weight:600;color:var(--accent)}.predictions-table-container{margin-top:1rem}.predictions-note{font-size:.8rem;color:var(--text-dim);margin-bottom:1rem;font-style:italic}.predictions-table{width:100%;border-collapse:collapse;font-size:.85rem}.predictions-table td,.predictions-table th{padding:.6rem .75rem;text-align:left;border-bottom:1px solid var(--border)}.predictions-table th{font-size:.75rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.03em}.predictions-table th,.predictions-table tr:hover td{background:var(--surface2)}.predictions-table td{color:var(--text)}.totals-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:1rem;gap:1rem}.total-item{display:flex;flex-direction:column;gap:.25rem;padding:1rem;background:var(--bg);border-radius:8px;text-align:center}.total-label{font-size:.75rem;color:var(--text-dim);text-transform:uppercase}.total-value{font-size:1.75rem;font-weight:700;color:var(--accent)}.config-page{max-width:900px;margin:2rem auto;padding:0 1.5rem}.config-page h1{font-size:1.4rem;font-weight:700;margin-bottom:.25rem}.config-page .subtitle{color:var(--text-dim);font-size:.85rem;margin-bottom:1.5rem}.config-form-card{margin-bottom:1.5rem}.config-form{display:flex;flex-direction:column;gap:1rem}.config-form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem}.config-form-group{display:flex;flex-direction:column;gap:.35rem}.config-form-group label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}.config-form-group input,.config-form-group select{padding:.6rem .85rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.9rem;outline:none;transition:border-color .2s}.config-form-group input:focus,.config-form-group select:focus{border-color:var(--accent)}.config-form-group input::placeholder{color:var(--text-dim)}.config-form-group select{cursor:pointer}.config-form-group select option{background:var(--surface)}.config-form-url{grid-column:1/-1}.url-input-row{display:flex;gap:.5rem}.url-input-row input{flex:1 1}.url-input-row input.input-disabled{background:var(--surface2);color:var(--text-dim);cursor:not-allowed}.input-hint{font-size:.75rem;color:var(--text-dim);margin-top:.25rem;font-style:italic}.validation-result{display:flex;align-items:center;gap:.5rem;padding:.65rem .85rem;border-radius:6px;font-size:.85rem}.validation-result.valid{background:#22c55e12;border:1px solid #22c55e30;color:var(--green)}.validation-result.invalid{background:#ef444412;border:1px solid #ef444430;color:var(--red)}.validation-icon{font-weight:700;font-size:1rem}.validation-details{font-size:.78rem;color:var(--text-dim)}.config-error{padding:.65rem .85rem;background:#ef444412;border:1px solid #ef444430;border-radius:6px;color:var(--red);font-size:.85rem}.config-form-actions{display:flex;justify-content:flex-start;gap:.5rem;margin-top:.5rem}.config-list{display:flex;flex-direction:column}.config-item{display:flex;align-items:flex-start;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--border);transition:background .2s}.config-item:last-child{border-bottom:none}.config-item:hover{background:var(--surface2)}.config-item-info{flex:1 1;min-width:0}.config-item-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.35rem}.config-item-name{font-weight:600;font-size:.95rem}.config-item-category{font-size:.65rem;background:#a78bfa22;color:var(--purple);padding:2px 7px;border-radius:99px;font-weight:600;text-transform:uppercase}.config-item-url{font-size:.8rem;color:var(--accent);font-family:monospace;word-break:break-all;margin-bottom:.35rem}.config-item-meta{font-size:.72rem;color:var(--text-dim)}.config-item-actions{display:flex;gap:.35rem;margin-left:1rem;flex-shrink:0}@media (max-width:768px){.config-form-row{grid-template-columns:1fr}.config-item{flex-direction:column;gap:.75rem}.config-item-actions{margin-left:0;width:100%}.config-item-actions .btn{flex:1 1}}.t-sentiment{margin-right:.35rem;font-size:.9rem}.m-type-icon{font-size:.85rem;margin-right:.25rem}.m-item-fingerprint{background:#3b82f60c;border-color:#3b82f622}.m-kw-fp{background:#3b82f622;color:var(--accent)}.m-sentiment{font-size:.85rem;margin-left:.25rem}.m-confidence{font-size:.75rem;color:var(--text-dim);font-style:italic}.m-item{padding:.6rem .75rem;border-radius:6px;margin:.4rem .75rem;background:#7c3aed0c;border:1px solid #7c3aed22;animation:fadeIn .3s ease}.stream-category{font-size:.65rem;background:#a78bfa22;color:var(--purple);padding:2px 6px;border-radius:99px;text-transform:uppercase}.dashboard-actions{display:flex;gap:.75rem;margin-bottom:1rem}.dashboard-actions .btn{display:flex;align-items:center;gap:.5rem;text-decoration:none}.form-select{padding:.55rem .75rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.85rem;outline:none;cursor:pointer;transition:border-color .2s;min-width:100px}.form-select:focus{border-color:var(--accent)}.form-select option{background:var(--surface)}.stream-selector{width:100%;min-width:0}.stream-hint{font-size:.8rem;color:var(--text-dim);margin-top:.5rem}.stream-hint a{color:var(--accent);text-decoration:none}.stream-hint a:hover{text-decoration:underline}.autocomplete-wrapper{position:relative;flex:1 1}.autocomplete-input{width:100%}.autocomplete-dropdown{max-height:250px;background:var(--surface);border-radius:0 0 6px 6px;box-shadow:0 8px 24px #0004}.autocomplete-item{padding:.65rem .85rem;border-bottom:1px solid var(--border)}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item.highlighted,.autocomplete-item:hover{background:var(--surface2)}.autocomplete-item-name{font-weight:600;font-size:.9rem}.autocomplete-item-url{font-size:.75rem;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.autocomplete-item-category{font-size:.65rem;background:#a78bfa22;color:var(--purple);padding:1px 6px;border-radius:99px;margin-left:.5rem}.autocomplete-empty{padding:.75rem;text-align:center;color:var(--text-dim);font-size:.85rem}.autocomplete-create{padding:.65rem .85rem;cursor:pointer;background:#3b82f610;border-top:1px solid var(--border);color:var(--accent);font-size:.85rem;display:flex;align-items:center;gap:.5rem;transition:background .15s}.autocomplete-create:hover{background:#3b82f620}.clips-panel-wrapper{display:flex;gap:1rem;align-items:flex-start}.clips-panel-main{flex:1 1;min-width:0}.clips-scroll{max-height:600px;overflow-y:auto}.clips-scroll::-webkit-scrollbar{width:6px}.clips-scroll::-webkit-scrollbar-track{background:transparent}.clips-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.clips-type-filter{display:flex;gap:.35rem;align-items:center;flex-wrap:wrap}.has-active{position:relative}.has-active:after{content:"";position:absolute;top:3px;right:3px;width:6px;height:6px;border-radius:50%;background:var(--accent)}.filter-panel-side{width:220px;min-width:220px;flex-shrink:0}.filter-panel-side .filter-panel-head{display:flex;align-items:center;justify-content:space-between;padding:.65rem .85rem;border-bottom:1px solid var(--border);background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;border:1px solid var(--border)}.filter-panel-side .filter-panel-body{background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);padding:.85rem;display:flex;flex-direction:column;gap:.75rem}.filter-panel-side .filter-select{width:100%}.filter-panel{width:0;min-width:0;overflow:hidden;opacity:0;transition:width .25s ease,opacity .2s ease,min-width .25s ease;flex-shrink:0}.filter-panel.open{width:240px;min-width:240px;opacity:1}.filter-panel-head{display:flex;align-items:center;justify-content:space-between;padding:.65rem .85rem;background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;border-bottom:1px solid var(--border);border:1px solid var(--border)}.filter-panel-head h3{font-size:.85rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.filter-panel-body{background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);padding:.85rem;gap:.75rem}.filter-group,.filter-panel-body{display:flex;flex-direction:column}.filter-group{gap:.3rem}.filter-group label{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);font-weight:600}.m-type-badge{display:inline-flex;align-items:center;gap:.2rem;font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:4px;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.m-type-badge[data-type=keyword]{background:#a78bfa22;color:var(--purple)}.m-type-badge[data-type=fingerprint]{background:#3b82f622;color:var(--accent)}.popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);z-index:500;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.popup-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0008;animation:slideIn .25s ease}.popup-header{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.15rem;border-bottom:1px solid var(--border)}.popup-header h2{font-size:1rem;font-weight:700}.popup-close{background:none;border:none;color:var(--text-dim);font-size:1.3rem;cursor:pointer;padding:.1rem .35rem;border-radius:4px;line-height:1;transition:background .2s,color .2s}.popup-close:hover{background:var(--surface2);color:var(--text)}.popup-body{padding:1.15rem}.config-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.config-page-header>div{flex:1 1}.config-search-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.6rem .85rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.config-search-input{flex:1 1;padding:.5rem .75rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.88rem;outline:none;transition:border-color .2s}.config-search-input:focus{border-color:var(--accent)}.config-search-input::placeholder{color:var(--text-dim)}.config-search-count{font-size:.78rem;color:var(--text-dim);white-space:nowrap}.empty-state-link{color:var(--accent);text-decoration:none;font-weight:600}.empty-state-link:hover{text-decoration:underline}@media (max-width:768px){.sidebar{width:var(--sidebar-w-collapsed)}.sidebar .sidebar-link-label,.sidebar .sidebar-logo h1,.sidebar-status span{display:none}.main-content{margin-left:var(--sidebar-w-collapsed)}.filter-panel.open{width:200px;min-width:200px}.clips-panel-wrapper{flex-direction:column}.filter-panel-side,.filter-panel.open{width:100%;min-width:100%}}.video-transcript{border-top:1px solid var(--border)}.video-transcript-head{padding:.65rem 1rem;border-bottom:1px solid var(--border)}.video-transcript-body{max-height:600px;overflow-y:auto;padding:.5rem 0}.video-transcript-body::-webkit-scrollbar{width:6px}.video-transcript-body::-webkit-scrollbar-track{background:transparent}.video-transcript-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.transcript-line{display:flex;gap:.6rem;padding:.35rem 1rem;font-size:.84rem;line-height:1.5;cursor:pointer;border-left:3px solid transparent;transition:background .15s,border-color .15s}.transcript-line:hover{background:var(--surface2)}.transcript-line.active{background:#3b82f610;border-left-color:var(--accent)}.transcript-time{color:var(--text-dim);font-size:.72rem;font-family:monospace;min-width:3rem;flex-shrink:0;padding-top:2px}.transcript-text{color:var(--text)}.transcript-line.active .transcript-text{color:var(--text);font-weight:500}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;background:var(--card);border:1px solid var(--border);border-radius:.5rem;margin-top:.25rem;max-height:240px;overflow-y:auto;box-shadow:0 4px 16px rgba(0,0,0,.3)}.autocomplete-item{display:flex;justify-content:space-between;align-items:center;padding:.55rem .75rem;cursor:pointer;font-size:.85rem;transition:background .15s}.autocomplete-item.highlighted,.autocomplete-item:hover{background:var(--hover)}.autocomplete-name{color:var(--text);font-weight:500}.autocomplete-meta{color:var(--text-dim);font-size:.75rem}.settings-duration-preview{margin-top:.5rem}.settings-duration-bar{display:flex;align-items:stretch;border-radius:6px;overflow:hidden;font-size:.75rem;font-weight:600;min-height:2rem}.settings-duration-before{background:#3b82f622;color:var(--accent);padding:.35rem .5rem}.settings-duration-before,.settings-duration-marker{display:flex;align-items:center;justify-content:center;white-space:nowrap}.settings-duration-marker{background:var(--accent);color:#fff;padding:.35rem .75rem;font-size:.7rem;letter-spacing:.05em;flex-shrink:0}.settings-duration-after{background:#22c55e22;color:var(--green);display:flex;align-items:center;justify-content:center;padding:.35rem .5rem;white-space:nowrap}.settings-duration-total{text-align:center;font-size:.8rem;color:var(--text-dim);margin-top:.5rem}.settings-retention-panel{margin-top:1rem;padding:1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface2)}.settings-retention-panel h3{font-size:.95rem;margin-bottom:.35rem}.settings-retention-panel p{color:var(--text-dim);font-size:.85rem;margin-bottom:.75rem}.settings-retention-controls{display:grid;grid-template-columns:minmax(120px,180px) minmax(120px,180px);grid-gap:.75rem;gap:.75rem;margin-bottom:.75rem}.settings-retention-controls input,.settings-retention-controls select{width:100%;padding:.6rem .75rem;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text)}