/* =========================================================
   CNPJ Hunter — Stylesheet (unificado claro/escuro)
   ========================================================= */

/* ------------------------------
   0) Design tokens globais
   ------------------------------ */
:root {
  /* espaçamento, raio, tipografia */
  --spacing: 1.5rem;
  --radius: 12px;          /* cartas */
  --radius-sm: 8px;        /* inputs/badges */
  --fs-xxl: 5rem;
  --fs-xl: 4rem;
  --fs-lg: 3.2rem;
  --fs-md: 2rem;
  --fs-sm: 1.6rem;
  --fs-xs: 1.4rem;
  --fs-2xs: 1.2rem;

  /* sombras */
  --shadow-5: rgba(2,6,23,.05);
  --shadow-10: rgba(2,6,23,.10);
  --shadow-20: rgba(2,6,23,.20);

  /* layout */
  --main-page-width: 120rem;
  --table-min-width: 60rem;

  /* cores auxiliares fixas */
  --accent-1: #58aaff;
  --accent-2: #22d3ee;

  /* === HERO fixo (mesma aparência no claro e escuro) === */
  --hero-start: #0a4f68;
  --hero-mid:   #0b5a75;
  --hero-end:   #173d5a;
  --hero-glow:  rgba(255,255,255,.10);
  --hero-text:  #e9f4ff;
  --hero-chip-text: #e9f4ff;
  --hero-chip-border: rgba(255,255,255,.22);
  --hero-chip-bg: rgba(255,255,255,.12);
  --hero-chip-bg-hover: rgba(255,255,255,.18);
  --hero-chip-active-start: #58aaff;
  --hero-chip-active-end:   #2ed3ee;
}

/* -------------------------------------------------------
   1) Tokens de TEMA (LIGHT)
   ------------------------------------------------------- */
:root {
  --bg: #edf0f7;
  --surface: #ffffff;
  --surface-2: #fafbff;
  --border: #e5e7eb;

  --txt: #0b1220;
  --txt-muted: #6b7280;
  --link: #005386;

  --thead-bg: #0b1220;
  --thead-text: #e6f1ff;
  --row-alt: rgba(2, 6, 23, 0.04);
  --row-hover: rgba(2, 6, 23, 0.08);

  --pill-bg: rgba(0,0,0,.06);
  --pill-text: #0b1220;
}

/* -------------------------------------------------------
   2) Tokens de TEMA (DARK)
   ------------------------------------------------------- */
[data-theme="dark"] {
  --bg: #0b1220;
  --surface: #101828;
  --surface-2: #0f1a2b;
  --border: #1f2a3a;

  --txt: #e8eef9;
  --txt-muted: #9fb0c7;
  --link: #86c5ff;

  --thead-bg: #111827;
  --thead-text: #cfe6ff;
  --row-alt: rgba(255,255,255,.03);
  --row-hover: rgba(255,255,255,.07);

  --pill-bg: rgba(255,255,255,.10);
  --pill-text: #e8eef9;
}

/* ------------------------------
   3) Reset / base
   ------------------------------ */
*,
*::before,
*::after { box-sizing: border-box; margin:0; padding:0; }

html { font-size: 62.5%; }

body {
  font-family: system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,"Open Sans","Helvetica Neue",sans-serif;
  font-size: var(--fs-sm);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  background: var(--bg);
  color: var(--txt);
}

img, svg { display:block; max-width:100%; }

a { color: var(--link); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 2px; }

/* ------------------------------
   4) Header / Hero (unificado)
   ------------------------------ */
.header.hero {
  background:
    radial-gradient(120rem 60rem at 20% -10%, var(--hero-glow) 0%, rgba(0,0,0,0) 60%),
    linear-gradient(100deg, var(--hero-start) 0%, var(--hero-mid) 60%, var(--hero-end) 100%);
  padding: calc(var(--spacing)*1.2) var(--spacing) calc(var(--spacing)*1.5);
  color: var(--hero-text);
  position: relative;
  z-index: 1;
}

.hero-wrap { max-width: var(--main-page-width); margin: 0 auto; display: grid; gap: 1.2rem; }

.hero-top { display:flex; align-items:center; justify-content:space-between; gap:1rem; }

.hero-title { margin: 0; }
.hero-brand {
  color: var(--hero-text);
  text-decoration: none;
  font-size: clamp(2.4rem, 3.5vw, var(--fs-xxl));
  font-weight: 800;
  letter-spacing: .5px;
  text-shadow: 0 8px 24px rgba(0,0,0,.35);
}
.hero-brand:hover { filter: brightness(0.95); }

/* navegação (chips) */
.hero-nav { display:flex; gap:.6rem; flex-wrap:wrap; align-items:center; }
.user-menu ul { list-style:none; display:flex; gap:.6rem; align-items:center; }
.user-menu .muted { color: rgba(255,255,255,.85); }

.chip{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.55rem .9rem; border-radius:999px;
  background: var(--hero-chip-bg);
  color: var(--hero-chip-text);
  border:1px solid var(--hero-chip-border);
  backdrop-filter: blur(8px);
  text-decoration:none;
  transition: transform 180ms, background 180ms, opacity 180ms;
}
.chip:hover { transform: translateY(-1px); background: var(--hero-chip-bg-hover); }
.chip.active{
  background: linear-gradient(90deg, var(--hero-chip-active-start), var(--hero-chip-active-end));
  color:#0b1220; border-color: transparent;
}

/* garante links do hero sem sublinhado */
.header.hero a { color: var(--hero-text); text-decoration: none; }

/* ------------------------------
   5) Container principal
   ------------------------------ */
.content {
  max-width: var(--main-page-width);
  margin: calc(var(--spacing)*2) auto;
  padding: var(--spacing);
  background: var(--surface);
  color: var(--txt);
  border-radius: var(--radius);
  box-shadow: 0 12px 30px var(--shadow-10);
}
/* compensa espaço abaixo do hero */
.content { margin-top: calc(var(--spacing)*1.5); }

.page-wrap { max-width: var(--main-page-width); margin:0 auto; padding: 1.5rem; }

/* ------------------------------
   6) Cards
   ------------------------------ */
.card{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 15px 40px var(--shadow-10);
  overflow: hidden;
}
.card-head{
  padding: 1rem 1.25rem;
  background: linear-gradient(180deg, var(--accent-1) 0%, var(--accent-2) 100%);
  color: #0b1220;
}
.card-title{ margin:0; font-size:1.6rem; font-weight:800; letter-spacing:.3px; }

/* ------------------------------
   7) Filtros (index)
   ------------------------------ */
.filters {
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}
.filters-row { display:grid; grid-template-columns: repeat(7, minmax(0,1fr)); gap:.8rem; }
.filters .f-col { display:flex; flex-direction:column; gap:.35rem; }
.filters label { font-size:1.2rem; color:var(--txt-muted); font-weight:700; }

.filters input,
.filters select {
  padding:.8rem .9rem;
  border:1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--surface-2);
  color: var(--txt);
}
.filters-actions { display:flex; align-items:center; gap:.6rem; padding-top:.8rem; }

.btn { background: var(--link); color:#fff; font-weight:700; border:none; padding:.9rem 1.4rem; border-radius: var(--radius-sm); cursor:pointer; }
.btn:hover { filter: brightness(0.95); }
.btn.small{ padding:.45rem .75rem; font-size:1.4rem; }
.btn.btn-secondary{ background: transparent; color: var(--link); border:1px solid var(--border); }

@media (max-width:1100px){
  .filters-row { grid-template-columns: 1fr 1fr; }
}

/* ------------------------------
   8) Tabela
   ------------------------------ */
.tbl { width:100%; border-collapse:separate; border-spacing:0; min-width: var(--table-min-width); color: var(--txt); }
.tbl th, .tbl td { padding:.9rem 1rem; vertical-align:top; border-color: var(--border); }

.tbl thead th{
  position: sticky; top: 0; z-index: 1;
  background: var(--thead-bg);
  color: var(--thead-text);
  font-weight: 700;
  font-size: 1.2rem;
  text-transform: uppercase;
  letter-spacing: .03em;
  border-bottom: 1px solid var(--border);
}

.tbl tbody tr:nth-child(even){ background: var(--row-alt); }
.tbl tbody tr:hover{ background: var(--row-hover); }

/* polimento tipográfico */
.tbl tbody td{
  border-bottom: 1px solid var(--border);
  line-height: 1.4;
  padding-top: 1.1rem;
  padding-bottom: 1.1rem;
}

.name-link{
  font-weight: 800;
  color: var(--txt);
  text-decoration: none;
  letter-spacing: .2px;
}
.name-link:hover{ text-decoration: underline; text-underline-offset: 2px; }

.col-fantasia { color: var(--txt-muted); font-weight: 600; }
.cnae-desc{
  color: var(--txt);
  opacity: .85;
  font-size: 1.5rem;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.mono{ font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; }

.email-pill{
  display: inline-block;
  font-weight: 700;
  padding: .35rem .7rem;
  border-radius: 999px;
  background: var(--pill-bg);
  color: var(--pill-text);
  border: 1px solid rgba(255,255,255,.08);
  max-width: 32ch;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}

.badge{
  display:inline-block;
  padding:.35rem .6rem;
  border-radius: 8px;
  font-weight:700;
  background: var(--pill-bg);
  color: var(--pill-text);
  border: 1px solid rgba(255,255,255,.08);
}

.col-cnae{ max-width: 44rem; }
.col-email{ max-width: 32rem; }
.col-regiao{ width: 12rem; }

.sort{ cursor:pointer; user-select:none; display:inline-flex; align-items:center; gap:.4rem; }
.sort svg{ width:12px; height:12px; opacity:.45; }
.sort[data-dir="asc"] .up{ opacity:1; }
.sort[data-dir="desc"] .down{ opacity:1; }

/* estrela (lead) */
.star-btn{ background:transparent; border:0; cursor:pointer; padding:.25rem; border-radius:8px; }
.star-btn:hover{ background: rgba(255,255,255,.07); }
.star{ width:20px; height:20px; fill:transparent; stroke: var(--txt-muted); stroke-width:2; display:inline-block; }
.star.filled{ fill:#fbbf24; stroke:#f59e0b; }

/* ------------------------------
   9) Mensagens (flash)
   ------------------------------ */
.message{
  max-width:60rem; margin: var(--spacing) auto; margin-top: calc(var(--spacing)*2);
  padding: var(--spacing); text-align:center; border-radius: var(--radius-sm);
  font-size: var(--fs-xs);
  background: var(--surface-2);
  border: 1px solid var(--border);
  color: var(--txt);
}
.message.success{ box-shadow: 0 0 0 2px rgba(16,185,129,.25) inset; }
.message.error{ box-shadow: 0 0 0 2px rgba(239,68,68,.25) inset; }
.message.warning{ box-shadow: 0 0 0 2px rgba(245,158,11,.25) inset; }
.message.info{ box-shadow: 0 0 0 2px rgba(59,130,246,.25) inset; }

/* ------------------------------
   10) Formulários
   ------------------------------ */
.form-wrapper{ max-width:60rem; margin: var(--spacing) auto; }
.form-group{ display:flex; flex-direction:column; gap:.6rem; padding-bottom: var(--spacing); }
.form-group label{ font-size: var(--fs-xs); color: var(--txt-muted); }
.form-group input, .form-group textarea, .form-group select{
  padding:1rem; border-radius: var(--radius-sm);
  border:1px solid var(--border);
  background: var(--surface-2);
  color: var(--txt);
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus{
  outline: none;
  box-shadow: 0 0 0 3px rgba(88,170,255,.25);
}
.errorlist{ list-style:none; font-size: var(--fs-xs); color: tomato; }
.errorlist.nonfield{ color: inherit; }

.btn-delete{ background: tomato; }

/* CTA de lead */
.btn-lead{
  background: linear-gradient(90deg,#0077b6 0%, #00b4d8 100%);
  color:#fff; font-size:1.7rem; font-weight:700;
  border:none; padding:1.1rem 2.2rem; border-radius:30px;
  box-shadow:0 2px 8px var(--shadow-10);
  cursor:pointer; letter-spacing:.03em;
  display:inline-flex; align-items:center; gap:.7rem;
  transition: transform .2s, box-shadow .2s, filter .2s;
}
.btn-lead:hover, .btn-lead:focus{
  filter: brightness(1.06);
  transform: translateY(-1px);
  box-shadow:0 8px 20px var(--shadow-20);
}
.btn-lead-remove{
  background: linear-gradient(90deg,#b60000 0%, #ff4d4d 100%);
}

/* ------------------------------
   11) Detalhe do CNPJ
   ------------------------------ */
.grid{ display:grid; grid-template-columns:repeat(12,1fr); gap:1rem; }
@media (min-width: 900px){
  .span-6{ grid-column: span 6; }
  .span-4{ grid-column: span 4; }
  .span-8{ grid-column: span 8; }
}

.cnpj-section,
.detail-card,
.info-card,
.kpi-card {
  background: var(--surface);
  color: var(--txt);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.2rem;
}

.section-title{
  margin: 0 0 .6rem 0;
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--txt);
}

/* listas semânticas (dl) */
.dl{ display:grid; grid-template-columns:1fr 2fr; gap:.6rem 1.2rem; }
.dt{ color: var(--txt-muted); }
.dd{ font-weight:600; color: var(--txt); }

/* cards KPIs (simples/MEI datas) */
.kpi{
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: .9rem 1.1rem;
}
.kpi .hint{ color: var(--txt-muted); font-size: 1.2rem; }

/* tabela de sócios */
.tbl th,.tbl td{ text-align:left; }
.tbl thead th{ font-size:1.1rem; }

/* ------------------------------
   12) Paginação
   ------------------------------ */
.pagination{
  margin-top: var(--spacing);
  display:flex; justify-content:center; gap:.6rem;
  padding: calc(var(--spacing)*.8);
  font-size: var(--fs-xs);
}
.pagination .step-links{ display:flex; gap:.6rem; }
.pagination .step-links a,
.pagination .step-links span{
  display:inline-block;
  padding:.5rem .9rem;
  border-radius: 10px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  color: var(--txt);
}

/* ------------------------------
   13) Utilitários
   ------------------------------ */
.nowrap{ white-space:nowrap; }
.muted{ color: var(--txt-muted) !important; }

.email, .badge, .pill, .mail-pill{
  background: var(--pill-bg);
  color: var(--pill-text);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 999px;
  padding: .25rem .6rem;
  display:inline-block;
  line-height: 1.2;
}

/* Garante legibilidade das colunas-chave no dark */
td[data-col="fantasia"],
td[data-col="cnae"],
td[data-col="telefone"]{ color: var(--txt) !important; }
