/**
 * main.css — Sistema de diseño completo Mr Offroad Experience
 * @package MrBuggy
 */

/* ============================================================
   1. BASE
   ============================================================ */

html { font-size: 16px; }

body {
    font-family:      var(--font-body);
    font-size:        var(--text-base);
    color:            var(--color-text-primary);
    background-color: var(--color-bg-primary);
    overflow-x:       hidden;
}

body.menu-open { overflow: hidden; }

::selection {
    background: var(--color-accent);
    color: #000;
}

/* ============================================================
   2. TIPOGRAFÍA
   ============================================================ */

h1, h2, h3, h4, h5, h6 {
    font-family:    var(--font-display);
    font-weight:    400;
    line-height:    1.05;
    letter-spacing: 0.02em;
    color:          var(--color-text-primary);
    text-transform: uppercase;
}

h1 { font-size: var(--text-7xl); }
h2 { font-size: var(--text-5xl); }
h3 { font-size: var(--text-4xl); }
h4 { font-family: var(--font-body); font-size: var(--text-xl); font-weight: 700; text-transform: none; letter-spacing: 0; }
h5 { font-family: var(--font-body); font-size: var(--text-lg); font-weight: 600; text-transform: none; letter-spacing: 0; }

p {
    line-height: 1.7;
    color:       var(--color-text-secondary);
    max-width:   65ch;
}

a { transition: color var(--transition-fast); }
a:hover { color: var(--color-accent); }

strong, b { font-weight: 700; color: var(--color-text-primary); }

.eyebrow {
    display:        inline-block;
    font-family:    var(--font-body);
    font-size:      var(--text-xs);
    font-weight:    700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color:          var(--color-accent);
    margin-bottom:  var(--space-4);
}

.eyebrow::before {
    content:      '— ';
    opacity:      0.6;
}

/* ============================================================
   3. LAYOUT
   ============================================================ */

.container {
    width:          100%;
    max-width:      var(--container-max);
    margin-inline:  auto;
    padding-inline: var(--gutter);
}

.container--lg   { max-width: var(--container-lg); }
.container--md   { max-width: var(--container-md); }
.container--full { max-width: 100%; padding-inline: 0; }

.section           { padding-block: var(--section-pad); }
.section--sm       { padding-block: calc(var(--section-pad) * 0.55); }
.section--dark     { background-color: var(--color-bg-secondary); }
.section--darker   { background-color: var(--color-bg-tertiary); }
.section--accent   { background-color: var(--color-accent); color: #000; }

/* ============================================================
   4. SECTION HEADER — Eyebrow + Título + Subtítulo
   ============================================================ */

.section-header {
    margin-bottom: var(--space-16);
}

.section-header--center {
    text-align:     center;
    max-width:      740px;
    margin-inline:  auto;
    margin-bottom:  var(--space-16);
}

.section-header__title {
    margin-bottom: var(--space-5);
    line-height:   1.0;
}

.section-header__subtitle {
    font-size:  var(--text-lg);
    color:      var(--color-text-secondary);
    max-width:  60ch;
    line-height:1.65;
}

.section-header--center .section-header__subtitle {
    margin-inline: auto;
}

/* ============================================================
   5. DIVIDERS
   ============================================================ */

.divider {
    width:      48px;
    height:     2px;
    background: var(--color-accent);
    border:     none;
    margin:     var(--space-5) 0;
}

.divider--center { margin-inline: auto; }
.divider--wide   { width: 80px; }

/* ============================================================
   6. BOTONES
   ============================================================ */

.btn {
    display:         inline-flex;
    align-items:     center;
    justify-content: center;
    gap:             8px;
    padding:         14px 34px;
    font-family:     var(--font-body);
    font-size:       var(--text-sm);
    font-weight:     700;
    letter-spacing:  0.1em;
    text-transform:  uppercase;
    border-radius:   var(--radius);
    cursor:          pointer;
    transition:      all var(--transition-base) var(--ease-premium);
    position:        relative;
    overflow:        hidden;
    white-space:     nowrap;
    text-decoration: none;
    border:          2px solid transparent;
    line-height:     1;
}

/* Botón primario — dorado sólido */
.btn--primary {
    background:   var(--color-accent);
    color:        #000;
    border-color: var(--color-accent);
}

.btn--primary:hover {
    background:   var(--color-accent-hover);
    border-color: var(--color-accent-hover);
    color:        #000;
    box-shadow:   var(--shadow-btn);
    transform:    translateY(-2px);
}

.btn--primary:active { transform: translateY(0); }

/* Botón secundario — outline dorado */
.btn--secondary {
    background:   transparent;
    color:        var(--color-accent);
    border-color: var(--color-accent);
}

.btn--secondary:hover {
    background:   var(--color-accent-subtle);
    color:        var(--color-accent-hover);
    border-color: var(--color-accent-hover);
    transform:    translateY(-2px);
}

/* Botón ghost — sin borde, solo texto */
.btn--ghost {
    background:   transparent;
    color:        var(--color-text-secondary);
    border-color: transparent;
    padding-inline: 0;
}

.btn--ghost:hover {
    color: var(--color-text-primary);
    transform: none;
}

/* Tamaños */
.btn--hero { padding: 18px 48px; font-size: var(--text-base); }
.btn--sm   { padding: 10px 22px; font-size: var(--text-xs); }
.btn--lg   { padding: 18px 40px; font-size: var(--text-base); }
.btn--block{ width: 100%; }

/* En sección accent (fondo dorado) */
.section--accent .btn--primary {
    background:   #000;
    border-color: #000;
    color:        var(--color-accent);
}

.section--accent .btn--secondary {
    color:        #000;
    border-color: #000;
}

/* Shine effect */
.btn__shine {
    position:       absolute;
    top:            0;
    left:           -120%;
    width:          60%;
    height:         100%;
    background:     linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
    transform:      skewX(-20deg);
    pointer-events: none;
}

/* ============================================================
   7. BADGES
   ============================================================ */

.badge {
    display:        inline-flex;
    align-items:    center;
    gap:            5px;
    padding:        5px 12px;
    font-family:    var(--font-body);
    font-size:      var(--text-xs);
    font-weight:    700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border-radius:  var(--radius-sm);
    white-space:    nowrap;
}

.badge--accent   { background: var(--color-accent-subtle); color: var(--color-accent); border: 1px solid var(--color-border); }
.badge--dark     { background: var(--color-bg-tertiary);   color: var(--color-text-secondary); border: 1px solid var(--color-border); }
.badge--outline  { background: transparent; color: var(--color-accent); border: 1px solid var(--color-border-strong); }

/* ============================================================
   8. CARDS BASE
   ============================================================ */

.card {
    background:    var(--color-bg-secondary);
    border:        1px solid var(--color-border);
    border-radius: var(--radius);
    overflow:      hidden;
    transition:    border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base);
}

.card:hover {
    border-color: var(--color-border-strong);
    box-shadow:   var(--shadow-card);
}

/* ============================================================
   9. TOUR CARD
   ============================================================ */

.tour-card {
    background:    var(--color-bg-secondary);
    border:        1px solid var(--color-border);
    border-radius: var(--radius);
    overflow:      hidden;
    display:       flex;
    flex-direction:column;
    transition:    border-color var(--transition-base),
                   box-shadow var(--transition-base),
                   transform var(--transition-slow) var(--ease-premium);
    cursor:        pointer;
    text-decoration: none;
    color:         inherit;
}

.tour-card:hover {
    border-color: var(--color-border-strong);
    box-shadow:   var(--shadow-card-lg);
    transform:    translateY(-6px);
    color:        inherit;
}

.tour-card__img-wrap {
    position:     relative;
    aspect-ratio: 4 / 3;
    overflow:     hidden;
    background:   var(--color-bg-tertiary);
}

.tour-card__img {
    width:      100%;
    height:     100%;
    object-fit: cover;
    transition: transform 0.7s var(--ease-premium);
    display:    block;
}

.tour-card:hover .tour-card__img { transform: scale(1.06); }

/* Overlay dorado en hover */
.tour-card__img-wrap::after {
    content:    '';
    position:   absolute;
    inset:      0;
    background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, transparent 60%);
    transition: opacity var(--transition-base);
}

.tour-card__badges {
    position: absolute;
    top:       var(--space-4);
    left:      var(--space-4);
    display:   flex;
    gap:       var(--space-2);
    z-index:   1;
}

.tour-card__body {
    padding:       var(--space-6);
    display:       flex;
    flex-direction:column;
    flex:          1;
}

.tour-card__meta {
    display:       flex;
    align-items:   center;
    gap:           var(--space-4);
    margin-bottom: var(--space-3);
}

.tour-card__meta-item {
    display:    flex;
    align-items:center;
    gap:        5px;
    font-size:  var(--text-xs);
    color:      var(--color-text-muted);
    font-weight:600;
}

.tour-card__meta-item svg {
    width:  14px;
    height: 14px;
    color:  var(--color-accent);
    flex-shrink: 0;
}

.tour-card__title {
    font-size:     var(--text-3xl);
    margin-bottom: var(--space-3);
    line-height:   1.0;
    transition:    color var(--transition-fast);
}

.tour-card:hover .tour-card__title { color: var(--color-accent); }

.tour-card__excerpt {
    font-size:     var(--text-sm);
    line-height:   1.6;
    color:         var(--color-text-secondary);
    margin-bottom: var(--space-5);
    flex:          1;
    max-width:     none;
}

.tour-card__footer {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    padding-top:     var(--space-4);
    border-top:      1px solid var(--color-border);
    margin-top:      auto;
}

.tour-card__price-wrap {}

.tour-card__price-label {
    font-size:  var(--text-xs);
    color:      var(--color-text-muted);
    font-weight:600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    display:    block;
    line-height:1;
    margin-bottom: 2px;
}

.tour-card__price {
    font-family:    var(--font-display);
    font-size:      var(--text-2xl);
    color:          var(--color-accent);
    line-height:    1;
}

/* ============================================================
   10. VALUE CARD — Iconos de características
   ============================================================ */

.value-card {
    display:        flex;
    flex-direction: column;
    align-items:    center;
    gap:            var(--space-3);
    padding:        var(--space-8) var(--space-5);
    text-align:     center;
    border:         1px solid var(--color-border);
    border-radius:  var(--radius);
    background:     var(--color-bg-secondary);
    transition:     all var(--transition-base);
}

.value-card:hover {
    border-color:  var(--color-border-strong);
    background:    var(--color-bg-tertiary);
    box-shadow:    var(--shadow-glow-sm);
    transform:     translateY(-3px);
}

.value-card__icon {
    width:  48px;
    height: 48px;
    color:  var(--color-accent);
    transition: filter var(--transition-base);
}

.value-card:hover .value-card__icon {
    filter: drop-shadow(0 0 8px var(--color-accent-glow));
}

.value-card__title {
    font-family:    var(--font-body);
    font-size:      var(--text-sm);
    font-weight:    700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color:          var(--color-text-primary);
}

/* ============================================================
   11. STAT CARD
   ============================================================ */

.stat-card {
    text-align: center;
    padding:    var(--space-6);
}

.stat-card__number {
    font-family: var(--font-display);
    font-size:   var(--text-6xl);
    color:       var(--color-accent);
    line-height: 1;
    display:     block;
}

.stat-card__label {
    font-size:      var(--text-sm);
    color:          var(--color-text-muted);
    font-weight:    600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-top:     var(--space-2);
    display:        block;
}

/* ============================================================
   12. TRUST BADGES — pago seguro
   ============================================================ */

.trust-bar {
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             var(--space-8);
    flex-wrap:       wrap;
    padding:         var(--space-5) var(--gutter);
    background:      var(--color-bg-secondary);
    border-top:      1px solid var(--color-border);
    border-bottom:   1px solid var(--color-border);
}

.trust-item {
    display:    flex;
    align-items:center;
    gap:        var(--space-2);
    font-size:  var(--text-xs);
    font-weight:700;
    color:      var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    white-space:nowrap;
}

.trust-item svg {
    width:  16px;
    height: 16px;
    color:  var(--color-accent);
    flex-shrink: 0;
}

/* ============================================================
   13. ACCESIBILIDAD
   ============================================================ */

.skip-link {
    position:   absolute;
    top:        -100%;
    left:       var(--gutter);
    padding:    8px 16px;
    background: var(--color-accent);
    color:      #000;
    font-weight:700;
    font-size:  var(--text-sm);
    border-radius: 0 0 var(--radius) var(--radius);
    z-index:    var(--z-toast);
    transition: top var(--transition-fast);
}

.skip-link:focus { top: 0; }

/* ============================================================
   14. PRELOADER
   ============================================================ */

#mb-preloader {
    position:        fixed;
    inset:           0;
    background:      var(--color-bg-primary);
    display:         flex;
    flex-direction:  column;
    align-items:     center;
    justify-content: center;
    gap:             24px;
    z-index:         var(--z-cursor);
    opacity:         1;
    transition:      opacity 0.5s ease, visibility 0.5s ease;
    /* Failsafe 100% CSS: si TODO el JS falla, el preloader NUNCA bloquea el
       contenido — se desvanece solo a los 6 s. El JS lo oculta mucho antes. */
    animation:       mbPreloaderFailsafe 0.5s ease 6s forwards;
}
#mb-preloader.is-hidden {
    opacity:        0;
    visibility:     hidden;
    pointer-events: none;
}
@keyframes mbPreloaderFailsafe {
    to { opacity: 0; visibility: hidden; pointer-events: none; }
}
@media (prefers-reduced-motion: reduce) {
    #mb-preloader { transition: none; animation-delay: 2s; }
}

.preloader__logo {
    width:   160px;
    height:  auto;
    animation: preloader-pulse 1.5s ease-in-out infinite;
}

@keyframes preloader-pulse {
    0%, 100% { opacity: 1; }
    50%       { opacity: 0.6; }
}

.preloader__bar {
    width:        200px;
    height:       2px;
    background:   rgba(255,255,255,0.08);
    border-radius:1px;
    overflow:     hidden;
}

.preloader__bar-fill {
    height:       100%;
    width:        0%;
    background:   linear-gradient(90deg, var(--color-accent-dark), var(--color-accent-hover));
    border-radius:1px;
    animation:    preloader-fill 1.2s var(--ease-out-expo) forwards 0.1s;
}

@keyframes preloader-fill { to { width: 100%; } }

/* ============================================================
   15. HEADER
   ============================================================ */

.site-header {
    position:   fixed;
    top:        0;
    left:       0;
    right:      0;
    z-index:    var(--z-sticky);
    padding:    22px 0;
    will-change: transform;
    transition: padding        0.4s var(--ease-premium),
                background    0.4s var(--ease-premium),
                border-color  0.4s var(--ease-premium),
                transform     0.35s var(--ease-in-out-quart);
    border-bottom: 1px solid transparent;
}

/* Estado transparente (por defecto — sobre el hero) */
.site-header::before {
    content:  '';
    position: absolute;
    inset:    0;
    background: linear-gradient(to bottom, rgba(10,10,10,0.8) 0%, transparent 100%);
    opacity:  1;
    transition: opacity 0.4s;
    pointer-events: none;
}

/* Header al hacer scroll.
   Sin backdrop-filter: con fondo al 98% el blur era invisible pero forzaba
   repintado del header en cada frame de scroll (jank en Chromium escritorio). */
.site-header.is-scrolled {
    padding:        14px 0;
    background:     rgba(10, 10, 10, 0.98);
    border-bottom-color: var(--color-border);
}

.site-header.is-scrolled::before { opacity: 0; }

/* Header oculto al bajar */
.site-header.is-hidden {
    transform: translateY(-100%);
}

/* El header usa un contenedor más ancho para que el menú completo quepa centrado sin desbordar */
.site-header > .container { max-width: 1480px; }

.header__inner {
    display:     flex;
    align-items: center;
    gap:         var(--space-5);
    position:    relative;
    z-index:     1;
}

/* Logo */
.header__logo { flex-shrink: 0; }

.header__logo a {
    display:     block;
    line-height: 0;
}

.header__logo img,
.header__logo svg {
    height:    56px;
    width:     auto;
    max-width: 185px;
    transition:filter var(--transition-base);
}

.site-header:not(.is-scrolled) .header__logo img {
    filter: brightness(1.1);
}

/* Nav */
.header__nav { margin-inline: auto; }

/* CTA area */
.header__actions {
    display:     flex;
    align-items: center;
    gap:         var(--space-4);
    flex-shrink: 0;
}

/* Hamburger */
.header__menu-toggle {
    display:        none;
    flex-direction: column;
    justify-content:center;
    gap:            5px;
    padding:        6px;
    cursor:         pointer;
    background:     none;
    border:         none;
    z-index:        calc(var(--z-overlay) + 10);
    width:          38px;
    height:         38px;
}

.header__menu-toggle span {
    display:      block;
    width:        22px;
    height:       1.5px;
    background:   var(--color-text-primary);
    border-radius:1px;
    transition:   transform 0.35s var(--ease-in-out-quart),
                  opacity   0.2s ease,
                  width     0.3s ease;
    transform-origin: center;
}

.header__menu-toggle span:nth-child(3) { width: 14px; }

.header__menu-toggle.is-active span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.header__menu-toggle.is-active span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.header__menu-toggle.is-active span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); width: 22px; }

/* ============================================================
   16. NAVEGACIÓN DESKTOP
   ============================================================ */

.nav__list {
    display:     flex;
    align-items: center;
    gap:         15px;
    list-style:  none;
    padding:     0;
    margin:      0;
}

.nav__link {
    font-size:      var(--text-xs);
    font-weight:    600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color:          rgba(245, 245, 240, 0.75);
    position:       relative;
    padding-bottom: 3px;
    transition:     color var(--transition-fast);
    white-space:    nowrap;
}

.nav__link::after {
    content:    '';
    position:   absolute;
    bottom:     0;
    left:       0;
    width:      0%;
    height:     1px;
    background: var(--color-accent);
    transition: width 0.3s var(--ease-out-expo);
}

.nav__link:hover,
.current-menu-item > .nav__link,
.current-page-ancestor > .nav__link {
    color: var(--color-text-primary);
}

.nav__link:hover::after,
.current-menu-item > .nav__link::after {
    width: 100%;
}

/* Fuerza que los <li> que genera WP tengan los estilos correctos */
.nav__list li { list-style: none; }
.nav__list li > a {
    font-size:      var(--text-xs);
    font-weight:    600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color:          rgba(245,245,240,0.75);
    position:       relative;
    padding-bottom: 3px;
    transition:     color var(--transition-fast);
    white-space:    nowrap;
    text-decoration:none;
}
.nav__list li > a:hover { color: var(--color-text-primary); }

/* ============================================================
   17. MENÚ MÓVIL OVERLAY FULLSCREEN
   ============================================================ */

.nav-overlay {
    position:        fixed;
    inset:           0;
    background:      var(--color-bg-secondary);
    z-index:         var(--z-overlay);
    display:         flex;
    flex-direction:  column;
    align-items:     center;
    justify-content: center;
    gap:             var(--space-8);
    padding:         calc(var(--header-height, 96px) + var(--space-6)) var(--space-6) var(--space-10);
    clip-path:       inset(0% 0% 100% 0%);
    /* Apertura/cierre por la clase .menu-open del <body>: NO depende de GSAP. */
    transition:      clip-path 0.5s cubic-bezier(0.76, 0, 0.24, 1),
                     visibility 0s linear 0.5s;
    visibility:      hidden;
    overflow-y:      auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
}

/* Estado abierto controlado por clase: funciona aunque GSAP no cargue. */
body.menu-open .nav-overlay {
    clip-path:  inset(0% 0% 0% 0%);
    visibility: visible;
    transition: clip-path 0.5s cubic-bezier(0.76, 0, 0.24, 1),
                visibility 0s;
}

/* El overlay (z 300) cubre el header (z 200): menú a pantalla completa con su  */
/* propio botón X — siempre clicable y sin solaparse con la hamburguesa.        */

/* Borde decorativo lateral en el overlay */
.nav-overlay::before {
    content:   '';
    position:  absolute;
    left:      0;
    top:       0;
    bottom:    0;
    width:     3px;
    background:linear-gradient(to bottom, transparent, var(--color-accent), transparent);
}

/* Botón cerrar (X) — fijo arriba-derecha, siempre visible aunque se haga    */
/* scroll dentro del overlay (el overlay tiene clip-path → es su contenedor). */
.nav-overlay__close {
    position:        fixed;
    top:             var(--space-5);
    right:           var(--space-5);
    width:           48px;
    height:          48px;
    display:         flex;
    align-items:     center;
    justify-content: center;
    background:      transparent;
    border:          1px solid var(--color-border, rgba(255,255,255,0.15));
    border-radius:   50%;
    cursor:          pointer;
    z-index:         2;
    transition:      border-color var(--transition-fast), transform var(--transition-fast);
}
.nav-overlay__close:hover { border-color: var(--color-accent); transform: rotate(90deg); }
.nav-overlay__close span {
    position:   absolute;
    width:      20px;
    height:     2px;
    background: var(--color-text-primary);
    border-radius: 2px;
}
.nav-overlay__close span:first-child { transform: rotate(45deg); }
.nav-overlay__close span:last-child  { transform: rotate(-45deg); }

/* Pantallas cortas (móvil apaisado / alturas reducidas): el menú se alinea   */
/* arriba y hace scroll, evitando que flexbox recorte el contenido por arriba.*/
@media (max-height: 720px) {
    .nav-overlay { justify-content: flex-start; gap: var(--space-5); }
}

.nav-overlay .nav__list {
    flex-direction: column;
    gap:            var(--space-6);
    text-align:     center;
}

.nav-overlay .nav__list li a,
.nav-overlay .nav__link {
    font-family:    var(--font-display);
    font-size:      var(--text-3xl);
    line-height:    1.1;
    letter-spacing: 0.04em;
    color:          var(--color-text-primary);
    text-transform: uppercase;
    transition:     color var(--transition-fast);
}

.nav-overlay .nav__list li a:hover,
.nav-overlay .nav__link:hover {
    color: var(--color-accent);
}

.nav-overlay .nav__list li a::after,
.nav-overlay .nav__link::after { display: none; }

/* CTA en el overlay móvil */
.nav-overlay__cta {
    display:   flex;
    gap:       var(--space-4);
    flex-wrap: wrap;
    justify-content: center;
}

/* Datos de contacto en el overlay */
.nav-overlay__contact {
    font-size:  var(--text-sm);
    color:      var(--color-text-muted);
    text-align: center;
}

.nav-overlay__contact a {
    color: var(--color-text-secondary);
    transition: color var(--transition-fast);
}

.nav-overlay__contact a:hover { color: var(--color-accent); }

/* ============================================================
   18. LANGUAGE SWITCHER
   ============================================================ */

.lang-switcher {
    position: relative;
}

.lang-switcher__toggle {
    display:         flex;
    align-items:     center;
    gap:             5px;
    padding:         6px 10px;
    background:      transparent;
    border:          1px solid var(--color-border);
    border-radius:   var(--radius-sm);
    cursor:          pointer;
    font-size:       var(--text-xs);
    font-weight:     700;
    letter-spacing:  0.06em;
    color:           var(--color-text-secondary);
    transition:      all var(--transition-fast);
    white-space:     nowrap;
}

.lang-switcher__toggle:hover {
    border-color:  var(--color-border-strong);
    color:         var(--color-text-primary);
}

.lang-switcher__toggle::after {
    content:     '▾';
    font-size:   10px;
    margin-left: 2px;
    transition:  transform var(--transition-fast);
}

.lang-switcher.is-open .lang-switcher__toggle::after {
    transform: rotate(180deg);
}

.lang-switcher__dropdown {
    position:      absolute;
    top:           calc(100% + 8px);
    right:         0;
    background:    var(--color-bg-secondary);
    border:        1px solid var(--color-border-strong);
    border-radius: var(--radius);
    padding:       var(--space-2);
    min-width:     100px;
    box-shadow:    var(--shadow-card);
    list-style:    none;
    margin:        0;
    /* Oculto por defecto */
    opacity:       0;
    transform:     translateY(-8px);
    pointer-events:none;
    transition:    opacity var(--transition-fast), transform var(--transition-fast);
    z-index:       var(--z-dropdown);
}

.lang-switcher.is-open .lang-switcher__dropdown {
    opacity:        1;
    transform:      translateY(0);
    pointer-events: all;
}

.lang-switcher__option {
    display:       flex;
    align-items:   center;
    gap:           7px;
    padding:       8px 12px;
    font-size:     var(--text-xs);
    font-weight:   600;
    letter-spacing:0.06em;
    color:         var(--color-text-secondary);
    border-radius: var(--radius-sm);
    transition:    all var(--transition-fast);
    text-decoration: none;
    white-space:   nowrap;
}

.lang-switcher__option:hover {
    background: var(--color-accent-subtle);
    color:      var(--color-accent);
}

.lang-switcher__option.is-active {
    color:      var(--color-accent);
    background: var(--color-accent-subtle);
}

/* ============================================================
   19. FOOTER
   ============================================================ */

.site-footer {
    background:    var(--color-bg-secondary);
    border-top:    1px solid var(--color-border);
}

.footer__main {
    padding-block: var(--space-20);
}

.footer__grid {
    display:               grid;
    grid-template-columns: 1.6fr 1fr 1.4fr 1fr;
    gap:                   var(--space-12);
}

.footer__heading {
    font-family:    var(--font-body);
    font-size:      var(--text-xs);
    font-weight:    700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color:          var(--color-text-primary);
    margin-bottom:  var(--space-5);
    padding-bottom: var(--space-3);
    border-bottom:  1px solid var(--color-border);
}

.footer__logo {
    margin-bottom: var(--space-5);
}

.footer__logo img { height: 44px; width: auto; }

.footer__tagline {
    font-size:  var(--text-sm);
    line-height:1.65;
    color:      var(--color-text-muted);
    max-width:  26ch;
    margin-bottom: var(--space-6);
}

/* Footer nav */
.footer__nav {
    display:        flex;
    flex-direction: column;
    gap:            var(--space-3);
    list-style:     none;
    padding:        0;
    margin:         0;
}

.footer__nav a {
    font-size:  var(--text-sm);
    color:      var(--color-text-muted);
    transition: color var(--transition-fast);
}

.footer__nav a:hover { color: var(--color-accent); }

/* Footer contacto */
.footer__contact {
    display:        flex;
    flex-direction: column;
    gap:            var(--space-3);
    font-style:     normal;
}

.footer__contact-item {
    display:    flex;
    align-items:center;
    gap:        var(--space-2);
    font-size:  var(--text-sm);
    color:      var(--color-text-muted);
}

.footer__contact-item a { color: var(--color-text-secondary); }
.footer__contact-item a:hover { color: var(--color-accent); }

.footer__contact-item svg {
    width:      16px;
    height:     16px;
    color:      var(--color-accent);
    flex-shrink:0;
}

/* Social links */
.footer__social {
    display:    flex;
    gap:        var(--space-3);
    flex-wrap:  wrap;
    margin-top: var(--space-5);
}

.social-link {
    display:        flex;
    align-items:    center;
    justify-content:center;
    width:          36px;
    height:         36px;
    border:         1px solid var(--color-border);
    border-radius:  var(--radius-sm);
    color:          var(--color-text-muted);
    transition:     all var(--transition-fast);
}

.social-link svg { width: 16px; height: 16px; }

.social-link:hover {
    border-color: var(--color-border-strong);
    color:        var(--color-accent);
    background:   var(--color-accent-subtle);
    transform:    translateY(-2px);
}

/* Footer bottom bar */
.footer__bottom {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    padding-block:   var(--space-5);
    border-top:      1px solid var(--color-border);
    flex-wrap:       wrap;
    gap:             var(--space-4);
}

.footer__copyright {
    font-size:  var(--text-xs);
    color:      var(--color-text-muted);
    line-height:1.5;
}

.footer__legal-nav {
    display:    flex;
    gap:        var(--space-5);
    list-style: none;
    padding:    0;
    margin:     0;
}

.footer__legal-nav a {
    font-size:  var(--text-xs);
    color:      var(--color-text-muted);
}

.footer__legal-nav a:hover { color: var(--color-text-secondary); }

/* ── Footer responsive: la rejilla de 4 columnas debe colapsar en móvil ── */
/* Sin esto, las columnas 3-4 quedaban fuera de pantalla y se recortaban.   */
@media (max-width: 900px) {
    .footer__grid { grid-template-columns: 1fr 1fr; gap: var(--space-8) var(--space-6); }
}
@media (max-width: 560px) {
    .footer__grid   { grid-template-columns: 1fr; gap: var(--space-8); }
    .footer__bottom { justify-content: center; text-align: center; }
    .footer__legal-nav { justify-content: center; flex-wrap: wrap; }
}
/* El email y los datos de contacto nunca deben desbordar su columna. */
.footer__contact-item { min-width: 0; }
.footer__contact-item a,
.footer__contact-item span { overflow-wrap: anywhere; word-break: break-word; min-width: 0; }

/* ============================================================
   20. WHATSAPP FLOTANTE
   ============================================================ */

.whatsapp-float {
    position:        fixed;
    bottom:          28px;
    right:           28px;
    z-index:         var(--z-toast);
    width:           56px;
    height:          56px;
    background:      #25D366;
    border-radius:   50%;
    display:         flex;
    align-items:     center;
    justify-content: center;
    box-shadow:      0 4px 24px rgba(37, 211, 102, 0.35);
    transition:      transform var(--transition-base), box-shadow var(--transition-base);
    text-decoration: none;
    /* Oculto hasta que JS lo muestre */
    opacity:         0;
    transform:       scale(0);
}

.whatsapp-float:hover {
    transform:  translateY(-3px) scale(1.08);
    box-shadow: 0 8px 32px rgba(37, 211, 102, 0.5);
    color:      white;
}

.whatsapp-float svg { width: 28px; height: 28px; fill: white; }

.whatsapp-float__badge {
    position:      absolute;
    top:           -3px;
    right:         -3px;
    width:         16px;
    height:        16px;
    background:    var(--color-accent);
    border-radius: 50%;
    border:        2px solid var(--color-bg-primary);
}

.whatsapp-float__tooltip {
    position:       absolute;
    right:          calc(100% + 14px);
    top:            50%;
    transform:      translateY(-50%);
    background:     var(--color-bg-secondary);
    color:          var(--color-text-primary);
    font-size:      var(--text-xs);
    font-weight:    600;
    white-space:    nowrap;
    padding:        6px 12px;
    border-radius:  var(--radius);
    border:         1px solid var(--color-border);
    box-shadow:     var(--shadow-card);
    opacity:        0;
    pointer-events: none;
    transition:     opacity var(--transition-fast);
}

.whatsapp-float:hover .whatsapp-float__tooltip { opacity: 1; }

/* ============================================================
   21+. HOME — Secciones completas (rediseño premium)
   ============================================================ */

/* ── Gradientes placeholder para imágenes de tours ── */
:root {
    --gradient-tour-1: linear-gradient(160deg,#251000 0%,#4a2000 45%,#0a0a0a 100%);
    --gradient-tour-2: linear-gradient(160deg,#001a10 0%,#003820 45%,#0a0a0a 100%);
    --gradient-tour-3: linear-gradient(160deg,#1a0d00 0%,#4a2800 45%,#0a0a0a 100%);
    --gradient-tour-4: linear-gradient(160deg,#0d0d1a 0%,#1e1e50 45%,#0a0a0a 100%);
}

/* ─────────────────────────────────────────────────────────────
   HERO
───────────────────────────────────────────────────────────── */

.hero {
    position:   relative;
    min-height: 100svh;
    display:    flex;
    align-items:center;
    overflow:   hidden;
    background: #0a0a0a;
}

/* Fondo */
.hero__bg {
    position: absolute;
    inset:    0;
    z-index:  0;
}

.hero__bg-photo {
    width:      100%;
    height:     100%;
    object-fit: cover;
    opacity:    0.55;
}

/* Si no hay foto → gradiente cinematográfico */
.hero__bg::before {
    content:    '';
    position:   absolute;
    inset:      0;
    background: linear-gradient(150deg, #1a0800 0%, #0a0a0a 55%, #060810 100%);
    z-index:    1;
}

.hero__overlay {
    position:   absolute;
    inset:      0;
    z-index:    2;
    background: linear-gradient(
        100deg,
        rgba(10,10,10,0.92) 0%,
        rgba(10,10,10,0.65) 55%,
        rgba(10,10,10,0.40) 100%
    );
}

/* Vídeo hero en bucle */
.hero__video {
    position:        absolute;
    inset:           0;
    width:           100%;
    height:          100%;
    object-fit:      cover;
    object-position: center center;
    opacity:         0.72;
    pointer-events:  none;
    z-index:         1;
}

@media (prefers-reduced-motion: reduce) {
    .hero__video { display: none; }
}

.hero__glow {
    position:   absolute;
    bottom:     0;
    left:       0;
    right:      0;
    height:     40%;
    background: linear-gradient(to top, #0a0a0a 0%, transparent 100%);
    z-index:    4;
}

/* Contenedor — sin specs card: layout de una columna */
.hero__container {
    position:       relative;
    z-index:        5;
    display:        flex;
    align-items:    center;
    justify-content:center;
    text-align:     center;
    min-height:     100svh;
    padding-top:    clamp(5rem, 12vh, 9rem);
    padding-bottom: clamp(3rem, 8vh, 6rem);
}

/* Contenido — centrado en pantalla */
.hero__content {
    display:        flex;
    flex-direction: column;
    align-items:    center;
    text-align:     center;
    gap:            var(--space-6);
    max-width:      900px;
    width:          100%;
    margin-inline:  auto;
}

.hero__eyebrow {
    display:        inline-flex;
    align-items:    center;
    gap:            var(--space-3);
    font-size:      var(--text-xs);
    font-weight:    700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color:          var(--color-accent);
}

.hero__eyebrow-dot {
    display:       inline-block;
    width:         6px;
    height:        6px;
    border-radius: 50%;
    background:    var(--color-accent);
    animation:     pulse-dot 2s ease-in-out infinite;
}

@keyframes pulse-dot {
    0%,100% { opacity: 1; transform: scale(1);   }
    50%      { opacity: 0.5; transform: scale(0.7); }
}

.hero__title {
    font-family:    var(--font-display);
    font-size:      clamp(3rem, 9vw, 8rem);
    line-height:    0.95;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color:          #F5F5F0;
    margin:         0;
    text-shadow:    0 4px 60px rgba(0,0,0,0.7);
    overflow-wrap:  break-word;   /* en móvil el título PUEDE partirse para no desbordar */
    text-wrap:      balance;
}

.hero__title-accent {
    color: var(--color-accent);
}

.hero__bullets {
    list-style: none;
    padding:    0;
    margin:     0;
    display:    flex;
    flex-direction: column;
    align-items: flex-start;
    gap:        var(--space-3);
    width:      fit-content;
    margin-inline: auto;
}

.hero__bullet {
    display:     flex;
    align-items: center;
    gap:         var(--space-3);
    font-size:   var(--text-sm);
    font-weight: 600;
    color:       rgba(245,245,240,0.82);
    letter-spacing: 0.02em;
}

.hero__bullet-icon {
    color:       var(--color-accent);
    flex-shrink: 0;
    width:       20px;
    height:      20px;
}

.hero__actions {
    display:         flex;
    justify-content: center;
    gap:             var(--space-4);
    flex-wrap:       wrap;
    margin-top:      var(--space-2);
}

.hero__btn-primary {
    display:    inline-flex;
    align-items:center;
    gap:        var(--space-2);
}

.hero__proof {
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             var(--space-3);
    font-size:       var(--text-xs);
    color:           rgba(245,245,240,0.55);
    flex-wrap:       wrap;
}

.hero__proof-stars {
    color:       var(--color-accent);
    letter-spacing:3px;
    font-size:   var(--text-sm);
}

/* Scroll indicator */
.hero__scroll {
    position:       absolute;
    bottom:         var(--space-8);
    left:           50%;
    transform:      translateX(-50%);
    z-index:        5;
    display:        flex;
    flex-direction: column;
    align-items:    center;
    gap:            var(--space-2);
    animation:      hero-scroll 2.5s ease-in-out infinite;
}

.hero__scroll-label {
    font-size:      var(--text-xs);
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color:          rgba(245,245,240,0.4);
    writing-mode:   vertical-rl;
}

.hero__scroll-line {
    width:      1px;
    height:     40px;
    background: linear-gradient(to bottom, var(--color-accent) 0%, transparent 100%);
}

@keyframes hero-scroll {
    0%,100% { transform: translateX(-50%) translateY(0); }
    50%      { transform: translateX(-50%) translateY(7px); }
}

/* ─────────────────────────────────────────────────────────────
   VALUES STRIP
───────────────────────────────────────────────────────────── */

.values-strip {
    background:   #141414;
    border-top:   1px solid rgba(232,163,61,0.12);
    border-bottom:1px solid rgba(232,163,61,0.12);
    padding-block:var(--space-6);
}

.values-grid {
    display:               grid;
    grid-template-columns: repeat(6, 1fr);
    gap:                   0;
}

.value-card {
    display:        flex;
    flex-direction: column;
    align-items:    center;
    justify-content:center;
    text-align:     center;
    gap:            var(--space-2);
    padding:        var(--space-5) var(--space-4);
    border-right:   1px solid rgba(232,163,61,0.1);
    transition:     background var(--transition-base);
    cursor:         default;
}

.value-card:last-child { border-right: none; }

.value-card:hover {
    background: rgba(232,163,61,0.06);
}

.value-card__icon {
    color:  var(--color-accent);
    width:  28px;
    height: 28px;
    display:flex;
}

.value-card__icon svg {
    width:  100%;
    height: 100%;
}

.value-card__title {
    font-size:      var(--text-xs);
    font-weight:    700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color:          var(--color-text-secondary);
    line-height:    1.3;
}

/* ─────────────────────────────────────────────────────────────
   STATS SECTION
───────────────────────────────────────────────────────────── */

.stats-section {
    background:   #0a0a0a;
    padding-block:var(--space-6);
}

/* Trust bar — separadores dentro del contenedor (mismo ancho que las features) */
.trust-bar {
    padding-block: var(--space-8);
    border-top:    1px solid rgba(232,163,61,0.12);
}

.trust-bar__list {
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             clamp(var(--space-5), 4vw, var(--space-8));
    flex-wrap:       wrap;
    list-style:      none;
    padding:         0;
    margin:          0;
    row-gap:         var(--space-4);
}

.trust-bar__item {
    display:    flex;
    align-items:center;
    opacity:    0.6;
    transition: opacity var(--transition-fast);
}

.trust-bar__item:hover { opacity: 1; }

.trust-bar__item--text {
    gap:            var(--space-2);
    font-size:      var(--text-xs);
    font-weight:    700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color:          var(--color-text-secondary);
}

/* ─────────────────────────────────────────────────────────────
   TOURS SECTION
───────────────────────────────────────────────────────────── */

.tours-section {
    background:    #141414;
    padding-block: var(--section-pad);
}

.tours-grid {
    display:               grid;
    grid-template-columns: repeat(4, 1fr);
    gap:                   clamp(var(--space-3), 2vw, var(--space-5));
    margin-top:            var(--space-12);
    align-items:           start;
}

/* Gradientes fallback por tarjeta — cuando no carga imagen */
.tours-grid .tour-card:nth-child(1) .tour-card__bg { background: linear-gradient(155deg, #0c180c 0%, #1a1000 100%); }
.tours-grid .tour-card:nth-child(2) .tour-card__bg { background: linear-gradient(155deg, #001418 0%, #000c18 100%); }
.tours-grid .tour-card:nth-child(3) .tour-card__bg { background: linear-gradient(155deg, #000f1c 0%, #041218 100%); }
.tours-grid .tour-card:nth-child(4) .tour-card__bg { background: linear-gradient(155deg, #120c00 0%, #1a0e00 100%); }

/* ══════════════════════════════════════════════════════════
   TOUR CARD — Premium visual (redesign)
   ══════════════════════════════════════════════════════════ */

.tour-card {
    background:  #131313;
    border:      1px solid rgba(232,163,61,0.13);
    border-radius: 14px;
    overflow:    hidden;
    display:     flex;
    flex-direction: column;
    position:    relative;
    transition:  transform 420ms var(--ease-premium),
                 border-color 250ms ease,
                 box-shadow 420ms var(--ease-premium);
}

/* Acento izquierdo en hover — toque premium */
.tour-card::before {
    content:    '';
    position:   absolute;
    left:       0; top: 0; bottom: 0;
    width:      3px;
    background: linear-gradient(to bottom, var(--color-accent), transparent 80%);
    opacity:    0;
    transition: opacity var(--transition-slow);
    z-index:    3;
    border-radius: 14px 0 0 14px;
}

.tour-card:hover::before { opacity: 1; }

.tour-card:hover {
    transform:    translateY(-7px);
    border-color: rgba(232,163,61,0.42);
    box-shadow:   0 28px 60px rgba(0,0,0,0.7),
                  0 0 0 1px rgba(232,163,61,0.18),
                  0 0 50px rgba(232,163,61,0.05);
}

/* ── Imagen ──────────────────────────────────────────────── */
.tour-card__bg {
    position:   relative;
    height:     240px;
    flex-shrink:0;
    overflow:   hidden;
    background: #080808;
}

.tour-card__bg-img {
    position:   absolute;
    inset:      0;
    width:      100%;
    height:     100%;
    object-fit: cover;
    opacity:    0.82;
    transition: opacity 700ms ease,
                transform 700ms var(--ease-premium);
}

.tour-card:hover .tour-card__bg-img {
    opacity:   0.92;
    transform: scale(1.07);
}

/* Overlay: transparent→dark, imagen respira arriba */
.tour-card__bg-overlay {
    position:   absolute;
    inset:      0;
    background: linear-gradient(
        180deg,
        rgba(10,10,10,0)    0%,
        rgba(10,10,10,0.15) 45%,
        rgba(19,19,19,0.95) 100%
    );
    z-index: 1;
}

/* Duración — cinematic, bottom-left, sin caja */
.tour-card__duration {
    position:    absolute;
    bottom:      var(--space-4);
    left:        var(--space-4);
    z-index:     2;
    font-family: var(--font-display);
    font-size:   2.6rem;
    letter-spacing: 0.01em;
    color:       var(--color-accent);
    line-height: 1;
    text-shadow: 0 2px 16px rgba(0,0,0,0.9),
                 0 0 30px rgba(232,163,61,0.25);
}

/* Badge promo — top-right */
.tour-card__badge {
    position:        absolute;
    top:             var(--space-3);
    right:           var(--space-3);
    z-index:         2;
    font-size:       9px;
    font-weight:     700;
    letter-spacing:  0.1em;
    text-transform:  uppercase;
    padding:         4px 10px;
    border-radius:   var(--radius);
    backdrop-filter: blur(8px);
}

/* ── Cuerpo ──────────────────────────────────────────────── */
.tour-card__body {
    padding:        var(--space-5);
    display:        flex;
    flex-direction: column;
    gap:            var(--space-4);
    flex:           1;
}

/* Título */
.tour-card__title {
    font-family:    var(--font-display);
    font-size:      clamp(1.4rem, 1.7vw, 1.7rem);
    line-height:    1.12;
    letter-spacing: 0.015em;
    text-transform: uppercase;
    color:          #F5F5F0;
    margin:         0;
}

.tour-card__title a       { color: inherit; text-decoration: none; }
.tour-card__title a:hover { color: var(--color-accent); }

/* Tagline */
.tour-card__tagline {
    font-size:      10px;
    font-weight:    700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color:          var(--color-accent);
    margin:         var(--space-2) 0 0;
    opacity:        0.78;
}

/* Separador visual gold */
.tour-card__sep {
    height:     1px;
    border:     none;
    background: linear-gradient(90deg,
        rgba(232,163,61,0.55) 0%,
        rgba(232,163,61,0.15) 60%,
        transparent 100%);
    flex-shrink:0;
    margin:     0;
}

/* Destino */
.tour-card__destination {
    display:    flex;
    align-items:center;
    gap:        var(--space-2);
    font-size:  var(--text-xs);
    font-weight:600;
    color:      var(--color-text-secondary);
}

.tour-card__destination svg { color: var(--color-accent); flex-shrink: 0; }

/* Features */
.tour-card__features {
    list-style: none;
    padding:    0;
    margin:     0;
    display:    grid;
    grid-template-columns: 1fr 1fr;
    gap:        5px var(--space-2);
}

.tour-card__features li {
    font-size:   var(--text-xs);
    color:       var(--color-text-secondary);
    display:     flex;
    align-items: center;
    gap:         5px;
    line-height: 1.35;
    opacity:     0.9;
}

.tour-card__features li::before {
    content:     '';
    width:       4px;
    height:      4px;
    border-radius:50%;
    background:  var(--color-accent);
    flex-shrink: 0;
    opacity:     0.55;
}

/* Intensidad + Briefing */
.tour-card__meta-row {
    display:         flex;
    justify-content: space-between;
    align-items:     center;
    gap:             var(--space-3);
}

.tour-card__meta-label {
    font-size:      9px;
    font-weight:    700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color:          var(--color-text-muted);
    display:        block;
    margin-bottom:  4px;
    line-height:    1.2;
}

.tour-card__dots { display: flex; gap: 4px; align-items: center; }

.tour-card__dot {
    width:         8px;
    height:        8px;
    border-radius: 50%;
    background:    rgba(232,163,61,0.1);
    border:        1px solid rgba(232,163,61,0.22);
}

.tour-card__dot--on {
    background:  var(--color-accent);
    border-color:var(--color-accent);
    box-shadow:  0 0 7px rgba(232,163,61,0.55);
}

/* Briefing badge — solo etiqueta, sin número */
.tour-card__briefing-badge {
    text-align: right;
}

.tour-card__briefing-badge .tour-card__meta-label {
    margin-bottom: 0;
    color:         var(--color-accent);
    opacity:       0.75;
    letter-spacing:0.2em;
}

/* Descripción briefing — discreta, solo info */
.tour-card__briefing-desc {
    font-size:  var(--text-xs);
    color:      rgba(160,160,160,0.55);
    line-height:1.5;
    margin:     0;
    font-style: italic;
}

/* CTA */
.tour-card__cta {
    display:         inline-flex;
    align-items:     center;
    justify-content: center;
    gap:             var(--space-2);
    width:           100%;
    margin-top:      auto;
}

/* Tours CTA inferior */
.tours-section__cta {
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             var(--space-4);
    margin-top:      var(--space-12);
    flex-wrap:       wrap;
}

/* ══════════════════════════════════════════════════════════
   TOURS — Tabs + Nuevos elementos (v2)
   ══════════════════════════════════════════════════════════ */

/* ── Selector vehículo ── */
.tours-tabs {
    display:         flex;
    justify-content: center;
    gap:             var(--space-3);
    margin-top:      var(--space-8);
    flex-wrap:       wrap;
}

.tours-tab-btn {
    display:        inline-flex;
    align-items:    center;
    gap:            var(--space-2);
    padding:        var(--space-3) var(--space-6);
    background:     rgba(255,255,255,0.03);
    border:         1px solid rgba(232,163,61,0.18);
    border-radius:  var(--radius-full);
    color:          var(--color-text-secondary);
    font-size:      var(--text-sm);
    font-weight:    600;
    letter-spacing: 0.06em;
    cursor:         pointer;
    transition:     all 280ms var(--ease-premium);
    min-height:     48px;
}

.tours-tab-btn:hover {
    border-color: rgba(232,163,61,0.45);
    color:        var(--color-accent);
    background:   rgba(232,163,61,0.06);
}

.tours-tab-btn--active {
    background:   rgba(232,163,61,0.12);
    border-color: var(--color-accent);
    color:        var(--color-accent);
    box-shadow:   0 0 22px rgba(232,163,61,0.15);
}

.tours-tab-count {
    font-size:      9px;
    font-weight:    700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding:        3px 8px;
    background:     rgba(232,163,61,0.14);
    border-radius:  var(--radius-full);
    font-style:     normal;
}

/* ── Panels ── */
.tours-panel { margin-top: var(--space-8); }
.tours-panel--hidden { display: none !important; }

/* ── Banner XL ── */
.tours-xl-banner {
    display:      flex;
    align-items:  center;
    flex-wrap:    wrap;
    gap:          var(--space-2) var(--space-3);
    padding:      var(--space-3) var(--space-5);
    background:   rgba(232,163,61,0.06);
    border:       1px solid rgba(232,163,61,0.22);
    border-radius:var(--radius-lg);
    font-size:    var(--text-xs);
    color:        var(--color-text-secondary);
    margin-bottom:var(--space-6);
}

.tours-xl-banner strong {
    color:          var(--color-accent);
    letter-spacing: 0.1em;
    font-size:      10px;
    font-weight:    800;
}

.tours-xl-banner svg { color: var(--color-accent); flex-shrink: 0; }
.tours-xl-banner__sep { color: rgba(232,163,61,0.35); }

/* ── Grid 3 columnas (Quad) ── */
.tours-grid--3col {
    grid-template-columns: repeat(3, 1fr);
}

/* ── Horarios ── */
.tour-card__horarios { display: flex; flex-direction: column; gap: 6px; }

.tour-card__times {
    display:   flex;
    flex-wrap: wrap;
    gap:       5px;
}

.tour-card__time {
    font-size:      9px;
    font-weight:    700;
    letter-spacing: 0.06em;
    padding:        3px 8px;
    background:     rgba(255,255,255,0.05);
    border:         1px solid rgba(255,255,255,0.1);
    border-radius:  4px;
    color:          var(--color-text-secondary);
    white-space:    nowrap;
}

.tour-card__time--night {
    background:   rgba(232,163,61,0.08);
    border-color: rgba(232,163,61,0.25);
    color:        var(--color-accent);
}

/* ── Pricing (Buggy: Standard + XL) ── */
.tour-card__pricing {
    display:      flex;
    align-items:  center;
    gap:          var(--space-3);
    background:   rgba(232,163,61,0.07);
    border-radius:var(--radius);
    padding:      var(--space-3);
}

.tour-card__price-col {
    display:        flex;
    flex-direction: column;
    gap:            3px;
    flex:           1;
}

.tour-card__price-col--xl .tour-card__price-label { color: var(--color-accent); opacity: 0.7; }

.tour-card__price-divider {
    width:        1px;
    height:       36px;
    background:   rgba(232,163,61,0.22);
    flex-shrink:  0;
}

.tour-card__price-label {
    font-size:      10px;
    font-weight:    600;
    letter-spacing: 0.02em;
    color:          var(--color-text-muted);
    line-height:    1.25;
    white-space:    nowrap;
}

.tour-card__price-amount {
    font-family:    var(--font-display);
    font-size:      clamp(1.2rem, 1.6vw, 1.5rem);
    color:          var(--color-accent);
    line-height:    1;
    letter-spacing: 0.01em;
}

.tour-card__price-xl {
    font-size:   clamp(1rem, 1.4vw, 1.2rem);
    color:       rgba(232,163,61,0.8);
}

/* ── Pricing (Quad: single) ── */
.tour-card__pricing--single {
    flex-direction: column;
    align-items:    flex-start;
    gap:            4px;
    padding:        var(--space-3) var(--space-4);
}

/* ── What's included ── */
.tours-includes {
    margin-top:   var(--space-14);
    background:   rgba(255,255,255,0.02);
    border:       1px solid rgba(232,163,61,0.14);
    border-radius:var(--radius-xl);
    padding:      var(--space-8) var(--space-10);
}

.tours-includes__grid {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   var(--space-10);
}

.tours-includes__col { display: flex; flex-direction: column; gap: var(--space-4); }

.tours-includes__heading {
    display:     flex;
    align-items: center;
    gap:         var(--space-3);
    font-size:   var(--text-sm);
    font-weight: 700;
    color:       var(--color-accent);
    margin:      0;
}

.tours-includes__list {
    list-style: none;
    padding:    0;
    margin:     0;
    display:    flex;
    flex-direction: column;
    gap:        var(--space-2);
}

.tours-includes__list li {
    display:     flex;
    align-items: center;
    gap:         var(--space-2);
    font-size:   var(--text-sm);
    color:       var(--color-text-secondary);
}

.tours-includes__list li::before {
    content:      '';
    width:        5px;
    height:       5px;
    border-radius:50%;
    background:   var(--color-accent);
    opacity:      0.55;
    flex-shrink:  0;
}

/* ── Footer CTA ── */
.tours-footer {
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             var(--space-4);
    margin-top:      var(--space-12);
    flex-wrap:       wrap;
}

/* ── Responsive ── */
@media (max-width: 1024px) {
    .tours-grid--3col { grid-template-columns: repeat(2, 1fr); }
    .tours-includes   { padding: var(--space-6) var(--space-8); }
}

@media (max-width: 768px) {
    .tours-grid--3col         { grid-template-columns: 1fr; }
    .tours-includes__grid     { grid-template-columns: 1fr; gap: var(--space-8); }
    .tours-includes           { padding: var(--space-6); }
    .tours-tab-btn            { padding: var(--space-3) var(--space-4); font-size: var(--text-xs); }
    /* Precio en móvil: SIEMPRE en fila y compacto (antes en columna estiraba
       las celdas con flex:1 y dejaba una caja muy alta con huecos). */
    .tour-card__pricing       { flex-direction: row; align-items: center; gap: var(--space-2); }
    .tour-card__price-col     { flex: 1 1 0; text-align: center; }
    .tour-card__price-label   { white-space: normal; }
    .tour-card__price-divider { width: 1px; height: 34px; }
}

@media (max-width: 480px) {
    .tours-tabs               { gap: var(--space-2); }
    .tours-xl-banner          { font-size: 11px; padding: var(--space-3); }
    .tours-footer             { flex-direction: column; align-items: stretch; }
    .tours-footer .btn        { text-align: center; justify-content: center; }
}

/* ═══════════════════════════════════════════════════════════
   EXPERIENCE CATEGORIES (home) — Buggy / Quad / 4x4
═══════════════════════════════════════════════════════════ */
.exp-cats { background: #0a0a0a; padding-block: clamp(3rem, 4.5vw, 4rem); }

.exp-cats__grid {
    display:               grid;
    grid-template-columns: repeat(2, 1fr);
    gap:                   var(--space-6);
    margin-top:            var(--space-12);
    width:                 100%;
}

.exp-cat-card {
    display:        flex;
    flex-direction: column;
    background:     #131313;
    border:         1px solid rgba(232,163,61,0.13);
    border-radius:  var(--radius-xl);
    overflow:       hidden;
    transition:     transform 420ms var(--ease-premium), border-color 250ms ease, box-shadow 420ms var(--ease-premium);
}

.exp-cat-card:hover {
    transform:    translateY(-8px);
    border-color: rgba(232,163,61,0.4);
    box-shadow:   0 28px 60px rgba(0,0,0,0.7), 0 0 0 1px rgba(232,163,61,0.12);
}

.exp-cat-card__media {
    position:      relative;
    aspect-ratio:  4 / 3;
    overflow:      hidden;
    display:       flex;
    align-items:   flex-end;
    background:    linear-gradient(150deg, #1c0c00 0%, #2d1500 40%, #0a0a0a 100%);
}

.exp-cat-card__img {
    position:   absolute;
    inset:      0;
    width:      100%;
    height:     100%;
    object-fit: cover;
    opacity:    0.82;
    transition: transform 800ms var(--ease-premium), opacity 600ms ease;
}

.exp-cat-card:hover .exp-cat-card__img { transform: scale(1.07); opacity: 0.95; }

.exp-cat-card__overlay {
    position:   absolute;
    inset:      0;
    background: linear-gradient(180deg, rgba(10,10,10,0) 35%, rgba(10,10,10,0.55) 70%, rgba(19,19,19,0.96) 100%);
    z-index:    1;
}

.exp-cat-card__badge {
    position: absolute;
    top:      var(--space-4);
    right:    var(--space-4);
    z-index:  3;
    font-size: 9px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 4px 10px;
}

.exp-cat-card__title {
    position:       relative;
    z-index:        2;
    font-family:    var(--font-display);
    font-size:      clamp(1.8rem, 2.6vw, 2.4rem);
    line-height:    0.95;
    text-transform: uppercase;
    color:          #F5F5F0;
    margin:         0;
    padding:        var(--space-6);
}

.exp-cat-card__title-accent { display: block; color: var(--color-accent); }

.exp-cat-card__body {
    display:        flex;
    flex-direction: column;
    gap:            var(--space-5);
    padding:        var(--space-6);
    flex:           1;
}

.exp-cat-card__desc {
    font-size:   var(--text-base);
    color:       var(--color-text-secondary);
    line-height: 1.55;
    margin:      0;
    flex:        1;
}

.exp-cat-card__cta { margin-top: auto; }

/* Fila de garantías */
.exp-features {
    display:               grid;
    grid-template-columns: repeat(4, 1fr);
    gap:                   var(--space-6);
    margin-top:            var(--space-10);
    padding-top:           var(--space-8);
    border-top:            1px solid rgba(232,163,61,0.12);
}

.exp-feature {
    display:     flex;
    align-items: flex-start;
    gap:         var(--space-3);
}

.exp-feature__icon {
    flex-shrink: 0;
    width:       44px;
    height:      44px;
    display:     flex;
    align-items: center;
    justify-content: center;
    border:      1px solid rgba(232,163,61,0.25);
    border-radius: 50%;
    color:       var(--color-accent);
}

.exp-feature__icon svg { width: 20px; height: 20px; }

.exp-feature__text { display: flex; flex-direction: column; gap: 3px; }
.exp-feature__title { font-size: var(--text-sm); font-weight: 700; color: #F5F5F0; }
.exp-feature__desc  { font-size: var(--text-xs); color: var(--color-text-muted); line-height: 1.45; }

@media (max-width: 1024px) {
    .exp-cats__grid { grid-template-columns: 1fr; max-width: 520px; margin-inline: auto; }
    .exp-features   { grid-template-columns: repeat(2, 1fr); gap: var(--space-8) var(--space-6); }
}

@media (max-width: 520px) {
    .exp-features { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════
   SOBRE NOSOTROS — storytelling
═══════════════════════════════════════════════════════════ */
.about-story { background: #0a0a0a; padding-block: var(--section-pad); }
.about-story__inner { max-width: 820px; margin-inline: auto; }
.about-story__text { margin-top: var(--space-6); }
.about-story__text p {
    font-size:     var(--text-lg);
    color:         var(--color-text-secondary);
    line-height:   1.8;
    margin-bottom: var(--space-5);
    max-width:     none;
}
.about-stats {
    display:               grid;
    grid-template-columns: repeat(4, 1fr);
    gap:                   var(--space-6);
    margin-top:            var(--space-12);
    padding-top:           var(--space-10);
    border-top:            1px solid rgba(232,163,61,0.12);
}
.about-stat { display: flex; flex-direction: column; gap: 6px; text-align: center; }
.about-stat__num {
    font-family: var(--font-display);
    font-size:   clamp(2rem, 3vw, 2.8rem);
    color:       var(--color-accent);
    line-height: 1;
}
.about-stat__label { font-size: var(--text-xs); color: var(--color-text-muted); letter-spacing: 0.03em; }

@media (max-width: 640px) {
    .about-stats { grid-template-columns: repeat(2, 1fr); gap: var(--space-8) var(--space-4); }
}

/* ── Página Experience (hub por vehículo) ── */
.exp-quote { padding: clamp(2.5rem, 4vw, 3.5rem) 0 clamp(1rem, 2vw, 1.5rem); text-align: center; }
.exp-quote__text {
    font-family:    var(--font-display);
    font-size:      clamp(2rem, 5vw, 4rem);
    text-transform: uppercase;
    color:          #F5F5F0;
    margin:         0;
    line-height:    1.05;
    letter-spacing: 0.02em;
}
.exp-quote__text em { color: var(--color-accent); font-style: normal; }
.exp-block { padding-block: clamp(1.5rem, 3vw, 2.5rem); }
.exp-block:first-of-type { padding-top: clamp(1rem, 2vw, 1.5rem); }
.exp-block__head { display: flex; align-items: center; gap: var(--space-5); margin-bottom: var(--space-10); }
.exp-block__num { font-family: var(--font-display); font-size: clamp(2rem, 3vw, 2.6rem); color: rgba(232,163,61,0.4); line-height: 1; flex-shrink: 0; }
.exp-block__title { font-family: var(--font-display); font-size: clamp(1.8rem, 3vw, 2.6rem); text-transform: uppercase; color: #F5F5F0; margin: 0; line-height: 1; }
.exp-block__sub { font-size: 0.95rem; color: var(--color-text-secondary); margin: 4px 0 0; }
.exp-grid--single { grid-template-columns: 1fr !important; max-width: 430px; margin-inline: auto; }
.exp-includes-wrap { padding-bottom: clamp(2.5rem, 5vw, 4rem); }

/* ── Fila de acciones de la tarjeta (+ Info / Reservar) ── */
.tour-card__actions { display: flex; flex-wrap: wrap; gap: 10px; align-items: stretch; margin-top: auto; }
.tour-card__actions .tour-card__cta { flex: 1 1 auto; margin: 0; padding-left: 14px; padding-right: 14px; letter-spacing: 0.03em; font-size: var(--text-xs); gap: 6px; }
.tour-card__actions .tour-card__cta svg { width: 12px; height: 12px; }
.tour-card__info {
    flex: 0 0 auto;
    display: inline-flex; align-items: center; justify-content: center; gap: 5px;
    padding: 0 13px; min-height: 46px;
    font-family: var(--font-body); font-size: 0.78rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.06em;
    color: var(--color-accent);
    background: rgba(232,163,61,0.06);
    border: 1px solid rgba(232,163,61,0.35);
    border-radius: 100px; cursor: pointer;
    transition: background .25s ease, border-color .25s ease, color .25s ease, transform .25s ease;
}
.tour-card__info svg { width: 15px; height: 15px; }
.tour-card__info:hover { background: rgba(232,163,61,0.16); border-color: var(--color-accent); transform: translateY(-1px); }
.tour-card__info:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; }

/* Botón terciario: Regala esta experiencia (outline dorado, full-width) */
.tour-card__gift {
    display: flex; align-items: center; justify-content: center; gap: 7px;
    width: 100%; margin-top: 10px; padding: 11px 14px;
    font-family: var(--font-body); font-size: 0.72rem; font-weight: 700;
    letter-spacing: 0.05em; text-transform: uppercase; text-align: center; line-height: 1.15;
    color: var(--color-accent); background: transparent;
    border: 1px solid rgba(232,163,61,0.3); border-radius: 100px;
    text-decoration: none;
    transition: background 0.25s ease, border-color 0.25s ease;
}
.tour-card__gift svg { flex-shrink: 0; }
.tour-card__gift:hover { background: rgba(232,163,61,0.12); border-color: var(--color-accent); }
.tour-card__gift:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; }

/* ── Modal de experiencia (+ Info) ── */
.exp-modal { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: center; justify-content: center; padding: 24px; }
.exp-modal[hidden] { display: none; }
.exp-modal__overlay { position: absolute; inset: 0; background: rgba(8,8,8,0.82); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); opacity: 0; transition: opacity .35s ease; }
.exp-modal.is-open .exp-modal__overlay { opacity: 1; }
.exp-modal__dialog {
    position: relative; z-index: 1;
    width: min(900px, 100%); max-height: 88vh;
    display: grid; grid-template-columns: 1fr 1fr;
    background: #141310; border: 1px solid rgba(232,163,61,0.18);
    border-radius: 22px; overflow: hidden;
    box-shadow: 0 40px 120px rgba(0,0,0,0.6);
    opacity: 0; transform: translateY(18px) scale(0.985);
    transition: opacity .4s ease, transform .45s cubic-bezier(.16,1,.3,1);
}
.exp-modal.is-open .exp-modal__dialog { opacity: 1; transform: none; }
.exp-modal__media { position: relative; min-height: 100%; background: #0d0d0d; }
.exp-modal__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.exp-modal__media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(13,13,13,0) 55%, rgba(13,13,13,0.55) 100%); pointer-events: none; }
.exp-modal__badge-dur { position: absolute; left: 22px; bottom: 20px; z-index: 1; font-family: var(--font-display); font-size: 2.4rem; line-height: 1; color: #fff; text-shadow: 0 2px 24px rgba(0,0,0,0.55); }
.exp-modal__content { padding: 44px; overflow-y: auto; max-height: 88vh; }
.exp-modal__eyebrow { display: inline-block; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-accent); margin-bottom: 12px; }
.exp-modal__title { font-family: var(--font-display); font-size: clamp(1.9rem, 3vw, 2.8rem); line-height: 1.05; text-transform: uppercase; color: #F5F5F0; margin: 0; }
.exp-modal__tagline { font-size: 0.74rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-accent); opacity: 0.85; margin: 8px 0 26px; }
.exp-modal__text p { color: var(--color-text-secondary); line-height: 1.75; margin: 0 0 16px; font-size: 0.95rem; }
.exp-modal__text p:last-child { margin-bottom: 0; }
.exp-modal__lead { color: #ECEAE4 !important; font-size: 1.08rem !important; font-weight: 500; }
.exp-modal__cta { margin-top: 30px; }
.exp-modal__close {
    position: absolute; top: 16px; right: 16px; z-index: 3;
    width: 42px; height: 42px; display: flex; align-items: center; justify-content: center;
    border-radius: 50%; background: rgba(0,0,0,0.45); border: 1px solid rgba(255,255,255,0.18);
    color: #fff; cursor: pointer; backdrop-filter: blur(4px);
    transition: background .25s ease, color .25s ease, border-color .25s ease, transform .35s ease;
}
.exp-modal__close:hover { background: var(--color-accent); border-color: var(--color-accent); color: #141310; transform: rotate(90deg); }
body.mb-modal-open { overflow: hidden; }

@media (max-width: 760px) {
    .exp-modal { padding: 0; align-items: stretch; }
    .exp-modal__dialog { grid-template-columns: 1fr; grid-template-rows: auto minmax(0, 1fr); width: 100%; max-height: 100vh; max-height: 100dvh; border-radius: 0; border: none; overflow: hidden; }
    .exp-modal__media { min-height: 200px; height: 200px; }
    .exp-modal__badge-dur { font-size: 2rem; }
    .exp-modal__content { padding: 30px 22px 40px; max-height: none; overflow-y: auto; -webkit-overflow-scrolling: touch; }
    .exp-modal__close { position: absolute; top: 14px; right: 14px; }
}

/* ── badge--gold y badge--premium ── */
.badge--gold {
    background: rgba(232,163,61,0.18);
    color:      var(--color-accent);
    border:     1px solid rgba(232,163,61,0.35);
}

.badge--premium {
    background: rgba(232,163,61,0.22);
    color:      var(--color-accent);
    border:     1px solid rgba(232,163,61,0.45);
}

/* ─────────────────────────────────────────────────────────────
   WHY US
───────────────────────────────────────────────────────────── */

.why-us-section {
    background:    #0a0a0a;
    padding-block: clamp(3rem, 5vw, 4.5rem);
}

/* ── Cabecera ── */
.why-us__header {
    max-width:    640px;
    margin:       0 auto var(--space-12);
    text-align:   center;
}

.why-us__intro {
    font-size:    var(--text-lg);
    color:        var(--color-text-secondary);
    line-height:  1.6;
    margin-top:   var(--space-5);
}

/* ── Bento grid ── */
.why-bento {
    display:               grid;
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows:        minmax(155px, auto);
    gap:                   var(--space-4);
    grid-auto-flow:        dense;
}
.why-bento__cell--wide { grid-column: span 2; }

.why-bento__cell {
    position:       relative;
    display:        flex;
    flex-direction: column;
    justify-content:flex-end;
    gap:            6px;
    padding:        var(--space-6);
    background:     #161616;
    border:         1px solid rgba(232,163,61,0.13);
    border-radius:  var(--radius-xl);
    overflow:       hidden;
    transition:     transform 420ms var(--ease-premium),
                    border-color 250ms ease,
                    box-shadow 420ms var(--ease-premium);
}

.why-bento__cell:hover {
    transform:    translateY(-5px);
    border-color: rgba(232,163,61,0.4);
    box-shadow:   0 22px 48px rgba(0,0,0,0.55), 0 0 0 1px rgba(232,163,61,0.12);
}

/* Celda imagen: ocupa 2×2 (esquina superior izquierda) */
.why-bento__cell--media {
    grid-column: span 2;
    grid-row:    span 2;
    justify-content: flex-end;
    padding:     0;
    background:  linear-gradient(150deg, #1c0c00 0%, #2d1500 40%, #0a0a0a 100%);
    min-height:  330px;
}

.why-bento__img {
    position:   absolute;
    inset:      0;
    width:      100%;
    height:     100%;
    object-fit: cover;
    opacity:    0.85;
    transition: transform 800ms var(--ease-premium), opacity 600ms ease;
}

.why-bento__cell--media:hover .why-bento__img { transform: scale(1.06); opacity: 0.95; }

.why-bento__media-overlay {
    position:   absolute;
    inset:      0;
    background: linear-gradient(180deg, rgba(10,10,10,0) 40%, rgba(10,10,10,0.85) 100%);
    z-index:    1;
}

.why-bento__media-tag {
    position:       relative;
    z-index:        2;
    display:        inline-flex;
    align-items:    center;
    gap:            7px;
    margin:         var(--space-6);
    padding:        7px 13px;
    background:     rgba(10,10,10,0.55);
    backdrop-filter:blur(8px);
    border:         1px solid rgba(232,163,61,0.3);
    border-radius:  var(--radius-full);
    font-size:      var(--text-xs);
    font-weight:    600;
    letter-spacing: 0.04em;
    color:          #F5F5F0;
    width:          fit-content;
}

.why-bento__media-tag svg { color: var(--color-accent); }

/* Celda highlight (+500) */
.why-bento__cell--highlight {
    grid-column: span 2;
    background:  linear-gradient(135deg, #E8A33D 0%, #C9821F 100%);
    border-color:transparent;
}

.why-bento__cell--highlight .why-bento__value { color: #0a0a0a; }
.why-bento__cell--highlight .why-bento__label { color: #1a1208; }
.why-bento__cell--highlight .why-bento__sub   { color: rgba(26,18,8,0.7); }
.why-bento__cell--highlight:hover {
    box-shadow: 0 22px 48px rgba(232,163,61,0.35);
}

/* Valor grande */
.why-bento__value {
    font-family:    var(--font-display);
    font-size:      clamp(2.6rem, 4vw, 3.6rem);
    line-height:    0.9;
    letter-spacing: 0.01em;
    color:          var(--color-accent);
}

.why-bento__value small {
    font-size: 0.42em;
    margin-left: 3px;
    opacity:   0.85;
}

.why-bento__icon {
    color:        var(--color-accent);
    margin-bottom:auto;
}

.why-bento__label {
    font-size:   var(--text-base);
    font-weight: 700;
    color:       #F5F5F0;
    line-height: 1.2;
}

.why-bento__label--lg { font-size: var(--text-lg); }

.why-bento__sub {
    font-size:   var(--text-xs);
    color:       var(--color-text-muted);
    line-height: 1.4;
}

/* ── CTA ── */
.why-us__cta {
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             var(--space-4);
    margin-top:      var(--space-16);
    flex-wrap:       wrap;
}


/* ─────────────────────────────────────────────────────────────
   FLEET SECTION — grid de 3 vehículos
───────────────────────────────────────────────────────────── */

.fleet-section { background: #141414; padding-block: clamp(3.5rem, 6vw, 5.5rem); overflow: hidden; }

.fleet-grid {
    display:               grid;
    grid-template-columns: repeat(2, 1fr);
    gap:                   var(--space-6);
    margin-top:            var(--space-12);
    width:                 100%;
}

.fleet-card {
    display:        flex;
    flex-direction: column;
    background:     #1a1a1a;
    border:         1px solid rgba(232,163,61,0.13);
    border-radius:  var(--radius-xl);
    overflow:       hidden;
    transition:     transform 420ms var(--ease-premium), border-color 250ms ease, box-shadow 420ms var(--ease-premium);
}

.fleet-card:hover {
    transform:    translateY(-6px);
    border-color: rgba(232,163,61,0.4);
    box-shadow:   0 22px 48px rgba(0,0,0,0.55);
}

.fleet-card__media {
    position:        relative;
    aspect-ratio:    16 / 10;
    display:         flex;
    align-items:     center;
    justify-content: center;
    overflow:        hidden;
}

.fleet-card__type {
    position:       absolute;
    top:            var(--space-4);
    left:           var(--space-4);
    font-size:      10px;
    font-weight:    700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color:          var(--color-accent);
    background:     rgba(10,10,10,0.55);
    border:         1px solid rgba(232,163,61,0.3);
    border-radius:  var(--radius-full);
    padding:        5px 12px;
    backdrop-filter:blur(8px);
}

.fleet-card__ghost {
    font-family:    var(--font-display);
    font-size:      clamp(1.1rem, 2vw, 1.5rem);
    text-transform: uppercase;
    color:          rgba(232,163,61,0.18);
    text-align:     center;
    padding:        0 var(--space-5);
    letter-spacing: 0.02em;
}

.fleet-card__body { display: flex; flex-direction: column; gap: var(--space-4); padding: var(--space-6); }
.fleet-card__model { font-family: var(--font-display); font-size: clamp(1.4rem, 2vw, 1.7rem); text-transform: uppercase; color: #F5F5F0; margin: 0; line-height: 1; }
.fleet-card__sub { font-size: var(--text-sm); color: var(--color-accent); font-weight: 600; letter-spacing: 0.04em; margin: 0; }

.fleet-card__specs {
    display:               grid;
    grid-template-columns: repeat(2, 1fr);
    gap:                   1px;
    background:            rgba(232,163,61,0.13);
    border-radius:         var(--radius-lg);
    overflow:              hidden;
}

.fleet-spec { background: #1a1a1a; padding: 14px 16px; display: flex; flex-direction: column; gap: 3px; }
.fleet-spec__value { font-family: var(--font-display); font-size: 1.5rem; color: var(--color-accent); line-height: 1; }
.fleet-spec__value small { font-size: 0.5em; margin-left: 2px; opacity: 0.85; }
.fleet-spec__label { font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-text-muted); }

.fleet-card__tags { display: flex; flex-wrap: wrap; gap: 6px; }
.fleet-card__tag { font-size: 10px; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; color: var(--color-text-secondary); border: 1px solid var(--color-border-strong); border-radius: var(--radius-full); padding: 4px 10px; }

.fleet-cta {
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             var(--space-6);
    flex-wrap:       wrap;
    margin-top:      var(--space-12);
    padding-top:     var(--space-8);
    border-top:      1px solid rgba(232,163,61,0.12);
    text-align:      center;
}

.fleet-cta__text { font-size: var(--text-sm); color: var(--color-text-secondary); max-width: 480px; }

@media (max-width: 1024px) {
    .fleet-grid { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; }
}

/* ─────────────────────────────────────────────────────────────
   EQUIPMENT SECTION
───────────────────────────────────────────────────────────── */

.equipment-section {
    background:    #0a0a0a;
    padding-block: var(--section-pad);
}

.equipment-grid {
    display:               grid;
    grid-template-columns: repeat(5, 1fr);
    gap:                   var(--space-5);
    margin-top:            var(--space-12);
}

.equipment-card {
    background:    #141414;
    border:        1px solid rgba(232,163,61,0.1);
    border-radius: var(--radius-lg);
    padding:       var(--space-8) var(--space-5);
    display:       flex;
    flex-direction:column;
    align-items:   center;
    text-align:    center;
    gap:           var(--space-4);
    transition:    all var(--transition-base);
    position:      relative;
    overflow:      hidden;
}

.equipment-card::before {
    content:    '';
    position:   absolute;
    bottom:     0;
    left:       0;
    right:      0;
    height:     2px;
    background: var(--color-accent);
    transform:  scaleX(0);
    transform-origin:left;
    transition: transform var(--transition-base);
}

.equipment-card:hover {
    border-color:var(--color-border-strong);
    transform:   translateY(-3px);
    box-shadow:  0 12px 32px rgba(0,0,0,0.4);
}

.equipment-card:hover::before { transform: scaleX(1); }

.equipment-card__icon {
    width:            52px;
    height:           52px;
    background:       rgba(232,163,61,0.08);
    border-radius:    var(--radius);
    display:          flex;
    align-items:      center;
    justify-content:  center;
    color:            var(--color-accent);
    transition:       background var(--transition-base);
}

.equipment-card:hover .equipment-card__icon {
    background: rgba(232,163,61,0.2);
}

.equipment-card__icon svg { width: 26px; height: 26px; }

.equipment-card__name {
    font-size:      var(--text-sm);
    font-weight:    700;
    color:          var(--color-text-primary);
    letter-spacing: 0.04em;
}

.equipment-card__sub {
    font-size:  var(--text-xs);
    color:      var(--color-text-muted);
    line-height:1.5;
}

/* Nota informativa — centrada */
.equipment-section__note {
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             var(--space-3);
    margin-top:      var(--space-10);
    max-width:       660px;
    margin-inline:   auto;
    text-align:      center;
    color:           var(--color-text-muted);
}
.equipment-section__note svg { color: var(--color-accent); flex-shrink: 0; }
.equipment-section__note p   { margin: 0; font-size: var(--text-sm); line-height: 1.6; }
.equipment-section__note a   { color: var(--color-accent); font-weight: 600; }

/* Equipación — grid minimalista (visible siempre, sin animación) */
.equip-grid {
    display:               grid;
    grid-template-columns: repeat(3, 1fr);
    gap:                   var(--space-4);
    margin-top:            var(--space-12);
}
.equip-item {
    display:       flex;
    align-items:   flex-start;
    gap:           var(--space-4);
    padding:       var(--space-6);
    background:    rgba(255,255,255,0.02);
    border:        1px solid rgba(232,163,61,0.14);
    border-radius: 14px;
    transition:    border-color 300ms ease, background 300ms ease, transform 300ms ease;
}
.equip-item:hover { border-color: rgba(232,163,61,0.35); background: rgba(232,163,61,0.04); transform: translateY(-3px); }
.equip-item__icon {
    flex-shrink:   0;
    width:         46px;
    height:        46px;
    display:       flex;
    align-items:   center;
    justify-content:center;
    border:        1px solid rgba(232,163,61,0.25);
    border-radius: 50%;
    color:         var(--color-accent);
}
.equip-item__icon svg { width: 23px; height: 23px; }
.equip-item__text  { flex: 1; }
.equip-item__title { font-size: 1rem; font-weight: 700; color: #F5F5F0; margin: 0 0 4px; }
.equip-item__desc  { font-size: 0.8125rem; color: var(--color-text-muted); line-height: 1.5; margin: 0; }
.equip-item__check {
    flex-shrink:   0;
    width:         24px;
    height:        24px;
    display:       flex;
    align-items:   center;
    justify-content:center;
    border-radius: 50%;
    background:    rgba(232,163,61,0.15);
    color:         var(--color-accent);
}
@media (max-width: 900px) { .equip-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .equip-grid { grid-template-columns: 1fr; } }

/* ─────────────────────────────────────────────────────────────
   EXCLUSIVE BANNER
───────────────────────────────────────────────────────────── */

.exclusive-banner {
    position:   relative;
    background: #0a0a0a;
    overflow:   hidden;
    padding-block:var(--section-pad);
}

.exclusive-banner__bg {
    position: absolute;
    inset:    0;
    z-index:  0;
    overflow: hidden;
    background: linear-gradient(135deg, #1a0800 0%, #0a0a0a 60%);
}

.exclusive-banner__photo {
    position:   absolute;
    inset:      0;
    width:      100%;
    height:     100%;
    object-fit: cover;
    opacity:    0.6;
    transform:  scale(1.02);
}

.exclusive-banner__bg::after {
    content:    '';
    position:   absolute;
    inset:      0;
    background: linear-gradient(95deg, rgba(10,10,10,0.94) 0%, rgba(10,10,10,0.78) 42%, rgba(10,10,10,0.30) 75%, rgba(10,10,10,0.55) 100%);
    z-index:    1;
}

.exclusive-banner__container {
    position:              relative;
    z-index:               1;
    display:               grid;
    grid-template-columns: 1fr auto;
    gap:                   var(--space-16);
    align-items:           center;
}

.exclusive-banner__eyebrow {
    display:        inline-block;
    font-size:      var(--text-xs);
    font-weight:    700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color:          var(--color-accent);
    margin-bottom:  var(--space-3);
}

.exclusive-banner__title {
    font-size:    clamp(2.5rem, 5vw, 4.5rem);
    line-height:  0.95;
    margin-bottom:var(--space-8);
}

.exclusive-banner__features {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   var(--space-3) var(--space-8);
    margin-bottom:         var(--space-10);
}

.exclusive-banner__feature {
    display:     flex;
    align-items: center;
    gap:         var(--space-3);
    font-size:   var(--text-sm);
    font-weight: 600;
    color:       rgba(245,245,240,0.8);
}

.exclusive-banner__feature-check {
    width:         20px;
    height:        20px;
    background:    rgba(232,163,61,0.15);
    border-radius: 50%;
    display:       flex;
    align-items:   center;
    justify-content:center;
    color:         var(--color-accent);
    flex-shrink:   0;
}

.exclusive-banner__feature-check svg { width: 11px; height: 11px; }

.exclusive-banner__actions { display: flex; gap: var(--space-4); flex-wrap: wrap; }

/* Price card lado derecho — destacada con glow dorado */
.exclusive-banner__price-card {
    background:    linear-gradient(160deg, rgba(28,20,8,0.96) 0%, rgba(16,16,16,0.96) 100%);
    border:        1px solid rgba(232,163,61,0.4);
    border-radius: var(--radius-xl);
    padding:       var(--space-10) var(--space-8);
    text-align:    center;
    min-width:     240px;
    box-shadow:    0 24px 60px rgba(0,0,0,0.55), 0 0 0 1px rgba(232,163,61,0.12), 0 0 50px rgba(232,163,61,0.15);
}

.exclusive-banner__price-label {
    font-size:      var(--text-xs);
    font-weight:    700;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color:          var(--color-text-muted);
    margin-bottom:  var(--space-3);
    display:        block;
}

.exclusive-banner__price-amount {
    font-family:    var(--font-display);
    font-size:      clamp(2.5rem, 5vw, 4rem);
    color:          var(--color-accent);
    line-height:    1;
    display:        block;
    margin-bottom:  var(--space-2);
}

.exclusive-banner__price-per {
    font-size:   var(--text-xs);
    color:       var(--color-text-muted);
    margin-bottom:var(--space-6);
    display:     block;
}

/* ─────────────────────────────────────────────────────────────
   CTA FINAL
───────────────────────────────────────────────────────────── */

.cta-final {
    background:  var(--color-accent);
    padding-block:var(--section-pad);
    position:    relative;
    overflow:    hidden;
}

.cta-final::before {
    content:    '';
    position:   absolute;
    inset:      0;
    background-image: repeating-linear-gradient(
        45deg,
        transparent,
        transparent 30px,
        rgba(0,0,0,0.03) 30px,
        rgba(0,0,0,0.03) 31px
    );
}

.cta-final__inner {
    position:   relative;
    z-index:    1;
    text-align: center;
    max-width:  720px;
    margin-inline:auto;
}

.cta-final__eyebrow {
    display:        inline-block;
    font-size:      var(--text-xs);
    font-weight:    700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color:          rgba(0,0,0,0.55);
    margin-bottom:  var(--space-4);
}

.cta-final__title {
    font-size:    clamp(2.2rem, 5vw, 4rem);
    line-height:  1.0;
    color:        #000;
    margin-bottom:var(--space-5);
}

.cta-final__subtitle {
    font-size:    var(--text-lg);
    color:        #000;
    margin-bottom:var(--space-10);
    max-width:    none;
    line-height:  1.55;
}

/* Prueba social bajo el CTA: legible sobre el fondo dorado */
.cta-final__social-proof {
    display:         flex;
    align-items:     center;
    gap:             var(--space-3);
    flex-wrap:       wrap;
    margin-bottom:   var(--space-8);
}

.cta-final__social-text {
    font-size:   var(--text-sm);
    font-weight: 700;
    color:       #000;
    margin:      0;
}

/* Avatars proof */
.cta-final__proof {
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             var(--space-3);
    margin-bottom:   var(--space-8);
}

.cta-final__avatars {
    display:  flex;
    margin:   0;
}

.cta-final__avatar {
    width:        36px;
    height:       36px;
    border-radius:50%;
    background:   rgba(0,0,0,0.2);
    border:       2px solid var(--color-accent);
    display:      flex;
    align-items:  center;
    justify-content:center;
    font-size:    0.7rem;
    font-weight:  900;
    color:        #000;
    margin-left:  -10px;
    flex-shrink:  0;
}

.cta-final__avatars .cta-final__avatar:first-child { margin-left: 0; }

.cta-final__proof-text {
    font-size:   var(--text-sm);
    font-weight: 700;
    color:       rgba(0,0,0,0.7);
}

/* Actions */
.cta-final__actions {
    display:         flex;
    align-items:     center;
    justify-content: center;
    gap:             var(--space-4);
    flex-wrap:       wrap;
    margin-bottom:   var(--space-8);
}

.btn--dark {
    background:   #000;
    color:        var(--color-accent);
    border-color: #000;
}

.btn--dark:hover {
    background:   #1a1a1a;
    border-color: #1a1a1a;
    color:        var(--color-accent);
    transform:    translateY(-2px);
}

.btn--outline-dark {
    background:   transparent;
    color:        #000;
    border-color: rgba(0,0,0,0.4);
}

.btn--outline-dark:hover {
    background:   rgba(0,0,0,0.08);
    border-color: #000;
    color:        #000;
    transform:    translateY(-2px);
}

/* Guarantees */
.cta-final__guarantees {
    display:         flex;
    justify-content: center;
    gap:             var(--space-8);
    flex-wrap:       wrap;
}

.cta-final__guarantee {
    display:     flex;
    align-items: center;
    gap:         var(--space-2);
}

.cta-final__guarantee-icon { font-size: var(--text-base); }

.cta-final__guarantee-text {
    font-size:  var(--text-xs);
    font-weight:700;
    color:      rgba(0,0,0,0.6);
}

/* ─────────────────────────────────────────────────────────────
   SECTION HEADER — variantes
───────────────────────────────────────────────────────────── */

.section-header {
    margin-bottom: var(--space-14);
}

.section-header__eyebrow {
    display:        block;
    font-size:      var(--text-xs);
    font-weight:    700;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color:          var(--color-accent);
    margin-bottom:  var(--space-3);
}

.section-header__title {
    font-size:    clamp(2rem, 4vw, 3.5rem);
    line-height:  1.0;
    margin:       0;
}

.section-header__title em {
    font-style: normal;
    color:      var(--color-accent);
}

/* Acento de texto: la clase se usaba en muchos títulos pero no estaba definida */
/* (en páginas sin tours.css salía en blanco). Define el amarillo de marca.      */
.text-accent { color: var(--color-accent); font-style: normal; }

.section-header--center {
    text-align:   center;
    max-width:    640px;
    margin-inline:auto;
    margin-bottom:var(--space-14);
}

.section-header--split {
    display:               grid;
    grid-template-columns: 1fr auto;
    align-items:           flex-end;
    gap:                   var(--space-8);
}

.section-header__right {
    display:     flex;
    flex-direction:column;
    align-items: flex-end;
    gap:         var(--space-3);
    text-align:  right;
}

.section-header__desc {
    font-size:   var(--text-base);
    color:       var(--color-text-secondary);
    max-width:   40ch;
    line-height: 1.6;
    margin:      0;
}

/* ─────────────────────────────────────────────────────────────
   BADGES
───────────────────────────────────────────────────────────── */

.badge--green   { background:rgba(16,185,129,0.12);  color:#10B981; border-color:rgba(16,185,129,0.25); }
.badge--amber   { background:rgba(245,158,11,0.12);  color:#F59E0B; border-color:rgba(245,158,11,0.25); }
.badge--red     { background:rgba(239,68,68,0.12);   color:#EF4444; border-color:rgba(239,68,68,0.25);  }
.badge--outline { background:transparent; border:1px solid var(--color-border-strong); color:var(--color-text-secondary); }
.badge--sm      { font-size:0.6rem; padding:3px 8px; }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE MOBILE-FIRST — Completo
═══════════════════════════════════════════════════════════ */

/* ── TABLET LANDSCAPE ≤1200px ── */
@media (max-width: 1200px) {
    .nav__list { gap: var(--space-4); }
}

/* ── HEADER: hamburguesa cuando el menú completo (8 ítems) no cabe holgado ── */
@media (max-width: 1320px) {
    .header__nav     { display: none; }
    .header__actions .lang-switcher { display: none; }
    .header__menu-toggle { display: flex; margin-left: auto; }
}

/* ── TABLET ≤1024px — layouts ── */
@media (max-width: 1024px) {

    /* Hero: full-width, centrado */
    .hero__container {
        display:        flex;
        text-align:     center;
        padding-top:    clamp(5.5rem, 16vh, 9rem);
    }
    .hero__eyebrow { justify-content: center; }
    .hero__content { align-items: center; max-width: 100%; }
    .hero__bullets { align-items: flex-start; display: inline-flex; flex-direction: column; text-align: left; }
    .hero__actions { justify-content: center; }
    .hero__proof   { justify-content: center; }

    /* Values: 3 columnas en tablet (5 ítems → 3+2) */
    .values-grid { grid-template-columns: repeat(3, 1fr); }
    .value-card  { border-bottom: 1px solid rgba(232,163,61,0.1); }

    /* Tours: 2 columnas */
    .tours-grid { grid-template-columns: repeat(2, 1fr); }
    .tour-card__bg { height: 260px; }
    .tour-card__title { font-size: clamp(1.5rem, 2.5vw, 1.8rem); }
    .tour-card__duration { font-size: 3rem; }

    /* Why us — bento a 2 columnas */
    .why-bento { grid-template-columns: repeat(2, 1fr); }
    .why-bento__cell--media     { grid-column: span 2; grid-row: span 1; min-height: 240px; }
    .why-bento__cell--highlight { grid-column: span 2; }

    /* Fleet */
    .fleet-slide__inner { grid-template-columns: 1fr; }
    .fleet-slide__img   { min-height: 260px; }
    .fleet-slide__specs { grid-template-columns: repeat(4, 1fr); }

    /* Equipment: 3 cols */
    .equipment-grid { grid-template-columns: repeat(3, 1fr); }

    /* Exclusive */
    .exclusive-banner__container  { grid-template-columns: 1fr; }
    .exclusive-banner__price-card { display: none; }
    .exclusive-banner__features   { grid-template-columns: 1fr; }
}

/* ── TABLET PORTRAIT ≤768px ── */
@media (max-width: 768px) {

    /* Espaciado global reducido */
    :root {
        --section-pad: clamp(3rem, 8vw, 5rem);
        --gutter:      clamp(1rem, 4vw, 1.5rem);
    }

    /* Botones: tamaño táctil mínimo 44px */
    .btn { min-height: 44px; padding: 12px 24px; }
    .btn--sm { min-height: 40px; padding: 10px 18px; }
    .btn--lg { padding: 16px 28px; }

    /* Values: 2 col */
    .values-grid { grid-template-columns: repeat(2, 1fr); }
    .value-card:nth-child(3n) { border-right: 1px solid rgba(232,163,61,0.1); }
    .value-card:nth-child(2n) { border-right: none; }
    .value-card { padding: var(--space-4) var(--space-3); }

    /* Tours: 1 columna */
    .tours-grid { grid-template-columns: 1fr; }
    .tour-card__bg { height: 280px; }
    .tour-card__duration { font-size: 3.2rem; }

    /* Equipment */
    .equipment-grid { grid-template-columns: repeat(2, 1fr); }

    /* Fleet */
    .fleet-slide__specs { grid-template-columns: repeat(2, 1fr); }

    /* CTA final */
    .cta-final__actions  { flex-direction: column; align-items: stretch; }
    .cta-final__actions .btn { text-align: center; justify-content: center; }
    .cta-final__guarantees   { gap: var(--space-4); flex-direction: column; align-items: center; }

    /* Trust bar */
    .trust-bar__list     { gap: var(--space-5); }

    /* Section CTAs */
    .tours-section__cta  { flex-direction: column; align-items: center; }
    .fleet-section__cta  { flex-direction: column; }
    .hero__actions       { flex-direction: column; align-items: center; }
    .hero__actions .btn  { width: 100%; max-width: 320px; justify-content: center; }

    /* Why us CTA */
    .why-us__cta         { flex-direction: column; }

    /* Section headers */
    .section-header--split { grid-template-columns: 1fr; }
    .section-header__right { align-items: flex-start; text-align: left; }
}

/* ── MOBILE ≤480px ── */
@media (max-width: 480px) {

    /* Título hero más pequeño pero impactante */
    .hero__title { font-size: clamp(3rem, 17vw, 4.5rem); }
    .hero__subtitle { font-size: var(--text-sm); }

    /* Una sola columna para todo */
    .values-grid    { grid-template-columns: repeat(2, 1fr); }
    .equipment-grid { grid-template-columns: 1fr; }
    .exclusive-banner__features { grid-template-columns: 1fr; }

    /* Logo más pequeño en header */
    .header__logo img, .header__logo svg { height: 38px; }

    /* Overlay nav: fuente más compacta en móviles pequeños */
    .nav-overlay .nav__list li a,
    .nav-overlay .nav__link {
        font-size: var(--text-2xl);
    }

    /* Fleet specs: 2 col */
    .fleet-slide__specs { grid-template-columns: repeat(2, 1fr); }

    /* Tour card: imagen compacta */
    .tour-card__bg { height: 240px; }
    .tour-card__duration { font-size: 2.8rem; }

    /* Proof row: columna */
    .hero__proof { flex-direction: column; align-items: center; gap: var(--space-2); text-align: center; }

    /* Why us bento: imagen y celdas compactas */
    .why-bento               { gap: var(--space-3); }
    .why-bento__cell         { padding: var(--space-5); min-height: 130px; }
    .why-bento__cell--media  { min-height: 200px; }

    /* Exclusive features: texto más pequeño */
    .exclusive-banner__feature { font-size: var(--text-xs); }
    .exclusive-banner__title   { font-size: clamp(1.8rem, 7vw, 2.5rem); }
}

/* ── MOBILE PEQUEÑO ≤375px ── */
@media (max-width: 375px) {
    .hero__title     { font-size: clamp(2.6rem, 16vw, 3.8rem); }
    .btn--lg         { padding: 14px 20px; font-size: 0.7rem; }
    .why-bento__value { font-size: clamp(2.2rem, 11vw, 3rem); }
}

/* ── LANDSCAPE MÓVIL ── */
@media (max-width: 768px) and (orientation: landscape) and (max-height: 500px) {
    .hero {
        min-height: 100vh;
        min-height: 100dvh; /* viewport dinámico: evita saltos con la barra del navegador */
        padding-top: 5rem;
    }
    .hero__title { font-size: clamp(2.2rem, 8vw, 3rem); }
    .hero__bullets { display: none; }
    .hero__scroll  { display: none; }
}

/* ── TOUCH: mejorar interacción táctil ── */
@media (hover: none) and (pointer: coarse) {
    /* Sin hover effects en móvil real */
    .tour-card:hover      { transform: none; }
    .tour-card:hover .tour-card__bg-img { transform: none; opacity: 0.7; }
    .equipment-card:hover { transform: none; }
    .btn:hover            { transform: none; }

    /* Área táctil mínima 44×44px en todos los links interactivos */
    .nav__link,
    .nav-overlay .nav__link { min-height: 44px; display: flex; align-items: center; }
    .lang-switcher__toggle  { min-height: 44px; }
    .header__menu-toggle    { width: 44px; height: 44px; }

    /* Quitar efectos de transición complejos para mejor rendimiento */
    .hero__bg-photo { transition: none; }
    .tour-card__bg-img { transition: none; }
}

/* ── ACCESIBILIDAD: preferencia sin movimiento ── */
@media (prefers-reduced-motion: reduce) {
    .hero__eyebrow-dot { animation: none; }
    .hero__scroll      { animation: none; }
    * { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}



/* ─────────────────────────────────────────────────────────────
   PÁGINA VIP
───────────────────────────────────────────────────────────── */

.page-vip { background: #0a0a0a; }

/* Hero VIP */
.page-hero--vip {
    position:    relative;
    min-height:  80svh;
    display:     flex;
    align-items: center;
    overflow:    hidden;
    background:  #0a0a0a;
}

.page-hero__bg {
    position: absolute;
    inset: 0;
}
.page-hero__photo {
    width: 100%; height: 100%; object-fit: cover; opacity: 0.45;
}
.page-hero__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(120deg, rgba(10,10,10,0.92) 0%, rgba(10,10,10,0.55) 100%);
}
.page-hero__container {
    position: relative; z-index: 1;
    padding-block: clamp(5rem, 12vh, 9rem);
}
.page-hero__content { max-width: 640px; display: flex; flex-direction: column; gap: var(--space-6); }
.page-hero__title {
    font-family: var(--font-display);
    font-size:   var(--text-7xl);
    line-height: 0.92;
    color:       var(--color-text-primary);
}
.page-hero__desc { font-size: var(--text-lg); color: var(--color-text-secondary); max-width: 520px; }

/* VIP includes */
.vip-includes {
    background:   #0a0a0a;
    padding-block:var(--section-pad);
}

.vip-grid {
    display:               grid;
    grid-template-columns: repeat(3, 1fr);
    gap:                   var(--space-6);
    margin-top:            var(--space-12);
}

.vip-card {
    background:   rgba(20,20,20,0.8);
    border:       1px solid rgba(232,163,61,0.12);
    border-radius:var(--radius-lg);
    padding:      var(--space-8) var(--space-6);
    display:      flex;
    flex-direction:column;
    gap:          var(--space-4);
    transition:   border-color var(--transition-base), transform var(--transition-base);
}
.vip-card:hover {
    border-color: rgba(232,163,61,0.35);
    transform:    translateY(-3px);
}
.vip-card__icon { color: var(--color-accent); width: 28px; height: 28px; }
.vip-card__icon svg { width: 28px; height: 28px; }
.vip-card__title { font-size: var(--text-lg); font-weight: 700; color: var(--color-text-primary); }
.vip-card__desc  { font-size: var(--text-sm); color: var(--color-text-secondary); line-height: 1.6; margin: 0; }

/* VIP CTA */
.vip-cta {
    background:   #141414;
    padding-block:var(--section-pad);
    border-top:   1px solid rgba(232,163,61,0.12);
}
.vip-cta__inner {
    max-width:     640px;
    margin-inline: auto;
    text-align:    center;
    display:       flex;
    flex-direction:column;
    gap:           var(--space-6);
    align-items:   center;
}
.vip-cta__title {
    font-family: var(--font-display);
    font-size:   var(--text-5xl);
    line-height: 1.05;
    color:       var(--color-text-primary);
}
.vip-cta__text  { font-size: var(--text-base); color: var(--color-text-secondary); max-width: 480px; }
.vip-cta__actions { display: flex; gap: var(--space-4); flex-wrap: wrap; justify-content: center; }

/* Responsive VIP */
@media (max-width: 768px) {
    .vip-grid  { grid-template-columns: 1fr; }
    .vip-cta__actions { flex-direction: column; align-items: stretch; }
    .page-hero__title { font-size: var(--text-6xl); }
}

/* ══════════════════════════════════════════════════════════
   EXPEDITIONS — expediciones multi-día (The Smugglers Raid)
   ══════════════════════════════════════════════════════════ */

/* Expedición destacada */
.exped-feature { padding-block: clamp(2.5rem, 6vw, 5rem); }
.exped-feature__inner {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: clamp(1.5rem, 4vw, 3.5rem);
    align-items: center;
}
.exped-feature__media {
    position: relative;
    aspect-ratio: 4 / 3;
    border-radius: var(--radius-xl);
    overflow: hidden;
    background: linear-gradient(155deg, #14213a 0%, #0c1018 100%);
    border: 1px solid rgba(232,163,61,0.18);
}
.exped-feature__media img { width: 100%; height: 100%; object-fit: cover; }
.exped-feature__media::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(10,10,10,0) 55%, rgba(10,10,10,0.5) 100%);
    pointer-events: none;
}
.exped-feature__flag {
    position: absolute; top: 16px; left: 16px; z-index: 1;
    font-size: 11px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase;
    color: #0A0A0A; background: var(--color-accent);
    padding: 6px 14px; border-radius: var(--radius-full);
}
.exped-feature__eyebrow {
    display: block; font-size: var(--text-xs); font-weight: 700;
    letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-accent);
    margin-bottom: var(--space-3);
}
.exped-feature__title {
    font-family: var(--font-display); font-size: clamp(2.4rem, 6vw, 4rem);
    line-height: 1; text-transform: uppercase; color: var(--color-text-primary);
    margin: 0 0 var(--space-2);
}
.exped-feature__sub {
    font-size: var(--text-sm); font-weight: 600; letter-spacing: 0.04em;
    color: var(--color-text-secondary); margin: 0 0 var(--space-5);
}
.exped-feature__lead {
    font-size: var(--text-base); line-height: 1.7; color: var(--color-text-secondary);
    margin: 0 0 var(--space-6);
}

/* Stats */
.exped-stats {
    list-style: none; margin: 0 0 var(--space-6); padding: 0;
    display: flex; flex-wrap: wrap; gap: var(--space-6);
    border-top: 1px solid rgba(232,163,61,0.15);
    border-bottom: 1px solid rgba(232,163,61,0.15);
    padding-block: var(--space-4);
}
.exped-stats li { display: flex; flex-direction: column; gap: 2px; }
.exped-stats strong {
    font-family: var(--font-display); font-size: clamp(1.6rem, 3vw, 2.2rem);
    color: var(--color-accent); line-height: 1;
}
.exped-stats span {
    font-size: 11px; font-weight: 600; letter-spacing: 0.08em;
    text-transform: uppercase; color: var(--color-text-muted);
}

/* Precio destacado */
.exped-price {
    display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
    gap: var(--space-5);
    background: linear-gradient(135deg, rgba(232,163,61,0.10), rgba(232,163,61,0.03));
    border: 1px solid rgba(232,163,61,0.3);
    border-radius: var(--radius-lg);
    padding: var(--space-5) var(--space-6);
}
.exped-price__label {
    display: block; font-size: 11px; font-weight: 600; letter-spacing: 0.06em;
    text-transform: uppercase; color: var(--color-text-muted); margin-bottom: 4px;
}
.exped-price__amount {
    font-family: var(--font-display); font-size: clamp(2.2rem, 5vw, 3rem);
    color: var(--color-text-primary); line-height: 1;
}
.exped-price__amount em { color: var(--color-accent); font-style: normal; }
.exped-price__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }

/* Qué incluye */
.exped-includes-wrap { padding-block: clamp(2.5rem, 5vw, 4rem); background: rgba(255,255,255,0.015); }
.exped-includes {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: clamp(0.75rem, 2vw, 1.25rem); margin-top: var(--space-10);
}
.exped-include {
    background: var(--color-bg-secondary);
    border: 1px solid rgba(232,163,61,0.12);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    transition: border-color 0.25s ease, transform 0.25s ease;
}
.exped-include:hover { border-color: rgba(232,163,61,0.35); transform: translateY(-3px); }
.exped-include__icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 48px; height: 48px; border-radius: var(--radius);
    background: rgba(232,163,61,0.1); color: var(--color-accent);
    margin-bottom: var(--space-4);
}
.exped-include__title {
    font-family: var(--font-display); font-size: 1.25rem; text-transform: uppercase;
    color: var(--color-text-primary); margin: 0 0 var(--space-2); line-height: 1.1;
}
.exped-include__desc { font-size: var(--text-sm); line-height: 1.6; color: var(--color-text-secondary); margin: 0; }
.exped-include__list { list-style: none; margin: var(--space-2) 0 0; padding: 0; display: grid; gap: 6px; }
.exped-include__list li {
    position: relative; padding-left: 18px; font-size: var(--text-sm); color: var(--color-text-secondary);
}
.exped-include__list li::before {
    content: ""; position: absolute; left: 0; top: 8px; width: 6px; height: 6px;
    border-radius: 50%; background: var(--color-accent);
}

/* La ruta */
.exped-route { padding-block: clamp(2.5rem, 5vw, 4rem); }
.exped-route__grid {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: clamp(0.75rem, 1.5vw, 1rem); margin-top: var(--space-10);
}
.exped-route__item {
    position: relative; margin: 0; aspect-ratio: 3 / 4; overflow: hidden;
    border-radius: var(--radius-lg);
    background: linear-gradient(155deg, #1a2238 0%, #0c1018 100%);
    border: 1px solid rgba(232,163,61,0.12);
}
.exped-route__item img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform 0.6s var(--ease-premium);
}
.exped-route__item:hover img { transform: scale(1.06); }
.exped-route__item figcaption {
    position: absolute; inset: auto 0 0 0; z-index: 1;
    padding: var(--space-5) var(--space-4) var(--space-4);
    font-family: var(--font-display); font-size: 1.05rem; text-transform: uppercase;
    letter-spacing: 0.02em; color: #fff; line-height: 1.1;
    background: linear-gradient(180deg, rgba(10,10,10,0) 0%, rgba(10,10,10,0.85) 100%);
}

/* Hotel 4* */
.exped-hotel { padding-block: clamp(2.5rem, 5vw, 4rem); background: rgba(255,255,255,0.015); }
.exped-hotel__inner { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(1.5rem, 4vw, 3.5rem); align-items: center; }
.exped-hotel__title {
    font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3rem);
    text-transform: uppercase; color: var(--color-text-primary); line-height: 1; margin: var(--space-2) 0 var(--space-4);
}
.exped-hotel__title em { color: var(--color-accent); font-style: normal; }
.exped-hotel__desc { font-size: var(--text-base); line-height: 1.7; color: var(--color-text-secondary); margin: 0 0 var(--space-5); }
.exped-hotel__feats { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }
.exped-hotel__feats li {
    position: relative; padding-left: 24px; font-size: var(--text-sm); font-weight: 600; color: var(--color-text-primary);
}
.exped-hotel__feats li::before {
    content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
    width: 14px; height: 14px; border-radius: 50%;
    background: var(--color-accent);
    -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath d='M16.7 5.3a1 1 0 010 1.4l-8 8a1 1 0 01-1.4 0l-4-4a1 1 0 011.4-1.4L8 12.6l7.3-7.3a1 1 0 011.4 0z'/%3E%3C/svg%3E") center/10px no-repeat;
            mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath d='M16.7 5.3a1 1 0 010 1.4l-8 8a1 1 0 01-1.4 0l-4-4a1 1 0 011.4-1.4L8 12.6l7.3-7.3a1 1 0 011.4 0z'/%3E%3C/svg%3E") center/10px no-repeat;
}
.exped-hotel__gallery { display: grid; grid-template-columns: 2fr 1fr; grid-template-rows: 1fr 1fr; gap: var(--space-3); aspect-ratio: 3 / 2; }
.exped-hotel__gallery img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius-lg); background: #14213a; }
.exped-hotel__gallery img:first-child { grid-row: span 2; }

/* CTA final */
.exped-cta { padding-block: clamp(3rem, 7vw, 5.5rem); text-align: center; }
.exped-cta__inner { max-width: 760px; margin-inline: auto; }
.exped-cta__kicker {
    font-family: var(--font-display); font-size: clamp(1.1rem, 3vw, 1.5rem);
    letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-accent); margin: 0 0 var(--space-2);
}
.exped-cta__title {
    font-family: var(--font-display); font-size: clamp(2.2rem, 6vw, 3.6rem);
    text-transform: uppercase; color: var(--color-text-primary); line-height: 1.02; margin: 0 0 var(--space-4);
}
.exped-cta__title em { font-style: normal; }
.exped-cta__desc { font-size: var(--text-base); color: var(--color-text-secondary); margin: 0 auto var(--space-6); max-width: 540px; }
.exped-cta__actions { display: flex; flex-wrap: wrap; gap: var(--space-4); justify-content: center; }
.exped-cta__soon {
    margin: var(--space-8) 0 0; font-size: var(--text-xs); letter-spacing: 0.08em;
    text-transform: uppercase; color: var(--color-text-muted);
}

/* ── Responsive Expeditions ── */
@media (max-width: 980px) {
    .exped-feature__inner,
    .exped-hotel__inner { grid-template-columns: 1fr; }
    .exped-includes     { grid-template-columns: repeat(2, 1fr); }
    .exped-hotel__gallery { aspect-ratio: 16 / 9; }
}
@media (max-width: 640px) {
    .exped-includes   { grid-template-columns: 1fr; }
    .exped-route__grid { grid-template-columns: repeat(2, 1fr); }
    .exped-price      { flex-direction: column; align-items: flex-start; }
    .exped-price__actions { width: 100%; }
    .exped-price__actions .btn { flex: 1 1 auto; }
    .exped-stats      { gap: var(--space-4) var(--space-5); }
    .exped-hotel__feats { grid-template-columns: 1fr; }
    .exped-cta__actions .btn { flex: 1 1 100%; }
}

/* ══════════════════════════════════════════════════════════
   VIP EXPERIENCE — grupos a medida
   ══════════════════════════════════════════════════════════ */

/* Para quién (tipos de grupo) */
.vip-groups { padding-block: clamp(2.5rem, 5vw, 4rem); }
.vip-groups__grid {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: clamp(0.75rem, 2vw, 1.25rem); margin-top: var(--space-10);
}
.vip-group {
    text-align: center; padding: var(--space-8) var(--space-5);
    background: var(--color-bg-secondary);
    border: 1px solid rgba(232,163,61,0.12);
    border-radius: var(--radius-lg);
    transition: border-color 0.25s ease, transform 0.25s ease;
}
.vip-group:hover { border-color: rgba(232,163,61,0.35); transform: translateY(-3px); }
.vip-group__icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 64px; height: 64px; border-radius: 50%;
    background: rgba(232,163,61,0.1); color: var(--color-accent);
    margin-bottom: var(--space-4);
}
.vip-group__title {
    font-family: var(--font-display); font-size: 1.4rem; text-transform: uppercase;
    color: var(--color-text-primary); margin: 0 0 var(--space-2); line-height: 1.1;
}
.vip-group__desc { font-size: var(--text-sm); line-height: 1.6; color: var(--color-text-secondary); margin: 0; }

/* Precio a consultar */
.vip-quote { padding-block: clamp(2rem, 5vw, 4rem); }
.vip-quote__card {
    max-width: 720px; margin-inline: auto; text-align: center;
    padding: clamp(2rem, 5vw, 3.5rem);
    background: linear-gradient(135deg, rgba(232,163,61,0.10), rgba(232,163,61,0.02));
    border: 1px solid rgba(232,163,61,0.3);
    border-radius: var(--radius-xl);
    box-shadow: 0 30px 80px rgba(0,0,0,0.35);
}
.vip-quote__eyebrow {
    display: block; font-size: var(--text-xs); font-weight: 700;
    letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-accent);
    margin-bottom: var(--space-3);
}
.vip-quote__amount {
    display: block; font-family: var(--font-display);
    font-size: clamp(2.2rem, 6vw, 3.4rem); text-transform: uppercase;
    color: var(--color-text-primary); line-height: 1; margin-bottom: var(--space-4);
}
.vip-quote__text {
    font-size: var(--text-base); line-height: 1.7; color: var(--color-text-secondary);
    margin: 0 auto var(--space-6); max-width: 540px;
}
.vip-quote__actions { display: flex; flex-wrap: wrap; gap: var(--space-4); justify-content: center; }

@media (max-width: 900px) { .vip-groups__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) {
    .vip-groups__grid { grid-template-columns: 1fr; }
    .vip-quote__actions .btn { flex: 1 1 100%; }
}

/* ══════════════════════════════════════════════════════════
   PREMIUM EQUIPMENT — equipamiento profesional
   ══════════════════════════════════════════════════════════ */
.peq-hero__claim {
    font-size: var(--text-sm); font-weight: 700; letter-spacing: 0.16em;
    text-transform: uppercase; color: var(--color-accent);
    margin: 0 0 var(--space-4);
}

/* Tarjetas de equipo */
.peq-equipos { padding-block: clamp(2.5rem, 6vw, 5rem); }
.peq-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2.5vw, 1.75rem); }
.peq-card {
    display: flex; flex-direction: column;
    background: var(--color-bg-secondary);
    border: 1px solid rgba(232,163,61,0.14);
    border-radius: var(--radius-xl);
    overflow: hidden;
    transition: border-color 0.25s ease, transform 0.25s ease;
}
.peq-card:hover { border-color: rgba(232,163,61,0.35); transform: translateY(-4px); }
.peq-card__media {
    position: relative; display: flex; align-items: center; justify-content: center;
    aspect-ratio: 16 / 10; color: var(--color-accent);
    background:
        radial-gradient(120% 120% at 50% 0%, rgba(232,163,61,0.14) 0%, rgba(232,163,61,0) 55%),
        linear-gradient(155deg, #1c160c 0%, #0c0c0c 100%);
    border-bottom: 1px solid rgba(232,163,61,0.14);
}
.peq-card__media svg { opacity: 0.92; filter: drop-shadow(0 6px 20px rgba(232,163,61,0.25)); }
.peq-card__body { padding: var(--space-6) var(--space-6) var(--space-7); display: flex; flex-direction: column; gap: 0; flex: 1; }
.peq-card__name {
    font-family: var(--font-display); font-size: clamp(1.5rem, 2.2vw, 1.9rem);
    text-transform: uppercase; color: var(--color-text-primary); line-height: 1; margin: 0;
}
.peq-card__claim {
    display: block; font-size: 11px; font-weight: 700; letter-spacing: 0.12em;
    text-transform: uppercase; color: var(--color-accent); margin: var(--space-2) 0 var(--space-4);
}
.peq-card__desc { font-size: var(--text-sm); line-height: 1.65; color: var(--color-text-secondary); margin: 0 0 var(--space-5); }
.peq-card__feats { list-style: none; margin: auto 0 0; padding: var(--space-5) 0 0; display: grid; gap: 10px; border-top: 1px solid rgba(232,163,61,0.12); }
.peq-card__feats li { display: flex; align-items: flex-start; gap: 10px; font-size: var(--text-sm); color: var(--color-text-primary); }
.peq-card__feats svg { color: var(--color-accent); flex-shrink: 0; margin-top: 3px; }

/* Preparación exclusiva */
.peq-prep { padding-block: clamp(2rem, 4vw, 3.5rem); }
.peq-prep__inner {
    background: rgba(255,255,255,0.02);
    border: 1px solid rgba(232,163,61,0.16);
    border-radius: var(--radius-2xl);
    padding: clamp(1.75rem, 4vw, 3rem);
}
.peq-prep__head { display: flex; align-items: center; gap: var(--space-5); margin-bottom: var(--space-5); }
.peq-prep__icon {
    flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center;
    width: 60px; height: 60px; border-radius: var(--radius-lg);
    background: rgba(232,163,61,0.1); color: var(--color-accent);
}
.peq-prep__title { font-family: var(--font-display); font-size: clamp(1.8rem, 3vw, 2.6rem); text-transform: uppercase; color: var(--color-text-primary); line-height: 1; margin: 4px 0 0; }
.peq-prep__title em { color: var(--color-accent); font-style: normal; }
.peq-prep__desc { font-size: var(--text-base); line-height: 1.75; color: var(--color-text-secondary); margin: 0 0 var(--space-8); max-width: 90ch; }
.peq-prep__feats { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); }
.peq-prep__feats li { display: flex; flex-direction: column; gap: var(--space-3); font-size: var(--text-sm); font-weight: 600; color: var(--color-text-primary); }
.peq-prep__feat-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 44px; height: 44px; border-radius: 50%;
    background: rgba(232,163,61,0.08); border: 1px solid rgba(232,163,61,0.22); color: var(--color-accent);
}

/* CTA banner */
.peq-cta { position: relative; padding-block: clamp(3rem, 8vw, 6rem); text-align: center; overflow: hidden; }
.peq-cta__bg { position: absolute; inset: 0; z-index: 0; background: linear-gradient(155deg, #14213a 0%, #0c1018 100%); }
.peq-cta__bg img { width: 100%; height: 100%; object-fit: cover; opacity: 0.45; }
.peq-cta__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,10,10,0.7) 0%, rgba(10,10,10,0.85) 100%); }
.peq-cta__inner { position: relative; z-index: 1; max-width: 760px; margin-inline: auto; }
.peq-cta__title { font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3.4rem); text-transform: uppercase; color: var(--color-text-primary); line-height: 1.05; margin: 0 0 var(--space-4); }
.peq-cta__title em { font-style: normal; display: block; }
.peq-cta__desc { font-size: var(--text-base); color: var(--color-text-secondary); margin: 0 auto var(--space-6); max-width: 520px; }

@media (max-width: 980px) {
    .peq-grid { grid-template-columns: 1fr; max-width: 540px; margin-inline: auto; }
    .peq-prep__feats { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
    .peq-prep__head { flex-direction: column; align-items: flex-start; gap: var(--space-3); }
    .peq-prep__feats { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════
   SOBRE NOSOTROS
   ══════════════════════════════════════════════════════════ */

/* Tira de claims bajo el hero */
.ab-claims { padding-block: clamp(1.5rem, 3vw, 2.25rem); border-bottom: 1px solid rgba(232,163,61,0.12); background: rgba(255,255,255,0.015); }
.ab-claims__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); }
.ab-claim { display: flex; align-items: center; gap: var(--space-3); color: var(--color-text-secondary); }
.ab-claim svg { color: var(--color-accent); flex-shrink: 0; }
.ab-claim span { font-size: var(--text-sm); font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--color-text-primary); }

/* Filosofía */
.ab-philosophy { padding-block: clamp(3rem, 6vw, 5rem); text-align: center; }
.ab-philosophy__inner { max-width: 820px; margin-inline: auto; }
.ab-philosophy__title { font-family: var(--font-display); font-size: clamp(2rem, 4.5vw, 3.4rem); text-transform: uppercase; color: var(--color-text-primary); line-height: 1.04; margin: var(--space-3) 0 var(--space-6); }
.ab-philosophy__title em { color: var(--color-accent); font-style: normal; }
.ab-philosophy p { font-size: var(--text-lg); line-height: 1.75; color: var(--color-text-secondary); margin: 0 auto var(--space-4); max-width: 720px; }
.ab-philosophy p:last-child { margin-bottom: 0; }

/* Pilares */
.ab-pillars { padding-block: clamp(2.5rem, 5vw, 4rem); background: rgba(255,255,255,0.015); }
.ab-pillars__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(0.85rem, 2vw, 1.4rem); margin-top: var(--space-10); align-items: stretch; }
.ab-pillar { display: flex; flex-direction: column; background: var(--color-bg-secondary); border: 1px solid rgba(232,163,61,0.12); border-radius: var(--radius-lg); padding: var(--space-6); transition: border-color 0.25s ease, transform 0.25s ease; }
.ab-pillar:hover { border-color: rgba(232,163,61,0.35); transform: translateY(-3px); }
.ab-pillar__icon { display: inline-flex; align-items: center; justify-content: center; width: 56px; height: 56px; border-radius: var(--radius); background: rgba(232,163,61,0.1); color: var(--color-accent); margin-bottom: var(--space-4); }
.ab-pillar__title { font-family: var(--font-display); font-size: 1.3rem; text-transform: uppercase; color: var(--color-text-primary); line-height: 1.1; margin: 0 0 var(--space-3); }
.ab-pillar__desc { font-size: var(--text-sm); line-height: 1.6; color: var(--color-text-secondary); margin: 0 0 var(--space-4); }
.ab-pillar__lead { display: block; font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-text-muted); margin-bottom: var(--space-2); }
.ab-pillar__list { list-style: none; margin: auto 0 0; padding: var(--space-4) 0 0; display: grid; gap: 8px; border-top: 1px solid rgba(232,163,61,0.1); }
.ab-pillar__list li { display: flex; align-items: flex-start; gap: 8px; font-size: var(--text-sm); color: var(--color-text-primary); }
.ab-pillar__list svg { color: var(--color-accent); flex-shrink: 0; margin-top: 3px; }

/* La diferencia MR */
.ab-diff { padding-block: clamp(2.5rem, 5vw, 4rem); }
.ab-diff__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(0.85rem, 2vw, 1.25rem); margin-top: var(--space-10); }
.ab-diff__item { display: flex; flex-direction: column; gap: var(--space-3); padding: var(--space-5); background: var(--color-bg-secondary); border: 1px solid rgba(232,163,61,0.1); border-radius: var(--radius-lg); }
.ab-diff__icon { display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 48px; border-radius: 50%; background: rgba(232,163,61,0.08); border: 1px solid rgba(232,163,61,0.2); color: var(--color-accent); }
.ab-diff__label { font-size: var(--text-sm); font-weight: 600; line-height: 1.4; color: var(--color-text-primary); }

/* Nuestra promesa */
.ab-promise { padding-block: clamp(2.5rem, 5vw, 4rem); background: rgba(255,255,255,0.015); }
.ab-promise__intro { max-width: 760px; margin: 0 auto var(--space-10); text-align: center; }
.ab-promise__intro p { font-size: var(--text-lg); line-height: 1.7; color: var(--color-text-secondary); margin: var(--space-3) 0 0; }
.ab-promise__values { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2.5vw, 1.75rem); }
.ab-promise__value { text-align: center; padding: var(--space-7) var(--space-5); background: var(--color-bg-secondary); border: 1px solid rgba(232,163,61,0.12); border-radius: var(--radius-lg); }
.ab-promise__icon { display: inline-flex; align-items: center; justify-content: center; width: 60px; height: 60px; border-radius: 50%; background: rgba(232,163,61,0.1); color: var(--color-accent); margin-bottom: var(--space-4); }
.ab-promise__title { font-family: var(--font-display); font-size: 1.4rem; text-transform: uppercase; color: var(--color-text-primary); margin: 0 0 var(--space-2); }
.ab-promise__desc { font-size: var(--text-sm); line-height: 1.6; color: var(--color-text-secondary); margin: 0; }

/* Cierre */
.ab-closing { position: relative; padding-block: clamp(3.5rem, 9vw, 6.5rem); text-align: center; overflow: hidden; }
.ab-closing__bg { position: absolute; inset: 0; z-index: 0; background: linear-gradient(155deg, #14213a 0%, #0c1018 100%); }
.ab-closing__bg img { width: 100%; height: 100%; object-fit: cover; opacity: 0.4; }
.ab-closing__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,10,10,0.65) 0%, rgba(10,10,10,0.85) 100%); }
.ab-closing__inner { position: relative; z-index: 1; }
.ab-closing__tagline { font-family: var(--font-display); font-size: clamp(2rem, 6vw, 4rem); text-transform: uppercase; color: var(--color-text-primary); line-height: 1.02; letter-spacing: 0.02em; margin: 0 0 var(--space-6); }
.ab-closing__tagline em { font-style: normal; }
.ab-closing__actions { display: flex; flex-wrap: wrap; gap: var(--space-4); justify-content: center; }

@media (max-width: 980px) {
    .ab-pillars__grid { grid-template-columns: repeat(2, 1fr); }
    .ab-diff__grid    { grid-template-columns: repeat(2, 1fr); }
    .ab-claims__grid  { grid-template-columns: repeat(2, 1fr); }
    .ab-promise__values { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; }
}
@media (max-width: 560px) {
    .ab-pillars__grid { grid-template-columns: 1fr; }
    .ab-closing__actions .btn { flex: 1 1 100%; }
}

/* ══════════════════════════════════════════════════════════
   GIFT CARD — banner de tarjeta regalo
   ══════════════════════════════════════════════════════════ */
.gift-card { padding-block: clamp(2rem, 5vw, 3.5rem); }
.gift-card__inner {
    display: grid; grid-template-columns: minmax(0, 360px) 1fr;
    gap: clamp(1.5rem, 4vw, 3.5rem); align-items: center;
    background: linear-gradient(135deg, rgba(232,163,61,0.07), rgba(255,255,255,0.015));
    border: 1px solid rgba(232,163,61,0.3);
    border-radius: var(--radius-2xl);
    padding: clamp(1.75rem, 4vw, 3rem);
}

/* Visual de la tarjeta */
.gift-card__visual { display: flex; justify-content: center; }
.gift-card__card {
    position: relative; width: 100%; max-width: 340px; aspect-ratio: 1.6 / 1;
    border-radius: 16px; overflow: hidden;
    background: linear-gradient(150deg, #1f1f1f 0%, #0a0a0a 100%);
    border: 1px solid rgba(232,163,61,0.35);
    box-shadow: 0 30px 70px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.05);
    display: flex; align-items: center; justify-content: center;
}
.gift-card__card-logo { width: 56%; max-width: 200px; height: auto; position: relative; z-index: 2; margin-top: -8%; }
.gift-card__ribbon { position: absolute; z-index: 1; background: linear-gradient(90deg, #9c6f1a, #F5B547 50%, #caa040); box-shadow: 0 1px 6px rgba(0,0,0,0.35); }
.gift-card__ribbon--v { top: 0; bottom: 0; left: 50%; width: 15%; transform: translateX(-50%); }
.gift-card__ribbon--h { left: 0; right: 0; top: 64%; height: 22%; }
.gift-card__bow { position: absolute; z-index: 3; width: 74px; height: 46px; left: 50%; top: 64%; transform: translate(-50%, -42%); filter: drop-shadow(0 4px 12px rgba(0,0,0,0.45)); }

/* Contenido */
.gift-card__title {
    display: flex; align-items: center; gap: var(--space-3);
    font-family: var(--font-display); font-size: clamp(1.8rem, 4vw, 3rem);
    text-transform: uppercase; color: var(--color-text-primary); line-height: 1; margin: 0 0 var(--space-3);
}
.gift-card__title em { color: var(--color-accent); font-style: normal; }
.gift-card__gift { color: var(--color-accent); display: inline-flex; flex-shrink: 0; }
.gift-card__lead { font-size: var(--text-lg); font-weight: 600; color: var(--color-text-primary); margin: 0 0 var(--space-5); line-height: 1.3; }
.gift-card__row { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--space-4); }
.gift-card__text { font-size: var(--text-sm); color: var(--color-text-secondary); line-height: 1.6; margin: 0; max-width: 46ch; }
.gift-card__cta { flex-shrink: 0; }

@media (max-width: 760px) {
    .gift-card__inner { grid-template-columns: 1fr; }
    .gift-card__visual { max-width: 320px; margin-inline: auto; }
    .gift-card__row { flex-direction: column; align-items: stretch; }
    .gift-card__cta { width: 100%; justify-content: center; }
}

/* ============================================================
   SEASON COLLECTIONS — selector de temporada (Summer / Winter)
   Solo en /buggy/ y /quad/
   ============================================================ */
.season-section {
    padding-block: clamp(3rem, 6vw, 5rem);
    background: #0a0a0a;
    border-top: 1px solid rgba(232,163,61,.10);
}
.season-header { text-align: center; max-width: 760px; margin: 0 auto clamp(2.25rem, 5vw, 3.25rem); }
.season-header__eyebrow {
    display: inline-block; font-size: var(--text-xs); font-weight: 700;
    letter-spacing: .22em; text-transform: uppercase; color: var(--color-accent); margin-bottom: var(--space-3);
}
.season-header__title {
    font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3.4rem);
    text-transform: uppercase; line-height: 1; color: var(--color-text-primary); margin: 0 0 var(--space-4);
}
.season-header__title em { color: var(--color-accent); font-style: normal; }
.season-header__subtitle { font-size: var(--text-base); color: var(--color-text-secondary); line-height: 1.6; margin: 0; }

.season-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(1.25rem, 3vw, 2rem); align-items: stretch; }

.season-card {
    display: flex; flex-direction: column; background: #131313;
    border: 1px solid rgba(232,163,61,.18); border-radius: 18px; overflow: hidden; position: relative;
}
/* Winter usa los mismos acentos dorados que Summer (negro/dorado/blanco). */
.season-card__media { position: relative; aspect-ratio: 16 / 9; overflow: hidden; }
.season-card__media img { width: 100%; height: 100%; object-fit: cover; opacity: .9; }
.season-card__media-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,10,10,.15) 0%, rgba(10,10,10,.55) 58%, rgba(19,19,19,.97) 100%); }
.season-card--summer .season-card__media-overlay,
.season-card--winter .season-card__media-overlay { background: linear-gradient(180deg, rgba(45,28,0,.20) 0%, rgba(22,14,0,.60) 58%, rgba(19,19,19,.97) 100%); }

.season-card__head { position: absolute; left: clamp(20px, 3vw, 28px); bottom: 16px; z-index: 2; display: flex; flex-direction: column; gap: 2px; }
.season-card__season { display: inline-flex; align-items: center; gap: 8px; font-size: clamp(1rem, 2vw, 1.35rem); font-weight: 800; text-transform: uppercase; letter-spacing: .05em; color: var(--color-accent); }
.season-card__collection { font-family: var(--font-display); font-size: clamp(1.9rem, 4.2vw, 2.9rem); text-transform: uppercase; line-height: .9; color: var(--color-text-primary); }

.season-card__body { display: flex; flex-direction: column; gap: var(--space-4); padding: clamp(20px, 3vw, 28px); flex: 1; }
.season-card__desc { font-size: var(--text-base); color: var(--color-text-secondary); margin: 0; line-height: 1.5; }
.season-card__avail { display: inline-flex; align-items: center; gap: 8px; font-size: var(--text-sm); color: var(--color-text-muted); }
.season-card__avail svg { width: 15px; height: 15px; flex-shrink: 0; color: var(--color-accent); }
.season-card__avail strong { color: var(--color-accent); font-weight: 700; }

.season-card__list { display: flex; flex-direction: column; gap: var(--space-4); border-top: 1px solid rgba(232,163,61,.12); padding-top: var(--space-4); }
.season-card__list-label { font-size: var(--text-xs); font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--color-text-muted); text-align: center; }
/* Experiencias en columnas horizontales (lado a lado), no apiladas */
.season-card__exps { display: grid; grid-template-columns: repeat(var(--cols, 3), minmax(0, 1fr)); gap: 18px; }
.season-exp { display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.season-exp__dur { align-self: flex-start; font-family: var(--font-display); font-size: .82rem; font-weight: 700; color: var(--color-accent); background: rgba(232,163,61,.12); border-radius: 7px; padding: 4px 8px; line-height: 1; margin-bottom: 3px; }
.season-exp__title { font-size: .8rem; font-weight: 700; text-transform: uppercase; color: var(--color-text-primary); line-height: 1.18; letter-spacing: .01em; }
.season-exp__sub { font-size: .62rem; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: .05em; line-height: 1.35; }
.season-exp__price { margin-top: auto; padding-top: 12px; font-family: var(--font-display); font-size: 1.5rem; color: var(--color-accent); line-height: 1; }
.season-exp__unit { font-size: .58rem; text-transform: uppercase; letter-spacing: .06em; color: var(--color-text-muted); }

.season-card__cta { margin-top: auto; }

.season-features { list-style: none; margin: clamp(2.25rem, 5vw, 3.25rem) 0 0; padding: clamp(1.5rem, 3vw, 2rem) 0 0; border-top: 1px solid rgba(232,163,61,.12); display: flex; flex-wrap: wrap; justify-content: center; gap: clamp(1.25rem, 3vw, 2.5rem); }
.season-feature { display: flex; align-items: center; gap: 10px; }
.season-feature__icon { width: 40px; height: 40px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; border: 1px solid rgba(232,163,61,.25); border-radius: 50%; color: var(--color-accent); }
.season-feature__icon svg { width: 20px; height: 20px; }
.season-feature__text { display: flex; flex-direction: column; line-height: 1.15; }
.season-feature__text strong { font-size: .78rem; font-weight: 700; color: var(--color-text-primary); text-transform: uppercase; letter-spacing: .03em; }
.season-feature__text span { font-size: .68rem; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: .05em; }

@media (max-width: 860px) {
    .season-grid { grid-template-columns: 1fr; max-width: 480px; margin-inline: auto; }
}
@media (max-width: 560px) {
    .season-features { gap: 1.25rem 1.75rem; }
    .season-feature { flex: 1 1 42%; }
    .season-card__exps { grid-template-columns: repeat(2, 1fr); }
}

/* ============================================================
   INFO DE VEHÍCULOS — botón en fleet-card + modal con claim
   ============================================================ */
/* Tag destacado (ej. Suspensión FOX) */
.fleet-card__tag--accent {
    color: var(--color-accent);
    border-color: rgba(232,163,61,.55);
    background: rgba(232,163,61,.08);
    font-weight: 700;
}
.fleet-card__actions { display: flex; margin-top: 2px; }
.fleet-card__actions .tour-card__info { flex: 1; justify-content: center; }

/* Media del modal de vehículo: espacio reservado para foto/vídeo */
.exp-modal__media--vehicle { display: flex; align-items: center; justify-content: center; }
.vehicle-claim {
    position: absolute; top: 28px; left: 20px; right: 20px; z-index: 2;
    text-align: center; font-family: var(--font-display);
    font-size: clamp(1.25rem, 2.2vw, 1.8rem); text-transform: uppercase;
    letter-spacing: .04em; color: var(--color-accent);
    text-shadow: 0 2px 18px rgba(0,0,0,.55);
}
.vehicle-ghost {
    font-family: var(--font-display); font-size: clamp(1.3rem, 2.2vw, 1.9rem);
    text-transform: uppercase; color: rgba(232,163,61,.16);
    text-align: center; padding: 0 24px;
}

/* Lista de puntos clave del vehículo */
.vehicle-modal__list { list-style: none; margin: 4px 0 28px; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.vehicle-modal__list li { position: relative; padding-left: 22px; font-size: .92rem; color: var(--color-text-secondary); line-height: 1.5; }
.vehicle-modal__list li::before { content: ""; position: absolute; left: 0; top: .5em; width: 8px; height: 8px; border-radius: 50%; background: var(--color-accent); }

@media (max-width: 760px) {
    .vehicle-claim { top: 18px; font-size: 1.15rem; }
}
