/* ═══════════════════════════════════════════════════════════════════════════
   MultDash UI Override — Sidebar moderna azul + responsividade + cards
   Injete via index.html: <link rel="stylesheet" href="/assets/multdash-ui.css">
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── Variáveis globais ─────────────────────────────────────────────────── */
:root {
  --sidebar-from: #0f172a;
  --sidebar-to:   #1e3a6e;
  --sidebar-accent: #3b82f6;
  --sidebar-active-bg: rgba(59,130,246,0.22);
  --sidebar-active-border: #3b82f6;
  --sidebar-text: rgba(255,255,255,0.85);
  --sidebar-text-dim: rgba(255,255,255,0.45);
  --sidebar-hover: rgba(255,255,255,0.08);
  --sidebar-group: rgba(255,255,255,0.35);
  --card-radius: 14px;
  --card-shadow: 0 2px 16px rgba(30,58,143,0.10), 0 1px 4px rgba(0,0,0,0.06);
  --card-shadow-hover: 0 8px 32px rgba(30,58,143,0.18), 0 2px 8px rgba(0,0,0,0.10);
  --transition: 0.22s cubic-bezier(.4,0,.2,1);
}

/* ═══════════════════════════════════════════════════════════════════════════
   SIDEBAR — Gradiente azul profundo moderno
   ═══════════════════════════════════════════════════════════════════════════ */

aside {
  background: linear-gradient(165deg, var(--sidebar-from) 0%, var(--sidebar-to) 100%) !important;
  box-shadow: 4px 0 30px rgba(0,0,0,0.25) !important;
  border-right: 1px solid rgba(255,255,255,0.06) !important;
  position: relative;
}

/* Linha decorativa lateral na borda direita */
aside::after {
  content: '';
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: 1px;
  background: linear-gradient(to bottom, transparent, rgba(59,130,246,0.4), transparent);
  pointer-events: none;
}

/* ── Logo area ─────────────────────────────────────────────────────────── */
aside > div:first-child {
  background: rgba(0,0,0,0.18) !important;
  border-bottom: 1px solid rgba(255,255,255,0.08) !important;
  padding: 18px 14px !important;
}

aside > div:first-child p {
  color: rgba(255,255,255,0.95) !important;
  font-size: 11px !important;
  letter-spacing: 1.5px !important;
  text-shadow: 0 1px 4px rgba(0,0,0,0.4) !important;
  margin-top: 4px !important;
}

/* ── Nav ───────────────────────────────────────────────────────────────── */
aside nav {
  padding: 10px 8px !important;
  scrollbar-width: thin;
  scrollbar-color: rgba(59,130,246,0.3) transparent;
}

aside nav::-webkit-scrollbar { width: 3px; }
aside nav::-webkit-scrollbar-track { background: transparent; }
aside nav::-webkit-scrollbar-thumb { background: rgba(59,130,246,0.35); border-radius: 2px; }

/* ── Grupo de categoria (label) ────────────────────────────────────────── */
aside nav button.w-full {
  color: var(--sidebar-text-dim) !important;
  font-size: 9.5px !important;
  letter-spacing: 1.2px !important;
  padding: 6px 10px 4px !important;
  margin-top: 6px !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
  opacity: 1 !important;
  border-radius: 6px !important;
  transition: color var(--transition) !important;
}
aside nav button.w-full:hover {
  color: rgba(255,255,255,0.7) !important;
  background: rgba(255,255,255,0.04) !important;
}

/* ── Itens de menu ─────────────────────────────────────────────────────── */
aside a {
  border-radius: 10px !important;
  margin: 2px 0 !important;
  padding: 10px 12px !important;
  color: var(--sidebar-text) !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
  letter-spacing: 0.1px !important;
  transition: all var(--transition) !important;
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  gap: 11px !important;
  text-decoration: none !important;
  border: 1px solid transparent !important;
}

aside a:hover {
  background: var(--sidebar-hover) !important;
  color: #fff !important;
  border-color: rgba(255,255,255,0.07) !important;
  transform: translateX(2px) !important;
}

/* ── Item ATIVO (active state) ─────────────────────────────────────────── */
aside a.bg-white\/20,
aside a[class*="bg-white/20"] {
  background: var(--sidebar-active-bg) !important;
  color: #fff !important;
  border-color: rgba(59,130,246,0.4) !important;
  box-shadow: 0 2px 12px rgba(59,130,246,0.2), inset 0 0 0 1px rgba(59,130,246,0.25) !important;
  font-weight: 600 !important;
}

/* Linha esquerda no item ativo */
aside a.bg-white\/20::before,
aside a[class*="bg-white/20"]::before {
  content: '';
  position: absolute;
  left: 0; top: 20%; bottom: 20%;
  width: 3px;
  background: var(--sidebar-accent);
  border-radius: 0 3px 3px 0;
  box-shadow: 0 0 8px rgba(59,130,246,0.6);
}

/* Ícones nos itens */
aside a span.flex-shrink-0 { opacity: 0.85; transition: opacity var(--transition); }
aside a:hover span.flex-shrink-0,
aside a.bg-white\/20 span.flex-shrink-0 { opacity: 1; }

/* ── Bottom: usuário + logout ───────────────────────────────────────────── */
aside > div:last-child {
  background: rgba(0,0,0,0.22) !important;
  border-top: 1px solid rgba(255,255,255,0.08) !important;
  padding: 12px 12px !important;
}

aside > div:last-child p { color: rgba(255,255,255,0.9) !important; }
aside > div:last-child span { color: rgba(255,255,255,0.5) !important; }

/* Avatar do usuário */
aside > div:last-child > div > div:first-child {
  background: linear-gradient(135deg, var(--sidebar-accent), #6366f1) !important;
  border: 2px solid rgba(255,255,255,0.2) !important;
  box-shadow: 0 2px 8px rgba(59,130,246,0.4) !important;
  border-radius: 50% !important;
}

/* Botão logout */
aside > div:last-child button {
  color: rgba(255,255,255,0.5) !important;
  transition: all var(--transition) !important;
  border-radius: 8px !important;
  padding: 6px !important;
}
aside > div:last-child button:hover {
  color: #f87171 !important;
  background: rgba(239,68,68,0.12) !important;
}

/* ─── Collapsed sidebar — ícones centralizados ─────────────────────────── */
aside a.justify-center {
  gap: 0 !important;
  padding: 12px !important;
  border-radius: 10px !important;
}
aside a.justify-center:hover { transform: translateX(0) scale(1.05) !important; }

/* ═══════════════════════════════════════════════════════════════════════════
   HEADER TOPO
   ═══════════════════════════════════════════════════════════════════════════ */

header, .header-bar {
  border-bottom: 1px solid rgba(30,58,143,0.10) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
}

/* Botão hamburguer mobile */
.md\:hidden button[class*="text-slate"] {
  background: white !important;
  border-radius: 10px !important;
  padding: 8px !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   CARDS — Mais sombra e estilo
   ═══════════════════════════════════════════════════════════════════════════ */

.card {
  border-radius: var(--card-radius) !important;
  box-shadow: var(--card-shadow) !important;
  border: 1px solid rgba(226,232,240,0.8) !important;
  transition: box-shadow var(--transition), transform var(--transition) !important;
}

.card:hover {
  box-shadow: var(--card-shadow-hover) !important;
  transform: translateY(-2px) !important;
}

/* KPI cards com ícone colorido */
.kpi-card {
  border-radius: var(--card-radius) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.12) !important;
  transition: all var(--transition) !important;
  overflow: hidden !important;
  position: relative !important;
}

.kpi-card::before {
  content: '';
  position: absolute;
  top: -30px; right: -30px;
  width: 100px; height: 100px;
  background: rgba(255,255,255,0.08);
  border-radius: 50%;
  pointer-events: none;
}

.kpi-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 12px 32px rgba(0,0,0,0.20) !important;
}

/* ── Section title ──────────────────────────────────────────────────────── */
.section-title {
  color: #0f172a !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
}

/* ── Botões ─────────────────────────────────────────────────────────────── */
.btn-primary {
  border-radius: 10px !important;
  background: linear-gradient(135deg, #2563eb, #1d4ed8) !important;
  box-shadow: 0 2px 10px rgba(37,99,235,0.35) !important;
  transition: all var(--transition) !important;
  font-weight: 600 !important;
}
.btn-primary:hover {
  background: linear-gradient(135deg, #1d4ed8, #1e40af) !important;
  box-shadow: 0 4px 16px rgba(37,99,235,0.45) !important;
  transform: translateY(-1px) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PAGE HEADER — Banner superior de cada página
   ═══════════════════════════════════════════════════════════════════════════ */

/* Gradiente do banner de cabeçalho de página */
.bg-gradient-to-r.from-blue-900,
.bg-gradient-to-r.from-slate-800,
[class*="from-blue-9"],
[class*="from-slate-8"] {
  background: linear-gradient(135deg, #0f172a 0%, #1e40af 100%) !important;
  border-radius: var(--card-radius) !important;
  box-shadow: 0 4px 24px rgba(15,23,42,0.2) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   TABELAS
   ═══════════════════════════════════════════════════════════════════════════ */

table {
  border-collapse: separate !important;
  border-spacing: 0 !important;
}

thead tr th {
  background: #f1f5f9 !important;
  color: #475569 !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.8px !important;
  text-transform: uppercase !important;
  border-bottom: 2px solid #e2e8f0 !important;
  padding: 10px 14px !important;
  position: sticky;
  top: 0;
  z-index: 1;
}

tbody tr {
  transition: background var(--transition) !important;
}

tbody tr:hover td {
  background: #eff6ff !important;
}

tbody tr td {
  border-bottom: 1px solid #f1f5f9 !important;
  padding: 9px 14px !important;
  font-size: 13.5px !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   CHARTS — Containers dos gráficos
   ═══════════════════════════════════════════════════════════════════════════ */

/* Recharts container */
.recharts-wrapper {
  border-radius: 10px !important;
  overflow: visible !important;
}

/* Tooltip dos gráficos */
.recharts-tooltip-wrapper .recharts-default-tooltip {
  border-radius: 10px !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.15) !important;
  border: 1px solid rgba(226,232,240,0.8) !important;
  font-size: 13px !important;
  padding: 10px 14px !important;
  background: rgba(255,255,255,0.97) !important;
  backdrop-filter: blur(8px) !important;
}

.recharts-tooltip-wrapper .recharts-tooltip-label {
  font-weight: 700 !important;
  color: #0f172a !important;
  margin-bottom: 4px !important;
  font-size: 12px !important;
}

/* Legend */
.recharts-legend-wrapper {
  font-size: 12px !important;
  font-weight: 500 !important;
}

/* Linha de grid mais suave */
.recharts-cartesian-grid line {
  stroke: #f1f5f9 !important;
}

/* Eixos */
.recharts-cartesian-axis-tick text {
  fill: #94a3b8 !important;
  font-size: 11px !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   INPUTS, SELECTS, FILTERS
   ═══════════════════════════════════════════════════════════════════════════ */

input[type="text"], input[type="number"], input[type="date"],
input[type="email"], input[type="password"], input[type="search"],
select, textarea {
  border-radius: 9px !important;
  border: 1px solid #cbd5e1 !important;
  transition: all var(--transition) !important;
  font-size: 13.5px !important;
  padding: 8px 12px !important;
  background: white !important;
}

input:focus, select:focus, textarea:focus {
  border-color: #3b82f6 !important;
  box-shadow: 0 0 0 3px rgba(59,130,246,0.15) !important;
  outline: none !important;
}

/* ── Badges / Status pills ─────────────────────────────────────────────── */
span[class*="rounded-full"][class*="text-xs"] {
  font-weight: 600 !important;
  letter-spacing: 0.2px !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   ANIMAÇÕES SUAVES
   ═══════════════════════════════════════════════════════════════════════════ */

@keyframes fadeSlideIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

.animate-fade-in-up {
  animation: fadeSlideIn 0.35s cubic-bezier(.4,0,.2,1) both !important;
}

/* Skeleton loading pulse */
@keyframes shimmer {
  0%   { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   MOBILE — Responsividade (≤ 768px)
   ═══════════════════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* Garante que o conteúdo não fique escondido atrás do header mobile */
  main { padding-top: 60px !important; }

  /* Cards empilhados e touch-friendly */
  .card {
    border-radius: 12px !important;
    padding: 14px !important;
    margin-bottom: 10px !important;
  }

  /* KPI cards em grid 2 colunas no mobile */
  .grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px !important;
  }

  /* Exceção: 1 coluna se muitos itens */
  .grid.grid-cols-4, .grid.grid-cols-5 {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  /* Tabelas com scroll horizontal */
  .overflow-x-auto { overflow-x: auto !important; -webkit-overflow-scrolling: touch !important; }

  table { min-width: 600px; }

  thead tr th { padding: 8px 10px !important; font-size: 10px !important; }
  tbody tr td { padding: 8px 10px !important; font-size: 12px !important; }

  /* Section titles menores */
  .section-title { font-size: 0.9rem !important; }

  /* Botões touch-friendly */
  button { min-height: 40px; }
  .btn-primary { padding: 10px 16px !important; font-size: 14px !important; }

  /* Esconde colunas opcionais em telas pequenas */
  .hide-mobile { display: none !important; }

  /* Sidebar overlay no mobile — toma tela cheia */
  .md\:hidden.fixed {
    z-index: 50 !important;
  }

  /* Recharts responsivo */
  .recharts-wrapper {
    width: 100% !important;
    min-height: 200px !important;
  }

  /* Títulos menores */
  h1 { font-size: 1.4rem !important; }
  h2 { font-size: 1.2rem !important; }

  /* Inputs touch-friendly */
  input, select { min-height: 40px; font-size: 16px !important; }

  /* Espaçamento interno dos painéis */
  .p-4, .p-6 { padding: 12px !important; }
  .p-4.md\:p-6 { padding: 12px !important; }
  .space-y-4 > * + * { margin-top: 10px !important; }
  .gap-4 { gap: 10px !important; }
  .gap-6 { gap: 12px !important; }

  /* Flex wrap em mobile */
  .flex:not(aside):not(nav):not(header) {
    flex-wrap: wrap !important;
  }

  /* Ocultar texto longo em mobile */
  .truncate { max-width: 120px; }
}

/* ── Telas muito pequenas (< 480px) ────────────────────────────────────── */
@media (max-width: 480px) {
  .grid { grid-template-columns: 1fr !important; }

  .kpi-card { padding: 12px !important; }

  h1 { font-size: 1.2rem !important; }

  /* Header compacto */
  header { padding: 0 10px !important; }

  main { padding-top: 56px !important; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   SCROLLBAR GLOBAL — Slim e elegante
   ═══════════════════════════════════════════════════════════════════════════ */

* { scrollbar-width: thin; scrollbar-color: #cbd5e1 transparent; }
*::-webkit-scrollbar { width: 5px; height: 5px; }
*::-webkit-scrollbar-track { background: transparent; }
*::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 4px; }
*::-webkit-scrollbar-thumb:hover { background: #94a3b8; }

/* ═══════════════════════════════════════════════════════════════════════════
   DROPDOWN / MODALS
   ═══════════════════════════════════════════════════════════════════════════ */

[role="dialog"], .modal {
  border-radius: 18px !important;
  box-shadow: 0 24px 64px rgba(0,0,0,0.2) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PRINT — Limpa para impressão
   ═══════════════════════════════════════════════════════════════════════════ */

@media print {
  aside { display: none !important; }
  main { padding: 0 !important; }
  .card { box-shadow: none !important; border: 1px solid #e2e8f0 !important; }
  .btn-primary { display: none !important; }
}
