/* ============================================================
   HUGO GRASSI — Molhos, Fundos & Técnicas | Landing Page
   Identidade visual derivada da logo oficial:
   Copper #E0742A · Espresso #181311 · Cream #F7F1E8
   Tipografia: Cinzel (títulos, igual à logo) + Inter (texto)
   ============================================================ */

:root{
  --copper:#E0742A;
  --copper-d:#C25E1B;
  --copper-l:#F2A45E;
  --copper-soft:#FBEADB;
  --ink:#181311;
  --ink-2:#221A16;
  --ink-3:#32271F;
  --cream:#F7F1E8;
  --cream-2:#EFE5D6;
  --paper:#FFFFFF;
  --text:#2C2420;
  --muted:#7A6C61;
  --line:#E6D8C6;
  --gold:#D8A94B;
  --green:#2F7D5B;
  --shadow:0 18px 50px rgba(24,19,17,.14);
  --shadow-sm:0 8px 24px rgba(24,19,17,.10);
  --radius:16px;
  --maxw:1140px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--text);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,.serif{font-family:'Cinzel',Georgia,serif;line-height:1.18;letter-spacing:.01em}
h2{font-size:clamp(1.7rem,3.6vw,2.7rem);font-weight:700;color:var(--ink)}
h3{font-size:1.18rem;font-weight:600}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:78px 0}
.center{text-align:center}
.eyebrow{
  font-size:.78rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--copper-d);margin-bottom:14px;display:block;
}
.lead{font-size:1.12rem;color:var(--muted)}
.muted{color:var(--muted)}
.divider-orn{height:36px;margin:6px auto 22px;opacity:.9}
.divider-orn img{height:100%;margin:0 auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  background:linear-gradient(180deg,var(--copper-l),var(--copper) 55%,var(--copper-d));
  color:#fff;font-weight:800;font-size:1.05rem;letter-spacing:.01em;
  padding:18px 34px;border-radius:60px;border:none;cursor:pointer;
  box-shadow:0 12px 26px rgba(224,116,42,.38);
  transition:transform .15s ease,box-shadow .15s ease,filter .15s ease;
  text-align:center;line-height:1.2;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(224,116,42,.5);filter:brightness(1.04)}
.btn:active{transform:translateY(0)}
.btn .sub{display:block;font-weight:600;font-size:.72rem;opacity:.92;letter-spacing:.08em;text-transform:uppercase}
.btn-lg{padding:22px 44px;font-size:1.18rem}
.cta-note{font-size:.84rem;color:var(--muted);margin-top:12px}
.cta-note b{color:var(--text)}

/* ---------- Header ---------- */
.topbar{
  position:static;background:var(--ink);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.topbar .wrap{display:flex;align-items:center;justify-content:center;height:64px}
.topbar img{height:30px}
.topbar .btn{padding:11px 22px;font-size:.92rem;box-shadow:none}
@media(max-width:560px){.topbar .btn{padding:10px 16px;font-size:.82rem}.topbar img{height:24px}}

/* ---------- Hero ---------- */
.hero{
  background:
    radial-gradient(900px 500px at 78% -8%,rgba(224,116,42,.30),transparent 60%),
    linear-gradient(165deg,var(--ink) 0%,var(--ink-2) 60%,var(--ink-3) 130%);
  color:#fff;position:relative;overflow:hidden;padding:64px 0 76px;
}
.hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(700px 320px at 12% 110%,rgba(224,116,42,.16),transparent 60%);
}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center}
.hero h1{font-size:clamp(1.85rem,3.9vw,2.85rem);font-weight:900;color:#fff;margin:14px 0 18px}
.hero h1 em{font-style:normal;color:var(--copper-l)}
.hero .lead{color:#E9DFD4;font-size:1.16rem;max-width:560px}
.hero .eyebrow{color:var(--copper-l)}
.hero-cta{margin-top:28px}
.trust{display:flex;flex-wrap:wrap;gap:18px 26px;margin-top:26px;font-size:.9rem;color:#D8CCC0}
.trust span{display:flex;align-items:center;gap:8px}
.trust .ck{color:var(--copper-l);font-weight:900}
.hero-art{position:relative}
.badge-float{
  position:absolute;right:-6px;top:-18px;z-index:3;background:var(--copper);
  color:#fff;font-weight:800;border-radius:50%;width:108px;height:108px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;line-height:1.05;box-shadow:var(--shadow);transform:rotate(-8deg);
  border:3px solid #fff;
}
.badge-float .big{font-size:1.5rem;font-family:'Cinzel',serif}
.badge-float small{font-size:.62rem;letter-spacing:.06em;opacity:.95}

/* ---------- Photo / image slots ---------- */
.ph{
  border:2px dashed var(--copper);border-radius:var(--radius);
  background:repeating-linear-gradient(135deg,var(--cream-2),var(--cream-2) 14px,#f3ead9 14px,#f3ead9 28px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:26px;color:var(--copper-d);min-height:300px;gap:8px;
}
.ph .ico{font-size:2rem}
.ph b{font-family:'Cinzel',serif;font-size:1rem;color:var(--ink)}
.ph small{color:var(--muted);max-width:300px;font-size:.82rem}
.ph--dark{background:repeating-linear-gradient(135deg,#241b16,#241b16 14px,#2c211a 14px,#2c211a 28px);border-color:var(--copper-l)}
.ph--dark b{color:#fff}.ph--dark small{color:#cdbfb2}
.ph--ratio{aspect-ratio:4/5}
.ph--wide{min-height:220px}

/* ---------- Fotos reais do chef ---------- */
.hero-photo{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center top;
  border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.12)}
.product-mock{display:block;width:100%;max-width:430px;margin:0 auto;
  filter:drop-shadow(0 26px 36px rgba(24,19,17,.20))}
.auth-photo-wrap{position:relative;margin:0}
.auth-photo{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--radius);
  box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.12)}
.auth-inset{position:absolute;left:-16px;bottom:-16px;width:44%;aspect-ratio:1/1;object-fit:cover;
  object-position:center top;border-radius:12px;border:5px solid var(--cream);
  box-shadow:var(--shadow);transform:rotate(-4deg)}

/* ---------- Media / "as seen on" strip ---------- */
.media{background:var(--ink-2);color:#cdbfb2;padding:22px 0;border-top:1px solid rgba(255,255,255,.06)}
.media .wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px 30px}
.media .label{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:#9a8b7e;width:100%;text-align:center;margin-bottom:4px}
.media .chip{font-family:'Cinzel',serif;font-size:1rem;color:#F2E7DA;opacity:.9;white-space:nowrap}
.media .dot{color:var(--copper)}

/* ---------- Pain ---------- */
.pain{background:var(--paper)}
.pain-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:30px}
.pain-card{
  background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:20px 22px;
  display:flex;gap:14px;align-items:flex-start;
}
.pain-card .x{color:var(--copper-d);font-weight:900;font-size:1.2rem;line-height:1.4}
.pain-card p{margin:0}
.pain-after{margin-top:30px;text-align:center;font-size:1.15rem;color:var(--ink);font-weight:600}

/* ---------- Mechanism ---------- */
.mech{background:var(--ink);color:#fff;text-align:center}
.mech h2{color:#fff;max-width:780px;margin:0 auto}
.mech h2 em{font-style:normal;color:var(--copper-l)}
.mech .lead{color:#E2D7CC;max-width:680px;margin:20px auto 0}
.mech-keys{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:42px}
.mech-key{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:22px 16px}
.mech-key .n{font-family:'Cinzel',serif;color:var(--copper-l);font-size:1.6rem}
.mech-key h3{color:#fff;margin:8px 0 6px;font-size:1.02rem}
.mech-key p{color:#cdbfb2;font-size:.9rem;margin:0}

/* ---------- Solution / reveal ---------- */
.reveal .wrap{display:grid;grid-template-columns:.95fr 1.05fr;gap:44px;align-items:center}
.reveal .tag{display:inline-block;background:var(--copper-soft);color:var(--copper-d);font-weight:700;
  padding:6px 14px;border-radius:30px;font-size:.8rem;letter-spacing:.06em;margin-bottom:16px}
.reveal ul{list-style:none;margin:22px 0 0}
.reveal li{position:relative;padding:9px 0 9px 30px;border-bottom:1px dashed var(--line)}
.reveal li .ck{position:absolute;left:0;top:9px;color:var(--copper);font-weight:900}

/* ---------- Modules ---------- */
.modules{background:var(--cream-2)}
.mod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}
.mod{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:26px 22px;transition:transform .15s,box-shadow .15s}
.mod:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.mod .ico{font-size:1.9rem}
.mod h3{margin:12px 0 8px;color:var(--ink)}
.mod p{font-size:.92rem;color:var(--muted);margin:0}
.mod .flag{display:inline-block;margin-top:14px;font-size:.78rem;font-weight:700;color:var(--copper-d);letter-spacing:.04em}

/* ---------- Authority ---------- */
.authority{background:var(--ink);color:#fff;position:relative}
.authority .wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:46px;align-items:center}
.authority .eyebrow{color:var(--copper-l)}
.authority h2{color:#fff}
.authority p{color:#E2D7CC;margin-top:14px}
.cred{list-style:none;margin:24px 0 0;display:grid;gap:12px}
.cred li{position:relative;padding-left:30px;color:#F1E7DB}
.cred li .ck{position:absolute;left:0;top:0;color:var(--copper-l);font-weight:900;font-size:1.1rem}
.auth-quote{margin-top:26px;border-left:3px solid var(--copper);padding:6px 0 6px 18px;
  font-family:'Cinzel',serif;font-size:1.12rem;color:#fff;font-style:italic}
.auth-quote span{display:block;font-family:'Inter';font-style:normal;font-size:.85rem;color:var(--copper-l);margin-top:8px;letter-spacing:.04em}

/* ---------- Value stack / Offer ---------- */
.offer{background:linear-gradient(180deg,var(--cream),var(--cream-2))}
.stack{
  max-width:720px;margin:34px auto 0;background:var(--paper);border:1px solid var(--line);
  border-radius:20px;box-shadow:var(--shadow);overflow:hidden;
}
.stack-head{background:var(--ink);color:#fff;text-align:center;padding:22px}
.stack-head h3{font-family:'Cinzel',serif;color:#fff;font-size:1.3rem}
.stack-head small{color:var(--copper-l);letter-spacing:.06em}
.stack-row{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:16px 26px;border-bottom:1px solid var(--line)}
.stack-row .t{display:flex;gap:12px;align-items:flex-start}
.stack-row .t .ck{color:var(--copper);font-weight:900}
.stack-row .t b{font-weight:700;color:var(--ink)}
.stack-row .t small{display:block;color:var(--muted);font-size:.84rem}
.stack-row .v{white-space:nowrap;color:var(--muted);font-weight:600}
.stack-row.bonus{background:var(--copper-soft)}
.stack-row.bonus .tag{display:inline-block;background:var(--copper);color:#fff;font-size:.66rem;font-weight:800;
  padding:2px 8px;border-radius:20px;letter-spacing:.08em;margin-right:8px;vertical-align:middle}
.stack-total{display:flex;justify-content:space-between;align-items:center;padding:18px 26px;background:#fbf6ee}
.stack-total span{font-weight:700;color:var(--ink)}
.stack-total .old{color:var(--muted);text-decoration:line-through;font-size:1.2rem}

.pricebox{max-width:560px;margin:38px auto 0;background:var(--paper);border:2px solid var(--copper);
  border-radius:20px;text-align:center;padding:34px 26px;box-shadow:var(--shadow);position:relative}
.pricebox .ribbon{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--copper);
  color:#fff;font-weight:800;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;padding:7px 18px;border-radius:30px}
.pricebox .from{color:var(--muted);text-decoration:line-through;font-size:1.1rem}
.pricebox .now{font-family:'Cinzel',serif;font-size:3.2rem;font-weight:900;color:var(--ink);line-height:1;margin:6px 0}
.pricebox .now small{font-size:1rem;color:var(--muted);font-family:'Inter'}
.pricebox .install{color:var(--copper-d);font-weight:700;margin-bottom:18px}
.pricebox .btn{width:100%}
.pay{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:16px;color:var(--muted);font-size:.84rem}

/* countdown */
.countdown{display:flex;justify-content:center;gap:10px;margin:0 auto 18px}
.cd-box{background:var(--ink);color:#fff;border-radius:10px;padding:8px 12px;min-width:62px}
.cd-box b{font-family:'Cinzel',serif;font-size:1.5rem;display:block;line-height:1}
.cd-box small{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--copper-l)}
.scarcity-line{text-align:center;color:var(--copper-d);font-weight:700;margin-top:8px}

/* ---------- Guarantee ---------- */
.guarantee{background:var(--paper)}
.guar-card{max-width:860px;margin:0 auto;display:grid;grid-template-columns:160px 1fr;gap:30px;align-items:center;
  background:var(--cream);border:1px solid var(--line);border-radius:20px;padding:34px}
.seal{width:150px;height:150px;border-radius:50%;background:var(--green);color:#fff;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;border:4px dashed rgba(255,255,255,.55);margin:0 auto}
.seal b{font-family:'Cinzel',serif;font-size:2.3rem;line-height:1}
.seal small{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;margin-top:4px}
.guar-card h3{font-family:'Cinzel',serif;font-size:1.5rem;color:var(--ink)}
.guar-card p{margin-top:10px;color:var(--text)}

/* ---------- Testimonials ---------- */
.testi{background:var(--cream-2)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.tcard{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:24px}
.stars{color:var(--gold);letter-spacing:2px;margin-bottom:10px}
.tcard p{font-size:.95rem}
.tcard .who{display:flex;align-items:center;gap:12px;margin-top:16px}
.tcard .av{width:42px;height:42px;border-radius:50%;background:var(--copper-soft);color:var(--copper-d);
  display:flex;align-items:center;justify-content:center;font-weight:800;font-family:'Cinzel',serif}
.tcard .who b{font-size:.9rem}.tcard .who small{color:var(--muted);font-size:.8rem}

/* ---------- FAQ ---------- */
.faq{background:var(--paper)}
.faq-list{max-width:780px;margin:34px auto 0}
.qa{border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden;background:var(--cream)}
.qa summary{list-style:none;cursor:pointer;padding:18px 22px;font-weight:700;color:var(--ink);
  display:flex;justify-content:space-between;align-items:center;gap:14px;font-size:1rem}
.qa summary::-webkit-details-marker{display:none}
.qa summary .pm{color:var(--copper);font-size:1.5rem;font-weight:400;transition:transform .2s}
.qa[open] summary .pm{transform:rotate(45deg)}
.qa .a{padding:0 22px 20px;color:var(--text)}

/* ---------- Final CTA ---------- */
.final{background:linear-gradient(165deg,var(--ink),var(--ink-3));color:#fff;text-align:center}
.final h2{color:#fff;max-width:760px;margin:0 auto}
.final h2 em{font-style:normal;color:var(--copper-l)}
.final .lead{color:#E2D7CC;max-width:620px;margin:18px auto 30px}
.final img.orn{height:34px;margin:0 auto 18px}

/* ---------- Footer ---------- */
.footer{background:#120e0c;color:#9a8b7e;padding:48px 0 36px;font-size:.86rem}
.footer img{height:44px;margin-bottom:18px}
.footer .wrap{text-align:center}
.footer a{color:var(--copper-l)}
.footer .legal{margin-top:18px;font-size:.76rem;line-height:1.7;color:#7d6f63;max-width:760px;margin-left:auto;margin-right:auto}
.footer .sep{height:1px;background:rgba(255,255,255,.08);margin:26px auto;max-width:760px}

/* ---------- Floating mobile CTA ---------- */
.float-cta{position:fixed;left:0;right:0;bottom:0;z-index:70;background:rgba(24,19,17,.97);
  padding:10px 16px;display:none;align-items:center;justify-content:space-between;gap:12px;
  box-shadow:0 -8px 24px rgba(0,0,0,.25);border-top:1px solid rgba(255,255,255,.1)}
.float-cta .px{color:#fff;font-weight:800;font-family:'Cinzel',serif}
.float-cta .px small{display:block;color:var(--copper-l);font-size:.66rem;font-family:'Inter';text-decoration:line-through}
.float-cta .btn{padding:13px 20px;font-size:.95rem}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .hero .wrap,.reveal .wrap,.authority .wrap{grid-template-columns:1fr;gap:30px}
  .mech-keys{grid-template-columns:repeat(2,1fr)}
  .mod-grid,.testi-grid{grid-template-columns:1fr 1fr}
  .badge-float{width:90px;height:90px}
}
@media(max-width:680px){
  .section{padding:56px 0}
  .pain-grid,.mod-grid,.testi-grid{grid-template-columns:1fr}
  .guar-card{grid-template-columns:1fr;text-align:center}
  .stack-row{flex-direction:column;align-items:flex-start;gap:6px}
  .stack-row .v{align-self:flex-end}
  .hero{padding-bottom:40px}
  .auth-inset{width:40%;left:-6px;bottom:-6px}
}

/* ============================================================
   MOBILE-FIRST POLISH + INTERAÇÕES
   ============================================================ */

/* Scroll reveal (aplicado via JS; sem JS tudo aparece normal) */
.reveal-up{opacity:0;transform:translateY(26px);transition:opacity .65s ease,transform .65s cubic-bezier(.2,.7,.2,1)}
.reveal-up.in{opacity:1;transform:none}

/* Estados de toque (mobile não tem hover) */
.btn:active{transform:translateY(1px) scale(.99)}
.mod:active,.tcard:active,.qa:active{transform:scale(.992)}

/* Pulse sutil no CTA principal */
.btn-pulse{animation:ctaPulse 2.6s ease-in-out infinite}
@keyframes ctaPulse{
  0%,100%{box-shadow:0 12px 26px rgba(224,116,42,.38)}
  50%{box-shadow:0 14px 34px rgba(224,116,42,.6),0 0 0 7px rgba(224,116,42,.10)}
}

/* Âncora não fica escondida sob o header fixo */
#oferta{scroll-margin-top:84px}

/* Dica de swipe (só mobile) */
.swipe-hint{display:none;margin-top:14px;color:var(--copper-d);font-weight:700;font-size:.85rem;letter-spacing:.02em}

@media(prefers-reduced-motion:reduce){
  .reveal-up{opacity:1;transform:none;transition:none}
  .btn-pulse{animation:none}
  html{scroll-behavior:auto}
}

/* ---------- Tablet ---------- */
@media(max-width:760px){
  .hero h1{font-size:clamp(1.75rem,6.4vw,2.4rem)}
}

/* ---------- Mobile (<=560px) ---------- */
@media(max-width:560px){
  .wrap{padding:0 18px}
  .section{padding:46px 0}
  h2{font-size:clamp(1.5rem,6.6vw,2rem)}
  .hero{padding-top:40px}
  .hero h1{font-size:clamp(1.7rem,7.4vw,2.15rem);margin:12px 0 14px}
  .hero .lead,.lead{font-size:1.02rem}
  .eyebrow{font-size:.72rem;letter-spacing:.18em}

  /* CTAs full-width e confortáveis pro dedo */
  .btn-lg,.hero-cta .btn{width:100%}
  .btn{padding:17px 22px}

  /* Trust: um por linha, alinhado à esquerda */
  .trust{flex-direction:column;gap:11px;margin-top:22px}
  .trust span{font-size:.95rem}

  /* Badge do hero menor e fora do caminho do texto */
  .badge-float{width:74px;height:74px;top:-8px;right:4px;border-width:2px}
  .badge-float .big{font-size:1.05rem}
  .badge-float small{font-size:.52rem}

  /* Hero: foto com altura controlada */
  .hero-photo{aspect-ratio:4/4.4}

  /* Mechanism: 1 coluna respira melhor */
  .mech-keys{grid-template-columns:1fr;gap:12px}
  .mech-key{display:flex;align-items:center;gap:14px;text-align:left;padding:16px}
  .mech-key .n{font-size:1.4rem;min-width:34px}
  .mech-key h3{margin:0 0 2px}

  /* Oferta */
  .stack-head h3{font-size:1.1rem}
  .pricebox .now{font-size:2.7rem}
  .cd-box{min-width:54px;padding:7px 10px}
  .cd-box b{font-size:1.3rem}

  /* Garantia centralizada */
  .seal{width:128px;height:128px}

  /* FAQ tap target maior */
  .qa summary{padding:18px}

  /* Footer */
  .footer img{height:38px}
}

/* ---------- Carrosséis com swipe (módulos + depoimentos) no mobile ---------- */
@media(max-width:680px){
  .mod-grid,.testi-grid{
    display:flex;grid-template-columns:none;gap:14px;
    overflow-x:auto;scroll-snap-type:x mandatory;
    padding:6px 18px 16px;margin:0 -18px;
    -webkit-overflow-scrolling:touch;scrollbar-width:none;
  }
  .mod-grid::-webkit-scrollbar,.testi-grid::-webkit-scrollbar{display:none}
  .mod{flex:0 0 80%;scroll-snap-align:center}
  .tcard{flex:0 0 85%;scroll-snap-align:center}
  .swipe-hint{display:block}
}
