*{
margin:0;
padding:0;
box-sizing:border-box;
}

body{
font-family:'Nunito',sans-serif;
background:linear-gradient(
135deg,
#ffd6f6,
#ffc2eb,
#f7b2ff,
#d6a8ff
);
min-height:100vh;
overflow-x:hidden;
color:#ffffff;
}

/* estrelas */

.star{
position:fixed;
color:white;
font-size:12px;
pointer-events:none;
animation:twinkle 2s infinite alternate;
}

@keyframes twinkle{
from{opacity:.2;}
to{opacity:1;}
}

/* corações */

.heart{
position:fixed;
font-size:24px;
animation:fall linear forwards;
pointer-events:none;
}

@keyframes fall{
to{
transform:translateY(110vh);
opacity:0;
}
}

header{
text-align:center;
padding:60px 20px;
}

.logo{
font-family:'Pacifico',cursive;
font-size:4rem;
color:white;
text-shadow:
0 0 10px #ff8fd1,
0 0 20px #ff8fd1,
0 0 40px #ff8fd1;
}

.subtitle{
font-size:1.3rem;
margin-top:15px;
}

.container{
width:90%;
max-width:1200px;
margin:auto;
}

.card{
background:rgba(255,255,255,.18);
backdrop-filter:blur(10px);
padding:30px;
border-radius:25px;
margin-bottom:30px;
box-shadow:
0 8px 25px rgba(255,94,188,.3);
border:1px solid rgba(255,255,255,.3);
}

.card h2{
margin-bottom:15px;
font-family:'Pacifico',cursive;
font-size:2rem;
}

.card p{
line-height:1.8;
}

/* galeria */

.gallery{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
gap:25px;
}

.polaroid{
background:white;
padding:10px;
border-radius:12px;
color:#333;
transform:rotate(-2deg);
box-shadow:0 5px 15px rgba(0,0,0,.15);
}

.polaroid img{
width:100%;
height:280px;
object-fit:cover;
border-radius:8px;
}

.polaroid p{
text-align:center;
margin-top:10px;
font-weight:bold;
}

/* contador */

#contador{
font-size:2rem;
text-align:center;
font-weight:bold;
}

/* botão */

button{
padding:15px 30px;
border:none;
border-radius:50px;
background:#ff5ebc;
color:white;
font-size:1rem;
cursor:pointer;
margin-top:20px;
transition:.3s;
}

button:hover{
transform:scale(1.05);
}

#mensagem{
margin-top:20px;
font-size:1.2rem;
font-weight:bold;
}

footer{
padding:50px;
text-align:center;
font-size:1rem;
}

.badges{
margin-top:20px;
font-size:2rem;
}
