/* ==========================================================
   Hypearts Estúdio Criativo
   Single source of truth: tokens, layout, type, components.
   ========================================================== */

:root {
  /* Cromáticos */
  --navy: #1B2145;
  --navy-2: #2A3160;
  --ow:   #F5F3F0;
  --wh:   #FFFFFF;
  --lav:  #E8E4F0;
  --peach:#F8D4A0;
  --cyan: #D4F0E8;
  --gold: #F5C842;
  --gray: #333333;
  --hair: rgba(27, 33, 69, 0.12);
  --hair-strong: rgba(27, 33, 69, 0.2);

  /* Tipografia */
  --display: 'Poppins', 'Inter', system-ui, -apple-system, sans-serif;
  --label:   'Montserrat', 'Inter', system-ui, sans-serif;
  --body:    'Inter', 'Montserrat', system-ui, sans-serif;

  /* Forma e respiro */
  --r:    12px;
  --rs:   6px;
  --rp:   999px;
  --pad-x: clamp(20px, 5vw, 88px);
  --sec-y: clamp(50px, 6.2vw, 90px);
  --container: 1320px;

  /* Animação */
  --e: cubic-bezier(0.22, 1, 0.36, 1);
  --t-fast: 0.25s var(--e);
  --t-base: 0.45s var(--e);
  --t-slow: 0.8s var(--e);
  --e-soft: cubic-bezier(0.45, 0, 0.25, 1); /* hover suave nos dois sentidos: entra e sai sem dureza */
  --t-soft: 0.34s var(--e-soft);
  --e-reveal: cubic-bezier(0.16, 1, 0.3, 1); /* expo-out: a curva do fade reversível (ref. Três Mares) */
}

/* ---------- reset / base ---------- */

*, *::before, *::after { box-sizing: border-box; }
/* clip (não hidden) pra clipar o overflow horizontal SEM criar container de scroll,
   senão o position:sticky (carrossel pinado do /conteudo) não gruda. hidden é fallback. */
html, body { overflow-x: hidden; overflow-x: clip; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; background: var(--ow); }
body {
  margin: 0;
  font-family: var(--body);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.7;
  color: var(--navy);
  background: transparent;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
main { flex: 1 0 auto; }
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; background: none; border: 0; padding: 0; color: inherit; }
ul { list-style: none; padding: 0; margin: 0; }
h1, h2, h3, h4, p { margin: 0; }

::selection { background: var(--navy); color: var(--ow); }

/* ---------- shared ---------- */

.lbl {
  display: inline-block;
  font-family: var(--label);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--navy);
  padding-bottom: 6px;
  border-bottom: 1px solid var(--gold);
}
.lbl--inv { color: var(--ow); border-bottom-color: var(--gold); }

em {
  font-style: italic;
  font-weight: inherit;
  color: var(--navy);
}

/* ---------- reveal ---------- */

.rv { opacity: 0; transform: translateY(28px); transition: opacity var(--t-slow), transform var(--t-slow); }
.rv.vs { opacity: 1; transform: none; }
.rv.d1 { transition-delay: 0.08s; }
.rv.d2 { transition-delay: 0.16s; }
.rv.d3 { transition-delay: 0.24s; }
.rv.d4 { transition-delay: 0.32s; }

/* Fade reversível das sessões que iniciam um tema: aparece ao entrar na viewport e
   some de volta ao sair, refazendo o caminho toda vez (igual à referência Três Mares,
   que usa onEnter/onLeave/onEnterBack/onLeaveBack). Só opacidade + transform, expo-out.
   opacity .0001 (não 0) mantém a camada composta na GPU, sem flash de re-pintura. */
.tr {
  opacity: 0.0001;
  transform: translateY(28px);
  transition: opacity 0.6s var(--e-reveal), transform 0.6s var(--e-reveal);
  will-change: opacity, transform;
}
.tr.is-in { opacity: 1; transform: none; }
.tr.d1 { transition-delay: 0.06s; }
.tr.d2 { transition-delay: 0.14s; }
.tr.d3 { transition-delay: 0.22s; }

/* Reveal CARACTERE-a-caractere das chamadas de sessão (scrub no scroll, reversível, ref. Três
   Mares). Cada caractere acende da esquerda pra direita conforme a sessão sobe; some na ordem
   inversa ao subir. O JS (charReveal) quebra o título em palavras .wr__w (inline-block) e
   caracteres .wr__c, e escreve o ALPHA da cor por frame. Floor 0.06 = caractere ainda não
   revelado. Acende pela transparência da COR, não por element-opacity (esta isolava cada
   glifo numa camada e duplicava o itálico / travava no iOS). Sem split (no-JS /
   reduced-motion): texto cheio e legível. */
.wr__w { display: inline-block; } /* palavra não quebra no meio */
.wr__c { color: rgba(27, 33, 69, 0.06); } /* caractere: floor via ALPHA da cor, não element-opacity (evita o "fantasma duplo" do itálico e o travamento no iOS). O JS reescreve a cor real de cada título. */

@media (prefers-reduced-motion: reduce) {
  .rv { opacity: 1; transform: none; transition: none; }
  .tr { opacity: 1; transform: none; transition: none; will-change: auto; }
  .wr__c { opacity: 1; }
  html { scroll-behavior: auto; }
}

/* ---------- nav ---------- */

.hd {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  background: transparent;
  transition: background var(--t-base), box-shadow var(--t-base), padding var(--t-base);
}
.hd.is-stuck {
  background: rgba(245, 243, 240, 0.94);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
          backdrop-filter: saturate(160%) blur(14px);
  box-shadow: 0 1px 0 var(--hair);
}
.nv {
  max-width: var(--container);
  margin: 0 auto;
  padding: 22px var(--pad-x);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  transition: padding var(--t-base);
}
.hd.is-stuck .nv { padding-top: 14px; padding-bottom: 14px; }
.nv__logo { display: block; }
.nv__logo img { height: 44px; width: auto; transition: height var(--t-base); display: block; }
.hd.is-stuck .nv__logo img { height: 36px; }

.nv__links { display: flex; gap: 36px; align-items: center; }
.nv__links a {
  font-family: var(--label);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.04em;
  color: var(--navy);
  position: relative;
  padding: 6px 0;
  transition: color var(--t-fast);
}
.nv__links a::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 1px;
  background: var(--navy);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--t-base);
}
.nv__links a:hover::after { transform: scaleX(1); }

.nv__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 22px;
  background: var(--navy);
  color: var(--ow);
  font-family: var(--label);
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-radius: var(--rp);
  transition: transform var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);
}
.nv__cta:hover { transform: translateY(-1px); background: var(--navy-2); box-shadow: 0 8px 20px rgba(27, 33, 69, 0.18); }

/* Pílula PT/EN (injetada pelo js/main.js langPill) */
.nv__lang { display: inline-flex; align-items: center; gap: 2px; font-family: var(--label); font-weight: 600; font-size: 11px; letter-spacing: 0.06em; margin-right: 6px; }
.nv__lang a { padding: 4px 8px; border-radius: 7px; color: var(--navy); opacity: 0.45; transition: opacity var(--t-fast), background var(--t-fast); }
.nv__lang a:hover { opacity: 0.9; }
.nv__lang a[aria-current="true"] { opacity: 1; background: rgba(27, 33, 69, 0.08); }
.nv__lang--mm { margin: 20px 0 0; }

.nv__burger {
  display: none;
  width: 40px; height: 40px;
  position: relative;
  z-index: 60;
}
.nv__burger span {
  display: block;
  position: absolute;
  left: 8px;
  width: 24px;
  height: 2px;
  background: var(--navy);
  transition: transform var(--t-base), opacity var(--t-fast), top var(--t-base);
}
.nv__burger span:nth-child(1) { top: 13px; }
.nv__burger span:nth-child(2) { top: 19px; }
.nv__burger span:nth-child(3) { top: 25px; }
.nv__burger[aria-expanded="true"] span:nth-child(1) { top: 19px; transform: rotate(45deg); }
.nv__burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nv__burger[aria-expanded="true"] span:nth-child(3) { top: 19px; transform: rotate(-45deg); }

.mm {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  /* mesmo vidro da barra de cima (ref. sohub.digital): fundo translúcido + blur */
  background: rgba(245, 243, 240, 0.78);
  -webkit-backdrop-filter: saturate(160%) blur(22px);
          backdrop-filter: saturate(160%) blur(22px);
  z-index: 55;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--t-base);
}
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .mm { background: var(--ow); }
}
.mm.is-open { opacity: 1; pointer-events: auto; }
.mm__inner {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 0 var(--pad-x);
  gap: 36px;
}
.mm__links { display: flex; flex-direction: column; gap: 18px; }
.mm__links a {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(2rem, 8vw, 3rem);
  line-height: 1;
  color: var(--navy);
  letter-spacing: -0.01em;
}
.mm__cta { align-self: flex-start; }

/* ---------- hero ---------- */

.hr {
  position: relative;
  min-height: 100vh;
  padding: clamp(140px, 16vw, 200px) var(--pad-x) clamp(80px, 10vw, 140px);
  overflow: hidden;
  display: flex;
  align-items: center;
}
.hr__bg {
  position: absolute;
  inset: -10% -5%;
  background:
    radial-gradient(60% 50% at 15% 10%, rgba(232, 228, 240, 0.9), transparent 70%),
    radial-gradient(45% 45% at 90% 8%, rgba(212, 240, 232, 0.85), transparent 70%),
    radial-gradient(70% 60% at 85% 95%, rgba(248, 212, 160, 0.9), transparent 70%),
    radial-gradient(50% 40% at 20% 95%, rgba(245, 200, 66, 0.18), transparent 70%),
    linear-gradient(135deg, #F0EEF5 0%, #F5F3F0 45%, #FDF0D8 80%, #F8E8B0 100%);
  z-index: -2;
}
.hr::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url('../assets/textura-hypearts.webp');
  background-size: cover;
  background-position: center;
  opacity: 0.07;
  mix-blend-mode: multiply;
  pointer-events: none;
  z-index: -1;
}
.hr__inner {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
}
.hr__content { max-width: 940px; }
.hr__title {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(3rem, 8.4vw, 7rem);
  line-height: 1.0;
  letter-spacing: -0.035em;
  color: var(--navy);
  margin-top: 28px;
}
.hr__title em { font-weight: 900; }
.hr__caret {
  display: inline-block;
  width: 0.1em;
  min-width: 7px;
  height: 0.88em;
  background: var(--gold);
  margin-left: 0.12em;
  vertical-align: -0.06em;
  border-radius: 3px;
  /* inclinado como itálico, acompanhando a última palavra em itálico */
  transform: skewX(-12deg);
  box-shadow: 0 0 16px rgba(245, 200, 66, 0.8), 0 0 5px rgba(245, 200, 66, 0.95);
  animation: caretBlink 1.05s steps(1) infinite;
}
@keyframes caretBlink { 0%, 50% { opacity: 1; } 50.01%, 100% { opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .hr__caret { animation: none; opacity: 1; } }
.hr__lead {
  margin-top: 28px;
  max-width: 640px;
  font-size: clamp(1.05rem, 1.6vw, 1.25rem);
  line-height: 1.65;
  color: var(--navy);
  opacity: 0.86;
}
.hr__actions {
  margin-top: 40px;
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

/* Hero centralizado: uma chamada única, três temas em negrito + resto em peso normal,
   "resultado" em itálico navy (sem negrito). Centralizado no mobile e no desktop. */
.hr--center .hr__content { max-width: min(94vw, 1180px); margin-left: auto; margin-right: auto; text-align: center; }
.hr--center .hr__actions { justify-content: center; }
.hr__call {
  font-family: var(--display);
  font-weight: 300; /* leve de verdade (Poppins 300 carregado): contraste forte com o strong 900 */
  /* exatamente 3 linhas (quebra via <br> no HTML); a fonte cai pra a linha mais longa
     ("social media para quem") caber. Grande no desktop, modesta no mobile (linha longa). */
  font-size: clamp(1.5rem, 5.6vw, 6rem);
  line-height: 1.08;
  letter-spacing: -0.035em;
  color: var(--navy);
  margin: 28px auto 0;
}
/* quebras responsivas: .brd só no desktop, .brm só no mobile (≤600px) */
.hr__call .brm { display: none; }
.hr__call strong { font-weight: 900; letter-spacing: -0.035em; }
.hr__call em { font-style: italic; } /* itálico navy via em global, emphasis sem negrito */
/* +10% só na home PT (Jordan 2026-06-19). O EN fica no tamanho base por já ser largo na horizontal. */
html[lang="pt-BR"] .hr__call { font-size: clamp(1.65rem, 6.16vw, 6.6rem); }

.hr__pillars {
  margin-top: clamp(64px, 9vw, 110px);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--hair-strong);
}
.pillar {
  padding: 32px 28px 32px 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-right: 1px solid var(--hair-strong);
}
.pillar:last-child { border-right: 0; padding-right: 0; }
.pillar:not(:first-child) { padding-left: 28px; }
.pillar__num {
  font-family: var(--label);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--navy);
  opacity: 0.55;
}
.pillar__name {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.1rem, 1.6vw, 1.4rem);
  color: var(--navy);
  letter-spacing: -0.01em;
}
.pillar__desc {
  font-size: 0.95rem;
  color: var(--navy);
  opacity: 0.78;
  line-height: 1.55;
}

/* ---------- buttons ---------- */

.bt {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 18px 32px;
  font-family: var(--label);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-radius: var(--rp);
  transition: transform var(--t-soft), background var(--t-soft), color var(--t-soft), box-shadow var(--t-soft), border-color var(--t-soft);
  border: 1px solid transparent;
  white-space: nowrap;
}
.bt--solid { background: var(--navy); color: var(--ow); }
.bt--solid:hover { background: var(--navy-2); transform: translateY(-2px); box-shadow: 0 12px 28px rgba(27, 33, 69, 0.2); }
.bt--ghost { background: transparent; color: var(--navy); border-color: var(--navy); }
.bt--ghost:hover { background: var(--navy); color: var(--ow); transform: translateY(-2px); }

/* ---------- sections ---------- */

/* esconde visualmente mas mantém no fluxo de leitura/SEO (headings semânticos) */
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

.sc {
  padding: var(--sec-y) var(--pad-x);
  max-width: var(--container);
  margin: 0 auto;
  position: relative;
}
.sc--cases { background: transparent; }
.sc__head { max-width: 900px; margin-bottom: clamp(26px, 3.6vw, 46px); }
.sc__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(2rem, 4.6vw, 3.6rem);
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--navy);
  margin-top: 24px;
}
.sc__title em { font-weight: 800; }

/* ---------- services ---------- */

.srv {
  display: flex;
  flex-direction: column;
}
.srv__item {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: clamp(20px, 4vw, 64px);
  padding: clamp(40px, 5vw, 72px) 0;
  border-top: 1px solid var(--hair-strong);
}
.srv__item:last-child { border-bottom: 1px solid var(--hair-strong); }
.srv__num {
  font-family: var(--label);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.22em;
  color: var(--navy);
  opacity: 0.5;
  padding-top: 8px;
}
.srv__name {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.8rem, 3.4vw, 2.8rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--navy);
}
.srv__desc {
  margin-top: 22px;
  max-width: 720px;
  font-size: clamp(1rem, 1.4vw, 1.1rem);
  line-height: 1.7;
  color: var(--navy);
  opacity: 0.82;
}
.srv__list {
  margin-top: 28px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 36px;
  max-width: 720px;
}
.srv__list li {
  position: relative;
  padding-left: 22px;
  font-size: 0.95rem;
  color: var(--navy);
  opacity: 0.78;
  line-height: 1.55;
}
.srv__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.65em;
  width: 12px;
  height: 1px;
  background: var(--gold);
}

.sc__cta { margin-top: clamp(48px, 6vw, 80px); }

/* ---------- cases ---------- */

.case {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: clamp(28px, 5vw, 80px);
  padding: clamp(48px, 6vw, 80px) 0;
  border-top: 1px solid var(--hair-strong);
}
.case:last-child { border-bottom: 1px solid var(--hair-strong); }
.case__meta { display: flex; flex-direction: column; gap: 6px; padding-top: 10px; }
.case__client {
  font-family: var(--display);
  font-weight: 800;
  font-size: 1.05rem;
  letter-spacing: -0.01em;
  color: var(--navy);
}
.case__type {
  font-family: var(--label);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--navy);
  opacity: 0.55;
  line-height: 1.6;
  margin-top: 4px;
}
.case__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--navy);
}
.case__desc {
  margin-top: 22px;
  max-width: 720px;
  font-size: clamp(1rem, 1.35vw, 1.08rem);
  line-height: 1.7;
  color: var(--navy);
  opacity: 0.84;
}
.case__stats {
  margin-top: 36px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px 48px;
}
.stat { display: flex; flex-direction: column; gap: 4px; }
.stat__num {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.6rem, 2.4vw, 2rem);
  letter-spacing: -0.02em;
  color: var(--navy);
  line-height: 1;
}
.stat__lbl {
  font-family: var(--label);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--navy);
  opacity: 0.6;
}

/* ---------- about ---------- */

.sc--about { padding-top: clamp(60px, 8vw, 100px); }
.ab {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: clamp(28px, 5vw, 80px);
  border-top: 1px solid var(--hair-strong);
  padding-top: clamp(48px, 6vw, 80px);
  padding-bottom: clamp(48px, 6vw, 80px);
}
.ab__col--label { padding-top: 6px; }
.ab__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.8rem, 3.6vw, 2.8rem);
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: var(--navy);
}
.ab__desc {
  margin-top: 24px;
  max-width: 700px;
  font-size: clamp(1rem, 1.4vw, 1.1rem);
  line-height: 1.75;
  color: var(--navy);
  opacity: 0.84;
}
.ab__sig {
  margin-top: 36px;
  padding-top: 22px;
  border-top: 1px solid var(--hair);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.ab__sig-name {
  font-family: var(--display);
  font-weight: 800;
  font-size: 1.1rem;
  letter-spacing: -0.01em;
  color: var(--navy);
}
.ab__sig-role {
  font-family: var(--label);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--navy);
  opacity: 0.6;
}
.ab__sig-list {
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ab__sig-list li {
  font-family: var(--body);
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--navy);
  opacity: 0.85;
  padding-left: 16px;
  position: relative;
}
.ab__sig-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.65em;
  width: 6px;
  height: 2px;
  background: #F5C842;
}

/* ---------- contact ---------- */

.sc--contact {
  background: var(--navy);
  color: var(--ow);
  max-width: none;
  margin: 0;
  padding-top: clamp(96px, 12vw, 160px);
  padding-bottom: clamp(96px, 12vw, 160px);
  position: relative;
  overflow: hidden;
}
.sc--contact::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url('../assets/textura-hypearts.webp');
  background-size: cover;
  background-position: center;
  opacity: 0.05;
  mix-blend-mode: screen;
  pointer-events: none;
}
.ct {
  max-width: var(--container);
  margin: 0 auto;
  position: relative;
}
.ct__head { max-width: 820px; }
.ct__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(2rem, 4.6vw, 3.6rem);
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--ow);
  margin-top: 24px;
}
.ct__title em { color: var(--gold); font-weight: 800; }
.ct__lead {
  margin-top: 26px;
  max-width: 600px;
  font-size: clamp(1.05rem, 1.5vw, 1.2rem);
  line-height: 1.65;
  color: var(--ow);
  opacity: 0.78;
}
.ct__grid {
  margin-top: clamp(56px, 7vw, 88px);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.ct__card {
  position: relative;
  padding: 22px 24px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--r);
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 16px;
  transition: transform var(--t-base), background var(--t-base), border-color var(--t-base);
}
.ct__card:hover {
  transform: translateY(-4px);
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(245, 200, 66, 0.4);
}
.ct__card-ic {
  flex: 0 0 auto;
  width: 46px; height: 46px;
  border-radius: 50%;
  background: rgba(245, 200, 66, 0.14);
  color: var(--gold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.ct__card-ic svg { width: 22px; height: 22px; display: block; }
.ct__card-body { display: flex; flex-direction: column; gap: 3px; flex: 1; min-width: 0; }
.ct__card-lbl {
  font-family: var(--label);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
}
.ct__card-name {
  font-family: var(--display);
  font-weight: 800;
  font-size: 1.28rem;
  letter-spacing: -0.01em;
  color: var(--ow);
  white-space: nowrap;
}
.ct__card-val {
  font-size: 0.95rem;
  color: var(--ow);
  opacity: 0.74;
  word-break: break-word;
}
.ct__card-arrow {
  margin-left: auto;
  font-size: 1.4rem;
  color: var(--gold);
  transition: transform var(--t-base);
}
.ct__card:hover .ct__card-arrow { transform: translateX(6px); }

/* ---------- footer: card flutuante (frase grande + menu horizontal + ícones) ---------- */

.ft {
  margin-top: auto;
  padding: clamp(16px, 2.6vw, 30px) clamp(14px, 2.4vw, 28px) clamp(18px, 2.8vw, 32px);
}
.ft__card {
  max-width: 1380px;
  margin: 0 auto;
  background:
    radial-gradient(46% 40% at 88% -8%, rgba(245, 200, 66, 0.15), rgba(245, 200, 66, 0) 70%),
    linear-gradient(168deg, #242b56 0%, var(--navy) 52%, #161b38 100%);
  border: 1px solid rgba(245, 243, 240, 0.08);
  border-radius: clamp(22px, 2.6vw, 30px);
  padding: clamp(46px, 6vw, 82px) clamp(22px, 5vw, 72px) clamp(24px, 2.8vw, 36px);
  color: var(--ow);
  text-align: center;
  box-shadow: 0 24px 70px rgba(27, 33, 69, 0.16);
}
.ft__stmt {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.5rem, 3.3vw, 2.8rem);
  line-height: 1.2;
  letter-spacing: -0.015em;
  max-width: 30ch;
  margin: 0 auto;
}
.ft__stmt em { color: var(--gold); }
.ft__menu {
  margin-top: clamp(30px, 4vw, 44px);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px clamp(22px, 3vw, 40px);
}
.ft__menu a {
  font-family: var(--label);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ow);
  opacity: 0.85;
  padding: 4px 2px;
  transition: opacity var(--t-fast), color var(--t-fast);
}
.ft__menu a:hover { opacity: 1; color: var(--gold); }
.ft__ic { width: 16px; height: 16px; flex: 0 0 auto; color: var(--gold); }
.ft__line {
  margin: clamp(26px, 3.4vw, 40px) auto 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold) 30%, var(--gold) 70%, transparent);
  opacity: 0.4;
}
.ft__base {
  margin-top: clamp(18px, 2.4vw, 24px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.ft__copy {
  font-size: 12.5px;
  line-height: 1.6;
  color: var(--ow);
  opacity: 0.6;
  text-align: left;
}
.ft__social { display: flex; gap: 10px; flex: 0 0 auto; }
.ft__social a {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(245, 243, 240, 0.22);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--ow);
  transition: color var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
}
.ft__social a:hover { color: var(--gold); border-color: rgba(245, 200, 66, 0.55); transform: translateY(-2px); }
.ft__social .ft__ic { width: 19px; height: 19px; color: currentColor; }

/* ==========================================================
   Responsive
   ========================================================== */

@media (max-width: 960px) {
  .nv__links { display: none; }
  .nv__cta { display: none; }
  .nv > .nv__lang { margin-left: auto; margin-right: 10px; } /* pílula fica no topo, à esquerda do hambúrguer (Jordan); também segue no menu (.nv__lang--mm) */
  .nv__burger { display: block; }

  .hr__pillars { grid-template-columns: 1fr; border-top: 1px solid var(--hair-strong); }
  .pillar { border-right: 0; border-bottom: 1px solid var(--hair-strong); padding: 22px 0; }
  .pillar:not(:first-child) { padding-left: 0; }
  .pillar:last-child { border-bottom: 0; }

  .srv__item { grid-template-columns: 1fr; gap: 16px; }
  .srv__num { padding-top: 0; }
  .srv__list { grid-template-columns: 1fr; gap: 10px; }

  .case { grid-template-columns: 1fr; gap: 24px; }
  .case__meta { padding-top: 0; }

  .ab { grid-template-columns: 1fr; gap: 14px; padding-top: 36px; }

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

  .ft__base { flex-direction: column-reverse; gap: 18px; }
  .ft__copy { text-align: center; }
  .ft__fresh { display: block; margin-top: 4px; }
}

@media (max-width: 600px) {
  :root {
    --pad-x: 22px;
    --sec-y: clamp(38px, 7.6vw, 56px);
  }
  .nv { padding-top: 16px; padding-bottom: 16px; }
  .nv__logo img { height: 30px; }
  /* hero ocupa a primeira tela inteira no mobile (svh ignora a barra do iOS Safari) */
  .hr { min-height: 100vh; min-height: 100svh; padding-top: clamp(104px, 19vw, 132px); padding-bottom: 40px; }
  /* mobile: troca o jogo de quebras (4 linhas curtas) e sobe a fonte, já que as linhas encurtaram */
  .hr__call .brd { display: none; }
  .hr__call .brm { display: inline; }
  .hr__call { font-size: clamp(2.3rem, 9.5vw, 3.2rem); }
  html[lang="pt-BR"] .hr__call { font-size: clamp(2.53rem, 10.45vw, 3.52rem); } /* +10% PT */
  .bt { padding: 16px 26px; font-size: 12px; }
  .srv__item { padding: 36px 0; }
  .case__stats { gap: 18px 28px; }
  .ct__card { padding: 28px 24px; }
}

/* Body lock when mobile menu is open */
body.mm-open { overflow: hidden; }

/* ==========================================================
   Visual elements (poly accent, pillar icons, service art, case art)
   ========================================================== */

/* Hero polygonal accent */
.hr__poly {
  position: absolute;
  top: 6%;
  right: -6%;
  width: clamp(280px, 36vw, 520px);
  aspect-ratio: 1 / 1;
  pointer-events: none;
  z-index: -1;
}
.hr__poly svg { width: 100%; height: 100%; display: block; animation: floatPoly 14s ease-in-out infinite; }
@keyframes floatPoly {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50%      { transform: translateY(-18px) rotate(4deg); }
}
@media (prefers-reduced-motion: reduce) {
  .hr__poly svg { animation: none; }
}

/* Pillar icons */
.pillar { gap: 14px; }
.pillar__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: var(--rs);
  background: var(--wh);
  border: 1px solid var(--hair-strong);
  color: var(--navy);
  box-shadow: 0 4px 18px rgba(27, 33, 69, 0.06);
  transition: transform var(--t-base), border-color var(--t-base), background var(--t-base);
}
.pillar__icon svg { width: 32px; height: 32px; }
.pillar:hover .pillar__icon {
  transform: translateY(-3px);
  border-color: var(--gold);
  background: #fffdf5;
}

/* Service item layout with art column */
.srv__item {
  grid-template-columns: 110px minmax(0, 1fr) clamp(260px, 28%, 380px);
  align-items: start;
}
.srv__art {
  border-radius: var(--r);
  overflow: hidden;
  background: linear-gradient(135deg, #F0EEF5 0%, #F5F3F0 50%, #FDF0D8 100%);
  border: 1px solid var(--hair);
  box-shadow: 0 18px 40px rgba(27, 33, 69, 0.08);
  padding: 18px;
  transition: transform var(--t-base), box-shadow var(--t-base);
}
.srv__art svg { width: 100%; height: auto; display: block; }
.srv__item:hover .srv__art {
  transform: translateY(-4px);
  box-shadow: 0 26px 56px rgba(27, 33, 69, 0.12);
}

/* Case layout with art column */
.case {
  grid-template-columns: 220px minmax(0, 1fr) clamp(300px, 32%, 420px);
  align-items: start;
}
.case__art {
  border-radius: var(--r);
  overflow: hidden;
  box-shadow: 0 22px 50px rgba(27, 33, 69, 0.12);
  border: 1px solid var(--hair);
  transition: transform var(--t-base), box-shadow var(--t-base);
}
.case__art svg { width: 100%; height: auto; display: block; }
.case:hover .case__art {
  transform: translateY(-4px);
  box-shadow: 0 30px 64px rgba(27, 33, 69, 0.18);
}

/* Responsive collapses */
@media (max-width: 1100px) {
  .srv__item { grid-template-columns: 110px 1fr; }
  .srv__art {
    grid-column: 1 / -1;
    margin-top: 24px;
    max-width: 480px;
  }
  .case { grid-template-columns: 220px 1fr; }
  .case__art {
    grid-column: 1 / -1;
    margin-top: 28px;
    max-width: 560px;
  }
}
@media (max-width: 960px) {
  .srv__item, .srv__item:hover { grid-template-columns: 1fr; }
  .srv__art { margin-top: 18px; max-width: none; }
  .case { grid-template-columns: 1fr; }
  .case__art { margin-top: 22px; max-width: none; }
  .hr__poly {
    width: clamp(220px, 60vw, 360px);
    top: auto;
    bottom: -8%;
    right: -12%;
    opacity: 0.55;
  }
}
@media (max-width: 600px) {
  .pillar__icon { width: 48px; height: 48px; }
  .pillar__icon svg { width: 28px; height: 28px; }
  .nv__logo img { height: 36px; }
  .hd.is-stuck .nv__logo img { height: 32px; }
  .srv__art { padding: 12px; }
}

/* ==========================================================
   Service CTA
   ========================================================== */
.srv__cta {
  margin-top: 32px;
  align-self: flex-start;
}

/* ==========================================================
   Tech section — PageSpeed gauges, comparison, globe, stack
   ========================================================== */

.sc--tech { padding-top: 0; }
.sc__lead {
  margin-top: 22px;
  max-width: 760px;
  font-size: clamp(1rem, 1.4vw, 1.15rem);
  line-height: 1.7;
  color: var(--navy);
  opacity: 0.84;
}

/* PageSpeed gauges */
.ps {
  border-radius: var(--r);
  padding: clamp(28px, 4vw, 56px);
  background: var(--wh);
  border: 1px solid var(--hair);
  box-shadow: 0 22px 50px rgba(27, 33, 69, 0.07);
  margin-bottom: clamp(56px, 7vw, 96px);
}
.ps__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(20px, 3vw, 40px);
}
.ps__gauge {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  position: relative;
}
.ps__gauge svg {
  width: clamp(120px, 14vw, 160px);
  height: auto;
}
.ps__track { stroke: rgba(27, 33, 69, 0.08); }
.ps__bar {
  stroke: url(#psGrad);
  stroke-dasharray: 326.7;
  stroke-dashoffset: 326.7;
  transition: stroke-dashoffset 1.8s var(--e);
}
.ps__gauge.is-okay .ps__bar { stroke: #E0A93B; }
.ps__gauge.is-bad  .ps__bar { stroke: #C2543B; }
/* ponto de luz que corre na ponta do arco (estilo do loading de referencia) */
.ps__dot {
  transform-box: view-box;
  transform-origin: 60px 60px;
  transform: rotate(0deg);
  transition: transform 1.8s var(--e);
  filter: drop-shadow(0 0 5px rgba(245, 200, 66, 0.95)) drop-shadow(0 0 12px rgba(245, 200, 66, 0.55));
}
.ps__dot circle { fill: var(--gold); }
.ps__num {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, calc(-50% - 16px));
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.7rem, 2.6vw, 2.4rem);
  color: var(--navy);
  letter-spacing: -0.02em;
}
.ps__name {
  font-family: var(--label);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--navy);
  opacity: 0.75;
}
.ps__note {
  margin-top: 32px;
  font-size: 0.92rem;
  color: var(--navy);
  opacity: 0.65;
  line-height: 1.6;
  max-width: 640px;
}

/* Comparison bars */
.cmp {
  margin-bottom: clamp(56px, 7vw, 96px);
}
.cmp__head { max-width: 760px; margin-bottom: 36px; }
.cmp__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--navy);
  margin-top: 16px;
}
.cmp__rows {
  display: flex;
  flex-direction: column;
  gap: 22px;
  padding: clamp(24px, 3vw, 36px);
  background: var(--wh);
  border-radius: var(--r);
  border: 1px solid var(--hair);
}
.cmp__row {
  display: grid;
  grid-template-columns: 240px 1fr;
  grid-template-rows: auto auto;
  gap: 6px 24px;
  align-items: center;
}
.cmp__row > .cmp__bar:nth-child(2) { grid-row: 1; grid-column: 2; }
.cmp__row > .cmp__bar:nth-child(3) { grid-row: 2; grid-column: 2; }
.cmp__lbl {
  grid-row: 1 / span 2;
  grid-column: 1;
  font-family: var(--label);
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--navy);
  align-self: center;
}
.cmp__bar {
  position: relative;
  height: 22px;
  background: rgba(27, 33, 69, 0.06);
  border-radius: var(--rp);
  overflow: hidden;
}
.cmp__fill {
  position: absolute;
  inset: 0;
  width: 0;
  border-radius: var(--rp);
  transition: width 1.6s var(--e);
}
.cmp__fill--us   { background: linear-gradient(90deg, var(--navy), var(--navy-2)); }
.cmp__fill--them { background: linear-gradient(90deg, #BFA98A, #D9C7A3); }
.cmp__val {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--label);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--ow);
  z-index: 2;
  text-shadow: 0 1px 2px rgba(0,0,0,0.18);
}
.cmp__leg {
  display: flex;
  gap: 24px;
  margin-top: 18px;
  font-family: var(--label);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--navy);
  opacity: 0.8;
}
.cmp__leg-item { display: inline-flex; align-items: center; gap: 8px; }
.cmp__sw { width: 14px; height: 14px; border-radius: 3px; background: var(--navy); }
.cmp__leg-item--them .cmp__sw { background: #BFA98A; }

/* Global / globe */
.glob {
  margin-bottom: clamp(56px, 7vw, 96px);
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: clamp(28px, 5vw, 64px);
  align-items: center;
}
.glob__head { max-width: 480px; }
.glob__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(2rem, 4.6vw, 3.6rem); /* mesmo tamanho das chamadas de seção (.sc__title) */
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--navy);
  margin-top: 16px;
}
.glob__desc {
  margin-top: 22px;
  font-size: 1rem;
  line-height: 1.7;
  color: var(--navy);
  opacity: 0.82;
}
.glob__viz {
  position: relative;
  border-radius: var(--r);
  padding: clamp(20px, 3vw, 36px);
  background:
    radial-gradient(60% 50% at 50% 50%, rgba(232, 228, 240, 0.6), transparent 70%),
    linear-gradient(135deg, #F0EEF5 0%, #F5F3F0 50%, #FDF0D8 100%);
  border: 1px solid var(--hair);
  overflow: hidden;
}
.glob__svg { width: 100%; height: auto; display: block; }
.glob__nodes g.node {
  transform: translate(var(--x), var(--y));
}
.node__pulse {
  transform-origin: center;
  transform-box: fill-box;
  animation: nodePulse 2.4s var(--e) infinite;
  opacity: 0;
}
.glob__nodes g.node:nth-child(2) .node__pulse { animation-delay: 0.3s; }
.glob__nodes g.node:nth-child(3) .node__pulse { animation-delay: 0.6s; }
.glob__nodes g.node:nth-child(4) .node__pulse { animation-delay: 0.9s; }
.glob__nodes g.node:nth-child(5) .node__pulse { animation-delay: 1.1s; }
.glob__nodes g.node:nth-child(6) .node__pulse { animation-delay: 1.3s; }
.glob__nodes g.node:nth-child(7) .node__pulse { animation-delay: 1.5s; }
.glob__nodes g.node:nth-child(8) .node__pulse { animation-delay: 1.7s; }
.glob__nodes g.node:nth-child(9) .node__pulse { animation-delay: 1.9s; }
@keyframes nodePulse {
  0%   { transform: scale(1);   opacity: 0.9; }
  100% { transform: scale(5.5); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
  .node__pulse { animation: none; }
}
.glob__stat {
  position: absolute;
  bottom: 26px;
  left: 26px;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid var(--hair);
  border-radius: var(--rs);
  padding: 12px 18px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  backdrop-filter: blur(8px);
}
.glob__stat--2 {
  bottom: 26px;
  left: auto;
  right: 26px;
}
.glob__stat-num {
  font-family: var(--display);
  font-weight: 800;
  font-size: 1.4rem;
  color: var(--navy);
  letter-spacing: -0.02em;
  display: inline-flex;
  align-items: baseline;
}
.glob__stat-suffix { font-size: 0.9rem; margin-left: 2px; opacity: 0.7; }
.glob__stat-lbl {
  font-family: var(--label);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--navy);
  opacity: 0.66;
}

/* Stack — só a tecnologia dos grandes, largura cheia (cards de segurança removidos);
   sem a linha divisória de cima (Jordan pediu pra tirar) */
.stk {
  display: block;
  padding-top: clamp(20px, 3vw, 36px);
}
.stk__col { min-width: 0; }
.stk__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(2rem, 4.6vw, 3.6rem); /* mesmo tamanho das chamadas de seção (.sc__title) */
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--navy);
  margin-top: 16px;
}
.stk__desc {
  margin-top: 22px;
  max-width: 540px;
  font-size: 1rem;
  line-height: 1.7;
  color: var(--navy);
  opacity: 0.82;
}
.stk__brands {
  margin-top: 28px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.stk__brand {
  padding: 10px 16px;
  border: 1px solid var(--hair-strong);
  border-radius: var(--rp);
  font-family: var(--display);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: -0.01em;
  color: var(--navy);
  background: var(--wh);
}

.stk__col--sec { display: flex; flex-direction: column; gap: 22px; }
.sec {
  display: flex;
  gap: 18px;
  padding: 22px;
  background: var(--wh);
  border: 1px solid var(--hair);
  border-radius: var(--r);
  transition: transform var(--t-base), border-color var(--t-base), box-shadow var(--t-base);
}
.sec:hover {
  transform: translateY(-3px);
  border-color: var(--gold);
  box-shadow: 0 18px 40px rgba(27, 33, 69, 0.1);
}
.sec__icon {
  flex: 0 0 48px;
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--navy);
  background: rgba(245, 200, 66, 0.18);
  border-radius: var(--rs);
}
.sec__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: 1.05rem;
  letter-spacing: -0.01em;
  color: var(--navy);
}
.sec__desc {
  margin-top: 6px;
  font-size: 0.94rem;
  line-height: 1.6;
  color: var(--navy);
  opacity: 0.78;
}

@media (max-width: 900px) {
  .ps__grid { grid-template-columns: repeat(2, 1fr); gap: 28px; }
  .glob { grid-template-columns: 1fr; }
  .glob__stat, .glob__stat--2 { position: static; margin-top: 14px; display: inline-flex; }
  .stk { grid-template-columns: 1fr; }
  .cmp__row { grid-template-columns: 1fr; }
  .cmp__lbl { grid-row: 1; grid-column: 1; }
  .cmp__row > .cmp__bar:nth-child(2) { grid-row: 2; grid-column: 1; }
  .cmp__row > .cmp__bar:nth-child(3) { grid-row: 3; grid-column: 1; }
}

/* ==========================================================
   Funnel modal
   ========================================================== */

.fnl {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--t-base);
}
.fnl.is-open { opacity: 1; pointer-events: auto; }
.fnl__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 12, 30, 0.55);
  backdrop-filter: blur(10px);
}
.fnl__panel {
  position: relative;
  width: min(920px, 96vw);
  max-height: 92vh;
  background: var(--ow);
  border-radius: var(--r);
  box-shadow: 0 40px 100px rgba(0, 0, 0, 0.4);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transform: translateY(20px) scale(0.985);
  transition: transform var(--t-base);
}
.fnl.is-open .fnl__panel { transform: translateY(0) scale(1); }

.fnl__close {
  position: absolute;
  top: 18px;
  right: 18px;
  z-index: 5;
  width: 38px; height: 38px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--navy);
  background: rgba(27, 33, 69, 0.06);
  transition: background var(--t-fast), transform var(--t-fast);
}
.fnl__close:hover { background: rgba(27, 33, 69, 0.14); transform: rotate(90deg); }

.fnl__head {
  padding: clamp(28px, 4vw, 44px) clamp(24px, 4vw, 56px) 0;
  background:
    radial-gradient(60% 80% at 0% 0%, rgba(232, 228, 240, 0.5), transparent 70%),
    radial-gradient(60% 80% at 100% 0%, rgba(248, 212, 160, 0.5), transparent 70%);
}
.fnl__eyebrow { display: inline-block; }
.fnl__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.5rem, 2.6vw, 2rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--navy);
  margin-top: 16px;
}
.fnl__progress {
  margin-top: 24px;
  height: 4px;
  background: rgba(27, 33, 69, 0.08);
  border-radius: 4px;
  overflow: hidden;
}
.fnl__progress-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--navy), var(--gold));
  border-radius: 4px;
  transition: width 0.5s var(--e);
}
.fnl__step-meta {
  margin-top: 10px;
  display: flex;
  justify-content: space-between;
  font-family: var(--label);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--navy);
  opacity: 0.6;
}

.fnl__body {
  flex: 1;
  overflow-y: auto;
  padding: clamp(28px, 4vw, 40px) clamp(24px, 4vw, 56px);
}
.fnl__step {
  animation: fnlIn 0.4s var(--e);
}
@keyframes fnlIn {
  from { opacity: 0; transform: translateX(16px); }
  to   { opacity: 1; transform: none; }
}
.fnl__step-title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.2rem, 2vw, 1.6rem);
  letter-spacing: -0.015em;
  color: var(--navy);
  line-height: 1.2;
}
.fnl__step-desc {
  margin-top: 10px;
  color: var(--navy);
  opacity: 0.78;
  font-size: 0.98rem;
  line-height: 1.65;
  max-width: 640px;
}

.fnl__foot {
  padding: 22px clamp(24px, 4vw, 56px) clamp(22px, 3vw, 32px);
  display: flex;
  justify-content: space-between;
  gap: 14px;
  border-top: 1px solid var(--hair);
  background: var(--ow);
}
.fnl__foot .bt { padding: 14px 26px; font-size: 12px; }
.fnl__back[hidden] { visibility: hidden; pointer-events: none; }

/* Cards grid */
.cgr {
  margin-top: 26px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.cgr--2 { grid-template-columns: repeat(2, 1fr); }
.cgr--wide { grid-template-columns: repeat(2, 1fr); }
.cg {
  position: relative;
  padding: 22px 18px;
  background: var(--wh);
  border: 1.5px solid var(--hair-strong);
  border-radius: var(--r);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  text-align: left;
  transition: border-color var(--t-fast), transform var(--t-fast), background var(--t-fast), box-shadow var(--t-fast);
}
.cg:hover {
  border-color: var(--gold);
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(27, 33, 69, 0.08);
}
.cg.is-sel {
  border-color: var(--gold);
  background: linear-gradient(135deg, rgba(245, 200, 66, 0.12), rgba(245, 200, 66, 0.04));
}
.cg.is-sel::after {
  content: '';
  position: absolute;
  top: 12px; right: 12px;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--gold);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231B2145' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='5 12 10 17 19 8'/></svg>");
  background-size: 14px;
  background-position: center;
  background-repeat: no-repeat;
}
.cg__icon {
  width: 36px; height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--navy);
}
.cg__icon svg { width: 100%; height: 100%; }
.cg__name {
  font-family: var(--display);
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: -0.01em;
  color: var(--navy);
}
.cg__desc {
  font-size: 0.85rem;
  line-height: 1.5;
  color: var(--navy);
  opacity: 0.7;
}
.cg--ill {
  padding: 0;
  overflow: hidden;
  min-height: 160px;
}
.cg--ill .cg__ill {
  width: 100%;
  aspect-ratio: 16 / 10;
  background: linear-gradient(135deg, #F0EEF5, #FDF0D8);
  display: block;
}
.cg--ill .cg__ill svg { width: 100%; height: 100%; display: block; }
.cg--ill .cg__txt { padding: 14px 16px 18px; display: flex; flex-direction: column; gap: 4px; }

/* Pinterest-style references grid */
.pin {
  margin-top: 26px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  grid-auto-flow: dense;
}
.pn {
  position: relative;
  border-radius: var(--rs);
  overflow: hidden;
  cursor: pointer;
  border: 2px solid transparent;
  transition: transform var(--t-fast), border-color var(--t-fast), box-shadow var(--t-fast);
  background: var(--wh);
  aspect-ratio: 1 / 1;
}
.pn:nth-child(3n+1) { aspect-ratio: 3 / 4; grid-row: span 2; }
.pn:nth-child(5n+3) { aspect-ratio: 4 / 5; grid-row: span 2; }
.pn:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(27,33,69,0.16); }
.pn.is-sel { border-color: var(--gold); box-shadow: 0 12px 32px rgba(245,200,66,0.35); }
.pn.is-sel::after {
  content: '';
  position: absolute;
  top: 8px; right: 8px;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--gold) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231B2145' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='5 12 10 17 19 8'/></svg>") center / 14px no-repeat;
}
.pn svg { width: 100%; height: 100%; display: block; }
.pn img { width: 100%; height: 100%; object-fit: contain; padding: 14px; display: block; }
/* Grid de referências reais, agrupado por tipo de logo */
.pin__group { margin-top: 22px; }
.pin__group:first-of-type { margin-top: 6px; }
.pin__glabel { display: block; font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--gold); font-weight: 600; margin: 0 0 10px 2px; }
.pin--logos { margin-top: 0; }
.pin--logos .pn { aspect-ratio: 1 / 1; grid-row: auto; background: var(--wh); }

/* Color palette */
.plt {
  margin-top: 26px;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
}
.pl {
  cursor: pointer;
  aspect-ratio: 1 / 1.1;
  border-radius: var(--rs);
  position: relative;
  display: flex;
  align-items: flex-end;
  padding: 8px;
  border: 2px solid transparent;
  transition: transform var(--t-fast), border-color var(--t-fast);
  overflow: hidden;
}
.pl:hover { transform: translateY(-2px); }
.pl.is-sel { border-color: var(--gold); }
.pl.is-sel::after {
  content: '';
  position: absolute;
  top: 6px; right: 6px;
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--gold) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231B2145' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='5 12 10 17 19 8'/></svg>") center / 12px no-repeat;
}
.pl__name {
  font-family: var(--label);
  font-weight: 600;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 4px 8px;
  background: rgba(255,255,255,0.92);
  border-radius: 4px;
  color: var(--navy);
}

/* Textarea + voice */
.tav {
  margin-top: 20px;
  position: relative;
  background: var(--wh);
  border: 1.5px solid var(--hair-strong);
  border-radius: var(--r);
  padding: 18px 20px 18px 20px;
  transition: border-color var(--t-fast);
}
.tav:focus-within { border-color: var(--navy); }
.tav textarea {
  width: 100%;
  border: 0;
  background: transparent;
  resize: vertical;
  min-height: 140px;
  font-family: var(--body);
  font-size: 1rem;
  line-height: 1.6;
  color: var(--navy);
  outline: none;
}
.tav textarea::placeholder { color: var(--navy); opacity: 0.4; }
.tav__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px dashed var(--hair);
}
.tav__hint {
  font-family: var(--label);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--navy);
  opacity: 0.55;
}
.tav__mic {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: var(--rp);
  background: var(--navy);
  color: var(--ow);
  font-family: var(--label);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  transition: background var(--t-fast), transform var(--t-fast);
  position: relative;
}
.tav__mic:hover { background: var(--navy-2); transform: translateY(-1px); }
.tav__mic svg { width: 16px; height: 16px; }
.tav__mic.is-rec { background: #E63946; }
.tav__mic.is-rec::before {
  content: '';
  position: absolute;
  inset: -6px;
  border-radius: var(--rp);
  border: 2px solid #E63946;
  animation: micPulse 1.2s var(--e) infinite;
}
@keyframes micPulse {
  0% { transform: scale(1); opacity: 0.8; }
  100% { transform: scale(1.5); opacity: 0; }
}
.tav__mic[disabled] { opacity: 0.4; cursor: not-allowed; }

/* Contact form */
.fnl__form {
  margin-top: 22px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px 14px;
}
.fnl__field { display: flex; flex-direction: column; gap: 6px; }
.fnl__field--full { grid-column: 1 / -1; }
.fnl__field label {
  font-family: var(--label);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--navy);
  opacity: 0.7;
}
.fnl__field input {
  border: 1.5px solid var(--hair-strong);
  background: var(--wh);
  border-radius: var(--rs);
  padding: 14px 16px;
  font-family: var(--body);
  font-size: 1rem;
  color: var(--navy);
  outline: none;
  transition: border-color var(--t-fast);
}
.fnl__field input:focus { border-color: var(--navy); }

/* Summary */
.sum {
  margin-top: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.sum__row {
  padding: 16px 20px;
  background: var(--wh);
  border: 1px solid var(--hair);
  border-radius: var(--rs);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
}
.sum__lbl {
  font-family: var(--label);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--navy);
  opacity: 0.62;
  flex: 0 0 180px;
}
.sum__val {
  flex: 1;
  color: var(--navy);
  font-size: 0.96rem;
  line-height: 1.5;
}
.sum__val--chips { display: flex; flex-wrap: wrap; gap: 6px; }
.sum__chip {
  display: inline-block;
  padding: 4px 10px;
  background: rgba(27, 33, 69, 0.06);
  border-radius: var(--rp);
  font-size: 0.84rem;
  color: var(--navy);
}

/* Thank-you state */
.fnl__thanks {
  text-align: center;
  padding: 24px 20px;
}
.fnl__thanks-icon {
  width: 74px;
  height: 74px;
  margin: 0 auto 18px;
  background: var(--gold);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--navy);
}
.fnl__thanks-title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  letter-spacing: -0.02em;
  color: var(--navy);
}
.fnl__thanks-desc {
  margin-top: 10px;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
  color: var(--navy);
  opacity: 0.78;
}

@media (max-width: 720px) {
  /* 100dvh = viewport visivel real do mobile (sem a barra do navegador): mantem o rodape do
     funil (botao Proximo) sempre na tela, sem cortar os passos. O body rola por dentro. */
  .fnl__panel { max-height: 100vh; max-height: 100dvh; height: 100vh; height: 100dvh; border-radius: 0; width: 100vw; }
  .cgr, .cgr--2, .cgr--wide { grid-template-columns: 1fr 1fr; }
  .pin { grid-template-columns: repeat(2, 1fr); }
  .plt { grid-template-columns: repeat(4, 1fr); }
  .fnl__form { grid-template-columns: 1fr; }
  .sum__row { flex-direction: column; gap: 6px; }
  .sum__lbl { flex: none; }
}
@media (max-width: 480px) {
  .cgr, .cgr--2, .cgr--wide { grid-template-columns: 1fr; }
  .plt { grid-template-columns: repeat(3, 1fr); }
}

body.fnl-open { overflow: hidden; }

/* ==========================================================
   MULTI-PAGE ADDITIONS
   ========================================================== */

/* ---------- nav active state ---------- */
.nv__links a[aria-current="page"]::after { transform: scaleX(1); }
.nv__links a[aria-current="page"] { font-weight: 600; }

/* ---------- page hero (inner pages) ---------- */
.phr {
  position: relative;
  padding: clamp(128px, 16vw, 188px) var(--pad-x) clamp(48px, 7vw, 92px);
  overflow: hidden;
}
.phr__bg {
  position: absolute;
  inset: -10% -5%;
  background:
    radial-gradient(55% 50% at 12% 8%, rgba(232, 228, 240, 0.85), transparent 70%),
    radial-gradient(45% 45% at 92% 6%, rgba(212, 240, 232, 0.8), transparent 70%),
    radial-gradient(60% 55% at 88% 96%, rgba(248, 212, 160, 0.8), transparent 70%),
    linear-gradient(135deg, #F0EEF5 0%, #F5F3F0 50%, #FDF0D8 85%, #F8E8B0 100%);
  z-index: -2;
}
.phr::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url('../assets/textura-hypearts.webp');
  background-size: cover;
  background-position: center;
  opacity: 0.06;
  mix-blend-mode: multiply;
  pointer-events: none;
  z-index: -1;
}
.phr__inner {
  max-width: var(--container);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: center;
}
.phr__inner--solo { grid-template-columns: 1fr; }
.phr__content { max-width: 680px; }
.phr__title {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(2.2rem, 5.4vw, 4.2rem);
  line-height: 1.04;
  letter-spacing: -0.03em;
  color: var(--navy);
  margin-top: 22px;
}
.phr__title em { font-weight: 900; }
.phr__def {
  margin-top: 24px;
  padding-left: 18px;
  border-left: 3px solid var(--gold);
  max-width: 600px;
  font-size: clamp(0.98rem, 1.3vw, 1.08rem);
  line-height: 1.6;
  color: var(--navy);
  opacity: 0.82;
}
.phr__lead {
  margin-top: 24px;
  max-width: 620px;
  font-size: clamp(1.02rem, 1.5vw, 1.2rem);
  line-height: 1.65;
  color: var(--navy);
  opacity: 0.86;
}
.phr__actions { margin-top: 34px; display: flex; gap: 14px; flex-wrap: wrap; }
.phr__media { position: relative; }

@media (max-width: 960px) {
  .phr__inner, .phr__inner--solo { grid-template-columns: 1fr; gap: 28px; }
  .phr__media { order: -1; max-width: 520px; }
}

/* ---------- image placeholders ---------- */
.imgph {
  position: relative;
  width: 100%;
  border-radius: var(--r);
  overflow: hidden;
  background: #2A2D3A;
  background-image:
    radial-gradient(120% 120% at 0% 0%, rgba(245, 200, 66, 0.06), transparent 55%),
    linear-gradient(135deg, #2A2D3A 0%, #232636 100%);
  border: 1px solid rgba(245, 200, 66, 0.14);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
  padding: 18px;
  box-shadow: 0 18px 44px rgba(27, 33, 69, 0.16);
}
.imgph::before {
  content: '';
  position: absolute;
  inset: 12px;
  border: 1px dashed rgba(245, 200, 66, 0.22);
  border-radius: calc(var(--r) - 6px);
  pointer-events: none;
}
.imgph img { width: 100%; height: 100%; object-fit: cover; display: block; }
.imgph--filled::before { display: none; }
.imgph--filled { background: var(--navy); }
.imgph__lbl {
  font-family: var(--label);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  position: relative;
  z-index: 1;
}
.imgph__dim {
  font-family: var(--label);
  font-weight: 500;
  font-size: 10px;
  letter-spacing: 0.16em;
  color: var(--ow);
  opacity: 0.45;
  position: relative;
  z-index: 1;
}

/* ---------- "o que entrega": esteira horizontal com icone por etapa ---------- */
.deliv {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  /* respiro nas 4 bordas pra sombra dos cards não cortar; margens devolvem o alinhamento */
  padding: 12px 26px 42px;
  margin: -6px -26px -18px;
  scroll-padding-inline: 26px;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
@media (max-width: 900px) {
  .deliv { padding-left: 18px; padding-right: 18px; margin-left: -18px; margin-right: -18px; scroll-padding-inline: 18px; }
}
.deliv::-webkit-scrollbar { display: none; }
.deliv__item {
  flex: 0 0 auto;
  width: clamp(204px, 22vw, 252px);
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 20px 22px 22px;
  background: var(--wh);
  border: 1px solid var(--hair);
  border-radius: var(--r);
  transition: border-color var(--t-base), transform var(--t-base);
}
.deliv__item:hover { border-color: var(--gold); transform: translateY(-2px); }
.deliv__ic { width: 40px; height: 40px; border-radius: 12px; background: rgba(245, 200, 66, 0.16); color: var(--navy); display: inline-flex; align-items: center; justify-content: center; }
.deliv__ic svg { width: 20px; height: 20px; display: block; }
.deliv__txt { font-size: 0.98rem; line-height: 1.55; color: var(--navy); }

/* ---------- process steps "como funciona" ---------- */
.proc {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  counter-reset: proc;
}
.proc__step {
  padding: 28px 24px;
  background: var(--wh);
  border: 1px solid var(--hair);
  border-radius: var(--r);
  border-top: 3px solid var(--gold);
  box-shadow: 0 14px 36px rgba(27, 33, 69, 0.09);
  transition: transform var(--t-base), box-shadow var(--t-base);
}
.proc__step:hover { transform: translateY(-4px); box-shadow: 0 20px 44px rgba(27, 33, 69, 0.13); }
.proc__num {
  font-family: var(--display);
  font-weight: 800;
  font-size: 1rem;
  color: var(--navy);
  opacity: 0.4;
  letter-spacing: 0.1em;
}
.proc__name {
  font-family: var(--display);
  font-weight: 800;
  font-size: 1.2rem;
  letter-spacing: -0.01em;
  color: var(--navy);
  margin-top: 8px;
}
.proc__desc { margin-top: 10px; font-size: 0.95rem; line-height: 1.6; color: var(--navy); opacity: 0.8; }
@media (max-width: 980px) { .proc { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .proc { grid-template-columns: 1fr; } }

/* ---------- principle block ---------- */
.prin {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: clamp(28px, 5vw, 72px);
  align-items: start;
  border-top: 1px solid var(--hair-strong);
  padding-top: clamp(40px, 5vw, 64px);
}
.prin__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--navy);
}
.prin__desc {
  margin-top: 0;
  max-width: 720px;
  font-size: clamp(1rem, 1.4vw, 1.12rem);
  line-height: 1.75;
  color: var(--navy);
  opacity: 0.84;
}
.prin__body .prin__desc + .prin__desc { margin-top: 18px; }
@media (max-width: 880px) { .prin { grid-template-columns: 1fr; gap: 16px; } }
.prin--solo { grid-template-columns: 1fr; }
.prin--solo .prin__title { font-size: clamp(2.2rem, 6vw, 3.6rem); max-width: 20ch; line-height: 1.06; }

/* statement centralizado, grande, animado (estilo depoimento) */
.stmt { max-width: 940px; margin: 0 auto; text-align: center; padding: clamp(24px, 5vw, 64px) 0; }
.stmt__quote {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(2.3rem, 6.4vw, 4.8rem);
  line-height: 1.04;
  letter-spacing: -0.035em;
  color: var(--navy);
  min-height: 2.1em;
}
.stmt__quote em { font-weight: 900; color: var(--navy); }

/* ---------- FAQ ---------- */
.faq { max-width: 880px; margin-left: auto; margin-right: auto; display: flex; flex-direction: column; gap: 0; } /* bloco centralizado; texto interno segue à esquerda */
.faq__item {
  border-bottom: 1px solid var(--hair-strong);
}
.faq__item summary {
  list-style: none;
  cursor: pointer;
  padding: 24px 48px 24px 0;
  position: relative;
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(1.05rem, 1.7vw, 1.25rem);
  line-height: 1.35;
  letter-spacing: -0.01em;
  color: var(--navy);
}
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary::after {
  content: '';
  position: absolute;
  right: 6px;
  top: 30px;
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231B2145' stroke-width='2' stroke-linecap='round'><line x1='12' y1='5' x2='12' y2='19'/><line x1='5' y1='12' x2='19' y2='12'/></svg>") center / contain no-repeat;
  transition: transform 0.4s var(--e-soft);
}
.faq__item[open] summary::after,
.faq__item.is-open summary::after { transform: rotate(135deg); }
/* enquanto a resposta desliza, o conteúdo do details não pode estourar */
.faq__a { overflow: hidden; }
.faq__a {
  padding: 0 48px 26px 0;
  max-width: 720px;
  font-size: 1rem;
  line-height: 1.7;
  color: var(--navy);
  opacity: 0.84;
}

/* ---------- logos carousel (infinite) ---------- */
.logos { overflow: hidden; position: relative; -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); }
.logos__track { display: flex; width: max-content; animation: logoScroll 32s linear infinite; will-change: transform; backface-visibility: hidden; transform: translateZ(0); }
.logos:hover .logos__track { animation-play-state: paused; }
@keyframes logoScroll { from { transform: translate3d(0, 0, 0); } to { transform: translate3d(-50%, 0, 0); } }
@media (prefers-reduced-motion: reduce) { .logos__track { animation: none; flex-wrap: wrap; width: auto; justify-content: center; } }

/* ---------- home: numbers ---------- */
.nums {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 4vw, 56px);
  border-top: 1px solid var(--hair-strong);
  padding-top: clamp(40px, 5vw, 64px);
}
.num__big {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(2.6rem, 6vw, 4.4rem);
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--navy);
}
.num__big em { color: var(--navy); }
.num__lbl {
  margin-top: 14px;
  font-size: 1rem;
  line-height: 1.5;
  color: var(--navy);
  opacity: 0.78;
  max-width: 280px;
}
@media (max-width: 760px) { .nums { grid-template-columns: 1fr; gap: 28px; } }

/* ---------- home: service preview cards (mockups em destaque) ---------- */
/* ===== Serviços: carrossel focal (centro em foco, laterais atrás) ===== */
/* ===== Serviços: carrossel scroll-snap, recorte flutuando acima do card ===== */
.svc { --svc-gap: clamp(18px, 2.2vw, 28px); --rise: clamp(74px, 8.5vw, 116px); position: relative; margin-top: clamp(6px, 1vw, 14px); }

.svc__scroller {
  display: flex;
  gap: var(--svc-gap);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  /* topo: recorte rompe o card e cresce no hover; laterais e base: sombra flutua sem corte */
  padding: calc(var(--rise) + 30px) 44px 68px;
  margin: 0 -44px -28px;
  scroll-padding-inline: 44px;
}
.svc__scroller::-webkit-scrollbar { display: none; }
.svc__scroller:focus-visible { outline: 2px solid var(--gold); outline-offset: 4px; border-radius: var(--r); }

.svcard {
  flex: 0 0 calc((100% - 2 * var(--svc-gap)) / 3);
  scroll-snap-align: center;
  scroll-snap-stop: always; /* swipe forte para no próximo card, não atravessa o carrossel */
  position: relative;
  display: flex; flex-direction: column;
  background: var(--ow);
  border: 1px solid var(--hair);
  border-radius: var(--r);
  box-shadow: 0 16px 40px rgba(27, 33, 69, 0.10);
  text-decoration: none;
  transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base), filter 0.45s var(--e), opacity 0.45s var(--e);
}
.svcard:hover { transform: translateY(-6px); box-shadow: 0 20px 42px rgba(27, 33, 69, 0.16); border-color: rgba(245, 200, 66, 0.5); }

/* o recorte sem fundo rompe o topo do card */
.svcard__float { position: relative; height: clamp(92px, 10vw, 128px); pointer-events: none; }
.svcard__float img {
  position: absolute; left: 50%; bottom: 8px;
  transform: translateX(-50%);
  width: 92%; height: auto;
  filter: drop-shadow(0 22px 26px rgba(10, 12, 30, 0.20));
  transition: transform 0.6s var(--e);
}
.svcard:hover .svcard__float img { transform: translateX(-50%) translateY(-8px) scale(1.03); }

.svcard__body { padding: clamp(20px, 2vw, 28px); padding-top: 0; display: flex; flex-direction: column; flex: 1; position: relative; z-index: 2; }
.svcard__ic { width: 34px; height: 34px; color: var(--gold); margin: -30px 0 12px; position: relative; z-index: 3; perspective: 420px; }
.svcard__ic svg { width: 100%; height: 100%; display: block; overflow: visible; filter: drop-shadow(0 2px 6px rgba(10, 12, 30, 0.25)); }
.svcard__name { font-family: var(--display); font-weight: 800; font-size: clamp(1.4rem, 1.9vw, 1.9rem); letter-spacing: -0.015em; color: var(--navy); line-height: 1.05; }
.svcard__rule { width: 42px; height: 2px; background: var(--gold); margin: 14px 0; border-radius: 2px; }
.svcard__desc { font-size: 0.98rem; line-height: 1.6; color: var(--navy); opacity: 0.8; flex: 1; }
.svcard__btn { margin-top: 20px; align-self: flex-start; width: 48px; height: 48px; border-radius: 50%; background: var(--navy); color: var(--gold); display: inline-flex; align-items: center; justify-content: center; transition: transform var(--t-base), background var(--t-base); }
.svcard__btn svg { width: 19px; height: 19px; }
.svcard:hover .svcard__btn { transform: translateX(4px); background: #232a55; }

/* controle: setas + dots (aparecem quando da pra rolar = mobile) */
.svc__nav { display: none; align-items: center; justify-content: center; gap: 16px; margin-top: clamp(20px, 3vw, 30px); }
.svc__arrow {
  width: 50px; height: 50px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--navy);
  background: rgba(255, 255, 255, 0.5);
  border: 1px solid var(--hair);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85), 0 8px 22px rgba(27, 33, 69, 0.10);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  cursor: pointer;
  transition: transform var(--t-base), background var(--t-base), color var(--t-base), opacity var(--t-base), border-color var(--t-base);
}
.svc__arrow svg { width: 22px; height: 22px; }
.svc__arrow:hover { background: var(--navy); color: var(--gold); border-color: var(--navy); transform: translateY(-2px); }
.svc__arrow[disabled] { opacity: 0.32; pointer-events: none; }
.svc__dots { display: inline-flex; align-items: center; gap: 9px; }
.svc__dot { position: relative; width: 8px; height: 8px; border-radius: 50%; padding: 0; cursor: pointer; background: rgba(27, 33, 69, 0.2); border: 0; transition: width var(--t-base), background var(--t-base); }
.svc__dot::after { content: ''; position: absolute; inset: -12px -6px; }
.svc__dot:hover { background: rgba(27, 33, 69, 0.46); }
.svc__dot.is-on { background: var(--gold); width: 22px; border-radius: 5px; }

/* ---- icones animados (hover no desktop; card central no mobile) ---- */
.ic, .ic * { transform-box: fill-box; transform-origin: center; }
@media (prefers-reduced-motion: no-preference) {
  @media (hover: hover) {
    .svcard:hover .ic--diamond { animation: icSpin 3.2s var(--e) infinite; }
    .svcard:hover .ic--code .ic__chev--l { animation: icChevL 1.5s var(--e) infinite; }
    .svcard:hover .ic--code .ic__chev--r { animation: icChevR 1.5s var(--e) infinite; }
    .svcard:hover .ic--chat .ic__dot { animation: icType 1.4s ease-in-out infinite; }
    .svcard:hover .ic--chat .ic__dot--2 { animation-delay: 0.18s; }
    .svcard:hover .ic--chat .ic__dot--3 { animation-delay: 0.36s; }
  }
}
@keyframes icSpin { to { transform: rotateY(360deg); } }
@keyframes icChevL { 0%, 100% { transform: translateX(0); } 50% { transform: translateX(-1.8px); } }
@keyframes icChevR { 0%, 100% { transform: translateX(0); } 50% { transform: translateX(1.8px); } }
@keyframes icType { 0%, 70%, 100% { transform: translateY(0); opacity: 0.4; } 35% { transform: translateY(-2px); opacity: 1; } }

@media (max-width: 900px) {
  .svc { --rise: clamp(64px, 17vw, 96px); }
  .svc__nav { display: flex; }
  .svc__scroller { gap: 14px; padding-left: 18px; padding-right: 18px; margin-left: -18px; margin-right: -18px; scroll-padding-inline: 18px; }
  .svcard { flex-basis: 72%; }
  .svcard.is-mid .ic--diamond { animation: icSpin 3.2s var(--e) infinite; }
  .svcard.is-mid .ic--code .ic__chev--l { animation: icChevL 1.5s var(--e) infinite; }
  .svcard.is-mid .ic--code .ic__chev--r { animation: icChevR 1.5s var(--e) infinite; }
  .svcard.is-mid .ic--chat .ic__dot { animation: icType 1.4s ease-in-out infinite; }
  .svcard.is-mid .ic--chat .ic__dot--2 { animation-delay: 0.18s; }
  .svcard.is-mid .ic--chat .ic__dot--3 { animation-delay: 0.36s; }
}
@media (max-width: 560px) { .svcard { flex-basis: 80%; } }

/* ===== Depoimentos: carrossel scroll-snap ===== */
.sc__head--center { margin-left: auto; margin-right: auto; text-align: center; }
.tst { --tst-gap: clamp(16px, 2vw, 26px); position: relative; margin-top: clamp(20px, 3vw, 38px); }
.tst__scroller {
  display: flex; gap: var(--tst-gap);
  overflow-x: auto; scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch; scrollbar-width: none;
  padding: 34px 44px 66px; scroll-padding-inline: 44px;
  margin: 0 -44px -28px;
}
.tst__scroller::-webkit-scrollbar { display: none; }
.tst__scroller:focus-visible { outline: 2px solid var(--gold); outline-offset: 4px; border-radius: var(--r); }
.tcard {
  flex: 0 0 calc((100% - 2 * var(--tst-gap)) / 3);
  scroll-snap-align: center;
  scroll-snap-stop: always;
  position: relative; margin: 0;
  display: flex; flex-direction: column;
  background: var(--ow);
  border: 1px solid var(--hair);
  border-radius: var(--r);
  box-shadow: 0 16px 40px rgba(27, 33, 69, 0.08);
  padding: clamp(26px, 2.4vw, 38px);
  transition: filter 0.45s var(--e), opacity 0.45s var(--e);
}
.tcard__mark { position: absolute; top: 10px; right: 22px; font-family: var(--display); font-weight: 800; font-size: 4.2rem; line-height: 1; color: var(--gold); opacity: 1; pointer-events: none; }
.tcard__head { font-family: var(--display); font-weight: 800; font-size: clamp(1.3rem, 1.7vw, 1.7rem); letter-spacing: -0.01em; color: var(--navy); margin-bottom: 14px; position: relative; }
.tcard__quote { font-size: 1rem; line-height: 1.72; color: var(--navy); opacity: 0.82; flex: 1; }
.tcard__by { display: flex; align-items: center; gap: 13px; margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--hair); }
.tcard__av { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; flex: 0 0 48px; border: 1px solid var(--hair); }
.tcard__who { display: flex; flex-direction: column; line-height: 1.32; }
.tcard__who strong { font-weight: 700; color: var(--navy); font-size: 0.95rem; }
.tcard__who span { font-size: 0.82rem; color: var(--navy); opacity: 0.6; }
@media (max-width: 900px) {
  .tst__scroller { gap: 14px; padding-left: 18px; padding-right: 18px; margin-left: -18px; margin-right: -18px; scroll-padding-inline: 18px; }
  .tcard { flex-basis: 82%; }
}
@media (max-width: 560px) { .tcard { flex-basis: 88%; } }



/* ===== Founder / quem está por trás ===== */
.fnd__inner { display: grid; grid-template-columns: 0.82fr 1fr; gap: clamp(28px, 5vw, 70px); align-items: center; max-width: 1020px; margin: 0 auto; }
.fnd__photo { position: relative; border-radius: var(--r); overflow: hidden; aspect-ratio: 4 / 5; box-shadow: 0 26px 60px rgba(27, 33, 69, 0.2); border: 1px solid var(--hair); }
.fnd__photo img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 20%; display: block; }
.fnd__photo-glow { position: absolute; inset: auto -15% -22% auto; width: 66%; height: 56%; background: radial-gradient(60% 60% at 72% 72%, rgba(245, 200, 66, 0.3), transparent 70%); pointer-events: none; }
.fnd__title { font-family: var(--display); font-weight: 800; font-size: clamp(1.9rem, 3.6vw, 3rem); line-height: 1.06; letter-spacing: -0.02em; color: var(--navy); margin: 14px 0 18px; }
.fnd__title em { font-style: italic; }
.fnd__lead { font-size: clamp(1rem, 1.2vw, 1.1rem); line-height: 1.75; color: var(--navy); opacity: 0.84; margin-bottom: 14px; max-width: 46ch; }
.fnd__sign { display: inline-block; margin-top: 10px; font-family: var(--label); font-weight: 600; font-size: 0.82rem; letter-spacing: 0.05em; color: var(--navy); opacity: 0.6; }
@media (max-width: 760px) {
  .fnd__inner { grid-template-columns: 1fr; gap: 26px; max-width: 440px; }
  .fnd__photo { aspect-ratio: 4 / 4.2; }
}

/* ---------- home/trabalho: teaser cases ---------- */
.tcase { display: flex; flex-direction: column; }
.tcase__row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 28px 0;
  border-top: 1px solid var(--hair-strong);
  transition: padding var(--t-base);
}
.tcase__row:last-child { border-bottom: 1px solid var(--hair-strong); }
.tcase__client {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.3rem, 2.4vw, 1.9rem);
  letter-spacing: -0.02em;
  color: var(--navy);
}
a.tcase__client {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  text-decoration: none;
  transition: color var(--t-base);
}
a.tcase__client::after {
  content: '\2197'; /* seta diagonal: indica link externo */
  font-family: var(--body);
  font-size: 0.62em;
  font-weight: 600;
  opacity: 0;
  transform: translate(-5px, 2px);
  transition: opacity var(--t-base), transform var(--t-base);
}
a.tcase__client:hover { color: #b8860b; } /* dourado escurecido: legível sobre card claro */
a.tcase__client:hover::after { opacity: 0.75; transform: translate(0, 0); }
.tcase__desc { margin-top: 6px; font-size: 1rem; line-height: 1.55; color: var(--navy); opacity: 0.8; max-width: 640px; }
.tcase__years {
  font-family: var(--label);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--navy);
  opacity: 0.55;
  white-space: nowrap;
}
@media (max-width: 640px) { .tcase__row { grid-template-columns: 1fr; gap: 8px; } }

/* ---------- CTA band ---------- */
.ctab {
  background: var(--navy);
  color: var(--ow);
  border-radius: var(--r);
  padding: clamp(44px, 6vw, 80px) clamp(32px, 5vw, 72px);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.ctab::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url('../assets/textura-hypearts.webp');
  background-size: cover;
  background-position: center;
  opacity: 0.05;
  mix-blend-mode: screen;
}
.ctab__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.8rem, 3.6vw, 2.8rem);
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: var(--ow);
  position: relative;
}
.ctab__title em { color: var(--gold); font-weight: 800; }
.ctab__lead { margin: 18px auto 0; max-width: 560px; font-size: 1.05rem; line-height: 1.6; color: var(--ow); opacity: 0.8; position: relative; }
.ctab__actions { margin-top: 32px; display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; position: relative; }
.ctab .bt--ghost { color: var(--ow); border-color: rgba(255,255,255,0.4); }
.ctab .bt--ghost:hover { background: var(--ow); color: var(--navy); border-color: var(--ow); }
.ctab .bt--gold { background: var(--gold); color: var(--navy); }
.ctab .bt--gold:hover { background: #ffd969; transform: translateY(-2px); box-shadow: 0 12px 28px rgba(245, 200, 66, 0.3); }

/* ---------- trabalho: galleries ---------- */
.galw { padding: clamp(40px, 5vw, 72px) 0; border-top: 1px solid var(--hair-strong); }
.galw:last-of-type { border-bottom: 1px solid var(--hair-strong); }
.galw__head { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 16px; margin-bottom: 28px; }
.galw__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(2rem, 4.6vw, 3.6rem); /* mesmo tamanho das chamadas de seção (.sc__title) */
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--navy);
}
.galw__title em { font-weight: 800; }
.galw__client {
  font-family: var(--label);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--navy);
  opacity: 0.55;
  margin-bottom: 6px;
  display: block;
}
.galw__lead { max-width: 640px; font-size: 1rem; line-height: 1.65; color: var(--navy); opacity: 0.82; }
.galw__stats { display: flex; flex-wrap: wrap; gap: 10px 36px; margin-bottom: 26px; }
.gal {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(260px, 1fr);
  gap: 14px;
  overflow-x: auto;
  padding-bottom: 14px;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
}
.gal__item {
  scroll-snap-align: start;
  position: relative;
  border-radius: var(--r);
  overflow: hidden;
}
.gal__item .imgph { aspect-ratio: 3 / 2; }
.gal__cap {
  position: absolute;
  inset: auto 0 0 0;
  padding: 14px 16px;
  background: linear-gradient(transparent, rgba(10, 12, 30, 0.82));
  color: var(--ow);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity var(--t-base), transform var(--t-base);
  z-index: 2;
}
.gal__item:hover .gal__cap { opacity: 1; transform: none; }
.gal__cap-name { font-family: var(--display); font-weight: 700; font-size: 0.95rem; }
.gal__cap-meta { font-family: var(--label); font-weight: 500; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; opacity: 0.75; }

/* trabalho recent mosaic */
.recent {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
}
.recent__item { display: flex; flex-direction: column; gap: 10px; }
.recent__item .imgph { aspect-ratio: 4 / 3; }
.recent__meta { display: flex; flex-direction: column; gap: 2px; }
.recent__client { font-family: var(--display); font-weight: 700; font-size: 0.98rem; color: var(--navy); }
.recent__type { font-family: var(--label); font-weight: 500; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--navy); opacity: 0.6; }
.recent__date { font-size: 0.85rem; color: var(--navy); opacity: 0.6; }

/* ---------- estudio: bio + portrait ---------- */
.bio {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: start;
}
.bio__portrait .imgph { aspect-ratio: 4 / 5; }
.bio__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(2rem, 4.6vw, 3.6rem); /* mesmo tamanho das chamadas de seção (.sc__title) */
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--navy);
}
.bio__desc { margin-top: 22px; max-width: 640px; font-size: clamp(1rem, 1.4vw, 1.12rem); line-height: 1.75; color: var(--navy); opacity: 0.85; }
.bio__desc + .bio__desc { margin-top: 16px; }
@media (max-width: 880px) { .bio { grid-template-columns: 1fr; } .bio__portrait { max-width: 420px; } }

/* principles list (estudio) */
.princ { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.princ__item { padding: 28px 26px; background: var(--wh); border: 1px solid var(--hair); border-radius: var(--r); border-left: 3px solid var(--gold); }
.princ__t { font-family: var(--display); font-weight: 800; font-size: 1.15rem; letter-spacing: -0.01em; color: var(--navy); }
.princ__d { margin-top: 10px; font-size: 0.96rem; line-height: 1.6; color: var(--navy); opacity: 0.8; }
@media (max-width: 880px) { .princ { grid-template-columns: 1fr; } }

/* bastidor gallery reuses .gal */
.bast .imgph { aspect-ratio: 3 / 2; }

/* timeline */
.tl { max-width: 820px; border-left: 2px solid var(--hair-strong); margin-left: 6px; }
.tl__item { position: relative; padding: 0 0 32px 32px; }
.tl__item:last-child { padding-bottom: 0; }
.tl__item::before {
  content: '';
  position: absolute;
  left: -7px;
  top: 4px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--gold);
  border: 2px solid var(--ow);
}
.tl__year { font-family: var(--display); font-weight: 800; font-size: 1.05rem; color: var(--navy); }
.tl__t { font-family: var(--display); font-weight: 700; font-size: 1.05rem; color: var(--navy); margin-top: 2px; }
.tl__d { margin-top: 6px; font-size: 0.96rem; line-height: 1.6; color: var(--navy); opacity: 0.8; }

/* ---------- contato: map + availability ---------- */
.ctmap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 5vw, 64px);
  align-items: center;
  border-top: 1px solid var(--hair-strong);
  padding-top: clamp(40px, 5vw, 64px);
}
.ctmap__svg {
  width: 100%;
  height: auto;
  border-radius: var(--r);
  background: linear-gradient(135deg, #F0EEF5 0%, #F5F3F0 60%, #FDF0D8 100%);
  border: 1px solid var(--hair);
  box-shadow: 0 18px 44px rgba(27, 33, 69, 0.08);
  display: block;
}
.ctmap__title { font-family: var(--display); font-weight: 800; font-size: clamp(1.6rem, 3vw, 2.4rem); letter-spacing: -0.02em; color: var(--navy); margin-top: 16px; }
.ctmap__desc { margin-top: 18px; font-size: 1rem; line-height: 1.7; color: var(--navy); opacity: 0.84; max-width: 480px; }
.ctmap__desc + .ctmap__desc { margin-top: 12px; }
@media (max-width: 880px) { .ctmap { grid-template-columns: 1fr; } }

.avail {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.avail__item { padding: 26px 24px; background: var(--wh); border: 1px solid var(--hair); border-radius: var(--r); }
.avail__lbl { font-family: var(--label); font-weight: 500; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--navy); opacity: 0.55; }
.avail__val { font-family: var(--display); font-weight: 800; font-size: 1.2rem; color: var(--navy); margin-top: 8px; letter-spacing: -0.01em; }
.avail__d { margin-top: 6px; font-size: 0.92rem; line-height: 1.55; color: var(--navy); opacity: 0.78; }
@media (max-width: 760px) { .avail { grid-template-columns: 1fr; } }

/* ---------- footer freshness ---------- */
.ft__fresh {
  font-family: var(--label);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ow);
  opacity: 0.55;
}

/* ---------- 404 ---------- */
.nf {
  min-height: 70vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: clamp(120px, 16vw, 200px) var(--pad-x) 80px;
}
.nf__code {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(5rem, 18vw, 11rem);
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--navy);
}
.nf__code em { color: var(--gold); }
.nf__msg { margin-top: 18px; font-size: 1.1rem; color: var(--navy); opacity: 0.8; max-width: 460px; }
.nf__actions { margin-top: 32px; display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }

/* section helper for white sub-bg sections */
.sc--soft { background: linear-gradient(180deg, transparent, rgba(232, 228, 240, 0.18)); }

/* ==========================================================
   GLOBAL BACKGROUND FX — luzes + profundidade + textura (todo o scroll)
   ========================================================== */

.bgfx {
  position: fixed;
  inset: 0;
  z-index: -2;
  overflow: hidden;
  background: #ffffff;
  pointer-events: none;
  --p: 0;
}

/* fundo de referência: branco com glow amarelo (topo) e azul/ciano (direita) */
.bgfx__warm {
  position: absolute;
  inset: -3%;
  background-image: url('../assets/img/bg-site.webp?v=20260603');
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  will-change: transform;
}
.bgfx__cool { display: none; }

/* BLOBS LÍQUIDOS COM PELE DE VIDRO — duas poças orgânicas de cor (amarela inf-esq, ciano
   sup-dir) que abraçam a borda da tela: o lado de fora morre na moldura do viewport, o
   lado de dentro é a silhueta orgânica em morph contínuo (rascunho do Jordan, formas
   pintadas). ::before = o líquido: cor blurada com densidade variável (2 miolos de
   radial-gradient). ::after = a pele de vidro delicada NA MESMA forma, mesmo morph
   sincronizado: fio de borda branca, brilho suave e blur de vidro sutil no desktop.
   No scroll percorrem as bordas devagar (js/parallax.js escreve translate/rotate/scale,
   propriedades individuais que compõem com a deriva do CSS em `transform`; o scale
   achata a poça contra a borda). */
.bgfx__lights { position: absolute; inset: 0; }
.bgfx__light {
  position: absolute;
  display: none; /* luzes azul/amarela removidas de vez (Jordan 2026-06-19): site mais limpo e branco, e zero risco de trava no iPhone. O fundo fica so o bg-site.webp. */
}
/* o líquido */
.bgfx__light::before {
  content: '';
  position: absolute;
  inset: -3%;
  border-radius: 62% 38% 56% 44% / 48% 62% 38% 52%;
  filter: blur(46px);
  animation: blobMorphA 30s ease-in-out infinite;
}
/* a pele de vidro: mesma forma, mesmo ritmo do líquido */
.bgfx__light::after {
  content: '';
  position: absolute;
  inset: 1.5%;
  border-radius: 62% 38% 56% 44% / 48% 62% 38% 52%;
  border: 1px solid rgba(255, 255, 255, 0.52);
  background: linear-gradient(168deg, rgba(255, 255, 255, 0.28), rgba(255, 255, 255, 0.03) 42%, rgba(255, 255, 255, 0.10) 88%);
  animation: blobMorphA 30s ease-in-out infinite;
}
/* vidro de verdade só no desktop (backdrop-filter pesa no mobile) */
@media (min-width: 769px) {
  .bgfx__light::after {
    -webkit-backdrop-filter: blur(6px);
            backdrop-filter: blur(6px);
  }
}
.bgfx__light.b1 {
  width: 684px; height: 528px;
  bottom: -12%; left: -10%;
  rotate: -10deg;
  animation: orbDrift1 52s ease-in-out infinite;
}
.bgfx__light.b2 {
  width: 716px; height: 552px;
  top: -12%; right: -10%;
  rotate: -10deg;
  animation: orbDrift2 60s ease-in-out infinite -20s;
}
.bgfx__light.b1::before {
  background:
    radial-gradient(58% 64% at 36% 38%, rgba(245, 200, 66, 0.9), rgba(245, 200, 66, 0) 70%),
    radial-gradient(52% 58% at 68% 66%, rgba(239, 177, 59, 0.78), rgba(239, 177, 59, 0) 72%);
  opacity: 0.57;
}
.bgfx__light.b2::before {
  background:
    radial-gradient(58% 64% at 64% 36%, rgba(111, 205, 230, 0.9), rgba(111, 205, 230, 0) 70%),
    radial-gradient(52% 58% at 34% 66%, rgba(84, 185, 218, 0.78), rgba(84, 185, 218, 0) 72%);
  opacity: 0.55;
}
.bgfx__light.b3, .bgfx__light.b4, .bgfx__light.b5, .bgfx__light.b6 { display: none; }

/* a forma da poça muda o tempo todo, devagar */
@keyframes blobMorphA {
  0%, 100% { border-radius: 62% 38% 56% 44% / 48% 62% 38% 52%; }
  33%      { border-radius: 44% 56% 66% 34% / 58% 42% 60% 40%; }
  66%      { border-radius: 56% 44% 42% 58% / 38% 58% 44% 62%; }
}

@keyframes orbDrift1 {
  0%, 100% { transform: translate3d(0, 0, 0); }
  25%      { transform: translate3d(36px, -26px, 0); }
  50%      { transform: translate3d(-26px, 34px, 0); }
  75%      { transform: translate3d(28px, 18px, 0); }
}
@keyframes orbDrift2 {
  0%, 100% { transform: translate3d(0, 0, 0); }
  25%      { transform: translate3d(-34px, 26px, 0); }
  50%      { transform: translate3d(30px, -30px, 0); }
  75%      { transform: translate3d(-22px, -18px, 0); }
}

.bgfx__tx { display: none; }

.hr.is-parallax .hr__poly { will-change: transform; }

/* o fundo global substitui os fundos locais do hero / page-hero */
.hr__bg, .phr__bg { display: none; }
.hr::after, .phr::after { display: none; }

@media (max-width: 768px) {
  /* iPhone (causa raiz do scroll travado): o fundo é uma camada FIXA e os blobs carregam blur
     de 38px. O Safari não consegue congelar uma camada fixa borrada, então repinta esse blur a
     cada frame enquanto a página rola por cima. No mobile as poças vivas saem de vez: o glow
     amarelo/ciano já está pintado no bg-site.webp, então o visual fica praticamente igual e o
     scroll destrava. A órbita JS (parallax.js) e o dotfield já eram desktop-only. */
  .bgfx__light { display: none; }
  .bgfx__warm { will-change: auto; }
}
@media (prefers-reduced-motion: reduce) {
  .bgfx__light, .bgfx__light::before, .bgfx__light::after { animation: none; }
}

/* ==========================================================
   LIQUID GLASS — botões e cards flutuantes (estilo Apple, sutil)
   ========================================================== */

/* Identidade única de vidro inset: navy = .bt--solid + .nv__cta; sem relevo pra fora */
.bt--solid, .nv__cta {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, #242b56 0%, #1B2145 100%);
  color: var(--ow);
  border: 1px solid rgba(255, 255, 255, 0.16);
  box-shadow:
    inset 0 1px 1px rgba(255, 255, 255, 0.22),
    inset 0 -11px 22px rgba(0, 0, 0, 0.22),
    inset 0 0 0 1px rgba(143, 220, 236, 0.05);
}
.bt--solid::before, .nv__cta::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: inset 0 0 14px rgba(143, 220, 236, 0.10);
  pointer-events: none;
}
.bt--solid:hover, .nv__cta:hover {
  background: linear-gradient(180deg, #2b3266 0%, #20264f 100%);
  border-color: rgba(143, 220, 236, 0.42);
  transform: none;
  box-shadow:
    inset 0 1px 1px rgba(255, 255, 255, 0.28),
    inset 0 -11px 22px rgba(0, 0, 0, 0.2),
    inset 0 0 18px rgba(143, 220, 236, 0.16);
}
.hd.is-stuck .nv__cta { box-shadow:
    inset 0 1px 1px rgba(255, 255, 255, 0.22),
    inset 0 -11px 22px rgba(0, 0, 0, 0.22); }

/* ghost = vidro fosco inset */
.bt--ghost {
  background: rgba(255, 255, 255, 0.42);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
          backdrop-filter: blur(12px) saturate(140%);
  color: var(--navy);
  border: 1px solid rgba(27, 33, 69, 0.16);
  box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.7), inset 0 -8px 18px rgba(27, 33, 69, 0.05);
}
.bt--ghost:hover {
  background: rgba(255, 255, 255, 0.6);
  color: var(--navy);
  border-color: rgba(143, 220, 236, 0.5);
  transform: none;
}

/* dourado = mesmo vidro inset, na cor de acento */
.bt--gold, .ctab .bt--gold {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, #ffd763 0%, #F5C842 100%);
  color: var(--navy);
  border: 1px solid rgba(255, 255, 255, 0.45);
  box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.65), inset 0 -8px 18px rgba(150, 110, 12, 0.28);
}
.bt--gold:hover, .ctab .bt--gold:hover {
  background: linear-gradient(180deg, #ffe085 0%, #ffce52 100%);
  border-color: rgba(255, 255, 255, 0.7);
  transform: none;
}

/* vidro real (backdrop-filter) só nos painéis de destaque — economiza GPU */
.ps,
.glob__viz {
  background: rgba(255, 255, 255, 0.6);
  -webkit-backdrop-filter: blur(14px) saturate(150%);
          backdrop-filter: blur(14px) saturate(150%);
  border-color: rgba(255, 255, 255, 0.55);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.7) inset, 0 18px 44px rgba(27, 33, 69, 0.08);
}

/* cards repetidos: translucidez leve sem backdrop-filter (barato, ainda parece vidro) */
.proc__step,
.deliv__item,
.avail__item,
.princ__item,
.sec {
  background: rgba(255, 255, 255, 0.72);
  border-color: rgba(255, 255, 255, 0.6);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.7) inset, 0 14px 36px rgba(27, 33, 69, 0.07);
}
/* "Quatro etapas" / "Da imersão à entrega": sombra estava fraca demais (lia como cortada).
   Sombra flutuante clara, como as outras cards. (Não havia overflow cortando de fato.) */
/* sombra CONTIDA (spread negativo): alcance lateral ~22px, cabe na margem da pagina e nunca corta
   no recorte do viewport (body overflow-x: clip), nem no mobile. Jordan 2026-06-19. */
.proc__step { box-shadow: 0 1px 0 rgba(255, 255, 255, 0.7) inset, 0 16px 32px -10px rgba(27, 33, 69, 0.2); }
.proc__step:hover { box-shadow: 0 1px 0 rgba(255, 255, 255, 0.7) inset, 0 22px 42px -12px rgba(27, 33, 69, 0.24); }

/* funil em vidro sobre o backdrop */
.fnl__panel {
  background: rgba(245, 243, 240, 0.86);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
          backdrop-filter: blur(24px) saturate(160%);
}

@media (prefers-reduced-motion: reduce) {
  .bt--ghost, .ps, .glob__viz, .fnl__panel {
    -webkit-backdrop-filter: none; backdrop-filter: none;
  }
}

/* ==========================================================
   IMAGENS — tratamento editorial navy (preto e branco + tint da marca)
   ========================================================== */
.shot {
  position: relative;
  overflow: hidden;
  border-radius: var(--r);
  background: var(--navy);
  aspect-ratio: 3 / 2;
  box-shadow: 0 18px 44px rgba(27, 33, 69, 0.16);
}
.shot img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(1) contrast(1.08) brightness(1.04);
  transition: transform 0.7s var(--e), filter 0.7s var(--e);
}
.shot::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(145deg, rgba(27, 33, 69, 0.6), rgba(27, 33, 69, 0.16) 55%, rgba(245, 200, 66, 0.14));
  mix-blend-mode: multiply;
  pointer-events: none;
}
.shot:hover img { transform: scale(1.04); filter: grayscale(0.55) contrast(1.05) brightness(1.05); }

/* aspect-ratios por contexto (heros/cards usam inline) */
.gal__item .shot { aspect-ratio: 3 / 2; height: 100%; }
.recent__item .shot { aspect-ratio: 4 / 3; }
.bio__portrait .shot { aspect-ratio: 4 / 5; }

@media (prefers-reduced-motion: reduce) { .shot img { transition: none; } }

/* ==========================================================
   LOGOS REAIS no carrossel (/sites)
   ========================================================== */
.logos__logo {
  height: 44px;
  width: auto;
  opacity: 0.62;
  flex: 0 0 auto;
  transition: opacity 0.4s var(--e-soft), transform 0.5s var(--e-soft);
}
.logos:hover .logos__logo { opacity: 0.78; }
.logos__logo:hover { opacity: 1; transform: scale(1.06); }
.logos__track { align-items: center; }
.logos__track > * { margin-right: 72px; }
@media (max-width: 600px) { .logos__logo { height: 34px; } .logos__track > * { margin-right: 48px; } }

/* Logos das big techs (/sites): mix de wordmarks (largos) e símbolos (quadrados).
   Altura base por logo, com --s pra os símbolos subirem e equilibrarem com os wordmarks. */
/* opacidade e cor (navy) HERDAM o padrao do carrossel de clientes da home (.logos base): opacity
   0.62, hover de trilho 0.78, hover do logo 1 + scale. Mesma referencia pro site inteiro. Jordan 2026-06-19. */
.logos--tech .logos__logo { height: calc(28px * var(--s, 1)); width: auto; }
.logos--tech .logos__track > * { margin-right: 64px; }
@media (max-width: 600px) { .logos--tech .logos__logo { height: calc(23px * var(--s, 1)); } .logos--tech .logos__track > * { margin-right: 44px; } }

/* ==========================================================
   MOCKUPS — imagens de produto em destaque (sem tratamento navy)
   ========================================================== */
.mockup { width: 100%; height: auto; display: block; object-fit: contain; }
.phr__media--mockup { display: flex; align-items: center; justify-content: center; }
.phr__media--mockup .mockup {
  max-width: 100%;
  max-height: clamp(320px, 44vh, 540px);
  filter: drop-shadow(0 34px 64px rgba(10, 12, 30, 0.30));
}
@media (max-width: 960px) {
  .phr__media--mockup { order: -1; }
  .phr__media--mockup .mockup { max-height: 360px; }
}

/* ==========================================================
   GAUGES PageSpeed — painel escuro com arco quente e ponto de luz (estilo loading de referência)
   ========================================================== */
.ps {
  background: linear-gradient(158deg, #161a38 0%, #0c0f24 100%);
  border-color: rgba(255, 255, 255, 0.08);
  box-shadow: 0 34px 80px rgba(8, 10, 26, 0.42);
  -webkit-backdrop-filter: none;
          backdrop-filter: none;
}
.ps__track { stroke: rgba(255, 255, 255, 0.09); }
.ps__num { color: #fff; }
.ps__name { color: rgba(255, 255, 255, 0.74); opacity: 1; }
.ps__dot circle { fill: #FFDE7A; }
.ps__dot {
  filter:
    drop-shadow(0 0 6px rgba(245, 200, 66, 1))
    drop-shadow(0 0 16px rgba(245, 200, 66, 0.85))
    drop-shadow(0 0 30px rgba(245, 200, 66, 0.5));
}

/* globo CDN: só o globo azul Hypearts girando, sem painel, sem fundo */
.glob__viz {
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 0;
  -webkit-backdrop-filter: none;
          backdrop-filter: none;
}
.glob__canvas { width: 100%; height: auto; aspect-ratio: 1 / 0.92; display: block; }
.glob__stat {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 255, 255, 0.12);
  -webkit-backdrop-filter: blur(6px);
          backdrop-filter: blur(6px);
}
.glob__stat-num { color: #fff; }
.glob__stat-lbl { color: rgba(255, 255, 255, 0.6); opacity: 1; }
.glob__stat-suffix { color: rgba(255, 255, 255, 0.7); opacity: 1; }

/* carrossel de logos de clientes na Home (cor única cinza-navy, sutil) */
/* peso óptico equilibrado: cada logo recebe --s (escala) pra que horizontais,
   verticais e símbolos tenham massa visual parecida, sem os largos dominarem */
.logos--clients .logos__track { align-items: center; }
.logos--clients .logos__track > * { margin-right: clamp(40px, 5vw, 72px); }
.logos--clients .logos__logo { height: calc(clamp(28px, 3.4vw, 41px) * var(--s, 1)); width: auto; }
/* logos quase fantasma (ref. noteworthy.studio) + fade lateral bem mais forte */
.logos--clients .logos__logo { opacity: 0.45; }
.logos--clients:hover .logos__logo { opacity: 0.55; }
.logos--clients .logos__logo:hover { opacity: 0.92; }
.logos--clients {
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 18%, #000 82%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 18%, #000 82%, transparent);
}
.logos__logo-link { display: inline-flex; align-items: center; flex: 0 0 auto; }
a.logos__logo-link { cursor: pointer; }

/* ---------- seção de projetos: grid de imagens + lightbox ---------- */
.projg {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(12px, 1.6vw, 20px);
}
.projg__item {
  position: relative;
  border: 0;
  padding: 0;
  border-radius: var(--r);
  overflow: hidden;
  cursor: zoom-in;
  background: var(--navy);
  aspect-ratio: 4 / 5;
  box-shadow: 0 14px 36px rgba(27, 33, 69, 0.1);
}
.projg__item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.6s var(--e); }
.projg__item:hover img { transform: scale(1.06); }
@media (max-width: 700px) { .projg { grid-template-columns: repeat(2, 1fr); } }

/* /conteudo: marquee de cards estilo feed de rede social (a imagem é o destaque) */
.feedshow {
  overflow: hidden; position: relative;
  /* padding vertical = espaço pra sombra de cada card não ser cortada (eles flutuam) */
  padding: 30px 0 58px;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.feedshow__track { display: flex; width: max-content; animation: feedScroll 54s linear infinite; }
.feedshow__track > * { margin-right: clamp(18px, 2vw, 26px); }
.feedshow:hover .feedshow__track { animation-play-state: paused; }
@keyframes feedScroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.feedcard {
  flex: 0 0 auto; width: clamp(164px, 16vw, 196px);
  background: var(--wh); border: 1px solid var(--hair);
  border-radius: 16px; overflow: hidden; box-shadow: 0 16px 40px rgba(27, 33, 69, 0.15);
  transition: transform var(--t-base), box-shadow var(--t-base);
}
.feedcard:hover { transform: translateY(-6px); box-shadow: 0 18px 40px rgba(27, 33, 69, 0.18); }
.feedcard__top { display: flex; align-items: center; gap: 10px; padding: 12px 14px; }
.feedcard__avatar { width: 30px; height: 30px; border-radius: 50%; object-fit: contain; background: var(--ow); padding: 4px; border: 1px solid var(--hair); }
.feedcard__id { display: flex; flex-direction: column; line-height: 1.15; flex: 1; min-width: 0; }
.feedcard__id b { font-family: var(--label); font-weight: 600; font-size: 13px; color: var(--navy); }
.feedcard__id span { font-size: 11px; color: var(--navy); opacity: 0.55; }
.feedcard__more { color: var(--navy); opacity: 0.5; font-size: 17px; }
.feedcard__media { display: block; width: 100%; border: 0; padding: 0; cursor: zoom-in; background: var(--navy); aspect-ratio: 4 / 5; overflow: hidden; }
.feedcard__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.6s var(--e); }
.feedcard__media:hover img { transform: scale(1.05); }
.feedcard__bar { display: flex; align-items: center; justify-content: space-between; padding: 11px 14px 4px; }
.feedcard__acts { display: inline-flex; gap: 14px; }
.feedcard__act { color: var(--navy); display: inline-flex; }
.feedcard__act svg { width: 22px; height: 22px; display: block; }

/* /conteudo: carrossel VERTICAL "pinado". A seção prende (sticky), a CTA fica no topo e
   as colunas de imagens rolam verticalmente (velocidades escalonadas) até o fim; aí solta
   e a página segue pro rodapé. Fade topo+base via máscara. js/main.js IIFE vshow. */
.vshow { position: relative; }
.sc.vshow { padding-top: 0; } /* tira o respiro duplicado entre "Trend passa." e este carrossel (Jordan 2026-06-19) */
.vshow__pin {
  position: sticky; top: 0;
  height: 100vh; height: 100svh;
  display: flex; flex-direction: column;
  padding: clamp(86px, 12vw, 132px) var(--pad-x) clamp(18px, 3vw, 34px);
  overflow: hidden;
}
.vshow__head { flex: 0 0 auto; width: 100%; max-width: var(--container); margin: 0 auto clamp(16px, 2.4vw, 30px); }
.vshow__cols {
  flex: 1 1 auto; min-height: 0;
  width: 100%; max-width: var(--container); margin: 0 auto;
  display: flex; gap: clamp(12px, 1.6vw, 20px); align-items: flex-start;
  overflow: hidden;
  padding: 14px clamp(22px, 2.6vw, 40px); /* respiro pra sombra das cards nao ser cortada pelo overflow (Jordan 2026-06-19) */
  -webkit-mask-image: linear-gradient(180deg, transparent 0, #000 8%, #000 92%, transparent 100%);
          mask-image: linear-gradient(180deg, transparent 0, #000 8%, #000 92%, transparent 100%);
}
.vshow__col { flex: 1 1 0; min-width: 0; display: flex; flex-direction: column; gap: clamp(12px, 1.6vw, 20px); will-change: transform; }
.vshow__col .feedcard { width: 100%; }
/* fallback (sem JS enhancement / reduced-motion): grade estática, sem prender nem rolar */
.vshow:not(.is-on) .vshow__pin { position: static; height: auto; overflow: visible; padding: clamp(50px, 6.2vw, 90px) var(--pad-x); }
.vshow:not(.is-on) .vshow__cols { overflow: visible; -webkit-mask-image: none; mask-image: none; }
@media (max-width: 700px) { .vshow__pin { padding-top: clamp(82px, 18vw, 112px); } }
@media (prefers-reduced-motion: reduce) { .vshow__col { will-change: auto; } }
.feedcard__acts .feedcard__act:first-child svg { fill: var(--gold); stroke: var(--gold); }
.feedcard__cap { padding: 4px 14px 14px; font-size: 12.5px; line-height: 1.5; color: var(--navy); opacity: 0.88; }
.feedcard__cap b { font-family: var(--label); font-weight: 600; opacity: 1; margin-right: 4px; }
@media (prefers-reduced-motion: reduce) { .feedshow__track { animation: none; } }
@media (max-width: 600px) { .feedcard { width: 54vw; } }
/* Mobile (Jordan 2026-06-19): cards de social media maiores + sombra contida que nao corta nas laterais */
@media (max-width: 600px) {
  .sc.vshow { padding-left: 6px; padding-right: 6px; } /* libera largura pros cards maiores */
  .vshow__pin { padding-left: 6px; padding-right: 6px; }
  .vshow__cols { padding-left: 14px; padding-right: 14px; gap: 10px; }
  .vshow__col { gap: 10px; }
  .vshow .feedcard { box-shadow: 0 10px 24px -11px rgba(27, 33, 69, 0.22); }
  /* o título alinha com os títulos do resto do site (~pad-x), mesmo com a seção reduzida pros cards */
  .vshow__head { padding-left: 10px; padding-right: 10px; }
}
/* menos respiro abaixo de "Trend passa. Marca fica." no mobile (pra casar com o respiro de cima) */
@media (max-width: 700px) { .sc--stmt { padding-bottom: 0; } }

.lb {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(8, 10, 26, 0.88);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 4vmin;
  opacity: 0; pointer-events: none;
  transition: opacity var(--t-base);
}
.lb.is-open { opacity: 1; pointer-events: auto; }
.lb img { max-width: 94vw; max-height: 92vh; border-radius: var(--r); box-shadow: 0 40px 100px rgba(0,0,0,0.6); }
.lb__close {
  position: absolute; top: 18px; right: 18px;
  width: 44px; height: 44px; border-radius: 50%;
  background: rgba(255,255,255,0.14); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 1.6rem; line-height: 1; cursor: pointer;
}

/* Sites no ar (/sites): marquee da direita p/ esquerda com o site rolando dentro do frame */
/* antes era puxada pra cima (margin negativa); Jordan pediu respiro entre tecnologia e sites no ar */
.sc--pulled { padding-top: clamp(14px, 2vw, 28px); margin-top: 0; }
.siteshow {
  overflow: hidden; position: relative;
  /* padding vertical = espaço pra sombra de cada frame não ser cortada (eles flutuam) */
  padding: 30px 0 58px;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.siteshow__track { display: flex; width: max-content; animation: siteScroll 48s linear infinite; }
.siteshow__track > * { margin-right: clamp(20px, 2.2vw, 30px); }
.siteshow:hover .siteshow__track { animation-play-state: paused; }
@keyframes siteScroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.siteframe {
  flex: 0 0 auto; width: clamp(218px, 22vw, 280px);
  border-radius: 14px; overflow: hidden; background: #fff;
  border: 1px solid var(--hair); box-shadow: 0 16px 40px rgba(27, 33, 69, 0.17);
  display: block; text-decoration: none;
  transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
}
.siteframe:hover { transform: translateY(-6px); border-color: rgba(245, 200, 66, 0.6); box-shadow: 0 18px 40px rgba(27, 33, 69, 0.2); }
/* barra minimalista: branca, hairline, dots neutros; o domínio identifica o site */
.siteframe__bar { display: flex; align-items: center; gap: 5px; padding: 9px 13px; background: #fff; border-bottom: 1px solid var(--hair); }
.siteframe__bar i { width: 6px; height: 6px; border-radius: 50%; background: rgba(27, 33, 69, 0.16); }
.siteframe__bar em { margin-left: 9px; font-style: normal; font-family: var(--label); font-size: 11px; letter-spacing: 0.05em; color: var(--navy); opacity: 0.55; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.siteframe__win { display: block; height: clamp(158px, 16.5vw, 192px); overflow: hidden; background: #f3f3f6; position: relative; }
/* o site rola pra revelar o resultado ao passar o mouse (o carrossel pausa no hover);
   transição em vez de loop contínuo pra não pesar 8 capturas animando ao mesmo tempo */
.siteframe__shot { width: 100%; height: auto; display: block; transform: translateY(0); transition: transform 6.5s ease-in-out; }
.siteframe:hover .siteframe__shot { transform: translateY(calc(-100% + clamp(158px, 16.5vw, 192px))); }
.siteframe__win::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 30px; background: linear-gradient(transparent, rgba(243,243,246,0.9)); opacity: 0; transition: opacity var(--t-base); pointer-events: none; }
.siteframe:hover .siteframe__win::after { opacity: 1; }
@media (prefers-reduced-motion: reduce) { .siteshow__track, .siteframe__shot { animation: none; } }
@media (max-width: 600px) { .siteframe { width: 60vw; } }

/* ===== Showcase interativo (/sites e /conteudo): auto R->L + arrastar + setas ===== */
/* setas como na home: abaixo do carrossel, centralizadas (o padding-bottom do show é respiro de sombra, a margem aproxima) */
.show__nav { display: flex; justify-content: center; gap: 16px; margin-top: -22px; }
.siteshow.is-js, .feedshow.is-js, .mockshow.is-js {
  overflow-x: auto; overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  /* pan-y junto: gesto vertical sobre o carrossel continua rolando a PÁGINA (pan-x sozinho travava) */
  touch-action: pan-x pan-y;
  scrollbar-width: none;
  cursor: grab;
}
.siteshow.is-js::-webkit-scrollbar, .feedshow.is-js::-webkit-scrollbar, .mockshow.is-js::-webkit-scrollbar { width: 0; height: 0; display: none; }
.siteshow.is-js.is-drag, .feedshow.is-js.is-drag, .mockshow.is-js.is-drag { cursor: grabbing; }
.siteshow.is-js .siteshow__track, .feedshow.is-js .feedshow__track, .mockshow.is-js .mockshow__track { animation: none !important; }
/* mobile: mostra mais do site sem depender de hover (não anima várias capturas juntas, que pesa) */
@media (hover: none) and (max-width: 760px) { .siteframe__win { height: clamp(132px, 32vw, 175px); } }

/* =================== Rodada 2026-06-10 =================== */

/* -- blur sutil no que nao esta em evidencia (convida a olhar o proximo) -- */
@media (hover: hover) {
  .svc__scroller:hover .svcard:not(:hover) { filter: blur(1.5px) saturate(0.96); opacity: 0.85; }
  .tst__scroller:hover .tcard:not(:hover) { filter: blur(1.5px) saturate(0.96); opacity: 0.85; }
}
@media (max-width: 900px) {
  .svcard:not(.is-mid) { filter: blur(1.5px); opacity: 0.86; }
  .tcard:not(.is-mid) { filter: blur(1.5px); opacity: 0.86; }
}

/* -- logos dos clientes em duas linhas, maiores, direcoes opostas -- */
.logorows { display: flex; flex-direction: column; gap: clamp(20px, 2.6vw, 34px); }
.logos--big .logos__track { animation-duration: 76s; }
.logos--big .logos__track > * { margin-right: clamp(48px, 6vw, 88px); }
.logos--big .logos__logo { height: calc(clamp(30px, 3.7vw, 46px) * var(--s, 1)); }
.logos__track--r { animation-name: logoScrollR; }
@keyframes logoScrollR { from { transform: translateX(-50%); } to { transform: translateX(0); } }
@media (max-width: 600px) { .logos--big .logos__logo { height: calc(clamp(26px, 6.6vw, 35px) * var(--s, 1)); } }

/* -- hero das paginas de servico: cena com fundo + titulo invadindo + parallax -- */
.phr--visual .phr__inner { grid-template-columns: 0.92fr 1.08fr; gap: clamp(20px, 3vw, 44px); }
.phr--visual .phr__content { position: relative; z-index: 2; max-width: none; }
.phr--visual .phr__title {
  font-size: clamp(2.3rem, 5.6vw, 4.5rem);
  position: relative; z-index: 2;
  margin-right: clamp(-190px, -11vw, -52px);   /* o titulo deita sobre a imagem (profundidade) */
  text-shadow: 0 2px 22px rgba(245, 243, 240, 0.6), 0 1px 4px rgba(245, 243, 240, 0.4);
}
.phr--visual .phr__lead { max-width: 520px; }
.phr__visual { position: relative; }
.phr__visual img {
  width: 100%; height: auto; display: block;
  filter: drop-shadow(0 28px 44px rgba(27, 33, 69, 0.30));
  will-change: transform;
}
@media (max-width: 960px) {
  .phr--visual .phr__inner { grid-template-columns: 1fr; gap: 0; }
  .phr__visual { order: -1; }
  /* título abaixo da imagem, sem sobrepor o recorte */
  .phr--visual .phr__content { margin-top: 10px; }
  .phr--visual .phr__title { margin-right: 0; }
  .phr--visual .lbl { background: rgba(245, 243, 240, 0.85); padding: 5px 12px; border-radius: 999px; backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); }
}

/* -- pagina marca: esteira de mockups dos clientes (colagem viva) -- */
.mockshow {
  overflow: hidden; position: relative;
  padding: 26px 0 58px;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.mockshow__track { display: flex; align-items: center; width: max-content; animation: feedScroll 58s linear infinite; }
.mockshow__track > * { margin-right: clamp(16px, 2vw, 26px); }
.mockshow:hover .mockshow__track { animation-play-state: paused; }
.mockitem {
  flex: 0 0 auto;
  height: clamp(190px, 23vw, 280px);
  border-radius: 16px; overflow: hidden;
  background: var(--wh);
  border: 1px solid var(--hair);
  box-shadow: 0 16px 40px rgba(27, 33, 69, 0.15);
  transition: transform var(--t-base), box-shadow var(--t-base);
}
.mockitem:hover { transform: translateY(-6px); box-shadow: 0 18px 40px rgba(27, 33, 69, 0.18); }
.mockitem img { height: 100%; width: auto; display: block; }
.mockitem--tall { height: clamp(190px, 23vw, 280px); }

/* -- feedcard minimalista (so a imagem + acoes, frame IG limpo) -- */
.feedcard--min .feedcard__bar { padding: 11px 14px 13px; justify-content: flex-start; }
.feedcard--min .feedcard__acts { gap: 14px; }

/* -- menu mobile: redes e contato -- */
/* redes no menu: navy sobre o vidro claro (antes era off-white sobre off-white, sem contraste) */
.mm__extra { margin-top: 34px; padding-top: 26px; border-top: 1px solid rgba(27, 33, 69, 0.16); display: flex; flex-direction: column; gap: 18px; }
.mm__extra a { display: inline-flex; align-items: center; gap: 13px; color: var(--navy); opacity: 0.9; text-decoration: none; font-size: 1.05rem; font-weight: 500; }
.mm__extra a:hover { opacity: 1; color: var(--gold); }
.mm__extra .ft__ic { width: 27px; height: 27px; flex: 0 0 auto; }
.mm__city { font-family: var(--label); font-weight: 500; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--navy); opacity: 0.52; margin-top: 4px; }
.mm { overscroll-behavior: contain; }

/* -- formulario de contato (tema escuro da secao) -- */
.ctf { margin-top: clamp(46px, 6vw, 72px); max-width: 760px; }
.ctf__title { font-family: var(--display); font-weight: 800; font-size: clamp(1.5rem, 2.6vw, 2.1rem); letter-spacing: -0.015em; color: #fff; margin: 12px 0 22px; }
.ctf__title em { color: var(--gold); }
.ctf__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.ctf__fld { display: flex; flex-direction: column; gap: 7px; }
.ctf__fld--full { grid-column: 1 / -1; }
.ctf__fld span { font-family: var(--label); font-weight: 600; font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255, 255, 255, 0.6); }
.ctf__fld input, .ctf__fld textarea {
  width: 100%;
  padding: 13px 15px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 12px;
  color: #fff;
  font: inherit;
  font-size: 0.98rem;
  transition: border-color var(--t-base), background var(--t-base);
}
.ctf__fld input:focus-visible, .ctf__fld textarea:focus-visible { outline: none; border-color: rgba(245, 200, 66, 0.65); background: rgba(255, 255, 255, 0.08); }
.ctf__fld textarea { resize: vertical; min-height: 110px; }
.ctf__foot { margin-top: 18px; display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.ctf__msg { font-size: 0.94rem; color: rgba(255, 255, 255, 0.75); }
.ctf__msg.is-ok { color: #8fe3b0; }
.ctf__msg.is-err { color: #ffb4a2; }
@media (max-width: 640px) { .ctf__grid { grid-template-columns: 1fr; } }

/* =================== Rodada 2026-06-10 R3 =================== */

/* contato: painel navy com acento dourado de canto (contraste e vida de volta) */
.ct--panel {
  position: relative;
  background:
    radial-gradient(120% 95% at 108% -10%, rgba(245, 200, 66, 0.17), transparent 56%),
    radial-gradient(95% 80% at -8% 110%, rgba(101, 199, 255, 0.10), transparent 55%),
    linear-gradient(135deg, #232a55 0%, #1B2145 55%, #161b39 100%);
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: calc(var(--r) + 10px);
  padding: clamp(26px, 4.2vw, 58px);
  overflow: hidden;
  box-shadow: 0 34px 80px -28px rgba(27, 33, 69, 0.5);
}
.ct--panel::before {
  content: '';
  position: absolute; inset: 0;
  background-image: url('../assets/textura-hypearts.webp');
  background-size: cover; background-position: center;
  opacity: 0.05; mix-blend-mode: screen;
  pointer-events: none;
}
.ct--panel > * { position: relative; }
.ct--panel .lbl { color: var(--gold); }
/* ordem R4: formulário primeiro, canais diretos depois */
.ct--panel .ctf { margin-top: 0; }
.ct--panel .ct__or { display: block; margin: clamp(34px, 4.5vw, 54px) 0 20px; }
.ct--panel .ct__grid { margin-top: 0; }

/* contato centralizado e enxuto: texto de chamada + explicação + formulário na mesma coluna,
   sem o buracão entre o hero e o painel (Jordan R8) */
.phr--center { padding-bottom: clamp(16px, 2.8vw, 36px); }
.phr--center .phr__content { max-width: 720px; margin-inline: auto; text-align: center; }
.phr--center .phr__lead { margin-left: auto; margin-right: auto; }
.sc--ct { padding-top: clamp(6px, 1.6vw, 22px); }
.ct--narrow { max-width: 1120px; margin-left: auto; margin-right: auto; }
.ct--narrow .ctf { max-width: 720px; margin-inline: auto; }
.ct--narrow .ctf > .lbl { display: block; width: fit-content; margin-inline: auto; }
.ct--narrow .ctf__title { text-align: center; }
.ct--narrow .ctf__foot { justify-content: center; }
.ct--narrow .ct__or { text-align: center; }

/* =================== Rodada 2026-06-11 R4 =================== */

/* marca: esteira de mockups vive na mesma seção dos logos, logo abaixo das duas linhas */
.logorows + .mockshow { margin-top: clamp(14px, 2.4vw, 30px); }

/* =================== Rodada 2026-06-12 R8 =================== */

/* convite de scroll: mousezinho animado no rodapé do hero (padrão Cosmos, cor Hypearts).
   É um link pra #servicos: convida e leva ao primeiro bloco. */
.hr__cue {
  position: absolute;
  bottom: clamp(18px, 3.4vh, 40px);
  left: 50%;
  transform: translateX(-50%);
  z-index: 4;
  height: 40px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  animation: cueIn 0.9s var(--e) 1.1s backwards;
  transition: opacity var(--t-soft);
}
/* some suave ao descer, volta ao subir (js/main.js cueScroll) */
.hr__cue.is-gone { opacity: 0; pointer-events: none; }
/* ponto que simula o dedo deslizando pra cima: surge embaixo (fade in), sobe e some
   (fade out) até apagar de vez no topo, pausa curta, repete. Simples e super fluido. */
.hr__cue__dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--navy);
  animation: dotSwipe 2.2s cubic-bezier(0.33, 0, 0.2, 1) infinite;
}
@keyframes cueIn { from { opacity: 0; } }
@keyframes dotSwipe {
  0%   { transform: translateY(13px) scale(0.9); opacity: 0; }
  16%  { opacity: 1; }
  62%  { transform: translateY(-15px) scale(1); opacity: 0; }
  100% { transform: translateY(-15px) scale(1); opacity: 0; }
}
@media (max-width: 600px) { .hr__cue { bottom: 16px; } }
@media (prefers-reduced-motion: reduce) { .hr__cue__dot { animation: none; opacity: 0.6; } }

/* campo de pontos reativo ao cursor (js/dotfield.js injeta o canvas em .bgfx) */
.bgfx__dots {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
