*{margin:0;padding:0;box-sizing:border-box}
:root{--ink:#1a1008;--ink2:#3a280e;--sepia:#7a5628;--parch:#ede4d0;}
html{scroll-behavior:smooth}
body{background:radial-gradient(ellipse at center,#ccc0aa 0%,#b0a490 100%);min-height:100vh;display:flex;justify-content:center;padding:20px 0 20px;font-family:'Cormorant Garamond',serif;}

/* ═══ WATERCOLOR PAPER ═══ */
.wrap{width:100%;max-width:430px;background:var(--parch);position:relative;overflow:hidden;box-shadow:0 18px 80px rgba(0,0,0,0.3),0 4px 20px rgba(0,0,0,0.15);}
#grain-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:3;mix-blend-mode:multiply;opacity:0.82;}
.wrap::before{content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='350' height='350'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.80' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.50 0 0 0 0 0.38 0 0 0 0 0.22 0 0 0 0.35 0'/%3E%3C/filter%3E%3Crect width='350' height='350' filter='url(%23g)'/%3E%3C/svg%3E");
  background-size:350px 350px;pointer-events:none;z-index:4;mix-blend-mode:multiply;}
.wrap::after{content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='280' height='280'%3E%3Cfilter id='f'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.30 0.08' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.48 0 0 0 0 0.36 0 0 0 0 0.20 0 0 0 0.22 0'/%3E%3C/filter%3E%3Crect width='280' height='280' filter='url(%23f)'/%3E%3C/svg%3E");
  background-size:280px 280px;pointer-events:none;z-index:4;mix-blend-mode:multiply;}

.cloud-side{position:absolute;pointer-events:none;z-index:1;}
.wc-blob{position:absolute;pointer-events:none;z-index:1;border-radius:62% 38% 55% 45%/48% 58% 42% 52%;}
.wb1{width:340px;height:250px;top:-40px;right:-90px;background:radial-gradient(ellipse,rgba(185,152,85,0.22) 0%,rgba(185,152,85,0.10) 45%,transparent 70%);transform:rotate(16deg);}
.wb2{width:290px;height:210px;top:300px;left:-95px;background:radial-gradient(ellipse,rgba(168,142,78,0.20) 0%,rgba(168,142,78,0.08) 45%,transparent 70%);transform:rotate(-22deg);}
.wb3{width:310px;height:230px;top:700px;right:-75px;background:radial-gradient(ellipse,rgba(178,148,82,0.18) 0%,transparent 65%);transform:rotate(9deg);}
.wb4{width:290px;height:220px;top:1080px;left:-85px;background:radial-gradient(ellipse,rgba(170,142,78,0.19) 0%,transparent 65%);transform:rotate(-14deg);}
.wb5{width:330px;height:240px;top:1540px;right:-95px;background:radial-gradient(ellipse,rgba(180,150,82,0.17) 0%,transparent 65%);transform:rotate(20deg);}
.wb6{width:310px;height:230px;top:2050px;left:-75px;background:radial-gradient(ellipse,rgba(170,142,75,0.18) 0%,transparent 65%);transform:rotate(-9deg);}
.wb7{width:360px;height:250px;top:2500px;right:-85px;background:radial-gradient(ellipse,rgba(176,150,82,0.17) 0%,transparent 65%);transform:rotate(15deg);}

.content{position:relative;z-index:2;}

/* ═══ HERO ═══ */
.hero{padding:52px 32px 22px;min-height:280px;position:relative;}
.hero-names{position:relative;z-index:4;}
.name-line{font-family:'Nothing You Could Do',cursive;font-size:52px;line-height:1.3;color:var(--ink);display:block;overflow:hidden;white-space:nowrap;padding-bottom: 10px;}
.name-amp{font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--ink2); display:block;margin:4px 50px;overflow:hidden;opacity:0; }
.hero-date{font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--ink2);letter-spacing:2px;margin-top:10px;opacity:0;}
@keyframes reveal{from{width:0}to{width:100%}}
@keyframes fadein{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}
.name1{animation:reveal 1s steps(20,end) 0.4s forwards;width:0;}
.name-amp{animation:fadein 0.5s ease 1.5s forwards;}
.name2{animation:reveal 1s steps(20,end) 2.1s forwards;width:0;}
.hero-date{animation:fadein 0.6s ease 3.3s forwards;}

.train-wrap{position:absolute;top:130px;right:-10px;width:150px;z-index:2;}
.hedwig-hero{position:absolute;top:0px;right:70px;width:82px;z-index:5;}

@keyframes flapL{0%{transform:rotate(0deg) scaleY(1);}30%{transform:rotate(-38deg) scaleY(0.62);}60%{transform:rotate(-58deg) scaleY(0.42);}80%{transform:rotate(-22deg) scaleY(0.76);}100%{transform:rotate(0deg) scaleY(1);}}
@keyframes flapR{0%{transform:rotate(0deg) scaleY(1);}30%{transform:rotate(38deg) scaleY(0.62);}60%{transform:rotate(58deg) scaleY(0.42);}80%{transform:rotate(22deg) scaleY(0.76);}100%{transform:rotate(0deg) scaleY(1);}}
@keyframes owlBob{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}
.hedwig-hero{animation:owlBob 0.85s ease-in-out infinite;}
.wing-l{animation:flapL 0.85s ease-in-out infinite;transform-origin:44px 52px;}
.wing-r{animation:flapR 0.85s ease-in-out infinite;transform-origin:46px 52px;}

@keyframes owlProgBob{0%,100%{transform:translateY(0) rotate(-4deg);}50%{transform:translateY(-10px) rotate(2deg);}}
.owl-prog{animation:owlProgBob 2s ease-in-out infinite;}
.owl-prog-wl{animation:flapL 1.2s ease-in-out infinite;transform-origin:72px 52px;}
.owl-prog-wr{animation:flapR 1.2s ease-in-out infinite;transform-origin:72px 52px;}

/* ═══ SECTIONS ═══ */
.nos-casamos{padding:18px 36px 8px;text-align:center;position:relative;}
.venue{text-align:center;padding:6px 36px 22px;position:relative;}
.programa{padding:18px 10px 18px 36px;position:relative;text-align:center;}
.faltan{text-align:center;padding:14px 36px 18px;position:relative;}
.obsequios{text-align:center;padding:6px 36px 18px;}
.confirma{text-align:center;padding:6px 48px 22px;position:relative;}
.castle-footer{position:relative;padding:20px 36px 0;min-height:220px;text-align:center;}

.script-title{font-family:'Nothing You Could Do',cursive;font-size:34px;color:var(--ink);display:block;margin-bottom:10px;}
.italic-text{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:15px;color:var(--ink2);line-height:1.85;}
.datetime-text{font-family:'Cormorant Garamond',serif;font-size:13px;letter-spacing:2.5px;text-transform:uppercase;color:var(--ink);line-height:2;margin:12px 0 8px;}
.venue-name{font-family:'Cormorant Garamond',serif;font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--ink);line-height:2;}
.pill-btn{display:inline-block;margin-top:12px;padding:7px 22px;border:1px solid rgba(100,75,40,0.4);border-radius:20px;background:rgba(185,150,100,0.15);font-family:'Cormorant Garamond',serif;font-size:14px;color:var(--sepia);cursor:pointer;text-decoration:none;transition:background 0.2s;}
.pill-btn:hover{background:rgba(185,150,100,0.28);}

/* ═══ TIMELINE & FOOTPRINTS ═══ */
.tl-map{position:relative;width:100%;min-height:430px;padding-left:38px;}
.path-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:visible;z-index:2;}
#map-fp-track{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;}
.fp{opacity:0;transition:opacity 0.6s ease;will-change:opacity;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-transform:translateZ(0);transform:translateZ(0);}
.tl-item{position:absolute;display:flex;align-items:center;z-index:3;-webkit-transform:translateZ(0);transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden;}
.tl-icon-w{width:38px;height:38px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.tl-label{font-family:'Nothing You Could Do',cursive;font-size:13px;color:var(--ink2);line-height:1.3;white-space:nowrap;}
.tl-time{font-family:'Nothing You Could Do',cursive;font-size:12px;color:var(--sepia);display:block;}

.tl0{top:8px;left:58%;}
.tl1{top:100px;left:60%;}
.tl2{top:155px;left:-7%;}
.tl3{top:278px;left:60%;}
.tl4{top:372px;left:2%;}
.owl-prog{position:absolute;left:-14px;top:60px;width:112px;z-index:4;}

/* ═══ COUNTDOWN ═══ */
.faltan-title{font-family:'Nothing You Could Do',cursive;font-size:38px;color:var(--ink);display:inline-block;margin-right:6px;}
.owl-small-wrap{display:inline-block;vertical-align:middle;position:relative;top:-6px;width:52px;animation:owlProgBob 2s ease-in-out infinite;}
.faltan-header{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:4px;}
.cd-box{
  border:1.5px solid rgba(100,75,40,0.38);border-radius:10px;
  display:inline-flex;align-items:stretch;
  padding:10px 12px 8px;margin-top:10px;
  background:rgba(240,232,220,0.6);
  gap:0;
}
.cd-unit{text-align:center;padding:0 8px;min-width:52px;}
.cd-unit .cd-num{
  display:block;
  font-family:'Cormorant Garamond',serif;
  font-size:34px;font-weight:500;
  color:var(--ink);letter-spacing:1px;line-height:1;
  font-variant-numeric:tabular-nums;
  white-space:nowrap;
}
.cd-unit.secs-unit .cd-num{color:#a07018;}
.cd-unit .cd-lbl{
  display:block;font-family:'Cormorant Garamond',serif;
  font-size:9px;letter-spacing:1.2px;text-transform:uppercase;
  color:var(--sepia);margin-top:4px;
}
.cd-sep{
  font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:500;
  color:rgba(90,65,28,0.5);align-self:flex-start;padding-top:2px;
}

.te-esperamos{font-family:'Nothing You Could Do',cursive;font-size:36px;color:var(--ink);position:relative;z-index:2;}
.reveal{opacity:0;transform:translateY(22px);transition:opacity 0.75s ease,transform 0.75s ease;}
.reveal.visible{opacity:1;transform:none;}
.section-gap{height:28px;}
.end-line{margin-bottom:0;}
/* Títulos de sección con tamaño variable */
.script-title--sm{font-size:28px;}
.script-title--xs{font-size:26px;}
/* Caja IBAN */
.iban-box{font-family:'Cormorant Garamond',serif;font-size:14px;letter-spacing:1.5px;color:var(--ink);margin-top:10px;padding:8px 18px;border:1px solid rgba(100,75,40,0.35);border-radius:10px;display:inline-block;background:rgba(240,232,215,0.50);}
/* Imagen obsequios */
.obsequios-img{width:100%;max-width:320px;display:block;margin:0 auto 14px;}
/* Imagen del castillo de acuarela final */
.end-castle-img {
  width: 100%;
  height: auto;
  display: block;
  margin: -2px auto 0;
  max-height: 400px;
  opacity: 0.95;
  object-fit: cover;
}
@media(max-width:430px){.wrap{max-width:100%;}.name-line{font-size:44px;}.train-wrap{width:170px;}}
/* Anula el subrayado automático que aplica iOS a números de cuenta, fechas, etc. */
a[x-apple-data-detectors]{
  color:inherit!important;
  text-decoration:none!important;
  font-size:inherit!important;
  font-family:inherit!important;
  font-weight:inherit!important;
  line-height:inherit!important;
  pointer-events:none;
}

/* ═══ RSVP MODAL ═══ */
.rsvp-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(30,20,8,0.55);
  backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  opacity:0;pointer-events:none;
  transition:opacity 0.3s ease;
}
.rsvp-overlay--open{opacity:1;pointer-events:all;}
.rsvp-modal{
  position:relative;
  width:100%;max-width:390px;max-height:90vh;overflow-y:auto;
  background:var(--parch);
  border-radius:4px;
  box-shadow:0 24px 80px rgba(0,0,0,0.30),0 4px 20px rgba(0,0,0,0.14);
  padding:36px 28px 28px;
  transform:translateY(18px);
  transition:transform 0.3s ease;
}
.rsvp-overlay--open .rsvp-modal{transform:translateY(0);}
.rsvp-modal::before{
  content:'';position:absolute;inset:0;border-radius:4px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='350' height='350'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.80' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.50 0 0 0 0 0.38 0 0 0 0 0.22 0 0 0 0.28 0'/%3E%3C/filter%3E%3Crect width='350' height='350' filter='url(%23g)'/%3E%3C/svg%3E");
  background-size:350px 350px;pointer-events:none;z-index:0;mix-blend-mode:multiply;
}
.rsvp-modal > *{position:relative;z-index:1;}
.rsvp-close{
  position:absolute;top:14px;right:16px;z-index:2;
  background:none;border:none;cursor:pointer;
  font-family:'Cormorant Garamond',serif;font-size:18px;
  color:var(--sepia);opacity:0.6;line-height:1;
  transition:opacity 0.2s;padding:4px;
}
.rsvp-close:hover{opacity:1;}
.rsvp-modal .script-title{text-align:center;display:block;margin-bottom:18px;}
.rsvp-form{text-align:left;}
.rsvp-field{margin-bottom:14px;}
.rsvp-label{
  display:block;
  font-family:'Cormorant Garamond',serif;
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--sepia);margin-bottom:6px;
}
.rsvp-input{
  width:100%;
  font-family:'Cormorant Garamond',serif;font-size:15px;
  color:var(--ink);background:rgba(240,232,215,0.55);
  border:1px solid rgba(100,75,40,0.30);border-radius:8px;
  padding:9px 14px;outline:none;
  transition:border-color 0.2s,background 0.2s;
  -webkit-appearance:none;appearance:none;
}
.rsvp-input:focus{border-color:rgba(100,75,40,0.60);background:rgba(240,232,215,0.80);}
.rsvp-select{cursor:pointer;}
.rsvp-radio-group{display:flex;gap:12px;flex-wrap:wrap;}
.rsvp-radio{
  display:flex;align-items:center;gap:7px;cursor:pointer;
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-size:15px;color:var(--ink2);
}
.rsvp-radio input[type="radio"]{accent-color:var(--sepia);width:16px;height:16px;cursor:pointer;flex-shrink:0;}
.rsvp-submit{
  margin-top:6px;width:100%;
  font-family:'Cormorant Garamond',serif;font-size:15px;
  color:var(--sepia);letter-spacing:1px;
  background:rgba(185,150,100,0.15);
  border:1px solid rgba(100,75,40,0.40);border-radius:20px;
  padding:10px 22px;cursor:pointer;transition:background 0.2s;
}
.rsvp-submit:hover:not(:disabled){background:rgba(185,150,100,0.28);}
.rsvp-submit:disabled{opacity:0.55;cursor:not-allowed;}
.rsvp-msg{
  margin-top:10px;font-family:'Cormorant Garamond',serif;
  font-style:italic;font-size:14px;text-align:center;min-height:20px;
}
.rsvp-msg--ok{color:#4a6820;}
.rsvp-msg--error{color:#8c2020;}

/* ═══ 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(--sepia,#a08060);
  text-decoration:none;
  letter-spacing:0.5px;
  opacity:0.7;
  transition:opacity 0.2s;
}
#velum-badge a:hover{opacity:1;}
