:root{
  --pink:#ff5fa7;
  --pink-2:#ffa8d0;
  --cream:#fff3ea;
  --peach:#ffd4a8;
  --orange:#ffb347;
  --yellow:#ffd95a;
  --brown:#3b2325;
  --muted:#7a5560;
  --gold:#f0ae34;
  --gold-2:#ffd470;
  --green:#25d366;
  --shadow:0 24px 70px rgba(154,76,106,.18);
}

*{box-sizing:border-box;margin:0;padding:0}

body.dona-body,
body.dona-do-precinho-page{
  font-family:"Poppins",sans-serif;
  color:var(--brown);
  min-height:100vh;
  background:
    radial-gradient(circle at 12% 0%, rgba(255,255,255,.85), transparent 30%),
    radial-gradient(circle at 88% 8%, rgba(255,255,255,.55), transparent 28%),
    linear-gradient(180deg,#ff9fca 0%,#ffc4d8 26%,#ffd9b2 72%,#fff3e6 100%);
}

a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}

.page{
  padding:26px 14px 42px;
  position:relative;
  overflow-x:hidden;
  overflow-y:visible;
  min-height:auto;
}

.page::before,
.page::after{
  content:"";
  position:fixed;
  width:220px;
  height:220px;
  border-radius:50%;
  filter:blur(50px);
  opacity:.32;
  pointer-events:none;
}

.page::before{background:#fff;top:-80px;left:-70px}
.page::after{background:linear-gradient(135deg,var(--pink),var(--orange));right:-80px;bottom:40px}

.shell{
  position:relative;
  z-index:1;
  width:min(500px,100%);
  margin:0 auto;
}

.card{
  position:relative;
  overflow:hidden;
  border-radius:36px;
  background:linear-gradient(180deg,rgba(255,250,245,.98),rgba(255,241,233,.98));
  border:1px solid rgba(132,84,70,.12);
  box-shadow:var(--shadow);
}

.card::before{
  content:"";
  position:absolute;
  inset:0;
  background:repeating-linear-gradient(90deg, rgba(255,95,167,.11) 0 7px, transparent 7px 18px);
  mask-image:linear-gradient(180deg, #000 0%, transparent 26%);
  pointer-events:none;
}

.hero{
  position:relative;
  padding:24px 22px 24px;
  text-align:center;
}

.logo{
  position:relative;
  z-index:2;
  width:230px;
  height:230px;
  margin:0 auto 18px;
  border-radius:50%;
  object-fit:cover;
  object-position:center center;
  border:6px solid rgba(255,255,255,.95);
  box-shadow:0 18px 38px rgba(130,70,74,.20);
}

.decor{
  position:absolute;
  z-index:1;
  width:52px;
  height:52px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:17px;
  font-weight:900;
  color:#fff;
  background:linear-gradient(135deg,var(--pink),var(--orange));
  box-shadow:0 14px 26px rgba(243,154,178,.22);
}

.decor-a{top:30px;left:18px;transform:rotate(-12deg)}
.decor-b{top:94px;right:24px;border-radius:50%;background:linear-gradient(135deg,#ff6f92,#ffbf5b)}
.decor-c{bottom:166px;right:14px;transform:rotate(10deg);background:linear-gradient(135deg,#ff9fd0,#ffd470)}

.badge{
  position:relative;
  z-index:2;
  display:inline-flex;
  padding:8px 15px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--brown);
  background:linear-gradient(90deg,#ffd2ea,#ffeaa9);
  border:1px solid rgba(212,166,91,.26);
  margin-bottom:16px;
}

h1{
  position:relative;
  z-index:2;
  font-size:clamp(30px,7.4vw,44px);
  line-height:1.08;
  letter-spacing:-.03em;
  margin-bottom:14px;
}

h1 span{
  font-family:"Pacifico",cursive;
  font-weight:400;
  color:#ff6fa3;
}

.hero p{
  position:relative;
  z-index:2;
  color:var(--muted);
  font-size:16px;
  line-height:1.65;
  margin:0 auto 22px;
  max-width:410px;
}

.main-btn{
  position:relative;
  z-index:2;
  min-height:58px;
  width:100%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  color:#fff;
  background:linear-gradient(90deg,#22c961,var(--green));
  font-size:17px;
  font-weight:900;
  text-transform:uppercase;
  box-shadow:0 12px 28px rgba(37,211,102,.30);
  animation:btnPulse 1.7s ease-in-out infinite;
  transition:.18s;
}

@keyframes btnPulse{
  0%,100%{transform:scale(1);box-shadow:0 12px 28px rgba(37,211,102,.30)}
  50%{transform:scale(1.045);box-shadow:0 18px 42px rgba(37,211,102,.44)}
}

.progress-box{
  margin:0 18px 24px;
  padding:18px 20px 20px;
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.72), rgba(255,246,239,.64));
  border:1px solid rgba(132,84,70,.10);
  box-shadow:0 12px 28px rgba(130,70,74,.08);
}

.progress-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  margin-bottom:12px;
  font-size:14px;
  padding:0 4px;
}

.progress-top span{
  color:#fff;
  font-weight:900;
  font-size:13px;
  line-height:1;
  padding:7px 10px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--pink),var(--orange));
  box-shadow:0 8px 18px rgba(216,135,156,.22);
  min-width:50px;
  text-align:center;
}

.progress{
  height:10px;
  border-radius:999px;
  background:rgba(122,94,87,.10);
  overflow:hidden;
  margin-bottom:12px;
}

.progress span{
  display:block;
  width:85%;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,var(--pink),var(--orange),var(--yellow));
  transition:width .8s ease;
}

.progress-box p{
  color:var(--muted);
  font-size:12.5px;
  line-height:1.45;
  max-width:92%;
}

.section-title{text-align:center;padding:2px 18px 14px}

.section-title h2,
.why h2{
  font-size:18px;
  text-transform:uppercase;
  letter-spacing:.04em;
  font-weight:900;
}

.section-title::after,
.why h2::after{
  content:"";
  display:block;
  width:78px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--pink),var(--orange),var(--yellow));
  margin:10px auto 0;
}

.items{display:grid;gap:12px;padding:0 18px 24px}

.item{
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.58);
  border:1px solid rgba(132,84,70,.10);
  border-left:4px solid var(--pink);
}

.item:nth-child(2){border-left-color:var(--gold)}
.item:nth-child(3){border-left-color:#ff8dbc}
.item:nth-child(4){border-left-color:#ffb347}

.item span{
  width:46px;
  height:46px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:15px;
  background:linear-gradient(135deg,#ffd4ea,#ffe59a);
  margin-bottom:10px;
  font-size:23px;
}

.item h3{font-size:16px;text-transform:uppercase;margin-bottom:7px}
.item p{color:var(--muted);font-size:14px;line-height:1.6}

.why{padding:0 18px 24px;text-align:center}
.why-grid{display:grid;gap:12px;margin-top:16px}

.why-grid div{
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.46);
  border:1px solid rgba(132,84,70,.10);
}

.why-grid strong{display:block;margin-bottom:6px;font-size:15px;text-transform:uppercase}
.why-grid p{color:var(--muted);font-size:14px;line-height:1.55}

footer{
  border-top:1px solid rgba(132,84,70,.10);
  padding:20px 18px 24px;
  text-align:center;
  color:var(--muted);
}

footer div{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  flex-wrap:wrap;
  margin-bottom:10px;
}

footer a,footer span,footer p{font-size:12px;font-weight:600}

.join-pop{
  position:fixed;
  left:50%;
  bottom:22px;
  z-index:99999;
  transform:translate(-50%,130%);
  width:min(420px,calc(100% - 28px));
  display:flex;
  align-items:center;
  gap:12px;
  padding:13px 15px;
  border-radius:20px;
  background:rgba(255,250,243,.96);
  border:1px solid rgba(132,84,70,.12);
  box-shadow:0 18px 45px rgba(130,70,74,.16);
  opacity:0;
  pointer-events:none;
  transition:transform .45s ease,opacity .45s ease;
}

.join-pop.show{transform:translate(-50%,0);opacity:1}

.join-pop-avatar{
  width:42px;
  height:42px;
  min-width:42px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,#ffd4ea,#ffe59a);
  font-size:20px;
}

.join-pop strong{display:block;color:var(--brown);font-size:14px;line-height:1.25}
.join-pop span{display:block;color:var(--muted);font-size:12px;margin-top:2px}

@media(min-width:768px){
  .page{padding-top:42px}
  .card{border-radius:40px}
  .hero{padding:30px 30px 28px}
  .progress-box,.items,.why{margin-left:24px;margin-right:24px;padding-left:0;padding-right:0}
}


@media(max-width:420px){
  .progress-box{
    margin-left:14px;
    margin-right:14px;
    padding:17px 18px 19px;
  }

  .progress-top strong{
  flex:1;
  padding-left:2px;

    font-size:13px;
  }

  .progress-top span{
    font-size:12px;
    min-width:46px;
    padding:6px 9px;
  }

  .progress-box p{
    font-size:12px;
    max-width:100%;
  }
}
