/* Mobile-first styles for Baby Shower Sara Natalia */
:root{
  --rosa:#ffb2cb;
  --rosa-suave:#ffd6e7;
  --rosa-fuerte:#ff79ab;
  --marron:#9d5a70;
  --gris:#6b6b6b;
  --blanco:#fff;
  --negro:#111;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif; background:var(--rosa-suave); color:#402633;}
img{max-width:100%;display:block}

.container{width:100%;max-width:960px;margin:0 auto;padding:16px}

.header{
  text-align:center;
  padding:22px 16px 8px;
  background:linear-gradient(180deg, var(--rosa-suave), #fff 70%);
  position:relative;
  overflow:hidden;
}
.header .badge{
  display:inline-block;
  background:var(--rosa-fuerte);
  color:#fff;
  padding:6px 12px;
  border-radius:999px;
  font-size:12px;
  letter-spacing:.5px;
  box-shadow:0 6px 18px rgba(255,121,171,.35);
}
.header h1{
  font-size:30px;
  margin:10px 0 6px;
  letter-spacing:.3px;
}
.header p.sub{
  margin:0;
  color:#5b2f3e;
}

.hero-card{
  margin:18px auto;
  background:#fff;
  border-radius:22px;
  padding:16px;
  box-shadow:0 10px 30px rgba(157,90,112,.15);
  position:relative;
  overflow:hidden;
}
.hero-top{
  display:flex;align-items:center;gap:12px;
}
.hero-top img{
  width:88px;height:88px;border-radius:16px;
  background:var(--rosa);padding:8px;
}
.hero-info h2{
  margin:0 0 6px;font-size:22px;
}
.kv{
  display:flex;flex-wrap:wrap;gap:10px;font-size:14px;color:#6b3a4a;
}
.kv span{background:var(--rosa-suave);padding:6px 10px;border-radius:999px}

.actions{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.btn{
  appearance:none;border:0;cursor:pointer;text-decoration:none;
  padding:12px 16px;border-radius:14px;font-weight:600;font-size:15px;
  display:inline-flex;align-items:center;gap:10px;
  transition:transform .08s ease, box-shadow .2s ease, background .2s ease;
}
.btn-primary{background:var(--rosa-fuerte);color:#fff;box-shadow:0 8px 20px rgba(255,121,171,.35)}
.btn-primary:active{transform:translateY(1px)}
.btn-outline{background:#fff;border:2px solid var(--rosa-fuerte);color:#9d3d62}
.btn-outline:active{transform:translateY(1px)}

.countdown{
  display:flex;justify-content:space-between;gap:10px;margin:16px 0 6px;
}
.countdown .item{flex:1;background:#fff;border-radius:16px;padding:10px;text-align:center;box-shadow:0 10px 24px rgba(157,90,112,.12)}
.countdown .num{display:block;font-size:22px;font-weight:800}
.countdown .lbl{font-size:11px;letter-spacing:.6px;color:#8b5568;text-transform:uppercase}

.card{
  background:#fff;border-radius:20px;padding:16px;margin:16px 0;
  box-shadow:0 10px 24px rgba(157,90,112,.12)
}
.card h3{margin:0 0 10px;font-size:20px}
.card p{margin:0;color:#5c3a47;line-height:1.5}

.grid-photos{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px
}
.photo{border-radius:14px;overflow:hidden;position:relative;background:linear-gradient(135deg, var(--rosa), var(--rosa-fuerte));height:120px}
.photo:after{
  content:"";position:absolute;inset:0;background-image:url('./assets/teddy.svg');
  background-repeat:no-repeat;background-position:center;background-size:110px;
  opacity:.25;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))
}

/* ---------- Galería ---------- */
.grid-photos {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 18px;
}

.photo {
  border-radius: 12px;
  overflow: hidden;
}

.photo img {
  display: block;
  width: 100%;
  height: 220px;      /* 👈 Ajusta la altura de la miniatura */
  object-fit: cover;  /* recorta un poquito pero mantiene proporción */
  border-radius: 12px;
  cursor: zoom-in;
}

/* ---------- Lightbox ---------- */
.lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.88);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  padding: 32px;
}

.lightbox.active { display: flex; }

.lightbox img {
  max-width: 96vw;
  max-height: 90vh;
  object-fit: contain;
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}

/* Botones */
.lb-close, .lb-prev, .lb-next {
  position: absolute;
  background: rgba(255,255,255,.9);
  border: 0;
  width: 42px;
  height: 42px;
  line-height: 42px;
  text-align: center;
  border-radius: 999px;
  font-size: 26px;
  cursor: pointer;
  user-select: none;
}

.lb-close { top: 20px; right: 20px; }
.lb-prev  { left: 20px;  top: 50%; transform: translateY(-50%); }
.lb-next  { right: 20px; top: 50%; transform: translateY(-50%); }
.lb-close:hover, .lb-prev:hover, .lb-next:hover { background: #fff; }


.badge-inline{
  display:inline-block;background:var(--rosa-suave);padding:6px 10px;border-radius:999px;margin-right:8px
}

.footer{
  text-align:center;color:#854a61;padding:30px 10px 60px;
}

.music-toggle{
  position:fixed;right:14px;bottom:20px;z-index:50;
  background:#fff;border:2px solid var(--rosa-fuerte);color:#9d3d62;
  box-shadow:0 10px 22px rgba(157,90,112,.2);border-radius:999px;
  padding:10px 14px;display:flex;align-items:center;gap:8px;font-weight:700
}
.music-toggle .dot{width:10px;height:10px;border-radius:50%;background:#bbb}
.music-toggle.playing .dot{background:#38d39f;box-shadow:0 0 0 6px rgba(56,211,159,.2)}

.floating{
  position:fixed;pointer-events:none;inset:0;overflow:hidden;z-index:0
}
.floating span{
  position:absolute;bottom:-40px;opacity:.6;animation:rise 10s linear infinite;
  background:var(--rosa-fuerte);width:10px;height:10px;border-radius:50%;filter:blur(0.3px)
}
@keyframes rise{
  from{transform:translateY(0) translateX(0) scale(0.8)}
  to{transform:translateY(-110vh) translateX(40px) scale(1.2)}
}

/* Desktop tweaks */
@media(min-width:768px){
  .header h1{font-size:40px}
  .hero-top img{width:110px;height:110px}
  .countdown .num{font-size:28px}
  .grid-photos{grid-template-columns:repeat(4,1fr)}
}

/* ===== Custom cursive split title ===== */
.title-split{display:flex;flex-direction:column;align-items:center;gap:2px;margin:10px 0 6px}
.title-split .t1{font-family:"Dancing Script", cursive;font-size:38px;line-height:1;color:#9d5a70;text-shadow:0 2px 10px rgba(157,90,112,.15)}
.title-split .t2{font-family:"Great Vibes", cursive;font-size:50px;line-height:1;color:#a55b73;letter-spacing:.5px}

/* ===== Scroll reveal animations ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}

.reveal .item{transition:transform .6s ease .1s, opacity .6s ease .1s}
.reveal.in .item{opacity:1;transform:none}


/* Imagen de osita debajo del título */
.osita-img{
  width:160px;
  max-width:60%;
  margin:10px auto 0;
  display:block;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.15));
}


/* Texto de nombres de los papás en cursiva */
.parents{
  margin-top:10px;
  font-size: 30px;
  font-weight: 700;
  color:#5b2f3e;
  text-align:center;
  font-style:italic;
  font-family:'Dancing Script', cursive;
}
.parents strong{
  color:#9d5a70;
  font-size: 30px;
  font-weight: 700;
}
