/* === Cuaderno de los 21 Decretos — estilos === */
:root{
  --c-bg:        #2A1B3D;        /* mantel morado */
  --c-bg-2:      #1d1229;        /* mais escuro */
  --c-wine:      #4A2B5C;        /* morado vinho */
  --c-gold:      #F5C45E;        /* dourado vela */
  --c-gold-deep: #B8860B;        /* dourado quente */
  --c-gold-soft: #e8c97c;
  --c-bone:      #F5EFE6;        /* blanco hueso */
  --c-mauve:     #C8B8D9;        /* texto secundário */
  --c-line:      rgba(245,196,94,.28);
  --c-line-soft: rgba(245,196,94,.16);

  --f-display: 'Cormorant Garamond', 'Cardo', Georgia, serif;
  --f-body:    'Lora', 'Source Serif 4', Georgia, serif;
  --f-script:  'Dancing Script', 'Caveat', cursive;
}

*,*::before,*::after{ box-sizing:border-box; }

html,body{
  margin:0; padding:0;
  background:var(--c-bg);
  color:var(--c-bone);
  font-family:var(--f-body);
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

body{
  min-height:100dvh;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(245,196,94,.10), transparent 55%),
    radial-gradient(ellipse at 50% 100%, rgba(74,43,92,.7), transparent 60%),
    linear-gradient(180deg, var(--c-bg) 0%, var(--c-bg-2) 100%);
  background-attachment:fixed;
}

/* Paper noise overlay */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='4'/><feColorMatrix values='0 0 0 0 0.96  0 0 0 0 0.93  0 0 0 0 0.85  0 0 0 0.06 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.35; mix-blend-mode:overlay;
}

#root{ position:relative; z-index:1; }

img{ max-width:100%; display:block; }

/* Headings */
.h-display{
  font-family:var(--f-display);
  font-weight:500;
  letter-spacing:.005em;
  line-height:1.12;
  color:var(--c-bone);
}
.h-script{
  font-family:var(--f-script);
  font-weight:500;
  color:var(--c-gold);
}
.eyebrow{
  font-family:var(--f-script);
  color:var(--c-gold);
  font-size:1.15rem;
  letter-spacing:.01em;
}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55em;
  min-height:54px; padding:14px 22px;
  font-family:var(--f-display); font-size:1.18rem; font-weight:600; letter-spacing:.02em;
  border-radius:6px; border:1px solid var(--c-gold);
  background:linear-gradient(180deg, var(--c-gold) 0%, #d8a93f 100%);
  color:#2a1a0a; cursor:pointer;
  box-shadow:
    0 0 0 1px rgba(245,196,94,.25),
    0 8px 24px rgba(0,0,0,.35),
    inset 0 1px 0 rgba(255,255,255,.5);
  transition: transform .25s ease, box-shadow .25s ease, filter .25s ease;
  text-decoration:none;
}
.btn:hover, .btn:focus-visible{
  transform: scale(1.02);
  box-shadow:
    0 0 0 1px rgba(245,196,94,.45),
    0 0 28px rgba(245,196,94,.35),
    0 8px 24px rgba(0,0,0,.4),
    inset 0 1px 0 rgba(255,255,255,.55);
  filter:brightness(1.04);
  outline:none;
}
.btn:active{ transform: scale(.99); }
.btn-ghost{
  background:transparent; color:var(--c-gold);
  border:1px solid var(--c-line);
  box-shadow:none;
}
.btn-ghost:hover{ background:rgba(245,196,94,.08); box-shadow:none; transform:none; }

/* Cards / blocks */
.block{
  border:1px solid var(--c-line);
  border-radius:6px;
  background:linear-gradient(180deg, rgba(74,43,92,.45), rgba(42,27,61,.55));
  padding:22px 20px;
  box-shadow: 0 6px 30px rgba(0,0,0,.25), inset 0 1px 0 rgba(245,196,94,.06);
}

/* Decorative golden divider */
.divider{
  display:flex; align-items:center; justify-content:center; gap:14px;
  color:var(--c-gold);
  margin:18px 0;
}
.divider::before, .divider::after{
  content:""; flex:1; height:1px;
  background:linear-gradient(90deg, transparent, var(--c-line), transparent);
}
.divider svg{ width:18px; height:18px; opacity:.85; }

/* Stage container */
.stage{
  width:100%;
  max-width:430px;
  margin:0 auto;
  padding: 28px 22px 56px;
  min-height:100dvh;
  position:relative;
}

/* Steps transitions */
.step{
  animation: fadeUp .55s ease both;
}
@keyframes fadeUp{
  from{ opacity:0; transform: translateY(10px); }
  to  { opacity:1; transform: translateY(0); }
}

/* Progress bar */
.progress{
  position:relative; height:2px; width:100%;
  background:rgba(245,196,94,.15);
  border-radius:2px; overflow:hidden;
}
.progress > i{
  position:absolute; left:0; top:0; bottom:0;
  background:linear-gradient(90deg, var(--c-gold-deep), var(--c-gold));
  transition: width .45s ease;
  box-shadow: 0 0 8px rgba(245,196,94,.55);
}
.progress-label{
  font-family:var(--f-display);
  font-size:.85rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--c-mauve);
}

/* Quiz options */
.opt{
  display:flex; align-items:center; gap:12px;
  width:100%;
  text-align:left;
  padding:16px 18px; min-height:56px;
  border:1px solid var(--c-line);
  border-radius:6px;
  background:rgba(74,43,92,.35);
  color:var(--c-bone);
  font-family:var(--f-body); font-size:1.02rem; line-height:1.4;
  cursor:pointer;
  transition: border-color .25s ease, background .25s ease, transform .15s ease;
}
.opt:hover, .opt:focus-visible{
  border-color: var(--c-gold);
  background: rgba(74,43,92,.6);
  outline:none;
}
.opt.selected{
  border-color: var(--c-gold);
  background: linear-gradient(180deg, rgba(245,196,94,.18), rgba(245,196,94,.06));
  box-shadow: 0 0 0 1px rgba(245,196,94,.35) inset;
}
.opt .dot{
  width:14px; height:14px; flex-shrink:0;
  border-radius:50%;
  border:1px solid var(--c-line);
  background: rgba(0,0,0,.25);
  box-shadow: inset 0 0 0 3px transparent;
  transition: all .2s ease;
}
.opt.selected .dot{
  border-color: var(--c-gold);
  box-shadow: inset 0 0 0 3px var(--c-gold), 0 0 8px rgba(245,196,94,.6);
}

/* Sign grid */
.sign-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:10px;
}
.sign{
  display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:12px 6px; min-height:74px;
  border:1px solid var(--c-line); border-radius:6px;
  background: rgba(74,43,92,.35);
  color:var(--c-bone); font-family:var(--f-display);
  font-size:.95rem;
  cursor:pointer;
  transition:all .2s ease;
}
.sign svg{ width:22px; height:22px; color:var(--c-gold); opacity:.85; }
.sign:hover, .sign:focus-visible{ border-color:var(--c-gold); outline:none; }
.sign.selected{
  border-color:var(--c-gold);
  background: linear-gradient(180deg, rgba(245,196,94,.18), rgba(245,196,94,.04));
}
.sign.selected svg{ opacity:1; }

/* Inputs */
.field{
  width:100%;
  height:54px;
  padding: 0 16px;
  font-family:var(--f-body); font-size:1.05rem;
  color:var(--c-bone);
  background: rgba(0,0,0,.25);
  border:1px solid var(--c-line);
  border-radius:6px;
  outline:none;
  transition: border-color .25s ease, background .25s ease;
}
.field::placeholder{ color: rgba(200,184,217,.6); }
.field:focus{ border-color: var(--c-gold); background: rgba(0,0,0,.35); }

.microcopy{
  color: var(--c-mauve); font-size:.9rem; line-height:1.45;
  font-style: italic;
}

/* Calculando */
.calc-stage{
  position:fixed; inset:0; z-index:50;
  display:flex; align-items:center; justify-content:center; flex-direction:column;
  padding: 0 24px;
  background:
    radial-gradient(ellipse at 50% 50%, rgba(245,196,94,.18), transparent 60%),
    linear-gradient(180deg, #1c1129 0%, #0f0818 100%);
}
.calc-glow{
  position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(circle at 50% 50%, rgba(245,196,94,.22), transparent 40%);
  animation: pulse 4s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{ opacity:.5; transform:scale(1); }
  50%{ opacity:1; transform:scale(1.05); }
}
.calc-rings i{
  position:absolute; left:50%; top:50%;
  width:80px; height:80px; margin-left:-40px; margin-top:-40px;
  border:1px solid var(--c-line);
  border-radius:50%;
  animation: ring 4s ease-out infinite;
  opacity:0;
}
.calc-rings i:nth-child(2){ animation-delay:1.3s; }
.calc-rings i:nth-child(3){ animation-delay:2.6s; }
@keyframes ring{
  0%{ transform: scale(.5); opacity:.8; }
  100%{ transform: scale(6); opacity:0; }
}
.candle{
  position:relative; width:42px; height:90px;
  margin-bottom:42px;
  z-index:2;
}
.candle .body{
  position:absolute; bottom:0; left:50%; transform:translateX(-50%);
  width:32px; height:60px;
  background: linear-gradient(180deg, #f5e6c2 0%, #c9a86a 100%);
  border-radius: 3px;
  box-shadow: 0 -4px 12px rgba(245,196,94,.3), inset -4px 0 6px rgba(0,0,0,.2);
}
.candle .wick{
  position:absolute; bottom:60px; left:50%; transform:translateX(-50%);
  width:2px; height:6px; background:#1a0e08;
}
.candle .flame{
  position:absolute; bottom:65px; left:50%; transform-origin: 50% 100%;
  width:14px; height:24px;
  margin-left:-7px;
  background: radial-gradient(ellipse at 50% 70%, #fff8c4 0%, var(--c-gold) 35%, #b8860b 70%, transparent 100%);
  border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
  filter: blur(.3px);
  animation: flicker 1.4s ease-in-out infinite;
  box-shadow: 0 0 24px rgba(245,196,94,.7), 0 0 48px rgba(245,196,94,.4);
}
@keyframes flicker{
  0%,100%{ transform: translateX(0) scale(1) rotate(-1deg); opacity:.95; }
  25%{ transform: translateX(.5px) scale(.97, 1.03) rotate(1.5deg); opacity:1; }
  50%{ transform: translateX(-.4px) scale(1.02, .98) rotate(-1.5deg); opacity:.9; }
  75%{ transform: translateX(.3px) scale(.98, 1.02) rotate(.8deg); opacity:1; }
}
.calc-text{
  position:relative; z-index:2;
  font-family:var(--f-display);
  font-size:1.4rem; line-height:1.4;
  color:var(--c-bone);
  text-align:center;
  max-width:340px;
  font-style:italic;
  min-height:90px;
  animation: fadeText .8s ease both;
}
@keyframes fadeText{
  from{ opacity:0; transform: translateY(6px); }
  to  { opacity:1; transform: translateY(0); }
}

/* === Cards (Etapa 3) === */
.cards-row{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:10px;
  margin: 20px 0 8px;
}
.tarot{
  position:relative;
  aspect-ratio: 5 / 9;
  perspective: 1200px;
  cursor:pointer;
}
.tarot .face{
  position:absolute; inset:0;
  border-radius:8px;
  backface-visibility:hidden;
  transition: transform .8s cubic-bezier(.4, 0, .2, 1);
  overflow:hidden;
  box-shadow: 0 10px 30px rgba(0,0,0,.5), 0 0 0 1px var(--c-line) inset;
}
.tarot .back{
  background:
    radial-gradient(ellipse at 50% 50%, rgba(245,196,94,.18), transparent 60%),
    linear-gradient(160deg, #3a2150 0%, #21142f 100%);
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--c-line);
}
.tarot .back::before{
  content:""; position:absolute; inset:6px;
  border:1px solid rgba(245,196,94,.35);
  border-radius:5px;
}
.tarot .back svg{ width:60%; height:auto; color: var(--c-gold); }
.tarot .front{
  transform: rotateY(180deg);
  background: linear-gradient(180deg, #f5efe2 0%, #e7d7b6 100%);
  color:#2a1a0a;
  display:flex; flex-direction:column;
  border:1px solid var(--c-gold-deep);
  padding: 8px 6px;
}
.tarot.flipped .back{ transform: rotateY(180deg); }
.tarot.flipped .front{ transform: rotateY(0deg); }
.tarot .front .name-top, .tarot .front .name-bot{
  font-family:var(--f-display);
  font-weight:600;
  text-align:center;
  letter-spacing:.1em;
  font-size:.6rem;
  text-transform:uppercase;
  color:#5a3a18;
}
.tarot .front .name-bot{ transform: rotate(180deg); }
.tarot .front .art{
  flex:1;
  display:flex; align-items:center; justify-content:center;
  position:relative;
}
.tarot .front .art svg{ width:88%; height:88%; }

.card-label{
  margin-top:8px;
  text-align:center;
  font-family:var(--f-display);
  font-size:.78rem;
  line-height:1.25;
  color:var(--c-mauve);
  letter-spacing:.02em;
  min-height:32px;
}
.card-label b{
  display:block;
  color:var(--c-gold);
  font-style:italic;
  font-weight:500;
  margin-bottom:2px;
  font-size:.85rem;
}

/* VSL */
.vsl-frame{
  position:relative;
  aspect-ratio: 16 / 9;
  background: linear-gradient(135deg, #1a1024, #0d0617);
  border:1px solid var(--c-line);
  border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
  box-shadow: 0 12px 40px rgba(0,0,0,.5);
}
.vsl-frame .play{
  width:78px; height:78px;
  border-radius:50%;
  background: rgba(245,196,94,.15);
  border:1px solid var(--c-gold);
  display:flex; align-items:center; justify-content:center;
  color:var(--c-gold);
  backdrop-filter: blur(4px);
  cursor:pointer;
  transition: transform .25s ease, box-shadow .25s ease;
}
.vsl-frame .play:hover{
  transform:scale(1.06);
  box-shadow: 0 0 24px rgba(245,196,94,.5);
}
.vsl-frame .label{
  position:absolute; bottom:12px; left:0; right:0;
  text-align:center;
  color: var(--c-mauve);
  font-family:var(--f-display);
  font-size:.85rem;
  letter-spacing:.18em;
  text-transform:uppercase;
}

/* === Player VSL custom === */
.vsl-frame .vsl-video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  background:#000;
  pointer-events:none;       /* clique do user nunca pausa o vídeo */
}
.vsl-fallback{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  text-align:center; padding:24px;
  color: var(--c-mauve);
}
/* Banner pequeno de unmute — não cobre o vídeo, só pisca discretamente
   no canto inferior. Vídeo continua visível e tocando. */
.vsl-unmute{
  position:absolute;
  left:12px; bottom:14px;
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 14px 8px 10px;
  background: rgba(42,27,61,.78);
  backdrop-filter: blur(6px);
  border:1px solid var(--c-gold);
  border-radius:999px;
  color: var(--c-bone);
  font-family: var(--f-body, 'Lora', serif);
  font-size:.78rem;
  font-weight:500;
  letter-spacing:.02em;
  cursor:pointer;
  z-index:3;
  box-shadow: 0 4px 14px rgba(0,0,0,.4), 0 0 0 0 rgba(245,196,94,.5);
  animation: vslUnmuteAttention 2.6s ease-in-out infinite;
  transition: background .2s ease, transform .15s ease;
}
.vsl-unmute:hover{
  background: rgba(42,27,61,.92);
  transform: translateY(-1px);
}
.vsl-unmute:focus{ outline: 2px solid var(--c-gold); outline-offset: 2px; }
.vsl-unmute .vsl-unmute-ico{
  display:inline-flex; align-items:center; justify-content:center;
  width:24px; height:24px;
  border-radius:50%;
  background: rgba(245,196,94,.18);
  color: var(--c-gold);
  flex-shrink:0;
}
@keyframes vslUnmuteAttention{
  0%, 100% { box-shadow: 0 4px 14px rgba(0,0,0,.4), 0 0 0 0 rgba(245,196,94,.45); }
  50%      { box-shadow: 0 4px 14px rgba(0,0,0,.4), 0 0 0 6px rgba(245,196,94,0); }
}

.vsl-progress{
  position:absolute; left:0; right:0; bottom:0;
  height:3px;
  background: rgba(255,255,255,.08);
  z-index:1;
  pointer-events:none;
}
.vsl-progress-bar{
  height:100%;
  background: linear-gradient(90deg, var(--c-gold-deep), var(--c-gold));
  transition: width .9s cubic-bezier(.33, 1, .68, 1);
  box-shadow: 0 0 8px rgba(245,196,94,.5);
  will-change: width;
}

/* Offer block */
.offer-list{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:14px;
}
.offer-list li{
  display:flex; align-items:flex-start; gap:14px;
  font-size:1rem; line-height:1.45;
  color: var(--c-bone);
}
.offer-list svg{
  flex-shrink:0; width:22px; height:22px; color:var(--c-gold);
  margin-top:2px;
}

/* Guarantee */
.guarantee{
  position:relative;
  border:1px solid var(--c-gold);
  border-radius:6px;
  padding: 24px 20px 20px;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(245,196,94,.12), transparent 70%),
    linear-gradient(180deg, rgba(74,43,92,.55), rgba(42,27,61,.65));
  text-align:center;
  margin-top: 6px;
}
.seal{
  width:84px; height:84px;
  margin: -50px auto 12px;
  border-radius:50%;
  background:
    radial-gradient(circle at 35% 30%, #fff7d4 0%, var(--c-gold) 40%, var(--c-gold-deep) 100%);
  display:flex; align-items:center; justify-content:center;
  box-shadow: 0 8px 24px rgba(0,0,0,.5), inset 0 0 0 2px rgba(255,255,255,.25), 0 0 0 4px rgba(245,196,94,.18);
  font-family:var(--f-display);
  font-weight:600;
  color:#3a2407;
  text-align:center;
  line-height:1;
}
.seal small{ display:block; font-size:.65rem; letter-spacing:.16em; }
.seal b{ display:block; font-size:1.5rem; }
.seal i{ display:block; font-size:.55rem; letter-spacing:.16em; font-style:normal; }

/* FAQ */
.faq details{
  border-bottom:1px solid var(--c-line-soft);
  padding: 14px 0;
}
.faq details:last-child{ border-bottom:0; }
.faq summary{
  list-style:none;
  cursor:pointer;
  display:flex; align-items:center; justify-content:space-between;
  gap:12px;
  font-family:var(--f-display);
  font-size:1.1rem;
  color:var(--c-bone);
  line-height:1.3;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{
  content:"+";
  color:var(--c-gold);
  font-size:1.3rem;
  transition: transform .25s ease;
  flex-shrink:0;
}
.faq details[open] summary::after{ content:"–"; }
.faq .ans{
  margin-top:10px;
  color: var(--c-mauve);
  line-height:1.55;
  font-size:.98rem;
}

/* Testimonial-manifesto */
.manifesto{
  font-style:italic;
  color: var(--c-bone);
  font-size:1.05rem;
  line-height:1.7;
  position:relative;
  padding: 8px 4px 8px 22px;
  border-left: 2px solid var(--c-gold);
}
.manifesto .sig{
  display:block; margin-top:14px;
  font-family:var(--f-script);
  font-style:normal;
  font-size:1.4rem;
  color: var(--c-gold);
}

/* Footer */
.footer{
  margin-top: 48px;
  padding-top: 24px;
  border-top:1px solid var(--c-line-soft);
  text-align:center;
  font-size:.88rem;
  color: var(--c-mauve);
  line-height:1.6;
}
.footer .disclaimer{
  font-size:.92rem;
  font-style:italic;
  margin-bottom:18px;
  color: var(--c-mauve);
}
.footer-links{
  display:flex; gap:16px; justify-content:center; flex-wrap:wrap;
  margin-bottom:14px;
}
.footer-links a{
  color: var(--c-gold-soft); text-decoration:none;
  border-bottom: 1px dotted rgba(245,196,94,.35);
  font-size:.85rem;
}
.footer-links a:hover{ color: var(--c-gold); }

/* Section spacing */
.s-block + .s-block{ margin-top:36px; }
.s-block h2{
  font-family:var(--f-display);
  font-size: 1.7rem;
  font-weight:500;
  margin: 0 0 16px;
  line-height:1.15;
  color: var(--c-bone);
}
.s-block h3{
  font-family:var(--f-display);
  font-size: 1.25rem;
  font-weight:600;
  margin: 0 0 10px;
  color: var(--c-bone);
}
.s-block p{ margin: 0 0 12px; }

/* Step navigator (only in tweaks mode) */
.step-nav{
  position:fixed; top:10px; left:50%; transform:translateX(-50%);
  z-index: 60;
  display:flex; gap:6px;
  padding: 6px 8px;
  background: rgba(15,8,24,.92);
  border:1px solid var(--c-line);
  border-radius: 999px;
  backdrop-filter: blur(8px);
  font-family: var(--f-display);
  font-size:.78rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  max-width: calc(100vw - 16px);
  white-space: nowrap;
  flex-wrap: nowrap;
}
.step-nav button{
  white-space: nowrap;
  flex: 0 0 auto;
}
@media (max-width: 480px){
  .step-nav{ font-size:.65rem; padding: 4px 4px; gap:1px; letter-spacing:.04em; }
  .step-nav button{ padding: 5px 8px; }
  .step-nav .lbl{ display:none; }
}
.step-nav button{
  appearance:none; border:0; background:transparent;
  color: var(--c-mauve);
  padding: 6px 10px;
  border-radius: 999px;
  cursor:pointer;
  font:inherit;
}
.step-nav button.active{
  background: rgba(245,196,94,.2);
  color: var(--c-gold);
}
.step-nav button:hover{ color: var(--c-gold); }

/* When step-nav is on, push down the stage and calc text so they don't collide */
body.has-stepnav .stage{ padding-top: 90px; }
body.has-stepnav .calc-stage{ padding-top: 90px; }
@media (max-width: 480px){
  body.has-stepnav .stage{ padding-top: 80px; }
  body.has-stepnav .calc-stage{ padding-top: 80px; }
}

/* VSL waiting state */
.vsl-waiting{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding: 32px 16px;
  border-top: 1px solid var(--c-line-soft);
  border-bottom: 1px solid var(--c-line-soft);
  margin-top: 28px;
}
.vsl-wait-dots{ display:flex; gap:8px; }
.vsl-wait-dots i{
  width:6px; height:6px; border-radius:50%;
  background: var(--c-gold);
  opacity:.3;
  animation: blink 1.2s ease-in-out infinite;
}
.vsl-wait-dots i:nth-child(2){ animation-delay:.2s; }
.vsl-wait-dots i:nth-child(3){ animation-delay:.4s; }
.vsl-offer-reveal{ animation: fadeUp .7s ease both; }

/* Calculando — loader/progress + aviso */
.calc-progress{
  position:relative; z-index:2;
  width: min(280px, 70vw); height: 3px;
  margin-top: 22px;
  background: rgba(245,196,94,.12);
  border-radius: 999px; overflow:hidden;
}
.calc-progress-bar{
  height:100%;
  background: linear-gradient(90deg, var(--c-gold-deep), var(--c-gold));
  box-shadow: 0 0 8px rgba(245,196,94,.55);
  transition: width .15s linear;
}
.calc-dots{
  position:relative; z-index:2;
  display:flex; align-items:center; gap:6px;
  margin-top:14px;
  color: var(--c-mauve);
  font-family: var(--f-display);
  font-size:.95rem;
  letter-spacing:.04em;
}
.calc-dots i{
  width:5px; height:5px; border-radius:50%;
  background: var(--c-gold);
  opacity:.3;
  animation: blink 1.2s ease-in-out infinite;
}
.calc-dots i:nth-child(2){ animation-delay:.15s; }
.calc-dots i:nth-child(3){ animation-delay:.3s; }
.calc-dots i:nth-child(4){ animation-delay:.45s; }
@keyframes blink{
  0%,80%,100%{ opacity:.3; transform:scale(.9); }
  40%{ opacity:1; transform:scale(1.15); }
}
.calc-hint{
  position:relative; z-index:2;
  margin-top:10px;
  color: rgba(200,184,217,.6);
  font-size:.82rem;
  font-style:italic;
  text-align:center;
  max-width: 280px;
}

/* Tiny utility */
.center{ text-align:center; }
.mt-8{ margin-top:8px; }
.mt-16{ margin-top:16px; }
.mt-24{ margin-top:24px; }
.mt-32{ margin-top:32px; }
.gap-12{ display:flex; flex-direction:column; gap:12px; }
.gap-16{ display:flex; flex-direction:column; gap:16px; }

/* Scale up slightly on bigger viewports — still mobile-shaped frame */
@media (min-width: 700px){
  .stage{ max-width: 460px; padding: 36px 22px 64px; }
}

/* ── Sticky CTA bar (aparece quando botão principal sai da viewport) ─── */
.sticky-cta {
  position: fixed;
  left: 0; right: 0;
  bottom: 0;
  z-index: 60;
  padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
  background: linear-gradient(180deg, rgba(26, 16, 41, .85), rgba(15, 8, 26, .98));
  border-top: 1px solid var(--c-line);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  box-shadow: 0 -10px 30px rgba(0, 0, 0, .35);
  animation: sticky-cta-in .32s cubic-bezier(.2,.9,.3,1.2) both;
}
.sticky-cta.fade-out {
  animation: sticky-cta-out .22s ease forwards;
}
.sticky-cta-inner {
  max-width: 460px;
  margin: 0 auto;
}
.sticky-cta-btn {
  display: flex;
  width: 100%;
  background: linear-gradient(180deg, var(--c-gold), var(--c-gold-deep));
  color: #1a0a26;
  border: 0;
  border-radius: 14px;
  padding: 13px 18px;
  font-family: var(--f-display);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .01em;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  gap: 8px;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  box-shadow: 0 0 0 2px rgba(245, 196, 94, .25), 0 6px 18px rgba(245, 196, 94, .25);
  transition: transform .15s ease, opacity .25s ease;
  animation: sticky-cta-pulse-soft 2.4s ease-in-out infinite;
}
.sticky-cta-btn:hover {
  transform: translateY(-1px);
}
.sticky-cta-btn:active {
  transform: translateY(0) scale(.98);
}
.sticky-cta-arrow {
  display: inline-flex;
  animation: sticky-cta-arrow-bounce 1.1s ease-in-out infinite;
}
.sticky-cta-microcopy {
  text-align: center;
  font-size: .72rem;
  color: var(--c-mauve);
  margin: 6px 0 0;
  letter-spacing: .01em;
}
@keyframes sticky-cta-in {
  from { transform: translateY(110%); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
@keyframes sticky-cta-out {
  to { transform: translateY(110%); opacity: 0; }
}
@keyframes sticky-cta-pulse-soft {
  0%, 100% { opacity: 1; }
  50%      { opacity: .92; }
}
@keyframes sticky-cta-arrow-bounce {
  0%, 100% { transform: translateX(0); }
  50%      { transform: translateX(4px); }
}

/* Pulse glow no botão principal por alguns segundos depois de aparecer */
.btn.pulse-glow {
  animation: btn-pulse-glow 1.6s ease-in-out 2;
}
@keyframes btn-pulse-glow {
  0%, 100% { box-shadow: 0 0 0 0 rgba(245, 196, 94, 0); }
  50%      { box-shadow: 0 0 0 14px rgba(245, 196, 94, .35); }
}

/* Sticky-mini: quando botão principal já tá visível, vira só hint pra rolar */
.sticky-cta-mini {
  background: linear-gradient(180deg, rgba(26, 16, 41, .7), rgba(15, 8, 26, .92));
  border-top: 1px solid var(--c-line-soft);
  padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
}
.sticky-cta-mini-text {
  margin: 0;
  text-align: center;
  font-size: .82rem;
  color: var(--c-gold);
  font-style: italic;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.sticky-cta-arrow-down {
  display: inline-flex;
  animation: sticky-cta-arrow-down-bounce 1.2s ease-in-out infinite;
}
@keyframes sticky-cta-arrow-down-bounce {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(5px); }
}

/* Ajusta espaço inferior do conteúdo quando sticky CTA está visível.
   120px cobre altura real do sticky (botão + microcopy + padding) e somamos
   safe-area-inset-bottom pra iPhone com home indicator. */
body.has-sticky-cta {
  padding-bottom: calc(120px + env(safe-area-inset-bottom));
}

/* ── ScrollNudge: bloco GIGANTE in-line com chevron animado ─────────────── */
.scroll-nudge {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 28px auto 24px;
  text-align: center;
  color: var(--c-gold);
}
.scroll-nudge-line {
  width: 1px;
  height: 28px;
  background: linear-gradient(180deg, transparent, var(--c-gold));
}
.scroll-nudge-chev {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: radial-gradient(circle, rgba(245,196,94,.18), rgba(245,196,94,.04) 70%);
  border: 1.5px solid rgba(245, 196, 94, .35);
  margin-top: 4px;
  color: var(--c-gold);
  animation: scroll-nudge-bounce 1.3s ease-in-out infinite;
}
.scroll-nudge-text {
  font-family: var(--f-script);
  font-size: 1.15rem;
  margin: 10px 0 0;
  letter-spacing: .01em;
  color: var(--c-gold-soft);
}
@keyframes scroll-nudge-bounce {
  0%, 100% { transform: translateY(0); box-shadow: 0 0 0 0 rgba(245,196,94,.0); }
  50%      { transform: translateY(8px); box-shadow: 0 6px 18px rgba(245,196,94,.25); }
}
