/* ============================================================
   JEJUM INVERTIDO — Quiz Funnel
   Estética: "clínica acolhedora" — creme quente, verde da marca,
   coral de urgência. Mobile-first.
   ============================================================ */
:root{
  --bg:#FBF7F1;
  --bg-soft:#F4EDE2;
  --card:#FFFFFF;
  --ink:#2B2420;
  --ink-soft:#6F655C;
  --green:#1DBE5C;
  --green-dark:#149A49;
  --green-soft:#E4F8EC;
  --coral:#FF5F52;
  --coral-soft:#FFECEA;
  --amber-soft:#FFF6E3;
  --amber-ink:#8A6A1F;
  --radius:18px;
  --shadow:0 10px 30px -12px rgba(43,36,32,.18);
  --shadow-press:0 4px 14px -6px rgba(29,190,92,.45);
  --font-display:"Bricolage Grotesque",system-ui,sans-serif;
  --font-body:"Nunito",system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
img{max-width:100%;height:auto}
/* qualquer foto solta (landing, statcard) com teto de altura e cantos */
img.ph{width:100%;height:34svh;max-height:320px;min-height:180px;object-fit:cover;object-position:center 30%;border-radius:18px;display:block}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--ink);
  min-height:100svh;
  background-image:
    radial-gradient(900px 420px at 85% -10%, rgba(29,190,92,.07), transparent 60%),
    radial-gradient(700px 380px at -10% 100%, rgba(255,95,82,.05), transparent 60%);
}
#app{max-width:480px;margin:0 auto;padding:0 18px 56px;position:relative}

/* ---------- Header / progresso ---------- */
.topbar{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:24px 0 16px;position:relative;
}
.topbar .back{
  position:absolute;left:0;top:50%;translate:0 -50%;border:0;background:transparent;cursor:pointer;
  font-size:24px;color:var(--ink-soft);padding:4px 10px;border-radius:10px;line-height:1;
}
.topbar .back:active{background:var(--bg-soft)}
.topbar img{height:34px;display:block}
.progress{display:flex;align-items:center;padding:6px 2px 28px}
.progress .seg{flex:1;height:6px;border-radius:99px;background:#EBE3D6;position:relative;margin-right:20px}
.progress .seg:last-child{margin-right:0}
.progress .seg i{
  position:absolute;inset:0;transform-origin:left;transform:scaleX(var(--p,0));
  background:linear-gradient(90deg,var(--green),#3BD97B);border-radius:99px;
  transition:transform .45s cubic-bezier(.22,1,.36,1);display:block;
}
.progress .seg .dot{
  position:absolute;right:-17px;top:50%;translate:0 -50%;z-index:2;
  width:15px;height:15px;border-radius:50%;
  background:var(--bg);border:2.5px solid #DDD3C4;
  display:grid;place-items:center;
  font-size:8.5px;font-weight:900;color:#fff;line-height:1;
  transition:background .3s,border-color .3s,transform .3s;
}
.progress .seg:last-child .dot{right:-7px}
.progress .seg.active .dot{
  border-color:var(--green);
  animation:ringPulse 1.6s ease-out infinite;
}
@keyframes ringPulse{
  0%{box-shadow:0 0 0 0 rgba(29,190,92,.35)}
  70%{box-shadow:0 0 0 7px rgba(29,190,92,0)}
  100%{box-shadow:0 0 0 0 rgba(29,190,92,0)}
}
.progress .seg.done .dot{
  background:linear-gradient(180deg,#23CD68,var(--green));
  border-color:var(--green);animation:none;
  box-shadow:0 2px 7px -2px rgba(29,190,92,.55);
}
.progress .seg.done .dot::after{content:"✓";animation:dotPop .35s cubic-bezier(.34,1.56,.64,1) both}
@keyframes dotPop{from{transform:scale(0)}to{transform:scale(1)}}

/* ---------- Etapas ---------- */
.step{animation:stepIn .42s cubic-bezier(.22,1,.36,1) both}
@keyframes stepIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
h1.q{
  font-family:var(--font-display);font-weight:700;font-size:clamp(21px,5.6vw,26px);
  line-height:1.22;text-align:center;margin:6px 0 20px;letter-spacing:-.01em;
}
h1.q .hl{color:var(--green-dark)}
.sub{color:var(--ink-soft);text-align:center;font-size:15px;margin:-10px 0 20px;line-height:1.5}

/* opções */
.opts{display:flex;flex-direction:column;gap:11px}
.opt{
  display:flex;align-items:center;gap:12px;width:100%;
  background:var(--card);border:2px solid transparent;border-radius:var(--radius);
  padding:16px 16px;font-family:var(--font-body);font-size:16px;font-weight:700;color:var(--ink);
  cursor:pointer;text-align:left;box-shadow:0 3px 12px -8px rgba(43,36,32,.22);
  transition:transform .12s,border-color .12s,background .12s;
}
.opt .emoji{font-size:24px;margin-left:auto;flex:none}
.opt .box{
  width:22px;height:22px;border-radius:7px;border:2px solid #D8CFC2;flex:none;
  display:grid;place-items:center;font-size:13px;color:#fff;transition:.12s;
}
.opt.single .box{display:none}
.opt:active{transform:scale(.985)}
.opt.sel{border-color:var(--green);background:var(--green-soft)}
.opt.sel .box{background:var(--green);border-color:var(--green)}
.opt.sel .box::after{content:"✓"}

/* botão principal */
.btn{
  display:block;width:100%;border:0;cursor:pointer;margin-top:22px;
  background:linear-gradient(180deg,#23CD68,var(--green) 55%,var(--green-dark));
  color:#fff;font-family:var(--font-body);font-weight:800;font-size:17px;letter-spacing:.02em;
  padding:17px 20px;border-radius:16px;box-shadow:var(--shadow-press);
  transition:transform .12s,opacity .15s,filter .15s;
}
.btn:active{transform:scale(.985)}
.btn:disabled{filter:grayscale(.8);opacity:.55;cursor:not-allowed;box-shadow:none}
.btn.coral{background:linear-gradient(180deg,#FF7A6E,var(--coral) 60%,#E84A3D);box-shadow:0 4px 14px -6px rgba(255,95,82,.5)}
.btn.pulse{animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.025)}}
.skip{display:block;margin:16px auto 0;background:none;border:0;color:var(--ink-soft);
  font-family:var(--font-body);font-size:14px;text-decoration:underline;cursor:pointer}

/* ---------- Cards intersticiais ---------- */
.icard{border-radius:24px;overflow:hidden;background:var(--card);box-shadow:var(--shadow);position:relative}
.icard .ph{
  width:100%;height:38svh;max-height:340px;min-height:200px;
  object-fit:cover;object-position:center 35%;display:block;background:
  linear-gradient(135deg,#E8F7EE,#F8EFE0 60%,#FFE9E6);
}
.icard .ph.placeholder{height:auto;aspect-ratio:4/3;display:grid;place-items:center;color:var(--ink-soft);font-size:13px;text-align:center;padding:20px}
.icard .body{padding:22px 22px 24px;margin-top:-46px;position:relative;background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);border-radius:20px 20px 0 0}
.icard h2{font-family:var(--font-display);font-size:23px;line-height:1.2;margin-bottom:10px;letter-spacing:-.01em}
.icard h2 .hl{color:var(--green-dark)}
.icard p{color:var(--ink-soft);font-size:15.5px;line-height:1.6}
.icard p b{color:var(--ink)}
.stat-big{font-family:var(--font-display);font-weight:800;font-size:46px;color:var(--green-dark);text-align:center;letter-spacing:-.02em}
.stat-sub{text-align:center;color:var(--ink-soft);font-size:15px;margin-top:4px}

/* história de sucesso (antes e depois) */
.storycard{background:var(--card);border-radius:22px;box-shadow:var(--shadow);overflow:hidden}
.storycard .ph{width:100%;height:auto;aspect-ratio:1212/1074;object-fit:cover;display:block}
.storycard .ph.placeholder{aspect-ratio:1/1;display:grid;place-items:center;color:var(--ink-soft);font-size:13px;text-align:center;padding:20px}
.storybody{padding:18px 20px 20px}
.storybody b{font-size:14.5px;display:block;margin-bottom:7px}
.storybody p{font-style:italic;color:var(--ink-soft);font-size:14.5px;line-height:1.6}

/* depoimento */
.depo{background:var(--card);border-radius:22px;box-shadow:var(--shadow);padding:24px 22px;text-align:left}
.depo .stars{color:#F5B301;font-size:19px;letter-spacing:3px;margin-bottom:10px}
.depo p{font-style:italic;font-size:16px;line-height:1.65;color:var(--ink)}
.depo .who{display:flex;align-items:center;gap:12px;margin-top:16px}
.depo .who img{width:46px;height:46px;border-radius:50%;object-fit:cover;background:var(--bg-soft)}
.depo .who span{font-weight:800;font-size:14px}
.depo .who small{display:block;color:var(--ink-soft);font-weight:600}

/* ---------- Inputs numéricos / texto ---------- */
.numwrap{display:flex;align-items:baseline;justify-content:center;gap:10px;margin:26px 0 8px}
.numwrap input{
  width:130px;border:0;border-bottom:3px solid #D8CFC2;background:transparent;outline:0;
  font-family:var(--font-display);font-size:44px;font-weight:700;text-align:center;color:var(--ink);
}
.numwrap input:focus{border-color:var(--green)}
.numwrap .unit{font-size:18px;color:var(--ink-soft);font-weight:700}
input.text{
  width:100%;background:var(--card);border:2px solid #E7DFD3;border-radius:16px;outline:0;
  padding:16px;font-family:var(--font-body);font-size:17px;font-weight:700;color:var(--ink);
}
input.text:focus{border-color:var(--green)}
.infobox{
  margin-top:18px;border-radius:14px;padding:14px 16px;font-size:14px;line-height:1.55;
  background:var(--green-soft);color:#14522E;display:none;animation:stepIn .3s both;
}
.infobox.warn{background:var(--amber-soft);color:var(--amber-ink)}
.infobox.danger{background:var(--coral-soft);color:#A12A21}

/* campo de data + calendário customizado */
.datewrap{position:relative}
.datewrap input{padding-right:54px;text-align:left}
.calbtn{
  position:absolute;right:8px;top:50%;translate:0 -50%;
  width:42px;height:42px;border:0;border-radius:12px;cursor:pointer;
  background:var(--green-soft);font-size:20px;line-height:1;
  display:grid;place-items:center;transition:background .15s,transform .1s;
}
.calbtn:active{transform:scale(.94);background:#D2F2DF}
.calendar{
  background:var(--card);border-radius:20px;box-shadow:var(--shadow);
  padding:16px;margin-top:12px;animation:stepIn .25s both;
}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cal-head b{font-family:var(--font-display);font-size:17px}
.cal-nav{
  width:38px;height:38px;border:0;border-radius:12px;background:var(--bg-soft);
  font-size:22px;color:var(--green-dark);cursor:pointer;font-weight:800;line-height:1;
  transition:background .15s;
}
.cal-nav:active{background:var(--green-soft)}
.cal-nav:disabled{opacity:.3;cursor:default}
.cal-week{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:6px}
.cal-week span{text-align:center;font-size:12px;font-weight:900;color:var(--ink-soft)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-grid .day{
  aspect-ratio:1;border:0;border-radius:12px;background:transparent;cursor:pointer;
  font-family:var(--font-body);font-size:15px;font-weight:800;color:var(--ink);
  display:grid;place-items:center;transition:background .12s,color .12s;
}
.cal-grid .day:not(.off):hover{background:var(--green-soft)}
.cal-grid .day.today{box-shadow:inset 0 0 0 2px #D8CFC2}
.cal-grid .day.sel{background:linear-gradient(180deg,#23CD68,var(--green));color:#fff;box-shadow:0 4px 10px -4px rgba(29,190,92,.6)}
.cal-grid .day.off{color:#D8CFC2;cursor:default;background:transparent}
.infobox b{display:block;margin-bottom:2px}
.infobox.show{display:block}

/* ---------- Resumo / régua IMC ---------- */
.panel{background:var(--card);border-radius:20px;box-shadow:var(--shadow);padding:20px;margin-bottom:14px}
.panel .row{display:flex;justify-content:space-between;font-size:14px;color:var(--ink-soft);font-weight:700}
.ruler{position:relative;height:10px;border-radius:99px;margin:30px 4px 8px;
  background:linear-gradient(90deg,#3BD97B,#F5B301 55%,#FF5F52)}
.ruler .pin{
  position:absolute;top:-30px;translate:-50% 0;background:var(--ink);color:#fff;font-size:12px;font-weight:800;
  padding:4px 9px;border-radius:8px;white-space:nowrap}
.ruler .pin::after{content:"";position:absolute;left:50%;translate:-50% 0;top:100%;
  border:5px solid transparent;border-top-color:var(--ink)}
.ruler-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--ink-soft);margin-top:10px;font-weight:700}
.kv{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.kv .item small{color:var(--ink-soft);font-weight:700;font-size:12.5px;text-transform:uppercase;letter-spacing:.04em}
.kv .item div{font-weight:800;font-size:16px}

/* ---------- Tela de análise ---------- */
.anl .line{margin-bottom:18px}
.anl .line .lbl{display:flex;justify-content:space-between;font-size:14.5px;font-weight:800;margin-bottom:7px}
.anl .line .lbl .pct{color:var(--green-dark)}
.anl .bar{height:9px;border-radius:99px;background:#EBE3D6;overflow:hidden}
.anl .bar i{display:block;height:100%;width:0%;border-radius:99px;
  background:linear-gradient(90deg,var(--green),#3BD97B);transition:width .25s linear}
.seals{display:flex;gap:12px;justify-content:center;margin:26px 0 8px}
.seal{flex:1;background:var(--card);border-radius:16px;box-shadow:var(--shadow);padding:14px 10px;text-align:center}
.seal b{font-family:var(--font-display);font-size:20px;color:var(--green-dark);display:block}
.seal span{font-size:12px;color:var(--ink-soft);font-weight:700;line-height:1.3;display:block;margin-top:3px}

/* popup da análise */
.modal-bg{position:fixed;inset:0;background:rgba(43,36,32,.45);display:grid;place-items:center;
  z-index:50;padding:22px;animation:fadeIn .25s both}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:#fff;border-radius:22px;padding:24px 20px;width:100%;max-width:380px;
  animation:stepIn .3s both;box-shadow:0 30px 80px -20px rgba(0,0,0,.35)}
.modal h3{font-family:var(--font-display);font-size:19px;margin-bottom:16px;text-align:center;line-height:1.3}

/* ---------- Vídeo / VSL ---------- */
.vslbox{border-radius:20px;overflow:hidden;background:#100E0D;aspect-ratio:9/16;max-height:62svh;
  margin:0 auto 18px;box-shadow:var(--shadow);position:relative;width:100%}
.vslbox.wide{aspect-ratio:16/9;max-height:none}
.vslbox .ph-video{position:absolute;inset:0;display:grid;place-items:center;color:#CDC4B8;
  font-size:13.5px;text-align:center;padding:24px;line-height:1.6}
.vslbox iframe,.vslbox video{width:100%;height:100%;border:0;display:block}
.alertbar{display:flex;gap:10px;align-items:flex-start;background:var(--amber-soft);color:var(--amber-ink);
  border-radius:14px;padding:13px 15px;font-size:14.5px;font-weight:700;line-height:1.5;margin-bottom:16px}

/* ---------- Resultado / projeção ---------- */
.diagcard{background:var(--card);border-radius:22px;box-shadow:var(--shadow);padding:24px 20px;margin-bottom:16px}
.tagline{display:inline-block;background:var(--coral-soft);color:#B03228;font-weight:800;font-size:13px;
  padding:6px 12px;border-radius:99px;margin-bottom:12px}
.proj-date{font-family:var(--font-display);font-size:23px;color:var(--green-dark);font-weight:800;line-height:1.25;
  text-align:center;margin:14px 0 6px}
.disclaimer{font-size:11.5px;color:var(--ink-soft);line-height:1.5;text-align:center;margin-top:10px}
.checklist{list-style:none;margin-top:14px;display:flex;flex-direction:column;gap:11px}
.checklist li{display:flex;gap:10px;font-size:15px;font-weight:700;line-height:1.45}
.checklist li::before{content:"✅";flex:none}
.arrowdown{text-align:center;font-size:30px;margin:8px 0;animation:bounce 1.4s infinite}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}

svg.chart{width:100%;height:auto;display:block}

/* ---------- Oferta em texto (modo sem VSL) ---------- */
.offer{margin-top:6px}
.offer-lead{text-align:center;font-weight:800;color:var(--ink);font-size:16px;margin-bottom:14px}
.offer-card{background:var(--card);border-radius:22px;box-shadow:var(--shadow);padding:22px 20px;border:2px solid var(--green-soft)}
.offer-card h2{font-family:var(--font-display);font-size:21px;line-height:1.25;margin-bottom:8px}
.offer-card h2 .hl{color:var(--green-dark)}
.offer-intro{color:var(--ink-soft);font-size:15px;line-height:1.55;margin-bottom:16px}
.stack{list-style:none;display:flex;flex-direction:column;gap:0}
.stack li{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:13px 0;border-bottom:1px dashed #E7DFD3;font-size:15px;font-weight:700}
.stack li span{flex:1}
.stack li b{color:var(--coral);font-weight:800;white-space:nowrap;text-decoration:line-through;text-decoration-thickness:2px}
.anchor{margin-top:18px;text-align:center}
.anchor>span{color:var(--ink-soft);font-size:14px;font-weight:700}
.anchor s{color:var(--coral)}
.anchor .price{margin-top:6px;font-family:var(--font-display);font-size:30px;font-weight:800;color:var(--ink)}
.anchor .price b{color:var(--green-dark);font-size:38px}
.anchor .price small{display:block;font-family:var(--font-body);font-size:13px;font-weight:700;color:var(--ink-soft);margin-top:2px}
.offer-why{margin-top:18px;font-size:14px;line-height:1.6;color:var(--ink-soft);font-style:italic}
.urg{margin-top:16px;background:var(--coral-soft);color:#A12A21;border-radius:14px;
  padding:13px 15px;font-size:14px;font-weight:800;line-height:1.5}
.guarantee{margin-top:12px;display:flex;gap:10px;align-items:flex-start;background:var(--green-soft);
  color:#14522E;border-radius:14px;padding:13px 15px;font-size:14px;line-height:1.5}
.guarantee b{font-weight:800}

/* ---------- Página de resultado (modelo BodyFast fundido) ---------- */
.result .diagcard{margin-bottom:14px}
.sec-title{font-family:var(--font-display);font-size:21px;line-height:1.25;text-align:center;margin:26px 0 6px;letter-spacing:-.01em}
.sec-title .hl{color:var(--green-dark)}
.sec-sub{text-align:center;color:var(--ink-soft);font-size:14.5px;line-height:1.55;margin-bottom:16px}

/* resumo do plano (meta | nível) */
.plansum{display:flex;align-items:center;justify-content:space-around;background:var(--card);
  border-radius:18px;box-shadow:var(--shadow);padding:16px;margin-bottom:6px}
.plansum>div{text-align:center}
.plansum small{display:block;color:var(--ink-soft);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.plansum b{font-family:var(--font-display);font-size:19px}
.plansum .div{width:1px;height:38px;background:#E7DFD3}

/* mockup do app (imagens reais) */
.appshow{margin-top:4px}
.phones{display:flex;gap:14px;justify-content:center;align-items:flex-start;margin-top:10px}
.appscreen{
  width:calc(50% - 7px);max-width:210px;height:auto;display:block;
  border-radius:22px;box-shadow:0 14px 34px -14px rgba(43,36,32,.3);
}

/* selos de prova */
.badges{display:flex;gap:12px;margin:20px 0}
.badge{flex:1;background:var(--card);border-radius:16px;box-shadow:var(--shadow);padding:16px 10px;text-align:center}
.badge b{font-family:var(--font-display);font-size:22px;color:var(--green-dark);display:block}
.badge span{font-size:12px;color:var(--ink-soft);font-weight:700;line-height:1.3;display:block;margin-top:3px}

/* garantia com selo */
.warranty{display:flex;gap:14px;align-items:center;background:var(--card);border:2px solid var(--green-soft);
  border-radius:18px;box-shadow:var(--shadow);padding:18px;margin-top:6px}
.warranty p{font-size:14px;line-height:1.55;color:var(--ink-soft)}
.warranty p b{color:var(--ink)}
.seal-30{flex:none;width:62px;height:62px;border-radius:50%;background:linear-gradient(180deg,#23CD68,var(--green-dark));
  color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-size:24px;font-weight:800;line-height:.9;
  box-shadow:0 6px 16px -6px rgba(29,190,92,.6);text-align:center}
.seal-30 small{font-size:9px;font-weight:800;letter-spacing:.08em;display:block}

/* footer legal */
.legal{margin-top:34px;text-align:center;font-size:12px;color:var(--ink-soft);line-height:1.6}
.legal a{color:var(--green-dark)}
.hidden{display:none!important}
