:root{
  --boda-white:#fff;
  --boda-ivory:#fffdf9;
  --boda-soft:#faf8f3;
  --boda-cream:#f5efe4;
  --boda-green:#153f2c;
  --boda-green-2:#2f6649;
  --boda-gold:#bc8734;
  --boda-gold-2:#d8b376;
  --boda-ink:#25362d;
  --boda-muted:#68756d;
  --boda-line:rgba(188,135,52,.25);
  --boda-shadow:0 18px 54px rgba(40,32,22,.10);
  --boda-shadow-soft:0 10px 28px rgba(40,32,22,.07);
  --boda-radius:24px;
  --boda-serif:'Cormorant Garamond', Georgia, serif;
  --boda-sans:'Montserrat', Arial, sans-serif;
}

html{scroll-behavior:smooth;overflow-x:hidden;background:#fff!important}
body.boda-sevilla-template{margin:0!important;background:#fff!important;overflow-x:hidden!important}
#main-header,#top-header,#main-footer,.et-l--header,.et-l--footer,body.boda-sevilla-template #main-header,body.boda-sevilla-template #top-header,body.boda-sevilla-template #main-footer,body.boda-sevilla-template .et-l--header,body.boda-sevilla-template .et-l--footer{display:none!important}
body.et_fixed_nav #page-container,body.et_fixed_nav.boda-sevilla-template #page-container{padding-top:0!important}
body.boda-sevilla-template #page-container,body.boda-sevilla-template #et-main-area,body.boda-sevilla-template #main-content{padding-top:0!important;background:#fff!important}

.boda-simple,.boda-simple *{box-sizing:border-box}
.boda-simple{font-family:var(--boda-sans);line-height:1.5;color:var(--boda-ink);background:#fff;overflow:hidden;-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision}
.boda-simple img{display:block;max-width:100%;height:auto}
.boda-simple a{color:inherit;text-decoration:none}
.boda-container{width:min(1120px,calc(100% - 44px));margin-inline:auto}

.boda-loader{position:fixed;inset:0;z-index:99999;background:#fff;display:flex;align-items:center;justify-content:center;flex-direction:column;transition:opacity .55s ease,visibility .55s ease}.boda-loader img{width:min(240px,62vw);filter:drop-shadow(0 16px 24px rgba(21,63,44,.10));animation:bodaLogoPulse 1.8s ease-in-out infinite}.boda-loader span{width:116px;height:1px;margin-top:20px;background:linear-gradient(90deg,transparent,var(--boda-gold),transparent);animation:bodaLine 1.2s ease-in-out infinite}.boda-loader.is-hidden{opacity:0;visibility:hidden;pointer-events:none}@keyframes bodaLogoPulse{0%,100%{transform:scale(.985);opacity:.85}50%{transform:scale(1.015);opacity:1}}@keyframes bodaLine{0%,100%{transform:scaleX(.35);opacity:.35}50%{transform:scaleX(1);opacity:1}}

/* PORTADA: una sola imagen de Plaza de España en acuarela, sin texto incrustado y sin esquinas sueltas */
.boda-hero{position:relative;min-height:100svh;isolation:isolate;display:flex;align-items:center;justify-content:center;padding:clamp(36px,6vh,74px) 18px 42px;background:#fff;overflow:hidden}
.boda-hero__bg{position:absolute;inset:0;z-index:-3;background-size:max(1320px,100vw) auto;background-position:center top;background-repeat:no-repeat;will-change:transform;filter:saturate(.98) contrast(.98) brightness(1.02)}
.boda-hero__shade{position:absolute;inset:0;z-index:-2;background:radial-gradient(ellipse at 50% 34%,rgba(255,255,255,.98) 0%,rgba(255,255,255,.90) 20%,rgba(255,255,255,.66) 43%,rgba(255,255,255,.30) 70%,rgba(255,255,255,.18) 100%),linear-gradient(180deg,rgba(255,255,255,.10) 0%,rgba(255,255,255,.04) 50%,#fff 100%)}
.boda-hero:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:120px;background:linear-gradient(180deg,transparent,#fff 75%);z-index:-1;pointer-events:none}
.boda-hero__stack{position:relative;z-index:2;width:min(820px,100%);margin:auto;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(16px,2.2vh,24px);padding:clamp(16px,2.4vw,28px) 12px}.boda-hero__stack:before{content:"";position:absolute;inset:clamp(-20px,-3vw,-10px) clamp(-28px,-4vw,-12px);z-index:-1;background:radial-gradient(ellipse at center,rgba(255,255,255,.92) 0%,rgba(255,255,255,.72) 42%,rgba(255,255,255,.22) 72%,transparent 100%);filter:blur(3px);pointer-events:none}
.boda-hero__content{width:100%;text-align:center}.boda-logo{width:clamp(250px,27vw,430px);margin:0 auto 20px;object-fit:contain;filter:drop-shadow(0 12px 18px rgba(21,63,44,.18));animation:bodaHeroLogo .95s cubic-bezier(.2,.8,.2,1) both}.boda-kicker{width:min(620px,100%);margin:0 auto;color:var(--boda-green);font:700 13px/1.65 var(--boda-sans);text-transform:uppercase;letter-spacing:.20em}.boda-ornament{display:block;width:126px;height:16px;margin:18px auto 0;position:relative}.boda-ornament:before,.boda-ornament:after{content:"";position:absolute;top:50%;width:47px;height:1px;background:linear-gradient(90deg,transparent,var(--boda-gold))}.boda-ornament:before{left:0}.boda-ornament:after{right:0;transform:scaleX(-1)}.boda-ornament{background:radial-gradient(circle at 50% 50%,var(--boda-gold) 0 3px,transparent 4px)}.boda-date{margin:20px 0 0;color:var(--boda-green);font:700 clamp(25px,2.4vw,34px)/1.15 var(--boda-serif);text-transform:uppercase;letter-spacing:.18em}.boda-city{margin:14px 0 0;color:var(--boda-green);font:700 clamp(20px,2vw,28px)/1.15 var(--boda-serif);text-transform:uppercase;letter-spacing:.30em}
.boda-countdown{position:relative;z-index:3;display:flex;align-items:stretch;justify-content:center;background:rgba(255,255,255,.88);border:1px solid rgba(188,135,52,.24);border-radius:18px;box-shadow:0 22px 54px rgba(40,32,22,.14);backdrop-filter:blur(14px);overflow:hidden;width:min(700px,calc(100% - 22px))}.boda-countdown div{flex:1;min-width:118px;padding:18px 18px;text-align:center}.boda-countdown strong{display:block;color:var(--boda-green);font:600 42px/.95 var(--boda-serif)}.boda-countdown span{display:block;margin-top:5px;color:var(--boda-muted);font-size:9px;font-weight:700;letter-spacing:.15em;text-transform:uppercase}.boda-countdown i{width:1px;margin:18px 0;background:linear-gradient(transparent,var(--boda-gold),transparent);position:relative}.boda-countdown i:after{content:"✦";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-style:normal;color:var(--boda-gold);font-size:13px;background:rgba(255,255,255,.96);padding:0 4px}.boda-actions{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:14px}.boda-btn{position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 26px;border-radius:999px;font:700 11px/1 var(--boda-sans);text-transform:uppercase;letter-spacing:.11em;cursor:pointer;border:1px solid transparent;transition:transform .28s ease,box-shadow .28s ease,background .28s ease,border-color .28s ease,color .28s ease}.boda-btn:after{content:"";position:absolute;top:0;bottom:0;left:-46%;width:34%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.42),transparent);transform:skewX(-18deg);transition:left .55s ease}.boda-btn:hover{transform:translateY(-3px);box-shadow:0 18px 36px rgba(21,63,44,.14)}.boda-btn:hover:after{left:115%}.boda-btn--green{background:var(--boda-green);border-color:var(--boda-green);color:#fff!important}.boda-btn--light{background:rgba(255,255,255,.86);border-color:rgba(188,135,52,.42);color:var(--boda-green)!important;backdrop-filter:blur(10px)}.boda-btn--gold{background:var(--boda-gold);border-color:var(--boda-gold);color:#fff!important}@keyframes bodaHeroLogo{from{opacity:0;transform:translateY(18px) scale(.94)}to{opacity:1;transform:none}}

.boda-section{padding:92px 0;background:#fff;position:relative}.boda-section:nth-of-type(odd){background:linear-gradient(180deg,#fff,var(--boda-soft) 100%)}.boda-section__header{text-align:center;margin:0 auto 42px;width:min(760px,100%)}.boda-section__header p,.boda-label{margin:0 0 6px;color:var(--boda-gold);font:700 11px/1 var(--boda-sans);text-transform:uppercase;letter-spacing:.18em}.boda-section__header h2{margin:0;color:var(--boda-green);font:500 clamp(36px,4.6vw,62px)/.95 var(--boda-serif)}.boda-section__header--left{text-align:left;margin-left:0}.boda-section__header--left .boda-ornament{margin-left:0}
.boda-card{background:rgba(255,255,255,.90);border:1px solid rgba(188,135,52,.16);border-radius:var(--boda-radius);padding:30px;box-shadow:var(--boda-shadow-soft);backdrop-filter:blur(12px);transition:transform .32s ease,box-shadow .32s ease,border-color .32s ease}.boda-card:hover{transform:translateY(-7px);box-shadow:var(--boda-shadow);border-color:rgba(188,135,52,.32)}.boda-card h3{margin:0 0 8px;color:var(--boda-green);font:600 31px/1 var(--boda-serif)}.boda-card p{margin:0;color:var(--boda-muted)}.boda-card small{display:block;margin-top:14px;color:var(--boda-gold);font-weight:700;letter-spacing:.10em;text-transform:uppercase}.boda-card-link{display:inline-flex;margin-top:12px;color:var(--boda-green);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.10em}
.boda-story__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.boda-story-card{text-align:center;min-height:228px}.boda-story-card__icon{display:grid;width:54px;height:54px;margin:0 auto 18px;place-items:center;border:1px solid rgba(188,135,52,.30);border-radius:50%;color:var(--boda-gold);font-size:26px;background:#fff}.boda-story-card h3{font-size:27px}.boda-details__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}.boda-detail{text-align:center}.boda-detail img{width:100%;height:180px;object-fit:contain;margin:0 auto 8px;filter:drop-shadow(0 14px 18px rgba(40,32,22,.08))}.boda-detail strong{display:block;color:var(--boda-gold);font:700 16px var(--boda-serif);margin:0 0 7px}.boda-detail span{color:var(--boda-muted)}
.boda-rsvp{padding:66px 0;background:radial-gradient(ellipse at 15% 20%,rgba(216,179,118,.16),transparent 35%),radial-gradient(ellipse at 85% 80%,rgba(216,179,118,.12),transparent 34%),linear-gradient(135deg,#113724,#1b4a34);color:#fff;position:relative;overflow:hidden}.boda-rsvp:before,.boda-rsvp:after{content:"";position:absolute;top:12px;bottom:12px;width:240px;opacity:.18;background:radial-gradient(circle at 30% 20%,#d8b376 0 2px,transparent 3px),linear-gradient(120deg,transparent 10%,rgba(255,255,255,.18),transparent 80%);filter:blur(.2px)}.boda-rsvp:before{left:-70px;transform:rotate(-12deg)}.boda-rsvp:after{right:-70px;transform:rotate(12deg)}.boda-rsvp .boda-container{position:relative;z-index:2;display:grid;grid-template-columns:.75fr 1.25fr;gap:34px;align-items:center}.boda-rsvp__header h2{margin:0 0 12px;color:#fff;font:500 clamp(36px,4.2vw,58px)/.96 var(--boda-serif)}.boda-rsvp__header span,.boda-rsvp__header small{display:block;color:rgba(255,255,255,.80);font-size:15px}.boda-rsvp__header small{margin-top:7px;color:var(--boda-gold-2);font-weight:700}.boda-rsvp__form{display:grid;grid-template-columns:1.2fr .8fr .8fr 1fr auto;gap:12px;align-items:end;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:16px;backdrop-filter:blur(12px);box-shadow:0 20px 48px rgba(0,0,0,.14)}.boda-rsvp__form label{display:grid;gap:6px;color:rgba(255,255,255,.76);font-size:10px;text-transform:uppercase;letter-spacing:.12em;font-weight:700}.boda-rsvp__form input,.boda-rsvp__form select{height:44px;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:#fff;color:var(--boda-green);padding:0 13px;font:500 14px var(--boda-sans);outline:none}.boda-rsvp__form input:focus,.boda-rsvp__form select:focus{border-color:var(--boda-gold-2);box-shadow:0 0 0 4px rgba(216,179,118,.14)}.boda-form__status{grid-column:1/-1;margin:0;color:#fff;font-weight:700;text-align:center}

.boda-agenda__grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:64px;align-items:center}.boda-timeline{display:grid;gap:12px}.boda-timeline__item{display:grid;grid-template-columns:92px 1fr;gap:16px;align-items:center}.boda-timeline__item time{background:#fff;border:1px solid rgba(188,135,52,.16);border-radius:16px;text-align:center;padding:16px 8px;color:var(--boda-green);font:700 21px/1 var(--boda-serif);box-shadow:0 10px 24px rgba(40,32,22,.06)}.boda-timeline__item div{background:#fff;border:1px solid rgba(188,135,52,.15);border-radius:18px;padding:17px 20px;box-shadow:0 10px 24px rgba(40,32,22,.06);transition:transform .3s ease,box-shadow .3s ease}.boda-timeline__item:hover div{transform:translateX(4px);box-shadow:0 18px 36px rgba(40,32,22,.09)}.boda-timeline__item h3{margin:0 0 4px;color:var(--boda-green);font:600 24px/1.05 var(--boda-serif)}.boda-timeline__item p{margin:0;color:var(--boda-muted);font-size:14px}.boda-agenda__image{margin:0}.boda-agenda__image img{width:100%;filter:drop-shadow(0 18px 30px rgba(40,32,22,.08));animation:bodaFloat 8s ease-in-out infinite}@keyframes bodaFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.boda-route__grid{display:grid;grid-template-columns:.55fr 1.45fr;gap:44px;align-items:center}.boda-route__grid h2{margin:0 0 12px;color:var(--boda-green);font:500 clamp(36px,4vw,56px)/.96 var(--boda-serif)}.boda-route__grid p{color:var(--boda-muted);margin:0 0 22px}.boda-route-card{position:relative;background:#fff;border:1px solid rgba(188,135,52,.20);border-radius:24px;padding:24px;box-shadow:var(--boda-shadow-soft);overflow:hidden}.boda-route-line{position:absolute;left:40px;right:40px;top:50%;height:2px;background:repeating-linear-gradient(90deg,var(--boda-green) 0 18px,transparent 18px 30px);opacity:.28;animation:bodaDashBg 8s linear infinite}.boda-route-stops{position:relative;display:grid;grid-template-columns:repeat(var(--stops),minmax(150px,1fr));gap:18px;align-items:stretch}.boda-route-stop{position:relative;text-align:center;background:var(--boda-soft);border:1px solid rgba(188,135,52,.16);border-radius:18px;padding:20px 12px;box-shadow:0 10px 22px rgba(40,32,22,.05)}.boda-route-stop span{display:grid;place-items:center;width:34px;height:34px;margin:0 auto 10px;border-radius:50%;background:var(--boda-green);color:#fff;font-size:11px;font-weight:800}.boda-route-stop h3{margin:0;color:var(--boda-green);font:600 23px/1.05 var(--boda-serif)}.boda-route-stop p{margin:6px 0 4px;color:var(--boda-muted);font-size:13px}.boda-route-stop strong{display:block;color:var(--boda-gold);font-weight:800}.boda-route-stop a{display:inline-flex;margin-top:8px;color:var(--boda-green);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.10em}@keyframes bodaDashBg{to{background-position:96px 0}}
.boda-extra__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;text-align:center}.boda-icon{display:grid;width:52px;height:52px;margin:0 auto 15px;place-items:center;border:1px solid rgba(188,135,52,.34);border-radius:50%;color:var(--boda-gold);background:#fff;font-size:25px}.boda-copy,.boda-link{display:inline-flex;align-items:center;justify-content:center;margin:14px 0 12px;min-height:40px;padding:0 18px;border-radius:999px;border:1px solid rgba(188,135,52,.38);background:#fff;color:var(--boda-green)!important;font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:11px;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease,background .25s ease}.boda-copy:hover,.boda-link:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(40,32,22,.08);background:var(--boda-soft)}
.boda-faq__grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 20px}.boda-faq__item{background:#fff;border:1px solid rgba(188,135,52,.15);border-radius:16px;padding:0 19px;box-shadow:0 8px 20px rgba(40,32,22,.05);transition:box-shadow .25s ease,transform .25s ease}.boda-faq__item:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(40,32,22,.08)}.boda-faq__item summary{cursor:pointer;list-style:none;color:var(--boda-green);font:600 23px/1.15 var(--boda-serif);padding:18px 26px 18px 0;position:relative}.boda-faq__item summary::-webkit-details-marker{display:none}.boda-faq__item summary:after{content:"+";position:absolute;right:0;top:50%;transform:translateY(-50%);color:var(--boda-gold);font-family:var(--boda-sans)}.boda-faq__item[open] summary:after{content:"–"}.boda-faq__item p{margin:0 0 18px;color:var(--boda-muted)}
.boda-gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.boda-gallery__item{padding:0;border:0;background:transparent;cursor:pointer;border-radius:18px;overflow:hidden;box-shadow:0 12px 26px rgba(40,32,22,.11);outline:1px solid rgba(188,135,52,.16);outline-offset:-1px}.boda-gallery__item img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .55s ease,filter .55s ease}.boda-gallery__item:hover img{transform:scale(1.06);filter:saturate(1.08) contrast(1.02)}
.boda-footer{padding:72px 0 42px;background:linear-gradient(180deg,#fff,var(--boda-cream))}.boda-footer__card{width:min(1040px,calc(100% - 44px));margin:auto;background:rgba(255,255,255,.84);border:1px solid rgba(188,135,52,.28);border-radius:28px;padding:38px 30px;text-align:center;box-shadow:var(--boda-shadow-soft);backdrop-filter:blur(10px)}.boda-footer__card img{width:min(300px,70vw);margin:0 auto 10px}.boda-footer__card p{margin:0;color:var(--boda-green);font:700 18px/1.25 var(--boda-serif);text-transform:uppercase;letter-spacing:.13em}.boda-footer__card span{display:block;margin-top:7px;color:var(--boda-muted)}.boda-footer__phones{display:flex;justify-content:center;gap:30px;flex-wrap:wrap;margin:22px 0}.boda-footer__phones a{color:var(--boda-green);font-weight:700}.boda-footer small{color:var(--boda-muted)}
.boda-toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%,30px);opacity:0;background:var(--boda-green);color:#fff;padding:12px 18px;border-radius:999px;z-index:9999;box-shadow:0 18px 36px rgba(0,0,0,.25);transition:.3s ease}.boda-toast.is-visible{opacity:1;transform:translate(-50%,0)}.boda-lightbox{position:fixed;inset:0;background:rgba(21,63,44,.88);z-index:9998;display:grid;place-items:center;padding:28px;opacity:0;visibility:hidden;transition:.25s ease}.boda-lightbox.is-visible{opacity:1;visibility:visible}.boda-lightbox img{max-height:86vh;border-radius:18px;box-shadow:0 30px 80px rgba(0,0,0,.45)}.boda-lightbox button{position:absolute;top:18px;right:18px;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.12);color:#fff;font-size:34px;line-height:1;cursor:pointer}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .72s cubic-bezier(.2,.8,.2,1),transform .72s cubic-bezier(.2,.8,.2,1)}.reveal.is-visible{opacity:1;transform:none}.boda-story__grid .reveal:nth-child(2),.boda-details__grid .reveal:nth-child(2),.boda-extra__grid .reveal:nth-child(2),.boda-gallery__grid .reveal:nth-child(2){transition-delay:.08s}.boda-story__grid .reveal:nth-child(3),.boda-details__grid .reveal:nth-child(3),.boda-extra__grid .reveal:nth-child(3),.boda-gallery__grid .reveal:nth-child(3){transition-delay:.16s}.boda-story__grid .reveal:nth-child(4),.boda-gallery__grid .reveal:nth-child(4){transition-delay:.24s}

@media(max-width:1100px){.boda-story__grid{grid-template-columns:repeat(2,1fr)}.boda-rsvp__form{grid-template-columns:1fr 1fr}.boda-rsvp__form .boda-btn{grid-column:1/-1}.boda-countdown div{min-width:108px}.boda-agenda__grid,.boda-route__grid{gap:38px}.boda-route-stops{grid-template-columns:repeat(2,minmax(160px,1fr))}.boda-route-line{display:none}}
@media(max-width:900px){.boda-container{width:min(720px,calc(100% - 34px))}.boda-section{padding:72px 0}.boda-hero{min-height:820px}.boda-hero__bg{background-size:auto 100%;background-position:center top}.boda-details__grid,.boda-extra__grid,.boda-agenda__grid,.boda-route__grid,.boda-rsvp .boda-container{grid-template-columns:1fr}.boda-section__header--left{text-align:center;margin-inline:auto}.boda-section__header--left .boda-ornament{margin-left:auto}.boda-agenda__image{max-width:560px;margin:auto}.boda-faq__grid{grid-template-columns:1fr}.boda-gallery__grid{grid-template-columns:repeat(2,1fr)}.boda-countdown{display:grid;grid-template-columns:repeat(4,1fr)}.boda-countdown i{display:none}.boda-countdown div{min-width:0}.boda-countdown strong{font-size:36px}.boda-route-stops{grid-template-columns:1fr}}
@media(max-width:640px){.boda-hero{min-height:760px;padding:30px 12px 34px}.boda-hero__bg{background-size:auto 100%;background-position:center top}.boda-hero__shade{background:radial-gradient(ellipse at 50% 34%,rgba(255,255,255,.99) 0%,rgba(255,255,255,.92) 24%,rgba(255,255,255,.68) 55%,rgba(255,255,255,.32) 100%),linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,.04) 46%,rgba(255,255,255,.88) 100%)}.boda-hero__stack{gap:14px;padding:8px 8px}.boda-logo{width:min(82vw,330px);margin-bottom:12px}.boda-kicker{font-size:10px;letter-spacing:.12em;line-height:1.65}.boda-date{font-size:20px;letter-spacing:.08em}.boda-city{font-size:17px;letter-spacing:.16em}.boda-actions{gap:10px}.boda-btn{width:100%;max-width:292px;min-height:44px}.boda-countdown{width:100%;border-radius:16px}.boda-countdown div{padding:14px 6px}.boda-countdown strong{font-size:27px}.boda-countdown span{font-size:8px;letter-spacing:.1em}.boda-story__grid{grid-template-columns:1fr}.boda-card{padding:24px}.boda-rsvp__form{grid-template-columns:1fr;padding:14px}.boda-timeline__item{grid-template-columns:76px 1fr;gap:10px}.boda-timeline__item time{font-size:17px;padding:14px 6px}.boda-timeline__item div{padding:14px}.boda-footer__phones{display:grid;gap:12px}.boda-rsvp,.boda-section{padding:62px 0}.boda-section__header{margin-bottom:30px}.boda-footer__card{width:calc(100% - 28px);padding:30px 18px}}
@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}.reveal{opacity:1!important;transform:none!important}}

/* ==========================================================
   V11 · Responsive universal
   Ajustes específicos para PC, portátil, tablet, móvil,
   móvil pequeño, landscape y pantallas táctiles.
   ========================================================== */
:root{--boda-safe-x:max(18px,env(safe-area-inset-left));--boda-safe-r:max(18px,env(safe-area-inset-right));--boda-vh:1vh}
.boda-simple{width:100%;max-width:100%;min-width:0;overflow-x:clip}.boda-simple *{min-width:0}.boda-container{max-width:1120px}.boda-hero{min-height:calc(var(--boda-vh,1vh) * 100);padding-left:max(18px,env(safe-area-inset-left));padding-right:max(18px,env(safe-area-inset-right))}.boda-hero__stack{max-width:820px}.boda-hero__content{min-width:0}.boda-logo{max-height:38vh}.boda-countdown,.boda-actions{max-width:100%}.boda-rsvp__form input,.boda-rsvp__form select,.boda-rsvp__form button{max-width:100%;min-width:0}.boda-card,.boda-route-card,.boda-rsvp__form,.boda-footer__card{overflow-wrap:anywhere}.boda-route-stops{grid-template-columns:repeat(auto-fit,minmax(min(180px,100%),1fr))!important}.boda-gallery__grid{grid-template-columns:repeat(auto-fit,minmax(min(210px,100%),1fr))}.boda-story__grid{grid-template-columns:repeat(auto-fit,minmax(min(235px,100%),1fr))}.boda-details__grid,.boda-extra__grid{grid-template-columns:repeat(auto-fit,minmax(min(260px,100%),1fr))}
@media (min-width:1440px){.boda-container{max-width:1180px}.boda-hero__stack{max-width:860px}.boda-hero__bg{background-size:cover;background-position:center center}.boda-logo{width:clamp(330px,24vw,470px)}.boda-countdown{width:min(760px,100%)}}
@media (min-width:1025px) and (max-height:820px){.boda-hero{min-height:100dvh;padding-top:22px;padding-bottom:22px}.boda-hero__stack{gap:10px;transform:translateY(-1vh)}.boda-logo{width:clamp(250px,22vw,360px);max-height:32vh;margin-bottom:10px}.boda-kicker{font-size:11px;line-height:1.45}.boda-ornament{margin-top:10px}.boda-date{margin-top:12px;font-size:clamp(22px,2vw,30px)}.boda-city{margin-top:7px;font-size:clamp(18px,1.7vw,24px)}.boda-countdown div{padding:12px 14px}.boda-countdown strong{font-size:34px}.boda-btn{min-height:42px;padding-inline:22px}}
@media (min-width:901px) and (max-width:1200px){.boda-container{width:min(1024px,calc(100% - 40px))}.boda-hero__bg{background-size:cover;background-position:center center}.boda-rsvp__form{grid-template-columns:1fr 1fr 1fr}.boda-rsvp__form label:nth-child(4){grid-column:1/3}.boda-rsvp__form .boda-btn{grid-column:3/4;width:100%}.boda-route__grid{grid-template-columns:.72fr 1.28fr}.boda-agenda__grid{grid-template-columns:1fr .95fr}}
@media (max-width:900px){.boda-container{width:min(760px,calc(100% - 32px))}.boda-hero{min-height:auto;padding-top:calc(42px + env(safe-area-inset-top));padding-bottom:64px}.boda-hero__bg{background-size:cover!important;background-position:center top!important}.boda-hero__stack{width:100%;gap:16px}.boda-logo{width:min(430px,72vw);max-height:none}.boda-kicker{max-width:520px}.boda-countdown{width:min(620px,100%)}.boda-actions{width:100%}.boda-rsvp .boda-container{display:grid;grid-template-columns:1fr!important}.boda-rsvp__header{text-align:center}.boda-rsvp__form{width:100%;grid-template-columns:1fr 1fr!important}.boda-rsvp__form .boda-btn,.boda-form__status{grid-column:1/-1}.boda-agenda__grid,.boda-route__grid{display:grid;grid-template-columns:1fr!important}.boda-route-card{padding:20px}.boda-route-line{display:none}.boda-footer__card{width:min(760px,calc(100% - 32px))}}
@media (min-width:641px) and (max-width:900px){.boda-section{padding:76px 0}.boda-story__grid,.boda-details__grid,.boda-extra__grid{grid-template-columns:repeat(2,minmax(0,1fr))}.boda-gallery__grid{grid-template-columns:repeat(3,minmax(0,1fr))}.boda-route-stops{grid-template-columns:repeat(2,minmax(0,1fr))!important}.boda-countdown{grid-template-columns:repeat(4,1fr)!important}.boda-countdown strong{font-size:36px}.boda-actions .boda-btn{width:auto;min-width:210px}}
@media (max-width:640px){html,body{max-width:100%;overflow-x:hidden!important}.boda-container{width:calc(100% - 28px)}.boda-section,.boda-rsvp{padding:58px 0}.boda-section__header h2,.boda-route__grid h2{font-size:clamp(34px,11vw,48px);line-height:.98}.boda-section__header p,.boda-label{font-size:10px;letter-spacing:.14em}.boda-hero{min-height:auto;padding-top:calc(28px + env(safe-area-inset-top));padding-bottom:48px}.boda-hero__bg{background-size:cover!important;background-position:center top!important}.boda-hero__shade{background:radial-gradient(ellipse at 50% 31%,rgba(255,255,255,.98) 0%,rgba(255,255,255,.92) 28%,rgba(255,255,255,.70) 58%,rgba(255,255,255,.52) 100%),linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.32) 62%,#fff 100%)!important}.boda-hero__stack:before{inset:-12px -8px;background:radial-gradient(ellipse at center,rgba(255,255,255,.86),rgba(255,255,255,.56) 50%,transparent 82%)}.boda-logo{width:min(360px,84vw);filter:drop-shadow(0 10px 18px rgba(21,63,44,.18))}.boda-kicker{font-size:10px;letter-spacing:.10em;line-height:1.55}.boda-date{font-size:clamp(19px,6vw,26px);letter-spacing:.07em}.boda-city{font-size:clamp(17px,5.8vw,23px);letter-spacing:.15em}.boda-countdown{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:0;width:min(360px,100%);border-radius:18px}.boda-countdown div{min-width:0;padding:13px 8px}.boda-countdown div:nth-of-type(1),.boda-countdown div:nth-of-type(2){border-bottom:1px solid rgba(188,135,52,.18)}.boda-countdown div:nth-of-type(odd){border-right:1px solid rgba(188,135,52,.18)}.boda-countdown strong{font-size:clamp(28px,9vw,38px)}.boda-countdown span{font-size:8px}.boda-countdown i{display:none!important}.boda-actions{display:grid;grid-template-columns:1fr;justify-items:center;gap:10px}.boda-actions .boda-btn,.boda-rsvp__form .boda-btn{width:min(310px,100%)}.boda-story__grid,.boda-details__grid,.boda-extra__grid,.boda-gallery__grid,.boda-faq__grid,.boda-route-stops{grid-template-columns:1fr!important}.boda-card{padding:22px;border-radius:20px}.boda-card h3{font-size:28px}.boda-detail img{height:auto;max-height:170px}.boda-rsvp__header h2{font-size:clamp(36px,12vw,52px)}.boda-rsvp__form{grid-template-columns:1fr!important;padding:14px;border-radius:16px}.boda-rsvp__form label span{font-size:9px}.boda-rsvp__form input,.boda-rsvp__form select{height:46px}.boda-timeline__item{grid-template-columns:70px 1fr}.boda-timeline__item time{font-size:16px;border-radius:14px}.boda-timeline__item h3{font-size:22px}.boda-route-card{padding:16px}.boda-route-stop{padding:18px 12px}.boda-gallery__item img{aspect-ratio:16/11}.boda-footer__card{width:calc(100% - 24px);border-radius:22px}.boda-footer__card p{font-size:15px;letter-spacing:.09em}.boda-toast{width:calc(100% - 28px);max-width:420px;text-align:center;border-radius:18px}}
@media (max-width:380px){.boda-container{width:calc(100% - 22px)}.boda-hero{padding-left:11px;padding-right:11px}.boda-logo{width:88vw}.boda-kicker{font-size:9px;letter-spacing:.08em}.boda-date{font-size:18px;letter-spacing:.045em}.boda-city{font-size:16px}.boda-countdown{width:100%}.boda-countdown div{padding:11px 6px}.boda-countdown strong{font-size:27px}.boda-btn{font-size:10px;letter-spacing:.08em;padding-inline:18px}.boda-card{padding:19px}.boda-timeline__item{grid-template-columns:62px 1fr;gap:8px}.boda-timeline__item time{font-size:14px;padding:13px 4px}.boda-timeline__item div{padding:13px}}
@media (orientation:landscape) and (max-height:560px){.boda-hero{min-height:auto;padding-top:18px;padding-bottom:28px}.boda-hero__stack{gap:8px}.boda-logo{width:min(240px,38vw);margin-bottom:4px}.boda-kicker{font-size:9px;line-height:1.35}.boda-ornament{margin-top:6px;height:10px}.boda-date{margin-top:8px;font-size:18px}.boda-city{margin-top:4px;font-size:16px}.boda-countdown{width:min(520px,88vw);display:flex!important}.boda-countdown div{padding:8px 10px}.boda-countdown strong{font-size:24px}.boda-countdown span{font-size:7px}.boda-actions{display:flex}.boda-actions .boda-btn{width:auto;min-height:36px;max-width:none}.boda-hero__shade{background:radial-gradient(ellipse at 50% 34%,rgba(255,255,255,.97),rgba(255,255,255,.64) 58%,rgba(255,255,255,.26) 100%)!important}}
@media (hover:none),(pointer:coarse){.boda-card:hover,.boda-btn:hover,.boda-copy:hover,.boda-link:hover,.boda-timeline__item:hover div{transform:none}.boda-btn:hover{box-shadow:none}.boda-gallery__item:hover img{transform:none;filter:none}.boda-hero__bg{transform:none!important}}
@supports (height:100dvh){.boda-hero{min-height:100dvh}@media (max-width:900px){.boda-hero{min-height:auto}}}


/* ==========================================================
   v11.1.0 - Detalles premium: cursor elegante, scrollbar verde/dorada
   y loader con presencia mínima de 3 segundos.
   ========================================================== */
html{
  scrollbar-width:thin;
  scrollbar-color:var(--boda-gold) #f7f3eb;
}
html::-webkit-scrollbar,
body::-webkit-scrollbar{
  width:14px;
  height:14px;
}
html::-webkit-scrollbar-track,
body::-webkit-scrollbar-track{
  background:linear-gradient(180deg,#fffdf8,#f5efe4);
  border-left:1px solid rgba(188,135,52,.16);
}
html::-webkit-scrollbar-thumb,
body::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,var(--boda-green),var(--boda-gold));
  border:3px solid #f7f3eb;
  border-radius:999px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.28);
}
html::-webkit-scrollbar-thumb:hover,
body::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg,#0f3223,var(--boda-gold-2));
}
html::-webkit-scrollbar-corner,
body::-webkit-scrollbar-corner{
  background:#f7f3eb;
}

.boda-loader{
  transition:opacity .72s ease,visibility .72s ease;
}
.boda-loader img{
  transform-origin:center center;
}

@media (hover:hover) and (pointer:fine){
  body.boda-custom-cursor,
  body.boda-custom-cursor .boda-simple,
  body.boda-custom-cursor .boda-simple *,
  body.boda-custom-cursor .boda-lightbox,
  body.boda-custom-cursor .boda-lightbox *{
    cursor:none!important;
  }
  .boda-cursor-dot,
  .boda-cursor-ring{
    position:fixed;
    top:0;
    left:0;
    pointer-events:none;
    opacity:0;
    z-index:2147483000;
    will-change:transform,opacity;
    transition:opacity .22s ease,border-color .22s ease,background .22s ease,box-shadow .22s ease;
  }
  .boda-cursor-dot{
    width:7px;
    height:7px;
    border-radius:50%;
    background:var(--boda-gold);
    box-shadow:0 0 0 3px rgba(188,135,52,.10),0 0 18px rgba(188,135,52,.38);
  }
  .boda-cursor-ring{
    width:34px;
    height:34px;
    border-radius:50%;
    border:1px solid rgba(21,63,44,.58);
    background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.10),rgba(255,255,255,.02));
    box-shadow:0 8px 22px rgba(21,63,44,.12),inset 0 0 0 1px rgba(188,135,52,.18);
    backdrop-filter:blur(2px);
  }
  body.boda-cursor-ready .boda-cursor-dot,
  body.boda-cursor-ready .boda-cursor-ring{
    opacity:1;
  }
  body.boda-cursor-hover .boda-cursor-dot{
    background:var(--boda-green);
    box-shadow:0 0 0 4px rgba(21,63,44,.10),0 0 18px rgba(21,63,44,.28);
  }
  body.boda-cursor-hover .boda-cursor-ring{
    border-color:rgba(188,135,52,.82);
    box-shadow:0 10px 30px rgba(188,135,52,.18),inset 0 0 0 1px rgba(21,63,44,.16);
  }
}
@media (hover:none),(pointer:coarse){
  .boda-cursor-dot,
  .boda-cursor-ring{display:none!important;}
}

/* ==========================================================
   v11.2.0 - Movimiento sutil de fondos y capas visuales.
   ========================================================== */
.boda-hero__bg{
  animation:bodaHeroWatercolorDrift 30s ease-in-out infinite alternate;
}
@keyframes bodaHeroWatercolorDrift{
  0%{background-position:50% 0%;filter:saturate(.98) contrast(.98) brightness(1.02)}
  38%{background-position:52% 1.4%;filter:saturate(1.02) contrast(.99) brightness(1.035)}
  72%{background-position:48% .6%;filter:saturate(1) contrast(.985) brightness(1.025)}
  100%{background-position:51% 2%;filter:saturate(1.03) contrast(.99) brightness(1.04)}
}
.boda-section{
  isolation:isolate;
  overflow:hidden;
}
.boda-section:before{
  content:"";
  position:absolute;
  inset:-18% -8%;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(ellipse at 16% 20%,rgba(216,179,118,.13),transparent 34%),
    radial-gradient(ellipse at 88% 72%,rgba(21,63,44,.055),transparent 30%),
    radial-gradient(ellipse at 48% 110%,rgba(188,135,52,.07),transparent 36%);
  opacity:.68;
  transform:translate3d(-1.6%,0,0) scale(1.01);
  animation:bodaSoftBackgroundDrift 22s ease-in-out infinite alternate;
}
.boda-section:nth-of-type(even):before{
  animation-duration:27s;
  animation-direction:alternate-reverse;
  opacity:.55;
}
.boda-section>.boda-container{
  position:relative;
  z-index:1;
}
.boda-rsvp:before{
  animation:bodaRsvpBackgroundFloat 18s ease-in-out infinite alternate;
}
.boda-rsvp:after{
  animation:bodaRsvpBackgroundFloat 22s ease-in-out infinite alternate-reverse;
}
@keyframes bodaSoftBackgroundDrift{
  0%{transform:translate3d(-1.8%,-.5%,0) scale(1.01);opacity:.52}
  50%{transform:translate3d(1.2%,.7%,0) scale(1.025);opacity:.74}
  100%{transform:translate3d(2.2%,-.4%,0) scale(1.015);opacity:.60}
}
@keyframes bodaRsvpBackgroundFloat{
  0%{translate:0 0;opacity:.14}
  50%{translate:12px -8px;opacity:.22}
  100%{translate:-8px 10px;opacity:.17}
}
@media (max-width:900px){
  .boda-hero__bg{animation-duration:36s;}
  .boda-section:before{opacity:.42;animation-duration:30s;}
}
@media (prefers-reduced-motion:reduce){
  .boda-hero__bg,.boda-section:before,.boda-rsvp:before,.boda-rsvp:after{animation:none!important;}
}

/* ==========================================================
   v11.3.0 - Portada 100% alto en cualquier dispositivo.
   La primera pantalla mantiene logo, textos, contador y botones
   dentro del alto visible, usando escalado fluido y safe-area.
   ========================================================== */
.boda-simple{
  --boda-hero-height:calc(var(--boda-vh, 1vh) * 100);
}
.boda-hero{
  min-height:100vh!important;
  min-height:100svh!important;
  min-height:var(--boda-hero-height)!important;
  height:auto!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding-top:max(clamp(20px,4.6vh,64px),env(safe-area-inset-top))!important;
  padding-bottom:max(clamp(18px,4.2vh,52px),env(safe-area-inset-bottom))!important;
}
.boda-hero__stack{
  min-height:auto!important;
  max-height:calc(var(--boda-hero-height) - max(clamp(20px,4.6vh,64px),env(safe-area-inset-top)) - max(clamp(18px,4.2vh,52px),env(safe-area-inset-bottom)))!important;
  justify-content:center!important;
  gap:clamp(10px,1.8vh,22px)!important;
}
.boda-hero__content{
  flex:0 1 auto;
}
.boda-countdown,
.boda-actions{
  flex:0 0 auto;
}

@supports (height:100dvh){
  .boda-hero{
    min-height:100dvh!important;
  }
  .boda-simple{
    --boda-hero-height:100dvh;
  }
}

@media (max-width:900px){
  .boda-hero{
    min-height:100vh!important;
    min-height:100svh!important;
    min-height:var(--boda-hero-height)!important;
    padding-top:max(clamp(16px,4svh,40px),env(safe-area-inset-top))!important;
    padding-bottom:max(clamp(16px,4svh,40px),env(safe-area-inset-bottom))!important;
  }
  .boda-hero__stack{
    gap:clamp(8px,1.45svh,16px)!important;
    padding-top:0!important;
    padding-bottom:0!important;
  }
  .boda-logo{
    width:clamp(190px,58vw,340px)!important;
    margin-bottom:clamp(4px,1.2svh,12px)!important;
  }
  .boda-kicker{
    font-size:clamp(9px,1.55vw,12px)!important;
    line-height:1.45!important;
    letter-spacing:.11em!important;
  }
  .boda-ornament{
    margin-top:clamp(6px,1.1svh,12px)!important;
    height:clamp(9px,1.8svh,15px)!important;
  }
  .boda-date{
    margin-top:clamp(7px,1.4svh,15px)!important;
    font-size:clamp(18px,3.4vw,28px)!important;
    letter-spacing:.11em!important;
  }
  .boda-city{
    margin-top:clamp(4px,1svh,10px)!important;
    font-size:clamp(16px,3vw,24px)!important;
    letter-spacing:.18em!important;
  }
  .boda-actions{
    margin-top:0!important;
  }
}

@media (max-width:640px){
  .boda-hero{
    min-height:100vh!important;
    min-height:100svh!important;
    min-height:var(--boda-hero-height)!important;
    padding-left:14px!important;
    padding-right:14px!important;
  }
  .boda-logo{
    width:clamp(168px,55vw,250px)!important;
  }
  .boda-countdown{
    width:min(340px,100%)!important;
  }
  .boda-countdown div{
    padding:clamp(9px,1.65svh,13px) 7px!important;
  }
  .boda-countdown strong{
    font-size:clamp(25px,7vw,35px)!important;
  }
  .boda-countdown span{
    font-size:7.5px!important;
  }
  .boda-actions{
    width:min(340px,100%)!important;
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:8px!important;
  }
  .boda-actions .boda-btn{
    width:100%!important;
    min-width:0!important;
    min-height:clamp(34px,5.4svh,42px)!important;
    padding:0 9px!important;
    font-size:clamp(8px,2.05vw,9.5px)!important;
    letter-spacing:.055em!important;
    white-space:normal!important;
    text-align:center!important;
    line-height:1.08!important;
  }
}

@media (max-width:380px){
  .boda-hero{
    min-height:100vh!important;
    min-height:100svh!important;
    min-height:var(--boda-hero-height)!important;
    padding-left:10px!important;
    padding-right:10px!important;
  }
  .boda-logo{
    width:clamp(150px,51vw,205px)!important;
  }
  .boda-kicker{
    font-size:8.6px!important;
    letter-spacing:.075em!important;
  }
  .boda-date{
    font-size:clamp(16px,5vw,19px)!important;
    letter-spacing:.055em!important;
  }
  .boda-city{
    font-size:15px!important;
    letter-spacing:.12em!important;
  }
  .boda-actions .boda-btn{
    font-size:7.8px!important;
    padding-inline:6px!important;
  }
}

@media (max-height:740px){
  .boda-hero{
    padding-top:max(12px,env(safe-area-inset-top))!important;
    padding-bottom:max(12px,env(safe-area-inset-bottom))!important;
  }
  .boda-hero__stack{
    gap:clamp(6px,1.15vh,12px)!important;
  }
  .boda-logo{
    width:clamp(155px,24vw,285px)!important;
    margin-bottom:4px!important;
  }
  .boda-kicker{
    font-size:clamp(8px,1.2vw,10.5px)!important;
    line-height:1.35!important;
  }
  .boda-ornament{
    margin-top:5px!important;
    height:10px!important;
  }
  .boda-date{
    margin-top:6px!important;
    font-size:clamp(16px,2vw,24px)!important;
  }
  .boda-city{
    margin-top:3px!important;
    font-size:clamp(14px,1.7vw,20px)!important;
  }
  .boda-countdown div{
    padding-top:clamp(8px,1.3vh,14px)!important;
    padding-bottom:clamp(8px,1.3vh,14px)!important;
  }
  .boda-countdown strong{
    font-size:clamp(24px,4.5vh,34px)!important;
  }
  .boda-actions .boda-btn{
    min-height:clamp(34px,5.4vh,42px)!important;
  }
}

@media (orientation:landscape) and (max-height:560px){
  .boda-hero{
    min-height:100vh!important;
    min-height:100svh!important;
    min-height:var(--boda-hero-height)!important;
    padding-top:max(8px,env(safe-area-inset-top))!important;
    padding-bottom:max(8px,env(safe-area-inset-bottom))!important;
  }
  .boda-hero__stack{
    gap:6px!important;
  }
  .boda-logo{
    width:clamp(126px,17vw,210px)!important;
    margin-bottom:0!important;
  }
  .boda-kicker{
    font-size:8px!important;
    line-height:1.25!important;
    letter-spacing:.07em!important;
  }
  .boda-ornament{
    margin-top:3px!important;
    height:8px!important;
  }
  .boda-date{
    margin-top:4px!important;
    font-size:15px!important;
    letter-spacing:.06em!important;
  }
  .boda-city{
    margin-top:1px!important;
    font-size:13px!important;
    letter-spacing:.11em!important;
  }
  .boda-countdown{
    width:min(470px,86vw)!important;
  }
  .boda-countdown div{
    padding:6px 8px!important;
  }
  .boda-countdown strong{
    font-size:21px!important;
  }
  .boda-countdown span{
    font-size:6.5px!important;
    margin-top:1px!important;
  }
  .boda-actions{
    display:flex!important;
    gap:8px!important;
    width:auto!important;
  }
  .boda-actions .boda-btn{
    width:auto!important;
    min-width:150px!important;
    min-height:30px!important;
    font-size:8px!important;
    padding-inline:11px!important;
  }
}

/* ==========================================================
   v11.4.0 - Imágenes con movimiento, RSVP full-screen y
   formulario avanzado por pasos.
   ========================================================== */
.boda-motion-frame,
.boda-gallery-motion{
  display:block;
  transform:translate3d(0,var(--boda-img-y,0px),0);
  will-change:transform;
  transition:transform .16s linear;
}
.boda-detail .boda-motion-frame{margin:0 auto 8px;}
.boda-agenda__image-inner{width:100%;}
.boda-gallery-motion{overflow:hidden;border-radius:inherit;}
.boda-gallery__item img{width:100%;}

.boda-rsvp{
  width:100vw!important;
  min-height:100vh!important;
  min-height:100svh!important;
  min-height:calc(var(--boda-vh,1vh) * 100)!important;
  margin-left:calc(50% - 50vw)!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:clamp(54px,7vh,92px) 0!important;
}
.boda-rsvp .boda-container{
  width:min(1220px,calc(100% - 48px))!important;
  min-height:min(760px,calc((var(--boda-vh,1vh) * 100) - 96px));
  display:grid!important;
  grid-template-columns:minmax(260px,.72fr) minmax(560px,1.28fr)!important;
  gap:clamp(28px,4vw,62px)!important;
  align-items:center!important;
}
.boda-rsvp__header{max-width:470px;}
.boda-rsvp__form.boda-rsvp-wizard{
  display:block!important;
  width:100%;
  max-width:760px;
  margin-left:auto;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  border-radius:clamp(18px,2vw,28px);
  padding:clamp(18px,2.6vw,30px)!important;
  box-shadow:0 28px 70px rgba(0,0,0,.20);
}
.boda-rsvp-steps{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
  margin:0 0 20px;
}
.boda-rsvp-steps button{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  min-height:38px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:rgba(255,255,255,.72);
  font:800 9px/1 var(--boda-sans);
  letter-spacing:.08em;
  text-transform:uppercase;
  cursor:pointer;
  transition:background .24s ease,color .24s ease,border-color .24s ease,transform .24s ease;
}
.boda-rsvp-steps button span{
  display:grid;
  place-items:center;
  width:20px;
  height:20px;
  border-radius:50%;
  background:rgba(255,255,255,.12);
  color:var(--boda-gold-2);
}
.boda-rsvp-steps button.is-active,
.boda-rsvp-steps button.is-complete{
  color:#fff;
  border-color:rgba(216,179,118,.55);
  background:rgba(216,179,118,.18);
}
.boda-rsvp-steps button.is-active{transform:translateY(-1px);}
.boda-rsvp-step{
  display:none;
  border:0;
  padding:0;
  margin:0;
  min-height:350px;
}
.boda-rsvp-step.is-active{
  display:block;
  animation:bodaRsvpStepIn .36s cubic-bezier(.2,.8,.2,1) both;
}
.boda-rsvp-step.is-skipped{opacity:.58;}
@keyframes bodaRsvpStepIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.boda-rsvp-step legend{
  margin:0 0 6px;
  color:#fff;
  font:500 clamp(30px,3vw,44px)/1 var(--boda-serif);
}
.boda-rsvp-step p{
  margin:0 0 18px;
  color:rgba(255,255,255,.75);
}
.boda-rsvp-fields,
.boda-rsvp-options-grid{
  display:grid;
  gap:14px;
}
.boda-rsvp-fields--two{grid-template-columns:repeat(2,minmax(0,1fr));}
.boda-rsvp-field-wide,
.boda-rsvp-options-wide{grid-column:1/-1;}
.boda-rsvp__form.boda-rsvp-wizard label{
  display:grid;
  gap:7px;
  color:rgba(255,255,255,.78);
  font-size:10px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.boda-rsvp__form.boda-rsvp-wizard input,
.boda-rsvp__form.boda-rsvp-wizard select,
.boda-rsvp__form.boda-rsvp-wizard textarea{
  width:100%;
  min-width:0;
  border:1px solid rgba(255,255,255,.18);
  border-radius:12px;
  background:#fff;
  color:var(--boda-green);
  padding:0 13px;
  font:600 14px/1.25 var(--boda-sans);
  outline:none;
}
.boda-rsvp__form.boda-rsvp-wizard input,
.boda-rsvp__form.boda-rsvp-wizard select{height:48px;}
.boda-rsvp__form.boda-rsvp-wizard textarea{min-height:92px;padding:12px 13px;resize:vertical;}
.boda-rsvp__form.boda-rsvp-wizard input:focus,
.boda-rsvp__form.boda-rsvp-wizard select:focus,
.boda-rsvp__form.boda-rsvp-wizard textarea:focus{border-color:var(--boda-gold-2);box-shadow:0 0 0 4px rgba(216,179,118,.16)}
.boda-rsvp-choice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}
.boda-rsvp-choice{
  position:relative;
  display:block!important;
  text-transform:none!important;
  letter-spacing:0!important;
  cursor:pointer;
}
.boda-rsvp-choice input{position:absolute;opacity:0;inset:0;pointer-events:none;}
.boda-rsvp-choice>span{
  display:grid;
  gap:6px;
  min-height:126px;
  align-content:center;
  padding:20px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:18px;
  background:rgba(255,255,255,.09);
  color:#fff;
  transition:background .24s ease,border-color .24s ease,transform .24s ease,box-shadow .24s ease;
}
.boda-rsvp-choice strong{font:600 27px/1 var(--boda-serif);}
.boda-rsvp-choice small{color:rgba(255,255,255,.72);font:600 12px/1.35 var(--boda-sans);}
.boda-rsvp-choice input:checked+span{border-color:rgba(216,179,118,.72);background:rgba(216,179,118,.18);box-shadow:0 18px 38px rgba(0,0,0,.14);transform:translateY(-2px)}
.boda-guest-groups{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:16px;}
.boda-guest-group,
.boda-rsvp-options-grid>div{
  padding:14px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  background:rgba(255,255,255,.07);
}
.boda-guest-group h4,
.boda-rsvp-options-grid h4{
  margin:0 0 11px;
  color:var(--boda-gold-2);
  font:800 11px/1 var(--boda-sans);
  letter-spacing:.14em;
  text-transform:uppercase;
}
.boda-guest-group [data-guest-list]{display:grid;gap:10px;}
.boda-generated-guest{letter-spacing:.10em!important;}
.boda-rsvp-options-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
.boda-rsvp-checks{display:flex;flex-wrap:wrap;gap:8px;}
.boda-rsvp-checks label{
  display:inline-flex!important;
  align-items:center;
  gap:7px!important;
  min-height:34px;
  padding:7px 10px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:#fff!important;
  cursor:pointer;
  font-size:10px!important;
  letter-spacing:.05em!important;
  text-transform:none!important;
  transition:background .22s ease,border-color .22s ease,transform .22s ease;
}
.boda-rsvp-checks input{width:14px!important;height:14px!important;accent-color:var(--boda-gold);padding:0!important;}
.boda-rsvp-checks label:has(input:checked){background:rgba(216,179,118,.18);border-color:rgba(216,179,118,.55);transform:translateY(-1px)}
.boda-rsvp-wizard__nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-top:20px;
}
.boda-rsvp-wizard__nav .boda-btn[hidden]{display:none!important;}
.boda-rsvp-wizard__nav .boda-btn{min-width:160px;}
.boda-rsvp-wizard .boda-form__status{margin:14px 0 0;min-height:22px;}

@media(max-width:1040px){
  .boda-rsvp .boda-container{grid-template-columns:1fr!important;min-height:auto;text-align:center;}
  .boda-rsvp__header{max-width:760px;margin:auto;}
  .boda-rsvp__form.boda-rsvp-wizard{max-width:860px;margin-inline:auto;}
}
@media(max-width:700px){
  .boda-rsvp{min-height:100svh!important;padding:52px 0!important;}
  .boda-rsvp .boda-container{width:calc(100% - 28px)!important;gap:24px!important;}
  .boda-rsvp-steps{grid-template-columns:repeat(2,minmax(0,1fr));}
  .boda-rsvp-fields--two,
  .boda-rsvp-choice-grid,
  .boda-guest-groups,
  .boda-rsvp-options-grid{grid-template-columns:1fr!important;}
  .boda-rsvp-step{min-height:auto;}
  .boda-rsvp-wizard__nav{display:grid;grid-template-columns:1fr;}
  .boda-rsvp-wizard__nav .boda-btn{width:100%;min-width:0;}
  .boda-rsvp-choice>span{min-height:96px;}
  .boda-rsvp-checks--dense label{font-size:9.5px!important;}
}
@media(prefers-reduced-motion:reduce){
  .boda-motion-frame,
  .boda-gallery-motion{transform:none!important;}
}

/* ==========================================================
   v11.5.0 - Loader fusionado con logo hero + navegación por puntos.
   ========================================================== */
html.boda-no-native-scrollbar,
html.boda-no-native-scrollbar body,
body.boda-no-native-scrollbar{
  scrollbar-width:none!important;
  -ms-overflow-style:none!important;
}
html.boda-no-native-scrollbar::-webkit-scrollbar,
html.boda-no-native-scrollbar body::-webkit-scrollbar,
body.boda-no-native-scrollbar::-webkit-scrollbar{
  width:0!important;
  height:0!important;
  display:none!important;
}
html.boda-no-native-scrollbar::-webkit-scrollbar-track,
html.boda-no-native-scrollbar::-webkit-scrollbar-thumb,
html.boda-no-native-scrollbar body::-webkit-scrollbar-track,
html.boda-no-native-scrollbar body::-webkit-scrollbar-thumb,
body.boda-no-native-scrollbar::-webkit-scrollbar-track,
body.boda-no-native-scrollbar::-webkit-scrollbar-thumb{
  display:none!important;
  background:transparent!important;
  border:0!important;
}

.boda-simple.boda-loader-pending .boda-hero .boda-logo{
  opacity:0;
  visibility:hidden;
}
.boda-simple.boda-loader-complete .boda-hero .boda-logo{
  opacity:1;
  visibility:visible;
}
.boda-loader{
  background:rgba(255,255,255,.985);
  transition:background .82s ease,opacity .58s ease,visibility .58s ease;
}
.boda-loader.is-merging{
  background:rgba(255,255,255,0);
}
.boda-loader.is-merging img{
  animation:bodaLoaderMergeToHero .94s cubic-bezier(.18,.84,.22,1) forwards!important;
  will-change:transform,opacity,filter;
}
.boda-loader.is-merging span{
  opacity:0;
  transform:scaleX(0);
  transition:opacity .26s ease,transform .26s ease;
}
.boda-loader.is-hidden{
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
}
@keyframes bodaLoaderMergeToHero{
  0%{
    transform:translate3d(0,0,0) scale(1);
    opacity:1;
    filter:drop-shadow(0 16px 24px rgba(21,63,44,.10));
  }
  72%{
    opacity:1;
  }
  100%{
    transform:translate3d(var(--boda-loader-merge-x,0px),var(--boda-loader-merge-y,0px),0) scale(var(--boda-loader-merge-scale,1));
    opacity:.98;
    filter:drop-shadow(0 12px 18px rgba(21,63,44,.18));
  }
}
@media (prefers-reduced-motion:reduce){
  .boda-loader.is-merging img{animation:none!important;}
}

.boda-section-dots{
  position:fixed;
  right:max(14px,env(safe-area-inset-right));
  top:50%;
  transform:translateY(-50%);
  z-index:9990;
  display:grid;
  gap:11px;
  padding:10px 7px;
  border:1px solid rgba(188,135,52,.22);
  border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.76),rgba(255,253,249,.54));
  box-shadow:0 18px 42px rgba(21,63,44,.12),inset 0 0 0 1px rgba(255,255,255,.52);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
.boda-section-dot{
  position:relative;
  width:14px;
  height:14px;
  padding:0;
  border:1px solid rgba(21,63,44,.58);
  border-radius:999px;
  background:rgba(255,255,255,.82);
  box-shadow:0 0 0 3px rgba(188,135,52,.08),inset 0 0 0 2px rgba(255,255,255,.58);
  cursor:pointer;
  transition:height .28s ease,background .28s ease,border-color .28s ease,box-shadow .28s ease,transform .28s ease;
}
.boda-section-dot span{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  color:transparent;
  font:800 0/1 var(--boda-sans);
  pointer-events:none;
}
.boda-section-dot em{
  position:absolute;
  right:24px;
  top:50%;
  transform:translate(8px,-50%);
  opacity:0;
  visibility:hidden;
  white-space:nowrap;
  padding:7px 10px;
  border:1px solid rgba(188,135,52,.26);
  border-radius:999px;
  background:rgba(255,253,249,.94);
  color:var(--boda-green);
  box-shadow:0 10px 24px rgba(21,63,44,.10);
  font:800 10px/1 var(--boda-sans);
  letter-spacing:.10em;
  text-transform:uppercase;
  transition:opacity .22s ease,visibility .22s ease,transform .22s ease;
}
.boda-section-dot:hover,
.boda-section-dot:focus-visible{
  transform:scale(1.12);
  border-color:var(--boda-gold);
  outline:none;
}
.boda-section-dot:hover em,
.boda-section-dot:focus-visible em{
  opacity:1;
  visibility:visible;
  transform:translate(0,-50%);
}
.boda-section-dot.is-active{
  height:34px;
  border-color:rgba(188,135,52,.90);
  background:linear-gradient(180deg,var(--boda-green),var(--boda-gold));
  box-shadow:0 9px 22px rgba(21,63,44,.22),0 0 0 4px rgba(188,135,52,.12),inset 0 0 0 1px rgba(255,255,255,.30);
}
.boda-section-dot.is-active span{
  color:rgba(255,255,255,.88);
  font-size:7px;
}
@media (max-width:760px){
  .boda-section-dots{
    right:max(6px,env(safe-area-inset-right));
    gap:8px;
    padding:8px 5px;
    background:rgba(255,253,249,.64);
  }
  .boda-section-dot{
    width:10px;
    height:10px;
  }
  .boda-section-dot.is-active{
    height:24px;
  }
  .boda-section-dot em,
  .boda-section-dot span{
    display:none!important;
  }
}
@media (max-width:420px){
  .boda-section-dots{
    right:4px;
    gap:6px;
    padding:7px 4px;
    border-color:rgba(188,135,52,.14);
  }
  .boda-section-dot{
    width:8px;
    height:8px;
  }
  .boda-section-dot.is-active{
    height:20px;
  }
}
@media print{
  .boda-section-dots{display:none!important;}
}


/* ==========================================================
   Ajuste solicitado: fusión directa del logo, puntos puros y Spotify.
   ========================================================== */
.boda-logo.is-loader-sized,
.boda-simple.boda-loader-complete .boda-hero .boda-logo.is-loader-sized{
  width:var(--boda-hero-logo-merge-width, min(240px,62vw))!important;
  max-width:min(430px,82vw)!important;
}
.boda-loader img{
  width:min(240px,62vw)!important;
}
.boda-section-dot,
.boda-section-dot.is-active{
  width:13px!important;
  height:13px!important;
  min-width:13px!important;
  min-height:13px!important;
  border-radius:999px!important;
}
.boda-section-dot span,
.boda-section-dot.is-active span{
  display:block!important;
  color:transparent!important;
  font-size:0!important;
  line-height:0!important;
  width:100%!important;
  height:100%!important;
}
.boda-section-dot.is-active{
  transform:scale(1.38)!important;
  background:linear-gradient(135deg,var(--boda-green),var(--boda-gold))!important;
  box-shadow:0 0 0 4px rgba(188,135,52,.14),0 10px 22px rgba(21,63,44,.20)!important;
}
@media (max-width:760px){
  .boda-section-dot,
  .boda-section-dot.is-active{width:10px!important;height:10px!important;min-width:10px!important;min-height:10px!important;}
}

.boda-spotify{
  overflow:hidden;
  background:
    radial-gradient(circle at 14% 15%,rgba(216,179,118,.18),transparent 31%),
    radial-gradient(circle at 86% 80%,rgba(21,63,44,.10),transparent 30%),
    linear-gradient(180deg,#fff,#fbf8f1 48%,#fff);
}
.boda-spotify:before{
  content:"";
  position:absolute;
  inset:18px;
  border:1px solid rgba(188,135,52,.16);
  border-radius:32px;
  pointer-events:none;
}
.boda-spotify__grid{
  display:grid;
  grid-template-columns:minmax(0,.82fr) minmax(420px,1.18fr);
  gap:clamp(28px,5vw,74px);
  align-items:center;
}
.boda-spotify__copy h2{
  margin:0;
  color:var(--boda-green);
  font:500 clamp(42px,5.6vw,76px)/.92 var(--boda-serif);
}
.boda-spotify__copy .boda-ornament{margin-left:0;margin-right:0;}
.boda-spotify__copy p:not(.boda-label){
  margin:18px 0 0;
  color:var(--boda-muted);
  font-size:16px;
  max-width:560px;
}
.boda-spotify__actions{display:flex;flex-wrap:wrap;gap:13px;margin-top:28px;}
.boda-spotify__panel{
  position:relative;
  padding:clamp(18px,2.8vw,30px);
  border:1px solid rgba(188,135,52,.28);
  border-radius:30px;
  background:linear-gradient(145deg,rgba(255,255,255,.94),rgba(255,252,246,.86));
  box-shadow:0 26px 80px rgba(21,63,44,.16), inset 0 0 0 1px rgba(255,255,255,.62);
  backdrop-filter:blur(14px);
}
.boda-spotify__glow{
  position:absolute;
  right:22px;
  top:-26px;
  width:132px;
  height:132px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(188,135,52,.30),transparent 68%);
  filter:blur(8px);
  pointer-events:none;
}
.boda-spotify__embed{
  position:relative;
  z-index:1;
  display:block;
  width:100%;
  min-height:352px;
  border:0;
  border-radius:22px;
  box-shadow:0 18px 36px rgba(21,63,44,.12);
  background:#153f2c;
}
.boda-spotify__placeholder{
  min-height:310px;
  display:grid;
  place-items:center;
  text-align:center;
  padding:34px;
  border:1px dashed rgba(188,135,52,.34);
  border-radius:22px;
  background:linear-gradient(135deg,rgba(21,63,44,.06),rgba(188,135,52,.08));
  color:var(--boda-green);
}
.boda-spotify__placeholder span{
  display:grid;
  place-items:center;
  width:70px;
  height:70px;
  margin:0 auto 12px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--boda-green),var(--boda-gold));
  color:#fff;
  font:600 38px/1 var(--boda-serif);
  box-shadow:0 14px 26px rgba(21,63,44,.18);
}
.boda-spotify__placeholder strong{display:block;font:600 34px/1 var(--boda-serif);}
.boda-spotify__placeholder p{margin:7px auto 0;max-width:360px;color:var(--boda-muted);}
.boda-spotify__tracks{
  display:grid;
  gap:10px;
  margin-top:18px;
}
.boda-spotify-track{
  display:grid;
  grid-template-columns:42px minmax(0,1fr);
  gap:12px;
  align-items:center;
  padding:12px 14px;
  border:1px solid rgba(188,135,52,.18);
  border-radius:18px;
  background:rgba(255,255,255,.72);
  box-shadow:0 8px 20px rgba(21,63,44,.06);
  transition:transform .28s ease,border-color .28s ease,box-shadow .28s ease,background .28s ease;
}
.boda-spotify-track:hover{
  transform:translateY(-3px);
  border-color:rgba(188,135,52,.38);
  box-shadow:0 14px 32px rgba(21,63,44,.10);
  background:#fff;
}
.boda-spotify-track>span{
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  border-radius:50%;
  color:#fff;
  background:linear-gradient(135deg,var(--boda-gold),var(--boda-green));
  font:600 21px/1 var(--boda-serif);
}
.boda-spotify-track strong{
  display:block;
  color:var(--boda-green);
  font:700 14px/1.25 var(--boda-sans);
  letter-spacing:.02em;
}
.boda-spotify-track em{
  display:block;
  margin-top:2px;
  color:var(--boda-gold);
  font-style:normal;
  font-weight:800;
  font-size:11px;
  letter-spacing:.11em;
  text-transform:uppercase;
}
.boda-spotify-track small{
  display:block;
  margin-top:4px;
  color:var(--boda-muted);
  font-size:12px;
}
@media (max-width:980px){
  .boda-spotify__grid{grid-template-columns:1fr;}
  .boda-spotify__copy{text-align:center;}
  .boda-spotify__copy .boda-ornament{margin-left:auto;margin-right:auto;}
  .boda-spotify__copy p:not(.boda-label){margin-left:auto;margin-right:auto;}
  .boda-spotify__actions{justify-content:center;}
}
@media (max-width:640px){
  .boda-spotify:before{inset:10px;border-radius:24px;}
  .boda-spotify__panel{padding:14px;border-radius:22px;}
  .boda-spotify__embed{min-height:300px;border-radius:18px;}
  .boda-spotify-track{grid-template-columns:36px minmax(0,1fr);padding:10px;border-radius:16px;}
  .boda-spotify-track>span{width:36px;height:36px;}
}

/* ==========================================================
   v11.5.2 · Spotify API real: playlist en directo, buscador
   y añadido de canciones por invitados.
   ========================================================== */
.screen-reader-text{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
.boda-spotify__admin-note{margin-top:18px!important;padding:12px 14px;border-radius:16px;background:rgba(188,135,52,.11);border:1px solid rgba(188,135,52,.22);font-size:13px!important;color:var(--boda-green)!important}
.boda-spotify-live{position:relative;z-index:2;padding:18px;border:1px solid rgba(21,63,44,.10);border-radius:24px;background:linear-gradient(145deg,rgba(255,255,255,.86),rgba(255,249,238,.74));box-shadow:inset 0 0 0 1px rgba(255,255,255,.55)}
.boda-spotify-live__head{display:flex;align-items:center;gap:12px;margin-bottom:14px}.boda-spotify-live__head>span{display:grid;place-items:center;flex:0 0 48px;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--boda-green),var(--boda-gold));color:#fff;font:600 27px/1 var(--boda-serif);box-shadow:0 12px 24px rgba(21,63,44,.18)}.boda-spotify-live__head strong{display:block;color:var(--boda-green);font:700 18px/1.15 var(--boda-sans)}.boda-spotify-live__head small{display:block;margin-top:3px;color:var(--boda-muted);font-size:12px}.boda-spotify-playlist{display:grid;gap:10px;max-height:430px;overflow:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:var(--boda-gold) rgba(21,63,44,.08)}.boda-spotify-playlist::-webkit-scrollbar,.boda-spotify-results::-webkit-scrollbar{width:8px}.boda-spotify-playlist::-webkit-scrollbar-thumb,.boda-spotify-results::-webkit-scrollbar-thumb{border-radius:999px;background:linear-gradient(180deg,var(--boda-green),var(--boda-gold))}.boda-spotify-api-track{display:grid;grid-template-columns:58px minmax(0,1fr) auto;gap:12px;align-items:center;padding:10px;border:1px solid rgba(188,135,52,.16);border-radius:18px;background:rgba(255,255,255,.78);box-shadow:0 8px 18px rgba(21,63,44,.05);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease,background .25s ease}.boda-spotify-api-track:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(21,63,44,.10);border-color:rgba(188,135,52,.32);background:#fff}.boda-spotify-api-track__cover{display:grid;place-items:center;width:58px;height:58px;border-radius:14px;background:linear-gradient(135deg,rgba(21,63,44,.08),rgba(188,135,52,.12));overflow:hidden;border:1px solid rgba(21,63,44,.08)}.boda-spotify-api-track__cover img{width:100%;height:100%;object-fit:contain;background:#fff}.boda-spotify-api-track__cover span{display:grid;place-items:center;width:100%;height:100%;color:#fff;background:linear-gradient(135deg,var(--boda-green),var(--boda-gold));font:600 25px/1 var(--boda-serif)}.boda-spotify-api-track__body{min-width:0}.boda-spotify-api-track__body strong{display:block;color:var(--boda-green);font:800 14px/1.22 var(--boda-sans);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.boda-spotify-api-track__body em{display:block;margin-top:3px;color:var(--boda-gold);font-style:normal;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.boda-spotify-api-track__body small{display:block;margin-top:3px;color:var(--boda-muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.boda-spotify-open,.boda-spotify-add{display:inline-flex;align-items:center;justify-content:center;min-height:36px;padding:0 13px;border:1px solid rgba(188,135,52,.38);border-radius:999px;background:#fff;color:var(--boda-green)!important;font:800 10px/1 var(--boda-sans);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;transition:transform .25s ease,background .25s ease,color .25s ease,box-shadow .25s ease}.boda-spotify-add{background:var(--boda-green);border-color:var(--boda-green);color:#fff!important}.boda-spotify-add:hover,.boda-spotify-open:hover{transform:translateY(-2px);box-shadow:0 9px 20px rgba(21,63,44,.12)}.boda-spotify-add.is-added,.boda-spotify-add:disabled{background:var(--boda-gold);border-color:var(--boda-gold);cursor:default;opacity:.95}.boda-spotify-search{margin-top:18px;padding:18px;border-radius:24px;background:linear-gradient(135deg,rgba(21,63,44,.96),rgba(31,84,58,.95));color:#fff;box-shadow:0 18px 46px rgba(21,63,44,.18)}.boda-spotify-search__title{display:flex;align-items:end;justify-content:space-between;gap:12px;margin-bottom:13px}.boda-spotify-search__title strong{display:block;color:#fff;font:600 30px/1 var(--boda-serif)}.boda-spotify-search__title small{display:block;color:rgba(255,255,255,.72);font-size:12px}.boda-spotify-search__form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px}.boda-spotify-search__form input{width:100%;height:48px;border:1px solid rgba(255,255,255,.34);border-radius:999px;background:rgba(255,255,255,.96);color:var(--boda-green);padding:0 18px;font:600 14px var(--boda-sans);outline:0}.boda-spotify-search__form input:focus{border-color:var(--boda-gold);box-shadow:0 0 0 4px rgba(188,135,52,.24)}.boda-spotify-message{min-height:20px;margin:10px 4px 0;color:rgba(255,255,255,.78);font-size:13px}.boda-spotify-message.is-success{color:#fff4cc}.boda-spotify-message.is-error{color:#ffd9d9}.boda-spotify-results{display:grid;gap:10px;margin-top:10px;max-height:390px;overflow:auto;padding-right:4px}.boda-spotify-results .boda-spotify-api-track{background:rgba(255,255,255,.96)}.boda-spotify-loading,.boda-spotify-empty{padding:22px;border-radius:18px;text-align:center;color:var(--boda-muted);background:rgba(255,255,255,.72);border:1px dashed rgba(188,135,52,.28)}.boda-spotify-search .boda-spotify-loading,.boda-spotify-search .boda-spotify-empty{color:rgba(255,255,255,.88);background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.24)}.boda-spotify-embed-fallback{margin-top:16px;border:1px solid rgba(188,135,52,.18);border-radius:18px;background:rgba(255,255,255,.72);padding:12px}.boda-spotify-embed-fallback summary{cursor:pointer;color:var(--boda-green);font:800 12px/1 var(--boda-sans);text-transform:uppercase;letter-spacing:.10em}.boda-spotify-embed-fallback[open] summary{margin-bottom:12px}
@media(max-width:760px){.boda-spotify-live,.boda-spotify-search{padding:14px;border-radius:20px}.boda-spotify-search__title{display:block}.boda-spotify-search__title strong{font-size:26px}.boda-spotify-search__title small{margin-top:6px}.boda-spotify-search__form{grid-template-columns:1fr}.boda-spotify-search__form .boda-btn{width:100%}.boda-spotify-api-track{grid-template-columns:50px minmax(0,1fr);align-items:start}.boda-spotify-api-track__cover{width:50px;height:50px;border-radius:12px}.boda-spotify-api-track__action{grid-column:1/-1}.boda-spotify-open,.boda-spotify-add{width:100%;min-height:40px}.boda-spotify-playlist,.boda-spotify-results{max-height:430px}}

/* ==========================================================
   v11.5.3 · Spotify API en modal elegante, sin interfaz Spotify.
   ========================================================== */
.boda-spotify{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  background:
    radial-gradient(circle at 13% 18%,rgba(188,135,52,.16),transparent 34%),
    radial-gradient(circle at 90% 76%,rgba(21,63,44,.10),transparent 30%),
    linear-gradient(180deg,#ffffff 0%,#fbf8f1 52%,#ffffff 100%);
}
.boda-spotify__layout{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(360px,1.1fr);
  align-items:center;
  gap:clamp(30px,6vw,84px);
}
.boda-spotify__showcase{
  position:relative;
  min-height:430px;
  display:grid;
  place-items:center;
}
.boda-spotify-orb{
  position:absolute;
  inset:auto auto 34px 14px;
  width:min(300px,62vw);
  aspect-ratio:1;
  border-radius:50%;
  background:
    radial-gradient(circle at 50% 50%,rgba(255,255,255,.96) 0 7%,transparent 7.5% 100%),
    repeating-radial-gradient(circle at 50% 50%,rgba(255,255,255,.13) 0 2px,transparent 3px 11px),
    linear-gradient(135deg,#143c2b,#1f573e 54%,#bc8734);
  box-shadow:0 38px 90px rgba(21,63,44,.25),inset 0 0 0 1px rgba(255,255,255,.20);
  transform:rotate(-12deg);
  opacity:.95;
  animation:bodaSpotifyFloat 7s ease-in-out infinite alternate;
}
.boda-spotify-orb span{
  position:absolute;
  inset:50% auto auto 50%;
  transform:translate(-50%,-50%);
  display:grid;
  place-items:center;
  width:68px;
  height:68px;
  border-radius:50%;
  background:#fff;
  color:var(--boda-green);
  font:700 38px/1 var(--boda-serif);
  box-shadow:0 10px 22px rgba(21,63,44,.16);
}
@keyframes bodaSpotifyFloat{to{transform:translate3d(10px,-12px,0) rotate(-8deg)}}
.boda-spotify-preview-card{
  position:relative;
  z-index:2;
  width:min(100%,520px);
  margin-left:auto;
  padding:clamp(18px,2.8vw,30px);
  border:1px solid rgba(188,135,52,.28);
  border-radius:34px;
  background:linear-gradient(145deg,rgba(255,255,255,.92),rgba(255,250,241,.82));
  box-shadow:0 28px 84px rgba(21,63,44,.18),inset 0 0 0 1px rgba(255,255,255,.65);
  backdrop-filter:blur(18px);
}
.boda-spotify-preview-card:before{
  content:"";
  position:absolute;
  inset:12px;
  border:1px solid rgba(188,135,52,.14);
  border-radius:26px;
  pointer-events:none;
}
.boda-spotify-preview-card__head{
  position:relative;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:14px;
}
.boda-spotify-preview-card__head span{
  display:block;
  color:var(--boda-gold);
  font:800 11px/1 var(--boda-sans);
  letter-spacing:.14em;
  text-transform:uppercase;
}
.boda-spotify-preview-card__head strong{
  display:block;
  margin-top:5px;
  color:var(--boda-green);
  font:600 clamp(28px,3vw,40px)/.9 var(--boda-serif);
}
.boda-spotify-mini-btn,
.boda-spotify-external{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:0 15px;
  border:1px solid rgba(188,135,52,.42);
  border-radius:999px;
  background:rgba(255,255,255,.72);
  color:var(--boda-green)!important;
  font:800 10px/1 var(--boda-sans);
  text-transform:uppercase;
  letter-spacing:.11em;
  text-decoration:none!important;
  cursor:pointer;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
}
.boda-spotify-mini-btn:hover,
.boda-spotify-external:hover{transform:translateY(-2px);background:#fff;box-shadow:0 12px 26px rgba(21,63,44,.10)}
.boda-spotify-preview-card>p{
  position:relative;
  margin:0 0 16px;
  color:var(--boda-muted);
  font-size:14px;
}
.boda-spotify-preview-list{
  position:relative;
  display:grid;
  gap:10px;
}
.boda-spotify-preview-track{
  display:grid;
  grid-template-columns:46px minmax(0,1fr);
  gap:12px;
  align-items:center;
  padding:9px;
  border:1px solid rgba(188,135,52,.14);
  border-radius:18px;
  background:rgba(255,255,255,.70);
  box-shadow:0 8px 18px rgba(21,63,44,.05);
}
.boda-spotify-preview-track>div{
  display:grid;
  place-items:center;
  width:46px;
  height:46px;
  border-radius:14px;
  overflow:hidden;
  background:linear-gradient(135deg,rgba(21,63,44,.08),rgba(188,135,52,.14));
}
.boda-spotify-preview-track img{width:100%;height:100%;object-fit:cover}.boda-spotify-preview-track div span{display:grid;place-items:center;width:100%;height:100%;color:#fff;background:linear-gradient(135deg,var(--boda-green),var(--boda-gold));font:700 20px/1 var(--boda-serif)}
.boda-spotify-preview-track strong{display:block;color:var(--boda-green);font:800 13px/1.2 var(--boda-sans);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.boda-spotify-preview-track em{display:block;margin-top:3px;color:var(--boda-gold);font-style:normal;font-size:10px;font-weight:900;letter-spacing:.10em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.boda-spotify__actions--modal .boda-btn{border:0;cursor:pointer;text-decoration:none!important}
.boda-spotify-modal{
  position:fixed;
  inset:0;
  z-index:99998;
  display:grid;
  place-items:center;
  padding:clamp(14px,3vw,34px);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .34s ease,visibility .34s ease;
}
.boda-spotify-modal.is-visible{opacity:1;visibility:visible;pointer-events:auto}
.boda-spotify-modal__backdrop{
  position:absolute;
  inset:0;
  background:rgba(12,35,25,.64);
  backdrop-filter:blur(16px);
}
.boda-spotify-modal__dialog{
  position:relative;
  z-index:2;
  width:min(1040px,calc(100vw - 28px));
  max-height:min(88vh,880px);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  border:1px solid rgba(225,204,161,.45);
  border-radius:32px;
  background:
    radial-gradient(circle at 0% 0%,rgba(188,135,52,.13),transparent 32%),
    radial-gradient(circle at 100% 100%,rgba(21,63,44,.10),transparent 30%),
    linear-gradient(145deg,rgba(255,255,255,.97),rgba(255,250,241,.94));
  box-shadow:0 36px 110px rgba(0,0,0,.32),inset 0 0 0 1px rgba(255,255,255,.72);
  transform:translateY(24px) scale(.96);
  transition:transform .38s cubic-bezier(.22,1,.36,1);
}
.boda-spotify-modal.is-visible .boda-spotify-modal__dialog{transform:translateY(0) scale(1)}
.boda-spotify-modal__dialog--search{width:min(980px,calc(100vw - 28px))}
.boda-spotify-modal__close{
  position:absolute;
  top:16px;
  right:16px;
  z-index:4;
  display:grid;
  place-items:center;
  width:44px;
  height:44px;
  border:1px solid rgba(188,135,52,.34);
  border-radius:50%;
  background:#fff;
  color:var(--boda-green);
  font:400 30px/1 var(--boda-serif);
  cursor:pointer;
  box-shadow:0 10px 24px rgba(21,63,44,.11);
  transition:transform .25s ease,background .25s ease,color .25s ease;
}
.boda-spotify-modal__close:hover{transform:rotate(7deg) scale(1.05);background:var(--boda-green);color:#fff}
.boda-spotify-modal__header{
  position:relative;
  padding:clamp(24px,4vw,42px) clamp(22px,4vw,54px) 18px;
  text-align:center;
}
.boda-spotify-modal__header h3{
  margin:0;
  color:var(--boda-green);
  font:500 clamp(40px,5vw,70px)/.9 var(--boda-serif);
}
.boda-spotify-modal__header .boda-ornament{margin-top:14px;margin-bottom:12px}.boda-spotify-modal__header small{display:block;max-width:620px;margin:0 auto;color:var(--boda-muted);font-size:13px}
.boda-spotify-modal__content{
  min-height:0;
  padding:0 clamp(16px,3.8vw,44px) clamp(18px,3vw,32px);
  overflow:auto;
  scrollbar-width:thin;
  scrollbar-color:var(--boda-gold) rgba(21,63,44,.08);
}
.boda-spotify-modal__content::-webkit-scrollbar{width:9px}.boda-spotify-modal__content::-webkit-scrollbar-thumb{border-radius:999px;background:linear-gradient(180deg,var(--boda-green),var(--boda-gold))}
.boda-spotify-modal__footer{
  padding:0 clamp(22px,4vw,54px) clamp(20px,3vw,34px);
  text-align:center;
}
.boda-spotify-playlist--modal{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  max-height:none;
  overflow:visible;
  padding:0;
}
.boda-spotify-api-track{
  border-color:rgba(188,135,52,.20);
  background:linear-gradient(145deg,rgba(255,255,255,.90),rgba(255,252,246,.82));
}
.boda-spotify-api-track__cover img{object-fit:cover;background:transparent}.boda-spotify-api-track__body small{font-size:11px}.boda-spotify-search--modal{
  margin:0;
  padding:0 clamp(20px,4vw,50px) clamp(22px,4vw,44px);
  border-radius:0;
  background:transparent;
  box-shadow:none;
  color:var(--boda-green);
}
.boda-spotify-search--modal .boda-spotify-search__form{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
  padding:10px;
  border:1px solid rgba(188,135,52,.24);
  border-radius:999px;
  background:rgba(255,255,255,.76);
  box-shadow:0 16px 38px rgba(21,63,44,.08);
}
.boda-spotify-search--modal .boda-spotify-search__form input{
  height:54px;
  border:0;
  background:transparent;
  padding:0 18px;
  box-shadow:none!important;
}
.boda-spotify-search--modal .boda-spotify-message{color:var(--boda-muted);text-align:center;margin:12px 0 0}.boda-spotify-search--modal .boda-spotify-message.is-success{color:var(--boda-green);font-weight:800}.boda-spotify-search--modal .boda-spotify-message.is-error{color:#9c2929;font-weight:800}.boda-spotify-search--modal .boda-spotify-results{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px;max-height:min(52vh,520px);overflow:auto;padding:2px 6px 2px 2px;scrollbar-width:thin;scrollbar-color:var(--boda-gold) rgba(21,63,44,.08)}
.boda-spotify-modal-open{overflow:hidden!important}.boda-spotify-loading,.boda-spotify-empty{grid-column:1/-1}
@media(max-width:980px){.boda-spotify__layout{grid-template-columns:1fr}.boda-spotify__showcase{min-height:auto}.boda-spotify-orb{left:50%;bottom:18px;transform:translateX(-50%) rotate(-10deg);opacity:.34}.boda-spotify-preview-card{margin:0 auto}.boda-spotify-playlist--modal,.boda-spotify-search--modal .boda-spotify-results{grid-template-columns:1fr}.boda-spotify-modal__dialog{border-radius:26px;max-height:90vh}.boda-spotify-modal__header{text-align:left;padding-right:70px}.boda-spotify-modal__header .boda-ornament{margin-left:0;margin-right:0}.boda-spotify-modal__header small{margin-left:0}}
@media(max-width:640px){.boda-spotify__actions--modal{display:grid}.boda-spotify__actions--modal .boda-btn{width:100%}.boda-spotify-preview-card{border-radius:24px}.boda-spotify-preview-card__head{display:block}.boda-spotify-mini-btn{margin-top:12px;width:100%}.boda-spotify-modal{padding:10px}.boda-spotify-modal__dialog{width:calc(100vw - 20px);max-height:92vh;border-radius:22px}.boda-spotify-modal__header{padding:22px 62px 14px 18px}.boda-spotify-modal__header h3{font-size:34px}.boda-spotify-modal__close{top:12px;right:12px;width:40px;height:40px}.boda-spotify-modal__content{padding:0 12px 16px}.boda-spotify-search--modal{padding:0 12px 18px}.boda-spotify-search--modal .boda-spotify-search__form{grid-template-columns:1fr;border-radius:22px}.boda-spotify-search--modal .boda-spotify-search__form .boda-btn{width:100%}.boda-spotify-api-track{grid-template-columns:52px minmax(0,1fr);padding:10px}.boda-spotify-api-track__action{grid-column:1/-1}.boda-spotify-add,.boda-spotify-open{width:100%}}
@media(prefers-reduced-motion:reduce){.boda-spotify-orb{animation:none}.boda-spotify-modal__dialog{transition:none}}

/* ==========================================================
   v11.5.4 · Portabilidad dominio, modales aislados y preview Spotify.
   ========================================================== */
html.boda-modal-lock,
html.boda-modal-lock body,
body.boda-modal-lock{
  overflow:hidden!important;
  overscroll-behavior:none!important;
}
body.boda-modal-lock{
  position:fixed!important;
  left:0!important;
  right:0!important;
  width:100%!important;
}
.boda-spotify-modal,
.boda-lightbox{
  overscroll-behavior:contain;
  touch-action:auto;
}
.boda-spotify-modal__dialog{
  width:min(1040px,calc(100vw - 28px))!important;
  max-width:calc(100vw - 28px)!important;
  max-height:calc((var(--boda-vh,1vh) * 100) - 28px)!important;
  min-height:0!important;
}
@supports (height:100dvh){
  .boda-spotify-modal__dialog{max-height:calc(100dvh - 28px)!important;}
}
.boda-spotify-modal__header,
.boda-spotify-modal__footer{
  flex:0 0 auto;
}
.boda-spotify-modal__content{
  flex:1 1 auto;
  min-height:0!important;
  overflow:auto!important;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
}
.boda-spotify-playlist--modal{
  height:auto;
  max-height:none;
  overflow:visible;
  padding-bottom:4px;
}
.boda-spotify-modal__dialog--search .boda-spotify-search--modal{
  flex:1 1 auto;
  min-height:0!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  overscroll-behavior:contain;
}
.boda-spotify-search--modal .boda-spotify-search__form,
.boda-spotify-search--modal .boda-spotify-message{
  flex:0 0 auto;
}
.boda-spotify-search--modal .boda-spotify-results{
  flex:1 1 auto;
  min-height:0!important;
  max-height:none!important;
  overflow:auto!important;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
}
.boda-spotify-actions-inline{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  align-items:center;
  gap:8px;
}
.boda-spotify-preview,
.boda-spotify-no-preview{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:36px;
  padding:0 13px;
  border:1px solid rgba(188,135,52,.38);
  border-radius:999px;
  background:#fff;
  color:var(--boda-green)!important;
  font:800 10px/1 var(--boda-sans);
  text-transform:uppercase;
  letter-spacing:.08em;
  white-space:nowrap;
}
.boda-spotify-preview{
  cursor:pointer;
  transition:transform .25s ease,background .25s ease,color .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.boda-spotify-preview:hover,
.boda-spotify-preview.is-playing,
.boda-spotify-preview.is-listened{
  transform:translateY(-2px);
  box-shadow:0 9px 20px rgba(21,63,44,.12);
  border-color:rgba(188,135,52,.58);
}
.boda-spotify-preview.is-playing{
  background:linear-gradient(135deg,var(--boda-green),var(--boda-gold));
  color:#fff!important;
}
.boda-spotify-preview.is-listened{
  background:rgba(216,179,118,.18);
  color:var(--boda-green)!important;
}
.boda-spotify-no-preview{
  opacity:.58;
  cursor:not-allowed;
}
.boda-spotify-add[disabled]{
  opacity:.56;
  cursor:not-allowed;
  box-shadow:none!important;
  transform:none!important;
}
.boda-spotify-add.is-preview-ok{
  opacity:1;
}
.boda-lightbox{
  overflow:auto!important;
  padding:clamp(12px,3vw,36px)!important;
  -webkit-overflow-scrolling:touch;
}
.boda-lightbox img{
  max-width:min(100%,1200px)!important;
  max-height:calc((var(--boda-vh,1vh) * 100) - 88px)!important;
  object-fit:contain!important;
}
@supports (height:100dvh){
  .boda-lightbox img{max-height:calc(100dvh - 88px)!important;}
}
@media(max-width:760px){
  .boda-spotify-modal{padding:8px!important;}
  .boda-spotify-modal__dialog{width:calc(100vw - 16px)!important;max-width:calc(100vw - 16px)!important;max-height:calc((var(--boda-vh,1vh) * 100) - 16px)!important;border-radius:20px!important;}
  .boda-spotify-playlist--modal{grid-template-columns:1fr!important;}
  .boda-spotify-actions-inline{justify-content:stretch;display:grid;grid-template-columns:1fr;}
  .boda-spotify-preview,.boda-spotify-no-preview,.boda-spotify-open,.boda-spotify-add{width:100%;}
}

/* ==========================================================
   v11.5.6 · secciones full-screen, contador independiente,
   modales Spotify corregidos y RSVP configurable.
   ========================================================== */
:root{
  --boda-safe-vh: calc(var(--boda-vh, 1vh) * 100);
}
.boda-simple{
  width:100%;
  min-height:100vh;
}
.boda-hero,
.boda-section,
.boda-rsvp,
.boda-footer{
  width:100%;
  min-height:100vh;
  min-height:var(--boda-safe-vh);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
@supports (height:100dvh){
  .boda-hero,
  .boda-section,
  .boda-rsvp,
  .boda-footer{min-height:100dvh;}
}
.boda-section,
.boda-rsvp,
.boda-footer{
  padding-block:clamp(56px,8vh,104px);
  padding-inline:0;
}
.boda-section > .boda-container,
.boda-rsvp > .boda-container,
.boda-footer > .boda-footer__card{
  width:min(1120px,calc(100% - 44px));
  margin-inline:auto;
}
.boda-countdown-section{
  position:relative;
  background:
    radial-gradient(circle at 10% 15%,rgba(188,135,52,.12),transparent 28%),
    radial-gradient(circle at 88% 85%,rgba(21,63,44,.10),transparent 30%),
    linear-gradient(180deg,#fff,#fffaf1);
}
.boda-countdown-section:before,
.boda-countdown-section:after{
  content:"";
  position:absolute;
  width:min(300px,34vw);
  aspect-ratio:1;
  border-radius:50%;
  background:radial-gradient(circle,rgba(188,135,52,.16),transparent 60%);
  filter:blur(14px);
  opacity:.65;
  pointer-events:none;
}
.boda-countdown-section:before{left:-110px;top:12%;}
.boda-countdown-section:after{right:-110px;bottom:10%;background:radial-gradient(circle,rgba(21,63,44,.13),transparent 62%);}
.boda-countdown-section__inner{
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:clamp(22px,4vh,36px);
  text-align:center;
}
.boda-countdown-section .boda-section__header{margin-bottom:0;}
.boda-countdown-section .boda-section__header small{
  display:block;
  max-width:620px;
  margin:18px auto 0;
  color:var(--boda-muted);
  font-size:15px;
}
.boda-countdown-section .boda-countdown{
  width:min(820px,100%);
  margin:clamp(12px,3vh,28px) auto 0;
  transform:translateZ(0);
}
.boda-actions--countdown{
  margin-top:clamp(20px,4vh,42px);
}
.boda-hero .boda-hero__stack{min-height:auto;}
.boda-hero .boda-logo{width:clamp(260px,30vw,450px);}
.boda-hero__content{padding-block:clamp(10px,2vh,24px);}
.boda-rsvp{
  min-height:100vh;
  min-height:var(--boda-safe-vh);
}
@supports (height:100dvh){.boda-rsvp{min-height:100dvh;}}
.boda-rsvp > .boda-container{
  display:grid;
  grid-template-columns:minmax(260px,.85fr) minmax(320px,1.15fr);
  align-items:center;
  gap:clamp(28px,5vw,70px);
}
.boda-rsvp__header{margin:0;}
.boda-rsvp__form{max-height:calc(var(--boda-safe-vh) - 112px);overflow:hidden;display:flex;flex-direction:column;min-height:min(620px,calc(var(--boda-safe-vh) - 120px));}
.boda-rsvp-step{flex:1 1 auto;min-height:0;overflow:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--boda-gold) rgba(255,255,255,.18);}
.boda-rsvp-step::-webkit-scrollbar{width:8px}.boda-rsvp-step::-webkit-scrollbar-thumb{border-radius:999px;background:linear-gradient(180deg,var(--boda-gold),rgba(255,255,255,.72))}
.boda-rsvp-wizard__nav{flex:0 0 auto;}
.boda-rsvp-closed-card{
  width:min(620px,100%);
  margin-left:auto;
  padding:clamp(30px,4vw,54px);
  border:1px solid rgba(216,179,118,.42);
  border-radius:30px;
  background:linear-gradient(145deg,rgba(255,255,255,.94),rgba(255,248,235,.84));
  color:var(--boda-green);
  text-align:center;
  box-shadow:0 24px 70px rgba(0,0,0,.18),inset 0 0 0 1px rgba(255,255,255,.62);
  backdrop-filter:blur(14px);
}
.boda-rsvp-closed-card>span{display:grid;place-items:center;width:48px;height:48px;margin:0 auto 18px;border-radius:50%;background:linear-gradient(135deg,var(--boda-green),var(--boda-gold));color:#fff;}
.boda-rsvp-closed-card h3{margin:0;color:var(--boda-green);font:600 clamp(34px,4vw,54px)/.95 var(--boda-serif);}
.boda-rsvp-closed-card p{max-width:520px;margin:16px auto 0;color:var(--boda-muted);}
.boda-rsvp-closed-card__actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:24px;}
.boda-custom-section{background:linear-gradient(180deg,#fff,#fffaf3);}
.boda-custom-section__grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(260px,1.1fr);gap:clamp(26px,5vw,70px);align-items:center;}
.boda-custom-section h2{margin:0;color:var(--boda-green);font:500 clamp(40px,5vw,70px)/.9 var(--boda-serif);}
.boda-custom-section p:not(.boda-label){max-width:560px;color:var(--boda-muted);font-size:16px;}
.boda-custom-section .boda-btn{margin-top:24px;}
.boda-custom-section__image{margin:0;}
.boda-custom-section__image img{width:100%;height:min(56vh,520px);object-fit:cover;border-radius:28px;box-shadow:var(--boda-shadow);}
/* Modales: siempre por encima de toda la web y con scroll interno correcto */
.boda-spotify-modal,
.boda-lightbox{
  z-index:2147483000!important;
}
.boda-spotify-modal__backdrop{z-index:1;}
.boda-spotify-modal__dialog{
  z-index:2!important;
  max-height:calc(var(--boda-safe-vh) - 24px)!important;
  height:auto;
}
.boda-spotify-modal__dialog--search{
  height:calc(var(--boda-safe-vh) - 24px)!important;
  max-height:calc(var(--boda-safe-vh) - 24px)!important;
}
@supports(height:100dvh){
  .boda-spotify-modal__dialog{max-height:calc(100dvh - 24px)!important;}
  .boda-spotify-modal__dialog--search{height:calc(100dvh - 24px)!important;max-height:calc(100dvh - 24px)!important;}
}
.boda-spotify-modal__header{flex:0 0 auto;}
.boda-spotify-modal__dialog--search .boda-spotify-search--modal{
  flex:1 1 auto!important;
  min-height:0!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  padding-bottom:clamp(18px,3vw,34px)!important;
}
.boda-spotify-search--modal .boda-spotify-results{
  flex:1 1 auto!important;
  min-height:160px!important;
  max-height:none!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  padding:4px 16px 16px 4px!important;
  margin-right:-6px;
  scrollbar-gutter:stable;
}
.boda-spotify-search--modal .boda-spotify-search__form{flex:0 0 auto;}
.boda-spotify-search--modal .boda-spotify-message{flex:0 0 auto;}
.boda-spotify-preview,
.boda-spotify-no-preview{display:none!important;}
.boda-spotify-actions-inline{justify-content:flex-end!important;}
.boda-spotify-add{opacity:1!important;cursor:pointer!important;}
body.boda-modal-lock .boda-section-dots,
body.boda-spotify-modal-open .boda-section-dots{opacity:0!important;pointer-events:none!important;z-index:1!important;}
.boda-section-dots{z-index:4000!important;}
@media(max-width:980px){
  .boda-section,
  .boda-rsvp,
  .boda-footer{padding-block:clamp(44px,6vh,78px);}
  .boda-rsvp > .boda-container,
  .boda-custom-section__grid{grid-template-columns:1fr;}
  .boda-rsvp__header{text-align:center;}
  .boda-rsvp-closed-card{margin-inline:auto;}
}
@media(max-width:760px){
  .boda-section > .boda-container,
  .boda-rsvp > .boda-container,
  .boda-footer > .boda-footer__card{width:min(100% - 28px,1120px);}
  .boda-countdown{display:grid!important;grid-template-columns:1fr 1px 1fr;}
  .boda-countdown i:nth-of-type(2){display:none;}
  .boda-countdown div{min-width:0;padding:14px 10px;}
  .boda-countdown strong{font-size:34px;}
  .boda-actions--countdown{display:grid;width:100%;max-width:360px;}
  .boda-actions--countdown .boda-btn{width:100%;}
  .boda-rsvp__form{max-height:calc(var(--boda-safe-vh) - 86px);min-height:calc(var(--boda-safe-vh) - 96px);}
  .boda-rsvp > .boda-container{gap:18px;}
  .boda-rsvp__header h2{font-size:clamp(34px,9vw,48px);}
  .boda-spotify-modal{padding:8px!important;}
  .boda-spotify-modal__dialog,
  .boda-spotify-modal__dialog--search{width:calc(100vw - 16px)!important;max-width:calc(100vw - 16px)!important;height:calc(var(--boda-safe-vh) - 16px)!important;max-height:calc(var(--boda-safe-vh) - 16px)!important;}
  .boda-spotify-search--modal .boda-spotify-results{min-height:130px!important;padding-right:12px!important;}
  .boda-spotify-api-track{grid-template-columns:52px minmax(0,1fr)!important;}
  .boda-spotify-api-track__action{grid-column:1/-1!important;}
}

/* ==========================================================
   v11.5.7 · Modal Spotify a pantalla completa real.
   - El modal se renderiza por encima de toda la web.
   - El buscador ocupa el 100% del navegador.
   - Solo el contenido interno del modal tiene scroll.
   ========================================================== */
body.boda-modal-lock,
body.boda-spotify-modal-open{
  overflow:hidden!important;
  overscroll-behavior:none!important;
}
body.boda-spotify-modal-open .boda-section-dots,
body.boda-modal-lock .boda-section-dots{
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
  z-index:0!important;
}
.boda-spotify-modal{
  position:fixed!important;
  inset:0!important;
  z-index:2147483600!important;
  width:100vw!important;
  height:calc(var(--boda-vh,1vh) * 100)!important;
  min-height:calc(var(--boda-vh,1vh) * 100)!important;
  max-height:calc(var(--boda-vh,1vh) * 100)!important;
  display:flex!important;
  align-items:stretch!important;
  justify-content:stretch!important;
  padding:0!important;
  margin:0!important;
  overflow:hidden!important;
  overscroll-behavior:contain!important;
  touch-action:auto!important;
}
@supports (height:100dvh){
  .boda-spotify-modal{
    height:100dvh!important;
    min-height:100dvh!important;
    max-height:100dvh!important;
  }
}
.boda-spotify-modal__backdrop{
  position:absolute!important;
  inset:0!important;
  z-index:1!important;
  background:rgba(12,35,25,.72)!important;
  backdrop-filter:blur(18px)!important;
}
.boda-spotify-modal__dialog,
.boda-spotify-modal__dialog--search{
  position:relative!important;
  z-index:2!important;
  width:100vw!important;
  max-width:none!important;
  height:calc(var(--boda-vh,1vh) * 100)!important;
  min-height:calc(var(--boda-vh,1vh) * 100)!important;
  max-height:calc(var(--boda-vh,1vh) * 100)!important;
  margin:0!important;
  border:0!important;
  border-radius:0!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  box-shadow:none!important;
  background:
    radial-gradient(circle at 0% 0%,rgba(188,135,52,.14),transparent 28%),
    radial-gradient(circle at 100% 100%,rgba(21,63,44,.12),transparent 30%),
    linear-gradient(145deg,rgba(255,255,255,.985),rgba(255,249,238,.965))!important;
}
@supports (height:100dvh){
  .boda-spotify-modal__dialog,
  .boda-spotify-modal__dialog--search{
    height:100dvh!important;
    min-height:100dvh!important;
    max-height:100dvh!important;
  }
}
.boda-spotify-modal__close{
  position:fixed!important;
  top:max(16px,env(safe-area-inset-top))!important;
  right:max(16px,env(safe-area-inset-right))!important;
  z-index:2147483640!important;
}
.boda-spotify-modal__header{
  flex:0 0 auto!important;
  padding:clamp(22px,4vh,46px) clamp(20px,5vw,72px) clamp(12px,2vh,22px)!important;
  padding-top:max(clamp(22px,4vh,46px),env(safe-area-inset-top))!important;
  text-align:center!important;
}
.boda-spotify-modal__header h3{
  font-size:clamp(38px,6.2vw,78px)!important;
  line-height:.88!important;
  max-width:1100px!important;
  margin-inline:auto!important;
}
.boda-spotify-modal__header small{
  display:block!important;
  max-width:760px!important;
  margin:0 auto!important;
}
.boda-spotify-modal__content{
  flex:1 1 auto!important;
  min-height:0!important;
  height:auto!important;
  overflow:auto!important;
  overscroll-behavior:contain!important;
  -webkit-overflow-scrolling:touch!important;
  padding:0 clamp(16px,5vw,72px) clamp(18px,4vh,42px)!important;
}
.boda-spotify-modal__footer{
  flex:0 0 auto!important;
  padding:0 clamp(20px,5vw,72px) clamp(18px,3vh,34px)!important;
  padding-bottom:max(clamp(18px,3vh,34px),env(safe-area-inset-bottom))!important;
}
.boda-spotify-modal__dialog--search .boda-spotify-search--modal{
  flex:1 1 auto!important;
  min-height:0!important;
  height:auto!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  overscroll-behavior:contain!important;
  margin:0!important;
  padding:0 clamp(16px,5vw,72px) max(clamp(18px,3vh,34px),env(safe-area-inset-bottom))!important;
  background:transparent!important;
  box-shadow:none!important;
}
.boda-spotify-search--modal .boda-spotify-search__form{
  flex:0 0 auto!important;
  width:min(1180px,100%)!important;
  margin:0 auto!important;
  position:relative!important;
  z-index:2!important;
}
.boda-spotify-search--modal .boda-spotify-message{
  flex:0 0 auto!important;
  width:min(1180px,100%)!important;
  margin:12px auto 0!important;
}
.boda-spotify-search--modal .boda-spotify-results{
  flex:1 1 auto!important;
  min-height:0!important;
  height:auto!important;
  max-height:none!important;
  width:min(1280px,100%)!important;
  margin:clamp(12px,2vh,22px) auto 0!important;
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(min(390px,100%),1fr))!important;
  align-content:start!important;
  gap:14px!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  overscroll-behavior:contain!important;
  -webkit-overflow-scrolling:touch!important;
  padding:4px 18px 24px 4px!important;
  scrollbar-gutter:stable both-edges!important;
}
.boda-spotify-search--modal .boda-spotify-results::-webkit-scrollbar,
.boda-spotify-modal__content::-webkit-scrollbar{
  width:10px!important;
}
.boda-spotify-search--modal .boda-spotify-results::-webkit-scrollbar-track,
.boda-spotify-modal__content::-webkit-scrollbar-track{
  background:rgba(21,63,44,.08)!important;
  border-radius:999px!important;
}
.boda-spotify-search--modal .boda-spotify-results::-webkit-scrollbar-thumb,
.boda-spotify-modal__content::-webkit-scrollbar-thumb{
  border-radius:999px!important;
  background:linear-gradient(180deg,var(--boda-green),var(--boda-gold))!important;
}
.boda-spotify-playlist--modal{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(min(420px,100%),1fr))!important;
  gap:14px!important;
  width:min(1280px,100%)!important;
  margin:0 auto!important;
  padding-bottom:24px!important;
}
.boda-spotify-api-track__action{
  min-width:max-content;
}
.boda-spotify-add{
  min-width:150px!important;
}
.boda-spotify-preview,
.boda-spotify-no-preview{
  display:none!important;
}
@media(max-width:760px){
  .boda-spotify-modal__header{
    text-align:left!important;
    padding:22px 70px 12px 18px!important;
    padding-top:max(22px,env(safe-area-inset-top))!important;
  }
  .boda-spotify-modal__header h3{
    font-size:clamp(34px,11vw,48px)!important;
  }
  .boda-spotify-modal__header small{
    margin-left:0!important;
    max-width:100%!important;
  }
  .boda-spotify-modal__close{
    top:max(12px,env(safe-area-inset-top))!important;
    right:max(12px,env(safe-area-inset-right))!important;
    width:42px!important;
    height:42px!important;
  }
  .boda-spotify-modal__dialog--search .boda-spotify-search--modal{
    padding:0 12px max(14px,env(safe-area-inset-bottom))!important;
  }
  .boda-spotify-search--modal .boda-spotify-search__form{
    grid-template-columns:1fr!important;
    border-radius:24px!important;
    padding:10px!important;
  }
  .boda-spotify-search--modal .boda-spotify-search__form input{
    height:48px!important;
  }
  .boda-spotify-search--modal .boda-spotify-results{
    grid-template-columns:1fr!important;
    min-height:0!important;
    padding:2px 12px 22px 2px!important;
  }
  .boda-spotify-api-track{
    grid-template-columns:52px minmax(0,1fr)!important;
    gap:10px!important;
  }
  .boda-spotify-api-track__action{
    grid-column:1/-1!important;
    min-width:0!important;
  }
  .boda-spotify-add,
  .boda-spotify-open{
    width:100%!important;
  }
}

/* ==========================================================
   v11.5.8 · Corrección cursor elegante dentro de modales.
   - El modal Spotify ocupa toda la pantalla, pero el cursor
     personalizado queda siempre por encima del backdrop/dialog.
   - Se oculta también el cursor nativo dentro del modal para
     evitar duplicados visuales.
   ========================================================== */
@media (hover:hover) and (pointer:fine){
  body.boda-custom-cursor .boda-spotify-modal,
  body.boda-custom-cursor .boda-spotify-modal *,
  body.boda-custom-cursor .boda-lightbox,
  body.boda-custom-cursor .boda-lightbox *{
    cursor:none!important;
  }
  .boda-cursor-dot,
  .boda-cursor-ring{
    z-index:2147483647!important;
    visibility:visible!important;
    display:block!important;
  }
  body.boda-spotify-modal-open.boda-cursor-ready .boda-cursor-dot,
  body.boda-spotify-modal-open.boda-cursor-ready .boda-cursor-ring,
  body.boda-modal-lock.boda-cursor-ready .boda-cursor-dot,
  body.boda-modal-lock.boda-cursor-ready .boda-cursor-ring{
    opacity:1!important;
  }
  body.boda-spotify-modal-open .boda-cursor-ring,
  body.boda-modal-lock .boda-cursor-ring{
    border-color:rgba(188,135,52,.86)!important;
    box-shadow:0 12px 34px rgba(188,135,52,.22),inset 0 0 0 1px rgba(21,63,44,.18)!important;
    backdrop-filter:blur(3px)!important;
  }
}


/* v11.5.9 · Camino irregular de historia + WhatsApp elegante */
.boda-story__path{
  display:block!important;
  position:relative;
  width:min(100%,1040px);
  margin:0 auto;
  padding:clamp(16px,3vh,34px) 0 clamp(20px,4vh,46px);
}
.boda-story__path:before{
  content:"";
  position:absolute;
  z-index:0;
  top:clamp(20px,3vh,42px);
  bottom:clamp(20px,3vh,42px);
  left:50%;
  width:min(230px,26vw);
  transform:translateX(-50%);
  opacity:.72;
  pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 220 1200' preserveAspectRatio='none'%3E%3Cpath d='M110 0 C40 95 180 170 110 260 C34 360 187 456 112 560 C42 657 177 756 110 858 C48 950 174 1050 110 1200' fill='none' stroke='%23bc8734' stroke-width='4' stroke-linecap='round' stroke-dasharray='14 18'/%3E%3C/svg%3E") center/100% 100% no-repeat;
  filter:drop-shadow(0 10px 16px rgba(188,135,52,.11));
}
.boda-story__step{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1fr) 82px minmax(0,1fr);
  align-items:center;
  gap:clamp(14px,3vw,34px);
  margin:clamp(20px,5vh,62px) 0;
}
.boda-story__step:first-child{margin-top:0}
.boda-story__step:last-child{margin-bottom:0}
.boda-story__pin{
  grid-column:2;
  grid-row:1;
  justify-self:center;
  position:relative;
  z-index:2;
  display:grid;
  place-items:center;
  width:58px;
  height:58px;
  border-radius:50%;
  border:1px solid rgba(188,135,52,.44);
  background:linear-gradient(180deg,#fff,#fffaf0);
  color:var(--boda-green);
  font:800 14px/1 var(--boda-sans);
  letter-spacing:.08em;
  box-shadow:0 16px 34px rgba(21,63,44,.10), inset 0 0 0 6px rgba(188,135,52,.075);
}
.boda-story__pin:before{
  content:"";
  position:absolute;
  inset:-9px;
  border:1px solid rgba(188,135,52,.16);
  border-radius:50%;
}
.boda-story__step .boda-story-card{
  position:relative;
  width:min(100%,390px);
  min-height:0;
  text-align:left;
  padding:clamp(24px,3.2vw,34px);
  overflow:visible;
}
.boda-story__step:nth-child(odd) .boda-story-card{
  grid-column:1;
  justify-self:end;
  transform:translateX(-12px) rotate(-.85deg);
}
.boda-story__step:nth-child(even) .boda-story-card{
  grid-column:3;
  justify-self:start;
  transform:translateX(12px) rotate(.85deg);
}
.boda-story__step:nth-child(3n) .boda-story-card{transform:translateX(-32px) rotate(.65deg)}
.boda-story__step:nth-child(4n) .boda-story-card{transform:translateX(32px) rotate(-.65deg)}
.boda-story__step:nth-child(odd) .boda-story-card:after,
.boda-story__step:nth-child(even) .boda-story-card:after{
  content:"";
  position:absolute;
  top:50%;
  width:44px;
  height:1px;
  background:linear-gradient(90deg,rgba(188,135,52,.12),rgba(188,135,52,.72),rgba(188,135,52,.12));
}
.boda-story__step:nth-child(odd) .boda-story-card:after{right:-48px}
.boda-story__step:nth-child(even) .boda-story-card:after{left:-48px}
.boda-story__step .boda-story-card__icon{
  margin:0 0 14px;
  width:50px;
  height:50px;
  background:linear-gradient(180deg,#fff,#fffaf1);
  box-shadow:0 10px 18px rgba(188,135,52,.10);
}
.boda-story__step .boda-story-card h3{font-size:clamp(28px,3vw,38px);margin-bottom:8px}
.boda-story__step .boda-story-card small{
  display:inline-flex;
  margin-top:16px;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(188,135,52,.10);
  color:var(--boda-green);
  font:800 11px/1 var(--boda-sans);
  letter-spacing:.12em;
  text-transform:uppercase;
}
.boda-footer__phones{
  align-items:center;
}
.boda-footer__whatsapp{
  display:inline-flex!important;
  align-items:center;
  gap:12px;
  min-width:210px;
  padding:12px 16px;
  border:1px solid rgba(188,135,52,.28);
  border-radius:999px;
  background:rgba(255,255,255,.78);
  box-shadow:0 12px 26px rgba(21,63,44,.07);
  text-decoration:none!important;
  transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease,background .22s ease;
}
.boda-footer__whatsapp:hover{
  transform:translateY(-2px);
  border-color:rgba(188,135,52,.54);
  background:#fffdf8;
  box-shadow:0 18px 36px rgba(21,63,44,.12);
}
.boda-whatsapp-icon{
  display:grid!important;
  place-items:center;
  flex:0 0 42px;
  width:42px;
  height:42px;
  margin:0!important;
  border-radius:50%;
  color:#fff!important;
  background:linear-gradient(135deg,#1f7b52,#0f4d34);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.26),0 10px 20px rgba(21,63,44,.18);
}
.boda-whatsapp-icon svg{display:block;width:24px;height:24px;fill:currentColor}
.boda-footer__phone-text{display:grid!important;gap:2px;margin:0!important;text-align:left;color:var(--boda-green)!important}
.boda-footer__phone-text strong{font:700 22px/1 var(--boda-serif);color:var(--boda-green)}
.boda-footer__phone-text em{font:700 13px/1.2 var(--boda-sans);font-style:normal;letter-spacing:.03em;color:var(--boda-muted)}
@media (max-width:760px){
  .boda-story__path{width:100%;padding-left:0;padding-right:0}
  .boda-story__path:before{left:28px;width:82px;transform:none;opacity:.58}
  .boda-story__step{grid-template-columns:58px minmax(0,1fr);gap:14px;margin:26px 0}
  .boda-story__pin{grid-column:1;width:48px;height:48px;font-size:12px}
  .boda-story__step .boda-story-card,
  .boda-story__step:nth-child(odd) .boda-story-card,
  .boda-story__step:nth-child(even) .boda-story-card,
  .boda-story__step:nth-child(3n) .boda-story-card,
  .boda-story__step:nth-child(4n) .boda-story-card{
    grid-column:2;
    justify-self:stretch;
    width:100%;
    transform:none;
  }
  .boda-story__step .boda-story-card:after{left:-16px!important;right:auto!important;width:18px}
  .boda-footer__phones{display:grid!important;grid-template-columns:1fr;justify-items:center;gap:12px}
  .boda-footer__whatsapp{width:min(100%,310px);justify-content:flex-start}
}

/* ==========================================================
   v11.5.10 · RSVP por pasos refinado + playlist aleatoria
   ========================================================== */
.boda-rsvp__form.boda-rsvp-wizard{
  position:relative;
  width:100%;
  min-height:min(720px,calc(var(--boda-safe-vh) - 96px));
  max-height:calc(var(--boda-safe-vh) - 96px);
  padding:clamp(16px,2.4vw,24px)!important;
  display:flex!important;
  flex-direction:column!important;
  gap:14px!important;
}
.boda-rsvp-wizard__body{
  flex:1 1 auto;
  min-height:0;
  display:grid;
  overflow:hidden;
}
.boda-rsvp-step{
  grid-area:1/1;
  height:100%;
  max-height:100%;
  padding:clamp(4px,1vh,12px) 4px 8px;
  overflow:auto!important;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(10px) scale(.985);
  transition:opacity .28s ease,visibility .28s ease,transform .28s ease;
}
.boda-rsvp-step.is-active{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(0) scale(1);
}
.boda-rsvp-wizard__nav{
  position:relative;
  z-index:5;
  flex:0 0 auto;
  margin-top:auto!important;
  padding-top:12px;
  border-top:1px solid rgba(255,255,255,.18);
  display:flex!important;
  justify-content:flex-end!important;
  align-items:center;
  gap:12px!important;
}
.boda-rsvp-wizard__nav .boda-btn[disabled]{
  opacity:.48;
  cursor:not-allowed;
  transform:none!important;
  box-shadow:none!important;
}
.boda-rsvp-fields--two{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.boda-rsvp-choice-grid--fullheight{
  min-height:min(340px,46vh);
  grid-template-columns:repeat(2,minmax(0,1fr));
  align-items:stretch;
}
.boda-rsvp-choice-grid--fullheight .boda-rsvp-choice>span,
.boda-transport-choice>span{
  height:100%;
  min-height:clamp(160px,28vh,290px);
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.boda-rsvp-counter-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:18px;
}
.boda-rsvp-counter-card{
  padding:clamp(18px,2vw,26px);
  border-radius:22px;
  border:1px solid rgba(216,179,118,.28);
  background:rgba(255,255,255,.10);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);
}
.boda-rsvp-counter-card>span{
  display:block;
  margin-bottom:12px;
  color:#fff;
  font:700 13px/1 var(--boda-sans);
  letter-spacing:.12em;
  text-transform:uppercase;
}
.boda-rsvp-counter-card small{
  display:block;
  margin-top:10px;
  color:rgba(255,255,255,.70);
}
.boda-stepper{
  display:grid;
  grid-template-columns:54px minmax(0,1fr) 54px;
  align-items:center;
  gap:8px;
}
.boda-stepper button{
  height:54px;
  border-radius:50%;
  border:1px solid rgba(216,179,118,.48);
  background:rgba(255,255,255,.95);
  color:var(--boda-green);
  font:800 24px/1 var(--boda-sans);
  cursor:pointer;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
}
.boda-stepper button:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(0,0,0,.16);background:#fffaf0}
.boda-stepper input{
  height:54px!important;
  padding:0!important;
  text-align:center;
  font:700 28px/1 var(--boda-serif)!important;
}
.boda-rsvp-companions-btn{
  margin-top:18px;
  max-width:320px;
}
.boda-rsvp-helper{
  margin:12px 0 0!important;
  padding:10px 12px;
  border:1px solid rgba(216,179,118,.24);
  border-radius:14px;
  color:rgba(255,255,255,.80)!important;
  background:rgba(255,255,255,.075);
  font-size:13px!important;
}
.boda-rsvp-helper.is-error{color:#ffd5d5!important;border-color:rgba(255,130,130,.38);background:rgba(120,0,0,.12)}
.boda-transport-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:16px;
}
.boda-pickup-panel{
  margin-top:16px;
  display:grid;
  grid-template-columns:.55fr 1fr;
  gap:14px;
  align-items:stretch;
}
.boda-bus-availability,
.boda-pickup-option>span{
  border:1px solid rgba(216,179,118,.26);
  background:rgba(255,255,255,.10);
  border-radius:20px;
  padding:16px;
}
.boda-bus-availability{display:grid;place-items:center;text-align:center;color:#fff}
.boda-bus-availability span{font:800 11px/1 var(--boda-sans);letter-spacing:.14em;text-transform:uppercase;color:var(--boda-gold-2)}
.boda-bus-availability strong{margin:8px 0;color:#fff;font:700 clamp(46px,6vw,74px)/.9 var(--boda-serif)}
.boda-bus-availability small{color:rgba(255,255,255,.72)}
.boda-pickup-options{display:grid;gap:10px}
.boda-pickup-option{position:relative;display:block;cursor:pointer}
.boda-pickup-option input{position:absolute;opacity:0;inset:0;pointer-events:none}
.boda-pickup-option>span{display:block;transition:transform .24s ease,border-color .24s ease,background .24s ease,box-shadow .24s ease}
.boda-pickup-option strong{display:block;color:#fff;font:700 18px/1.2 var(--boda-serif)}
.boda-pickup-option small{display:block;margin-top:6px;color:rgba(255,255,255,.70)}
.boda-pickup-option input:checked+span{background:rgba(216,179,118,.18);border-color:rgba(216,179,118,.70);box-shadow:0 16px 34px rgba(0,0,0,.14);transform:translateY(-2px)}
.boda-pickup-option.is-disabled{opacity:.45;cursor:not-allowed}
.boda-rsvp-confirm-step{display:grid;place-items:center;text-align:center;overflow:hidden!important}
.boda-rsvp-confirm-card{
  width:min(100%,640px);
  margin:auto;
  padding:clamp(24px,4vw,46px);
  border:1px solid rgba(216,179,118,.30);
  border-radius:28px;
  background:linear-gradient(145deg,rgba(255,255,255,.16),rgba(255,255,255,.08));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08),0 24px 58px rgba(0,0,0,.14);
}
.boda-rsvp-confirm-icon{
  display:grid;
  place-items:center;
  width:70px;
  height:70px;
  margin:0 auto 14px;
  border-radius:50%;
  color:#fff;
  background:linear-gradient(135deg,var(--boda-gold),var(--boda-green));
  box-shadow:0 18px 34px rgba(0,0,0,.18);
  font:600 38px/1 var(--boda-serif);
  animation:bodaConfirmPulse 2.4s ease-in-out infinite;
}
@keyframes bodaConfirmPulse{0%,100%{transform:scale(1);box-shadow:0 18px 34px rgba(0,0,0,.18)}50%{transform:scale(1.06);box-shadow:0 24px 52px rgba(188,135,52,.24)}}
.boda-rsvp-confirm-card h3{margin:0;color:#fff;font:600 clamp(34px,4vw,54px)/.9 var(--boda-serif)}
.boda-rsvp-confirm-card p{max-width:520px;margin:12px auto;color:rgba(255,255,255,.78)}
.boda-rsvp-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:18px 0}
.boda-rsvp-summary span{padding:12px;border-radius:16px;background:rgba(255,255,255,.10);border:1px solid rgba(216,179,118,.20)}
.boda-rsvp-summary strong{display:block;color:#fff;font:700 16px/1.2 var(--boda-sans);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.boda-rsvp-summary small{display:block;margin-top:4px;color:var(--boda-gold-2);font:800 10px/1 var(--boda-sans);letter-spacing:.12em;text-transform:uppercase}
.boda-guests-modal{
  position:fixed!important;
  inset:0!important;
  z-index:2147483605!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:clamp(10px,3vw,34px);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .24s ease,visibility .24s ease;
}
.boda-guests-modal.is-visible{opacity:1;visibility:visible;pointer-events:auto}
.boda-guests-modal__backdrop{position:absolute;inset:0;background:rgba(12,35,25,.72);backdrop-filter:blur(18px)}
.boda-guests-modal__dialog{
  position:relative;
  z-index:2;
  width:min(880px,100%);
  max-height:calc(var(--boda-safe-vh) - 28px);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  border-radius:30px;
  border:1px solid rgba(216,179,118,.35);
  background:linear-gradient(145deg,#fffdf8,#fff7ea);
  box-shadow:0 40px 100px rgba(0,0,0,.30);
  color:var(--boda-green);
}
.boda-guests-modal__close{position:absolute;top:16px;right:16px;z-index:3;width:44px;height:44px;border-radius:50%;border:1px solid rgba(188,135,52,.35);background:#fff;color:var(--boda-green);font-size:24px;cursor:pointer}
.boda-guests-modal header{padding:clamp(22px,4vw,42px) clamp(22px,5vw,58px) 14px;text-align:center}
.boda-guests-modal header h3{margin:0;color:var(--boda-green);font:600 clamp(38px,5vw,64px)/.9 var(--boda-serif)}
.boda-guests-modal header small{display:block;max-width:600px;margin:0 auto;color:var(--boda-muted)}
.boda-guests-modal__content{flex:1 1 auto;min-height:0;overflow:auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;padding:0 clamp(18px,5vw,58px) 18px;overscroll-behavior:contain}
.boda-guests-modal__content section{padding:16px;border-radius:20px;background:#fff;border:1px solid rgba(188,135,52,.16);box-shadow:0 10px 24px rgba(21,63,44,.06)}
.boda-guests-modal__content h4{margin:0 0 12px;color:var(--boda-gold);font:800 12px/1 var(--boda-sans);letter-spacing:.14em;text-transform:uppercase}
.boda-guests-modal__content [data-guest-list-modal]{display:grid;gap:10px}
.boda-guests-modal__content .boda-generated-guest{color:var(--boda-green)!important}
.boda-guests-modal__content .boda-generated-guest input{border:1px solid rgba(188,135,52,.26);background:#fff;color:var(--boda-green)}
.boda-guests-modal__empty{margin:0;color:var(--boda-muted)}
.boda-guests-modal footer{flex:0 0 auto;display:flex;justify-content:flex-end;gap:12px;padding:16px clamp(18px,5vw,58px) max(18px,env(safe-area-inset-bottom));border-top:1px solid rgba(188,135,52,.16);background:rgba(255,255,255,.76)}
.boda-spotify-preview-list.is-rotating .boda-spotify-preview-track{animation:bodaSpotifyShuffle .42s ease both}
@keyframes bodaSpotifyShuffle{from{opacity:.2;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
@media(max-width:980px){
  .boda-rsvp__form.boda-rsvp-wizard{min-height:min(720px,calc(var(--boda-safe-vh) - 60px));max-height:calc(var(--boda-safe-vh) - 60px)}
  .boda-rsvp-fields--two,.boda-rsvp-counter-grid,.boda-transport-grid,.boda-pickup-panel{grid-template-columns:1fr}
  .boda-rsvp-choice-grid--fullheight{grid-template-columns:1fr;min-height:0}
  .boda-rsvp-choice-grid--fullheight .boda-rsvp-choice>span,.boda-transport-choice>span{min-height:120px}
  .boda-rsvp-summary{grid-template-columns:1fr}
}
@media(max-width:760px){
  .boda-rsvp__form.boda-rsvp-wizard{max-height:calc(var(--boda-safe-vh) - 32px);min-height:calc(var(--boda-safe-vh) - 34px);padding:14px!important;border-radius:22px}
  .boda-rsvp-steps{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}
  .boda-rsvp-steps button{padding:7px 5px;font-size:9px}
  .boda-rsvp-step legend{font-size:clamp(28px,8vw,38px)}
  .boda-rsvp-wizard__nav{display:grid!important;grid-template-columns:1fr;gap:8px!important}
  .boda-rsvp-wizard__nav .boda-btn{max-width:none!important;width:100%}
  .boda-stepper{grid-template-columns:48px minmax(0,1fr) 48px}.boda-stepper button,.boda-stepper input{height:48px!important}
  .boda-guests-modal{padding:8px}.boda-guests-modal__dialog{max-height:calc(var(--boda-safe-vh) - 16px);border-radius:22px}.boda-guests-modal header{text-align:left;padding-right:64px}.boda-guests-modal__content{grid-template-columns:1fr}.boda-guests-modal footer{display:grid}.boda-guests-modal footer .boda-btn{width:100%;max-width:none}
}

/* ==========================================================
   v11.5.11 · Ajustes RSVP: pasos circulares, modales y bus
   ========================================================== */
.boda-rsvp-steps{
  display:flex!important;
  flex-wrap:wrap!important;
  justify-content:center!important;
  align-items:center!important;
  gap:10px!important;
  margin-bottom:clamp(16px,2.3vh,26px)!important;
}
.boda-rsvp-steps button{
  width:clamp(36px,4.2vw,46px)!important;
  height:clamp(36px,4.2vw,46px)!important;
  min-height:0!important;
  padding:0!important;
  border-radius:50%!important;
  gap:0!important;
  font-size:0!important;
  flex:0 0 auto!important;
  overflow:hidden!important;
}
.boda-rsvp-steps button span{
  width:100%!important;
  height:100%!important;
  background:transparent!important;
  color:rgba(255,255,255,.72)!important;
  font:800 13px/1 var(--boda-sans)!important;
}
.boda-rsvp-steps button.is-active span,
.boda-rsvp-steps button.is-complete span{color:#fff!important;}
.boda-rsvp-choice-grid,
.boda-transport-grid,
.boda-rsvp-counter-grid{width:100%;max-width:100%;overflow:visible!important;}
.boda-rsvp-choice-grid--fullheight,
.boda-transport-grid{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  align-items:stretch!important;
}
.boda-rsvp-choice>span,
.boda-transport-choice>span{
  text-align:center!important;
  justify-items:center!important;
  align-content:center!important;
  min-width:0!important;
  width:100%!important;
  height:100%!important;
  min-height:clamp(132px,18vh,190px)!important;
  padding:clamp(16px,2.2vw,26px)!important;
}
.boda-rsvp-choice i,
.boda-transport-choice i{
  display:grid;
  place-items:center;
  width:clamp(42px,5vw,58px);
  height:clamp(42px,5vw,58px);
  margin:0 auto 4px;
  border-radius:50%;
  border:1px solid rgba(216,179,118,.45);
  background:rgba(255,255,255,.12);
  color:var(--boda-gold-2);
  font-style:normal;
  font-size:clamp(24px,3vw,34px);
  line-height:1;
}
.boda-rsvp-choice strong,
.boda-transport-choice strong{
  width:100%;
  text-align:center!important;
  overflow-wrap:normal!important;
  word-break:normal!important;
}
.boda-rsvp-choice small,
.boda-transport-choice small{text-align:center!important;}
.boda-rsvp-companions-wrap{display:flex!important;justify-content:center!important;align-items:center!important;margin-top:18px;width:100%;}
.boda-rsvp-companions-btn[hidden],.boda-pickup-open-btn[hidden]{display:none!important;}
.boda-rsvp-companions-btn,.boda-pickup-open-btn{margin:0 auto!important;}
.boda-bus-availability--inline{margin:18px auto 0;max-width:310px;min-height:0;padding:14px 18px!important;}
.boda-bus-availability--inline strong{font-size:clamp(34px,4vw,50px)!important;}
.boda-pickup-modal{
  position:fixed!important;
  inset:0!important;
  z-index:2147483610!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:clamp(10px,3vw,34px);
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .24s ease,visibility .24s ease;
}
.boda-pickup-modal.is-visible{opacity:1;visibility:visible;pointer-events:auto;}
.boda-pickup-modal__backdrop{position:absolute;inset:0;background:rgba(12,35,25,.76);backdrop-filter:blur(18px);}
.boda-pickup-modal__dialog{
  position:relative;
  z-index:2;
  width:min(var(--boda-modal-panel-width, 760px),calc(100vw - 28px));
  max-height:calc(var(--boda-safe-vh) - 28px);
  display:flex;
  flex-direction:column;
  overflow:hidden;
  border-radius:30px;
  border:1px solid rgba(216,179,118,.35);
  background:linear-gradient(145deg,#fffdf8,#fff7ea);
  box-shadow:0 40px 100px rgba(0,0,0,.32);
  color:var(--boda-green);
}
.boda-pickup-modal__close{position:absolute;top:16px;right:16px;z-index:3;width:44px;height:44px;border-radius:50%;border:1px solid rgba(188,135,52,.35);background:#fff;color:var(--boda-green);font-size:24px;cursor:pointer;}
.boda-pickup-modal header{padding:clamp(22px,4vw,42px) clamp(22px,5vw,58px) 14px;text-align:center;}
.boda-pickup-modal header h3{margin:0;color:var(--boda-green);font:600 clamp(38px,5vw,64px)/.9 var(--boda-serif);}
.boda-pickup-modal header small{display:block;max-width:600px;margin:0 auto;color:var(--boda-muted);}
.boda-pickup-modal__content{flex:1 1 auto;min-height:0;overflow:auto;display:grid;gap:18px;padding:0 clamp(18px,5vw,58px) 18px;overscroll-behavior:contain;}
.boda-pickup-modal .boda-bus-availability{background:#fff;border-color:rgba(188,135,52,.22);color:var(--boda-green);}
.boda-pickup-modal .boda-bus-availability strong{color:var(--boda-green)!important;}
.boda-pickup-modal .boda-bus-availability small{color:var(--boda-muted)!important;}
.boda-pickup-modal .boda-pickup-options{grid-template-columns:repeat(2,minmax(0,1fr));display:grid;gap:14px;}
.boda-pickup-modal .boda-pickup-option>span{background:#fff;color:var(--boda-green);min-height:128px;display:grid;align-content:center;text-align:center;}
.boda-pickup-modal .boda-pickup-option strong{color:var(--boda-green);}
.boda-pickup-modal .boda-pickup-option small{color:var(--boda-muted);}
.boda-pickup-modal footer{flex:0 0 auto;display:flex;justify-content:flex-end;gap:12px;padding:16px clamp(18px,5vw,58px) max(18px,env(safe-area-inset-bottom));border-top:1px solid rgba(188,135,52,.16);background:rgba(255,255,255,.76);}
.boda-guests-modal__dialog{width:min(var(--boda-modal-panel-width, 760px),calc(100vw - 28px))!important;max-height:calc(var(--boda-safe-vh) - 28px)!important;}
.boda-guests-modal__content{overflow-y:auto!important;overflow-x:hidden!important;scrollbar-width:thin;scrollbar-color:var(--boda-gold) rgba(21,63,44,.10);}
.boda-guests-modal__content::-webkit-scrollbar,.boda-pickup-modal__content::-webkit-scrollbar{width:8px;}
.boda-guests-modal__content::-webkit-scrollbar-thumb,.boda-pickup-modal__content::-webkit-scrollbar-thumb{border-radius:999px;background:linear-gradient(180deg,var(--boda-gold),var(--boda-green));}
.boda-rsvp-confirm-card [data-rsvp-music][hidden]{display:none!important;}
.boda-rsvp-confirm-card [data-rsvp-music]{margin-top:14px;}
@media(max-width:980px){
  .boda-rsvp-choice-grid--fullheight,.boda-transport-grid{grid-template-columns:1fr!important;}
  .boda-rsvp-choice>span,.boda-transport-choice>span{min-height:118px!important;}
  .boda-pickup-modal .boda-pickup-options{grid-template-columns:1fr;}
}
@media(max-width:760px){
  .boda-rsvp-steps{gap:7px!important;}
  .boda-rsvp-steps button{width:36px!important;height:36px!important;}
  .boda-rsvp-steps button span{font-size:12px!important;}
  .boda-rsvp-choice i,.boda-transport-choice i{width:40px;height:40px;font-size:22px;}
  .boda-rsvp-choice>span,.boda-transport-choice>span{min-height:102px!important;padding:14px!important;}
  .boda-rsvp-choice strong,.boda-transport-choice strong{font-size:clamp(22px,7vw,30px)!important;}
  .boda-guests-modal,.boda-pickup-modal{padding:8px;}
  .boda-guests-modal__dialog,.boda-pickup-modal__dialog{width:calc(100vw - 16px)!important;max-height:calc(var(--boda-safe-vh) - 16px)!important;border-radius:22px;}
  .boda-guests-modal header,.boda-pickup-modal header{text-align:left;padding-right:64px;}
  .boda-guests-modal__content,.boda-pickup-modal__content{grid-template-columns:1fr!important;}
  .boda-guests-modal footer,.boda-pickup-modal footer{display:grid;}
  .boda-guests-modal footer .boda-btn,.boda-pickup-modal footer .boda-btn{width:100%;max-width:none;}
}

/* ==========================================================
   v11.5.12 · Ajustes solicitados: RSVP, autobuses, localización,
   lista de bodas, contacto final y modales sin salto de página.
   ========================================================== */
html.boda-modal-lock,
html.boda-modal-lock body,
body.boda-modal-lock{
  overflow:hidden!important;
  overscroll-behavior:none!important;
}
body.boda-modal-lock{
  position:static!important;
  top:auto!important;
  left:auto!important;
  right:auto!important;
  width:auto!important;
}
.boda-section,.boda-rsvp,.boda-footer{width:100%;min-height:100vh;min-height:var(--boda-safe-vh)}
@supports(height:100dvh){.boda-section,.boda-rsvp,.boda-footer{min-height:100dvh}}

/* RSVP: el segundo paso avanza por selección, sin botón siguiente visible */
.boda-rsvp-step[data-rsvp-step="1"]{overflow:hidden!important;display:flex;flex-direction:column;justify-content:center;}
.boda-rsvp-step[data-rsvp-step="1"] .boda-rsvp-choice-grid{width:100%;max-width:100%;overflow:hidden;}
.boda-rsvp-choice-grid--fullheight{grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(12px,2vw,18px);overflow:hidden;}
.boda-rsvp-choice{min-width:0;max-width:100%;overflow:hidden;}
.boda-rsvp-choice>span{min-width:0;max-width:100%;text-align:center;align-items:center;justify-content:center;overflow:hidden;}
.boda-rsvp-choice i{display:grid;place-items:center;width:54px;height:54px;margin:0 auto 12px;border-radius:50%;border:1px solid rgba(216,179,118,.38);background:rgba(255,255,255,.10);font-size:27px;line-height:1;color:var(--boda-gold-2)}
.boda-rsvp-choice strong{width:100%;text-align:center;}
.boda-rsvp-choice small{width:100%;text-align:center;}
.boda-rsvp-step[data-rsvp-step="2"] .boda-rsvp-helper{text-align:center!important;margin-top:24px!important;margin-bottom:8px!important;}
.boda-rsvp-companions-wrap{display:flex;justify-content:center;margin:22px auto 8px;}
.boda-rsvp-companions-btn[hidden]{display:none!important;}
.boda-rsvp-counter-grid{overflow:hidden;}
.boda-rsvp-counter-card{min-width:0;overflow:hidden;}
.boda-guests-modal__dialog{width:min(var(--boda-modal-panel-width, 880px), calc(100vw - 28px))!important;max-width:calc(100vw - 28px)!important;}
.boda-guests-modal__content{max-height:min(56vh,520px);overflow-y:auto!important;overflow-x:hidden!important;scrollbar-gutter:stable;}
.boda-guests-modal__content::-webkit-scrollbar{width:9px}.boda-guests-modal__content::-webkit-scrollbar-thumb{border-radius:999px;background:linear-gradient(180deg,var(--boda-green),var(--boda-gold))}
.boda-pickup-modal{z-index:2147483606!important;}
.boda-pickup-modal__dialog{width:min(var(--boda-modal-panel-width, 880px), calc(100vw - 28px))!important;max-width:calc(100vw - 28px)!important;}
.boda-pickup-modal__content{max-height:min(58vh,540px);overflow:auto!important;}

/* Ruta de autobuses */
.boda-bus-service{background:linear-gradient(180deg,#fff,#fffaf2)}
.boda-bus-service__grid{grid-template-columns:minmax(260px,.75fr) minmax(320px,1.25fr)!important;}
.boda-bus-route-card{min-height:clamp(340px,52vh,560px);display:flex;align-items:center;justify-content:center;padding:clamp(22px,4vw,42px);}
.boda-bus-route-track{position:absolute;inset:clamp(18px,3vw,34px);pointer-events:none;}
.boda-bus-route-dash{position:absolute;left:6%;right:6%;top:50%;height:4px;background:repeating-linear-gradient(90deg,rgba(21,63,44,.48) 0 16px,transparent 16px 30px);border-radius:999px;opacity:.8;animation:bodaBusDash 9s linear infinite;}
.boda-bus-route-bus{position:absolute;top:calc(50% - 21px);left:4%;display:grid;place-items:center;width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,#fff,var(--boda-soft));border:1px solid rgba(188,135,52,.38);box-shadow:0 12px 24px rgba(21,63,44,.16);animation:bodaBusMove 12s ease-in-out infinite;}
@keyframes bodaBusDash{to{background-position:90px 0}}
@keyframes bodaBusMove{0%,100%{left:4%;transform:translateY(0)}50%{left:90%;transform:translateY(-3px)}}
.boda-bus-route-stops{width:100%;align-items:stretch;z-index:2;}
.boda-bus-stop{display:flex;flex-direction:column;justify-content:center;min-height:170px;}
.boda-bus-stop span{background:linear-gradient(135deg,var(--boda-green),var(--boda-gold));}

/* Localización */
.boda-location{background:radial-gradient(circle at 85% 14%,rgba(188,135,52,.10),transparent 28%),linear-gradient(180deg,#fff,#fffaf4);}
.boda-location__grid{display:grid;grid-template-columns:minmax(280px,.75fr) minmax(320px,1.25fr);gap:clamp(28px,5vw,70px);align-items:center;}
.boda-location h2{margin:0 0 12px;color:var(--boda-green);font:500 clamp(40px,5vw,70px)/.9 var(--boda-serif)}
.boda-location p:not(.boda-label){color:var(--boda-muted);max-width:560px;}
.boda-location__address{display:grid;gap:4px;margin:22px 0;padding:18px;border:1px solid rgba(188,135,52,.22);border-radius:20px;background:#fff;box-shadow:0 12px 28px rgba(21,63,44,.06)}
.boda-location__address strong{color:var(--boda-green);font:700 24px/1.1 var(--boda-serif)}
.boda-location__address span{color:var(--boda-muted)}
.boda-location__actions{display:flex;gap:12px;flex-wrap:wrap;}
.boda-location__map{height:min(62vh,560px);min-height:360px;border-radius:30px;overflow:hidden;border:1px solid rgba(188,135,52,.28);box-shadow:var(--boda-shadow-soft);background:#fffaf2;}
.boda-location__map iframe{width:100%;height:100%;border:0;display:block;filter:saturate(.9) contrast(.96);}
.boda-location__map-placeholder{height:100%;display:grid;place-items:center;text-align:center;color:var(--boda-green)}
.boda-location__map-placeholder span{font-size:52px;color:var(--boda-gold)}
.boda-location__map-placeholder strong{display:block;font:600 34px/1 var(--boda-serif)}

/* Lista de bodas */
.boda-gift{background:linear-gradient(180deg,#fff,#fff7ea);}
.boda-gift__wrap{display:grid;place-items:center;}
.boda-gift__card{position:relative;width:min(820px,100%);padding:clamp(32px,6vw,76px);text-align:center;border:1px solid rgba(188,135,52,.30);border-radius:34px;background:linear-gradient(145deg,rgba(255,255,255,.96),rgba(255,248,236,.88));box-shadow:0 28px 80px rgba(21,63,44,.12),inset 0 0 0 1px rgba(255,255,255,.7);overflow:hidden;}
.boda-gift__card:before,.boda-gift__card:after{content:"";position:absolute;width:180px;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(188,135,52,.14),transparent 65%);pointer-events:none;}
.boda-gift__card:before{left:-70px;top:-70px}.boda-gift__card:after{right:-70px;bottom:-70px}
.boda-gift__icon{display:grid;place-items:center;width:64px;height:64px;margin:0 auto 18px;border-radius:50%;background:var(--boda-green);color:#fff;font-size:30px;box-shadow:0 18px 34px rgba(21,63,44,.18)}
.boda-gift h2{margin:0;color:var(--boda-green);font:500 clamp(42px,5vw,74px)/.9 var(--boda-serif)}
.boda-gift p{max-width:620px;margin:18px auto 0;color:var(--boda-muted);font-size:17px;}
.boda-gift__iban{margin:26px auto 16px;padding:18px;border:1px solid rgba(188,135,52,.30);border-radius:22px;background:#fff;box-shadow:0 12px 28px rgba(21,63,44,.06)}
.boda-gift__iban small{display:block;color:var(--boda-gold);font:900 11px/1 var(--boda-sans);letter-spacing:.18em;text-transform:uppercase}.boda-gift__iban strong{display:block;margin:8px 0;color:var(--boda-green);font:700 clamp(18px,3vw,28px)/1.2 var(--boda-serif);letter-spacing:.04em;word-break:break-word}.boda-gift em{display:block;max-width:520px;margin:18px auto 0;color:var(--boda-gold);font:600 18px/1.35 var(--boda-serif)}

/* Footer contacto/calendario */
.boda-footer__calendar{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin:18px 0 8px;}
.boda-footer__web{display:block;margin-top:10px!important;color:var(--boda-green)!important;letter-spacing:.08em;text-transform:none!important;font-size:13px!important;}
.boda-footer__credit{display:flex!important;align-items:center;justify-content:center;gap:7px;margin-top:8px!important;color:var(--boda-muted)!important;font-size:12px!important;letter-spacing:.02em!important;text-transform:none!important;}
.boda-footer__credit strong{color:var(--boda-green)}

@media(max-width:980px){
  .boda-bus-service__grid,.boda-location__grid{grid-template-columns:1fr!important;text-align:center;}
  .boda-location p:not(.boda-label),.boda-bus-service p{margin-inline:auto;}
  .boda-location__actions{justify-content:center;}
  .boda-bus-route-card{min-height:auto;}
  .boda-bus-route-dash,.boda-bus-route-bus{display:none;}
}
@media(max-width:760px){
  .boda-rsvp-choice-grid--fullheight,.boda-rsvp-counter-grid,.boda-transport-grid{grid-template-columns:1fr!important;}
  .boda-rsvp-choice-grid--fullheight .boda-rsvp-choice>span,.boda-transport-choice>span{min-height:112px!important;}
  .boda-rsvp-step[data-rsvp-step="1"]{justify-content:flex-start;}
  .boda-location__map{min-height:300px;height:46vh;border-radius:22px;}
  .boda-gift__card{border-radius:26px;padding:28px 18px;}
  .boda-footer__calendar{display:grid;justify-items:center;}.boda-footer__calendar .boda-btn{width:100%;max-width:320px;}
}

/* ==========================================================
   v11.5.13 · Ajustes finales: RSVP, calendario, Spotify, IBAN,
   modales, teléfono internacional y responsive fino.
   ========================================================== */
.boda-rsvp__form.boda-rsvp-wizard{
  overflow:visible!important;
  isolation:isolate;
}
.boda-rsvp-wizard__body{overflow:hidden!important;}
.boda-rsvp-steps{
  width:100%!important;
  max-width:680px!important;
  margin:0 auto clamp(10px,1.8vh,20px)!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  flex-wrap:wrap!important;
  gap:10px!important;
  align-self:center!important;
}
.boda-rsvp-steps button{
  width:42px!important;
  height:42px!important;
  min-width:42px!important;
  padding:0!important;
  display:grid!important;
  place-items:center!important;
  border-radius:50%!important;
  text-indent:0!important;
  font-size:0!important;
}
.boda-rsvp-steps button span{
  display:grid!important;
  place-items:center!important;
  width:100%!important;
  height:100%!important;
  margin:0!important;
  font:800 13px/1 var(--boda-sans)!important;
  text-indent:0!important;
}
.boda-rsvp__header small{
  display:inline-flex!important;
  align-items:center;
  justify-content:center;
  margin-top:18px!important;
  padding:11px 18px!important;
  border-radius:999px!important;
  border:1px solid rgba(216,179,118,.42)!important;
  background:rgba(255,255,255,.10)!important;
  color:var(--boda-gold-2)!important;
  font:800 clamp(15px,1.7vw,22px)/1.1 var(--boda-sans)!important;
  letter-spacing:.04em;
  box-shadow:0 14px 30px rgba(0,0,0,.08);
}
.boda-rsvp-fields--two{align-items:start;}
.boda-phone-field{grid-column:auto;}
.boda-phone-control{
  display:grid;
  grid-template-columns:minmax(96px,126px) minmax(0,1fr);
  gap:8px;
  min-width:0;
}
.boda-phone-control select,
.boda-phone-control input{width:100%;min-width:0;}
.boda-rsvp__form.boda-rsvp-wizard input[type="text"],
.boda-rsvp__form.boda-rsvp-wizard input[type="email"],
.boda-rsvp__form.boda-rsvp-wizard textarea,
.boda-guests-modal input[type="text"]{
  text-transform:uppercase;
}
.boda-rsvp-choice-grid,
.boda-transport-grid{
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  overflow:hidden!important;
}
.boda-rsvp-choice,
.boda-transport-choice{min-width:0!important;width:100%!important;overflow:hidden!important;}
.boda-rsvp-choice>span,
.boda-transport-choice>span{
  transform:none!important;
  overflow:hidden!important;
  word-break:normal!important;
  overflow-wrap:anywhere!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
  gap:6px;
}
.boda-rsvp-choice input:checked+span,
.boda-pickup-option input:checked+span{
  transform:none!important;
}
.boda-rsvp-choice i,
.boda-transport-choice i{
  flex:0 0 auto!important;
  display:grid!important;
  place-items:center!important;
}
.boda-rsvp-wizard__nav{
  justify-content:center!important;
  align-items:center!important;
  gap:clamp(10px,2vw,18px)!important;
  min-height:74px;
}
.boda-rsvp-wizard__nav .boda-btn{
  min-width:min(190px,42vw)!important;
  text-align:center!important;
}
.boda-rsvp-step[data-rsvp-step="2"] .boda-rsvp-helper{
  display:block!important;
  width:min(620px,100%)!important;
  margin:clamp(20px,3vh,34px) auto 0!important;
  text-align:center!important;
}
.boda-rsvp-companions-wrap{width:100%;text-align:center!important;}
.boda-rsvp-companions-btn{margin-inline:auto!important;}
.boda-guests-modal,
.boda-pickup-modal{z-index:2147483620!important;}
.boda-guests-modal__dialog,
.boda-pickup-modal__dialog{
  width:min(var(--boda-modal-panel-width, 880px), calc(100vw - 36px))!important;
  max-width:calc(100vw - 36px)!important;
  height:auto!important;
  max-height:calc(var(--boda-safe-vh) - 36px)!important;
  overflow:hidden!important;
  display:flex!important;
  flex-direction:column!important;
}
.boda-guests-modal__content,
.boda-pickup-modal__content{
  flex:1 1 auto!important;
  min-height:0!important;
  max-height:none!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  scrollbar-gutter:stable!important;
}
.boda-guests-modal__content section[hidden]{display:none!important;}
.boda-guests-modal__content:has(section[hidden] + section[hidden]){grid-template-columns:1fr!important;}
.boda-guests-modal__content section:not([hidden]):only-child{max-width:560px;margin-inline:auto;width:100%;}
.boda-gift__iban{padding:clamp(20px,3vw,30px)!important;}
.boda-gift__iban small{font-size:13px!important;letter-spacing:.22em!important;}
.boda-gift__iban strong{
  font-family:var(--boda-serif)!important;
  font-size:clamp(28px,4.6vw,46px)!important;
  line-height:1.12!important;
  letter-spacing:.055em!important;
  color:var(--boda-green)!important;
}
.boda-gift__iban .boda-copy{margin-top:14px;}
.boda-actions--countdown{
  display:flex!important;
  justify-content:center!important;
  align-items:center!important;
  flex-wrap:wrap!important;
  gap:14px!important;
}
.boda-btn--calendar:before{content:"♡";margin-right:8px;color:inherit;}
.boda-waze-link[data-mobile-only="1"]{display:none;}
@media(max-width:760px),(pointer:coarse){
  .boda-waze-link[data-mobile-only="1"]{display:inline-flex;}
}
@media(min-width:761px) and (pointer:fine){
  .boda-waze-link[data-mobile-only="1"]{display:none!important;}
}
@media(max-width:760px){
  .boda-rsvp-wizard__nav{
    display:flex!important;
    flex-direction:row!important;
    justify-content:space-between!important;
    gap:10px!important;
  }
  .boda-rsvp-wizard__nav .boda-btn{
    width:auto!important;
    flex:1 1 0!important;
    min-width:0!important;
    max-width:none!important;
  }
  .boda-phone-control{grid-template-columns:104px minmax(0,1fr);}
  .boda-rsvp-steps{gap:7px!important;margin-bottom:10px!important;}
  .boda-rsvp-steps button{width:36px!important;height:36px!important;min-width:36px!important;}
  .boda-guests-modal__dialog,.boda-pickup-modal__dialog{
    width:calc(100vw - 16px)!important;
    max-width:calc(100vw - 16px)!important;
    max-height:calc(var(--boda-safe-vh) - 16px)!important;
  }
  .boda-guests-modal header,.boda-pickup-modal header{padding-top:22px!important;}
  .boda-gift__iban strong{font-size:clamp(22px,7vw,32px)!important;letter-spacing:.02em!important;}
}

/* ==========================================================
   v11.5.14 · slider portada, RSVP deadline y modales
   ========================================================== */
.boda-simple,
.boda-simple * {
  box-sizing: border-box;
}
.boda-simple {
  max-width: 100vw;
  overflow-x: hidden !important;
}
.boda-simple section {
  max-width: 100vw;
  overflow-x: clip;
}
.boda-hero {
  position: relative;
  height: var(--boda-safe-vh);
  min-height: var(--boda-safe-vh);
  padding: clamp(32px, 6vh, 72px) 18px;
  isolation: isolate;
}
@supports (height: 100dvh) {
  .boda-hero {
    height: 100dvh;
    min-height: 100dvh;
  }
}
.boda-hero__slider {
  position: absolute;
  inset: 0;
  z-index: -3;
  overflow: hidden;
  background: #f8f1e4;
  will-change: transform;
}
.boda-hero__slide,
.boda-hero__bg.boda-hero__slide {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  opacity: 0;
  transform: scale(1.018);
  transition: opacity 1400ms ease, transform 6500ms ease;
  filter: saturate(.98) contrast(.98) brightness(1.03);
}
.boda-hero__slide.is-active {
  opacity: 1;
  transform: scale(1);
}
.boda-hero__shade {
  pointer-events: none;
}
@media (orientation: portrait) {
  .boda-hero__slide,
  .boda-hero__bg.boda-hero__slide {
    background-position: center center !important;
  }
}
@media (prefers-reduced-motion: reduce) {
  .boda-hero__slide,
  .boda-hero__bg.boda-hero__slide {
    transition: none !important;
    transform: none !important;
  }
}
.boda-rsvp__header .boda-rsvp__intro-text {
  display: block !important;
  width: min(660px, 100%);
  margin: clamp(14px, 2.4vh, 24px) auto 0 !important;
  color: rgba(255,255,255,.88) !important;
  font-family: var(--boda-sans);
  font-size: clamp(15px, 1.35vw, 18px) !important;
  line-height: 1.75 !important;
  letter-spacing: .01em;
  text-align: center;
}
.boda-rsvp__header .boda-rsvp-deadline-pill,
.boda-rsvp-deadline-pill {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  margin-top: clamp(16px, 2.8vh, 24px) !important;
  padding: 12px 22px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(216,179,118,.82) !important;
  background: linear-gradient(135deg, rgba(255,255,255,.99), rgba(255,247,231,.95)) !important;
  color: var(--boda-green) !important;
  box-shadow: 0 16px 34px rgba(0,0,0,.18), inset 0 0 0 1px rgba(255,255,255,.72) !important;
  font-family: var(--boda-sans) !important;
  font-size: clamp(12px, 1.1vw, 14px) !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: .13em !important;
}
.boda-guests-modal,
.boda-pickup-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 2147483640 !important;
  width: 100vw !important;
  height: var(--boda-safe-vh) !important;
  max-height: var(--boda-safe-vh) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: clamp(12px, 3vw, 32px) !important;
  overflow: hidden !important;
  isolation: isolate !important;
}
@supports (height: 100dvh) {
  .boda-guests-modal,
  .boda-pickup-modal {
    height: 100dvh !important;
    max-height: 100dvh !important;
  }
}
.boda-guests-modal[aria-hidden="true"],
.boda-pickup-modal[aria-hidden="true"] {
  pointer-events: none !important;
}
.boda-guests-modal__backdrop,
.boda-pickup-modal__backdrop {
  position: absolute !important;
  inset: 0 !important;
}
.boda-guests-modal__dialog,
.boda-pickup-modal__dialog {
  position: relative !important;
  z-index: 2 !important;
  width: min(var(--boda-modal-panel-width, 920px), calc(100vw - 32px)) !important;
  max-width: calc(100vw - 32px) !important;
  height: auto !important;
  max-height: calc(var(--boda-safe-vh) - 32px) !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  border-radius: clamp(22px, 3vw, 32px) !important;
  background: linear-gradient(180deg, #fff, #fffaf1) !important;
  box-shadow: 0 30px 90px rgba(0,0,0,.34) !important;
}
@supports (height: 100dvh) {
  .boda-guests-modal__dialog,
  .boda-pickup-modal__dialog {
    max-height: calc(100dvh - 32px) !important;
  }
}
.boda-guests-modal__dialog > header,
.boda-pickup-modal__dialog > header,
.boda-guests-modal__dialog > footer,
.boda-pickup-modal__dialog > footer {
  flex: 0 0 auto !important;
}
.boda-guests-modal__content,
.boda-pickup-modal__content {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  overscroll-behavior: contain !important;
  -webkit-overflow-scrolling: touch !important;
  scrollbar-gutter: stable !important;
  padding-bottom: clamp(16px, 3vh, 28px) !important;
}
.boda-pickup-modal .boda-pickup-options {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(min(260px, 100%), 1fr)) !important;
  gap: clamp(14px, 2vw, 22px) !important;
  width: 100% !important;
}
.boda-pickup-modal .boda-pickup-option {
  min-width: 0 !important;
}
.boda-pickup-modal .boda-pickup-option > span {
  min-height: 138px !important;
  height: 100% !important;
  border-radius: 22px !important;
  border: 1px solid rgba(188,135,52,.22) !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 10px 24px rgba(21,63,44,.06) !important;
}
.boda-pickup-modal .boda-pickup-option input:checked + span {
  border-color: rgba(188,135,52,.72) !important;
  background: linear-gradient(135deg, rgba(21,63,44,.08), rgba(216,179,118,.22)) !important;
  box-shadow: 0 18px 36px rgba(21,63,44,.13) !important;
}
.boda-pickup-modal .boda-bus-availability--modal {
  margin-bottom: clamp(16px, 2.8vh, 28px) !important;
}
body.boda-modal-lock .boda-section-dots {
  opacity: 0 !important;
  pointer-events: none !important;
}
@media (max-width: 900px) {
  .boda-section,
  .boda-rsvp,
  .boda-footer {
    min-height: var(--boda-safe-vh);
  }
  .boda-section > .boda-container,
  .boda-footer > .boda-footer__card {
    max-height: calc(var(--boda-safe-vh) - 42px);
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
  }
}
@media (max-width: 760px) {
  .boda-rsvp__header .boda-rsvp__intro-text {
    width: min(92vw, 520px);
    font-size: 14px !important;
    line-height: 1.65 !important;
  }
  .boda-rsvp__header .boda-rsvp-deadline-pill,
  .boda-rsvp-deadline-pill {
    padding: 10px 16px !important;
    letter-spacing: .08em !important;
  }
  .boda-guests-modal,
  .boda-pickup-modal {
    align-items: stretch !important;
    padding: 8px !important;
  }
  .boda-guests-modal__dialog,
  .boda-pickup-modal__dialog {
    width: calc(100vw - 16px) !important;
    max-width: calc(100vw - 16px) !important;
    max-height: calc(var(--boda-safe-vh) - 16px) !important;
    border-radius: 22px !important;
  }
  @supports (height: 100dvh) {
    .boda-guests-modal__dialog,
    .boda-pickup-modal__dialog {
      max-height: calc(100dvh - 16px) !important;
    }
  }
  .boda-guests-modal__dialog > header,
  .boda-pickup-modal__dialog > header {
    padding: 22px 18px 12px !important;
  }
  .boda-guests-modal__dialog > footer,
  .boda-pickup-modal__dialog > footer {
    padding: 14px 18px 18px !important;
    gap: 10px !important;
  }
  .boda-pickup-modal .boda-pickup-options {
    grid-template-columns: 1fr !important;
  }
  .boda-pickup-modal .boda-pickup-option > span {
    min-height: 112px !important;
  }
}


/* v11.5.14 · liberar contenedor RSVP mientras hay modal abierto */
.boda-rsvp__form.boda-rsvp-wizard.has-open-modal {
  overflow: visible !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  transform: none !important;
  contain: none !important;
}


/* ==========================================================
   v11.5.15 · scroll natural y RSVP sin scroll interno.
   - Se retira el encaje/scroll snap por secciones.
   - El formulario RSVP deja de crear scroll vertical u horizontal propio.
   - Solo el modal de acompañantes conserva scroll interno.
   - La píldora de fecha límite queda centrada.
   ========================================================== */
html.boda-section-snap,
html.boda-section-snap.boda-modal-lock,
html.boda-section-snap:has(body.boda-modal-lock) {
  scroll-snap-type: none !important;
  scroll-padding-top: 0 !important;
}
html.boda-section-snap .boda-hero,
html.boda-section-snap .boda-section,
html.boda-section-snap .boda-rsvp,
html.boda-section-snap .boda-footer {
  scroll-snap-align: none !important;
  scroll-snap-stop: normal !important;
}
html.boda-section-snap .boda-section,
html.boda-section-snap .boda-rsvp,
html.boda-section-snap .boda-footer,
.boda-section,
.boda-rsvp,
.boda-footer {
  height: auto !important;
  min-height: var(--boda-safe-vh) !important;
  overflow: visible !important;
}
@supports (height:100dvh) {
  html.boda-section-snap .boda-section,
  html.boda-section-snap .boda-rsvp,
  html.boda-section-snap .boda-footer,
  .boda-section,
  .boda-rsvp,
  .boda-footer {
    min-height: 100dvh !important;
  }
}
html.boda-section-snap .boda-section > .boda-container,
html.boda-section-snap .boda-rsvp > .boda-container,
html.boda-section-snap .boda-footer > .boda-footer__card,
.boda-section > .boda-container,
.boda-rsvp > .boda-container,
.boda-footer > .boda-footer__card {
  max-height: none !important;
  overflow: visible !important;
  overflow-x: visible !important;
  overflow-y: visible !important;
}
.boda-hero {
  height: auto !important;
  min-height: var(--boda-safe-vh) !important;
  overflow: hidden !important;
}
@supports (height:100dvh) {
  .boda-hero { min-height: 100dvh !important; }
}
.boda-rsvp {
  padding-block: clamp(34px, 5.6vh, 76px) !important;
  overflow: visible !important;
}
.boda-rsvp > .boda-container {
  min-height: 0 !important;
  align-items: center !important;
  grid-template-columns: minmax(250px,.78fr) minmax(420px,1.22fr) !important;
  gap: clamp(22px, 4vw, 52px) !important;
}
.boda-rsvp__header {
  display: grid !important;
  justify-items: center;
  text-align: center;
}
.boda-rsvp__header .boda-rsvp-deadline-pill,
.boda-rsvp-deadline-pill {
  display: inline-flex !important;
  width: fit-content !important;
  max-width: min(100%, 520px) !important;
  margin: clamp(14px, 2.2vh, 22px) auto 0 !important;
  align-self: center !important;
  justify-self: center !important;
  text-align: center !important;
  white-space: normal !important;
}
.boda-rsvp__form.boda-rsvp-wizard {
  width: 100% !important;
  max-width: 760px !important;
  min-height: 0 !important;
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
  padding: clamp(14px, 2vw, 22px) !important;
  gap: clamp(10px, 1.6vh, 14px) !important;
  contain: layout paint;
}
.boda-rsvp-wizard__body {
  display: block !important;
  min-height: 0 !important;
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
}
.boda-rsvp-step {
  display: none !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
  padding: clamp(2px, .7vh, 8px) 0 !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: none !important;
  transition: opacity .22s ease !important;
}
.boda-rsvp-step.is-active {
  display: block !important;
  animation: bodaRsvpStepIn .24s ease both;
}
.boda-rsvp-step legend {
  margin-bottom: clamp(4px, .8vh, 8px) !important;
  font-size: clamp(28px, 2.8vw, 42px) !important;
}
.boda-rsvp-step p {
  margin-bottom: clamp(10px, 1.6vh, 16px) !important;
  font-size: clamp(13px, 1vw, 15px) !important;
  line-height: 1.45 !important;
}
.boda-rsvp-fields,
.boda-rsvp-options-grid,
.boda-rsvp-choice-grid,
.boda-transport-grid,
.boda-rsvp-counter-grid {
  overflow: visible !important;
}
.boda-rsvp-fields,
.boda-rsvp-options-grid { gap: clamp(10px, 1.5vh, 14px) !important; }
.boda-rsvp-choice-grid,
.boda-transport-grid,
.boda-rsvp-counter-grid { gap: clamp(10px, 1.6vh, 14px) !important; }
.boda-rsvp-choice > span,
.boda-transport-choice > span {
  min-height: clamp(88px, 15vh, 126px) !important;
  padding: clamp(12px, 2vw, 20px) !important;
}
.boda-rsvp-choice i,
.boda-transport-choice i {
  width: clamp(38px, 5.5vh, 54px) !important;
  height: clamp(38px, 5.5vh, 54px) !important;
  margin-bottom: clamp(6px, 1vh, 10px) !important;
}
.boda-rsvp-choice strong,
.boda-transport-choice strong {
  font-size: clamp(23px, 2.2vw, 31px) !important;
  line-height: 1.02 !important;
}
.boda-rsvp-choice small,
.boda-transport-choice small {
  font-size: clamp(10px, .9vw, 12px) !important;
  line-height: 1.3 !important;
}
.boda-rsvp-counter-card {
  padding: clamp(12px, 2vw, 18px) !important;
}
.boda-stepper {
  grid-template-columns: clamp(42px, 6vh, 54px) minmax(0,1fr) clamp(42px, 6vh, 54px) !important;
}
.boda-stepper button,
.boda-stepper input {
  height: clamp(42px, 6vh, 54px) !important;
}
.boda-rsvp-helper {
  margin-top: clamp(10px, 1.8vh, 18px) !important;
  padding: clamp(8px, 1.4vh, 10px) 12px !important;
}
.boda-rsvp-wizard__nav {
  min-height: 0 !important;
  margin-top: clamp(10px, 1.8vh, 18px) !important;
  gap: clamp(8px, 1.4vw, 14px) !important;
}
.boda-rsvp-wizard .boda-form__status {
  min-height: 0 !important;
  margin: clamp(6px, 1vh, 10px) 0 0 !important;
}
.boda-rsvp-summary {
  gap: 8px !important;
  margin: clamp(10px, 1.6vh, 16px) 0 !important;
}
.boda-rsvp-summary span {
  padding: clamp(8px, 1.4vh, 12px) !important;
}
.boda-rsvp-confirm-card {
  padding: clamp(18px, 3vw, 36px) !important;
}
.boda-rsvp-confirm-icon {
  width: clamp(48px, 7vh, 70px) !important;
  height: clamp(48px, 7vh, 70px) !important;
  margin-bottom: clamp(8px, 1.4vh, 14px) !important;
}
.boda-rsvp__form.boda-rsvp-wizard.has-open-modal {
  overflow: visible !important;
  contain: none !important;
}
.boda-guests-modal__content {
  overflow-y: auto !important;
  overflow-x: hidden !important;
  overscroll-behavior: contain !important;
  -webkit-overflow-scrolling: touch !important;
}
.boda-pickup-modal__dialog {
  max-height: calc(var(--boda-safe-vh) - 24px) !important;
}
.boda-pickup-modal__content {
  overflow: visible !important;
  display: grid !important;
  grid-template-columns: minmax(150px, .44fr) minmax(0, 1fr) !important;
  align-items: stretch !important;
  gap: clamp(12px, 2vw, 18px) !important;
}
.boda-pickup-modal .boda-bus-availability--modal {
  margin-bottom: 0 !important;
}
.boda-pickup-modal .boda-pickup-options {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  gap: clamp(10px, 1.5vw, 14px) !important;
}
.boda-pickup-modal .boda-pickup-option > span {
  min-height: clamp(96px, 16vh, 132px) !important;
  padding: clamp(12px, 2vw, 18px) !important;
}
@media (max-width: 1040px) {
  .boda-rsvp > .boda-container {
    grid-template-columns: 1fr !important;
    width: min(900px, calc(100% - 34px)) !important;
  }
  .boda-rsvp__header { max-width: 760px !important; margin-inline: auto !important; }
  .boda-rsvp__form.boda-rsvp-wizard { margin-inline: auto !important; max-width: 860px !important; }
}
@media (max-width: 760px) {
  .boda-rsvp {
    padding-block: clamp(24px, 4vh, 42px) !important;
  }
  .boda-rsvp > .boda-container {
    width: calc(100% - 24px) !important;
    gap: clamp(14px, 3vh, 22px) !important;
  }
  .boda-rsvp__header .boda-rsvp__intro-text {
    margin-top: 10px !important;
    font-size: clamp(12px, 3.35vw, 14px) !important;
    line-height: 1.45 !important;
  }
  .boda-rsvp__header .boda-rsvp-deadline-pill,
  .boda-rsvp-deadline-pill {
    padding: 9px 13px !important;
    font-size: clamp(10px, 2.7vw, 12px) !important;
    letter-spacing: .06em !important;
  }
  .boda-rsvp__form.boda-rsvp-wizard {
    padding: 12px !important;
    border-radius: 20px !important;
  }
  .boda-rsvp-steps {
    gap: 6px !important;
    margin-bottom: 8px !important;
  }
  .boda-rsvp-steps button {
    width: clamp(31px, 9vw, 36px) !important;
    height: clamp(31px, 9vw, 36px) !important;
    min-width: clamp(31px, 9vw, 36px) !important;
  }
  .boda-rsvp-fields--two,
  .boda-rsvp-options-grid,
  .boda-rsvp-choice-grid,
  .boda-transport-grid,
  .boda-rsvp-counter-grid,
  .boda-pickup-panel {
    grid-template-columns: 1fr !important;
  }
  .boda-rsvp-choice > span,
  .boda-transport-choice > span {
    min-height: clamp(78px, 14vh, 104px) !important;
  }
  .boda-rsvp-wizard__nav {
    display: flex !important;
    flex-direction: row !important;
  }
  .boda-rsvp-wizard__nav .boda-btn {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    max-width: none !important;
    width: auto !important;
  }
  .boda-pickup-modal__content {
    grid-template-columns: 1fr !important;
  }
  .boda-pickup-modal .boda-pickup-options {
    grid-template-columns: 1fr !important;
  }
}
@media (max-height: 740px) and (min-width: 761px) {
  .boda-rsvp { padding-block: 24px !important; }
  .boda-rsvp > .boda-container { gap: 24px !important; }
  .boda-rsvp__header h2 { font-size: clamp(32px, 3.8vw, 48px) !important; }
  .boda-rsvp__header .boda-rsvp__intro-text { font-size: 14px !important; line-height: 1.45 !important; margin-top: 10px !important; }
  .boda-rsvp__header .boda-rsvp-deadline-pill { margin-top: 12px !important; padding: 9px 15px !important; }
  .boda-rsvp__form.boda-rsvp-wizard { padding: 12px !important; gap: 8px !important; }
  .boda-rsvp-steps { margin-bottom: 6px !important; gap: 6px !important; }
  .boda-rsvp-steps button { width: 34px !important; height: 34px !important; min-width: 34px !important; }
  .boda-rsvp-step legend { font-size: clamp(26px, 2.6vw, 36px) !important; }
  .boda-rsvp-step p { margin-bottom: 8px !important; font-size: 12px !important; }
  .boda-rsvp-choice > span,
  .boda-transport-choice > span { min-height: 82px !important; padding: 10px !important; }
  .boda-rsvp-choice i,
  .boda-transport-choice i { width: 36px !important; height: 36px !important; font-size: 20px !important; margin-bottom: 4px !important; }
  .boda-rsvp-choice strong,
  .boda-transport-choice strong { font-size: 24px !important; }
  .boda-rsvp-counter-card { padding: 10px !important; }
  .boda-stepper { grid-template-columns: 40px minmax(0,1fr) 40px !important; }
  .boda-stepper button,
  .boda-stepper input { height: 40px !important; }
  .boda-rsvp-helper { margin-top: 8px !important; font-size: 12px !important; }
  .boda-rsvp-wizard__nav { margin-top: 8px !important; }
  .boda-rsvp-confirm-icon { display: none !important; }
  .boda-rsvp-confirm-card { padding: 16px !important; }
  .boda-rsvp-summary span { padding: 8px !important; }
}
@media (max-height: 560px) and (orientation: landscape) {
  .boda-rsvp { align-items: flex-start !important; padding-block: 14px !important; }
  .boda-rsvp > .boda-container { width: calc(100% - 24px) !important; gap: 12px !important; }
  .boda-rsvp__header .boda-label,
  .boda-rsvp__header .boda-ornament { display: none !important; }
  .boda-rsvp__header h2 { font-size: 30px !important; margin-bottom: 4px !important; }
  .boda-rsvp__header .boda-rsvp__intro-text { display: none !important; }
  .boda-rsvp__header .boda-rsvp-deadline-pill { margin-top: 6px !important; padding: 7px 12px !important; font-size: 10px !important; }
  .boda-rsvp-step legend { font-size: 26px !important; }
  .boda-rsvp-step p { display: none !important; }
  .boda-pickup-modal__dialog > header .boda-ornament,
  .boda-pickup-modal__dialog > header small { display: none !important; }
  .boda-pickup-modal__dialog > header { padding: 14px 58px 8px 18px !important; }
  .boda-pickup-modal__dialog > header h3 { font-size: 30px !important; }
  .boda-pickup-modal__dialog > footer { padding: 10px 18px 14px !important; }
  .boda-pickup-modal__content { grid-template-columns: minmax(120px,.34fr) minmax(0,1fr) !important; padding-bottom: 10px !important; }
  .boda-pickup-modal .boda-pickup-option > span { min-height: 78px !important; }
}

/* ==========================================================
   v11.5.16 · Ajustes RSVP, contador, WhatsApp y responsive.
   ========================================================== */
.boda-rsvp__form.boda-rsvp-wizard{
  overflow:visible!important;
  max-height:none!important;
  height:auto!important;
}
.boda-rsvp-wizard__body,
.boda-rsvp-step{
  overflow:visible!important;
  max-height:none!important;
}
.boda-rsvp-step.is-active{
  display:grid!important;
  align-content:center!important;
  justify-items:stretch!important;
  min-height:0!important;
}
.boda-rsvp-step[data-rsvp-step="1"].is-active{
  justify-items:center!important;
  text-align:center!important;
}
.boda-rsvp-step[data-rsvp-step="1"] .boda-rsvp-choice-grid,
.boda-rsvp-choice-grid--fullheight{
  width:min(100%,680px)!important;
  margin-inline:auto!important;
  justify-content:center!important;
  align-items:stretch!important;
}
.boda-rsvp-choice,
.boda-transport-choice,
.boda-pickup-option{
  display:block!important;
}
.boda-rsvp-choice > span,
.boda-transport-choice > span{
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
  margin-inline:auto!important;
}
.boda-rsvp-choice.is-selected > span,
.boda-transport-choice.is-selected > span,
.boda-rsvp-choice input:checked + span,
.boda-transport-choice input:checked + span,
.boda-pickup-option.is-selected > span,
.boda-pickup-option input:checked + span{
  border-color:rgba(216,179,118,.78)!important;
  background:rgba(216,179,118,.20)!important;
  box-shadow:0 18px 38px rgba(0,0,0,.14), inset 0 0 0 1px rgba(255,255,255,.20)!important;
  transform:translateY(-2px)!important;
}
.boda-rsvp-confirm-step.is-active{
  place-items:center!important;
  text-align:center!important;
}
.boda-rsvp-confirm-card{
  width:min(100%,620px)!important;
  margin:auto!important;
}
.boda-rsvp-summary{
  justify-content:center!important;
}
.boda-rsvp-wizard__nav{
  justify-content:center!important;
  align-items:center!important;
}
.boda-rsvp-wizard__nav .boda-btn{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
}
.boda-rsvp-wizard__nav .boda-btn[hidden]{display:none!important;}
.boda-bus-availability small em,
.boda-pickup-option small em{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:20px;
  padding:2px 8px;
  border-radius:999px;
  background:rgba(255,255,255,.60);
  color:var(--boda-gold-2);
  font-style:normal;
  font-weight:900;
}
.boda-pickup-option.is-disabled > span,
.boda-pickup-option input:disabled + span{
  opacity:.52!important;
  filter:grayscale(.25)!important;
  cursor:not-allowed!important;
}
.boda-countdown.is-wedding-day [data-count-unit="days"],
.boda-countdown.is-wedding-day [data-count-separator="days"]{
  display:none!important;
}
.boda-countdown.is-wedding-day{
  grid-template-columns:1fr 1px 1fr 1px 1fr!important;
  max-width:min(660px,100%)!important;
}
.boda-countdown.is-finished{
  display:none!important;
}
.boda-countdown-finished-message{
  width:min(680px,100%);
  margin:clamp(14px,2vh,22px) auto 0;
  padding:clamp(16px,3vw,24px) clamp(18px,4vw,34px);
  border:1px solid rgba(188,135,52,.30);
  border-radius:26px;
  background:linear-gradient(145deg,rgba(255,255,255,.94),rgba(255,248,235,.88));
  color:var(--boda-green);
  text-align:center;
  font:600 clamp(22px,3vw,34px)/1.18 var(--boda-serif);
  box-shadow:0 18px 44px rgba(21,63,44,.10);
}
.boda-btn--whatsapp,
.boda-footer__whatsapp{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  text-align:center!important;
  gap:12px!important;
}
.boda-whatsapp-mini,
.boda-whatsapp-icon{
  flex:0 0 auto!important;
  display:grid!important;
  place-items:center!important;
  width:42px!important;
  height:42px!important;
  border-radius:999px!important;
  color:#fff!important;
  background:linear-gradient(135deg,#18b45f,#0f8b49)!important;
  box-shadow:0 10px 22px rgba(15,139,73,.24)!important;
}
.boda-whatsapp-mini{font-size:19px!important;line-height:1!important;}
.boda-footer__phone-text{
  display:grid!important;
  gap:2px!important;
  justify-items:center!important;
  text-align:center!important;
  min-width:0!important;
}
.boda-footer__phones{
  justify-content:center!important;
}
.boda-footer__whatsapp{
  min-width:min(100%,260px)!important;
  padding:10px 18px!important;
}
@media(max-width:760px){
  .boda-rsvp-step.is-active{align-content:start!important;}
  .boda-rsvp-step[data-rsvp-step="1"].is-active,
  .boda-rsvp-confirm-step.is-active{align-content:center!important;}
  .boda-rsvp-step[data-rsvp-step="1"] .boda-rsvp-choice-grid,
  .boda-rsvp-choice-grid--fullheight{width:100%!important;}
  .boda-rsvp-choice-grid--fullheight,
  .boda-transport-grid{grid-template-columns:1fr!important;}
  .boda-countdown.is-wedding-day{grid-template-columns:1fr!important;gap:10px!important;}
  .boda-countdown.is-wedding-day i{display:none!important;}
  .boda-footer__whatsapp{width:100%!important;max-width:330px!important;}
}
@media(max-height:740px) and (min-width:761px){
  .boda-rsvp-step[data-rsvp-step="1"] .boda-rsvp-choice-grid{width:min(100%,600px)!important;}
  .boda-rsvp-choice > span,
  .boda-transport-choice > span{min-height:76px!important;}
  .boda-rsvp-confirm-card{padding:14px!important;}
}
@media(max-height:590px) and (orientation:landscape){
  .boda-rsvp-step[data-rsvp-step="1"] .boda-rsvp-choice-grid,
  .boda-transport-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
  .boda-rsvp-choice > span,
  .boda-transport-choice > span{min-height:70px!important;}
  .boda-rsvp-choice small,
  .boda-transport-choice small{display:none!important;}
}

/* RSVP compacto para evitar scroll del formulario fuera de modales */
.boda-rsvp-step[data-rsvp-step="4"] .boda-rsvp-options-grid{gap:clamp(8px,1.2vh,12px)!important;}
.boda-rsvp-step[data-rsvp-step="4"] .boda-rsvp-options-grid>div{padding:clamp(9px,1.5vh,13px)!important;}
.boda-rsvp-step[data-rsvp-step="4"] .boda-rsvp-options-grid h4{margin-bottom:clamp(6px,1vh,9px)!important;}
.boda-rsvp-step[data-rsvp-step="4"] .boda-rsvp-checks{gap:6px!important;}
.boda-rsvp-step[data-rsvp-step="4"] .boda-rsvp-checks label{min-height:28px!important;padding:5px 8px!important;font-size:9.5px!important;}
.boda-rsvp-step[data-rsvp-step="4"] textarea{min-height:clamp(54px,9vh,76px)!important;resize:none!important;}
@media(max-height:740px) and (min-width:761px){
  .boda-rsvp-step[data-rsvp-step="4"] .boda-rsvp-options-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
  .boda-rsvp-step[data-rsvp-step="4"] .boda-rsvp-options-wide{grid-column:auto!important;}
  .boda-rsvp-step[data-rsvp-step="4"] .boda-rsvp-field-wide{grid-column:1/-1!important;}
}


/* ==========================================================
   v11.5.17 · Correcciones finales de centrado, dots y back.
   ========================================================== */
.boda-rsvp__form.boda-rsvp-wizard{
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:14px!important;
}
.boda-rsvp-wizard__body{
  width:100%!important;
  display:grid!important;
  place-items:center!important;
  overflow:visible!important;
}
.boda-rsvp-step{
  width:100%!important;
  margin-inline:auto!important;
}
.boda-rsvp-step[data-rsvp-step="1"].is-active,
.boda-rsvp-step[data-rsvp-step="5"].is-active{
  justify-items:center!important;
  align-content:center!important;
  text-align:center!important;
}
.boda-rsvp-step[data-rsvp-step="1"] .boda-rsvp-choice-grid{
  width:min(100%,720px)!important;
  margin-inline:auto!important;
}
.boda-rsvp-choice-grid--fullheight,
.boda-transport-grid{
  justify-content:center!important;
}
.boda-rsvp-choice,
.boda-transport-choice{
  margin-inline:auto!important;
}
.boda-rsvp-choice>span,
.boda-transport-choice>span{
  margin-inline:auto!important;
}
.boda-rsvp-steps{
  display:flex!important;
  justify-content:center!important;
  align-items:center!important;
  gap:12px!important;
}
.boda-rsvp-steps button{
  width:14px!important;
  height:14px!important;
  min-width:14px!important;
  border-radius:999px!important;
  border:1px solid rgba(216,179,118,.60)!important;
  background:rgba(255,255,255,.18)!important;
  padding:0!important;
  box-shadow:none!important;
}
.boda-rsvp-steps button span{
  display:block!important;
  width:100%!important;
  height:100%!important;
  border-radius:inherit!important;
  background:transparent!important;
  color:transparent!important;
  font-size:0!important;
}
.boda-rsvp-steps button.is-active,
.boda-rsvp-steps button.is-complete{
  background:rgba(216,179,118,.92)!important;
  border-color:rgba(216,179,118,.92)!important;
  box-shadow:0 0 0 5px rgba(216,179,118,.16)!important;
}
.boda-rsvp-confirm-card{
  width:min(100%,720px)!important;
  margin-inline:auto!important;
  text-align:center!important;
}
.boda-rsvp-summary{
  width:100%!important;
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  justify-content:center!important;
}
.boda-rsvp-summary>span:only-child{
  grid-column:1/-1!important;
  width:100%!important;
  max-width:none!important;
}
.boda-rsvp-wizard__nav{
  width:100%!important;
  display:flex!important;
  justify-content:center!important;
  align-items:center!important;
  gap:14px!important;
  flex-wrap:wrap!important;
}
.boda-rsvp-wizard__nav .boda-btn{
  min-width:220px!important;
}
@media(max-width:700px){
  .boda-rsvp-summary{grid-template-columns:1fr!important;}
  .boda-rsvp-wizard__nav{
    display:flex!important;
    flex-wrap:wrap!important;
    justify-content:center!important;
  }
  .boda-rsvp-wizard__nav .boda-btn{
    width:min(100%,280px)!important;
    min-width:0!important;
  }
  .boda-rsvp-steps{gap:10px!important;}
  .boda-rsvp-steps button{width:12px!important;height:12px!important;min-width:12px!important;}
}
.boda-section-dots{
  transition:opacity .22s ease,transform .22s ease!important;
}
@media(max-width:760px){
  .boda-section-dots.is-idle-hidden{
    opacity:0!important;
    transform:translateY(-50%) translateX(18px)!important;
    pointer-events:none!important;
  }
}
.boda-route-stop a,
.boda-route-stop .boda-btn,
.boda-route-card a{
  text-align:center!important;
  justify-content:center!important;
}
.boda-footer__credit{
  display:block!important;
  text-align:center!important;
}
.boda-admin-field--datetime .boda-admin-datetime-row,
.boda-admin-datetime-row{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
}
.boda-admin-field input,
.boda-admin-field select,
.boda-admin-field textarea{
  width:100%!important;
  box-sizing:border-box!important;
}
@media(max-width:900px){
  .boda-admin-datetime-row{grid-template-columns:1fr 1fr!important;}
}
@media(max-width:640px){
  .boda-admin-datetime-row{grid-template-columns:1fr!important;}
}


/* ==========================================================
   v11.5.18 · Centrado real del panel RSVP y puntos más pequeños.
   ========================================================== */
.boda-rsvp__form.boda-rsvp-wizard{
  width:min(100%, 980px)!important;
  margin-inline:auto!important;
}
.boda-rsvp-wizard__body{
  width:100%!important;
  display:grid!important;
  place-items:center!important;
}
.boda-rsvp-step.is-active{
  width:100%!important;
  display:grid!important;
  justify-items:center!important;
  align-content:center!important;
  text-align:center!important;
}
.boda-rsvp-step>legend,
.boda-rsvp-step>p,
.boda-rsvp-step>.boda-rsvp-fields,
.boda-rsvp-step>.boda-rsvp-choice-grid,
.boda-rsvp-step>.boda-rsvp-counter-grid,
.boda-rsvp-step>.boda-rsvp-companions-wrap,
.boda-rsvp-step>.boda-rsvp-helper,
.boda-rsvp-step>.boda-transport-grid,
.boda-rsvp-step>.boda-bus-availability--inline,
.boda-rsvp-step>.boda-rsvp-options-grid,
.boda-rsvp-step>.boda-rsvp-summary,
.boda-rsvp-step>.boda-rsvp-confirm-card{
  width:min(100%, 760px)!important;
  margin-inline:auto!important;
}
.boda-rsvp-step>.boda-rsvp-fields,
.boda-rsvp-step>.boda-rsvp-options-grid{
  justify-items:stretch!important;
}
.boda-rsvp-step>.boda-rsvp-choice-grid{
  width:min(100%, 640px)!important;
}
.boda-rsvp-step>.boda-transport-grid{
  width:min(100%, 680px)!important;
}
.boda-rsvp-step>.boda-rsvp-counter-grid{
  width:min(100%, 680px)!important;
}
.boda-rsvp-step>.boda-rsvp-helper{
  max-width:680px!important;
}
.boda-rsvp-confirm-card{
  display:grid!important;
  justify-items:center!important;
}
.boda-rsvp-summary{
  align-items:stretch!important;
}
.boda-rsvp-summary span{
  display:grid!important;
  place-items:center!important;
  text-align:center!important;
}
.boda-rsvp-wizard__nav{
  width:min(100%, 760px)!important;
  margin-inline:auto!important;
}
.boda-rsvp-steps{
  gap:8px!important;
  margin-bottom:14px!important;
}
.boda-rsvp-steps button{
  width:10px!important;
  height:10px!important;
  min-width:10px!important;
  border-width:1px!important;
}
.boda-rsvp-steps button.is-active,
.boda-rsvp-steps button.is-complete{
  box-shadow:0 0 0 3px rgba(216,179,118,.14)!important;
}
@media(max-width:700px){
  .boda-rsvp-step>legend,
  .boda-rsvp-step>p,
  .boda-rsvp-step>.boda-rsvp-fields,
  .boda-rsvp-step>.boda-rsvp-choice-grid,
  .boda-rsvp-step>.boda-rsvp-counter-grid,
  .boda-rsvp-step>.boda-rsvp-companions-wrap,
  .boda-rsvp-step>.boda-rsvp-helper,
  .boda-rsvp-step>.boda-transport-grid,
  .boda-rsvp-step>.boda-bus-availability--inline,
  .boda-rsvp-step>.boda-rsvp-options-grid,
  .boda-rsvp-step>.boda-rsvp-summary,
  .boda-rsvp-step>.boda-rsvp-confirm-card,
  .boda-rsvp-wizard__nav{
    width:100%!important;
  }
  .boda-rsvp-steps{gap:7px!important;}
  .boda-rsvp-steps button{
    width:8px!important;
    height:8px!important;
    min-width:8px!important;
  }
  .boda-rsvp-steps button.is-active,
  .boda-rsvp-steps button.is-complete{
    box-shadow:0 0 0 2px rgba(216,179,118,.14)!important;
  }
}

/* ==========================================================
   v11.5.19 · Autobuses: sin contador visible por parada y mensaje de completo.
   ========================================================== */
.boda-pickup-option [data-bus-available-pickup][hidden]{
  display:none!important;
}
.boda-pickup-full-message{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:max-content!important;
  max-width:100%!important;
  margin:.42rem auto 0!important;
  padding:.32rem .72rem!important;
  border-radius:999px!important;
  background:rgba(154,52,18,.12)!important;
  border:1px solid rgba(154,52,18,.28)!important;
  color:#9a3412!important;
  font:900 10px/1 var(--boda-sans)!important;
  letter-spacing:.12em!important;
  text-transform:uppercase!important;
  font-style:normal!important;
}
.boda-pickup-full-message[hidden]{
  display:none!important;
}
.boda-pickup-option.is-full > span,
.boda-pickup-option input:disabled + span{
  opacity:.62!important;
  filter:grayscale(.18)!important;
}
.boda-pickup-option.is-full > span{
  border-color:rgba(154,52,18,.25)!important;
  background:linear-gradient(145deg,rgba(255,255,255,.72),rgba(255,244,238,.74))!important;
}


/* ==========================================================
   v11.5.20 · Scroll interno real en modal de playlist Spotify.
   ========================================================== */
.boda-spotify-modal[data-spotify-modal="playlist"]{
  overflow:hidden!important;
}
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__dialog{
  display:flex!important;
  flex-direction:column!important;
  height:calc(var(--boda-safe-vh, 100vh) - 0px)!important;
  max-height:calc(var(--boda-safe-vh, 100vh) - 0px)!important;
  min-height:0!important;
  overflow:hidden!important;
}
@supports (height:100dvh){
  .boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__dialog{
    height:100dvh!important;
    max-height:100dvh!important;
  }
}
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__header,
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__footer{
  flex:0 0 auto!important;
}
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__content{
  flex:1 1 auto!important;
  min-height:0!important;
  height:auto!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  overscroll-behavior:contain!important;
  -webkit-overflow-scrolling:touch!important;
  scrollbar-gutter:stable both-edges!important;
}
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-playlist--modal{
  height:auto!important;
  min-height:min-content!important;
  max-height:none!important;
  overflow:visible!important;
  align-content:start!important;
}
@media(max-width:760px){
  .boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__dialog{
    width:100vw!important;
    max-width:100vw!important;
    height:var(--boda-safe-vh, 100vh)!important;
    max-height:var(--boda-safe-vh, 100vh)!important;
  }
  .boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__header{
    padding-top:max(18px,env(safe-area-inset-top))!important;
    padding-bottom:10px!important;
  }
  .boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__content{
    padding-bottom:max(24px,env(safe-area-inset-bottom))!important;
  }
}


/* ==========================================================
   v11.5.21 · Scroll vertical real del listado de canciones.
   El scroll queda en la lista, no solo en el contenedor del modal.
   ========================================================== */
.boda-spotify-modal[data-spotify-modal="playlist"]{
  overflow:hidden!important;
  align-items:center!important;
  justify-items:center!important;
}
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__dialog{
  display:flex!important;
  flex-direction:column!important;
  width:min(1080px,calc(100vw - 24px))!important;
  height:min(900px,calc(var(--boda-safe-vh,100vh) - 24px))!important;
  max-height:calc(var(--boda-safe-vh,100vh) - 24px)!important;
  min-height:0!important;
  overflow:hidden!important;
}
@supports(height:100dvh){
  .boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__dialog{
    height:min(900px,calc(100dvh - 24px))!important;
    max-height:calc(100dvh - 24px)!important;
  }
}
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__header,
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__footer{
  flex:0 0 auto!important;
}
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__content{
  flex:1 1 auto!important;
  display:flex!important;
  flex-direction:column!important;
  min-height:0!important;
  height:auto!important;
  overflow:hidden!important;
  padding:0 clamp(14px,3vw,38px) clamp(12px,2.4vh,24px)!important;
}
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-playlist--modal{
  flex:1 1 auto!important;
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(min(420px,100%),1fr))!important;
  grid-auto-rows:min-content!important;
  align-content:start!important;
  gap:14px!important;
  width:min(1280px,100%)!important;
  height:100%!important;
  min-height:0!important;
  max-height:100%!important;
  margin:0 auto!important;
  padding:4px 14px 22px 2px!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  overscroll-behavior:contain!important;
  -webkit-overflow-scrolling:touch!important;
  scrollbar-gutter:stable both-edges!important;
  scrollbar-width:thin!important;
  scrollbar-color:var(--boda-gold) rgba(21,63,44,.10)!important;
}
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-playlist--modal::-webkit-scrollbar{
  width:10px!important;
}
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-playlist--modal::-webkit-scrollbar-track{
  background:rgba(21,63,44,.08)!important;
  border-radius:999px!important;
}
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-playlist--modal::-webkit-scrollbar-thumb{
  border-radius:999px!important;
  background:linear-gradient(180deg,var(--boda-green),var(--boda-gold))!important;
}
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-loading,
.boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-empty{
  align-self:start!important;
}
@media(max-width:760px){
  .boda-spotify-modal[data-spotify-modal="playlist"]{
    padding:8px!important;
  }
  .boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__dialog{
    width:calc(100vw - 16px)!important;
    max-width:calc(100vw - 16px)!important;
    height:calc(var(--boda-safe-vh,100vh) - 16px)!important;
    max-height:calc(var(--boda-safe-vh,100vh) - 16px)!important;
    border-radius:20px!important;
  }
  @supports(height:100dvh){
    .boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__dialog{
      height:calc(100dvh - 16px)!important;
      max-height:calc(100dvh - 16px)!important;
    }
  }
  .boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__header{
    padding:18px 58px 10px 18px!important;
  }
  .boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__header h3{
    font-size:32px!important;
  }
  .boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__header .boda-ornament{
    display:none!important;
  }
  .boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__content{
    padding:0 10px 10px!important;
  }
  .boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-playlist--modal{
    grid-template-columns:1fr!important;
    gap:10px!important;
    padding:2px 10px max(20px,env(safe-area-inset-bottom)) 2px!important;
  }
  .boda-spotify-modal[data-spotify-modal="playlist"] .boda-spotify-modal__footer{
    padding:0 14px max(12px,env(safe-area-inset-bottom))!important;
  }
}


/* ==========================================================
   v11.5.22 · Collage de momentos, Spotify fullscreen y protección visual.
   ========================================================== */
.boda-momentos{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 16% 12%, rgba(216,179,118,.18), transparent 34%),
    radial-gradient(circle at 86% 78%, rgba(255,255,255,.10), transparent 30%),
    linear-gradient(180deg, #123e2a 0%, #174b34 48%, #103623 100%);
}
.boda-momentos::before{
  content:"";
  position:absolute;
  inset:6%;
  border:1px solid rgba(216,179,118,.14);
  border-radius:42px;
  pointer-events:none;
}
.boda-momentos__inner{
  position:relative;
  z-index:1;
  display:grid;
  gap:clamp(22px,3vw,42px);
}
.boda-momentos__header{
  max-width:820px;
  margin-inline:auto;
  text-align:center;
}
.boda-momentos__header small{
  display:block;
  max-width:760px;
  margin:12px auto 0;
  color:rgba(255,255,255,.78);
  font-family:Montserrat,Arial,sans-serif;
  font-size:clamp(14px,1.3vw,17px);
  line-height:1.7;
}
.boda-momentos-collage{
  width:min(100%,1120px);
  margin-inline:auto;
  display:grid;
  grid-template-columns:repeat(12,minmax(0,1fr));
  grid-auto-rows:clamp(118px,12vw,184px);
  gap:clamp(12px,1.8vw,22px);
  align-items:stretch;
}
.boda-momento-card{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  min-width:0;
  min-height:0;
  border-radius:clamp(20px,2.4vw,34px);
  border:1px solid rgba(216,179,118,.34);
  background:rgba(255,255,255,.06);
  box-shadow:0 22px 60px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.13);
  transform:translateZ(0);
  -webkit-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
}
.boda-momento-card::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.08) 45%, rgba(11,38,25,.72)),
    radial-gradient(circle at 20% 12%, rgba(255,255,255,.20), transparent 28%);
  pointer-events:none;
}
.boda-momento-card figure{
  width:100%;
  height:100%;
  margin:0;
}
.boda-momento-card img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.018);
  transition:transform .8s cubic-bezier(.2,.8,.2,1), filter .8s ease;
  pointer-events:none;
  -webkit-user-drag:none;
  -webkit-touch-callout:none;
}
.boda-momento-card:hover img{
  transform:scale(1.075);
  filter:saturate(1.04) contrast(1.02);
}
.boda-momento-card__caption{
  position:absolute;
  left:clamp(16px,2vw,26px);
  right:clamp(16px,2vw,26px);
  bottom:clamp(14px,1.8vw,24px);
  z-index:2;
  display:grid;
  gap:4px;
  color:#fff;
  text-shadow:0 2px 12px rgba(0,0,0,.42);
}
.boda-momento-card__caption strong{
  font-family:"Cormorant Garamond",serif;
  font-size:clamp(24px,3vw,42px);
  line-height:.95;
  font-weight:700;
}
.boda-momento-card__caption span{
  font-family:Montserrat,Arial,sans-serif;
  font-size:clamp(12px,1vw,14px);
  line-height:1.45;
  color:rgba(255,255,255,.84);
  font-weight:600;
}
.boda-momento-card--1{grid-column:span 5;grid-row:span 2;}
.boda-momento-card--2{grid-column:span 4;grid-row:span 1;}
.boda-momento-card--3{grid-column:span 3;grid-row:span 2;}
.boda-momento-card--4{grid-column:span 4;grid-row:span 2;}
.boda-momento-card--5{grid-column:span 5;grid-row:span 1;}
.boda-momento-card--6{grid-column:span 3;grid-row:span 1;}
.boda-momentos__note{
  width:min(100%,760px);
  margin:0 auto;
  padding:14px 20px;
  border:1px solid rgba(216,179,118,.30);
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:rgba(255,255,255,.82);
  text-align:center;
  font-family:Montserrat,Arial,sans-serif;
  font-size:13px;
  font-weight:700;
  letter-spacing:.02em;
}

/* Spotify modal full screen en escritorio, portátil, tablet y móvil */
.boda-spotify-modal{
  position:fixed!important;
  inset:0!important;
  z-index:2147483000!important;
}
.boda-spotify-modal[aria-hidden="true"]{
  display:none!important;
}
.boda-spotify-modal[aria-hidden="false"],
.boda-spotify-modal.is-open{
  display:block!important;
}
.boda-spotify-modal__backdrop{
  position:absolute!important;
  inset:0!important;
  background:rgba(7,28,18,.88)!important;
  backdrop-filter:blur(14px)!important;
}
.boda-spotify-modal__dialog,
.boda-spotify-modal__dialog--search{
  position:fixed!important;
  inset:0!important;
  width:100vw!important;
  max-width:none!important;
  height:100vh!important;
  height:100dvh!important;
  max-height:none!important;
  min-height:100vh!important;
  min-height:100dvh!important;
  margin:0!important;
  border-radius:0!important;
  display:grid!important;
  grid-template-rows:auto minmax(0,1fr) auto!important;
  gap:clamp(12px,2vw,22px)!important;
  overflow:hidden!important;
  padding:clamp(18px,3vw,44px)!important;
  border:0!important;
  background:
    radial-gradient(circle at 18% 8%, rgba(216,179,118,.20), transparent 30%),
    linear-gradient(150deg, rgba(21,63,44,.98), rgba(12,43,28,.98))!important;
  box-shadow:none!important;
}
.boda-spotify-modal__dialog--search{
  grid-template-rows:auto minmax(0,1fr)!important;
}
.boda-spotify-modal__header{
  width:min(100%,980px)!important;
  margin:0 auto!important;
  text-align:center!important;
  flex:0 0 auto!important;
}
.boda-spotify-modal__content{
  width:min(100%,1120px)!important;
  min-height:0!important;
  height:100%!important;
  margin:0 auto!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
}
.boda-spotify-playlist--modal,
.boda-spotify-modal [data-spotify-playlist-list]{
  flex:1 1 auto!important;
  min-height:0!important;
  height:100%!important;
  max-height:none!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  -webkit-overflow-scrolling:touch!important;
  overscroll-behavior:contain!important;
  padding-right:clamp(2px,1vw,10px)!important;
  scrollbar-gutter:stable both-edges;
}
.boda-spotify-search--modal{
  width:min(100%,1120px)!important;
  height:100%!important;
  min-height:0!important;
  margin:0 auto!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
}
.boda-spotify-search--modal .boda-spotify-search__form{
  flex:0 0 auto!important;
}
.boda-spotify-search--modal .boda-spotify-message{
  flex:0 0 auto!important;
}
.boda-spotify-results,
.boda-spotify-modal [data-spotify-results]{
  flex:1 1 auto!important;
  min-height:0!important;
  height:100%!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  -webkit-overflow-scrolling:touch!important;
  overscroll-behavior:contain!important;
  padding-right:clamp(2px,1vw,10px)!important;
  scrollbar-gutter:stable both-edges;
}
.boda-spotify-modal__footer{
  width:min(100%,1120px)!important;
  margin:0 auto!important;
  flex:0 0 auto!important;
}
.boda-spotify-modal__close{
  position:fixed!important;
  top:max(14px,env(safe-area-inset-top))!important;
  right:max(14px,env(safe-area-inset-right))!important;
  z-index:2147483001!important;
}

/* Protección disuasoria de imágenes y gestos */
.boda-simple,
.boda-simple img,
.boda-simple picture,
.boda-simple figure,
.boda-simple .boda-momento-card{
  -webkit-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
  -webkit-tap-highlight-color:transparent;
}
.boda-simple img{
  -webkit-user-drag:none;
  pointer-events:auto;
}
.boda-simple input,
.boda-simple textarea,
.boda-simple select,
.boda-simple button{
  -webkit-user-select:auto!important;
  user-select:auto!important;
  -webkit-touch-callout:default!important;
}
#boda-sevilla-simple{
  touch-action:manipulation;
}
@media(max-width:900px){
  .boda-momentos-collage{
    grid-template-columns:repeat(6,minmax(0,1fr));
    grid-auto-rows:clamp(120px,24vw,180px);
  }
  .boda-momento-card--1,
  .boda-momento-card--4{grid-column:span 6;grid-row:span 2;}
  .boda-momento-card--2,
  .boda-momento-card--3,
  .boda-momento-card--5,
  .boda-momento-card--6{grid-column:span 3;grid-row:span 1;}
}
@media(max-width:640px){
  .boda-momentos::before{inset:12px;border-radius:28px;}
  .boda-momentos-collage{
    grid-template-columns:1fr;
    grid-auto-rows:auto;
  }
  .boda-momento-card,
  .boda-momento-card--1,
  .boda-momento-card--2,
  .boda-momento-card--3,
  .boda-momento-card--4,
  .boda-momento-card--5,
  .boda-momento-card--6{
    grid-column:auto;
    grid-row:auto;
    min-height:0;
  }
  .boda-momento-card figure{
    aspect-ratio:4/5;
  }
  .boda-momentos__note{
    border-radius:24px;
  }
  .boda-spotify-modal__dialog,
  .boda-spotify-modal__dialog--search{
    padding:clamp(14px,4vw,22px)!important;
  }
  .boda-spotify-modal__header{
    padding-right:44px!important;
  }
}


/* ==========================================================
   v11.5.23 · Collage inteligente: horizontal / vertical / cuadrada.
   ========================================================== */
.boda-momento-card--detecting{
  opacity:.92;
}
.boda-momento-card--detected{
  opacity:1;
}
.boda-momento-card[data-orientation="portrait"] img{
  object-position:center center;
}
.boda-momento-card[data-orientation="landscape"] img{
  object-position:center center;
}
.boda-momento-card[data-orientation="square"] img{
  object-position:center center;
}
@media(min-width:901px){
  .boda-momento-card.boda-momento-card--landscape{
    grid-column:span 5!important;
    grid-row:span 1!important;
  }
  .boda-momento-card.boda-momento-card--portrait{
    grid-column:span 3!important;
    grid-row:span 2!important;
  }
  .boda-momento-card.boda-momento-card--square{
    grid-column:span 4!important;
    grid-row:span 2!important;
  }
  .boda-momento-card.boda-momento-card--unknown{
    grid-column:span 4!important;
    grid-row:span 2!important;
  }
}
@media(min-width:641px) and (max-width:900px){
  .boda-momento-card.boda-momento-card--landscape{
    grid-column:span 6!important;
    grid-row:span 1!important;
  }
  .boda-momento-card.boda-momento-card--portrait{
    grid-column:span 3!important;
    grid-row:span 2!important;
  }
  .boda-momento-card.boda-momento-card--square,
  .boda-momento-card.boda-momento-card--unknown{
    grid-column:span 3!important;
    grid-row:span 2!important;
  }
}
@media(max-width:640px){
  .boda-momento-card.boda-momento-card--landscape figure{
    aspect-ratio:16/10!important;
  }
  .boda-momento-card.boda-momento-card--portrait figure{
    aspect-ratio:4/5!important;
  }
  .boda-momento-card.boda-momento-card--square figure,
  .boda-momento-card.boda-momento-card--unknown figure{
    aspect-ratio:1/1!important;
  }
}


/* ==========================================================
   v11.5.24 · Collage compacto sin huecos innecesarios.
   ========================================================== */
.boda-momentos-collage{
  display:grid!important;
  grid-template-columns:repeat(12,minmax(0,1fr))!important;
  grid-auto-rows:8px!important;
  grid-auto-flow:dense!important;
  gap:14px!important;
  align-items:start!important;
}
.boda-momento-card{
  min-height:0!important;
  height:auto!important;
  display:grid!important;
  grid-template-rows:auto auto!important;
  align-self:start!important;
}
.boda-momento-card figure{
  margin:0!important;
  height:auto!important;
}
.boda-momento-card img{
  width:100%!important;
  height:auto!important;
  display:block!important;
}
.boda-momento-card__caption{
  position:relative!important;
}
@media(min-width:901px){
  .boda-momento-card.boda-momento-card--landscape{grid-column:span 6!important;}
  .boda-momento-card.boda-momento-card--portrait{grid-column:span 4!important;}
  .boda-momento-card.boda-momento-card--square,
  .boda-momento-card.boda-momento-card--unknown{grid-column:span 4!important;}
}
@media(min-width:641px) and (max-width:900px){
  .boda-momentos-collage{grid-template-columns:repeat(6,minmax(0,1fr))!important;grid-auto-rows:8px!important;gap:12px!important;}
  .boda-momento-card.boda-momento-card--landscape{grid-column:span 6!important;}
  .boda-momento-card.boda-momento-card--portrait{grid-column:span 3!important;}
  .boda-momento-card.boda-momento-card--square,
  .boda-momento-card.boda-momento-card--unknown{grid-column:span 3!important;}
}
@media(max-width:640px){
  .boda-momentos-collage{grid-template-columns:repeat(2,minmax(0,1fr))!important;grid-auto-rows:6px!important;gap:10px!important;}
  .boda-momento-card.boda-momento-card--landscape{grid-column:span 2!important;}
  .boda-momento-card.boda-momento-card--portrait,
  .boda-momento-card.boda-momento-card--square,
  .boda-momento-card.boda-momento-card--unknown{grid-column:span 1!important;}
}


/* ==========================================================
   v11.5.25 · Spotify modal fullscreen centrado y legible.
   ========================================================== */
.boda-spotify-modal[aria-hidden="false"],
.boda-spotify-modal.is-open{
  position:fixed!important;
  inset:0!important;
  width:100vw!important;
  height:100vh!important;
  height:100dvh!important;
  display:grid!important;
  place-items:center!important;
  background:
    radial-gradient(circle at 18% 10%, rgba(216,179,118,.22), transparent 30%),
    radial-gradient(circle at 82% 82%, rgba(255,255,255,.08), transparent 34%),
    linear-gradient(135deg,#082719 0%,#0f3f2a 52%,#061f14 100%)!important;
  overflow:hidden!important;
  z-index:2147483000!important;
}
.boda-spotify-modal__backdrop{
  position:fixed!important;
  inset:0!important;
  width:100vw!important;
  height:100vh!important;
  height:100dvh!important;
  background:transparent!important;
  opacity:1!important;
  pointer-events:none!important;
}
.boda-spotify-modal__dialog,
.boda-spotify-modal__dialog--search{
  position:relative!important;
  inset:auto!important;
  left:auto!important;
  right:auto!important;
  top:auto!important;
  bottom:auto!important;
  transform:none!important;
  width:100vw!important;
  max-width:100vw!important;
  height:100vh!important;
  height:100dvh!important;
  min-height:0!important;
  max-height:100vh!important;
  max-height:100dvh!important;
  margin:0!important;
  border-radius:0!important;
  border:0!important;
  display:grid!important;
  grid-template-rows:auto minmax(0,1fr) auto!important;
  justify-items:center!important;
  align-items:stretch!important;
  gap:clamp(14px,2vw,24px)!important;
  padding:clamp(28px,4vw,56px) clamp(18px,5vw,80px)!important;
  background:transparent!important;
  box-shadow:none!important;
  color:#fffdf5!important;
  overflow:hidden!important;
  z-index:1!important;
}
.boda-spotify-modal__dialog--search{
  grid-template-rows:auto minmax(0,1fr)!important;
}
.boda-spotify-modal__header,
.boda-spotify-modal__content,
.boda-spotify-modal__footer,
.boda-spotify-search--modal{
  width:min(1120px,calc(100vw - 40px))!important;
  max-width:1120px!important;
  margin-left:auto!important;
  margin-right:auto!important;
}
.boda-spotify-modal__header{
  text-align:center!important;
  align-self:start!important;
  padding:0!important;
}
.boda-spotify-modal__header h2,
.boda-spotify-modal .boda-section__header h2,
.boda-spotify-modal h2{
  color:#fffdf5!important;
  opacity:1!important;
  text-shadow:0 10px 42px rgba(0,0,0,.52)!important;
  mix-blend-mode:normal!important;
}
.boda-spotify-modal__header p,
.boda-spotify-modal__header small,
.boda-spotify-modal__header span,
.boda-spotify-modal .boda-section__header small{
  color:rgba(255,253,245,.78)!important;
  opacity:1!important;
  text-shadow:0 4px 18px rgba(0,0,0,.26)!important;
}
.boda-spotify-modal__header .boda-label,
.boda-spotify-modal__header p:first-child,
.boda-spotify-modal .boda-label{
  color:#d8b376!important;
  opacity:1!important;
  text-shadow:0 5px 18px rgba(0,0,0,.28)!important;
}
.boda-spotify-modal .boda-ornament,
.boda-spotify-modal__header .boda-ornament{
  opacity:1!important;
  filter:drop-shadow(0 4px 16px rgba(0,0,0,.28))!important;
}
.boda-spotify-modal__content{
  min-height:0!important;
  height:100%!important;
  overflow:hidden!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:flex-start!important;
  align-items:stretch!important;
}
.boda-spotify-playlist--modal,
.boda-spotify-modal [data-spotify-playlist-list]{
  width:100%!important;
  max-width:1120px!important;
  margin:0 auto!important;
  display:grid!important;
  grid-template-columns:repeat(2,minmax(280px,1fr))!important;
  align-content:start!important;
  gap:16px!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  min-height:0!important;
  height:100%!important;
  max-height:100%!important;
  padding:2px 10px 14px!important;
  -webkit-overflow-scrolling:touch!important;
  overscroll-behavior:contain!important;
  scrollbar-gutter:stable both-edges;
}
.boda-spotify-modal__footer{
  display:flex!important;
  justify-content:center!important;
  align-items:center!important;
  align-self:end!important;
  gap:12px!important;
  min-height:0!important;
}
.boda-spotify-modal__close{
  position:fixed!important;
  top:max(18px,env(safe-area-inset-top))!important;
  right:max(18px,env(safe-area-inset-right))!important;
  left:auto!important;
  z-index:2147483001!important;
  box-shadow:0 12px 30px rgba(0,0,0,.24)!important;
}
.boda-spotify-search--modal{
  height:100%!important;
  min-height:0!important;
  overflow:hidden!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:flex-start!important;
  align-items:stretch!important;
}
.boda-spotify-search--modal .boda-spotify-search__form,
.boda-spotify-search--modal .boda-spotify-message{
  flex:0 0 auto!important;
}
.boda-spotify-results,
.boda-spotify-modal [data-spotify-results]{
  flex:1 1 auto!important;
  min-height:0!important;
  height:auto!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  -webkit-overflow-scrolling:touch!important;
  overscroll-behavior:contain!important;
  padding:2px 10px 14px!important;
  scrollbar-gutter:stable both-edges;
}
.boda-spotify-modal .boda-spotify-track{
  box-shadow:0 12px 32px rgba(0,0,0,.13)!important;
}
@media(min-width:761px) and (max-width:1100px){
  .boda-spotify-modal__dialog,
  .boda-spotify-modal__dialog--search{
    padding:clamp(24px,4vw,44px) clamp(18px,4vw,42px)!important;
  }
  .boda-spotify-playlist--modal,
  .boda-spotify-modal [data-spotify-playlist-list]{
    grid-template-columns:repeat(2,minmax(240px,1fr))!important;
  }
}
@media(max-width:760px){
  .boda-spotify-modal__dialog,
  .boda-spotify-modal__dialog--search{
    padding:clamp(16px,4vw,22px)!important;
    gap:12px!important;
  }
  .boda-spotify-modal__header,
  .boda-spotify-modal__content,
  .boda-spotify-modal__footer,
  .boda-spotify-search--modal{
    width:calc(100vw - 28px)!important;
  }
  .boda-spotify-modal__header{
    padding-right:44px!important;
  }
  .boda-spotify-modal__header h2,
  .boda-spotify-modal h2{
    font-size:clamp(34px,12vw,52px)!important;
    line-height:.95!important;
  }
  .boda-spotify-playlist--modal,
  .boda-spotify-modal [data-spotify-playlist-list]{
    grid-template-columns:1fr!important;
    gap:12px!important;
    padding-right:2px!important;
  }
}


/* ==========================================================
   v11.5.26 · Collage de momentos compacto sin huecos + dots para nuevas secciones.
   ========================================================== */
.boda-momentos-collage{
  display:block!important;
  width:min(100%,1160px)!important;
  margin-inline:auto!important;
  column-count:3;
  column-gap:18px!important;
}
.boda-momento-card{
  display:block!important;
  width:100%!important;
  margin:0 0 18px!important;
  break-inside:avoid!important;
  -webkit-column-break-inside:avoid!important;
  page-break-inside:avoid!important;
  height:auto!important;
  grid-row-end:auto!important;
}
.boda-momento-card figure,
.boda-momento-card img{
  display:block!important;
  width:100%!important;
  height:auto!important;
}
.boda-momento-card__caption{
  position:relative!important;
  left:auto!important;
  right:auto!important;
  bottom:auto!important;
  padding:14px 16px 16px!important;
}
.boda-momento-card::before{
  background:linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.06) 42%, rgba(11,38,25,.64))!important;
}
@media (max-width:900px){
  .boda-momentos-collage{
    column-count:2;
    column-gap:14px!important;
  }
  .boda-momento-card{margin-bottom:14px!important;}
}
@media (max-width:640px){
  .boda-momentos-collage{
    column-count:1;
    column-gap:0!important;
  }
  .boda-momento-card{margin-bottom:12px!important;}
}


/* ==========================================================
   v11.5.27 · Spotify modals en fondo blanco y listado sin recortes.
   ========================================================== */
.boda-spotify-modal[aria-hidden="false"],
.boda-spotify-modal.is-open{
  background:#fff!important;
  overflow:hidden!important;
}
.boda-spotify-modal__backdrop{
  background:#fff!important;
  backdrop-filter:none!important;
}
.boda-spotify-modal__dialog,
.boda-spotify-modal__dialog--search{
  background:#fff!important;
  color:var(--boda-green)!important;
  overflow:hidden!important;
  width:100vw!important;
  max-width:100vw!important;
  box-sizing:border-box!important;
  padding:clamp(18px,3vw,42px)!important;
}
.boda-spotify-modal__header,
.boda-spotify-modal__content,
.boda-spotify-modal__footer,
.boda-spotify-search--modal{
  box-sizing:border-box!important;
  max-width:1180px!important;
  width:min(100%,1180px)!important;
  margin-left:auto!important;
  margin-right:auto!important;
  color:var(--boda-green)!important;
}
.boda-spotify-modal__header h3,
.boda-spotify-modal__header p,
.boda-spotify-modal__header small,
.boda-spotify-modal__count,
.boda-spotify-modal__eyebrow{
  color:var(--boda-green)!important;
  opacity:1!important;
  text-shadow:none!important;
}
.boda-spotify-modal__header .boda-ornament,
.boda-spotify-modal .boda-ornament{
  opacity:1!important;
}
.boda-spotify-modal__content,
.boda-spotify-search--modal{
  overflow:hidden!important;
  min-width:0!important;
}
.boda-spotify-playlist--modal,
.boda-spotify-modal [data-spotify-playlist-list],
.boda-spotify-results,
.boda-spotify-modal [data-spotify-results]{
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  box-sizing:border-box!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  padding-left:0!important;
  padding-right:0!important;
  scrollbar-gutter:auto!important;
}
.boda-spotify-modal .boda-spotify-track,
.boda-spotify-modal .boda-spotify-result,
.boda-spotify-modal [data-spotify-playlist-list] > *,
.boda-spotify-modal [data-spotify-results] > *{
  max-width:100%!important;
  min-width:0!important;
  box-sizing:border-box!important;
}
.boda-spotify-modal .boda-spotify-track,
.boda-spotify-modal .boda-spotify-result{
  background:linear-gradient(180deg,#fff,#f8f6f0)!important;
  border:1px solid rgba(188,135,52,.22)!important;
  color:var(--boda-green)!important;
}
.boda-spotify-modal .boda-spotify-track * ,
.boda-spotify-modal .boda-spotify-result *{
  min-width:0!important;
}
.boda-spotify-modal .boda-spotify-track strong,
.boda-spotify-modal .boda-spotify-result strong,
.boda-spotify-modal .boda-spotify-track b,
.boda-spotify-modal .boda-spotify-result b{
  color:var(--boda-green)!important;
}
.boda-spotify-modal .boda-spotify-track span,
.boda-spotify-modal .boda-spotify-result span,
.boda-spotify-modal .boda-spotify-track small,
.boda-spotify-modal .boda-spotify-result small,
.boda-spotify-modal .boda-spotify-track p,
.boda-spotify-modal .boda-spotify-result p{
  color:rgba(21,63,44,.68)!important;
}
.boda-spotify-modal__close{
  background:#fff!important;
  color:var(--boda-green)!important;
  border:1px solid rgba(188,135,52,.30)!important;
  box-shadow:0 12px 28px rgba(21,63,44,.16)!important;
}
@media(max-width:900px){
  .boda-spotify-modal__dialog,
  .boda-spotify-modal__dialog--search{
    padding:clamp(14px,4vw,28px)!important;
  }
}
