/* static/css/app.css */

:root{
  --bg: #0b0f1e;
  --panel: rgba(255,255,255,.06);
  --panel-2: rgba(255,255,255,.08);
  --border: rgba(255,255,255,.10);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.70);

  --primary: #2563eb;   /* azul */
  --primary-2: #1d4ed8;
  --secondary: rgba(255,255,255,.12);
  --secondary-2: rgba(255,255,255,.18);
  --danger: #dc2626;    /* vermelho */
  --danger-2: #b91c1c;
}

*{ box-sizing: border-box; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color: var(--text);
  background: radial-gradient(1200px 600px at 20% 0%, rgba(99,102,241,.25), transparent 60%),
              radial-gradient(900px 500px at 90% 10%, rgba(168,85,247,.20), transparent 55%),
              var(--bg);
}

a{ color: inherit; text-decoration: none; }
.container{ max-width: 1200px; margin: 0 auto; padding: 24px; }

.card{
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px;
  backdrop-filter: blur(10px);
}

.hstack{ display:flex; align-items:center; gap:12px; }
.vstack{ display:flex; flex-direction:column; gap:12px; }

.muted{ color: var(--muted); }
.hr{ height:1px; background: var(--border); margin: 14px 0; }

/* Tabs */
.tabs{ display:flex; gap:10px; margin: 14px 0 18px; flex-wrap: wrap; }
.tab{
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
}
.tab.active{
  background: rgba(99,102,241,.18);
  border-color: rgba(99,102,241,.35);
}

/* Forms */
.form-grid{
  display:grid;
  grid-template-columns: 180px 1fr;
  gap: 10px 14px;
  align-items:center;
}

@media (max-width: 720px){
  .form-grid{ grid-template-columns: 1fr; }
}

label{
  color: var(--muted);
  font-size: 13px;
}

input, select, textarea{
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(0,0,0,.18);
  color: var(--text);
  outline: none;
}

input:focus, select:focus, textarea:focus{
  border-color: rgba(37,99,235,.55);
  box-shadow: 0 0 0 3px rgba(37,99,235,.20);
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid transparent;
  cursor:pointer;
  font-weight: 600;
  font-size: 14px;
  line-height: 1;
  user-select:none;
}

.btn:disabled{
  opacity: .55;
  cursor:not-allowed;
}

.btn-primary{
  background: var(--primary);
  border-color: rgba(255,255,255,.10);
}
.btn-primary:hover{ background: var(--primary-2); }

.btn-secondary{
  background: var(--secondary);
  border-color: var(--border);
}
.btn-secondary:hover{ background: var(--secondary-2); }

.btn-danger{
  background: var(--danger);
  border-color: rgba(255,255,255,.10);
}
.btn-danger:hover{ background: var(--danger-2); }

.btn-sm{ padding: 8px 10px; border-radius: 10px; font-size: 13px; }

/* Tables */
.table{
  width: 100%;
  border-collapse: collapse;
  overflow:hidden;
  border-radius: 14px;
  border: 1px solid var(--border);
}

.table th, .table td{
  padding: 12px 12px;
  border-bottom: 1px solid var(--border);
  text-align: left;
  vertical-align: middle;
}

.table th{
  color: var(--muted);
  font-size: 12px;
  letter-spacing: .02em;
  background: rgba(255,255,255,.04);
}

.table tr:hover td{
  background: rgba(255,255,255,.03);
}

.actions{
  display:flex;
  gap:10px;
  justify-content:flex-start;
  flex-wrap: wrap;
}

/* =========================================================
   CONTRASTE GLOBAL (Dashboard + Mensal)
   ========================================================= */

/* Se Bootstrap estiver presente, ele deixa .text-muted apagado no tema escuro */
.text-muted{
  color: rgba(255,255,255,.74) !important;
}

/* Cards usados no tema (templates usam app-card) */
.app-card,
.app-card .card-body{
  color: rgba(255,255,255,.92);
}

/* Títulos dentro de cards (Mensal e Dashboard) */
.app-card .h5,
.app-card .h6,
.app-card h1,
.app-card h2,
.app-card h3,
.app-card h4,
.app-card h5,
.app-card h6{
  color: rgba(255,255,255,.96);
}

/* Labels/valores (Dashboard) */
.metric-title{
  color: rgba(255,255,255,.82);
  font-weight: 700;
}

.metric-big{
  color: rgba(255,255,255,.98);
  font-weight: 900;
  letter-spacing: .01em;
}

/* Blocos de contagem (Dashboard) */
.stack-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 8px 0;
}

.stack-label{
  color: rgba(255,255,255,.82);
  font-weight: 700;
}

.stack-value{
  color: rgba(255,255,255,.98);
  font-weight: 900;
}

/* Mensal: garantir título do card e headings com contraste */
.card-title,
.app-title{
  color: rgba(255,255,255,.96);
  font-weight: 800;
}

/* Mensal: labels (caso use form-label do Bootstrap) */
.form-label{
  color: rgba(255,255,255,.78) !important;
  font-weight: 600;
}

/* Mensal: tabela no tema escuro (quando a tabela NÃO é branca) */
.app-table,
.app-table td{
  color: rgba(255,255,255,.92);
}

.app-table th{
  color: rgba(255,255,255,.78);
}

/* Garante que nada herde opacity baixo dentro do card */
.app-card *{
  opacity: 1;
}