:root{
  --cream:#fbf3ec;
  --cream-deep:#f5e7da;
  --ink:#3a2230;
  --ink-soft:#6b5260;
  --wine:#9d2b53;
  --wine-deep:#7a1f40;
  --rose:#e8a0b4;
  --mint:#2f9e7e;
  --mint-deep:#1f7a60;
  --mint-soft:#d4ece2;
  --gold:#caa15a;
  --white:#fffaf6;
  --radius:22px;
  --shadow:0 30px 60px -25px rgba(58,34,48,.35);
  --shadow-sm:0 10px 30px -12px rgba(58,34,48,.28);
}

*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none !important}
html{scroll-behavior:smooth}
body{
  font-family:"Manrope",sans-serif;
  color:var(--ink);
  background:
    radial-gradient(1100px 700px at 85% -10%, rgba(232,160,180,.45), transparent 60%),
    radial-gradient(900px 600px at -10% 110%, rgba(212,236,226,.7), transparent 55%),
    linear-gradient(160deg,var(--cream),var(--cream-deep));
  min-height:100vh;
  overflow-x:hidden;
  position:relative;
  -webkit-font-smoothing:antialiased;
}

/* grain overlay */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* floating petals */
.petals{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.petal{
  position:absolute;top:-10%;font-size:1.4rem;color:var(--rose);opacity:.5;
  animation:fall linear infinite;
}
.petal:nth-child(1){left:8%;animation-duration:14s;animation-delay:0s;color:var(--rose)}
.petal:nth-child(2){left:24%;animation-duration:18s;animation-delay:3s;color:var(--mint)}
.petal:nth-child(3){left:48%;animation-duration:16s;animation-delay:6s;color:var(--wine)}
.petal:nth-child(4){left:67%;animation-duration:20s;animation-delay:2s;color:var(--rose)}
.petal:nth-child(5){left:82%;animation-duration:15s;animation-delay:8s;color:var(--mint)}
.petal:nth-child(6){left:93%;animation-duration:19s;animation-delay:5s;color:var(--wine)}
@keyframes fall{
  0%{transform:translateY(-10vh) rotate(0deg);opacity:0}
  10%{opacity:.55}
  90%{opacity:.55}
  100%{transform:translateY(112vh) rotate(360deg);opacity:0}
}

.page{position:relative;z-index:2}

/* ===== brand ===== */
.brand{display:flex;align-items:center;gap:.6rem;margin-bottom:clamp(2rem,6vh,4rem)}
.brand__logo{height:40px;width:auto}
.brand__text{
  display:none;font-family:"Fraunces",serif;font-weight:600;font-size:1.7rem;
  letter-spacing:-.02em;color:var(--mint-deep);
}
.brand__text::first-letter{color:var(--wine)}

/* ===== hero ===== */
.hero{padding:clamp(1.5rem,4vw,2.5rem) clamp(1.25rem,5vw,4rem) clamp(2rem,5vw,4rem)}
.hero__inner{max-width:1180px;margin:0 auto}
.hero__grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);
  align-items:center;
}

/* copy */
.eyebrow{
  display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--wine);
  background:rgba(157,43,83,.08);padding:.5rem .9rem;border-radius:100px;
  border:1px solid rgba(157,43,83,.16);
}
.headline{
  font-family:"Fraunces",serif;font-weight:500;
  font-size:clamp(2.8rem,7vw,5rem);line-height:.98;letter-spacing:-.02em;
  margin:1.4rem 0 1.2rem;color:var(--ink);
}
.headline em{
  font-style:italic;font-weight:400;color:var(--wine);
  position:relative;
}
.headline em::after{
  content:"";position:absolute;left:0;bottom:.08em;width:100%;height:.12em;
  background:linear-gradient(90deg,var(--mint),var(--rose));border-radius:4px;opacity:.55;
}
.lede{
  font-size:clamp(1.02rem,1.4vw,1.18rem);line-height:1.6;color:var(--ink-soft);
  max-width:30rem;margin-bottom:1.6rem;
}
.lede strong{color:var(--ink);font-weight:600}

.perks{list-style:none;display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.8rem}
.perks li{display:flex;align-items:center;gap:.7rem;font-weight:500;color:var(--ink);font-size:.98rem}
.perks__dot{
  width:9px;height:9px;border-radius:50%;flex-shrink:0;
  background:var(--mint);box-shadow:0 0 0 4px var(--mint-soft);
}

/* countdown */
.countdown__title{font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.7rem}
.countdown{display:flex;align-items:center;gap:.5rem}
.countdown__item{
  display:flex;flex-direction:column;align-items:center;
  background:var(--white);border:1px solid rgba(58,34,48,.08);
  border-radius:14px;padding:.6rem .85rem;min-width:62px;box-shadow:var(--shadow-sm);
}
.countdown__num{
  font-family:"Fraunces",serif;font-size:1.7rem;font-weight:600;line-height:1;color:var(--wine);
  font-variant-numeric:tabular-nums;
}
.countdown__label{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-top:.35rem}
.countdown__sep{font-family:"Fraunces",serif;font-size:1.4rem;color:var(--rose);font-weight:600;align-self:flex-start;margin-top:.55rem}

/* ===== form card ===== */
.card{
  position:relative;background:var(--white);border-radius:var(--radius);
  padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.6);overflow:hidden;
}
.card::before{
  content:"";position:absolute;inset:0;border-radius:var(--radius);padding:1px;
  background:linear-gradient(140deg,rgba(232,160,180,.6),transparent 40%,rgba(47,158,126,.5));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;
}
.card__ribbon{
  position:absolute;top:15px;right:-42px;transform:rotate(45deg);
  background:linear-gradient(135deg,var(--wine),var(--wine-deep));color:#fff;
  font-size:.62rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  padding:.32rem 0;width:150px;text-align:center;
  box-shadow:0 5px 12px -4px rgba(122,31,64,.45);
}
.card__title{font-family:"Fraunces",serif;font-weight:600;font-size:1.7rem;letter-spacing:-.01em;color:var(--ink)}
.card__sub{color:var(--ink-soft);font-size:.92rem;margin:.4rem 0 1.5rem}

.field{margin-bottom:1.05rem}
.field label{display:block;font-size:.82rem;font-weight:600;color:var(--ink);margin-bottom:.4rem}
.field input{
  width:100%;padding:.85rem 1rem;border-radius:13px;border:1.5px solid rgba(58,34,48,.13);
  background:var(--cream);font-family:inherit;font-size:1rem;color:var(--ink);
  transition:border-color .2s,box-shadow .2s,background .2s;
}
.field input::placeholder{color:#b6a6ad}
.field input:focus{
  outline:none;border-color:var(--mint);background:#fff;
  box-shadow:0 0 0 4px var(--mint-soft);
}
.field input.invalid{border-color:var(--wine);box-shadow:0 0 0 4px rgba(157,43,83,.12)}
.field__error{display:block;min-height:1rem;font-size:.78rem;color:var(--wine);margin-top:.3rem;font-weight:500}

.hp{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}

.btn{
  width:100%;border:none;cursor:pointer;border-radius:13px;padding:1rem 1.2rem;
  font-family:inherit;font-size:1.02rem;font-weight:700;color:#fff;letter-spacing:.01em;
  background:linear-gradient(135deg,var(--wine),var(--wine-deep));
  box-shadow:0 14px 28px -10px rgba(122,31,64,.6);
  display:flex;align-items:center;justify-content:center;gap:.6rem;
  transition:transform .15s,box-shadow .2s,filter .2s;margin-top:.4rem;
}
.btn:hover{transform:translateY(-2px);filter:brightness(1.06);box-shadow:0 20px 34px -10px rgba(122,31,64,.65)}
.btn:active{transform:translateY(0)}
.btn:disabled{filter:grayscale(.3) brightness(.95);cursor:wait;transform:none}
.btn__spinner{
  width:18px;height:18px;border:2.5px solid rgba(255,255,255,.4);border-top-color:#fff;
  border-radius:50%;display:none;animation:spin .7s linear infinite;
}
.btn.loading .btn__text{opacity:.7}
.btn.loading .btn__spinner{display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

.card__legal{font-size:.74rem;color:var(--ink-soft);text-align:center;margin-top:1rem;line-height:1.5}

/* success */
.success{text-align:center;padding:1rem 0 .5rem;animation:pop .5s cubic-bezier(.2,.8,.3,1.2)}
.success__heart{font-size:3.2rem;color:var(--wine);animation:beat 1.1s ease-in-out infinite}
.success h3{font-family:"Fraunces",serif;font-size:1.7rem;color:var(--ink);margin:.4rem 0 .6rem}
.success p{color:var(--ink-soft);line-height:1.55;max-width:24rem;margin:0 auto}
@keyframes beat{0%,100%{transform:scale(1)}15%{transform:scale(1.18)}30%{transform:scale(1)}45%{transform:scale(1.12)}}
@keyframes pop{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}

/* ===== como participar ===== */
.steps{padding:clamp(2rem,6vw,4.5rem) clamp(1.25rem,5vw,4rem) clamp(1rem,3vw,2rem)}
.steps__inner{max-width:1080px;margin:0 auto;text-align:center}
.eyebrow--center{margin-bottom:.2rem}
.steps__title{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(1.9rem,4vw,2.8rem);letter-spacing:-.02em;color:var(--ink);margin:1rem 0 2.2rem}
.steps__grid{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;text-align:left;counter-reset:none}
.step{
  position:relative;background:var(--white);border-radius:18px;padding:1.5rem 1.3rem 1.4rem;
  box-shadow:var(--shadow-sm);border:1px solid rgba(58,34,48,.06);
}
.step__num{
  display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;
  font-family:"Fraunces",serif;font-weight:600;font-size:1.2rem;color:#fff;margin-bottom:.9rem;
  background:linear-gradient(135deg,var(--wine),var(--wine-deep));box-shadow:0 8px 18px -8px rgba(122,31,64,.6);
}
.step h3{font-family:"Fraunces",serif;font-weight:600;font-size:1.18rem;color:var(--ink);margin-bottom:.45rem}
.step p{font-size:.92rem;line-height:1.5;color:var(--ink-soft)}

.info-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:.65rem;margin:2.2rem 0 0}
.chip{
  font-size:.86rem;color:var(--ink);background:var(--mint-soft);border:1px solid rgba(47,158,126,.25);
  padding:.5rem .95rem;border-radius:100px;
}
.chip strong{color:var(--mint-deep);font-weight:700}

.download{margin-top:2.4rem;display:flex;flex-direction:column;align-items:center;gap:.7rem;animation:fadeup .6s ease both}
@keyframes fadeup{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.btn--outline{
  width:auto;background:transparent;color:var(--wine-deep);
  border:1.8px solid var(--wine);box-shadow:none;padding:.95rem 1.6rem;
}
.btn--outline:hover{background:var(--wine);color:#fff;filter:none;box-shadow:0 16px 30px -12px rgba(122,31,64,.5)}
.btn--outline svg{flex-shrink:0}
.download__note{font-size:.84rem;color:var(--ink-soft)}

/* footer */
.footer{
  text-align:center;padding:2rem 1.5rem 2.5rem;color:var(--ink-soft);
  font-size:.85rem;display:flex;align-items:center;justify-content:center;gap:.6rem;flex-wrap:wrap;
}
.footer__dot{color:var(--rose)}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);animation:rise .8s cubic-bezier(.2,.7,.3,1) forwards}
.reveal--delay{animation-delay:.18s}
@keyframes rise{to{opacity:1;transform:none}}

/* responsive */
@media(max-width:880px){
  .hero__grid{grid-template-columns:1fr;gap:2.5rem}
  .hero__copy{text-align:center}
  .lede{margin-left:auto;margin-right:auto}
  .perks{align-items:center}
  .countdown{justify-content:center}
  .brand{justify-content:center}
  /* mobile: na seção "Como participar" deixa só o botão de download */
  .steps{padding-top:1.4rem;padding-bottom:1.4rem}
  .eyebrow--center,.steps__title,.steps__grid,.info-chips,.download__note{display:none}
  .download{margin-top:0}
}
@media(max-width:520px){
  .btn--outline{width:100%}
}
@media(max-width:420px){
  .countdown__item{min-width:54px;padding:.5rem .55rem}
  .countdown__num{font-size:1.4rem}
  .card__ribbon{display:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}