@charset "UTF-8";
/*
Theme Name: Ideal Theme
Theme URI: 
Author: Ideal Agency
Author URI: https://theideal.agency/
Description: 
Requires at least: 4.9.6
Requires PHP: 5.2.4
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: idealtheme
*/

* {
  margin:0;
  padding: 0;
  box-sizing: border-box;
  cursor: none;
}
html, body { 
  max-width: 100%;
  height: 100%;
  overflow-x: clip;
  /* scroll-behavior: smooth; */
  /* cursor: url('/wp-content/themes/idealtheme/assets/images/cursor.png') 20 20, auto; */
  /* background-color: var(--color-nude); */
  background-color: #d8d0bf;
}

::selection { background-color: var(--color-white); color: var(--color-dark);}
::-moz-selection { background-color: var(--color-white); color: var(--color-dark);}

.flex { display: flex; }
.flex-col { flex-direction: column; }
.justify-end { justify-content: flex-end; }
.space-between { justify-content: space-between; }
.align-hor-center { align-items: center; }
.img-fluid {  max-width: 100%; height: auto; }

.stopScroll { overflow: hidden !important; }
.gap-0 { gap:0; }



/* --------------------- Variables --------------------- */
:root {
    --font-size: 18px;
    --color-dark: #101010;
    --color-white: #FDFCF8;
    --color-nudelight: #F3F0E9;
    --color-nude: #ccb094;
    --transition-dur: 0.4s;
    --font-coconat: 'Coconat';
    --font-instrument: 'Instrument Serif';

    --width: 40vw;
    --width-m: 20vw;
}


@font-face {
  font-family: 'Coconat';
  src: url('/wp-content/themes/idealtheme/assets/font/Coconat-Regular.woff2') format('woff2'),
    url('/wp-content/themes/idealtheme/assets/font/Coconat-Regular.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Instrument Serif';
  src: url('/wp-content/themes/idealtheme/assets/font/InstrumentSerif-Italic.woff2') format('woff2'),
  url('/wp-content/themes/idealtheme/assets/font/InstrumentSerif-Italic.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
 

  
/* --------------------- Typography --------------------- */
body {
  font-family: var(--font-instrument);
  font-size: var(--font-size);
  line-height: 1.5;
}

@media (min-width: 992px) {
  .container {
    max-width: 1600px;
    margin: auto;
  }
}


a {
  transition: var(--transition-dur);
  color: inherit;
  overflow: hidden;
  /* position: relative; */
  text-decoration: none;
}
  
a:hover {
  color: inherit;
}
.hero {
  color: var(--color-dark);
  line-height: 0.8;
}
.preloader-text {
  font-family: 'Instrument Serif';
  color: var(--color-white);
  font-size: 20vw;
  line-height: 1;
}

h1, h2, h3, h4, h5, h6, .blog .post p {
  font-weight: 400;
}
h1 {
  color: var(--color-dark);
  font-size: 120px;
  line-height: 0.9;
}
h2 {
  color: var(--color-dark);
  font-size: 10vw;
  transition: var(--transition-dur);
  line-height: 0.8;
  font-family: var(--font-coconat);
  text-transform: uppercase;
  letter-spacing: -7px;
}

h2.instrument {
  font-family: var(--font-instrument);
  text-transform: none;
  letter-spacing: -5px;
  margin-left: 20px;
}

h3 {
  color: var(--color-dark);
  font-size: 2vw;
  font-family: var(--font-instrument);
  line-height: 1.1;
}
h4 {
  color: var(--color-dark);
  font-size: 2vw;
  line-height: 1;
}

h5 {
  font-size: 40px;
}
h6 {
  font-size: 1.4vw;
  line-height: 1;
  font-family: var(--font-coconat);
}
p {
  color: var(--color-dark);
  font-size: 18px;
  line-height: 1.2 !important;
  font-family: 'Instrument Serif';
}
p:not(:last-child) {
  margin-bottom: 20px; 
}

blockquote.wp-block-quote p {
  color: rgb(0, 0, 0, 0.6); 
  font-family: var(--font-serif);
  font-size: 1.6rem;
  font-style: italic;
  text-align: left;
  line-height: 1.5;
  margin: 2rem 0 2rem 2rem;
}


p.hero-text {
  font-family: 'Coconat';
  font-size: 12vw;
  letter-spacing: -12px;
  line-height: 0.7 !important;
}

p.hero-text span {
  font-family: 'Instrument Serif';
  font-size: 10vw;
  letter-spacing: -1px;
  margin-right: -2vw;
}

p.hero-text.second-line {
  margin-left: 7vw;
  white-space: nowrap;
}

p.hero-subtext {
  font-family: 'Instrument Serif';
  font-size: 7vw;
  letter-spacing: -1px;
  white-space: nowrap;
}

p.hero-subtext::before {
  content: '';
  width: 18vw;
  height: 2px;
  background-color: #101010;
  position: relative;
  display: inline-block;
  margin-right: 40px;
  top: -14px;
}



/* --------------------- Main Page --------------------- */
.alignwide {
  border-top: 1px solid var(--color-nude);
  padding: 8% 10%;
}

.floating-nav {
  padding: 8px 8px 8px 20px;
  position: fixed;
  bottom: 20px;
  z-index: 999;
  left: 50%;
  transform: translateX(-50%);
  opacity: 0;
  visibility: hidden;
  width: 90%;
  border-radius: 20px;
  background-color: rgb(204 176 148 / 80%);
  transition: opacity 0.3s ease, visibility 0.3s ease;
  backdrop-filter: blur(10px);
}

.floating-nav p {
  margin-bottom: 0;
}

.floating-nav .btn {
  font-size: 12px !important;
}

.floating-nav.show {
  opacity: 1;
  visibility: visible;
}


/* .hero-section {
  display: flex;
  align-items: center;
  min-height: 80vh;
  padding-left: 4vw;
  padding-right: 4vw;
  gap: 60px;
  position: relative;
} */

/* .hero-section::after {
  content: '';
  position: absolute;
  width: 100%;
  background-image: url(/wp-content/uploads/2025/02/bk-flowers.avif);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  z-index: 0;
  height: 100%;
  mix-blend-mode: soft-light;
} */

/* .hero-section > * {
  z-index: 1;
} */

.hero-section .hero-image {
  border-radius: 20px;
}

.hero-section.v2 {
  display: flex;
  justify-content: center;
  padding: 10% 2% 6% !important;
  width: 100%;
  overflow: hidden;
  position: relative;
}

.hero-section.v2 .col-left {
  position: relative;
  width: fit-content ;
  will-change: transform;
}



.hero-section.v2 .col-left p.hero-text {
  font-size: 14vw;
  letter-spacing: -10px;
  will-change: transform;
  width: fit-content;
  position: relative;
}

.hero-section.v2 p.hero-subtext {
  font-size: 4vw;
  width: fit-content;
  position: relative;
}

.hero-section.v2 p.hero-subtext::before {
  width: var(--width);
}
.col-left .btn {
  transition: none;
}

.fullimage {
  position: relative;
  transform: scale(.90);
}

.fullimage img {
  border-radius: 20px;
}


.marquee {
  max-width: 100%;
  width: 100%;
  overflow: hidden;
  background-color: var(--color-nude);
  padding: 1%;
  position: relative;
}

.marquee-content {
  height: 100%;
  width: fit-content;
  align-items: center;
  display: flex;
  position: relative;
  animation: marquee 20s linear infinite;
  will-change: transform;
}

.marquee-inner {
  white-space: nowrap;
  font-family: var(--font-coconat);
  text-transform: uppercase;
  font-size: 1.2vw;
}

@keyframes marquee {
  to {
    transform: translateX(-50%);
  }
}

.main-info-block {
  padding: 5vw 10vw;
}

h2.twentyfive {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
  line-height: .8;
}
h2.twentyfive::before {
  content: '';
  width: 12vw;
  height: 2px;
  background-color: #101010;
  position: relative;
  display: inline-block;
  margin-right: 40px;
  top: 7px;
}

.small-h2 h2 {
  font-size: 6vw;
}
.small-h2 h2.instrument {
  letter-spacing: -2px;
  margin-left: 0;
}

.main-info-block .row .info {
  padding-top: 10%;
}

.main-info-block .row-2 {
  margin-top: -10%;
  padding-bottom: 4%;
}

.main-info-block .img-masia {
  padding-bottom: 6%;
}

.main-info-block .timeline {
  width: 100%;
  align-items: flex-end;
  padding-bottom: 2%;
}

.main-info-block .timeline h4 {
  line-height: 2;
}

.main-info-block .timeline .fiesta::after {
  content: '';
  background-image: url('/wp-content/uploads/2025/02/burning-heart.avif');
  background-repeat: no-repeat;
  background-size: contain;
  width: 2vw;
  height: 2vw;
  display: inline-block;
  margin-left: 10px;
}

.bloque-3.alignwide {
  padding-top: 0;
}

.bloque-3 .col {
  padding-top: 8%;
}

h3.bus-info {
  margin-top: 20px;
}

.hotel-card {
  height: 100%;
  gap: 0;
}

.hotel-card figure img {
  border-radius: 14px 14px 0 0 ;
}

.hotel-card  .info {
  background-color: var(--color-nude);
  width: 100%;
  padding: 7%;
  border-radius: 0 0 14px 14px;
}

.hotel-card .wp-block-buttons {
  margin-top: auto;
}

.tag-ciudad {
  color: var(--color-dark);
  font-family: var(--font-instrument);
  font-size: 2vw;
  margin-bottom: 10px !important;
}

.width-60 { width: 60%; }
.gap-20 { gap: 20px; }
.gap-60 { gap: 60px; }
.align-self-end { align-self: flex-end; }

details {
  border-bottom: 1px solid var(--color-dark);
  width: 100%;
  padding: 2% 0;
}

details[open] summary {
  padding-bottom: 10px;
}

details summary {
  font-family: var(--font-instrument);
  font-size: 2vw;
  list-style-position: outside;
  margin-left: 20px;
  padding: 0 0 0 10px;
}

summary::marker {
  font-size: 1.2vw;
}

details ul {
  padding-left: 40px;
}

details ul li {
  margin-bottom: 10px;
  font-family: var(--font-instrument);
}

details p {
  font-family: var(--font-instrument);
}

details a {
  text-decoration: underline;
}


.seccion-cta {
  padding: 2%;
}

.seccion-cta h3 {
  font-family: var(--font-instrument);
  font-size: 6vw;
}

.seccion-cta .img-duki {
  width: 23%;
}

.seccion-cta .img-ron {
  width: 25%;
  padding: 0 6%;
}



/* --------------------- Button Styles --------------------- */
.btn, .btn a, #forminator-module-36 .forminator-button-submit {
  padding: 14px 20px;
  display: inline-block;
  border: none;
  transition: var(--transition-dur);
  font-family: var(--font-coconat);
  text-transform: uppercase;
  border-radius: 10px;
  font-size: 1.2vw !important;
  letter-spacing: -.5px;
  line-height: 1;
}
.btn.btn-primary:hover {
  color: var(--color-dark);
  background-color: var(--color-nude);
}

.btn.btn-primary {
  color: var(--color-nude);
  background-color: var(--color-dark);
}

.btn.btn-primary a {
  color: var(--color-nude);
}

.btn.btn-primary:hover a {
  color: var(--color-dark) !important;
}

.btn.btn-secondary {
  color: var(--color-dark);
  background-color: transparent;
  border: 1px solid var(--color-dark);
}

.btn.btn-secondary:hover {
  background-color: var(--color-dark);
  border: 1px solid var(--color-dark);
}

.btn.btn-secondary:hover a {
  color: var(--color-nude) !important;
}

.btn.btn-primary::after, .btn.btn-secondary a::after {
  content: '\f061';
  font-family: 'Font Awesome 6 Free';
  margin-left: 12px;
}

.btn.btn-link {
  line-height: 1;
  padding: 0;
  border-radius: 0;
  border-bottom: 1px solid transparent;
}

.btn.btn-link:hover {
  border-bottom: 1px solid var(--color-dark);
}

.btn.mapa a::after {
  content: '\f14c';
  font-family: 'Font Awesome 6 Free';
  margin-left: 8px;
  width: 1.2vw;
  height: 1.2vw;
  display: inline-block;
}

.copy-icon::after {
  content: '\f0c5';
  font-family: 'Font Awesome 6 Free';
  margin-left: 8px;
  width: 1.4vw;
  height: 1.4vw;
  display: inline-block;
  font-size: 16px;
}

/* --------------------- Forms --------------------- */
input[type="text"] {
  font-size: 1rem;
  padding: 8px 5px;
  border-radius: 5px;
}


/* --------------------- TOP NAV --------------------- */
#top-navigation {
  position: fixed;
  width: 100%;
  z-index: 99;
  transition: all .4s ease;
  transition-delay: .2s;
  padding: 0 20px;
  border-bottom: 1px solid var(--color-dark);
  background-color: #d8d0bf;
      top: 0;
}

.hidden {
  transform: translateY(-130px);
}


.main-menu .navigation {
  position: static;
  margin: 0;
  gap: 40px;
}
.main-menu .navigation > li {
  position: relative;
  list-style: none;
  transition: all ease var(--transition-dur);
  -moz-transition: all ease var(--transition-dur);
  -webkit-transition: all ease var(--transition-dur);
  -ms-transition: all ease var(--transition-dur); 
  -o-transition: all ease var(--transition-dur);
}



.main-menu .navigation > li:hover > a,
.main-menu .navigation > li.current > a {
  opacity: 1;
  color: var(--color-dark);
}

.main-menu .navigation > li > a {
  position: relative;
  display: block;
  color: var(--color-dark);
  text-align: center;
  line-height: 1.6;
  text-transform: capitalize;
  letter-spacing: 0px;
  opacity: 1;
  overflow: hidden;
  font-size: 18px;
  text-decoration: none;
  transition: all ease var(--transition-dur);
  -moz-transition: all ease var(--transition-dur);
  -webkit-transition: all ease var(--transition-dur);
  -ms-transition: all ease var(--transition-dur);
  -o-transition: all ease var(--transition-dur);
}





.navbar-open {
  position: relative;
  display: none;
  background-color: unset;
  padding: 0;
  border: none;
  background-color: unset !important;
}

.navbar-open .flaticon {
  color: var(--color-dark);
  display: block;
  cursor: pointer;
  font-size: 20px; padding: 0; line-height: 1;
}

.mobile-menu {
  position: fixed;
  right: 0;
  top: 0;
  width: 80%;
  max-width: 100%;
  height: 100%;
  opacity: 0;
  visibility: hidden;
  z-index: 999999;
}

.mobile-menu-visible .mobile-menu {
  opacity: 1;
  visibility: visible;
}



.mobile-menu .menu-box {
  position: absolute;
  right: 5%;
  top: 0px;
  height: fit-content;
  max-height: 100%;
  overflow-y: auto;
  background: var(--color-dark);
  padding: 0;
  z-index: 5;
  opacity: 0;
  visibility: hidden;
  border-radius: 12px;
  margin-top: 66px;
  transform: translateX(101%);
  -webkit-transform: translateX(101%);
  -ms-transform: translateX(101%);
}

.mobile-menu-visible .mobile-menu .menu-box {
  opacity: 1;
  visibility: visible;
  transition: all 0.7s ease;
  -webkit-transition: all 0.7s ease;
  -moz-transition: all 0.7s ease;
  -ms-transition: all 0.7s ease;
  -o-transition: all 0.7s ease;
  -webkit-transform: translateX(0%);
  -ms-transform: translateX(0%);
  transform: translateX(0%);
}

.mobile-menu .close-btn {
  position: absolute;
  right: 3%;
  line-height: 1;
  margin-top: 3%;
  text-align: center;
  font-size: 14px;
  color: var(--color-nude);
  cursor: pointer;
  z-index: 10;
  background-color: var(--color-dark);
  padding: 5%;
  border-radius: 50%;
  -webkit-transition: all var(--transition-dur) ease;
  -moz-transition: all var(--transition-dur) ease;
  -ms-transition: all var(--transition-dur) ease;
  -o-transition: all var(--transition-dur) ease;
  transition: all var(--transition-dur) ease;
  -webkit-transform: translateX(50px);
  -ms-transform: translateX(50px);
  transform: translateX(50px);
}

.mobile-menu-visible .mobile-menu .close-btn {
  -webkit-transform: translateX(0px);
  -ms-transform: translateX(0px);
  transform: translateX(0px);
}

.mobile-menu .close-btn:hover {
  opacity: 0.5;
}

.mobile-menu .navigation {
  position: relative;
  display: block;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.mobile-menu .navigation li {
  position: relative;
  display: block;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.mobile-menu .navigation li > ul > li:last-child {
  border-bottom: none;
}

.mobile-menu .navigation li > ul > li:first-child {
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.mobile-menu .navigation li > a {
  position: relative;
  display: block;
  line-height: 1.4;
  padding: 10px 20px;
  font-size: 15px;
  color: var(--color-nude);
  text-transform: capitalize;
  font-family: var(--font-coconat);
  transition: all var(--transition-dur) ease;
  -webkit-transition: all var(--transition-dur) ease;
  -moz-transition: all var(--transition-dur) ease;
  -ms-transition: all var(--transition-dur) ease;
  -o-transition: all var(--transition-dur) ease;
}

.mobile-menu .navigation li.current > a,
.mobile-menu .navigation li > a:hover {
  color: var(--color-nude);
}

.mobile-menu .navigation li.menu-item-has-children .dropdown-btn {
  position: absolute;
  right: 0px;
  top: 0px;
  width: 44px;
  height: 44px;
  text-align: center;
  font-size: 16px;
  line-height: 44px;
  color: var(--color-dark);
  cursor: pointer;
  z-index: 5;
}

.mobile-menu .navigation li.menu-item-has-children .dropdown-btn:after {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 1px;
  height: 24px;
  border-left: 1px solid rgba(0, 0, 0, 0.1);
}

.mobile-menu .navigation li > ul,
.mobile-menu .navigation li > ul > li > ul {
  display: none;
}

@media only screen and (max-width: 768px) {
  #top-navigation .top-menu {
    display: none !important;
    visibility: hidden;
  }
  .navbar-open {
    opacity: 1;
    visibility: visible;
    display: inline-block;
  }
}



/* --------------------- Pop Up Banner --------------------- */
section.popup-banner {
  position: absolute;
  z-index: 99;
  width: 100%;
  background-color: #ebe5d9e2;
  top: 0;
  overscroll-behavior: contain;
/*  min-height: 100vh !important; */
}

html:has(.activemodal) {
    overflow-y: hidden;
}


span.cerrar-popup {
  font-family: 'Instrument Serif';
  position: absolute;
  left: 50%;
  top: 20px;
  transition: all 1s ease;
  transform: translateX(-50%);
  background-color: #EBE5D9;
  padding: 4px 12px;
  border-radius: 8px;
}

span.cerrar-popup:hover {
  background-color: #101010;
  color: #fff;
}
 



/* --------------------- Content Section --------------------- */
.content-area {
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-content: center;
  justify-content: center;
  height: 100%;
  position: relative;
}


/* --------------------- Pop Up RSVP --------------------- */
.popup {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  justify-content: center;
  align-items: center;
  z-index: 999;
}

/* Contenido del popup */
.popup-content {
  background: var(--color-nudelight);
  padding: 40px;
  width: 70%;
  position: relative;
  border-radius: 10px;
  max-height: 94vh;
  overflow-y: scroll;
}

/* Botón de cerrar */
.close-popup {
  position: absolute;
  top: -5px;
  right: 15px;
  font-size: 35px;
  cursor: pointer;
  font-family: var(--font-coconat);
}

.no-scroll {
  overflow: hidden;
}

#custom-popup[style*="display: flex"] ~ .content {
  visibility: hidden;
  pointer-events: none;
}

.popup-content .title {
  font-family: var(--font-coconat);
  font-size: 4vw;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: -3px;
}

#forminator-module-36 .forminator-label[class*="forminator-floating-"], .forminator-field-radio .forminator-label, #forminator-module-36 .forminator-button-submit {
  font-family: var(--font-coconat) !important;
}

.forminator-field-radio .forminator-label {
  font-size: 16px !important;
}

#forminator-module-36 .forminator-radio-label {
  font-size: 18px;
}

#forminator-module-36 [role="radiogroup"] .forminator-label {
  font-weight: 400 !important;
}

.forminator-ui.forminator-custom-form:not(.forminator-size--small)[data-grid=open] .forminator-row:not(:last-child) {
	margin-bottom: 10px; 
}



/* --------------------- Footer Section --------------------- */
.ft-main {
  background-color: transparent;
  color: var(--color-dark);
  border-top: 1px solid var(--color-dark);
}

.ft-main .row.first {
  padding: 1% 1% 4% 1%;
}

.ft-main .row.second {
  padding: 1%;
  border-top: 1px solid var(--color-dark);
}

.ft-names {
  font-family: var(--font-coconat);
  font-size: 14vw;
  letter-spacing: -11px;
  line-height: .7 !important;
}

.ft-names.second {
  align-self: flex-end;
  margin-right: -20%;
}

.ft-names .instrument {
  font-family: var(--font-instrument);
  margin-right: 20px;
} 

.ft-right-col {
  width: 25%;
}



/* --------------------- Save the Date Page --------------------- */

.page-template-page-savethedate #top-navigation, .page-template-page-savethedate footer {
  display: none;
}

.page-template-page-savethedate {
  background-image: url(/wp-content/themes/idealtheme/assets/images/monogram-bk.png);
  background-size: cover;
  background-position: center;
}



/* ----------------------------------------------------------------------------------------------------
* Noise background
* ---------------------------------------------------------------------------------------------------- */
 body::before {
  content: "";
  background-image: url('/wp-content/themes/idealtheme/assets/images/noise2b.avif');
  pointer-events: none;
  animation: noise 12s steps(12) infinite;
  height: 300%;
  left: -50%;
  opacity: 0.8;
  position: fixed;
  top: -100%;
  width: 300%;
}

@keyframes noise {
  0%, 100% { transform:translate(0, 0) }
    10% { transform:translate(-5%, -10%) }
    20% { transform:translate(-15%, 5%) }
    30% { transform:translate(7%, -25%) }
    40% { transform:translate(-5%, 25%) }
    50% { transform:translate(-15%, 10%) }
    60% { transform:translate(15%, 0%) }
    70% { transform:translate(0%, 15%) }
    80% { transform:translate(3%, 35%) }
    90% { transform:translate(-10%, 10%) }
}



/* ----------------------------------------------------------------------------------------------------
* Custom Cursor
* ---------------------------------------------------------------------------------------------------- */
.hovered-btn {
  display: none;
  text-align: center;
  color: var(--color-white);
}

.addtocalendar {
  margin-top: -14px;
}

.custom-cursor {
  position: absolute;
  background-color: var(--color-nudelight);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  margin-left: -10px;
  margin-top: -10px;
  pointer-events: none;
  z-index: 10000;
  transition-property: width, height, background, border, margin-left, margin-top, border-radius, background-size, transform, rotate, translate, clip-path;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  border: 0px solid white;
  display: flex;
  align-items: center;
  justify-content: center;
  mix-blend-mode: difference;
}

.page-template-page-savethedate .custom-cursor {
  mix-blend-mode: normal;
}

.custom-cursor .ball {
  position: absolute;
  width: 0px;
  height: 0px;
  background: black;
  border-radius: 100%;
  transition: all .3s ease;
}

.custom-cursor.activemenu {
  width: 120px;
  height: 120px;
  margin-left: -50px;
  margin-top: -50px;
  /* background: var(--color-dark); */
  background: linear-gradient(124deg, #ff2400, #e81d1d, #e8b71d, #e3e81d, #1de840, #1ddde8, #2b1de8, #dd00f3, #dd00f3);
  background-size: 500% 100%;  
  padding:20px;

  animation: create-rainbow-gradient-shift 5s ease infinite;
}

  @keyframes create-rainbow-gradient-shift{
    0%, 100% {background-position:0% 50%}
    50% {background-position:100% 100%}
}



/* Click Effect */
.custom-cursor.activemenu.animated {
  animation: pulse 0.7s;
}
@keyframes pulse {
  0% {
    box-shadow: 0px 0px 0px 0px #2382dc;
 }
  100% {
    box-shadow: 0px 0px 5px 25px rgba(35,130,220,0);
 }
}


/* ----------------------------------------------------------------------------------------------------
* Trail Img Effect
* ---------------------------------------------------------------------------------------------------- */
.content {
  position: relative;
  overflow: hidden;
}

.content__img {
	max-width: 200px;
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
  border-radius: 10px;
  pointer-events: none;
  will-change: transform, opacity;
  z-index: 8;
}


/* ----------------------------------------------------------------------------------------------------
* 3d effect
* ---------------------------------------------------------------------------------------------------- */
.perspective {
  width: 100%;
  perspective: 1000px;
}
#top {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: auto;
}

.card {
  width: 400px;
  height: 600px;
  margin: auto;
  box-shadow: 0px 0px 50px -20px #a5a5a5; 
  transform-style: preserve-3d;
  transition: transform .05s linear;
  animation: float 5s ease infinite;
}



@keyframes float {
  0%, 100% { margin-top: 0; }
  50% { margin-top: -40px; }
}

.card .thumb {
  background-size: cover;
  height: 100%;
  width: 100%;
  /* border-radius: 15px; */
}
.card .thumb:after {
  background: inherit;
  content: '';
  display: block;
  position: absolute;
  left: 0px;
  top: 5px;
  width: 100%;
  height: 100%;
  z-index: -1;
  filter: blur(20px);
  opacity: 1;
}


.card .nombres {
  position: absolute;
  top: 34px;
  right: 20px;
  transform: translateZ(20px);
}

.card .nombres svg, .card .fecha svg, .card .save svg {
  width: 300px;
  /* width: 28vw; */
  height: auto;
}


.card .fecha {
  position: absolute;
  top: 227px;
  left: 60px;
  transform: translateZ(40px);
}

.card .save {
  position: absolute;
  bottom: 22px;
  left: 30px;
  transform: translateZ(20px);
}





/* ----------------------------------------------------------------------------------------------------
* Top and bottom secctions
* ---------------------------------------------------------------------------------------------------- */
section.top {
  position: absolute;
  top: 0;
  left: 0;
  padding:20px;
  width: 100vw;
}
section.bottom {
  position: absolute;
  /* right: 20px; */
  bottom: 0;
  width: 100vw;
  justify-content: space-between;
  align-items: center;
  padding: 20px;
}

#atcb-reference {
  display: none;
}



.preloader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--color-dark);
  overflow: hidden;
  z-index: 100;
}

.preloader .preloader-container {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 1em;
  overflow: hidden;
  opacity: 0;
}
.preloader .preloader-container .c {
  justify-content: center;
}

.preloader .preloader-container svg, .preloader-text {
  position: absolute;
}

.preloader .preloader-container svg path {
  stroke: #fff; 
}

/* .preloader-text.one {
  top: 10%;
}

.preloader-text.two {
  bottom: 10%;
} */



/* ----------------------------------------------------------------------------------------------------
* Responsive
* ---------------------------------------------------------------------------------------------------- */
@media screen and ( max-width: 1024px ),
       screen and ( max-height: 683px ) {
  html {
    width: 100vw;
    height: 100%;
  }
  .card {
    width: 325px;
    height: 500px;
  }

  .card .nombres svg, .card .fecha svg, .card .save svg {
    width: 270px;
  }

  .card .nombres {
    top: 30px;
    right: 18px;
  }
  .card .save {
    bottom: 22px;
    left: 18px;
  }

  .card .fecha {
    top: 184px;
    left: 22px;
  }


}

@media screen and (max-width: 768px) {
  .custom-cursor { display: none; }
  p:not(:last-child) { margin-bottom: 10px;}

  #top-navigation { padding-top: 3%; padding-bottom: 3%; }
  #top-navigation .container div:first-child { gap:10px;}

  .floating-nav { background: transparent; bottom: 0; width: 100%;}
  .floating-nav p { display: none; }
  .floating-nav .btn { width: 100%; font-size: initial; }


  .hero-section { flex-direction: column-reverse; padding: 20% 5% 10%; gap: 40px; }
  p.hero-text { letter-spacing: -5px; margin-bottom: 10px; }
  .hero-section.v2 { padding: 30% 5% 6% !important; }
  .hero-section.v2 .col-left p.hero-text { font-size: 21vw; letter-spacing: -7px; }
  p.hero-text.second-line { margin-left: 0; }
  .hero-section.v2 p.hero-subtext {     font-size: 11vw; }
  .fullimage img { height: 50vh; object-fit: cover; }
  p.hero-subtext::before { margin-right: 20px; top: -7px; }
  .hero-section.v2 p.hero-subtext::before { width: var(--width-m); }

  .marquee-inner { font-size: 4vw; }
  .marquee { padding: 3%; }

  .btn, .btn a { font-size: 4vw !important; letter-spacing: 0; }
  .btn.mapa a::after { width: 4vw; height: 4vw; }

  .main-info-block { padding: 5%; }
  .main-info-block .row, .main-info-block .timeline, .bloque-3.alignwide, .seccion-cta { flex-direction: column; }
  .main-info-block .row .info { padding-top: 0; }
  .main-info-block .row-2 { flex-direction: column; margin-top: -2%; align-items: flex-start; }
  .main-info-block .row-2 h2 { font-size: 17vw; letter-spacing: -4px; line-height: .9;  }
  .main-info-block .row-2 > .wp-block-group { padding-left: 0 !important;}
  .main-info-block .timeline h4 { line-height: 1;}
  .wp-container-core-group-is-layout-6 { padding-left: 0 !important; }
  .main-info-block .timeline .fiesta::after { width: 6vw; height: 9vw; }
  .main-info-block .timeline { padding: 18% 5%; }
  .btn.btn-link a { text-align: left; line-height: 1.2; font-size: 3vw !important; }

  .bloque-3.alignwide { flex-direction: column-reverse;}
  .bloque-3.alignwide figure { width: 39%; align-self: flex-end;  }


  h2 { font-size: 20vw; }
  h2.instrument { letter-spacing: -4px; margin-left: 10px; }
  h2.twentyfive::before { margin-right: 10px; width: 32vw;  }
  h2.twentyfive { line-height: .9;  }
  .small-h2 h2 { font-size: 10vw; letter-spacing: -2px; line-height: .9; }
  .small-h2 h2.instrument { letter-spacing: -1px;}

  h3, details p, details ul li, details summary, summary::marker { font-size: 5vw ;}
  h3.big { font-size: 7vw; margin-bottom: 10px; }
  .seccion-cta h3 { font-size: 13vw; }
  h4 { font-size: 8vw;}
  h6 { font-size: 5vw;}
  .tag-ciudad { font-size: 4vw; }
  .ft-names { font-size: 22vw; letter-spacing: -5px; }



  .alignwide { padding: 15% 5%; }
  .width-60 { width: 100%; }

  .card-container { white-space: nowrap; overflow-x: scroll; -webkit-overflow-scrolling: touch; width: 100%; scroll-snap-type: x mandatory; overflow-y: hidden; }
  .card-container .hotel-card { flex: 0 0 auto; width: 82%; flex-shrink: 0; scroll-snap-align: start; }
  .card-container .hotel-card:last-child { margin-right: 10%; }

  details { padding: 5% 0; }
  .seccion-cta .img-duki, .seccion-cta .img-ron { width: 40%;}
  .seccion-cta { gap: 30px; }
   
  .ft-main .row.first { padding: 5%; flex-direction: column;}
  .ft-names.second { margin-right: 0 ;}
  .ft-names:not(:last-child) { margin-bottom: 10px; }
  .ft-right-col { width: 70%; margin-top: 20px; }

  .main-menu .navigation { flex-direction: column; gap: 10px; }
  .ft-main .row.second { padding: 5%; }
  .ft-main .main-menu .navigation > li > a { text-align: left; line-height: 1; }


  .popup-content { width: 90%; padding: 7%; }
  #forminator-module-36 input, #forminator-module-36 .forminator-label[class*="forminator-floating-"], .forminator-field-radio .forminator-label, #forminator-module-36 .forminator-button-submit { font-size: 14px !important; }
  #forminator-module-36 .forminator-radio-label { font-size: 16px !important; }
  .popup-content .title { font-size: 9vw; letter-spacing: 0; line-height: 1;}
  #forminator-module-36 { margin-top: 10px; }
  .forminator-ui.forminator-custom-form[data-grid=open] .forminator-col:not(:last-child) { margin-bottom: 10px !important;}
 
 

}