/* ═══════════════════════════════════════════════════════════════
   TWClaw Admin — Design System v2
   Dark mode · CSS variables · Modern components
   ═══════════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
button,.btn,[onclick],a,select,input[type='checkbox'],.nav-item,.alert-item,.skill-card,.ft-item{cursor:pointer;}

/* ── Theme tokens (Light) ── */
:root{
  --primary:#4f6ef2;--primary-dark:#3a56d4;--primary-bg:rgba(79,110,242,.06);
  --danger:#e74c3c;--danger-bg:rgba(231,76,60,.06);
  --success:#27ae60;--success-bg:rgba(39,174,96,.06);
  --warning:#f39c12;--warning-bg:rgba(243,156,18,.06);
  --info:#3498db;--purple:#6c5ce7;
  --bg:#f0f2f8;--bg-2:#f7f8fd;--card:#ffffff;
  --text:#2d3436;--text-light:#636e72;
  --border:#e8eaed;--hover:#f5f7ff;
  --radius:12px;
  --shadow:0 2px 12px rgba(0,0,0,.07);--shadow-lg:0 20px 60px rgba(0,0,0,.18);
  --mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;
  --sidebar-bg:#1a1d2e;--sidebar-border:rgba(255,255,255,.08);--sidebar-hover:rgba(255,255,255,.06);--sidebar-active:rgba(255,255,255,.1);
  --topbar-bg:#fff;--topbar-border:var(--border);
}

/* ── Theme tokens (Dark) ── */
@media(prefers-color-scheme:dark){
  :root:not([data-theme="light"]){
    --primary:#7c9ef8;--primary-dark:#6b8bf5;--primary-bg:rgba(124,158,248,.1);
    --danger:#f87171;--danger-bg:rgba(248,113,113,.1);
    --success:#4ade80;--success-bg:rgba(74,222,128,.1);
    --warning:#fbbf24;--warning-bg:rgba(251,191,36,.1);
    --info:#60a5fa;--purple:#a78bfa;
    --bg:#0f1117;--bg-2:#151826;--card:#1a1d2e;
    --text:#e2e8f0;--text-light:#94a3b8;
    --border:#2d3461;--hover:#1e2340;
    --shadow:0 2px 12px rgba(0,0,0,.35);--shadow-lg:0 20px 60px rgba(0,0,0,.55);
    --sidebar-bg:#111427;--sidebar-border:rgba(255,255,255,.06);--sidebar-hover:rgba(255,255,255,.05);--sidebar-active:rgba(255,255,255,.08);
    --topbar-bg:var(--card);--topbar-border:var(--border);
  }
}
:root[data-theme="dark"]{
  --primary:#7c9ef8;--primary-dark:#6b8bf5;--primary-bg:rgba(124,158,248,.1);
  --danger:#f87171;--danger-bg:rgba(248,113,113,.1);
  --success:#4ade80;--success-bg:rgba(74,222,128,.1);
  --warning:#fbbf24;--warning-bg:rgba(251,191,36,.1);
  --info:#60a5fa;--purple:#a78bfa;
  --bg:#0f1117;--bg-2:#151826;--card:#1a1d2e;
  --text:#e2e8f0;--text-light:#94a3b8;
  --border:#2d3461;--hover:#1e2340;
  --shadow:0 2px 12px rgba(0,0,0,.35);--shadow-lg:0 20px 60px rgba(0,0,0,.55);
  --sidebar-bg:#111427;--sidebar-border:rgba(255,255,255,.06);--sidebar-hover:rgba(255,255,255,.05);--sidebar-active:rgba(255,255,255,.08);
  --topbar-bg:var(--card);--topbar-border:var(--border);
}

body{font-family:system-ui,-apple-system,'PingFang SC','Microsoft YaHei',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;transition:background .2s,color .2s;}
a{color:var(--primary);text-decoration:none;}
a:hover{text-decoration:underline;}
code{font-family:var(--mono);}

/* ── Login ── */
#loginOverlay{display:none;position:fixed;inset:0;background:var(--bg);z-index:9999;align-items:center;justify-content:center;padding:20px;}
#loginOverlay.active{display:flex;}
.login-box{background:var(--card);border-radius:16px;padding:40px;width:380px;max-width:100%;box-shadow:var(--shadow-lg);text-align:center;border:1px solid var(--border);}
.login-box img{width:80px;height:80px;margin-bottom:12px;border-radius:14px;}
.login-box h1{font-size:22px;margin-bottom:4px;color:var(--text);}
.login-box p{color:var(--text-light);font-size:13px;margin-bottom:24px;}
.login-box input{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:14px;margin-bottom:12px;outline:none;transition:border-color .2s;background:var(--bg);color:var(--text);}
.login-box input:focus{border-color:var(--primary);}
.login-box button{width:100%;padding:12px;background:var(--primary);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;transition:background .2s;}
.login-box button:hover{background:var(--primary-dark);}
.login-error{color:var(--danger);font-size:12px;margin-top:8px;display:none;}
.login-title{font-size:16px;font-weight:800;margin-bottom:8px;color:var(--text);}

/* ── App shell ── */
.app{display:flex;min-height:100vh;}
.sidebar{position:fixed;left:0;top:0;bottom:0;width:240px;z-index:100;background:var(--sidebar-bg);color:#e2e8f0;display:flex;flex-direction:column;transition:transform .2s ease,width .2s ease;border-right:1px solid var(--sidebar-border);}
.sidebar .brand{padding:18px 16px;border-bottom:1px solid var(--sidebar-border);}
.brand-top{display:flex;align-items:center;gap:10px;}
.brand-top img{width:40px;height:40px;border-radius:10px;}
.brand-top .name{font-weight:800;font-size:17px;letter-spacing:.2px;color:#fff;}
.brand-sub{font-size:11px;opacity:.45;margin-top:3px;}
.nav{flex:1;padding:8px 0;overflow:auto;}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:15px;border-left:3px solid transparent;transition:all .15s;opacity:.65;user-select:none;color:#cbd5e1;}
.nav-item:hover{background:var(--sidebar-hover);opacity:.85;}
.nav-item.active{background:var(--sidebar-active);border-left-color:var(--primary);opacity:1;color:#fff;}
.nav-item .icon{font-size:16px;width:22px;text-align:center;display:flex;align-items:center;justify-content:center;}
.nav-item .icon svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;}
.nav-bottom{padding:12px 16px;border-top:1px solid var(--sidebar-border);font-size:11px;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.nav-bottom .theme-sw{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1);width:100%;}
.nav-bottom .theme-sw-opt{color:rgba(255,255,255,.5);}
.nav-bottom .theme-sw-opt:hover{color:rgba(255,255,255,.8);}
.nav-bottom .theme-sw-opt.active{background:rgba(255,255,255,.12);color:#fff;box-shadow:none;}
.main{margin-left:240px;min-height:100vh;flex:1;display:flex;flex-direction:column;transition:margin-left .2s ease;min-width:0;overflow-x:hidden;}

/* ── Topbar ── */
.topbar{background:var(--topbar-bg);padding:10px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--topbar-border);position:sticky;top:0;z-index:50;min-height:48px;gap:8px;}
.topbar-left{display:flex;align-items:center;gap:10px;min-width:0;}
/* Topbar burger — minimal, blends with background */
.topbar-burger{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:none;color:var(--text-light);cursor:pointer;border-radius:8px;transition:all .15s;padding:0;flex-shrink:0;opacity:.5;}
.topbar-burger:hover{opacity:1;color:var(--text);background:var(--hover);}
/* Topbar refresh — circle */
.topbar-refresh{height:32px;width:32px;display:flex;align-items:center;justify-content:center;border:none;background:var(--bg);color:var(--text-light);cursor:pointer;border-radius:50%;transition:all .2s;padding:0;flex-shrink:0;}
.topbar-refresh:hover{background:var(--primary);color:#fff;transform:rotate(30deg);}
.topbar-refresh.spinning svg{animation:spin .8s linear infinite;}
/* Topbar separator */
.topbar-sep{width:1px;height:28px;background:var(--border);flex-shrink:0;margin:0 4px;}
.topbar-title{font-size:16px;font-weight:700;color:var(--text);white-space:nowrap;}
.topbar-status{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-light);}
/* Inline icon button (delete row, edit partition, close overlay, etc.) */
.icon-btn{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-light);padding:2px;border-radius:4px;transition:all .15s;flex-shrink:0;}
.icon-btn:hover{color:var(--primary);background:var(--hover);}
.icon-btn.danger:hover{color:var(--danger);background:var(--danger-bg);}
.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0;}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.content{padding:16px;overflow-x:hidden;}

/* ── Theme toggle (segmented control, same as webdav-browser) ── */
.theme-sw{display:inline-flex;align-items:center;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:2px;gap:2px;flex-shrink:0;}
.theme-sw-opt{width:26px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:6px;border:none;background:none;cursor:pointer;transition:all .2s;color:var(--text-light);padding:0;}
.theme-sw-opt:hover{color:var(--text);}
.theme-sw-opt.active{background:var(--card);color:var(--text);box-shadow:0 1px 3px rgba(0,0,0,.1);}

/* ── Panels ── */
.panel{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden;margin-bottom:14px;min-width:0;}
.panel-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.panel-header h2{font-size:14px;font-weight:800;color:var(--text);}
.panel-body{padding:14px 16px;min-width:0;}

/* ── Stat cards ── */
.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:14px;}
@media(max-width:1100px){.stat-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(max-width:520px){.stat-grid{grid-template-columns:1fr;}}
.stat-card{background:var(--card);border-radius:var(--radius);padding:16px;border:1px solid var(--border);box-shadow:var(--shadow);border-left:4px solid var(--border);transition:transform .15s,box-shadow .15s;}
.stat-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.1);}
.stat-card .label{font-size:12px;color:var(--text-light);margin-bottom:6px;letter-spacing:.3px;}
.stat-card .value{font-size:26px;font-weight:900;line-height:1;}
.stat-card .sub{font-size:11px;color:var(--text-light);margin-top:6px;}
.stat-card.green{border-left-color:var(--success);}.stat-card.green .value{color:var(--success);}
.stat-card.blue{border-left-color:var(--info);}.stat-card.blue .value{color:var(--info);}
.stat-card.orange{border-left-color:var(--warning);}.stat-card.orange .value{color:var(--warning);}
.stat-card.purple{border-left-color:var(--purple);}.stat-card.purple .value{color:var(--purple);}
.stat-card.red{border-left-color:var(--danger);}.stat-card.red .value{color:var(--danger);}

/* ── Table ── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%;}
table{width:100%;border-collapse:collapse;font-size:13px;table-layout:auto;}
th{padding:9px 12px;background:var(--bg);color:var(--text-light);font-weight:700;text-align:center;border-bottom:2px solid var(--border);white-space:nowrap;}
th.sortable{cursor:pointer;user-select:none;position:relative;padding-right:22px;}
th.sortable::after{content:'⇅';position:absolute;right:6px;top:50%;transform:translateY(-50%);opacity:0;font-size:11px;color:var(--text-light);transition:opacity .15s;}
th.sortable:hover::after{opacity:.6;}
th.sortable[data-sort-dir='asc']::after{content:'↑';opacity:1;color:var(--primary);}
th.sortable[data-sort-dir='desc']::after{content:'↓';opacity:1;color:var(--primary);}
td{padding:9px 12px;border-bottom:1px solid var(--border);vertical-align:middle;text-align:center;color:var(--text);max-width:200px;overflow:hidden;text-overflow:ellipsis;}
tbody tr:hover td{background:var(--hover);}

/* ── Buttons ── */
.btn{height:32px;box-sizing:border-box;padding:0 12px;border:1.5px solid transparent;border-radius:8px;cursor:pointer;font-size:12px;font-weight:600;transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:5px;background:var(--card);color:var(--text);}
.btn:hover{border-color:var(--primary);color:var(--primary);}
.btn-sm{height:28px;padding:0 10px;font-size:11px;border-radius:7px;}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);}
.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger);}.btn-danger:hover{background:#c0392b;border-color:#c0392b;}
.btn-success{background:var(--success);color:#fff;border-color:var(--success);}.btn-success:hover{background:#219a52;border-color:#219a52;}
.btn-warning{background:var(--warning);color:#fff;border-color:var(--warning);}.btn-warning:hover{background:#d68910;border-color:#d68910;}
.btn-info{background:var(--info);color:#fff;border-color:var(--info);}.btn-info:hover{background:#2980b9;border-color:#2980b9;}
.btn-secondary{background:#636e72;color:#fff;border-color:#636e72;}.btn-secondary:hover{background:#535c60;border-color:#535c60;}
.btn-ghost{background:transparent;color:var(--text-light);border:1.5px solid var(--border);}.btn-ghost:hover{background:var(--hover);border-color:var(--primary);color:var(--primary);}
.btn-group{display:flex;gap:6px;flex-wrap:wrap;align-items:center;}
.batch-toolbar{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-bottom:12px;}

/* ── Inputs ── */
.search-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px;}
.search-bar input,.search-bar select{height:32px;box-sizing:border-box;padding:0 12px;border:1.5px solid var(--border);border-radius:8px;font-size:13px;outline:none;background:var(--card);color:var(--text);transition:border-color .2s;}
.search-bar input{flex:1;min-width:120px;}
.search-bar input:focus,.search-bar select:focus{border-color:var(--primary);}
.form-row{display:flex;gap:12px;flex-wrap:wrap;}
.form-group{display:flex;flex-direction:column;gap:5px;flex:1;min-width:160px;}
.form-group label{font-size:12px;color:var(--text-light);font-weight:700;}
.form-group input,.form-group select{height:36px;box-sizing:border-box;padding:0 12px;border:1.5px solid var(--border);border-radius:8px;font-size:13px;outline:none;background:var(--card);color:var(--text);transition:border-color .2s;}
.form-group select{padding-right:32px;}
.form-group textarea{padding:9px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:13px;outline:none;background:var(--card);color:var(--text);transition:border-color .2s;}
.form-group textarea{min-height:160px;font-family:var(--mono);font-size:12px;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);}
td select{padding:5px 8px;border:1.5px solid var(--border);border-radius:6px;font-size:12px;background:var(--card);color:var(--text);cursor:pointer;}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;}
.badge-green{background:var(--success-bg);color:var(--success);}
.badge-yellow{background:var(--warning-bg);color:var(--warning);}
.badge-red{background:var(--danger-bg);color:var(--danger);}
.badge-blue{background:rgba(52,152,219,.1);color:var(--info);}
.badge-gray{background:var(--hover);color:var(--text-light);}
.badge-purple{background:rgba(108,92,231,.08);color:var(--purple);}
.badge-orange{background:var(--warning-bg);color:var(--warning);}

/* ── Progress ── */
.prog-bar{height:6px;background:var(--border);border-radius:4px;overflow:hidden;min-width:80px;}
.prog-fill{height:100%;border-radius:4px;transition:width .35s;}

/* ── Empty ── */
.empty-state{text-align:center;padding:36px;color:var(--text-light);}
.empty-state .icon{font-size:38px;margin-bottom:8px;opacity:.45;}
.empty-state p{font-size:13px;}

/* ── Toast ── */
#toast{position:fixed;top:20px;left:50%;transform:translateX(-50%) translateY(-20px);padding:10px 22px;background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:10px;font-size:13px;z-index:9000;opacity:0;transition:all .3s;pointer-events:none;max-width:min(480px,calc(100vw - 40px));white-space:nowrap;box-shadow:var(--shadow-lg);}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
#toast.error{background:var(--danger);color:#fff;border-color:var(--danger);}
#toast.success{background:var(--success);color:#fff;border-color:var(--success);}
#toast.warning{background:var(--warning);color:#fff;border-color:var(--warning);}
#toast.info{background:var(--info);color:#fff;border-color:var(--info);}

/* ── Modal ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(4px);z-index:3000;align-items:center;justify-content:center;padding:18px;}
.modal-overlay.active{display:flex;}
.modal{background:var(--card);border-radius:16px;padding:24px;width:480px;max-width:100%;box-shadow:var(--shadow-lg);border:1px solid var(--border);}
.modal h3{font-size:16px;margin-bottom:8px;font-weight:800;color:var(--text);}
.modal p{color:var(--text-light);font-size:13px;margin-bottom:14px;line-height:1.6;}
.modal .modal-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap;}
.modal .highlight{color:var(--danger);font-weight:800;}
.progress-modal-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(4px);z-index:3100;align-items:center;justify-content:center;padding:18px;}
.progress-modal-overlay.active{display:flex;}
.progress-modal{background:var(--card);border-radius:16px;padding:24px;width:460px;max-width:100%;box-shadow:var(--shadow-lg);border:1px solid var(--border);}
.progress-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.progress-modal-header h3{font-size:16px;font-weight:800;margin:0;color:var(--text);}
.progress-modal-header .close-btn{background:none;border:none;font-size:16px;cursor:pointer;color:var(--text-light);padding:4px 8px;border-radius:6px;}
.progress-modal-header .close-btn:hover{background:var(--hover);}
.progress-bar-track{width:100%;height:20px;background:var(--border);border-radius:10px;overflow:hidden;margin-bottom:6px;position:relative;}
.progress-bar-fill{height:100%;background:var(--primary);border-radius:10px;transition:width .4s ease;}
.progress-bar-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);}
.progress-steps{max-height:180px;overflow-y:auto;margin-top:10px;padding:6px 0;font-size:12px;line-height:1.8;color:var(--text);}
.progress-steps::-webkit-scrollbar{width:4px;}
.progress-steps::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.progress-step-done{color:var(--success);}
.progress-step-error{color:var(--danger);}
.progress-step-running{color:var(--text);}

/* ── Pages ── */
.page{display:none;min-width:0;overflow:hidden;}.page.active{display:block;}

/* ── Dashboard layout ── */
.dash-grid{display:grid;grid-template-columns:1.6fr .9fr;gap:14px;align-items:stretch;}
.dash-grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;align-items:stretch;}
.dash-grid-4>.panel,.dash-grid>.panel{margin-bottom:0;}
@media(max-width:1100px){.dash-grid-4{grid-template-columns:1fr;}.dash-grid-4 .panel{grid-column:1/-1!important;}}
@media(max-width:1100px){.dash-grid{grid-template-columns:1fr;}}
@media(max-width:900px){#page-analytics .panel{min-width:0;}#page-analytics>div:last-child{grid-template-columns:1fr!important;}}
.alert-list{display:flex;flex-direction:column;gap:8px;}
.alert-item{border:1px solid var(--border);border-radius:10px;padding:10px 12px;background:var(--bg-2);display:flex;gap:10px;align-items:flex-start;transition:background .15s;}
.alert-item:hover{background:var(--hover);}
.alert-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex:0 0 auto;}
.alert-title{font-weight:800;font-size:12px;color:var(--text);}
.alert-meta{font-size:11px;color:var(--text-light);margin-top:3px;}

/* ── Worker card ── */
.worker-card{display:flex;align-items:flex-start;gap:14px;padding:14px;border:1.5px solid var(--border);border-radius:12px;margin-bottom:10px;background:var(--card);transition:border-color .15s;}
.worker-card:hover{border-color:var(--primary);}
.worker-card .wc-info{flex:1;min-width:0;}
.worker-card .wc-name{font-weight:800;font-size:13px;color:var(--text);}
.worker-card .wc-host{font-size:11px;color:var(--text-light);font-family:var(--mono);margin-top:2px;}
.worker-card .wc-stat{font-size:11px;color:var(--text-light);margin-top:6px;display:flex;gap:12px;flex-wrap:wrap;}
.worker-card .wc-progs{margin-top:8px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;}
@media(max-width:640px){.worker-card .wc-progs{grid-template-columns:1fr;}}

/* ── Tabs ── */
.tabs{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--card);}
.tab-headers{display:flex;gap:0;border-bottom:1px solid var(--border);background:var(--bg);overflow:auto;}
.tab-btn{padding:10px 14px;border:none;background:transparent;cursor:pointer;font-weight:700;font-size:12px;color:var(--text-light);white-space:nowrap;display:flex;gap:6px;align-items:center;transition:color .15s,background .15s;border-bottom:2px solid transparent;}
.tab-btn:hover{color:var(--text);background:var(--hover);}
.tab-btn.active{color:var(--primary);background:var(--card);border-bottom-color:var(--primary);}
.tab-panels{padding:14px;}
.tab-panel{display:none;}.tab-panel.active{display:block;}
.tab-panel .form-row{margin-bottom:12px;}.tab-panel .form-row:last-child{margin-bottom:0;}
.tab-panel .section-title{font-size:13px;font-weight:700;margin:16px 0 8px;display:flex;align-items:center;gap:6px;color:var(--text);}
.tab-panel .section-title:first-child{margin-top:0;}
.tab-panel .section-title .count{font-weight:400;color:var(--text-light);}
.tab-panel .info-card{padding:12px 14px;background:var(--bg-2);border-radius:10px;border:1px solid var(--border);margin-bottom:12px;}
.tab-panel .info-card .info-label{font-size:11px;color:var(--text-light);margin-bottom:3px;}
.tab-panel .info-card .info-value{font-size:14px;font-weight:700;color:var(--text);}
.tab-panel .info-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:12px;}
.tab-panel .info-row .info-card{flex:1;min-width:140px;margin-bottom:0;}
.tab-panel .hint{font-size:12px;color:var(--text-light);line-height:1.6;margin-top:8px;}
.tab-panel .hint.warn{padding:10px 12px;background:var(--warning-bg);border:1px solid var(--warning);border-radius:8px;color:var(--warning);}
.tab-panel .toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:12px;}
.tab-panel .toolbar .badge{vertical-align:middle;}
.tab-panel .status-line{font-size:12px;color:var(--text-light);display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap;}
.tab-panel .table-wrap{margin-bottom:14px;}

/* ── Cron ── */
.cron-preview-btn{background:none;border:none;cursor:pointer;font-size:14px;padding:2px 4px;border-radius:4px;vertical-align:middle;opacity:.7;transition:all .15s;}
.cron-preview-btn:hover{opacity:1;background:var(--primary-bg);}

/* ── Dropdown ── */
.btn-dropdown{position:relative;display:inline-flex;}
.btn-dropdown .btn-main{border-radius:7px 0 0 7px;}
.btn-dropdown .btn-caret{border-radius:0 7px 7px 0;padding:5px 6px;border-left:1px solid rgba(255,255,255,.25);}
.btn-dropdown .btn-caret::after{content:'▾';font-size:9px;}
.btn-dropdown .dropdown-menu{display:none;position:absolute;top:100%;right:0;margin-top:4px;background:var(--card);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-lg);z-index:20;min-width:120px;overflow:hidden;}
.btn-dropdown:hover .dropdown-menu,.btn-dropdown:focus-within .dropdown-menu{display:block;}
.btn-dropdown .dropdown-menu button{display:block;width:100%;text-align:left;padding:8px 14px;border:none;background:none;font-size:12px;cursor:pointer;white-space:nowrap;color:var(--text);}
.btn-dropdown .dropdown-menu button:hover{background:var(--hover);}

/* ── Batch panel ── */
.batch-panel-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:3000;align-items:center;justify-content:center;padding:18px;backdrop-filter:blur(4px);}
.batch-panel-overlay.active{display:flex;}
.batch-panel{background:var(--card);border-radius:16px;padding:24px;width:340px;max-width:100%;box-shadow:var(--shadow-lg);border:1px solid var(--border);}
.batch-panel h3{font-size:14px;font-weight:800;margin-bottom:14px;text-align:center;color:var(--text);}
.batch-panel .batch-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.batch-panel .batch-grid .batch-card{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1.5px solid var(--border);border-radius:10px;background:var(--card);cursor:pointer;font-size:12px;font-weight:600;color:var(--text);transition:all .15s;}
.batch-panel .batch-grid .batch-card:hover{background:var(--primary-bg);border-color:var(--primary);color:var(--primary);}
.batch-panel .batch-grid .batch-card .batch-icon{font-size:18px;flex-shrink:0;}
.batch-panel .batch-grid .batch-card.danger:hover{background:var(--danger-bg);color:var(--danger);border-color:var(--danger);}
.batch-panel .batch-grid .batch-card.full{grid-column:1/-1;justify-content:center;}
.batch-panel .batch-close{display:block;margin:14px auto 0;padding:6px 24px;border:none;background:none;color:var(--text-light);font-size:12px;cursor:pointer;border-radius:8px;}
.batch-panel .batch-close:hover{background:var(--hover);}

/* ── Details row ── */
.details-row>td{background:var(--bg-2)!important;padding:0!important;}
.details-row td>.details-wrap{padding:12px;text-align:left;width:0;min-width:100%;overflow:hidden;}
.details-wrap .tab-panels{max-width:100%;overflow:hidden;}
.details-wrap .tab-panel{max-width:100%;overflow-x:auto;}

/* ── File browser (in-page) ── */
.crumbs{display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-bottom:10px;}
.crumb{font-size:12px;color:var(--text-light);cursor:pointer;padding:3px 8px;border-radius:999px;border:1px solid var(--border);background:var(--card);transition:all .15s;}
.crumb:hover{border-color:var(--primary);color:var(--primary);}
.file-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:12px;align-items:start;}
@media(max-width:980px){.file-grid{grid-template-columns:1fr;}}
.file-list{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--card);}
.file-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;}
.file-item:hover{background:var(--hover);}
.file-item:last-child{border-bottom:none;}
.file-left{display:flex;align-items:center;gap:10px;min-width:0;}
.file-name{font-weight:700;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text);}
.file-meta{font-size:11px;color:var(--text-light);}
.preview{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--card);}
.preview-header{padding:10px 12px;border-bottom:1px solid var(--border);background:var(--bg);display:flex;align-items:center;justify-content:space-between;gap:10px;}
.preview-body{padding:12px;}
.code-block{background:#1e2533;color:#e2e8f0;border-radius:10px;padding:14px;font-family:var(--mono);font-size:12px;line-height:1.6;overflow:auto;max-height:520px;white-space:pre-wrap;word-break:break-word;}

/* ── Chat ── */
.chat{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px;max-height:520px;overflow:auto;}
[id^="chatContainer-"]{word-break:break-word;overflow-wrap:anywhere;min-width:0;}
[id^="chatMessages-"]{min-width:0;max-width:100%;}
[id^="chatMessages-"]>div{min-width:0;max-width:100%;}
[id^="chatMessages-"]>div>div{min-width:0;max-width:100%;}
.msg{display:flex;margin:8px 0;}
.msg .bubble{max-width:min(720px,85%);padding:10px 12px;border-radius:14px;font-size:13px;line-height:1.6;word-break:break-word;overflow-wrap:anywhere;}
.msg.user{justify-content:flex-end;}
.msg.user .bubble{background:var(--primary);color:#fff;border-bottom-right-radius:6px;}
.msg.assistant{justify-content:flex-start;}
.msg.assistant .bubble{background:var(--bg-2);color:var(--text);border-bottom-left-radius:6px;border:1px solid var(--border);}
.msg.system,.msg.tool{justify-content:center;}
.msg.system .bubble,.msg.tool .bubble{background:transparent;color:var(--text-light);border:none;font-size:12px;max-width:95%;}
.msg-meta{font-size:11px;color:rgba(255,255,255,.85);margin-top:6px;}
.msg.assistant .msg-meta{color:var(--text-light);}

/* ── Logs ── */
.log-stream{background:#0d1117;color:#58a6ff;border-radius:10px;padding:14px;font-family:var(--mono);font-size:12px;line-height:1.7;max-height:520px;overflow:auto;white-space:pre-wrap;word-break:break-word;border:1px solid #1b2838;}
.log-error{color:#ff6b6b;}.log-warn{color:#ffd93d;}.log-info{color:#6bcb77;}

/* ── Skills grid ── */
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;}
@media(max-width:1100px){.grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(max-width:640px){.grid{grid-template-columns:1fr;}}
.skill-drawer{margin-bottom:10px;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--card);box-shadow:var(--shadow);}
.skill-drawer-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;cursor:pointer;user-select:none;transition:background .15s;}
.skill-drawer-header:hover{background:var(--hover);}
.skill-drawer-header .drawer-left{display:flex;align-items:center;gap:10px;}
.skill-drawer-header .drawer-icon{font-size:15px;}
.skill-drawer-header .drawer-title{font-size:13px;font-weight:800;color:var(--text);}
.skill-drawer-header .drawer-arrow{font-size:11px;color:var(--text-light);transition:transform .2s;flex-shrink:0;}
.skill-drawer.collapsed .drawer-arrow{transform:rotate(-90deg);}
.skill-drawer-body{border-top:1px solid var(--border);padding:10px;}
.skill-drawer.collapsed .skill-drawer-body{display:none;}
.batch-drawer-check{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0;}
.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:8px;}
.skill-card{border:1.5px solid var(--border);border-radius:10px;background:var(--card);padding:12px 14px;display:flex;flex-direction:column;gap:5px;transition:all .15s;cursor:pointer;position:relative;}
.skill-card:hover{border-color:var(--primary);transform:translateY(-1px);}
.skill-card .skill-desc{flex:1;}
.skill-card .btn-group{margin-top:auto;}
.skill-title{display:flex;align-items:center;justify-content:space-between;gap:8px;}
.skill-title .name{font-weight:800;font-size:12px;font-family:var(--mono);color:var(--text);}
.skill-desc{font-size:11px;color:var(--text-light);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.skill-meta{font-size:10px;color:var(--text-light);display:flex;gap:8px;align-items:center;}
.skill-tags{display:flex;gap:6px;flex-wrap:wrap;}
.skill-card.batch-mode{cursor:default;}.skill-card.batch-mode:hover{transform:none;}
.skill-card .batch-check{position:absolute;top:10px;right:10px;width:18px;height:18px;accent-color:var(--primary);cursor:pointer;display:none;}
.skill-card.batch-mode .batch-check{display:block;}
.skill-card.batch-selected{border-color:var(--primary);background:var(--primary-bg);}
#skillsGrid{display:flex;flex-direction:column;gap:0;}

/* ── Editor overlay ── */
#editorOverlay,#agentEditorOverlay{display:none;position:fixed;inset:0;z-index:2000;background:rgba(15,23,42,.6);backdrop-filter:blur(6px);}
#editorOverlay.active,#agentEditorOverlay.active{display:block;}
.editor-shell{position:absolute;inset:14px;background:var(--card);border-radius:16px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--border);}
.editor-top{padding:8px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;background:var(--bg);min-height:44px;}
.agent-tab-bar{display:flex;gap:0;border-bottom:1px solid var(--border);background:var(--bg);padding:0 14px;flex-shrink:0;}
.agent-tab{padding:10px 18px;font-size:13px;font-weight:600;border:none;background:none;cursor:pointer;color:var(--text-light);border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap;}
.agent-tab:hover{color:var(--text);background:var(--hover);}
.agent-tab.active{color:var(--primary);border-bottom-color:var(--primary);}
.agent-tab-content{min-height:0;}
.editor-top-left{flex-shrink:0;}
.custom-partition-select{position:relative;display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border:1.5px solid var(--border);border-radius:8px;font-size:11px;font-weight:600;cursor:pointer;background:var(--card);color:var(--text);outline:none;transition:border-color .15s;user-select:none;min-width:80px;}
.custom-partition-select:focus,.custom-partition-select.open{border-color:var(--primary);}
.custom-partition-select .cps-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.custom-partition-select .cps-arrow{font-size:8px;margin-left:2px;opacity:.5;}
.custom-partition-select .cps-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:140px;background:var(--card);border:1.5px solid var(--border);border-radius:10px;box-shadow:var(--shadow-lg);z-index:10;overflow:hidden;display:none;}
.custom-partition-select.open .cps-dropdown{display:block;}
.cps-dropdown .cps-item{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:12px;font-weight:600;cursor:pointer;transition:background .12s;color:var(--text);}
.cps-dropdown .cps-item:hover{background:var(--hover);}
.cps-dropdown .cps-item.active{background:var(--primary-bg);}
.editor-top-center{flex:1;text-align:center;min-width:0;overflow:hidden;}
.editor-top .title{font-weight:800;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text);}
.editor-top-right{flex-shrink:0;display:flex;align-items:center;gap:4px;}
.editor-top-right .btn{font-size:12px;padding:5px 10px;border-color:transparent;}
.editor-top-right .btn:hover{background:var(--primary-bg);border-color:var(--border);}
.editor-btn-danger:hover{background:var(--danger-bg)!important;color:var(--danger)!important;}
.editor-sep{width:1px;height:18px;background:var(--border);flex-shrink:0;margin:0 2px;}
.editor-main{flex:1;display:grid;grid-template-columns:240px 1fr;min-height:0;}
@media(max-width:900px){.editor-main{grid-template-columns:1fr;}}
.filetree{border-right:1px solid var(--border);min-height:0;overflow:auto;background:var(--bg);}
.filetree .ft-item{padding:8px 12px;border-bottom:1px solid var(--border);cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .15s;color:var(--text);}
.filetree .ft-item:hover{background:var(--hover);}
.filetree .ft-item.active{background:var(--primary-bg);border-left:3px solid var(--primary);}
.filetree .ft-icon{font-size:14px;flex-shrink:0;width:20px;text-align:center;}
.filetree .ft-info{flex:1;min-width:0;}
.filetree .ft-name{font-family:var(--mono);font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.filetree .ft-meta{font-size:10px;color:var(--text-light);margin-top:1px;}
.filetree .ft-dir{padding:6px 12px;display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--text-light);cursor:pointer;user-select:none;border-bottom:1px solid var(--border);background:var(--bg-2);}
.filetree .ft-dir:hover{background:var(--hover);}
.filetree .ft-dir .dir-arrow{font-size:9px;transition:transform .15s;width:12px;text-align:center;}
.filetree .ft-dir.collapsed .dir-arrow{transform:rotate(-90deg);}
.filetree .ft-item.indent-1{padding-left:24px;}
.filetree .ft-item.indent-2{padding-left:36px;}
.filetree .ft-item.indent-3{padding-left:48px;}
.editor-pane{min-height:0;display:flex;flex-direction:column;background:var(--card);}
.editor-toolbar{padding:6px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--bg);}
.editor-filepath{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-light);min-width:0;overflow:hidden;}
.filepath-icon{font-size:14px;flex-shrink:0;}
.filepath-meta{font-size:11px;color:var(--text-light);opacity:.7;flex-shrink:0;}
.editor-filepath #editorFilePath{font-family:var(--mono);font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.editor-wrap{flex:1;display:flex;min-height:0;overflow:hidden;}
.line-numbers{width:48px;flex-shrink:0;background:var(--bg);border-right:1px solid var(--border);overflow:hidden;padding:14px 0;font-family:var(--mono);font-size:12px;line-height:1.6;color:var(--text-light);text-align:right;user-select:none;-webkit-user-select:none;opacity:.5;}
.line-numbers .ln{padding-right:10px;}
.editor-pane textarea,.editor-wrap textarea{flex:1;width:100%;height:100%;border:none;outline:none;padding:14px;font-family:var(--mono);font-size:12px;line-height:1.6;resize:none;tab-size:2;-moz-tab-size:2;overflow:auto;background:var(--card);color:var(--text);}
.editor-bottom{padding:8px 14px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;background:var(--bg);}

/* ── Sidebar collapse ── */
.sidebar.collapsed{transform:translateX(-100%);}
.main.sidebar-collapsed{margin-left:0!important;transition:margin-left .2s ease;}
@media(max-width:860px){
  .sidebar{transform:translateX(-100%);width:240px;}
  .sidebar.open{transform:translateX(0);}
  .main{margin-left:0;}
}
@media(max-width:560px){.sidebar{width:86vw;max-width:320px;}}

/* ── Markdown ── */
.markdown-body h1{font-size:20px;margin:18px 0 10px;padding-bottom:8px;border-bottom:1px solid var(--border);color:var(--text);}
.markdown-body h2{font-size:17px;margin:14px 0 8px;padding-bottom:6px;border-bottom:1px solid var(--border);color:var(--text);}
.markdown-body h3{font-size:14px;margin:12px 0 8px;color:var(--text);}
.markdown-body p{margin:8px 0;color:var(--text);}
.markdown-body ul,.markdown-body ol{margin:8px 0;padding-left:22px;}
.markdown-body li{margin:4px 0;}
.markdown-body code{background:var(--bg);padding:2px 6px;border-radius:6px;font-size:12px;}
.markdown-body pre{background:#1e2533;color:#e2e8f0;padding:14px;border-radius:10px;overflow:auto;margin:10px 0;}
.markdown-body pre code{background:none;padding:0;color:inherit;}
.markdown-body blockquote{border-left:3px solid var(--primary);padding:8px 14px;margin:10px 0;background:var(--primary-bg);border-radius:0 8px 8px 0;}
.markdown-body table{border-collapse:collapse;margin:12px 0;width:100%;}
.markdown-body th,.markdown-body td{border:1px solid var(--border);padding:8px 10px;text-align:left;}
.markdown-body th{background:var(--bg);font-weight:800;}
.markdown-body hr{border:none;border-top:1px solid var(--border);margin:14px 0;}

.modal-bg{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(15,23,42,.45);display:flex;align-items:center;justify-content:center;z-index:9999;backdrop-filter:blur(4px);}
.btn-copy-id{border:none;background:transparent;cursor:pointer;font-size:11px;padding:2px 4px;margin-left:4px;opacity:0;transition:opacity .15s;vertical-align:middle;color:var(--text-light);}
td:hover .btn-copy-id{opacity:.7;}
.btn-copy-id:hover{opacity:1!important;}

/* ── Toggle switch ── */
.toggle-switch{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0;}
.toggle-switch input{opacity:0;width:0;height:0;}
.toggle-switch .slider{position:absolute;cursor:pointer;inset:0;background:var(--border);border-radius:20px;transition:.2s;}
.toggle-switch .slider:before{content:'';position:absolute;height:14px;width:14px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 2px rgba(0,0,0,.12);}
.toggle-switch input:checked+.slider{background:var(--primary);}
.toggle-switch input:checked+.slider:before{transform:translateX(16px);}

/* ── Employee toolbar ── */
.emp-toolbar{align-items:center;}
.emp-toolbar .emp-tabs{display:flex;gap:4px;flex-shrink:0;}
.emp-toolbar .emp-tabs .btn{font-size:12px;padding:7px 12px;}
.emp-toolbar input,.emp-toolbar select{height:36px;box-sizing:border-box;}
.emp-toolbar>.btn{height:36px;box-sizing:border-box;font-size:12px;}
.emp-toolbar input{flex:1;min-width:100px;max-width:200px;}
.search-divider{border-left:1px solid var(--border);height:20px;flex-shrink:0;}
#empTableWrap>thead>tr>th,#empTableWrap>tbody>tr:not(.details-row)>td{padding:4px 6px;white-space:nowrap;}
#empTableWrap>thead>tr>th:nth-child(2),#empTableWrap>tbody>tr:not(.details-row)>td:nth-child(2){max-width:80px;overflow:hidden;}
#empTableWrap>tbody>tr:not(.details-row)>td:nth-child(2) code{display:inline-block;max-width:44px;overflow:hidden;text-overflow:ellipsis;vertical-align:middle;}
#empTableWrap>thead>tr>th:nth-child(3),#empTableWrap>tbody>tr:not(.details-row)>td:nth-child(3){max-width:100px;overflow:hidden;text-overflow:ellipsis;}
#empTableWrap>thead>tr>th:nth-child(4),#empTableWrap>tbody>tr:not(.details-row)>td:nth-child(4){max-width:80px;overflow:hidden;text-overflow:ellipsis;}
#empTableWrap>tbody>tr:not(.details-row)>td:nth-child(4) code{display:inline-block;max-width:72px;overflow:hidden;text-overflow:ellipsis;vertical-align:middle;}
#empTableWrap>tbody>tr:not(.details-row)>td:nth-child(5) select{max-width:100px;}
#empTableWrap>tbody>tr:not(.details-row)>td:last-child .btn-group{flex-wrap:nowrap!important;gap:3px;justify-content:center;}
#empTableWrap .btn-sm{height:auto;padding:3px 7px;white-space:nowrap;}
#containerTable td,#llmTokenTable td{padding:4px 8px;line-height:1.3;}
#containerTable th,#llmTokenTable th{padding:6px 8px;}
#containerTable .btn-group,#llmTokenTable .btn-group{flex-wrap:nowrap;gap:3px;}
#containerTable .btn-sm,#llmTokenTable .btn-sm{height:auto;padding:2px 7px;font-size:11px;line-height:1.3;min-height:0;}

/* ── Session Picker ── */
.sp-modal{background:var(--card);border-radius:16px;width:480px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--border);}
.sp-header{padding:18px 24px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.sp-header h3{margin:0;font-size:15px;font-weight:700;color:var(--text);}
.sp-close{background:none;border:none;font-size:16px;color:var(--text-light);padding:4px 8px;border-radius:6px;line-height:1;cursor:pointer;}
.sp-close:hover{background:var(--hover);}
.sp-search-wrap{padding:12px 24px 8px;position:relative;}
.sp-search-wrap input{width:100%;padding:9px 14px 9px 36px;border:1.5px solid var(--border);border-radius:10px;font-size:13px;outline:none;background:var(--bg);color:var(--text);box-sizing:border-box;transition:border-color .2s;}
.sp-search-wrap input:focus{border-color:var(--primary);}
.sp-search-icon{position:absolute;left:36px;top:50%;transform:translateY(-50%);font-size:14px;opacity:.4;pointer-events:none;}
.sp-select-all{padding:6px 24px;display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--text-light);}
.sp-select-all label{display:flex;align-items:center;gap:6px;cursor:pointer;font-weight:600;}
.sp-selected-count{font-size:12px;color:var(--primary);font-weight:700;}
.sp-list{flex:1;overflow-y:auto;padding:4px 24px 8px;max-height:340px;}
.sp-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;margin-bottom:4px;cursor:pointer;transition:background .15s;}
.sp-item:hover{background:var(--hover);}
.sp-item input[type="checkbox"]{flex-shrink:0;width:16px;height:16px;accent-color:var(--primary);}
.sp-avatar{width:30px;height:30px;border-radius:50%;flex-shrink:0;object-fit:cover;}
.sp-avatar-placeholder{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0;}
.sp-item-info{flex:1;min-width:0;}
.sp-item-name{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text);}
.sp-item-id{font-size:11px;color:var(--text-light);margin-top:1px;}
.sp-footer{padding:12px 24px 16px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;}

/* ── GitHub Skill Picker ── */
.gh-picker-modal{background:var(--card);border-radius:16px;width:640px;max-width:90vw;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--border);}
.gh-picker-header{padding:18px 24px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.gh-picker-header h3{margin:0;font-size:15px;font-weight:700;color:var(--text);}
.gh-picker-list{flex:1;overflow-y:auto;max-height:400px;padding:4px 24px 8px;}
.gh-picker-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:10px;margin-bottom:4px;cursor:pointer;transition:background .15s;border:1px solid transparent;}
.gh-picker-item:hover{background:var(--hover);border-color:var(--border);}
.gh-picker-item input[type="checkbox"]{flex-shrink:0;width:16px;height:16px;accent-color:var(--primary);margin-top:2px;}
.gh-picker-item-info{flex:1;min-width:0;}
.gh-picker-item-name{font-size:13px;font-weight:600;color:var(--text);}
.gh-picker-item-desc{font-size:12px;color:var(--text-light);margin-top:2px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.gh-picker-footer{padding:12px 24px 16px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;}

/* ── Subscription Manager ── */
.sub-mgr-group{margin-bottom:14px;border:1px solid var(--border);border-radius:12px;overflow:hidden;}
.sub-mgr-repo{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg);border-bottom:1px solid var(--border);color:var(--text);}
.sub-mgr-skills{padding:6px 14px;}
.sub-mgr-skill{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--text);}
.sub-mgr-skill:last-child{border-bottom:none;}
.sub-mgr-skill-active{background:var(--primary-bg);border-left:3px solid var(--primary);padding-left:11px!important;}
.sub-mgr-skill-inactive{opacity:.65;border-left:3px solid transparent;padding-left:11px!important;}
.sub-mgr-skill-inactive:hover{opacity:1;background:var(--hover);}

/* ── Orgmgmt tree mobile ── */
@media(max-width:700px){
  #orgmgmt-content>div>div:first-child{flex-direction:column!important;}
  #orgDeptTree{width:100%!important;min-width:0!important;max-width:100%!important;max-height:40vh!important;border-right:none!important;border-bottom:1px solid var(--border)!important;border-radius:var(--radius) var(--radius) 0 0!important;}
}

/* ── Analytics rank grid ── */
.analytics-rank-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}
@media(max-width:900px){.analytics-rank-grid{grid-template-columns:1fr;}}

/* ── Utilities ── */
.text-muted{color:var(--text-light);}.text-sm{font-size:12px;}.text-xs{font-size:11px;}.text-mono{font-family:var(--mono);}.fw-700{font-weight:700;}.nowrap{white-space:nowrap;}

/* ═══ Mobile Responsive ═══ */
@media(max-width:640px){
  .modal,.progress-modal{width:100%!important;max-width:100%!important;min-width:0!important;padding:16px;border-radius:12px;}
  .modal-overlay,.progress-modal-overlay,.modal-bg{padding:10px;}
  .modal-bg>div{width:100%!important;max-width:100%!important;min-width:0!important;padding:16px;box-sizing:border-box;}
  .btn{min-height:30px;padding:5px 10px;font-size:12px;}
  .btn-sm{min-height:26px;padding:4px 8px;font-size:11px;}
  .nav-item{padding:12px 16px;min-height:42px;}
  td select{min-height:28px;padding:4px 6px;font-size:12px;}
  .tab-btn{padding:10px 12px;min-height:36px;}
  .search-bar input,.search-bar select{min-height:30px;font-size:12px;}
  .form-group input,.form-group select,.form-group textarea{min-height:32px;}
  .form-row{flex-direction:column;}
  .form-group{min-width:0;}
  .search-bar{flex-wrap:wrap;gap:5px;align-items:center;}
  .search-bar>*{flex:0 0 auto;}
  .search-bar input{min-width:0!important;max-width:none!important;width:auto;flex:1 1 80px;}
  .search-bar select{min-width:0;width:auto;max-width:45%;}
  .search-divider{display:none;}
  .btn-group{gap:5px;}
  .emp-toolbar{gap:4px;}
  .emp-toolbar .emp-tabs{gap:2px;}
  .emp-toolbar .emp-tabs .btn{font-size:11px;padding:3px 6px;}
  .emp-toolbar input{flex:1 1 60px;min-width:0!important;max-width:none!important;}
  .emp-toolbar select{font-size:11px;padding:4px 6px;}
  .emp-toolbar .btn-sm{font-size:10px;padding:3px 6px;min-height:24px;}
  .content{padding:10px;}
  .panel-header{padding:10px 12px;flex-wrap:wrap;gap:6px;}
  .panel-header .btn-group{width:100%;}
  .panel-body{padding:10px 12px;}
  .stat-card{padding:12px;}.stat-card .value{font-size:20px;}
  .empty-state{padding:20px;}
  .topbar{padding:6px 10px;flex-wrap:nowrap;gap:4px;}
  .topbar-left{gap:4px;min-width:0;flex-shrink:1;}
  .topbar-title{font-size:13px;white-space:nowrap;}
  .topbar-burger{width:28px;height:28px;}
  .topbar-refresh{width:26px;height:26px;}
  .topbar-sep{display:none;}
  .topbar-right{flex-shrink:0;margin-left:auto;}
  .topbar-status{font-size:11px;white-space:nowrap;}
  .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%;}
  table{font-size:12px;}
  th{padding:6px 8px;font-size:11px;}td{padding:6px 8px;}
  .panel-header .btn-group{flex-wrap:wrap;}
  .panel-header .btn-group input,.panel-header .btn-group select{min-width:0!important;width:100%;}
  .dash-grid{grid-template-columns:1fr;gap:10px;}
  .dash-grid-4{grid-template-columns:1fr;gap:10px;}
  .worker-card{flex-direction:column;}.worker-card .wc-progs{grid-template-columns:repeat(2,1fr);}
  #page-analytics>div:last-child{grid-template-columns:1fr!important;}
  .skills-grid{grid-template-columns:1fr!important;}
  .chat{max-height:60vh;}.msg .bubble{max-width:90%;}
  .code-block,.log-stream{max-height:300px;font-size:11px;}
  .editor-shell{inset:4px;border-radius:10px;}
  .editor-main{grid-template-columns:1fr;}
  .filetree{max-height:30vh;border-right:none;border-bottom:1px solid var(--border);}
  .line-numbers{width:36px;}.line-numbers .ln{padding-right:6px;font-size:11px;}
  .editor-toolbar{flex-wrap:wrap;gap:6px;}
}
@media(max-width:860px){
  .main{max-width:100vw;}
  .content{max-width:100vw;overflow-x:hidden;}
  .table-wrap{max-width:calc(100vw - 24px);overflow-x:auto;}
}
/* Model picker & tag pool: allow floating overlays to escape all ancestor clips */
.panel-overflow-visible,.panel-overflow-visible>.panel-body{overflow:visible !important;}
#page-settings,#page-settings>.tabs,#page-settings .tab-panels,#page-settings .tab-panel{overflow:visible !important;}
/* Model picker & tag pool items */
.mpk-item{display:flex;flex-direction:row;align-items:center;flex-wrap:nowrap;}
.mpk-item.mpk-hidden,.mpk-group.mpk-hidden{display:none !important;}
.mpk-item:hover{background:var(--bg-light,#f0f0f0) !important;}
.mpk-item.mpk-sel{background:var(--primary-bg,#e3f2fd);border:1px solid var(--primary,#42a5f5);}
.mpk-item.mpk-sel:hover{background:color-mix(in srgb,var(--primary-bg,#e3f2fd) 70%,var(--primary,#42a5f5)) !important;}
.mpk-item>span:last-child{margin-left:auto;}
.mpk-item svg{display:inline-block;flex-shrink:0;width:14px;height:14px;}
/* Drag & drop: insertion indicator */
.fb-tag.drag-over-left,.av-tag.drag-over-left{box-shadow:-3px 0 0 0 var(--primary,#42a5f5);}
.fb-tag.drag-over-right,.av-tag.drag-over-right{box-shadow:3px 0 0 0 var(--primary,#42a5f5);}
.fb-tag[style*="opacity: 0.4"],.av-tag[style*="opacity: 0.4"]{transform:scale(0.95);}
