/* Fonts loaded via WordPress enqueue (see plugin PHP) */

/* ── Base ── */
.id-wrap{
  font-family:'DM Sans',sans-serif;
  max-width:640px;margin:0 auto;
  color:#1A1208;
}

/* ══════════════════════════════════════════════════
   HEADER
══════════════════════════════════════════════════ */
.id-top{
  position:relative;
  overflow:hidden;
  min-height:360px;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:5rem 2rem 3.5rem;
  text-align:center;
  /* sin border-radius arriba — full bleed */
}
#id-three-canvas{
  position:absolute;inset:0;
  width:100%;height:100%;
  pointer-events:none;
}

/* badge de tipo */
.id-badge{
  display:inline-flex;align-items:center;gap:6px;
  position:relative;z-index:2;
  padding:5px 16px;
  border-radius:20px;border:1px solid;
  font-size:10px;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:1.4rem;
}

/* título */
.id-titulo{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,7vw,3rem);
  font-weight:300;
  color:#fff;
  line-height:1.1;
  margin:0 0 .5rem;
  position:relative;z-index:2;
  text-shadow:0 2px 30px rgba(0,0,0,.4);
}

/* divisor ornamental */
.id-rule-wrap{
  position:relative;z-index:2;
  display:flex;align-items:center;gap:10px;
  margin:.3rem auto .8rem;
  width:180px;
}
.id-rule-line{flex:1;height:1px;opacity:.5;}
.id-rule-diamond{
  width:6px;height:6px;
  transform:rotate(45deg);
  flex-shrink:0;opacity:.7;
}

.id-subtitulo{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;font-weight:300;
  font-size:1.05rem;color:rgba(255,255,255,.75);
  margin:0;position:relative;z-index:2;
}

/* ── CUENTA REGRESIVA ── */
.id-countdown{
  position:relative;z-index:2;
  margin-top:2rem;
  display:inline-flex;flex-direction:column;align-items:center;
  background:rgba(0,0,0,.25);
  border:1px solid rgba(255,255,255,.1);
  border-radius:18px;
  padding:.9rem 1.6rem 1rem;
  backdrop-filter:blur(8px);
}
.id-cd-lbl{
  font-size:9px;font-weight:500;
  text-transform:uppercase;letter-spacing:.18em;
  margin-bottom:.7rem;opacity:.6;color:#fff;
}
.id-cd-row{display:flex;gap:6px;}
.id-cd-box{
  display:flex;flex-direction:column;align-items:center;
  min-width:54px;
  background:rgba(255,255,255,.06);
  border-radius:10px;
  padding:.5rem .3rem .4rem;
}
.id-cd-n{
  font-family:'Cormorant Garamond',serif;
  font-size:1.9rem;font-weight:600;
  color:#fff;line-height:1;
  font-variant-numeric:tabular-nums;
}
.id-cd-u{
  font-size:9px;text-transform:uppercase;
  letter-spacing:.1em;margin-top:3px;
  opacity:.55;color:#fff;
}

/* ══════════════════════════════════════════════════
   BODY
══════════════════════════════════════════════════ */
.id-body{
  background:#fff;
  padding:0;
}

/* ── sección genérica ── */
.id-section{
  padding:1.75rem 1.75rem;
  border-bottom:1px solid #F0EDE6;
}
.id-section:last-child{border-bottom:none;}

/* ── Info rows ── */
.id-meta-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
  background:#F0EDE6;
  border:1px solid #F0EDE6;
  border-radius:14px;
  overflow:hidden;
  margin-bottom:1.5rem;
}
.id-meta-cell{
  background:#fff;
  padding:1rem 1.1rem;
  display:flex;flex-direction:column;gap:4px;
}
.id-meta-label{
  font-size:10px;font-weight:500;
  text-transform:uppercase;letter-spacing:.1em;
  color:#B8A888;
}
.id-meta-value{
  font-size:14px;font-weight:500;color:#1A1208;
  line-height:1.35;
}
.id-meta-cell.full{grid-column:1/-1;}

/* ── Enlace mapa ── */
.id-map-link{
  display:flex;align-items:center;justify-content:space-between;
  padding:13px 16px;
  background:#F8F6F1;
  border-radius:12px;
  border:1.5px solid;
  text-decoration:none;
  font-size:13px;font-weight:500;
  transition:.15s;
  margin-top:.75rem;
}
.id-map-link:hover{background:#F2EDE3;}
.id-map-link svg{opacity:.5;transition:.15s;}
.id-map-link:hover svg{opacity:1;transform:translateX(2px);}

/* ── Descripción ── */
.id-desc{
  font-size:14px;color:#6B6050;
  line-height:1.8;
}

/* ── Galería ── */
.id-galeria{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:3px;
  border-radius:14px;overflow:hidden;
}
.id-galeria.cols-1{grid-template-columns:1fr;}
.id-galeria.cols-2{grid-template-columns:1fr 1fr;}
.id-gal-item img{width:100%;aspect-ratio:1;object-fit:cover;display:block;}
.id-gal-item:first-child:nth-last-child(1){aspect-ratio:16/7;}

/* ══════════════════════════════════════════════════
   DRESS CODE — editorial
══════════════════════════════════════════════════ */
.id-dress-section{
  border-bottom:1px solid #F0EDE6;
}
.id-dress-editorial{
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-align:stretch;
  -ms-flex-align:stretch;
  align-items:stretch;
  min-height:88px;
}
.id-dress-label-col{
  padding:1.2rem 1.2rem 1.2rem 1.75rem;
  display:-webkit-box;display:-ms-flexbox;display:flex;
  -webkit-box-align:center;-ms-flex-align:center;align-items:center;
  -ms-flex-negative:0;flex-shrink:0;
}
.id-dress-label{
  font-size:9px;font-weight:500;
  text-transform:uppercase;letter-spacing:.14em;
  color:#B8A888;line-height:1.7;
  white-space:nowrap;
}
.id-dress-divider-v{
  width:1px;background:#EDE8DE;
  -ms-flex-negative:0;flex-shrink:0;
  margin:1rem 0;
}
.id-dress-main-col{
  padding:1.2rem 1.4rem;
  -webkit-box-flex:1;-ms-flex:1 1 auto;flex:1 1 auto;
  display:-webkit-box;display:-ms-flexbox;display:flex;
  -webkit-box-orient:vertical;-webkit-box-direction:normal;
  -ms-flex-direction:column;flex-direction:column;
  -webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;
  gap:4px;
  min-width:0;
}
.id-dress-name{
  font-family:'Cormorant Garamond',serif;
  font-size:1.55rem;font-weight:300;
  color:#1A1208;line-height:1.1;
  letter-spacing:-.01em;
}
.id-dress-detail{
  font-size:12px;color:#9A8870;
  line-height:1.55;font-style:italic;
  margin:0;
}
.id-dress-swatch-col{
  padding:1.2rem 1.75rem 1.2rem 1rem;
  -ms-flex-negative:0;flex-shrink:0;
  display:-webkit-box;display:-ms-flexbox;display:flex;
  -webkit-box-orient:vertical;-webkit-box-direction:normal;
  -ms-flex-direction:column;flex-direction:column;
  -webkit-box-align:center;-ms-flex-align:center;align-items:center;
  -webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;
  gap:6px;
}
.id-dress-swatch{
  width:32px;height:32px;
  border-radius:3px;
  -webkit-box-shadow:inset 0 0 0 1px rgba(0,0,0,.1);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.1);
}
.id-dress-swatch-hex{
  font-size:8px;font-weight:500;
  letter-spacing:.05em;text-transform:uppercase;
  color:#C0B090;
}

/* ══════════════════════════════════════════════════
   WISHLIST
══════════════════════════════════════════════════ */
.id-wishlist-header{
  display:flex;flex-direction:column;gap:3px;
  margin-bottom:1.25rem;
}
.id-wishlist-eyebrow{
  font-size:10px;font-weight:500;text-transform:uppercase;
  letter-spacing:.12em;color:#B8A888;
}
.id-wishlist-title{
  font-family:'Cormorant Garamond',serif;
  font-size:1.4rem;font-weight:400;color:#1A1208;
}
.id-wishlist-sub{font-size:13px;color:#9A8870;}

.id-wishlist-grid{
  display:flex;flex-direction:column;gap:10px;
  margin-bottom:.8rem;
}

/* ── Gift card — diseño horizontal tipo receipt ── */
.id-gift-card{
  display:flex;
  border-radius:14px;
  border:1px solid #EDE8DE;
  overflow:hidden;
  background:#fff;
  transition:box-shadow .2s,transform .2s;
  position:relative;
}
.id-gift-card:not(.is-reserved):hover{
  box-shadow:0 6px 24px rgba(0,0,0,.08);
  transform:translateY(-2px);
}
.id-gift-card.is-reserved{
  background:#FAFAF8;
}

/* imagen lateral */
.id-gift-img-wrap{
  width:96px;flex-shrink:0;
  background:#F5F3EE;
  position:relative;overflow:hidden;
}
.id-gift-img-wrap img{
  width:100%;height:100%;
  object-fit:cover;display:block;
  transition:transform .3s;
}
.id-gift-card:not(.is-reserved):hover .id-gift-img-wrap img{transform:scale(1.06);}
.id-gift-img-placeholder{
  width:100%;height:100%;min-height:90px;
  display:flex;align-items:center;justify-content:center;
  font-size:28px;color:#CCC;
}

/* badge de tienda en la imagen */
.id-store-badge{
  position:absolute;bottom:6px;left:6px;
  padding:2px 7px;border-radius:5px;
  font-size:10px;font-weight:700;
  color:#fff;letter-spacing:.02em;
  box-shadow:0 1px 4px rgba(0,0,0,.3);
  line-height:1.5;
}

/* contenido */
.id-gift-body{
  flex:1;padding:.85rem 1rem;
  display:flex;flex-direction:column;gap:3px;
  min-width:0;
}
.id-gift-store-name{
  font-size:10px;font-weight:600;
  text-transform:uppercase;letter-spacing:.08em;
}
.id-gift-name{
  font-size:14px;font-weight:500;color:#1A1208;
  line-height:1.3;
  /* clamp a 2 líneas */
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.id-gift-desc{
  font-size:12px;color:#9A8870;line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;
}
.id-gift-footer{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:auto;padding-top:.5rem;
  gap:8px;
}
.id-gift-price{font-size:13px;font-weight:500;color:#3A6A42;}
.id-gift-btn-buy{
  font-size:11px;font-weight:600;
  padding:5px 12px;border-radius:7px;
  color:#fff;text-decoration:none;
  white-space:nowrap;transition:.15s;
  display:inline-block;
}
.id-gift-btn-buy:hover{filter:brightness(1.1);}
.id-gift-btn-reserve{
  font-size:11px;font-weight:500;
  padding:5px 10px;border-radius:7px;
  border:1.5px solid;background:transparent;
  cursor:pointer;font-family:'DM Sans',sans-serif;
  white-space:nowrap;transition:.15s;
}
.id-gift-btn-reserve:hover{opacity:.7;}

/* estado reservado */
.id-gift-reserved-overlay{
  position:absolute;inset:0;
  background:rgba(255,255,255,.6);
  backdrop-filter:blur(2px);
  display:flex;align-items:center;justify-content:center;
  border-radius:14px;z-index:3;
}
.id-gift-reserved-overlay span{
  background:#E4F5E8;color:#2A6035;
  font-size:12px;font-weight:600;
  padding:6px 16px;border-radius:20px;
  border:1.5px solid #B0D8B0;
}
.id-gift-reserved-txt{
  font-size:11px;color:#2A6035;font-weight:500;
  padding-top:3px;
}
.id-wishlist-hint{
  font-size:11px;color:#C0B090;
  text-align:center;padding:.3rem 0;
}

/* ══════════════════════════════════════════════════
   RSVP
══════════════════════════════════════════════════ */
.id-rsvp{
  position:relative;overflow:hidden;
}
.id-rsvp-inner{
  position:relative;z-index:1;
}
.id-rsvp-eyebrow{
  font-size:10px;font-weight:500;letter-spacing:.12em;
  text-transform:uppercase;color:#B8A888;margin-bottom:5px;
}
.id-rsvp-titulo{
  font-family:'Cormorant Garamond',serif;
  font-size:1.55rem;font-weight:400;
  color:#1A1208;margin-bottom:.3rem;line-height:1.2;
}
.id-rsvp-sub{font-size:13px;color:#9A8870;margin-bottom:1.25rem;}

/* botones principales RSVP */
.id-rsvp-btns{display:flex;flex-direction:column;gap:8px;}
.id-btn-confirmar{
  width:100%;padding:14px;
  border-radius:12px;border:none;
  font-family:'Cormorant Garamond',serif;
  font-size:1.1rem;font-weight:600;
  color:#1A1208;cursor:pointer;
  letter-spacing:.02em;
  transition:.2s;
}
.id-btn-confirmar:hover{transform:translateY(-1px);filter:brightness(1.06);}
.id-btn-declinar{
  width:100%;padding:12px;
  border-radius:12px;
  background:transparent;
  border:1.5px solid #E0D8C8;
  font-family:'DM Sans',sans-serif;
  font-size:13px;font-weight:400;
  color:#9A8870;cursor:pointer;transition:.2s;
}
.id-btn-declinar:hover{background:#F8F5EE;color:#6B6050;}

/* formulario RSVP */
.id-rsvp-form{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid #EDE8DE;}
.id-field{margin-bottom:12px;}
.id-field label{
  display:block;font-size:11px;font-weight:500;
  color:#9A8870;text-transform:uppercase;letter-spacing:.08em;margin-bottom:5px;
}
.id-field input,.id-field select{
  width:100%;padding:11px 13px;
  border:1.5px solid #E0D8C8;border-radius:10px;
  font-family:'DM Sans',sans-serif;font-size:14px;
  color:#1A1208;background:#FDFBF8;outline:none;
  box-sizing:border-box;transition:.15s;
}
.id-field input:focus,.id-field select:focus{
  border-color:#C9A84C;background:#fff;
  box-shadow:0 0 0 3px rgba(201,168,76,.1);
}
.id-plus-row{display:flex;align-items:center;gap:12px;}
.id-plus-btn{
  width:32px;height:32px;border-radius:9px;
  border:1.5px solid #E0D8C8;background:transparent;
  font-size:18px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:#1A1208;transition:.15s;
}
.id-plus-btn:hover{background:#F0EBE0;border-color:#C9A84C;}
.id-plus-num{font-size:15px;font-weight:500;min-width:20px;text-align:center;}
.id-plus-max-txt{font-size:12px;color:#B8A888;}
.id-companion-inputs input{margin-bottom:6px;}

.id-form-btns{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap;}
.id-btn-submit{
  flex:1;padding:12px;
  border-radius:10px;border:none;
  font-family:'Cormorant Garamond',serif;
  font-size:1rem;font-weight:600;
  color:#1A1208;cursor:pointer;transition:.15s;
  letter-spacing:.02em;
}
.id-btn-submit:hover{filter:brightness(1.06);}
.id-btn-cancelar{
  padding:12px 16px;border-radius:10px;
  background:transparent;border:1.5px solid #E0D8C8;
  font-family:'DM Sans',sans-serif;font-size:13px;color:#9A8870;cursor:pointer;
}
.id-rsvp-success{
  background:#F0F8F1;border:1px solid #B8D8BC;border-radius:12px;
  padding:1.1rem;font-size:14px;color:#2A6035;text-align:center;line-height:1.6;
}

/* ── footer ── */
.id-footer{
  text-align:center;font-size:12px;color:#C0B090;
  letter-spacing:.05em;padding:.25rem 0 .5rem;
}

/* ══════════════════════════════════════════════════
   MODAL REGALO
══════════════════════════════════════════════════ */
.id-modal{
  position:fixed;inset:0;
  background:rgba(0,0,0,.55);backdrop-filter:blur(4px);
  display:flex;align-items:flex-end;justify-content:center;
  z-index:9999;
}
@media(min-width:500px){.id-modal{align-items:center;}}
.id-modal-box{
  background:#fff;
  border-radius:20px 20px 0 0;
  padding:1.5rem 1.5rem 2.5rem;
  width:100%;max-width:480px;
  animation:id-up .28s cubic-bezier(.4,0,.2,1);
}
@media(min-width:500px){.id-modal-box{border-radius:20px;padding:1.75rem;}}
@keyframes id-up{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}
.id-modal-handle{width:32px;height:3px;border-radius:2px;background:#E0D8C8;margin:0 auto .9rem;}
@media(min-width:500px){.id-modal-handle{display:none;}}
.id-modal-emoji{font-size:32px;text-align:center;margin-bottom:.4rem;}
.id-modal-titulo{
  font-family:'Cormorant Garamond',serif;font-size:1.2rem;
  text-align:center;margin-bottom:.2rem;color:#1A1208;
}
.id-modal-sub{font-size:12px;color:#9A8870;text-align:center;margin-bottom:1.1rem;}

/* ── Reveal ── */
.id-reveal{opacity:0;transform:translateY(14px);transition:opacity .45s ease,transform .45s ease;}
.id-reveal.visible{opacity:1;transform:none;}

/* ── Loading ── */
.id-loading{
  display:inline-block;width:13px;height:13px;
  border:2px solid rgba(255,255,255,.4);border-top-color:#fff;
  border-radius:50%;animation:id-spin .7s linear infinite;
  vertical-align:middle;margin-right:4px;
}
@keyframes id-spin{to{transform:rotate(360deg)}}

@media(max-width:480px){
  .id-top{padding:4.5rem 1.5rem 3rem;min-height:320px;}
  .id-titulo{font-size:2rem;}
  .id-section{padding:1.4rem 1.25rem;}
  .id-dress-visual{height:160px;}
}

/* ── Padrinos ── */
.id-padrinos-titulo{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:1.1rem;font-weight:400;
  text-transform:uppercase;letter-spacing:.14em;
  color:#B8A888;margin-bottom:.6rem;
}
.id-padrinos-rule{
  width:40px;height:1px;margin:.3rem auto .9rem;opacity:.5;
}
.id-padrinos-grid{
  display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;
}
.id-padrino-item{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  min-width:80px;max-width:140px;
}
.id-padrino-icon{
  width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:600;letter-spacing:.04em;
  flex-shrink:0;
}
.id-padrino-name{
  font-size:12px;color:#6B6050;line-height:1.4;
  text-align:center;font-family:'Cormorant Garamond',Georgia,serif;
  font-size:13px;
}

/* ── Lluvia de sobres ── */
.id-sobres-section{
  text-align:center;
}
.id-sobres-card{
  display:inline-flex;flex-direction:column;align-items:center;
  gap:.6rem;
  background:var(--id-sobres-bg,#FDFBF8);
  border:1.5px solid var(--id-sobres-border,#EDE8DE);
  border-radius:16px;
  padding:1.5rem 2rem;
  width:100%;
}
.id-sobres-icon{
  font-size:2rem;line-height:1;
}
.id-sobres-title{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:1.2rem;font-weight:400;color:#1A1208;
}
.id-sobres-sub{
  font-size:12px;color:#9A8870;line-height:1.6;
  max-width:280px;
}
.id-sobres-cuenta{
  margin-top:.3rem;
  background:#F5F2EC;
  border-radius:10px;
  padding:.7rem 1.2rem;
  width:100%;
}
.id-sobres-cuenta-label{
  font-size:9px;font-weight:600;text-transform:uppercase;
  letter-spacing:.12em;color:#B8A888;margin-bottom:4px;
}
.id-sobres-cuenta-num{
  font-size:1rem;font-weight:500;color:#1A1208;
  letter-spacing:.04em;font-family:'DM Sans',monospace;
}
.id-sobres-cuenta-banco{
  font-size:11px;color:#9A8870;margin-top:2px;
}
.id-sobres-copy-btn{
  margin-top:.5rem;
  padding:8px 20px;border-radius:20px;
  border:1.5px solid;background:transparent;
  font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;
  cursor:pointer;transition:.15s;
  display:inline-flex;align-items:center;gap:5px;
}
.id-sobres-copy-btn:hover{opacity:.75;}
