/**
* Template Name: dwebqro
* Template URL: https://dwebqro.com/
* Author: Dora Nely Vega Gonzalez
**/

@import url("https://fonts.googleapis.com/css2?family=Great+Vibes&family=Montserrat:wght@300;400;500;600;700&family=Playfair+Display:wght@400;500;600;700&family=Cormorant+Garamond:wght@300;400;500;600;700&family=Raleway:wght@300;400;500;600&display=swap");

/* =========================================================
   1. VARIABLES Y BASE
   ========================================================= */
:root {
  --white: #ffffff;
  --black: #000000;
  --main-color: #aac1c1;
  --secondary-color: #27357e;
  --third-color: #727475;
  --fourth-color: #a4a4a4;
  --fifth-color: #fbfbfb;
  --dark-color: #303030;
  --body-font-color: #181a68;
  --page-gap: 1%;
  --section-gap: 20px;
  --font-script: "Great Vibes", cursive;
  --font-primary: "Montserrat", sans-serif;
  --font-title: "Playfair Display", serif;
  --font-classic: "Cormorant Garamond", serif;
  --font-footer: "Raleway", sans-serif;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

*:focus {
  outline: none !important;
}

html,
body {
  margin: 0 !important;
  padding: 0 !important;
}

body {
  position: relative;
  background: #eee;
  color: var(--body-font-color);
  font-family: var(--font-primary);
  font-size: 14px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.page-wrapper {
  position: relative;
  overflow: hidden;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

svg {
  max-width: 100%;
}

ul {
  margin: 0;
  padding: 0;
}

a {
  color: var(--main-color);
  text-decoration: none;
  cursor: pointer;
}

a:hover,
a:focus {
  text-decoration: none;
  color: var(--main-color);
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin-bottom: 32px;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 3px;
  line-height: 1.4;
  font-family: var(--font-primary) !important;
}

h1 {
  font-size: 36px;
}
h2 {
  font-size: 32px;
}
h3 {
  font-size: 28px;
}
h4 {
  font-size: 24px;
}
h5 {
  font-size: 20px;
}
h6 {
  font-size: 18px;
}

p,
body,
a {
  font-family: var(--font-primary) !important;
}

p {
  margin-bottom: 20px;
  color: var(--body-font-color);
  line-height: normal;
}

/* =========================================================
   2. UTILIDADES
   ========================================================= */
.bg-blue {
  background: var(--secondary-color);
}

.text-boda {
  font-family: var(--font-title) !important;
}

.text-logo {
  font-family: var(--font-script) !important;
  font-size: 4em;
}

.light-color-text {
  color: #fff !important;
}

.main-color-text {
  color: var(--main-color) !important;
}

.secondary-color-text {
  color: var(--secondary-color) !important;
}

.third-color-text {
  color: var(--third-color) !important;
  line-height: normal;
}

.fourth-color-text {
  color: var(--fourth-color) !important;
}

.fifth-color-text {
  color: var(--fifth-color) !important;
}

.dark-color-text {
  color: var(--dark-color) !important;
}

.light-text {
  font-weight: 600 !important;
}

.regular-text {
  font-weight: 400 !important;
}

.semibold-text {
  font-weight: 600 !important;
}

.bold-text {
  font-weight: 800 !important;
}

.no-margin-bottom {
  margin-bottom: 0 !important;
  color: #fff;
}

.sm-line-height {
  line-height: 1em;
  color: #292a2a;
  font-family: var(--font-title) !important;
}

.centered-content-inline {
  display: inline-block;
  margin: auto;
  text-align: center;
}

.centered-content-block {
  display: block;
  margin: auto;
  text-align: center;
}

.padding-2 {
  padding: 2%;
  color: #fff;
}

.padding-5 {
  padding: 5%;
}

.padding-10 {
  padding: 10%;
}

.u-border-b-grey {
  border-bottom: 1px solid #e5e5e5;
}

.u-font-script {
  color: #fff;
  word-spacing: 8px;
  font-family: var(--font-script), serif;
}

.u-m-b-3 {
  margin-bottom: 30px;
}

.u-m-b-5 {
  margin-bottom: 50px;
}

.u-m-b-8 {
  margin-bottom: 80px;
}

.icon {
  transition: color 0.4s ease;
}

.icon--sm {
  width: 20px;
  height: 20px;
  font-size: 20px;
}

.icon--md {
  width: 30px;
  height: 30px;
  font-size: 30px;
}

.icon--lg {
  width: 50px;
  height: 50px;
  font-size: 50px;
}

.icon--xl {
  width: 70px;
  height: 70px;
  font-size: 70px;
}

.icon--primary {
  color: var(--main-color);
}

.icon--white {
  color: #fff;
}

.icon--black {
  color: #000;
}

.icon:hover {
  color: var(--main-color);
}

.icon svg {
  display: block;
  width: 100%;
  height: 100%;
  fill: currentColor;
}

.animation-pulse {
  animation: pulseIcon 2s ease-out infinite;
  opacity: 0;
}

@keyframes pulseIcon {
  0% {
    transform: scale(0.2, 0.2);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: scale(1.5, 1.5);
    opacity: 0;
  }
}

/* =========================================================
   3. PRELOADER / SOBRE
   ========================================================= */
#pre_page {
  position: fixed;
  inset: 0;
  z-index: 9999;
  overflow: hidden;
  background: linear-gradient(180deg, #f4f4f2 0%, #dddcd9 100%);
}

#pre_page.hidden-pre {
  opacity: 0 !important;
  z-index: -1 !important;
  pointer-events: none !important;
}

.pre-page {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 1);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.pre-page .inner {
  display: flex;
  height: 100vh;
}

.pre-page .icon {
  display: block;
  margin: auto;
  text-align: center;
}

.pre-page-content {
  position: relative;
  z-index: 16;
  padding: 0;
  text-align: center;
}

.welcome-text {
  font-size: 5em;
  color: var(--body-font-color);
  text-transform: capitalize;
  font-weight: 700;
  font-style: normal;
  font-family: var(--font-script) !important;
}

.pre-page .left-graph {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 11;
  height: 100vh;
}

.pre-page .right-graph {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 11;
  height: 100vh;
}

#env_top,
#env_bottom,
#inner_elements {
  transition: all 1.2s ease-in-out;
}

#env_top {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 58vh;
  opacity: 1;
  overflow: visible;
  object-fit: cover;
  vertical-align: top;
}

#env_bottom {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 100%;
  opacity: 1;
  overflow: visible;
  vertical-align: bottom;
}

#env_middle {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  opacity: 1;
  object-fit: fill;
  vertical-align: bottom;
}

.stamp {
  position: relative;
  z-index: 11;
  display: flex;
  width: 120px;
  margin: auto;
}

.stamp:hover {
  cursor: pointer;
}

.btn-pre-page {
  position: relative;
  z-index: 12;
  display: block;
  width: 232px;
  margin: 60px auto 0;
  padding: 15px 20px;
  border: 2px solid #303030;
  border-radius: 1000px;
  color: #ffffff !important;
  text-align: center;
  text-transform: uppercase;
  font-style: normal;
  font-weight: 600;
  background: var(--secondary-color);
}

.btn-pre-page:hover {
  width: 250px;
  padding: 17px 20px;
  font-size: 1rem;
  background-color: rgba(131, 131, 131, 0.5);
}

@media (max-width: 991px) {
  .pre-page {
    display: flex;
    justify-content: center;
  }

  .welcome-text {
    font-size: 3em !important;
  }

  .pre-page .left-graph,
  .pre-page .right-graph {
    height: 37vh;
    width: 48%;
    margin: auto;
    object-fit: cover;
  }

  .stamp {
    width: 100px;
  }

  #env_top,
  #env_bottom {
    width: 100%;
    height: 58vh;
    margin: auto;
    object-fit: cover;
  }
}

/* =========================================================
   4. NAVBAR BOOTSTRAP SUPERIOR
   ========================================================= */
nav.navbar.navbar-expand-lg {
  z-index: 3000 !important;
}

.fixed-top {
  z-index: 3000 !important;
}

.navbar-dark .navbar-toggler {
  border-color: rgb(39 53 126) !important;
}

.navbar-expand-lg .navbar-nav .nav-link {
  padding-right: 1rem;
  padding-left: 1rem;
}

.navbar-nav .nav-link.nav-list__link {
  border-bottom: 0;
  color: #fff !important;
  font-style: normal;
  font-weight: 500;
}

.navbar-nav .nav-link.nav-list__link:hover,
.navbar-nav .nav-link.nav-list__link:focus,
.navbar-nav .nav-link.nav-list__link.active {
  color: var(--main-color) !important;
  text-decoration: none;
}

/* =========================================================
   5. HEADER SECUNDARIO
   ========================================================= */
#header {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 8000;
  padding: 15px 0;
  background-color: var(--body-font-color);
  box-shadow: 0 2px 25px rgba(0, 0, 0, 0.08);
  opacity: 1;
}

#header .logo-text {
  color: var(--white);
  font-size: 2rem;
  font-family: var(--font-script) !important;
}

#header .navbar {
  padding: 0;
}

#header .navbar ul {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
}

#header .navbar li {
  position: relative;
}

#header .navbar a,
#header .navbar a:focus {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 0 10px 30px;
  white-space: nowrap;
  color: var(--white);
  font-size: 2rem;
  font-weight: 500;
  font-family: var(--font-script) !important;
}

#header .navbar a:hover,
#header .navbar .active,
#header .navbar .active:focus,
#header .navbar li:hover > a {
  color: var(--main-color);
}

.mobile-nav-toggle {
  z-index: 9999;
  display: none;
  color: var(--white);
  font-size: 30px;
  line-height: 0;
  cursor: pointer;
}

.mobile-nav-toggle.bi-x {
  color: var(--main-color);
}

@media (max-width: 991px) {
  .mobile-nav-toggle {
    display: block;
  }

  #header .navbar ul {
    display: none;
  }

  #header .navbar-mobile {
    position: fixed;
    inset: 0;
    z-index: 9998;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: var(--body-font-color);
  }

  #header .navbar-mobile::before,
  #header .navbar-mobile::after {
    content: "";
    position: absolute;
    width: 180px;
    height: 220px;
    opacity: 0.9;
    pointer-events: none;
    background-size: contain;
    background-repeat: no-repeat;
  }

  #header .navbar-mobile::before {
    top: 0;
    left: 0;
    background-image: url("../img/mw-welcome-graph-left.svg");
    background-position: top left;
  }

  #header .navbar-mobile::after {
    right: 0;
    bottom: 0;
    background-image: url("svg");
    background-position: bottom right;
  }

  #header .navbar-mobile .mobile-nav-toggle {
    position: absolute;
    top: 28px;
    right: 24px;
    font-size: 34px;
  }

  #header .navbar-mobile ul {
    position: relative;
    z-index: 2;
    display: flex !important;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 18px;
    width: 100%;
    margin: 0;
    padding: 40px 20px;
  }

  #header .navbar-mobile li {
    width: 100%;
    text-align: center;
  }

  #header .navbar-mobile a,
  #header .navbar-mobile a:focus {
    display: inline-block;
    padding: 0;
    color: var(--white);
    font-size: 2rem;
    line-height: 1.1;
    font-family: var(--font-script);
  }
}

/* =========================================================
   6. HERO PRINCIPAL Y HERO FOOTER
   ========================================================= */
#hero {
  height: 100dvh;
  opacity: 1 !important;
}

.hero-invitacion,
.hero-invitacion-top {
  position: relative;
  width: 100%;
  height: 100vh;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

.hero-invitacion-top {
  background-image: url("../img/boda.webp");
}

.hero-invitacion {
  background-image: url("../img/galeria9.jpeg");
}

.overlay-fade {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  height: 250px;
  background: linear-gradient(
    to top,
    rgba(39, 53, 126, 0.92),
    rgba(255, 255, 255, 0)
  );
}

.contenido-hero {
  position: absolute;
  bottom: 31px;
  left: 50%;
  z-index: 2;
  width: 100%;
  padding: 0 20px;
  text-align: center;
  transform: translateX(-50%);
}

.hero-subtitle {
  margin-bottom: 12px;
  color: #d9dadd;
  text-transform: uppercase;
  letter-spacing: 4px;
  text-shadow: 0 4px 20px rgba(0, 0, 0, 0.28);
  font-size: 0.95rem;
  font-family: var(--font-title);
}

.nombres-principales {
  margin-bottom: 0;
  color: #fff;
  text-transform: capitalize;
  line-height: 1;
  font-size: 3rem;
  font-family: var(--font-script) !important;
}

.amp-white {
  color: #fff;
  font-size: 2rem;
  font-family: var(--font-script);
}

.ampersand {
  display: inline-block;
  margin: 5px 0;
  color: #fff;
  font-size: 3rem;
  font-family: var(--font-script);
}

/* =========================================================
   7. INTRO
   ========================================================= */
.intro-block {
  min-height: 100vh;
  background-image: url("../img/fondo-gd.png");
  background-position: center center;
  background-size: cover;
}

.intro-block .first-half {
  min-height: 100vh;
  padding: 5%;
  background-position: left bottom;
  background-size: cover;
  background-repeat: no-repeat;
}

.intro-block .last-half {
  min-height: 100vh;
  padding: 5%;
}

@media (max-width: 990px) {
  .intro-block {
    background-position: center;
  }
}

@media (max-width: 480px) {
  .intro-block {
    background-image: url("../img/fondo.jpeg");
  }

  .intro-block .first-half {
    min-height: 0;
    padding: 0;
  }

  .intro-block p,
  .text-intro {
    color: #fff !important;
  }
}

.section-title-xl {
  font-family: "Playfair Display", serif !important;
  font-size: 2em;
  text-transform: uppercase;
  text-align: center;
  color: #343a40;
  margin-bottom: 0px;
}

/* =========================================================
   8. CONTADORES
   ========================================================= */
.countdown-date {
  color: #343a40;
  font-family: var(--font-primary) !important;
  font-size: 1.5rem;
}

.counter-list {
  list-style: none;
  margin-top: 25px;
  text-align: center;
}

.counter-list__item {
  position: relative;
  float: left;
  width: 25%;
  width: 160px;
  margin: 0 20px;
  padding: 46px 10px;
  border-radius: 15px;
}

.counter-card {
  background: #27357e !important;
  color: #fff !important;
  padding: 5px;
  font-size: 1rem;
  border-radius: 15px;
}

.counter-card p {
  color: #fff !important;
}

@media (min-width: 992px) {
  .counter-list {
    display: flex;
    justify-content: center;
    margin-left: 0;
  }
}

@media (max-width: 1024px) and (min-width: 767px) {
  .counter-list {
    display: flex;
  }

  .counter-list__item {
    width: 126px;
    margin: 14px;
    padding: 19px 10px;
  }

  .counter-list .centered-content-inline {
    display: flex;
    margin: 0;
  }
}

@media (max-width: 480px) {
  .counter-list {
    display: grid;
    margin-top: 0;
  }

  .counter-list__item {
    margin: 0 auto 20px;
    padding: 20px 10px !important;
  }
}

/* =========================================================
   9. CUANDO Y DONDE
   ========================================================= */
.location-info-box {
  padding: 5%;
  background-color: var(--secondary-color);
}

.btn-b {
  display: inline-block;
  width: auto;
  padding: 15px 20px;
  background-color: #cfcfd8;
  color: rgb(20, 18, 18);
  text-transform: uppercase;
  font-style: normal;
  font-weight: 600;
}

.btn-b:hover {
  width: auto;
  padding: 15px 30px;
  border: 3px solid var(--main-color);
  background-color: var(--secondary-color);
  color: #fff;
  text-decoration: none;
}

@media (max-width: 480px) {
  #cuando-donde .first-half {
    margin-bottom: 32px;
  }
}

/* =========================================================
   10. ITINERARIO
   ========================================================= */
.story-timeline {
  position: relative;
  padding: 50px 0;
}

.story-timeline__col img {
  display: block;
  width: 120px;
  margin: auto;
}

.story-timeline__text {
  position: relative;
  z-index: 9;
  padding: 20px 0;
  padding-top: 82px;
}

.story-timeline__text h6 {
  position: relative;
  margin-bottom: 15px;
  font-style: initial;
  font-weight: 600;
}

@media (min-width: 768px) {
  .story-timeline__col {
    width: 50%;
  }

  .story-timeline__col--left {
    position: relative;
    padding-right: 45px;
  }

  .story-timeline__col--left .story-timeline__text {
    text-align: right;
  }

  .story-timeline__col--right {
    padding-top: 32px;
    padding-left: 45px;
  }

  .story-timeline__col--left:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 1px;
    height: 100%;
    background-color: #dfdfdf;
  }

  .story-timeline__text h6:before {
    content: "";
    position: absolute;
    top: 14px;
    left: -33px;
    width: 26px;
    height: 1px;
    background: #dfdfdf;
  }

  .story-timeline__col--left h6:before {
    right: -33px;
    left: auto;
  }
}

@media (min-width: 992px) {
  .story-timeline__text h6,
  .story-timeline__text p {
    padding-right: 18px;
    padding-left: 78px;
  }

  .story-timeline__col--left p,
  .story-timeline__col--left h6 {
    padding-right: 78px;
    padding-left: 18px;
  }

  .story-timeline__text h6:before {
    width: 100px;
  }
}

@media (max-width: 480px) {
  .story-timeline__text {
    text-align: center;
  }
}

/* =========================================================
   11. HOTELES
   ========================================================= */
.hotels-tabs {
  margin-top: 5%;
}

.tabcontent {
  display: none;
  padding: 2%;
  color: #fff;
  text-align: center;
}

.tabcontent img {
  width: 100%;
  margin-bottom: 20px;
}

.btn-mw {
  display: inline-block;
  width: auto;
  padding: 15px 20px;
  background-color: #27357e;
  color: #fff;
  text-transform: uppercase;
  font-style: normal;
  font-weight: 600;
}

.btn-mw:hover {
  width: auto;
  padding: 15px 30px;
  border: 3px solid var(--main-color);
  background-color: var(--secondary-color);
  color: #fff;
  text-decoration: none;
}

/* =========================================================
   12. GALERÍA
   ========================================================= */
.gallery-block {
  padding: 5%;
  background-color: var(--secondary-color);
}

body.no-scroll {
  height: 100%;
  overflow-y: hidden;
}

.gallery-block .row > .column {
  padding: 8px;
}

.gallery-block .row:after {
  content: "";
  display: table;
  clear: both;
}

.gallery-block .column {
  float: left;
  width: 25%;
}

.modal {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99999;
  display: none;
  width: 100%;
  height: 100%;
  overflow: auto;
  padding-top: 100px;
  background-color: rgba(0, 0, 0, 0.95);
}

.modal-content {
  position: relative;
  width: 90%;
  max-width: 1200px;
  margin: auto;
  padding: 0;
  background-color: transparent;
}

.close {
  position: absolute;
  top: 10px;
  right: 25px;
  color: #fff;
  font-weight: bold;
  font-size: 35px;
}

.close:hover,
.close:focus {
  color: #fff;
  cursor: pointer;
  text-decoration: none;
}

.mySlides {
  display: none;
}

.active-slide img {
  display: block;
  height: 80vh;
  margin: auto;
}

.cursor {
  cursor: pointer;
}

.prev,
.next {
  position: absolute;
  top: 50%;
  width: auto;
  margin-top: -50px;
  padding: 16px;
  border-radius: 0 3px 3px 0;
  background: rgba(0, 0, 0, 0.5);
  color: #fff !important;
  font-style: normal;
  font-weight: bold;
  font-size: 20px;
  cursor: pointer;
  user-select: none;
  -webkit-user-select: none;
}

.next {
  right: 0;
  border-radius: 3px 0 0 3px;
}

.prev:hover,
.next:hover {
  background-color: rgba(0, 0, 0, 0.8);
}

.numbertext {
  display: none;
  color: #f2f2f2;
  font-size: 12px;
  position: absolute;
  top: 0;
  padding: 8px 12px;
}

img.hover-shadow {
  transition: 0.3s;
}

.hover-shadow:hover {
  box-shadow:
    0 4px 8px 0 rgba(0, 0, 0, 0.2),
    0 6px 20px 0 rgba(0, 0, 0, 0.19);
}

@media (max-width: 480px) {
  .gallery-block .column {
    width: 50%;
  }

  .modal {
    padding-top: 54%;
  }

  .active-slide img {
    width: 100%;
    height: auto;
  }
}

/* =========================================================
   13. SLIDER DE HISTORIA
   ========================================================= */
.slider-list {
  margin-bottom: 25px;
  list-style: none;
}

.slider-list .slick-list {
  padding-top: 25px !important;
}

.slider-list__item {
  text-align: center;
  transition: transform 0.4s ease;
}

.slider-list__item.slick-current {
  transform: translateY(-25px);
}

.slider-list__item img {
  display: inline !important;
  width: 92%;
  max-width: 180px;
  margin-bottom: 20px;
  border: 3px solid rgba(0, 0, 0, 0.1);
  border-radius: 50%;
  background-color: #fcfcfc;
  transition: box-shadow 0.4s ease;
}

.slider-list__item.slick-current img {
  border: 3px solid #fcfcfc;
  background-color: rgba(0, 0, 0, 0.1);
  box-shadow: none;
}

.slider-list__item p,
.slider-list__item h6 {
  display: none;
  font-size: 1rem;
}

.slider-list__item.slick-current p,
.slider-list__item.slick-current h6 {
  display: block;
}

.slider-arrows {
  justify-content: center;
}

.slider-arrows .icon {
  padding: 0 5px;
  margin-top: 5px;
}

.slider-arrow {
  cursor: pointer;
}

.slider-arrow svg path {
  stroke: #b1b1b1;
  transition: stroke 0.4s ease;
}

.slider-arrow:hover svg path {
  stroke: var(--third-color);
}

@media (min-width: 768px) {
  .slider-list__item img {
    max-width: 200px;
  }
}

/* =========================================================
   14. REGALOS
   ========================================================= */
.registry-item {
  display: grid;
  padding: 0 5%;
}

.registry-item p {
  font-size: 2rem;
  text-align: center;
  line-height: normal;
  font-style: normal;
  font-weight: 100;
  font-family: var(--font-title) !important;
}

@media (max-width: 480px) {
  .registry-item {
    padding: 5%;
  }

  .registry-item p {
    font-size: 1.5rem;
    letter-spacing: -1px;
  }
}

/* =========================================================
   15. HASHTAG
   ========================================================= */
.hashtag-block {
  background-color: var(--secondary-color);
  background-image: url(../img/hashtag-pattern-1.png);
  border-width: 5px 0;
  border-style: solid;
  padding: 7% 5%;
}

.hashtag-block h1 {
  font-size: 3.2rem;
}

@media (max-width: 480px) {
  .hashtag-block h1 {
    font-size: 1.5rem;
  }
}

/* =========================================================
   16. FOOTER
   ========================================================= */
.footer {
  padding: 60px 0 20px;
  background-color: var(--secondary-color);
}

.footer-invitacion {
  padding: 25px 10px;
  background: #fff;
  text-align: center;
}

.footer-invitacion a {
  color: #333;
  text-transform: uppercase;
  letter-spacing: 3px;
  font-size: 12px;
  font-family: var(--font-footer);
}

.footer-invitacion a:hover {
  color: var(--secondary-color);
}

/* =========================================================
   17. BOTONES FLOTANTES Y AUDIO
   ========================================================= */
#footer-bottom {
  position: fixed;
  right: 15px;
  bottom: 15px;
  z-index: 9998;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  opacity: 1 !important;
}

#custom-audio-player {
  position: relative;
  order: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
}

#audio-element {
  display: none;
}

#play-pause-button {
  position: relative;
  z-index: 3;
  display: block;
  width: 56px;
  height: 56px;
  min-width: 56px;
  min-height: 56px;
  padding: 0;
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
}

#notes-container {
  position: absolute;
  bottom: 24px;
  left: 50%;
  z-index: 2;
  width: 70px;
  height: 140px;
  overflow: visible;
  pointer-events: none;
  transform: translateX(-50%);
}

.note-block {
  position: absolute;
  bottom: 0;
  color: #494949;
  font-size: 1rem;
  animation: rise 2s ease-out forwards;
}

.back-to-top {
  position: relative !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  order: 2;
  display: flex !important;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  padding: 0;
  border-radius: 50%;
  background: #b1771d;
  visibility: visible !important;
  opacity: 1 !important;
}

.back-to-top i {
  color: #fff;
  line-height: 1;
  font-size: 30px;
}

.pulsing {
  animation: pulseBtn 2s ease-in-out infinite;
}

.rotating {
  animation: rotateBtn 6s linear infinite;
}

@keyframes rise {
  0% {
    transform: translateY(0);
    opacity: 1;
  }
  100% {
    transform: translateY(-140px);
    opacity: 0;
  }
}

@keyframes pulseBtn {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}

@keyframes rotateBtn {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

/* =========================================================
   18. RESPONSIVE GENERAL
   ========================================================= */
@media (min-width: 1025px) {
  .mobile-only {
    display: none;
  }

  .tbalet-only {
    display: none;
  }

  .desktop-hidden {
    display: none;
  }
}

@media (max-width: 1024px) and (min-width: 767px) {
  .mobile-only {
    display: none;
  }

  .tablet-hidden {
    display: none;
  }
}

@media (max-width: 480px) {
  .desktop-only {
    display: none;
  }

  .tbalet-only {
    display: none;
  }

  .mobile-hidden {
    display: none;
  }

  .text-logo {
    font-size: 2em !important;
  }

  .nombres-principales {
    font-size: 2.5rem;
  }

  .amp-white,
  .ampersand {
    font-size: 2rem;
  }

  .navbar-expand-lg .navbar-nav .nav-link {
    padding-right: 0.5rem !important;
    padding-left: 0.5rem !important;
  }
}
