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

:root{
  --ivory:#f6f1e7;
  --paper:#fbf8f1;
  --cream:#efe6d6;
  --ink:#0e2a1e;
  --green:#0f3d2b;
  --green-2:#13412f;
  --lime:#d3e24f;
  --lime-2:#c7da3a;
  --coral:#ec7a68;
  --teal:#5cc2bf;
  --rose:#f6cdbf;
  --muted:#5d6b60;
  --muted-light:rgba(255,255,255,.66);

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

  --wrap:1180px;
  --r:18px;
  --r-lg:30px;
  --shadow:0 30px 70px -36px rgba(14,42,30,.5);
  --shadow-sm:0 16px 40px -24px rgba(14,42,30,.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(199,218,58,.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(14,42,30,.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(14,42,30,.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(14,42,30,.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(14,42,30,.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:#08332b}
.cover-c3 .cover-n{color:#08332b} .cover-c3::before{background:#08332b}
.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(14,42,30,.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(14,42,30,.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(211,226,79,.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(14,42,30,.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(14,42,30,.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:#0e1f17;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:#0e1f17;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(14,42,30,.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(14,42,30,.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:#9aa49c}
.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(14,42,30,.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(211,226,79,.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(14,42,30,.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(14,42,30,.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(14,42,30,.16);border-color:rgba(14,42,30,.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(14,42,30,.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(14,42,30,.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(211,226,79,.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(211,226,79,.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(14,42,30,.08)}
  .mmenu.open{display:flex}
  .mmenu a{padding:13px 0;font-weight:600;border-bottom:1px solid rgba(14,42,30,.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(14,42,30,.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}
}
