:root{
  --bg:#0f172a; --panel:#111827; --card:#0b1323; --muted:#9ca3af; --text-muted:#94a3b8; --fg:#e5e7eb; --accent:#10b981; --danger:#ef4444; --border:#1f2937;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif}
body.wait-cursor,body.wait-cursor *{cursor:wait!important}
.btn.is-loading{opacity:.7;pointer-events:none}
.btn.btn-success{background:#166534;border-color:#14532d;color:#ecfdf5}
.btn.btn-success:hover{background:#15803d;border-color:#166534}
a{color:inherit;text-decoration:none}

.topbar{position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#0b1220;border-bottom:1px solid var(--border);z-index:10}
.brand{font-weight:700;color:#fff}
.nav{display:flex;gap:.75rem;align-items:center}
.nav a{padding:.4rem .6rem;border-radius:.4rem;color:var(--muted);border:1px solid transparent}
.topbar .nav a{display:flex;align-items:center;gap:.35rem;white-space:nowrap}
.topbar .nav a .icon{flex:0 0 auto}
/* Dark theme: make topbar active link higher contrast */
.topbar .nav a.active{background:#111f38;border-color:#2563eb;color:#eaf2ff;box-shadow:inset 0 0 0 1px #2563eb}
.nav a.right{margin-left:1rem;color:#cbd5e1}
.nav .nav-right{display:flex;gap:.5rem;align-items:center}
.nav #global-search{width:220px}

.container{max-width:1200px;margin:1rem auto;padding:0 1rem}
.container.with-sidebar{transition:margin-left .2s ease}

/* Admin Sidebar (scoped) */
/* Autohide styles removed per revert */
.admin-ui .sidebar{position:fixed;inset:0 auto 0 0;width:260px;background:#0b1220;border-right:1px solid var(--border);transform:translateX(-100%);transition:transform .2s ease;z-index:20}
.admin-ui .sidebar.open{transform:translateX(0)}
.admin-ui.menu-pinned .sidebar{transform:translateX(0)}
.admin-ui .sidebar .sidebar-inner{display:flex;flex-direction:column;height:100%;overflow-y:auto}
.admin-ui .sidebar .sidebar-inner{scrollbar-width:thin;scrollbar-color:#334155 transparent}
.admin-ui .sidebar .sidebar-inner::-webkit-scrollbar{width:8px}
.admin-ui .sidebar .sidebar-inner::-webkit-scrollbar-track{background:transparent}
.admin-ui .sidebar .sidebar-inner::-webkit-scrollbar-thumb{background-color:#334155;border-radius:8px;border:2px solid transparent;background-clip:padding-box}
.admin-ui .sidebar .sidebar-inner::-webkit-scrollbar-thumb:hover{background-color:#475569}
.admin-ui .sidebar-head{position:sticky;top:0;background:#0b1220;z-index:1;display:flex;align-items:center;justify-content:space-between;padding:.75rem .75rem;border-bottom:1px solid var(--border)}
.admin-ui .sidebar-filter{position:sticky;top:52px;background:#0b1220;z-index:1;padding:.35rem .5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.4rem}
.admin-ui .sidebar-filter input{flex:1;width:auto}
.admin-ui .sidebar-filter-controls{display:flex;align-items:center;gap:.25rem}
.icon-btn{background:#1f2937;border:1px solid var(--border);color:#cbd5e1;border-radius:.4rem;padding:.3rem .35rem;cursor:pointer}
.icon-btn.danger{background:#7f1d1d;border-color:#991b1b;color:#fee2e2}
.icon-btn:hover{background:#273244}

/* Simple tooltip bubble */
.tooltip-bubble{position:fixed;z-index:9999;background:#111827;color:#e5e7eb;border:1px solid var(--border);border-radius:.35rem;padding:.25rem .4rem;font-size:.85rem;box-shadow:0 6px 18px rgba(0,0,0,.35);pointer-events:none;opacity:0;transform:translateY(-4px);transition:opacity .12s ease, transform .12s ease}
.tooltip-bubble.show{opacity:1;transform:translateY(0)}
.admin-ui .sidebar-head .pin-toggle{background:#1f2937;border:1px solid var(--border);color:#cbd5e1}
.admin-ui .sidebar-head .pin-toggle.active{background:#064e3b;border-color:#065f46;color:#d1fae5}
.icon{display:inline-block;vertical-align:middle}
.admin-ui .side-group{padding:.5rem .5rem}
.admin-ui .side-title{font-size:.9rem;color:#93a3b8;margin:.5rem .25rem .25rem .25rem;display:flex;align-items:center;gap:.4rem;cursor:pointer;user-select:none}
.admin-ui .side-group.collapsed .side-links{display:none}
.admin-ui .side-title::after{content:'▾'; margin-left:auto; color:#667085}
.admin-ui .side-group.collapsed .side-title::after{content:'▸'}
.admin-ui .side-links{list-style:none;margin:0;padding:0}
.admin-ui .side-links li{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%}
.admin-ui .side-links li > a{display:flex;align-items:center;gap:.45rem;padding:.45rem .6rem;border-radius:.6rem;color:#cbd5e1;border:1px solid transparent;min-width:0;flex-wrap:nowrap;white-space:nowrap;flex:1 1 auto;overflow:hidden}
.admin-ui .side-links li a .icon-wrap{display:inline-flex;align-items:center;flex:0 0 auto}
.admin-ui .side-links li a .icon{flex:0 0 auto}
.admin-ui .side-links li a .link-text{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.admin-ui .side-links li a:hover{background:#0e1628;border-color:#1f2937}
.admin-ui .side-links li a.active{background:#111f38;border-color:#2563eb;color:#eaf2ff;box-shadow:inset 0 0 0 1px #2563eb}
.admin-ui .side-links .pin-topbar{padding:.25rem .4rem;font-size:.85rem;background:#1f2937;border:1px solid var(--border);color:#cbd5e1}
.admin-ui .side-links .pin-topbar.active{background:#064e3b;border-color:#065f46;color:#d1fae5}
.admin-ui .side-links .fav-toggle{padding:.25rem .4rem;font-size:.85rem;background:#1f2937;border:1px solid var(--border);color:#fbbf24}
.admin-ui .side-links .fav-toggle.active{background:#3b2f1a;border-color:#b45309;color:#fde68a}
.admin-ui .backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:15}

body.admin-ui.menu-open .sidebar{transform:translateX(0)}
body.admin-ui.menu-open .backdrop{display:block}
body.admin-ui.menu-open .container.with-sidebar{margin-left:260px}
body.admin-ui.menu-pinned .backdrop{display:none}
body.admin-ui.menu-pinned .container.with-sidebar{margin-left:260px}

@media (max-width: 900px){
  body.menu-open .container.with-sidebar{margin-left:0}
  .menu-pinned .container.with-sidebar{margin-left:0}
}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}
.card{background:var(--panel);border:1px solid var(--border);border-radius:.6rem;padding:1rem}

/* Tables: sortable headers and quick filters */
th[data-sort]{cursor:pointer}
th[data-sort].asc::after{content:' \25B2'; color:#93c5fd}
th[data-sort].desc::after{content:' \25BC'; color:#93c5fd}
.table-tools{display:flex;gap:.5rem;align-items:center;margin:.5rem 0}
.filter-badges{display:flex;gap:.35rem;align-items:center;flex-wrap:wrap}
.pager{display:flex;justify-content:space-between;align-items:center;gap:.6rem;flex-wrap:wrap;margin:.5rem 0}
.pager__links{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}
.pager__label{color:#9ca3af;font-size:.9rem}
.pager__sort{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}
.pager__sort select{min-width:10rem}

.table-scroll{overflow-x:auto;border:1px solid var(--border);border-radius:.6rem;background:var(--panel)}
.table-scroll table{border:0;border-radius:0;background:transparent}
table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--border);border-radius:.6rem;overflow:hidden;background:var(--panel)}
th,td{padding:.6rem;border-bottom:1px solid var(--border);vertical-align:top}
th{background:#0e1628;color:#cbd5e1;text-align:left;font-weight:600;position:sticky;top:0;z-index:1}
tr:last-child td{border-bottom:0}
pre{white-space:pre-wrap}
.md-body h1,.md-body h2,.md-body h3,.md-body h4,.md-body h5,.md-body h6{margin:.6rem 0 .3rem 0}
.md-body p{margin:.4rem 0}
.md-body hr{border:0;border-top:1px solid var(--border);margin:.8rem 0}
.md-body a{color:#93c5fd}
.md-body code{background:#0b1220;border:1px solid var(--border);border-radius:.25rem;padding:.05rem .25rem}
.md-body pre{background:#0b1220;border:1px solid var(--border);border-radius:.35rem;padding:.6rem;overflow:auto}
.md-body pre code{background:transparent;border:none;padding:0}
.md-body img{max-width:100%;display:block;margin:.25rem 0}
.md-body blockquote{border-left:3px solid #93c5fd;margin:.5rem 0;padding:.25rem .75rem;background:#0b1220;border-radius:.2rem}
.md-body table{width:100%;border-collapse:collapse;margin:.5rem 0;background:transparent}
.md-body th,.md-body td{border:1px solid var(--border);padding:.45rem;vertical-align:top}
.md-body thead th{background:#0e1628}

input[type=text],input[type=password],textarea,select{width:100%;background:#0b1220;color:#e5e7eb;border:1px solid var(--border);border-radius:.4rem;padding:.5rem}
/* Compact rounded search bar (reusable)
   Usage:
   <form class="searchbar">
     <span class="addon">🔎</span>
     <input class="grow" type="search" placeholder="Search...">
     <select>...</select>
     <button>Search</button>
   </form>
*/
.searchbar{display:flex;align-items:center;gap:.5rem;border:1px solid var(--border);border-radius:9999px;padding:.35rem .5rem;background:var(--panel)}
.searchbar .addon{color:var(--muted);flex:0 0 auto}
.searchbar .grow{flex:1 1 auto;min-width:8rem}
.searchbar input[type=text],
.searchbar input[type=search],
.searchbar input[type=number],
.searchbar input[type=date],
.searchbar input[type=datetime-local],
.searchbar select{border:none;background:transparent;color:var(--fg);padding:.25rem;outline:none}
/* Theme-aligned selects inside searchbar */
.searchbar select{background:var(--panel); border:1px solid var(--border); border-radius:.4rem; padding:.3rem .5rem; color:var(--fg); appearance:auto}
.searchbar option{background:var(--panel); color:var(--fg)}
[data-theme="light"] .searchbar select{background:#ffffff; border-color:#cbd5e1; color:#0f172a}
[data-theme="light"] .searchbar option{background:#ffffff; color:#0f172a}
.searchbar label{display:flex; align-items:center; gap:.35rem}
.searchbar input[type=search]::-webkit-search-cancel-button{ -webkit-appearance:none; appearance:none; height:0; width:0; margin:0; }
.searchbar input[type=search]::-ms-clear{ display:none; width:0; height:0; }
.searchbar input[type=search]::-webkit-search-decoration{ -webkit-appearance:none; }
.searchbar input::placeholder{color:#6b7280}
.searchbar button,.searchbar .btn{border-radius:9999px;padding:.4rem .8rem}
.searchbar .btn.clear{background:transparent;color:var(--muted);border:1px solid var(--border)}
[data-theme="light"] .searchbar .btn.clear{color:#64748b;border-color:#cbd5e1}
.searchbar--tight{padding:.25rem .4rem;gap:.35rem}
.searchbar--wide{padding:.45rem .75rem}
.searchbar--wrap{flex-wrap:wrap}
[data-theme="light"] .searchbar--wrap .btn{color:#0f172a}
.sticky-panel{position:sticky;top:0;background:var(--panel);z-index:2;border-bottom:1px solid var(--border)}
.badge--clickable{cursor:pointer;border-color:var(--accent);color:var(--accent);background:transparent;transition:background .15s ease}
.badge--clickable:hover{background:rgba(16,185,129,.12)}
[data-theme="light"] .searchbar input::placeholder{color:#94a3b8}
label{display:block;margin:.25rem 0}
button,.btn{background:var(--accent);color:#001b12;border:none;border-radius:.4rem;padding:.5rem .8rem;cursor:pointer}
/* Utility: full-width button */
.btn.block{display:block;width:100%}
.btn.btn-small{padding:.3rem .55rem;font-size:.85rem}
.btn.btn-small.is-loading{opacity:.6;pointer-events:none}

/* Ensure anchored/scrollIntoView targets account for sticky topbar */
#create-client-panel{scroll-margin-top: 84px}
/* Generic class for any highlighted action panel (used by create forms) */
.panel-highlight{border:1px solid #2563eb;box-shadow:inset 0 0 0 1px #2563eb, 0 0 0 1px #1d4ed8}
/* Light theme highlight adjustment */
[data-theme="light"] .panel-highlight{border-color:#0ea5e9; box-shadow: inset 0 0 0 1px #0ea5e9, 0 0 0 1px #0284c7}
/* Generic class to align scroll into view under sticky topbar */
.panel-scroll-anchor{scroll-margin-top:84px}
button.danger{background:var(--danger);color:#fff}
button:disabled{opacity:.5;cursor:not-allowed}

.ffmpeg-mismatch{
  background-color:#fee2e2 !important;
  border-color:#dc2626 !important;
  color:#1f2937;
}

.ffmpeg-field{display:inline-flex;align-items:center;gap:.35rem}
.ffmpeg-sync-btn{background:#1f2937;border:1px solid #334155;color:#d1fae5;padding:.2rem .45rem;border-radius:.4rem;font-size:.9rem;line-height:1;cursor:pointer}
.ffmpeg-sync-btn:hover{background:#0f172a;border-color:#16a34a;color:#bbf7d0}
.ffmpeg-sync-btn:focus{outline:2px solid #16a34a;outline-offset:2px}

.ffmpeg-command-shell{display:flex;flex-direction:column;gap:.55rem}
.ffmpeg-command-row{border:1px solid #1f2937;background:#0b1424;padding:.5rem;border-radius:.6rem;display:flex;flex-direction:column;gap:.35rem}
.ffmpeg-command-row textarea{width:100%;font-family:'JetBrains Mono','SFMono-Regular',Menlo,monospace;font-size:.85rem;white-space:pre-wrap;word-break:break-word}
.ffmpeg-command-original{border:1px solid #1f2937;background:#0b1424;padding:.5rem;border-radius:.6rem}
.ffmpeg-command-label{font-size:.75rem;letter-spacing:.05em;text-transform:uppercase;color:#94a3b8;margin-bottom:.25rem}
.ffmpeg-command-text,
.ffmpeg-diff-text{margin:0;font-family:'JetBrains Mono','SFMono-Regular',Menlo,monospace;font-size:.85rem;white-space:pre-wrap;color:#e2e8f0}
.ffmpeg-diff{border:1px dashed #334155;background:#070f1f;padding:.45rem .55rem;border-radius:.6rem}
.ffmpeg-diff[hidden]{display:none}
.ffmpeg-diff-add{color:#22c55e;background:rgba(34,197,94,.18);padding:0 .08rem;border-radius:.2rem}
.ffmpeg-diff-change{color:#f87171;background:rgba(248,113,113,.18);padding:0 .08rem;border-radius:.2rem}
.ffmpeg-diff-remove{color:#cbd5e1;text-decoration:line-through;text-decoration-style:dashed;opacity:.75}
.ffmpeg-diff-warning{color:#f59e0b}
[data-theme="light"] .ffmpeg-command-row{background:#f8fafc;border-color:#cbd5e1}
[data-theme="light"] .ffmpeg-command-original{background:#f8fafc;border-color:#cbd5e1}
[data-theme="light"] .ffmpeg-command-text,
[data-theme="light"] .ffmpeg-diff-text{color:#0f172a}
[data-theme="light"] .ffmpeg-command-label{color:#475569}
[data-theme="light"] .ffmpeg-diff{border-color:#cbd5e1;background:#eef2ff}
[data-theme="light"] .ffmpeg-diff-remove{color:#475569}
[data-theme="light"] .ffmpeg-diff-warning{color:#b45309}

.btn.btn-muted{background:#4b5563;border-color:#4b5563;color:#e5e7eb;cursor:default}
.btn.btn-muted:hover{background:#4b5563;border-color:#4b5563}

.field-row{display:flex;gap:.6rem;flex-wrap:wrap;align-items:flex-end}
.field-row .field{display:flex;flex-direction:column;gap:.25rem;min-width:140px}
.field-row .field label{font-size:.85rem;color:#cbd5e1}
.field-row .field select,
.field-row .field input{width:100%}
.field-row .ffmpeg-field{width:100%}
.field-row .ffmpeg-field input{width:100%}
.field-row--source .field-channel{flex:1 1 220px;min-width:190px}
.field-row--source .field-server{flex:1 1 170px;min-width:150px}
.field-row--source .field-mode{flex:0 0 140px}
.field-row--source .field-profile{flex:0 0 160px}
.field-row--output .field-master{flex:1 1 200px;min-width:170px}
.field-row--output .field-segment{flex:1 1 340px;min-width:260px}
.field-row--output .field-priority{flex:0 0 70px;min-width:65px}
.field-row--output .field-enabled{flex:0 0 90px;min-width:80px}
.field-row--output .field-webtv{flex:0 0 110px;min-width:100px}
.field-row--output .field-note{flex:0 0 130px;min-width:120px}
.checkbox-field{display:flex;flex-direction:column;gap:.25rem;align-items:flex-start}
.checkbox-field label{font-size:.85rem;color:#cbd5e1;font-weight:500;display:block}
.checkbox-field input[type="checkbox"]{margin:0;width:auto;height:auto}
.field-row--vod .field{min-width:150px}
.field-row--vod .field-quota{flex:0 0 150px}
.field-row--vod .field-maxhours{flex:0 0 140px}
.field-row--vod .field-vod-actions{flex:0 0 150px;justify-content:flex-end}

.builder-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}
.builder-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}
.builder-status{font-size:.85rem;color:#cbd5e1}
.builder-status.warn{color:#fbbf24}
.builder-status.error{color:#fca5a5}
.builder-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.6rem .75rem}
.builder-grid .field{display:flex;flex-direction:column;gap:.25rem}
.builder-hidden{display:none!important}
.builder-section{margin-top:.6rem;padding:.6rem;border:1px solid #223049;border-radius:.6rem;background:#0f172a}
.builder-section h5{margin:.1rem 0 .4rem 0;font-size:.9rem;color:#93c5fd;text-transform:uppercase;letter-spacing:.05em}
.builder-track-list{display:flex;flex-direction:column;gap:.5rem}
.builder-track{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.5rem .75rem;padding:.45rem .6rem;border:1px solid #1f2937;border-radius:.5rem;background:#0b1322}
.builder-track .field{gap:.2rem}
.builder-track label{font-size:.8rem;color:#cbd5e1}
.builder-track input[type="checkbox"]{margin-right:.35rem}
.builder-track .field-inline{display:flex;align-items:center;gap:.35rem}
.builder-hint{font-size:.85rem;color:#cbd5e1}

.builder-subpanel,
.vod-subpanel{margin-top:.35rem;padding:.75rem;border:1px solid var(--border);border-radius:.6rem;background:#101826;scroll-margin-top:120px}
.vod-subpanel .toolbar{margin-top:.5rem}

#sources-table tr.active-source{background:rgba(34,197,94,0.12); box-shadow:inset 0 0 0 1px rgba(34,197,94,0.35);}
#sources-table tr.active-source td{border-top:1px solid rgba(34,197,94,0.25); border-bottom:1px solid rgba(34,197,94,0.25);}

.chip{display:inline-flex;align-items:center;padding:.15rem .45rem;border-radius:.5rem;font-size:.8rem;font-weight:500;line-height:1;border:1px solid transparent;gap:.25rem}
.chip-transcode{background:rgba(59,130,246,0.15);color:#bfdbfe;border-color:rgba(59,130,246,0.35)}
.chip-passthrough{background:rgba(148,163,184,0.15);color:#e2e8f0;border-color:rgba(148,163,184,0.3)}
.chip-enabled{background:rgba(16,185,129,0.18);color:#bbf7d0;border-color:rgba(16,185,129,0.4)}
.chip-disabled{background:rgba(239,68,68,0.18);color:#fecaca;border-color:rgba(239,68,68,0.35)}
.chip-active{background:rgba(34,197,94,0.2);color:#dcfce7;border-color:rgba(34,197,94,0.45)}
.chip-standby{background:rgba(148,163,184,0.12);color:#e2e8f0;border-color:rgba(148,163,184,0.25)}
.chip-muted{background:rgba(148,163,184,0.08);color:#cbd5e1;border-color:rgba(148,163,184,0.2)}
.chip-priority{background:rgba(59,130,246,0.1);color:#c7d2fe;border-color:rgba(59,130,246,0.25)}
.chip-remote{background:rgba(250,204,21,0.12);color:#fef3c7;border-color:rgba(250,204,21,0.35)}
.chip-local{background:rgba(13,148,136,0.18);color:#99f6e4;border-color:rgba(13,148,136,0.35)}

.help-icon{background:#1f2937;border:1px solid #334155;color:#e5e7eb;width:1.4rem;height:1.4rem;border-radius:50%;font-size:.75rem;line-height:1.2rem;text-align:center;cursor:pointer;padding:0}
.help-icon:hover{background:#0f172a}
.help-icon:focus{outline:2px solid #16a34a;outline-offset:2px}

.vod-progress{position:relative;height:.5rem;width:180px;background:rgba(148,163,184,0.2);border-radius:9999px;overflow:hidden;margin:.35rem 0}
.vod-progress span{display:block;height:100%;background:linear-gradient(90deg, rgba(34,197,94,0.85), rgba(16,185,129,0.7));border-radius:inherit}

.vod-usage{margin-top:.35rem}

details summary{cursor:pointer;color:#cbd5e1}
details summary.btn{list-style:none}
details summary.btn::-webkit-details-marker{display:none}
details summary.btn::marker{content:''}
.table-actions{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}
.table-actions form{margin:0;display:inline-flex}
.scroll{max-height:22rem;overflow:auto;border:1px solid var(--border);border-radius:.4rem;padding:.5rem;background:#0b1220}

.box{max-width:420px;margin:10vh auto;padding:2rem;background:var(--panel);border:1px solid var(--border);border-radius:.6rem}
.error{color:#fca5a5;margin:.5rem 0}

.toolbar{display:flex;gap:.5rem;flex-wrap:wrap;margin:.5rem 0}
.source-status-banner{margin-top:.35rem}
.source-status-banner[hidden]{display:none}
.status-pill{display:flex;align-items:center;gap:.5rem;background:#312e81;border:1px solid #4338ca;border-radius:.6rem;padding:.45rem .6rem;font-size:.9rem;flex-wrap:wrap}
.status-pill--error{background:#7f1d1d;border-color:#991b1b;color:#fee2e2}
.status-pill__text{flex:1 1 auto;min-width:160px}
.status-pill__link{background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.2);color:inherit}
.status-pill__link:hover{background:rgba(255,255,255,0.2)}
.status-pill__details{background:#111827;border:1px solid rgba(255,255,255,0.15);border-radius:.4rem;padding:.5rem;max-height:180px;overflow:auto;width:100%}
.status-pill__retry{background:#111f38;border:1px solid #1e3a8a;color:#bfdbfe}
.status-pill__retry:hover{background:#1e3a8a;color:#e0f2fe}
.help{color:#9ca3af;font-size:.9rem;margin-top:.3rem}

.toast{position:fixed;bottom:1rem;right:1rem;background:#111827;color:#e5e7eb;border:1px solid var(--border);border-radius:.4rem;padding:.6rem .8rem;box-shadow:0 6px 20px rgba(0,0,0,.3);display:flex;align-items:flex-start;gap:.6rem;max-width:420px}
.toast-text{flex:1 1 auto;white-space:pre-line}
.toast-close{background:transparent;border:0;color:#e5e7eb;font-weight:700;font-size:.9rem;line-height:1;cursor:pointer;padding:.1rem .35rem;border-radius:.3rem}
.toast-close:hover{background:rgba(255,255,255,0.12)}
.toast-close:focus{outline:2px solid #38bdf8;outline-offset:2px}

.badge{display:inline-block;padding:.15rem .45rem;border-radius:.5rem;font-size:.8rem;border:1px solid var(--border)}
.badge.active{background:#064e3b;color:#d1fae5;border-color:#065f46}
.badge.inactive{background:#7f1d1d;color:#fee2e2;border-color:#991b1b}
.drag-handle{cursor:grab;display:inline-block;margin-right:.4rem;color:#93c5fd}
tr.dragging{opacity:.6}
.droptarget{outline:2px dashed #93c5fd; outline-offset: -4px}
.draggable-channel{cursor:grab;border:1px dashed var(--border);background:#0b1220;border-radius:.3rem;padding:.35rem .5rem;margin:.25rem 0;user-select:none}
.draggable-channel:active{cursor:grabbing}
.draggable-channel.assigned{color:#fca5a5;border-color:#991b1b}
.pkg-channel{border:1px solid var(--border);border-radius:.3rem;padding:.35rem .5rem;margin:.25rem 0;background:#0b1220}

/* Channel Groups */
#channel-groups-board{margin-bottom:1.5rem;--channel-groups-height:min(72vh,760px)}
.channel-groups-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,360px);gap:1rem;align-items:start}
.channel-groups-left{max-height:var(--channel-groups-height);overflow:auto;padding-right:.25rem}
.channel-groups-right{max-height:var(--channel-groups-height);overflow:auto;position:sticky;top:.5rem}
.channel-groups-columns{display:flex;flex-direction:column;gap:1rem}
.channel-group{background:var(--card-bg,#0f172a);border:1px solid var(--border,#1f2937);border-radius:.5rem;display:flex;flex-direction:column;width:100%}
.channel-group[draggable="true"]{cursor:grab}
.channel-group.is-dragging{opacity:.7}
.channel-group.drag-over{border-color:#2563eb;box-shadow:0 0 0 1px #2563eb inset}
.channel-group__header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;border-bottom:1px solid var(--border,#1f2937);gap:.5rem}
.channel-group__title{display:flex;align-items:center;gap:.5rem;font-size:.95rem}
.channel-group__title .drag-handle{cursor:grab;color:#6b7280}
.channel-group__actions{display:flex;gap:.5rem}
.channel-group__list{list-style:none;margin:0;padding:.5rem;display:flex;flex-direction:column;gap:.35rem;min-height:2.5rem}
.channel-group__list.drag-over{border:1px dashed #3b82f6;border-radius:.35rem}
.channel-group__item{display:flex;align-items:center;gap:.5rem;background:rgba(15,23,42,.6);border:1px solid rgba(148,163,184,.2);border-radius:.35rem;padding:.4rem .5rem;font-size:.9rem}
.channel-group__item .drag-handle{cursor:grab;color:#6b7280}
.channel-group__item.is-disabled{opacity:.55}
.channel-group__item.is-dragging{opacity:.7}
.channel-group__name{flex:1 1 auto}
.channel-group--ungrouped{background:transparent;border:1px dashed var(--border,#1f2937)}
.channel-group--ungrouped .channel-group__header{border-bottom:none}
.channel-group--ungrouped .channel-group__list{min-height:3rem}
@media (max-width: 1000px){
  .channel-groups-layout{grid-template-columns:1fr}
  .channel-groups-left,.channel-groups-right{max-height:none;overflow:visible;position:static;padding-right:0}
}

footer.about{max-width:1200px;margin:0.5rem auto 1rem auto;padding:0 .75rem;color:#9ca3af;font-size:.85rem}

@media (max-width: 720px){
  .nav{flex-wrap:wrap}
  th,td{padding:.45rem}
  table{font-size:.95rem}
  th:nth-child(6),td:nth-child(6),th:nth-child(7),td:nth-child(7){display:none}
}

/* Light theme overrides */
[data-theme="light"]{--bg:#f8fafc; --panel:#ffffff; --muted:#475569; --fg:#0f172a; --accent:#0ea5e9; --danger:#b91c1c; --border:#e2e8f0}
[data-theme="light"] .nav a.active{background:#e2e8f0;color:#0f172a}

/* Global thin scrollbars */
html{scrollbar-width:thin; scrollbar-color:#334155 transparent}
html::-webkit-scrollbar{width:8px;height:8px}
html::-webkit-scrollbar-track{background:transparent}
html::-webkit-scrollbar-thumb{background-color:#334155;border-radius:8px;border:2px solid transparent;background-clip:padding-box}
[data-theme="light"] html{scrollbar-color:#cbd5e1 transparent}
[data-theme="light"] html::-webkit-scrollbar-thumb{background-color:#cbd5e1}

/* Portal-specific topbar modern styling */
.portal-ui .topbar{position:fixed;top:0;left:auto;right:.5rem;display:flex;align-items:center;justify-content:center;padding:.4rem .5rem;background:rgba(11,18,32,.92);backdrop-filter:saturate(120%) blur(6px);border:1px solid var(--border);box-shadow:0 4px 18px rgba(0,0,0,.35);z-index:40;transition:transform .2s ease, opacity .2s ease;border-radius:9999px;width:auto;max-width:calc(100% - 1rem)}
.portal-ui .topbar .brand{display:none}
.portal-ui .topbar .nav{display:flex;align-items:center;gap:.4rem}
.portal-ui .topbar .nav a{padding:.35rem .6rem}
.portal-ui .topbar .nav a{display:flex;align-items:center;gap:.35rem;white-space:nowrap;border-radius:.5rem}
.portal-ui .topbar .nav a.active{background:#122242;border-color:#2563eb;color:#eaf2ff;box-shadow:inset 0 0 0 1px #2563eb, 0 8px 22px rgba(37,99,235,.25)}
.portal-ui .topbar:hover{transform:none; opacity:1}
body.portal-ui.topbar-hidden .topbar{transform:translateY(calc(-100% + 6px)); opacity:.9}
body.portal-ui.topbar-hidden .topbar::after{content:''; position:absolute; inset:auto 0 0 0; height:6px; background:linear-gradient(90deg, rgba(37,99,235,.5), rgba(16,185,129,.5)); opacity:.8}
/* Move portal content up; topbar overlays content */
/* Leave enough space for the compact portal topbar */
.portal-ui .container{margin-top:56px}
.builder-muted{opacity:.7}

/* Tasks board */
.task-layout{display:grid;grid-template-columns:220px 1fr 260px;gap:1rem;margin-top:1rem;align-items:start}
.task-sidebar,.task-panel{background:var(--panel);border:1px solid var(--border);border-radius:6px;padding:.75rem;display:flex;flex-direction:column;gap:.75rem}
.task-sidebar__header,.task-panel__header,.task-main__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}
.task-group-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.35rem}
.task-group{display:flex;align-items:center;justify-content:space-between;background:var(--card);border:1px solid transparent;border-radius:6px;padding:.35rem .4rem;gap:.35rem;cursor:pointer}
.task-group.is-active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.task-group.drag-target{border-color:var(--accent);background:rgba(37,99,235,.12)}
.task-group__button{border:none;background:transparent;font:inherit;text-align:left;flex:1;cursor:pointer;color:inherit}
.task-group__actions{display:flex;gap:.25rem}
.task-group__actions .btn.btn-ghost{padding:0 .25rem}
.task-main{background:var(--panel);border:1px solid var(--border);border-radius:6px;padding:1rem;min-height:480px;display:flex;flex-direction:column;position:relative}
.task-main__header{margin:-1rem -1rem 1rem -1rem;padding:1rem 1.2rem;border-bottom:1px solid transparent;background:transparent}
.task-main__header.sticky-panel{border-bottom:1px solid var(--border);background:var(--panel)}
.task-main__meta{color:var(--text-muted);font-size:.85rem}
.task-main__actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-left:auto}
.task-list{display:flex;flex-direction:column;gap:.5rem;flex:1;min-height:200px}
.task-item{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:.65rem .75rem;display:flex;flex-direction:column;gap:.35rem}
.task-item.is-dragging{opacity:.6}
.task-item--done .task-item__title{text-decoration:line-through;color:var(--text-muted)}
.task-item__head{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}
.task-item__check{display:flex;gap:.5rem;align-items:flex-start}
.task-item__check input[type=checkbox]{margin-top:.2rem}
.task-item__actions{display:flex;gap:.35rem}
.task-item__meta{color:var(--text-muted);font-size:.85rem}
.task-item__notes{white-space:pre-wrap;background:rgba(255,255,255,.04);padding:.3rem .4rem;border-radius:4px;border:1px dashed var(--border);font-size:.9rem}
.task-meta__due{font-weight:500}
.task-meta__due--soon{color:#b45309}
.task-meta__due--overdue{color:#dc2626}
.task-panel__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.35rem;max-height:420px;overflow:auto}
.task-note{border:1px solid var(--border);border-radius:6px;padding:.4rem .5rem;background:var(--card);font-size:.85rem;display:grid;gap:.25rem}
.task-dialog{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:2000}
.task-dialog[hidden]{display:none}
.task-dialog__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.65)}
.task-dialog__panel{position:relative;background:var(--panel);border-radius:12px;padding:1rem 1.2rem;border:1px solid var(--border);width:min(420px,90vw);max-height:90vh;overflow:auto}
.task-dialog__panel header{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.75rem}
.task-dialog__form label{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem}
.task-dialog__form input,.task-dialog__form select,.task-dialog__form textarea{border:1px solid var(--border);border-radius:6px;background:var(--card);padding:.45rem .55rem;color:inherit}
.task-dialog__actions{display:flex;justify-content:flex-end;gap:.5rem}

.confirm-dialog{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:2100}
.confirm-dialog[hidden]{display:none}
.confirm-dialog__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.65)}
.confirm-dialog__panel{position:relative;background:var(--panel);border-radius:12px;padding:1rem 1.2rem;border:1px solid var(--border);width:min(480px,92vw);max-height:90vh;overflow:auto;box-shadow:0 18px 50px rgba(15,23,42,.45)}
.confirm-dialog__header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}
.confirm-dialog__badge{display:inline-flex;align-items:center;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:#f59e0b;background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.4);padding:.2rem .5rem;border-radius:999px}
.confirm-dialog__title{margin:.4rem 0 0;font-size:1.05rem;color:inherit}
.confirm-dialog__lead{margin:.5rem 0 .35rem;color:#f59e0b}
.confirm-dialog__list{margin:.2rem 0 .75rem 1.1rem;padding:0;color:#f59e0b}
.confirm-dialog__prompt{margin:0;color:#e2e8f0}
.confirm-dialog__actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.75rem}
[data-theme="light"] .confirm-dialog__backdrop{background:rgba(15,23,42,.45)}
[data-theme="light"] .confirm-dialog__lead,
[data-theme="light"] .confirm-dialog__list{color:#b45309}
[data-theme="light"] .confirm-dialog__prompt{color:#0f172a}
@media (max-width:1100px){.task-layout{grid-template-columns:1fr}.task-panel{order:-1}}
