/* ==========================================================================
   Brasília Notebooks — Design System "Midnight Neon" (dark premium)
   Tema escuro sofisticado com bordas neon e brilhos ambientes.
   ========================================================================== */

:root {
  /* Base escura */
  --bg: #06060f;
  --bg-2: #0a0a16;
  --surface: #0f0f1d;
  --card: rgba(255, 255, 255, 0.035);
  --card-solid: #11111f;
  --borda: rgba(255, 255, 255, 0.09);
  --borda-forte: rgba(255, 255, 255, 0.16);

  /* Texto */
  --texto: #eef0f8;
  --texto-suave: #99a1ba;
  --texto-tenue: #6a7090;

  /* Neon */
  --neon-1: #22d3ee;   /* ciano */
  --neon-2: #a855f7;   /* violeta */
  --neon-3: #f43f9d;   /* magenta */
  --whatsapp: #25d97a;

  /* Gradientes */
  --grad-neon: linear-gradient(120deg, #22d3ee 0%, #6d8bff 48%, #a855f7 100%);
  --grad-neon-2: linear-gradient(120deg, #a855f7, #f43f9d);
  --grad-texto: linear-gradient(110deg, #5eead4 0%, #38bdf8 40%, #a855f7 100%);

  /* Glows */
  --glow-ciano: 0 0 30px rgba(34, 211, 238, 0.4);
  --glow-violeta: 0 0 34px rgba(168, 85, 247, 0.4);
  --glow-mix: 0 0 0 1px rgba(34, 211, 238, 0.2), 0 18px 50px -12px rgba(168, 85, 247, 0.45);

  /* Layout */
  --container: 1180px;
  --raio: 20px;
  --raio-sm: 14px;
  --sombra: 0 24px 60px -24px rgba(0, 0, 0, 0.8);
  --transicao: 0.3s cubic-bezier(0.2, 0.7, 0.2, 1);

  /* Tipografia */
  --fonte-titulo: "Plus Jakarta Sans", "Inter", system-ui, sans-serif;
  --fonte-corpo: "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --fonte-tech: "Space Grotesk", "Plus Jakarta Sans", sans-serif;
}

/* Reset --------------------------------------------------------------------*/
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--fonte-corpo);
  color: var(--texto);
  background: var(--bg);
  line-height: 1.6;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  position: relative;
  hyphens: none;
  -webkit-hyphens: none;
}
/* Brilhos ambientes fixos no fundo */
body::before {
  content: ""; position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background:
    radial-gradient(620px 460px at 10% 4%, rgba(34, 211, 238, 0.16), transparent 60%),
    radial-gradient(720px 520px at 92% 12%, rgba(168, 85, 247, 0.20), transparent 60%),
    radial-gradient(680px 560px at 74% 96%, rgba(244, 63, 157, 0.10), transparent 62%),
    var(--bg);
}
body::after {
  content: ""; position: fixed; inset: 0; z-index: -2; pointer-events: none; opacity: 0.4;
  background-image: linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px);
  background-size: 54px 54px;
  -webkit-mask-image: radial-gradient(circle at 50% 20%, #000, transparent 80%);
  mask-image: radial-gradient(circle at 50% 20%, #000, transparent 80%);
}
img { max-width: 100%; display: block; height: auto; }
a { color: inherit; text-decoration: none; }
ul { margin: 0; padding: 0; list-style: none; }
h1, h2, h3, h4 { font-family: var(--fonte-titulo); font-weight: 800; line-height: 1.12; color: var(--texto); margin: 0 0 0.5em; letter-spacing: -0.025em; }
p { margin: 0 0 1rem; }

::selection { background: rgba(168, 85, 247, 0.4); color: #fff; }
::-webkit-scrollbar { width: 11px; }
::-webkit-scrollbar-track { background: #06060f; }
::-webkit-scrollbar-thumb { background: linear-gradient(#22d3ee, #a855f7); border-radius: 999px; border: 3px solid #06060f; }

/* Borda neon reutilizável (via máscara) ------------------------------------*/
.neon, .card-servico, .passo, .depoimento, .stats, .faq__item, .hero__card {
  position: relative;
}
.card-servico::after, .passo::after, .depoimento::after, .stats::after, .faq__item::after, .hero__card::after {
  content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1px; pointer-events: none;
  background: var(--grad-neon);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: 0.35; transition: opacity var(--transicao);
}
.card-servico:hover::after, .passo:hover::after, .depoimento:hover::after, .faq__item[open]::after { opacity: 1; }

/* Animação de entrada ------------------------------------------------------*/
.js .reveal { opacity: 0; transform: translateY(26px); transition: opacity 0.7s ease, transform 0.7s cubic-bezier(0.2, 0.7, 0.2, 1); }
.js .reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .js .reveal { opacity: 1; transform: none; transition: none; } html { scroll-behavior: auto; } }

/* Utilitários --------------------------------------------------------------*/
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: 22px; }
.secao { padding: 96px 0; position: relative; }
.secao--suave { background: linear-gradient(180deg, rgba(255, 255, 255, 0.022), rgba(255, 255, 255, 0)); }
.secao > .container { position: relative; z-index: 1; }
.secao-cabecalho { text-align: center; max-width: 730px; margin: 0 auto 60px; }
.secao-cabecalho h2 { font-size: clamp(1.85rem, 4vw, 2.7rem); }
.secao-cabecalho p { color: var(--texto-suave); font-size: 1.1rem; }

.olho {
  display: inline-flex; align-items: center; gap: 8px; font-family: var(--fonte-tech);
  font-weight: 600; font-size: 0.78rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: #c4b5fd; margin-bottom: 18px; padding: 7px 15px; border-radius: 999px;
  background: rgba(168, 85, 247, 0.08); border: 1px solid rgba(168, 85, 247, 0.25);
  box-shadow: inset 0 0 18px rgba(168, 85, 247, 0.12);
}
.olho::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--neon-1); box-shadow: 0 0 10px 2px rgba(34, 211, 238, 0.8); }

/* Botões -------------------------------------------------------------------*/
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 15px 28px; border-radius: 999px; font-family: var(--fonte-titulo); font-weight: 700; font-size: 1rem;
  cursor: pointer; border: none; text-align: center; position: relative;
  transition: transform var(--transicao), box-shadow var(--transicao), background var(--transicao);
}
.btn:active { transform: translateY(1px); }
.btn--cta { background: var(--grad-neon); color: #06060f; box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.1), 0 10px 30px -6px rgba(34, 211, 238, 0.55), 0 10px 40px -6px rgba(168, 85, 247, 0.5); }
.btn--cta:hover { transform: translateY(-3px); box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.18), 0 14px 40px -6px rgba(34, 211, 238, 0.7), 0 14px 50px -6px rgba(168, 85, 247, 0.65); }
.btn--wpp { background: var(--whatsapp); color: #042b15; box-shadow: 0 0 26px -4px rgba(37, 217, 122, 0.7); }
.btn--wpp:hover { transform: translateY(-3px); box-shadow: 0 0 36px -2px rgba(37, 217, 122, 0.85); }
.btn--ghost { background: rgba(255, 255, 255, 0.04); color: var(--texto); border: 1px solid var(--borda-forte); backdrop-filter: blur(6px); }
.btn--ghost:hover { background: rgba(255, 255, 255, 0.09); border-color: var(--neon-1); box-shadow: var(--glow-ciano); }
.btn--outline { background: transparent; color: var(--neon-1); border: 1px solid rgba(34, 211, 238, 0.45); }
.btn--outline:hover { border-color: var(--neon-1); box-shadow: var(--glow-ciano); }
.btn--bloco { width: 100%; }

/* Selo/Pílula --------------------------------------------------------------*/
.selo { display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px; border-radius: 999px; font-size: 0.86rem; font-weight: 600; background: rgba(255, 255, 255, 0.05); color: var(--texto); border: 1px solid var(--borda); }
.selo svg { flex: none; }

/* Header -------------------------------------------------------------------*/
.header { position: sticky; top: 0; z-index: 50; background: rgba(6, 6, 15, 0.72); backdrop-filter: blur(16px) saturate(140%); border-bottom: 1px solid var(--borda); }
.header__inner { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 13px 0; }
.logo { display: flex; align-items: center; gap: 11px; font-family: var(--fonte-titulo); }
.logo__mark { width: 44px; height: 44px; border-radius: 13px; background: var(--grad-neon); display: grid; place-items: center; color: #06060f; flex: none; box-shadow: var(--glow-ciano); position: relative; overflow: hidden; }
.logo__txt { line-height: 1.1; }
.logo__txt strong { display: block; font-size: 1.08rem; font-weight: 800; color: var(--texto); }
.logo__txt span { font-size: 0.74rem; color: var(--texto-suave); font-weight: 600; }
.header__selos { display: flex; gap: 10px; }
.header__cta { display: flex; align-items: center; gap: 14px; }
.header__tel { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; font-family: var(--fonte-titulo); color: var(--texto); white-space: nowrap; }

/* Hero ---------------------------------------------------------------------*/
.hero { position: relative; overflow: hidden; color: var(--texto); border-bottom: 1px solid var(--borda); }
.hero::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(700px 360px at 78% 6%, rgba(34, 211, 238, 0.20), transparent 60%),
    radial-gradient(680px 420px at 6% 100%, rgba(168, 85, 247, 0.22), transparent 60%);
}
.hero__grid { display: grid; grid-template-columns: 1.08fr 0.92fr; gap: 56px; align-items: center; padding: 90px 0; position: relative; z-index: 1; }
.hero h1 { font-size: clamp(2.15rem, 4.8vw, 3.5rem); text-wrap: balance; line-height: 1.08; }
.hero h1 .grad { background: var(--grad-texto); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero__sub { color: var(--texto-suave); font-size: 1.16rem; max-width: 540px; text-align: justify; text-justify: inter-word; }
.hero__botoes { display: flex; flex-wrap: wrap; gap: 14px; margin: 34px 0 26px; }
.hero__selos { display: flex; flex-wrap: wrap; gap: 18px; margin-top: 8px; }
.hero__selo { display: inline-flex; align-items: center; gap: 8px; font-size: 0.92rem; font-weight: 600; color: var(--texto-suave); }
.hero__selo svg { color: var(--neon-1); flex: none; }

.hero__media { position: relative; }
.hero__media::before { content: ""; position: absolute; inset: -16% -12% -20% -12%; background: radial-gradient(closest-side, rgba(34, 211, 238, 0.35), transparent 70%); filter: blur(10px); z-index: 0; }
.hero__media img { position: relative; z-index: 1; border-radius: 22px; box-shadow: var(--sombra); border: 1px solid var(--borda-forte); }
.hero__card {
  position: absolute; left: -20px; bottom: -24px; z-index: 2;
  background: rgba(12, 12, 24, 0.82); backdrop-filter: blur(20px) saturate(150%);
  border: 1px solid var(--borda-forte); color: #fff; border-radius: var(--raio);
  padding: 16px 18px; box-shadow: var(--sombra); display: flex; align-items: center; gap: 13px; max-width: 290px;
}
.hero__card .ic { width: 44px; height: 44px; border-radius: 12px; background: rgba(37, 217, 122, 0.16); color: #4dffa0; display: grid; place-items: center; flex: none; box-shadow: 0 0 20px rgba(37, 217, 122, 0.4); }
.hero__card strong { display: block; font-family: var(--fonte-titulo); font-size: 0.98rem; color: #fff; line-height: 1.25; }
.hero__card span { font-size: 0.82rem; color: var(--texto-suave); }

/* Faixa de confiança -------------------------------------------------------*/
.faixa { background: rgba(255, 255, 255, 0.018); border-top: 1px solid var(--borda); border-bottom: 1px solid var(--borda); }
.marquee { overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent); mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent); }
.marquee__track { display: flex; width: max-content; align-items: center; animation: marquee 34s linear infinite; }
.marquee:hover .marquee__track { animation-play-state: paused; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.faixa__item { display: inline-flex; align-items: center; gap: 11px; padding: 22px 40px; color: var(--texto-suave); font-weight: 600; font-size: 0.95rem; white-space: nowrap; flex: none; }
.faixa__item svg { color: var(--neon-1); flex: none; }
@media (prefers-reduced-motion: reduce) { .marquee__track { animation: none; flex-wrap: wrap; justify-content: center; } }

/* Cards de serviço ---------------------------------------------------------*/
.grid-servicos { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.card-servico { background: var(--card); border: 1px solid var(--borda); border-radius: var(--raio); padding: 30px 26px; transition: transform var(--transicao), box-shadow var(--transicao); backdrop-filter: blur(8px); display: flex; flex-direction: column; }
.card-servico:hover { transform: translateY(-7px); box-shadow: var(--glow-mix); }
.card-servico__ic { width: 58px; height: 58px; border-radius: 16px; background: rgba(34, 211, 238, 0.1); color: var(--neon-1); display: grid; place-items: center; margin-bottom: 18px; border: 1px solid rgba(34, 211, 238, 0.22); transition: var(--transicao); }
.card-servico:hover .card-servico__ic { background: var(--grad-neon); color: #06060f; box-shadow: var(--glow-ciano); border-color: transparent; }
.card-servico h3 { font-size: 1.2rem; margin-bottom: 8px; }
.card-servico p { color: var(--texto-suave); font-size: 0.98rem; margin: 0 0 16px; }
.card-servico__tags { display: flex; flex-wrap: nowrap; gap: 8px; margin-top: auto; padding-top: 6px; }
.tag { font-size: 0.72rem; font-weight: 600; padding: 5px 10px; border-radius: 999px; background: rgba(255, 255, 255, 0.05); color: var(--texto-suave); border: 1px solid var(--borda); white-space: nowrap; }
.card-servico--destaque { background: rgba(168, 85, 247, 0.06); }
.card-servico--destaque::after { opacity: 1; background: var(--grad-neon-2); }
.card-servico--destaque:hover { box-shadow: 0 0 0 1px rgba(244, 63, 157, 0.3), 0 18px 50px -12px rgba(244, 63, 157, 0.5); }
.card-servico--destaque .card-servico__ic { background: rgba(244, 63, 157, 0.12); color: #f9a8d4; border-color: rgba(244, 63, 157, 0.3); }
.card-servico--destaque:hover .card-servico__ic { background: var(--grad-neon-2); color: #fff; }
.badge-destaque { position: absolute; top: 16px; right: 18px; background: var(--grad-neon-2); color: #fff; font-family: var(--fonte-tech); font-weight: 600; font-size: 0.68rem; letter-spacing: 0.08em; padding: 5px 12px; border-radius: 999px; box-shadow: 0 0 20px rgba(244, 63, 157, 0.6); z-index: 1; }

/* Por que escolher ---------------------------------------------------------*/
.grid-motivos { display: grid; grid-template-columns: repeat(5, 1fr); gap: 18px; }
.motivo { text-align: center; padding: 28px 16px; border-radius: var(--raio); transition: var(--transicao); border: 1px solid transparent; }
.motivo:hover { background: var(--card); border-color: var(--borda); transform: translateY(-5px); box-shadow: var(--glow-mix); }
.motivo__num { width: 56px; height: 56px; margin: 0 auto 16px; border-radius: 16px; background: rgba(255, 255, 255, 0.04); border: 1px solid var(--borda-forte); color: var(--neon-1); display: grid; place-items: center; font-family: var(--fonte-tech); font-weight: 700; font-size: 1.25rem; transition: var(--transicao); }
.motivo:hover .motivo__num { background: var(--grad-neon); color: #06060f; box-shadow: var(--glow-ciano); border-color: transparent; }
.motivo h3 { font-size: 1.04rem; margin-bottom: 6px; }
.motivo p { font-size: 0.9rem; color: var(--texto-suave); margin: 0; }

/* Efeito "raio": feixe de luz percorrendo os números 1 → 5 (desktop) */
.grid-motivos { position: relative; }
.grid-motivos::before {
  content: ""; position: absolute; top: 55px; left: 10%; right: 10%; height: 2px;
  background: rgba(255, 255, 255, 0.07); border-radius: 2px; z-index: 0;
}
.grid-motivos::after {
  content: ""; position: absolute; top: 50px; left: 10%; transform: translateX(-50%);
  width: 130px; height: 12px; border-radius: 999px; z-index: 0;
  background: radial-gradient(closest-side, rgba(34, 211, 238, 0.95), rgba(168, 85, 247, 0.45) 55%, transparent 80%);
  filter: blur(3px); animation: raio 6s ease-in-out infinite;
}
@keyframes raio {
  0% { left: 10%; opacity: 0; }
  8% { opacity: 1; }
  44% { left: 90%; opacity: 1; }
  55% { left: 90%; opacity: 0; }
  100% { left: 10%; opacity: 0; }
}
.grid-motivos .motivo { position: relative; z-index: 1; }
.motivo__num { animation: acender 6s ease-in-out infinite; }
.grid-motivos .motivo:nth-child(1) .motivo__num { animation-delay: 0s; }
.grid-motivos .motivo:nth-child(2) .motivo__num { animation-delay: 0.5s; }
.grid-motivos .motivo:nth-child(3) .motivo__num { animation-delay: 1s; }
.grid-motivos .motivo:nth-child(4) .motivo__num { animation-delay: 1.5s; }
.grid-motivos .motivo:nth-child(5) .motivo__num { animation-delay: 2s; }
@keyframes acender {
  0%, 18%, 100% { box-shadow: none; border-color: var(--borda-forte); color: var(--neon-1); background: rgba(255, 255, 255, 0.04); }
  7% { box-shadow: 0 0 0 1px rgba(34, 211, 238, 0.7), 0 0 28px rgba(34, 211, 238, 0.9); border-color: #22d3ee; color: #06060f; background: var(--grad-neon); }
}
@media (max-width: 980px) { .grid-motivos::before, .grid-motivos::after { display: none; } }
@media (prefers-reduced-motion: reduce) { .grid-motivos::after, .motivo__num { animation: none; } }

/* Como funciona ------------------------------------------------------------*/
.grid-passos { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.passo { background: var(--card); border: 1px solid var(--borda); border-radius: var(--raio); padding: 30px 24px; transition: var(--transicao); backdrop-filter: blur(8px); }
.passo:hover { transform: translateY(-6px); box-shadow: var(--glow-mix); }
.passo__num { font-family: var(--fonte-tech); font-weight: 700; font-size: 2.7rem; line-height: 1; background: var(--grad-texto); -webkit-background-clip: text; background-clip: text; color: transparent; margin-bottom: 10px; }
.passo h3 { font-size: 1.1rem; margin-bottom: 6px; }
.passo p { font-size: 0.92rem; color: var(--texto-suave); margin: 0; }
.passo__tempo { display: inline-block; margin-top: 14px; font-size: 0.75rem; font-weight: 700; font-family: var(--fonte-tech); color: var(--neon-1); background: rgba(34, 211, 238, 0.1); border: 1px solid rgba(34, 211, 238, 0.25); padding: 4px 11px; border-radius: 999px; }

/* Neon girando em volta dos cards de "Como funciona" */
@property --giroNeon { syntax: "<angle>"; initial-value: 0deg; inherits: false; }
.passo::after { content: none; }
.passo::before {
  content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1.6px; pointer-events: none; z-index: 0;
  background: conic-gradient(from var(--giroNeon), transparent 0deg 200deg, #22d3ee 270deg, #a855f7 312deg, transparent 360deg);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  animation: giroNeon 4s linear infinite;
}
.passo > * { position: relative; z-index: 1; }
@keyframes giroNeon { to { --giroNeon: 360deg; } }
@media (prefers-reduced-motion: reduce) { .passo::before { animation: none; } }

/* Provas / Estatísticas / Depoimentos -------------------------------------*/
.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-bottom: 58px; background: var(--card); border: 1px solid var(--borda); border-radius: var(--raio); padding: 40px 24px; backdrop-filter: blur(8px); }
.stat { text-align: center; position: relative; }
.stat + .stat::before { content: ""; position: absolute; left: -11px; top: 12%; height: 76%; width: 1px; background: linear-gradient(var(--borda), transparent); }
.stat strong { display: block; font-family: var(--fonte-tech); font-size: 2.8rem; font-weight: 700; background: var(--grad-texto); -webkit-background-clip: text; background-clip: text; color: transparent; }
.stat span { color: var(--texto-suave); font-weight: 600; font-size: 0.96rem; }

.grid-depoimentos { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.depoimento { background: var(--card); border: 1px solid var(--borda); border-radius: var(--raio); padding: 30px 26px; display: flex; flex-direction: column; transition: var(--transicao); backdrop-filter: blur(8px); }
.depoimento:hover { transform: translateY(-5px); box-shadow: var(--glow-mix); }
.depoimento__estrelas { color: #fbbf24; margin-bottom: 12px; letter-spacing: 2px; text-shadow: 0 0 12px rgba(251, 191, 36, 0.5); }
.depoimento p { font-size: 0.98rem; flex: 1; color: #d7dbe8; }
.depoimento__autor { display: flex; align-items: center; gap: 12px; margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--borda); }
.depoimento__avatar { width: 46px; height: 46px; border-radius: 14px; background: var(--grad-neon); color: #06060f; display: grid; place-items: center; font-family: var(--fonte-tech); font-weight: 700; flex: none; box-shadow: var(--glow-ciano); }
.depoimento__autor strong { display: block; font-size: 0.96rem; }
.depoimento__autor span { font-size: 0.84rem; color: var(--texto-suave); }

/* FAQ ----------------------------------------------------------------------*/
.faq { max-width: 820px; margin: 0 auto; }
.faq__item { border: 1px solid var(--borda); border-radius: var(--raio-sm); margin-bottom: 12px; background: var(--card); overflow: hidden; transition: var(--transicao); backdrop-filter: blur(8px); }
.faq__pergunta { width: 100%; text-align: left; background: none; border: none; cursor: pointer; padding: 20px 22px; font-family: var(--fonte-titulo); font-weight: 700; font-size: 1.04rem; color: var(--texto); display: flex; align-items: center; justify-content: space-between; gap: 16px; list-style: none; }
.faq__pergunta::-webkit-details-marker { display: none; }
.faq__pergunta .chev { transition: transform var(--transicao); color: var(--neon-1); flex: none; }
.faq__item[open] .chev { transform: rotate(180deg); }
.faq__resposta { padding: 0 22px 20px; color: var(--texto-suave); }
.faq__item[open] .faq__pergunta { color: var(--neon-1); }

/* CTA final ----------------------------------------------------------------*/
.cta-final { position: relative; overflow: hidden; color: var(--texto); text-align: center; border-radius: 28px; padding: 72px 30px; background: linear-gradient(135deg, rgba(34, 211, 238, 0.1), rgba(168, 85, 247, 0.14)), var(--surface); border: 1px solid var(--borda-forte); box-shadow: var(--glow-mix); }
.cta-final::before { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(600px 300px at 50% 120%, rgba(244, 63, 157, 0.22), transparent 60%); }
.cta-final > * { position: relative; z-index: 1; }
.cta-final h2 { font-size: clamp(1.85rem, 4vw, 2.8rem); }
.cta-final p { color: var(--texto-suave); max-width: 620px; margin: 0 auto 30px; font-size: 1.12rem; }
.cta-final__botoes { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; }

/* Footer -------------------------------------------------------------------*/
.footer { background: #04040b; padding: 66px 0 30px; font-size: 0.95rem; position: relative; border-top: 1px solid var(--borda); color: var(--texto-suave); }
.footer__grid { display: grid; grid-template-columns: 1.5fr 1fr 1.3fr; gap: 40px; }
.footer h4 { color: var(--texto); font-size: 1rem; margin-bottom: 16px; }
.footer a:hover { color: var(--neon-1); }
.footer__contato li { margin-bottom: 10px; display: flex; gap: 10px; align-items: flex-start; }
.footer__contato svg { color: var(--neon-1); flex: none; margin-top: 3px; }
.footer__regioes { display: flex; flex-wrap: wrap; gap: 8px; }
.footer__regioes span { font-size: 0.82rem; padding: 5px 11px; border-radius: 999px; background: rgba(255, 255, 255, 0.04); border: 1px solid var(--borda); }
.footer__legal { margin-top: 44px; padding-top: 24px; border-top: 1px solid var(--borda); display: flex; flex-wrap: wrap; gap: 16px; justify-content: space-between; align-items: center; }
.footer__links { display: flex; flex-wrap: wrap; gap: 18px; }
.footer__links a { font-size: 0.88rem; }
.footer__disclaimer { margin-top: 18px; font-size: 0.8rem; color: var(--texto-tenue); line-height: 1.6; }

/* WhatsApp flutuante -------------------------------------------------------*/
.wpp-float { position: fixed; right: 22px; bottom: 22px; z-index: 60; width: 62px; height: 62px; border-radius: 50%; background: var(--whatsapp); color: #042b15; display: grid; place-items: center; box-shadow: 0 0 30px -4px rgba(37, 217, 122, 0.8); transition: transform var(--transicao); animation: pulso 2.6s infinite; }
.wpp-float:hover { transform: scale(1.08); }
@keyframes pulso {
  0% { box-shadow: 0 0 30px -4px rgba(37, 217, 122, 0.8), 0 0 0 0 rgba(37, 217, 122, 0.4); }
  70% { box-shadow: 0 0 30px -4px rgba(37, 217, 122, 0.8), 0 0 0 18px rgba(37, 217, 122, 0); }
  100% { box-shadow: 0 0 30px -4px rgba(37, 217, 122, 0.8), 0 0 0 0 rgba(37, 217, 122, 0); }
}

/* Banner de cookies (controlado por classe — corrige o "não some") ---------*/
.cookies { position: fixed; left: 16px; right: 16px; bottom: 16px; max-width: 690px; margin: 0 auto; z-index: 70; display: none; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; background: rgba(12, 12, 24, 0.92); backdrop-filter: blur(20px); border: 1px solid var(--borda-forte); border-radius: 16px; padding: 18px 20px; box-shadow: 0 0 0 1px rgba(34, 211, 238, 0.18), 0 24px 60px rgba(0, 0, 0, 0.7); }
.cookies.is-visivel { display: flex; }
.cookies__txt { margin: 0; font-size: 0.9rem; color: var(--texto-suave); flex: 1; min-width: 240px; }
.cookies__txt a { color: var(--neon-1); font-weight: 600; }
.cookies__acoes { display: flex; gap: 10px; flex-wrap: wrap; }
.cookies__acoes .btn { padding: 11px 20px; }

/* Mapa sob demanda ---------------------------------------------------------*/
.mapa-cta { background: linear-gradient(135deg, rgba(34, 211, 238, 0.08), rgba(168, 85, 247, 0.12)), var(--surface); }

/* Páginas legais -----------------------------------------------------------*/
.pagina-legal { padding: 62px 0 88px; max-width: 820px; }
.pagina-legal h1 { font-size: clamp(1.9rem, 4vw, 2.5rem); margin-bottom: 8px; }
.pagina-legal .atualizado { color: var(--texto-suave); font-size: 0.9rem; margin-bottom: 38px; }
.pagina-legal h2 { font-size: 1.32rem; margin: 34px 0 10px; color: var(--texto); }
.pagina-legal p, .pagina-legal li { color: var(--texto-suave); }
.pagina-legal strong { color: var(--texto); }
.pagina-legal a { color: var(--neon-1); }
.pagina-legal ul { list-style: disc; padding-left: 22px; margin-bottom: 16px; }
.pagina-legal li { margin-bottom: 6px; }
.voltar-topo { display: inline-flex; align-items: center; gap: 8px; margin-bottom: 28px; color: var(--neon-1); font-weight: 600; }

/* Responsivo ---------------------------------------------------------------*/
@media (max-width: 980px) {
  .hero__grid { grid-template-columns: 1fr; gap: 46px; }
  .hero__media { max-width: 480px; }
  .grid-servicos { grid-template-columns: repeat(2, 1fr); }
  .grid-motivos { grid-template-columns: repeat(2, 1fr); }
  .grid-passos { grid-template-columns: repeat(2, 1fr); }
  .grid-depoimentos { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .header__selos { display: none; }
}
@media (max-width: 620px) {
  body { font-size: 16px; }
  .secao { padding: 62px 0; }
  .grid-servicos, .grid-motivos, .grid-passos, .stats { grid-template-columns: 1fr; }
  .stat + .stat::before { display: none; }
  .hero__grid { padding: 52px 0; }
  .hero h1 { font-size: clamp(1.95rem, 7.6vw, 2.5rem); }
  .hero__sub { text-align: center; font-size: 1.04rem; margin-inline: auto; }
  .olho { font-size: 0.62rem; letter-spacing: 0.1em; padding: 6px 12px; text-align: center; line-height: 1.5; }
  .secao-cabecalho { margin-bottom: 40px; }
  .secao-cabecalho h2 { font-size: clamp(1.55rem, 6.5vw, 2rem); }
  .hero__botoes .btn, .cta-final__botoes .btn { width: 100%; }
  .btn { padding: 14px 20px; }
  .logo__mark { width: 40px; height: 40px; border-radius: 11px; }
  .logo__txt strong { font-size: 1rem; }
  .header__inner { padding: 11px 0; }
  .footer__grid { grid-template-columns: 1fr; gap: 30px; }
  .header__cta .header__tel { display: none; }
  .hero__card { position: static; margin-top: 18px; max-width: none; }
  .cta-final { padding: 48px 20px; }
  .stats { padding: 30px 18px; }
  .faixa__item { padding: 18px 26px; font-size: 0.9rem; }

  /* Padrão mobile: conteúdo centralizado (referência: landing Dr. Bruno) */
  .hero__txt { text-align: center; }
  .hero__botoes { justify-content: center; }
  .grid-motivos { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .motivo { padding: 22px 12px; }
  #servicos .card-servico { text-align: center; }
  #servicos .card-servico__ic { margin-inline: auto; }
  #servicos .card-servico__tags { justify-content: center; }
  .card-servico--destaque .badge-destaque { left: 50%; right: auto; transform: translateX(-50%); }
  .passo { text-align: center; }
  #atendimento .card-servico ul { align-items: center; }
  #atendimento .card-servico li { text-align: left; }
}

/* Seção Atendimento — 2 colunas centralizadas no desktop, 1 coluna no mobile */
.grid-atendimento { grid-template-columns: 1.1fr 0.9fr; align-items: stretch; max-width: 980px; margin-inline: auto; }
@media (max-width: 880px) { .grid-atendimento { grid-template-columns: 1fr; } }

/* Cards de serviço: mesma altura e tags sempre numa linha só */
#servicos .card-servico { display: flex; flex-direction: column; }
#servicos .card-servico__tags { margin-top: auto; flex-wrap: nowrap; }
#servicos .tag { white-space: nowrap; }
#servicos .card-servico h3 { min-height: 2.35em; }
#servicos .card-servico p { min-height: 4.5em; }
