/* =========================================================
   FORMAÇÃO PERSONAL CHEF · Escola Fran Tonello
   Editorial · clean · sophisticated · playful
   ========================================================= */

:root{
  --ivory:#f4efe0;
  --paper:#fbf7ea;
  --cream:#e8e2cb;
  --ink:#2b3720;
  --green:#4d6a2f;
  --green-2:#587a37;
  --lime:#9ec24c;
  --lime-2:#8aae3a;
  --coral:#6f9a3c;
  --teal:#8aa84a;
  --rose:#dfe6c3;
  --muted:#74795f;
  --muted-light:rgba(255,255,255,.66);

  --serif:'Fraunces', Georgia, serif;
  --sans:'DM Sans', system-ui, sans-serif;
  --display:'Bebas Neue', 'DM Sans', system-ui, sans-serif;

  --wrap:1180px;
  --r:18px;
  --r-lg:30px;
  --shadow:0 30px 70px -36px rgba(61,29,18,.5);
  --shadow-sm:0 16px 40px -24px rgba(61,29,18,.4);
  --ease:cubic-bezier(.22,1,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip;-webkit-text-size-adjust:100%}
/* Lenis smooth scroll */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}
body{
  font-family:var(--sans);
  background:var(--ivory);
  color:var(--ink);
  line-height:1.6;
  overflow-x:clip;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
ul{list-style:none}

.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 28px}
.wrap-narrow{max-width:780px}

/* prevent any grid/flex child from forcing overflow */
.hero-in>*,.quem-in>*,.fran-in>*,.calc>*,.offer>*{min-width:0}

/* ---------- type ---------- */
.sec-title{
  font-family:var(--serif);
  font-weight:600;
  font-size:clamp(2.2rem,5vw,4rem);
  line-height:1.02;
  letter-spacing:-.02em;
}
.sec-title em{font-style:italic;font-weight:500;color:var(--coral)}
.sec-dark .sec-title em{color:var(--lime)}

/* ---------- buttons ---------- */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--sans);font-weight:700;font-size:1rem;
  padding:14px 26px;border-radius:100px;cursor:pointer;border:0;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), background .3s, color .3s;
  white-space:nowrap;
}
.btn:has(.arr){padding:9px 9px 9px 24px}
.btn-lg{padding:16px 30px;font-size:1.06rem}
.btn-lg:has(.arr){padding:10px 10px 10px 30px}
.btn-block{width:100%;justify-content:space-between}
/* circular arrow with swap-on-hover */
.btn .arr{
  position:relative;flex:none;width:36px;height:36px;border-radius:50%;
  display:inline-grid;place-items:center;overflow:hidden;
}
.btn-lg .arr{width:40px;height:40px}
.btn .arr::before,.btn .arr::after{
  content:'→';position:absolute;inset:0;display:grid;place-items:center;
  font-size:1.1rem;font-style:normal;transition:transform .85s cubic-bezier(.6,.01,.2,1);
}
.btn .arr::after{transform:translateX(-160%)}
.btn:hover .arr::before{transform:translateX(160%)}
.btn:hover .arr::after{transform:translateX(0)}
.btn-lime{background:var(--lime);color:var(--green)}
.btn-lime .arr{background:var(--green);color:#fff}
.btn-lime:hover{transform:translateY(-3px);box-shadow:0 18px 36px -14px rgba(224,153,31,.85)}
.btn-ink{background:var(--green);color:#fff}
.btn-ink .arr{background:var(--lime);color:var(--green)}
.btn-ink:hover{transform:translateY(-3px);box-shadow:0 18px 36px -16px rgba(15,61,43,.7);background:var(--ink)}
/* outline (header) */
.btn-outline{background:transparent;color:var(--ink);border:1.6px solid var(--ink);padding:11px 22px;transition:background .3s,color .3s,transform .3s var(--ease)}
.btn-outline:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px)}
.btn-outline .arr{background:var(--ink);color:var(--paper)}
.btn-outline.btn-lg:has(.arr){padding:10px 10px 10px 30px}
.btn-text{background:transparent;padding:14px 6px;color:var(--ink);border-bottom:2px solid transparent;border-radius:0;font-weight:600}
.btn-text:hover{border-bottom-color:var(--coral)}
.sec-dark .btn-text{color:#fff}

/* ============ HEADER ============ */
.hdr{position:fixed;inset:0 0 auto 0;z-index:100;padding:20px 0;transition:padding .35s var(--ease),background .35s,box-shadow .35s}
.hdr.scrolled{background:rgba(246,241,231,.86);backdrop-filter:blur(14px);padding:12px 0;box-shadow:0 8px 30px -22px rgba(61,29,18,.5)}
.hdr-in{display:flex;align-items:center;gap:24px}
.logo img{height:38px;width:auto}
.nav{display:flex;gap:34px;margin-left:auto}
.nav a{font-weight:500;font-size:1.08rem;color:var(--ink);position:relative;padding:4px 0}
.nav a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--coral);transition:width .3s var(--ease)}
.nav a:hover::after{width:100%}
.hdr-cta{padding:13px 26px;font-size:1.05rem}
.burger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:6px;width:46px;height:46px;background:transparent;border:0;outline:0;cursor:pointer;padding:0;border-radius:50%;-webkit-tap-highlight-color:transparent;transition:background .25s}
.burger:hover{background:rgba(61,29,18,.07)}
.burger span{width:26px;height:3px;background:var(--ink);border-radius:100px;transition:transform .3s var(--ease),opacity .25s}
.mmenu{display:none}

/* ============ HERO (imagem inteira, sem corte) ============ */
.hero{position:relative;overflow:clip;background:var(--ivory)}
.hero-img{display:block;width:100%;height:auto;margin-top:clamp(78px,6.5vw,92px)}
.hero-img--mob{display:none}
.hero-in{position:absolute;left:0;right:0;top:clamp(78px,6.5vw,92px);bottom:0;z-index:2;display:flex;align-items:flex-start;padding-top:clamp(28px,5vh,72px)}
.hero-copy{max-width:560px}
.hero-h1{font-family:var(--serif);font-weight:600;font-size:clamp(2.4rem,4.4vw,3.5rem);line-height:1.04;letter-spacing:-.02em;margin-bottom:24px}
.hero-h1 .line{display:block;white-space:nowrap}
.hero-h1 em{font-style:italic;font-weight:500;color:var(--coral)}
.hero-h1 .amp{color:var(--coral)}
.hero-h1 .hl{position:relative;white-space:nowrap}
.hero-h1 .hl::after{content:'';position:absolute;left:-2%;right:-2%;bottom:.12em;height:.32em;background:var(--lime);z-index:-1;border-radius:4px;transform:rotate(-1deg)}
.hero-lead{font-size:clamp(1.05rem,1.5vw,1.25rem);color:var(--muted);max-width:480px;margin-bottom:32px}
.hero-cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:40px}
.hero-stats{display:flex;gap:34px}
.hero-stats li{display:flex;flex-direction:column}
.hero-stats b{font-family:var(--serif);font-weight:600;font-size:2.1rem;line-height:1;color:var(--green)}
.hero-stats span{font-size:.9rem;color:var(--muted)}
.tilt{transition:transform .5s var(--ease)}
.tilt:hover{transform:rotate(-1.5deg) scale(1.015)}

/* ============ TICKER ============ */
.ticker{background:var(--green);color:var(--lime);padding:16px 0;overflow:hidden;transform:rotate(-1.4deg) scale(1.04);margin:-10px 0 0}
.ticker-row{display:flex;align-items:center;gap:26px;width:max-content;animation:slide 30s linear infinite}
.ticker-row span{font-family:var(--serif);font-style:italic;font-size:1.5rem;font-weight:500;white-space:nowrap}
.ticker-row i{color:#fff;opacity:.5;font-style:normal}
@keyframes slide{to{transform:translateX(-50%)}}

/* ============ SECTION SHELL ============ */
.sec{padding:clamp(70px,10vw,130px) 0;position:relative}
.sec-head{max-width:760px;margin:0 auto clamp(46px,6vw,72px);text-align:center;position:relative}
.sec-num{display:none}
.sec-sub{font-size:clamp(1.05rem,1.4vw,1.2rem);color:var(--muted);margin-top:18px;line-height:1.6}
.sec-sub.left{text-align:left;margin-left:0}
.sec-dark{background:var(--green);color:#fff;border-radius:clamp(30px,4vw,56px) clamp(30px,4vw,56px) 0 0}
/* curved transitions between sections */
.sec-quem{border-radius:clamp(30px,4vw,56px) clamp(30px,4vw,56px) 0 0}
.sec-dark .sec-sub{color:var(--muted-light)}

/* ============ FEATURES ============ */
.feat-list{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:960px;margin:0 auto}
.feat{position:relative;background:var(--paper);border:1px solid rgba(61,29,18,.08);border-radius:var(--r-lg);padding:34px;overflow:hidden;transition:transform .45s var(--ease),box-shadow .45s,background .4s,border-color .3s}
.feat:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--lime)}
.feat-ico{position:relative;display:inline-grid;place-items:center;width:58px;height:58px;margin-bottom:22px;color:var(--coral)}
.feat-ico::before{content:'';position:absolute;inset:0;border-radius:46% 54% 56% 44%/54% 46% 54% 46%;background:currentColor;opacity:.15;transition:transform .5s var(--ease),opacity .4s}
.feat-ico svg{position:relative;z-index:1;width:34px;height:34px;stroke:currentColor}
.feat:hover .feat-ico::before{opacity:.24;transform:rotate(12deg) scale(1.12)}
.feat:nth-child(2) .feat-ico,.feat:nth-child(5) .feat-ico{color:var(--teal)}
.feat:nth-child(3) .feat-ico,.feat:nth-child(6) .feat-ico{color:var(--green)}
.feat h3{font-family:var(--serif);font-weight:600;font-size:1.45rem;margin-bottom:10px;letter-spacing:-.01em}
.feat p{color:var(--muted);font-size:1rem;line-height:1.55}
.feat-list-3{grid-template-columns:repeat(3,1fr);max-width:1080px}
.feat-list-3 .feat{padding:30px 28px}
.feat-list-3 h3{font-size:1.28rem}

/* "pra quem é" — two groups */
.quem-group{margin-bottom:24px}
.quem-label{display:block;font-family:var(--serif);font-style:italic;font-size:1.2rem;color:var(--coral);margin-bottom:12px}
.quem-group .ticks{margin:0;gap:11px}

/* prova social — profession chips */
.prof-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:11px;max-width:780px;margin:34px auto 0}
.prof-chips li{background:var(--paper);border:1px solid rgba(61,29,18,.1);color:var(--green);font-weight:600;font-size:.92rem;padding:9px 18px;border-radius:100px;transition:transform .3s var(--ease),background .3s,color .3s}
.prof-chips li:hover{background:var(--green);color:#fff;transform:translateY(-3px)}

/* ============ PRA QUEM / split sections ============ */
.sec-quem{background:var(--paper)}
.quem-in,.fran-in{display:grid;gap:60px;align-items:center}
.quem-in{grid-template-columns:.92fr 1.08fr}
.fran-in{grid-template-columns:.92fr 1.08fr}
.quem-art,.fran-art{position:relative}
.frame{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow);position:relative}
.frame img{width:100%;height:100%;object-fit:cover}
.sticker{position:absolute;top:-16px;right:-10px;background:var(--lime);color:var(--green);font-weight:700;font-size:.95rem;padding:11px 18px;border-radius:100px;transform:rotate(6deg);box-shadow:var(--shadow-sm);z-index:3}
.ig-badge{position:absolute;bottom:-22px;left:16px;display:flex;align-items:center;gap:11px;background:#fff;padding:8px 18px 8px 8px;border-radius:100px;box-shadow:var(--shadow-sm);z-index:4;transition:transform .35s var(--ease),box-shadow .35s}
.ig-badge:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.ig-av{width:46px;height:46px;border-radius:50%;object-fit:cover;flex:none;border:2px solid var(--lime)}
.ig-meta{display:flex;flex-direction:column;line-height:1.2}
.ig-handle{display:flex;align-items:center;gap:5px;font-weight:700;font-size:.98rem;color:var(--ink)}
.ig-verified{width:15px;height:15px;flex:none}
.ig-prof{font-size:.78rem;color:var(--muted)}

.ticks{display:grid;gap:14px;margin:28px 0 34px}
.ticks li{position:relative;padding-left:40px;font-size:1.08rem}
.ticks li::before{content:'';position:absolute;left:0;top:3px;width:26px;height:26px;border-radius:50%;background:var(--lime);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230f3d2b' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");background-size:15px;background-repeat:no-repeat;background-position:center}
.ticks b{font-weight:700}

/* ============ 02 MODULES (cover carousel) ============ */
.mod-carousel{overflow:hidden;width:100vw;margin-left:calc(50% - 50vw)}
.mod-track{display:flex;width:max-content;animation:slide 70s linear infinite}
.mod-carousel:hover .mod-track{animation-play-state:paused}
.cover{position:relative;flex:none;width:300px;height:392px;margin-right:18px;border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:28px;text-align:left;transition:transform .45s var(--ease),box-shadow .45s}
.cover:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.cover-n{font-family:var(--serif);font-style:italic;font-size:2.4rem;line-height:1}
.cover-tx h3{font-family:var(--serif);font-weight:600;font-size:1.6rem;line-height:1.05;letter-spacing:-.01em;margin-bottom:10px;text-wrap:balance}
.cover-tx p{font-size:.95rem;line-height:1.45;opacity:.82;text-wrap:pretty}
.cover::before{content:'';position:absolute;left:0;bottom:0;width:100%;height:5px;transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.cover:hover::before{transform:scaleX(1)}
/* color themes */
.cover-c1{background:var(--green);color:#fff}
.cover-c1 .cover-n{color:var(--lime)} .cover-c1::before{background:var(--lime)}
.cover-c2{background:var(--lime);color:var(--green)}
.cover-c2 .cover-n{color:var(--green)} .cover-c2::before{background:var(--green)}
.cover-c3{background:var(--teal);color:#7a2e15}
.cover-c3 .cover-n{color:#7a2e15} .cover-c3::before{background:#7a2e15}
.cover-c4{background:var(--coral);color:#fff}
.cover-c4 .cover-n{color:#fff} .cover-c4::before{background:#fff}
.cover-c5{background:var(--cream);color:var(--green)}
.cover-c5 .cover-n{color:var(--coral)} .cover-c5::before{background:var(--coral)}

/* ============ GALLERY (bento) ============ */
.gallery{padding:clamp(20px,4vw,48px) 0}
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:16px;max-width:1100px;margin:0 auto}
.bento-item{position:relative;overflow:hidden;border-radius:var(--r);background:var(--cream)}
.bento-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.bento-item:hover img{transform:scale(1.07)}
.bento-item::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(61,29,18,.18));opacity:0;transition:opacity .4s}
.bento-item:hover::after{opacity:1}
.b-2x2{grid-column:span 2;grid-row:span 2}
.b-1x2{grid-row:span 2}
.b-2x1{grid-column:span 2}
@media(max-width:900px){
  .bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .b-1x2{grid-row:span 1}
  .bento-item:last-child{grid-column:span 2}
}
@media(max-width:520px){
  .bento{grid-auto-rows:148px;gap:12px}
}

/* ============ STEPS (connected flow) ============ */
.flow{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:44px;max-width:1000px;margin:0 auto;padding-top:8px}
/* static connecting track behind the numbered nodes */
.flow-track{position:absolute;top:46px;left:16.6%;right:16.6%;height:3px;border-radius:100px;background:linear-gradient(90deg,var(--lime),var(--teal));z-index:0}
.flow-step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center}
.flow-node{position:relative;width:76px;height:76px;border-radius:50%;background:var(--lime);color:var(--green);display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:2rem;border:7px solid var(--green);box-shadow:0 0 0 1px rgba(255,255,255,.12)}
.flow-label{margin-top:22px;font-size:.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--lime)}
.flow-step h3{font-family:var(--serif);font-weight:600;font-size:1.4rem;margin:6px 0 8px;color:#fff}
.flow-step p{color:var(--muted-light);font-size:.97rem;max-width:280px;line-height:1.55}

/* ============ CALCULATOR (inputs em cima, resultado embaixo) ============ */
.br-d{display:inline}
.br-m{display:none}
.calc-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(36px,5vw,60px);align-items:center;max-width:1180px;margin:0 auto}
.calc-head{text-align:left;max-width:none;margin:0}
.calc-grid .calc{max-width:none;margin:0}
.calc{background:var(--paper);border:1px solid rgba(61,29,18,.08);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);max-width:1000px;margin:0 auto}
.calc-inputs{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);padding:clamp(30px,4vw,46px)}
.cf-head{display:flex;flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:16px}
.cf label{font-weight:600;font-size:1rem;line-height:1.3;max-width:18ch}
.cf-pill{flex:none;font-family:var(--serif);font-weight:600;font-size:1.3rem;color:var(--green);background:var(--lime);padding:5px 15px;border-radius:100px;line-height:1;white-space:nowrap}
.cf-scale{display:flex;justify-content:space-between;font-size:.82rem;color:var(--muted);margin-top:10px}
/* result band */
.calc-result{position:relative;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:space-between;gap:32px;padding:clamp(28px,3.5vw,40px) clamp(30px,4vw,46px);overflow:hidden}
.calc-result::before{content:'';position:absolute;top:-50%;right:-10%;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(240,169,43,.2),transparent 68%);pointer-events:none}
.calc-result-l{position:relative}
.calc-kicker{display:block;font-size:.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--teal);margin-bottom:6px}
.calc-line{display:flex;align-items:center;gap:16px}
.calc-big{font-family:var(--serif);font-weight:600;font-size:clamp(4rem,8vw,5.6rem);line-height:.8;color:var(--lime)}
.calc-big.pop{animation:numPop .4s var(--ease)}
@keyframes numPop{0%{transform:scale(.7);opacity:.4}60%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}
.calc-line-tx{font-size:1.05rem;line-height:1.25}
.calc-line-tx b{color:var(--lime)}
.calc-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px;max-width:260px}
.calc-chips span{width:12px;height:12px;border-radius:50%;background:var(--lime);animation:chipPop .35s var(--ease) both}
@keyframes chipPop{from{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}
.calc-result-r{position:relative;flex:none;width:280px;text-align:center}
.calc-note{font-size:.9rem;color:var(--muted-light);margin-bottom:16px}

input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:100px;background:rgba(61,29,18,.12);outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:26px;height:26px;border-radius:50%;background:var(--lime);cursor:pointer;border:5px solid var(--green);transition:transform .15s}
input[type=range]::-webkit-slider-thumb:active{transform:scale(1.18)}
input[type=range]::-moz-range-thumb{width:26px;height:26px;border-radius:50%;background:var(--lime);cursor:pointer;border:5px solid var(--green)}

/* ============ COMMUNITY (halo layout) ============ */
.tag-pill{display:inline-block;background:var(--rose);color:var(--coral);font-weight:700;letter-spacing:.04em;font-size:.82rem;padding:7px 16px;border-radius:100px;margin-bottom:14px}
#comunidade .sec-head{max-width:none}
#comunidade .sec-title{white-space:nowrap;font-size:clamp(2rem,5vw,3.4rem)}
.comu-halo{display:grid;grid-template-columns:1fr auto 1fr;gap:28px;align-items:center;max-width:1080px;margin:0 auto}
.comu-side{display:flex;flex-direction:column;gap:24px}
.cbox{position:relative;background:var(--paper);border:1px solid rgba(61,29,18,.08);border-radius:var(--r);padding:26px 24px;transition:transform .4s var(--ease),box-shadow .4s,border-color .3s}
.cbox:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm);border-color:var(--lime)}
.comu-side-l .cbox{text-align:right}
.comu-side-l .cbox .ck{margin-left:auto}
.cbox .ck{display:block;width:30px;height:30px;border-radius:50%;background:var(--lime);margin-bottom:14px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230f3d2b' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");background-size:17px;background-repeat:no-repeat;background-position:center}
.cbox h3{font-family:var(--serif);font-weight:600;font-size:1.16rem;line-height:1.14;margin-bottom:7px;letter-spacing:-.01em;text-wrap:balance}
.cbox p{color:var(--muted);font-size:.92rem;line-height:1.5;text-wrap:pretty}
.comu-cta{display:flex;justify-content:center;margin-top:52px}
/* iPhone frame */
.phone{position:relative;width:340px;max-width:100%;margin:0 auto;background:#2a130b;border-radius:54px;padding:13px;box-shadow:var(--shadow),inset 0 0 0 2px rgba(255,255,255,.06)}
.phone::before{content:'';position:absolute;inset:5px;border-radius:48px;border:1px solid rgba(255,255,255,.08);pointer-events:none;z-index:6}
.phone-notch{position:absolute;top:13px;left:50%;transform:translateX(-50%);width:120px;height:24px;background:#2a130b;border-radius:0 0 16px 16px;z-index:5}
.chat{position:relative;background:var(--ivory);border:0;border-radius:42px;padding:30px 12px 12px;box-shadow:none;width:100%;max-width:none;margin:0;overflow:hidden}
.chat-top{background:var(--green);color:#fff;border-radius:18px 18px 7px 7px;padding:15px 17px;display:flex;align-items:center;gap:11px}
.chat-av{width:42px;height:42px;border-radius:50%;background:var(--lime);display:grid;place-items:center;font-size:1.4rem}
.chat-top b{display:block;font-size:.98rem}
.chat-top i{font-style:normal;font-size:.77rem;color:rgba(255,255,255,.7)}
.chat-bd{padding:16px 12px;display:flex;flex-direction:column;gap:11px}
.chat-day{align-self:center;background:rgba(61,29,18,.07);color:var(--muted);font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 14px;border-radius:100px}
.b{max-width:88%;padding:11px 15px;border-radius:16px;font-size:.92rem;line-height:1.45;box-shadow:0 4px 12px -8px rgba(61,29,18,.3)}
.b i{display:block;font-style:normal;font-weight:700;color:var(--coral);font-size:.8rem;margin-bottom:2px}
.b.in{background:#fff;border-top-left-radius:4px}
.b.out{background:var(--lime);color:var(--green);align-self:flex-end;border-top-right-radius:4px;font-weight:500}
/* message reveal + typing indicator */
.b.show{animation:bubblePop .4s var(--ease) both}
@keyframes bubblePop{from{opacity:0;transform:translateY(10px) scale(.96)}to{opacity:1;transform:none}}
.b.typing{display:inline-flex;align-items:center;gap:5px;width:fit-content;padding:14px 16px;animation:bubblePop .3s var(--ease) both}
.b.typing span{width:8px;height:8px;border-radius:50%;background:var(--muted);animation:typingDot 1.3s infinite ease-in-out}
.b.typing span:nth-child(2){animation-delay:.18s}
.b.typing span:nth-child(3){animation-delay:.36s}
.b.typing.out span{background:var(--green)}
@keyframes typingDot{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}
.chat-in{background:#fff;border-radius:100px;padding:13px 20px;margin:6px;display:flex;justify-content:space-between;color:#b09a86}
.chat-in i{color:var(--green);font-style:normal}

/* ============ TESTIMONIALS ============ */
.testis{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.testi{background:var(--paper);border:1px solid rgba(61,29,18,.07);border-radius:var(--r-lg);padding:34px 30px 28px;position:relative;transition:transform .35s var(--ease),box-shadow .3s}
.testi:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.qt{font-family:var(--serif);font-size:4.5rem;line-height:.4;color:var(--lime);height:.5em;margin-bottom:6px}
.testi blockquote{font-size:1.02rem;color:var(--ink);margin-bottom:24px;font-style:italic;font-family:var(--serif);font-weight:400;line-height:1.45}
.testi figcaption{display:flex;align-items:center;gap:12px}
.testi figcaption img{width:48px;height:48px;border-radius:50%;object-fit:cover}
.testi figcaption span{font-size:.85rem;color:var(--muted)}
.testi figcaption b{display:block;color:var(--ink);font-size:.98rem}
.turmas{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:34px}
.turmas img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:20px}

/* ============ FRAN ============ */
.creds{display:grid;gap:10px;margin-top:24px}
.creds li{position:relative;padding-left:28px;color:var(--muted);font-size:.98rem}
.creds li::before{content:'🥑';position:absolute;left:0;font-size:.85rem}

/* ============ OFFER (card único: checklist dentro, antes do preço) ============ */
.tag-pill-lime{background:rgba(240,169,43,.16);color:var(--lime)}
.offer{display:flex;justify-content:center}
.offer-card{width:100%;max-width:560px;background:var(--lime);color:var(--green);border-radius:var(--r-lg);padding:clamp(34px,4vw,48px);text-align:center;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center}
.offer-card-tag{display:inline-block;font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:.74rem;background:rgba(15,61,43,.14);padding:8px 18px;border-radius:100px;margin-bottom:22px}
.incl{display:grid;gap:10px;text-align:left;width:100%;max-width:360px;margin:0 auto 22px;padding-bottom:22px;border-bottom:1px solid rgba(15,61,43,.16)}
.incl li{position:relative;padding-left:30px;font-size:.92rem;color:var(--green);line-height:1.35}
.incl li b{font-weight:700}
.incl li::before{content:'';position:absolute;left:0;top:0;width:22px;height:22px;border-radius:50%;background:var(--green);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d3e24f' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");background-size:13px;background-repeat:no-repeat;background-position:center}
.offer-price{display:flex;flex-direction:column;align-items:center;line-height:.85}
.offer-price .x{font-family:var(--serif);font-style:italic;font-size:1.5rem;opacity:.85;margin-bottom:6px}
.offer-price .v{font-family:var(--serif);font-weight:600;font-size:clamp(4.2rem,9vw,6rem);line-height:.82;letter-spacing:-.02em}
.offer-price .v small{font-size:.36em;font-weight:600;vertical-align:super}
.offer-cash{margin:12px 0 24px;font-size:.98rem}
.offer-cash b{font-weight:700}
.offer-card .btn-block{justify-content:space-between}
.offer-trust{margin-top:18px;font-size:.84rem;opacity:.72;line-height:1.5}

/* ============ FAQ ============ */
.faq{display:grid;gap:12px}
.faq details{background:var(--paper);border:1px solid rgba(61,29,18,.08);border-radius:16px;padding:2px 24px;transition:border-color .25s}
.faq details[open]{border-color:var(--lime)}
.faq summary{list-style:none;cursor:pointer;font-weight:600;font-size:1.06rem;padding:18px 0;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-family:var(--serif);font-size:1.7rem;color:var(--coral);transition:transform .3s var(--ease);flex:none;line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{padding:0 0 20px;color:var(--muted)}

/* ============ FINAL CTA ============ */
.final{background:var(--lime);padding:clamp(70px,10vw,120px) 0;text-align:center;position:relative;overflow:hidden;border-radius:clamp(30px,4vw,56px) clamp(30px,4vw,56px) 0 0}
.final-in{position:relative;z-index:2}
.final-h{font-family:var(--serif);font-weight:600;font-size:clamp(2.4rem,6vw,4.6rem);line-height:1;letter-spacing:-.02em;color:var(--green)}
.final-h em{font-style:italic;font-weight:500;color:#fff}
.final p{color:var(--green);font-size:1.15rem;margin:18px 0 32px;opacity:.85}
.final-stamp{position:absolute;font-size:13rem;opacity:.12;right:4%;top:50%;transform:translateY(-50%) rotate(12deg);z-index:1}

/* ============ FOOTER ============ */
.ft{background:var(--green);color:#fff;padding:64px 0 0}
.ft-in{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;padding-bottom:46px}
.ft-brand img{height:38px;margin-bottom:16px}
.ft-brand p{color:var(--muted-light);max-width:320px;font-size:.95rem}
.ft-links,.ft-social{display:flex;flex-direction:column;gap:12px}
.ft-links a,.ft-social a{color:rgba(255,255,255,.82);font-size:.95rem;transition:color .2s}
.ft-links a:hover,.ft-social a:hover{color:var(--lime)}
.ft-social span{color:rgba(255,255,255,.5);font-size:.8rem;text-transform:uppercase;letter-spacing:.12em}
.ft-btm{border-top:1px solid rgba(255,255,255,.12);padding:22px 0;font-size:.85rem;color:rgba(255,255,255,.5);text-align:center}

/* ============ MISE EN PLACE / DIFERENCIAIS ============ */
.mp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:56px}
.mp-card{
  background:var(--paper);border:1px solid rgba(61,29,18,.09);border-radius:var(--r-lg);
  padding:32px 26px 36px;display:flex;flex-direction:column;position:relative;overflow:hidden;
  transition:transform .45s var(--ease),box-shadow .35s,border-color .3s
}
.mp-card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--coral);transform:scaleX(0);transform-origin:left;
  transition:transform .5s var(--ease)
}
.mp-card:hover::after{transform:scaleX(1)}
.mp-card:hover{transform:translateY(-5px);box-shadow:0 24px 52px -16px rgba(61,29,18,.16);border-color:rgba(61,29,18,.14)}
.mp-ico{
  width:48px;height:48px;background:var(--cream);border-radius:12px;
  display:grid;place-items:center;color:var(--green);margin-bottom:20px;flex:none;
  transition:background .35s,color .35s
}
.mp-card:hover .mp-ico{background:var(--coral);color:#fff}
.mp-card h3{font-family:var(--serif);font-weight:600;font-size:clamp(1.05rem,1.15vw,1.18rem);line-height:1.22;color:var(--ink);margin-bottom:10px}
.mp-card p{font-size:.88rem;line-height:1.72;color:var(--muted)}

/* ============ CREDIBILIDADE ============ */
.tag-pill-green{background:rgba(61,29,18,.08);color:var(--green)}
.cred-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin:48px 0 40px}
.cred-stat{background:var(--paper);border:1px solid rgba(61,29,18,.08);border-radius:var(--r);padding:28px 24px;text-align:center}
.cred-stat b{display:block;font-family:var(--serif);font-weight:600;font-size:clamp(1.5rem,3vw,2rem);color:var(--green);margin-bottom:6px}
.cred-stat span{font-size:.92rem;color:var(--muted);line-height:1.4}
.cred-body{max-width:780px;margin:0 auto;display:grid;gap:16px}
.cred-body p{font-size:1.06rem;color:var(--muted);line-height:1.65;text-align:center}

/* ============ FINE PRINT ============ */
.fine-print{text-align:center;font-size:.84rem;color:var(--muted);margin-top:28px;opacity:.75}
.fine-print.light{color:var(--muted-light)}

/* ============ FEAT DARK (mentorias) ============ */
.feat-dark{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1)}
.feat-dark h3{color:#fff}
.feat-dark p{color:var(--muted-light)}
.feat-dark .feat-ico{background:rgba(240,169,43,.15);color:var(--lime)}

/* ============ BÔNUS ============ */
.sec-bonus{background:var(--green);color:#fff}
.sec-bonus .sec-title{color:#fff}
.sec-bonus .sec-sub{color:var(--muted-light)}
.sec-bonus .tag-pill-lime{background:rgba(240,169,43,.18);color:var(--lime)}
.bonus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:44px 0 32px}
.bonus-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:32px 28px;display:flex;flex-direction:column;gap:12px;transition:transform .4s var(--ease),border-color .3s}
.bonus-card:hover{transform:translateY(-6px);border-color:var(--lime)}
.bonus-num{font-size:.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--lime)}
.bonus-card h3{font-family:var(--serif);font-weight:600;font-size:1.3rem;color:#fff;line-height:1.15}
.bonus-card p{font-size:.95rem;color:var(--muted-light);line-height:1.6;flex:1}
.bonus-val{font-size:.9rem;color:rgba(255,255,255,.55)}
.bonus-val b{color:var(--lime);font-weight:700}
.bonus-total{display:flex;align-items:center;justify-content:space-between;gap:32px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:36px 44px}
.bonus-total-l{display:flex;flex-direction:column;gap:6px}
.bonus-total-l>span{font-size:.85rem;color:var(--muted-light);text-transform:uppercase;letter-spacing:.1em}
.bonus-total-l>b{font-family:var(--serif);font-weight:600;font-size:clamp(2.4rem,5vw,3.6rem);color:var(--lime);line-height:.9}
.bonus-free{font-size:.9rem;color:var(--muted-light);max-width:360px;line-height:1.5}
.bonus-countdown{text-align:center}
.cd-label{display:block;font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-light);margin-bottom:12px}
.cd-digs{display:flex;align-items:center;gap:8px}
.cd-unit{display:flex;flex-direction:column;align-items:center;gap:4px}
.cd-unit b{font-family:var(--serif);font-weight:600;font-size:clamp(2rem,4vw,3rem);color:var(--lime);line-height:1;min-width:2.2ch;text-align:center}
.cd-unit span{font-size:.72rem;color:var(--muted-light);letter-spacing:.08em;text-transform:uppercase}
.cd-sep{font-family:var(--serif);font-size:2rem;color:var(--lime);line-height:1;opacity:.6;margin-top:-10px}

/* ============ UTILITIES ============ */
.center{text-align:center}
.hdr-cta.btn-lime{padding:10px 22px;font-size:.95rem}

/* ============ REVEAL ============ */
.reveal-up{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal-up.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal-up{opacity:1;transform:none}
  .ill-3 .bar{transform:scaleY(1)!important}
  .ill3-line{stroke-dashoffset:0!important}
  .ill3-dot{transform:scale(1)!important}
}

/* ============ RESPONSIVE ============ */
@media(max-width:1000px){
  .hero{display:block;min-height:0;padding:104px 0 116.05vw;background:var(--ivory) url(assets/img/Hero-mobile.png?v=4) no-repeat bottom center;background-size:100vw auto}
  .calc-grid{grid-template-columns:1fr;gap:30px}
  .hero-h1 .line{white-space:normal}
  .hero-copy{max-width:none}
  .hero-in{position:static;display:block;padding-top:0}
  .hero-img--desk{display:none}
  .hero-img--mob{display:none}
  .cover{width:248px;height:340px}
  .quem-in,.fran-in{grid-template-columns:1fr;gap:42px}
  .quem-art,.fran-art{max-width:420px;margin:0 auto}
  .comu-halo{grid-template-columns:1fr;gap:22px;max-width:460px}
  .comu-halo .chat{order:-1;margin:0 auto;width:100%}
  .comu-side-l .cbox{text-align:left}
  .comu-side-l .cbox .ck{margin-left:0}
  .testis{grid-template-columns:1fr;gap:16px}
  /* steps become a vertical timeline */
  .flow{grid-template-columns:1fr;gap:0;max-width:440px}
  .flow-track{display:none}
  .flow-step{display:grid;grid-template-columns:auto 1fr;column-gap:20px;align-items:start;text-align:left;padding-bottom:36px}
  .flow-step:last-child{padding-bottom:0}
  .flow-step::before{content:'';position:absolute;left:38px;top:80px;bottom:-2px;width:3px;background:rgba(255,255,255,.16);z-index:0}
  .flow-step:last-child::before{display:none}
  .flow-node{grid-column:1;grid-row:1 / span 4;flex:none}
  .flow-ill{grid-column:2;order:-1;margin-top:0;max-width:180px}
  .flow-label{grid-column:2;margin-top:10px}
  .flow-step h3{grid-column:2;margin-top:2px}
  .flow-step p{grid-column:2;max-width:none}
  .feat-list{grid-template-columns:1fr;gap:14px}
  .feat-list-3{grid-template-columns:1fr 1fr;gap:16px}
  .cred-stats{grid-template-columns:1fr 1fr;gap:16px;margin:32px 0 28px}
  .bonus-grid{grid-template-columns:1fr;gap:16px}
  .bonus-total{flex-direction:column;text-align:center;padding:28px 24px;gap:28px}
  .bonus-free{max-width:none}
  .calc-result{flex-direction:column;text-align:center;gap:20px}
  .calc-result-l{display:flex;flex-direction:column;align-items:center}
  .calc-line{justify-content:center}
  .calc-chips{justify-content:center}
  .calc-result-r{width:100%;max-width:360px}
  .mp-grid{grid-template-columns:repeat(2,1fr);gap:14px}
}
@media(max-width:760px){
  .nav,.hdr-cta{display:none}
  .burger{display:flex;margin-left:auto}
  .hdr-in{justify-content:space-between;gap:12px}
  .hdr{background:rgba(246,241,231,.9);backdrop-filter:blur(12px);padding:12px 0}
  .mmenu{display:none;flex-direction:column;gap:4px;padding:14px 28px 24px;background:var(--ivory);border-top:1px solid rgba(61,29,18,.08)}
  .mmenu.open{display:flex}
  .mmenu a{padding:13px 0;font-weight:600;border-bottom:1px solid rgba(61,29,18,.08)}
  .mmenu .btn{margin-top:12px;justify-content:center}
  .burger.open span:nth-child(1){transform:translateY(9px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}
  .hero{padding-top:88px}
  .hero-copy{text-align:center}
  .hero-h1{font-size:clamp(2.1rem,9.8vw,3rem);letter-spacing:-.02em;line-height:1.06;margin-bottom:20px}
  .hero-h1 .line{white-space:nowrap}
  .hero-lead{font-size:16px;line-height:1.5;margin:0 auto 26px;max-width:420px}
  .br-d{display:none}
  .br-m{display:inline}
  .sec-title{font-size:clamp(1.55rem,6.6vw,2.1rem)}
  .calc-inputs{grid-template-columns:1fr;gap:26px}
  #comunidade .sec-title{white-space:normal;font-size:clamp(2rem,7vw,2.6rem)}
  /* modules: static, swipeable carousel */
  .mod-carousel{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity;scrollbar-width:none}
  .mod-carousel::-webkit-scrollbar{display:none}
  .mod-track{animation:none;width:max-content;padding:0 20px}
  .mod-track > [aria-hidden="true"]{display:none}
  .cover{scroll-snap-align:start}
  /* calc result: stacked + centered number */
  .calc-line{flex-direction:column;gap:0}
  .calc-big{font-size:clamp(4.6rem,23vw,6rem);line-height:.95;margin-bottom:6px}
  .calc-line-tx{text-align:center;font-size:1.05rem;line-height:1.3}
  .calc-chips{justify-content:center;max-width:none;margin-top:18px}
  /* calc CTA: content-width, arrow close to text */
  .calc-result-r .btn{width:auto;justify-content:center;gap:14px;padding:9px 9px 9px 22px}
  .hero-cta{flex-direction:column;align-items:center;gap:14px;margin-bottom:26px;width:100%}
  .hero-cta .btn-lime{width:auto;justify-content:center;gap:14px;font-size:1rem;padding:10px 10px 10px 26px}
  .hero-cta .btn-lime .arr{width:40px;height:40px}
  .hero-cta .btn-secondary{width:auto;padding:12px 28px;font-size:.95rem;border-color:rgba(61,29,18,.28);color:var(--green);font-weight:600;justify-content:center}
  .hero-stats{gap:28px;justify-content:center}
  .hero-stats b{font-size:1.5rem}
  .hero-stats span{font-size:.82rem}
  .cred-stats{grid-template-columns:1fr 1fr}
  .bonus-grid{grid-template-columns:1fr}
  .bonus-total{flex-direction:column;text-align:center;padding:24px 20px;gap:24px}
  .sec-bonus .center .btn-lime{width:100%;justify-content:space-between;gap:14px;padding:10px 10px 10px 24px;box-sizing:border-box;overflow:hidden}
  .sec-bonus .center .btn-lime span{min-width:0;flex-shrink:1;white-space:normal;line-height:1.3}
  .ft-in{grid-template-columns:1fr;gap:28px}
  .turmas{grid-template-columns:1fr 1fr}
  .ticker{transform:rotate(-1.4deg) scale(1.08)}
  .ticker-row span{font-size:1.25rem}
  .mp-grid{grid-template-columns:1fr;gap:12px;margin-top:40px}
  .mp-card{padding:26px 22px 30px}
}
@media(max-width:440px){
  :root{--r-lg:24px}
  .wrap{padding:0 20px}
  .feat-list-3{grid-template-columns:1fr}
  .cover{width:220px;height:300px;padding:22px}
  .cover h3{font-size:1.3rem}
  .turmas{grid-template-columns:1fr 1fr}
  .hero-stats b{font-size:1.45rem}
  .stamp{width:96px;height:96px}
  .sticker{font-size:.85rem;top:-12px}
}

/* =========================================================
   ADIÇÕES · Humanização + posicionamento de carreira
   (manifesto · dores · bastidores · depoimentos reais)
   ========================================================= */

/* ----- pill variants (sem rosa: paleta do briefing) ----- */
.tag-pill{background:rgba(201,138,58,.18);color:#a85a1f}      /* default → teal */
.tag-pill-coral{background:rgba(217,107,74,.16);color:var(--coral)}
.tag-pill-teal{background:rgba(201,138,58,.2);color:#a85a1f}

/* ----- MANIFESTO / POSICIONAMENTO ----- */
.manifesto{background:var(--ivory);padding:clamp(62px,9vw,116px) 0;overflow:hidden}
.manifesto-in{display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(36px,6vw,86px);align-items:center}
.manifesto-copy{max-width:620px}
.manifesto-kicker{display:inline-block;font-family:var(--display);font-size:1.02rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin-bottom:20px}
.manifesto-h{font-family:var(--serif);font-weight:600;font-size:clamp(1.9rem,4.2vw,3.15rem);line-height:1.12;letter-spacing:-.02em;color:var(--green);text-wrap:balance}
.manifesto-h em{font-style:italic;font-weight:500;color:var(--coral)}
.manifesto-h .mk{background:linear-gradient(transparent 60%, var(--lime) 60%, var(--lime) 92%, transparent 92%);padding:0 .08em;border-radius:2px;white-space:nowrap}
.manifesto-sub{font-size:clamp(1.05rem,1.5vw,1.24rem);color:var(--muted);margin:26px 0 0;max-width:560px;line-height:1.62}
.manifesto-sub b{color:var(--ink);font-weight:600}

/* device do manual: prato recortado (círculo) sobre bloco de cor c/ split diagonal */
.manifesto-art{position:relative;display:flex;justify-content:center}
.plate-block{position:relative;width:min(430px,90%);aspect-ratio:1;margin-inline:auto}
.plate-block::before{content:"";position:absolute;inset:5% -7% -7% 5%;border-radius:36px;transform:rotate(-3.5deg);
  background:linear-gradient(116deg,var(--green) 0 55%, #cf8a4a 55% 100%);
  box-shadow:0 36px 70px -38px rgba(61,29,18,.55)}
.plate-block::after{content:"";position:absolute;inset:5% -7% -7% 5%;border-radius:36px;transform:rotate(-3.5deg);
  background:linear-gradient(116deg,transparent 0 54%, var(--lime) 54% 55.4%, transparent 55.4% 100%)}
.plate{position:absolute;inset:7%;margin:0;border-radius:50%;overflow:hidden;z-index:1;
  border:7px solid var(--ivory);box-shadow:0 30px 60px -26px rgba(61,29,18,.5)}
.plate img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1s var(--ease)}
.plate-block:hover .plate img{transform:scale(1.05)}
.plate-tag{position:absolute;right:-3%;bottom:8%;z-index:2;font-family:var(--display);letter-spacing:.1em;text-transform:uppercase;
  font-size:.86rem;color:var(--green);background:var(--lime);padding:8px 16px 6px;border-radius:100px;
  box-shadow:0 14px 30px -16px rgba(61,29,18,.45)}

/* ----- AS DORES / PROBLEMA ----- */
.pains{background:var(--green);color:#fff;border-radius:clamp(30px,4vw,56px) clamp(30px,4vw,56px) 0 0}
.pains .sec-title{color:#fff}
.pains .sec-title em{color:var(--lime)}
.pains .sec-sub{color:var(--muted-light)}
.pain-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:900px;margin:0 auto}
.pain{position:relative;display:flex;gap:14px;align-items:flex-start;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-lg);padding:28px 30px;transition:transform .4s var(--ease),border-color .3s,background .3s}
.pain:hover{transform:translateY(-5px);border-color:var(--coral);background:rgba(255,255,255,.09)}
.pain-q{font-family:var(--serif);font-style:italic;font-size:2.8rem;line-height:.62;color:var(--coral);flex:none}
.pain p{font-size:1.12rem;line-height:1.45;color:#fff}
.pain p b{color:var(--lime);font-weight:600}
.pain-turn{max-width:900px;margin:30px auto 0;background:var(--lime);color:var(--green);border-radius:var(--r-lg);padding:clamp(28px,4vw,42px);display:flex;align-items:center;justify-content:space-between;gap:30px;text-align:left}
.pain-turn p{font-family:var(--serif);font-weight:500;font-size:clamp(1.18rem,2vw,1.55rem);line-height:1.28;letter-spacing:-.01em}
.pain-turn p b{font-weight:700}
.pain-turn .btn{flex:none}
.pain-turn .btn-lime{background:var(--green);color:#fff}
.pain-turn .btn-lime .arr{background:var(--lime);color:var(--green)}
.pain-turn .btn-lime:hover{background:var(--ink);box-shadow:0 18px 36px -16px rgba(15,61,43,.55)}

/* ----- BENTO captions (a profissão por dentro) ----- */
.bento-item{position:relative}
.bento-cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:30px 18px 15px;color:#fff;font-weight:600;font-size:.93rem;letter-spacing:-.01em;line-height:1.2;background:linear-gradient(180deg,transparent,rgba(61,29,18,.82));text-shadow:0 1px 10px rgba(0,0,0,.35);transform:translateY(6px);opacity:.96;transition:transform .45s var(--ease),opacity .45s}
.bento-item:hover .bento-cap{transform:none;opacity:1}

/* ----- DEPOIMENTOS REAIS ----- */
.testis{margin-bottom:6px}
.testi figcaption img{object-position:50% 26%}
.testi-foot{text-align:center;color:var(--muted);font-size:1.02rem;margin:46px auto 0;max-width:580px;line-height:1.5}

@media(max-width:1000px){
  .testis{grid-template-columns:1fr;gap:16px}
}
@media(max-width:860px){
  .manifesto-in{grid-template-columns:1fr;gap:clamp(34px,7vw,48px)}
  .manifesto-copy{max-width:none;text-align:center;margin-inline:auto}
  .manifesto-sub{margin-inline:auto}
  .manifesto-art{order:1;max-width:380px;margin-inline:auto;width:100%}
}
@media(max-width:760px){
  .manifesto-h{font-size:clamp(1.65rem,7.4vw,2.2rem)}
  .pain-grid{grid-template-columns:1fr;gap:14px}
  .pain{padding:24px 24px}
  .pain p{font-size:1.05rem}
  .pain-turn{flex-direction:column;text-align:center;align-items:center;gap:22px}
  .pain-turn .btn-lime{width:100%;justify-content:space-between;gap:14px;padding:10px 10px 10px 24px}
}

/* =========================================================
   PALETA · bege + verde dominante · lime como ÚNICO apoio
   (coral e teal saem dos papéis de destaque → viram verde)
   ========================================================= */

/* destaques itálicos dos títulos: verde sóbrio (em fundo claro) */
.sec-title em{color:var(--green)}
.hero-h1 .amp{color:var(--green)}
.hero-h1 em{color:var(--green)}
.manifesto-kicker{color:var(--green)}
.manifesto-h em{color:var(--green)}
.quem-label{color:var(--green)}
.final-h em{color:#fff}
/* em fundo escuro/lime continua o apoio em lime */
.sec-dark .sec-title em,.pains .sec-title em,.sec-bonus .sec-title em{color:var(--lime)}

/* micro-detalhes: trocas de coral → verde / lime de apoio */
.nav a::after{background:var(--green)}
.faq summary::after{color:var(--green)}
.btn-text:hover{border-bottom-color:var(--lime)}

/* cards "o que você leva" (mp): linha e ícones em verde, hover lime */
.mp-card::after{background:var(--lime)}
.mp-card:hover .mp-ico{background:var(--green);color:#fff}

/* features: ícones unificados em verde (sem coral/teal) */
.feat-ico,
.feat:nth-child(2) .feat-ico,.feat:nth-child(3) .feat-ico,
.feat:nth-child(5) .feat-ico,.feat:nth-child(6) .feat-ico{color:var(--green)}

/* pills: tudo em verde-sobre-bege; apoio lime quando no escuro */
.tag-pill,.tag-pill-teal,.tag-pill-green{background:rgba(15,61,43,.08);color:var(--green)}
.tag-pill-coral{background:rgba(240,169,43,.18);color:var(--lime)}

/* seção DORES (fundo verde): aspas e bordas viram lime de apoio */
.pain-q{color:var(--lime)}
.pain:hover{border-color:var(--lime)}

/* calculadora: kicker passa de teal → lime */
.calc-kicker{color:var(--lime)}
.flow-track{background:linear-gradient(90deg,var(--lime),var(--green))}

/* carrossel de módulos: rotação só verde / lime / bege */
.cover-c3{background:var(--cream);color:var(--green)}
.cover-c3 .cover-n{color:var(--green)} .cover-c3::before{background:var(--lime)}
.cover-c4{background:var(--green);color:#fff}
.cover-c4 .cover-n{color:var(--lime)} .cover-c4::before{background:var(--lime)}
.cover-c5{background:var(--cream);color:var(--green)}
.cover-c5 .cover-n{color:var(--green)} .cover-c5::before{background:var(--lime)}

/* =========================================================
   LIME DISCRETO · só botão / destaque / detalhe
   (sem grandes preenchimentos lime; bege + verde mandam)
   ========================================================= */

/* CTA final: bege com título verde + botão lime de destaque */
.final{background:var(--cream)}
.final-h{color:var(--green)}
.final-h em{color:var(--green);font-style:italic}
.final p{color:var(--muted)}

/* card da oferta: bege em vez de lime cheio (texto/preço em verde) */
.offer-card{background:var(--cream);color:var(--green)}
.offer-card-tag{background:rgba(15,61,43,.1)}

/* módulos: alterna verde / bege; lime fica só no nº e na linha */
.cover-c2,.cover-c4{background:var(--cream);color:var(--green)}
.cover-c2 .cover-n,.cover-c4 .cover-n{color:var(--green)}
.cover-c2::before,.cover-c4::before{background:var(--lime)}
.cover-c3,.cover-c5{background:var(--green);color:#fff}
.cover-c3 .cover-n,.cover-c5 .cover-n{color:var(--lime)}
.cover-c3::before,.cover-c5::before{background:var(--lime)}

/* HERO · sobe o conjunto (h1 → KPIs) mais perto da margem superior (só desktop) */
@media(min-width:1001px){
  .hero-in{padding-top:clamp(6px,2vh,22px)}
}

/* =========================================================
   COMO FUNCIONA · mockups de app (jornada em 3 passos)
   ========================================================= */
.appsteps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.6vw,32px);max-width:1060px;margin:0 auto}
.appstep{display:flex;flex-direction:column;align-items:center;text-align:center}
/* sem contêiner: só um wrapper de centralização (deixa a sombra do phone aparecer) */
.appcard{position:relative;width:100%;padding:0 0 clamp(4px,1vw,12px);display:flex;justify-content:center;overflow:visible}
.appcard::after{display:none}

/* phone — recortado na base (sai de baixo, não é um "mini iphone") + sombra projetada */
.mphone{position:relative;width:min(218px,84%);background:#2a130b;border-radius:46px 46px 0 0;padding:10px 10px 0;box-shadow:0 18px 46px -16px rgba(0,0,0,.58),0 5px 18px -8px rgba(0,0,0,.45);transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.mphone-notch{position:absolute;top:10px;left:50%;transform:translateX(-50%);width:66px;height:16px;background:#2a130b;border-radius:0 0 11px 11px;z-index:6}
.mphone-screen{position:relative;background:var(--ivory);border-radius:36px 36px 0 0;overflow:hidden;height:340px}

/* screen shell */
.appsc{padding:22px 12px 12px;text-align:left;height:100%;display:flex;flex-direction:column;gap:9px}
.appsc-bar{display:flex;align-items:center;gap:6px;font-size:.62rem;font-weight:700;letter-spacing:.01em;color:var(--green);text-transform:uppercase}
.appsc-dot{width:13px;height:13px;border-radius:50%;background:var(--lime);flex:none}

/* screen 1 · inscrição */
.appsc-welcome{display:flex;flex-direction:column;align-items:center;text-align:center;gap:5px;padding:16px 4px 2px}
.appsc-tick{width:42px;height:42px;border-radius:50%;background:var(--green);display:grid;place-items:center;margin-bottom:4px}
.appsc-tick svg{width:22px;height:22px;stroke:var(--lime);stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round}
.appsc-welcome b{font-family:var(--serif);font-size:1.02rem;color:var(--green);line-height:1.08}
.appsc-welcome span{font-size:.72rem;color:var(--muted);line-height:1.35}
.appsc-cta{margin-top:auto;background:var(--green);color:#fff;text-align:center;font-weight:700;font-size:.76rem;padding:11px;border-radius:100px}
.appsc-mini{text-align:center;font-size:.6rem;color:var(--muted)}

/* screen 2 · método */
.appsc-lesson{display:flex;align-items:center;gap:9px;background:var(--green);color:#fff;border-radius:14px;padding:10px 11px}
.appsc-play{width:26px;height:26px;border-radius:50%;background:var(--lime);color:var(--green);display:grid;place-items:center;font-size:.62rem;flex:none}
.appsc-lesson b{font-size:.74rem;display:block;line-height:1.12}
.appsc-lesson i{font-style:normal;font-size:.6rem;opacity:.82}
.appsc-prog{height:7px;border-radius:100px;background:rgba(61,29,18,.12);overflow:hidden}
.appsc-prog span{display:block;height:100%;background:var(--lime);border-radius:100px}
.appsc-progtx{font-size:.6rem;color:var(--muted);margin-top:-3px}
.appsc-list{display:flex;flex-direction:column;gap:8px;margin-top:2px}
.appsc-list li{position:relative;padding-left:23px;font-size:.7rem;color:var(--ink);line-height:1.2}
.appsc-list li::before{content:'';position:absolute;left:0;top:0;width:16px;height:16px;border-radius:50%;background:rgba(61,29,18,.1)}
.appsc-list li.done::before{background:var(--lime) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230f3d2b' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/10px no-repeat}
.appsc-list li.now{font-weight:700;color:var(--green)}
.appsc-list li.now::before{background:transparent;border:2px solid var(--lime)}

/* screen 3 · clientes */
.appsc-notif{background:var(--lime);color:var(--green);font-weight:700;font-size:.66rem;text-align:center;padding:8px;border-radius:10px}
.appsc-agenda{display:flex;flex-direction:column;gap:7px}
.appsc-agenda li{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid rgba(61,29,18,.07);border-radius:11px;padding:7px 9px}
.appsc-agenda b{font-size:.54rem;font-weight:800;letter-spacing:.04em;color:var(--green);background:var(--cream);padding:4px 5px;border-radius:6px;flex:none}
.appsc-agenda span{font-size:.63rem;color:var(--ink);flex:1;line-height:1.1}
.appsc-agenda i{font-style:normal;font-weight:700;font-size:.66rem;color:var(--green)}
.appsc-earn{margin-top:auto;display:flex;align-items:center;justify-content:space-between;background:var(--green);color:#fff;border-radius:12px;padding:9px 13px}
.appsc-earn span{font-size:.62rem;opacity:.85}
.appsc-earn b{font-family:var(--serif);font-size:.98rem;color:var(--lime)}

/* footer meta + conector */
.appstep-foot{position:relative;margin-top:28px;display:flex;flex-direction:column;align-items:center;gap:7px;width:100%}
.appstep-num{font-family:var(--serif);font-weight:600;font-size:1.05rem;color:var(--lime);width:48px;height:48px;border:1.5px solid rgba(240,169,43,.45);border-radius:13px;display:grid;place-items:center;background:rgba(240,169,43,.06)}
.appstep:not(:last-child) .appstep-foot::after{content:'';position:absolute;top:24px;left:calc(50% + 38px);width:calc(100% + clamp(18px,2.6vw,32px) - 76px);height:2px;transform:translateY(-50%);background:repeating-linear-gradient(90deg,rgba(240,169,43,.55) 0 6px,transparent 6px 13px)}
.appstep-foot h3{font-family:var(--serif);font-weight:600;font-size:1.32rem;color:#fff;margin-top:5px}
.appstep-foot p{color:var(--muted-light);font-size:.95rem;line-height:1.5;max-width:268px}

@media(max-width:880px){
  .appsteps{grid-template-columns:1fr;gap:44px;max-width:340px}
  .appstep:not(:last-child) .appstep-foot::after{display:none}
}

/* =========================================================
   QUICK WINS (lote 1) · ritmo, CTA, fatos, coesão
   ========================================================= */

/* 1 · OFERTA em fundo claro → quebra o "muro verde" + card verde de destaque */
.sec-offerlight{background:var(--paper);border-radius:clamp(30px,4vw,56px) clamp(30px,4vw,56px) 0 0}
.sec-offerlight .sec-title{color:var(--ink)}
.sec-offerlight .sec-title em{color:var(--green)}
.sec-offerlight .sec-sub{color:var(--muted)}
.sec-offerlight .tag-pill-lime{background:rgba(15,61,43,.08);color:var(--green)}
.sec-offerlight .offer-card{background:var(--green);color:#fff}
.sec-offerlight .offer-card-tag{background:rgba(255,255,255,.14);color:#fff}
.sec-offerlight .incl{border-bottom-color:rgba(255,255,255,.18)}
.sec-offerlight .incl li{color:#fff}
.sec-offerlight .incl li::before{background-color:var(--lime);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230f3d2b' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E")}
.sec-offerlight .offer-price .v{color:var(--lime)}
.sec-offerlight .offer-cash{color:rgba(255,255,255,.92)}
.sec-offerlight .offer-trust{color:rgba(255,255,255,.72)}

/* 3 · título da Comunidade volta à escala padrão (sem override menor) */
#comunidade .sec-title{white-space:normal;font-size:clamp(2.2rem,5vw,4rem)}

/* 5 · mockups do "Como funciona": gradiente único (coesão dos 3 passos) */
.appcard-1,.appcard-2,.appcard-3{background:none}

/* 6 · marcador das credenciais: troca o emoji 🥑 por check lime (editorial) */
.creds li{padding-left:27px}
.creds li::before{content:"";top:5px;width:16px;height:16px;border-radius:50%;font-size:0;background:var(--lime) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230f3d2b' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/10px no-repeat}

/* =========================================================
   ELEVAÇÕES (lote 2) · eyebrows · hover · data-viz · affordance
   ========================================================= */

/* 1 · EYEBROWS em caixa-alta (ar de programa/método estruturado) */
.sec-num{display:block;font-family:var(--display);font-weight:400;font-size:1.18rem;line-height:1;letter-spacing:.16em;text-transform:uppercase;color:var(--green);margin-bottom:14px}
.sec-num.light{color:var(--lime)}
.calc-head .sec-num,.fran-copy .sec-num{margin-bottom:12px}

/* 2 · HOVER de elevação nos mockups do "Como funciona" */
.appstep:hover .mphone{transform:translateY(-8px);box-shadow:0 30px 58px -18px rgba(0,0,0,.62),0 8px 22px -10px rgba(0,0,0,.5)}

/* 3 · CALCULADORA vira data-viz: renda potencial no 1º mês */
.calc-income{display:flex;flex-direction:column;align-items:center;gap:3px;margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.16)}
.calc-income-l{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-light)}
.calc-income b{font-family:var(--serif);font-weight:600;font-size:clamp(1.9rem,4vw,2.7rem);color:var(--lime);line-height:1}
.calc-income b.pop{animation:numPop .4s var(--ease)}

/* 4 · AFFORDANCE do carrossel de módulos: fade nas bordas (continuidade) */
.mod-carousel{-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.mod-hint{text-align:center;font-size:.8rem;color:var(--muted);margin-top:22px;display:flex;align-items:center;justify-content:center;gap:8px}
.mod-hint::before,.mod-hint::after{content:"";width:26px;height:1px;background:rgba(61,29,18,.2)}

/* 5 · DIFERENCIAR A Fran × Vivi: espelha o split da Vivi (imagem à direita) */
@media(min-width:1001px){
  .fran-in.rev{grid-template-columns:1.08fr .92fr}
  .fran-in.rev .fran-art{order:2}
}

/* =========================================================
   ENCONTROS PRESENCIAIS · colagem editorial de fotos reais
   ========================================================= */
.men-collage{position:relative;display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,minmax(0,200px));gap:14px;max-width:1080px;margin:clamp(40px,5vw,60px) auto 0}
.men-collage figure{margin:0;overflow:hidden;border-radius:20px;position:relative;box-shadow:0 30px 60px -34px rgba(0,0,0,.6)}
.men-collage figure::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(8,28,20,.28));opacity:0;transition:opacity .4s}
.men-collage figure:hover::after{opacity:1}
.men-collage img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s var(--ease)}
.men-collage figure:hover img{transform:scale(1.06)}
.men-c2{grid-column:1 / 3;grid-row:1}
.men-c4{grid-column:1 / 3;grid-row:2}
.men-c1{grid-column:3;grid-row:1 / 3}
.men-c3{grid-column:4;grid-row:1 / 3}
.men-badge{position:absolute;left:18px;bottom:18px;z-index:3;background:var(--lime);color:var(--green);font-weight:700;font-size:.82rem;padding:9px 18px;border-radius:100px;box-shadow:0 14px 30px -14px rgba(0,0,0,.6)}

.men-benefits{display:grid;grid-template-columns:repeat(3,1fr);max-width:1000px;margin:clamp(40px,5vw,56px) auto 0}
.men-benefit{padding:6px 32px;position:relative}
.men-benefit + .men-benefit::before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:1px;background:rgba(255,255,255,.16)}
.men-ico{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:13px;background:rgba(240,169,43,.16);color:var(--lime);margin-bottom:18px;transition:transform .4s var(--ease),background .3s}
.men-ico svg{width:24px;height:24px;stroke:currentColor;fill:none}
.men-benefit:hover .men-ico{transform:translateY(-3px);background:rgba(240,169,43,.26)}
.men-benefit h4{font-family:var(--serif);font-weight:600;font-size:1.24rem;color:#fff;margin-bottom:8px;line-height:1.2}
.men-benefit p{color:var(--muted-light);font-size:.95rem;line-height:1.56}

@media(max-width:880px){
  .men-collage{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .men-c1,.men-c2,.men-c3,.men-c4{grid-column:auto;grid-row:auto;aspect-ratio:4/3}
  .men-benefits{grid-template-columns:1fr;gap:4px;max-width:440px}
  .men-benefit{padding:20px 0}
  .men-benefit + .men-benefit::before{left:0;right:0;top:0;bottom:auto;width:auto;height:1px}
  .men-ico{margin-bottom:12px}
}

/* =========================================================
   A ESCOLA · credibilidade institucional (foto nítida + stats)
   ========================================================= */
.sec-escola{position:relative;color:#fff;overflow:hidden;border-radius:clamp(30px,4vw,56px) clamp(30px,4vw,56px) 0 0;background:radial-gradient(120% 90% at 85% 0%,#587a37 0%,#3e5a2a 55%,#2a3d1d 100%);padding:clamp(80px,11vw,138px) 0}
.escola-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(40px,6vw,80px);align-items:center}
.sec-escola .sec-num.light{color:var(--lime)}
.sec-escola .sec-title{color:#fff;text-align:left}
.sec-escola .sec-title em{color:var(--lime)}
.sec-escola .sec-sub{color:rgba(255,255,255,.8);text-align:left;margin:20px 0 0;max-width:520px}
.escola-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.escola-tags span{font-size:.85rem;font-weight:600;color:var(--lime);border:1px solid rgba(240,169,43,.4);padding:8px 16px;border-radius:100px}
/* foto nítida emoldurada com legenda de localização */
.escola-photo{position:relative;margin:0;border-radius:clamp(20px,2.5vw,28px);overflow:hidden;aspect-ratio:5/4;box-shadow:0 50px 80px -34px rgba(0,0,0,.7)}
.escola-photo img{width:100%;height:100%;object-fit:cover;object-position:center 42%;display:block;transition:transform .8s var(--ease)}
.escola-photo:hover img{transform:scale(1.04)}
.escola-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 58%,rgba(8,28,20,.55));pointer-events:none}
.escola-loc{position:absolute;left:18px;bottom:18px;z-index:2;display:inline-flex;align-items:center;gap:7px;background:var(--lime);color:var(--green);font-weight:700;font-size:.82rem;padding:9px 16px 9px 13px;border-radius:100px;box-shadow:0 14px 30px -14px rgba(0,0,0,.5)}
.escola-loc svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2}
/* barra de estatísticas grandes */
.escola-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,40px);margin-top:clamp(52px,7vw,84px);padding-top:clamp(36px,4vw,52px);border-top:1px solid rgba(255,255,255,.16)}
.estat b{display:block;font-family:var(--serif);font-weight:600;font-size:clamp(1.9rem,3.4vw,2.9rem);line-height:1;letter-spacing:-.02em;color:var(--lime)}
.estat span{display:block;margin-top:9px;font-size:.92rem;line-height:1.4;color:rgba(255,255,255,.72)}
@media(max-width:900px){
  .escola-grid{grid-template-columns:1fr;gap:34px}
  .escola-photo{aspect-ratio:4/3;order:-1}
  .escola-stats{grid-template-columns:1fr 1fr;gap:26px 20px}
}
@media(max-width:440px){
  .escola-stats{grid-template-columns:1fr 1fr;gap:22px 16px}
  .estat b{font-size:1.7rem}
}

/* =========================================================
   A FORMAÇÃO · deck de cards empilhados (sticky · scroll nativo)
   linguagem dos pôsteres "food for good" do manual da marca
   ========================================================= */
.sec-formacao{position:relative;background:var(--ivory);padding:clamp(64px,9vw,118px) 0 clamp(40px,7vw,90px)}

/* INTRO — fora do deck, rola normalmente */
.formacao-intro{position:relative;max-width:var(--wrap);margin:0 auto clamp(34px,5vw,62px);padding:0 clamp(24px,5vw,40px)}
.formacao-intro .sec-num{color:var(--green)}
.formacao-title{font-family:var(--serif);font-weight:600;font-size:clamp(2.1rem,5vw,4rem);line-height:1.0;letter-spacing:-.028em;color:var(--green);max-width:16ch}
.formacao-title em{font-style:italic;font-weight:500;position:relative;white-space:nowrap}
.formacao-title em::after{content:"";position:absolute;left:0;right:0;bottom:.08em;height:.30em;background:var(--lime);z-index:-1;border-radius:3px;opacity:.9}
.formacao-lead{margin-top:20px;max-width:52ch;font-size:clamp(1.02rem,1.3vw,1.18rem);line-height:1.6;color:var(--muted)}

/* DECK — cards sticky full-bleed que se empilham conforme o scroll */
.deck{position:relative;margin:0;padding:0;display:flex;flex-direction:column;gap:0}
.deck-card{position:sticky;display:block;min-height:clamp(370px,52vh,486px);overflow:hidden;background:var(--green);color:#fff;
  box-shadow:0 -10px 24px -18px rgba(0,0,0,.45)}
/* offsets crescentes -> cada card empilha mostrando uma "lombada" do anterior */
.deck-card:nth-child(1){top:84px}
.deck-card:nth-child(2){top:94px}
.deck-card:nth-child(3){top:104px}
.deck-card:nth-child(4){top:114px}
.deck-card:nth-child(5){top:124px}
.deck-card:nth-child(6){top:134px}
.deck-card:nth-child(even){background:var(--green-2)}

/* CONTEÚDO — alinhado à mesma grade do H1 da seção (.wrap), texto à esquerda */
.dc-inner{position:relative;z-index:1;max-width:var(--wrap);margin:0 auto;min-height:inherit;display:flex;align-items:center;padding:clamp(42px,5vw,66px) clamp(24px,5vw,40px)}
.dc-tx{display:flex;flex-direction:column;max-width:clamp(320px,46%,520px)}
.dc-num{font-family:var(--display);font-size:clamp(2.6rem,5vw,4.4rem);line-height:.78;letter-spacing:.02em;color:var(--lime);position:relative;padding-bottom:16px;margin-bottom:18px}
.dc-num::after{content:"";position:absolute;left:.06em;bottom:0;width:clamp(38px,4vw,58px);height:3px;background:rgba(240,169,43,.5);border-radius:3px}
.dc-tx h3{font-family:var(--serif);font-weight:600;font-size:clamp(1.55rem,2.7vw,2.45rem);line-height:1.06;letter-spacing:-.018em;color:#fff;text-wrap:balance}
.dc-tx p{margin-top:15px;max-width:44ch;font-size:clamp(1rem,1.15vw,1.12rem);line-height:1.58;color:rgba(255,255,255,.78)}
.dc-tag{align-self:flex-start;margin-top:26px;font-family:var(--display);font-size:.92rem;letter-spacing:.12em;color:var(--lime);border:1px solid rgba(240,169,43,.34);padding:7px 16px 5px;border-radius:100px}

/* imagem — full-bleed à direita do card (não estica a altura) */
.dc-img{position:absolute;top:0;right:0;bottom:0;width:46%;margin:0;overflow:hidden}
.dc-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform 1.1s var(--ease)}
.deck-card:hover .dc-img img{transform:scale(1.05)}
.dc-img::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--green) 0%,transparent 18%);opacity:.55;pointer-events:none}
.deck-card:nth-child(even) .dc-img::after{background:linear-gradient(90deg,var(--green-2) 0%,transparent 18%)}

/* mobile — empilhamento natural, imagem no topo, sem sticky */
@media(max-width:860px){
  .deck-card{position:static;display:flex;flex-direction:column;min-height:0}
  .dc-img{position:relative;width:100%;aspect-ratio:16/10;order:-1}
  .dc-img::after{display:none}
  .dc-inner{min-height:0;padding:clamp(30px,7vw,44px) clamp(22px,6vw,30px)}
  .dc-tx{max-width:none}
}
@media(prefers-reduced-motion:reduce){
  .deck-card{position:static}
}

/* =========================================================
   CARROSSEL DE MÓDULOS · capas de imagem 16:9 (substitui cards)
   ========================================================= */
.cover{width:clamp(280px,42vw,470px);height:auto;aspect-ratio:1675/939;padding:0;display:block;background:var(--cream);border:1px solid rgba(61,29,18,.07);box-shadow:0 20px 44px -24px rgba(61,29,18,.4)}
.cover img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}
.cover::before{display:none}
.cover-name{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:46px 22px 18px;text-align:left;color:#fff;font-family:var(--serif);font-weight:600;font-size:1.22rem;line-height:1.12;letter-spacing:-.01em;background:linear-gradient(to top,rgba(48,30,18,.9) 12%,rgba(48,30,18,.5) 55%,rgba(48,30,18,0) 100%);border-radius:0 0 var(--r-lg) var(--r-lg)}
.cover-name small{display:block;font-family:var(--sans);font-style:normal;font-weight:600;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;opacity:.8;margin-bottom:5px}
@media(max-width:600px){.cover-name{font-size:1.06rem;padding:40px 18px 15px}}
@media(max-width:1000px){.cover{width:clamp(260px,66vw,380px);height:auto}}
@media(max-width:440px){.cover{width:80vw}}

/* =========================================================
   VÍDEO DE VENDAS (placeholder pronto p/ embed)
   ========================================================= */
.sec-video{background:var(--paper)}
.sec-video .sec-num{margin-bottom:18px}
.sec-video .sec-title{letter-spacing:-.032em;line-height:1.04}
.sec-video .sec-sub{max-width:680px;margin:22px auto 0}
.video-frame{position:relative;max-width:920px;margin:clamp(44px,5.5vw,68px) auto 0;aspect-ratio:16/9;border-radius:var(--r-lg);overflow:hidden;background:var(--green);box-shadow:var(--shadow)}
.video-poster{width:100%;height:100%;object-fit:cover;display:block}
.video-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,28,20,.12),rgba(8,28,20,.46));z-index:1}
.video-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;width:clamp(64px,8vw,90px);height:clamp(64px,8vw,90px);border:0;border-radius:50%;cursor:pointer;background:var(--lime);color:var(--green);display:grid;place-items:center;box-shadow:0 18px 44px -12px rgba(0,0,0,.55);transition:transform .35s var(--ease)}
.video-play::before{content:"";position:absolute;inset:-10px;border-radius:50%;border:2px solid rgba(240,169,43,.55);animation:vpulse 2.4s var(--ease) infinite}
@keyframes vpulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(1.35);opacity:0}100%{opacity:0}}
.video-play:hover{transform:translate(-50%,-50%) scale(1.08)}
.video-play svg{width:42%;height:42%;fill:currentColor;margin-left:8%}
.video-soon{position:absolute;left:50%;bottom:clamp(16px,3vw,26px);transform:translateX(-50%);z-index:2;background:rgba(61,29,18,.66);color:#fff;font-size:.8rem;font-weight:600;letter-spacing:.04em;padding:8px 17px;border-radius:100px;backdrop-filter:blur(6px)}

/* =========================================================
   AVALIAÇÕES DO GOOGLE · carrossel automático
   ========================================================= */
.sec-reviews{background:var(--ivory);overflow:hidden}
.reviews-carousel{overflow:hidden;width:100vw;margin:clamp(40px,5vw,56px) calc(50% - 50vw) 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.reviews-track{display:flex;width:max-content;gap:20px;padding:10px 20px;animation:slide 56s linear infinite}
.reviews-carousel:hover .reviews-track{animation-play-state:paused}
.review-card{flex:none;width:clamp(290px,28vw,350px);background:var(--paper);border:1px solid rgba(61,29,18,.08);border-radius:var(--r-lg);padding:26px 26px 24px;display:flex;flex-direction:column;gap:13px;box-shadow:0 18px 40px -26px rgba(61,29,18,.4)}
.review-top{display:flex;align-items:center;justify-content:space-between}
.review-stars{color:#f5a623;font-size:1.05rem;letter-spacing:2px;line-height:1}
.review-g{width:18px;height:18px;flex:none}
.review-text{color:var(--ink);font-size:.97rem;line-height:1.55;flex:1}
.review-author{display:flex;align-items:center;gap:11px;margin-top:2px}
.review-av{width:40px;height:40px;border-radius:50%;background:var(--green);color:var(--lime);display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:1.15rem;flex:none}
.review-author b{display:block;font-size:.95rem;color:var(--ink);line-height:1.2}
.review-author span{font-size:.82rem;color:var(--muted)}
@media(max-width:760px){
  .review-card{width:80vw;max-width:330px}
  .reviews-track{animation-duration:42s}
}

/* =========================================================
   POR QUE ESSA GELEIA É DIFERENTE — seção poster
   ========================================================= */
.sec-why{background:var(--ivory);padding:clamp(48px,8vw,104px) 0}
.why-card{
  background:var(--green);color:#fff;border-radius:clamp(28px,4vw,48px);
  padding:clamp(40px,6vw,86px) clamp(26px,5vw,70px);
  box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.why-card::after{ /* brilho diagonal sutil em mel */
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 80% at 100% 0%, rgba(240,169,43,.16), transparent 55%);
}
.why-kicker{
  display:block;text-align:center;position:relative;z-index:1;
  font-family:var(--sans);font-weight:600;font-size:.92rem;
  letter-spacing:.2em;text-transform:uppercase;color:var(--lime);
}
.why-title{
  position:relative;z-index:1;text-align:center;margin:14px 0 0;
  font-family:var(--display);font-weight:400;text-transform:uppercase;
  color:var(--lime);line-height:.9;letter-spacing:.01em;
  font-size:clamp(3rem,9.5vw,7rem);
}
.why-grid{
  position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(26px,4vw,52px);margin-top:clamp(38px,6vw,68px);
  max-width:980px;margin-inline:auto;
}
.why-item{display:flex;gap:18px;align-items:flex-start}
.why-ico{flex:0 0 auto;width:clamp(42px,5vw,56px);height:clamp(42px,5vw,56px);color:var(--lime)}
.why-ico svg{width:100%;height:100%;display:block}
.why-item h3{
  font-family:var(--display);font-weight:400;text-transform:uppercase;
  letter-spacing:.04em;line-height:1;color:var(--lime);
  font-size:clamp(1.4rem,2.6vw,2rem);
}
.why-item p{margin-top:8px;color:rgba(255,255,255,.82);line-height:1.5;font-size:clamp(1rem,1.3vw,1.12rem)}
.why-cta{position:relative;z-index:1;text-align:center;margin-top:clamp(36px,5vw,60px)}
@media(max-width:760px){
  .why-grid{grid-template-columns:1fr;gap:24px}
  .why-title{font-size:clamp(2.6rem,13vw,4rem)}
}

/* Player de vídeo (VTurb) — moldura arredondada */
.video-embed{
  max-width:920px;margin:0 auto;
  border-radius:clamp(16px,2.4vw,28px);overflow:hidden;
  box-shadow:var(--shadow);background:#000;line-height:0;
}
.video-embed vturb-smartplayer{border-radius:inherit;overflow:hidden}

/* =========================================================
   HERO — redesign em 2 colunas (foto contida, sem distorção)
   ========================================================= */
.hero{background:var(--ivory);overflow:clip}
.hero .hero-in{
  position:static;inset:auto;min-height:0;
  display:grid;grid-template-columns:1.05fr .92fr;
  gap:clamp(30px,5vw,70px);align-items:center;
  padding:clamp(120px,13vw,162px) 0 clamp(56px,8vw,96px);
}
.hero-copy{max-width:560px}
.hero-media{position:relative;z-index:1}
.hero-media .hero-img{
  display:block;width:100%;height:clamp(360px,44vw,540px);
  object-fit:cover;border-radius:clamp(20px,3vw,34px);
  box-shadow:var(--shadow);margin:0;
}
.hero-media::after{ /* blob mel sutil atrás da foto */
  content:"";position:absolute;right:-5%;bottom:-6%;width:62%;height:64%;
  background:var(--lime);opacity:.4;z-index:-1;
  border-radius:46% 54% 50% 50% / 52% 48% 52% 48%;
}
@media(max-width:900px){
  .hero{background:var(--ivory)!important;padding:0}
  .hero .hero-in{grid-template-columns:1fr;gap:26px;padding:100px 0 56px}
  .hero-media{order:9}
  .hero-media .hero-img{height:clamp(240px,64vw,400px)}
  .hero-img--mob{display:none!important}
}
@media(max-width:560px){
  .hero .hero-in{text-align:center}
  .hero-copy{margin:0 auto}
  .hero-media::after{display:none}
}

/* =========================================================
   HERO — estilo "banner" com foto recortada + blobs do abacate
   ========================================================= */
.hero-media{position:relative;z-index:1;isolation:isolate}
.hero-media .hero-img{
  position:relative;z-index:2;
  width:100%;height:clamp(380px,46vw,560px);object-fit:cover;object-position:50% 28%;
  border-radius:56% 44% 47% 53% / 58% 55% 45% 42%;
  box-shadow:0 40px 80px -40px rgba(28,59,31,.45);margin:0;
}
/* blob lima (abacate claro) atrás da foto */
.hero-media::before{
  content:"";position:absolute;z-index:1;top:-7%;right:-9%;
  width:80%;height:88%;background:#d7e89a;
  border-radius:58% 42% 50% 50% / 62% 52% 48% 38%;
}
/* blob verde-escuro (casca do abacate) no canto inferior */
.hero-media::after{
  content:"";position:absolute;z-index:0;bottom:-7%;right:-5%;
  width:46%;height:46%;background:#1c3b1f;border-radius:50%;opacity:1;
}
/* pontinho lima de detalhe */
.hero-media{--dot:#c5dd6b}
.hero-photo-dot{position:absolute;z-index:3;left:-18px;bottom:16%;width:42px;height:42px;background:var(--dot);border-radius:50%;box-shadow:var(--shadow-sm)}
@media(max-width:900px){
  .hero-media .hero-img{height:clamp(300px,72vw,440px)}
  .hero-media::before{width:86%;height:84%}
  .hero-media::after{width:40%;height:40%}
}
@media(max-width:560px){
  .hero-media::after,.hero-photo-dot{display:none}
}
