/* ════════════════════════════════════════════════════════════════════
   TERRA V4 — Refresh visual (Login + App Shell + Report)
   ────────────────────────────────────────────────────────────────────
   Override aditivo dos tokens existentes (tokens.css + style.css).
   Carregado POR ÚLTIMO em index.html para vencer especificidade.

   Mudanças principais:
   • Paleta: navy #02131A + petroleo #06333C + verde #009579 +
              aqua #00AB92 + lima #61A60E + areia #D6C6A5
   • Tipografia: Poppins (display) + Inter (body) + JetBrains Mono (mono)
   • Tom: editorial-técnico premium (referência: Terra App Shell 4.0)
   ════════════════════════════════════════════════════════════════════ */

:root,
:root[data-site-theme="terra"],
body[data-site-theme="terra"] {
  /* ── Paleta v4 ───────────────────────────────────────────── */
  --v4-navy:        #02131A;
  --v4-navy-2:      #06181f;
  --v4-petroleo:    #06333C;
  --v4-petroleo-2:  #0a4651;
  --v4-verde:       #009579;
  --v4-aqua:        #00AB92;
  --v4-lima:        #61A60E;
  --v4-areia:       #D6C6A5;
  --v4-areia-soft:  #efe6cf;
  --v4-branco:      #FFFFFF;
  --v4-neve:        #F5F7F4;
  --v4-paper:       #FAFBF8;
  --v4-ink:         #1A2B23;
  --v4-ink-soft:    #5b6b65;
  --v4-ink-mute:    #8a948f;
  --v4-line:        #E2E8E3;
  --v4-line-strong: #c8d3cb;
  --v4-danger:      #C0392B;

  /* ── Sobrepor brand tokens existentes para herdar v4 ─────── */
  --brand-night:        var(--v4-navy);
  --brand-deep:         var(--v4-petroleo);
  --brand-forest:       var(--v4-petroleo-2);
  --brand-forest-soft:  var(--v4-aqua);
  --brand-moss:         var(--v4-lima);
  --brand-gold:         var(--v4-verde);
  --brand-gold-strong:  var(--v4-petroleo);
  --brand-gold-soft:    rgba(0, 149, 121, 0.16);
  --brand-cream:        var(--v4-neve);
  --brand-cream-strong: var(--v4-branco);
  --brand-mist:         var(--v4-neve);
  --brand-line:         rgba(2, 19, 26, 0.10);
  --focus-ring:         0 0 0 3px rgba(0, 149, 121, 0.42);

  --top-bar-bg:         #102a52;
  --top-bar-bg-edge:    #071a35;
  --shell-navy-strong:  var(--v4-navy);
  --shell-navy:         var(--v4-navy-2);
  --shell-ink:          var(--v4-ink);
  --shell-gold:         var(--v4-verde);
  --shell-mist:         var(--v4-neve);

  /* ── Fontes v4 ───────────────────────────────────────────── */
  --font-sans:    "Inter", "Manrope", system-ui, sans-serif;
  --font-display: "Poppins", "Inter", system-ui, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  /* ── Auth tokens reaplicados ─────────────────────────────── */
  --auth-ink:          var(--v4-ink);
  --auth-ink-soft:     var(--v4-ink-soft);
  --auth-accent:       var(--v4-verde);
  --auth-accent-strong:var(--v4-petroleo);
  --auth-shadow:       0 28px 80px rgba(2, 19, 26, 0.30);
}

/* ── Body & tipografia base ────────────────────────────────── */
body {
  font-family: "Inter", "Manrope", system-ui, sans-serif !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6,
.auth-card-head h1,
.modal-header h2,
.profile-modal-header h2,
.report-modal-header h2,
.section-title,
.top-nav-tab,
.auth-tab-button,
.layer-card-head h3,
.layer-card-title,
.kpi-label,
.kpi-value {
  font-family: "Poppins", "Inter", system-ui, sans-serif !important;
}

code, kbd, samp, .tooltip-value-mono, .code, .mono,
.report-item-meta code, .report-item-title code,
.layer-count {
  font-family: "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace !important;
}

/* ── Top bar v4: compacta, técnica e menos poluída ─────────── */
.top-bar {
  background:
    linear-gradient(90deg, var(--top-bar-bg-edge) 0%, var(--top-bar-bg) 58%, var(--top-bar-bg-edge) 100%) !important;
  border-bottom: 0 !important;
  padding: 0 16px !important;
  gap: 16px !important;
  box-shadow: none !important;
}
.top-bar-left,
.top-bar-right {
  gap: 14px !important;
}

.top-nav-tabs {
  gap: 2px !important;
  padding: 3px !important;
  border-radius: 999px !important;
  background: rgba(245, 247, 244, 0.06) !important;
  border: 1px solid rgba(245, 247, 244, 0.08) !important;
}

.logo-mark {
  width: 124px !important;
  height: 38px !important;
  border-radius: 8px !important;
  background: rgba(255, 255, 255, 0.97) !important;
  border-color: rgba(245, 247, 244, 0.18) !important;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.42) inset,
    0 10px 22px rgba(2, 19, 26, 0.24) !important;
}

.logo-mark-image {
  width: 100% !important;
  height: 100% !important;
  padding: 2px 8px !important;
  object-fit: contain !important;
  object-position: center !important;
}

.top-nav-tab {
  padding: 8px 13px !important;
  border-radius: 999px !important;
  color: rgba(245, 247, 244, 0.68) !important;
  font-size: 11.5px !important;
  line-height: 1 !important;
}

.top-nav-tab:hover {
  background: rgba(245, 247, 244, 0.08) !important;
  color: var(--v4-neve) !important;
}

.top-nav-tab.is-active,
.top-nav-tab[aria-selected="true"] {
  background: rgba(0, 171, 146, 0.16) !important;
  color: var(--v4-neve) !important;
}

.top-nav-tab.is-active::after,
.top-nav-tab[aria-selected="true"]::after {
  display: none !important;
}

/* ── Botão primário verde (em vez de teal antigo) ────────── */
.primary-btn, .auth-primary-btn, .pri-btn,
.report-modal .modal-footer .btn-primary,
button.report-btn-primary {
  background: var(--v4-verde) !important;
  color: var(--v4-branco) !important;
}
.primary-btn:hover, .auth-primary-btn:hover, .pri-btn:hover {
  background: #00a486 !important;
}

/* ── Cards de fazenda na sidebar: borda aqua quando ativos ── */
.layer-card.is-active,
.filter-group-card.is-active {
  border-color: rgba(0, 171, 146, 0.32) !important;
}

/* ── Chips de filtro v4 (mono + outline aqua quando ativo) ── */
.filter-chip, .chip-control button, button.filter-chip {
  font-family: "JetBrains Mono", ui-monospace, monospace !important;
  font-size: 10.5px !important;
  letter-spacing: 0.02em;
}
.filter-chip.is-selected, .filter-chip[aria-pressed="true"] {
  background: rgba(0, 171, 146, 0.16) !important;
  border-color: rgba(0, 171, 146, 0.36) !important;
  color: var(--v4-aqua) !important;
}

/* ── Search bar (top) v4 ───────────────────────────────────── */
.search-input, .search-group input[type="text"] {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 13px !important;
  line-height: 1.2 !important;
}

.search-group:focus-within {
  border-color: rgba(245, 247, 244, 0.42) !important;
  background: rgba(245, 247, 244, 0.10) !important;
  box-shadow: none !important;
}

.search-group {
  min-height: 34px !important;
  width: min(30vw, 340px) !important;
  border-radius: 8px !important;
  padding: 3px 8px !important;
  gap: 6px !important;
  background: rgba(245, 247, 244, 0.05) !important;
  border: 1px solid rgba(245, 247, 244, 0.14) !important;
  box-shadow: none !important;
  transition: background 140ms ease, border-color 140ms ease;
}

.search-mode-select {
  height: 26px !important;
  max-width: 84px !important;
  border: 0 !important;
  border-radius: 5px !important;
  background: transparent !important;
  color: rgba(245, 247, 244, 0.78) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  padding: 0 6px !important;
  border-right: 1px solid rgba(245, 247, 244, 0.14) !important;
  border-radius: 0 !important;
}

.search-mode-select option {
  color: var(--v4-ink);
  background: var(--v4-neve);
}

.search-input {
  color: var(--v4-neve) !important;
  font-weight: 500 !important;
  width: 100% !important;
}

.search-input::placeholder {
  color: rgba(245, 247, 244, 0.46) !important;
  font-weight: 400 !important;
}

.search-icon {
  color: rgba(245, 247, 244, 0.5) !important;
  font-size: 11px !important;
}

.auth-client-select,
.top-btn,
.top-btn-label {
  font-size: 12px !important;
  letter-spacing: 0.02em !important;
}

.auth-client-select {
  height: 34px !important;
  min-width: 168px !important;
  border-radius: 8px !important;
  background: transparent !important;
  border: 1px solid rgba(245, 247, 244, 0.14) !important;
  color: rgba(245, 247, 244, 0.88) !important;
  padding: 0 10px !important;
  transition: background 140ms ease, border-color 140ms ease;
}

.auth-client-select:hover {
  background: rgba(245, 247, 244, 0.06) !important;
  border-color: rgba(245, 247, 244, 0.28) !important;
}

.auth-client-select option {
  color: var(--v4-ink);
  background: var(--v4-neve);
}

.top-btn-account,
.top-btn-report {
  min-height: 34px !important;
  height: 34px !important;
  border-radius: 8px !important;
  background: transparent !important;
  border: 1px solid transparent !important;
  color: rgba(245, 247, 244, 0.78) !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
  gap: 6px !important;
  transition: background 140ms ease, border-color 140ms ease, color 140ms ease;
}

.top-btn-account i,
.top-btn-report i {
  font-size: 13px !important;
  opacity: 0.85;
}

.top-btn-account:hover,
.top-btn-report:hover {
  background: rgba(245, 247, 244, 0.08) !important;
  border-color: rgba(245, 247, 244, 0.22) !important;
  color: var(--v4-neve) !important;
}

.top-btn-report:disabled,
.top-btn-report[disabled] {
  opacity: 0.42 !important;
  background: transparent !important;
  border-color: transparent !important;
}

#disclaimerModal,
#disclaimerModal.show,


/* ── Map shell: menus retrateis e borda Leaflet ───────────── */
body[data-app-view="map"] .app-shell {
  background:
    linear-gradient(90deg, var(--top-bar-bg-edge) 0%, var(--top-bar-bg) 58%, var(--top-bar-bg-edge) 100%) !important;
}

#map {
  top: var(--top-bar-height) !important;
  border-color: var(--top-bar-bg-edge) !important;
  border-top: 0 !important;
  border-top-left-radius: 16px !important;
  border-top-right-radius: 16px !important;
  border-bottom-left-radius: 16px !important;
  border-bottom-right-radius: 16px !important;
  box-shadow:
    0 0 0 1px rgba(2, 19, 26, 0.42),
    0 18px 46px rgba(2, 19, 26, 0.22) !important;
}

.map-filter-control {
  left: 22px !important;
  right: auto !important;
}

.map-basemap-control {
  right: 22px !important;
}

/* Sidebar (Camadas) — abrir pela esquerda, alinhada ao botão Filtros */
.sidebar {
  left: 22px !important;
  right: auto !important;
  top: calc(var(--top-bar-height) + 18px) !important;
  width: min(332px, calc(100vw - 36px)) !important;
  max-height: calc(100vh - var(--top-bar-height) - 34px) !important;
  padding: 13px 12px !important;
  border-radius: 14px !important;
  background:
    linear-gradient(180deg, rgba(8, 25, 48, 0.88) 0%, rgba(5, 18, 34, 0.90) 100%) !important;
  border: 1px solid rgba(126, 181, 255, 0.18) !important;
  box-shadow: 0 18px 42px rgba(2, 10, 24, 0.34) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
}

@media (min-width: 961px) {
  body.has-filter-sidebar-open .map-filter-control {
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translateY(-4px) scale(0.92) !important;
  }
}

.map-thumbnails-floating {
  background: rgba(2, 19, 26, 0.94) !important;
  border-color: rgba(214, 198, 165, 0.16) !important;
}

.filter-btn-primary {
  background: linear-gradient(180deg, var(--v4-verde) 0%, #007d67 100%) !important;
  color: var(--v4-branco) !important;
  box-shadow: 0 8px 18px rgba(0, 149, 121, 0.22) !important;
}

.filter-btn-primary:hover:not(:disabled) {
  background: linear-gradient(180deg, #00a486 0%, var(--v4-verde) 100%) !important;
}

/* ── Leaflet popups/tooltips: remove azul legado ───────────── */
.leaflet-popup-content-wrapper {
  background: rgba(250, 251, 248, 0.98) !important;
  border: 1px solid rgba(0, 149, 121, 0.28) !important;
  border-left: 4px solid rgba(0, 149, 121, 0.72) !important;
  border-radius: 12px !important;
  box-shadow: 0 18px 42px rgba(2, 19, 26, 0.18) !important;
}

.leaflet-popup-tip {
  background: rgba(250, 251, 248, 0.98) !important;
  border: 1px solid rgba(0, 149, 121, 0.18) !important;
}

.leaflet-popup-content {
  margin: 12px 14px 13px !important;
}

.tooltip-content {
  font-family: "Inter", "Manrope", system-ui, sans-serif !important;
  color: var(--v4-ink) !important;
}

.tooltip-title,
.tooltip-content-public .tooltip-title {
  color: var(--v4-petroleo) !important;
  font-family: "Poppins", "Inter", system-ui, sans-serif !important;
}

.tooltip-content-faz {
  min-width: 286px;
  max-width: 330px;
  color: var(--v4-ink) !important;
}

.tooltip-content-faz .tooltip-title {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin: 0 0 12px !important;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(0, 149, 121, 0.16);
  font-size: 14px !important;
  line-height: 1.28;
}

.tooltip-content-faz .tooltip-title-name {
  min-width: 0;
  font-weight: 700;
  overflow-wrap: anywhere;
}

.tooltip-content-faz .tooltip-source {
  flex: 0 0 auto;
  max-width: 118px;
  padding: 4px 7px;
  border: 1px solid rgba(0, 149, 121, 0.26);
  border-radius: 999px;
  background: rgba(0, 149, 121, 0.09);
  color: var(--v4-petroleo) !important;
  font-size: 9px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.04em;
  text-align: center;
  text-transform: uppercase;
}

.tooltip-content-faz .tooltip-field {
  margin-bottom: 7px;
  font-size: 12px;
}

.tooltip-content-faz .tooltip-label {
  display: inline-flex;
  margin-bottom: 2px;
  font-weight: 700;
}

.tooltip-content-faz .tooltip-value {
  margin-left: 6px;
}

.tooltip-content-faz .tooltip-field--block .tooltip-value {
  margin-left: 0;
}

.tooltip-content-faz .tooltip-breakdown {
  gap: 0;
  overflow: hidden;
  border: 1px solid rgba(0, 149, 121, 0.10);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.48);
}

.tooltip-content-faz .tooltip-subrow {
  align-items: flex-start;
  gap: 12px;
  padding: 5px 7px;
  border-bottom: 1px dashed rgba(0, 149, 121, 0.16) !important;
  line-height: 1.25;
}

.tooltip-content-faz .tooltip-subrow:last-child {
  border-bottom: 0 !important;
}

.tooltip-content-faz .tooltip-subrow > span:first-child {
  flex: 0 0 92px;
  color: var(--v4-ink-soft) !important;
}

.tooltip-content-faz .tooltip-subrow > span:last-child {
  flex: 1 1 auto;
  min-width: 0;
  color: var(--v4-ink) !important;
  font-weight: 500;
  text-align: right;
  overflow-wrap: anywhere;
}

.tooltip-content-faz .tooltip-divider {
  height: 1px;
  margin: 12px 0 10px;
  background: rgba(0, 149, 121, 0.18) !important;
}

.tooltip-content-faz .tooltip-action-note {
  display: block;
  margin-top: 9px;
  padding: 8px 9px;
  border: 1px solid rgba(0, 149, 121, 0.18);
  border-radius: 8px;
  background: rgba(0, 149, 121, 0.07);
  color: var(--v4-petroleo) !important;
  font-size: 11px;
  line-height: 1.35;
}

.tooltip-divider {
  background: rgba(0, 149, 121, 0.18) !important;
}

.tooltip-label,
.tooltip-value-mono {
  color: var(--v4-ink) !important;
}

.tooltip-value,
.tooltip-subrow,
.tooltip-content-public .tooltip-source {
  color: var(--v4-ink-soft) !important;
}

/* ── Avatar account com gradient v4 ────────────────────────── */
.account-avatar, .auth-account-menu-avatar,
.user-settings-avatar, .top-bar-account-avatar {
  background: linear-gradient(135deg, var(--v4-verde), var(--v4-aqua)) !important;
  color: var(--v4-branco) !important;
}

/* ── Badges (ativo / pendente / cancelado) v4 ─────────────── */
.status-pill[data-status="ativo"], .status-pill[data-status="certificada"],
.status-pill[data-status="ok"], .badge.ok {
  background: rgba(0, 149, 121, 0.10) !important;
  color: var(--v4-verde) !important;
}
.status-pill[data-status="pendente"], .status-pill[data-status="em-analise"],
.badge.pend {
  background: #fdf3e3 !important;
  color: #b27518 !important;
}
.status-pill[data-status="cancelado"], .status-pill[data-status="cancelada"],
.badge.warn {
  background: #fbe9e6 !important;
  color: var(--v4-danger) !important;
}

/* ── Aba Análises v4: superfície operacional, sem hero legado ── */
.analyses-view {
  background:
    linear-gradient(180deg, rgba(245, 247, 244, 0.98) 0%, rgba(238, 243, 236, 0.98) 100%) !important;
  padding: 22px 24px 28px !important;
}

.analyses-shell {
  max-width: 1280px !important;
  gap: 12px !important;
}

.analyses-hero,
.analysis-summary-card,
.analysis-card {
  background: rgba(250, 251, 248, 0.96) !important;
  border: 1px solid rgba(2, 19, 26, 0.10) !important;
  border-radius: 10px !important;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.78) inset,
    0 10px 24px rgba(2, 19, 26, 0.07) !important;
}

.analyses-hero {
  align-items: center !important;
  min-height: 0 !important;
  padding: 16px 18px !important;
}

.executive-card::after,
.analysis-summary-card::after {
  display: none !important;
}

.analyses-hero-copy {
  gap: 5px !important;
}

.analyses-kicker,
.analysis-card-kicker {
  width: fit-content;
  background: transparent !important;
  color: var(--v4-verde) !important;
  font-family: "JetBrains Mono", ui-monospace, monospace !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase;
}

.analyses-mode-pill,
.analysis-status-pill,
.analysis-qa-badge,
.analysis-scope-chip {
  border: 1px solid rgba(0, 149, 121, 0.18) !important;
  background: rgba(0, 149, 121, 0.08) !important;
  color: var(--v4-petroleo) !important;
  border-radius: 999px !important;
  font-family: "JetBrains Mono", ui-monospace, monospace !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
}

.analyses-hero h1 {
  color: var(--v4-petroleo) !important;
  font-family: "Poppins", "Inter", system-ui, sans-serif !important;
  font-size: clamp(24px, 2.2vw, 34px) !important;
  font-weight: 700 !important;
  line-height: 1.08 !important;
  letter-spacing: -0.015em !important;
}

.analyses-hero p,
.analysis-empty,
.analysis-qa-head p,
.analysis-qa-hint {
  color: var(--v4-ink-soft) !important;
}

.analyses-hero p {
  max-width: 760px !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}

.analyses-hero-actions {
  gap: 8px !important;
}

.analysis-primary-btn,
.analysis-secondary-btn,
.analysis-ghost-btn,
.analysis-inline-btn {
  min-height: 34px !important;
  border-radius: 8px !important;
  font-family: "Inter", system-ui, sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  box-shadow: none !important;
}

.analysis-primary-btn {
  background: linear-gradient(180deg, var(--v4-verde) 0%, #007d67 100%) !important;
  color: var(--v4-branco) !important;
}

.analysis-primary-btn:disabled,
.analysis-secondary-btn:disabled,
.analysis-ghost-btn:disabled,
.analysis-inline-btn:disabled {
  border-color: rgba(2, 19, 26, 0.08) !important;
  background: rgba(255, 255, 255, 0.58) !important;
  color: rgba(91, 107, 101, 0.76) !important;
  cursor: not-allowed !important;
  opacity: 1 !important;
  box-shadow: none !important;
}

.analysis-secondary-btn,
.analysis-ghost-btn,
.analysis-inline-btn {
  border: 1px solid rgba(2, 19, 26, 0.10) !important;
  background: rgba(255, 255, 255, 0.72) !important;
  color: var(--v4-petroleo) !important;
}

.analysis-inline-btn-danger {
  border-color: rgba(192, 57, 43, 0.18) !important;
  background: rgba(192, 57, 43, 0.08) !important;
  color: var(--v4-danger) !important;
}

.analysis-summary-card {
  min-height: 106px !important;
  padding: 14px 16px !important;
}

.analysis-summary-card strong,
.analysis-detail-item strong,
.analysis-signal-card strong,
.analysis-public-item strong,
.analysis-qa-result strong {
  color: var(--v4-ink-mute) !important;
  font-family: "JetBrains Mono", ui-monospace, monospace !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
}

.analysis-summary-card span {
  margin-top: 8px !important;
  color: var(--v4-petroleo) !important;
  font-family: "Poppins", "Inter", system-ui, sans-serif !important;
  font-size: clamp(20px, 1.8vw, 26px) !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
}

.analysis-summary-card small {
  color: var(--v4-ink-soft) !important;
  font-size: 11.5px !important;
}

.analysis-card {
  padding: 16px !important;
}

.analysis-card h3,
.analysis-insight-grid h4 {
  color: var(--v4-petroleo) !important;
  font-family: "Poppins", "Inter", system-ui, sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
}

.analysis-card h3 {
  font-size: 16px !important;
}

.analysis-insight-grid h4 {
  font-size: 13px !important;
}

.analysis-signal-card,
.analysis-public-item,
.analysis-list-item,
.analysis-qa-result,
.analysis-qa-input {
  background: rgba(255, 255, 255, 0.62) !important;
  border: 1px solid rgba(2, 19, 26, 0.08) !important;
  border-radius: 8px !important;
  box-shadow: none !important;
}

.analysis-signal-card,
.analysis-public-item {
  padding: 12px !important;
}

.analysis-signal-card span,
.analysis-public-item span,
.analysis-detail-item span,
.analysis-list-item-head strong,
.analysis-list-item-area {
  color: var(--v4-petroleo) !important;
}

.analysis-signal-card small,
.analysis-public-item small,
.analysis-list-item-head span,
.analysis-list-item-meta span,
.analysis-breakdown-row span,
.analysis-qa-result small {
  color: var(--v4-ink-soft) !important;
}

.analysis-breakdown-bar {
  height: 6px !important;
  background: rgba(2, 19, 26, 0.08) !important;
}

.analysis-breakdown-bar span {
  background: linear-gradient(90deg, var(--v4-verde) 0%, var(--v4-aqua) 100%) !important;
}

.analysis-list-item.is-selected {
  border-color: rgba(0, 171, 146, 0.34) !important;
  box-shadow: inset 3px 0 0 var(--v4-aqua) !important;
}

.analysis-mini-map-block {
  display: grid;
  gap: 8px;
  margin: 12px 0 14px;
}

.analysis-mini-map-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.analysis-mini-map-head strong,
.analysis-mini-map-head span {
  font-family: "JetBrains Mono", ui-monospace, monospace !important;
  font-size: 10px !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase;
}

.analysis-mini-map-head strong {
  color: var(--v4-verde) !important;
}

.analysis-mini-map-head span {
  color: var(--v4-ink-mute) !important;
}

.analysis-mini-map {
  width: 100%;
  height: 180px;
  overflow: hidden;
  border: 1px solid rgba(2, 19, 26, 0.10);
  border-radius: 8px;
  background: #e8eee8;
}

.analysis-mini-map .leaflet-control-container {
  display: none;
}

.analysis-qa-input {
  min-height: 78px !important;
}

@media (max-width: 960px) {
  .analyses-view {
    padding: 14px 12px 18px !important;
  }
}

@media (max-width: 768px) {
  .top-bar {
    padding: 8px 12px !important;
    gap: 8px !important;
  }

  .top-bar-left,
  .top-bar-right {
    gap: 8px !important;
  }

  .search-group {
    width: 100% !important;
  }

  .logo-mark {
    width: 124px !important;
    height: 40px !important;
  }
}

@media (max-width: 560px) {
  .top-bar {
    padding: 6px 10px !important;
    gap: 5px !important;
  }

  .top-bar-left,
  .top-bar-right {
    gap: 6px !important;
  }

  .logo-mark {
    width: 102px !important;
    height: 32px !important;
  }

  .logo-mark-image {
    padding: 1px 6px !important;
  }

  .top-nav-tabs {
    gap: 1px !important;
  }

  .top-nav-tab {
    padding: 4px 5px !important;
    font-size: 9px !important;
  }

  .search-group {
    min-height: 36px !important;
    width: 100% !important;
    padding: 3px 8px !important;
  }

  .search-mode-select {
    max-width: 104px !important;
    font-size: 11px !important;
    padding-right: 6px !important;
  }

  .search-input {
    font-size: 12px !important;
    padding: 5px 6px !important;
  }

  .auth-client-select {
    height: 32px !important;
  }

  .top-btn-account,
  .top-btn-report {
    width: 32px !important;
    min-width: 32px !important;
    height: 32px !important;
    min-height: 32px !important;
    padding: 0 !important;
  }
}

/* ════════════════════════════════════════════════════════════════════
   UNIFIED BUTTON SYSTEM — paleta, tipografia e estados padronizados
   ════════════════════════════════════════════════════════════════════ */
:root {
  --ui-font: "Inter", system-ui, -apple-system, sans-serif;
  --ui-blue-bg: rgba(255, 255, 255, 0.04);
  --ui-blue-bg-hover: rgba(255, 255, 255, 0.10);
  --ui-blue-border: rgba(255, 255, 255, 0.14);
  --ui-blue-border-hover: rgba(255, 255, 255, 0.28);
  --ui-blue-accent: #5b8cd9;
  --ui-blue-accent-strong: #4a7bc9;
  --ui-blue-accent-soft: rgba(91, 140, 217, 0.18);
  --ui-blue-accent-border: rgba(91, 140, 217, 0.45);
  --ui-text: rgba(245, 247, 244, 0.82);
  --ui-text-strong: #ffffff;
  --ui-text-mute: rgba(245, 247, 244, 0.50);
  --ui-text-dark: #17324a;
  --ui-radius: 8px;
  --ui-h: 34px;
  --ui-h-sm: 30px;
  --ui-transition: background 140ms ease, border-color 140ms ease, color 140ms ease, box-shadow 140ms ease;
}

/* Tipografia base — todos os controles usam Inter */
.top-bar,
.top-bar button,
.top-bar select,
.top-bar input,
.top-nav-tab,
.top-btn,
.top-btn-label,
.auth-client-select,
.search-mode-select,
.search-input,
.map-filter-toggle,
.map-basemap-control summary,
.control-btn,
.leaflet-upload-launch,
.map-thumb,
.section-toggle,
.section-action-btn,
.uf-chip-button,
.layer-toggle .layer-title-text,
.layer-section-label {
  font-family: var(--ui-font) !important;
  letter-spacing: 0.015em !important;
}

/* ─── Topbar tabs (MAPA / ANÁLISES) — match leaflet glass ─── */
.top-nav-tabs {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  gap: 10px !important;
}
.top-nav-tab {
  min-width: 78px !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: rgba(245, 247, 244, 0.88) !important;
  background: rgba(15, 28, 52, 0.96) !important;
  border: 1px solid rgba(91, 140, 217, 0.58) !important;
  border-radius: var(--ui-radius) !important;
  height: 40px !important;
  padding: 0 18px !important;
  box-shadow:
    0 8px 20px rgba(2, 19, 26, 0.44),
    inset 0 1px 0 rgba(255, 255, 255, 0.06) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: var(--ui-transition), transform 140ms ease;
}
.top-nav-tab:hover {
  color: var(--ui-text-strong) !important;
  background: rgba(31, 62, 116, 0.98) !important;
  border-color: rgba(105, 158, 239, 0.82) !important;
  transform: translateY(-1px);
}
.top-nav-tab.is-active,
.top-nav-tab[aria-selected="true"] {
  color: var(--ui-text-strong) !important;
  background: linear-gradient(180deg, rgba(43, 84, 152, 0.98) 0%, rgba(23, 55, 108, 0.98) 100%) !important;
  border-color: rgba(126, 181, 255, 0.9) !important;
  box-shadow:
    0 10px 24px rgba(2, 19, 26, 0.52),
    0 0 0 2px rgba(91, 140, 217, 0.18),
    inset 0 -2px 0 0 #18dec4 !important;
}

/* ─── Search bar — match leaflet glass ─────────────────────── */
.search-group {
  width: 280px !important;
  height: 34px !important;
  padding: 0 10px !important;
  gap: 6px !important;
  border-radius: var(--ui-radius) !important;
  background: rgba(15, 28, 52, 0.58) !important;
  border: 1px solid rgba(91, 140, 217, 0.24) !important;
  box-shadow: none !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: var(--ui-transition);
}
.search-group:hover {
  background: rgba(15, 28, 52, 0.72) !important;
  border-color: rgba(91, 140, 217, 0.42) !important;
}
.search-group:focus-within {
  border-color: var(--ui-blue-accent) !important;
  background: rgba(15, 28, 52, 0.82) !important;
  box-shadow: 0 0 0 2px rgba(91, 140, 217, 0.16) !important;
}
.search-icon {
  width: 14px !important;
  font-size: 12px !important;
  color: rgba(245, 247, 244, 0.42) !important;
}
.search-mode-select {
  width: 74px !important;
  max-width: 74px !important;
  height: 32px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  color: rgba(245, 247, 244, 0.72) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  border-right: 1px solid rgba(245, 247, 244, 0.12) !important;
  background: transparent !important;
  padding: 0 6px 0 0 !important;
}
.search-input,
.search-group .search-input,
.search-group input.search-input[type="text"] {
  width: 1px !important;
  flex: 1 1 auto !important;
  height: 32px !important;
  padding: 0 0 0 4px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  color: var(--ui-text-strong) !important;
}
.search-input::placeholder {
  color: var(--ui-text-mute) !important;
  font-weight: 400 !important;
}
.search-icon { color: var(--ui-text-mute) !important; }

/* ─── Selects e botões da topbar (Cliente, Conta, PDF) — glass */
.auth-client-select,
.top-btn,
.top-btn-account,
.top-btn-report {
  font-family: var(--ui-font) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  height: 40px !important;
  min-height: 40px !important;
  border-radius: var(--ui-radius) !important;
  background: rgba(15, 28, 52, 0.78) !important;
  border: 1px solid rgba(91, 140, 217, 0.35) !important;
  color: var(--ui-text) !important;
  padding: 0 14px !important;
  gap: 8px !important;
  box-shadow: 0 6px 18px rgba(2, 19, 26, 0.38) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: var(--ui-transition);
}
.auth-client-select:hover,
.top-btn:hover,
.top-btn-account:hover,
.top-btn-report:not(:disabled):hover {
  background: rgba(20, 38, 64, 0.92) !important;
  border-color: rgba(91, 140, 217, 0.55) !important;
  color: var(--ui-text-strong) !important;
}
.top-btn-report:disabled,
.top-btn-report[disabled] {
  opacity: 0.38 !important;
  background: transparent !important;
  border-color: transparent !important;
  cursor: not-allowed;
}

/* Cliente + conta em um unico controle segmentado */
.top-bar-buttons {
  gap: 0 !important;
}

.auth-userbar {
  gap: 0 !important;
}

.top-bar-action-group {
  gap: 8px !important;
}

.auth-userbar:not([hidden]) + .top-bar-action-group .account-menu {
  margin-left: -1px !important;
}

.auth-userbar:not([hidden]) .auth-client-select {
  border-top-right-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
  border-right-color: rgba(245, 247, 244, 0.10) !important;
}

.auth-userbar:not([hidden]) + .top-bar-action-group .top-btn-account {
  width: 40px !important;
  min-width: 40px !important;
  border-top-left-radius: 0 !important;
  border-bottom-left-radius: 0 !important;
  padding: 0 !important;
}

.auth-userbar:not([hidden]) + .top-bar-action-group .top-btn-report {
  margin-left: 8px !important;
}

.top-btn i,
.top-btn-account i,
.top-btn-report i {
  font-size: 12px !important;
  opacity: 0.85;
}

.top-btn-account {
  width: 40px !important;
  min-width: 40px !important;
  padding: 0 !important;
}

.top-btn-account .top-btn-label,
.top-btn-account .account-menu-caret {
  display: none !important;
}

.account-menu-panel {
  min-width: 220px !important;
  padding: 8px !important;
  border-radius: 12px !important;
  background: rgba(7, 22, 43, 0.96) !important;
  border: 1px solid rgba(91, 140, 217, 0.26) !important;
  box-shadow: 0 18px 46px rgba(0, 0, 0, 0.42) !important;
}

.account-menu-identity {
  padding: 10px 10px 8px !important;
  min-height: auto !important;
}

.account-menu-identity-text {
  display: block !important;
}

.account-menu-identity-text strong {
  display: block !important;
  color: var(--ui-text-strong) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.account-menu-divider {
  margin: 6px 0 !important;
  background: rgba(91, 140, 217, 0.18) !important;
}

.account-menu-item {
  min-height: 34px !important;
  border-radius: 8px !important;
  color: rgba(245, 247, 244, 0.84) !important;
}

.account-menu-item:hover {
  background: rgba(91, 140, 217, 0.12) !important;
  color: var(--ui-text-strong) !important;
}

.account-menu-theme {
  gap: 7px !important;
  padding: 8px 2px !important;
}

.account-menu-theme-label {
  color: rgba(245, 247, 244, 0.54) !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: 0.08em !important;
  padding: 0 6px !important;
  text-transform: uppercase !important;
}

.account-menu-theme-options {
  gap: 5px !important;
}

.account-menu-theme-opt {
  min-height: 30px !important;
  border-radius: 8px !important;
  background: rgba(15, 28, 52, 0.72) !important;
  border-color: rgba(91, 140, 217, 0.22) !important;
  color: rgba(245, 247, 244, 0.76) !important;
}

.account-menu-theme-opt:hover,
.account-menu-theme-opt.is-active,
.account-menu-theme-opt[aria-checked="true"] {
  background: rgba(42, 94, 160, 0.42) !important;
  border-color: rgba(126, 181, 255, 0.58) !important;
  color: var(--ui-text-strong) !important;
}

/* Modal de upload: evita corte em telas menores e mantem a acao visivel */
.upload-modal-content {
  width: min(860px, calc(100vw - 40px)) !important;
  max-width: none !important;
  max-height: calc(100vh - 48px) !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  border-radius: 16px !important;
  background: #f7f9fc !important;
}

.upload-modal-header {
  flex: 0 0 auto !important;
  padding: 18px 24px !important;
  border-radius: 16px 16px 0 0 !important;
  background: linear-gradient(135deg, #102a52 0%, #173f62 58%, #168b84 100%) !important;
}

.upload-modal-header h2 {
  font-size: 22px !important;
}

.upload-modal-body {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  padding: 22px 24px !important;
  gap: 16px !important;
  background: #f7f9fc !important;
}

.upload-workbench {
  display: block !important;
}

.upload-kicker {
  background: transparent !important;
  color: #0d6f83 !important;
  display: inline-block !important;
  font-size: 10px !important;
  font-weight: 850 !important;
  letter-spacing: 0.12em !important;
  margin-bottom: 7px !important;
  padding: 0 !important;
  text-transform: uppercase !important;
}

.upload-dropzone {
  align-items: center !important;
  background: #ffffff !important;
  border: 1.5px dashed rgba(16, 42, 82, 0.22) !important;
  border-radius: 14px !important;
  box-shadow: 0 10px 24px rgba(16, 42, 82, 0.06) !important;
  min-height: 172px !important;
  padding: 20px !important;
}

.upload-dropzone:hover,
.upload-dropzone:focus-visible,
.upload-dropzone.is-dragover {
  border-color: rgba(24, 139, 132, 0.70) !important;
  box-shadow: 0 16px 32px rgba(16, 42, 82, 0.10) !important;
}

.upload-dropzone.is-processing {
  opacity: 0.82 !important;
  pointer-events: none !important;
}

.upload-dropzone-icon {
  background: linear-gradient(135deg, #102a52 0%, #168b84 100%) !important;
  width: 56px !important;
  height: 56px !important;
  border-radius: 14px !important;
  font-size: 20px !important;
}

.upload-dropzone-copy strong {
  color: #102a52 !important;
  font-size: 18px !important;
  letter-spacing: -0.01em !important;
}

.upload-dropzone-copy p {
  color: #5e7283 !important;
  font-size: 13px !important;
  margin-top: 5px !important;
}

.upload-analysis-preview {
  min-height: 86px !important;
}

.upload-analysis-preview .report-empty {
  align-items: center !important;
  background: #ffffff !important;
  border: 1px solid rgba(16, 42, 82, 0.08) !important;
  border-radius: 14px !important;
  flex-direction: row !important;
  justify-content: flex-start !important;
  padding: 16px !important;
  text-align: left !important;
}

.upload-analysis-preview .report-empty i {
  align-items: center !important;
  background: rgba(16, 42, 82, 0.06) !important;
  border-radius: 12px !important;
  color: #168b84 !important;
  display: inline-flex !important;
  flex: 0 0 auto !important;
  font-size: 20px !important;
  height: 46px !important;
  justify-content: center !important;
  width: 46px !important;
}

.upload-analysis-preview .report-empty h3 {
  font-size: 15px !important;
  margin-bottom: 4px !important;
}

.upload-empty-state--processing i,
.upload-empty-state--processing h3 {
  color: #0d6f83 !important;
}

.upload-empty-state--error {
  border-color: rgba(190, 61, 61, 0.20) !important;
}

.upload-empty-state--error i,
.upload-empty-state--error h3 {
  color: #b53d3d !important;
}

.upload-modal-content .modal-footer {
  flex: 0 0 auto !important;
  background: #ffffff !important;
  border-top: 1px solid rgba(16, 42, 82, 0.08) !important;
  padding: 14px 24px !important;
  border-radius: 0 0 16px 16px !important;
}

.upload-modal-content .modal-footer .btn {
  border-radius: 9px !important;
  min-height: 38px !important;
}

.upload-modal-content .modal-footer .btn-primary {
  background: #168b84 !important;
  color: #ffffff !important;
}

.upload-modal-content .modal-footer .btn-secondary {
  background: #eef3f8 !important;
  color: #33485d !important;
}

.upload-modal-content .modal-footer .btn:disabled {
  opacity: 0.45 !important;
  cursor: not-allowed !important;
}

.upload-report-card {
  border-radius: 14px !important;
  box-shadow: none !important;
}

/* ─── Floating controls sobre o mapa (Filtros, Base, Zoom, FS) */
.map-filter-toggle,
.map-basemap-control summary,
#baseMapPicker > summary,
.control-btn,
#zoomIn,
#zoomOut,
#fullscreen {
  font-family: var(--ui-font) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  padding: 0 !important;
  border-radius: var(--ui-radius) !important;
  background: rgba(15, 28, 52, 0.78) !important;
  border: 1px solid rgba(91, 140, 217, 0.35) !important;
  color: var(--ui-text-strong) !important;
  box-shadow: 0 6px 18px rgba(2, 19, 26, 0.38) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: var(--ui-transition);
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  gap: 0 !important;
  list-style: none !important;
  appearance: none !important;
  -webkit-appearance: none !important;
}

#baseMapPicker > summary::-webkit-details-marker {
  display: none !important;
}

.map-filter-toggle:hover,
.map-filter-toggle[aria-expanded="true"],
.map-basemap-control summary:hover,
.map-basemap-control details[open] summary,
#baseMapPicker[open] > summary,
#baseMapPicker > summary:hover,
.control-btn:hover,
#zoomIn:hover,
#zoomOut:hover,
#fullscreen:hover {
  background: var(--ui-blue-accent-strong) !important;
  border-color: var(--ui-blue-accent) !important;
  color: var(--ui-text-strong) !important;
}
.map-filter-toggle i,
.map-basemap-control summary i,
#baseMapPicker > summary i,
.control-btn i,
#zoomIn i,
#zoomOut i,
#fullscreen i {
  color: #18dec4 !important;
  display: block !important;
  font-size: 14px !important;
  line-height: 1 !important;
  margin: 0 !important;
}
.map-filter-toggle span,
.map-basemap-control summary span,
#baseMapPicker > summary span { display: none !important; }

/* ─── Upload vetorial no mapa ──────────────────────────────── */
.leaflet-upload-launch {
  width: auto !important;
  min-width: 126px !important;
  max-width: 150px !important;
  height: 40px !important;
  min-height: 40px !important;
  max-height: 40px !important;
  padding: 0 12px 0 0 !important;
  overflow: hidden !important;
  border-radius: var(--ui-radius) !important;
  background: rgba(15, 28, 52, 0.78) !important;
  border: 1px solid rgba(91, 140, 217, 0.35) !important;
  color: var(--ui-text-strong) !important;
  box-shadow: 0 6px 18px rgba(2, 19, 26, 0.38) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  gap: 8px !important;
  transition: var(--ui-transition), transform 140ms ease !important;
  align-items: center !important;
  justify-content: center !important;
}

.leaflet-upload-launch:hover,
.leaflet-upload-launch:focus-visible {
  background: var(--ui-blue-accent-strong) !important;
  border-color: var(--ui-blue-accent) !important;
  color: var(--ui-text-strong) !important;
  transform: translateY(-1px) !important;
}

.leaflet-upload-launch__icon {
  width: 40px !important;
  height: 40px !important;
  border-radius: var(--ui-radius) !important;
  background: transparent !important;
  color: #18dec4 !important;
  font-size: 14px !important;
  flex: 0 0 40px !important;
}

.leaflet-upload-launch__label {
  display: flex !important;
  min-width: 0 !important;
}

.leaflet-upload-launch__title {
  color: var(--ui-text-strong) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}

.leaflet-upload-launch__hint {
  display: none !important;
}

.leaflet-upload-launch__status {
  display: none !important;
}

.leaflet-upload-launch.has-upload {
  border-color: var(--ui-blue-accent-border) !important;
}

.leaflet-upload-launch.has-upload .leaflet-upload-launch__status {
  background: #18dec4 !important;
}

.leaflet-upload-launch.has-error {
  border-color: rgba(192, 57, 43, 0.6) !important;
}

.leaflet-upload-launch.has-error .leaflet-upload-launch__icon,
.leaflet-upload-launch.has-error .leaflet-upload-launch__status {
  color: #ffb4aa !important;
  background: rgba(192, 57, 43, 0.82) !important;
}

/* ─── Basemap thumbnails (Ruas, Claro, Escuro, Satélite...) ─ */
.map-thumb {
  font-family: var(--ui-font) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  border-radius: var(--ui-radius) !important;
  background: var(--ui-blue-bg) !important;
  border: 1px solid var(--ui-blue-border) !important;
  color: var(--ui-text) !important;
  padding: 8px 10px !important;
  gap: 8px !important;
  transition: var(--ui-transition);
}
.map-thumb:hover {
  background: var(--ui-blue-bg-hover) !important;
  border-color: var(--ui-blue-border-hover) !important;
  color: var(--ui-text-strong) !important;
}
.map-thumb.active,
.map-thumb[aria-pressed="true"] {
  background: var(--ui-blue-accent-soft) !important;
  border-color: var(--ui-blue-accent-border) !important;
  color: var(--ui-text-strong) !important;
}
.map-thumb i { font-size: 13px !important; opacity: 0.85; }

/* ─── Sidebar — Camadas / Limpar / cards / chips ──────────── */
.section-header {
  padding: 0 4px 10px !important;
  border-bottom: 1px solid rgba(126, 181, 255, 0.12) !important;
  margin-bottom: 8px !important;
}

.section-toggle {
  font-family: var(--ui-font) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--ui-text-strong) !important;
  background: transparent !important;
  border: 0 !important;
}

.section-toggle::before,
.section-toggle i {
  display: none !important;
}

.section-action-btn {
  font-family: var(--ui-font) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: var(--ui-blue-accent) !important;
  background: transparent !important;
  border: 0 !important;
  padding: 4px 8px !important;
  border-radius: 6px !important;
  transition: var(--ui-transition);
}
.section-action-btn:hover {
  color: var(--ui-text-strong) !important;
  background: var(--ui-blue-accent-soft) !important;
}

.section-close-btn {
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
  border: 1px solid rgba(126, 181, 255, 0.18) !important;
  border-radius: 8px !important;
  background: rgba(15, 28, 52, 0.58) !important;
  color: rgba(245, 247, 244, 0.72) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  transition: var(--ui-transition);
}

.section-close-btn:hover,
.section-close-btn:focus-visible {
  background: rgba(42, 94, 160, 0.42) !important;
  border-color: rgba(126, 181, 255, 0.48) !important;
  color: var(--ui-text-strong) !important;
}

.section-close-btn i {
  font-size: 11px !important;
}

.layer-stack {
  gap: 0 !important;
}

.layer-flow-steps {
  display: none !important;
}

.layer-section-label {
  display: none !important;
}

.layer-card {
  border-radius: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.layer-card + .layer-card,
.layer-card + .layer-section-label,
.layer-section-label + .public-layer-actions,
.public-layer-actions {
  border-top: 1px solid rgba(126, 181, 255, 0.10) !important;
}

.layer-card.open,
.layer-card.active,
.layer-card.is-locked {
  background: transparent !important;
  box-shadow: none !important;
}

.layer-card.open::before,
.layer-card.is-locked::before {
  display: none !important;
}

.layer-card-head {
  padding: 3px 0 0 !important;
}

.layer-toggle {
  min-height: 32px !important;
  padding: 4px 6px !important;
  border-radius: 8px !important;
}

.layer-title-text {
  font-size: 13px !important;
  font-weight: 750 !important;
}

.layer-summary {
  padding: 0 6px 6px 32px !important;
  font-size: 9px !important;
  color: rgba(245, 247, 244, 0.44) !important;
}

.layer-filter-panel {
  margin: 0 6px 9px 32px !important;
}

.filter-field {
  gap: 6px !important;
}

.filter-field-uf-grid {
  gap: 0 !important;
}

.filter-field label {
  display: none !important;
}

/* Chips UF (AC, AL, ...) — grade fixa sem busca interna */
#estadoFilterUf.filter-chip-group,
#estadoFilterUf.uf-square-grid {
  display: grid !important;
  grid-template-columns: repeat(7, 32px) !important;
  gap: 7px 6px !important;
  justify-content: space-between !important;
  max-height: none !important;
  overflow: visible !important;
  padding: 1px 0 0 !important;
  scrollbar-width: auto !important;
}

#estadoFilterUf .filter-chip {
  aspect-ratio: 1 / 1 !important;
  height: 32px !important;
  min-height: 32px !important;
  width: 32px !important;
}

.filter-chip {
  font-family: var(--ui-font) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  height: 28px !important;
  min-height: 28px !important;
  padding: 0 !important;
  border-radius: 6px !important;
  background: rgba(15, 28, 52, 0.78) !important;
  border: 1px solid rgba(91, 140, 217, 0.22) !important;
  color: var(--ui-text) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: var(--ui-transition);
}
.filter-chip:hover {
  background: rgba(20, 38, 64, 0.92) !important;
  border-color: rgba(91, 140, 217, 0.55) !important;
  color: var(--ui-text-strong) !important;
}
.filter-chip.is-selected,
.filter-chip[aria-pressed="true"] {
  background: var(--ui-blue-accent-strong) !important;
  border-color: var(--ui-blue-accent) !important;
  color: var(--ui-text-strong) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14) !important;
}
.filter-chip.is-selected::before {
  display: none !important;
}

/* Inputs compactos usados nos demais filtros */
.filter-input,
.filter-input-compact {
  font-family: var(--ui-font) !important;
  font-size: 12px !important;
  height: 34px !important;
  border-radius: var(--ui-radius) !important;
  background: rgba(15, 28, 52, 0.78) !important;
  border: 1px solid rgba(91, 140, 217, 0.30) !important;
  color: var(--ui-text-strong) !important;
  padding: 0 12px !important;
  transition: var(--ui-transition);
}
.filter-input:focus,
.filter-input-compact:focus {
  outline: none !important;
  border-color: var(--ui-blue-accent) !important;
  box-shadow: 0 0 0 3px rgba(91, 140, 217, 0.16) !important;
}
.filter-input::placeholder,
.filter-input-compact::placeholder {
  color: var(--ui-text-mute) !important;
}

.filter-inline-actions {
  margin-top: 4px !important;
}

.filter-link-btn {
  color: rgba(245, 247, 244, 0.48) !important;
  font-size: 10px !important;
  font-weight: 650 !important;
  text-transform: none !important;
}

/* CTA "Mostrar CAR e SIGEF" e botões primários da sidebar */
.filter-btn-primary,
.section button[class*="primary"],
.section .btn-primary,
.section .layer-action-btn,
.layer-action-primary,
.public-layer-show-all {
  font-family: var(--ui-font) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.015em !important;
  width: 100% !important;
  height: 36px !important;
  min-height: 36px !important;
  border-radius: var(--ui-radius) !important;
  background: var(--ui-blue-accent-strong) !important;
  border: 1px solid var(--ui-blue-accent) !important;
  color: var(--ui-text-strong) !important;
  padding: 0 14px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  white-space: nowrap !important;
  text-overflow: ellipsis !important;
  overflow: hidden !important;
  cursor: pointer;
  transition: var(--ui-transition);
}
.filter-btn-primary > span,
.public-layer-show-all > span {
  display: inline-block !important;
  white-space: nowrap !important;
  position: static !important;
  background: transparent !important;
  color: inherit !important;
  font: inherit !important;
  padding: 0 !important;
}
.filter-btn-primary > i,
.public-layer-show-all > i {
  font-size: 13px !important;
}
.filter-btn-primary:hover:not(:disabled),
.public-layer-show-all:hover:not(:disabled) {
  background: var(--ui-blue-accent) !important;
}
.filter-btn-primary:disabled,
.public-layer-show-all:disabled {
  opacity: 0.42 !important;
  cursor: not-allowed !important;
  filter: saturate(0.72) !important;
}
.public-layer-actions {
  display: block !important;
  padding: 12px 6px 8px 32px !important;
}
.filter-btn-primary,
.public-layer-show-all {
  flex: 1 1 100% !important;
}

.sidebar-attribution {
  color: rgba(245, 247, 244, 0.20) !important;
  font-size: 9px !important;
  margin: 8px 6px 0 32px !important;
}

/* Modal de tipo de relatorio */
#reportModal {
  background:
    radial-gradient(circle at 50% 35%, rgba(0, 171, 146, 0.18), transparent 34%),
    rgba(2, 19, 26, 0.68) !important;
  backdrop-filter: blur(10px) saturate(1.05) !important;
  -webkit-backdrop-filter: blur(10px) saturate(1.05) !important;
}

#reportModal .report-modal-content {
  width: min(760px, calc(100vw - 32px)) !important;
  max-height: min(88vh, 560px) !important;
  border: 1px solid rgba(245, 247, 244, 0.72) !important;
  border-radius: 16px !important;
  background: #f8faf7 !important;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.88) inset,
    0 28px 80px rgba(2, 19, 26, 0.34),
    0 10px 24px rgba(2, 19, 26, 0.18) !important;
}

#reportModal .report-modal-header {
  padding: 22px 24px 18px !important;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(241, 247, 243, 0.98) 100%) !important;
  border-bottom: 1px solid rgba(2, 19, 26, 0.08) !important;
  color: var(--v4-ink) !important;
}

#reportModal .report-modal-heading {
  gap: 14px !important;
}

#reportModal .report-modal-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 12px !important;
  background: rgba(0, 149, 121, 0.12) !important;
  color: var(--v4-verde) !important;
  font-size: 18px !important;
  opacity: 1 !important;
  flex: 0 0 auto !important;
}

#reportModal .report-modal-header h2 {
  color: var(--v4-ink) !important;
  font-size: 21px !important;
  line-height: 1.1 !important;
  letter-spacing: 0 !important;
}

#reportModal .report-modal-header p {
  max-width: none !important;
  margin-top: 4px !important;
  color: var(--v4-ink-soft) !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
}

#reportModal .report-modal-header .close {
  width: 36px !important;
  height: 36px !important;
  border-radius: 10px !important;
  color: rgba(26, 43, 35, 0.56) !important;
  font-size: 24px !important;
  line-height: 1 !important;
}

#reportModal .report-modal-header .close:hover {
  background: rgba(2, 19, 26, 0.06) !important;
  color: var(--v4-ink) !important;
}

#reportModal .report-modal-body {
  padding: 20px 24px 22px !important;
  background: #f8faf7 !important;
}

#reportModal .report-type-selector {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 12px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
}

#reportModal .report-type-option {
  position: relative !important;
  display: grid !important;
  grid-template-rows: auto 1fr auto !important;
  align-items: start !important;
  gap: 14px !important;
  min-height: 154px !important;
  padding: 16px !important;
  border: 1px solid rgba(2, 19, 26, 0.10) !important;
  border-radius: 14px !important;
  background: #ffffff !important;
  color: var(--v4-ink) !important;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.95) inset,
    0 10px 24px rgba(2, 19, 26, 0.055) !important;
  transition:
    transform 140ms ease,
    border-color 140ms ease,
    box-shadow 140ms ease,
    background 140ms ease !important;
}

#reportModal .report-type-option:hover {
  transform: translateY(-2px) !important;
  border-color: rgba(0, 149, 121, 0.32) !important;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.95) inset,
    0 16px 34px rgba(2, 19, 26, 0.10) !important;
}

#reportModal .report-type-option:has(input:checked) {
  border-color: rgba(0, 149, 121, 0.78) !important;
  background:
    linear-gradient(180deg, rgba(0, 149, 121, 0.10), rgba(255, 255, 255, 0.98) 58%) !important;
  box-shadow:
    0 0 0 3px rgba(0, 149, 121, 0.14),
    0 18px 38px rgba(2, 19, 26, 0.12) !important;
}

#reportModal .report-type-option:focus-within {
  outline: none !important;
  box-shadow:
    0 0 0 3px rgba(0, 149, 121, 0.22),
    0 18px 38px rgba(2, 19, 26, 0.12) !important;
}

#reportModal .report-type-option > .report-type-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 38px !important;
  height: 38px !important;
  border-radius: 12px !important;
  background: rgba(2, 19, 26, 0.05) !important;
  color: rgba(2, 19, 26, 0.62) !important;
  font-size: 16px !important;
  flex: 0 0 auto !important;
}

#reportModal .report-type-option:has(input:checked) > .report-type-icon {
  background: var(--v4-verde) !important;
  color: #ffffff !important;
}

#reportModal .report-type-content {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  min-width: 0 !important;
}

#reportModal .report-type-topline {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 7px !important;
  min-width: 0 !important;
}

#reportModal .report-type-option strong {
  color: var(--v4-ink) !important;
  font-size: 15px !important;
  font-weight: 750 !important;
  line-height: 1.18 !important;
  letter-spacing: 0 !important;
}

#reportModal .report-type-option em {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 22px !important;
  padding: 3px 8px !important;
  border-radius: 999px !important;
  background: rgba(2, 19, 26, 0.055) !important;
  color: rgba(26, 43, 35, 0.64) !important;
  font-style: normal !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
}

#reportModal .report-type-option:has(input:checked) em {
  background: rgba(0, 149, 121, 0.14) !important;
  color: var(--v4-petroleo) !important;
}

#reportModal .report-type-option small {
  color: var(--v4-ink-soft) !important;
  font-size: 12.5px !important;
  line-height: 1.42 !important;
}

#reportModal .report-type-check {
  position: absolute !important;
  top: 14px !important;
  right: 14px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 22px !important;
  height: 22px !important;
  border-radius: 999px !important;
  background: rgba(0, 149, 121, 0.14) !important;
  color: var(--v4-verde) !important;
  font-size: 11px !important;
  opacity: 0 !important;
  transform: scale(0.82) !important;
  transition: opacity 140ms ease, transform 140ms ease !important;
}

#reportModal .report-type-option:has(input:checked) .report-type-check {
  opacity: 1 !important;
  transform: scale(1) !important;
}

#reportModal .report-modal-footer {
  padding: 16px 24px 22px !important;
  background: #ffffff !important;
  border-top: 1px solid rgba(2, 19, 26, 0.08) !important;
}

#reportModal .report-modal-footer-actions {
  gap: 10px !important;
}

#reportModal .btn {
  min-height: 40px !important;
  border-radius: 10px !important;
  padding: 0 18px !important;
  font-family: var(--ui-font, var(--font-sans)) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  transition: background 140ms ease, border-color 140ms ease, box-shadow 140ms ease, transform 140ms ease !important;
}

#reportModal .btn-secondary {
  border: 1px solid rgba(2, 19, 26, 0.10) !important;
  background: #eef2ef !important;
  color: var(--v4-ink-soft) !important;
}

#reportModal .btn-secondary:hover {
  background: #e5ebe7 !important;
  color: var(--v4-ink) !important;
}

#reportModal .btn-primary {
  border: 1px solid rgba(0, 149, 121, 0.72) !important;
  background: var(--v4-verde) !important;
  color: #ffffff !important;
  box-shadow: 0 10px 22px rgba(0, 149, 121, 0.20) !important;
}

#reportModal .btn-primary:hover:not(:disabled) {
  transform: translateY(-1px) !important;
  background: #00a486 !important;
  box-shadow: 0 14px 28px rgba(0, 149, 121, 0.25) !important;
}

#reportModal .btn-primary:disabled {
  border-color: rgba(2, 19, 26, 0.08) !important;
  background: #d5ddd8 !important;
  color: rgba(26, 43, 35, 0.58) !important;
  box-shadow: none !important;
}

#reportModal .report-modal-footer .btn-primary:not(:disabled) {
  border-color: rgba(0, 149, 121, 0.72) !important;
  background: var(--v4-verde) !important;
  background-color: var(--v4-verde) !important;
  background-image: none !important;
  color: #ffffff !important;
  box-shadow: 0 10px 22px rgba(0, 149, 121, 0.20) !important;
}

#reportModal .report-token-panel {
  display: grid !important;
  gap: 8px !important;
  width: min(100%, 520px) !important;
  color: var(--v4-ink-soft) !important;
  font-family: var(--ui-font, var(--font-sans)) !important;
  font-size: 12.5px !important;
}

#reportModal .report-token-panel p {
  margin: 0 !important;
}

#reportModal #reportTokenStatus[data-state="insufficient"] {
  color: #9f2d1f !important;
  font-weight: 700 !important;
}

#reportModal #reportTokenStatus[data-state="ok"] {
  color: var(--v4-verde) !important;
  font-weight: 700 !important;
}

#reportModal .report-token-purchase {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
}

#reportModal .report-token-purchase label {
  font-weight: 700 !important;
  color: var(--v4-ink) !important;
}

#reportModal .report-token-purchase input {
  width: 92px !important;
  min-height: 36px !important;
  border: 1px solid rgba(2, 19, 26, 0.14) !important;
  border-radius: 10px !important;
  padding: 0 10px !important;
  font: inherit !important;
}

@media (max-width: 768px) {
  #reportModal .report-modal-content {
    width: calc(100vw - 16px) !important;
    max-height: calc(100vh - 16px) !important;
    border-radius: 14px !important;
  }

  #reportModal .report-modal-header,
  #reportModal .report-modal-body,
  #reportModal .report-modal-footer {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  #reportModal .report-type-selector {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  #reportModal .report-type-option {
    grid-template-columns: auto 1fr auto !important;
    grid-template-rows: auto !important;
    min-height: 0 !important;
    align-items: center !important;
    padding: 14px !important;
  }

  #reportModal .report-type-check {
    position: static !important;
    opacity: 1 !important;
    transform: scale(1) !important;
    background: rgba(2, 19, 26, 0.06) !important;
    color: transparent !important;
  }

  #reportModal .report-type-option:has(input:checked) .report-type-check {
    background: rgba(0, 149, 121, 0.14) !important;
    color: var(--v4-verde) !important;
  }
}
