:root{--bg: #282a36;--bg-darker: #1e1f29;--current-line: #44475a;--foreground: #f8f8f2;--comment: #6272a4;--cyan: #8be9fd;--green: #50fa7b;--orange: #ffb86c;--pink: #ff79c6;--purple: #bd93f9;--red: #ff5555;--yellow: #f1fa8c;--font: "JetBrains Mono", monospace;--radius: 6px;--transition: .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-text-size-adjust:100%}body{font-family:var(--font);background:var(--bg);color:var(--foreground);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh}a{color:var(--cyan);text-decoration:none}a:hover{text-decoration:underline}button{font-family:var(--font);font-size:.85rem;cursor:pointer;border:1px solid var(--comment);background:var(--current-line);color:var(--foreground);padding:.5rem 1rem;border-radius:var(--radius);transition:background var(--transition),border-color var(--transition)}button:hover:not(:disabled){background:var(--comment);border-color:var(--purple)}button:disabled{opacity:.5;cursor:not-allowed}input,select,textarea{font-family:var(--font);font-size:.85rem;background:var(--bg-darker);color:var(--foreground);border:1px solid var(--comment);border-radius:var(--radius);padding:.5rem .75rem;outline:none;transition:border-color var(--transition)}input:focus,select:focus,textarea:focus{border-color:var(--purple)}input::placeholder{color:var(--comment)}label{font-size:.8rem;color:var(--comment);font-weight:500;display:block;margin-bottom:.25rem}h1,h2,h3{font-weight:700;color:var(--foreground)}hr{border:none;border-top:1px solid var(--current-line);margin:1rem 0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-darker)}::-webkit-scrollbar-thumb{background:var(--comment);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--purple)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.login-card{background:var(--current-line);border:1px solid var(--comment);border-radius:var(--radius);padding:2.5rem 2rem;width:100%;max-width:380px}.login-title{font-size:1.5rem;color:var(--purple);margin-bottom:.25rem}.login-subtitle{color:var(--comment);font-size:.85rem;margin-bottom:1.5rem}.login-error{background:#ff555526;border:1px solid var(--red);color:var(--red);padding:.5rem .75rem;border-radius:var(--radius);font-size:.8rem;margin-bottom:1rem}.login-form{display:flex;flex-direction:column;gap:.75rem}.login-form input{width:100%}.login-form button[type=submit]{background:var(--purple);border-color:var(--purple);color:var(--bg);font-weight:700}.login-form button[type=submit]:hover:not(:disabled){background:var(--pink);border-color:var(--pink)}.btn-secondary{background:transparent;border-color:var(--comment);color:var(--comment)}.btn-secondary:hover:not(:disabled){color:var(--foreground);border-color:var(--foreground);background:transparent}.dashboard{min-height:100vh;display:flex;flex-direction:column}.dash-header{display:flex;align-items:center;gap:1rem;padding:.75rem 1.25rem;background:var(--bg-darker);border-bottom:1px solid var(--current-line);position:sticky;top:0;z-index:100}.dash-title{font-size:1.1rem;color:var(--purple);flex:1}.btn-logout{background:transparent;border-color:var(--red);color:var(--red);font-size:.75rem;padding:.35rem .75rem}.btn-logout:hover{background:var(--red);color:var(--bg)}.hamburger{display:none;flex-direction:column;gap:4px;background:transparent;border:none;padding:.25rem;cursor:pointer}.hamburger span{display:block;width:20px;height:2px;background:var(--foreground);border-radius:1px}.dash-body{display:flex;flex:1;overflow:hidden}.dash-sidebar{width:180px;min-width:180px;background:var(--bg-darker);border-right:1px solid var(--current-line);padding:.5rem 0;display:flex;flex-direction:column}.nav-item{display:block;width:100%;text-align:left;background:transparent;border:none;border-radius:0;padding:.75rem 1.25rem;color:var(--comment);font-size:.85rem;transition:background var(--transition),color var(--transition)}.nav-item:hover{background:var(--current-line);color:var(--foreground)}.nav-item.active{color:var(--purple);background:var(--current-line);border-left:3px solid var(--purple)}.dash-content{flex:1;padding:1.25rem;overflow-y:auto;max-height:calc(100vh - 52px)}.table-tabs{display:flex;gap:.25rem;margin-bottom:1rem;flex-wrap:wrap}.table-tab{background:var(--bg-darker);border:1px solid var(--current-line);color:var(--comment);padding:.4rem 1rem;font-size:.8rem;border-radius:var(--radius) var(--radius) 0 0}.table-tab:hover{color:var(--foreground);border-color:var(--comment)}.table-tab.active{background:var(--current-line);color:var(--cyan);border-color:var(--cyan);border-bottom-color:var(--current-line)}.table-actions-bar{margin-bottom:.75rem}.btn-add-stream{background:var(--green);border-color:var(--green);color:var(--bg);font-weight:700;font-size:.8rem}.btn-add-stream:hover:not(:disabled){background:var(--cyan);border-color:var(--cyan)}.data-table-container{background:var(--bg-darker);border:1px solid var(--current-line);border-radius:var(--radius);overflow:hidden}.data-table-toolbar{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-bottom:1px solid var(--current-line);flex-wrap:wrap}.row-count{color:var(--comment);font-size:.75rem;margin-left:auto}.table-error{display:flex;align-items:center;gap:.5rem;background:#ff555526;border-bottom:1px solid var(--red);color:var(--red);padding:.5rem .75rem;font-size:.8rem}.dismiss-btn{background:transparent;border:none;color:var(--red);font-size:1rem;padding:0;margin-left:auto;cursor:pointer}.data-table-scroll{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.8rem}.data-table th{text-align:left;padding:.6rem .75rem;background:var(--current-line);color:var(--comment);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border-bottom:1px solid var(--comment);position:sticky;top:0;z-index:1}.data-table td{padding:.5rem .75rem;border-bottom:1px solid var(--current-line);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.data-table tr:hover{background:#44475a4d}.adding-row{background:#50fa7b0d}.adding-row td{padding:.35rem .5rem}.editable-cell{cursor:pointer;transition:background var(--transition)}.editable-cell:hover{background:#8be9fd14}.id-col{color:var(--comment);font-size:.75rem}.cell-empty{color:var(--comment);opacity:.5}.cell-color{display:inline-flex;align-items:center;gap:.4rem}.color-swatch{display:inline-block;width:14px;height:14px;border-radius:3px;border:1px solid var(--comment);vertical-align:middle}.cell-icon{width:24px;height:24px;border-radius:3px;object-fit:cover}.cell-edit-input{width:100%;min-width:80px;padding:.3rem .5rem;font-size:.8rem}.actions-col{white-space:nowrap;width:1%}.btn-save{background:var(--green);border-color:var(--green);color:var(--bg);font-size:.7rem;padding:.25rem .6rem;margin-right:.25rem}.btn-cancel{background:transparent;border-color:var(--comment);color:var(--comment);font-size:.7rem;padding:.25rem .6rem}.btn-delete{background:transparent;border-color:var(--red);color:var(--red);font-size:.7rem;padding:.25rem .6rem}.btn-delete:hover:not(:disabled){background:var(--red);color:var(--bg)}.empty-row{text-align:center;color:var(--comment);padding:2rem 1rem}.status-section h2,.logs-section h2,.actions-section h2{font-size:1.1rem;margin-bottom:1rem;color:var(--cyan)}.status-card{margin-top:1rem;background:var(--bg-darker);border:1px solid var(--current-line);border-radius:var(--radius);padding:1rem}.status-error{color:var(--red)}.status-json{font-size:.8rem;white-space:pre-wrap;word-break:break-all;color:var(--green)}.log-viewer{display:flex;flex-direction:column;gap:.75rem}.log-toolbar{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;justify-content:space-between}.log-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.auto-refresh-toggle{display:flex;align-items:center;gap:.4rem;color:var(--foreground);font-size:.8rem;cursor:pointer}.auto-refresh-toggle input{width:auto}.log-filters{display:flex;gap:.25rem;flex-wrap:wrap}.log-filter-btn{font-size:.7rem;padding:.25rem .6rem;background:transparent;border-color:var(--current-line);color:var(--comment)}.log-filter-btn.active{background:var(--current-line);border-color:var(--purple);color:var(--purple)}.log-output{background:var(--bg-darker);border:1px solid var(--current-line);border-radius:var(--radius);padding:.75rem;max-height:calc(100vh - 250px);min-height:300px;overflow-y:auto;font-size:.75rem;line-height:1.6}.log-line{white-space:pre-wrap;word-break:break-all}.log-error{color:var(--red)}.log-warning{color:var(--orange)}.log-debug{color:var(--comment)}.action-msg{background:#50fa7b1a;border:1px solid var(--green);color:var(--green);padding:.5rem .75rem;border-radius:var(--radius);font-size:.8rem;margin-bottom:1rem}.actions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.action-card{background:var(--bg-darker);border:1px solid var(--current-line);border-radius:var(--radius);padding:1.25rem}.action-card h3{font-size:.95rem;margin-bottom:.5rem;color:var(--orange)}.action-card p{color:var(--comment);font-size:.8rem;margin-bottom:1rem}.action-card button{background:var(--orange);border-color:var(--orange);color:var(--bg);font-weight:700}.action-card button:hover:not(:disabled){background:var(--yellow);border-color:var(--yellow)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal-content{background:var(--bg);border:1px solid var(--comment);border-radius:var(--radius);width:100%;max-width:640px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--current-line)}.modal-header h2{font-size:1rem;color:var(--cyan)}.modal-close{background:transparent;border:none;color:var(--comment);font-size:1.5rem;padding:0;line-height:1;cursor:pointer}.modal-close:hover{color:var(--red)}.modal-body{padding:1.25rem}.modal-divider{margin:1.25rem 0}.lookup-section label{margin-bottom:.5rem}.lookup-row{display:flex;gap:.5rem}.lookup-row input{flex:1}.lookup-result{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem;background:#50fa7b14;border-radius:var(--radius);color:var(--green);font-size:.85rem}.lookup-icon{width:28px;height:28px;border-radius:50%}.field-error{color:var(--red);font-size:.75rem;margin-top:.25rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.form-field label{margin-bottom:.25rem}.form-field input{width:100%}.form-field.full-width{grid-column:1 / -1}.color-input-row{display:flex;gap:.5rem;align-items:center}.color-input-row input[type=color]{width:36px;height:32px;padding:2px;cursor:pointer}.color-input-row input[type=text]{flex:1}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--current-line)}.modal-actions button[type=submit]{background:var(--green);border-color:var(--green);color:var(--bg);font-weight:700}.modal-actions button[type=submit]:hover:not(:disabled){background:var(--cyan);border-color:var(--cyan)}.add-stream-form{display:flex;flex-direction:column}@media(max-width:768px){.hamburger{display:flex}.dash-sidebar{position:fixed;top:52px;left:0;bottom:0;z-index:90;transform:translate(-100%);transition:transform .2s ease;box-shadow:4px 0 12px #0000004d}.dash-sidebar.open{transform:translate(0)}.dash-content{padding:.75rem;max-height:calc(100vh - 52px)}.table-tabs{gap:.15rem}.table-tab{padding:.35rem .6rem;font-size:.7rem}.data-table td,.data-table th{padding:.4rem .5rem;font-size:.7rem}.form-grid{grid-template-columns:1fr}.modal-content{max-width:100%}.log-toolbar{flex-direction:column;align-items:flex-start}.actions-grid{grid-template-columns:1fr}}
