/* =========================================================
   Mis 15 · Salma — Vintage botánico (crema + terracota)
   ========================================================= */
:root{
  --crema:#f5efe1;
  --crema-2:#efe6d2;
  --crema-3:#e9dcc2;
  --terracota:#9c4a38;
  --terracota-2:#b5603f;
  --terracota-claro:#c87a5c;
  --texto:#5e4a3a;
  --texto-suave:#8a755f;
  --verde:#869266;
  --sombra:0 14px 36px rgba(120,80,50,.16);
  --display:'Fraunces', serif;
  --texto-font:'Mulish', sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--texto-font);
  color:var(--texto);
  background:var(--crema);
  line-height:1.65;
  overflow-x:hidden;
}
section{padding:84px 22px;position:relative;overflow:hidden}

/* ---------- Tipografía común ---------- */
.section-title{
  font-family:var(--display);
  font-optical-sizing:auto;
  font-size:clamp(2rem,7vw,2.9rem);
  font-weight:500;
  text-align:center;
  color:var(--terracota);
  letter-spacing:.5px;
}
.section-title::after{
  content:"";display:block;width:54px;height:1.5px;margin:14px auto 0;
  background:var(--terracota-claro);opacity:.6;
}
.section-sub{
  text-align:center;font-style:italic;color:var(--texto-suave);
  font-family:var(--display);font-size:1.2rem;margin-top:6px;margin-bottom:38px;
}

/* ---------- Botánicos decorativos ---------- */
.botanic{position:absolute;width:180px;height:auto;opacity:.92;pointer-events:none;z-index:0}
.botanic-tl{top:-26px;left:-40px;transform:rotate(-18deg)}
.botanic-br{bottom:-34px;right:-44px;transform:rotate(150deg);width:150px;opacity:.8}
.botanic-side{top:10px;right:-46px;transform:rotate(35deg);width:140px;opacity:.8}
.botanic-flip{left:-46px;right:auto;transform:scaleX(-1) rotate(35deg)}
.botanic-center{position:static;display:block;margin:0 auto 6px;width:120px;transform:none;opacity:.9}

/* ---------- PORTADA ---------- */
.hero{
  min-height:100svh;display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(circle at 80% 15%, #f7f1e4, transparent 55%),
    radial-gradient(circle at 10% 85%, #efe5cf, transparent 50%),
    var(--crema);
}
.hero-inner{
  display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center;
  max-width:920px;width:100%;position:relative;z-index:2;
}
.hero-text{text-align:left}
.hero-pre{font-family:var(--display);font-style:italic;font-size:1.3rem;color:var(--texto-suave)}
.hero-name{
  font-family:var(--display);font-weight:600;
  font-size:clamp(3.5rem,12vw,6rem);line-height:.95;color:var(--terracota);
  margin:.05em 0 .1em;letter-spacing:1px;
}
.hero-date{font-family:var(--display);font-size:1.5rem;color:var(--texto);margin-bottom:26px}
.hero-photo{
  border-radius:14px;overflow:hidden;box-shadow:var(--sombra);
  border:6px solid #fff;rotate:2.5deg;aspect-ratio:3/4;
}
.hero-photo img{width:100%;height:100%;object-fit:cover;display:block}
.hero-scroll{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);text-align:center;z-index:2}
.hero-scroll span{display:block;width:22px;height:35px;margin:0 auto 6px;border:2px solid var(--terracota-claro);border-radius:12px;position:relative}
.hero-scroll span::after{content:"";position:absolute;top:6px;left:50%;transform:translateX(-50%);width:3px;height:7px;background:var(--terracota);border-radius:2px;animation:scrolldot 1.8s infinite}
@keyframes scrolldot{0%{opacity:0;top:6px}50%{opacity:1}100%{opacity:0;top:18px}}
.hero-scroll p{font-size:.68rem;letter-spacing:2px;color:var(--texto-suave);text-transform:uppercase}

/* ---------- FRASE ---------- */
.quote{max-width:660px;margin:0 auto;text-align:center;background:var(--crema-2)}
.quote-text{font-family:var(--display);font-style:italic;font-size:clamp(1.3rem,4.5vw,1.7rem);color:var(--texto)}
.quote-sign{font-family:var(--display);font-size:2.4rem;color:var(--terracota);margin-top:16px}

/* ---------- CUENTA REGRESIVA ---------- */
.countdown-grid{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;max-width:560px;margin:0 auto}
.cd-box{background:#fff;border:1px solid var(--crema-3);border-radius:14px;padding:18px 12px;min-width:74px;text-align:center;box-shadow:var(--sombra)}
.cd-num{display:block;font-family:var(--display);font-weight:600;font-size:2.5rem;color:var(--terracota);line-height:1}
.cd-label{font-size:.7rem;letter-spacing:2px;text-transform:uppercase;color:var(--texto-suave)}

/* ---------- GALERÍA ---------- */
.gallery{background:var(--crema-2)}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;max-width:900px;margin:0 auto;grid-auto-flow:dense}
.g-item{overflow:hidden;border-radius:12px;box-shadow:var(--sombra);border:5px solid #fff;aspect-ratio:1/1}
.g-item.g-tall{aspect-ratio:3/4}
.g-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.g-item:hover img{transform:scale(1.07)}
@media(min-width:640px){.g-item.g-tall{grid-row:span 2}}

/* ---------- DRESS CODE ---------- */
.dresscode{text-align:center;background:var(--crema)}
.dc-title{font-family:var(--display);font-weight:600;font-size:clamp(2.6rem,11vw,4.5rem);color:var(--terracota);line-height:1}
.dc-row{display:flex;align-items:center;justify-content:center;gap:24px;margin-top:18px;flex-wrap:wrap}
.dc-svg{width:88px;height:auto}
.dc-icons{display:flex;gap:10px;align-items:flex-end}
.dc-label{font-family:var(--display);font-size:2rem;color:var(--texto)}

/* ---------- DETALLES ---------- */
.details{background:var(--crema-2)}
.details-list{list-style:none;max-width:560px;margin:0 auto}
.details-list li{display:flex;gap:18px;padding:18px 4px;border-bottom:1px solid var(--crema-3);align-items:baseline}
.details-list li:last-child{border-bottom:none}
.dt-key{font-family:var(--display);font-style:italic;font-size:1.25rem;color:var(--terracota);min-width:84px;flex:none}
.dt-val{color:var(--texto);font-size:1rem}

/* ---------- MÚSICA ---------- */
.music{text-align:center}
.spotify-wrap{max-width:560px;margin:0 auto;box-shadow:var(--sombra);border-radius:16px;overflow:hidden;background:#fff}

/* ---------- UBICACIÓN ---------- */
.location{text-align:center;background:var(--crema-2)}
.map-wrap{max-width:720px;margin:0 auto 22px;border-radius:14px;overflow:hidden;box-shadow:var(--sombra);border:5px solid #fff}
.map-wrap iframe{display:block}

/* ---------- BOTONES ---------- */
.btn{display:inline-block;font-family:var(--texto-font);font-weight:600;letter-spacing:.6px;padding:13px 30px;border-radius:40px;cursor:pointer;text-decoration:none;font-size:.92rem;transition:transform .25s, box-shadow .25s, background .25s, color .25s;border:none}
.btn-outline{border:1.5px solid var(--terracota);color:var(--terracota);background:transparent}
.btn-outline:hover{background:var(--terracota);color:var(--crema);transform:translateY(-2px)}
.btn-fill{background:var(--terracota);color:var(--crema);width:100%;font-size:1rem;box-shadow:0 8px 20px rgba(156,74,56,.25)}
.btn-fill:hover{background:var(--terracota-2);transform:translateY(-2px)}

/* ---------- RSVP ---------- */
.rsvp{text-align:center}
.rsvp-form{max-width:470px;margin:0 auto;background:#fff;border:1px solid var(--crema-3);border-radius:18px;padding:30px 24px;box-shadow:var(--sombra);position:relative;z-index:2}
.field{margin-bottom:18px;text-align:left}
.field label{display:block;font-size:.78rem;letter-spacing:1px;color:var(--texto-suave);margin-bottom:6px;text-transform:uppercase}
.field .optional{text-transform:none;letter-spacing:0;font-style:italic;opacity:.7}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border-radius:10px;border:1px solid var(--crema-3);background:var(--crema);color:var(--texto);font-family:var(--texto-font);font-size:1rem}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--terracota-claro);box-shadow:0 0 0 3px rgba(200,122,92,.18)}
.field input::placeholder,.field textarea::placeholder{color:#bcae98}
.form-msg{text-align:center;margin-top:14px;font-size:.92rem;min-height:1.2em}
.form-msg.ok{color:var(--verde)}
.form-msg.error{color:#c0392b}

/* ---------- CIERRE ---------- */
.closing{text-align:center;padding-bottom:64px;background:var(--crema)}
.closing-text{font-family:var(--display);font-style:italic;font-size:1.35rem;color:var(--texto-suave)}
.closing-name{font-family:var(--display);font-weight:600;font-size:clamp(3rem,13vw,4.6rem);color:var(--terracota);line-height:1.05}
.closing-hashtag{letter-spacing:2px;color:var(--texto-suave);margin-top:10px;font-size:.9rem}

/* ---------- Animación reveal ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s ease, transform .9s ease}
.reveal.visible{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:620px){
  .hero-inner{grid-template-columns:1fr;text-align:center;gap:24px}
  .hero-text{text-align:center}
  .hero-photo{max-width:280px;margin:0 auto;rotate:0deg}
  .botanic{width:120px}
  .botanic-tl{left:-34px;top:-18px}
}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation:none !important}
}
