/* ===========================================================
   Restaurante Hosana — Landing Page
   Paleta: terracota, dourado, creme, madeira, carvão quente
   =========================================================== */

:root{
  /* Identidade Hosana: laranja vivo + creme + preto */
  --terracota:    #F54E07;   /* laranja da marca (mantém o nome p/ compatibilidade) */
  --terracota-2:  #FF6A28;   /* laranja claro hover */
  --orange-deep:  #D8420A;
  --gold:         #C9A24B;
  --gold-soft:    #EAD199;
  --charcoal:     #1B1410;   /* preto quente */
  --ink:          #241C17;
  --muted:        #6E6157;
  --cream:        #F8F8F5;   /* branco-gelo neutro (fundo geral) */
  --sand:         #EFEFEA;   /* gelo um tom abaixo (seções alternadas) */
  --line:         #E6E5DF;   /* linha/borda neutra */
  --white:        #ffffff;
  --whats:        #25D366;

  /* Ouro real (filetes/contornos premium) */
  --gold-line:      #C39A38;   /* ouro sólido para bordas finas */
  --gold-soft-line: #D6BB74;   /* ouro claro (bordas discretas) */
  --gold-grad:      linear-gradient(125deg, #8E6A22 0%, #DDBB5E 36%, #F6E7B4 52%, #C79A34 72%, #7E5F1E 100%);

  --radius:   18px;
  --radius-sm:12px;
  --shadow:   0 30px 60px -32px rgba(35,20,8,.28);
  --shadow-sm:0 14px 34px -20px rgba(35,20,8,.20);
  --maxw:     1180px;
  --ease:     cubic-bezier(.16,.84,.44,1);

  --font-display:"Fraunces", Georgia, serif;
  --font-script:"Pacifico", "Fraunces", cursive;
  --font-sans:"Inter", system-ui, -apple-system, sans-serif;
}

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

html{ scroll-behavior:smooth; scroll-padding-top:78px; }

body{
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.container{ width:min(100% - 2.5rem, var(--maxw)); margin-inline:auto; }

/* ---------- Tipografia base ---------- */
h1,h2,h3{ font-family:var(--font-display); font-weight:600; line-height:1.1; color:var(--charcoal); letter-spacing:-.01em; }

.eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-size:.72rem; font-weight:600; letter-spacing:.24em; text-transform:uppercase;
  color:var(--terracota); margin-bottom:1.1rem;
}
.eyebrow::before{
  content:""; width:36px; height:2px; border-radius:2px; background:var(--gold-grad);
}
.section__head .eyebrow{ justify-content:center; }
.eyebrow--light{ color:var(--gold-soft); }

.section__title{ font-size:clamp(1.7rem, 1.15rem + 2vw, 2.55rem); }
.section__head{ text-align:center; max-width:640px; margin:0 auto 3rem; }
.section__lead{ color:var(--muted); font-size:1.05rem; margin-top:1rem; }

/* ---------- Botões ---------- */
.btn{
  --bg:var(--terracota); --fg:#fff;
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  background:var(--bg); color:var(--fg);
  font-family:var(--font-sans); font-weight:600; font-size:.98rem; letter-spacing:.01em;
  padding:.9rem 1.7rem; border:none; border-radius:999px; cursor:pointer;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), background .25s;
  box-shadow:0 12px 28px -16px rgba(120,50,20,.55);
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 20px 36px -18px rgba(120,50,20,.6); }
.btn--lg{ padding:1.1rem 2.2rem; font-size:1.05rem; }
.btn--block{ width:100%; }
.btn--ghost{ background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,.6); box-shadow:none; }
.btn--ghost:hover{ background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.85); }
.btn--whats{ --bg:var(--whats); box-shadow:0 14px 30px -16px rgba(37,211,102,.7); }
.btn--whats:hover{ box-shadow:0 22px 40px -18px rgba(37,211,102,.7); }

/* ===========================================================
   HEADER
   =========================================================== */
.header{
  position:fixed; inset:0 0 auto 0; z-index:50;
  padding:.7rem 0;
  transition:background .3s, box-shadow .3s, padding .3s;
}
.header.is-scrolled{
  background:rgba(248,248,245,.94);
  backdrop-filter:saturate(120%) blur(12px);
  box-shadow:0 4px 20px -14px rgba(0,0,0,.35);
  border-bottom:1px solid rgba(201,162,75,.55);
}
.header__inner{ display:flex; align-items:center; justify-content:space-between; }

.brand{ display:flex; align-items:center; gap:.7rem; }
.brand__logo{
  width:52px; height:52px; flex:none; border-radius:14px; object-fit:cover;
  box-shadow:var(--shadow-sm); border:2px solid rgba(255,255,255,.6);
}
.header.is-scrolled .brand__logo{ border-color:var(--gold-line); }
.brand__text{ display:flex; flex-direction:column; line-height:1.15; color:#fff; }
.header.is-scrolled .brand__text{ color:var(--charcoal); }
.brand__text strong{ font-family:var(--font-display); font-size:1.08rem; font-weight:700; letter-spacing:-.01em; }
.brand__text small{ font-size:.66rem; letter-spacing:.13em; text-transform:uppercase; opacity:.85; }

.nav{ display:flex; align-items:center; gap:.4rem; }
.nav__link{
  padding:.5rem .9rem; border-radius:999px; font-weight:500; font-size:.95rem; color:#fff;
  transition:background .2s, color .2s;
}
.header.is-scrolled .nav__link{ color:var(--ink); }
.nav__link:hover{ background:rgba(255,255,255,.16); }
.header.is-scrolled .nav__link:hover{ background:var(--sand); }
.nav__cta{ background:var(--terracota); color:#fff !important; margin-left:.4rem; padding:.6rem 1.2rem; }
.nav__cta:hover{ background:var(--terracota-2) !important; }

.nav__toggle{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:.4rem; }
.nav__toggle span{ width:26px; height:2.5px; background:#fff; border-radius:2px; transition:.3s; }
.header.is-scrolled .nav__toggle span{ background:var(--charcoal); }

/* ===========================================================
   HERO
   =========================================================== */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; color:#fff; overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:-2; }
.hero__bg img{ width:100%; height:100%; object-fit:cover; }
.hero__overlay{
  position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(180deg, rgba(18,11,6,.58) 0%, rgba(18,11,6,.42) 45%, rgba(18,11,6,.74) 100%),
    radial-gradient(80% 55% at 50% 52%, rgba(18,11,6,.35), transparent 70%),
    radial-gradient(130% 90% at 50% 120%, rgba(245,78,7,.20), transparent 55%);
}
.hero__content{
  max-width:680px; margin:3rem auto; text-align:center;
  padding:2.4rem 2.4rem 2.6rem;
}
.hero__badge{
  display:inline-block; font-size:.8rem; font-weight:500; letter-spacing:.05em;
  background:rgba(255,255,255,.08); border:1px solid rgba(199,154,52,.85);
  padding:.5rem 1.1rem; border-radius:999px; margin-bottom:1.6rem;
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
}
.hero__title{
  font-size:clamp(2rem, 1.3rem + 2.4vw, 3.2rem); color:#fff; font-weight:500;
  text-shadow:0 2px 40px rgba(0,0,0,.4);
}
.hero__title span{
  display:inline-block; margin-top:.5rem;
  color:var(--gold-soft); font-style:italic; font-weight:500;
  text-shadow:0 2px 30px rgba(0,0,0,.4);
}
.hero__sub{ font-size:1.08rem; margin:1.4rem auto 1.9rem; max-width:600px; color:rgba(255,255,255,.92); font-weight:300; text-shadow:0 1px 16px rgba(0,0,0,.55); }
.hero__actions{ display:flex; gap:1rem; flex-wrap:wrap; justify-content:center; }
.hero__note{ margin-top:1.6rem; font-size:.88rem; letter-spacing:.02em; color:rgba(255,255,255,.72); }

/* ===========================================================
   STRIP (diferenciais)
   =========================================================== */
.strip{ background:var(--charcoal); color:#fff; position:relative; }
.strip::before{
  content:""; position:absolute; inset:0 0 auto 0; height:3px; background:var(--gold-grad);
}
.strip__inner{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; padding:2.8rem 0; }
.strip__item{ text-align:center; position:relative; }
.strip__item:not(:last-child)::after{
  content:""; position:absolute; right:-.75rem; top:50%; transform:translateY(-50%);
  width:1px; height:56%; background:rgba(199,154,52,.6);
}
.strip__item strong{
  display:block; font-family:var(--font-display); font-weight:600; font-size:1.65rem;
  color:var(--gold-soft); line-height:1.1; letter-spacing:-.01em;
}
.strip__item span{ display:block; margin-top:.55rem; font-size:.9rem; color:rgba(255,255,255,.7); }

/* ===========================================================
   SECTIONS
   =========================================================== */
.section{ padding:clamp(4rem, 7vw, 6.5rem) 0; }
.section--alt{ background:var(--sand); }

/* cards de eventos */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.card{
  background:var(--white); border:1px solid var(--gold-soft-line); border-radius:var(--radius);
  padding:2.4rem 2rem; box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s;
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:var(--gold-line); }
.card__icon{
  width:56px; height:56px; display:grid; place-items:center; font-size:1.5rem;
  background:var(--sand); border:1px solid var(--gold-soft-line);
  border-radius:50%; margin-bottom:1.3rem;
}
.card h3{ font-size:1.3rem; margin-bottom:.55rem; }
.card p{ color:var(--muted); font-size:.97rem; line-height:1.6; }

/* ---------- Galeria ---------- */
.gallery{ display:flex; flex-wrap:wrap; gap:1rem; justify-content:center; }
.gallery__item{
  flex:0 1 calc(33.333% - 0.667rem);
  border-radius:var(--radius-sm); overflow:hidden; aspect-ratio:4/3;
  cursor:pointer; position:relative; box-shadow:var(--shadow-sm);
  background:var(--sand);
}
.gallery__item picture{ display:block; width:100%; height:100%; }
.gallery__item img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.gallery__item::after{
  content:"🔍"; position:absolute; inset:0; display:grid; place-items:center;
  font-size:1.4rem; background:rgba(30,24,19,.0); opacity:0; transition:.35s;
}
.gallery__item:hover img{ transform:scale(1.06); }
.gallery__item:hover::after{ opacity:1; background:rgba(30,24,19,.28); }

/* ---------- Vídeo em destaque ---------- */
.video-sec{ background:var(--cream); }
.video-wrap{ display:grid; grid-template-columns:1fr .8fr; gap:3.5rem; align-items:center; }
.features--inline{ grid-template-columns:1fr; margin:1.4rem 0 1.8rem; }
.video-player{ position:relative; justify-self:center; }
.video-player video{
  width:100%; max-width:330px; aspect-ratio:9/16; object-fit:cover;
  display:block; border-radius:22px; background:#000;
  border:5px solid #fff; box-shadow:0 24px 50px -18px rgba(245,78,7,.55);
}
.video-tag{
  position:absolute; left:50%; bottom:-14px; transform:translateX(-50%);
  background:var(--terracota); color:#fff; font-size:.8rem; font-weight:600;
  padding:.4rem 1rem; border-radius:999px; white-space:nowrap; box-shadow:var(--shadow-sm);
}

/* ---------- Estrutura ---------- */
.estrutura{ display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:center; }
.estrutura__media img{ border-radius:var(--radius); box-shadow:var(--shadow); width:100%; }
.features{ list-style:none; display:grid; grid-template-columns:1fr 1fr; gap:.7rem 1.4rem; margin:1.6rem 0 2rem; }
.features li{ position:relative; padding-left:1.7rem; font-size:.98rem; }
.features li::before{
  content:"✓"; position:absolute; left:0; top:0; color:var(--terracota); font-weight:700;
}

/* ---------- Bloco "você traz" (liberdade de produção) ---------- */
.byo{
  margin-top:clamp(2.5rem, 4vw, 4rem);
  background:var(--white); border:2px solid var(--gold-line); border-radius:var(--radius);
  padding:clamp(2rem, 4vw, 3.2rem); box-shadow:var(--shadow-sm);
  display:grid; grid-template-columns:.9fr 1.1fr; gap:2.5rem 3rem; align-items:center;
}
.byo__title{ font-size:clamp(1.4rem, 1rem + 1.4vw, 1.9rem); margin-top:.2rem; }
.byo__lead{ color:var(--muted); font-size:1rem; margin-top:.9rem; line-height:1.65; }
.byo__list{
  list-style:none; display:grid; grid-template-columns:1fr 1fr; gap:.9rem 1.4rem;
}
.byo__list li{
  position:relative; padding-left:1.9rem; font-size:.98rem; font-weight:500; color:var(--ink);
}
.byo__list li::before{
  content:"+"; position:absolute; left:0; top:-.05rem;
  display:grid; place-items:center; width:1.25rem; height:1.25rem;
  background:var(--sand); color:var(--terracota); border-radius:50%;
  font-size:.9rem; font-weight:700; line-height:1;
}

/* ===========================================================
   FORM
   =========================================================== */
.section--form{
  position:relative;
  background:
    radial-gradient(90% 70% at 85% 0%, rgba(245,78,7,.16), transparent 55%),
    var(--charcoal);
  color:#fff;
}
.section--form::before{
  content:""; position:absolute; inset:0 0 auto 0; height:3px; background:var(--gold-grad);
}
.section--form .eyebrow--light{ color:var(--gold-soft); }
.section--form .section__title{ color:#fff; }
.form-wrap{ display:grid; grid-template-columns:.85fr 1.15fr; gap:3.5rem; align-items:start; }
.form-intro .section__lead{ color:rgba(255,255,255,.72); }
.form-perks{ list-style:none; margin-top:1.8rem; display:grid; gap:.8rem; }
.form-perks li{ font-weight:500; color:rgba(255,255,255,.92); }

.form{
  color:var(--ink);
  border:2px solid transparent; border-radius:var(--radius);
  background:linear-gradient(var(--white),var(--white)) padding-box, var(--gold-grad) border-box;
  padding:2.2rem; box-shadow:var(--shadow);
  display:grid; grid-template-columns:1fr 1fr; gap:1.1rem;
}
.field{ display:flex; flex-direction:column; gap:.35rem; }
.field--full{ grid-column:1 / -1; }
.field label{ font-size:.86rem; font-weight:600; color:var(--ink); }
.field label small{ color:var(--muted); font-weight:400; }
.field input, .field select, .field textarea{
  font-family:inherit; font-size:1rem; color:var(--ink);
  padding:.75rem .9rem; border:1.5px solid var(--line); border-radius:var(--radius-sm);
  background:#fff; transition:border-color .2s, box-shadow .2s; width:100%;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--terracota); box-shadow:0 0 0 3px rgba(164,71,31,.12);
}
.field textarea{ resize:vertical; }
.field.has-error input, .field.has-error select{ border-color:#d23f3f; }
.error{ font-size:.78rem; color:#d23f3f; min-height:0; }
.form-fineprint{ font-size:.8rem; color:var(--muted); text-align:center; margin-top:.7rem; }

/* ===========================================================
   LOCALIZAÇÃO
   =========================================================== */
.localizacao{ display:grid; grid-template-columns:1fr 1.2fr; gap:3rem; align-items:stretch; }
.contact-list{ list-style:none; display:grid; gap:1.2rem; margin:1.5rem 0 1.8rem; }
.contact-list li{ font-size:.97rem; color:var(--ink); }
.contact-list strong{ color:var(--terracota); font-size:.8rem; letter-spacing:.08em; text-transform:uppercase; }
.contact-list a:hover{ color:var(--terracota); text-decoration:underline; }
.social{ display:flex; gap:.7rem; }
.social a{
  padding:.55rem 1.1rem; border:1.5px solid var(--line); border-radius:999px; font-weight:500; font-size:.9rem;
  transition:.2s;
}
.social a:hover{ background:var(--terracota); color:#fff; border-color:var(--terracota); }
.localizacao__map{ border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); min-height:360px; }
.localizacao__map iframe{ width:100%; height:100%; min-height:360px; border:0; }

/* ===========================================================
   FOOTER
   =========================================================== */
.footer{ background:var(--charcoal); color:rgba(255,255,255,.7); padding:3.5rem 0 2.2rem; position:relative; }
.footer::before{ content:""; position:absolute; inset:0 0 auto 0; height:3px; background:var(--gold-grad); }
.footer__inner{ display:flex; flex-direction:column; align-items:center; gap:1.4rem; text-align:center; }
.footer__brand{ display:flex; align-items:center; gap:.9rem; color:#fff; }
.footer__logo{ width:64px; height:64px; border-radius:16px; object-fit:cover; box-shadow:var(--shadow-sm); border:2px solid rgba(255,255,255,.85); }
.footer__brand strong{ font-family:var(--font-display); font-size:1.2rem; }
.footer__brand p{ font-size:.82rem; color:rgba(255,255,255,.78); }
.footer__script{ font-family:var(--font-script); font-size:1.5rem; color:var(--gold-soft); line-height:1.2; }
.footer__nav{ display:flex; gap:1.4rem; flex-wrap:wrap; justify-content:center; }
.footer__nav a{ font-size:.92rem; transition:color .2s; }
.footer__nav a:hover{ color:#fff; }
.footer__copy{ font-size:.82rem; color:rgba(255,255,255,.65); }

/* ===========================================================
   WHATSAPP FLUTUANTE
   =========================================================== */
.whats-float{
  position:fixed; right:1.2rem; bottom:1.2rem; z-index:60;
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.7rem 1.15rem .7rem .85rem; color:#fff;
  background:var(--whats); border:none; cursor:pointer; border-radius:999px;
  font-family:var(--font-sans); font-weight:600; font-size:.95rem;
  box-shadow:0 16px 34px -12px rgba(37,211,102,.6);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.whats-float:hover{ transform:translateY(-2px) scale(1.03); box-shadow:0 22px 40px -14px rgba(37,211,102,.65); }
.whats-float__label{ white-space:nowrap; }

/* ---------- Modal do WhatsApp (formulário popup) ---------- */
.wmodal{
  position:fixed; inset:0; z-index:90; display:none;
  background:rgba(20,12,7,.72); -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px);
  padding:1.2rem; overflow-y:auto;
}
.wmodal.is-open{ display:block; }
.wmodal__card{ position:relative; width:min(560px,100%); margin:.75rem auto; animation:wpop .3s var(--ease); }
@keyframes wpop{ from{ opacity:0; transform:translateY(16px) scale(.98); } to{ opacity:1; transform:none; } }
.wmodal__close{
  position:absolute; top:10px; right:10px; z-index:2;
  width:36px; height:36px; border-radius:50%; border:none; cursor:pointer;
  background:var(--sand); color:var(--ink); font-size:1.4rem; line-height:1;
  box-shadow:var(--shadow-sm); transition:background .2s;
}
.wmodal__close:hover{ background:var(--line); }
.wmodal__head{ text-align:center; margin-bottom:.1rem; }
.wmodal__head h3{ font-family:var(--font-display); font-weight:700; font-size:1.3rem; color:var(--charcoal); }
.wmodal__head p{ font-size:.85rem; color:var(--muted); margin-top:.25rem; }

/* Compacto: garante caber na tela (com rolagem interna se faltar altura) */
.wmodal .form{
  padding:1.3rem 1.4rem 1.4rem; gap:.65rem .9rem;
  max-height:calc(100dvh - 1.5rem); overflow-y:auto;
}
.wmodal .field label{ font-size:.8rem; }
.wmodal .field input, .wmodal .field select, .wmodal .field textarea{ padding:.55rem .75rem; font-size:.95rem; }
.wmodal .field textarea{ rows:2; }
.wmodal .btn--lg{ padding:.8rem 1.4rem; font-size:1rem; }
@keyframes pulse{
  0%{ box-shadow:0 12px 28px -8px rgba(37,211,102,.7), 0 0 0 0 rgba(37,211,102,.5); }
  70%{ box-shadow:0 12px 28px -8px rgba(37,211,102,.7), 0 0 0 16px rgba(37,211,102,0); }
  100%{ box-shadow:0 12px 28px -8px rgba(37,211,102,.7), 0 0 0 0 rgba(37,211,102,0); }
}

/* ===========================================================
   LIGHTBOX
   =========================================================== */
.lightbox{
  position:fixed; inset:0; z-index:100; display:none;
  background:rgba(15,10,7,.92); place-items:center; padding:1.5rem;
}
.lightbox.is-open{ display:grid; }
.lightbox__img{ max-width:92vw; max-height:86vh; border-radius:10px; box-shadow:0 30px 60px -20px rgba(0,0,0,.8); }
.lightbox__close{
  position:absolute; top:1rem; right:1.4rem; background:none; border:none; color:#fff;
  font-size:2.6rem; line-height:1; cursor:pointer; opacity:.8; transition:.2s;
}
.lightbox__close:hover{ opacity:1; }
.lightbox__nav{
  position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.12);
  border:none; color:#fff; font-size:2rem; width:52px; height:52px; border-radius:50%;
  cursor:pointer; transition:.2s; display:grid; place-items:center;
}
.lightbox__nav:hover{ background:rgba(255,255,255,.25); }
.lightbox__prev{ left:1rem; }
.lightbox__next{ right:1rem; }

/* ===========================================================
   ANIMAÇÕES DE ENTRADA
   =========================================================== */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.is-visible{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
  .whats-float{ animation:none; }
}

/* ===========================================================
   RESPONSIVO
   =========================================================== */
@media (max-width:980px){
  .cards{ grid-template-columns:repeat(2,1fr); }
  .gallery__item{ flex-basis:calc(50% - 0.5rem); }
  .estrutura{ grid-template-columns:1fr; gap:2.2rem; }
  .video-wrap{ grid-template-columns:1fr; gap:2.5rem; }
  .form-wrap{ grid-template-columns:1fr; gap:2.2rem; }
  .localizacao{ grid-template-columns:1fr; }
  .section--form{ background-attachment:scroll; }
  .byo{ grid-template-columns:1fr; gap:1.8rem; }
}

@media (max-width:760px){
  .nav{
    position:fixed; inset:0 0 0 auto; width:min(80vw,320px);
    flex-direction:column; align-items:stretch; justify-content:flex-start; gap:.2rem;
    background:var(--cream); padding:5.5rem 1.4rem 2rem; box-shadow:-12px 0 40px -20px rgba(0,0,0,.5);
    transform:translateX(100%); transition:transform .35s var(--ease);
  }
  .nav.is-open{ transform:translateX(0); }
  .nav__link{ color:var(--ink); padding:.85rem 1rem; border-radius:10px; }
  .nav__link:hover{ background:var(--sand); }
  .nav__cta{ margin-left:0; margin-top:.5rem; text-align:center; }
  .nav__toggle{ display:flex; z-index:60; }
  .header.is-scrolled .nav__toggle span,
  .nav__toggle.is-open span{ background:var(--charcoal); }

  .strip__inner{ grid-template-columns:repeat(2,1fr); gap:1.6rem 1rem; }
  .strip__item:nth-child(2)::after, .strip__item:last-child::after{ display:none; }

  .section{ padding:4rem 0; }
  .form{ grid-template-columns:1fr; padding:1.6rem; }
  .features{ grid-template-columns:1fr; }
  .byo__list{ grid-template-columns:1fr; }
  .hero__content{ padding:1.8rem 1.4rem 2rem; margin:4.5rem auto; border-radius:20px; }

  /* mobile: centraliza conteúdo e botões das seções */
  .estrutura__text, .video-text{ text-align:center; }
  .estrutura__text .features{ text-align:left; }
  .estrutura__text .btn, .video-text .btn{ margin-inline:auto; }
  .form-intro{ text-align:center; }
  .form-perks{ display:inline-grid; text-align:left; }
}

@media (max-width:440px){
  .cards{ grid-template-columns:1fr; }
  .gallery__item{ flex-basis:100%; }
  .whats-float{ padding:0; width:56px; height:56px; justify-content:center; border-radius:50%; }
  .whats-float__label{ display:none; }
  .hero__actions .btn{ width:100%; }
}
