@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400..900;1,400..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');

.titulo-custom,
.titulo-bloque-custom {
  font-family: "Playfair Display", serif;
}
body { font-family: "Inter", sans-serif; }

/* VARIABLES */
:root {
    --main-color: #FF7A33;
    --main-color-light: #d00b24;
    --main-color-dark: #333;
}

/*HEADER CSS*/
img {transition: opacity ease 300ms;}
img:not([src]) {opacity: 0;}

nav.sticky { box-shadow: 0 0 #0000, 0 0 #0000, 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04); }
nav.sticky.sticked { box-shadow: none; }

.dropdown { opacity: 0; transition: max-height 0.35s ease-in-out, opacity 0.25s ease; }
.dropdown-toggle.open ~ .dropdown { max-height: 500px; opacity: 1; }
.icon { transition: transform 0.3s ease; }
.dropdown-toggle.open .icon { transform: rotate(180deg); }

/* Hamburger base */
.hamburger { width: 44px; height: 44px; display: flex; flex-direction: column; justify-content: center; }

nav:has(.navbar.open) .hamburger {
    position: fixed;
    top: 0.75rem;
    right: calc(1.5rem + var(--scrollbar-width, 0px));
    z-index: 50;
}

/* Animación: el selector apunta desde nav.open hacia el hamburger exterior */
nav .hamburger .hamburger-line:nth-child(1),
nav .hamburger .hamburger-line:nth-child(2),
nav .hamburger .hamburger-line:nth-child(3) { transition: all 0.3s ease; }

nav:has(.navbar.open) .hamburger .hamburger-line:nth-child(1) { transform: translateY(10px) rotate(45deg); }
nav:has(.navbar.open) .hamburger .hamburger-line:nth-child(2) { opacity: 0; transform: scaleX(0); }
nav:has(.navbar.open) .hamburger .hamburger-line:nth-child(3) { transform: translateY(-10px) rotate(-45deg); }

/* Evitar que la página se desplace al abrir el menú */
@media (max-width: 1023px) {
    body.navbar-open { height: 100vh; overflow: hidden; padding-right: var(--scrollbar-width, 0px); }
    .navbar { pointer-events: none; }
    .navbar.open { pointer-events: auto; }
    .navbar .navbar-content { transform: translateY(-100%); }
    .navbar.open .navbar-content { transform: translateY(0); }
    .navbar .navbar-overlay { opacity: 0; }
    .navbar.open .navbar-overlay { opacity: 1; }
}

/* SWIPER BASE CSS */
.c-swiper { position: relative; }

/* Dots */
.swiper-pagination { display: flex; justify-content: center; align-items: center; width: 100%; margin-top: 16px; position: relative; bottom: 0; gap: 6px; }
.c-swiper-dot { width: 12px; height: 12px; border-radius: 100%; background-color: #e4e4e4; border: 1px solid white; cursor: pointer; transition: background-color 0.3s ease, transform 0.3s ease; display: inline-block; }
.c-swiper-dot-active { background-color: var(--main-color); transform: scale(1.3); }

/* Paginación fraction */
.c-swiper-fraction-current { color: var(--main-color); font-weight: 600; }

/* Progressbar */
.swiper-pagination-progressbar { background: #e4e4e4; height: 4px; border-radius: 2px; position: relative; width: 100%; margin-top: 16px; }
.swiper-pagination-progressbar .swiper-pagination-progressbar-fill { background: var(--main-color); border-radius: 2px; }

/* Flechas prev/next */
.c-swiper-prev,
.c-swiper-next { display: flex; align-items: center; justify-content: center; cursor: pointer; flex-shrink: 0; }
.c-swiper-prev:hover,
.c-swiper-next:hover { opacity: 0.85; }
.c-swiper-btn-disabled { opacity: 0.35; pointer-events: none; }

/* Scrollbar */
.swiper-scrollbar { background: #e4e4e4; border-radius: 4px; height: 4px; position: relative !important; left: 0 !important; right: 0 !important; width: 100% !important; }
.swiper-scrollbar-horizontal { top: auto !important; bottom: auto !important; left: 0 !important; right: 0 !important; position: relative !important; align-self: center; }
.swiper-scrollbar-drag { background: var(--main-color); border-radius: 4px; height: 100%; cursor: grab; }
.swiper-scrollbar-drag:active { cursor: grabbing; }

/* TINY SLIDER */

.tns-controls { display: none; }

.tns-nav{display:flex;justify-content:center;width:100%;align-items:center;margin-top:20px;position:relative;bottom:0px;}
.tns-nav button{background-color:#e4e4e4; border:solid 1px white;width:20px; height:20px; border-radius:100%;margin:5px;}
.tns-nav button.tns-nav-active{ background-color: var(--main-color); }

.tns-nav-active { background-color: var(--main-color); }

/* BASE CLASES PROPIAS */
:focus,
input:focus,
button:hover,
button:focus { outline: none; }
.buscador_oculto{margin-top:-60px;opacity:0;}

.shadow-custom { box-shadow: 0 0 20px 2px rgb(0 0 0 / 10%); }
.text-shadow { text-shadow: 1px 1px 5px rgb(0 0 0 / 30%); }

.transition3s { transition: all 0.3s ease-in-out; }
.filter-white { filter: grayscale(100) brightness(0) invert(1); }
.fill-currentColor { fill: currentColor; }

.leading-snug { line-height: 1.375; }
.leading-relaxed { line-height: 1.625; }

.p-1\/20::after { content: ""; display: block; padding-top: 200%; }
.p-1\/15::after { content: ""; display: block; padding-top: 150%; }
.p-1\/12::after { content: ""; display: block; padding-top: 120%; }
.p-1\/10::after { content: ""; display: block; padding-top: 100%; }
.p-1\/9::after { content: ""; display: block; padding-top: 90%; }
.p-1\/8::after { content: ""; display: block; padding-top: 80%; }
.p-1\/7::after { content: ""; display: block; padding-top: 70%; }
.p-1\/6::after { content: ""; display: block; padding-top: 60%; }
.p-1\/5::after { content: ""; display: block; padding-top: 50%; }
.p-1\/4::after { content: ""; display: block; padding-top: 40%; }
.p-1\/3::after { content: ""; display: block; padding-top: 30%; }
.p-1\/2::after { content: ""; display: block; padding-top: 20%; }
.p-1\/1::after { content: ""; display: block; padding-top: 10%; }

.p-noticias::after { content: ""; display: block; padding-top: 60%; }
.p-principal::after { content: ""; display: block; padding-top: 69.2%; }

@media (min-width: 1023px) {
    .p-noticias::after { content: ""; display: block; padding-top: 40%; }
    .p-principal::after { content: ""; display: block; padding-top: 69.5%; }
}

@media (min-width: 	1280px) {
    .p-principal::after { content: ""; display: block; padding-top: 69.7%; }
}

.-z-1 { z-index: -1; }

.social-media li { padding: 0px; }
.social-media li a { margin: 0px; display: flex; width: 100%; height: 100%; }

@layer base {
  button:not(:disabled),
  [role="button"]:not(:disabled) {
    cursor: pointer;
  }

  button:disabled,
  [role="button"]:disabled {
    cursor: not-allowed;
    opacity: 0.6;
  }
}

body { opacity: 1; }


