/* Ordem correta: backdrop < modal < conteúdo/fechar */
.modal-backdrop { z-index: 1050 !important; }
.modal          { z-index: 1060 !important; }
.modal .modal-content { position: relative; z-index: 1065; }


.voto-btn.btn-light {
  border: 1px solid #ccc;   /* cinza */
}

/* ===== Design tokens (verde como cor primária) =========================== */
:root{
  /* Paleta base */
  --brand-900:#0f5132;
  --brand-800:#146c43;
  --brand-700:#198754; /* bootstrap green */
  --brand-600:#20a06a;
  --brand-500:#28b881;
  --brand-400:#66d1a5;
  --brand-300:#9fe3c6;
  --brand-200:#c9f0df;
  --brand-100:#e9fbf4;

  --accent-700:#f59f00;  /* amarelo: “talvez” */
  --danger-600:#dc3545;  /* vermelho: “não”   */
  --ink-900:#0b1220;
  --ink-700:#212529;
  --ink-500:#495057;
  --ink-300:#868e96;

  --bg-0:#f6f9fb;
  --bg-1:#eef2f7;
  --bg-card:#ffffff;
  --bg-elev:#ffffff;

  /* Bootstrap CSS variables (override) */
  --bs-body-bg: var(--bg-0);
  --bs-body-color: var(--ink-700);
  --bs-primary: var(--brand-700);
  --bs-primary-rgb: 25,135,84;
  --bs-secondary:#6c757d;
  --bs-link-color: var(--brand-700);
  --bs-link-hover-color: var(--brand-900);
  --bs-border-color:#e9ecef;
  --bs-border-radius: 1rem;         /* cantos arredondados */
  --bs-border-radius-lg: 1.25rem;
  --bs-box-shadow: 0 6px 20px rgba(16, 24, 40, .08);

  /* Tokens para gráficos / estados */
  --sim: var(--brand-700);
  --nao: var(--danger-600);
  --talvez: var(--accent-700);
  --sim-bg: rgba(25,135,84,.15);
  --nao-bg: rgba(220,53,69,.15);
  --talvez-bg: rgba(245,159,0,.18);
}

/* ===== Layout global ===================================================== */
html, body{ height:100%; }
main{ width:100%; }
body{
  background:
    radial-gradient(900px 480px at 5% -10%, rgba(25,135,84,.06), transparent 60%),
    radial-gradient(900px 480px at 105% 110%, rgba(25,135,84,.04), transparent 60%),
    linear-gradient(180deg, var(--bg-0), var(--bg-1));
}

/* ===== Sidebar =========================================================== */
#sidebar{
  background: linear-gradient(180deg, #1b2830, #121a20);
  color:#cfd6dd;
  border-right: 1px solid rgba(255,255,255,.06);
}
#sidebar .navbar-brand,
#sidebar .brand{
  display:flex; align-items:center; gap:.625rem; padding:1rem 1rem 0;
  color:#e9f1ee; font-weight:700; letter-spacing:.2px;
}
#sidebar .nav{
  padding: .5rem;
}
#sidebar .nav-link{
  color:#cfd6dd;
  border-radius:.75rem;
  padding:.6rem .9rem;
  display:flex; align-items:center; gap:.6rem;
  transition: all .2s ease;
}
#sidebar .nav-link:hover{
  background: rgba(255,255,255,.06);
  color:#fff;
  transform: translateX(2px);
}
#sidebar .nav-link.active{
  color:#fff; font-weight:700;
  background: linear-gradient(90deg, rgba(40,184,129,.22), rgba(40,184,129,.08));
  box-shadow: inset 0 0 0 1px rgba(40,184,129,.2);
}

/* ===== Topbar (busca/menu) ============================================== */
.topbar{
  display:flex; align-items:center; gap:1rem; padding:1rem 0 0;
}
.searchbox{
  position:relative; flex:1;
}
.searchbox input{
  border-radius: .85rem;
  border:1px solid #e6eaf0;
  padding-left: 2.25rem;
  box-shadow:none;
}
.searchbox .icon{
  position:absolute; left:.75rem; top:50%; transform:translateY(-50%);
  opacity:.6;
}

/* ===== Cards ============================================================== */
.card{
  border:1px solid #eef1f3 !important;
  border-radius: var(--bs-border-radius-lg);
  box-shadow: var(--bs-box-shadow);
  background: var(--bg-card);
}
.card .card-title{
  font-weight:700; letter-spacing:.2px;
}
.card .card-body{
  padding: 1rem 1rem 1.1rem 1rem;
}
.card:hover{
  transform: translateY(-1px);
  transition: transform .15s ease;
}

/* Painel escuro (para gráficos/heatmaps) */
.card.panel-dark{
  color:#e6edf3;
  background: radial-gradient(1000px 500px at -20% -40%, rgba(40,184,129,.08), transparent 55%),
              radial-gradient(1000px 500px at 120% 140%, rgba(40,184,129,.06), transparent 55%),
              linear-gradient(180deg, #0f1720, #111827);
  border-color: rgba(255,255,255,.06) !important;
  box-shadow: 0 6px 24px rgba(2,8,23,.45);
}
.panel-dark .card-title{ color:#d7ece4; }
.panel-dark .muted, .panel-dark .kpi { color:#9fb2ad; }

/* Mini badge no header do card */
.card .badge-dot{
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.25rem .5rem; border-radius:.6rem; font-weight:600;
  background:#f8fafc; color:#1e293b; border:1px solid #edf2f7;
}
.panel-dark .badge-dot{ background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.12); color:#e2e8f0;}

/* ===== Botões e estados =================================================== */
.btn-primary{
  --bs-btn-bg: var(--brand-700);
  --bs-btn-border-color: var(--brand-700);
  --bs-btn-hover-bg: var(--brand-800);
  --bs-btn-hover-border-color: var(--brand-800);
  --bs-btn-active-bg: var(--brand-900);
  --bs-btn-active-border-color: var(--brand-900);
  border-radius:.75rem;
}
.btn-outline-secondary{ border-radius:.75rem; }

/* Botão “kebab”/download suave */
.download-btn{
  border:none; background:#f8f9fa; padding:.35rem .6rem; border-radius:.6rem;
}
.download-btn:hover{ background:#eef1f3; }

/* ===== KPIs (cards de números) =========================================== */
.kpi-cards .card{ border:1px solid #eef1f3; }
.kpi-value{ font-size:1.35rem; font-weight:800; letter-spacing:.2px; }
.kpi-sub{ color: var(--ink-300); font-size:.85rem; }
.legend-dot{ display:inline-block; width:.75rem; height:.75rem; border-radius:50%; margin-right:.35rem; transform: translateY(1px); }

/* ===== Chart containers =================================================== */
.chart-box{
  position: relative;
  width: 100%;
  height: 510px; /* ajuste se quiser maior/menor */
}
.chart-box > canvas{
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
}
@media (max-width: 992px){
  .chart-box{ height: 280px; }
}

/* ===== Títulos de seção / separadores ==================================== */
.section-title{
  font-weight:800; font-size:1.05rem; letter-spacing:.25px; color: var(--ink-700);
}
.hr-soft{
  border:none; height:1px; background: linear-gradient(90deg, transparent, #e9edf3, transparent);
  margin: .75rem 0 1rem;
}

/* ===== Badges para filtros ativos ======================================== */
.badge-filter{
  background:#f1f5f9; color:#0f172a; border:1px solid #e2e8f0; border-radius:.75rem; font-weight:600;
}
.panel-dark .badge-filter{
  background:rgba(255,255,255,.06); color:#e2e8f0; border-color:rgba(255,255,255,.12);
}

/* ===== Tabelas e listas compactas ======================================== */
.table-sm th, .table-sm td{ padding:.5rem .6rem; }
.list-compact li{ padding:.4rem .25rem; }

/* ===== Progress (para “skills”/barras horizontais) ======================= */
.progress{
  --bs-progress-height: .6rem;
  --bs-progress-border-radius: 999px;
  background:#eef2f7;
}
.progress .progress-bar{
  background: linear-gradient(90deg, var(--brand-600), var(--brand-400));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.25);
}

/* ===== Pills e navs ====================================================== */
.nav-pills .nav-link{
  border-radius:.75rem;
  color:#344054;
  background:#f8fafc;
  border:1px solid #eef2f7;
}
.nav-pills .nav-link.active{
  color:#0b3d2a;
  background: linear-gradient(90deg, rgba(40,184,129,.20), rgba(40,184,129,.08));
  border-color: rgba(40,184,129,.30);
}

/* ===== Formularios / filtros ============================================ */
.filter-form .form-control, .filter-form .form-select{ min-width: 12rem; border-radius:.75rem; }
.form-floating > label{ color: #6c757d; }

/* ===== Login fullpage (mantive e harmonizei com tema) ==================== */
.auth-wrapper {
  min-height: 100vh;
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(25,135,84,.08), transparent 60%),
    radial-gradient(1000px 500px at 110% 110%, rgba(13,110,253,.06), transparent 55%),
    linear-gradient(180deg, #f8fafc, #eef2f7);
  display:grid; place-items:center; padding:2rem 1rem;
}
.auth-card {
  max-width: 440px; width:100%;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 1.1rem;
  box-shadow: var(--bs-box-shadow);
  background: var(--bg-elev);
}
.brand-lockup { display:flex; align-items:center; gap:.75rem; justify-content:center; margin-bottom:.75rem; }
.brand-lockup img { height: 150px; width:auto; }
.brand-name { font-weight: 800; letter-spacing: .2px; color: var(--brand-800); }
.muted { color: #6c757d; }
.auth-footer { font-size:.825rem; color:#6c757d; }
.btn-eye { border:1px solid #ced4da; border-left:0; border-radius:0 .5rem .5rem 0; }

/* ===== Utilitários para ícones/listas estilo “Last sales” ================= */
.list-dots{
  list-style:none; margin:0; padding:0;
}
.list-dots li{
  display:flex; justify-content:space-between; align-items:center; gap:.75rem;
  padding:.4rem .2rem; border-bottom:1px dashed #e9edf3;
}
.list-dots li:last-child{ border-bottom:0; }
.list-dots .dot{
  width:.55rem; height:.55rem; border-radius:50%;
  background: var(--brand-500);
  box-shadow: 0 0 0 3px rgba(40,184,129,.15);
}

/* ===== Pequenas animações ================================================ */
.fade-in{ animation: fadeIn .25s ease; }
@keyframes fadeIn{
  from{ opacity:0; transform: translateY(2px); }
  to{ opacity:1; transform:none; }
}
