/* ===================================================================
   Adesivo na Hora — styles.css
   Mobile-first · breakpoints 480 / 768 / 1024
   Paleta 60/30/10 (estrategia.md) — base branca, acentos red+yellow
   =================================================================== */

:root{
  /* Cores */
  --c-bg:        #FFFFFF;
  --c-bg-alt:    #F5F5F5;
  --c-border:    #E4E4E4;
  --c-ink:       #1A1A1A;
  --c-ink-soft:  #6B6B6B;
  --c-red:       #E11B22;
  --c-red-dark:  #B71419;
  --c-yellow:    #FFC400;
  --c-dark:      #101010;
  --c-wpp:       #25D366;
  --c-wpp-dark:  #1EBE5A;

  /* Tipografia */
  --font-display: 'Fredoka', system-ui, sans-serif;
  --font-body:    'Inter', system-ui, sans-serif;

  /* Raio */
  --radius-sm: 8px;
  --radius:    12px;
  --radius-lg: 20px;
  --radius-pill: 999px;

  /* Sombra */
  --shadow-sm: 0 2px 8px rgba(16,16,16,.06);
  --shadow:    0 8px 24px rgba(16,16,16,.10);
  --shadow-red:0 8px 20px rgba(225,27,34,.28);

  /* Transição */
  --t-fast: .18s ease;
  --t:      .28s cubic-bezier(.4,0,.2,1);

  /* Layout */
  --maxw: 1140px;
  --gutter: 20px;
  --section-y: 64px;
  --section-y-lg: 96px;
  --header-h: 72px;
  --header-h-lg: 88px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; scroll-padding-top:calc(var(--header-h) + 12px); }
body{
  font-family:var(--font-body);
  font-size:1rem; line-height:1.6;
  color:var(--c-ink); background:var(--c-bg);
  -webkit-font-smoothing:antialiased;
}
img,svg,iframe{ display:block; max-width:100%; }
ul,ol{ list-style:none; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.2; text-wrap:balance; }
p{ text-wrap:pretty; } /* evita viúvas/órfãs (1 palavra sozinha na última linha) */

/* ---------- Container / Seção ---------- */
.container{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:var(--section-y); }
.section--alt{ background:var(--c-bg-alt); }

/* ---------- Tipos utilitários ---------- */
.text-red{ color:var(--c-red); }
.text-yellow{ color:var(--c-yellow); }

.eyebrow{
  font-family:var(--font-body); font-weight:600;
  font-size:.8rem; letter-spacing:.08em; text-transform:uppercase;
  margin-bottom:10px;
}
.eyebrow--red{ color:var(--c-red); }
.eyebrow--yellow{ color:#C79600; } /* amarelo legível como texto pequeno */

.sec-head{ max-width:640px; margin:0 auto 40px; text-align:center; }
.sec-title{ font-size:clamp(1.7rem,4.5vw,2.4rem); color:var(--c-ink); }
.sec-lead{ margin-top:12px; color:var(--c-ink-soft); font-size:clamp(1rem,2.5vw,1.15rem); }

/* ---------- Botões ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--font-display); font-weight:600; font-size:1rem; line-height:1;
  padding:14px 28px; border:0; border-radius:var(--radius-pill);
  cursor:pointer; transition:var(--t); text-align:center; white-space:nowrap;
}
.btn:focus-visible{ outline:3px solid rgba(225,27,34,.35); outline-offset:2px; }
.btn svg{ width:18px; height:18px; flex:0 0 auto; }

.btn-primary{ background:var(--c-red); color:#fff; box-shadow:var(--shadow-red); }
.btn-primary svg{ fill:#fff; }
.btn-primary:hover{ background:var(--c-red-dark); transform:translateY(-2px); }

.btn-ghost{ background:transparent; color:var(--c-ink); border:2px solid var(--c-ink); padding:12px 26px; }
.btn-ghost:hover{ background:var(--c-ink); color:#fff; }

.btn--compact{ padding:10px 20px; font-size:.95rem; }
.btn--lg{ padding:18px 38px; font-size:1.1rem; }

.ico-bolt{ fill:var(--c-yellow); }

/* ===================================================================
   HEADER
   =================================================================== */
.header{
  position:fixed; top:0; left:0; width:100%; z-index:1000;
  background:var(--c-bg); border-bottom:1px solid var(--c-border);
  transition:var(--t);
}
.header.scrolled{ box-shadow:var(--shadow-sm); border-bottom-color:transparent; }
.header__inner{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  height:var(--header-h);
}
.header__logo img{ height:48px; width:auto; }
.header__actions{ display:flex; align-items:center; gap:12px; }

/* Nav desktop */
.nav{ display:none; }
.nav__link{
  position:relative; font-weight:500; font-size:.95rem; color:var(--c-ink);
  padding:4px 0; transition:color var(--t-fast);
}
.nav__link::after{
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0;
  background:var(--c-red); transition:width var(--t-fast);
}
.nav__link:hover{ color:var(--c-red); }
.nav__link:hover::after{ width:100%; }

/* Hambúrguer */
.nav-toggle{
  display:inline-flex; flex-direction:column; justify-content:center; gap:5px;
  width:42px; height:42px; padding:9px; background:transparent; border:0; cursor:pointer;
}
.nav-toggle span{ height:2.5px; width:100%; background:var(--c-ink); border-radius:2px; transition:var(--t); }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7.5px) rotate(-45deg); }

/* Painel mobile */
.nav.nav-open{
  display:flex; flex-direction:column;
  position:fixed; top:var(--header-h); left:0; width:100%;
  background:var(--c-bg); border-bottom:1px solid var(--c-border);
  box-shadow:var(--shadow); padding:8px 0;
  animation:slide-down .25s ease;
}
.nav.nav-open .nav__link{
  text-align:center; padding:16px var(--gutter); border-bottom:1px solid var(--c-border);
}
.nav.nav-open .nav__link:last-child{ border-bottom:0; }
.nav.nav-open .nav__link::after{ display:none; }
@keyframes slide-down{ from{ opacity:0; transform:translateY(-10px); } to{ opacity:1; transform:translateY(0); } }

/* ===================================================================
   HERO
   =================================================================== */
.hero{
  position:relative; overflow:hidden; background:var(--c-bg);
  padding-top:calc(var(--header-h) + 48px); padding-bottom:var(--section-y);
}
.hero__blob{
  position:absolute; right:-80px; top:10%; width:420px; height:420px;
  background:var(--c-yellow); opacity:.08; border-radius:50%; filter:blur(8px);
  pointer-events:none; z-index:0;
}
.hero__grid{ position:relative; z-index:1; display:grid; gap:32px; }
.hero__content{ display:flex; flex-direction:column; align-items:flex-start; gap:20px; }
.hero__logo{ height:100px; width:auto; margin-bottom:4px; } /* mascote em destaque, topo do hero — aspect-ratio preservado */

.badge{
  display:inline-flex; align-items:center; gap:6px;
  background:var(--c-yellow); color:var(--c-ink);
  font-family:var(--font-display); font-weight:600; font-size:.85rem;
  padding:6px 14px; border-radius:var(--radius-pill);
}
.badge .ico-bolt{ width:14px; height:14px; fill:var(--c-ink); }

.hero__title{ font-weight:700; font-size:clamp(2rem,7vw,3.4rem); line-height:1.05; color:var(--c-ink); }
.hero__sub{ max-width:46ch; color:var(--c-ink-soft); font-size:clamp(1rem,2.6vw,1.2rem); }

.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; width:100%; }
.hero__proof{
  display:flex; align-items:center; gap:8px;
  color:var(--c-ink-soft); font-weight:500; font-size:.85rem;
}
.hero__proof .ico-pin{ width:18px; height:18px; fill:var(--c-yellow); flex:0 0 auto; }

/* ---------- Carrossel do hero ----------
   Mesmas dimensões/raio/sombra do hero__media original (16/10 → 4/5 no ≥768):
   o aspect-ratio fica no container, então zero layout shift. */
.hero__media{ position:relative; }
.carousel{
  aspect-ratio:16/10; overflow:hidden;
  border-radius:var(--radius-lg); box-shadow:var(--shadow);
  background:var(--c-bg-alt);
}
.carousel__track{
  display:flex; height:100%;
  transition:transform .55s cubic-bezier(.4,0,.2,1);
}
.carousel__slide{ flex:0 0 100%; height:100%; }
.carousel__slide img{ width:100%; height:100%; object-fit:cover; }

.carousel__arrow{
  position:absolute; top:50%; transform:translateY(-50%); z-index:2;
  display:grid; place-items:center; width:40px; height:40px;
  border:0; border-radius:50%; cursor:pointer;
  background:rgba(255,255,255,.88); box-shadow:var(--shadow-sm);
  transition:var(--t-fast);
}
.carousel__arrow:hover{ background:#fff; transform:translateY(-50%) scale(1.08); }
.carousel__arrow:focus-visible{ outline:3px solid rgba(225,27,34,.35); outline-offset:2px; }
.carousel__arrow svg{
  width:20px; height:20px;
  fill:none; stroke:var(--c-ink); stroke-width:2.5; stroke-linecap:round; stroke-linejoin:round;
}
.carousel__arrow--prev{ left:12px; }
.carousel__arrow--next{ right:12px; }

.carousel__dots{
  position:absolute; left:0; right:0; bottom:12px; z-index:2;
  display:flex; justify-content:center; gap:8px;
}
.carousel__dot{
  width:9px; height:9px; padding:0; border:0; border-radius:var(--radius-pill);
  background:rgba(255,255,255,.55); cursor:pointer; transition:var(--t-fast);
}
.carousel__dot:hover{ background:rgba(255,255,255,.85); }
.carousel__dot:focus-visible{ outline:2px solid #fff; outline-offset:2px; }
.carousel__dot.is-active{ width:22px; background:#fff; }

/* ---------- Fallback de imagem (genérico) ---------- */
.img-fallback[hidden]{ display:none !important; } /* respeita o atributo hidden — placeholder só aparece quando o JS o remove (imagem ausente) */
.img-fallback{
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px;
  background:var(--c-bg-alt); color:var(--c-ink-soft);
  border:1px dashed var(--c-border); width:100%; height:100%;
}
.img-fallback svg{ width:42px; height:42px; fill:#C4C4C4; }
.img-fallback span{ font-family:var(--font-body); font-size:.85rem; font-weight:500; }

/* ===================================================================
   SERVIÇOS
   =================================================================== */
.cards{ display:grid; grid-template-columns:1fr; gap:20px; }
.card{
  display:flex; flex-direction:column;
  background:#fff; border:1px solid var(--c-border); border-radius:var(--radius);
  padding:28px 24px; box-shadow:var(--shadow-sm); transition:var(--t);
}
.card__ico{
  display:grid; place-items:center; width:48px; height:48px; margin-bottom:16px;
  background:rgba(255,196,0,.15); border-radius:var(--radius-sm); transition:var(--t);
}
.card__ico svg{ width:28px; height:28px; fill:none; stroke:var(--c-ink); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; transition:var(--t); }
.card__title{ font-weight:600; font-size:1.2rem; color:var(--c-ink); margin-bottom:8px; }
.card__desc{ color:var(--c-ink-soft); font-size:.95rem; }
.card__cta{
  align-self:flex-start; margin-top:18px; /* margin-top:auto não usado: mantém botão logo após o texto */
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--font-display); font-weight:600; font-size:.9rem; line-height:1;
  padding:9px 18px; border-radius:var(--radius-pill);
  background:transparent; border:2px solid var(--c-border); color:var(--c-ink);
  cursor:pointer; transition:var(--t);
}
.card__cta::after{ content:"→"; font-weight:600; transition:transform var(--t-fast); }
.card__cta:hover{ border-color:var(--c-red); color:var(--c-red); }
.card__cta:hover::after{ transform:translateX(3px); }
.card__cta:focus-visible{ outline:3px solid rgba(225,27,34,.35); outline-offset:2px; }
.card:hover{ transform:translateY(-4px); border-color:var(--c-red); box-shadow:var(--shadow); }
.card:hover .card__ico{ background:rgba(225,27,34,.12); }
.card:hover .card__ico svg{ stroke:var(--c-red); }
.card:hover .card__cta{ border-color:var(--c-red); color:var(--c-red); }

/* ===================================================================
   POR QUE A GENTE
   =================================================================== */
.feats{ display:grid; grid-template-columns:1fr; gap:32px; }
.feat{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:12px; }
.feat__ico{ display:grid; place-items:center; width:56px; height:56px; background:rgba(255,196,0,.15); border-radius:50%; }
.feat__ico svg{ width:28px; height:28px; fill:var(--c-ink); }
.feat__title{ font-weight:600; font-size:1.2rem; color:var(--c-ink); }
.feat__desc{ color:var(--c-ink-soft); font-size:.95rem; max-width:30ch; }

/* ===================================================================
   PORTFÓLIO
   =================================================================== */
.gallery{ display:grid; grid-template-columns:1fr; gap:14px; }
.shot{
  position:relative; border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow-sm); background:var(--c-bg-alt);
}
.shot img,
.shot video,
.shot .img-fallback{ width:100%; aspect-ratio:1/1; object-fit:cover; transition:transform var(--t); display:block; }
.shot video{ background:var(--c-ink); } /* enquanto carrega metadata, fundo neutro (não branco) */
.shot:hover img,
.shot:hover video{ transform:scale(1.06); }
.shot figcaption{
  position:absolute; left:0; right:0; bottom:0; padding:28px 14px 12px;
  color:#fff; font-weight:500; font-size:.9rem;
  background:linear-gradient(to top, rgba(16,16,16,.7), transparent);
  opacity:0; transform:translateY(8px); transition:var(--t);
}
.shot:hover figcaption{ opacity:1; transform:translateY(0); }
/* fallback ativo: esconde figcaption pra não cobrir o placeholder */
.shot.is-fallback figcaption{ display:none; }
.gallery__cta{ margin-top:32px; text-align:center; }

/* ===================================================================
   COMO FUNCIONA
   =================================================================== */
.steps{ display:grid; grid-template-columns:1fr; gap:32px; position:relative; }
.step{ display:flex; flex-direction:column; align-items:center; text-align:center; gap:12px; position:relative; }
.step__num{
  display:grid; place-items:center; width:64px; height:64px; border-radius:50%;
  background:var(--c-red); color:#fff; font-family:var(--font-display); font-weight:700; font-size:1.6rem;
  z-index:1;
}
.step__title{ font-weight:600; font-size:1.2rem; color:var(--c-ink); }
.step__desc{ color:var(--c-ink-soft); font-size:.95rem; max-width:34ch; }
/* conector vertical pontilhado (mobile) */
.step:not(:last-child)::after{
  content:""; position:absolute; top:64px; left:50%; transform:translateX(-50%);
  width:0; height:32px; border-left:2px dashed var(--c-border);
}
.steps__cta{ margin-top:40px; display:flex; flex-direction:column; align-items:center; gap:16px; }
.steps__close{ font-family:var(--font-display); font-weight:500; color:var(--c-ink); font-size:1.05rem; }

/* ===================================================================
   LOCALIZAÇÃO + CONTATO
   =================================================================== */
.contact{ display:grid; grid-template-columns:1fr; gap:24px; }
.contact__info{ display:flex; flex-direction:column; gap:14px; }
.contact__row{
  display:flex; align-items:center; gap:14px;
  background:#fff; border:1px solid var(--c-border); border-radius:var(--radius);
  padding:14px 16px; transition:var(--t);
}
.contact__row:hover{ border-color:var(--c-red); box-shadow:var(--shadow-sm); }
.contact__row:hover .contact__txt strong{ color:var(--c-red); }
.contact__ico{ display:grid; place-items:center; width:40px; height:40px; flex:0 0 auto; background:rgba(255,196,0,.15); border-radius:var(--radius-sm); }
.contact__ico svg{ width:22px; height:22px; fill:none; stroke:var(--c-ink); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
/* WhatsApp = glifo sólido (não line-icon): preenchido verde, sem stroke que o deforma */
.contact__ico--wpp svg{ width:22px; height:22px; fill:var(--c-wpp); stroke:none; }
.contact__txt{ display:flex; flex-direction:column; }
.contact__txt small{ color:var(--c-ink-soft); font-size:.78rem; }
.contact__txt strong{ font-weight:500; color:var(--c-ink); transition:color var(--t-fast); }
.contact__note{ color:var(--c-ink-soft); font-size:.9rem; margin:4px 0 8px; }
.contact__info .btn{ align-self:flex-start; }

/* Seletor de serviço (chips radio-like) */
.svc-picker{ border:0; margin:6px 0 4px; padding:0; min-width:0; }
.svc-picker__legend{ padding:0; margin-bottom:10px; font-size:.8rem; font-weight:600; letter-spacing:.02em; color:var(--c-ink-soft); }
.svc-picker__chips{ display:flex; flex-wrap:wrap; gap:8px; }
.svc-chip{ position:relative; display:inline-flex; cursor:pointer; }
.svc-chip input{ position:absolute; width:1px; height:1px; opacity:0; pointer-events:none; }
.svc-chip span{
  display:inline-block; padding:8px 14px; border-radius:var(--radius-pill);
  background:#fff; border:1px solid var(--c-border); color:var(--c-ink);
  font-family:var(--font-body); font-size:.85rem; font-weight:500; line-height:1.2;
  transition:var(--t); user-select:none;
}
.svc-chip:hover span{ border-color:var(--c-red); color:var(--c-red); }
.svc-chip input:checked + span{ background:var(--c-red); border-color:var(--c-red); color:#fff; box-shadow:var(--shadow-sm); }
.svc-chip input:focus-visible + span{ outline:3px solid rgba(225,27,34,.35); outline-offset:2px; }

.contact__map{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--c-border); }
.contact__map iframe{ width:100%; height:280px; border:0; }

/* ===================================================================
   CTA FINAL
   =================================================================== */
.cta-final{
  position:relative; overflow:hidden; background:var(--c-dark); color:#fff;
  padding:72px 0; text-align:center;
}
.cta-final__inner{ position:relative; z-index:1; display:flex; flex-direction:column; align-items:center; gap:16px; }
.cta-final__title{ font-weight:700; font-size:clamp(2rem,6vw,2.8rem); color:#fff; }
.cta-final__sub{ color:#C8C8C8; max-width:48ch; }
.cta-final__note{ color:#8A8A8A; font-size:.85rem; margin-top:4px; }
.cta-final .eyebrow--yellow{ color:var(--c-yellow); }

/* ===================================================================
   RODAPÉ
   =================================================================== */
.footer{ background:var(--c-dark); color:#C8C8C8; padding:48px 0 24px; }
.footer__grid{ display:grid; grid-template-columns:1fr; gap:32px; text-align:center; }
.footer__col--brand{ display:flex; align-items:center; justify-content:center; }
.footer__logo{ display:inline-block; background:#fff; border-radius:var(--radius); padding:12px 16px; }
.footer__logo img{ height:80px; width:auto; } /* logo em destaque; aspect-ratio real preservado */
.footer__h{ color:#fff; font-size:1rem; margin-bottom:12px; }
.footer__list li{ margin-bottom:8px; }
.footer__list a{ color:#C8C8C8; font-size:.92rem; transition:color var(--t-fast); }
.footer__list a:hover{ color:var(--c-yellow); }
.footer__bar{
  border-top:1px solid rgba(255,255,255,.12); margin-top:32px; padding-top:20px;
  text-align:center;
}
.footer__bar p{ color:#8A8A8A; font-size:.8rem; }

/* ===================================================================
   WHATSAPP FLOAT
   =================================================================== */
.wpp-float{
  position:fixed; right:20px; bottom:20px; z-index:1100;
  width:60px; height:60px; border-radius:var(--radius-pill);
  background:var(--c-wpp); display:grid; place-items:center;
  box-shadow:0 6px 20px rgba(37,211,102,.45);
  transition:var(--t); animation:wpp-pulse 2.4s ease-out infinite;
}
.wpp-float:hover{ background:var(--c-wpp-dark); transform:scale(1.08); }
.wpp-float svg{ width:32px; height:32px; fill:#fff; }
.wpp-float__tip{
  position:absolute; right:72px; top:50%; transform:translateY(-50%) translateX(8px);
  background:var(--c-ink); color:#fff; font-size:.82rem; font-weight:500; white-space:nowrap;
  padding:8px 12px; border-radius:var(--radius-sm); box-shadow:var(--shadow-sm);
  opacity:0; pointer-events:none; transition:var(--t);
}
.wpp-float:hover .wpp-float__tip{ opacity:1; transform:translateY(-50%) translateX(0); }
@keyframes wpp-pulse{
  0%{   box-shadow:0 6px 20px rgba(37,211,102,.45), 0 0 0 0 rgba(37,211,102,.5); }
  70%{  box-shadow:0 6px 20px rgba(37,211,102,.45), 0 0 0 16px rgba(37,211,102,0); }
  100%{ box-shadow:0 6px 20px rgba(37,211,102,.45), 0 0 0 0 rgba(37,211,102,0); }
}

/* ===================================================================
   REVEAL ON SCROLL
   =================================================================== */
.reveal{ opacity:0; transform:translateY(16px); transition:opacity .5s ease, transform .5s ease; }
.reveal.in-view{ opacity:1; transform:translateY(0); }

/* ===================================================================
   BREAKPOINTS
   =================================================================== */

/* ---------- ≥480 ---------- */
@media (min-width:480px){
  .cards{ grid-template-columns:repeat(2,1fr); }
  .feats{ grid-template-columns:repeat(2,1fr); }
  /* gallery: 3 fotos reais → fica 1 col até 768 (evita órfão no tablet) */
}

/* ---------- ≥768 ---------- */
@media (min-width:768px){
  .section{ padding-block:var(--section-y-lg); }
  .hero{ padding-bottom:var(--section-y-lg); }

  /* Hero split */
  .hero__grid{ grid-template-columns:1fr 1fr; align-items:center; gap:40px; }
  .hero__cta{ width:auto; }
  .carousel{ aspect-ratio:4/5; }
  .hero__logo{ height:140px; }

  .cards{ grid-template-columns:repeat(2,1fr); } /* 4 cards = 2x2, sem órfão */
  .feats{ grid-template-columns:repeat(2,1fr); }
  /* 5 itens (3 fotos + 2 vídeos): flex centralizado → 3 em cima, 2 centrados embaixo, sem órfão */
  .gallery{ display:flex; flex-wrap:wrap; justify-content:center; }
  .shot{ flex:0 1 calc((100% - 28px) / 3); }

  /* Steps horizontal */
  .steps{ grid-template-columns:repeat(3,1fr); gap:24px; }
  .step:not(:last-child)::after{
    top:32px; left:auto; right:-12px; transform:none;
    width:auto; height:0; border-left:0; border-top:2px dashed var(--c-border);
    left:calc(50% + 40px); right:calc(-50% + 40px);
  }
  /* setinha amarela no conector */
  .step:not(:last-child)::before{
    content:""; position:absolute; top:26px; right:-14px; z-index:2;
    border-left:7px solid var(--c-yellow); border-top:5px solid transparent; border-bottom:5px solid transparent;
  }

  .contact{ grid-template-columns:1fr 1fr; align-items:stretch; }
  .contact__map iframe{ height:100%; min-height:380px; }

  .cta-final{ padding:96px 0; }

  /* 3 colunas do tamanho do conteúdo, distribuídas de ponta a ponta do container
     (logo na borda esquerda, Navegação na direita) — sem vazio morto, alinha com o CTA centrado acima */
  .footer__grid{ grid-template-columns:repeat(3,auto); justify-content:space-between; text-align:left; gap:40px; align-items:center; }
  .footer__col--brand{ justify-content:flex-start; }
  .footer__logo img{ height:110px; }
}

/* ---------- ≥1024 ---------- */
@media (min-width:1024px){
  .header__inner{ height:var(--header-h-lg); }
  .header.scrolled .header__inner{ height:var(--header-h); }
  .header__logo img{ height:56px; }
  .nav{ display:flex; gap:28px; }
  .nav-toggle{ display:none; }

  .hero__grid{ grid-template-columns:55% 45%; }
  .feats{ grid-template-columns:repeat(4,1fr); }
}

/* ---------- Acessibilidade: movimento reduzido ---------- */
@media (prefers-reduced-motion:reduce){
  *{ scroll-behavior:auto !important; }
  .reveal{ opacity:1 !important; transform:none !important; transition:none; }
  .wpp-float{ animation:none; }
  .carousel__track{ transition:none; } /* troca de slide instantânea; autoplay desligado no JS */
}
