/* ============================================================
 * THEME.CSS — INVENT Projetos · V2 "Command"
 * Redesign completo (31/05/2026). Linguagem visual nova e premium,
 * mantendo a marca INVENT (amarelo #F5C300). Tipografia: Sora (display),
 * Inter (UI), JetBrains Mono (dados). Cascata p/ todas as páginas.
 * ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@500;600;700;800&family=JetBrains+Mono:wght@500;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --brand:#F5C300;
  --brand-2:#FFDA4B;
  --brand-dim:rgba(245,195,0,.14);
  --brand-ink:#0b0e14;
  --accent:#38bdf8;          /* ciano de dados */
  --accent-2:#34d399;
  --bg:#080b11;
  --bg2:#0d121b;             /* sidebar/topbar */
  --panel:#11161f;
  --panel-2:#161c27;
  --surface:rgba(255,255,255,.04);
  --surface2:rgba(255,255,255,.08);
  --border:rgba(255,255,255,.075);
  --border2:rgba(255,255,255,.14);
  --text:#eaf0f8;
  --muted:#7c8699;
  --muted2:#9aa6b8;
  --green:#22c55e; --blue:#38bdf8; --red:#f43f5e; --amber:#f59e0b; --purple:#a855f7;
  --sidebar-w:248px;
  --sidebar-collapsed:68px;
  --radius:16px;
  --radius-sm:10px;
  --shadow:0 18px 50px -18px rgba(0,0,0,.7);
  --font:'Inter',system-ui,sans-serif;
  --font-display:'Sora','Inter',sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
}
[data-theme="light"]{
  --bg:#eef1f6; --bg2:#ffffff; --panel:#ffffff; --panel-2:#f6f8fb;
  --surface:rgba(15,23,42,.035); --surface2:rgba(15,23,42,.06);
  --border:rgba(15,23,42,.09); --border2:rgba(15,23,42,.16);
  --text:#0d1320; --muted:#64748b; --muted2:#475569;
  --shadow:0 14px 40px -18px rgba(15,23,42,.25);
}

html,body{
  height:100%;
  font-family:var(--font);
  color:var(--text);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
  background:
    radial-gradient(1100px 600px at 100% -8%, rgba(245,195,0,.07), transparent 60%),
    radial-gradient(800px 600px at -8% 4%, rgba(56,189,248,.05), transparent 55%),
    var(--bg);
}
body::before{ /* grade sutil estilo command center */
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000,transparent 75%);
          mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000,transparent 75%);
}
[data-theme="light"] body::before{opacity:.6;background-image:linear-gradient(rgba(15,23,42,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,.03) 1px,transparent 1px)}
button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit}
a{color:inherit;text-decoration:none}
input,select,textarea{font-family:inherit}

::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:6px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.2);background-clip:padding-box}

/* ── Layout ──────────────────────────────────────────────── */
.app{display:flex;height:100vh;overflow:hidden;position:relative;z-index:1}
#main{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-width:0}
.page{padding:26px 30px 70px;animation:rise .5s cubic-bezier(.2,.7,.2,1)}
@keyframes rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ── Sidebar ─────────────────────────────────────────────── */
#sidebar{
  width:var(--sidebar-w);min-width:var(--sidebar-w);
  background:linear-gradient(180deg,var(--bg2),color-mix(in srgb,var(--bg2) 80%, #000));
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  transition:width .3s cubic-bezier(.4,0,.2,1),min-width .3s cubic-bezier(.4,0,.2,1);
  position:relative;z-index:10;overflow:hidden;
}
#sidebar.collapsed{width:var(--sidebar-collapsed);min-width:var(--sidebar-collapsed)}
.sb-header{padding:20px 16px 16px;display:flex;align-items:center;gap:11px}
.sb-logo{
  width:38px;height:38px;min-width:38px;border-radius:11px;
  background:linear-gradient(140deg,var(--brand),#e0a000);
  display:flex;align-items:center;justify-content:center;
  font-size:19px;font-weight:900;color:var(--brand-ink);flex-shrink:0;
  box-shadow:0 6px 18px -4px rgba(245,195,0,.5);
}
.sb-brand{overflow:hidden;line-height:1.2;transition:opacity .2s}
.sb-brand-name{font-family:var(--font-display);font-size:17px;font-weight:800;letter-spacing:-.4px;white-space:nowrap;color:var(--text)}
.sb-brand-name .vy{color:var(--brand)}
.sb-brand-name .sb-brand-desc{font-size:13px;font-weight:600;color:var(--muted2);letter-spacing:0}
.sb-brand-by{font-size:8px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--muted);white-space:nowrap;margin-top:1px}
#sidebar.collapsed .sb-brand{opacity:0;width:0}
#sidebar-toggle{margin-left:auto;color:var(--muted);font-size:18px;padding:4px 7px;border-radius:8px;flex-shrink:0;transition:.2s}
#sidebar-toggle:hover{color:var(--text);background:var(--surface2)}
#sidebar.collapsed #sidebar-toggle{transform:rotate(180deg)}

.sb-nav{flex:1;padding:8px 12px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:2px}
.sb-group{font-size:9.5px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted);padding:14px 12px 6px;white-space:nowrap}
#sidebar.collapsed .sb-group{opacity:0;height:8px;padding:4px 0}
.nav-item{
  position:relative;display:flex;align-items:center;gap:13px;
  padding:10px 12px;border-radius:11px;
  color:var(--muted2);font-size:13px;font-weight:600;
  transition:background .16s,color .16s;white-space:nowrap;overflow:hidden;
}
.nav-item:hover{background:var(--surface2);color:var(--text)}
.nav-item.active{background:linear-gradient(90deg,var(--brand-dim),transparent);color:var(--brand)}
.nav-item.active::before{content:'';position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--brand);box-shadow:0 0 12px var(--brand)}
.nav-icon{font-size:15px;flex-shrink:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center}
.nav-badge{margin-left:auto;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--red);color:#fff;font-size:10px;font-weight:800;align-items:center;justify-content:center;font-family:var(--font-mono);box-shadow:0 0 10px rgba(244,63,94,.5)}
.nav-badge.pulse{animation:nx-badge-pulse 1.5s ease-in-out infinite}
/* Sininho de notificações */
.bell-count{position:absolute;top:-3px;right:-3px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--red);color:#fff;font-size:9px;font-weight:800;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);box-shadow:0 0 8px rgba(244,63,94,.6)}
.notif-pop{position:fixed;top:62px;right:18px;width:340px;max-width:calc(100vw - 36px);max-height:70vh;overflow-y:auto;background:var(--bg2);border:1px solid var(--border2);border-radius:14px;box-shadow:0 18px 48px rgba(0,0,0,.6);z-index:1200;animation:rise .16s ease}
.notif-hd{font-size:12px;font-weight:800;padding:13px 15px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg2)}
.notif-it{display:flex;gap:11px;align-items:flex-start;padding:11px 15px;cursor:pointer;border-bottom:1px solid var(--border);transition:.12s}
.notif-it:hover{background:var(--surface2)}
.notif-it.novo{background:rgba(245,195,0,.06);border-left:3px solid var(--brand)}
.notif-ic{font-size:16px;flex-shrink:0}
.notif-ft{padding:11px 15px;text-align:center;font-size:12px;font-weight:700;color:var(--brand);cursor:pointer}
.notif-ft:hover{background:var(--surface2)}

/* ===== Pulse de severidade / atenção (reaproveitável em todo o sistema) ===== */
@keyframes nx-pulse-red{0%,100%{box-shadow:0 0 0 rgba(239,68,68,0)}50%{box-shadow:0 0 16px rgba(239,68,68,.5)}}
@keyframes nx-pulse-orange{0%,100%{box-shadow:0 0 0 rgba(249,115,22,0)}50%{box-shadow:0 0 12px rgba(249,115,22,.35)}}
@keyframes nx-blink{0%,100%{opacity:1}50%{opacity:.25}}
@keyframes nx-badge-pulse{0%,100%{transform:scale(1);box-shadow:0 0 6px rgba(244,63,94,.5)}50%{transform:scale(1.18);box-shadow:0 0 16px rgba(244,63,94,.95)}}
.nx-pulse-red{animation:nx-pulse-red 2.2s ease-in-out infinite}
.nx-pulse-orange{animation:nx-pulse-orange 2.8s ease-in-out infinite}
.nx-blink{display:inline-block;animation:nx-blink .8s steps(1,end) infinite}
@media (prefers-reduced-motion:reduce){.nav-badge.pulse,.nx-pulse-red,.nx-pulse-orange,.nx-blink,.kb-card.crit,.kb-card.urg{animation:none}}
#sidebar.collapsed .nav-badge{position:absolute;right:8px;top:6px;margin:0;min-width:8px;height:8px;padding:0;font-size:0}
#sidebar.collapsed .nav-label{opacity:0;width:0}
.sb-footer{padding:12px;border-top:1px solid var(--border)}
#sidebar-user{display:flex;align-items:center;gap:11px;padding:8px;border-radius:12px;background:var(--surface)}
.su-avatar{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;flex-shrink:0}
.su-info{overflow:hidden;flex:1}
.su-nome{font-size:12.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.su-papel{font-size:10px;color:var(--muted);text-transform:capitalize}
.su-logout{padding:6px 8px;color:var(--muted);font-size:15px;border-radius:8px;transition:.2s}
.su-logout:hover{color:var(--red);background:var(--surface2)}
#sidebar.collapsed .su-info,#sidebar.collapsed .su-logout{opacity:0;width:0;padding:0}

/* ── Topbar ──────────────────────────────────────────────── */
.topbar{
  padding:16px 30px;display:flex;align-items:center;gap:14px;
  border-bottom:1px solid var(--border);
  background:color-mix(in srgb,var(--bg2) 75%, transparent);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  position:sticky;top:0;z-index:6;
}
.topbar-title{font-family:var(--font-display);font-size:19px;font-weight:800;letter-spacing:-.4px;flex:1;display:flex;align-items:baseline;gap:10px}
.topbar-sub{font-size:12px;color:var(--muted);font-weight:400;font-family:var(--font)}
.topbar-actions{display:flex;align-items:center;gap:9px}

/* ── Botões ──────────────────────────────────────────────── */
.btn-icon{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);color:var(--muted2);font-size:15px;transition:.18s}
.btn-icon:hover{background:var(--surface2);color:var(--text);border-color:var(--border2)}
.btn-primary{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:var(--brand-ink);font-size:13px;font-weight:700;border-radius:11px;transition:.18s;box-shadow:0 8px 20px -8px rgba(245,195,0,.6)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 26px -8px rgba(245,195,0,.7)}
.btn-outline{display:inline-flex;align-items:center;gap:6px;padding:9px 15px;background:var(--surface);border:1px solid var(--border2);border-radius:11px;font-size:12.5px;font-weight:600;color:var(--muted2);transition:.18s}
.btn-outline:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-dim)}
.btn-danger{display:inline-flex;align-items:center;gap:6px;padding:9px 15px;background:rgba(244,63,94,.12);border:1px solid rgba(244,63,94,.35);border-radius:11px;font-size:12.5px;font-weight:600;color:#fb7185;transition:.18s}
.btn-danger:hover{background:rgba(244,63,94,.22)}

/* ── Cards ───────────────────────────────────────────────── */
.card{
  background:linear-gradient(160deg,var(--panel),var(--panel-2));
  border:1px solid var(--border);
  border-radius:var(--radius);padding:20px;position:relative;overflow:hidden;
  box-shadow:var(--shadow);
  transition:border-color .2s,transform .2s;
}
.card::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.14),transparent)}
.card-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--muted2);margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.card-title::before{content:'';display:inline-block;width:3px;height:13px;border-radius:2px;background:var(--brand);margin-right:9px;flex-shrink:0}
.card-title>span:first-child,.card-title>*{}
.ct-action{font-size:11px;color:var(--muted2);cursor:pointer;font-weight:600;text-transform:none;letter-spacing:0}
.ct-action:hover{color:var(--brand)}

.grid{display:grid;gap:18px}
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-5{grid-column:span 5}
.col-6{grid-column:span 6}.col-7{grid-column:span 7}.col-8{grid-column:span 8}
.col-9{grid-column:span 9}.col-12{grid-column:span 12}

/* ── KPI ─────────────────────────────────────────────────── */
.kpi{display:flex;flex-direction:column;gap:7px}
.kpi-top{display:flex;align-items:flex-start;justify-content:space-between}
.kpi-label{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--muted)}
.kpi-value{font-family:var(--font-mono);font-size:34px;font-weight:700;letter-spacing:-1.5px;line-height:1}
.kpi-sub{font-size:12px;color:var(--muted2)}
.kpi-icon{font-size:17px;opacity:.7}

/* ── Badges ──────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;white-space:nowrap;border:1px solid transparent}
.pill{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:9px;font-size:11px;font-weight:600;background:var(--surface);border:1px solid var(--border)}

/* ── Tabelas ─────────────────────────────────────────────── */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);padding:10px 12px;text-align:left;border-bottom:1px solid var(--border2);white-space:nowrap}
td{padding:12px;font-size:13px;border-bottom:1px solid var(--border);vertical-align:middle}
tbody tr{transition:background .14s}
tbody tr:hover td{background:var(--surface2)}

/* ── Forms ───────────────────────────────────────────────── */
.form-group{margin-bottom:15px}
.form-label{display:block;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin-bottom:8px}
.form-control{width:100%;padding:11px 13px;background:var(--surface);border:1px solid var(--border2);border-radius:11px;color:var(--text);font-size:13px;outline:none;transition:.18s}
.form-control:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim)}
.form-control::placeholder{color:var(--muted)}
select.form-control option{background:#11161f;color:var(--text)}
textarea.form-control{resize:vertical;min-height:72px}

/* ── Fluxo de Valor ──────────────────────────────────────── */
.vs-legend{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:18px;align-items:center}
.vs-legend .lg{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted2)}
.vs-legend .dot{width:10px;height:10px;border-radius:3px}
.vs-board{overflow-x:auto;padding-bottom:8px}
.vs-row{display:grid;grid-template-columns:200px repeat(14,minmax(60px,1fr));align-items:stretch;border-bottom:1px solid var(--border)}
.vs-row.head{position:sticky;top:0;z-index:3;background:var(--bg2)}
.vs-head-cell{padding:11px 6px;text-align:center;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);border-left:1px solid var(--border);line-height:1.2}
.vs-head-cell .he{font-size:15px;display:block;margin-bottom:3px}
.vs-proj-cell{padding:12px 14px;display:flex;flex-direction:column;gap:3px;justify-content:center;position:sticky;left:0;background:var(--bg2);z-index:2}
.vs-proj-cell .pn{font-size:13px;font-weight:700;color:var(--text);cursor:pointer}
.vs-proj-cell .pn:hover{color:var(--brand)}
.vs-proj-cell .pc{font-size:10px;color:var(--muted);font-family:var(--font-mono)}
.vs-cell{border-left:1px solid var(--border);display:flex;align-items:center;justify-content:center;padding:6px 2px;min-height:54px;cursor:pointer;transition:background .15s;position:relative}
.vs-cell:hover{background:var(--surface2)}
.vs-node{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;position:relative}
.vs-node .vp{position:absolute;bottom:-3px;left:50%;transform:translateX(-50%);font-size:8px;font-weight:700;color:var(--muted);font-family:var(--font-mono)}
.vs-row:hover .vs-proj-cell{background:var(--surface2)}

/* ── Dept card ───────────────────────────────────────────── */
.dept-card{display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:12px;background:var(--surface);border:1px solid var(--border);transition:.16s;cursor:pointer}
.dept-card:hover{transform:translateX(3px);border-color:var(--brand);background:var(--brand-dim)}
.dept-ico{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.dept-meta{flex:1;min-width:0}
.dept-nome{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dept-gestor{font-size:10px;color:var(--muted)}
.dept-nums{display:flex;gap:10px;font-size:11px;font-weight:700;font-family:var(--font-mono)}

/* ── Progress bar ────────────────────────────────────────── */
.pbar{height:8px;border-radius:5px;background:var(--surface2);overflow:hidden}
.pbar>i{display:block;height:100%;border-radius:5px;transition:width .8s cubic-bezier(.4,0,.2,1)}

/* ── Cobrança item ───────────────────────────────────────── */
.cob-item{display:flex;align-items:center;gap:12px;padding:13px 15px;border-radius:12px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--muted);margin-bottom:9px;transition:.15s}
.cob-item:hover{background:var(--surface2);transform:translateX(2px)}
.cob-flow{display:flex;align-items:center;gap:5px;font-size:13px;font-weight:700;white-space:nowrap}
.cob-main{flex:1;min-width:0}
.cob-titulo{font-size:13px;font-weight:600}
.cob-meta{font-size:11px;color:var(--muted);margin-top:2px}

.ring-wrap{display:flex;align-items:center;justify-content:center}

/* ── Funil ───────────────────────────────────────────────── */
.funnel{display:flex;flex-direction:column;gap:6px}
.funnel-row{display:flex;align-items:center;gap:10px}
.funnel-bar{height:26px;border-radius:7px;display:flex;align-items:center;padding:0 10px;font-size:11px;font-weight:800;color:var(--brand-ink);min-width:40px;font-family:var(--font-mono);transition:width .8s ease}
.funnel-label{width:130px;font-size:11px;color:var(--muted2);text-align:right;flex-shrink:0}

.empty{text-align:center;padding:48px 20px;color:var(--muted)}
.empty .ei{font-size:42px;opacity:.5;margin-bottom:10px}

/* ── Toast ───────────────────────────────────────────────── */
#toast-host{position:fixed;bottom:26px;right:26px;z-index:9999;display:flex;flex-direction:column;gap:10px}
.toast{background:var(--panel-2);border:1px solid var(--border2);border-left:3px solid var(--blue);border-radius:12px;padding:13px 17px;font-size:13px;color:var(--text);box-shadow:var(--shadow);opacity:0;transform:translateX(40px);transition:.32s;max-width:360px}
.toast.show{opacity:1;transform:none}

/* ── Modal ───────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(5,8,13,.72);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:1000;padding:20px}
.modal-overlay.open{display:flex;animation:rise .25s ease}
.modal{background:linear-gradient(160deg,var(--panel),var(--panel-2));border:1px solid var(--border2);border-radius:18px;width:100%;max-width:560px;max-height:88vh;overflow-y:auto;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.modal-head{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-head h3{font-family:var(--font-display);font-size:16px;font-weight:800}
.modal-body{padding:24px}
.modal-foot{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}
.modal-close{font-size:22px;color:var(--muted);cursor:pointer}
.modal-close:hover{color:var(--text)}

/* ── Segmented ───────────────────────────────────────────── */
.seg{display:inline-flex;background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:4px}
.seg button{padding:8px 15px;font-size:12px;font-weight:700;color:var(--muted2);border-radius:8px;transition:.15s}
.seg button.active{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:var(--brand-ink)}

/* ── Insight ─────────────────────────────────────────────── */
.insight{display:flex;gap:11px;padding:12px 14px;border-radius:11px;background:var(--surface);margin-bottom:8px;font-size:12.5px;line-height:1.55}
.insight .ii{font-size:16px;flex-shrink:0}

/* ── Command Palette ─────────────────────────────────────── */
.cmd-overlay{position:fixed;inset:0;background:rgba(5,8,13,.74);backdrop-filter:blur(6px);display:none;align-items:flex-start;justify-content:center;z-index:2000;padding-top:12vh}
.cmd-overlay.open{display:flex}
.cmd{width:100%;max-width:620px;background:linear-gradient(160deg,var(--panel),var(--panel-2));border:1px solid var(--border2);border-radius:16px;overflow:hidden;box-shadow:0 40px 90px rgba(0,0,0,.7)}
.cmd-input{width:100%;padding:19px 22px;background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text);font-size:16px;outline:none;font-family:var(--font)}
.cmd-input::placeholder{color:var(--muted)}
.cmd-list{max-height:52vh;overflow-y:auto;padding:8px}
.cmd-item{display:flex;align-items:center;gap:12px;padding:12px 15px;border-radius:11px;cursor:pointer}
.cmd-item.sel,.cmd-item:hover{background:var(--brand-dim)}
.ci-ico{width:22px;text-align:center;font-size:15px}
.ci-label{flex:1;font-size:14px;font-weight:600}
.ci-sub{font-size:11px;color:var(--muted)}
.cmd-empty{padding:26px;text-align:center;color:var(--muted);font-size:13px}
.cmd-foot{padding:10px 18px;border-top:1px solid var(--border);font-size:11px;color:var(--muted);display:flex;gap:14px}
.cmd-hint{display:flex;align-items:center;gap:7px;padding:8px 13px;border-radius:11px;background:var(--surface);border:1px solid var(--border);font-size:12.5px;color:var(--muted2);cursor:pointer}
.cmd-hint:hover{border-color:var(--brand);color:var(--brand)}
.cmd-hint kbd{font-family:var(--font-mono);font-size:10px;background:var(--surface2);border:1px solid var(--border2);border-radius:5px;padding:2px 6px}

/* ── Kanban ──────────────────────────────────────────────── */
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.kan-col{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;min-height:120px}
.kan-head{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:800;margin-bottom:13px;padding-bottom:9px;border-bottom:1px solid var(--border)}
.kan-card{background:var(--panel-2);border:1px solid var(--border);border-left:3px solid var(--muted);border-radius:11px;padding:12px;margin-bottom:9px;cursor:pointer;transition:transform .12s}
.kan-card:hover{transform:translateY(-2px)}
.kan-card:active{cursor:grabbing}
.kan-col.kan-over{outline:2px dashed var(--brand);outline-offset:-5px;background:var(--brand-dim)}

/* ── Capacity heatmap ────────────────────────────────────── */
.cap-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:11px}
.cap-cell{border-radius:12px;padding:13px;border:1px solid var(--border)}
.cap-bar{height:7px;border-radius:4px;background:var(--surface2);overflow:hidden;margin-top:9px}
.cap-bar>i{display:block;height:100%}

/* mono p/ números/códigos */
.mono,.kpi-value,.wpct{font-family:var(--font-mono)}

/* ── Print ───────────────────────────────────────────────── */
@media print{
  #sidebar,body::before{display:none!important}
  .topbar{position:static!important;backdrop-filter:none!important}
  html,body{overflow:visible!important;height:auto!important;background:#fff!important}
  .app,#main{display:block!important;height:auto!important;overflow:visible!important}
  .topbar-actions,.btn-icon,.cmd-hint{display:none!important}
  .card{break-inside:avoid;box-shadow:none!important;border:1px solid #e2e8f0!important;background:#fff!important}
}

/* ── Overlay mobile ──────────────────────────────────────── */
#sb-overlay{position:fixed;inset:0;background:rgba(5,8,13,.6);z-index:9;opacity:0;pointer-events:none;transition:opacity .25s}
#sb-overlay.show{opacity:1;pointer-events:auto}
#mobile-menu{display:none}

/* ── Responsivo ──────────────────────────────────────────── */
@media(max-width:980px){
  .bento{grid-template-columns:repeat(6,1fr)}
  .col-3{grid-column:span 3}.col-4,.col-5{grid-column:span 6}
  .col-6,.col-7,.col-8,.col-9{grid-column:span 6}
}
@media(max-width:600px){
  #sidebar{position:fixed;left:0;top:0;bottom:0;z-index:20;transform:translateX(-100%);box-shadow:0 0 50px rgba(0,0,0,.6)}
  #sidebar.collapsed{width:var(--sidebar-w);min-width:var(--sidebar-w)}
  #sidebar.collapsed .sb-brand,#sidebar.collapsed .nav-label,#sidebar.collapsed .su-info,#sidebar.collapsed .sb-group{opacity:1;width:auto}
  #sidebar-toggle{display:none}
  #sidebar.mobile-open{transform:none}
  #mobile-menu{display:flex}
  .bento{grid-template-columns:1fr}
  .col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9{grid-column:span 1}
  .page{padding:18px 15px 60px}
  .topbar{padding:14px 16px}
  .topbar-title{font-size:16px}
  .cmd-hint .cmd-hint-lbl,.cmd-hint kbd{display:none}
  .kanban{grid-template-columns:1fr}
}
