@charset "UTF-8";
/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   VARIABLES GLOBALES
   ======================================== */
:root {
  --primary: #3eb3e7;
}

@font-face {
  /*font-family: 'News Gothic BT Bold', sans-serif;*/
  font-family: "helvetica neue lt 45 light";
  font-style: normal;
  font-weight: normal;
  src: url("./fonts/nuevas/HelveticaNeueLT-Light?#iefix") format("eot"), url("./fonts/nuevas/HelveticaNeueLT-Light.woff") format("woff"), url("./fonts/nuevas/HelveticaNeueLT-Light.woff2") format("woff2"), url("./fonts/nuevas/HelveticaNeueLT-Light.ttf") format("truetype"), url("./fonts/nuevas/HelveticaNeueLT-Light.svg") format("svg");
}
.text-primary {
  color: var(--primary);
}

/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
  VARIABLES
   ======================================== */
/* _fonts.scss */
@font-face {
  font-family: "Adobe Garamond Pro";
  font-style: normal;
  font-weight: normal;
  src: url("../fonts/AdobeGaramondPro/AdobeGaramondPro-Regular.woff2") format("woff2"), url("../fonts/AdobeGaramondPro/AdobeGaramondPro-Regular.woff") format("woff"), url("../fonts/AdobeGaramondPro/AdobeGaramondPro-Regular.ttf") format("truetype");
}
@font-face {
  font-family: "Helvetica Neue LT 45 Light";
  font-style: normal;
  font-weight: normal;
  src: url("../fonts/nuevas/HelveticaNeueLT-Light.woff2") format("woff2"), url("../fonts/nuevas/HelveticaNeueLT-Light.woff") format("woff"), url("../fonts/nuevas/HelveticaNeueLT-Light.ttf") format("truetype");
}
@font-face {
  font-family: "Helvetica Neue LT 95 Black";
  font-style: normal;
  font-weight: 900;
  src: url("../fonts/nuevas/HelveticaNeueLT-Black.woff2") format("woff2"), url("../fonts/nuevas/HelveticaNeueLT-Black.woff") format("woff"), url("../fonts/nuevas/HelveticaNeueLT-Black.ttf") format("truetype");
}
/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   ESTILOS BASE Y ELEMENTOS GENERALES
   ======================================== */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  text-decoration: none;
  color: inherit;
  transition: all 0.3s ease;
}
a:hover {
  color: #3eb3e7;
}

ul {
  list-style: none;
}

#page-loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 99999;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

#page-loader.hidden {
  opacity: 0;
  visibility: hidden;
}

.spinner {
  width: 50px;
  height: 50px;
  border: 5px solid #ccc;
  border-top: 5px solid #3eb3e7;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

html::-webkit-scrollbar {
  width: 0.5rem;
}

html::-webkit-scrollbar-track {
  background: transparent;
}

html::-webkit-scrollbar-thumb {
  background: #196db6;
  border-radius: 5rem;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.container {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 1rem;
}

h1,
h2,
h3,
h4,
h5 {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 1rem;
  color: #383637;
  font-size: 34px;
}

h1 span,
h2 span,
h3 span {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  font-weight: 600;
  color: #3eb3e7;
}

.btn {
  display: inline-block;
  border: none;
  border-radius: 50px;
  font-family: "Helvetica Condensed", Arial, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  padding: 0.5rem 1.5rem;
  cursor: pointer;
  transition: all 0.3s ease;
}

.btn-amarillo {
  background-color: #fecb32;
  color: #fff;
}
.btn-amarillo:hover {
  background-color: rgb(27.8930875576, 163.8718894009, 224.3069124424);
}

.btn-celeste {
  background-color: #3eb3e7;
  color: #fff;
}
.btn-celeste:hover {
  background-color: rgb(27.8930875576, 163.8718894009, 224.3069124424);
}

.btn-gris {
  background-color: #b6b2b2;
  color: black;
}
.btn-gris:hover {
  background-color: rgb(162.144, 157.056, 157.056);
}

/**********************
Ws botón redondo con tooltip ws-tooltip
***********************/
#chat-ws-redondo.ws.tooltip {
  position: fixed;
  bottom: 13px;
  right: 40px;
  width: 60px;
  height: 60px;
  border-radius: 50% !important;
  cursor: pointer;
  display: block;
  -webkit-box-shadow: 0px 0px 20px 0px rgba(91, 91, 91, 0.5);
  box-shadow: 0px 0px 20px 0px rgba(91, 91, 91, 0.5);
  z-index: 999;
  background: #1ca550;
  padding: 8px 4px;
  opacity: 1;
}

#chat-ws-redondo.ws.tooltip img {
  padding-left: 0px;
  padding-top: 0px;
  width: 100%;
}

#chat-ws-redondo.ws.tooltip i {
  font-size: 44px;
  color: white;
}

.ws.tooltip .tooltiptext {
  visibility: hidden;
  width: 120px;
  background-color: #1ca550;
  color: #fff;
  text-align: center;
  border-radius: 6px;
  padding: 5px 0;
  position: absolute;
  z-index: 1;
  bottom: 125%;
  left: 50%;
  margin-left: -60px;
  opacity: 0;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

.ws.tooltip .tooltiptext::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -5px;
  border-width: 5px;
  border-style: solid;
  border-color: #1ca550 transparent transparent transparent;
}

.ws.tooltip:hover .tooltiptext {
  visibility: visible;
  opacity: 1;
}

.section-paseos {
  background: #fff;
  position: relative;
}

.section-paseos .image-wrapper {
  position: relative;
  display: inline-block;
}

.section-paseos .image-wrapper::after {
  content: "";
  position: absolute;
  top: 20px;
  left: 20px;
  right: -20px;
  bottom: -20px;
  border: 2px solid #009FE3;
  z-index: -1;
}

.section-paseos .subtitulo {
  color: #3eb3e7;
  font-style: italic;
  text-transform: none;
  font-size: 1.8rem;
  font-family: "Adobe Garamond Pro", serif;
  display: inline-block;
  margin-bottom: 10px;
  font-weight: 700;
}

.section-paseos h1 {
  font-size: 38px;
  font-weight: 700;
  color: #333;
  margin-bottom: 30px;
  line-height: 1.2;
}

.section-paseos h1 span {
  color: #00AEEF;
}

.lista-paseos {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.lista-paseos .item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px;
}

.lista-paseos .info {
  display: flex;
  align-items: center;
  gap: 0px;
  color: #333;
  font-size: 18px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: -0.05rem;
}

.lista-paseos .info i {
  color: #00AEEF;
  font-size: 18px;
}

/* RESPONSIVE */
@media (max-width: 768px) {
  .lista-paseos .item {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }
  .section-paseos h1 {
    font-size: 28px;
  }
}
.img-border {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 500px;
  margin-bottom: 20px;
}

.img-border::before {
  position: absolute;
  content: "";
  top: 1rem;
  left: 4rem;
  right: 9rem;
  bottom: -2rem;
  border: 5px solid #3eb3e7;
  z-index: 1;
}

.img-border img {
  position: absolute;
  top: 3rem;
  left: 2rem;
  width: 100%;
  height: 100%;
  object-fit: contain;
  z-index: 2;
}

@media (max-width: 1500px) {
  .img-border::before {
    position: absolute;
    content: "";
    top: 1rem;
    left: 3rem;
    right: 1rem;
    bottom: -2rem;
    border: 5px solid #3eb3e7;
    z-index: 1;
  }
  .img-border img {
    position: absolute;
    top: 3rem;
    left: 2rem;
    width: 100%;
    height: 100%;
    object-fit: contain;
    z-index: 2;
  }
}
@media (max-width: 991px) {
  .img-border::before {
    position: absolute;
    content: "";
    top: 1rem;
    left: 7rem;
    right: 5rem;
    bottom: -2rem;
    border: 5px solid #3eb3e7;
    z-index: 1;
  }
  .img-border img {
    position: absolute;
    top: 3rem;
    left: 2rem;
    width: 100%;
    height: 100%;
    object-fit: contain;
    z-index: 2;
  }
}
/* RESPONSIVE */
@media (max-width: 767px) {
  .img-border img {
    position: absolute;
    top: 2rem;
    left: 0rem;
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
    object-fit: contain;
    z-index: 2;
  }
  .img-border::before {
    position: absolute;
    content: "";
    top: 2rem;
    left: -1rem;
    right: -1rem;
    bottom: -2rem;
    border: 5px solid #3eb3e7;
    z-index: 1;
  }
  .img-border {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 700px;
    margin-bottom: 20px;
  }
}
.color-gris {
  color: #b6b2b2;
  font-size: 24px;
}

@media (max-width: 521px) {
  .img-border {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 500px;
    margin-bottom: 20px;
  }
}
.internas {
  padding-top: 150px !important;
}

/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   HEADER
   ======================================== */
header {
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 999;
  background-color: transparent;
  transition: all 0.4s ease;
}
header .logo {
  position: relative;
}
header .logo img {
  height: 60px;
  transition: opacity 0.3s ease;
}
header .logo .logo-color {
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
}
header nav a {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  font-weight: 500;
  color: #fff;
  text-transform: uppercase;
  position: relative;
}
header nav a:hover {
  color: #3eb3e7;
}
header .menu-toggle {
  color: #fff;
  font-size: 16px;
  text-transform: uppercase;
}
header {
  /* Dropdown desktop */
}
header .dropdown {
  position: relative;
}
header .dropdown .dropdown-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  background: #fff;
  border: none;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  padding: 0.5rem 0;
  min-width: 200px;
  z-index: 1001;
}
header .dropdown .dropdown-menu a {
  color: #383637;
  display: block;
  padding: 8px 16px;
  font-size: 15px;
  text-transform: none;
}
header .dropdown .dropdown-menu a:hover {
  background: #3eb3e7;
  color: #fff;
}
header .dropdown:hover .dropdown-menu {
  display: block;
}
header.scrolled {
  background-color: #fff;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}
header.scrolled .logo .logo-blanco {
  opacity: 0;
}
header.scrolled .logo .logo-color {
  opacity: 1;
}
header.scrolled nav a,
header.scrolled .menu-toggle {
  color: #383637;
}
header.scrolled .menu-toggle {
  background: #196db6 !important;
  color: white !important;
  padding: 5px 10px;
  border-radius: 50px;
}
header.scrolled .dropdown .dropdown-menu a:hover {
  background: #3eb3e7;
  color: #fff;
}

/* MENÚ MÓVIL */
.mobile-menu {
  position: fixed;
  top: 0;
  right: -100%;
  width: 300px;
  height: 100vh;
  background-color: #196db6;
  color: #fff;
  padding: 2rem;
  transition: right 0.4s ease;
  z-index: 1000;
  overflow-y: auto;
}
.mobile-menu.active {
  right: 0;
}
.mobile-menu .close-menu {
  background: none;
  border: none;
  color: #fff;
  font-size: 24px;
  position: absolute;
  top: 20px;
  right: 20px;
}
.mobile-menu ul {
  margin-top: 3rem;
}
.mobile-menu ul li {
  margin-bottom: 1rem;
}
.mobile-menu ul li a {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  font-size: 18px;
  color: #fff;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.mobile-menu ul li a:hover {
  color: #fecb32;
}
.mobile-menu ul li {
  /* Submenú móvil */
}
.mobile-menu ul li.has-submenu {
  position: relative;
  /* flecha solo en primer nivel */
}
.mobile-menu ul li.has-submenu > a::after {
  content: "\f107"; /* caret-down */
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 14px;
  transition: transform 0.3s ease;
}
.mobile-menu ul li.has-submenu .submenu {
  display: none;
  margin-top: 0.5rem;
  margin-left: 1rem;
}
.mobile-menu ul li.has-submenu .submenu a {
  font-size: 16px;
  color: #fff;
  opacity: 0.9;
}
.mobile-menu ul li.has-submenu .submenu a:hover {
  color: #fecb32;
}
.mobile-menu ul li.has-submenu .submenu {
  /* quita flecha de los internos */
}
.mobile-menu ul li.has-submenu .submenu li a::after {
  content: none !important;
}
.mobile-menu ul li.has-submenu.open .submenu {
  display: block;
}
.mobile-menu ul li.has-submenu.open > a::after {
  transform: rotate(180deg);
}
.mobile-menu .mobile-buttons .btn {
  width: 100%;
}
.mobile-menu .mobile-flags img {
  width: 28px;
}

/* Redes flotantes */
.social-fixed {
  position: fixed;
  top: 50%;
  right: 15px;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 1100;
}
.social-fixed a {
  width: 42px;
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: #fff;
  font-size: 18px;
  transition: all 0.3s ease;
}
.social-fixed a.facebook {
  background: #1877f2;
}
.social-fixed a.instagram {
  background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
}
.social-fixed a.tiktok {
  background: #000;
}
.social-fixed a:hover {
  transform: scale(1.1);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

/* Flecha del submenú móvil */
.mobile-menu > ul > li.has-submenu > a {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.mobile-menu > ul > li.has-submenu > a::after {
  content: "\f078";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  font-size: 14px;
  transition: transform 0.3s ease;
}

.mobile-menu > ul > li.has-submenu.open > a::after {
  transform: rotate(180deg);
}

/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   HERO
   ======================================== */
/* HERO INDEX  */
#hero.videoWrapper {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%; /* 16:9 */
  height: 0;
  overflow: hidden;
  background: #000;
}
#hero.videoWrapper .video-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
#hero.videoWrapper .video-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
  pointer-events: none;
}
#hero.videoWrapper .hero-content {
  bottom: 15%;
  left: 5%;
  z-index: 3;
  padding: 10px;
  color: #fff;
}
#hero.videoWrapper .hero-content h1 {
  font-family: "Adobe Garamond Pro", serif;
  font-size: 7rem;
  color: #fecb32;
  line-height: 1;
  margin: 0;
  font-style: italic;
}
#hero.videoWrapper .hero-content h2 {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  color: #fff;
  font-size: 4rem;
  line-height: 1;
  letter-spacing: -0.1rem;
}
#hero.videoWrapper .hero-overlay {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.25);
}
@media (max-width: 992px) {
  #hero.videoWrapper .hero-content {
    bottom: 12%;
    left: 4%;
  }
  #hero.videoWrapper .hero-content h1 {
    font-size: calc(56px + 0.6vw);
    margin-bottom: -10px;
  }
  #hero.videoWrapper .hero-content h2 {
    font-size: calc(28px + 1.2vw);
  }
}
@media (max-width: 576px) {
  #hero.videoWrapper .hero-content {
    bottom: 8%;
    left: 4%;
  }
}

/* HERO INTERNAS */
#hero-ficha.videoWrapper {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%; /* 16:9 */
  height: 0;
  overflow: hidden;
  background: #000;
}
#hero-ficha.videoWrapper .video-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
#hero-ficha.videoWrapper .video-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
  pointer-events: none;
}
#hero-ficha.videoWrapper .hero-content {
  z-index: 3;
  padding: 10px;
  color: #fff;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
}
#hero-ficha.videoWrapper .hero-content h1 {
  font-family: "Adobe Garamond Pro", serif;
  font-size: 4rem;
  color: #fecb32;
  line-height: 1;
  margin: 0;
  font-style: italic;
}
#hero-ficha.videoWrapper .hero-content h2 {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  color: #fff;
  font-size: 2rem;
  line-height: 1;
  letter-spacing: -0.1rem;
}
#hero-ficha.videoWrapper .hero-overlay {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.25);
}
@media (max-width: 992px) {
  #hero-ficha.videoWrapper .hero-content h1 {
    font-size: 1.5rem;
    line-height: 2rem;
    margin-bottom: 10px;
  }
  #hero-ficha.videoWrapper .hero-content h2 {
    font-size: 1.3rem;
  }
}

/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   POPUPS (PROMO + RESIDENCIA)
   ======================================== */
.popup {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.75);
  display: none;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  backdrop-filter: blur(4px);
}
.popup .popup-content {
  position: relative;
  background-color: #fff;
  border-radius: 12px;
  text-align: center;
  padding: 30px;
  max-width: 700px;
  width: 90%;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
  animation: fadeInUp 0.4s ease forwards;
  margin: 5% auto;
}
.popup .popup-content img {
  width: 100%;
  height: auto;
  border-radius: 8px;
  display: block;
}
.popup .popup-content p {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 20px;
  color: #222;
}
.popup .popup-content .botones {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-top: 15px;
}
.popup .popup-content .botones button {
  padding: 10px 25px;
  font-size: 1rem;
  font-weight: 500;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.3s ease;
}
.popup .popup-content .botones button#btn-si {
  background-color: #ffca00;
  color: #000;
}
.popup .popup-content .botones button#btn-si:hover {
  background-color: #e6b800;
}
.popup .popup-content .botones button#btn-no {
  background-color: #00bcd4;
  color: #fff;
}
.popup .popup-content .botones button#btn-no:hover {
  background-color: #009fb6;
}
.popup .popup-content .mensaje-error {
  color: #d32f2f;
  font-size: 0.95rem;
  margin-top: 15px;
  display: none;
}
.popup .popup-content .close-popup {
  position: absolute;
  top: 10px;
  right: 10px;
  background: none;
  border: none;
  font-size: 30px;
  color: #444;
  cursor: pointer;
  line-height: 1;
  transition: all 0.2s ease;
}
.popup .popup-content .close-popup:hover {
  color: #000;
  transform: scale(1.1);
}

/* ===== Animación ===== */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/* ===== Responsividad ===== */
@media (max-width: 480px) {
  .popup .popup-content {
    padding: 20px;
  }
  .popup .popup-content p {
    font-size: 1.1rem;
  }
  .popup .popup-content .botones {
    flex-direction: column;
    gap: 10px;
  }
  .popup .popup-content .botones button {
    width: 100%;
  }
  .popup .popup-content .close-popup {
    font-size: 26px;
  }
}
/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   CAROUSEL EXPERIENCIAS
   ======================================== */
.section-experiencias {
  position: relative;
  overflow: hidden;
}
.section-experiencias .bloque-experiencia {
  position: relative;
  background-color: #fff;
  border-radius: 16px;
  padding: 1.5rem;
  border: dotted 1px #dedede;
  height: 100%;
  overflow: visible;
  /* visible para permitir ver las flechas */
  min-height: 800px;
}
.section-experiencias .bloque-experiencia .titulo-seccion {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  font-size: 1.3rem;
  color: #383637;
  margin: 0;
  text-transform: uppercase;
}
.section-experiencias .bloque-experiencia .titulo-seccion span {
  font-family: "Adobe Garamond Pro", serif;
  color: #3eb3e7;
  font-style: italic;
  text-transform: none;
  font-size: 1.8rem;
}
.section-experiencias .bloque-experiencia .btn {
  font-size: 0.9rem;
  font-weight: 600;
  padding: 0.5rem 1rem;
  border-radius: 30px;
  text-transform: uppercase;
  white-space: nowrap;
}
.section-experiencias .bloque-experiencia .btn.btn-amarillo {
  background-color: #fecb32;
  color: #fff;
}
.section-experiencias .bloque-experiencia .btn.btn-amarillo:hover, .section-experiencias .bloque-experiencia .btn.btn-amarillo:active, .section-experiencias .bloque-experiencia .btn.btn-amarillo:focus {
  background-color: #3eb3e7;
  color: #fff;
}
.section-experiencias .bloque-experiencia .btn.btn-celeste {
  background-color: #3eb3e7;
  color: #fff;
}
.section-experiencias .bloque-experiencia .btn.btn-celeste:hover, .section-experiencias .bloque-experiencia .btn.btn-celeste:active, .section-experiencias .bloque-experiencia .btn.btn-celeste:focus {
  background-color: #fecb32;
  color: #fff;
}
.section-experiencias .bloque-experiencia .swiper {
  width: 100%;
  overflow: hidden;
  padding: 10px 0 50px;
  position: relative;
  z-index: 1;
  /* para que las flechas queden arriba */
}
.section-experiencias .bloque-experiencia .swiper-wrapper {
  display: flex;
  align-items: stretch;
}
.section-experiencias .bloque-experiencia .swiper-slide {
  height: auto;
  display: flex;
  flex-shrink: 0;
  box-sizing: border-box;
}
.section-experiencias .bloque-experiencia .card-experiencia {
  display: flex;
  flex-direction: column;
  background: #fff;
  overflow: hidden;
  height: 100%;
  transition: transform 0.3s ease;
  width: 100%;
}
.section-experiencias .bloque-experiencia .card-experiencia:hover {
  transform: translateY(-5px);
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.08);
}
.section-experiencias .bloque-experiencia .card-experiencia img {
  height: 200px;
  object-fit: cover;
  width: 100%;
}
.section-experiencias .bloque-experiencia .card-experiencia .contenido {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 1rem;
  justify-content: space-between;
}
.section-experiencias .bloque-experiencia .card-experiencia .contenido h4 {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  color: #383637;
  font-size: 1.1rem;
  margin-bottom: 0.5rem;
}
.section-experiencias .bloque-experiencia .card-experiencia .contenido .iconos-listado {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-content: center;
  justify-content: flex-start;
  align-items: center;
}
.section-experiencias .bloque-experiencia .card-experiencia .contenido .iconos-listado .cada-icono {
  margin: 10px 5px 10px 0px;
}
.section-experiencias .bloque-experiencia .card-experiencia .contenido .iconos-listado .cada-icono img {
  height: auto;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  max-width: 35px;
}
.section-experiencias .bloque-experiencia .card-experiencia .contenido p {
  flex-grow: 1;
  font-size: 0.95rem;
  color: #383637;
  margin-bottom: 1rem;
}
.section-experiencias .bloque-experiencia .card-experiencia .contenido .precios {
  font-size: 0.9rem;
  margin-bottom: 1rem;
}
.section-experiencias .bloque-experiencia .card-experiencia .contenido .precios span {
  display: block;
}
.section-experiencias .bloque-experiencia .card-experiencia .contenido a.btn {
  align-self: flex-start;
  margin-top: auto;
}
.section-experiencias .bloque-experiencia {
  /* Flechas — posicionadas respecto al bloque, no al swiper */
}
.section-experiencias .bloque-experiencia .swiper-button-prev,
.section-experiencias .bloque-experiencia .swiper-button-next {
  position: absolute;
  top: 25%;
  transform: translateY(-50%);
  width: 38px;
  height: 38px;
  background: rgb(62, 179, 231);
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
  color: #fff;
  display: flex !important;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  z-index: 99;
  /* por encima del swiper */
}
.section-experiencias .bloque-experiencia .swiper-button-prev:hover,
.section-experiencias .bloque-experiencia .swiper-button-next:hover {
  background: #3eb3e7;
  color: #fff;
}
.section-experiencias .bloque-experiencia .swiper-button-prev {
  left: -20px;
}
.section-experiencias .bloque-experiencia .swiper-button-next {
  right: -20px;
}
.section-experiencias .bloque-experiencia {
  /* Paginación */
}
.section-experiencias .bloque-experiencia .swiper-pagination {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  text-align: center;
  z-index: 5;
}
.section-experiencias .bloque-experiencia .swiper-pagination-bullet {
  background: #383637;
  opacity: 0.4;
}
.section-experiencias .bloque-experiencia .swiper-pagination-bullet-active {
  opacity: 1;
  background: #3eb3e7;
}
.section-experiencias .swiper-button-next:after,
.section-experiencias .swiper-button-prev:after {
  font-size: 14px !important;
}
@media (max-width: 992px) {
  .section-experiencias .bloque-experiencia {
    padding: 1rem;
    min-height: 100%;
  }
  .section-experiencias .swiper-button-prev,
  .section-experiencias .swiper-button-next {
    display: none !important;
  }
  .section-experiencias .swiper-pagination {
    display: block;
  }
}
.section-experiencias .swiper-button-prev {
  left: 15px !important;
}
.section-experiencias .swiper-button-next {
  right: 15px !important;
}

/* ========================================
   CAROUSEL INDEX
   ======================================== */
.section-carousel {
  position: relative;
  background-color: #fff;
}

.section-carousel .carousel-inner img {
  width: 100%;
  height: auto;
  border-radius: 12px;
}

.section-carousel .carousel-indicators [data-bs-target] {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: #00AEEF;
  opacity: 0.5;
}

.section-carousel .carousel-indicators .active {
  opacity: 1;
}

.section-carousel .carousel-control-prev-icon,
.section-carousel .carousel-control-next-icon {
  filter: invert(100%);
  width: 2rem;
  height: 2rem;
}

.section-carousel .carousel-control-next {
  right: 10px;
}

.section-carousel .carousel-control-prev {
  left: 10px;
}

.section-carousel .carousel-control-prev,
.section-carousel .carousel-control-next {
  width: 8%;
}

.section-carousel .carousel-control-prev,
.section-carousel .carousel-control-next {
  width: 46px;
  height: 46px;
  background: #3eb3e7;
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
  top: 50%;
  transform: translateY(-50%);
  transition: all 0.3s ease;
  opacity: 1;
}

.section-carousel .carousel-control-prev:hover,
.section-carousel .carousel-control-next:hover {
  background: #383637;
}

.section-carousel .carousel-control-prev-icon,
.section-carousel .carousel-control-next-icon {
  width: 20px;
  height: 20px;
  background-size: 100% 100%;
  filter: brightness(0) invert(1);
}

.section-carousel .carousel-control-prev:hover .carousel-control-prev-icon,
.section-carousel .carousel-control-next:hover .carousel-control-next-icon {
  filter: brightness(0) invert(1);
}

@media (max-width: 768px) {
  .section-carousel .carousel-control-prev,
  .section-carousel .carousel-control-next {
    width: 12%;
  }
}
/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   LISTADOS
   ======================================== */
.section-experiencias.internas {
  position: relative;
  overflow: hidden;
}
.section-experiencias.internas .titulo-seccion {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  font-size: 1.3rem;
  color: black;
  margin: 0;
  text-transform: uppercase;
}
.section-experiencias.internas .titulo-seccion span {
  font-family: "Adobe Garamond Pro", serif;
  color: #3eb3e7;
  font-style: italic;
  text-transform: none;
  font-size: 1.8rem;
}
.section-experiencias.internas .bloque-experiencia {
  position: relative;
  background-color: transparent;
  border-radius: 16px;
  padding: 0rem 1.5rem;
  border: dotted 0px #dedede;
  height: 100%;
  overflow: visible;
  /* visible para permitir ver las flechas */
  min-height: auto;
}
.section-experiencias.internas .bloque-experiencia .btn {
  font-size: 0.9rem;
  font-weight: 600;
  padding: 0.5rem 1rem;
  border-radius: 30px;
  text-transform: uppercase;
  white-space: nowrap;
}
.section-experiencias.internas .bloque-experiencia .btn.btn-amarillo {
  background-color: #fecb32;
  color: #fff;
}
.section-experiencias.internas .bloque-experiencia .btn.btn-amarillo:hover, .section-experiencias.internas .bloque-experiencia .btn.btn-amarillo:active, .section-experiencias.internas .bloque-experiencia .btn.btn-amarillo:focus {
  background-color: #3eb3e7;
  color: #fff;
}
.section-experiencias.internas .bloque-experiencia .btn.btn-celeste {
  background-color: #3eb3e7;
  color: #fff;
}
.section-experiencias.internas .bloque-experiencia .btn.btn-celeste:hover, .section-experiencias.internas .bloque-experiencia .btn.btn-celeste:active, .section-experiencias.internas .bloque-experiencia .btn.btn-celeste:focus {
  background-color: #fecb32;
  color: #fff;
}
.section-experiencias.internas .bloque-experiencia .swiper {
  width: 100%;
  overflow: hidden;
  padding: 10px 0 50px;
  position: relative;
  z-index: 1;
  /* para que las flechas queden arriba */
}
.section-experiencias.internas .bloque-experiencia .swiper-wrapper {
  display: flex;
  align-items: stretch;
}
.section-experiencias.internas .bloque-experiencia .swiper-slide {
  height: auto;
  display: flex;
  flex-shrink: 0;
  box-sizing: border-box;
}
.section-experiencias.internas .bloque-experiencia .card-experiencia {
  display: flex;
  flex-direction: column;
  background: #fff;
  overflow: hidden;
  height: 100%;
  transition: transform 0.3s ease;
  box-shadow: -1px -1px 10px 2px rgba(0, 0, 0, 0.1);
  width: 100%;
}
.section-experiencias.internas .bloque-experiencia .card-experiencia:hover {
  transform: translateY(-5px);
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.08);
}
.section-experiencias.internas .bloque-experiencia .card-experiencia img {
  height: 250px;
  object-fit: cover;
  width: 100%;
}
.section-experiencias.internas .bloque-experiencia .card-experiencia .contenido {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 1rem;
  justify-content: space-between;
}
.section-experiencias.internas .bloque-experiencia .card-experiencia .contenido h4 {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  color: #383637;
  font-size: 1.1rem;
  margin-bottom: 0.5rem;
  text-transform: uppercase;
}
.section-experiencias.internas .bloque-experiencia .card-experiencia .contenido .iconos-listado {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-content: center;
  justify-content: flex-start;
  align-items: center;
}
.section-experiencias.internas .bloque-experiencia .card-experiencia .contenido .iconos-listado .cada-icono {
  margin: 10px 5px 10px 0px;
}
.section-experiencias.internas .bloque-experiencia .card-experiencia .contenido .iconos-listado .cada-icono img {
  height: auto;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  max-width: 35px;
}
.section-experiencias.internas .bloque-experiencia .card-experiencia .contenido p {
  flex-grow: 1;
  font-size: 0.95rem;
  color: #383637;
  margin-bottom: 1rem;
}
.section-experiencias.internas .bloque-experiencia .card-experiencia .contenido .precios {
  font-size: 0.9rem;
  margin-bottom: 1rem;
}
.section-experiencias.internas .bloque-experiencia .card-experiencia .contenido .precios span {
  display: block;
}
.section-experiencias.internas .bloque-experiencia .card-experiencia .contenido a.btn {
  align-self: flex-start;
  margin-top: auto;
}
.section-experiencias.internas .bloque-experiencia {
  /* Flechas — posicionadas respecto al bloque, no al swiper */
}
.section-experiencias.internas .bloque-experiencia .swiper-button-prev,
.section-experiencias.internas .bloque-experiencia .swiper-button-next {
  position: absolute;
  top: 25%;
  transform: translateY(-50%);
  width: 38px;
  height: 38px;
  background: rgb(62, 179, 231);
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
  color: #fff;
  display: flex !important;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  z-index: 99;
  /* por encima del swiper */
}
.section-experiencias.internas .bloque-experiencia .swiper-button-prev:hover,
.section-experiencias.internas .bloque-experiencia .swiper-button-next:hover {
  background: #3eb3e7;
  color: #fff;
}
.section-experiencias.internas .bloque-experiencia .swiper-button-prev {
  left: -20px;
}
.section-experiencias.internas .bloque-experiencia .swiper-button-next {
  right: -20px;
}
.section-experiencias.internas .bloque-experiencia {
  /* Paginación */
}
.section-experiencias.internas .bloque-experiencia .swiper-pagination {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  text-align: center;
  z-index: 5;
}
.section-experiencias.internas .bloque-experiencia .swiper-pagination-bullet {
  background: #383637;
  opacity: 0.4;
}
.section-experiencias.internas .bloque-experiencia .swiper-pagination-bullet-active {
  opacity: 1;
  background: #3eb3e7;
}
.section-experiencias.internas .swiper-button-next:after,
.section-experiencias.internas .swiper-button-prev:after {
  font-size: 14px !important;
}
@media (max-width: 992px) {
  .section-experiencias.internas .bloque-experiencia {
    padding: 1rem;
    min-height: 100%;
  }
  .section-experiencias.internas .swiper-button-prev,
  .section-experiencias.internas .swiper-button-next {
    display: none !important;
  }
  .section-experiencias.internas .swiper-pagination {
    display: block;
  }
}
.section-experiencias.internas .swiper-button-prev {
  left: 15px !important;
}
.section-experiencias.internas .swiper-button-next {
  right: 15px !important;
}

/* ========================================
   CAROUSEL INDEX
   ======================================== */
.section-carousel {
  position: relative;
  background-color: #fff;
}

.section-carousel .carousel-inner img {
  width: 100%;
  height: auto;
  border-radius: 12px;
}

.section-carousel .carousel-indicators [data-bs-target] {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: #00AEEF;
  opacity: 0.5;
}

.section-carousel .carousel-indicators .active {
  opacity: 1;
}

.section-carousel .carousel-control-prev-icon,
.section-carousel .carousel-control-next-icon {
  filter: invert(100%);
  width: 2rem;
  height: 2rem;
}

.section-carousel .carousel-control-next {
  right: 10px;
}

.section-carousel .carousel-control-prev {
  left: 10px;
}

.section-carousel .carousel-control-prev,
.section-carousel .carousel-control-next {
  width: 8%;
}

.section-carousel .carousel-control-prev,
.section-carousel .carousel-control-next {
  width: 46px;
  height: 46px;
  background: #3eb3e7;
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
  top: 50%;
  transform: translateY(-50%);
  transition: all 0.3s ease;
  opacity: 1;
}

.section-carousel .carousel-control-prev:hover,
.section-carousel .carousel-control-next:hover {
  background: #383637;
}

.section-carousel .carousel-control-prev-icon,
.section-carousel .carousel-control-next-icon {
  width: 20px;
  height: 20px;
  background-size: 100% 100%;
  filter: brightness(0) invert(1);
}

.section-carousel .carousel-control-prev:hover .carousel-control-prev-icon,
.section-carousel .carousel-control-next:hover .carousel-control-next-icon {
  filter: brightness(0) invert(1);
}

@media (max-width: 768px) {
  .section-carousel .carousel-control-prev,
  .section-carousel .carousel-control-next {
    width: 12%;
  }
}
/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   PROMOS
   ======================================== */
.promo-nuevos {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 3rem;
  margin: 5rem 0;
}
.promo-nuevos .promo-img {
  position: relative;
  flex: 1;
}
.promo-nuevos .promo-img:after {
  content: "";
  position: absolute;
  top: 20px;
  left: 20px;
  width: 100%;
  height: 100%;
  border: 4px solid #ff2579;
  z-index: -1;
}
.promo-nuevos .promo-contenido {
  flex: 1;
}
.promo-nuevos .promo-contenido h2 {
  color: #ff2579;
  font-family: "Helvetica Condensed", Arial, sans-serif;
  font-size: 2rem;
}
.promo-nuevos .promo-contenido h2 span {
  color: #383637;
}
.promo-nuevos .promo-contenido ul {
  margin-top: 1rem;
}
.promo-nuevos .promo-contenido ul li {
  margin-bottom: 0.5rem;
}

/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   VIDEOS
   ======================================== */
.section-videos .video-item {
  overflow: hidden;
  border-radius: 10px;
  position: relative;
  cursor: pointer;
  transition: transform 0.3s ease;
}

.section-videos .video-item img {
  width: 100%;
  transition: transform 0.5s ease;
}

.section-videos .video-item:hover img {
  transform: scale(1.1);
}

.section-videos h1 {
  margin-bottom: 0px;
}

.section-videos h1 span {
  font-family: "Adobe Garamond Pro", serif;
  color: #3eb3e7;
  font-style: italic;
  text-transform: none;
  font-size: 2.8rem;
}

.section-videos .subtitle {
  text-align: center;
  background-color: #3eb3e7;
  text-transform: uppercase;
  padding: 5px;
  letter-spacing: 2px;
  display: table;
  margin: 0 auto;
  font-size: 24px;
  color: white;
  margin-bottom: 10px;
}

#videoModal .modal-content {
  background: transparent;
  box-shadow: none;
}

#videoModal iframe {
  width: 100%;
  height: 100%;
  border: none;
}

/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   FICHA
   ======================================== */
/* BASE */
.section-ficha h1 {
  margin-bottom: 10px;
}

.section-ficha h1 span {
  font-family: "Adobe Garamond Pro", serif;
  color: #3eb3e7;
  font-style: italic;
  text-transform: none;
  font-size: 2.8rem;
}

.section-ficha .subtitle {
  text-align: center;
  background-color: #3eb3e7;
  text-transform: uppercase;
  padding: 5px;
  letter-spacing: 2px;
  display: table;
  margin: 0 auto;
  font-size: 22px;
  color: white;
  margin-bottom: 10px;
  margin-top: 10px;
}

.aclaracion {
  background-color: #3eb3e7;
  border-radius: 50px;
  padding: 7%;
  text-transform: uppercase;
}
.aclaracion h1 {
  margin-bottom: 20px;
}
.aclaracion p {
  font-size: clamp(1.2rem, 1.4vw, 2rem);
  line-height: 1.2;
  font-weight: 600;
}

@media (max-width: 991px) {
  .section-ficha .subtitle {
    font-size: 14px;
  }
}
/* ITINERARIO */
.itinerario {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
}

.itinerario .item {
  margin-bottom: 10px;
}

.itinerario .fila {
  display: flex;
  align-items: center;
  gap: 20px;
}

.itinerario .icono {
  width: 70px;
  height: 70px;
  min-width: 70px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: white;
  position: relative;
}

.itinerario .icono:before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  padding: 3px;
  background: linear-gradient(to bottom, #fecb32, #3eb3e7);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: destination-out;
  mask-composite: exclude;
}

.itinerario .icono img {
  width: 60%;
  height: auto;
  display: block;
}

.itinerario .texto {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.3;
  flex: 1;
}

.itinerario .separador {
  margin-left: 30px;
  margin-top: 5px;
}

.itinerario .separador img {
  display: block;
  width: 12px;
}

/* RESPONSIVE */
@media (max-width: 768px) {
  .itinerario .fila {
    gap: 15px;
  }
  .itinerario .icono {
    width: 60px;
    height: 60px;
    min-width: 60px;
  }
  .itinerario .texto {
    font-size: 20px;
  }
  .itinerario .separador {
    margin-left: 30px;
  }
}
@media (max-width: 480px) {
  .itinerario .texto {
    font-size: 18px;
  }
}
/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   SLIDER FICHA
   ======================================== */
/* SLIDER FICHA */
#slider-ficha {
  position: relative;
  width: 100%;
  height: 700px;
  overflow: hidden;
  background: #000;
}

#slider-ficha .slider-ficha-container {
  position: relative;
  width: 100%;
  height: 100%;
}

/* SLIDER PRINCIPAL */
#slider-ficha .slider-principal {
  width: 100%;
  height: 100%;
}

#slider-ficha .slider-principal .swiper-slide {
  background-size: cover;
  background-position: center;
  position: relative;
}

/* TEXTO */
#slider-ficha .slider-texto {
  position: absolute;
  z-index: 10;
  left: 5%;
  top: 20%;
  max-width: 28%;
  color: white;
}

#slider-ficha .slider-texto .titulo {
  font-family: "Adobe Garamond Pro", serif;
  font-style: italic;
  text-transform: none;
  font-size: clamp(3rem, 4vw, 8rem);
  color: #fecb32;
  margin-bottom: 10px;
}

#slider-ficha .slider-texto .subtitulo {
  font-size: 30px;
  margin-bottom: 15px;
  color: white;
}

#slider-ficha .slider-texto .descripcion {
  font-size: 16px;
  line-height: 1.4;
}

/* THUMBNAILS */
#slider-ficha .slider-thumbs {
  position: absolute;
  bottom: 80px;
  right: 5%;
  width: 60%;
  padding-left: 10px;
  padding-right: 10px;
  box-sizing: border-box;
}

#slider-ficha .slider-thumbs .swiper-wrapper {
  padding-left: 5px;
}

#slider-ficha .slider-thumbs .swiper-slide {
  width: 150px;
  height: 150px;
  background-size: cover;
  background-position: center;
  border-radius: 15px;
  opacity: 0.6;
  cursor: pointer;
  transition: all 0.3s ease;
}

#slider-ficha .slider-thumbs .swiper-slide {
  overflow: hidden;
  border-radius: 8px;
}

#slider-ficha .slider-thumbs .swiper-slide img {
  transition: transform 0.3s ease;
}

#slider-ficha .slider-thumbs .swiper-slide-thumb-active {
  opacity: 1;
}

#slider-ficha .slider-thumbs .swiper-slide-thumb-active img {
  transform: scale(1.08);
}

#slider-ficha .slider-thumbs .swiper-slide {
  box-sizing: border-box;
  transition: opacity 0.3s ease;
}

/* NAVEGACIÓN */
#slider-ficha .slider-navegacion {
  position: absolute;
  bottom: 40px;
  left: 5%;
  display: flex;
  gap: 15px;
  z-index: 20;
}

#slider-ficha .slider-prev,
#slider-ficha .slider-next {
  width: 50px;
  height: 50px;
  border: 2px solid white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  cursor: pointer;
}

/* RESPONSIVE */
@media (max-width: 991px) {
  #slider-ficha {
    height: 600px;
  }
  #slider-ficha .slider-texto {
    max-width: 90%;
    top: 10%;
  }
  #slider-ficha .slider-thumbs {
    display: none;
  }
  #slider-ficha .slider-navegacion {
    left: 50%;
    transform: translateX(-50%);
    bottom: 40px;
  }
}
/* PROGRESS BAR + NUMERACIÓN */
#slider-ficha .slider-progress-container {
  position: absolute;
  bottom: 10px;
  right: 5%;
  width: 50%;
  display: flex;
  align-items: center;
  gap: 20px;
  z-index: 2;
}

#slider-ficha .slider-progress-bar {
  flex: 1;
  height: 4px;
  background: rgba(255, 255, 255, 0.3);
  position: relative;
  overflow: hidden;
}

#slider-ficha .slider-progress-bar:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 0%;
  background: #fecb32;
  transition: width 0.5s ease;
}

#slider-ficha .slider-numbers {
  color: white;
  font-size: 20px;
  font-weight: 600;
  min-width: 60px;
  text-align: right;
}

/* RESPONSIVE */
@media (max-width: 991px) {
  #slider-ficha .slider-progress-container {
    display: none;
  }
}
/* EFECTO MODERNO EN SLIDES */
#slider-ficha .slider-principal .swiper-slide {
  overflow: hidden;
}

#slider-ficha .slider-principal .swiper-slide::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: inherit;
  background-size: cover;
  background-position: center;
  transform: scale(1.15);
  transition: transform 4s ease, background-position 4s ease;
  z-index: 1;
  pointer-events: none;
}

#slider-ficha .slider-principal .swiper-slide-active::after {
  transform: scale(1);
  background-position: center top;
}

#slider-ficha .slider-principal .swiper-slide-prev::after {
  transform: scale(1.2);
  background-position: center bottom;
}

#slider-ficha .slider-principal .swiper-slide-next::after {
  transform: scale(1.2);
  background-position: center bottom;
}

#slider-ficha .slider-principal .swiper-slide::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
  z-index: 2;
}

#slider-ficha .slider-texto {
  z-index: 5;
}

/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   CAROUSEL EXPERIENCIAS
   ======================================== */
/* RESERVAS FICHA */
#reserva-formulario {
  max-width: 900px;
  padding: 40px 20px;
  display: flex;
  flex-direction: column;
  gap: 25px;
  margin: 0 auto;
}

#reserva-formulario .titulo-reserva {
  text-align: center;
  font-size: 26px;
  margin-bottom: 30px;
}

/* BLOQUE DE PASOS */
/*
#paso-1,
#paso-2 {
  height: 225px!important;
}
*/
#reserva-formulario .paso {
  margin-bottom: 20px;
  border-radius: 10px;
  background: #ffffff;
  border: 1px solid #e0e0e0;
  transition: all 0.3s ease;
}

/* HEADER DE CADA PASO */
#reserva-formulario .paso-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 15px 20px;
  font-weight: bold;
  font-size: 16px;
  color: #999999;
}

/* HEADER FLECHAS */
#reserva-formulario .paso-header {
  position: relative;
  cursor: pointer;
}

/* Flecha por defecto */
#reserva-formulario .paso-header::after {
  content: "\f107"; /* icono flecha abajo */
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  transition: transform 0.3s ease;
  font-size: 16px;
  color: #999;
}

#reserva-formulario .paso.abierto .paso-header::after {
  transform: translateY(-50%) rotate(180deg);
  color: #3eb3e7;
}

/* NÚMERO DEL PASO */
#reserva-formulario .paso-header .numero {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 2px solid #cccccc;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  color: #cccccc;
}

/* CONTENIDO DEL PASO */
#reserva-formulario .paso-contenido {
  padding: 20px;
  box-shadow: 0 0 12px rgba(0, 0, 0, 0.08);
  border-radius: 0 0 10px 10px;
}

#reserva-formulario .paso-contenido.cerrado {
  display: none;
}

/* ESTADOS DE LOS PASOS */
#reserva-formulario .paso.deshabilitado {
  opacity: 0.5;
  pointer-events: none;
}

#reserva-formulario .paso.activo {
  opacity: 1;
  pointer-events: all;
}

/* PASO COMPLETADO */
#reserva-formulario .paso.completado .paso-header {
  color: #2fb1f3;
}

#reserva-formulario .paso.completado .info-persona .precio {
  color: #2fb1f3;
}

#reserva-formulario .paso.completado .numero {
  border-color: #2fb1f3;
  color: #2fb1f3;
}

/* PASO SIEMPRE ABIERTO (EL 3) */
#reserva-formulario .paso.siempre-abierto {
  opacity: 1 !important;
  pointer-events: all !important;
}

#reserva-formulario .paso.abierto,
#reserva-formulario .paso.cerrado-con-contorno {
  border-color: #0bb0e3;
}

/* BOTONES */
#reserva-formulario .btn {
  margin-top: 40px;
  margin-bottom: 20px;
  float: right;
}

/* ESTILOS PARA CALENDARIO Y CONTENIDOS INTERNOS */
/* #selector-fecha,
#selector-horario,
#selector-personas,
#extras-experiencia {
  min-height: 180px;
} */
/* RESPONSIVE */
@media (max-width: 768px) {
  #reserva-formulario {
    padding: 20px 10px;
  }
  #reserva-formulario .paso-header {
    font-size: 14px;
  }
}
/* CALENDARIO */
#fecha-viaje {
  width: 50%;
  padding: 10px;
  border: 1px solid #ccc;
  border-radius: 8px;
  font-size: 14px;
}

.flatpickr-day.selected {
  background: #47a5ad !important;
  color: #fff !important;
}

.flatpickr-day.dia-no-disponible {
  background: #b6b2b2;
  color: black;
  cursor: not-allowed;
}

.flatpickr-day.pocos-lugares {
  border: 1px solid #ff2579;
}

/* HORARIOS */
/* Contenedor general */
#paso-horarios {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Cada fila */
.horario-opcion {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-size: 16px;
  user-select: none;
}

/* Ocultamos el radio nativo */
.horario-opcion input[type=radio] {
  display: none;
}

/* Círculo personalizado */
.check-personalizado {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid #3eb3e7;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
}

/* Ícono de tilde */
.check-personalizado i {
  color: white;
  font-size: 12px;
  opacity: 0;
  transition: opacity 0.2s ease;
}

/* Texto del horario */
.texto-horario {
  font-size: 16px;
  color: #333;
}

/* ESTADO SELECCIONADO */
.horario-opcion input[type=radio]:checked + .check-personalizado {
  background: #3eb3e7;
  border-color: #3eb3e7;
}

.horario-opcion input[type=radio]:checked + .check-personalizado i {
  opacity: 1;
}

/* PERSONAS */
/* Contenedor de cada renglón */
#reserva-formulario .fila-persona {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 20px;
}

/* Campo gris de cantidad */
#reserva-formulario .campo-cantidad {
  width: 50px;
  height: 50px;
  padding: 6px;
  border-radius: 8px;
  border: 1px solid #ccc;
  text-align: center;
}

/* Bloque derecho con texto + línea + precio */
#reserva-formulario .info-persona {
  display: flex;
  align-items: center;
  flex: 1;
  gap: 10px;
}

/* Tipo de pasajero */
#reserva-formulario .info-persona .tipo {
  white-space: nowrap;
}

/* ESTE ES EL TRUCO 👇 */
/* Línea dinámica que se estira sola */
#reserva-formulario .info-persona .relleno {
  flex: 1;
  height: 1px;
  background: #ccc;
}

/* Precio a la derecha */
#reserva-formulario .info-persona .precio {
  font-weight: bold;
  white-space: nowrap;
}

/* Estado deshabilitado */
#reserva-formulario .fila-persona.deshabilitado .campo-cantidad {
  background: #f2f2f2;
  color: #999;
}

#reserva-formulario .fila-persona.deshabilitado .tipo,
#reserva-formulario .fila-persona.deshabilitado .precio {
  color: #999;
}

/* EXPERIENCIAS */
#reserva-formulario .linea-opcion {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 15px;
}

#reserva-formulario .miniatura {
  width: 50px;
  height: 50px;
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  background: #f1f1f1;
  flex-shrink: 0;
}

#reserva-formulario .miniatura.vacia {
  background: transparent;
}

#reserva-formulario .miniatura img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#reserva-formulario .miniatura .lupa {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.5);
  color: white;
  font-size: 18px;
  opacity: 0;
  transition: all 0.3s ease;
  cursor: pointer;
}

#reserva-formulario .miniatura:hover .lupa {
  opacity: 1;
}

#reserva-formulario .nombre-opcion {
  font-size: 15px;
  min-width: 180px;
  text-transform: uppercase;
}

#reserva-formulario .relleno {
  flex: 1;
  border-bottom: 1px dotted #ccc;
  height: 1px;
}

#reserva-formulario .cantidad {
  width: 50px;
  height: 50px;
  padding: 6px;
  border-radius: 8px;
  border: 1px solid #ccc;
  text-align: center;
}

#reserva-formulario .precio {
  font-weight: bold;
  min-width: 120px;
  text-align: right;
}

/* EXPERIENCIAS POPUP */
.popup-adicional {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

.popup-adicional .popup-contenido {
  background: white;
  padding: 30px;
  max-width: 500px;
  width: 90%;
  border-radius: 15px;
  position: relative;
  text-align: center;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.popup-adicional .popup-imagen {
  width: 100%;
  border-radius: 10px;
  margin-bottom: 15px;
}

.popup-adicional .popup-titulo {
  margin-bottom: 10px;
}

.popup-adicional .popup-texto {
  font-size: 14px;
  margin-bottom: 15px;
}

.popup-adicional .popup-nota {
  font-size: 12px;
  color: #777;
}

.popup-adicional .cerrar-popup {
  position: absolute;
  top: 10px;
  right: 10px;
  cursor: pointer;
  font-size: 18px;
}

.footer-popup {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
}

.footer-popup .rayita {
  flex: 1;
  border-bottom: 1px solid #ccc;
  margin-right: 10px;
}

.footer-popup .precio {
  color: #00a7e1;
  font-weight: bold;
  font-size: 18px;
}

.linea-precio {
  display: flex;
  align-items: center;
  gap: 5px;
  flex: 1; /* que empuje a la derecha en desktop */
}

@media (max-width: 768px) {
  #fecha-viaje {
    width: 100%;
  }
  /* ===== PASO 3 - PERSONAS ===== */
  #reserva-formulario .fila-persona {
    flex-direction: row;
    align-items: center;
    gap: 10px;
  }
  #reserva-formulario .info-persona {
    flex-direction: row;
    align-items: center;
    flex: 1;
  }
  #reserva-formulario .info-persona .tipo {
    white-space: normal;
    max-width: 60%;
  }
  #reserva-formulario .info-persona .relleno {
    display: block;
  }
  #reserva-formulario .info-persona .precio {
    text-align: right;
    white-space: nowrap;
  }
  /* ===== PASO 4 - ADICIONALES ===== */
  #reserva-formulario .linea-opcion {
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    gap: 10px;
  }
  #reserva-formulario .linea-opcion .nombre-opcion {
    white-space: normal;
    max-width: 55%;
  }
  #reserva-formulario .linea-opcion .relleno {
    display: block;
  }
  #reserva-formulario .linea-opcion .precio {
    text-align: right;
    white-space: nowrap;
  }
}
#reserva-formulario input.cantidad,
#reserva-formulario input.campo-cantidad {
  font-size: 16px;
}

/* MENSAJES DE CUPO */
.msg-cupo,
.msg-cupo-aviso {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 8px;
  font-size: 14px;
  line-height: 1.5;
  margin-top: 12px;
  margin-bottom: 4px;
}
.msg-cupo i,
.msg-cupo-aviso i {
  flex-shrink: 0;
  margin-top: 2px;
  font-size: 15px;
}

/* Disponible - azul celeste */
.msg-cupo--info {
  background-color: rgb(234.3658986175, 246.8746543779, 252.4341013825);
  border: 1px solid rgb(130.0391705069, 205.7926267281, 239.4608294931);
  color: rgb(18.3041474654, 107.5368663594, 147.1958525346);
}
.msg-cupo--info i {
  color: #3eb3e7;
}

/* Últimos lugares - amarillo */
.msg-cupo--advertencia {
  background-color: rgb(254.7427184466, 241.6213592233, 202.2572815534);
  border: 1px solid rgb(254.1237864078, 209.4368932039, 75.3762135922);
  color: rgb(124.890776699, 93.8203883495, 0.609223301);
}
.msg-cupo--advertencia i {
  color: rgb(201.0194174757, 151.0097087379, 0.9805825243);
}

/* Sin lugares - rosa/rojo */
.msg-cupo--bloqueado {
  background-color: rgb(255, 251.2, 252.6642201835);
  border: 1px solid rgb(255, 139, 183.6972477064);
  color: rgb(190, 0, 73.2110091743);
}
.msg-cupo--bloqueado i {
  color: #ff2579;
}
.msg-cupo--bloqueado a {
  color: rgb(215.5, 0, 83.0366972477);
  font-weight: bold;
  text-decoration: underline;
}
.msg-cupo--bloqueado a:hover {
  color: #ff2579;
}

/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   CAROUSEL FICHA
   ======================================== */
#carousel-experiencias .swiper-horizontal {
  touch-action: pan-y;
  padding: 44px 0px;
}

#carousel-experiencias {
  padding: 60px 0;
  text-align: center;
  background: #f8f8f8;
}

#carousel-experiencias .titulo-seccion {
  font-size: 22px;
  margin-bottom: 40px;
  text-transform: uppercase;
}

#carousel-experiencias .contenedor-carousel {
  position: relative;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 60px;
}

#carousel-experiencias .swiper-wrapper {
  align-items: stretch;
}

#carousel-experiencias .swiper-slide {
  height: auto;
  display: flex;
}

.card-experiencia {
  background: #ffffff;
  border-radius: 10px;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
  padding: 15px;
  text-align: left;
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
  height: 100%;
  width: 100%;
}

.card-experiencia:hover {
  transform: translateY(-5px);
}

.card-experiencia .imagen {
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  aspect-ratio: 4/3;
}

.card-experiencia .imagen img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
  transition: all 0.4s ease;
}

.card-experiencia:hover .imagen img {
  transform: scale(1.08);
}

.card-experiencia .lupa {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 40px;
  height: 40px;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  cursor: pointer;
  opacity: 0;
  transition: all 0.3s ease;
}

.card-experiencia:hover .lupa {
  opacity: 1;
}

.card-experiencia h3 {
  font-size: 16px;
  margin: 15px 0;
  min-height: 48px;
  text-transform: uppercase;
}

.card-experiencia .footer-card {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 6px;
  margin-top: auto;
  padding: 0 1rem 1rem;
}

/* FLECHAS */
#carousel-experiencias .swiper-button-prev,
#carousel-experiencias .swiper-button-next {
  width: 45px;
  height: 45px;
  border: 2px solid #00a7e1;
  border-radius: 50%;
  color: #00a7e1;
  background: white;
}

#carousel-experiencias .swiper-button-prev:after,
#carousel-experiencias .swiper-button-next:after {
  font-size: 18px;
}

#carousel-experiencias .swiper-button-prev {
  left: 0;
}

#carousel-experiencias .swiper-button-next {
  right: 0;
}

@media (max-width: 1200px) {
  #carousel-experiencias .contenedor-carousel {
    padding: 0 20px;
  }
}
/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   PÁGINA DE CONFIRMACIÓN DE RESERVA
   ======================================== */
#confirmacion-reserva {
  background: #f8f9fa;
  min-height: 100vh;
  padding: 60px 20px;
}

.confirmacion-container {
  max-width: 900px;
  margin: 0 auto;
}

/* ══════════════════════════════════════════════════════════════
   TÍTULOS
   ══════════════════════════════════════════════════════════════ */
.titulo-confirmacion {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  font-size: 32px;
  font-weight: 700;
  color: #3eb3e7;
  text-align: center;
  margin-bottom: 15px;
  letter-spacing: 1px;
}

.subtitulo-confirmacion {
  font-family: "helvetica neue lt 45 light", sans-serif;
  font-size: 16px;
  color: #383637;
  text-align: center;
  margin-bottom: 40px;
}

/* ══════════════════════════════════════════════════════════════
   RESUMEN DE LA RESERVA
   ══════════════════════════════════════════════════════════════ */
.resumen-reserva {
  background: white;
  border-radius: 12px;
  padding: 30px;
  margin-bottom: 30px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
}

.resumen-titulo {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: #383637;
  margin-bottom: 20px;
  padding-bottom: 15px;
  border-bottom: 2px solid #3eb3e7;
}

.resumen-paquete {
  font-family: "helvetica neue lt 45 light", sans-serif;
  font-size: 18px;
  color: #383637;
  margin-bottom: 20px;
  padding: 15px;
  background: #f8f9fa;
  border-radius: 8px;
}

.resumen-fila {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid #e9ecef;
  font-family: "helvetica neue lt 45 light", sans-serif;
}

.resumen-fila:last-child {
  border-bottom: none;
}

.resumen-label {
  font-size: 15px;
  color: #383637;
}

.resumen-valor {
  font-size: 15px;
  color: #383637;
  font-weight: 600;
}

.resumen-subtotal,
.resumen-total {
  margin-top: 15px;
  padding-top: 15px;
  border-top: 2px solid #e9ecef;
}

.resumen-subtotal .resumen-label,
.resumen-subtotal .resumen-valor {
  font-size: 16px;
}

.resumen-total {
  border-top: 2px solid #3eb3e7;
  background: #f8f9fa;
  padding: 20px;
  margin: 20px -30px -30px;
  border-radius: 0 0 12px 12px;
}

.resumen-total .resumen-label,
.resumen-total .resumen-valor {
  font-size: 20px;
  color: #3eb3e7;
}

.resumen-descuento {
  color: #28a745;
}

.resumen-descuento .resumen-label,
.resumen-descuento .resumen-valor {
  color: #28a745;
}

/* ══════════════════════════════════════════════════════════════
   FORMULARIO
   ══════════════════════════════════════════════════════════════ */
#form-confirmacion {
  background: white;
  border-radius: 12px;
  padding: 30px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
}

.formulario-titulo {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: #383637;
  margin-bottom: 25px;
  padding-bottom: 15px;
  border-bottom: 2px solid #3eb3e7;
}

/* ══════════════════════════════════════════════════════════════
   GRID DE CAMPOS
   ══════════════════════════════════════════════════════════════ */
.campos-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-bottom: 30px;
}

.campo-grupo {
  display: flex;
  flex-direction: column;
}

.campo-grupo.campo-full {
  grid-column: 1/-1;
}

.campo-grupo label {
  font-family: "helvetica neue lt 45 light", sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: #383637;
  margin-bottom: 8px;
}

.campo-grupo input,
.campo-grupo select,
.campo-grupo textarea {
  font-family: "helvetica neue lt 45 light", sans-serif;
  font-size: 15px;
  padding: 12px 15px;
  border: 1px solid #ced4da;
  border-radius: 8px;
  background: white;
  color: #383637;
  transition: all 0.3s ease;
}

.campo-grupo input:focus,
.campo-grupo select:focus,
.campo-grupo textarea:focus {
  outline: none;
  border-color: #3eb3e7;
  box-shadow: 0 0 0 3px rgba(62, 179, 231, 0.1);
}

.campo-grupo input::placeholder,
.campo-grupo textarea::placeholder {
  color: #adb5bd;
}

.campo-grupo textarea {
  resize: vertical;
  min-height: 100px;
}

/* ══════════════════════════════════════════════════════════════
   SECCIÓN DE CUPÓN
   ══════════════════════════════════════════════════════════════ */
.cupon-section {
  background: #f8f9fa;
  border-radius: 10px;
  padding: 25px;
  margin-bottom: 25px;
}

.cupon-titulo {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: #383637;
  margin-bottom: 15px;
}

.cupon-fila {
  display: flex;
  gap: 10px;
  margin-bottom: 10px;
}

.cupon-fila input {
  flex: 1;
  font-family: "helvetica neue lt 45 light", sans-serif;
  font-size: 15px;
  padding: 12px 15px;
  border: 1px solid #ced4da;
  border-radius: 8px;
  background: white;
}

.cupon-fila input:focus {
  outline: none;
  border-color: #3eb3e7;
  box-shadow: 0 0 0 3px rgba(62, 179, 231, 0.1);
}

#cupon-mensaje {
  font-family: "helvetica neue lt 45 light", sans-serif;
  font-size: 14px;
  padding: 10px;
  border-radius: 6px;
  margin-top: 10px;
}

.cupon-ok {
  background: #d4edda;
  color: #155724;
  border: 1px solid #c3e6cb;
}

.cupon-error {
  background: #f8d7da;
  color: #721c24;
  border: 1px solid #f5c6cb;
}

/* ══════════════════════════════════════════════════════════════
   TÉRMINOS Y CONDICIONES
   ══════════════════════════════════════════════════════════════ */
.terminos-section {
  margin-bottom: 30px;
  padding: 20px;
  background: #f8f9fa;
  border-radius: 10px;
}

.terminos-label {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
  font-family: "helvetica neue lt 45 light", sans-serif;
  font-size: 14px;
  color: #383637;
}

.terminos-label input[type=checkbox] {
  margin-top: 3px;
  width: 18px;
  height: 18px;
  cursor: pointer;
}

.terminos-label a {
  color: #3eb3e7;
  text-decoration: underline;
}

.terminos-label a:hover {
  color: rgb(26.7649769585, 157.2442396313, 215.2350230415);
}

/* ══════════════════════════════════════════════════════════════
   BOTONES
   ══════════════════════════════════════════════════════════════ */
.btn-gris-outline {
  background: transparent;
  color: #b6b2b2;
  border: 2px solid #b6b2b2;
  padding: 12px 30px;
  font-size: 15px;
}
.btn-gris-outline:hover {
  background: #b6b2b2;
  color: white;
}

.confirmacion-acciones {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 15px;
  margin-top: 30px;
}

.confirmacion-acciones .btn {
  padding: 14px 40px;
  font-size: 16px;
  font-weight: 700;
}

/* ══════════════════════════════════════════════════════════════
   ALERTAS
   ══════════════════════════════════════════════════════════════ */
.alert-error {
  background: #f8d7da;
  border: 1px solid #f5c6cb;
  border-radius: 8px;
  padding: 15px 20px;
  margin-bottom: 25px;
}

.alert-error ul {
  margin: 0;
  padding-left: 20px;
}

.alert-error li {
  font-family: "helvetica neue lt 45 light", sans-serif;
  font-size: 14px;
  color: #721c24;
  margin-bottom: 5px;
}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  #confirmacion-reserva {
    padding: 40px 15px;
  }
  .confirmacion-container {
    max-width: 100%;
  }
  .titulo-confirmacion {
    font-size: 24px;
  }
  .subtitulo-confirmacion {
    font-size: 14px;
  }
  .resumen-reserva,
  #form-confirmacion {
    padding: 20px;
  }
  .resumen-titulo,
  .formulario-titulo {
    font-size: 18px;
  }
  .campos-grid {
    grid-template-columns: 1fr;
    gap: 15px;
  }
  .resumen-total {
    margin: 20px -20px -20px;
  }
  .cupon-fila {
    flex-direction: column;
  }
  .cupon-fila input {
    width: 100%;
  }
  .confirmacion-acciones {
    flex-direction: column-reverse;
  }
  .confirmacion-acciones .btn {
    width: 100%;
    text-align: center;
  }
  .resumen-fila {
    flex-direction: column;
    align-items: flex-start;
    gap: 5px;
  }
  .resumen-valor {
    font-weight: 700;
  }
}
@media (max-width: 480px) {
  .titulo-confirmacion {
    font-size: 20px;
  }
  .resumen-reserva,
  #form-confirmacion {
    padding: 15px;
  }
  .cupon-section {
    padding: 15px;
  }
}
/* ══════════════════════════════════════════════════════════════
   PÁGINA DE GRACIAS (POST-RESERVA)
   ══════════════════════════════════════════════════════════════ */
#reserva-gracias {
  background: #f8f9fa;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
}

.gracias-container {
  max-width: 600px;
  margin: 0 auto;
  background: white;
  border-radius: 12px;
  padding: 50px 40px;
  text-align: center;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

.gracias-icono {
  font-size: 80px;
  color: #28a745;
  margin-bottom: 25px;
  animation: checkBounce 0.6s ease-in-out;
}

@keyframes checkBounce {
  0% {
    transform: scale(0);
    opacity: 0;
  }
  50% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}
.gracias-titulo {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  font-size: 32px;
  font-weight: 700;
  color: #3eb3e7;
  margin-bottom: 20px;
  letter-spacing: 1px;
}

.gracias-texto {
  font-family: "helvetica neue lt 45 light", sans-serif;
  font-size: 16px;
  color: #383637;
  line-height: 1.6;
  margin-bottom: 30px;
}

.gracias-container .btn {
  padding: 14px 40px;
  font-size: 16px;
  font-weight: 700;
}

@media (max-width: 768px) {
  #reserva-gracias {
    padding: 40px 15px;
  }
  .gracias-container {
    padding: 40px 25px;
  }
  .gracias-icono {
    font-size: 60px;
  }
  .gracias-titulo {
    font-size: 24px;
  }
  .gracias-texto {
    font-size: 14px;
  }
}
/* ══════════════════════════════════════════════════════════════
   PÁGINA DE RESULTADO DE PAGO
   ══════════════════════════════════════════════════════════════ */
#pago-resultado {
  background: #f8f9fa;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
}

.resultado-container {
  max-width: 620px;
  width: 100%;
  margin: 0 auto;
  background: white;
  border-radius: 12px;
  padding: 50px 40px;
  text-align: center;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

/* ── Icono de estado ── */
.resultado-icono {
  font-size: 72px;
  margin-bottom: 20px;
  animation: checkBounce 0.6s ease-in-out;
}

.resultado-icono--success {
  color: #28a745;
}

.resultado-icono--pending {
  color: #fecb32;
}

.resultado-icono--error {
  color: #dc3545;
}

.resultado-icono--cancelled {
  color: #b6b2b2;
}

/* ── Título y texto ── */
.resultado-titulo {
  font-family: "Helvetica Condensed", Arial, sans-serif;
  font-size: 28px;
  font-weight: 700;
  color: #3eb3e7;
  margin-bottom: 12px;
  letter-spacing: 1px;
}

.resultado-titulo--error {
  color: #dc3545;
}

.resultado-texto {
  font-family: "helvetica neue lt 45 light", sans-serif;
  font-size: 16px;
  color: #383637;
  line-height: 1.6;
  margin-bottom: 30px;
}

/* ── Alerta de error ── */
.resultado-alerta {
  text-align: left;
  margin-bottom: 25px;
}

/* ── Resumen de transacción ── */
.resultado-resumen {
  background: #f8f9fa;
  border-radius: 10px;
  padding: 20px 25px;
  margin-bottom: 30px;
  text-align: left;
}
.resultado-resumen .resumen-fila {
  border-bottom: 1px solid #e9ecef;
  padding: 10px 0;
}
.resultado-resumen .resumen-fila:last-child {
  border-bottom: none;
}
.resultado-resumen .resumen-label {
  font-size: 14px;
  color: #b6b2b2;
}
.resultado-resumen .resumen-valor {
  font-size: 14px;
  font-weight: 600;
  color: #383637;
}

/* ── Badges de estado ── */
.resultado-badge {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.resultado-badge--paid {
  background: #d4edda;
  color: #155724;
}

.resultado-badge--pending {
  background: #fff3cd;
  color: #856404;
}

.resultado-badge--rejected {
  background: #f8d7da;
  color: #721c24;
}

.resultado-badge--cancelled {
  background: #e2e3e5;
  color: #383d41;
}

.resultado-badge--failed {
  background: #f8d7da;
  color: #721c24;
}

/* ── Acciones ── */
.resultado-acciones {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
  flex-wrap: wrap;
}
.resultado-acciones .btn {
  padding: 13px 35px;
  font-size: 15px;
  font-weight: 700;
}

/* ── Responsive ── */
@media (max-width: 768px) {
  #pago-resultado {
    padding: 30px 15px;
    align-items: flex-start;
  }
  .resultado-container {
    padding: 35px 20px;
  }
  .resultado-icono {
    font-size: 56px;
  }
  .resultado-titulo {
    font-size: 22px;
  }
  .resultado-texto {
    font-size: 15px;
  }
  .resultado-acciones {
    flex-direction: column;
  }
  .resultado-acciones .btn {
    width: 100%;
    text-align: center;
  }
}
/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   FOOTER
   ======================================== */
footer {
  background-color: #196db6;
  color: #fff;
}
footer h5 {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 15px;
  color: white;
}
footer p,
footer a {
  font-size: 14px;
  line-height: 1.5;
}
footer a {
  color: #fff;
  text-decoration: none;
  transition: color 0.3s ease;
}
footer a:hover {
  color: #d1e4ff;
}
footer i {
  color: #fff;
  font-size: 14px;
  width: 18px;
}
footer {
  /* LOGOS INFERIORES */
}
footer #lower-foot {
  background: #fff;
  padding: 20px 0;
}
footer #lower-foot a {
  display: inline-block;
  transition: transform 0.3s ease;
}
footer #lower-foot a:hover {
  transform: translateY(-3px);
}
footer #lower-foot a img {
  height: 50px;
  filter: grayscale(100%) brightness(1);
  opacity: 1;
  transition: all 0.4s ease;
}
footer #lower-foot a:hover img {
  filter: grayscale(0%) brightness(1);
  opacity: 1;
}
footer {
  /* COPYRIGHT */
}
footer .bg-danger {
  background-color: #3eb3e7 !important;
}
footer .bg-danger a {
  font-size: 10px;
  color: #fff !important;
  letter-spacing: 0.5px;
  transition: opacity 0.3s ease;
}
footer .bg-danger a:hover {
  opacity: 0.8;
}
footer {
  /* RESPONSIVE */
}
@media (max-width: 767px) {
  footer .row > div {
    text-align: center;
  }
  footer i {
    display: none;
  }
  footer h5 {
    margin-top: 20px;
  }
}

/* ========================================
   STURLA VIAJES - ARCHIVO MADRE
   ======================================== */
/* ========================================
   VARIABLES
   ======================================== */
@media (max-width: 1715px) {
  /* Oculta los links del menú desktop */
  header .main-nav ul {
    display: none !important;
  }
  /* Muestra botones y flags siempre */
  header .main-nav .lang-buttons {
    display: flex !important;
  }
  /* Asegura que el botón hamburguesa también se vea */
  header .menu-toggle {
    display: block !important;
  }
}
@media (max-width: 1360px) {
  header nav {
    display: none;
  }
  .menu-toggle {
    display: block;
  }
}
@media (max-width: 992px) {
  .promo-nuevos {
    flex-direction: column;
    text-align: center;
  }
  .videos-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 576px) {
  .videos-grid {
    grid-template-columns: 1fr;
  }
}
/* =========================================================
   HEADER MOBILE FIX
   ========================================================= */
@media (max-width: 991px) {
  body {
    padding-top: 95px;
  }
  header {
    background-color: #fff !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    transition: background-color 0.3s ease, box-shadow 0.3s ease;
  }
  header .logo .logo-blanco {
    opacity: 0 !important;
  }
  header .logo .logo-color {
    opacity: 1 !important;
  }
  header nav ul li a {
    color: #333 !important;
  }
  header .menu-toggle {
    color: #333 !important;
  }
  .section-experiencias .bloque-experiencia .swiper-button-prev, .section-experiencias .bloque-experiencia .swiper-button-next {
    top: 33%;
  }
}
