/* =====================================================
   GUIA CSS PARA INICIANTES - TRANSPORTE FUNERÁRIO
   =====================================================
   
   Este arquivo CSS controla toda a aparência visual do site.
   
   ESTRUTURA DO ARQUIVO:
   1. Variáveis CSS - Cores e valores reutilizáveis
   2. Reset Global - Remove estilos padrão do navegador
   3. Navegação - Menu do topo e menu mobile
   4. Hero - Banner principal da página
   5. Seções - Serviços, Sobre, Países, etc.
   6. Componentes - Botões, cards, modais
   7. Footer - Rodapé do site
   8. Media Queries - Adaptação para mobile/tablet
   
   CONCEITOS IMPORTANTES:
   - px = pixels (unidade fixa)
   - rem = relativo ao tamanho base da fonte
   - % = porcentagem do elemento pai
   - vh = viewport height (altura da tela)
   - rgba() = cor com transparência
   - var(--nome) = usa uma variável CSS
   - :hover = estilo ao passar o mouse
   - ::before/::after = elementos pseudo (decorativos)
   - @media = estilos para diferentes tamanhos de tela
   
   ===================================================== */

/* ===== VARIÁVEIS CSS =====
   Variáveis globais que definem as cores do site.
   Use var(--nome-da-variavel) para aplicar essas cores em qualquer lugar do CSS.
   Exemplo: color: var(--primary); */
:root {
  --primary: #1a2e4a;      /* Azul escuro - cor principal do site */
  --secondary: #c49a3c;    /* Dourado - cor secundária (botões, destaques) */
  --accent: #e8b84b;       /* Dourado claro - cor de destaque */
  --dark: #0d1b2a;         /* Azul muito escuro - fundos escuros */
  --light: #f5f0e8;        /* Bege claro - fundos claros */
  --white: #ffffff;        /* Branco puro */
  --gray: #6b7280;         /* Cinza médio - textos secundários */
  --light-gray: #f8f6f2;   /* Cinza muito claro - fundos suaves */
  --green: #2d7a4f;        /* Verde - ícones de confirmação */
  --text: #1f2937;         /* Cinza escuro - cor padrão de texto */
}

/* ===== RESET GLOBAL =====
   Remove margens e paddings padrão de todos os elementos.
   box-sizing: border-box faz com que padding e border sejam incluídos na largura total.
   scroll-behavior: smooth adiciona rolagem suave ao clicar em links âncora (#). */
* { 
  margin: 0; 
  padding: 0; 
  box-sizing: border-box; 
  scroll-behavior: smooth; 
}

/* ===== ESTILOS DO BODY =====
   Define a fonte padrão, cor de texto e tamanho base para todo o site. */
body {
  font-family: 'Poppins', sans-serif;  /* Fonte principal do site - Poppins para textos */
  color: var(--text);                   /* Cor padrão do texto */
  background: var(--white);             /* Cor de fundo do site */
  font-size: 17px;                      /* Tamanho base da fonte (1rem = 17px) */
  line-height: 1.6;                     /* Espaçamento entre linhas (1.6x o tamanho da fonte) */
}

/* ===== TÍTULOS =====
   Define fonte diferente para todos os títulos (h1, h2, h3). */
h1, h2, h3 { 
  font-family: 'Lato', sans-serif;  /* Fonte Lato para títulos */
}

/* ===== TOPBAR =====
   Barra superior do site (acima do menu de navegação).
   Geralmente usada para informações de contato ou avisos. */
.topbar {
  background: var(--dark);    /* Fundo azul escuro */
  color: #aab4be;             /* Texto cinza claro */
  font-size: 13px;            /* Fonte pequena */
  padding: 6px 0;             /* Espaçamento interno vertical */
}

.topbar-content {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.topbar-info {
  flex: 1;
}

/* ===== TRADUTOR NO TOPO =====
   Botão tradutor que abre menu de idiomas */
.language-selector {
  position: relative;
  display: inline-block;
}

.translator-btn {
  background: var(--secondary);
  border: none;
  color: var(--white);
  padding: 8px 16px;
  border-radius: 4px;
  cursor: pointer;
  display: flex;
  align-items: center;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.5px;
  transition: all 0.3s ease;
  text-transform: uppercase;
}

.translator-btn:hover {
  background: #b8923c;
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(196, 154, 60, 0.3);
}

.language-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  background: var(--white);
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
  min-width: 180px;
  display: none;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all 0.3s ease;
  z-index: 1001;
  overflow: hidden;
}

.language-menu.active {
  display: block;
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.language-menu a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  color: var(--text);
  text-decoration: none;
  font-size: 14px;
  transition: background 0.2s ease;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.language-menu a:last-child {
  border-bottom: none;
}

.language-menu a:hover {
  background: rgba(196, 154, 60, 0.1);
  color: var(--secondary);
}

.language-menu .flag {
  font-size: 18px;
  line-height: 1;
}

/* Ocultar barra do Google Translate */
.goog-te-banner-frame {
  display: none !important;
}

body {
  top: 0 !important;
}

.skiptranslate {
  display: none !important;
}

@media (max-width: 768px) {
  .topbar-content {
    flex-direction: column;
    gap: 8px;
    text-align: center;
  }
  
  .topbar-info {
    font-size: 11px;
  }
  
  .translator-btn {
    font-size: 11px;
    padding: 6px 12px;
  }
  
  .language-selector {
    margin-top: 4px;
  }
}

/* ===== NAVEGAÇÃO PRINCIPAL =====
   Menu de navegação fixo no topo da página.
   position: sticky mantém o menu visível ao rolar a página. */
nav {
  background: var(--white);                    /* Fundo branco */
  border-bottom: 3px solid var(--secondary);   /* Borda inferior dourada */
  position: sticky;                            /* Fica fixo ao rolar (mas começa no topo) */
  top: 0;                                      /* Gruda no topo da tela */
  z-index: 1000;                               /* Fica acima de outros elementos */
  box-shadow: 0 2px 20px rgba(0,0,0,0.1);     /* Sombra suave embaixo */
}

/* Container interno da navegação.
   max-width limita a largura em telas grandes.
   display: flex organiza os itens em linha horizontal. */
.nav-inner {
  max-width: 1200px;              /* Largura máxima do conteúdo */
  margin: 0 auto;                 /* Centraliza horizontalmente */
  display: flex;                  /* Layout flexível (itens em linha) */
  align-items: center;            /* Alinha itens verticalmente ao centro */
  justify-content: space-between; /* Espaça itens nas extremidades */
  padding: 12px 24px;             /* Espaçamento interno */
}

/* ===== LOGO =====
   Estilo do logotipo da empresa. */
.logo {
  display: flex;           /* Layout flexível */
  align-items: center;     /* Alinha verticalmente ao centro */
  gap: 10px;               /* Espaço entre logo e texto (se houver) */
  text-decoration: none;   /* Remove sublinhado do link */
}

/* Imagem do logo */
.logo img {
  height: 60px;   /* Altura fixa do logo */
  width: auto;    /* Largura proporcional (mantém proporção) */
}

/* ===== MENU HAMBURGUER =====
   Botão de 3 linhas que abre o menu no mobile.
   display: none significa que está oculto no desktop. */
.menu-toggle {
  display: none;              /* Oculto por padrão (aparece só no mobile) */
  flex-direction: column;     /* Empilha as 3 linhas verticalmente */
  gap: 5px;                   /* Espaço entre as linhas */
  background: none;           /* Sem fundo */
  border: none;               /* Sem borda */
  cursor: pointer;            /* Cursor de mão ao passar o mouse */
  padding: 8px;               /* Espaçamento interno */
}

/* Cada linha do menu hamburguer.
   transition faz a animação suave quando o menu abre/fecha. */
.menu-toggle span {
  width: 28px;                  /* Largura da linha */
  height: 3px;                  /* Altura (espessura) da linha */
  background: var(--primary);   /* Cor azul escuro */
  border-radius: 2px;           /* Cantos levemente arredondados */
  transition: all 0.3s ease;    /* Animação suave de 0.3 segundos */
}

/* ===== ANIMAÇÃO DO MENU HAMBURGUER =====
   Quando o menu está aberto (classe .active), as linhas formam um X.
   nth-child(1) = primeira linha, nth-child(2) = segunda linha, etc. */

/* Primeira linha: rotaciona 45° e move para formar o X */
.menu-toggle.active span:nth-child(1) {
  transform: rotate(45deg) translate(8px, 8px);
}

/* Segunda linha: fica invisível */
.menu-toggle.active span:nth-child(2) {
  opacity: 0;  /* Transparente (invisível) */
}

/* Terceira linha: rotaciona -45° e move para completar o X */
.menu-toggle.active span:nth-child(3) {
  transform: rotate(-45deg) translate(7px, -7px);
}

/* ===== LINKS DE NAVEGAÇÃO =====
   Lista de links do menu (Início, Serviços, Sobre, etc). */
.nav-links {
  list-style: none;     /* Remove os bullets da lista */
  display: flex;        /* Organiza os links em linha horizontal */
  gap: 6px;             /* Espaço entre cada link */
  align-items: center;  /* Alinha verticalmente ao centro */
}

.nav-links a {
  text-decoration: none;
  color: var(--primary);
  font-size: 13px;
  font-weight: 500;
  padding: 6px 12px;
  border-radius: 4px;
  transition: all 0.2s;
}

.nav-links a:hover {
  background: var(--secondary);
  color: var(--white);
}

.nav-cta {
  background: var(--secondary) !important;
  color: var(--white) !important;
  border-radius: 6px !important;
  padding: 8px 16px !important;
  font-weight: 600 !important;
}

/* ===== ESTILOS MOBILE =====
   @media (max-width: 768px) aplica estilos apenas em telas menores que 768px.
   Isso torna o site responsivo (adaptável a diferentes tamanhos de tela). */
@media (max-width: 768px) {
  /* Mostra o botão hamburguer no mobile */
  .menu-toggle {
    display: flex;  /* Torna visível (estava display: none no desktop) */
  }

  /* Menu lateral deslizante no mobile.
     position: fixed mantém o menu fixo na tela.
     right: -100% esconde o menu fora da tela (à direita). */
  .nav-links {
    position: fixed;              /* Fixo na tela (não rola com a página) */
    right: -100%;                 /* Escondido fora da tela (à direita) */
    top: 0;                       /* Alinhado ao topo */
    height: 100vh;                /* Altura total da tela (100% viewport height) */
    width: 70%;                   /* 70% da largura da tela */
    max-width: 300px;             /* Máximo de 300px de largura */
    background: var(--white);     /* Fundo branco */
    flex-direction: column;       /* Empilha links verticalmente */
    padding: 80px 24px 24px;      /* Espaçamento interno */
    box-shadow: -2px 0 10px rgba(0,0,0,0.1);  /* Sombra à esquerda */
    transition: right 0.3s ease;  /* Animação suave ao abrir/fechar */
    z-index: 999;                 /* Fica acima de outros elementos */
  }

  /* Botão X para fechar menu mobile.
     Posicionado no canto superior direito do menu lateral. */
  .menu-close {
    display: block;
    position: absolute;
    top: 20px;
    right: 20px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    transition: background 0.3s ease;
  }

  .menu-close:hover {
    background: rgba(0, 0, 0, 0.05);
  }

  .menu-close svg {
    width: 24px;
    height: 24px;
    fill: var(--primary);
  }

  /* Quando o menu está aberto (classe .active adicionada via JavaScript).
     right: 0 traz o menu para dentro da tela. */
  .nav-links.active {
    right: 0;  /* Menu desliza para dentro (visível) */
  }

  /* Links do menu no mobile ocupam toda a largura. */
  .nav-links a {
    display: block;        /* Cada link em uma linha */
    padding: 15px 10px;    /* Espaçamento interno maior (área clicável maior) */
    width: 100%;           /* Largura total */
  }

  .nav-cta {
    margin-top: 10px;
    text-align: center;
  }

  .logo img {
    height: 50px;
  }
}

/* ===== SEÇÃO HERO (BANNER PRINCIPAL) =====
   Primeira seção visível do site com informações principais.
   linear-gradient cria um degradê de cores.
   overflow: hidden esconde conteúdo que ultrapassa os limites. */
#inicio {
  background: linear-gradient(135deg, var(--dark) 0%, var(--primary) 60%, #1e3a5f 100%);
  /* Degradê diagonal (135deg) de azul escuro para azul médio */
  color: var(--white);      /* Texto branco */
  position: relative;       /* Permite posicionar elementos filhos de forma absoluta */
  overflow: hidden;         /* Esconde partes que ultrapassam a seção */
}

/* Imagem de fundo decorativa (equipe).
   ::before cria um elemento pseudo antes do conteúdo.
   position: absolute posiciona em relação ao elemento pai (#inicio). */
#inicio::before {
  content: '';              /* Necessário para ::before aparecer */
  position: absolute;       /* Posicionamento absoluto */
  top: 0;                   /* Alinhado ao topo */
  left: 0;                  /* Alinhado à esquerda */
  width: 100%;              /* Ocupa toda a largura */
  height: 100%;             /* Altura total */
  background: url('https://transportefunerario.net.br/wp-content/uploads/2026/03/equipe-global.jpeg') center/cover no-repeat;
  /* Imagem centralizada, cobrindo toda a área, sem repetição */
  opacity: 0.25;            /* 25% de opacidade (transparente) */
}

/* Container interno do hero.
   display: grid cria um layout em grade com 2 colunas iguais.
   z-index: 1 garante que fique acima da imagem de fundo. */
.hero-inner {
  max-width: 1200px;                /* Largura máxima */
  margin: 0 auto;                   /* Centraliza */
  padding: 60px 24px;               /* Espaçamento interno */
  display: grid;                    /* Layout em grade */
  grid-template-columns: 1fr 1fr;   /* 2 colunas de tamanho igual (1fr = 1 fração) */
  gap: 40px;                        /* Espaço entre as colunas */
  align-items: center;              /* Alinha verticalmente ao centro */
  position: relative;               /* Contexto para z-index */
  z-index: 1;                       /* Fica acima do ::before */
}

/* Imagem do avião no lado esquerdo.
   object-fit: cover faz a imagem preencher o espaço sem distorcer.
   filter: brightness ajusta o brilho da imagem. */
.hero-left img.hero-plane {
  width: 100%;              /* Largura total do container */
  border-radius: 12px;      /* Cantos arredondados */
  object-fit: cover;        /* Preenche o espaço mantendo proporção */
  height: 320px;            /* Altura fixa */
  display: block;           /* Remove espaço extra embaixo da imagem */
  filter: brightness(0.9);  /* Reduz brilho em 10% */
}

/* Card de informações no lado direito.
   backdrop-filter: blur cria efeito de vidro fosco (glassmorphism).
   rgba() permite definir cor com transparência (0.06 = 6% opaco). */
.hero-right {
  background: rgba(255,255,255,0.06);        /* Fundo branco 6% opaco */
  backdrop-filter: blur(10px);               /* Efeito de desfoque (vidro fosco) */
  border: 1px solid rgba(196,154,60,0.3);    /* Borda dourada 30% opaca */
  border-radius: 16px;                       /* Cantos bem arredondados */
  padding: 36px 32px;                        /* Espaçamento interno */
}

/* ===== BADGE DE ORÇAMENTO =====
   Botão pequeno de destaque (badge).
   inline-flex permite alinhar ícone e texto lado a lado. */
.whatsapp-badge {
  display: inline-flex;    /* Flex em linha (não ocupa linha inteira) */
  align-items: center;     /* Alinha ícone e texto verticalmente */
  gap: 8px;                /* Espaço entre ícone e texto */
  background: #25D366;     /* Verde WhatsApp (ou dourado se alterado) */
  color: white;            /* Texto branco */
  padding: 8px 16px;       /* Espaçamento interno */
  border-radius: 24px;     /* Muito arredondado (formato pílula) */
  font-size: 13px;         /* Fonte pequena */
  font-weight: 600;        /* Negrito */
  margin-bottom: 20px;     /* Espaço abaixo */
  text-decoration: none;   /* Remove sublinhado do link */
}

.whatsapp-badge svg { width: 18px; height: 18px; fill: white; }

.hero-right h1 {
  font-size: 28px;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 6px;
  line-height: 1.2;
}

.hero-phone {
  font-size: 26px;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 6px;
  font-family: 'Playfair Display', serif;
}

.hero-hours {
  font-size: 13px;
  color: rgba(255,255,255,0.7);
  margin-bottom: 20px;
}

/* ===== LISTA DE BENEFÍCIOS =====
   Lista com checkmarks (marcas de verificação). */
.hero-checks {
  list-style: none;      /* Remove bullets padrão */
  margin-bottom: 24px;   /* Espaço abaixo da lista */
}

.hero-checks li {
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(255,255,255,0.9);
  font-size: 14px;
  margin-bottom: 8px;
}

/* Ícone de check antes de cada item.
   ::before cria um elemento antes do conteúdo do <li>.
   content: '✓' insere o símbolo de check (✓).
   border-radius: 50% cria um círculo perfeito. */
.hero-checks li::before {
  content: '✓';                 /* Símbolo de check */
  width: 22px;                   /* Largura do círculo */
  height: 22px;                  /* Altura do círculo */
  background: var(--secondary);  /* Fundo dourado */
  border-radius: 50%;            /* Círculo perfeito (50% = metade da largura/altura) */
  display: flex;                 /* Permite centralizar o símbolo */
  align-items: center;           /* Centraliza verticalmente */
  justify-content: center;       /* Centraliza horizontalmente */
  font-size: 12px;               /* Tamanho do símbolo */
  font-weight: 700;              /* Negrito */
  flex-shrink: 0;                /* Não encolhe se faltar espaço */
  color: white;                  /* Cor do símbolo */
}

.hero-logo-bottom {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
}

.hero-logo-bottom .logo-icon {
  width: 42px;
  height: 42px;
  font-size: 16px;
}

.hero-logo-bottom strong {
  font-family: 'Playfair Display', serif;
  color: var(--white);
  font-size: 15px;
}

.hero-logo-bottom span {
  font-size: 10px;
  color: var(--secondary);
  letter-spacing: 1px;
  text-transform: uppercase;
}

/* ===== WORLD SECTION ===== */
.world-section {
  background: #f0ead8;
  padding: 50px 0;
}

.world-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 50px;
  align-items: center;
}

.world-map-area img {
  width: 100%;
  border-radius: 10px;
  object-fit: cover;
}

.world-photos {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 12px;
}

.world-photos img {
  width: 100%;
  height: 100px;
  object-fit: cover;
  border-radius: 6px;
}

.world-text h2 {
  font-size: 22px;
  color: var(--primary);
  margin-bottom: 6px;
  line-height: 1.3;
}

.world-text .subtitle {
  color: var(--secondary);
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 14px;
}

.flags { margin-bottom: 12px; font-size: 20px; letter-spacing: 4px; }

.world-text p {
  color: #4b5563;
  font-size: 14px;
  margin-bottom: 10px;
}

/* ===== ATENDIMENTO BANNER ===== */
.atend-global {
  background: var(--primary);
  color: var(--white);
  padding: 40px 0;
}

.atend-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 40px;
  align-items: center;
}

.atend-photo img {
  width: 200px;
  height: 240px;
  object-fit: cover;
  border-radius: 10px;
  border: 3px solid var(--secondary);
}

.atend-content h2 {
  font-size: 30px;
  color: var(--accent);
  margin-bottom: 12px;
}

.atend-content p {
  font-size: 14px;
  color: rgba(255,255,255,0.8);
  margin-bottom: 10px;
  max-width: 601px;
}

.btn-gold {
  display: inline-block;
  background: var(--secondary);
  color: var(--white);
  padding: 12px 28px;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  margin-top: 12px;
  transition: background 0.2s;
}

.btn-gold:hover { background: var(--accent); color: var(--dark); }

/* ===== CTA BANNER ===== */
.cta-banner {
  background: var(--secondary);
  padding: 18px 0;
}

.cta-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}

.cta-inner h3 {
  color: var(--white);
  font-size: 19px;
  font-family: 'Playfair Display', serif;
}

.btn-white {
  background: var(--white);
  color: var(--secondary);
  padding: 10px 24px;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
}

/* ===== SERVIÇOS ===== */
#servicos {
  background: var(--light-gray);
  padding: 60px 0;
}

.section-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}

.section-label {
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--secondary);
  margin-bottom: 6px;
}

.section-title {
  font-size: 29px;
  color: var(--primary);
  margin-bottom: 36px;
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.service-card {
  background: var(--white);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 2px 10px rgba(0,0,0,0.08);
  transition: transform 0.3s ease;
}

.service-card:hover {
  transform: translateY(-5px);
}

.service-card img {
  width: 100%;
  height: 181px;
  object-fit: cover;
}

.service-card-body {
  padding: 20px;
}

.service-card-body h3 {
  font-size: 17px;
  color: var(--primary);
  margin-bottom: 8px;
}

.service-card-body p {
  font-size: 14px;
  color: var(--gray);
  margin-bottom: 14px;
}

.btn-outline {
  display: inline-block;
  border: 2px solid var(--secondary);
  color: var(--secondary);
  padding: 8px 20px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s;
}

.btn-outline:hover {
  background: var(--secondary);
  color: var(--white);
}

/* ===== QUEM SOMOS ===== */
#sobre {
  padding: 70px 0;
  background: var(--white);
}

.sobre-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px;
  align-items: center;
}

.sobre-text .section-label { margin-bottom: 6px; }

.sobre-text .section-title {
  font-size: 33px;
  margin-bottom: 16px;
}

.sobre-text p {
  color: #4b5563;
  font-size: 16px;
  margin-bottom: 10px;
}

.sobre-checks {
  list-style: none;
  margin-top: 16px;
  margin-bottom: 20px;
}

.sobre-checks li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 15px;
  color: var(--text);
  margin-bottom: 8px;
  font-weight: 500;
}

.sobre-checks li::before {
  content: '✓';
  color: var(--green);
  font-weight: 700;
  font-size: 16px;
}

.sobre-image-area {
  position: relative;
}

.sobre-image-area img {
  width: 100%;
  border-radius: 12px;
  object-fit: cover;
  height: 421px;
}

.sobre-badge {
  position: absolute;
  bottom: -18px;
  left: -18px;
  background: var(--secondary);
  color: var(--white);
  border-radius: 10px;
  padding: 16px 20px;
  font-family: 'Playfair Display', serif;
  font-size: 14px;
  font-weight: 700;
  text-align: center;
  box-shadow: 0 4px 16px rgba(0,0,0,0.2);
}

.sobre-badge strong {
  display: block;
  font-size: 29px;
  line-height: 1;
}

/* ===== EMPRESA INFO ===== */
.empresa-section {
  background: var(--light-gray);
  padding: 60px 0;
}

.empresa-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 40px;
}

.empresa-col h3 {
  font-size: 17px;
  color: var(--primary);
  font-weight: 700;
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--secondary);
  display: inline-block;
}

.empresa-col p, .empresa-col li {
  font-size: 14px;
  color: #4b5563;
  line-height: 1.8;
  list-style: none;
}

.empresa-col li::before {
  content: '▸ ';
  color: var(--secondary);
  font-size: 13px;
}

.empresa-col .phone-big {
  font-family: 'Playfair Display', serif;
  font-size: 23px;
  color: var(--primary);
  font-weight: 700;
  display: block;
  margin-bottom: 4px;
}

.empresa-col .phone-small {
  font-size: 19px;
  color: var(--secondary);
  font-weight: 600;
  display: block;
}

/* ===== CTA WHATSAPP ===== */
.cta-whatsapp {
  background: #1a2e4a;
  padding: 18px 0;
}

.cta-whatsapp .cta-inner h3 { color: var(--accent); }

.btn-green {
  background: #25D366;
  color: var(--white);
  padding: 10px 24px;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
}

/* ===== PAÍSES ===== */
#paises {
  background: linear-gradient(135deg, #1a2332 0%, #2d3748 100%);
  padding: 80px 0;
}

.paises-intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  margin-bottom: 50px;
  align-items: center;
}

@media (max-width: 768px) {
  .paises-intro {
    grid-template-columns: 1fr;
    gap: 20px;
    margin-bottom: 30px;
  }
  
  .paises-text h1 {
    font-size: 33px;
  }
  
  .paises-map {
    display: none;
  }
}

.paises-text h2 {
  font-size: 15px;
  color: var(--secondary);
  text-transform: uppercase;
  letter-spacing: 2px;
  font-weight: 600;
  margin-bottom: 6px;
}

.paises-text h1 {
  font-size: 45px;
  color: var(--white);
  line-height: 1.1;
  margin-bottom: 14px;
}

.paises-text p {
  font-size: 15px;
  color: rgba(255, 255, 255, 0.8);
}

.paises-map img {
  width: 100%;
  border-radius: 10px;
  filter: saturate(0.7);
  object-fit: cover;
  height: 261px;
}

/* Card único com todos os países */
.pais-card-unico {
  max-width: 1200px;
  margin: 0 auto;
  border-radius: 15px;
  backdrop-filter: blur(15px);
  background: rgba(173, 173, 173, 0.05);
  box-shadow: inset 0 0 20px rgba(255, 255, 255, 0.1),
    inset 0 0 5px rgba(255, 255, 255, 0.15), 
    0 5px 15px rgba(0, 0, 0, 0.3);
  transition: 0.5s;
  padding: 2rem;
}

.pais-card-unico:hover {
  background: rgba(173, 173, 173, 0.08);
}

.pais-card-list-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 1.2rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

@media (max-width: 1400px) {
  .pais-card-list-grid {
    grid-template-columns: repeat(6, 1fr);
  }
}

@media (max-width: 1200px) {
  .pais-card-list-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media (max-width: 900px) {
  .pais-card-list-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 600px) {
  .pais-card-list-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 0.8rem;
  }
  
  .pais-card-unico {
    padding: 0.8rem;
  }
}

.pais-card-item {
  cursor: pointer;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 10px;
  border-radius: 10px;
  transition: all 0.3s;
  text-align: center;
}

.pais-flag {
  font-size: 41px;
  transition: all 0.3s;
  padding: 0.5rem;
  height: 61px;
  width: 61px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: inset 0 0 20px rgba(255, 255, 255, 0.2),
    inset 0 0 5px rgba(255, 255, 255, 0.3), 
    0 5px 5px rgba(0, 0, 0, 0.2);
  flex-shrink: 0;
}

@media (max-width: 600px) {
  .pais-flag {
    font-size: 33px;
    height: 51px;
    width: 51px;
    padding: 0.3rem;
  }
}

.pais-nome {
  opacity: 1;
  color: rgba(255, 255, 255, 0.9);
  font-size: 16px;
  font-weight: 500;
  transition: all 0.3s;
  word-break: break-word;
  line-height: 1.2;
}

@media (max-width: 600px) {
  .pais-nome {
    font-size: 14px;
    font-size: 13px;
  }
}

.pais-card-item span {
  opacity: 0;
  position: absolute;
  top: 10px;
  left: 50%;
  transform: translateX(-50%);
  border-radius: 50%;
  transition: all 0.3s;
  height: 60px;
  width: 60px;
  background: rgba(196, 154, 60, 0.3);
  box-shadow: inset 0 0 20px rgba(255, 255, 255, 0.2),
    inset 0 0 5px rgba(255, 255, 255, 0.3), 
    0 5px 5px rgba(0, 0, 0, 0.2);
}

@media (max-width: 600px) {
  .pais-card-item span {
    height: 50px;
    width: 50px;
  }
}

.pais-card-item:hover span {
  opacity: 1;
}

.pais-card-item:hover span:nth-child(1) {
  opacity: 0.2;
}

.pais-card-item:hover span:nth-child(2) {
  opacity: 0.4;
  transform: translate(-50%, -5px) translateX(5px);
}

.pais-card-item:hover span:nth-child(3) {
  opacity: 0.6;
  transform: translate(-50%, -10px) translateX(10px);
}

.pais-card-item:hover .pais-flag {
  transform: translateY(-10px);
}

.pais-card-item:hover .pais-nome {
  color: var(--secondary);
  font-weight: 600;
}

/* ===== MODAL DE PAÍSES ===== */
.modal-pais {
  display: none;
  position: fixed;
  z-index: 9999;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  align-items: center;
  justify-content: center;
  animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

.modal-pais-content {
  background-color: var(--white);
  padding: 40px 50px;
  border-radius: 12px;
  box-shadow: 0 10px 40px rgba(0,0,0,0.2);
  text-align: center;
  position: relative;
  max-width: 400px;
  width: 90%;
  animation: slideUp 0.3s ease;
}

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

.modal-pais-close {
  position: absolute;
  top: 15px;
  right: 20px;
  font-size: 32px;
  font-weight: 300;
  color: var(--gray);
  cursor: pointer;
  transition: color 0.3s ease;
  line-height: 1;
}

.modal-pais-close:hover {
  color: var(--primary);
}

.modal-pais-content h3 {
  font-family: 'Playfair Display', serif;
  font-size: 28px;
  color: var(--primary);
  margin-bottom: 20px;
  font-weight: 700;
}

.modal-pais-valor {
  font-family: 'Playfair Display', serif;
  font-size: 48px;
  font-weight: 700;
  color: var(--secondary);
  margin: 20px 0;
  letter-spacing: -1px;
}

.modal-pais-obs {
  font-size: 11px;
  color: var(--gray);
  font-style: italic;
  margin-top: 10px;
}

/* ===== DIRETOR ===== */
.diretor-section {
  background: var(--dark);
  color: var(--white);
  padding: 60px 0;
  text-align: center;
}

.diretor-inner {
  max-width: 700px;
  margin: 0 auto;
  padding: 0 24px;
}

.diretor-section .section-label { color: var(--secondary); }

.diretor-section h2 {
  font-size: 28px;
  color: var(--white);
  margin-bottom: 8px;
}

.diretor-section p {
  font-size: 14px;
  color: rgba(255,255,255,0.7);
  margin-bottom: 20px;
}

.director-phone {
  font-family: 'Playfair Display', serif;
  font-size: 38px;
  color: var(--accent);
  font-weight: 700;
  display: block;
  margin-bottom: 6px;
}

.director-label {
  font-size: 13px;
  color: rgba(255,255,255,0.6);
  margin-bottom: 24px;
}

.diretor-buttons {
  display: flex;
  gap: 16px;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 24px;
}

.diretor-buttons .btn-gold {
  flex: 0 1 auto;
  min-width: 200px;
}

@media (max-width: 600px) {
  .diretor-buttons {
    flex-direction: column;
    gap: 12px;
  }
  
  .diretor-buttons .btn-gold {
    width: 100%;
    max-width: 300px;
  }
}

/* ===== MOBILE BOTTOM MENU ===== */
.mobile-bottom-menu {
  display: none;
}

@media (max-width: 768px) {
  .mobile-bottom-menu {
    position: fixed;
    left: 50%;
    bottom: 12px;
    bottom: calc(12px + env(safe-area-inset-bottom));
    transform: translateX(-50%);
    width: calc(100% - 20px);
    max-width: 520px;
    backdrop-filter: blur(12px) saturate(180%) contrast(200%);
    -webkit-backdrop-filter: blur(12px) saturate(180%) contrast(200%);
    background: rgba(196, 154, 60, 0.5);
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
    padding: 8px;
    border-radius: 99rem;
    display: flex;
    justify-content: center;
    gap: 8px;
    z-index: 9998;
  }

  .mobile-bottom-menu::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    box-shadow:
      inset 2px 2px 5px -2px rgba(255, 255, 255, 0.4),
      inset -2px -2px 5px 2px rgba(255, 255, 255, 0.4),
      inset 0 -2px 0 rgba(255, 255, 255, 0.2);
    pointer-events: none;
    z-index: -1;
  }

  .mobile-bottom-menu a {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1 1 0;
    min-width: 0;
    text-decoration: none;
    padding: 10px 6px;
    border-radius: 999rem;
    -webkit-tap-highlight-color: transparent;
    transition:
      background 0.18s ease,
      color 0.18s ease,
      transform 0.18s ease,
      box-shadow 0.3s ease-in-out;
  }

  /* Ícones em verde */
  .mobile-bottom-menu a svg {
    width: 1.4rem;
    height: 1.4rem;
    color: #2d7a4f;  /* Verde */
  }

  /* Textos em vermelho */
  .mobile-bottom-menu a span {
    font-size: 0.8rem;
    font-weight: 600;
    line-height: 1;
    margin-top: 4px;
    color: #dc2626;  /* Vermelho */
  }

  .mobile-bottom-menu a:hover {
    background-color: rgba(255, 255, 255, 30%);
    box-shadow:
      inset 2px 2px 5px -2px rgba(255, 255, 255, 0.4),
      inset -2px -1px 5px 0 rgba(255, 255, 255, 0.4),
      inset 0 -2px 0 rgba(255, 255, 255, 0.2);
  }

  .mobile-bottom-menu a:hover svg {
    color: #1e5a3a;  /* Verde mais escuro ao hover */
  }

  .mobile-bottom-menu a:hover span {
    color: #b91c1c;  /* Vermelho mais escuro ao hover */
  }

  .mobile-bottom-menu a.active {
    background: rgba(255, 255, 255, 70%);  /* Fundo mais opaco */
  }

  .mobile-bottom-menu a.active svg {
    color: #2d7a4f;  /* Verde mantém */
  }

  .mobile-bottom-menu a.active span {
    color: #dc2626;  /* Vermelho mantém */
  }

  .mobile-bottom-menu a:active {
    transform: scale(0.98);
  }
  
  body {
    padding-bottom: 80px;
  }
}

/* ===== FOOTER ===== */
footer {
  background: var(--light);
  color: var(--text);
  padding: 50px 0 20px;
}

.footer-grid {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  display: grid;
  grid-template-columns: 1.5fr 1fr 1.5fr 1fr;
  gap: 36px;
  margin-bottom: 30px;
}

.footer-col h4 {
  font-family: 'Playfair Display', serif;
  font-size: 14px;
  color: var(--primary);
  margin-bottom: 12px;
  font-weight: 700;
}

.footer-col p, .footer-col a, .footer-col li {
  font-size: 14px;
  color: var(--text);
  text-decoration: none;
  list-style: none;
  line-height: 2;
}

.footer-col a:hover { color: var(--secondary); }

.footer-badges {
  max-width: 1200px;
  margin: 30px auto 0;
  padding: 20px 24px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  flex-wrap: nowrap;
}

/* Links das badges do footer */
.footer-badges a {
  display: inline-block;
  text-decoration: none;
  transition: transform 0.3s ease;
}

.footer-badges a:hover {
  transform: scale(1.05);
}

.footer-badges img {
  height: 80px;
  width: auto;
  object-fit: contain;
  max-width: 100%;
}

/* Separador entre badges (apenas desktop) */
.badge-separator {
  display: none;
  color: var(--secondary);
  font-size: 24px;
  font-weight: 700;
  margin: 0 20px;
  align-self: center;
}

@media (min-width: 769px) {
  .badge-separator {
    display: inline-block;
  }
}

@media (max-width: 768px) {
  .footer-badges {
    gap: 10px;
    padding: 20px 10px;
  }
  
  .footer-badges img {
    height: 60px;
    max-width: 30%;
  }

  .badge-separator {
    display: none;
  }
}

.footer-bottom {
  max-width: 1200px;
  margin: 0 auto;
  padding: 18px 24px 0;
  border-top: 1px solid rgba(0,0,0,0.1);
  text-align: center;
  font-size: 12px;
  color: var(--gray);
}

.footer-selo {
  background: var(--secondary);
  border-radius: 6px;
  padding: 8px 14px;
  font-size: 12px;
  font-weight: 700;
  color: var(--white);
  text-align: center;
  margin-top: 10px;
}

.badge-24h {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,0.1);
  border-radius: 20px;
  padding: 4px 12px;
  font-size: 12px;
  color: rgba(255,255,255,0.8);
  margin-top: 8px;
}

.logo-icon {
  width: 54px;
  height: 54px;
  background: var(--primary);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--secondary);
  font-size: 22px;
  font-weight: 900;
  font-family: 'Playfair Display', serif;
}

/* Responsive */
@media (max-width: 768px) {
  .hero-inner, .world-inner, .sobre-grid, .paises-intro,
  .empresa-grid, .footer-grid, .atend-inner {
    grid-template-columns: 1fr;
  }
  .services-grid { grid-template-columns: 1fr; }
  .hero-right h1 { font-size: 20px; }
  .paises-text h1 { font-size: 30px; }
}
