/* AHPulse v2 — Agent Workspace */
:root{
  --bg:#f5f4ef; --surface:#ffffff; --surface-2:#fbfaf6; --surface-3:#f3f1ea;
  --border:#e8e5dc; --border-strong:#dcd8cc;
  --text:#1e231f; --text-2:#454b46; --muted:#787e77;
  --accent:#2f8f5b; --accent-strong:#237046; --accent-soft:#e6f2ea; --accent-line:#bfe0cd;
  --danger:#c14a30; --danger-soft:#f7e6e1; --warn:#b9842b; --info:#3d7fae;
  --shadow:0 1px 2px rgba(30,35,31,.04), 0 8px 24px -12px rgba(30,35,31,.18);
  --shadow-lg:0 2px 6px rgba(30,35,31,.06), 0 28px 60px -28px rgba(30,35,31,.30);
  --radius:16px; --radius-sm:11px; --radius-lg:22px;
}
[data-theme="cloud"]{--bg:#eef1f2;--surface:#fff;--surface-2:#f7f9fa;--surface-3:#eef1f3;--border:#e1e7e9;--border-strong:#d2dadd;--text:#1b2326;--text-2:#3f494d;--muted:#6c767a;--accent:#1f8a86;--accent-strong:#176b68;--accent-soft:#e0f0ef;--accent-line:#b3ddda;}
[data-theme="linen"]{--bg:#f3eee2;--surface:#fffdf7;--surface-2:#faf6ea;--surface-3:#f1ebda;--border:#e8ddc9;--border-strong:#ddd0b8;--text:#282318;--text-2:#4c4636;--muted:#7c7460;--accent:#6f8a35;--accent-strong:#566c28;--accent-soft:#eef0db;--accent-line:#d2ddae;--danger:#bb5128;--danger-soft:#f5e6dc;}
[data-theme="mist"]{--bg:#eef1f6;--surface:#fff;--surface-2:#f6f8fc;--surface-3:#eaeef5;--border:#e0e6f0;--border-strong:#d0d8e6;--text:#1d2330;--text-2:#404858;--muted:#6a7383;--accent:#5379bf;--accent-strong:#3f5fa0;--accent-soft:#e7edf8;--accent-line:#c2d2ee;}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:"Hanken Grotesk",sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;letter-spacing:-.006em;transition:background .5s ease,color .5s ease;overflow:hidden}
.mono{font-family:"Spline Sans Mono",monospace;font-variant-numeric:tabular-nums}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
svg{display:block}
::selection{background:var(--accent-soft)}
[data-density="compact"]{--radius:12px;--radius-sm:9px}
[data-density="compact"] .card{padding:14px 16px}
[data-density="compact"] .kpi b{font-size:22px}
.app{height:100vh;display:grid;grid-template-columns:74px 1fr;grid-template-rows:60px 1fr;grid-template-areas:"rail top" "rail main"}
.topbar{grid-area:top;display:flex;align-items:center;gap:18px;padding:0 22px;background:var(--surface);border-bottom:1px solid var(--border);z-index:30}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(145deg,var(--accent),var(--accent-strong));display:grid;place-items:center;box-shadow:0 6px 14px -6px var(--accent)}
.brand .mark svg{width:20px;height:20px}
.brand .name{font-weight:800;font-size:18px;letter-spacing:-.03em}
.brand .name span{color:var(--accent)}
.search{flex:1;max-width:420px;display:flex;align-items:center;gap:9px;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:9px 13px;color:var(--muted);transition:border-color .25s,box-shadow .25s,background .25s}
.search:focus-within{border-color:var(--accent-line);box-shadow:0 0 0 4px var(--accent-soft);background:var(--surface)}
.search input{border:none;background:none;outline:none;flex:1;font-size:14px;color:var(--text)}
.search svg{width:17px;height:17px;flex:none}
.search kbd{font-family:"Spline Sans Mono";font-size:11px;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:2px 6px;color:var(--muted)}
.top-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.pill{display:flex;align-items:center;gap:8px;height:38px;padding:0 13px;border-radius:11px;background:var(--surface-2);border:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-2);transition:.2s}
.pill:hover{border-color:var(--border-strong)}
.dot{width:8px;height:8px;border-radius:50%;background:var(--accent);position:relative}
.dot.off{background:var(--muted)}
.dot.live::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--accent);animation:ping 1.8s ease-out infinite}
@keyframes ping{0%{transform:scale(.6);opacity:.7}100%{transform:scale(1.9);opacity:0}}
.icon-btn{width:38px;height:38px;border-radius:11px;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-2);transition:.2s}
.icon-btn:hover{border-color:var(--accent-line);color:var(--accent);transform:translateY(-1px)}
.icon-btn svg{width:18px;height:18px}
.avatar{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-strong);font-weight:800;font-size:14px;border:1px solid var(--accent-line)}
.rail{grid-area:rail;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:14px 0 16px;gap:6px;z-index:31}
.rail .logo-dot{width:40px;height:40px;border-radius:12px;background:var(--accent-soft);display:grid;place-items:center;margin-bottom:10px}
.rail .logo-dot svg{width:22px;height:22px;color:var(--accent-strong)}
.nav-item{position:relative;width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:var(--muted);transition:.22s cubic-bezier(.4,0,.2,1)}
.nav-item svg{width:21px;height:21px;transition:.22s}
.nav-item:hover{background:var(--surface-3);color:var(--text)}
.nav-item.active{background:var(--accent-soft);color:var(--accent-strong)}
.nav-item.active::before{content:"";position:absolute;left:-14px;top:13px;bottom:13px;width:3px;border-radius:3px;background:var(--accent);animation:slidein .3s}
@keyframes slidein{from{transform:scaleY(0)}to{transform:scaleY(1)}}
.nav-item .tip{position:absolute;left:56px;top:50%;transform:translateY(-50%) translateX(-4px);background:var(--text);color:var(--surface);font-size:12px;font-weight:600;padding:6px 10px;border-radius:8px;white-space:nowrap;opacity:0;pointer-events:none;transition:.18s;z-index:40}
.nav-item:hover .tip{opacity:1;transform:translateY(-50%) translateX(0)}
.rail .spacer{flex:1}
.main{grid-area:main;position:relative;overflow:hidden}
.view{position:absolute;inset:0;overflow:auto;padding:22px;opacity:0;transform:translateY(10px) scale(.995);pointer-events:none;transition:opacity .4s ease,transform .45s cubic-bezier(.2,.7,.2,1)}
.view.active{opacity:1;transform:none;pointer-events:auto}
.view::-webkit-scrollbar{width:10px}
.view::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:10px;border:3px solid var(--bg)}
.page-head{display:flex;align-items:flex-end;gap:14px;margin-bottom:18px}
.page-head h1{font-size:23px;font-weight:800;letter-spacing:-.03em}
.page-head .sub{color:var(--muted);font-size:13.5px;font-weight:500}
.page-head .actions{margin-left:auto;display:flex;gap:9px}
.btn{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 16px;border-radius:11px;font-weight:650;font-size:13.5px;border:1px solid var(--border);background:var(--surface);color:var(--text);transition:.2s}
.btn svg{width:16px;height:16px}
.btn:hover{border-color:var(--border-strong);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 8px 18px -8px var(--accent)}
.btn.primary:hover{background:var(--accent-strong)}
.btn.ghost{background:transparent}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}
.card.flat{box-shadow:none}
.card-title{display:flex;align-items:center;gap:9px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.card-title svg{width:15px;height:15px;color:var(--accent)}
.cockpit{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(0,1.15fr) minmax(0,.95fr);gap:18px;height:100%}
@media(max-width:1300px){.cockpit{grid-template-columns:1fr 1fr}.col-queue{grid-column:1/-1}}
.col{display:flex;flex-direction:column;gap:18px;min-height:0}
.stagger>*{animation:rise .5s both}
.stagger>*:nth-child(1){animation-delay:.02s}.stagger>*:nth-child(2){animation-delay:.09s}.stagger>*:nth-child(3){animation-delay:.16s}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.contact-top{display:flex;gap:15px;align-items:center}
.contact-av{width:60px;height:60px;border-radius:18px;flex:none;display:grid;place-items:center;background:linear-gradient(150deg,var(--accent-soft),var(--surface-3));color:var(--accent-strong);font-weight:800;font-size:21px;border:1px solid var(--accent-line)}
.contact-name{font-size:21px;font-weight:800;letter-spacing:-.03em;line-height:1.1}
.contact-phone{font-size:14.5px;color:var(--text-2);margin-top:3px}
.chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:650;padding:5px 11px;border-radius:9px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-2)}
.chip.state{background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent-line)}
.chip svg{width:13px;height:13px}
.tabs{display:flex;gap:4px;margin-top:18px;padding:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:12px}
.tab{flex:1;height:34px;border-radius:9px;font-size:13px;font-weight:650;color:var(--muted);transition:.22s;display:flex;align-items:center;justify-content:center;gap:6px}
.tab svg{width:14px;height:14px}
.tab:hover{color:var(--text)}
.tab.active{background:var(--surface);color:var(--accent-strong);box-shadow:var(--shadow)}
.tab-wrap{position:relative;margin-top:14px;min-height:150px}
.tab-panel{opacity:0;transform:translateX(12px);position:absolute;inset:0;pointer-events:none;transition:opacity .32s ease,transform .38s cubic-bezier(.2,.7,.2,1)}
.tab-panel.active{opacity:1;transform:none;pointer-events:auto;position:relative}
.field-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px dashed var(--border)}
.field-row:last-child{border:none}
.field-row .k{color:var(--muted);font-size:13px;font-weight:550}
.field-row .v{font-size:13.5px;font-weight:650}
.timeline{display:flex;flex-direction:column;gap:2px}
.tl-item{display:flex;gap:12px;padding:9px 0}
.tl-dot{width:9px;height:9px;border-radius:50%;background:var(--accent);margin-top:5px;flex:none;position:relative}
.tl-item:not(:last-child) .tl-dot::after{content:"";position:absolute;left:50%;top:13px;transform:translateX(-50%);width:1.5px;height:30px;background:var(--border-strong)}
.tl-item .tt{font-size:13.5px;font-weight:650}
.tl-item .td{font-size:12px;color:var(--muted)}
textarea.notes{width:100%;min-height:120px;resize:vertical;border:1px solid var(--border);border-radius:12px;padding:12px 14px;font-family:inherit;font-size:14px;background:var(--surface-2);color:var(--text);outline:none;transition:.2s}
textarea.notes:focus{border-color:var(--accent-line);box-shadow:0 0 0 4px var(--accent-soft);background:var(--surface)}
.call-card{background:linear-gradient(170deg,var(--surface),var(--surface-2));position:relative;overflow:hidden}
.call-card::before{content:"";position:absolute;top:-40px;right:-40px;width:160px;height:160px;border-radius:50%;background:var(--accent-soft);filter:blur(8px);opacity:.55}
.call-head{display:flex;align-items:center;justify-content:space-between;position:relative}
.call-state{display:flex;align-items:center;gap:9px;font-weight:700;font-size:14px}
.rec{display:flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;color:var(--danger);text-transform:uppercase;letter-spacing:.05em}
.rec.hidden{display:none}
.rec .rdot{width:8px;height:8px;border-radius:50%;background:var(--danger);animation:blink 1.3s infinite}
@keyframes blink{50%{opacity:.25}}
.timer{font-size:46px;font-weight:600;letter-spacing:-.02em;margin:16px 0 4px;text-align:center;position:relative}
.wave{display:flex;align-items:center;justify-content:center;gap:3px;height:26px;margin-bottom:18px;position:relative}
.wave i{width:3px;border-radius:3px;background:var(--accent-line);animation:wv 1.1s ease-in-out infinite}
.wave i:nth-child(odd){background:var(--accent)}
@keyframes wv{0%,100%{height:6px}50%{height:24px}}
.paused .wave i{animation-play-state:paused;height:6px!important;background:var(--border-strong)}
.controls{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;position:relative}
.ctrl{height:62px;border-radius:14px;background:var(--surface);border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;font-size:11.5px;font-weight:650;color:var(--text-2);transition:.18s}
.ctrl svg{width:20px;height:20px}
.ctrl:hover{border-color:var(--accent-line);transform:translateY(-2px);box-shadow:var(--shadow)}
.ctrl.on{background:var(--accent-soft);border-color:var(--accent-line);color:var(--accent-strong)}
.ctrl.hang{background:var(--danger);border-color:var(--danger);color:#fff;grid-column:span 3;height:50px;flex-direction:row;box-shadow:0 8px 18px -8px var(--danger)}
.ctrl.hang:hover{filter:brightness(.95);transform:translateY(-2px)}
.ctrl.call-btn{background:var(--accent);border-color:var(--accent);color:#fff;grid-column:span 3;height:50px;flex-direction:row;box-shadow:0 8px 18px -8px var(--accent)}
.dept{display:flex;align-items:center;gap:12px;width:100%;padding:13px 14px;border-radius:13px;background:var(--surface-2);border:1px solid var(--border);transition:.18s;text-align:left;margin-bottom:8px}
.dept:hover{border-color:var(--accent-line);background:var(--surface);transform:translateX(2px);box-shadow:var(--shadow)}
.dept .dico{width:38px;height:38px;border-radius:10px;background:var(--accent-soft);color:var(--accent-strong);display:grid;place-items:center;flex:none}
.dept .dico svg{width:18px;height:18px}
.dept .dt{font-weight:700;font-size:13.5px}
.dept .dd{font-size:11.5px;color:var(--muted)}
.dept .arrow{margin-left:auto;color:var(--muted);transition:.2s}
.dept:hover .arrow{color:var(--accent);transform:translateX(3px)}
.badge-ga{font-size:10px;font-weight:800;letter-spacing:.04em;padding:2px 7px;border-radius:6px;background:var(--accent);color:#fff;margin-left:6px}
.disp-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.disp{height:42px;border-radius:11px;border:1px solid var(--border);background:var(--surface-2);font-weight:650;font-size:13px;color:var(--text-2);transition:.18s;display:flex;align-items:center;justify-content:center;gap:7px}
.disp svg{width:15px;height:15px}
.disp:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.disp.win:hover{border-color:var(--accent-line);color:var(--accent-strong);background:var(--accent-soft)}
.disp.bad:hover{border-color:var(--danger-soft);color:var(--danger);background:var(--danger-soft)}
.q-item{display:flex;align-items:center;gap:12px;padding:11px;border-radius:13px;transition:.18s;cursor:pointer}
.q-item:hover{background:var(--surface-2)}
.q-item.cur{background:var(--accent-soft);outline:1px solid var(--accent-line)}
.q-av{width:38px;height:38px;border-radius:11px;background:var(--surface-3);display:grid;place-items:center;font-weight:700;font-size:13px;color:var(--text-2);flex:none}
.q-item.cur .q-av{background:var(--accent);color:#fff}
.q-name{font-weight:700;font-size:13.5px}
.q-meta{font-size:11.5px;color:var(--muted)}
.q-state{margin-left:auto;font-size:11px;font-weight:700;color:var(--muted)}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.kpi{background:var(--surface-2);border:1px solid var(--border);border-radius:13px;padding:13px}
.kpi small{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.kpi b{display:block;font-size:25px;font-weight:800;margin-top:4px;letter-spacing:-.02em}
.kpi .trend{font-size:11.5px;font-weight:700;color:var(--accent)}
.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700;padding:10px 14px;border-bottom:1px solid var(--border)}
.tbl td{padding:13px 14px;border-bottom:1px solid var(--border)}
.tbl tr{transition:.15s}
.tbl tbody tr:hover{background:var(--surface-2)}
.tag{font-size:11px;font-weight:700;padding:3px 9px;border-radius:7px;background:var(--surface-3);color:var(--text-2)}
.tag.green{background:var(--accent-soft);color:var(--accent-strong)}
.tag.warn{background:#f6edda;color:var(--warn)}
.tag.red{background:var(--danger-soft);color:var(--danger)}
.mini-wave{display:flex;align-items:center;gap:2px;height:22px}
.mini-wave i{width:2.5px;background:var(--accent-line);border-radius:2px}
.scrim{position:fixed;inset:0;background:rgba(20,24,21,.18);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:.3s;z-index:50}
.scrim.open{opacity:1;pointer-events:auto}
.theme-panel{position:fixed;top:14px;right:14px;width:320px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:20px;z-index:60;transform:translateY(-12px) scale(.97);opacity:0;pointer-events:none;transition:transform .35s cubic-bezier(.2,.8,.2,1),opacity .3s;transform-origin:top right}
.theme-panel.open{transform:none;opacity:1;pointer-events:auto}
.tp-head{font-weight:800;font-size:16px;letter-spacing:-.02em}
.tp-sub{font-size:12.5px;color:var(--muted);margin:2px 0 16px}
.tp-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:4px 0 10px}
.theme-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.theme-opt{border:1.5px solid var(--border);border-radius:14px;padding:11px;text-align:left;transition:.2s;background:var(--surface)}
.theme-opt:hover{border-color:var(--border-strong);transform:translateY(-2px)}
.theme-opt.sel{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.sw{display:flex;gap:4px;margin-bottom:9px}
.sw span{width:100%;height:26px;border-radius:6px;border:1px solid rgba(0,0,0,.05)}
.theme-opt .tn{font-weight:700;font-size:13px}
.theme-opt .tdsc{font-size:11px;color:var(--muted)}
.seg{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:11px;padding:4px;margin-top:8px}
.seg button{flex:1;height:34px;border-radius:8px;font-weight:650;font-size:13px;color:var(--muted);transition:.2s}
.seg button.on{background:var(--surface);color:var(--accent-strong);box-shadow:var(--shadow)}
.tp-foot{margin-top:16px;font-size:11.5px;color:var(--muted);display:flex;align-items:center;gap:7px}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--text);color:var(--surface);padding:12px 18px;border-radius:12px;font-size:13.5px;font-weight:600;opacity:0;pointer-events:none;transition:.3s;z-index:80;display:flex;align-items:center;gap:9px;box-shadow:var(--shadow-lg)}
.toast.show{opacity:1;transform:translateX(-50%)}
.toast svg{width:17px;height:17px;color:var(--accent)}
/* login */
.login{position:fixed;inset:0;background:var(--bg);z-index:100;display:grid;place-items:center;transition:opacity .4s}
.login.hidden{opacity:0;pointer-events:none}
.login-card{width:360px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:30px}
.login-card .brand{justify-content:center;margin-bottom:6px}
.login-card h2{text-align:center;font-size:18px;font-weight:800;margin-bottom:2px}
.login-card p{text-align:center;color:var(--muted);font-size:13px;margin-bottom:20px}
.login-card label{font-size:12px;font-weight:700;color:var(--text-2);display:block;margin:12px 0 6px}
.login-card input{width:100%;height:44px;border:1px solid var(--border);border-radius:11px;padding:0 13px;font-family:inherit;font-size:14px;background:var(--surface-2);color:var(--text);outline:none;transition:.2s}
.login-card input:focus{border-color:var(--accent-line);box-shadow:0 0 0 4px var(--accent-soft);background:var(--surface)}
.login-card .btn{width:100%;justify-content:center;margin-top:20px;height:46px}
.login-err{color:var(--danger);font-size:12.5px;text-align:center;margin-top:12px;min-height:16px}
.mock-banner{position:fixed;bottom:14px;left:14px;z-index:70;background:var(--warn);color:#fff;font-size:11.5px;font-weight:700;padding:6px 12px;border-radius:9px;box-shadow:var(--shadow);letter-spacing:.02em}
/* user menu */
.user-wrap{position:relative}
.user-menu{position:absolute;top:46px;right:0;width:208px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);padding:8px;opacity:0;transform:translateY(-8px) scale(.97);pointer-events:none;transition:.22s cubic-bezier(.2,.8,.2,1);transform-origin:top right;z-index:65}
.user-menu.open{opacity:1;transform:none;pointer-events:auto}
.user-menu .um-name{font-weight:700;font-size:14px;padding:8px 10px 0}
.user-menu .um-role{font-size:12px;color:var(--muted);padding:0 10px 8px;text-transform:capitalize}
.user-menu hr{border:none;border-top:1px solid var(--border);margin:6px 0}
.user-menu .um-item{display:flex;align-items:center;gap:9px;width:100%;text-align:left;padding:9px 10px;border-radius:9px;font-size:13.5px;font-weight:600;color:var(--text-2);transition:.15s}
.user-menu .um-item:hover{background:var(--surface-2)}
.user-menu .um-item.danger{color:var(--danger)}
.user-menu .um-item.danger:hover{background:var(--danger-soft)}
.user-menu .um-item svg{width:16px;height:16px}


/* === v2_queue_scroll: queue en caja fija con scroll interno === */
#queueList{
  max-height: calc(100vh - 340px);
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  padding-right: 4px;
}
#queueList::-webkit-scrollbar{ width: 8px }
#queueList::-webkit-scrollbar-track{ background: transparent }
#queueList::-webkit-scrollbar-thumb{ background: var(--border, #d8d6cd); border-radius: 4px }
#queueList::-webkit-scrollbar-thumb:hover{ background: var(--muted, #9a988f) }

/* columnas del cockpit ancladas arriba (no se van con el scroll) */
.cockpit .col{ align-self: start; position: sticky; top: 12px; }


/* === v2_layout_cols: queue angosta, columnas balanceadas === */
.cockpit{
  display: grid !important;
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr) minmax(260px, 320px) !important;
  gap: 14px;
  align-items: start;
}
.col-queue .card{ padding: 14px }
#queueList{ max-height: calc(100vh - 250px); }
.q-item .q-meta{ font-size: 11px }
@media (max-width: 1280px){
  .cockpit{ grid-template-columns: minmax(0,1.2fr) minmax(0,1fr) !important; }
  .col-queue{ grid-column: 1 / -1 }
  #queueList{ max-height: 40vh }
}
