:root{--red:#b21f2d;--red-dark:#7b1f2a;--denim:#1f5f9f;--sky:#8bd3ff;--yellow:#ffd166;--cream:#fff8e8;--paper:#fffdf6;--brown:#8a5527;--ink:#2a1d1b;--muted:#715f56;--line:rgba(122,69,33,.18);--shadow:0 24px 60px rgba(69,35,20,.16);--soft-shadow:0 16px 34px rgba(69,35,20,.09);--max:1120px;--header:72px}*{box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--header) + 18px)}body{margin:0;color:var(--ink);font-family:Fredoka,Montserrat,system-ui,sans-serif;background:radial-gradient(circle at 10% 8%,rgba(255,209,102,.35),transparent 25%),radial-gradient(circle at 95% 15%,rgba(139,211,255,.42),transparent 24%),linear-gradient(180deg,#eaf8ff 0%,#fff8e8 42%,#fffdf6 100%);line-height:1.6;padding-bottom:78px;overflow-x:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button,input,select,textarea{font:inherit}.container{width:min(var(--max),calc(100% - 32px));margin-inline:auto}.sky-bg{position:fixed;inset:0;z-index:-3;pointer-events:none;overflow:hidden}.cloud{position:absolute;width:180px;height:54px;border-radius:999px;background:rgba(255,255,255,.86);filter:drop-shadow(0 12px 18px rgba(31,95,159,.08));animation:floatCloud 18s ease-in-out infinite}.cloud:before,.cloud:after{content:"";position:absolute;border-radius:50%;background:inherit}.cloud:before{width:78px;height:78px;left:24px;top:-34px}.cloud:after{width:96px;height:96px;right:22px;top:-48px}.cloud-a{top:118px;left:-46px}.cloud-b{top:310px;right:-40px;transform:scale(.82);animation-delay:-6s}.cloud-c{top:70%;left:8%;transform:scale(.62);animation-delay:-10s;opacity:.68}@keyframes floatCloud{0%,100%{transform:translateX(0)}50%{transform:translateX(28px)}}.party-header{position:sticky;top:0;z-index:50;background:rgba(255,248,232,.86);backdrop-filter:blur(16px);box-shadow:0 10px 28px rgba(69,35,20,.08)}.party-nav{width:min(var(--max),calc(100% - 32px));margin:auto;height:var(--header);display:flex;align-items:center;justify-content:space-between;gap:16px}.brand{display:inline-flex;align-items:center;gap:10px;font-weight:900;color:var(--red-dark)}.brand img{width:38px;height:38px;border-radius:50%}.nav-links{display:flex;align-items:center;gap:4px}.nav-links a{padding:10px 12px;border-radius:999px;color:rgba(42,29,27,.74);font-size:.76rem;text-transform:uppercase;letter-spacing:.06em;font-weight:900}.nav-links a:hover{background:rgba(255,209,102,.35);color:var(--red-dark)}.nav-links .nav-cta{background:var(--red);color:#fff}.menu-btn{display:none;width:44px;height:44px;border:0;border-radius:50%;background:var(--red)}.menu-btn span{display:block;width:18px;height:2px;background:#fff;margin:4px auto;border-radius:99px}.hero{min-height:calc(100svh - var(--header));position:relative;display:grid;place-items:center;padding:clamp(58px,8vw,105px) 0 82px;overflow:hidden}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.22) 50%,transparent 50%) 0 0/120px 120px,radial-gradient(circle at 74% 20%,rgba(255,209,102,.4),transparent 25%),radial-gradient(circle at 22% 74%,rgba(178,31,45,.13),transparent 28%);z-index:-2}.rope{position:absolute;left:-8px;right:-8px;height:18px;background:repeating-linear-gradient(115deg,#b87935 0 10px,#8a5527 10px 18px);box-shadow:0 6px 0 rgba(138,85,39,.16);z-index:2}.rope-top{top:0}.hero-grid{width:min(var(--max),calc(100% - 32px));margin:auto;display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,410px);align-items:center;gap:clamp(34px,7vw,82px)}.badge{display:inline-flex;margin:0 0 16px;padding:9px 15px;border:2px dashed rgba(178,31,45,.36);border-radius:999px;background:rgba(255,255,255,.62);color:var(--red-dark);font-size:.82rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.invite-line{margin:0;color:var(--denim);font-weight:900;letter-spacing:.08em;text-transform:uppercase}.hero h1{margin:8px 0 14px;max-width:770px;color:var(--red-dark);font-family:Rye,Fredoka,serif;font-size:clamp(3.1rem,8.6vw,7rem);line-height:.92;text-shadow:3px 4px 0 rgba(255,209,102,.75)}.phrase{width:min(660px,100%);margin:0;color:var(--ink);font-size:clamp(1.35rem,3vw,2.15rem);line-height:1.25;font-weight:700}.hero-date{display:grid;width:min(520px,100%);margin:26px 0 0;padding:18px;border-radius:26px;background:rgba(255,255,255,.74);border:1px solid var(--line);box-shadow:var(--soft-shadow)}.hero-date span{color:var(--denim);text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;font-weight:900}.hero-date strong{color:var(--red-dark);font-size:clamp(1.35rem,3vw,2rem);line-height:1.15}.hero-date em{color:var(--brown);font-style:normal;font-weight:900}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:50px;padding:14px 22px;border-radius:999px;border:0;font-weight:900;cursor:pointer;transition:transform .22s ease,box-shadow .22s ease,background .22s ease;text-align:center}.btn:hover{transform:translateY(-2px)}.btn-primary{background:linear-gradient(135deg,var(--red),#e64956);color:#fff;box-shadow:0 16px 34px rgba(178,31,45,.26)}.btn-light{background:rgba(255,255,255,.82);color:var(--red-dark);border:1px solid var(--line)}.btn.full{width:100%}.wanted-card{position:relative;padding:18px 18px 26px;border-radius:34px;background:linear-gradient(180deg,rgba(255,248,232,.96),rgba(255,252,245,.96));border:3px solid #8a5527;box-shadow:var(--shadow);text-align:center;transform:rotate(1.2deg)}.wanted-card:before{content:"";position:absolute;inset:9px;border:2px dashed rgba(138,85,39,.38);border-radius:24px;pointer-events:none}.wanted-top{position:relative;z-index:1;margin:0 auto 12px;color:var(--brown);font-family:Rye,serif;font-size:clamp(1.05rem,2vw,1.3rem)}.photo-frame{position:relative;overflow:hidden;border-radius:24px;background:radial-gradient(circle at 50% 30%,#fff 0 16%,transparent 17%),linear-gradient(135deg,rgba(139,211,255,.75),rgba(255,209,102,.75));border:5px solid #fff;box-shadow:inset 0 0 0 1px var(--line),0 14px 30px rgba(69,35,20,.12)}.main-photo{aspect-ratio:4/5}.photo-frame img,.photo-slot img{width:100%;height:100%;object-fit:cover}.photo-empty{position:absolute;inset:0;display:grid;place-items:center;align-content:center;gap:6px;text-align:center;color:var(--red-dark);padding:22px}.photo-empty span{font-size:3rem}.photo-empty strong{font-size:1.1rem}.photo-empty small{color:var(--muted)}.wanted-card h2{position:relative;z-index:1;margin:18px 0 6px;color:var(--red-dark);font-size:clamp(1.5rem,3vw,2rem);line-height:1.05}.wanted-card p{position:relative;z-index:1;margin:0;color:var(--muted)}.sheriff-star{position:absolute;right:-16px;top:48%;width:72px;height:72px;display:grid;place-items:center;color:var(--red-dark);font-weight:900;font-size:2rem;background:var(--yellow);clip-path:polygon(50% 0%,61% 28%,91% 18%,78% 49%,100% 69%,68% 69%,50% 100%,32% 69%,0 69%,22% 49%,9% 18%,39% 28%);filter:drop-shadow(0 10px 18px rgba(69,35,20,.18))}.scroll-cue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);width:44px;height:44px;display:grid;place-items:center;border-radius:50%;background:#fff;color:var(--red);font-weight:900;box-shadow:var(--soft-shadow);animation:bounce 1.4s infinite}@keyframes bounce{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}.section{position:relative;padding:clamp(68px,8vw,112px) 0}.center{text-align:center;max-width:780px;margin-inline:auto}.section-tag{margin:0 0 10px;color:var(--red);font-weight:900;text-transform:uppercase;letter-spacing:.13em;font-size:.8rem}h2{margin:0;color:var(--red-dark);font-size:clamp(2.4rem,6vw,4.6rem);line-height:.96}.center p,.story-copy p,.info-card p,.fun-card p,.schedule-title p,.map-card p,.rsvp-copy p,.final-section p{color:var(--muted);font-size:clamp(1rem,2vw,1.12rem)}.countdown-section{background:linear-gradient(180deg,rgba(255,255,255,.42),rgba(255,248,232,.72))}.countdown{width:min(760px,calc(100% - 32px));margin:34px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.countdown div{padding:clamp(18px,4vw,32px) 8px;border-radius:28px;background:#fff;border:1px solid var(--line);box-shadow:var(--soft-shadow);text-align:center}.countdown strong{display:block;color:var(--denim);font-size:clamp(2.3rem,8vw,5.2rem);line-height:.82}.countdown span{display:block;margin-top:7px;color:var(--red);font-size:.78rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.details-grid,.fun-grid,.rsvp-grid,.story-grid,.schedule-wrap{display:grid;gap:22px}.details-grid{grid-template-columns:repeat(3,1fr)}.info-card,.fun-card,.rsvp-form,.map-card,.schedule,.story-copy,.photo-pair{border-radius:30px;background:rgba(255,255,255,.78);border:1px solid var(--line);box-shadow:var(--soft-shadow)}.info-card,.fun-card{padding:clamp(24px,4vw,36px)}.info-icon,.fun-card span{width:66px;height:66px;display:grid;place-items:center;border-radius:50%;background:var(--denim);color:#fff;font-size:2rem;box-shadow:0 12px 24px rgba(31,95,159,.18)}.info-card h3,.fun-card h3{margin:18px 0 8px;color:var(--red-dark);font-size:1.35rem;line-height:1.12}.info-card a{display:inline-flex;margin-top:8px;color:var(--red);font-weight:900}.story-section{background:linear-gradient(180deg,rgba(255,248,232,.68),rgba(255,255,255,.58)),radial-gradient(circle at 80% 40%,rgba(139,211,255,.28),transparent 28%)}.story-grid{grid-template-columns:.95fr 1.05fr;align-items:center}.story-copy{padding:clamp(26px,5vw,46px)}.photo-pair{position:relative;padding:20px;min-height:420px}.photo-slot{margin:0;position:absolute;overflow:hidden;border-radius:28px;background:linear-gradient(135deg,#fff,#ffe8ec);border:6px solid #fff;box-shadow:var(--shadow)}.photo-slot:first-child{left:24px;top:24px;width:56%;aspect-ratio:4/5;transform:rotate(-4deg)}.photo-slot.second{right:24px;bottom:24px;width:54%;aspect-ratio:4/5;transform:rotate(5deg)}.photo-slot figcaption{position:absolute;inset:0;display:grid;place-items:center;align-content:center;gap:6px;padding:20px;text-align:center;color:var(--red-dark);background:radial-gradient(circle at 50% 22%,rgba(255,255,255,.84),transparent 26%),linear-gradient(135deg,rgba(139,211,255,.75),rgba(255,209,102,.75))}.photo-slot strong{font-size:1.25rem}.photo-slot span{color:var(--muted);font-size:.82rem}.fun-section{background:#fffdf6}.fun-grid{grid-template-columns:repeat(4,1fr);margin-top:34px}.fun-card{position:relative;overflow:hidden}.fun-card:after{content:"";position:absolute;right:-40px;bottom:-55px;width:130px;height:130px;background:rgba(255,209,102,.28);border-radius:50%}.fun-card>*{position:relative;z-index:1}.map-section{background:#fffdf6}.map-card{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:clamp(26px,5vw,46px);background:linear-gradient(135deg,rgba(255,255,255,.88),rgba(255,248,232,.86)),linear-gradient(90deg,transparent 49%,rgba(31,95,159,.12) 49% 51%,transparent 51%)}.rsvp-section{background:linear-gradient(135deg,var(--red-dark),#a9333f);color:#fff}.rsvp-grid{grid-template-columns:.88fr 1.12fr;align-items:start}.rsvp-copy h2,.rsvp-copy .section-tag{color:#fff}.rsvp-copy p{color:rgba(255,255,255,.82)}.no-faltes{display:inline-flex;margin-top:20px;padding:14px 18px;border-radius:999px;background:var(--yellow);color:var(--red-dark);font-weight:900;box-shadow:0 14px 30px rgba(0,0,0,.12)}.rsvp-form{padding:clamp(22px,4vw,34px);background:rgba(255,255,255,.92)}.rsvp-form label{display:grid;gap:8px;margin-bottom:14px;color:var(--ink);font-weight:900}.rsvp-form input,.rsvp-form select,.rsvp-form textarea{width:100%;border:1px solid var(--line);border-radius:18px;padding:14px 15px;background:#fff;outline:none;color:var(--ink)}.rsvp-form input:focus,.rsvp-form select:focus,.rsvp-form textarea:focus{border-color:rgba(178,31,45,.45);box-shadow:0 0 0 4px rgba(178,31,45,.1)}.final-section{padding:clamp(72px,9vw,120px) 0;text-align:center;background:radial-gradient(circle at 50% 18%,rgba(255,209,102,.42),transparent 24%),linear-gradient(180deg,#fff8e8,#fffdf6)}.final-section h2{font-family:Rye,serif;text-shadow:3px 4px 0 rgba(255,209,102,.62)}.floating-confirm{position:fixed;z-index:60;left:50%;bottom:12px;transform:translateX(-50%);width:min(620px,calc(100% - 24px));display:flex;align-items:center;justify-content:space-between;gap:14px;padding:9px 10px 9px 16px;border-radius:18px;background:rgba(123,31,42,.96);color:#fff;box-shadow:0 18px 46px rgba(69,35,20,.24);backdrop-filter:blur(18px)}.floating-confirm strong{display:block;line-height:1.1}.floating-confirm span{display:block;color:rgba(255,255,255,.74);font-size:.78rem}.floating-confirm a{flex:0 0 auto;padding:10px 16px;border-radius:999px;background:var(--yellow);color:var(--red-dark);font-weight:900}.reveal{opacity:0;transform:translateY(42px) scale(.985);filter:blur(7px);transition:opacity 1.35s cubic-bezier(.16,1,.3,1),transform 1.35s cubic-bezier(.16,1,.3,1),filter 1.35s cubic-bezier(.16,1,.3,1);will-change:opacity,transform,filter}.reveal.visible{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}.delay-1{transition-delay:.22s}.delay-2{transition-delay:.42s}.delay-3{transition-delay:.62s}.hero-copy.reveal{transition-duration:1.55s}.wanted-card.reveal{transition-duration:1.7s}.info-card.reveal,.fun-card.reveal,.photo-pair.reveal,.story-copy.reveal{transition-duration:1.28s}
/* Animación premium de entrada lenta */
.hero-copy > *{opacity:0;transform:translateY(18px);animation:softRise 1.15s cubic-bezier(.16,1,.3,1) forwards}
.hero-copy > *:nth-child(1){animation-delay:.18s}
.hero-copy > *:nth-child(2){animation-delay:.34s}
.hero-copy > *:nth-child(3){animation-delay:.50s}
.hero-copy > *:nth-child(4){animation-delay:.66s}
.hero-copy > *:nth-child(5){animation-delay:.82s}
.hero-copy > *:nth-child(6){animation-delay:.98s}
@keyframes softRise{to{opacity:1;transform:translateY(0)}}


/* Fotos reales de Gabriela */
.photo-frame.has-image .photo-empty{display:none}
.photo-slot.has-image figcaption{
  inset:auto 12px 12px 12px;
  display:block;
  padding:10px 12px;
  border-radius:16px;
  background:rgba(123,31,42,.82);
  color:#fff;
  backdrop-filter:blur(10px);
}
.photo-slot.has-image figcaption strong{display:block;font-size:.92rem;line-height:1}
.photo-slot.has-image figcaption span{display:block;color:rgba(255,255,255,.78);font-size:.68rem;margin-top:2px}
.photo-slot.is-missing figcaption{
  inset:0;
  display:grid;
  place-items:center;
  align-content:center;
  gap:6px;
  padding:20px;
  text-align:center;
  color:var(--red-dark);
  background:radial-gradient(circle at 50% 22%,rgba(255,255,255,.84),transparent 26%),linear-gradient(135deg,rgba(139,211,255,.75),rgba(255,209,102,.75));
}
.main-photo img{
  filter:saturate(1.04) contrast(1.02);
}

@media(max-width:980px){.nav-links{position:fixed;inset:var(--header) 12px auto 12px;display:grid;gap:6px;padding:12px;border-radius:22px;background:rgba(255,248,232,.98);box-shadow:var(--shadow);transform:translateY(-12px);opacity:0;pointer-events:none;transition:.24s ease}body.menu-open .nav-links{opacity:1;pointer-events:auto;transform:none}.nav-links a{text-align:center;padding:13px}.menu-btn{display:block}.hero-grid,.story-grid,.schedule-wrap,.rsvp-grid{grid-template-columns:1fr}.hero{text-align:center}.hero-date{margin-inline:auto}.hero-actions{justify-content:center}.wanted-card{width:min(430px,100%);margin-inline:auto}.details-grid,.fun-grid{grid-template-columns:repeat(2,1fr)}.schedule-title{position:static;text-align:center}}@media(max-width:640px){:root{--header:66px}.container,.party-nav,.hero-grid{width:min(100% - 24px,var(--max))}.hero h1{font-size:clamp(2.6rem,15vw,4.5rem)}.phrase{font-size:1.24rem}.hero-actions{flex-direction:column;align-items:stretch}.btn{width:100%}.countdown{gap:8px;width:min(100% - 24px,760px)}.countdown div{padding-inline:3px;border-radius:18px}.countdown strong{font-size:clamp(1.9rem,13vw,3rem)}.details-grid,.fun-grid{grid-template-columns:1fr}.schedule-item{grid-template-columns:1fr;text-align:center}.schedule-item i{margin-inline:auto}.map-card{display:grid;text-align:center}.floating-confirm div span{display:none}.floating-confirm a{padding-inline:14px}}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.reveal{opacity:1;transform:none}}

/* Corrección móvil: las fotos pasan de collage a carrusel deslizable */
@media(max-width:640px){
  .photo-pair{
    min-height:auto;
    display:flex;
    gap:16px;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    padding:16px 16px 22px;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }

  .photo-pair::-webkit-scrollbar{
    display:none;
  }

  .photo-slot,
  .photo-slot:first-child,
  .photo-slot.second{
    position:relative;
    inset:auto;
    left:auto;
    right:auto;
    top:auto;
    bottom:auto;
    width:auto;
    min-width:82%;
    flex:0 0 82%;
    aspect-ratio:4/5;
    transform:none;
    scroll-snap-align:center;
  }

  .photo-slot:first-child{
    margin-left:0;
  }

  .photo-slot.second{
    margin-right:4px;
  }

  .photo-slot.has-image figcaption{
    inset:auto 10px 10px 10px;
  }
}
