/* =========================================================
   Captados — Tour Group brand (Outfit + cream/navy)
   Estrutura editorial mantida; tipografia e cores do Tour Group Hub.
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&display=swap');

:root {
  /* Tour Group brand tokens (espelhados do tour-group-hub) */
  --bg:              hsl(56 100% 95%);   /* #FFFEE4 cream */
  --bg-soft:         hsl(56 60% 92%);    /* cream sutilmente mais escuro */
  --surface:         hsl(0 0% 100%);     /* cards brancos */
  --surface-soft:    hsl(210 20% 98%);

  --ink:             hsl(213 100% 22%);  /* #003570 navy deep — foreground */
  --ink-soft:        hsl(214 60% 41%);   /* #2A5FA8 primary navy */
  --ink-secondary:   hsl(197 40% 63%);   /* #8EBADD azul claro */
  --ink-mute:        hsl(215 16% 47%);   /* #6B7B8E cinza médio */
  --ink-faint:       hsl(215 20% 70%);

  --border:          hsl(214 32% 91%);   /* #DDE3ED */
  --border-soft:     hsl(214 32% 94%);

  --success:         hsl(82 52% 60%);    /* #9DC97D verde Tour */
  --warning:         hsl(27 72% 59%);
  --gold:            hsl(46 82% 55%);    /* #EEB52D */
  --danger:          hsl(348 40% 53%);
  --danger-bg:       hsl(348 60% 96%);

  --radius:          12px;
  --radius-sm:       8px;
  --radius-pill:     999px;

  --t-fast: 150ms;
  --t-base: 220ms;
  --ease:   cubic-bezier(.4, 0, .2, 1);

  --shadow-1: 0 0 0 1px rgba(42,94,168,0.05), 0 2px 4px rgba(0,0,0,0.02), 0 10px 15px -3px rgba(0,0,0,0.03);
  --shadow-2: 0 0 0 1px rgba(42,94,168,0.08), 0 4px 8px rgba(0,0,0,0.04), 0 16px 24px -6px rgba(0,0,0,0.05);
}

/* ---------------- reset ---------------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
html { -webkit-text-size-adjust: 100%; }
body {
  font-family: 'Outfit', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  background: var(--bg);
  color: var(--ink);
  font-size: 16px;
  line-height: 1.5;
  font-weight: 400;
  letter-spacing: -0.005em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
button { font: inherit; cursor: pointer; background: transparent; border: 0; color: inherit; }
input  { font: inherit; font-family: 'Outfit', sans-serif; }
a { color: inherit; text-decoration: none; }
:focus-visible { outline: 2px solid var(--ink-soft); outline-offset: 2px; border-radius: 4px; }
::selection { background: hsl(56 100% 80%); color: var(--ink); }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0ms !important; transition-duration: 0ms !important; }
}

/* ---------------- layout ---------------- */
#app {
  min-height: 100dvh;
  padding: clamp(24px, 4vw, 56px) clamp(20px, 4vw, 56px) 56px;
  max-width: 1180px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: clamp(28px, 3.5vw, 48px);
}
.screen { display: flex; flex-direction: column; gap: clamp(24px, 3vw, 40px); }
.screen[hidden] { display: none; }
.muted { color: var(--ink-mute); }

/* ---------------- header (wordmark) ---------------- */
.wordmark {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--border);
}
.wordmark__brand {
  font-family: 'Outfit', sans-serif;
  font-weight: 900;
  font-size: clamp(22px, 2.4vw, 28px);
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--ink);
  text-transform: lowercase;
}
.wordmark__brand sup {
  font-size: 0.5em;
  font-weight: 700;
  color: var(--ink-soft);
  vertical-align: top;
  margin-left: 1px;
  letter-spacing: 0;
}
.wordmark__meta {
  font-family: 'Outfit', sans-serif;
  font-weight: 500;
  font-size: 12px;
  color: var(--ink-mute);
  display: flex;
  align-items: center;
  gap: 14px;
  letter-spacing: 0;
}
.wordmark__meta time { font-variant-numeric: tabular-nums; font-weight: 500; }
.dot-live {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--success);
  box-shadow: 0 0 0 4px hsla(82, 52%, 60%, 0.22);
  animation: pulse 2.4s var(--ease) infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 4px hsla(82, 52%, 60%, 0.22); }
  50%      { box-shadow: 0 0 0 7px hsla(82, 52%, 60%, 0.05); }
}
.link-logout {
  font-family: 'Outfit', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink-mute);
  padding: 6px 12px;
  border-radius: var(--radius-pill);
  transition: color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.link-logout:hover { color: var(--ink); background: var(--bg-soft); }

/* ---------------- LOGIN ---------------- */
.login {
  max-width: 420px;
  margin: 12vh auto 0;
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.login__head h1 {
  font-family: 'Outfit', sans-serif;
  font-weight: 900;
  font-size: clamp(48px, 7vw, 72px);
  letter-spacing: -0.05em;
  line-height: 0.95;
  margin: 0 0 12px;
  color: var(--ink);
}
.login__head h1 em {
  font-style: normal;
  color: var(--ink-soft);
}
.login__head p {
  margin: 0;
  font-size: 15px;
  color: var(--ink-mute);
  max-width: 340px;
  line-height: 1.55;
  font-weight: 400;
}
.login__form { display: flex; flex-direction: column; gap: 16px; }

.field { display: block; }
.field__label {
  display: block;
  font-family: 'Outfit', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 8px;
}
input[type="password"],
input[type="search"],
input[type="date"] {
  display: block;
  width: 100%;
  padding: 14px 16px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--ink);
  font-size: 15px;
  font-weight: 500;
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
input:focus { outline: none; border-color: var(--ink-soft); box-shadow: 0 0 0 3px hsla(214, 60%, 41%, 0.12); }
input::placeholder { color: var(--ink-faint); font-weight: 400; }

#pin {
  text-align: center;
  font-size: 24px;
  letter-spacing: 0.4em;
  padding: 18px;
  font-weight: 700;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 22px;
  border-radius: var(--radius-pill);
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.005em;
  cursor: pointer;
  transition: transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease), color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.btn:active { transform: translateY(1px); }
.btn[disabled] { opacity: 0.55; cursor: not-allowed; }
.btn--primary {
  background: var(--ink);
  color: var(--bg);
  width: 100%;
  padding: 16px;
  font-size: 15px;
}
.btn--primary:hover:not([disabled]) { background: var(--ink-soft); }
.btn--ghost {
  background: var(--surface);
  color: var(--ink);
  padding: 10px 16px;
  font-size: 13px;
  border: 1px solid var(--border);
}
.btn--ghost:hover:not([disabled]) { background: var(--bg-soft); border-color: var(--ink-secondary); }

.error {
  margin: 0;
  padding: 11px 14px;
  background: var(--danger-bg);
  border-left: 3px solid var(--danger);
  color: var(--danger);
  font-size: 14px;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  font-weight: 500;
}

/* ---------------- SELETOR ---------------- */
.selector__intro {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.selector__intro h2 {
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: clamp(24px, 2.6vw, 32px);
  letter-spacing: -0.035em;
  margin: 0;
  color: var(--ink);
}
.selector__intro p {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 12px;
  color: var(--ink-mute);
  margin: 0;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.cities {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.city-pick {
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  align-items: center;
  gap: clamp(20px, 4vw, 48px);
  padding: clamp(24px, 3vw, 36px) clamp(20px, 3vw, 32px);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  cursor: pointer;
  text-align: left;
  width: 100%;
  transition: border-color var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease), transform var(--t-base) var(--ease);
  box-shadow: var(--shadow-1);
}
.city-pick:hover {
  border-color: var(--ink-soft);
  box-shadow: var(--shadow-2);
  transform: translateY(-1px);
}
.city-pick:hover .city-pick__arrow { transform: translateX(4px); color: var(--ink-soft); }
.city-pick:hover .city-pick__name  { color: var(--ink-soft); }

.city-pick__name {
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: clamp(32px, 5vw, 52px);
  letter-spacing: -0.035em;
  line-height: 1;
  color: var(--ink);
  transition: color var(--t-base) var(--ease);
  text-transform: lowercase;
}
.city-pick__name em { font-style: normal; font-weight: 500; color: var(--ink-mute); }

.city-pick__metric {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  min-width: 76px;
}
.city-pick__metric-value {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: clamp(22px, 2.6vw, 32px);
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  line-height: 1;
  letter-spacing: -0.02em;
}
.city-pick__metric-label {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

.city-pick__hoje {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: 'Outfit', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  background: hsla(82, 52%, 60%, 0.18);
  padding: 6px 12px;
  border-radius: var(--radius-pill);
  font-variant-numeric: tabular-nums;
}
.city-pick__hoje.is-zero { color: var(--ink-mute); background: var(--bg-soft); }

.city-pick__arrow {
  font-family: 'Outfit', sans-serif;
  font-size: 26px;
  font-weight: 400;
  color: var(--ink-mute);
  transition: transform var(--t-base) var(--ease), color var(--t-base) var(--ease);
  line-height: 1;
}

@media (max-width: 640px) {
  .city-pick { grid-template-columns: 1fr auto; gap: 10px 16px; padding: 20px; }
  .city-pick__metric { grid-row: 2; grid-column: 1; flex-direction: row; gap: 12px; align-items: baseline; }
  .city-pick__hoje { grid-row: 2; grid-column: 2; }
  .city-pick__arrow { display: none; }
  .city-pick__name { font-size: clamp(28px, 7vw, 38px); }
}

/* ---------------- DASHBOARD ---------------- */
.dash__topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.dash__back {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'Outfit', sans-serif;
  font-size: 13px; font-weight: 600;
  color: var(--ink-mute);
  padding: 8px 14px;
  border-radius: var(--radius-pill);
  transition: color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.dash__back:hover { color: var(--ink); background: var(--bg-soft); }
.dash__back svg { width: 14px; height: 14px; }

.dash__switcher {
  display: flex; align-items: center; gap: 4px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  padding: 4px;
  box-shadow: var(--shadow-1);
}
.dash__switcher button {
  font-family: 'Outfit', sans-serif;
  font-size: 12px;
  font-weight: 600;
  padding: 7px 14px;
  border-radius: var(--radius-pill);
  color: var(--ink-mute);
  transition: color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.dash__switcher button:hover { color: var(--ink); }
.dash__switcher button.is-active { background: var(--ink); color: var(--bg); }

/* Hero da cidade */
.dash__hero {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: clamp(20px, 4vw, 48px);
  align-items: end;
  padding: clamp(24px, 3vw, 36px);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
}
.dash__hero-title {
  font-family: 'Outfit', sans-serif;
  font-weight: 900;
  font-size: clamp(48px, 8vw, 88px);
  letter-spacing: -0.045em;
  line-height: 0.9;
  color: var(--ink);
  margin: 0;
  text-transform: lowercase;
}
.dash__hero-title em { font-style: normal; font-weight: 500; color: var(--ink-soft); }
.dash__hero-sub {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 14px 0 0;
}
.dash__hero-num {
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: clamp(40px, 6vw, 64px);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.025em;
  color: var(--ink);
  line-height: 1;
  text-align: right;
}
.dash__hero-num-label {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-top: 6px;
  text-align: right;
}

/* Métricas (4 cards) */
.metrics {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.metric {
  padding: 20px 22px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  transition: box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.metric:hover { box-shadow: var(--shadow-2); border-color: var(--ink-secondary); }
.metric__label {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 10px;
}
.metric__value {
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: clamp(28px, 3.4vw, 40px);
  font-variant-numeric: tabular-nums;
  color: var(--ink);
  line-height: 1;
  letter-spacing: -0.025em;
}
.metric__delta {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 11px;
  color: var(--success);
  margin-top: 6px;
}
.metric__delta.is-flat { color: var(--ink-faint); }

@media (max-width: 720px) {
  .metrics { grid-template-columns: repeat(2, 1fr); }
}

/* Gráfico */
.chart-section {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: clamp(20px, 3vw, 28px);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
}
.chart-section__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.chart-section__title {
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: 18px;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0;
}
.chart-section__sub {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 11px;
  color: var(--ink-mute);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.chart-wrap {
  width: 100%;
  height: 160px;
  position: relative;
}
#chart { width: 100%; height: 100%; display: block; }
#chart .axis { stroke: var(--border); stroke-width: 1; }
#chart .grid { stroke: var(--border-soft); stroke-width: 1; stroke-dasharray: 2 4; }
#chart .area { fill: hsla(82, 52%, 60%, 0.22); }
#chart .line { fill: none; stroke: var(--success); stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
#chart .dot  { fill: var(--ink); }
#chart text { font-family: 'Outfit', sans-serif; font-size: 10px; font-weight: 600; fill: var(--ink-mute); }

/* Filtros */
.filters {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.filters .field-search { flex: 1; min-width: 240px; }
.filters input[type="search"] {
  padding: 12px 16px;
  font-size: 14px;
  font-weight: 500;
}
.filters input[type="date"] {
  background: var(--surface);
  padding: 12px 14px;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
  border-radius: var(--radius);
  width: 156px;
}

/* Lista de leads */
.leads-section__head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 4px;
}
.leads-section__title {
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: 22px;
  letter-spacing: -0.025em;
  margin: 0;
  text-transform: lowercase;
}
.leads-section__count {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 12px;
  color: var(--ink-mute);
}

.leads {
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  overflow: hidden;
}
.lead {
  display: grid;
  grid-template-columns: 1.4fr 1.1fr 1.4fr auto;
  gap: 18px;
  align-items: baseline;
  padding: 16px 22px;
  border-bottom: 1px solid var(--border-soft);
  transition: background var(--t-fast) var(--ease);
}
.lead:last-child { border-bottom: 0; }
.lead:hover { background: var(--bg); }
.lead__nome {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.lead__tel {
  font-family: 'Outfit', sans-serif;
  font-weight: 500;
  font-size: 13px;
  color: var(--ink-soft);
  font-variant-numeric: tabular-nums;
}
.lead__email {
  font-family: 'Outfit', sans-serif;
  font-weight: 400;
  font-size: 13px;
  color: var(--ink-mute);
  word-break: break-all;
}
.lead__when {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 12px;
  color: var(--ink-mute);
  text-align: right;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.empty {
  padding: 60px 12px;
  text-align: center;
  color: var(--ink-mute);
  font-family: 'Outfit', sans-serif;
  font-weight: 500;
  font-size: 15px;
}

.pager {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 16px;
}
.pager__info { font-family: 'Outfit', sans-serif; font-weight: 500; font-size: 12px; color: var(--ink-mute); font-variant-numeric: tabular-nums; }

@media (max-width: 720px) {
  .dash__hero { grid-template-columns: 1fr; gap: 12px; padding: 20px; }
  .dash__hero-num, .dash__hero-num-label { text-align: left; }
  .dash__switcher { display: none; }
  .lead { grid-template-columns: 1fr; gap: 4px; padding: 14px 18px; }
  .lead__when { text-align: left; }
}

/* ---------------- GRID CHART + ORIGEM ---------------- */
.dash__grid-2 {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 12px;
}
@media (max-width: 920px) { .dash__grid-2 { grid-template-columns: 1fr; } }

/* ---------------- ORIGEM (UTM breakdown) ---------------- */
.origem-section {
  padding: clamp(20px, 3vw, 28px);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  display: flex; flex-direction: column; gap: 14px;
}
.origem-section__head {
  display: flex; justify-content: space-between; align-items: center;
  gap: 12px; flex-wrap: wrap;
}
.origem-section__title {
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: 18px;
  letter-spacing: -0.02em;
  margin: 0;
  text-transform: lowercase;
}
.origem-section__dims {
  display: flex; gap: 2px;
  background: var(--bg-soft);
  border-radius: var(--radius-pill);
  padding: 3px;
}
.origem-section__dims button {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 11px;
  padding: 6px 10px;
  border-radius: var(--radius-pill);
  color: var(--ink-mute);
  transition: color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.origem-section__dims button:hover { color: var(--ink); }
.origem-section__dims button.is-active { background: var(--ink); color: var(--bg); }

.origem-list { display: flex; flex-direction: column; gap: 8px; min-height: 200px; }
.origem-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  background: var(--bg);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-align: left;
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
  position: relative;
  overflow: hidden;
}
.origem-row:hover { border-color: var(--ink-soft); background: var(--surface); }
.origem-row.is-active { border-color: var(--ink-soft); background: hsla(214, 60%, 41%, 0.06); }
.origem-row__label {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 13px;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  position: relative; z-index: 1;
}
.origem-row__count {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: 13px;
  color: var(--ink-soft);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  position: relative; z-index: 1;
}
.origem-row__count em {
  font-style: normal;
  font-weight: 500;
  color: var(--ink-mute);
  margin-left: 4px;
  font-size: 11px;
}
.origem-row__bar {
  position: absolute;
  inset: 0;
  background: hsla(82, 52%, 60%, 0.18);
  z-index: 0;
  transform-origin: left center;
  transition: width var(--t-base) var(--ease);
}

/* ---------------- FILTER CHIPS ---------------- */
.filter-chips {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  padding: 12px 16px;
  background: hsla(214, 60%, 41%, 0.06);
  border: 1px dashed var(--ink-secondary);
  border-radius: var(--radius);
}
.filter-chips__label {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 11px;
  color: var(--ink-mute);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-right: 4px;
}
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--ink); color: var(--bg);
  padding: 6px 6px 6px 12px;
  border-radius: var(--radius-pill);
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 12px;
  max-width: 320px;
}
.chip__key { color: hsla(56, 100%, 95%, 0.6); font-weight: 500; }
.chip__val { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.chip__x {
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px;
  background: hsla(56, 100%, 95%, 0.15);
  border-radius: 50%;
  font-size: 14px;
  line-height: 1;
  margin-left: 2px;
  transition: background var(--t-fast) var(--ease);
}
.chip__x:hover { background: hsla(56, 100%, 95%, 0.3); }
.filter-chips__clear {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 12px;
  color: var(--ink-mute);
  padding: 4px 8px;
  border-radius: var(--radius-pill);
}
.filter-chips__clear:hover { color: var(--danger); }

/* ---------------- LEAD ROW: badge fonte ---------------- */
.lead {
  grid-template-columns: 1.4fr 1.1fr 1.4fr auto auto;
  cursor: pointer;
}
.lead__source {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 11px;
  color: var(--ink-soft);
  background: hsla(214, 60%, 41%, 0.08);
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  white-space: nowrap;
  text-transform: lowercase;
}
.lead__source.is-empty { color: var(--ink-faint); background: var(--bg-soft); }
@media (max-width: 720px) {
  .lead { grid-template-columns: 1fr; }
  .lead__source { justify-self: start; }
}

/* ---------------- DRAWER ---------------- */
.drawer-scrim {
  position: fixed; inset: 0;
  background: hsla(213, 100%, 22%, 0.4);
  z-index: 200;
  animation: fadeIn var(--t-base) var(--ease) both;
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.drawer {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(480px, 92vw);
  background: var(--bg);
  border-left: 1px solid var(--border);
  z-index: 201;
  display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform var(--t-base) var(--ease);
  box-shadow: -16px 0 40px -8px rgba(0,0,0,0.12);
}
.drawer.is-open { transform: translateX(0); }
.drawer[aria-hidden="true"] { pointer-events: none; }
.drawer.is-open[aria-hidden="false"] { pointer-events: auto; }
.drawer__head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  padding: 22px 24px 16px;
  border-bottom: 1px solid var(--border);
}
.drawer__title {
  font-family: 'Outfit', sans-serif;
  font-weight: 800;
  font-size: 22px;
  letter-spacing: -0.025em;
  color: var(--ink);
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.drawer__close {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--surface);
  border: 1px solid var(--border);
  font-size: 22px;
  font-weight: 400;
  color: var(--ink-mute);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.drawer__close:hover { color: var(--ink); border-color: var(--ink-soft); }
.drawer__body {
  flex: 1;
  overflow-y: auto;
  padding: 18px 24px 32px;
  display: flex; flex-direction: column; gap: 20px;
}
.drawer__group {
  display: flex; flex-direction: column; gap: 6px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border-soft);
}
.drawer__group:last-child { border-bottom: 0; }
.drawer__group-title {
  font-family: 'Outfit', sans-serif;
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.drawer__kv {
  display: grid; grid-template-columns: 110px 1fr;
  gap: 12px;
  align-items: baseline;
  padding: 6px 0;
}
.drawer__kv dt {
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 12px;
  color: var(--ink-mute);
}
.drawer__kv dd {
  margin: 0;
  font-family: 'Outfit', sans-serif;
  font-weight: 500;
  font-size: 13px;
  color: var(--ink);
  word-break: break-word;
}
.drawer__kv dd.is-empty { color: var(--ink-faint); font-style: italic; }
.drawer__kv dd code {
  font-family: ui-monospace, 'SF Mono', Menlo, monospace;
  font-size: 12px;
  background: var(--bg-soft);
  padding: 2px 6px;
  border-radius: 4px;
}
.drawer__link {
  font-family: 'Outfit', sans-serif;
  font-size: 13px;
  color: var(--ink-soft);
  word-break: break-all;
  text-decoration: underline;
  text-decoration-color: var(--border);
  text-underline-offset: 3px;
  transition: text-decoration-color var(--t-fast) var(--ease);
}
.drawer__link:hover { text-decoration-color: var(--ink-soft); }
.drawer__filter-cta {
  margin-top: 4px;
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  font-size: 12px;
  color: var(--ink-soft);
  padding: 6px 12px;
  background: hsla(214, 60%, 41%, 0.08);
  border-radius: var(--radius-pill);
  align-self: flex-start;
}
.drawer__filter-cta:hover { background: hsla(214, 60%, 41%, 0.16); }

/* ---------------- TOAST ---------------- */
.toast {
  position: fixed;
  left: 50%;
  bottom: max(24px, env(safe-area-inset-bottom));
  transform: translateX(-50%);
  background: var(--ink);
  color: var(--bg);
  padding: 12px 20px;
  border-radius: var(--radius-pill);
  font-size: 13px;
  font-family: 'Outfit', sans-serif;
  font-weight: 600;
  box-shadow: var(--shadow-2);
  z-index: 100;
  animation: toast-in .22s var(--ease) both;
}
@keyframes toast-in { from { opacity: 0; transform: translate(-50%, 6px); } to { opacity: 1; transform: translate(-50%, 0); } }
