/* ============================================================
 * SHARED.CSS — V17b · Velox by Invent · PMO Dashboard
 * CSS base compartilhado por todas as páginas do sistema.
 * Sidebar, topbar, nav items, botões, cards, tokens de cor.
 * ============================================================ */

/* ── Reset & Base ──────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Brand */
  --brand:#F5C300;
  --brand-dim:rgba(245,195,0,.14);
  --brand-glow:rgba(245,195,0,.3);

  /* Backgrounds */
  --bg:#080b11;
  --bg2:#0d0b22;
  --bg3:rgba(16,12,42,.7);

  /* Panel (Command canônico — V17 usa --surface no lugar) */
  --panel:#11161f;

  /* Surfaces */
  --surface:rgba(255,255,255,.055);
  --surface2:rgba(255,255,255,.09);
  --surface3:rgba(255,255,255,.13);

  /* Borders */
  --border:rgba(255,255,255,.1);
  --border2:rgba(255,255,255,.16);

  /* Text */
  --text:#eaf0f8;
  --muted:#7c8699;
  --muted2:#94a3b8;

  /* Fonts (Command canônico) */
  --font:'Inter',system-ui,sans-serif;
  --font-display:'Sora','Inter',sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;

  /* Layout */
  --sidebar-w:248px;
  --sidebar-collapsed:60px;
  --topbar-h:60px;

  /* Radii */
  --radius:16px;
  --radius-sm:9px;
  --radius-xs:6px;

  /* Colors */
  --green:#22c55e;
  --blue:#38bdf8;
  --red:#f43f5e;
  --amber:#f59e0b;
  --violet:#8b5cf6;
  --violet-dim:rgba(139,92,246,.15);
  --teal:#14b8a6;
  --rose:#f43f5e;
  --indigo:#6366f1;

  /* Shadows */
  --shadow-sm:0 2px 8px rgba(0,0,0,.2);
  --shadow-md:0 8px 28px rgba(0,0,0,.28);
  --shadow-lg:0 20px 60px rgba(0,0,0,.4);

  /* Controles nativos (dropdown de select, date picker, scrollbar) seguem o tema escuro */
  color-scheme:dark;
}

/* Bolinha de cor dos chips de filtro (padrão da casa — substitui emoji no chrome) */
.fc-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:0.5px}
.fc-dot--pulse{animation:fcPulse 2s infinite}
@keyframes fcPulse{0%{box-shadow:0 0 0 0 rgba(244,63,94,.45)}70%{box-shadow:0 0 0 5px rgba(244,63,94,0)}100%{box-shadow:0 0 0 0 rgba(244,63,94,0)}}

/* Opções de <select> legíveis no tema escuro (dropdown nativo) */
select option,select optgroup{background-color:#11161f;color:#eaf0f8}
[data-theme="light"] select option,[data-theme="light"] select optgroup{background-color:#ffffff;color:#0f172a}

/* ── Light theme ───────────────────────────────────────── */
[data-theme="light"]{
  color-scheme:light;
  --bg:#f0f4f8;
  --bg2:#e2e8f0;
  --bg3:rgba(226,232,240,.9);
  --panel:#ffffff;
  --surface:rgba(255,255,255,.92);
  --surface2:rgba(255,255,255,.75);
  --surface3:rgba(255,255,255,.6);
  --border:rgba(0,0,0,.08);
  --border2:rgba(0,0,0,.14);
  --text:#0f172a;
  --muted:#64748b;
  --muted2:#475569;
}

/* ── Base ──────────────────────────────────────────────── */
html,body{
  height:100%;
  font-family:var(--font);
  background:radial-gradient(ellipse 130% 65% at 50% -8%, #1a1060 0%, #0a0520 38%, #030610 72%);
  color:var(--text);
  overflow:hidden;
}
[data-theme="light"] body{background:#f0f4f8!important}

/* Command-center grid — grade sutil sobre a aurora (assinatura V2/V9).
   Fixa, atrás do conteúdo (.app tem z-index:1), mascarada no topo. */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.02) 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}
a{color:inherit;text-decoration:none}

/* Entrada suave da página (assinatura Command) — fade no #main, 1x por load.
   Opacity-only para não quebrar a topbar sticky nem piscar no re-render. */
@keyframes pageFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ── Scrollbar ─────────────────────────────────────────── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:var(--surface3)}

/* ── Layout ────────────────────────────────────────────── */
.app{display:flex;height:100vh;overflow:hidden;position:relative;z-index:1}

/* ════════════════════════════════════════════════════════
   SIDEBAR — V17b glass
   ════════════════════════════════════════════════════════ */
#sidebar{
  width:var(--sidebar-w);
  min-width:var(--sidebar-w);
  background:rgba(13,11,34,.82);
  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;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:1px 0 0 rgba(255,255,255,.04),
             4px 0 24px rgba(0,0,0,.18);
}
#sidebar.collapsed{width:var(--sidebar-collapsed);min-width:var(--sidebar-collapsed)}

/* Subtle violet aurora inside sidebar */
#sidebar::before{
  content:'';position:absolute;top:-60px;left:-60px;
  width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle,rgba(99,102,241,.12),transparent 70%);
  pointer-events:none;
}

/* ── Sidebar header ──────────────────────────────────────*/
.sb-header{
  padding:18px 14px 14px;
  display:flex;align-items:center;gap:10px;
  border-bottom:1px solid var(--border);
  position:relative;
}
.sb-logo{
  width:34px;height:34px;min-width:34px;
  background:linear-gradient(135deg,var(--brand),#d97706);
  border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:900;color:#0a0e19;
  letter-spacing:-0.5px;flex-shrink:0;
  box-shadow:0 4px 16px rgba(245,195,0,.35),0 0 0 1px rgba(245,195,0,.2);
  transition:box-shadow .3s;
}
.sb-logo:hover{box-shadow:0 6px 22px rgba(245,195,0,.5),0 0 0 1px rgba(245,195,0,.35)}
.sb-brand{overflow:hidden;opacity:1;transition:opacity .25s,width .3s;line-height:1.25}
.sb-brand-name{
  font-size:15px;font-weight:900;letter-spacing:-1px;
  white-space:nowrap;color:var(--text);
}
.sb-brand-name .vy{color:var(--brand)}
.sb-brand-name .dot{color:var(--brand)}
.sb-brand-by{
  font-size:9px;font-weight:600;letter-spacing:2px;
  text-transform:uppercase;color:var(--muted);white-space:nowrap;
}
#sidebar.collapsed .sb-brand{opacity:0;width:0;overflow:hidden}
#sidebar-toggle{
  margin-left:auto;color:var(--muted);font-size:18px;
  padding:4px;border-radius:6px;flex-shrink:0;transition:color .2s,background .2s;
}
#sidebar-toggle:hover{color:var(--text);background:var(--surface)}

/* ── Sidebar nav ─────────────────────────────────────────*/
.sb-nav{
  flex:1;padding:10px 8px;
  overflow-y:auto;
  display:flex;flex-direction:column;gap:1px;
}
.nav-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 11px;border-radius:var(--radius-sm);
  color:var(--muted2);font-size:13px;font-weight:500;
  transition:all .18s;white-space:nowrap;overflow:hidden;
  position:relative;
}
.nav-item:hover{
  background:var(--surface2);color:var(--text);
  padding-left:14px;
}
.nav-item.active{
  background:linear-gradient(90deg,rgba(245,195,0,.15),rgba(245,195,0,.06));
  color:var(--brand);font-weight:600;
  padding-left:11px;
}
/* Barra ativa com glow dourado (assinatura Command V2/V9) */
.nav-item.active::before{
  content:'';position:absolute;left:0;top:7px;bottom:7px;width:3px;
  border-radius:0 3px 3px 0;background:var(--brand);
  box-shadow:0 0 12px var(--brand);
}
.nav-icon{font-size:17px;flex-shrink:0;width:20px;text-align:center}
.nav-label{transition:opacity .2s}
#sidebar.collapsed .nav-label{opacity:0;width:0;overflow:hidden}
#sidebar.collapsed .nav-item{padding-left:11px}
#sidebar.collapsed .nav-item.active{padding-left:11px}

/* ── Sidebar footer ──────────────────────────────────────*/
.sb-footer{padding:10px 8px;border-top:1px solid var(--border)}
#sidebar-user{
  display:flex;align-items:center;gap:10px;
  padding:8px 10px;border-radius:var(--radius-sm);
  transition:background .2s;
}
#sidebar-user:hover{background:var(--surface)}
.su-avatar{
  width:32px;height:32px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:#fff;flex-shrink:0;
}
.su-info{overflow:hidden;flex:1}
.su-nome{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.su-papel{font-size:10px;color:var(--muted);text-transform:capitalize}
.su-logout{
  padding:4px 6px;color:var(--muted);font-size:14px;
  border-radius:4px;transition:color .2s,background .2s;
}
.su-logout:hover{color:var(--red);background:rgba(244,63,94,.1)}
#sidebar.collapsed .su-info,
.su-info.hidden{opacity:0;width:0;overflow:hidden}

/* ════════════════════════════════════════════════════════
   TOPBAR — V17b
   ════════════════════════════════════════════════════════ */
#main{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-width:0;animation:pageFade .45s cubic-bezier(.2,.7,.2,1)}

.topbar{
  padding:0 28px;
  height:var(--topbar-h);
  min-height:var(--topbar-h);
  display:flex;align-items:center;gap:14px;
  border-bottom:1px solid var(--border);
  background:rgba(13,11,34,.75);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  position:sticky;top:0;z-index:5;
  box-shadow:0 1px 0 rgba(255,255,255,.04);
}
[data-theme="light"] .topbar{background:rgba(241,245,249,.92)}
.topbar-left{flex:1;min-width:0}
.topbar-title{
  font-size:17px;font-weight:700;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.topbar-sub{font-size:11px;color:var(--muted);font-weight:400;margin-top:1px}
.topbar-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* breadcrumb / subtitle inline */
.topbar-title span.topbar-subtitle{
  font-size:12px;color:var(--muted);font-weight:400;margin-left:8px;
}

/* ── Tab bar ───────────────────────────────────────────── */
.tab-bar{
  display:flex;gap:0;
  padding:0 28px;
  border-bottom:1px solid var(--border);
  background:rgba(13,11,34,.6);
  backdrop-filter:blur(12px);
  overflow-x:auto;
  flex-shrink:0;
}
.tab-btn{
  padding:13px 18px;font-size:13px;font-weight:500;
  color:var(--muted2);cursor:pointer;
  border-bottom:2px solid transparent;
  transition:color .2s,border-color .2s;white-space:nowrap;
}
.tab-btn:hover{color:var(--text)}
.tab-btn.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:700}

/* ════════════════════════════════════════════════════════
   BUTTONS
   ════════════════════════════════════════════════════════ */
.btn-icon{
  width:36px;height:36px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  background:var(--surface);border:1px solid var(--border);
  color:var(--muted2);font-size:15px;
  transition:all .2s;flex-shrink:0;
}
.btn-icon:hover{background:var(--surface2);color:var(--text);border-color:var(--border2)}

.btn-primary{
  display:flex;align-items:center;gap:7px;
  padding:9px 18px;
  background:linear-gradient(135deg,var(--brand),#d97706);
  color:#0a0e19;font-size:13px;font-weight:700;
  border-radius:var(--radius-sm);
  box-shadow:0 4px 16px rgba(245,195,0,.25);
  transition:opacity .2s,box-shadow .2s,transform .1s;
}
.btn-primary:hover{opacity:.9;box-shadow:0 6px 22px rgba(245,195,0,.4)}
.btn-primary:active{transform:scale(.98)}

.btn-outline{
  display:flex;align-items:center;gap:6px;
  padding:8px 14px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  font-size:12px;font-weight:600;color:var(--muted2);
  transition:all .2s;
}
.btn-outline:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-dim)}

/* ── Visões: abas no topo (Ação · Gerencial · Análise · Executivo) ── */
.vx-tabs{display:flex;gap:8px;padding:14px 28px 0;flex-wrap:wrap}
.vx-tab{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 18px;border-radius:10px;
  font-size:12.5px;font-weight:700;letter-spacing:.2px;
  color:var(--muted2);background:var(--surface);
  border:1px solid var(--border);text-decoration:none;
  transition:all .15s;
}
.vx-tab:hover{color:var(--text);border-color:var(--border2);transform:translateY(-1px)}
.vx-tab.active{
  color:var(--brand);background:var(--brand-dim);
  border-color:rgba(245,195,0,.45);
  box-shadow:0 0 14px rgba(245,195,0,.12);
}
.vx-tab svg{opacity:.9;flex-shrink:0}
@media print{.vx-tabs{display:none!important}}

.btn-danger{
  display:flex;align-items:center;gap:6px;
  padding:8px 14px;
  background:rgba(244,63,94,.1);
  border:1px solid rgba(244,63,94,.25);border-radius:var(--radius-sm);
  font-size:12px;font-weight:600;color:#f43f5e;transition:all .2s;
}
.btn-danger:hover{background:rgba(244,63,94,.2);border-color:rgba(244,63,94,.45)}

/* ════════════════════════════════════════════════════════
   CARD — V17b glassmorphism
   ════════════════════════════════════════════════════════ */
.card{
  background:linear-gradient(
    150deg,
    rgba(255,255,255,.065) 0%,
    rgba(255,255,255,.025) 60%,
    rgba(255,255,255,.01) 100%
  );
  border:1px solid rgba(255,255,255,.1);
  border-top:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius);
  padding:20px;
  position:relative;overflow:hidden;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-shadow:0 4px 24px rgba(0,0,0,.18),
             inset 0 1px 0 rgba(255,255,255,.06);
  transition:border-color .22s,box-shadow .22s,transform .22s;
}
.card::before{
  content:'';position:absolute;inset:0;border-radius:var(--radius);
  background:linear-gradient(135deg,rgba(255,255,255,.03) 0%,transparent 55%);
  pointer-events:none;
}
/* Linha de brilho no topo do card (assinatura Command V2/V9) */
.card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.16),transparent);
  pointer-events:none;
}
[data-theme="light"] .card::after{background:linear-gradient(90deg,transparent,rgba(15,23,42,.1),transparent)}
.card:hover{
  border-color:rgba(255,255,255,.17);
  box-shadow:0 8px 36px rgba(0,0,0,.26),
             inset 0 1px 0 rgba(255,255,255,.08);
}
[data-theme="light"] .card{
  background:rgba(255,255,255,.9);
  border-color:rgba(0,0,0,.07);
  border-top-color:rgba(0,0,0,.07);
  box-shadow:0 2px 12px rgba(0,0,0,.08);
}
.card-title{
  font-size:10.5px;font-weight:800;text-transform:uppercase;
  letter-spacing:.8px;color:var(--muted);margin-bottom:16px;
  display:flex;align-items:center;gap:9px;
}
/* Tick dourado antes do título (assinatura Command V2/V9) */
.card-title::before{
  content:'';flex-shrink:0;width:3px;height:12px;border-radius:2px;
  background:var(--brand);box-shadow:0 0 8px rgba(245,195,0,.5);
}
/* Elementos de ação/badge no fim do título encostam à direita
   (substitui o antigo justify-content:space-between) */
.card-title>.chip,
.card-title>.ct-action,
.card-title>.btn-dl,
.card-title>button{margin-left:auto}

/* Chip badge */
.chip{
  background:var(--surface2);border:1px solid var(--border);
  color:var(--muted);font-size:10px;font-weight:600;
  padding:2px 8px;border-radius:20px;
  text-transform:none;letter-spacing:0;
}

/* ════════════════════════════════════════════════════════
   FORM CONTROLS
   ════════════════════════════════════════════════════════ */
.form-group{margin-bottom:16px}
.form-label{
  display:block;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.8px;
  color:var(--muted);margin-bottom:8px;
}
.form-control{
  width:100%;padding:10px 13px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  color:var(--text);font-size:13px;font-family:var(--font);
  outline:none;transition:border-color .2s,box-shadow .2s;
}
.form-control:focus{
  border-color:rgba(245,195,0,.5);
  box-shadow:0 0 0 3px rgba(245,195,0,.08);
}
.form-control::placeholder{color:var(--muted)}
select.form-control option{background:var(--panel);color:var(--text)}

/* ════════════════════════════════════════════════════════
   TABLE
   ════════════════════════════════════════════════════════ */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.7px;color:var(--muted);
  padding:9px 12px;text-align:left;
  border-bottom:1px solid var(--border);white-space:nowrap;
}
td{padding:11px 12px;font-size:13px;border-bottom:1px solid rgba(255,255,255,.05)}
tr:hover td{background:var(--surface)}
[data-theme="light"] td{border-bottom-color:var(--border)}

/* ════════════════════════════════════════════════════════
   EMPTY STATES & SKELETONS — V17 (padrão da casa)
   ════════════════════════════════════════════════════════ */
/* Estado vazio reutilizável: ícone + título + dica + ação opcional.
   Uso: <div class="empty-state"><div class="es-icon">📭</div>
        <div class="es-title">Nada por aqui</div>
        <div class="es-hint">texto</div></div> */
.empty-state{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:5px;padding:44px 24px;color:var(--muted);
}
.empty-state .es-icon{
  font-size:34px;line-height:1;margin-bottom:6px;opacity:.9;
  filter:drop-shadow(0 4px 14px rgba(245,195,0,.18));
}
.empty-state .es-title{font-size:14px;font-weight:700;color:var(--muted2)}
.empty-state .es-hint{font-size:12px;color:var(--muted);max-width:340px;line-height:1.5}
.empty-state .es-action{margin-top:12px}

/* Command palette vazio — compartilhado por todas as páginas (utils.js) */
.cmd-empty{
  display:flex;flex-direction:column;align-items:center;gap:7px;
  padding:30px 20px;text-align:center;color:var(--muted);
  font-size:13px;font-weight:500;
}
.cmd-empty::before{content:'🔍';font-size:24px;opacity:.7}

/* Skeleton shimmer — placeholder de carregamento.
   Uso: <div class="skeleton skeleton-text"></div> · .sk-60/.sk-40 p/ larguras */
.skeleton{
  position:relative;overflow:hidden;border-radius:var(--radius-sm);
  background:var(--surface2);
}
.skeleton::after{
  content:'';position:absolute;inset:0;transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.09),transparent);
  animation:shimmer 1.4s infinite;
}
[data-theme="light"] .skeleton::after{background:linear-gradient(90deg,transparent,rgba(15,23,42,.06),transparent)}
@keyframes shimmer{100%{transform:translateX(100%)}}
.skeleton-text{height:12px;margin-bottom:8px;width:100%}
.skeleton-text.sk-60{width:60%}
.skeleton-text.sk-40{width:40%}
.skeleton-card{height:120px;border-radius:var(--radius)}

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

/* ════════════════════════════════════════════════════════
   VIEWER MODE
   ════════════════════════════════════════════════════════ */
.viewer-mode .viewer-hide{display:none!important}
.viewer-mode button[onclick*="openModal"],
.viewer-mode button[onclick*="editProj"],
.viewer-mode button[onclick*="deleteProj"]{display:none!important}

/* ════════════════════════════════════════════════════════
   V17 SPLIT LAYOUT
   ════════════════════════════════════════════════════════ */
.page-split{display:flex;flex:1;overflow:hidden;min-height:0}
.page-content{flex:1;overflow-y:auto;min-width:0;min-height:0;display:flex;flex-direction:column}
.live-panel{
  width:288px;min-width:288px;
  border-left:1px solid var(--border);
  background:rgba(13,11,34,.6);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  overflow-y:auto;display:flex;flex-direction:column;
}
[data-theme="light"] .live-panel{background:rgba(226,232,240,.85)}
.lp-section{padding:11px 16px;border-bottom:1px solid var(--border)}
.lp-title{
  font-size:9px;font-weight:800;text-transform:uppercase;
  letter-spacing:1.2px;color:var(--muted);margin-bottom:7px;
  display:flex;align-items:center;justify-content:space-between;
}
.lp-alert{
  display:flex;align-items:flex-start;gap:8px;
  padding:8px 10px;border-radius:9px;
  border:1px solid transparent;cursor:default;
  transition:all .15s;margin-bottom:5px;
}
.lp-alert.p0{background:rgba(244,63,94,.08);border-color:rgba(244,63,94,.2)}
.lp-alert.p1{background:rgba(249,115,22,.07);border-color:rgba(249,115,22,.18)}
.lp-alert.p2{background:rgba(245,195,0,.06);border-color:rgba(245,195,0,.14)}
.lp-alert:hover{filter:brightness(1.15)}
.lp-sev{font-size:8px;font-weight:900;padding:2px 5px;border-radius:4px;letter-spacing:.5px;flex-shrink:0;margin-top:1px}
.lp-sev.p0{background:rgba(244,63,94,.25);color:#fda4af}
.lp-sev.p1{background:rgba(249,115,22,.2);color:#fdba74}
.lp-sev.p2{background:rgba(245,195,0,.18);color:#fde047}
.lp-proj{font-size:11px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lp-desc{font-size:10px;color:var(--muted2);margin-top:1px;line-height:1.3}
.lp-meta{font-size:10px;color:var(--muted);margin-top:2px}

/* ════════════════════════════════════════════════════════
   V17 COMPONENTS
   ════════════════════════════════════════════════════════ */

/* Live dot */
.live-dot{
  width:6px;height:6px;border-radius:50%;background:#22c55e;
  animation:blink 2s infinite;display:inline-block;
  margin-right:4px;box-shadow:0 0 6px rgba(34,197,94,.6);
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.22}}

/* Heatmap */
/* Timeline compacta do portfólio (card compartilhado — utils.js buildTimelineCardHTML) */
.gantt-wrap{overflow-x:auto;padding-bottom:4px}
.gantt-row{display:grid;align-items:center;gap:12px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.gantt-row:last-child{border-bottom:none}
.gantt-label{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:default;color:var(--text)}
.gantt-label:hover{color:var(--brand)}

.heatmap-grid{display:flex;flex-wrap:wrap;gap:5px;padding-top:6px}
.heat-tile{
  width:44px;height:44px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  cursor:default;transition:all .22s;position:relative;
  flex-shrink:0;border:1px solid rgba(255,255,255,.1);
  overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.3);
}
.heat-tile:hover{
  transform:scale(1.38) translateY(-4px);z-index:10;
  box-shadow:0 12px 32px rgba(0,0,0,.6),0 0 0 2px rgba(255,255,255,.25)!important;
}
/* Tile crítico — pulso de atenção */
.heat-tile.heat-crit{animation:heatCritPulse 2.2s ease-in-out infinite}
@keyframes heatCritPulse{
  0%,100%{box-shadow:0 3px 14px rgba(220,38,38,.45),inset 0 1px 0 rgba(255,255,255,.2)}
  50%{box-shadow:0 3px 20px rgba(220,38,38,.85),0 0 0 1px rgba(220,38,38,.5),inset 0 1px 0 rgba(255,255,255,.2)}
}
.heat-lbl{
  font-size:7px;font-weight:900;color:rgba(255,255,255,.92);
  text-align:center;padding:0 2px;line-height:1.2;
  overflow:hidden;display:-webkit-box;
  -webkit-line-clamp:2;-webkit-box-orient:vertical;
  max-width:36px;pointer-events:none;
}

/* PMO mini */
.pmo-mini{
  display:flex;align-items:center;gap:8px;
  padding:7px 10px;border-radius:9px;
  background:var(--surface2);margin-bottom:5px;
  cursor:default;transition:background .15s;
}
.pmo-mini:hover{background:var(--surface3)}
.pmo-avatar{
  width:30px;height:30px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;flex-shrink:0;
}

/* Today items */
.today-item{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.today-item:last-child{border-bottom:none}
.today-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.today-txt{font-size:11px;color:var(--muted2);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.today-badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;flex-shrink:0}

/* Download PNG button */
.btn-dl{
  position:absolute;top:14px;right:14px;
  width:30px;height:30px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  background:var(--surface2);border:1px solid var(--border);
  color:var(--muted2);font-size:13px;cursor:pointer;
  transition:all .15s;z-index:3;
}
.btn-dl:hover{color:var(--brand);border-color:var(--brand)}
@media print{.btn-dl{display:none!important}}

/* War Room banner */
.war-room-banner{
  padding:10px 28px;
  background:linear-gradient(90deg,rgba(244,63,94,.15),rgba(244,63,94,.04));
  border-bottom:1px solid rgba(244,63,94,.3);
  display:flex;align-items:center;gap:12px;
  flex-shrink:0;
}
.war-room-dot{
  width:10px;height:10px;border-radius:50%;background:#f43f5e;
  flex-shrink:0;animation:blink 1s infinite;
  box-shadow:0 0 8px #f43f5e;
}
.war-room-txt{font-size:12px;font-weight:800;color:#fda4af;letter-spacing:.3px}
.war-room-count{
  background:rgba(244,63,94,.25);color:#fda4af;
  font-size:11px;font-weight:900;padding:3px 10px;
  border-radius:20px;border:1px solid rgba(244,63,94,.4);
}

/* TV mode btn */
.btn-tv{
  display:flex;align-items:center;gap:7px;
  padding:8px 16px;
  background:rgba(56,189,248,.18);border:1px solid rgba(56,189,248,.5);
  border-radius:var(--radius-sm);font-size:12px;font-weight:700;color:#38bdf8;
  transition:all .2s;
  box-shadow:0 0 12px rgba(56,189,248,.2);
  animation:tvBtnPulse 3s ease-in-out infinite;
}
.btn-tv:hover{
  background:rgba(56,189,248,.3);border-color:#38bdf8;
  box-shadow:0 0 20px rgba(56,189,248,.4);animation:none;
}
@keyframes tvBtnPulse{
  0%,100%{box-shadow:0 0 8px rgba(56,189,248,.18)}
  50%{box-shadow:0 0 18px rgba(56,189,248,.45)}
}

/* Print btn */
.btn-print{
  display:flex;align-items:center;gap:7px;
  padding:8px 16px;
  background:rgba(139,92,246,.1);border:1px solid rgba(139,92,246,.28);
  border-radius:var(--radius-sm);font-size:12px;font-weight:700;color:#a78bfa;
  transition:all .2s;
}
.btn-print:hover{background:rgba(139,92,246,.2);border-color:#a78bfa}

/* Cmd button */
.btn-cmd{
  display:flex;align-items:center;gap:8px;
  padding:8px 14px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  font-size:12px;color:var(--muted);transition:all .2s;
}
.btn-cmd:hover{background:var(--surface2);color:var(--text);border-color:var(--brand)}
.btn-cmd kbd{background:var(--border);padding:1px 5px;border-radius:3px;font-size:10px}

/* Status badges */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.3px}
.badge-green{background:rgba(34,197,94,.15);color:#4ade80;border:1px solid rgba(34,197,94,.25)}
.badge-amber{background:rgba(245,158,11,.15);color:#fbbf24;border:1px solid rgba(245,158,11,.25)}
.badge-red{background:rgba(244,63,94,.15);color:#fb7185;border:1px solid rgba(244,63,94,.25)}
.badge-blue{background:rgba(56,189,248,.15);color:#38bdf8;border:1px solid rgba(56,189,248,.25)}
.badge-violet{background:rgba(139,92,246,.15);color:#a78bfa;border:1px solid rgba(139,92,246,.25)}
.badge-muted{background:var(--surface2);color:var(--muted2);border:1px solid var(--border)}

/* ════════════════════════════════════════════════════════
   PRESENCE / ONLINE INDICATOR
   ════════════════════════════════════════════════════════ */
.presence-indicator{
  display:flex;align-items:center;gap:5px;
  font-size:10px;color:var(--muted);padding:4px 8px;
  border-radius:20px;background:var(--surface);
}
.presence-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 5px rgba(34,197,94,.6);animation:blink 2s infinite}

/* ════════════════════════════════════════════════════════
   STATUS CANCELADO (novo status V17b)
   ════════════════════════════════════════════════════════ */
.badge-cancelado{background:rgba(71,85,105,.18);color:#94a3b8;border:1px solid rgba(71,85,105,.35)}
.status-cancelado{color:#64748b}
/* Card de projeto cancelado — visual riscado/esmaecido */
.kanban-card.is-cancelado,.list-row.is-cancelado{opacity:.6;filter:grayscale(.3)}

/* ════════════════════════════════════════════════════════
   LIGHT THEME — refinamentos finais V17b
   ════════════════════════════════════════════════════════ */
[data-theme="light"] html,[data-theme="light"] body{background:#f0f4f8!important}
[data-theme="light"] #sidebar{
  background:#ffffff!important;
  box-shadow:1px 0 0 rgba(0,0,0,.04),4px 0 20px rgba(0,0,0,.05);
}
[data-theme="light"] #sidebar::before{
  background:radial-gradient(circle,rgba(99,102,241,.06),transparent 70%);
}
[data-theme="light"] .nav-item.active{
  background:linear-gradient(90deg,rgba(245,195,0,.18),rgba(245,195,0,.06));
  color:#b45309;
}
[data-theme="light"] .sb-brand-name{color:#0f172a}
[data-theme="light"] .topbar{background:rgba(255,255,255,.92)}
/* Botões mais legíveis no claro */
[data-theme="light"] .btn-icon{background:rgba(0,0,0,.03)}
[data-theme="light"] .btn-cmd kbd{background:rgba(0,0,0,.08);color:#475569}
/* Badges com texto mais escuro no claro p/ contraste */
[data-theme="light"] .badge-green{color:#15803d;background:rgba(34,197,94,.12)}
[data-theme="light"] .badge-amber{color:#b45309;background:rgba(245,158,11,.12)}
[data-theme="light"] .badge-red{color:#be123c;background:rgba(244,63,94,.1)}
[data-theme="light"] .badge-blue{color:#0284c7;background:rgba(56,189,248,.1)}
[data-theme="light"] .badge-violet{color:#6d28d9;background:rgba(139,92,246,.1)}
/* Live panel no claro */
[data-theme="light"] .live-panel{background:rgba(248,250,252,.9)}
/* Scrollbar no claro */
[data-theme="light"] ::-webkit-scrollbar-thumb{background:rgba(0,0,0,.15)}
[data-theme="light"] ::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.25)}
/* Command palette no claro (usa --bg2, já adaptado, mas reforça sombra) */
[data-theme="light"] #cmd-palette,[data-theme="light"] #cmd-list{box-shadow:0 24px 80px rgba(0,0,0,.18)}
/* Heat tile labels permanecem brancos sobre cores — mantém legibilidade no claro */
[data-theme="light"] .heat-lbl{color:rgba(255,255,255,.95);text-shadow:0 1px 2px rgba(0,0,0,.4)}

/* ════════════════════════════════════════════════════════
   ACESSIBILIDADE — V17d
   ════════════════════════════════════════════════════════ */
/* Foco visível para navegação por teclado (Tab) — anel dourado.
   :focus-visible só aparece em navegação por teclado, não no clique. */
a:focus-visible,
button:focus-visible,
.nav-item:focus-visible,
.btn-icon:focus-visible,
.btn-primary:focus-visible,
.btn-outline:focus-visible,
.btn-danger:focus-visible,
.btn-tv:focus-visible,
.btn-print:focus-visible,
.btn-cmd:focus-visible,
.filter-chip:focus-visible,
.tab-btn:focus-visible,
.view-btn:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible{
  outline:2px solid var(--brand);
  outline-offset:2px;
  border-radius:var(--radius-xs);
}
/* Remove outline padrão no clique (mouse), mantém no teclado */
a:focus:not(:focus-visible),
button:focus:not(:focus-visible){outline:none}

/* Skip link — pular para conteúdo (leitor de tela / teclado) */
.skip-link{
  position:absolute;left:-9999px;top:8px;z-index:100000;
  background:var(--brand);color:#0a0e19;font-weight:700;font-size:13px;
  padding:10px 18px;border-radius:8px;text-decoration:none;
}
.skip-link:focus{left:8px}

/* Respeita "reduzir movimento" do sistema operacional (acessibilidade) */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;
    animation-iteration-count:1!important;
    transition-duration:.001ms!important;
    scroll-behavior:auto!important;
  }
}

/* Touch targets — alvos de toque mínimos 40px em telas pequenas */
@media (max-width:560px){
  .nav-item,.btn-icon,.filter-chip,.view-btn,.tab-btn{min-height:40px}
}

/* Seleção de texto com a cor da marca */
::selection{background:rgba(245,195,0,.28);color:#fff}
[data-theme="light"] ::selection{background:rgba(245,195,0,.35);color:#0a0e19}
