*{margin:0;padding:0;box-sizing:border-box}
:root{
  --white:#f9f7f4;
  --cream:#f2ede6;
  --sage:#7a8c6e;
  --sage-light:#a8b89a;
  --sage-dark:#4e6245;
  --terra:#b07050;
  --terra-light:#c8907a;
  --ink:#2a2420;
  --ink2:#4a3e38;
  --muted:#7a6e68;
  --border:rgba(122,140,110,0.30);
}
html{scroll-behavior:smooth}
body{
  background:#e8e4dc;
  min-height:100vh;
  display:flex;
  justify-content:center;
  padding:32px 0;
  font-family:'Jost',sans-serif;
}

/* ═══ CARD ═══ */
.wrap{
  width:100%;
  max-width:430px;
  background:var(--white);
  position:relative;
  overflow:hidden;
  box-shadow:0 24px 80px rgba(0,0,0,0.12),0 4px 20px rgba(0,0,0,0.07);
}

/* ═══ HERO ═══ */
.hero{
  padding:64px 40px 40px;
  text-align:center;
  position:relative;
  background:var(--white);
}
.hero-olive-top{
  display:block;
  width:180px;
  margin:0 auto 28px;
  opacity:0.85;
}
.hero-eyebrow{
  font-family:'Jost',sans-serif;
  font-size:10px;
  letter-spacing:4px;
  text-transform:uppercase;
  color:var(--sage);
  margin-bottom:20px;
  display:block;
}
.hero-names{
  margin-bottom:16px;
}
.name-line{
  font-family:'Cormorant Garamond',serif;
  font-size:58px;
  font-weight:400;
  line-height:1.1;
  color:var(--ink);
  display:block;
  overflow:hidden;
  white-space:nowrap;
}
.name-amp{
  font-family:'Cormorant Garamond',serif;
  font-size:24px;
  font-style:italic;
  color:var(--sage);
  display:block;
  margin:6px 0;
  opacity:0;
}
.hero-date{
  font-family:'Jost',sans-serif;
  font-size:11px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--muted);
  margin-top:20px;
  opacity:0;
}
.hero-divider{
  width:48px;
  height:1px;
  background:var(--sage-light);
  margin:24px auto 0;
  opacity:0.6;
}

@keyframes reveal{from{width:0}to{width:100%}}
@keyframes fadein{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.name1{animation:reveal 1s steps(24,end) 0.3s forwards;width:0;}
.name-amp{animation:fadein 0.6s ease 1.4s forwards;}
.name2{animation:reveal 1s steps(24,end) 2s forwards;width:0;}
.hero-date{animation:fadein 0.6s ease 3.2s forwards;}

/* ═══ SECTIONS ═══ */
.section{
  padding:44px 40px;
  position:relative;
  border-top:1px solid rgba(122,140,110,0.12);
}
.section--center{text-align:center;}
.section--cream{background:var(--cream);}

.section-eyebrow{
  font-family:'Jost',sans-serif;
  font-size:9px;
  letter-spacing:4px;
  text-transform:uppercase;
  color:var(--sage);
  display:block;
  margin-bottom:14px;
}
.section-title{
  font-family:'Cormorant Garamond',serif;
  font-size:36px;
  font-weight:400;
  color:var(--ink);
  display:block;
  margin-bottom:16px;
  line-height:1.2;
}
.section-title--sm{font-size:28px;}
.body-text{
  font-family:'Jost',sans-serif;
  font-size:14px;
  line-height:1.9;
  color:var(--ink2);
  font-weight:300;
}
.detail-text{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:16px;
  color:var(--ink2);
  line-height:1.8;
}

/* ═══ DIVIDER OLIVO ═══ */
.olive-divider{
  display:block;
  width:120px;
  margin:0 auto;
  opacity:0.55;
}
.thin-divider{
  width:40px;
  height:1px;
  background:var(--sage-light);
  margin:20px auto;
  opacity:0.5;
}

/* ═══ VENUE ═══ */
.venue-name{
  font-family:'Cormorant Garamond',serif;
  font-size:22px;
  font-weight:400;
  color:var(--ink);
  display:block;
  letter-spacing:1px;
}
.venue-location{
  font-family:'Jost',sans-serif;
  font-size:11px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--muted);
  display:block;
  margin-top:6px;
}

/* ═══ PILL BUTTON ═══ */
.pill-btn{
  display:inline-block;
  margin-top:18px;
  padding:10px 28px;
  border:1px solid var(--border);
  border-radius:30px;
  background:transparent;
  font-family:'Jost',sans-serif;
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--sage-dark);
  cursor:pointer;
  text-decoration:none;
  transition:background 0.2s, border-color 0.2s;
}
.pill-btn:hover{background:rgba(122,140,110,0.10);border-color:var(--sage);}

/* ═══ PROGRAMA / TIMELINE ═══ */
.programa-list{
  list-style:none;
  margin-top:8px;
}
.programa-item{
  display:flex;
  align-items:center;
  gap:20px;
  padding:14px 0;
  border-bottom:1px solid rgba(122,140,110,0.10);
}
.programa-item:last-child{border-bottom:none;}
.prog-hora{
  font-family:'Cormorant Garamond',serif;
  font-size:13px;
  letter-spacing:1.5px;
  color:var(--muted);
  min-width:52px;
  flex-shrink:0;
}
.prog-dot{
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--sage-light);
  flex-shrink:0;
}
.prog-evento{
  font-family:'Jost',sans-serif;
  font-size:14px;
  font-weight:300;
  color:var(--ink2);
  letter-spacing:0.5px;
}

/* ═══ COUNTDOWN ═══ */
.cd-box{
  display:inline-flex;
  align-items:stretch;
  gap:0;
  margin-top:16px;
  border:1px solid var(--border);
  border-radius:12px;
  overflow:hidden;
  background:var(--cream);
}
.cd-unit{
  text-align:center;
  padding:14px 16px 10px;
  min-width:60px;
  border-right:1px solid var(--border);
}
.cd-unit:last-child{border-right:none;}
.cd-num{
  display:block;
  font-family:'Cormorant Garamond',serif;
  font-size:36px;
  font-weight:400;
  color:var(--ink);
  line-height:1;
  font-variant-numeric:tabular-nums;
}
.cd-unit.secs-unit .cd-num{color:var(--terra);}
.cd-lbl{
  display:block;
  font-family:'Jost',sans-serif;
  font-size:8px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--muted);
  margin-top:5px;
}

/* ═══ IBAN ═══ */
.iban-box{
  font-family:'Jost',sans-serif;
  font-size:13px;
  letter-spacing:2px;
  color:var(--ink2);
  margin-top:14px;
  padding:10px 20px;
  border:1px solid var(--border);
  border-radius:10px;
  display:inline-block;
  background:var(--cream);
  font-weight:300;
}

/* ═══ IMÁGENES ═══ */
.obsequios-img{
  width:100%;
  max-width:260px;
  display:block;
  margin:0 auto 20px;
}
.end-castle-img{
  width:100%;
  height:auto;
  display:block;
  margin:0 auto;
  max-height:380px;
  object-fit:cover;
  mix-blend-mode:multiply;
  -webkit-mask-image:linear-gradient(to bottom, transparent 0%, black 12%, black 96%, transparent 100%), linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
  -webkit-mask-composite:destination-in;
  mask-image:linear-gradient(to bottom, transparent 0%, black 12%, black 96%, transparent 100%), linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
  mask-composite:intersect;
}

/* ═══ FOOTER ═══ */
.castle-footer{
  padding:32px 40px 0;
  text-align:center;
  position:relative;
  background:#fff;
}
.footer-names{
  font-family:'Cormorant Garamond',serif;
  font-size:28px;
  font-style:italic;
  color:var(--ink2);
  margin-bottom:8px;
  display:block;
}
.footer-date{
  font-family:'Jost',sans-serif;
  font-size:10px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--muted);
  display:block;
  margin-bottom:24px;
}

/* ═══ REVEAL SCROLL ═══ */
.reveal{opacity:0;transform:translateY(18px);transition:opacity 0.7s ease,transform 0.7s ease;}
.reveal.visible{opacity:1;transform:none;}

/* ═══ RESPONSIVE ═══ */
@media(max-width:430px){
  .wrap{max-width:100%;}
  .name-line{font-size:48px;}
}

/* Anula detección automática iOS */
a[x-apple-data-detectors]{
  color:inherit!important;
  text-decoration:none!important;
  pointer-events:none;
}

/* ═══ RSVP MODAL ═══ */
.rsvp-overlay{position:fixed;inset:0;background:rgba(20,18,14,0.55);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .3s;}
.rsvp-overlay--open{opacity:1;pointer-events:auto;}
.rsvp-modal{background:var(--white);border:1px solid rgba(122,140,110,0.22);border-radius:18px;padding:32px 28px 28px;width:min(92vw,400px);max-height:90vh;overflow-y:auto;position:relative;display:flex;flex-direction:column;gap:18px;}
.rsvp-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--muted);line-height:1;padding:4px;}
.rsvp-form{display:flex;flex-direction:column;gap:14px;}
.rsvp-field{display:flex;flex-direction:column;gap:5px;}
.rsvp-label{font-family:'Jost',sans-serif;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);}
.rsvp-input{background:var(--cream);border:1px solid rgba(122,140,110,0.30);border-radius:8px;padding:9px 12px;font-family:'Jost',sans-serif;font-size:.95rem;color:var(--ink);outline:none;transition:border-color .2s;}
.rsvp-input:focus{border-color:rgba(122,140,110,0.60);}
.rsvp-radio-group{display:flex;gap:12px;flex-wrap:wrap;}
.rsvp-radio{display:flex;align-items:center;gap:8px;cursor:pointer;font-family:'Jost',sans-serif;font-size:.93rem;color:var(--ink);}
.rsvp-radio input[type="radio"]{accent-color:var(--sage);width:16px;height:16px;cursor:pointer;flex-shrink:0;}
.rsvp-submit{margin-top:6px;padding:11px 0;border:1px solid rgba(122,140,110,0.35);border-radius:50px;background:transparent;color:var(--sage-dark);font-family:'Jost',sans-serif;font-size:.88rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:background .2s,border-color .2s;}
.rsvp-submit:hover{background:rgba(122,140,110,0.12);border-color:var(--sage);}
.rsvp-msg{min-height:1.4em;font-family:'Jost',sans-serif;font-size:.85rem;text-align:center;}
.rsvp-msg--ok{color:#5a7a3a;}
.rsvp-msg--error{color:#b04040;}

/* ═══ FIRMA VELUM STUDIO ═══ */
#velum-badge{text-align:center;padding:14px 0 18px;}
#velum-badge a{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:12px;
  color:var(--muted,#a08060);
  text-decoration:none;
  letter-spacing:0.5px;
  opacity:0.7;
  transition:opacity 0.2s;
}
#velum-badge a:hover{opacity:1;}
