/* Generales */

@font-face {
  font-family: "GoodVibrations Script";
  src: url("fonts/GoodVibrations-Script.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --color-1: #728c76;
  --color-2: #9c82ad;
  --color-3: #bf6f84;
  --color-4: #f7f0ec;
  --color-5: #93a8ac;
  --color-pallete-4: #ffffff;

  /* Fuentes */
  --fuente-1: "Playfair Display", serif;
  --fuente-2: "Open Sans", sans-serif;
  --fuente-welcome-script: "GoodVibrations Script", "Good Vibration ROB Script", "Good Vibration", "Allura", cursive;

  --grosor-fuente-light: 300;
  --grosor-fuente-regular: 400;
  --grosor-fuente-bold: 700;

  --color-fondo-col-evento: var(--color-pallete-4);

  /* font-family: 'Open Sans', sans-serif; */
  /* font-family: 'Playfair Display', serif; */
}

/* Scroll */

::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

::-webkit-scrollbar-track {
  background: var(--color-4);
  border-radius: 10px;
}

::-webkit-scrollbar-thumb {
  border-radius: 10px;
  background: var(--color-3);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--color-2);
}

.custom-control-label::before {
  height: 20px;
  width: 20px;
}

.custom-control-label::after {
  height: 20px;
  width: 20px;
}

.custom-control-input:checked ~ .custom-control-label::before {
  color: var(--color-1);
  border-color: var(--color-1);
  background-color: var(--color-1);
  outline: none;
}

.custom-control-input:focus ~ .custom-control-label::before {
  box-shadow: none !important;
}

.addeventatc:hover {
  background: none;
}

.fancybox-bg {
  background-color: var(--color-3) !important;
}

.boton {
  background: var(--color-3);
  color: #fff;
  text-transform: capitalize;
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-regular);
  border-radius: 50px;
  line-height: 15px;
  font-size: 17px;
  padding: 18px 30px;

  -webkit-box-shadow: 0px 0px 5px -1px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 0px 5px -1px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 0px 5px -1px rgba(0, 0, 0, 0.4);

  -webkit-transition: all 0.5s 0s ease;
  -moz-transition: all 0.5s 0s ease;
  -o-transition: all 0.5s 0s ease;
  transition: all 0.5s 0s ease;
}

.boton:hover,
.boton:focus,
.boton:active {
  background: var(--color-3);
  text-decoration: none;
  color: #fff;
}

.boton:active {
  transform: translateY(2px) scale(0.985);
  -webkit-box-shadow: 0px 2px 4px -2px rgba(0, 0, 0, 0.35);
  -moz-box-shadow: 0px 2px 4px -2px rgba(0, 0, 0, 0.35);
  box-shadow: 0px 2px 4px -2px rgba(0, 0, 0, 0.35);
}

.title {
  width: 100%;
  display: inline-block;
  font-family: var(--fuente-1);
  font-weight: var(--grosor-fuente-regular);
  color: var(--color-1);
  font-size: 60px;
  line-height: 70px;
  margin-bottom: 0;
}

.subtitle {
  width: 100%;
  display: inline-block;
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-regular);
  color: var(--color-3);
  font-size: 20px;
}

ul {
  list-style: none;
  padding: 0;
}

a {
  -webkit-transition: all 0.5s 0s ease;
  -moz-transition: all 0.5s 0s ease;
  -o-transition: all 0.5s 0s ease;
  transition: all 0.5s 0s ease;
}

/* Fondo modales */
.modal-backdrop {
  background-color: var(--color-4);
  opacity: 1 !important;
}

.backdrop-modal-musica .modal-backdrop {
  background-color: #f8f5f2;
  opacity: 1 !important;
}

.modal-body {
  flex: inherit;
}

.modal.modal-transparent .modal-content {
  border: none;
  background-color: transparent;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  border-radius: 0;
  -webkit-box-shadow: none;
  box-shadow: none;
}

.modal.modal-transparent .close {
  color: var(--color-2);
  font-size: 40px;
  text-shadow: none;
  opacity: 1;
  position: absolute;
  right: 35px;
  outline: none;
  padding: 0;
}

.modal.modal-transparent .modal-header,
.modal .modal-transparent .modal-footer {
  border: none;
  padding: 0;
}

.modal.modal-transparent .modal-header h3 {
  color: var(--color-3);
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-regular);
  text-align: center;
  width: 100%;
}

.modal.modal-transparent .boton {
  padding: 15px 50px;
}

/* Cambio de idiomas / paises */

.flags-laguages {
  padding: 15px;
}

.flags-laguages li a {
  display: inline-block;
  width: 35px;
  height: 35px;
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
  border-radius: 20px;
  margin: 10px 8px;
  opacity: 0.75;
  border: 2px solid var(--color-4);
}

.flags-laguages li a:hover {
  opacity: 1;
}

.flags-laguages a.reset-lang {
  width: 100%;
  text-align: center;
  color: #fff;
  display: inline-block;
  font-size: 14px;
  margin-top: 30px;
}

.flags-laguages a.reset-lang:hover {
  text-decoration: underline;
}

.flags-laguages a.reset-lang img {
  width: 22px;
  height: auto;
  margin-right: 5px;
}

/* Loader */

.preloader-area {
  position: fixed;
  background: var(--color-4);
  z-index: 11000;
  height: 100%;
  width: 100%;
  overflow: hidden;
}

.preloader-area .loader {
  width: 130px;
}

#form-toast {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin: 14px 0 4px;
  padding: 14px 16px;
  border-radius: 12px;
  background-color: #fff8f5;
  border-left: 4px solid var(--color-3);
  text-align: left;
  animation: toastSlide 0.3s ease;
}

#form-toast.form-toast-confirm {
  border-left-color: var(--color-2);
  background-color: #fdf8f3;
}

.toast-actions {
  display: flex;
  gap: 8px;
  margin-top: 10px;
}

.toast-btn-si,
.toast-btn-no {
  border: none;
  border-radius: 20px;
  padding: 6px 16px;
  font-size: 12px;
  font-family: var(--fuente-2);
  cursor: pointer;
  transition: opacity 0.2s;
}

.toast-btn-si {
  background-color: var(--color-3);
  color: #fff;
}

.toast-btn-no {
  background-color: transparent;
  color: var(--color-2);
  border: 1px solid var(--color-2);
}

.toast-btn-si:hover,
.toast-btn-no:hover {
  opacity: 0.8;
}

#form-toast .toast-icon {
  font-size: 20px;
  flex-shrink: 0;
  line-height: 1.4;
}

#form-toast .toast-body {
  flex: 1;
}

#form-toast .toast-titulo {
  display: block;
  font-weight: 700;
  font-size: 13px;
  color: var(--color-1);
  font-family: var(--fuente-2);
  margin-bottom: 3px;
}

#form-toast .toast-msj {
  display: block;
  font-size: 12px;
  color: var(--color-2);
  font-family: var(--fuente-2);
  line-height: 1.5;
}

#form-toast .toast-nombre {
  font-weight: 700;
  color: var(--color-1);
}

#form-toast .toast-close {
  background: none;
  border: none;
  font-size: 16px;
  color: var(--color-2);
  cursor: pointer;
  flex-shrink: 0;
  padding: 0;
  line-height: 1;
  opacity: 0.6;
}

#form-toast .toast-close:hover {
  opacity: 1;
}

@keyframes toastSlide {
  from {
    opacity: 0;
    transform: translateY(-6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ---------- */

/* Portada */
section.portada {
  width: 100%;
  padding-bottom: 0;
  background-size: cover;
  color: #fff;
  position: relative;
}

section.portada .portada-picture {
  width: 55%;
  position: relative;
}

section.portada .portada-container {
  width: 45%;
  background: var(--color-4);
  padding-bottom: 60px;
  position: relative;
}

section.portada .portada-container .portada-container-2 {
  width: 100%;
  max-width: 610px;
  background: var(--color-4);
  padding-bottom: 60px;
  position: relative;
}

section.portada .portada-container .row.d-flex {
  height: 810px;
  margin: 0;
}

section.portada .portada-picture::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: rgba(29, 29, 27, 0.1);
  z-index: 0;
  top: 0;
  left: 0;
}

section.portada .portada-picture::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-image: url("../img/curva_portada_vertical.svg");
  background-repeat: no-repeat;
  background-position: top right;
  z-index: 0;
  top: 0;
  right: -2px;
}

section.portada::after {
  background-image: url("../img/img_ondas02.svg");
  position: absolute;
  content: "";
  background-repeat: no-repeat;
  background-position: bottom center;
  height: 100%;
  width: 100%;
  bottom: -10%;
  z-index: 9;
}

section.portada .container .row:first-child {
  height: 100vh;
}

section.portada .content-portada {
  width: 100%;
  z-index: 999;
  position: relative;
}

section.portada .adorno {
  position: absolute;
  height: auto;
}

section.portada .adorno-1 {
  position: absolute;
  width: 100%;
  height: auto;
  max-width: 400px;
  top: -50px;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
}

section.portada .adorno-2 {
  position: absolute;
  width: 300px;
  height: auto;
  top: -1px;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  z-index: 2;
}

section.portada .adorno-3 {
  position: absolute;
  width: 310px;
  height: auto;
  top: -10px;
  left: 0;
  right: 0;
  margin-left: auto;
  margin-right: auto;
  z-index: 2;
}

section.portada .box-nombres-fecha-portada {
  background: url("../img/ampersand.svg") center center no-repeat;
  background-size: 190px;
  background-position-y: 120px;
  padding-bottom: 20px;
}

section.portada .content-portada span.fecha {
  display: inline-block;
  white-space: nowrap;
  width: auto;
  font-family: var(--fuente-1);
  font-size: 29px;
  line-height: 25px;
  color: var(--color-3);
  padding: 5px 30px 10px;
  margin-bottom: 50px;
  margin-top: 40px;
  border: 2px solid;
  border-image-slice: 1;
  border-width: 1px;
  border-image-source: linear-gradient(
    to right,
    var(--color-4),
    var(--color-3),
    var(--color-4)
  );
}

section.portada .content-portada span.fecha:before {
  right: -25%;
}

section.portada .content-portada span.fecha:after {
  left: -25%;
}

section.portada .content-portada h1 + span:before,
section.portada .content-portada h1 + span:after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 30px;
  width: 80px;
  height: 1px;
}

section.portada .content-portada h1 + span:before {
  left: 65px;
  background: var(--color-3);
}

section.portada .content-portada h1 + span:after {
  right: 65px;
  background: var(--color-3);
}

section.portada .content-portada h1 {
  width: 100%;
  text-align: center;
  font-family: var(--fuente-1);
  text-transform: uppercase;
  font-weight: var(--grosor-fuente-regular);
  font-size: 80px;
  line-height: 85px;
  margin-bottom: 0;
  color: var(--color-1);
}

section.portada .box-nombres-fecha-portada h1:nth-of-type(2) {
  margin-top: -10px;
}

section.portada .box-nombres-fecha-portada h1 + span {
  background-color: #fff;
  position: relative;
  display: inline-block;
  border-radius: 50%;
  width: 60px;
  height: 60px;
  line-height: 60px;
  font-size: 50px;
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-light);
  color: var(--color-4);
}

section.portada .box-frase-portada {
  margin-top: 25px;
}

section.portada .box-frase-portada p {
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-regular);
  font-size: 22px;
  text-align: center;
  color: var(--color-2);
}

section.portada .box-frase-portada p img {
  width: 30px;
  margin: 10px 0;
}

/* Portada mockup */

section.portada {
  background: var(--color-4);
  color: #728c76;
  overflow: hidden;
}

section.portada > .d-md-flex {
  --flor-izquierda-ancho: 51.43%;
  --flor-izquierda-x: 0;
  --flor-izquierda-y: 222px;
  --pluma-derecha-ancho: 40%;
  --pluma-derecha-x: 0;
  --pluma-derecha-y: 200px;
  --portada-foto-alto: 650px;
  background: var(--color-4);
  display: block !important;
  margin: 0 auto;
  max-width: 760px;
  overflow: hidden;
  position: relative;
}

section.portada .portada-picture {
  background-image: url("../img/portada-nueva.webp");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  height: var(--portada-foto-alto);
  overflow: hidden;
  position: relative;
  width: 100%;
}

section.portada .portada-picture::before,
section.portada .portada-picture::after,
section.portada::after {
  display: none;
}

section.portada .portada-diseno-chatgpt {
  display: block;
  height: auto;
  margin-top: -174px;
  position: relative;
  width: 100%;
  z-index: 4;
}

section.portada .portada-flores,
section.portada .portada-flor-izquierda,
section.portada .portada-pluma-derecha {
  display: none;
}

section.portada .portada-flor-izquierda,
section.portada .portada-pluma-derecha {
  display: none;
  margin: 0;
  pointer-events: none;
  position: absolute;
  transform: translateY(-100%);
  z-index: 5;
}

section.portada .portada-flor-izquierda {
  left: var(--flor-izquierda-x);
  top: calc(var(--portada-foto-alto) + var(--flor-izquierda-y));
  width: var(--flor-izquierda-ancho);
}

section.portada .portada-pluma-derecha {
  right: var(--pluma-derecha-x);
  top: calc(var(--portada-foto-alto) + var(--pluma-derecha-y));
  width: var(--pluma-derecha-ancho);
}

section.portada .portada-flor-izquierda img,
section.portada .portada-pluma-derecha img {
  display: block;
  height: auto;
  width: 100%;
}

section.portada .portada-container {
  background: var(--color-4);
  display: none;
  padding: 150px 34px 86px;
  width: 100%;
}

section.portada .portada-container .portada-container-2 {
  background: transparent;
  max-width: 100%;
  padding-bottom: 0;
}

section.portada .portada-container-2 > picture {
  display: none;
}

section.portada .portada-container .row.d-flex {
  height: auto;
}

section.portada .box-nombres-fecha-portada {
  background: none;
  padding-bottom: 0;
}

section.portada .content-portada span.fecha {
  align-items: center;
  border: none;
  color: #728c76;
  display: inline-flex;
  font-family: "Cormorant Garamond", var(--fuente-1);
  font-size: 42px;
  font-weight: 500;
  gap: 18px;
  letter-spacing: 0.035em;
  line-height: 1;
  margin: 0 0 34px;
  padding: 0;
}

section.portada .content-portada span.fecha::before,
section.portada .content-portada span.fecha::after {
  background: rgba(114, 140, 118, 0.32);
  content: "";
  display: inline-block;
  height: 1px;
  position: static;
  width: 88px;
}

section.portada .content-portada h1 {
  color: #bf6f84;
  font-family: "Cormorant Garamond", var(--fuente-1);
  font-size: 86px;
  font-weight: 600;
  letter-spacing: 0.045em;
  line-height: 0.9;
}

section.portada .box-nombres-fecha-portada h1:nth-of-type(2) {
  margin-top: 0;
}

section.portada .box-nombres-fecha-portada h1 + span {
  background: transparent;
  border-radius: 0;
  color: #ead0da;
  display: inline-block;
  font-family: "Cormorant Garamond", var(--fuente-1);
  font-size: 78px;
  font-weight: 500;
  height: auto;
  line-height: 0.65;
  margin: 4px 0 8px;
  position: relative;
  width: auto;
}

section.portada .content-portada h1 + span::before,
section.portada .content-portada h1 + span::after {
  display: none;
}

section.portada .box-frase-portada {
  margin-top: 48px;
}

section.portada .box-frase-portada p {
  color: #9c82ad;
  font-family: var(--fuente-welcome-script);
  font-size: 54px;
  font-weight: 400;
  line-height: 1.12;
  margin-bottom: 0;
  white-space: nowrap;
}

ul.lang-inv {
  position: absolute;
  width: 100%;
  top: -25px;
}

ul.lang-inv li {
  margin: 0 5px;
}

ul.lang-inv li a {
  color: var(--color-4);
  background-color: var(--color-3);
  font-size: 14px;
  font-family: var(--fuente-2);
  font-weight: 400;
  display: inline-block;
  line-height: 30px;
  height: 30px;
  width: 30px;
  text-align: center;
  border-radius: 50%;
}

ul.lang-inv li a:hover {
  text-decoration: none;
  background: var(--color-2);
  color: var(--color-4);
}

/* ---------- */

/* Cuenta regresiva */
section.cuenta-regresiva {
  --contador-aro-size: 430px;
  --contador-aro-y: -200px;
  --contador-contenido-size: 315px;
  position: relative;
  height: 270px;
  padding-top: 70px;
  background-color: var(--color-4);
}

section.cuenta-regresiva .box-aros {
  width: var(--contador-aro-size);
  height: var(--contador-aro-size);
  background: url("../img/aro-contador-clean.png") center center no-repeat;
  background-size: contain;
  position: relative;
  z-index: 99;
  top: var(--contador-aro-y);
}

section.cuenta-regresiva .box-aros .box-circulo {
  width: var(--contador-contenido-size);
  height: var(--contador-contenido-size);
  padding: 20px;
}

section.cuenta-regresiva .box-aros .box-circulo span.falta {
  width: 100%;
  text-align: center;
  display: inline-block;
  font-family: var(--fuente-1);
  font-weight: var(--grosor-fuente-regular);
  color: var(--color-2);
  font-size: 50px;
  line-height: 60px;
  margin-top: 30px;
}

section.cuenta-regresiva .box-aros .box-circulo .corazon-falta {
  width: 18%;
  margin-top: 5px;
}

section.cuenta-regresiva .reloj-col {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  text-align: center;
  padding: 0 10px;
}

section.cuenta-regresiva .reloj-col.no-border {
  border: none;
}

section.cuenta-regresiva .reloj-col span.number {
  display: inline-block;
  width: 100%;
  color: var(--color-1);
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-bold);
  font-size: 40px;
}

section.cuenta-regresiva .reloj-col span.time {
  display: inline-block;
  width: 100%;
  color: var(--color-2);
  font-family: var(--fuente-1);
  font-weight: var(--grosor-fuente-regular);
  font-size: 20px;
}

section.cuenta-regresiva p.fin-cuenta {
  font-size: 30px;
  line-height: 35px;
  color: var(--color-3);
  font-family: var(--fuente-1);
  margin-top: 30px;
}

section.cuenta-regresiva .reloj {
  display: flex;
  width: 100%;
  max-width: 320px;
  margin: 10px auto 25px;
  align-items: stretch;
}
section.cuenta-regresiva .reloj-col span.number {
  white-space: nowrap;
}

section.cuenta-regresiva .reloj-col span.number {
  font-size: clamp(28px, 3vw, 40px);
}

/* Separadores bien hechos */
section.cuenta-regresiva .reloj-col:not(:last-of-type)::after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  height: 100%;
  width: 1px;
  background: var(--color-2);
}

/* Quitar separador al último */
section.cuenta-regresiva .reloj-col.no-border::after {
  display: none;
}

section.cuenta-regresiva .reloj-col span.number {
  text-align: center;
  font-variant-numeric: tabular-nums;
}

/* ---------- */

/* Ceremonia - Fiesta */

section.ceremonia-fiesta {
  padding-top: 17%;
  padding-bottom: 20%;
  position: relative;
  background: var(--color-4);
  z-index: 2;
}

section.ceremonia-fiesta .box-color-col {
  width: 95%;
  max-width: 900px;
  margin: 0 auto;
  background-color: var(--color-fondo-col-evento);
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
  border-radius: 20px;
  padding: 35px 0;
  border: 1px solid var(--color-bordes-marcos);
  -webkit-box-shadow: 0px 0px 15px 0px;
  box-shadow: 0px 0px 15px 0px #444;
  position: relative;
  z-index: 1;
}

section.ceremonia-fiesta .row {
  justify-content: center;
}

section.ceremonia-fiesta .adorno {
  display: none;
}

section.ceremonia-fiesta .adorno-1 {
  position: absolute;
  width: 180px;
  top: 230px;
  left: -2px;
  position: absolute;
  z-index: 10;
}

section.ceremonia-fiesta .adorno-2 {
  position: absolute;
  width: 195px;
  top: 250px;
  left: -1px;
  z-index: 10;
}

section.ceremonia-fiesta .adorno-3 {
  position: absolute;
  width: 190px;
  top: 250px;
  left: -2px;
  z-index: 10;
}

section.ceremonia-fiesta .col-ceremonia,
section.ceremonia-fiesta .col-fiesta {
  z-index: auto;
}

section.ceremonia-fiesta .col-ceremonia .anim-anillos,
section.ceremonia-fiesta .anim-fiesta {
  width: 160px;
  height: 160px;
  margin: 0 auto 20px;
}

section.ceremonia-fiesta .col-ceremonia .anim-anillos,
section.ceremonia-fiesta .anim-fiesta {
  width: 175px;
  height: 175px;
  margin: 0 auto 20px;
  padding: 20px;
  background-color: white;
  border-radius: 50%;
  -webkit-box-shadow: 0px 0px 15px -1px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 0px 15px -1px rgba(0, 0, 0, 0.4);
  box-shadow: 0px 0px 15px -1px rgba(0, 0, 0, 0.4);
}

section.ceremonia-fiesta .col-fiesta .anim-fiesta {
  padding: 30px;
}

section.ceremonia-fiesta .col-ceremonia .anim-anillos {
  padding: 20px;
}

section.ceremonia-fiesta .col-ceremonia h3,
section.ceremonia-fiesta .col-fiesta h3 {
  font-family: var(--fuente-1);
  color: #8c4660;
  font-size: clamp(20px, 4vw, 40px);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  min-width: 60%;
  padding: 10px 34px;
  background-color: #ebd2dc;
  line-height: 1.2;
  text-align: center;
}

section.ceremonia-fiesta .col-ceremonia h3:before,
section.ceremonia-fiesta .col-fiesta h3:before {
  background: #ebd2dc;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%, 32% 50%);
  position: absolute;
  content: "";
  height: 100%;
  width: 28px;
  left: -20px;
  top: 0;
}

section.ceremonia-fiesta .col-ceremonia h3:after,
section.ceremonia-fiesta .col-fiesta h3:after {
  background: #ebd2dc;
  clip-path: polygon(0 0, 100% 0, 68% 50%, 100% 100%, 0 100%);
  position: absolute;
  content: "";
  height: 100%;
  width: 28px;
  right: -20px;
  top: 0;
}

section.ceremonia-fiesta .info-col {
  margin-top: 30px;
}

section.ceremonia-fiesta .info-col .info-box {
  margin-bottom: 55px;
}

section.ceremonia-fiesta .info-col .info-box h6 {
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-bold);
  color: var(--color-1);
  font-size: 25px;
}

section.ceremonia-fiesta .info-col .info-box p {
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-regular);
  color: var(--color-2);
  font-size: 20px;
}

section.ceremonia-fiesta .info-col .info-box a.boton {
  margin-top: 5px;
  display: inline-block;
  width: 50%;
}

section.ceremonia-fiesta:after {
  display: none;
}

section.ceremonia-fiesta .ondas-2 {
  position: absolute;
  top: 3%;
}

section.ceremonia-fiesta .addeventatc .nameBtn {
  color: #fff;
}

section.ceremonia-fiesta .addeventatc:hover .nameBtn {
  color: #fff;
}

/* ---------- */

/* Galeria */

.separador-galeria {
  --separador-flor-top: 0px;
  --separador-flor-width: min(86%, 680px);
  background: transparent;
  height: 0;
  line-height: 0;
  margin-bottom: 0;
  margin-top: 0;
  overflow: visible;
  pointer-events: none;
  position: relative;
  text-align: center;
  z-index: 20;
}

.separador-galeria img {
  display: block;
  left: 50%;
  margin: 0;
  max-width: 100%;
  pointer-events: none;
  position: absolute;
  top: var(--separador-flor-top);
  transform: translateX(-50%);
  width: var(--separador-flor-width);
  z-index: 20;
}

section.galeria {
  padding-top: 50px;
  padding-bottom: 50px;
  position: relative;
  background-color: var(--color-4);
  z-index: 1;
}

section.galeria .title {
  color: #d9aebb;
}

section.galeria .subtitle {
  color: #728c76;
}

section.galeria .anim-galeria {
  width: 70px;
  margin: 0 auto;
}

section.galeria .content-fotos {
  margin-top: 40px;
  overflow: hidden;
  position: relative;
}

section.galeria .carrusel {
  margin: 0 auto;
  max-width: 430px;
}

section.galeria .carrusel,
section.galeria .slick-list {
  overflow: hidden;
}

section.galeria .content-fotos img {
  display: block;
  height: auto;
  max-height: 100%;
  object-fit: contain;
  width: 100%;
}

section.galeria .content-fotos .polaroid a {
  align-items: center;
  aspect-ratio: 2 / 3;
  display: flex;
  justify-content: center;
  outline: none;
}

section.galeria .content-fotos .polaroid-double .galeria-double {
  aspect-ratio: 2 / 3;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow: hidden;
}

section.galeria .content-fotos .polaroid-double a {
  aspect-ratio: auto;
  display: block;
  flex: 1;
  min-height: 0;
}

section.galeria .content-fotos .polaroid-double img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

section.galeria .content-fotos .polaroid {
  padding: 15px;
  padding-bottom: 15px;
  margin: 5px;
  background-color: #fff;
  -webkit-box-shadow: 0px 0px 5px -1px rgba(0, 0, 0, 0.4);
  -moz-box-shadow: 0px 0px 5px -1px rgba(0, 0, 0, 0.432);
  box-shadow: 0px 0px 5px -1px rgba(0, 0, 0, 0.4);

  -webkit-transition: all 0.5s 0s ease;
  -moz-transition: all 0.5s 0s ease;
  -o-transition: all 0.5s 0s ease;
  transition: all 0.5s 0s ease;
}

section.galeria .slick-slide:focus {
  outline: none !important;
}

section.galeria .slick-center .polaroid {
  background-color: var(--color-1) !important;
}

.content-fotos .shadow-left {
  display: none;
}

.content-fotos .shadow-right {
  display: none;
}

.slick-dots {
  bottom: -30px;
}

section.galeria .slick-dots li button:before {
  font-size: 15px !important;
  color: var(--color-1) !important;
  opacity: 0.6;
}

section.galeria .slick-dots li.slick-active button:before {
  color: var(--color-1) !important;
  opacity: 1;
}

section.galeria .slick-dots {
  display: flex !important;
  justify-content: center;
  align-items: center;
  left: 0;
  width: 100%;
  padding: 0;
  margin: 0;
}

section.galeria .slick-dots li {
  float: none !important;
}

/* ---------- */

/* Fiesta */

section.fiesta {
  background: var(--color-4);
  padding-top: 55px;
  position: relative;
  padding-bottom: 17%;
}

section.fiesta .fiesta-flor-izq {
  position: absolute;
  top: 20%;
  left: 0;
  max-width: 12%;
}

section.fiesta .container {
  z-index: 999;
  position: relative;
}

section.fiesta .title {
  color: #d9aebb;
}

section.fiesta .subtitle {
  color: var(--color-1);
}

section.fiesta .anim-musica {
  width: 75px;
  margin: 15px auto 40px auto;
}

section.fiesta .anim-vestuario {
  width: 95px;
}

section.fiesta .anim-tips {
  width: 55px;
}

section.fiesta:after {
  content: "";
  background-image: url("../img/separacion-flores.png");
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: min(86%, 680px) auto;
  bottom: -130px;
  height: 230px;
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: 99;
}

section.fiesta .item-fiesta {
  margin-top: 60px;
  padding: 0 40px;
  position: relative;
  z-index: 2;
}

section.fiesta .item-fiesta h3 {
  color: var(--color-1);
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-bold);
  text-transform: uppercase;
  font-size: 22px;
}

section.fiesta .item-fiesta p {
  color: var(--color-1);
  margin-bottom: 0;
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-light);
}

section.fiesta .item-fiesta a.boton {
  width: 85%;
}

section.fiesta .item-fiesta .content-item-fiesta {
  background-color: #fff;
  padding: 40px 25px;
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
  border-radius: 20px;
  min-height: 400px;
  -webkit-box-shadow: 0px 0px 15px 0px;
  box-shadow: 0px 0px 15px 0px #444;
}

section.fiesta .box-color-col {
  margin: 0 auto;
  min-height: 385px;
  padding: 30px 10px;
  background-color: var(--color-fondo-item-fiesta);
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
  border-radius: 20px;
}

section.fiesta .content-anim-fiesta {
  height: 80px;
}

section.fiesta .item-fiesta .adorno {
  position: absolute;
  height: auto;
}

section.fiesta .item-fiesta .adorno.adorno-1 {
  position: absolute;
  top: -96px;
  left: -12px;
  z-index: 0;
  width: 175px;
}

section.fiesta .item-fiesta .adorno.adorno-2 {
  position: absolute;
  top: -70px;
  left: -30px;
  z-index: 3;
  width: 160px;
}

/* ---------- */

/* Regalos */

section.regalos {
  padding-top: 14%;
  position: relative;
  padding-bottom: 10%;
  background-color: var(--color-4);
}

section.regalos .adorno {
  display: none;
}

section.regalos .adorno-1 {
  position: absolute;
  width: 180px;
  top: 230px;
  left: -2px;
}

section.regalos .adorno-2 {
  position: absolute;
  width: 195px;
  top: 250px;
  left: -1px;
  z-index: 1;
}

section.regalos .adorno-3 {
  position: absolute;
  width: 190px;
  top: 250px;
  left: -2px;
  z-index: 1;
}

section.regalos .title {
  color: #d9aebb;
  margin-bottom: 10px;
}

section.regalos .subtitle {
  color: var(--color-1);
}

section.regalos .anim-regalos {
  width: 70px;
  margin: 1px auto 40px;
}

/* ---------- */

/* Instagram */

section.instagram {
  padding-top: 16%;
  padding-bottom: 16%;
  /* background: url('../img/portada.jpg') center center; */
  position: relative;
}

section.instagram {
  padding-top: 16%;
  padding-bottom: 16%;
  /* background: url('../img/portada.jpg') center center; */
  position: relative;
}

section.instagram .container {
  position: relative;
  z-index: 999;
}

section.instagram:before {
  background-image: url("../img/img_ondas05.svg");
  background-color: rgba(214, 113, 146, 0.35);
  position: absolute;
  content: "";
  background-repeat: no-repeat;
  background-position: top center;
  height: 100%;
  width: 100%;
  top: -1px;
  left: 0;
  z-index: 1;
  pointer-events: none;
}

section.instagram .title {
  color: #fff;
  -webkit-background-clip: text;
  -webkit-text-fill-color: #fff;
  text-shadow: 0 3px 16px rgba(29, 29, 27, 0.48);
  font-size: 28px;
  line-height: 34px;
}

section.instagram .subtitle {
  color: #fff;
  text-shadow: 0 2px 12px rgba(29, 29, 27, 0.5);
}

section.instagram .boton {
  text-transform: none;
}

section.instagram .hashtag {
  color: #1d1d1b;
  text-transform: lowercase;
  font-size: 55px;
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-bold);
  margin-bottom: 40px;
  display: inline-block;
}

section.instagram .anim-instagram {
  width: 60px;
  margin: 0 auto 15px;
}

section.instagram .celebriam-logo-anim {
  animation: celebriam-logo-float 2.8s ease-in-out infinite;
  display: block;
  filter: drop-shadow(0 8px 18px rgba(29, 29, 27, 0.38));
  height: auto;
  margin: 8px auto 28px;
  max-width: 110px;
  width: 25vw;
}

@keyframes celebriam-logo-float {
  0%,
  100% {
    filter: drop-shadow(0 8px 18px rgba(29, 29, 27, 0.34));
    transform: translateY(0) scale(1);
  }

  50% {
    filter: drop-shadow(0 14px 24px rgba(29, 29, 27, 0.44));
    transform: translateY(-8px) scale(1.04);
  }
}

section.instagram:after {
  background-image: url("../img/img_ondas06.svg");
  position: absolute;
  content: "";
  /* background-size: contain !important; */
  background-repeat: no-repeat;
  background-position: bottom center;
  height: 100%;
  width: 100%;
  bottom: -70px;
  z-index: 99;
}

/* ---------- */

/* Footer */

section.footer {
  position: relative;
  padding-bottom: 10%;
  padding-top: 6%;
  margin-top: -2px;
  background-color: var(--color-4);
}

section.footer .col-nombres-footer {
  background: none;
}

section.footer .logo-boda-footer {
  display: block;
  height: auto;
  margin: 0 auto;
  max-width: 430px;
  width: min(88vw, 430px);
}

section.footer .col-acciones-footer ul {
  font-family: var(--fuente-2);
  font-weight: 400;
  margin-top: 40px;
  text-align: center;
}

section.footer .col-acciones-footer ul li {
  margin-bottom: 20px;
  text-align: center;
}

section.footer .col-acciones-footer ul a,
section.footer .addeventatc span.nameBtn {
  color: var(--color-3);
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-regular);
  font-size: 20px;

  -webkit-transition: all 0.5s 0s ease;
  -moz-transition: all 0.5s 0s ease;
  -o-transition: all 0.5s 0s ease;
  transition: all 0.5s 0s ease;
}

section.footer .col-acciones-footer ul a:hover,
section.footer .addeventatc span.nameBtn:hover {
  color: var(--color-2) !important;
  background: none;
  text-decoration: none;
}

/* ---------- */

/* Musica de fondo */

#player-musica-fondo {
  position: absolute;
  left: -99999px;
}

#controlador-musica {
  position: fixed;
  z-index: 999;
  top: 10px;
  right: 0;
}

.music-anim-icon {
  width: 100px;
  height: 100px;
  cursor: pointer;
}

/* ---------- */

/* Footer */

footer {
  background-color: var(--color-2);
  font-family: var(--fuente-2);
  font-weight: 400;
  padding: 20px 0;
}

/* ---------- */

/* Firma */

footer p {
  width: 100%;
  text-align: center;
  font-size: 14px;
  margin-top: 1rem;
  color: #fff;
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-light);
}

footer p a {
  color: #fff;
  font-size: 14px;
  display: inline-flex;
  -webkit-transition: all 0.5s 0s ease;
  -moz-transition: all 0.5s 0s ease;
  -o-transition: all 0.5s 0s ease;
  transition: all 0.5s 0s ease;
}

footer p a:hover {
  text-decoration: underline;
  color: var(--color-4);
}

footer img.firma-footer {
  width: 65px;
  height: auto;
}

/* ---------- */

.modal-dialog {
  font-family: var(--fuente-2);
}

.modal-dialog .modal-title {
  font-weight: 700;
  color: var(--color-4);
}

.modal-dialog form label {
  color: var(--color-2);
  font-family: var(--fuente-2);
}

.modal-dialog .white-circle-icon {
  width: 150px;
  height: auto;
  margin: 0 auto;
  position: relative;
  top: -75px;
}

.modal-dialog ::placeholder {
  /* Chrome, Firefox, Opera, Safari 10.1+ */
  color: var(--color-2);
  opacity: 1;
  font-family: var(--fuente-2);
  /* Firefox */
}

.modal-dialog :-ms-input-placeholder {
  /* Internet Explorer 10-11 */
  color: var(--color-2);
  font-family: var(--fuente-2);
}

.modal-dialog ::-ms-input-placeholder {
  /* Microsoft Edge */
  color: var(--color-2);
  font-family: var(--fuente-2);
}

/* Modal Musica */

#modalMusica .modal-content {
  background: transparent;
  border: none;
  font-family: "Cormorant Garamond", var(--fuente-1);
  font-weight: var(--weight-font-regular);
  border-radius: none;
  -webkit-box-shadow: none;
  box-shadow: none;
}

#modalMusica .modal-body {
  padding: 0 15px;
}

#modalMusica .modal-content p {
  text-align: center;
  font-family: "Cormorant Garamond", var(--fuente-1);
  text-transform: uppercase;
  font-weight: 600;
  font-size: 86px;
  line-height: 76px;
  letter-spacing: 0.055em;
  color: #728c76;
  display: inline-block;
  width: 100%;
  position: relative;
  margin-bottom: 0;
  background: none;
  isolation: isolate;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.35);
}

#modalMusica .modal-content p::before {
  content: "&";
  position: absolute;
  left: 50%;
  top: 62%;
  z-index: -1;
  color: #ead0da;
  font-family: "Cormorant Garamond", var(--fuente-1);
  font-size: 205px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0;
  opacity: 0.72;
  text-transform: none;
  transform: translate(-50%, -50%);
}

#modalMusica .modal-content p span {
  display: inline-block;
  font-size: 44px;
  line-height: 44px;
  font-family: var(--fuente-welcome-script);
  color: #9c82ad;
  text-transform: initial;
  letter-spacing: 0;
  font-weight: 400;
  max-width: 100%;
  white-space: nowrap;
  width: 100%;
}

#modalMusica .modal-content span.aclara-musica {
  font-size: 36px;
  line-height: 40px;
  color: #9c82ad;
  margin-top: -6px;
  margin-bottom: 4px;
  display: inline-block;
  max-width: 100%;
  font-family: var(--fuente-welcome-script);
  font-weight: 400;
  white-space: nowrap;
  width: 100%;
}

#modalMusica .adorno-musica {
  align-items: center;
  color: #9c82ad;
  display: flex;
  gap: 12px;
  justify-content: center;
  margin: 0 auto 10px;
  max-width: 360px;
  opacity: 0.72;
  width: 48%;
}

#modalMusica .adorno-musica span {
  align-items: center;
  display: flex;
  flex: 1;
  gap: 10px;
}

#modalMusica .adorno-musica span::before {
  content: "∞";
  font-family: "Cormorant Garamond", var(--fuente-1);
  font-size: 27px;
  line-height: 1;
}

#modalMusica .adorno-musica span::after {
  background: currentColor;
  content: "";
  flex: 1;
  height: 1px;
}

#modalMusica .adorno-musica span:last-child {
  flex-direction: row-reverse;
}

#modalMusica .adorno-musica i {
  color: #9c82ad;
  font-size: 20px;
  font-style: normal;
  line-height: 1;
}

#modalMusica .boton {
  background: #bf6f84;
  border: 1px solid rgba(191, 111, 132, 0.25);
  border-radius: 28px;
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "Montserrat", var(--fuente-2);
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 32px;
  margin: 0 18px;
  min-height: 118px;
  min-width: 0;
  padding: 24px 28px;
  position: relative;
  text-align: center;
  text-transform: uppercase;
  vertical-align: top;
  width: calc(50% - 40px);
  -webkit-box-shadow: 0 14px 18px -12px rgba(80, 42, 55, 0.35);
  -moz-box-shadow: 0 14px 18px -12px rgba(80, 42, 55, 0.35);
  box-shadow: 0 14px 18px -12px rgba(80, 42, 55, 0.35);
}

#modalMusica .boton::before,
#modalMusica .boton::after {
  display: none;
}

#modalMusica .boton:hover,
#modalMusica .boton:focus,
#modalMusica .boton:active {
  background-color: #bf6f84;
  border-color: rgba(191, 111, 132, 0.25);
  color: #ffffff;
  text-decoration: none;
}

#modalMusica .boton:active {
  transform: translateY(2px) scale(0.985);
  -webkit-box-shadow: 0 8px 12px -10px rgba(80, 42, 55, 0.35);
  -moz-box-shadow: 0 8px 12px -10px rgba(80, 42, 55, 0.35);
  box-shadow: 0 8px 12px -10px rgba(80, 42, 55, 0.35);
}

#modalMusica .adorno {
  display: block;
  width: 100%;
  max-width: 770px;
  height: auto;
  margin-left: auto;
  margin-right: auto;
}

#modalMusica .adorno.adorno-1 {
  box-shadow: inset 0 -2px 0 #9c82ad;
}

#modalMusica .adorno.adorno-2 {
  box-shadow: inset 0 2px 0 #9c82ad;
  margin-top: 38px;
}

/* Modales */

.modal .modal-content {
  text-align: center;
  border: none;
  padding: 10px;
  color: #fff;
  -webkit-border-radius: 40px;
  -moz-border-radius: 40px;
  border-radius: 40px;
  -webkit-box-shadow: 0px 0px 15px 0px #444;
  box-shadow: 0px 0px 15px 0px #444;
}

.modal .modal-content-2.box-color-col {
  background-color: var(--color-fondo-col-modal);
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
  border-radius: 20px;
  padding: 30px 20px;
}

.modal .modal-content-2 {
  position: relative;
  isolation: isolate;
  border: double 2px transparent;
  background-image:
    linear-gradient(var(--color-1), var(--color-1)),
    radial-gradient(
      circle at bottom left,
      var(--color-6),
      var(--color-7),
      var(--color-8)
    );
  background-origin: border-box;
  background-clip: content-box, border-box;
  -webkit-border-radius: 40px;
  -moz-border-radius: 40px;
  border-radius: 40px;
}

.modal .modal-content-2 p {
  color: var(--color-1);
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-regular);
}

.modal .modal-content-2 .img-top-modal {
  position: relative;
  height: 70px;
  z-index: 2;
}

.modal .modal-content-2 .close {
  position: absolute;
  top: -15px;
  right: 0;
  z-index: 3;
  color: #fff;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  line-height: 37px;
  background-color: var(--color-2);
  opacity: 1;
  outline: none;
  font-size: 34px;
  font-weight: normal;
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-regular);

  -webkit-box-shadow: 0px 0px 5px -1px rgba(0, 0, 0, 0.5);
  -moz-box-shadow: 0px 0px 5px -1px rgba(0, 0, 0, 0.5);
  box-shadow: 0px 0px 5px -1px rgba(0, 0, 0, 0.5);

  -webkit-transition: all 0.5s 0s ease;
  -moz-transition: all 0.5s 0s ease;
  -o-transition: all 0.5s 0s ease;
  transition: all 0.5s 0s ease;
}

.modal .modal-content-2 .close:hover {
  background-color: var(--color-1);
  opacity: 1;
}

.modal .modal-content-2 .close span {
  display: inline-block;
  width: 100%;
  height: 100%;
}

.modal .modal-content-2 .modal-header {
  border: none;
  display: inline-block;
  padding: 0;
  position: relative;
  z-index: 2;
}

.modal .modal-content-2 .modal-header .modal-title {
  font-size: 35px;
  font-family: var(--fuente-1);
  color: var(--color-3);
}

.modal .modal-content-2 .modal-footer {
  border: none;
  display: inline-block;
  padding: 0;
  position: relative;
  z-index: 2;
}

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

.modal .modal-content-2 .boton {
  outline: none;
  border: none;
  margin-bottom: 25px;
  margin-top: 25px;
  display: inline-block;
}

.modal .modal-content-2 .img-top-modal img {
  width: 100%;
  margin-top: 0;
}

.modal .modal-content-2 .adorno {
  position: absolute;
  height: auto;
  pointer-events: none;
}

.modal .modal-content-2 .adorno-1 {
  position: absolute;
  width: 116%;
  max-width: 540px;
  top: -128px;
  left: 50%;
  margin-left: 0;
  margin-right: 0;
  transform: translateX(-50%);
  z-index: 1;
}

#modalMapa .modal-content-2 .adorno-1 {
  top: -128px;
}

#modalMapa .modal-dialog {
  margin-top: 34px;
}

#modalMapa .modal-content-2 .img-top-modal {
  height: 108px;
}

#modalMapa .modal-dialog .white-circle-icon {
  width: 150px;
  top: -75px;
}

#modalMapa .modal-content-2 .modal-header {
  margin-bottom: 12px;
}

#modalMapa .modal-body {
  padding-bottom: 0;
  padding-top: 8px;
}

#modalMapa iframe {
  height: min(420px, 48vh);
}

/* Modal Confirmar asistencia*/

#modalAsistencia input,
#modalAsistencia textarea,
#modalTips input,
#modalTips textarea {
  text-align: center;
  background: none;
  resize: none;
  outline: none;
  padding-bottom: 5px;
}

#modalAsistencia input:focus,
#modalAsistencia textarea:focus,
#modalTips input:focus,
#modalTips textarea:focus {
  border: none;
  box-shadow: none;
}

#formAsistencia {
  width: 82%;
  margin: 0 auto;
}

#formAsistencia .form-group .form-check {
  float: left;
  margin-bottom: 10px;
  margin-top: 10px;
  font-size: 18px;
}

#formAsistencia .form-group .form-check label {
  cursor: pointer;
  padding-left: 5px;
}

#modalAsistencia .form-control {
  font-size: 15px;
}

.aviso-alergias {
  color: var(--color-1);
  font-family: var(--fuente-2);
  font-size: 14px;
  line-height: 1.5;
  margin: 8px auto 0;
  text-align: center;
  width: 90%;
}

#modalAsistencia {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

#modalAsistencia::-webkit-scrollbar {
  display: none;
}

#formAlergias {
  width: 82%;
  margin: 0 auto;
}

#modalTips .form-control {
  font-size: 15px;
}

/* Modal Sugerir cancion */

#modalSugerirCancion input {
  text-align: center;
  background: none;
  resize: none;
  outline: none;
  padding-bottom: 5px;
}

#modalSugerirCancion input:focus {
  border: none;
  box-shadow: none;
}

#modalSugerirCancion .form-control {
  font-size: 15px;
}

/* ---------- */

/* Modal Vestuario */

/* ---------- */

/* Modal Tips */

/* ---------- */

/* Modal Regalos */

.iban-box {
  text-align: center;
}

.iban-numero {
  background: transparent;
  border: 1px solid rgba(156, 130, 173, 0.35);
  border-radius: 8px;
  color: var(--color-1);
  display: block;
  font-family: var(--fuente-2);
  font-size: 15px;
  font-weight: var(--grosor-fuente-bold);
  letter-spacing: 0.02em;
  line-height: 1.5;
  margin: 0 auto 22px;
  max-width: 100%;
  padding: 10px 12px;
  text-align: center;
  width: 90%;
}

.iban-numero:focus {
  border-color: var(--color-2);
  outline: none;
}

.iban-copiado {
  color: var(--color-2);
  font-size: 14px;
  margin: 14px 0 0;
  min-height: 22px;
}

/* ---------- */

/* ---------- */

/* Modal de mensaje exito */

.modal-body.fix-height {
  height: 70%;
  margin-top: -35px;
}

.modal-body.fix-height .msj-content {
  height: 100%;
}

.modal .msj-content {
  width: 100%;
}

.modal .msj-content h5 {
  text-align: center;
  width: 100%;
  display: inline-block;
  font-weight: 700;
  color: var(--color-1);
}

.modal .msj-content p {
  text-align: center;
  width: 100%;
  display: inline-block;
  color: var(--color-1);
}

/* ---------- */

#googleMap,
#googleMapIframe {
  height: 450px;
  width: 100%;
  border: 0;
}

/* Loader del mapa */
.map-loader {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.3s ease;
}

.map-loader.hidden {
  opacity: 0;
  pointer-events: none;
}

.map-spinner {
  width: 40px;
  height: 40px;
  border: 3px solid rgba(198, 215, 207, 0.2);
  border-top-color: #ddd;
  border-radius: 50%;
  animation: spinner-rotate 0.8s linear infinite;
}

@keyframes spinner-rotate {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

#modalMapa .modal-body {
  position: relative;
  min-height: 0;
}

/* Banner para redirigir a la web */
.banner-contacto-web {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  height: auto;
  background: var(--color-1);
  z-index: 9999;
  padding: 0;
  margin: 0;
}

.banner-contacto-web p {
  width: 100%;
  text-align: center;
  color: #fff;
  margin: 0;
  padding: 8px 8px;
  font-family: var(--fuente-2);
  font-weight: var(--grosor-fuente-regular);
  font-size: 13px;
}

.banner-contacto-web a {
  color: #fff;
}

.banner-contacto-web a:first-child {
  background: #fff;
  color: var(--color-1);
  border-radius: 10px;
  padding: 3px 10px;
}

.banner-contacto-web a:first-child:hover {
  text-decoration: none;
  color: #fff;
  background-color: var(--color-2);
}

.fila-invitado {
  display: grid;
  grid-template-columns: calc(100% - 75px) 60px;
  gap: 15px;
  align-items: center;
  width: 100%;
}

.fila-invitado .select-nombre {
  width: 100%;
  min-width: 0;
}

.fila-invitado input {
  flex: 2;
}

.check-asistencia {
  display: flex;
  gap: 15px;
  align-items: center;
  white-space: nowrap;
}

.check-asistencia label {
  margin: 0;
  font-size: 14px;
  color: var(--color-2);
}

.select-tipo {
  flex: 1;
  min-width: 110px;
}

.btn-eliminar {
  width: 42px;
  height: 42px;
  border: none;
  border-radius: 50%;
  background: var(--color-3);
  color: white;
  font-size: 20px;
  cursor: pointer;
  flex-shrink: 0;
}

.btn-eliminar:hover {
  opacity: 0.9;
}

.boton-secundario {
  background: transparent;
  color: var(--color-2);
  border: 1px solid var(--color-2);
}

.boton-secundario:hover,
.boton-secundario:focus,
.boton-secundario:active {
  background: transparent;
  color: var(--color-2);
}

.boton-secundario:active {
  transform: translateY(2px) scale(0.985);
}

.modal-asistencia-fijo {
  margin: 170px auto 30px auto;
}

.bloque-invitado {
  margin-bottom: 25px;
}

.fila-nombres {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 14px;
}

.fila-nombres .form-control {
  border-radius: 8px;
  border: 1px solid #ddd;
  padding: 10px 14px;
  font-size: 14px;
  color: var(--color-2);
  transition: border-color 0.2s;
}

.fila-nombres .form-control:focus {
  border-color: var(--color-3);
  box-shadow: 0 0 0 3px rgba(214, 139, 117, 0.15);
  outline: none;
}

.fila-nombres .form-control::placeholder {
  color: #b0b0b0;
}

.fila-asistencia {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 15px;
}

.opciones-asistencia {
  margin: 0;
  flex: 1;
  display: flex;
  justify-content: flex-start;
  gap: 30px;
}

.btn-placeholder {
  width: 42px;
  height: 42px;
}
