/* =============================================
   SenaSeg — Corretora de Seguros
   style.css — v3.0
   ============================================= */

/* ╔══════════════════════════════════════════════════════════╗
   ║  PAINEL DE CONTROLE — MEXA AQUI                         ║
   ║  Tudo em rem: 1rem = 16px no navegador padrão.          ║
   ║  Exemplos rápidos: 1rem=16px  1.5rem=24px  2rem=32px    ║
   ╚══════════════════════════════════════════════════════════╝ */
:root {

  /* ── CORES ─────────────────────────────────────────────────
     Altere aqui para mudar a identidade visual do site inteiro.
     ─────────────────────────────────────────────────────────── */

  /* Azul escuro principal — botões, fundo da seção "Por que nós", footer */
  --azul:          #1a3f6f;

  /* Azul médio — hover de links e do botão CTA do menu */
  --azul-medio:    #2563a8;

  /* Azul bem claro — fundo do badge SUSEP, card destaque, hover dos canais */
  --azul-claro:    #e8f0fa;

  /* Azul de acento — foco em inputs, borda de card no hover, itálico do H1 */
  --azul-accent:   #3b82c4;

  /* Laranja — números dos motivos ("01","02"...), badge "Carro-chefe" */
  --laranja:       #e07b2a;

  /* Laranja claro — fundo do ícone de vida e do ícone de e-mail */
  --laranja-claro: #fdf3ea;

  /* Cor padrão de todo texto corrido da página */
  --cinza-texto:   #3d3d3d;

  /* Fundo suave — seção de contato, fundo dos inputs/selects/textarea */
  --cinza-suave:   #f5f6f8;

  /* Branco puro */
  --branco:        #ffffff;

  /* Cor das linhas divisórias, contornos de cards e bordas de inputs */
  --borda:         #dde3ec;


  /* ── TIPOGRAFIA ────────────────────────────────────────────
     Tamanhos de fonte (1rem = 16px).
     Os breakpoints responsivos ajustam automaticamente.
     ─────────────────────────────────────────────────────────── */

  /* Título principal do hero — a frase grande com itálico  (padrão: 3rem = 48px) */
  --font-h1:              3rem;

  /* Títulos das seções: "Nossos produtos", "Por que escolher a SenaSeg?"  (2.25rem = 36px) */
  --font-titulo-secao:    2.25rem;

  /* Subtítulo cinza abaixo de cada título de seção  (1rem = 16px) */
  --font-subtitulo-secao: 1rem;

  /* Parágrafo descritivo abaixo do H1 no hero  (1.0625rem ≈ 17px) */
  --font-hero-desc:       1.0625rem;

  /* Texto dos botões principais  (0.9375rem = 15px) */
  --font-botao:           0.9375rem;

  /* Links do menu e botão "Solicitar cotação"  (0.875rem = 14px) */
  --font-nav:             0.875rem;


  /* ── LAYOUT — LARGURAS MÁXIMAS ─────────────────────────────
     Define até onde o conteúdo se expande horizontalmente.
     ─────────────────────────────────────────────────────────── */

  /* Largura máxima do bloco de texto no hero  (33.75rem = 540px) */
  --largura-hero:     33.75rem;

  /* Largura máxima da seção de produtos  (62.5rem = 1000px) */
  --largura-secao:    62.5rem;

  /* Largura máxima da seção "Por que escolher a SenaSeg?"  (56.25rem = 900px) */
  --largura-porque:   56.25rem;

  /* Largura máxima do formulário de contato  (37.5rem = 600px) */
  --largura-contato:  37.5rem;


  /* ── ESPAÇAMENTOS ──────────────────────────────────────────
     Controla o "respiro" entre os elementos e seções.
     ─────────────────────────────────────────────────────────── */

  /* Altura da barra de navegação fixa no topo  (5rem = 80px) */
  --altura-nav:      5rem;

  /* Padding horizontal do menu (espaço nas laterais)  (3rem = 48px) */
  --padding-nav:     3rem;

  /* Padding horizontal das seções de conteúdo  (2rem = 32px) */
  --padding-lateral: 2rem;

  /* Padding vertical (cima e baixo) de todas as seções  (5rem = 80px) */
  --padding-secao:   5rem;

  /* Espaço entre texto e cards de estatística no hero  (3.75rem = 60px) */
  --gap-hero:        3.75rem;


  /* ── BORDAS E ARREDONDAMENTOS ──────────────────────────────
     Quanto os cantos dos elementos são arredondados.
     ─────────────────────────────────────────────────────────── */

  /* Arredondamento dos cards de produto, motivos e stat-cards  (0.875rem = 14px) */
  --raio-card:   0.875rem;

  /* Arredondamento dos botões, inputs, selects e textarea  (0.625rem = 10px) */
  --raio-botao:  0.625rem;


  /* ── SINISTRO — DIVISÃO DA TELA ───────────────────────────
     Controla a proporção entre a metade de cima (emergências)
     e a metade de baixo (seguradoras) na tela de sinistro.

     Funciona como flex — os valores são proporcionais entre si:
       1 e 1  → 50% / 50%  (padrão)
       2 e 1  → 67% / 33%  (mais espaço em cima)
       1 e 2  → 33% / 67%  (mais espaço embaixo)
       3 e 2  → 60% / 40%
     ─────────────────────────────────────────────────────────── */

  /* Proporção da metade SUPERIOR (emergências públicas) */
  --sinistro-topo:  1;

  /* Proporção da metade INFERIOR (seguradoras) */
  --sinistro-baixo: 2;

  /* ── SINISTRO — TAMANHO DOS BOTÕES DE EMERGÊNCIA ──────────
     Escala proporcional dos botões Polícia / Bombeiro.
     Aplica-se a todos os tamanhos de tela de forma relativa.
     Exemplos:
       1    → tamanho original  (padrão)
       0.85 → 15% menor
       0.7  → 30% menor
       1.15 → 15% maior
     ─────────────────────────────────────────────────────────── */

  /* Escala dos botões de emergência */
  --sinistro-btn-escala: 0.8;


  /* ── CARDS DAS SEGURADORAS — FUNDO DA LOGO ────────────────
     Cor de fundo do ícone/logo dentro de cada card de seguradora.
     Exemplos: #ffffff (branco puro) | transparent | #f0f4fb
     ─────────────────────────────────────────────────────────── */

  /* Fundo do ícone de logo nos cards das seguradoras */
  --seg-logo-bg: #ffffff;


  /* ── FAB — TAMANHO DOS BOTÕES FLUTUANTES ─────────────
     Escala proporcional de TUDO nos botões flutuantes mobile:
     botões, balões, pontinha, fontes e espaçamentos internos.
     Aceita porcentagem — 100% = tamanho original.
     Exemplos:
       100% → tamanho original
        90% → 10% menor
        80% → 20% menor  (padrão)
        70% → 30% menor
        60% → 40% menor
     ─────────────────────────────────────────────────────── */
  --fab-escala: 85%;

  /* ── FAB — TRANSPARÊNCIA DOS BOTÕES FLUTUANTES ────────
     Opacidade de todos os botões e balões flutuantes.
     1 = totalmente opaco  |  0 = invisível.
     Exemplos:
       1.0  → sem transparência (padrão)
       0.85 → levemente transparente
       0.6  → bastante transparente
       0.4  → muito transparente
     ─────────────────────────────────────────────────────── */
  --fab-opacidade: 0.90;

  /* ── FABs — VISIBILIDADE SOBRE O FORMULÁRIO DE COTAÇÃO ─
     Controla se os botões flutuantes (WhatsApp e Sinistro)
     aparecem por cima do formulário de cotação quando ele
     estiver aberto.
       1 → aparecem sobre o formulário (padrão)
       0 → ficam ocultos atrás do formulário
     ─────────────────────────────────────────────────────── */
  --fabs-sobre-cotacao: 0;

  /* ── SOBRE NÓS — TAMANHO DO TEXTO ───────────────────────
     Escala independente dos textos na seção Sobre nós.
     100 = tamanho atual. Proporcional em todos os breakpoints.
     Exemplos:
       100 → tamanho original
       115 → 15% maior
       130 → 30% maior
     ─────────────────────────────────────────────────────── */
  --sobre-texto-escala: 110;

  /* ── PARCEIROS — TAMANHO DOS LOGOS ───────────────────────
     Escala dos logos no carrossel de parceiras.
     100 = tamanho base atual (mínimo recomendado).
     Exemplos:
       100 → tamanho original (3 rem no desktop)
       130 → 30% maior
       150 → 50% maior
       200 → o dobro do tamanho original
     ─────────────────────────────────────────────────────── */
  --parceiro-logo-escala: 130;

  /* ── FAB — BALÃO DE CONTATO (TICKER) ─────────────────
     Velocidade do texto correndo no balão "Contato corretora".
     Exemplos:
       2s  → bem rápido
       4s  → velocidade padrão
       7s  → bem devagar (fácil de ler)
       10s → muito lento
     ─────────────────────────────────────────────────────── */
  --fab-balao-velocidade: 6s;

}
/* ╚══════════════════════════════════════════════════════════╝
   FIM DO PAINEL DE CONTROLE
   ══════════════════════════════════════════════════════════ */


*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  font-family: 'Plus Jakarta Sans', sans-serif;
  color: var(--cinza-texto);
  background: var(--branco);
  line-height: 1.6;
}

/* =============================================
   NAVEGAÇÃO
   ============================================= */
nav {
  background: var(--branco);
  border-bottom: 1px solid var(--borda);
  padding: 0 var(--padding-nav);
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--altura-nav);
  position: sticky;
  top: 0;
  z-index: 100;
}

.logo {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  text-decoration: none;
}

.logo-icon {
  display: flex;
  align-items: center;
  justify-content: center;
}

.logo-icon img {
  height: 4rem;
  width: auto;
  display: block;
}

.nav-links {
  display: flex;
  gap: 2rem;
  list-style: none;
}

.nav-links a {
  text-decoration: none;
  font-size: var(--font-nav);
  font-weight: 500;
  color: var(--cinza-texto);
  transition: color 0.2s;
}

.nav-links a:hover {
  color: var(--azul-medio);
}

.nav-actions {
  display: flex;
  align-items: center;
  gap: 0.625rem;
}

.nav-cta,
.nav-sinistro {
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 1.25rem;
  border-radius: 0.5rem;
  font-family: inherit;
  font-size: var(--font-nav);
  line-height: 1.5;
  white-space: nowrap;
  cursor: pointer;
  border: none;
  text-decoration: none;
  transition: background 0.2s, transform 0.15s;
}

.nav-cta {
  background: var(--azul);
  color: white;
  font-weight: 600;
}

.nav-cta:hover {
  background: var(--azul-medio);
}

.nav-sinistro {
  background: var(--laranja);
  color: white;
  font-weight: 700;
  letter-spacing: 0.2px;
}

.nav-sinistro:hover {
  background: #c96820;
  transform: translateY(-1px);
}

/* =============================================
   BOTÕES FLUTUANTES (MOBILE FAB)
   ============================================= */
.fabs-container {
  display: none;
  position: fixed;
  bottom: 0.75rem;
  right: 0.75rem;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  zoom: var(--fab-escala);
  opacity: var(--fab-opacidade);
  z-index: calc(200 + var(--fabs-sobre-cotacao) * 210);
}

.fab-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.fab-balao {
  background: var(--branco);
  border: 2px solid var(--azul-accent);
  border-radius: 1rem;
  padding: 0.25rem 0.75rem;
  font-size: 0.6875rem;
  font-weight: 700;
  color: var(--azul);
  letter-spacing: 0.03em;
  text-transform: uppercase;
  white-space: nowrap;
  position: relative;
  box-shadow: 0 2px 8px rgba(26, 63, 111, 0.12);
}

/* Balão com texto correndo (contato) — mesma largura do balão "Sinistro" */
.fab-balao--scroll {
  width: 5.25rem;
  padding-left: 0;
  padding-right: 0;
  /* overflow: visible — mantém os pseudo-elementos ::after/::before visíveis */
}

.fab-balao-clip {
  display: block;
  width: 100%;
  overflow: hidden;
}

.fab-balao-track {
  display: inline-flex;
  white-space: nowrap;
  animation: fabTicker var(--fab-balao-velocidade) linear infinite;
  will-change: transform;
}

.fab-balao-txt {
  padding: 0 0.75rem;
}

@keyframes fabTicker {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Cauda do balão apontando para baixo — borda */
.fab-balao::after {
  content: '';
  position: absolute;
  bottom: -0.5rem;
  left: 50%;
  transform: translateX(-50%);
  border: 0.4rem solid transparent;
  border-top-color: var(--azul-accent);
  border-bottom: 0;
}

/* Cauda do balão apontando para baixo — preenchimento branco */
.fab-balao::before {
  content: '';
  position: absolute;
  bottom: -0.28rem;
  left: 50%;
  transform: translateX(-50%);
  border: 0.28rem solid transparent;
  border-top-color: var(--branco);
  border-bottom: 0;
  z-index: 1;
}

.sinistro-fab {
  display: flex;
  width: 5.25rem;
  height: 5.25rem;
  border-radius: 50%;
  background: var(--azul);
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.28);
  overflow: hidden;
  padding: 0;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s, box-shadow 0.2s;
}

.sinistro-fab:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 22px rgba(0, 0, 0, 0.35);
}

.sinistro-fab img {
  width: 58%;
  height: 58%;
  object-fit: contain;
}

.contato-fab {
  display: flex;
  width: 5.25rem;
  height: 5.25rem;
  border-radius: 50%;
  background: #25D366;
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.28);
  overflow: hidden;
  padding: 0;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s, box-shadow 0.2s;
}

.contato-fab:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 22px rgba(0, 0, 0, 0.35);
}

.contato-fab img {
  width: 58%;
  height: 58%;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

/* =============================================
   MODAL CONTATO CORRETORA (MOBILE)
   ============================================= */
.contato-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 300;
  align-items: center;
  justify-content: center;
}

.contato-overlay.ativo {
  display: flex;
}

.contato-popup {
  background: var(--branco);
  border: 1px solid var(--borda);
  border-radius: 1.25rem;
  padding: 2rem 1.75rem 2.25rem;
  width: 90%;
  max-width: 22rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  position: relative;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.22);
  animation: contatoEntrar 0.22s ease;
}

@keyframes contatoEntrar {
  from { opacity: 0; transform: scale(0.92) translateY(16px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

.contato-popup-fechar {
  position: absolute;
  top: 0.75rem;
  right: 0.875rem;
  background: none;
  border: none;
  color: #9aa4b2;
  font-size: 1.125rem;
  cursor: pointer;
  line-height: 1;
  padding: 0.25rem;
  transition: color 0.15s;
}

.contato-popup-fechar:hover { color: var(--cinza-texto); }

.contato-popup-logo {
  height: 2.75rem;
  width: auto;
}

.contato-popup-titulo {
  font-family: 'DM Serif Display', serif;
  font-size: 1.375rem;
  color: var(--azul);
  margin: 0;
  text-align: center;
}

.contato-popup-sub {
  font-size: 0.8125rem;
  color: #7a8ca0;
  text-align: center;
  margin: 0;
}

.contato-popup-botoes {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  width: 100%;
  margin-top: 0.5rem;
}

.contato-popup-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
  padding: 0.875rem 1.25rem;
  border-radius: var(--raio-botao);
  font-size: 1rem;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.2s, transform 0.15s;
}

.contato-popup-btn:active { transform: scale(0.97); }

.contato-popup-btn--wpp {
  background: #25D366;
  color: white;
}

.contato-popup-btn--wpp img {
  width: 1.375rem;
  height: 1.375rem;
  object-fit: contain;
  filter: brightness(0) invert(1);
}

.contato-popup-btn--wpp:hover { background: #1da854; }

.contato-popup-btn--tel {
  background: var(--azul);
  color: white;
}

.contato-popup-btn--tel:hover { background: var(--azul-medio); }

/* =============================================
   MODAL SINISTRO / EMERGÊNCIA
   ============================================= */
.sinistro-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: #0d1520;
  z-index: 500;
  align-items: center;
  justify-content: center;
}

.sinistro-overlay.ativo {
  display: flex;
}

.sinistro-modal {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  position: relative;
  animation: sinistroEntrar 0.22s ease;
}

/* — Metade superior (emergências públicas) — */
.sinistro-top {
  flex: var(--sinistro-topo);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 3.5rem 1.5rem 2rem;
}

/* — Linha divisória — */
.sinistro-divider {
  height: 1px;
  background: rgba(255, 255, 255, 0.10);
  margin: 0 2rem;
  flex-shrink: 0;
}

/* — Metade inferior (seguradoras) — */
.sinistro-bottom {
  flex: var(--sinistro-baixo);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1.75rem 0 2rem;
}

.sinistro-seguradoras-titulo {
  font-size: 0.75rem;
  font-weight: 700;
  color: #566070;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 1.25rem;
}

/* — Carrossel wrapper — */
.sinistro-carrossel-wrapper {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  max-width: 58rem;
  padding: 0 1.5rem;
}

.sinistro-carrossel {
  flex: 1;
  display: flex;
  gap: 0.625rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 0.5rem 0.25rem;
}

.sinistro-carrossel::-webkit-scrollbar {
  display: none;
}

/* — Cards das seguradoras — */
.seguradora-card {
  scroll-snap-align: start;
  flex-shrink: 0;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 2rem;
  padding: 0.625rem 1rem 0.625rem 0.625rem;
  color: #c8d8e8;
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 600;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: background 0.2s, border-color 0.2s, color 0.2s, transform 0.15s;
}

.seg-logo {
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 0.375rem;
  background: var(--seg-logo-bg);
  border: 1px solid rgba(0, 0, 0, 0.08);
  flex-shrink: 0;
  display: block;
  overflow: hidden;
}

.seg-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.seg-nome {
  line-height: 1;
}

.seguradora-card:hover {
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.30);
  color: white;
  transform: translateY(-2px);
}

/* — Botões de navegação do carrossel — */
.carrossel-nav {
  flex-shrink: 0;
  background: rgba(255, 255, 255, 0.08);
  color: #a8b8cc;
  border: none;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 50%;
  cursor: pointer;
  font-size: 1.375rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, color 0.2s;
}

.carrossel-nav:hover {
  background: rgba(255, 255, 255, 0.18);
  color: white;
}

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

.sinistro-fechar {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: rgba(255, 255, 255, 0.09);
  color: #a8b8cc;
  border: none;
  width: 3.50rem;
  height: 3.50rem;
  border-radius: 50%;
  cursor: pointer;
  font-size: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, color 0.2s;
}

.sinistro-fechar:hover {
  background: rgba(255, 255, 255, 0.18);
  color: white;
}

.sinistro-titulo {
  font-family: 'DM Serif Display', serif;
  font-size: 2.125rem;
  color: white;
  margin-bottom: 0.5rem;
}

.sinistro-sub {
  color: #7a8ca0;
  font-size: 0.9375rem;
  margin-bottom: 2.25rem;
}

.sinistro-botoes {
  display: flex;
  gap: 1.5rem;
  justify-content: center;
  flex-wrap: wrap;
  zoom: var(--sinistro-btn-escala);
}

.sinistro-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.875rem;
  text-decoration: none;
  background: rgba(255, 255, 255, 0.04);
  border: 1.5px solid rgba(255, 255, 255, 0.10);
  border-radius: 1rem;
  padding: 1.75rem 2.25rem 1.5rem;
  min-width: 11rem;
  transition: background 0.2s, border-color 0.2s, transform 0.15s;
}

.sinistro-btn:hover {
  transform: translateY(-4px);
}

.sinistro-btn.policia:hover {
  background: rgba(59, 130, 196, 0.18);
  border-color: var(--azul-accent);
}

.sinistro-btn.bombeiro:hover {
  background: rgba(220, 60, 40, 0.18);
  border-color: #dc3c28;
}

.sinistro-img-placeholder {
  width: 5rem;
  height: 5rem;
  border-radius: 0.75rem;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.06);
}

.sinistro-img-placeholder img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.sinistro-num {
  font-family: 'DM Serif Display', serif;
  font-size: 2.75rem;
  color: white;
  line-height: 1;
}

.sinistro-label {
  font-size: 0.8125rem;
  font-weight: 700;
  color: #8a9bb0;
  text-transform: uppercase;
  letter-spacing: 1.5px;
}

/* =============================================
   HERO
   ============================================= */
.hero {
  background: linear-gradient(135deg, #eef3fa 0%, #f8faff 60%, #fdf3ea 100%);
  padding: var(--padding-secao) var(--padding-lateral);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--gap-hero);
}

.hero-content {
  max-width: var(--largura-hero);
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  background: var(--azul-claro);
  color: var(--azul);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.3125rem 0.75rem;
  border-radius: 1.25rem;
  margin-bottom: 1.25rem;
  letter-spacing: 0.5px;
}

.hero-badge::before {
  content: '';
  width: 0.375rem;
  height: 0.375rem;
  background: var(--laranja);
  border-radius: 50%;
}

h1 {
  font-family: 'DM Serif Display', serif;
  font-size: var(--font-h1);
  line-height: 1.15;
  color: var(--azul);
  margin-bottom: 1.25rem;
  letter-spacing: -0.5px;
}

h1 em {
  font-style: italic;
  color: var(--azul-accent);
}

.hero-desc {
  font-size: var(--font-hero-desc);
  color: #5a6a80;
  margin-bottom: 2.25rem;
  line-height: 1.7;
}

.hero-buttons {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.btn-primary {
  background: var(--azul);
  color: white;
  padding: 0.875rem 1.75rem;
  border-radius: var(--raio-botao);
  font-size: var(--font-botao);
  font-weight: 600;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: background 0.2s, transform 0.15s;
  display: inline-block;
}

.btn-primary:hover {
  background: #152e55;
  transform: translateY(-2px);
}

.btn-secondary {
  background: transparent;
  color: var(--azul);
  padding: 0.875rem 1.75rem;
  border-radius: var(--raio-botao);
  font-size: var(--font-botao);
  font-weight: 600;
  text-decoration: none;
  border: 1.5px solid var(--azul);
  cursor: pointer;
  transition: all 0.2s;
  display: inline-block;
}

.btn-secondary:hover {
  background: var(--azul-claro);
  transform: translateY(-2px);
}

.hero-visual {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.stat-card {
  background: white;
  border: 1px solid var(--borda);
  border-radius: var(--raio-card);
  padding: 1.125rem 1.375rem;
  min-width: 12.5rem;
  box-shadow: 0 2px 12px rgba(26, 63, 111, 0.07);
}

.stat-card .num {
  font-family: 'DM Serif Display', serif;
  font-size: 2rem;
  color: var(--azul);
}

.stat-card .label {
  font-size: 0.8125rem;
  color: #7a8ca0;
  font-weight: 500;
  margin-top: 0.125rem;
}

.stat-card.accent {
  background: var(--azul);
}

.stat-card.accent .num {
  color: white;
}

.stat-card.accent .label {
  color: #a8c4e0;
}

@keyframes numPiscar {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: 0; }
}
.num-cursor::after {
  content: '|';
  display: inline-block;
  margin-left: 0.08em;
  font-weight: 400;
  animation: numPiscar 0.9s step-start infinite;
}

/* =============================================
   PARCEIROS — Carrossel infinito
   ============================================= */
.partners {
  padding: 1.75rem 0;
  background: var(--branco);
  border-top: 1px solid var(--borda);
  border-bottom: 1px solid var(--borda);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.25rem;
  overflow: hidden;
}

.partners-label {
  font-size: 0.75rem;
  color: #9aa4b2;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin: 0;
}

.partners-scroll {
  /* Variáveis de layout — ajuste aqui para mudar nº de itens ou tamanho dos cards */
  --n:      6;        /* itens visíveis ao mesmo tempo                  */
  --card-w: 8.5rem;   /* largura de cada card                            */
  --gap:    1rem;     /* espaço entre cards                              */

  width: calc(var(--n) * var(--card-w) + (var(--n) - 1) * var(--gap));
  max-width: calc(100vw - 2rem);
  overflow: hidden;
  cursor: grab;
}

.partners-scroll.dragging {
  cursor: grabbing;
}

.partners-track {
  display: flex;
  gap: var(--gap);
  width: max-content;
  user-select: none;
  will-change: transform;
}

.partner-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  padding: 0.875rem 0;
  background: var(--branco);
  border: 1px solid var(--borda);
  border-radius: var(--raio-card);
  flex-shrink: 0;
  width: var(--card-w);
  pointer-events: none;
  box-sizing: border-box;
}

.partner-card img {
  width: calc(3rem * var(--parceiro-logo-escala) / 100);
  height: calc(3rem * var(--parceiro-logo-escala) / 100);
  object-fit: contain;
  display: block;
  background: var(--seg-logo-bg);
  border-radius: 0.375rem;
  padding: 0.25rem;
}

.partner-card span {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--cinza-texto);
  white-space: nowrap;
}

/* Tablet grande (< 1024px) — 4 itens */
@media (max-width: 1023px) {
  .partners-scroll { --n: 4; --card-w: 8.5rem; --gap: 1rem; }
}

/* Tablet pequeno / mobile grande (< 640px) — 3 itens */
@media (max-width: 639px) {
  .partners-scroll { --n: 3; --card-w: 6.5rem; --gap: 0.75rem; }
  .partner-card img { width: calc(2.5rem * var(--parceiro-logo-escala) / 100); height: calc(2.5rem * var(--parceiro-logo-escala) / 100); }
  .partner-card span { font-size: 0.6875rem; }
}

/* Mobile pequeno (< 400px) — 3 itens compactos */
@media (max-width: 399px) {
  .partners-scroll { --n: 3; --card-w: 5.5rem; --gap: 0.5rem; }
  .partner-card img { width: calc(2rem * var(--parceiro-logo-escala) / 100); height: calc(2rem * var(--parceiro-logo-escala) / 100); }
  .partner-card span { font-size: 0.625rem; }
}

/* =============================================
   PRODUTOS
   ============================================= */
.section {
  padding: var(--padding-secao) var(--padding-lateral);
  max-width: var(--largura-secao);
  margin: 0 auto;
}

.section-title {
  font-family: 'DM Serif Display', serif;
  font-size: var(--font-titulo-secao);
  color: var(--azul);
  text-align: center;
  margin-bottom: 0.625rem;
}

.section-sub {
  text-align: center;
  color: #7a8ca0;
  font-size: var(--font-subtitulo-secao);
  margin-bottom: 3rem;
}

.produtos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(13.75rem, 1fr));
  gap: 1rem;
}

.produto-card {
  background: var(--branco);
  border: 1px solid var(--borda);
  border-radius: var(--raio-card);
  padding: 1.5rem;
  text-decoration: none;
  color: inherit;
  display: block;
  cursor: pointer;
  transition: box-shadow 0.2s, border-color 0.2s, transform 0.15s;
}

.produto-card:hover {
  box-shadow: 0 8px 28px rgba(26, 63, 111, 0.14);
  border-color: var(--azul-accent);
  transform: translateY(-3px);
}

.produto-card:active {
  transform: translateY(-1px);
}

.produto-card.destaque {
  border-color: var(--azul-accent);
  border-width: 2px;
  background: var(--azul-claro);
}

.produto-card.consorcio {
  border-color: #e8b85a;
  background: #fffbf2;
}

.produto-card.consorcio:hover {
  border-color: #c99030;
  box-shadow: 0 8px 28px rgba(224, 184, 90, 0.2);
}

.produto-icon {
  width: 2.875rem;
  height: 2.875rem;
  border-radius: 0.625rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
  font-size: 1.375rem;
}

.icon-auto    { background: #e8f4f8; }
.icon-casa    { background: #eaf5ea; }
.icon-vida    { background: #fdf3ea; }
.icon-saude   { background: #f0eafa; }
.icon-empresa { background: #fef3e2; }
.icon-frota   { background: #e6f1fb; }

.produto-nome {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--azul);
  margin-bottom: 0.375rem;
}

.produto-desc {
  font-size: 0.8125rem;
  color: #7a8ca0;
  line-height: 1.6;
}

.badge-destaque {
  display: inline-block;
  background: var(--laranja);
  color: white;
  font-size: 0.625rem;
  font-weight: 700;
  padding: 0.125rem 0.5rem;
  border-radius: 0.625rem;
  margin-bottom: 0.625rem;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

/* =============================================
   POR QUE NÓS
   ============================================= */
.porque {
  background: var(--azul);
  padding: var(--padding-secao) var(--padding-lateral);
}

.porque-inner {
  max-width: var(--largura-porque);
  margin: 0 auto;
}

.porque-inner .section-title { color: white; }
.porque-inner .section-sub   { color: #a8c4e0; }

.motivos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
  gap: 1.25rem;
}

.motivo {
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--raio-card);
  padding: 1.5rem;
}

.motivo-num {
  font-family: 'DM Serif Display', serif;
  font-size: 2.25rem;
  color: var(--laranja);
  margin-bottom: 0.5rem;
}

.motivo-titulo {
  font-size: 0.9375rem;
  font-weight: 600;
  color: white;
  margin-bottom: 0.375rem;
}

.motivo-texto {
  font-size: 0.8125rem;
  color: #a8c4e0;
  line-height: 1.6;
}

/* =============================================
   SOBRE NÓS
   ============================================= */
/* Oculto por padrão — só aparece na vista "Sobre nós" */
.sobre { display: none; }

/* ── Vista "Sobre nós" ativa (class no <body>) ── */
body.vista-sobre .sobre    { display: block; animation: sobreFadeIn 0.25s ease; }
body.vista-sobre .hero     { display: none; }
body.vista-sobre .partners { display: none; }
body.vista-sobre #produtos { display: none; }
body.vista-sobre .porque   { display: none; }

/* Cópia do carrossel de parceiras reaparece ao final da vista "Sobre nós" */
body.vista-sobre .partners--sobre { display: flex; margin-top: 4rem; }

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

.sobre {
  padding: var(--padding-secao) var(--padding-lateral);
  background: var(--branco);
}

.sobre-inner {
  max-width: var(--largura-secao);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 5rem;
}

.sobre-bloco {
  display: flex;
  align-items: center;
  gap: 3.5rem;
}

.sobre-texto {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.sobre-badge {
  display: inline-flex;
  align-items: center;
  background: var(--azul-claro);
  color: var(--azul-medio);
  border: 1px solid var(--borda);
  border-radius: 2rem;
  padding: 0.3rem 0.875rem;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  width: fit-content;
}

.sobre-titulo {
  font-family: 'DM Serif Display', serif;
  font-size: calc(1.75rem * var(--sobre-texto-escala) / 100);
  color: var(--azul);
  line-height: 1.25;
}

.sobre-desc {
  font-size: calc(0.9375rem * var(--sobre-texto-escala) / 100);
  color: #5a6a80;
  line-height: 1.8;
  text-align: justify;
}

.sobre-imagem {
  flex: 1;
}

.sobre-foto {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: var(--raio-card);
  display: block;
}

@media (max-width: 768px) {
  .sobre-inner { gap: 3rem; }

  .sobre-bloco {
    flex-direction: column;
    gap: 1.5rem;
  }

  /* Texto sempre primeiro, imagem sempre abaixo */
  .sobre-texto  { order: 1; width: 100%; }
  .sobre-imagem { order: 2; width: 100%; }

  .sobre-titulo { font-size: calc(1.375rem * var(--sobre-texto-escala) / 100); }
  .sobre-desc   { font-size: calc(0.875rem * var(--sobre-texto-escala) / 100); }
}

/* =============================================
   CONTATO
   ============================================= */
.contato-section {
  padding: var(--padding-secao) var(--padding-lateral);
  background: var(--cinza-suave);
}

.contato-inner {
  max-width: var(--largura-contato);
  margin: 0 auto;
  text-align: center;
}

.contato-inner .section-title { margin-bottom: 0.625rem; }
.contato-inner .section-sub   { margin-bottom: 2rem; }

.contato-form {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
  text-align: left;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.875rem;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}

.form-group label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--azul);
}

.form-group input,
.form-group select,
.form-group textarea {
  background: white;
  border: 1px solid var(--borda);
  border-radius: var(--raio-botao);
  padding: 0.6875rem 0.875rem;
  font-size: 0.875rem;
  font-family: inherit;
  color: var(--cinza-texto);
  outline: none;
  transition: border-color 0.2s;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--azul-accent);
}

.form-group textarea {
  resize: vertical;
  min-height: 5.625rem;
}

.btn-form {
  background: var(--azul);
  color: white;
  padding: 0.875rem;
  border-radius: var(--raio-botao);
  font-size: var(--font-botao);
  font-weight: 600;
  border: none;
  cursor: pointer;
  width: 100%;
  transition: background 0.2s, transform 0.15s;
}

.btn-form:hover {
  background: #152e55;
  transform: translateY(-1px);
}

.canais {
  display: flex;
  justify-content: center;
  gap: 1.5rem;
  margin-top: 2rem;
  flex-wrap: wrap;
}

.canal {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: #5a6a80;
  font-weight: 500;
  text-decoration: none;
  padding: 0.5rem 0.875rem;
  border-radius: var(--raio-botao);
  transition: background 0.2s, color 0.2s, transform 0.15s;
}

.canal:hover {
  background: var(--azul-claro);
  color: var(--azul);
  transform: translateY(-2px);
}

.canal-icon {
  width: 2rem;
  height: 2rem;
  border-radius: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
}

.wpp   { background: #e8f8ef; }
.tel   { background: var(--azul-claro); }
.email { background: var(--laranja-claro); }

.canal-icon img {
  width: 65%;
  height: 65%;
  object-fit: contain;
  display: block;
}

/* =============================================
   FOOTER
   ============================================= */
footer {
  background: #111c2d;
  color: #8a9bb0;
  padding: 2.5rem var(--padding-lateral) 1.75rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.25rem;
}

.footer-logo {
  display: flex;
  align-items: center;
  justify-content: center;
}

.footer-logo-img {
  height: 2.8rem;
  width: auto;
  filter: brightness(0) invert(1);
  opacity: 0.85;
}

.footer-links {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
  justify-content: center;
}

.footer-links a {
  text-decoration: none;
  font-size: 0.8125rem;
  color: #8a9bb0;
  transition: color 0.2s;
}

.footer-links a:hover {
  color: white;
}

.footer-copy {
  font-size: 0.75rem;
  color: #566070;
}

/* =============================================
   MENU MOBILE
   ============================================= */
.menu-toggle {
  display: none;
  font-size: 1.6rem;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--azul);
  padding: 0.25rem 0.5rem;
}

/* =============================================
   RESPONSIVO — Full HD e superiores (≥ 1920px)
   ============================================= */
@media (min-width: 1920px) {
  :root {
    --font-h1:              4rem;       /* 64px */
    --font-titulo-secao:    3rem;       /* 48px */
    --font-subtitulo-secao: 1.1875rem;  /* 19px */
    --font-hero-desc:       1.25rem;    /* 20px */
    --font-botao:           1.0625rem;  /* 17px */
    --largura-hero:         43.75rem;   /* 700px */
    --largura-secao:        87.5rem;    /* 1400px */
    --largura-porque:       87.5rem;    /* 1400px */
    --largura-contato:      50rem;      /* 800px */
    --padding-nav:          6rem;
    --padding-secao:        6.25rem;    /* 100px */
    --gap-hero:             6.25rem;    /* 100px */
  }

  nav { height: 5.5rem; }
  .stat-card { min-width: 16.25rem; padding: 1.5rem 1.875rem; }
  .stat-card .num { font-size: 2.625rem; }
  .stat-card .label { font-size: 0.9375rem; }
  .produtos-grid { grid-template-columns: repeat(4, 1fr); gap: 1.25rem; }
  .produto-card { padding: 1.875rem; }
  .produto-icon { width: 3.625rem; height: 3.625rem; font-size: 1.75rem; margin-bottom: 1.25rem; }
  .produto-nome { font-size: 1.0625rem; margin-bottom: 0.5rem; }
  .produto-desc { font-size: 0.9375rem; }
  .motivos-grid { grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
  .motivo { padding: 2rem; }
  .motivo-num { font-size: 3rem; }
  .motivo-titulo { font-size: 1.0625rem; }
  .motivo-texto { font-size: 0.9375rem; }
  footer { padding: 3.5rem 6rem 2.25rem; }
  .footer-links a { font-size: 0.9375rem; }
  .footer-copy { font-size: 0.875rem; }

  /* Sinistro — Full HD */
  .sinistro-top { padding: 4.5rem 2rem 2.5rem; }
  .sinistro-titulo { font-size: 3rem; }
  .sinistro-sub { font-size: 1.125rem; margin-bottom: 3rem; }
  .sinistro-btn { padding: 2.25rem 3rem 2rem; min-width: 14rem; }
  .sinistro-img-placeholder { width: 6.5rem; height: 6.5rem; }
  .sinistro-num { font-size: 3.5rem; }
  .sinistro-label { font-size: 1rem; letter-spacing: 2px; }
  .sinistro-bottom { padding: 2rem 0 2.5rem; }
  .sinistro-seguradoras-titulo { font-size: 0.875rem; margin-bottom: 1.5rem; }
  .sinistro-carrossel-wrapper { max-width: 72rem; }
  .seguradora-card { font-size: 1rem; padding: 0.875rem 1.875rem; }
  .carrossel-nav { width: 3rem; height: 3rem; font-size: 1.75rem; }
}

/* =============================================
   RESPONSIVO — HD (1280px – 1919px)
   ============================================= */
@media (min-width: 1280px) and (max-width: 1919px) {
  :root {
    --font-h1:        3.25rem;    /* 52px */
    --largura-hero:   36.25rem;   /* 580px */
    --largura-secao:  68.75rem;   /* 1100px */
    --largura-porque: 62.5rem;    /* 1000px */
    --padding-nav:    4rem;
    --padding-secao:  5.625rem;   /* 90px */
    --gap-hero:       5rem;       /* 80px */
  }
}

/* =============================================
   RESPONSIVO — Abaixo de HD (769px – 1279px)
   ============================================= */
@media (min-width: 769px) and (max-width: 1279px) {
  :root {
    --font-h1:              2.375rem;   /* 38px */
    --font-titulo-secao:    1.875rem;   /* 30px */
    --font-subtitulo-secao: 0.9375rem;  /* 15px */
    --font-hero-desc:       0.9375rem;  /* 15px */
    --largura-hero:         28.75rem;   /* 460px */
    --largura-secao:        53.75rem;   /* 860px */
    --largura-porque:       52.5rem;    /* 840px */
    --largura-contato:      32.5rem;    /* 520px */
    --padding-nav:          2rem;
    --padding-secao:        3.75rem;    /* 60px */
    --gap-hero:             2.25rem;    /* 36px */
  }

  .stat-card { min-width: 10.625rem; padding: 1rem 1.125rem; }
  .stat-card .num { font-size: 1.75rem; }
  .motivos-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .produtos-grid { grid-template-columns: repeat(auto-fit, minmax(12.5rem, 1fr)); gap: 0.875rem; }
  .produto-card { padding: 1.25rem; }

  /* Sinistro — Abaixo de HD */
  .sinistro-top { padding: 2.5rem 1.5rem 1.75rem; }
  .sinistro-titulo { font-size: 1.75rem; }
  .sinistro-sub { font-size: 0.875rem; margin-bottom: 1.75rem; }
  .sinistro-btn { padding: 1.25rem 1.5rem 1.125rem; min-width: 9rem; }
  .sinistro-img-placeholder { width: 4rem; height: 4rem; }
  .sinistro-num { font-size: 2.25rem; }
  .sinistro-bottom { padding: 1.5rem 0 1.75rem; }
  .sinistro-carrossel-wrapper { max-width: 44rem; }
  .seguradora-card { font-size: 0.8125rem; padding: 0.5625rem 1.125rem; }
}

/* =============================================
   RESPONSIVO — Mobile (≤ 768px)
   ============================================= */
@media (max-width: 768px) {
  :root {
    --font-h1:              2rem;       /* 32px */
    --font-titulo-secao:    1.75rem;    /* 28px */
    --font-subtitulo-secao: 0.875rem;   /* 14px */
    --font-hero-desc:       0.9375rem;  /* 15px */
    --altura-nav:           4.5rem;
    --padding-nav:          1.2rem;
    --padding-lateral:      1.2rem;
    --padding-secao:        3.125rem;   /* 50px */
    --gap-hero:             2rem;       /* 32px */
  }

  .logo-icon img { height: 3.2rem; }

  .menu-toggle { display: block; }

  .nav-links {
    position: absolute;
    top: var(--altura-nav);
    left: 0;
    width: 100%;
    background: var(--branco);
    flex-direction: column;
    gap: 0;
    padding: 0;
    display: none;
    border-bottom: 1px solid var(--borda);
    box-shadow: 0 4px 16px rgba(26, 63, 111, 0.08);
  }

  .nav-links.active { display: flex; }

  .nav-links li { border-bottom: 1px solid var(--borda); }

  .nav-links a {
    display: block;
    padding: 1rem 1.5rem;
    font-size: 1rem;
  }

  .nav-actions { display: none; }
  .fabs-container { display: flex; }

  .hero {
    flex-direction: column;
    text-align: center;
  }

  .hero-content { max-width: 100%; }

  .hero-desc { margin-bottom: 1.75rem; }

  .hero-buttons {
    justify-content: center;
    flex-direction: column;
    align-items: center;
  }

  .btn-primary,
  .btn-secondary {
    width: 100%;
    text-align: center;
    padding: 0.875rem 1.25rem;
  }

  .hero-visual {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
  }

  .stat-card { min-width: 8.125rem; flex: 1; padding: 0.875rem 1rem; }
  .stat-card .num { font-size: 1.625rem; }
  .stat-card .label { font-size: 0.75rem; }


  .section-sub { margin-bottom: 2rem; }

  .produtos-grid { grid-template-columns: 1fr 1fr; gap: 0.75rem; }
  .produto-card { padding: 1.125rem 0.875rem; }
  .produto-icon { width: 2.5rem; height: 2.5rem; font-size: 1.125rem; }
  .produto-nome { font-size: 0.875rem; }
  .produto-desc { font-size: 0.75rem; }

  .motivos-grid { grid-template-columns: 1fr; gap: 0.875rem; }
  .motivo { padding: 1.25rem; }
  .motivo-num { font-size: 1.875rem; }

  .contato-form { gap: 0.75rem; }
  .form-row { grid-template-columns: 1fr; }
  .btn-form { padding: 1rem; font-size: 1rem; }

  .canais { flex-direction: column; align-items: stretch; gap: 0.625rem; margin-top: 1.5rem; }
  .canal { justify-content: center; padding: 0.75rem 1rem; }

  footer { gap: 1rem; }
  .footer-links { gap: 1rem; }
  .footer-links a { font-size: 0.8125rem; }
  .footer-copy { font-size: 0.6875rem; text-align: center; }

  /* Sinistro — Mobile */
  .sinistro-top { padding: 2.25rem 1rem 1.25rem; }
  .sinistro-titulo { font-size: 1.375rem; }
  .sinistro-sub { font-size: 0.8125rem; margin-bottom: 1.25rem; }

  /* Botões Polícia/Bombeiro lado a lado, cada um metade da tela */
  .sinistro-top   { flex: var(--sinistro-topo); }
  .sinistro-botoes { flex-wrap: nowrap; gap: 0.625rem; width: 100%; padding: 0 0.75rem; }
  .sinistro-btn    { flex: 1; min-width: 0; padding: 1rem 0.5rem 0.875rem; border-radius: 0.75rem; }
  .sinistro-img-placeholder { width: 3.25rem; height: 3.25rem; border-radius: 0.5rem; }
  .sinistro-num   { font-size: 1.875rem; }
  .sinistro-label { font-size: 0.625rem; letter-spacing: 1px; }

  /* Metade inferior — usa a variável para respeitar a divisão configurada */
  .sinistro-bottom {
    flex: var(--sinistro-baixo);  /* ← controlado por --sinistro-baixo no :root */
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    padding: 0.875rem 0.75rem 0.875rem;
    overflow: hidden;
    width: 100%;
  }
  .sinistro-seguradoras-titulo {
    font-size: 0.6875rem;
    margin-bottom: 0.625rem;
    text-align: center;
    width: 100%;
  }

  /* Esconde setas no mobile */
  .carrossel-nav { display: none; }

  /* Wrapper: ocupa toda a largura e altura restante, sem max-width */
  .sinistro-carrossel-wrapper {
    flex: 1;
    width: 100%;
    max-width: none;
    padding: 0;
    gap: 0;
    align-items: stretch;
    overflow: hidden;
  }

  /* Grade 2 colunas — botões maiores e mais legíveis no celular */
  .sinistro-carrossel {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 1fr;
    gap: 0.375rem;
    width: 100%;
    height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    scroll-snap-type: none;
    padding: 0;
    flex: unset;
  }

  /* Cards ocupam a célula inteira do grid */
  .seguradora-card {
    flex-shrink: unset;
    scroll-snap-align: unset;
    white-space: normal;
    text-align: center;
    font-size: 0.8125rem;
    padding: 0.5rem 0.25rem;
    border-radius: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
  }
}

/* ═══════════════════════════════════════════════════
   CARD DE DETALHE DA SEGURADORA
═══════════════════════════════════════════════════ */

.seg-detalhe-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.22s ease;
  border-radius: inherit;
}

.seg-detalhe-backdrop.ativo {
  opacity: 1;
  pointer-events: auto;
}

.seg-detalhe-card {
  position: relative;
  background: linear-gradient(145deg, #1a2a3a 0%, #0f1d2b 100%);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 1.25rem;
  padding: 2rem 2rem 2.25rem;
  width: fit-content;
  min-width: min(20rem, 88vw);
  max-width: min(36rem, 92vw);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.55);
  transform: translateY(12px) scale(0.97);
  transition: transform 0.25s ease;
}

.seg-detalhe-backdrop.ativo .seg-detalhe-card {
  transform: translateY(0) scale(1);
}

.seg-detalhe-fechar {
  position: absolute;
  top: 0.75rem;
  right: 0.875rem;
  background: none;
  border: none;
  color: rgba(255, 255, 255, 0.45);
  font-size: 1.125rem;
  cursor: pointer;
  line-height: 1;
  padding: 0.25rem;
  transition: color 0.15s;
}

.seg-detalhe-fechar:hover {
  color: white;
}

.seg-detalhe-logo {
  width: 4rem;
  height: 4rem;
  border-radius: 0.75rem;
  background: var(--seg-logo-bg);
  border: 1px solid rgba(0, 0, 0, 0.08);
  overflow: hidden;
  margin-bottom: 0.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.seg-detalhe-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.seg-detalhe-nome {
  font-size: 1.25rem;
  font-weight: 700;
  color: #fff;
  margin: 0;
  text-align: center;
}

.seg-detalhe-contatos {
  list-style: none;
  margin: 0.75rem 0 0;
  padding: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

.seg-detalhe-contatos li {
  display: block;
}

.seg-contato-icone {
  font-size: 1.1rem;
  flex-shrink: 0;
  width: 1.4rem;
  text-align: center;
}

/* Ícone SVG do WhatsApp */
.seg-contato-icone--wa {
  display: inline-block;
  width: 1.4rem;
  height: 1.4rem;
  background: url("img/whatsapp.svg") center/contain no-repeat;
}

.seg-contato-link {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  width: 100%;
  box-sizing: border-box;
  padding: 0.625rem 0.875rem;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 0.625rem;
  color: #a8c8e8;
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: 500;
  transition: background 0.2s, color 0.15s, border-color 0.2s;
  white-space: nowrap;
}

.seg-contato-link:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.22);
  color: #ffffff;
  text-decoration: none;
}

/* Contato popup flutuante — exibido acima dos FABs quando cotação está aberta */
.contato-overlay--flutuante {
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  pointer-events: none;
  align-items: flex-end;
  justify-content: flex-end;
  padding-right: 0.75rem;
  padding-bottom: 14.5rem;
  z-index: 420;
}

.contato-overlay--flutuante .contato-popup {
  pointer-events: auto;
  width: 15rem;
  max-width: 15rem;
  padding: 1rem 1.125rem 1.25rem;
  gap: 0.5rem;
  border-radius: 1rem;
  animation: contatoEntrar 0.2s ease;
}

.contato-overlay--flutuante .contato-popup-logo { height: 2rem; }

.contato-overlay--flutuante .contato-popup-titulo { font-size: 1.125rem; }

.contato-overlay--flutuante .contato-popup-sub { display: none; }

.contato-overlay--flutuante .contato-popup-btn {
  padding: 0.625rem 0.875rem;
  font-size: 0.875rem;
}

/* =============================================
   MODAL COTAÇÃO DE PRODUTOS
   ============================================= */
@keyframes cotacaoEntrar {
  from { opacity: 0; transform: scale(0.94) translateY(16px); }
  to   { opacity: 1; transform: scale(1)    translateY(0); }
}

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

.cotacao-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(10, 22, 40, 0.62);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 400;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  overscroll-behavior: contain;
}

.cotacao-overlay.ativo {
  display: flex;
}

.cotacao-modal {
  background: var(--branco);
  border: 1px solid var(--borda);
  border-radius: var(--raio-card);
  padding: 2rem 2rem 2.25rem;
  width: 100%;
  max-width: 28rem;
  position: relative;
  box-shadow: 0 24px 64px rgba(26, 63, 111, 0.22);
  animation: cotacaoEntrar 0.22s ease;
  max-height: calc(100dvh - 2rem);
  overflow-y: auto;
  overscroll-behavior: contain;
}

.cotacao-fechar {
  position: absolute;
  top: 0.875rem;
  right: 0.875rem;
  background: none;
  border: none;
  color: #9aa4b2;
  font-size: 1.25rem;
  cursor: pointer;
  line-height: 1;
  padding: 0.375rem 0.5rem;
  border-radius: var(--raio-botao);
  transition: color 0.15s, background 0.15s;
  z-index: 1;
}

.cotacao-fechar:hover {
  color: var(--azul);
  background: var(--azul-claro);
}

.cotacao-cabecalho {
  margin-bottom: 1.5rem;
  padding-right: 2.25rem;
}

.cotacao-titulo {
  font-family: 'DM Serif Display', serif;
  font-size: 1.5rem;
  color: var(--azul);
  margin: 0 0 0.25rem;
  line-height: 1.2;
}

.cotacao-subtitulo {
  font-size: 0.8125rem;
  color: #7a8ca0;
  margin: 0;
}

.cotacao-form {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}

/* ── Tablet médio ── */
@media (min-width: 769px) and (max-width: 1279px) {
  .cotacao-modal { max-width: 26rem; }
}

/* ── Mobile — tela inteira ── */
@media (max-width: 768px) {
  .cotacao-overlay {
    padding: 0;
    align-items: stretch;
    justify-content: stretch;
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
  }

  .contato-overlay {
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
  }

  .seg-detalhe-backdrop {
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
  }

  .cotacao-modal {
    border-radius: 0;
    max-width: 100%;
    width: 100%;
    height: 100%;
    max-height: 100%;
    padding: 1.25rem 1.25rem 2rem;
    animation: cotacaoEntrarMobile 0.25s ease;
  }
}

/* =============================================
   MODAL OBRIGADO / CONFIRMAÇÃO
   ============================================= */
.obrigado-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(10, 22, 40, 0.62);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 600;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  overscroll-behavior: contain;
}

.obrigado-overlay.ativo {
  display: flex;
}

.obrigado-modal {
  background: var(--branco);
  border: 1px solid var(--borda);
  border-radius: var(--raio-card);
  padding: 2.5rem 2rem 2rem;
  width: 100%;
  max-width: 26rem;
  position: relative;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  box-shadow: 0 24px 64px rgba(26, 63, 111, 0.22);
  animation: cotacaoEntrar 0.22s ease;
  max-height: calc(100dvh - 2rem);
  overflow-y: auto;
}

.obrigado-fechar {
  position: absolute;
  top: 0.875rem;
  right: 0.875rem;
  background: none;
  border: none;
  color: #9aa4b2;
  font-size: 1.25rem;
  cursor: pointer;
  line-height: 1;
  padding: 0.375rem 0.5rem;
  border-radius: var(--raio-botao);
  transition: color 0.15s, background 0.15s;
}

.obrigado-fechar:hover {
  color: var(--azul);
  background: var(--azul-claro);
}

.obrigado-icone {
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  background: #e8f8ef;
  color: #1da854;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.875rem;
  font-weight: 700;
  margin-top: 0.25rem;
}

.obrigado-titulo {
  font-family: 'DM Serif Display', serif;
  font-size: 1.5rem;
  color: var(--azul);
  margin: 0;
  line-height: 1.2;
}

.obrigado-texto {
  font-size: 0.9375rem;
  color: #5a6a80;
  line-height: 1.7;
  margin: 0;
}

.obrigado-ok {
  background: var(--azul);
  color: white;
  padding: 0.75rem 2.75rem;
  border-radius: var(--raio-botao);
  font-family: inherit;
  font-size: var(--font-botao);
  font-weight: 600;
  border: none;
  cursor: pointer;
  margin-top: 0.5rem;
  transition: background 0.2s, transform 0.15s;
}

.obrigado-ok:hover {
  background: #152e55;
  transform: translateY(-1px);
}

/* Mensagem de consentimento LGPD — pequena, ao final dos formulários */
.form-consent {
  font-size: 0.6875rem;
  color: #7a8ca0;
  line-height: 1.5;
  text-align: center;
  margin-top: 0.75rem;
}

.form-consent a {
  color: var(--azul-medio);
  font-weight: 600;
  text-decoration: underline;
}

.form-consent a:hover {
  color: var(--azul);
}

/* Obrigado — Mobile */
@media (max-width: 768px) {
  .obrigado-overlay {
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
  }

  .obrigado-modal {
    padding: 2rem 1.5rem 1.75rem;
  }

  .obrigado-titulo {
    font-size: 1.25rem;
  }

  .obrigado-texto {
    font-size: 0.875rem;
  }

  .obrigado-ok {
    width: 100%;
  }
}
