*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #07070a;--surface: #0d0d13;--elevated: #13131b;--border: #1c1c28;--border-light: #262636;--accent: #7c6af7;--accent-dim: rgba(124, 106, 247, .12);--accent-glow: rgba(124, 106, 247, .25);--live: #00e676;--live-dim: rgba(0, 230, 118, .08);--spike: #ff6040;--spike-dim: rgba(255, 96, 64, .1);--warn: #f5a623;--warn-dim: rgba(245, 166, 35, .1);--text: #dddce9;--text-2: #7070888;--text-muted: #3c3c52;--font-ui: "Syne", sans-serif;--font-mono: "JetBrains Mono", monospace;--r: 6px;--r-lg: 10px}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-ui);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:240px;min-width:240px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.sidebar-logo{padding:20px 18px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.sidebar-logo-mark{width:28px;height:28px;background:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:#fff;font-family:var(--font-ui);letter-spacing:-.5px;flex-shrink:0}.sidebar-logo-name{font-size:15px;font-weight:700;letter-spacing:.04em;color:var(--text);text-transform:uppercase}.sidebar-sessions{flex:1;overflow-y:auto;padding:8px 0}.sidebar-sessions::-webkit-scrollbar{width:4px}.sidebar-sessions::-webkit-scrollbar-track{background:transparent}.sidebar-sessions::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:2px}.session-item{padding:10px 14px;cursor:pointer;border-left:2px solid transparent;transition:background .15s,border-color .15s;position:relative}.session-item:hover{background:var(--elevated)}.session-item.active{background:var(--elevated);border-left-color:var(--accent)}.session-item-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.status-dot.live{background:var(--live);box-shadow:0 0 6px var(--live);animation:pulse-dot 2s ease-in-out infinite}.status-dot.starting{background:var(--warn);animation:pulse-dot 1s ease-in-out infinite}.status-dot.offline{background:var(--text-muted)}.status-dot.error{background:var(--spike)}.status-dot.stopped{background:var(--text-muted);opacity:.4}@keyframes pulse{0%,to{opacity:.35}50%{opacity:.65}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.3}}.session-item-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.session-item-platform{font-size:10px;color:var(--text-muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em}.session-mini-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin-bottom:5px}.session-mini-bar-fill{height:100%;border-radius:2px;transition:width .5s ease,background .3s}.session-item-meta{display:flex;align-items:center;justify-content:space-between}.session-item-rate{font-size:11px;font-family:var(--font-mono);color:var(--text-2, #888)}.session-clip-badge{font-size:10px;font-family:var(--font-mono);background:var(--accent-dim);color:var(--accent);padding:1px 6px;border-radius:10px;font-weight:600}.session-stop-btn{position:absolute;top:8px;right:10px;opacity:0;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:2px 4px;border-radius:4px;transition:opacity .15s,color .15s}.session-item:hover .session-stop-btn{opacity:1}.session-stop-btn:hover{color:var(--spike)}.sidebar-footer{padding:12px 14px;border-top:1px solid var(--border)}.btn-add{width:100%;padding:9px 12px;background:var(--accent-dim);border:1px solid rgba(124,106,247,.2);border-radius:var(--r);color:var(--accent);font-family:var(--font-ui);font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:background .15s,border-color .15s;letter-spacing:.02em}.btn-add:hover{background:#7c6af733;border-color:#7c6af766}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-muted);padding:40px;text-align:center}.empty-icon{font-size:48px;opacity:.3;line-height:1}.empty-state h2{font-size:18px;font-weight:700;color:var(--text-2, #888);letter-spacing:.02em}.empty-state p{font-size:13px;color:var(--text-muted);max-width:260px;line-height:1.6}.btn-primary{padding:10px 20px;background:var(--accent);border:none;border-radius:var(--r);color:#fff;font-family:var(--font-ui);font-size:13px;font-weight:700;cursor:pointer;letter-spacing:.03em;transition:opacity .15s,transform .1s}.btn-primary:hover{opacity:.88}.btn-primary:active{transform:scale(.97)}.monitor-view{padding:20px 24px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.monitor-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.monitor-channel{font-size:20px;font-weight:800;letter-spacing:.02em;text-transform:uppercase}.live-badge{padding:3px 8px;background:var(--live-dim);border:1px solid rgba(0,230,118,.2);border-radius:4px;font-size:10px;font-weight:700;font-family:var(--font-mono);color:var(--live);letter-spacing:.1em;text-transform:uppercase}.monitor-viewers{font-size:12px;font-family:var(--font-mono);color:var(--text-muted);margin-left:auto}.monitor-title{font-size:12px;color:var(--text-muted);margin-bottom:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--font-mono)}.chart-wrap{background:var(--elevated);border:1px solid var(--border);border-radius:var(--r-lg);padding:12px 12px 4px;margin-bottom:16px;position:relative;overflow:hidden}.chart-canvas{width:100%;display:block}.chart-label{position:absolute;top:10px;left:14px;font-size:10px;font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.chart-warmup-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#07070a99;display:flex;align-items:center;justify-content:center;font-size:12px;font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.06em;border-radius:var(--r-lg)}.stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.stat-box{background:var(--elevated);border:1px solid var(--border);border-radius:var(--r);padding:10px 12px}.stat-label{font-size:10px;font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}.stat-value{font-size:18px;font-family:var(--font-mono);font-weight:600;color:var(--text);line-height:1.2}.stat-value.highlight{color:var(--accent)}.stat-value.spike{color:var(--spike)}.stat-value.live{color:var(--live)}.warmup-bar-wrap{margin-top:10px;display:flex;align-items:center;gap:10px}.warmup-bar{flex:1;height:3px;background:var(--border);border-radius:2px;overflow:hidden}.warmup-bar-fill{height:100%;background:var(--warn);border-radius:2px;transition:width 1s linear}.warmup-label{font-size:11px;font-family:var(--font-mono);color:var(--warn);white-space:nowrap}.spikes-log{padding:10px 24px;border-bottom:1px solid var(--border);flex-shrink:0;max-height:110px;overflow-y:auto}.spikes-log::-webkit-scrollbar{width:3px}.spikes-log::-webkit-scrollbar-thumb{background:var(--border-light)}.spikes-log-title{font-size:10px;font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}.spike-entry{display:flex;align-items:center;gap:10px;padding:4px 0;border-bottom:1px solid var(--border);font-size:12px;font-family:var(--font-mono);animation:fade-in .3s ease}.spike-entry:last-child{border-bottom:none}@keyframes fade-in{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}.spike-time{color:var(--text-muted);font-size:11px;min-width:54px}.spike-ratio{color:var(--spike);font-weight:600;min-width:48px}.spike-rate{color:var(--text-2, #888)}.spike-id{color:var(--text-muted);font-size:10px;margin-left:auto;opacity:.6}.clips-section{flex:1;overflow-y:auto;padding:16px 24px 24px}.clips-section::-webkit-scrollbar{width:6px}.clips-section::-webkit-scrollbar-track{background:transparent}.clips-section::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}.clips-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}.clips-title{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-2, #888);font-family:var(--font-mono)}.clips-count{font-size:11px;font-family:var(--font-mono);background:var(--accent-dim);color:var(--accent);padding:2px 7px;border-radius:10px;font-weight:600}.clips-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.clip-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:border-color .2s,transform .15s}.clip-card:hover{border-color:var(--border-light);transform:translateY(-1px)}.clip-card.new-clip{animation:clip-appear .4s ease;border-color:#7c6af766}@keyframes clip-appear{0%{opacity:0;transform:translateY(8px);border-color:var(--accent)}60%{border-color:var(--accent)}to{opacity:1;transform:translateY(0);border-color:var(--border)}}.clip-video-wrap{position:relative;background:#000;aspect-ratio:16/9;cursor:pointer;overflow:hidden}.clip-video{width:100%;height:100%;display:block;object-fit:cover}.clip-play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0006;transition:opacity .2s}.clip-video-wrap:hover .clip-play-overlay,.clip-video-wrap.playing .clip-play-overlay{opacity:0}.clip-play-btn{width:44px;height:44px;border-radius:50%;background:#ffffff26;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1.5px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff}.clip-spike-badge{position:absolute;top:8px;right:8px;background:var(--spike);color:#fff;font-size:10px;font-family:var(--font-mono);font-weight:600;padding:2px 6px;border-radius:4px;letter-spacing:.04em}.clip-body{padding:12px}.clip-meta{display:flex;align-items:center;gap:8px;margin-bottom:8px}.clip-duration{font-size:11px;font-family:var(--font-mono);color:var(--text-muted);background:var(--elevated);padding:2px 6px;border-radius:4px}.clip-size{font-size:11px;font-family:var(--font-mono);color:var(--text-muted)}.clip-time{font-size:10px;font-family:var(--font-mono);color:var(--text-muted);margin-left:auto}.clip-description{font-size:12px;line-height:1.6;color:var(--text-2, #888);margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.clip-description.expanded{display:block;-webkit-line-clamp:unset}.clip-expand-btn{background:none;border:none;color:var(--accent);font-size:11px;font-family:var(--font-mono);cursor:pointer;padding:0;margin-bottom:8px;display:block}.clip-actions{display:flex;gap:6px}.btn-clip{flex:1;padding:7px 10px;border-radius:var(--r);font-family:var(--font-ui);font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;transition:opacity .15s;text-decoration:none;border:none}.btn-clip:hover{opacity:.75}.btn-download{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(124,106,247,.2)}.btn-delete{background:var(--spike-dim);color:var(--spike);border:1px solid rgba(255,96,64,.15);flex:0 0 auto;width:36px}.no-clips{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;gap:10px;color:var(--text-muted);text-align:center}.no-clips-icon{font-size:32px;opacity:.25}.no-clips p{font-size:12px;font-family:var(--font-mono);letter-spacing:.04em}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:overlay-in .15s ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--r-lg);width:100%;max-width:400px;padding:24px;animation:modal-in .2s ease}@keyframes modal-in{0%{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-title{font-size:16px;font-weight:700;letter-spacing:.04em;margin-bottom:20px}.form-group{margin-bottom:14px}.form-label{display:block;font-size:11px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:6px}.form-input,.form-select,.form-textarea{width:100%;background:var(--elevated);border:1px solid var(--border-light);border-radius:var(--r);padding:9px 12px;color:var(--text);font-family:var(--font-ui);font-size:13px;outline:none;transition:border-color .15s}.form-textarea{resize:vertical;min-height:72px;font-size:12px;line-height:1.5}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' fill='none' stroke='%237070887' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}.modal-error{font-size:12px;color:var(--spike);font-family:var(--font-mono);margin-bottom:14px;padding:8px 10px;background:var(--spike-dim);border-radius:var(--r);border:1px solid rgba(255,96,64,.2)}.modal-actions{display:flex;gap:8px;margin-top:20px}.btn-cancel{flex:1;padding:10px;background:var(--elevated);border:1px solid var(--border-light);border-radius:var(--r);color:var(--text-2, #888);font-family:var(--font-ui);font-size:13px;font-weight:600;cursor:pointer;transition:border-color .15s}.btn-cancel:hover{border-color:var(--border);color:var(--text)}.btn-submit{flex:2;padding:10px;background:var(--accent);border:none;border-radius:var(--r);color:#fff;font-family:var(--font-ui);font-size:13px;font-weight:700;cursor:pointer;letter-spacing:.03em;transition:opacity .15s;display:flex;align-items:center;justify-content:center;gap:6px}.btn-submit:hover{opacity:.88}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
