/* ================================================================
   JSOLC — SOLUÇÕES ENERGÉTICAS
   Style Guide / Design System
   Versão 1.0 · Maio 2026
   Elaborado por: Payoff Marketing

   ÍNDICE
   1.  Tokens (variáveis de design)
   2.  Reset & Base
   3.  Tipografia
   4.  Layout (container, grid, flex helpers)
   5.  Botões
   6.  Formulários
   7.  Componentes de navegação (topbar, header, nav)
   8.  Badges & Tags
   9.  Cards
   10. Secções reutilizáveis (hero, steps, cta, dgeg band)
   11. Testimonials
   12. FAQ (accordion)
   13. Footer
   14. Utilitários
   15. Media queries (breakpoints)
================================================================ */


/* ================================================================
   1. TOKENS — Design Variables
================================================================ */

:root {

  /* --- Cores principais --- */
  --color-orange:       #E8610A;   /* CTA, destaques, hovers activos          */
  --color-orange-dark:  #C4510A;   /* Hover de botão primário                 */
  --color-orange-light: #FFF3EC;   /* Fundos suaves, badges de serviço        */
  --color-orange-alpha: rgba(232, 97, 10, 0.15); /* Overlays, glassmorphism   */

  --color-dark:         #1A1A1A;   /* Texto principal, fundos escuros (hero)  */
  --color-dark-2:       #2C2C2C;   /* Gradiente de fundo escuro               */
  --color-mid:          #444444;   /* Texto secundário, subtítulos            */
  --color-muted:        #888888;   /* Texto de apoio, meta-info               */
  --color-light:        #F7F5F2;   /* Fundos de secção alternada              */
  --color-white:        #FFFFFF;
  --color-border:       #E2DFDB;   /* Bordas de cards e inputs                */

  /* --- Cores de estado / sistema --- */
  --color-success:      #2E7D32;
  --color-warning:      #F59E0B;
  --color-error:        #C62828;
  --color-info:         #1565C0;

  /* --- Paleta de avatares / ilustrações --- */
  --color-avatar-1:     #E8610A;   /* Laranja (primário)                      */
  --color-avatar-2:     #2E7D32;   /* Verde                                   */
  --color-avatar-3:     #1565C0;   /* Azul                                    */
  --color-avatar-4:     #6A1B9A;   /* Roxo                                    */

  /* --- Tipografia --- */
  --font-base: 'Inter', 'Segoe UI', Arial, sans-serif;
  --font-size-xs:   12px;
  --font-size-sm:   13px;
  --font-size-base: 16px;
  --font-size-md:   17px;
  --font-size-lg:   18px;
  --font-size-xl:   20px;
  --font-size-2xl:  24px;
  --font-size-3xl:  28px;
  --font-size-4xl:  38px;
  --font-size-5xl:  52px;

  --font-weight-normal:    400;
  --font-weight-medium:    500;
  --font-weight-semibold:  600;
  --font-weight-bold:      700;
  --font-weight-extrabold: 800;

  --line-height-tight:   1.1;
  --line-height-snug:    1.3;
  --line-height-normal:  1.5;
  --line-height-relaxed: 1.65;

  --letter-spacing-tight:  -0.5px;
  --letter-spacing-normal:  0px;
  --letter-spacing-wide:    0.5px;
  --letter-spacing-wider:   1.5px;

  /* --- Espaçamento --- */
  --space-1:   4px;
  --space-2:   8px;
  --space-3:   12px;
  --space-4:   16px;
  --space-5:   20px;
  --space-6:   24px;
  --space-8:   32px;
  --space-10:  40px;
  --space-12:  48px;
  --space-16:  64px;
  --space-20:  80px;

  /* --- Bordas --- */
  --radius-sm:   6px;
  --radius-base: 8px;
  --radius-md:   10px;
  --radius-lg:   12px;
  --radius-xl:   16px;
  --radius-full: 9999px;

  /* --- Sombras --- */
  --shadow-sm:  0 2px 8px rgba(0, 0, 0, .06);
  --shadow-md:  0 4px 24px rgba(0, 0, 0, .10);
  --shadow-lg:  0 12px 48px rgba(0, 0, 0, .14);
  --shadow-cta: 0 4px 16px rgba(232, 97, 10, .35);

  /* --- Transições --- */
  --transition-fast:   all .15s ease;
  --transition-base:   all .2s ease;
  --transition-slow:   all .3s ease;

  /* --- Z-index --- */
  --z-base:    1;
  --z-above:   10;
  --z-header:  100;
  --z-modal:   1000;
  --z-tooltip: 2000;

  /* --- Layout --- */
  --container-max:  1160px;
  --container-pad:  24px;
  --section-pad-y:  80px;
}


/* ================================================================
   2. RESET & BASE
================================================================ */

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

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-base);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-normal);
  color: var(--color-dark);
  background: var(--color-white);
  line-height: var(--line-height-normal);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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

a { color: inherit; text-decoration: none; }

ul, ol { list-style: none; }

button { font-family: var(--font-base); cursor: pointer; }

input, select, textarea { font-family: var(--font-base); }


/* ================================================================
   3. TIPOGRAFIA
================================================================ */

/* Escala de headings */
h1, .h1 {
  font-size: clamp(32px, 4.5vw, var(--font-size-5xl));
  font-weight: var(--font-weight-extrabold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
}

h2, .h2 {
  font-size: clamp(26px, 3.5vw, var(--font-size-4xl));
  font-weight: var(--font-weight-extrabold);
  line-height: var(--line-height-tight);
  letter-spacing: -0.4px;
}

h3, .h3 {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-snug);
}

h4, .h4 {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-snug);
}

/* Rótulo de secção — ex: "PROCESSO SIMPLES" */
.section-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wider);
  color: var(--color-orange);
  margin-bottom: var(--space-3);
  display: block;
}

/* Subtítulo de secção */
.section-sub {
  font-size: var(--font-size-md);
  color: var(--color-mid);
  line-height: var(--line-height-relaxed);
  max-width: 560px;
}

/* Destaque inline (itálico colorido) */
em.highlight {
  font-style: normal;
  color: var(--color-orange);
}

/* Texto de apoio / nota */
.text-note {
  font-size: var(--font-size-xs);
  color: var(--color-muted);
  line-height: var(--line-height-relaxed);
}

/* Tamanhos utilitários */
.text-xs   { font-size: var(--font-size-xs); }
.text-sm   { font-size: var(--font-size-sm); }
.text-base { font-size: var(--font-size-base); }
.text-lg   { font-size: var(--font-size-lg); }
.text-xl   { font-size: var(--font-size-xl); }

/* Pesos utilitários */
.font-medium    { font-weight: var(--font-weight-medium); }
.font-semibold  { font-weight: var(--font-weight-semibold); }
.font-bold      { font-weight: var(--font-weight-bold); }
.font-extrabold { font-weight: var(--font-weight-extrabold); }

/* Cores de texto utilitárias */
.text-orange { color: var(--color-orange); }
.text-mid    { color: var(--color-mid); }
.text-muted  { color: var(--color-muted); }
.text-white  { color: var(--color-white); }


/* ================================================================
   4. LAYOUT
================================================================ */

/* Container base */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-pad);
}

/* Container estreito — para conteúdo editorial */
.container-narrow {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 var(--container-pad);
}

/* Secção genérica */
.section {
  padding: var(--section-pad-y) 0;
}

.section--light  { background: var(--color-light); }
.section--dark   { background: var(--color-dark); color: var(--color-white); }
.section--orange { background: var(--color-orange); color: var(--color-white); }

/* Header de secção centrado */
.section-header {
  text-align: center;
  margin-bottom: 52px;
}

.section-header .section-sub {
  margin: 16px auto 0;
}

/* Grids responsivos */
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-6); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); }

/* Grid hero (conteúdo + form lateral) */
.grid-hero {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 60px;
  align-items: start;
}

/* Flex helpers */
.flex         { display: flex; }
.flex-center  { display: flex; align-items: center; justify-content: center; }
.flex-between { display: flex; align-items: center; justify-content: space-between; }
.flex-gap-2   { gap: var(--space-2); }
.flex-gap-4   { gap: var(--space-4); }
.flex-gap-6   { gap: var(--space-6); }
.flex-wrap    { flex-wrap: wrap; }


/* ================================================================
   5. BOTÕES
================================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 12px 24px;
  border-radius: var(--radius-base);
  font-family: var(--font-base);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  line-height: 1;
  cursor: pointer;
  transition: var(--transition-base);
  border: 2px solid transparent;
  white-space: nowrap;
  text-decoration: none;
}

/* Primário — laranja sólido */
.btn--primary {
  background: var(--color-orange);
  color: var(--color-white);
  border-color: var(--color-orange);
}
.btn--primary:hover {
  background: var(--color-orange-dark);
  border-color: var(--color-orange-dark);
  transform: translateY(-1px);
  box-shadow: var(--shadow-cta);
}

/* Secundário — contorno laranja */
.btn--outline {
  background: transparent;
  color: var(--color-orange);
  border-color: var(--color-orange);
}
.btn--outline:hover {
  background: var(--color-orange);
  color: var(--color-white);
}

/* Ghost — para fundos escuros */
.btn--ghost {
  background: transparent;
  color: var(--color-white);
  border-color: rgba(255, 255, 255, 0.4);
}
.btn--ghost:hover {
  border-color: var(--color-white);
  background: rgba(255, 255, 255, 0.1);
}

/* Branco — para uso em fundos coloridos */
.btn--white {
  background: var(--color-white);
  color: var(--color-orange);
  border-color: var(--color-white);
  font-weight: var(--font-weight-extrabold);
}
.btn--white:hover {
  background: var(--color-light);
  transform: translateY(-1px);
}

/* Dark — para contextos claros com acção neutra */
.btn--dark {
  background: var(--color-dark);
  color: var(--color-white);
  border-color: var(--color-dark);
}
.btn--dark:hover {
  background: #333;
  border-color: #333;
}

/* Tamanhos */
.btn--sm { padding: 8px 16px; font-size: var(--font-size-xs); border-radius: var(--radius-sm); }
.btn--lg { padding: 16px 32px; font-size: var(--font-size-base); border-radius: var(--radius-md); }
.btn--xl { padding: 18px 40px; font-size: var(--font-size-md); border-radius: var(--radius-md); }
.btn--full { width: 100%; }


/* ================================================================
   6. FORMULÁRIOS
================================================================ */

.form-group {
  margin-bottom: var(--space-4);
}

.form-group label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-mid);
  margin-bottom: var(--space-1);
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-base);
  font-size: var(--font-size-base);
  font-family: var(--font-base);
  color: var(--color-dark);
  background: var(--color-white);
  transition: border-color .2s;
  outline: none;
  -webkit-appearance: none;
}

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

.form-group input::placeholder,
.form-group textarea::placeholder {
  color: #bbb;
}

.form-group textarea {
  resize: vertical;
  min-height: 100px;
}

/* Nota sob formulário */
.form-note {
  font-size: var(--font-size-xs);
  color: var(--color-muted);
  text-align: center;
  margin-top: var(--space-3);
}

/* Card de formulário (hero form, sidebar forms) */
.form-card {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--color-border);
}

.form-card h3 {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-extrabold);
  margin-bottom: var(--space-1);
  color: var(--color-dark);
}

.form-card > p {
  font-size: var(--font-size-sm);
  color: var(--color-mid);
  margin-bottom: var(--space-6);
}


/* ================================================================
   7. NAVEGAÇÃO
================================================================ */

/* Topbar — faixa de contacto rápido */
.topbar {
  background: var(--color-dark);
  color: #ccc;
  font-size: var(--font-size-sm);
  padding: var(--space-2) 0;
  text-align: center;
}
.topbar strong { color: var(--color-white); }
.topbar a { color: #F9A55A; font-weight: var(--font-weight-semibold); }
.topbar a:hover { color: var(--color-orange); }

/* Header sticky */
.site-header {
  background: var(--color-white);
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  box-shadow: var(--shadow-sm);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px var(--container-pad);
  max-width: var(--container-max);
  margin: 0 auto;
  gap: var(--space-4);
}

/* Logo */
.logo {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
}

.logo__mark {
  width: 44px;
  height: 44px;
  background: var(--color-orange);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.logo__mark svg {
  width: 26px;
  height: 26px;
  fill: var(--color-white);
}

.logo__text {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}

.logo__text strong {
  font-size: 18px;
  font-weight: var(--font-weight-extrabold);
  color: var(--color-dark);
  letter-spacing: -0.3px;
}

.logo__text span {
  font-size: var(--font-size-xs);
  color: var(--color-mid);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
}

/* ── Nav principal (dropdown) ── */
.main-nav { display: flex; align-items: center; }

.nav-list {
  display: flex; gap: 4px; align-items: center;
  list-style: none; margin: 0; padding: 0;
}

.nav-link {
  display: flex; align-items: center; gap: 4px;
  padding: 8px 14px; border-radius: var(--radius-sm);
  font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold);
  color: var(--color-mid);
  background: none; border: none; cursor: pointer;
  transition: color .2s, background .2s;
  white-space: nowrap; font-family: var(--font-base);
  text-decoration: none;
}
.nav-link:hover,
.nav-item:hover > .nav-link { color: var(--color-orange); background: var(--color-orange-light); }

.nav-chevron { font-size: 10px; transition: transform .2s; display: inline-block; }
.nav-item:hover > .nav-link .nav-chevron { transform: rotate(180deg); }

/* Dropdown (nível 2) */
.nav-item { position: relative; }

.dropdown {
  position: absolute; top: calc(100% + 6px); left: 0;
  background: var(--color-white); border: 1px solid var(--color-border);
  border-radius: 10px; box-shadow: 0 8px 32px rgba(0,0,0,.12);
  min-width: 220px; padding: 8px; list-style: none; margin: 0;
  opacity: 0; visibility: hidden; transform: translateY(6px);
  transition: opacity .18s, transform .18s, visibility .18s;
  z-index: var(--z-header);
}
.nav-item:hover > .dropdown {
  opacity: 1; visibility: visible; transform: translateY(0);
}

.dropdown__link {
  display: block; padding: 10px 14px; border-radius: var(--radius-sm);
  font-size: var(--font-size-sm); font-weight: var(--font-weight-medium);
  color: var(--color-dark); transition: background .15s, color .15s;
  white-space: nowrap;
}
.dropdown__link:hover { background: var(--color-orange-light); color: var(--color-orange); }

/* ── Hamburger (mobile) ── */
.nav-hamburger {
  display: none; flex-direction: column; justify-content: center;
  gap: 5px; width: 40px; height: 40px; padding: 8px;
  background: none; border: none; cursor: pointer; border-radius: var(--radius-sm);
  flex-shrink: 0;
}
.nav-hamburger span {
  display: block; height: 2px; background: var(--color-dark); border-radius: 2px;
}
.nav-hamburger:hover { background: #f5f5f5; }

/* ── Painel mobile ── */
.mobile-nav {
  display: none; position: fixed; inset: 0;
  background: var(--color-white); z-index: 300;
  padding: 80px 24px 32px; overflow-y: auto;
  flex-direction: column;
}
.mobile-nav.is-open { display: flex; }

.mobile-nav__close {
  position: absolute; top: 16px; right: 16px;
  width: 40px; height: 40px; border-radius: 50%;
  background: #f5f5f5; border: none; cursor: pointer;
  font-size: 20px; display: flex; align-items: center; justify-content: center;
  line-height: 1;
}

.mobile-nav__item { border-bottom: 1px solid var(--color-border); }

.mobile-nav__link {
  display: flex; align-items: center;
  padding: 16px 4px; font-size: 16px; font-weight: 600; color: var(--color-dark);
  background: none; border: none; cursor: pointer; width: 100%;
  font-family: var(--font-base); text-align: left; text-decoration: none;
}
.mobile-nav__link:hover { color: var(--color-orange); }

.mobile-nav__sub { display: none; padding-left: 16px; }
.mobile-nav__sub.is-open { display: block; }

.mobile-nav__sub-link {
  display: block; padding: 12px 4px;
  font-size: 15px; color: var(--color-mid); font-weight: 500;
  border-bottom: 1px solid #f5f5f5; text-decoration: none;
}
.mobile-nav__sub-link:hover { color: var(--color-orange); }

/* Header CTA group */
.header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.phone-link {
  display: flex; align-items: center; gap: 5px;
  font-size: 15px; font-weight: var(--font-weight-bold);
  color: var(--color-dark); white-space: nowrap; transition: color .2s;
}
.phone-link:hover { color: var(--color-orange); }
.phone-icon { font-size: 16px; }
.phone-text { font-size: 15px; }


/* ================================================================
   8. BADGES & TAGS
================================================================ */

.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 6px 14px;
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  letter-spacing: .3px;
}

/* Badge hero — fundo escuro com borda laranja */
.badge--hero {
  background: var(--color-orange-alpha);
  border: 1px solid rgba(232, 97, 10, 0.35);
  color: #F9A55A;
}

/* Badge de destaque suave — para cards e tags de serviço */
.badge--soft {
  background: var(--color-orange-light);
  color: var(--color-orange);
  border: none;
}

/* Badge de sucesso */
.badge--success {
  background: rgba(46, 125, 50, .12);
  color: var(--color-success);
}

/* Tag (menor, sem borda) */
.tag {
  display: inline-block;
  background: var(--color-orange-light);
  color: var(--color-orange);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  padding: 4px 12px;
  border-radius: var(--radius-full);
}

/* Stars (avaliações) */
.stars {
  color: var(--color-warning);
  font-size: var(--font-size-base);
  letter-spacing: 2px;
}


/* ================================================================
   9. CARDS
================================================================ */

/* Card base */
.card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  transition: var(--transition-base);
}

.card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}

/* Card com padding padrão */
.card--padded { padding: var(--space-8) var(--space-6); }
.card--padded-sm { padding: var(--space-6) var(--space-5); }

/* Step card (processo 3 passos) */
.step-card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: 36px 28px;
  text-align: center;
  border: 1px solid var(--color-border);
  transition: var(--transition-base);
}

.step-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-4px);
}

.step-card__num {
  width: 56px;
  height: 56px;
  background: var(--color-orange);
  color: var(--color-white);
  border-radius: var(--radius-full);
  font-size: 22px;
  font-weight: var(--font-weight-extrabold);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-5);
}

.step-card h3 {
  font-size: 19px;
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-3);
}

.step-card p {
  font-size: 15px;
  color: var(--color-mid);
  line-height: var(--line-height-relaxed);
}

/* Service card */
.service-card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  border: 1px solid var(--color-border);
  transition: var(--transition-base);
}

.service-card:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--color-orange);
  transform: translateY(-3px);
}

.service-card__icon {
  font-size: 36px;
  margin-bottom: var(--space-4);
}

.service-card h3 {
  font-size: 17px;
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-2);
}

.service-card p {
  font-size: 14px;
  color: var(--color-mid);
  line-height: var(--line-height-relaxed);
}

.service-card__link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: var(--space-4);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-orange);
  transition: gap .15s;
}

.service-card__link:hover { gap: 8px; }

/* Testimonial card */
.testimonial-card {
  background: var(--color-light);
  border-radius: var(--radius-lg);
  padding: 28px;
  border: 1px solid var(--color-border);
}

.testimonial-card blockquote {
  font-size: 15px;
  font-style: italic;
  color: var(--color-dark);
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--space-5);
}

.testimonial-author {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.testimonial-author__avatar {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--font-weight-extrabold);
  font-size: 15px;
  color: var(--color-white);
  flex-shrink: 0;
}

.testimonial-author__info strong {
  display: block;
  font-size: 14px;
  font-weight: var(--font-weight-bold);
}

.testimonial-author__info span {
  font-size: var(--font-size-sm);
  color: var(--color-mid);
}

/* Stat card (strip de números) */
.stat-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.stat-item strong {
  font-size: 26px;
  font-weight: var(--font-weight-extrabold);
  color: var(--color-white);
}

.stat-item span {
  font-size: var(--font-size-sm);
  color: rgba(255, 255, 255, .8);
  line-height: 1.3;
}

/* DGEG shield card */
.dgeg-shield-card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.dgeg-shield-card__icon {
  width: 64px;
  height: 64px;
  background: var(--color-orange);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  flex-shrink: 0;
}

.dgeg-shield-card strong {
  display: block;
  font-size: 18px;
  font-weight: var(--font-weight-extrabold);
  margin-bottom: var(--space-1);
}

.dgeg-shield-card p {
  font-size: 14px;
  color: #999;
  line-height: var(--line-height-relaxed);
  max-width: 380px;
}


/* ================================================================
   10. SECÇÕES REUTILIZÁVEIS
================================================================ */

/* Hero */
.hero {
  background: linear-gradient(135deg, var(--color-dark) 0%, var(--color-dark-2) 100%);
  color: var(--color-white);
  padding: var(--section-pad-y) 0 0;
  overflow: hidden;
  position: relative;
}

.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 70% 0%, rgba(232, 97, 10, .18) 0%, transparent 60%),
    radial-gradient(ellipse at 0% 100%, rgba(232, 97, 10, .10) 0%, transparent 50%);
  pointer-events: none;
}

.hero__inner {
  position: relative;
  z-index: var(--z-base);
}

.hero h1 em {
  font-style: normal;
  color: var(--color-orange);
}

.hero__sub {
  font-size: 18px;
  color: #B0ADA9;
  line-height: var(--line-height-relaxed);
  margin-bottom: var(--space-8);
  max-width: 520px;
}

.hero__sub strong { color: var(--color-white); }

.hero__actions {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-bottom: var(--space-12);
}

/* Trust row (bullets de confiança) */
.trust-row {
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
}

.trust-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: #888;
}

.trust-item__dot {
  width: 8px;
  height: 8px;
  background: var(--color-orange);
  border-radius: var(--radius-full);
  flex-shrink: 0;
}

/* Stats strip (faixa de números — dentro do hero) */
.stats-strip {
  background: var(--color-orange);
  padding: 16px var(--container-pad);
  display: flex;
  gap: 40px;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}

.stats-strip__divider {
  width: 1px;
  height: 36px;
  background: rgba(255, 255, 255, .3);
}

/* DGEG band */
.dgeg-band {
  background: var(--color-dark);
  color: var(--color-white);
  padding: 40px 0;
}

.dgeg-band__inner {
  display: flex;
  align-items: center;
  gap: 40px;
  flex-wrap: wrap;
  justify-content: center;
}

.dgeg-band__divider {
  width: 1px;
  height: 60px;
  background: rgba(255, 255, 255, .15);
}

.dgeg-band__stats {
  display: flex;
  gap: 40px;
  flex-wrap: wrap;
}

.dgeg-stat strong {
  display: block;
  font-size: 28px;
  font-weight: var(--font-weight-extrabold);
  color: var(--color-orange);
}

.dgeg-stat span { font-size: var(--font-size-sm); color: #888; }

/* CTA section (fundo laranja) */
.cta-section {
  padding: var(--section-pad-y) 0;
  background: linear-gradient(135deg, var(--color-orange), var(--color-orange-dark));
  text-align: center;
  color: var(--color-white);
}

.cta-section h2 { margin-bottom: var(--space-4); }

.cta-section p {
  font-size: var(--font-size-lg);
  opacity: .85;
  margin-bottom: 40px;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
  line-height: var(--line-height-relaxed);
}

.cta-section__actions {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
}

/* Why section — layout 2 colunas com visual + lista */
.why-list {
  list-style: none;
  margin-top: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.why-list li {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
}

.why-list__icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  background: var(--color-orange-light);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 18px;
}

.why-list__text strong {
  display: block;
  font-size: 15px;
  font-weight: var(--font-weight-bold);
  margin-bottom: 3px;
}

.why-list__text p {
  font-size: 14px;
  color: var(--color-mid);
  line-height: var(--line-height-relaxed);
}


/* ================================================================
   11. TESTIMONIALS
================================================================ */

.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}


/* ================================================================
   12. FAQ (Accordion)
================================================================ */

.faq-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.faq-item {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.faq-item__q {
  width: 100%;
  text-align: left;
  padding: 18px 20px;
  font-size: 15px;
  font-weight: var(--font-weight-semibold);
  font-family: var(--font-base);
  background: none;
  border: none;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-dark);
  transition: background .2s;
}

.faq-item__q:hover { background: var(--color-light); }

.faq-item__q .arrow {
  font-size: var(--font-size-xs);
  color: var(--color-orange);
  transition: transform .2s;
  flex-shrink: 0;
}

.faq-item__q.open .arrow { transform: rotate(180deg); }

.faq-item__a {
  display: none;
  padding: 0 20px 18px;
  font-size: 14px;
  color: var(--color-mid);
  line-height: var(--line-height-relaxed);
}

.faq-item__a.open { display: block; }

/* JavaScript helper — adicionar ao HTML:
   function toggleFaq(btn) {
     const a = btn.nextElementSibling;
     const isOpen = btn.classList.contains('open');
     document.querySelectorAll('.faq-item__q').forEach(b => b.classList.remove('open'));
     document.querySelectorAll('.faq-item__a').forEach(a => a.classList.remove('open'));
     if (!isOpen) { btn.classList.add('open'); a.classList.add('open'); }
   }
*/


/* ================================================================
   13. FOOTER
================================================================ */

footer,
.site-footer {
  background: #111;
  color: #999;
  padding: var(--space-12) 0 var(--space-6);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 40px;
}

.footer-brand p {
  font-size: 14px;
  line-height: var(--line-height-relaxed);
  margin-top: var(--space-3);
  max-width: 240px;
}

.footer-section h4 {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  text-transform: uppercase;
  letter-spacing: var(--letter-spacing-wide);
  margin-bottom: var(--space-4);
}

.footer-section ul { display: flex; flex-direction: column; gap: var(--space-2); }

.footer-section ul li a {
  font-size: 14px;
  color: #777;
  transition: color .2s;
}

.footer-section ul li a:hover { color: var(--color-orange); }

.footer-contact p { font-size: 14px; line-height: 1.8; }
.footer-contact a { color: #F9A55A; font-weight: var(--font-weight-semibold); }
.footer-contact a:hover { color: var(--color-orange); }

.footer-bottom {
  border-top: 1px solid #222;
  padding-top: var(--space-6);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  font-size: var(--font-size-sm);
}

.footer-dgeg-badge,
.dgeg-footer {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  background: rgba(255, 255, 255, .05);
  border: 1px solid #333;
  border-radius: var(--radius-base);
  padding: 6px 14px;
  font-size: var(--font-size-xs);
  color: #aaa;
}

.footer-dgeg-badge span,
.dgeg-footer span { color: #F9A55A; font-weight: var(--font-weight-bold); }


/* ================================================================
   14. UTILITÁRIOS
================================================================ */

/* Espaçamento */
.mt-0  { margin-top: 0; }
.mt-2  { margin-top: var(--space-2); }
.mt-4  { margin-top: var(--space-4); }
.mt-6  { margin-top: var(--space-6); }
.mt-8  { margin-top: var(--space-8); }
.mt-12 { margin-top: var(--space-12); }
.mb-4  { margin-bottom: var(--space-4); }
.mb-6  { margin-bottom: var(--space-6); }
.mb-8  { margin-bottom: var(--space-8); }

/* Alinhamento de texto */
.text-center { text-align: center; }
.text-left   { text-align: left; }
.text-right  { text-align: right; }

/* Visibilidade */
.hidden       { display: none; }
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

/* Divisor horizontal */
.divider {
  border: none;
  border-top: 1px solid var(--color-border);
  margin: var(--space-8) 0;
}

/* Divider vertical (inline) */
.vdivider {
  display: inline-block;
  width: 1px;
  background: var(--color-border);
  align-self: stretch;
  flex-shrink: 0;
}

/* Overlay de fundo (gradiente laranja) */
.bg-overlay-orange::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 70% 0%, rgba(232, 97, 10, .18) 0%, transparent 60%),
    radial-gradient(ellipse at 0% 100%, rgba(232, 97, 10, .10) 0%, transparent 50%);
  pointer-events: none;
}


/* ================================================================
   15. MEDIA QUERIES
================================================================ */

/* --- Tablet landscape & desktop médio (< 1024px) --- */
@media (max-width: 1024px) {
  .grid-hero {
    grid-template-columns: 1fr;
  }

  .form-card--hero { max-width: 480px; }

  .grid-4 { grid-template-columns: repeat(2, 1fr); }

  .footer-grid { grid-template-columns: 1fr 1fr; }

  .testimonials-grid { grid-template-columns: repeat(2, 1fr); }
}

/* --- Tablet portrait (< 768px) --- */
@media (max-width: 768px) {
  :root {
    --section-pad-y: 60px;
  }

  .main-nav { display: none; }
  .nav-hamburger { display: flex; }
  .phone-text { display: none; }

  .grid-2 { grid-template-columns: 1fr; }
  .grid-3 { grid-template-columns: 1fr; }
  .grid-4 { grid-template-columns: 1fr; }

  .testimonials-grid { grid-template-columns: 1fr; }

  .stats-strip { gap: 20px; }
  .stats-strip__divider { display: none; }

  .dgeg-band__inner { flex-direction: column; text-align: center; }
  .dgeg-band__divider { width: 60px; height: 1px; }
  .dgeg-band__stats { justify-content: center; }

  .dgeg-shield-card { flex-direction: column; text-align: center; }

  .footer-grid { grid-template-columns: 1fr; }

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

  .cta-section p { font-size: var(--font-size-base); }

  .faq-inner { grid-template-columns: 1fr; }
}

/* --- Mobile (< 480px) --- */
@media (max-width: 480px) {
  :root {
    --container-pad: 16px;
    --section-pad-y: 48px;
  }

  .btn--xl { padding: 16px 28px; font-size: var(--font-size-base); }

  .hero__actions { flex-direction: column; }
  .hero__actions .btn { width: 100%; }

  .trust-row { gap: 14px; }

  .section-header { text-align: left; }
  .section-header .section-sub { margin-left: 0; }
}
