/* ===== BELFEROCCI® — réplica fiel do site real (SCHABO + #161616 + #4C0000 + #e0e0e0) ===== */
:root{
  --ink:#161616; --ink-2:#1b1b1b; --char:#323232;
  --cream:#f3efe8; --light:#e0e0e0;
  --dim:rgba(243,239,232,.66); --faint:rgba(243,239,232,.42); --line:rgba(243,239,232,.13);
  --bordo:#4c0000; --bordo-2:#660909; --gold:#c9a86a;
  --ink-dim:rgba(22,22,22,.62);
  --f-disp:'SCHABO Condensed','SCHABO','Oswald',Impact,sans-serif;
  --f:'Sora',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --f-ui:'Space Grotesk','Sora',sans-serif; --f-mono:'Space Mono',ui-monospace,monospace;
  --wrap:1180px; --r:18px;
  --sp-4:16px; --sp-6:24px; --sp-8:32px; --sp-12:48px; --sp-16:64px; --sp-20:80px; --sp-24:96px;
  --r-sm:6px; --r-md:12px; --r-lg:18px;
  --sh-sm:0 2px 10px rgba(0,0,0,.3); --sh-md:0 12px 30px -14px rgba(0,0,0,.55); --sh-lg:0 28px 64px -26px rgba(0,0,0,.7); --sh-xl:0 44px 96px -38px rgba(0,0,0,.72);
  --ease:cubic-bezier(.2,.6,.2,1); --dur:.25s;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--ink);color:var(--cream);font-family:var(--f);font-weight:400;line-height:1.6;letter-spacing:-.01em;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body::after{content:"";position:fixed;inset:0;z-index:200;pointer-events:none;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
@media (prefers-reduced-motion:reduce){body::after{display:none}}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
em{font-style:normal;color:var(--gold)}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 30px;width:100%}
.narrow{max-width:840px}.center{text-align:center}
.disp{font-family:var(--f-disp);font-weight:400;text-transform:uppercase;line-height:.9;letter-spacing:.01em}
h1.disp{font-size:clamp(48px,8.2vw,128px)}
h2.disp{font-size:clamp(34px,5.4vw,76px)}
h3.disp{font-size:clamp(24px,3vw,40px)}
.eyebrow{display:inline-block;font-size:12.5px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.lead{color:var(--dim);font-size:clamp(16px,1.5vw,19px);max-width:600px}
.section-lead{color:var(--dim);font-size:clamp(16px,1.5vw,19px);max-width:680px;margin:18px auto 0}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-weight:600;font-size:14px;letter-spacing:.02em;padding:16px 32px;border-radius:999px;cursor:pointer;border:1px solid transparent;transition:.25s}
.btn-bordo{background:var(--bordo);color:var(--cream);box-shadow:0 14px 34px -16px rgba(76,0,0,.9)}
.btn-bordo:hover{background:var(--bordo-2);transform:translateY(-2px);box-shadow:0 18px 42px -16px rgba(76,0,0,.95)}
.btn-ghost{background:transparent;color:var(--cream);border-color:var(--line)}.btn-ghost:hover{border-color:var(--cream);transform:translateY(-2px)}
.btn.full{width:100%}.btn.lg{padding:19px 44px;font-size:15px}
.btn:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

/* navbar pílula creme */
.nav{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:60;width:calc(100% - 40px);max-width:1240px;display:flex;align-items:center;gap:24px;background:rgba(243,239,232,.9);backdrop-filter:blur(20px) saturate(1.1);-webkit-backdrop-filter:blur(20px) saturate(1.1);color:#1a1410;border-radius:999px;padding:13px 16px 13px 28px;box-shadow:0 16px 44px -22px rgba(0,0,0,.45);transition:top .35s var(--ease),padding .35s var(--ease),box-shadow .35s var(--ease)}
.nav.solid{top:10px;padding:9px 14px 9px 24px;box-shadow:0 10px 30px -18px rgba(0,0,0,.5)}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:45px;width:auto;display:block;transition:height .35s var(--ease)}
.nav.solid .nav-logo img{height:39px}
.nav-logo .sym{display:none}
.nav-links{display:flex;gap:30px;margin-left:auto}
.nav-links a{position:relative;font-size:14px;font-weight:500;color:#3a322c;transition:color .2s var(--ease)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--bordo);transition:width .28s var(--ease)}
.nav-links a:hover{color:#1a1410}
.nav-links a:hover::after{width:100%}
.nav-cta{margin-left:6px}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;margin-left:auto;padding:8px}
.nav-burger span{width:24px;height:2px;background:#1a1410;transition:.3s}
.scrim{position:fixed;inset:0;background:rgba(0,0,0,.6);opacity:0;pointer-events:none;transition:.3s;z-index:55}
.scrim.show{opacity:1;pointer-events:auto}

/* hero foto full-bleed */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;padding:0 0 8vh}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 28%}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(22,22,22,.32) 0%,rgba(22,22,22,0) 28%,rgba(22,22,22,.5) 70%,var(--ink) 100%)}
.hero-inner{position:relative;z-index:2;width:100%}
.hero .eyebrow{color:var(--cream)}
.hero h1{margin:6px 0 0;max-width:none;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero-sub{font-family:var(--f-disp);text-transform:uppercase;letter-spacing:.02em;font-size:clamp(18px,2vw,28px);color:var(--cream);margin:18px 0 0}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin:28px 0 0}

/* marquee banner */
.marquee{background:var(--bordo);overflow:hidden;white-space:nowrap;padding:18px 0;border-top:1px solid rgba(243,239,232,.12);border-bottom:1px solid rgba(243,239,232,.12)}
.marquee .track{display:inline-flex;gap:40px;animation:scroll 26s linear infinite;will-change:transform}
.marquee span{font-family:var(--f-disp);text-transform:uppercase;font-size:26px;letter-spacing:.04em;color:var(--cream)}
.marquee i{color:var(--gold);font-style:normal}
@keyframes scroll{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee .track{animation:none}}

/* sections */
section{position:relative}
.sec{padding:118px 0}
.char{background:var(--char)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}

/* dor */
.dor h2{margin-bottom:18px}
.dor .lines{list-style:none;display:flex;flex-direction:column;gap:8px;max-width:560px;margin:0 auto}
.dor .lines li{color:var(--dim);font-size:18px}
.dor .credo{margin-top:30px;font-size:19px}.dor .credo strong{color:var(--cream)}
.dor .kick{color:var(--gold);font-family:var(--f-disp);text-transform:uppercase;font-size:clamp(22px,2.6vw,34px);margin-top:30px;letter-spacing:.01em}

/* pillars (uma decisão) */
.pillars{background:var(--ink-2);text-align:center;padding-bottom:46px}
.pillars .row{display:flex;flex-wrap:wrap;justify-content:center;margin-top:34px}
.pillars .p{padding:10px 30px;font-size:16px;color:var(--cream);position:relative}
.pillars .p b{color:var(--gold);margin-right:6px}
.pillars .p+.p::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:1px;height:16px;background:var(--line)}

/* banda vermelha */
.band-red{background:radial-gradient(130% 130% at 72% 22%,#5d0c0c,var(--bordo) 58%);color:var(--cream)}
.band-red .eyebrow{color:rgba(243,239,232,.72)}
.band-red p{color:rgba(243,239,232,.84);margin-top:16px;max-width:540px}
.band-red strong{color:var(--cream)}
.band-red .fig{position:relative}
.band-red .figimg{position:relative}
.band-red .fig img{width:100%;border-radius:var(--r)}
.badge{position:absolute;right:14px;bottom:14px;width:150px;height:150px;border-radius:50%;background:var(--ink);border:1px solid var(--gold);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:0 20px 50px -20px rgba(0,0,0,.7)}
.badge .b1{font-family:var(--f-disp);font-size:54px;color:var(--gold);line-height:.9}
.badge .b2{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--cream);margin-top:4px;max-width:120px}
.formula{margin-top:24px;border:1px solid rgba(243,239,232,.22);border-radius:14px;padding:20px;background:rgba(0,0,0,.16)}
.formula h4{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--cream)}
.formula p{font-size:14px;margin-top:8px;color:rgba(243,239,232,.85)}
.formula .mini{font-size:11px;color:rgba(243,239,232,.6);margin-top:10px}

/* banda clara (#e0e0e0) */
.band-light{background:var(--light);color:#1a1410}
.band-light .eyebrow{color:var(--bordo)}
.band-light p{color:var(--ink-dim);margin-top:16px;max-width:520px}
.band-light strong{color:#1a1410}
.band-light .fig img{width:100%;border-radius:var(--r);box-shadow:0 40px 80px -40px rgba(0,0,0,.4)}

/* timeline */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:54px}
.step{border:1px solid var(--line);border-radius:16px;padding:30px 24px;background:var(--char);transition:.3s}
.step:hover{transform:translateY(-4px);border-color:rgba(201,168,106,.4)}
.step .n{font-family:var(--f-disp);font-size:50px;color:var(--gold);line-height:.9}
.step .n small{font-family:var(--f);font-size:13px;font-weight:500;color:var(--faint);margin-left:5px}
.step h3{font-size:18px;margin:12px 0 8px;text-transform:uppercase;letter-spacing:.03em}
.step p{font-size:14px;color:var(--dim)}

/* produtos */
.offers{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px;align-items:stretch}
.offer{position:relative;border:1px solid var(--line);border-radius:var(--r);padding:24px;display:flex;flex-direction:column;text-align:center;background:var(--char);transition:.3s}
.offer:hover{transform:translateY(-6px)}
.offer.feat{border-color:var(--gold)}
.offer-flag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--bordo);color:var(--cream);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:6px 16px;border-radius:999px;white-space:nowrap}
.offer-shot{border-radius:12px;overflow:hidden;margin-bottom:20px;background:#0d0d0d}
.offer-shot img{width:100%;height:240px;object-fit:cover}
.offer h3{font-family:var(--f-disp);font-size:32px;text-transform:uppercase}
.offer-for{color:var(--dim);font-size:14px;margin-top:8px;min-height:40px}
.offer-benefit{color:var(--gold);font-weight:600;margin-top:4px}
.offer-meta{display:flex;justify-content:center;gap:18px;margin:16px 0;font-size:12.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.04em}
.offer-price{font-family:var(--f-disp);font-size:58px;margin-bottom:20px;line-height:.9}
.offer-price .cur{font-family:var(--f);font-size:20px;font-weight:600;color:var(--faint);vertical-align:super;margin-right:3px}
.offer .btn{margin-top:auto}
.disc{text-align:center;font-size:12px;color:var(--faint);margin-top:30px;max-width:700px;margin-left:auto;margin-right:auto}

/* lifestyle band */
.life{position:relative;min-height:60vh;display:flex;align-items:center;overflow:hidden}
.life img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.life::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(22,22,22,.9),rgba(22,22,22,.4) 60%,transparent)}
.life .wrap{position:relative;z-index:2}.life h2{max-width:680px}.life .lead{margin-top:18px}

/* paraquem */
.checklist{list-style:none;display:flex;flex-direction:column;gap:2px;max-width:640px;margin:30px auto 0}
.checklist li{padding:18px 0 18px 40px;border-bottom:1px solid var(--line);position:relative;font-size:17px}
.checklist li::before{content:"✓";position:absolute;left:0;top:16px;color:var(--gold);font-weight:700}

/* depoimentos */
.depo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.cdepo{border:1px solid var(--line);border-radius:var(--r);padding:30px;background:var(--char);display:flex;flex-direction:column;gap:22px}
.cdepo blockquote{font-size:17px;line-height:1.6}
.cdepo figcaption{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--dim)}
.cdepo img{width:46px;height:46px;border-radius:50%;object-fit:cover;flex:none}
.cdepo b{color:var(--cream)}

/* valores */
.val-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.val{text-align:center;border:1px solid var(--line);border-radius:var(--r);padding:34px 24px;background:var(--char)}
.val .n{font-family:var(--f-disp);font-size:32px;color:var(--gold)}
.val h3{font-size:19px;margin:12px 0 8px;text-transform:uppercase;letter-spacing:.02em}.val p{color:var(--dim);font-size:15px}

/* faq */
.faq-list{max-width:820px;margin:46px auto 0}
.qa{border-bottom:1px solid var(--line)}
.qa summary{list-style:none;cursor:pointer;padding:22px 0;display:flex;justify-content:space-between;gap:16px;font-size:18px;font-weight:600}
.qa summary::-webkit-details-marker{display:none}
.qa summary i{flex:none;width:22px;height:22px;position:relative}
.qa summary i::before,.qa summary i::after{content:"";position:absolute;background:var(--gold);top:50%;left:50%;transition:.3s}
.qa summary i::before{width:14px;height:2px;transform:translate(-50%,-50%)}
.qa summary i::after{width:2px;height:14px;transform:translate(-50%,-50%)}
.qa[open] summary i::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.qa p{color:var(--dim);padding:0 0 24px;max-width:680px}

/* cta final */
.ctaf{text-align:center;background:linear-gradient(180deg,var(--ink),#240505)}
.ctaf .btn{margin-top:30px}

/* footer */
.ftr{border-top:1px solid var(--line);padding:64px 0 40px;background:#101010;text-align:center}
.ftr-wordmark{height:52px;width:auto;margin:0 auto 10px;opacity:.92}
.ftr-tag{font-size:12px;color:var(--faint);text-transform:uppercase;letter-spacing:.14em}
.ftr-nav{display:flex;justify-content:center;flex-wrap:wrap;gap:26px;margin:28px 0;font-size:14px;color:var(--dim)}
.ftr-nav a:hover{color:var(--gold)}
.ftr-legal{margin-top:28px;padding-top:26px;border-top:1px solid var(--line)}
.disclaimer{font-size:12px;line-height:1.7;color:var(--faint);max-width:860px;margin:0 auto}
.disclaimer strong{color:var(--dim)}
.copy{font-size:12px;color:var(--faint);margin-top:16px}

/* reveal */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s,transform .7s}
[data-reveal].in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none;transition:none}}

/* ===== polish pass: hovers consistentes + stagger + marquee pause ===== */
.offer{transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.offer:hover{transform:translateY(-6px);border-color:rgba(201,168,106,.4);box-shadow:var(--sh-lg)}
.offer.feat{transform:scale(1.03);box-shadow:var(--sh-lg);z-index:2}
.offer.feat:hover{transform:scale(1.03) translateY(-6px)}
.step{transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.step:hover{transform:translateY(-5px);border-color:rgba(201,168,106,.4);box-shadow:var(--sh-md)}
.val{transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.val:hover{transform:translateY(-5px);border-color:rgba(201,168,106,.32);box-shadow:var(--sh-md)}
.cdepo{transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.cdepo:hover{transform:translateY(-4px);border-color:rgba(201,168,106,.28);box-shadow:var(--sh-md)}
.offers>[data-reveal]:nth-child(2),.depo-grid>[data-reveal]:nth-child(2),.val-grid>[data-reveal]:nth-child(2),.steps>[data-reveal]:nth-child(2){transition-delay:.08s}
.offers>[data-reveal]:nth-child(3),.depo-grid>[data-reveal]:nth-child(3),.val-grid>[data-reveal]:nth-child(3),.steps>[data-reveal]:nth-child(3){transition-delay:.16s}
.steps>[data-reveal]:nth-child(4){transition-delay:.24s}
.marquee:hover .track{animation-play-state:paused}

/* tipografia da marca: Sora (corpo) · Space Grotesk (UI) · Space Mono (técnico/numeral) · SCHABO (display) */
.eyebrow,.btn,.nav-links a,.offer-flag,.offer-benefit,.offer-meta,.pillars .p,.ftr-nav a{font-family:var(--f-ui)}
.disclaimer,.copy,.ftr-tag,.badge .b2,.formula .mini,.step .n small,.offer-price .cur{font-family:var(--f-mono)}

/* bloco rotativo */
.rotate{background:var(--ink-2);text-align:center;padding:24px 0 68px}
.rot-mark{font-size:30px;color:var(--gold);margin-bottom:16px}
.rot-line{font-size:clamp(19px,2.3vw,29px);font-weight:600;letter-spacing:-.02em;max-width:760px;margin:0 auto;min-height:2.3em;display:flex;align-items:center;justify-content:center;transition:opacity .25s var(--ease)}
.rot-fixed{font-family:var(--f-disp);text-transform:uppercase;font-size:clamp(20px,2.4vw,32px);color:var(--gold);margin-top:24px;letter-spacing:.01em}

/* depoimento: título */
.cdepo .dh{font-family:var(--f-disp);text-transform:uppercase;font-size:21px;line-height:1.05;color:var(--cream);letter-spacing:.01em}
.cdepo blockquote{color:var(--dim);font-size:16px}

/* marquee de palavras (variante) */
.marquee-out{background:transparent;padding:26px 0;border-color:var(--line)}
.marquee-out span{font-size:clamp(26px,3.4vw,46px);color:var(--cream)}
.marquee-out i{color:var(--gold)}

/* faixa de benefícios */
.benefits .ben-row{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:30px}
.benefits .ben-row span{font-family:var(--f-disp);text-transform:uppercase;font-size:clamp(19px,2.1vw,29px);color:var(--cream);border:1px solid var(--line);border-radius:999px;padding:10px 26px;transition:border-color var(--dur) var(--ease),color var(--dur) var(--ease)}
.benefits .ben-row span:hover{border-color:var(--gold);color:var(--gold)}

/* responsive */
@media (max-width:1040px){
  .grid-2{grid-template-columns:1fr;gap:40px}
  .offers,.depo-grid,.val-grid,.steps{grid-template-columns:1fr 1fr}
  .offer.feat{transform:none}
  .badge{width:130px;height:130px}.badge .b1{font-size:42px}
}
@media (max-width:740px){
  .wrap{padding:0 22px}
  .nav{left:20px;right:20px;width:auto;transform:none;padding:10px 14px 10px 22px}
  .nav-logo img.full{height:34px}.nav-logo .sym{display:none}
  .nav-links{position:fixed;inset:0 0 0 auto;width:82%;max-width:320px;flex-direction:column;justify-content:center;gap:24px;background:var(--cream);padding:40px;transform:translateX(110%);transition:transform .35s;z-index:62;box-shadow:-20px 0 60px -20px rgba(0,0,0,.5)}
  .nav-links.open{transform:none}.nav-links a{font-size:18px;color:#1a1410}
  .nav-cta{display:none}.nav-burger{display:flex}
  .offers,.depo-grid,.val-grid,.steps{grid-template-columns:1fr}
  .sec{padding:74px 0}
  .marquee span{font-size:20px}
}

/* ===================== ANIMAÇÃO + CRAFT (GSAP) ===================== */
/* quando o GSAP carrega, ele assume opacity/transform do reveal e do tilt */
html.gsap-on [data-reveal]{transition:none}
.gsap-on .rot-line{transition:none}

/* --- bloco alternante: imagem + mensagem (cross-fade) --- */
.rotate{background:var(--ink-2);text-align:left;padding:100px 0}
.rot-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:60px;align-items:center}
.rot-media{position:relative}
.rot-imgs{position:relative;width:100%;aspect-ratio:4/5;border-radius:var(--r);overflow:hidden;background:#0d0d0d;box-shadow:var(--sh-xl)}
.rot-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.07);transition:opacity 1s var(--ease),transform 7s linear;will-change:opacity,transform}
.rot-img.is-on{opacity:1;transform:scale(1)}
.rot-imgs::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 52%,rgba(13,13,13,.55));pointer-events:none;z-index:2}
.rot-frame{position:absolute;inset:13px;border:1px solid rgba(243,239,232,.2);border-radius:calc(var(--r) - 7px);pointer-events:none;z-index:3}
.rot-copy{max-width:520px}
.rot-copy .rot-mark{margin-bottom:14px}
.rot-copy .rot-line{display:block;text-align:left;max-width:none;min-height:3.2em;margin:0}
.rot-copy .rot-fixed{text-align:left}

/* --- cena de ritmo (#metodo): pico/queda -> constância --- */
.band-red-head h2{margin-top:4px}
.rhythm{margin:42px 0 6px}
.rhythm-svg{width:100%;height:auto;display:block;overflow:visible}
.rh-line{fill:none;stroke:var(--gold);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 9px rgba(201,168,106,.4))}
.rh-dot{fill:#fff5e2;filter:drop-shadow(0 0 7px rgba(255,240,210,.95));opacity:0}
.gsap-on .rh-dot{opacity:1}
.rhythm-labels{display:flex;justify-content:space-between;margin-top:8px;font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.rhythm-labels span:first-child{color:rgba(243,239,232,.5)}
.rhythm-labels span:last-child{color:var(--gold)}
.band-red-body{margin-top:36px;align-items:stretch}
@media (min-width:1041px){
  .band-red-body .fig{align-self:stretch;display:flex}
  .band-red-body .figimg{height:100%;width:100%}
  .band-red-body .fig img{height:100%;object-fit:cover}
}

/* --- timeline: rail conector + count-up --- */
.steps{position:relative}
.step{position:relative;z-index:2;background:var(--bordo);border:1px solid rgba(201,168,106,.22)}
.step h3{color:var(--cream)}
.step p{color:rgba(243,239,232,.82)}
.step .n{display:inline-flex;align-items:flex-end}
.step .n small{color:rgba(243,239,232,.6)}
.step .n .num{font-style:normal;font-variant-numeric:tabular-nums}
.step:hover{border-color:var(--gold);box-shadow:0 16px 38px -26px rgba(0,0,0,.55)}
@media (max-width:740px){ .checklist li{padding:20px 0 20px 36px;font-size:16px;line-height:1.5} .checklist li::before{top:19px} }

/* --- produtos: cards alinhados (destaque só por borda + selo, sem scale) --- */
.offer.feat{transform:none}
.offer.feat:hover{transform:translateY(-6px)}

/* --- valores: ícones autorais --- */
.val-ic{display:inline-flex;width:58px;height:58px;color:var(--gold);margin-bottom:8px}
.val-ico{width:100%;height:100%;overflow:visible}
.val-rom{display:block;font-family:var(--f-mono);font-size:11px;letter-spacing:.22em;color:var(--faint);margin-bottom:6px}

/* --- micro-tilt: GSAP assume o transform desses cards --- */
.offers,.depo-grid,.val-grid{perspective:1100px}
.gsap-on .offer,.gsap-on .cdepo,.gsap-on .val{will-change:transform;transition:box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease)}

/* --- parallax --- */
.hero-bg{overflow:hidden}
.hero-bg img,.life img{will-change:transform}
.life img{object-position:center 26%}
/* para quem: foto A ao lado da checklist */
.paraquem-grid{margin-top:46px;align-items:center}
.pq-fig img{width:100%;border-radius:var(--r);box-shadow:var(--sh-lg);aspect-ratio:1/1;object-fit:cover;object-position:center 12%}
.paraquem-grid .checklist{margin:0;max-width:none}

/* --- spacing: marquee de palavras não cola no texto (#saber) --- */
#saber .marquee-out{margin-top:56px}

/* --- valores: cards escuros p/ contraste com a seção cinza --- */
#valores .val{background:linear-gradient(180deg,#1a1512,#101010);border-color:rgba(201,168,106,.2);box-shadow:0 18px 44px -22px rgba(0,0,0,.6)}
#valores .val:hover{border-color:var(--gold);box-shadow:0 26px 58px -22px rgba(76,0,0,.55)}

/* --- benefícios: thread animada + spark + hover bordô --- */
.benefits{padding-top:84px}
.benefits .ben-thread{position:relative;height:2px;max-width:760px;margin:38px auto 0}
.benefits .ben-track{position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(201,168,106,.55),transparent);transform:scaleX(1);transform-origin:center}
.gsap-on .benefits .ben-track{transform:scaleX(0)}
.benefits .ben-spark{position:absolute;top:50%;left:0;width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 12px 2px rgba(201,168,106,.8);transform:translate(-50%,-50%);opacity:0}
.benefits .ben-row span{cursor:default;transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease),transform var(--dur) var(--ease)}
.benefits .ben-row span:hover{background:var(--bordo);color:var(--cream);border-color:var(--bordo);transform:translateY(-3px)}

/* --- navbar logo composto: brasão + BELFEROCCI (vetores oficiais, sem Eredità) --- */
.nav-logo{gap:13px}
.nav-logo .nl-crest{height:44px}
.nav.solid .nav-logo .nl-crest{height:38px}
.nav-logo .nl-word{height:20px}
.nav.solid .nav-logo .nl-word{height:17px}
@media (max-width:740px){
  .nav-logo{gap:9px}
  .nav-logo .nl-crest{height:34px}
  .nav-logo .nl-word{height:15px}
}

/* --- reduced-motion safety --- */
@media (prefers-reduced-motion:reduce){
  .rot-img{transition:opacity .2s linear}
  .rot-img.is-on{transform:none}
  .rh-dot{display:none}
}

/* --- responsive dos componentes novos --- */
@media (max-width:1040px){
  .rot-grid{grid-template-columns:1fr;gap:34px;max-width:560px;margin:0 auto}
  .rot-imgs{aspect-ratio:16/10}
  .rot-copy{max-width:none;text-align:center}
  .rot-copy .rot-line,.rot-copy .rot-fixed{text-align:center}
  .rot-copy .rot-mark{margin-left:auto;margin-right:auto}
  .steps-line{display:none}
}
@media (max-width:740px){
  .rotate{padding:64px 0}
  .rhythm{margin:30px 0 4px}
  #saber .marquee-out{margin-top:40px}
}
