*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Nunito',sans-serif;background:#EBF7FF;color:#2D3A4A;overflow-x:hidden}

:root{
  --sky-top:#5AB4DC;
  --sky-mid:#8DCFEC;
  --sky-bot:#C2E8F8;
  --blue:#4AA8D0;
  --blue-d:#2E7EA8;
  --blue-dk:#1D5C80;
  --pink:#FFB3C6;
  --pink-d:#E8849A;
  --yellow:#FFE077;
  --green-d:#3A9E68;
  --cloud:#F0F8FF;
  --text:#2D3A4A;
  --muted:#6B8299;
  --card:#FFFFFF;
}

/* ===== HERO ===== */
.hero{
  min-height:100vh;
  background:linear-gradient(175deg,var(--sky-top) 0%,var(--sky-mid) 45%,var(--sky-bot) 100%);
  position:relative;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  padding:2rem 1.5rem 4rem;
}

/* sparkles */
.sp{position:absolute;border-radius:50%;pointer-events:none;animation:tw 3.5s ease-in-out infinite}
.sp1{width:5px;height:5px;background:rgba(255,255,255,0.85);top:9%;left:22%;animation-delay:0s}
.sp2{width:4px;height:4px;background:rgba(255,255,255,0.7);top:16%;left:62%;animation-delay:0.8s}
.sp3{width:3px;height:3px;background:rgba(255,255,255,0.9);top:32%;left:6%;animation-delay:1.3s}
.sp4{width:5px;height:5px;background:rgba(255,255,255,0.8);top:11%;left:86%;animation-delay:0.4s}
.sp5{width:3px;height:3px;background:rgba(255,255,255,0.7);top:58%;left:91%;animation-delay:1.9s}
@keyframes tw{0%,100%{opacity:0.2;transform:scale(0.8)}50%{opacity:1;transform:scale(1.5)}}

/* clouds */
.cloud{position:absolute;pointer-events:none;z-index:1}
.cb{background:var(--cloud);border-radius:40px;position:relative;opacity:0.88}
.cb::before,.cb::after{content:'';position:absolute;background:var(--cloud);border-radius:50%}
.c1{top:8%;left:-2%;animation:dr1 20s linear infinite}
.c1 .cb{width:150px;height:42px}
.c1 .cb::before{width:65px;height:65px;top:-32px;left:22px}
.c1 .cb::after{width:48px;height:48px;top:-24px;left:72px}
.c2{top:13%;right:2%;animation:dr2 25s linear infinite}
.c2 .cb{width:115px;height:34px}
.c2 .cb::before{width:50px;height:50px;top:-26px;left:16px}
.c2 .cb::after{width:38px;height:38px;top:-18px;left:58px}
.c3{top:4%;left:44%;animation:dr1 32s linear 5s infinite}
.c3 .cb{width:75px;height:24px;opacity:0.65}
.c3 .cb::before{width:32px;height:32px;top:-16px;left:10px}
.c3 .cb::after{width:26px;height:26px;top:-12px;left:38px}
.c4{bottom:9%;left:-4%;animation:dr2 35s linear 8s infinite}
.c4 .cb{width:190px;height:52px;opacity:0.6}
.c4 .cb::before{width:80px;height:80px;top:-40px;left:28px}
.c4 .cb::after{width:60px;height:60px;top:-30px;left:90px}
@keyframes dr1{from{transform:translateX(0)}to{transform:translateX(110vw)}}
@keyframes dr2{from{transform:translateX(0)}to{transform:translateX(-110vw)}}

.hero-inner{
  display:flex;align-items:center;justify-content:center;
  gap:3rem;max-width:960px;width:100%;
  position:relative;z-index:5;
}

.stork-scene{
  position:relative;
  width:300px;height:300px;
  flex-shrink:0;
  animation:fly 4s ease-in-out infinite;
  filter:drop-shadow(0 8px 24px rgba(20,80,130,0.2));
}
@keyframes fly{
  0%,100%{transform:translateY(0) rotate(-1.5deg)}
  50%{transform:translateY(-14px) rotate(1deg)}
}

.stork-img{
  width:300px;height:300px;
  display:block;
  object-fit:contain;
}

.hero-text{text-align:center;flex:1;max-width:460px}
.hero-pre{
  font-family:'Fredoka One',cursive;
  font-size:1.1rem;
  color:rgba(255,255,255,0.92);
  margin-bottom:0.3rem;
  letter-spacing:0.05em;
  text-shadow:0 1px 4px rgba(20,70,110,0.2);
}
.hero-title{
  font-family:'Fredoka One',cursive;
  font-size:clamp(2.8rem,5.5vw,4.2rem);
  color:white;
  line-height:1.05;
  margin-bottom:0.4rem;
  text-shadow:0 3px 12px rgba(20,70,110,0.28);
  letter-spacing:0.02em;
}
.hero-title span{color:var(--yellow);display:block}
.hero-tag{
  font-size:1rem;color:rgba(255,255,255,0.88);
  font-weight:600;margin-bottom:1.8rem;
  letter-spacing:0.04em;
}

.hdiv{display:flex;align-items:center;justify-content:center;gap:0.6rem;margin-bottom:1.8rem}
.hdl{height:2px;width:50px;background:rgba(255,255,255,0.5);border-radius:2px}
.hds{width:10px;height:10px;background:var(--yellow);clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}

.countdown{display:flex;align-items:center;justify-content:center;gap:0.6rem;margin-bottom:1.8rem}
.cnt{
  background:rgba(255,255,255,0.22);
  border:2px solid rgba(255,255,255,0.4);
  border-radius:16px;
  padding:0.75rem 1rem;
  min-width:68px;
  text-align:center;
}
.cnt-n{
  font-family:'Fredoka One',cursive;
  font-size:1.9rem;color:white;line-height:1;
  text-shadow:0 2px 6px rgba(20,70,110,0.3);
  font-variant-numeric:tabular-nums;
}
.cnt-l{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.12em;color:rgba(255,255,255,0.8);font-weight:700;margin-top:3px}
.cnt-sep{font-family:'Fredoka One',cursive;font-size:1.6rem;color:rgba(255,255,255,0.55);padding-bottom:1rem}

.hero-btn{
  display:inline-block;
  background:var(--yellow);color:var(--blue-dk);
  font-family:'Fredoka One',cursive;font-size:1.1rem;
  padding:0.85rem 2.4rem;border-radius:50px;
  text-decoration:none;letter-spacing:0.04em;
  box-shadow:0 4px 18px rgba(0,0,0,0.15);
  transition:transform .15s,box-shadow .15s;
}
.hero-btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 6px 22px rgba(0,0,0,0.2)}

.scroll-hint{margin-top:1.4rem;display:flex;flex-direction:column;align-items:center;gap:4px;opacity:0.45}
.scroll-arr{width:20px;height:20px;border-right:2.5px solid white;border-bottom:2.5px solid white;transform:rotate(45deg);animation:bounce .45s ease-in-out infinite alternate}
@keyframes bounce{to{transform:rotate(45deg) translate(3px,3px)}}

/* ===== SHARED ===== */
section.light{background:white;padding:5rem 1.5rem}
section.soft{background:#EBF7FF;padding:5rem 1.5rem}
.container{max-width:920px;margin:0 auto}
.stitle{font-family:'Fredoka One',cursive;font-size:clamp(1.9rem,4vw,2.6rem);color:var(--blue-dk);text-align:center;margin-bottom:0.35rem;letter-spacing:0.02em}
.ssub{text-align:center;color:var(--muted);font-size:0.93rem;font-weight:600;margin-bottom:3rem}

/* ===== EVENTO ===== */
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-bottom:2.5rem}
.info-card{background:#EBF7FF;border:2px solid rgba(74,168,208,0.2);border-radius:20px;padding:1.8rem 1.3rem;text-align:center;transition:transform .2s}
.info-card:hover{transform:translateY(-3px)}
.info-ico{width:52px;height:52px;background:var(--blue);border-radius:50%;margin:0 auto 0.9rem;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:white}
.info-lbl{font-size:0.68rem;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted);margin-bottom:4px;font-weight:700}
.info-val{font-family:'Fredoka One',cursive;font-size:1.15rem;color:var(--blue-dk)}
.info-det{font-size:0.8rem;color:var(--muted);margin-top:3px;font-weight:600}
.map-frame{border-radius:20px;overflow:hidden;border:2px solid rgba(74,168,208,0.2);margin-bottom:1.2rem}
.map-frame iframe{display:block;width:100%;height:260px;border:0}
.btn-map{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:fit-content;margin:0 auto;
  background:var(--blue);color:white;
  padding:0.85rem 2.2rem;border-radius:50px;
  text-decoration:none;
  font-family:'Fredoka One',cursive;font-size:1rem;letter-spacing:0.04em;
  box-shadow:0 4px 16px rgba(74,168,208,0.35);
  transition:background .2s,transform .15s;
}
.btn-map:hover{background:var(--blue-d);transform:translateY(-2px)}

/* ===== PRESENTES ===== */
.gift-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(195px,1fr));gap:1.4rem}
.gift-cat{
  grid-column:1/-1;
  font-family:'Fredoka One',cursive;
  font-size:1.15rem;
  color:var(--blue-dk);
  padding:0.5rem 0 0.2rem;
  border-bottom:2px solid rgba(74,168,208,0.18);
  margin-top:0.5rem;
  display:flex;align-items:center;gap:0.5rem;
}
.gift-cat-hint{
  font-family:'Nunito',sans-serif;
  font-size:0.72rem;font-weight:700;
  color:var(--blue);
  background:#EBF7FF;
  padding:2px 8px;border-radius:20px;letter-spacing:0.02em;
}
.gift-card{background:white;border-radius:20px;overflow:hidden;border:2px solid rgba(74,168,208,0.15);transition:transform .2s,box-shadow .2s}
.gift-card:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(74,168,208,0.15)}
.gift-img{width:100%;height:120px;display:flex;align-items:center;justify-content:center;font-size:3rem;background:#EBF7FF}
.gi-b{background:#EBF7FF}.gi-p{background:#FFF0F4}.gi-y{background:#FFFBEA}.gi-g{background:#EDFBF3}
.gift-body{padding:0.9rem 1rem 1rem}
.gift-name{font-weight:700;font-size:0.88rem;color:var(--text);margin-bottom:3px}
.gift-limit{font-size:0.75rem;color:var(--muted);font-weight:700;margin-bottom:0.7rem;font-style:italic}
.gift-reserved{display:inline-flex;align-items:center;gap:5px;background:#EDFBF3;color:var(--green-d);font-size:0.72rem;font-weight:800;padding:4px 10px;border-radius:20px}
.btn-gift{width:100%;background:var(--blue);color:white;border:none;padding:0.6rem;border-radius:12px;font-family:'Fredoka One',cursive;font-size:0.9rem;cursor:pointer;letter-spacing:0.03em;transition:background .2s,transform .1s}
.btn-gift:hover{background:var(--blue-d);transform:scale(1.02)}

/* ===== PIX ===== */
.pix-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:3rem}
.pix-card{background:linear-gradient(135deg,#FFFBEA,#FFF3C0);border:2px solid rgba(220,170,40,0.35);border-radius:18px;padding:1.4rem 1.1rem;text-align:center;cursor:pointer;display:block;text-decoration:none;transition:transform .15s,box-shadow .15s}
.pix-card:hover{transform:translateY(-3px);box-shadow:0 8px 20px rgba(180,130,0,0.15)}
.pix-val{font-family:'Fredoka One',cursive;font-size:1.7rem;color:var(--blue-dk);margin-bottom:4px}
.pix-desc{font-size:0.78rem;color:var(--muted);font-weight:600;line-height:1.4}
.pix-custom-box{background:linear-gradient(135deg,#FFFBEA,#FFF3C0);border:2px dashed rgba(220,170,40,0.45);border-radius:20px;padding:1.4rem 1.8rem;max-width:480px;margin:0 auto 1.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:0.7rem}
.pix-custom-row{display:flex;align-items:center;gap:0.5rem;width:100%;max-width:380px}
.pix-custom-prefix{font-family:'Fredoka One',cursive;font-size:1.2rem;color:var(--blue-dk)}
.pix-custom-input{flex:1;padding:0.65rem 0.9rem;border:2px solid rgba(74,168,208,0.3);border-radius:12px;font-family:'Fredoka One',cursive;font-size:1.2rem;color:var(--blue-dk);text-align:center;outline:none;transition:border-color .2s}
.pix-custom-input:focus{border-color:var(--blue)}
.pix-custom-hint{font-size:0.72rem;color:var(--muted);font-weight:600;font-style:italic}
.modal-qr-erro{padding:1rem;color:var(--muted);font-size:0.82rem;font-weight:600;text-align:center;line-height:1.4}
.pix-key-box{background:#EBF7FF;border:2px dashed rgba(74,168,208,0.4);border-radius:20px;padding:1.5rem 1.8rem;max-width:360px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:0.7rem}
.pix-k-lbl{font-size:0.68rem;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted);font-weight:700}
.pix-k-val{font-family:'Fredoka One',cursive;font-size:1.1rem;color:var(--blue-dk)}
.btn-copy{background:var(--blue);color:white;border:none;padding:0.55rem 1.6rem;border-radius:20px;font-family:'Fredoka One',cursive;font-size:0.9rem;cursor:pointer;letter-spacing:0.04em;transition:background .2s}
.btn-copy:hover{background:var(--blue-d)}

/* ===== MODALS ===== */
.modal-ov{display:none;position:fixed;inset:0;background:rgba(15,40,70,0.55);z-index:200;align-items:center;justify-content:center;padding:1rem}
.modal-ov.open{display:flex}
.modal-box{background:white;border-radius:24px;padding:2rem;max-width:380px;width:100%;text-align:center;position:relative;box-shadow:0 20px 60px rgba(0,0,0,0.2)}
.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--muted);line-height:1}
.modal-title{font-family:'Fredoka One',cursive;font-size:1.35rem;color:var(--blue-dk);margin-bottom:0.3rem}
.modal-sub{font-size:0.82rem;color:var(--muted);font-weight:600;margin-bottom:1.2rem}
.modal-qr{width:200px;height:200px;margin:0 auto 1rem;background:#EBF7FF;border-radius:16px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.modal-qr img{width:200px;height:200px;border-radius:16px}
.modal-val{font-family:'Fredoka One',cursive;font-size:2rem;color:var(--blue-dk);margin-bottom:0.3rem}
.modal-det{font-size:0.78rem;color:var(--muted);font-weight:600}
.modal-res{max-width:400px}
.modal-res h3{font-family:'Fredoka One',cursive;color:var(--blue-dk);font-size:1.4rem;margin-bottom:0.3rem}
.modal-res p{font-size:0.83rem;color:var(--muted);font-weight:600;margin-bottom:1.4rem}
.field{width:100%;padding:0.75rem 1rem;border:2px solid #D5E8F5;border-radius:14px;font-family:'Nunito',sans-serif;font-size:0.9rem;font-weight:600;margin-bottom:0.75rem;outline:none;color:var(--text);transition:border-color .2s}
.field:focus{border-color:var(--blue)}
textarea.field{height:80px;resize:none}
.btn-confirm{width:100%;background:var(--blue);color:white;border:none;padding:0.9rem;border-radius:14px;font-family:'Fredoka One',cursive;font-size:1.1rem;cursor:pointer;letter-spacing:0.04em;transition:background .2s}
.btn-confirm:hover{background:var(--blue-d)}

/* ===== FOOTER ===== */
footer{background:linear-gradient(160deg,var(--blue-dk) 0%,var(--blue-d) 100%);color:rgba(255,255,255,0.8);text-align:center;padding:4rem 1.5rem 3rem;position:relative;overflow:hidden}
.fc{position:absolute;pointer-events:none;opacity:0.07;background:white;border-radius:50px}
.fc1{top:-20px;left:-30px;width:200px;height:60px}
.fc1::before{content:'';position:absolute;width:80px;height:80px;background:white;border-radius:50%;top:-40px;left:40px}
.fc2{bottom:-20px;right:-20px;width:160px;height:50px}
.ft-title{font-family:'Fredoka One',cursive;font-size:1.8rem;color:var(--yellow);margin-bottom:0.6rem;letter-spacing:0.04em}
.ft-parents{font-size:0.92rem;letter-spacing:0.06em;opacity:0.82;margin-bottom:0.5rem;font-weight:600}
.ft-await{font-size:0.85rem;opacity:0.52;font-weight:600;margin-bottom:1.5rem}
.heart{display:inline-block;width:15px;height:13px;background:var(--pink);position:relative;transform:rotate(-45deg);margin:0 6px;vertical-align:middle}
.heart::before,.heart::after{content:'';width:15px;height:15px;background:var(--pink);border-radius:50%;position:absolute}
.heart::before{top:-8px;left:0}
.heart::after{top:0;right:-8px}
.ft-copy{font-size:0.7rem;opacity:0.28;font-weight:600;margin-top:1rem}

/* ===== RESPONSIVE ===== */
@media(max-width:720px){
  .hero-inner{flex-direction:column-reverse;gap:1rem}
  .stork-scene{width:220px;height:220px}
  .stork-img{width:220px;height:220px}
  .info-grid{grid-template-columns:1fr}
  .countdown{gap:0.35rem}
  .cnt{min-width:60px;padding:0.6rem 0.75rem}
  .cnt-n{font-size:1.5rem}
  section.light,section.soft{padding:3.5rem 1.2rem}
}
