/* ===========================================================================
   NAUTYGOS — Token override del theme GoTrip
   Redefinimos los tokens nativos al `:root` para que el primer paint use
   nuestros colores. Elimina el FOUC de azul→charcoal y reduce !important.
   =========================================================================== */
:root {
    /* Brand primary — antes era #3554D1 (azul). Ahora charcoal/navy oscuro */
    --color-blue-1: #0d1b2a !important;
    /* Brand soft — para hovers y backgrounds suaves */
    --color-blue-2: #f3f4f7 !important;
    /* Dark scale — todos charcoal */
    --color-dark-1: #0d1b2a !important;
    --color-dark-2: #1a2b48 !important;
    --color-dark-3: #2a3f5f !important;
    --color-dark-4: #3a5278 !important;
    /* Light scale (mantiene neutralidad pero más sutil) */
    --color-light-1: #5a6675 !important;
    --color-light-2: #f5f6f8 !important;
    --color-light-3: #fafafa !important;
    /* Accent amber (badge featured) */
    --color-amber: #ffc107;
    /* Verde de trust */
    --color-green-1: #eefaf2 !important;
    --color-green-2: #119b3f !important;
    /* Hairline / borders */
    --color-border: #e5e7eb;
    /* Bootstrap variable bridge: hacer que .btn-primary use blue-1 */
    --bs-primary: #0d1b2a;
    --bs-link-color: #0d1b2a;
}
/* CTA naranja gradient stays as override en el form (no es color token, es bg-image) */

/* === Nautygos modern header — aplica a TODAS las páginas === */
/* En home (body.ng-hero-page): header absolute + FAB sobre scroll
   En otras páginas: header fixed normal (theme default), pill modern siempre arriba */

/* ===== HEADER MODERNO — TODAS LAS PÁGINAS ===== */
.header.js-header {
    background: transparent !important;
    border-bottom: none !important;
    box-shadow: none !important;
}
.header .header-logo img { width: 190px !important; }

/* Menu abierto: header bar blanco */
.header.js-header.is-menu-opened {
    background: white !important;
    border: 0 !important;
    box-shadow: none !important;
}

/* ===== Desktop ≥1200px: header pill flotante moderno ===== */
@media (min-width: 1200px) {
    .header.js-header {
        height: 70px !important;
    }
    .header__container {
        box-sizing: border-box;
        width: calc(100% - 28px);
        max-width: 1300px;
        margin: 12px auto 0;
        padding: 4px 18px !important;
        background: rgba(255, 255, 255, .55);
        -webkit-backdrop-filter: saturate(180%) blur(28px);
        backdrop-filter: saturate(180%) blur(28px);
        border-radius: 999px;
        border: 1px solid rgba(255, 255, 255, .40);
        box-shadow:
            0 1px 2px rgba(13, 27, 42, .04),
            0 8px 24px -12px rgba(13, 27, 42, .16),
            inset 0 1px 0 rgba(255, 255, 255, .55);
    }

    /* Layout: logo izq, menú centrado en espacio disponible, acciones derecha
       Aplica en TODAS las páginas (home y resto) — flexbox real, sin overlap */
    body .header__container > .row,
    body.ng-hero-page .header__container > .row {
        flex-wrap: nowrap !important;
        align-items: center !important;
        display: flex !important;
    }
    /* Primer col-auto (logo + menu): crece para ocupar todo el espacio disponible */
    body .header__container > .row > .col-auto:first-child,
    body.ng-hero-page .header__container > .row > .col-auto:first-child {
        flex: 1 1 auto !important;
        min-width: 0 !important;
    }
    /* gotrip-header-* (cualquier variante: normal, transparent_v2, etc.) */
    body .header__container > .row > .col-auto:first-child [class*="gotrip-header-"],
    body.ng-hero-page .header__container > .row > .col-auto:first-child [class*="gotrip-header-"] {
        width: 100% !important;
        display: flex !important;
        align-items: center !important;
    }
    /* El menú: flex:1 + justify-content center → queda centrado en el espacio disponible */
    body .header__container > .row > .col-auto:first-child [class*="gotrip-header-"] > .header-menu,
    body.ng-hero-page .header__container > .row > .col-auto:first-child [class*="gotrip-header-"] > .header-menu {
        flex: 1 1 auto !important;
        display: flex !important;
        justify-content: center !important;
        margin-left: 0 !important;
    }
    /* Último col-auto (botones derecha): tamaño natural */
    body .header__container > .row > .col-auto:last-child,
    body.ng-hero-page .header__container > .row > .col-auto:last-child {
        flex: 0 0 auto !important;
    }

    /* Items del menú principal (desktop) */
    .header .menu__nav > li > a {
        font-size: 13.5px !important;
        padding: 8px 14px !important;
        border-radius: 999px !important;
        transition: background-color .15s ease, color .15s ease, box-shadow .15s ease !important;
        display: inline-flex !important;
        align-items: center;
    }
    /* Hover: pill gris suave con micro-shadow */
    .header .menu__nav > li > a:hover,
    .header .menu__nav > li:hover > a {
        background-color: rgba(13, 27, 42, .06) !important;
        color: #0d1b2a !important;
        box-shadow: 0 2px 6px -2px rgba(13, 27, 42, .10) !important;
    }
    /* Active state */
    .header .menu__nav > li.current-menu-item > a,
    .header .menu__nav > li.active > a {
        background-color: rgba(13, 27, 42, .08) !important;
        color: #0d1b2a !important;
    }
    .header .header-menu .menu__nav > li {
        padding: 10px 0 !important;
    }
}

/* ===== Botones del header (TODAS las páginas y resoluciones donde se muestren) ===== */
.header .button.h-50 {
    height: 42px !important;
    min-height: 42px !important;
    padding: 0 22px !important;
    border-radius: 999px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    letter-spacing: .1px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    line-height: 1 !important;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
}

/* Primary CTA (Become An Expert): cubre todos los bg/* del theme */
.header .button.bg-blue-1,
.header .button.bg-dark-1,
.header .button.bg-dark-2,
.header .button.bg-dark-3,
.header .button.bg-dark-4,
.header .button.bg-white,
.header .button.-blue-1,
.header .button.-white {
    background: linear-gradient(135deg, #ff5a00 0%, #ffb703 100%) !important;
    color: #fff !important;
    border: none !important;
    box-shadow: 0 4px 12px -4px rgba(255, 122, 0, .45),
                0 2px 4px rgba(255, 122, 0, .20) !important;
    transition: transform .2s ease, box-shadow .2s ease, background .2s ease !important;
}
.header .button.bg-blue-1:hover,
.header .button.bg-dark-1:hover,
.header .button.bg-dark-2:hover,
.header .button.bg-dark-3:hover,
.header .button.bg-dark-4:hover,
.header .button.bg-white:hover,
.header .button.-blue-1:hover,
.header .button.-white:hover {
    background: linear-gradient(135deg, #ff4d00 0%, #ffa600 100%) !important;
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 8px 18px -4px rgba(255, 122, 0, .55),
                0 3px 8px rgba(255, 122, 0, .28) !important;
}

/* Outline (Sign In / Register): cubre border-* y outline */
.header .button.border-dark-1,
.header .button.border-dark-2,
.header .button.border-dark-3,
.header .button.border-dark-4,
.header .button.border-white,
.header .button[class*="-outline"] {
    background: transparent !important;
    color: #0d1b2a !important;
    border: 1.5px solid #0d1b2a !important;
    box-shadow: none !important;
}
.header .button.border-dark-1:hover,
.header .button.border-dark-2:hover,
.header .button.border-dark-3:hover,
.header .button.border-dark-4:hover,
.header .button.border-white:hover,
.header .button[class*="-outline"]:hover {
    background: #0d1b2a !important;
    color: #fff !important;
    border-color: #0d1b2a !important;
}

.header .button.ml-20 { margin-left: 10px !important; }

/* ===== Tablet/Mobile <1200px ===== */
@media (max-width: 1199px) {
    .header.js-header {
        height: 70px !important;
    }
    .header__container {
        padding-left: 18px !important;
        padding-right: 18px !important;
    }
}
/* Mobile/Tablet: pill flotante glass SOLO con menú cerrado */
@media (max-width: 991px) {
    .header.js-header {
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
    }
    .header.js-header .header__container {
        background: rgba(255, 255, 255, .96) !important;
        -webkit-backdrop-filter: none !important;
        backdrop-filter: none !important;
        border: 1px solid rgba(13, 27, 42, .06) !important;
        border-radius: 50px !important;
        box-shadow:
            0 1px 2px rgba(13, 27, 42, .06),
            0 8px 22px -12px rgba(13, 27, 42, .18),
            inset 0 1px 0 rgba(255, 255, 255, .65) !important;
        margin: 10px 10px 0 !important;
        padding: 6px 16px !important;
        max-width: calc(100% - 20px) !important;
        width: calc(100% - 20px) !important;
        min-height: 52px;
        display: flex !important;
        align-items: center !important;
    }
    /* Organización del contenido interno del pill mobile */
    .header.js-header .header__container > .row {
        flex-wrap: nowrap !important;
        align-items: center !important;
        justify-content: space-between !important;
        width: 100% !important;
        margin: 0 !important;
        --bs-gutter-x: 0 !important;
    }
    .header.js-header .header__container > .row > .col-auto {
        padding: 0 !important;
        display: flex !important;
        align-items: center !important;
    }
    /* Logo a la izquierda */
    .header.js-header .header__container > .row > .col-auto:first-child {
        margin-right: auto !important;
    }
    /* Acciones (user + menu) a la derecha, espaciadas */
    .header.js-header .header__container > .row > .col-auto:last-child {
        margin-left: auto !important;
        gap: 8px !important;
    }
    .header.js-header .header__container > .row > .col-auto:last-child .d-flex {
        gap: 10px !important;
        align-items: center !important;
    }
    /* Icon button del hamburger más limpio */
    .header.js-header .icon-menu {
        font-size: 20px !important;
        color: #0d1b2a !important;
        padding: 6px !important;
    }
    .header.js-header .icon-user {
        font-size: 20px !important;
        color: #0d1b2a !important;
        padding: 6px !important;
    }
    /* === Menú abierto en mobile: barra blanca plana (sin pill) === */
    /* Especificidad alta para vencer body:not(.ng-hero-page) .header.js-header */
    body .header.js-header.is-menu-opened,
    body.ng-hero-page .header.js-header.is-menu-opened,
    body:not(.ng-hero-page) .header.js-header.is-menu-opened {
        background: #fff !important;
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 1000 !important;
        border-bottom: 1px solid rgba(13, 27, 42, .06) !important;
        box-shadow: none !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }
    /* Container interno: quitar pill (sin border-radius, sin margins, sin shadow) */
    body .header.js-header.is-menu-opened .header__container,
    body.ng-hero-page .header.js-header.is-menu-opened .header__container,
    body:not(.ng-hero-page) .header.js-header.is-menu-opened .header__container {
        background: transparent !important;
        border: 0 !important;
        border-radius: 0 !important;
        box-shadow: none !important;
        margin: 0 auto !important;
        max-width: 100% !important;
        width: 100% !important;
        padding: 6px 18px !important;
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }
}
@media (max-width: 767px) {
    .header.js-header .header__container {
        margin: -5px 8px 0 !important;
        max-width: calc(100% - 16px) !important;
        width: calc(100% - 16px) !important;
        padding: 3px 10px !important;
        min-height: 50px !important;
    }
    .header .header-logo img { width: 120px !important; }
    /* Acciones derechas: pegar logo + iconos (menos gap entre cols) */
    .header.js-header .header__container > .row > .col-auto:last-child {
        gap: 2px !important;
    }
    .header.js-header .header__container > .row > .col-auto:last-child .d-flex {
        gap: 4px !important;
    }
    /* Iconos más chicos y con menos padding */
    .header.js-header .icon-menu,
    .header.js-header .icon-user {
        font-size: 18px !important;
        padding: 4px !important;
    }
}

/* === SCROLL LOCK: bloquear scroll de la página cuando el menú está abierto === */
body.menu-locked,
html.menu-locked {
    overflow: hidden !important;
    height: 100vh !important;
    touch-action: none !important;
}

/* Override del menu panel: 70px en vez de 80px y header SIEMPRE arriba */
@media (max-width: 1199px) {
    /* Header bar SIEMPRE sobre el menu (para que el pill con logo y hamburger se vea) */
    .header.js-header {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 1000 !important;
    }
    .header .header-menu {
        position: fixed !important;
        top: 70px !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        z-index: 10 !important;
        width: 100vw !important;
        height: calc(100dvh - 70px) !important;
        max-height: calc(100vh - 70px) !important;
        transition: opacity 0.3s cubic-bezier(0.165, 0.84, 0.44, 1) !important;
    }
    .header .header-menu:not(.is-menu-active) {
        opacity: 0;
        pointer-events: none;
    }
    .header .header-menu.is-menu-active {
        opacity: 1;
        pointer-events: auto;
    }

    /* === Menu panel: estilo limpio Memorae/Apple === */
    .header.is-menu-opened .header-menu .mobile-bg {
        background-color: #fff !important;
    }
    .header.is-menu-opened .header-menu .menu {
        padding: 24px 20px calc(env(safe-area-inset-bottom, 0px) + 120px) !important;
        overflow-y: auto !important;
        height: 100% !important;
        background: #fff !important;
        -webkit-overflow-scrolling: touch;
        pointer-events: auto !important;
    }
    /* Forzar pointer-events en TODO el menu y subnav — fix de links bloqueados */
    .header.is-menu-opened .menu.js-navList,
    .header.is-menu-opened .menu.js-navList *,
    .header.is-menu-opened .menu__nav .subnav,
    .header.is-menu-opened .menu__nav .subnav * {
        pointer-events: auto !important;
    }
    /* Subnav items: aseguramos que sean tappeables y por encima */
    .header.is-menu-opened .menu__nav .subnav a {
        position: relative !important;
        z-index: 2 !important;
        cursor: pointer !important;
    }
    /* Ocultar SOLO el menú derecho (header-menu.menu-right) en mobile — el drawer queda intacto */
    .header .header-menu.menu-right .menu.js-navList { display: none !important; }
    /* Lista vertical limpia con dividers */
    .header.is-menu-opened .header-menu .menu .menu__nav {
        display: flex !important;
        flex-direction: column !important;
        gap: 0 !important;
        padding: 0 !important;
        margin: 0 !important;
        list-style: none !important;
        pointer-events: auto !important;
    }
    .header.is-menu-opened .header-menu .menu .menu__nav > li {
        display: block !important;
        width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        border-bottom: 1px solid rgba(13,27,42,.06) !important;
        background: transparent !important;
        pointer-events: auto !important;
    }
    /* Cada link grande y limpio */
    .header.is-menu-opened .header-menu .menu .menu__nav > li > a {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 14px !important;
        padding: 18px 8px !important;
        font-size: 17px !important;
        font-weight: 600 !important;
        color: #0d1b2a !important;
        text-decoration: none !important;
        background: transparent !important;
        line-height: 1.2 !important;
        letter-spacing: -.2px !important;
        min-height: 56px;
        transition: opacity .15s ease;
    }
    .header.is-menu-opened .header-menu .menu .menu__nav > li > a:active {
        opacity: .55 !important;
    }
    .header.is-menu-opened .header-menu .menu .menu__nav > li > a::after {
        content: "›" !important;
        font-size: 22px !important;
        color: rgba(13,27,42,.30) !important;
        font-weight: 400 !important;
        margin-left: auto !important;
    }
    /* Botones del fondo (Sign In / Become Expert): stack al final */
    .header.is-menu-opened .header-menu .menu .menu__nav > div.d-flex.items-center {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 12px !important;
        padding: 24px 0 0 !important;
        margin-top: 16px !important;
        border-bottom: 0 !important;
    }
    .header.is-menu-opened .header-menu .menu .menu__nav > div.d-flex.items-center a.button {
        width: 100% !important;
        height: 52px !important;
        padding: 0 24px !important;
        font-size: 15px !important;
        font-weight: 600 !important;
        border-radius: 999px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        margin: 0 !important;
    }
    /* Overlay sutil charcoal */
    .header.is-menu-opened .header-menu .mobile-overlay {
        background-color: rgba(13, 27, 42, .35) !important;
    }
}

/* (Menu mobile usa el comportamiento nativo del theme, sin overrides) */

/* === SPACING UNIVERSAL DE SECCIONES === */
/* PC: 60px / MOBILE: 30px (top y bottom uniformes en TODAS las secciones) */

.layout-pt-sm,
.layout-pt-md,
.layout-pt-lg,
.layout-pt-xl { padding-top: 60px !important; }
.layout-pb-sm,
.layout-pb-md,
.layout-pb-lg,
.layout-pb-xl { padding-bottom: 60px !important; }

/* GAP UNIVERSAL DE CARDS */
/* Desktop: 32px */
.y-gap-20,
.y-gap-24,
.y-gap-30 { margin-top: -16px !important; margin-bottom: -16px !important; }
.y-gap-20 > *,
.y-gap-24 > *,
.y-gap-30 > * { padding-top: 16px !important; padding-bottom: 16px !important; }

/* === MOBILE === */
@media (max-width: 767px) {
    .layout-pt-sm,
    .layout-pt-md,
    .layout-pt-lg,
    .layout-pt-xl { padding-top: 30px !important; }
    .layout-pb-sm,
    .layout-pb-md,
    .layout-pb-lg,
    .layout-pb-xl { padding-bottom: 30px !important; }

    /* Padding lateral consistente del container */
    .container { padding-left: 18px; padding-right: 18px; }

    /* sectionTitle más respirado */
    .sectionTitle.-md .sectionTitle__title { font-size: 24px; line-height: 1.2; }
    .sectionTitle.-md .sectionTitle__text { font-size: 14px; }

    /* Gap universal de cards en mobile: 32px (mantiene la separación entre cards) */
    .y-gap-20,
    .y-gap-24,
    .y-gap-30 { margin-top: -16px !important; margin-bottom: -16px !important; }
    .y-gap-20 > *,
    .y-gap-24 > *,
    .y-gap-30 > * { padding-top: 16px !important; padding-bottom: 16px !important; }
}

/* Container <576px */
@media (max-width: 575px) {
    .container { padding-left: 16px; padding-right: 16px; }
}

/* === Anti-zoom iOS al enfocar inputs === */
/* Safari iOS hace zoom automático si font-size < 16px en inputs. Forzar 16px en mobile evita ese comportamiento. */
@media (max-width: 767px) {
    input[type="text"],
    input[type="search"],
    input[type="email"],
    input[type="tel"],
    input[type="number"],
    input[type="password"],
    input[type="url"],
    input[type="date"],
    input[type="datetime-local"],
    input[type="time"],
    select,
    textarea {
        font-size: 16px !important;
    }
}

/* Estabilidad de sliders en mobile (evita salto al cambiar slide) */
@media (max-width: 991px) {
    /* CRÍTICO: oculta slides extras ANTES de que Swiper inicie (evita flash de cards encaramadas) */
    .js-section-slider:not(.swiper-initialized) .swiper-wrapper {
        display: block !important;
    }
    .js-section-slider:not(.swiper-initialized) .swiper-slide {
        display: none !important;
    }
    .js-section-slider:not(.swiper-initialized) .swiper-slide:first-child {
        display: block !important;
        width: 100% !important;
    }
}

@media (max-width: 991px) {
    .js-section-slider .swiper-wrapper {
        will-change: transform;
        flex-wrap: nowrap !important;
    }
    .js-section-slider .swiper-slide {
        backface-visibility: hidden;
        width: 100% !important;
        max-width: 100% !important;
        flex: 0 0 100% !important;
        flex-shrink: 0 !important;
    }
}

@media (max-width: 767px) {
    .ng-offerSlider__viewport,
    .js-section-slider {
        overflow: visible !important;
    }
}

/* Permite overflow para sliders (peek de cards "infinito") sin scroll horizontal de página */
.bc_wrap { overflow: clip !important; overflow-clip-margin: 0 !important; }
html, body { overflow-x: clip !important; }

/* === ACABADO HOMOGÉNEO DE CARDS (todas las secciones) === */
.ng-tourCard,
.ng-oCard,
.ng-locCard,
.ng-boatCard {
    border-radius: 18px;
    isolation: isolate;
    box-shadow:
        0 1px 2px rgba(0, 0, 0, .08),
        0 8px 24px -10px rgba(0, 0, 0, .22) !important;
    transition: box-shadow .25s ease, transform .25s cubic-bezier(.2,.7,.25,1) !important;
}

/* QUITAR zoom/scale al hover en todas las cards (mantiene border-radius limpio) */
.ng-tourCard:hover .ng-tourCard__bg,
.ng-oCard:hover .ng-oCard__bg,
.ng-locCard:hover .ng-locCard__thumb img,
.ng-tourCard:hover .ng-locCard__bg,
.swiper-slide-active .ng-oCard:hover .ng-oCard__bg {
    transform: none !important;
}
.ng-tourCard:hover,
.ng-oCard:hover,
.ng-locCard:hover {
    transform: translateY(-2px) !important;
}

/* Cards bigger + uniformes en mobile */
@media (max-width: 767px) {
    .ng-tourCard,
    .ng-oCard {
        aspect-ratio: 4 / 5 !important;
        min-height: 420px !important;
        border-radius: 18px !important;
    }
    .ng-locCard {
        border-radius: 16px !important;
        padding: 12px 16px 12px 12px !important;
    }
    .ng-locCard__thumb {
        flex: 0 0 80px !important;
        width: 80px !important;
        height: 80px !important;
        border-radius: 12px !important;
    }
    .ng-locCard__name { font-size: 16px !important; }

    /* Sombras y bordes consistentes en hover de todas las cards */
    .ng-tourCard:hover,
    .ng-oCard:hover {
        box-shadow: 0 18px 36px -14px rgba(13,27,42,.32) !important;
    }
}

/* Sombra consistente desktop al hover */
@media (min-width: 768px) {
    .ng-tourCard:hover,
    .ng-oCard:hover {
        box-shadow: 0 18px 36px -14px rgba(13,27,42,.30) !important;
    }
}

/* Iconos user/menu — color navy */
.header [data-x="header-mobile-icons"] .icon-user,
.header [data-x="header-mobile-icons"] .icon-menu {
    color: #0d1b2a !important;
}

/* Forzar texto navy en el header en TODAS las páginas (sobre el pill blanco) */
.header .menu__nav,
.header .menu__nav .text-white,
.header .menu__nav > li > a,
.header .menu__nav > li > a > span,
.header .menu__nav > li > a > i,
.header .menu__nav .subnav > li > a,
.header .menu__nav .currency-dropdown > a,
.header .menu__nav .language-dropdown > a,
.header .menu__nav .currency-dropdown > a span,
.header .menu__nav .language-dropdown > a span,
.header .menu__nav .login-item > a,
.header .menu__nav .login-item > a span {
    color: #0d1b2a !important;
}
.header .menu__nav .text-inherit { color: inherit !important; }

/* Iconos del header (chevron, etc) en navy */
.header .menu__nav > li > a > i.icon,
.header .menu__nav > li > a > i.icon-chevron-sm-down {
    color: #0d1b2a !important;
}

/* Si el theme/page tiene clase navTextStyle text-white, lo forzamos a navy en home y resto */
.header .text-white { color: #0d1b2a !important; }

/* Hover de items del menú */
.header .menu__nav > li > a:hover,
.header .menu__nav > li > a:hover > span,
.header .menu__nav > li > a:hover > i {
    color: #1a3a5e !important;
    opacity: 1;
}

/* ===== HOME (body.ng-hero-page): header absolute, scrollea con el contenido ===== */
body.ng-hero-page { padding-top: 0 !important; }
body.ng-hero-page .header.js-header {
    position: absolute !important;
}
/* En home: forzar mismo pill style que en otras páginas (transparent_v2 lo perdía) */
@media (min-width: 1200px) {
    body.ng-hero-page .header__container,
    body.ng-hero-page .header.js-header .header__container {
        box-sizing: border-box !important;
        width: calc(100% - 28px) !important;
        max-width: 1300px !important;
        margin: 12px auto 0 !important;
        padding: 4px 18px !important;
        background: rgba(255, 255, 255, .94) !important;
        -webkit-backdrop-filter: blur(10px) !important;
        backdrop-filter: blur(10px) !important;
        border-radius: 999px !important;
        box-shadow: 0 1px 3px rgba(13, 27, 42, .06),
                    0 0 0 1px rgba(13, 27, 42, .04) !important;
    }
    body.ng-hero-page .header.js-header {
        height: 70px !important;
    }
}

/* En páginas que NO son home: header tiene background blanco al hacerse sticky/scrollear */
body:not(.ng-hero-page) .header.js-header.bg-white,
body:not(.ng-hero-page) .header.js-header.is-sticky {
    background: transparent !important; /* el container interno ya tiene fondo */
}

/* ===========================================================
   DESACTIVAR FADE/DELAY DE SCROLL-REVEAL — vía JS agregamos
   .is-in-view a todos los elementos data-anim* en app.blade.php.
   Solo necesitamos asegurar duración 0 al cargar para que no
   se vea la transición inicial.
   =========================================================== */
html.ng-no-anim [data-anim],
html.ng-no-anim [data-anim-wrap],
html.ng-no-anim [data-anim-child] {
    transition-duration: 0s !important;
    animation-duration: 0s !important;
    transition-delay: 0s !important;
    animation-delay: 0s !important;
}

/* ===========================================================
   MOBILE SLIDERS: 1.3 cards visibles (peek) + ocultar dots
   =========================================================== */
@media (max-width: 767px) {
    /* Quita el width:250 fijo que pone el theme en el container del slider */
    .js-section-slider {
        width: auto !important;
    }
    /* Tamaño de cada card: ~80% del viewport para 1.2 cards.
       Gap se aplica como margin-right CSS (Swiper spaceBetween=0 en mobile). */
    .js-section-slider .swiper-slide {
        width: 80% !important;
        max-width: 80% !important;
        flex-shrink: 0 !important;
        margin-right: 14px !important;
    }
    .js-section-slider .swiper-slide:last-child {
        margin-right: 0 !important;
    }
    /* Oculta dots y barras de paginación en mobile */
    .js-section-slider + * .pagination,
    .swiper-pagination,
    .pagination.-dots,
    [class*="js-"][class*="-pag"],
    .pagination__item,
    .ng-snap-dots {
        display: none !important;
    }
    /* Oculta flechas prev/next en mobile */
    [class*="js-"][class*="-prev"],
    [class*="js-"][class*="-next"],
    .swiper-button-prev,
    .swiper-button-next {
        display: none !important;
    }

    /* ===== Botón "More" del header → ABAJO de toda la section en mobile (CSS only)
       Aplica a CUALQUIER section que tenga el patrón .row > .col-auto > a.button.
       Estrategia: flex-direction column en el container, .row con display:contents,
       y order 999 al col-auto del botón para que caiga al final. */
    section .container:has(.row > .col-auto > a.button) {
        display: flex !important;
        flex-direction: column !important;
    }
    section .container:has(.row > .col-auto > a.button) > .row,
    section .container:has(.row > .col-auto > a.button) .row:has(> .col-auto > a.button) {
        display: flex !important;
    }
    /* La col del título queda primera */
    section .container:has(.row > .col-auto > a.button) .row > .col-auto:first-child {
        order: 0;
        width: 100% !important;
        max-width: 100% !important;
        flex: none !important;
    }
    /* La col del botón queda al FINAL de la section */
    section .container:has(.row > .col-auto > a.button) .row > .col-auto:has(> a.button) {
        order: 999 !important;
        width: 100% !important;
        max-width: 100% !important;
        flex: none !important;
        margin-top: 24px !important;
        padding: 0 !important;
    }
    /* Botón "Más" full-width abajo */
    section .row > .col-auto:has(> a.button) > a.button {
        display: flex !important;
        width: 100% !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 8px !important;
        padding: 14px 20px !important;
        font-size: 15px !important;
        font-weight: 600 !important;
        border-radius: 12px !important;
        text-align: center !important;
    }
    section .row > .col-auto:has(> a.button) a.button [class*="icon-"] {
        margin-left: 4px !important;
    }
}

/* Smart search dropdown SIEMPRE arriba de todo */
.ng-smart-search,
.ng-smart-search__dropdown,
.ng-smart-search .dropdown-menu,
.ng-smart-search__results,
.ng-smart-search__dropdown.is-open,
.ng-smart-search__dropdown[data-ng-flip-above],
.ng-smart-search__dropdown.show {
    z-index: 99999 !important;
}
/* Asegurar también el contenedor del field si es relativo */
.ng-hero__searchField--what,
.ng-hero__searchField:has(.ng-smart-search) {
    z-index: 99999 !important;
}

/* ===========================================================
   AIRBNB-LIKE REFINEMENT LAYER (capa adicional, no sustituye nada)
   =========================================================== */

/* --- Tokens refinados (paleta Airbnb + finos como Cantinero) --- */
:root {
    --ng-ab-text:        #222222;
    --ng-ab-text-2:      #717171;
    --ng-ab-text-3:      #5a5a58;
    --ng-ab-border:      rgba(34, 34, 34, .06);    /* hairline ultra-light */
    --ng-ab-border-2:    rgba(34, 34, 34, .12);    /* hairline visible */
    --ng-ab-border-3:    rgba(34, 34, 34, .18);    /* contornos */
    --ng-ab-bg-soft:     #f7f7f7;
    --ng-ab-bg-cream:    #fafafa;
    /* Shadows multi-capa (estilo Cantinero/Apple) */
    --ng-ab-shadow-sm:   0 1px 2px rgba(0, 0, 0, .04), 0 0 0 1px rgba(34, 34, 34, .04);
    --ng-ab-shadow-md:   0 12px 32px -16px rgba(0, 0, 0, .25), 0 2px 6px rgba(0, 0, 0, .06);
    --ng-ab-shadow-lg:   0 24px 56px -24px rgba(0, 0, 0, .30), 0 6px 14px rgba(0, 0, 0, .08);
    --ng-ab-shadow-card: 0 1px 2px rgba(0, 0, 0, .04), 0 4px 12px -4px rgba(0, 0, 0, .08);
    --ng-ab-radius-xs:   8px;
    --ng-ab-radius-sm:   10px;
    --ng-ab-radius:      12px;
    --ng-ab-radius-md:   14px;
    --ng-ab-radius-lg:   16px;
    --ng-ab-radius-xl:   20px;
    --ng-ab-radius-pill: 999px;
    --ng-ab-ease:        cubic-bezier(.22, .61, .36, 1);
    --ng-ab-ease-soft:   cubic-bezier(.4, 0, .2, 1);
}

/* --- Tipografía base más limpia (Inter / system-ui) --- */
body,
.frontend-page {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: var(--ng-ab-text);
}

/* Títulos de section: tracking más ajustado, peso 600-700, color charcoal */
.sectionTitle__title {
    color: var(--ng-ab-text) !important;
    letter-spacing: -.4px;
    font-weight: 600;
}
.sectionTitle__text {
    color: var(--ng-ab-text-2) !important;
}

/* --- Cards: radius unificado 12px, sombras Airbnb sutiles --- */
.ng-tourCard,
.ng-locCard,
.ng-oCard {
    border-radius: var(--ng-ab-radius) !important;
}
.ng-tourCard,
.ng-oCard {
    transition: transform .25s cubic-bezier(.2,.7,.25,1),
                box-shadow .25s ease !important;
}
.ng-tourCard:hover,
.ng-oCard:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--ng-ab-shadow-md) !important;
}
.ng-locCard {
    border: 1px solid var(--ng-ab-border) !important;
    box-shadow: none !important;
    transition: box-shadow .2s ease !important;
}
.ng-locCard:hover {
    box-shadow: var(--ng-ab-shadow-sm) !important;
    transform: none !important;
}

/* --- Imagen del card: zoom suave en hover (Airbnb-style) --- */
.ng-tourCard__bg {
    transition: transform .55s cubic-bezier(.2,.7,.25,1) !important;
}
.ng-tourCard:hover .ng-tourCard__bg {
    transform: scale(1.05) !important;
}

/* --- Botones: estilo Airbnb (radius 8px, sin gradientes) --- */
.button,
button.button,
a.button {
    border-radius: 8px !important;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease !important;
}
.button:hover {
    box-shadow: var(--ng-ab-shadow-sm) !important;
}

/* --- Inputs y form fields más limpios --- */
.ng-hero__searchBar input,
.ng-hero__searchBar select {
    color: var(--ng-ab-text) !important;
}
.ng-hero__searchBar input::placeholder {
    color: var(--ng-ab-text-2) !important;
}

/* --- Hairlines en dividers --- */
hr,
.divider {
    border-color: var(--ng-ab-border) !important;
}

/* --- Section spacing más generoso (8px grid Airbnb) --- */
@media (min-width: 768px) {
    section.layout-pt-md { padding-top: 56px; }
    section.layout-pb-md { padding-bottom: 56px; }
    section.layout-pt-lg { padding-top: 80px; }
    section.layout-pb-lg { padding-bottom: 80px; }
}

/* --- Smart-search dropdown estilo Airbnb (radius + shadow) --- */
.ng-smart-search__dropdown {
    border-radius: var(--ng-ab-radius) !important;
    border: 1px solid var(--ng-ab-border) !important;
    box-shadow: var(--ng-ab-shadow-md) !important;
}
.ng-hero__suggest {
    border-radius: var(--ng-ab-radius) !important;
    border: 1px solid var(--ng-ab-border) !important;
    box-shadow: var(--ng-ab-shadow-md) !important;
}

/* --- Toggle Tours/Yates: refinamiento Airbnb (más limpio) --- */
.ng-hero__tabs.ng-hero__tabs--toggle {
    background: var(--ng-ab-bg-soft) !important;
    border: 1px solid var(--ng-ab-border) !important;
}

/* --- Fin de la capa Airbnb-like base --- */



/* ===========================================================
   PDP AIRBNB DEEP TRANSFORMATION — apunta a las clases reales
   del theme GoTrip (bc_single_book, searchMenu-*, etc.)
   =========================================================== */

/* === TÍTULO Y SHARE === */
.bc_detail h1.text-26,
.bc_detail h1 {
    font-size: 28px !important;
    font-weight: 600 !important;
    color: var(--ng-ab-text) !important;
    letter-spacing: -.5px !important;
    line-height: 1.18 !important;
    margin: 0 0 6px !important;
}
.bc_detail .text-15.text-light-1,
.bc_detail .text-light-1 {
    color: var(--ng-ab-text) !important;
}
.bc_detail i.icon-location-2 {
    color: var(--ng-ab-text) !important;
}

/* Botones Share / Save: estilo Airbnb (transparente con underline) */
.bc_detail .dropdown > button.button.-blue-1.dropdown-toggle,
.bc_detail .service-wishlist .button.-blue-1 {
    background: transparent !important;
    color: var(--ng-ab-text) !important;
    border: none !important;
    box-shadow: none !important;
    padding: 8px 12px !important;
    border-radius: 8px !important;
    text-decoration: underline !important;
    text-underline-offset: 3px !important;
    font-weight: 600 !important;
}
.bc_detail .dropdown > button.button.dropdown-toggle::after { display: none !important; }
.bc_detail .dropdown > button.button:hover,
.bc_detail .service-wishlist .button:hover {
    background: var(--ng-ab-bg-soft) !important;
    text-decoration: underline !important;
}
.bc_detail .service-wishlist .button .icon-heart,
.bc_detail .button .icon-share { color: var(--ng-ab-text) !important; }

/* === FORM BOOK sticky right === */
/* CRÍTICO: cuando estamos en PDP, los ancestors NO pueden tener overflow:clip/hidden */
body:has(.bc_detail) .bc_wrap,
body:has(.bc_detail) .bc_wrap.overflow-hidden,
.bc_wrap:has(.bc_detail),
.bc_wrap:has(.bc_detail).overflow-hidden,
.bc_detail,
.bc_detail.ng-pdp,
.bc_detail .ng-pdp__body,
.bc_detail .ng-pdp__body > .container,
.bc_detail .ng-pdp__body > .container > .row,
.bc_detail .ng-pdp__aside,
.bc_detail .col-lg-4 {
    overflow: visible !important;
    overflow-clip-margin: unset !important;
}
body:has(.bc_detail),
html:has(.bc_detail) {
    overflow-x: visible !important;
}

/* Anula ScrollMagic completamente */
.bc_detail .scrollmagic-pin-spacer {
    all: unset !important;
    display: contents !important;
}

/* Col aside: stretch automático para tomar la altura del row */
.bc_detail .ng-pdp__aside {
    position: relative;
    align-self: stretch !important;
}

/* Wrapper sticky */
.bc_detail .bc_single_book_wrap {
    padding: 0 !important;
    position: sticky !important;
    position: -webkit-sticky !important;
    top: 90px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    display: block !important;
    z-index: 5;
    justify-content: flex-start !important;
}
.bc_detail .bc_single_book {
    width: 100% !important;
    max-width: 100% !important;
    display: block;
}

/* Form más ancho — 100% del col aside (antes era fixed 360px) */
.bc_detail #bc_boat_book_app,
.bc_detail #bc_tour_book_app,
.bc_detail #bc_hotel_book_app,
.bc_detail [id$="_book_app"],
.bc_detail .bc_single_book .px-30.py-30 {
    width: 100% !important;
    max-width: 100% !important;
}
.bc_detail #bc_boat_book_app,
.bc_detail #bc_hotel_book_app,
.bc_detail [id$="_book_app"]:not(#bc_tour_book_app),
.bc_detail .bc_single_book .px-30.py-30,
.bc_detail .bc_single_book.px-30.py-30 {
    padding: 22px !important;
    border: 1px solid var(--ng-ab-border) !important;
    border-radius: var(--ng-ab-radius-lg) !important;
    box-shadow: var(--ng-ab-shadow-md) !important;
    background: #fff !important;
    width: 100% !important;
    max-width: 100% !important;
}
/* Tour: el inner #bc_tour_book_app NO debe tener border propio (lo tiene el outer) */
.bc_detail #bc_tour_book_app {
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
}
@media (max-width: 991px) {
    .bc_detail #bc_boat_book_app,
    .bc_detail #bc_tour_book_app,
    .bc_detail #bc_hotel_book_app,
    .bc_detail [id$="_book_app"],
    .bc_detail .bc_single_book .px-30.py-30 {
        width: 100% !important;
        padding: 18px !important;
    }
}

/* Precio */
.bc_detail .bc_single_book .text-20.fw-500.text-dark-1,
.bc_detail .bc_single_book span.value > div .text-20 {
    font-size: 22px !important;
    font-weight: 600 !important;
    color: var(--ng-ab-text) !important;
}
.bc_detail .bc_single_book span.value small {
    color: var(--ng-ab-text-2) !important;
    font-weight: 400;
    font-size: 14px;
}

/* Score badge a la derecha */
.bc_detail .bc_single_book .size-40.bg-blue-1 {
    background: var(--ng-ab-text) !important;
    border-radius: 8px !important;
    width: 36px !important;
    height: 36px !important;
}
.bc_detail .bc_single_book .size-40.bg-blue-1 .text-white {
    font-size: 13px !important;
}

/* Form fields dentro del book */
.bc_detail .form-book .searchMenu-guests:not(.bc-book-dateCard),
.bc_detail .form-book .searchMenu-date:not(.bc-book-dateCard),
.bc_detail .form-book .searchMenu-location:not(.bc-book-dateCard) {
    padding: 14px 40px 14px 14px !important;
    border: none !important;
    border-bottom: 1px solid #ebebeb !important;
    border-radius: 0 !important;
    background: #fff !important;
    transition: background .2s ease, box-shadow .2s ease !important;
    min-height: 64px !important;
    display: flex !important;
    grid-template-columns: 32px 1fr !important;
    align-items: center !important;
    gap: 12px !important;
    position: relative !important;
    cursor: pointer !important;
}
.bc_detail .form-book .searchMenu-guests:focus-within,
.bc_detail .form-book .searchMenu-date:focus-within,
.bc_detail .form-book .searchMenu-location:focus-within {
    border-color: var(--ng-ab-text) !important;
    box-shadow: 0 0 0 1px var(--ng-ab-text) inset !important;
}
.bc_detail .form-book .searchMenu-guests h4,
.bc_detail .form-book .searchMenu-date h4 {
    font-size: 11px !important;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--ng-ab-text) !important;
    font-weight: 700 !important;
    margin-bottom: 2px !important;
    line-height: 1 !important;
}
.bc_detail .form-book .searchMenu-guests .text-15,
.bc_detail .form-book .searchMenu-date .text-14,
.bc_detail .form-book .searchMenu-date .text-15 {
    font-size: 14px !important;
    color: var(--ng-ab-text) !important;
    font-weight: 500 !important;
}

/* Counter +/- buttons */
.bc_detail .form-book .js-counter button,
.bc_detail .form-book .button.-outline-blue-1.size-38 {
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    border: 1px solid var(--ng-ab-border-2) !important;
    color: var(--ng-ab-text) !important;
    background: #fff !important;
}
.bc_detail .form-book .js-counter button:hover {
    border-color: var(--ng-ab-text) !important;
}
.bc_detail .form-book .js-counter input {
    border: none !important;
    background: transparent !important;
    font-weight: 600 !important;
    color: var(--ng-ab-text) !important;
    width: 36px !important;
    text-align: center !important;
}

/* Botón principal RESERVAR */
.bc_detail .form-book button[type="submit"],
.bc_detail .form-book .button.-dark-1,
.bc_detail .bc_single_book .button.-dark-1 {
    width: 100% !important;
    padding: 14px 20px !important;
    border-radius: 10px !important;
    font-weight: 600 !important;
    font-size: 16px !important;
    border: none !important;
    box-shadow: none !important;
    margin-top: 14px !important;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease !important;
}
.bc_detail .form-book button[type="submit"]:hover,
.bc_detail .bc_single_book .button.-dark-1:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, .15) !important;
}

/* Total breakdown */
.bc_detail .form-book .total,
.bc_detail .form-book .item_total,
.bc_detail .booking-total {
    border-top: 1px solid var(--ng-ab-border) !important;
    padding-top: 14px !important;
    margin-top: 14px !important;
    color: var(--ng-ab-text) !important;
    font-size: 15px !important;
}

/* Tabs Book / Enquiry */
.bc_detail .nav-enquiry {
    display: flex !important;
    gap: 8px !important;
    margin: 18px 0 0 !important;
    border-bottom: 1px solid var(--ng-ab-border) !important;
    padding-bottom: 0 !important;
}
.bc_detail .nav-enquiry .enquiry-item {
    flex: 1;
    padding: 10px 4px !important;
    text-align: center !important;
    cursor: pointer;
    color: var(--ng-ab-text-2) !important;
    font-weight: 500 !important;
    border-bottom: 2px solid transparent !important;
    margin-bottom: -1px !important;
    background: transparent !important;
}
.bc_detail .nav-enquiry .enquiry-item.active {
    color: var(--ng-ab-text) !important;
    border-bottom-color: var(--ng-ab-text) !important;
    font-weight: 600 !important;
}

/* === SECCIONES (left col) limpieza === */
.bc_detail section.pt-40 {
    padding-top: 0 !important;
}
.bc_detail .container.js-pin-container > .row {
    padding-top: 24px;
}
.bc_detail .border-top-light {
    border-top: 1px solid var(--ng-ab-border) !important;
}

/* Specs / Attributes grid */
.bc_detail .row.attribute-list,
.bc_detail .row.specs {
    --bs-gutter-y: 12px;
}
.bc_detail .row.attribute-list .col-lg-6,
.bc_detail .row.attribute-list .col-md-6 {
    padding: 10px 12px !important;
    border-bottom: 1px solid var(--ng-ab-border) !important;
}

/* Description text más limpio */
.bc_detail .description {
    color: var(--ng-ab-text) !important;
    font-size: 16px !important;
    line-height: 1.6 !important;
}

/* === MOBILE PDP === */
@media (max-width: 767px) {
    .bc_detail h1.text-26,
    .bc_detail h1 { font-size: 22px !important; letter-spacing: -.4px !important; }
    .bc_detail section.pt-40 { padding-top: 16px !important; }
    .bc_detail .container.js-pin-container > .row { padding-top: 12px; }
    .bc_detail .bc_single_book_wrap {
        padding: 0 !important;
        margin-top: 8px;
    }
    .bc_detail #bc_boat_book_app,
    .bc_detail #bc_tour_book_app,
    .bc_detail [id$="_book_app"] {
        padding: 16px !important;
    }
    .bc_detail .form-book .searchMenu-guests,
    .bc_detail .form-book .searchMenu-date {
        padding: 10px 12px !important;
    }
    .bc_detail .nav-enquiry .enquiry-item {
        padding: 8px 4px !important;
        font-size: 14px;
    }
}

/* --- Fin PDP DEEP transformation --- */


/* ===========================================================
   PDP AIRBNB FINAL LAYOUT — wrapper limpio y consistente
   =========================================================== */
.ng-pdp { background: #fff; color: #222; }
.ng-pdp .container { max-width: 1300px; }

/* === HEADER (title + share/save) — Airbnb style === */
.ng-pdp__header {
    padding: 32px 0 20px;
}
.ng-pdp__header section.pt-40,
.ng-pdp__header > section {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}
.ng-pdp__header h1.text-26,
.ng-pdp__header h1 {
    font-size: 26px !important;
    font-weight: 600 !important;
    color: #222 !important;
    letter-spacing: -.4px !important;
    line-height: 1.2 !important;
    margin: 0 0 6px !important;
}
.ng-pdp__header .text-15.text-light-1,
.ng-pdp__header .pt-5 .text-15 {
    font-size: 14px !important;
    color: #222 !important;
}
.ng-pdp__header i.icon-location-2 {
    font-size: 14px !important;
    color: #222 !important;
}
.ng-pdp__header .row.justify-between { align-items: center !important; }

/* === GALERÍA dentro del col izquierdo (al lado del booking sticky) === */
.ng-pdp__gallery {
    padding: 0 0 24px;
    width: 100%;
}
/* TODOS los containers del PDP usan exactamente la misma config — respirable */
.bc_detail.ng-pdp .container,
.ng-pdp .container,
.ng-pdp__header .container,
.ng-pdp__gallery .container,
.ng-pdp__body .container,
.ng-pdp__body .container.js-pin-container {
    max-width: 1300px !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 24px !important;
    padding-right: 24px !important;
    box-sizing: border-box !important;
    display: block !important;
}
@media (max-width: 767px) {
    .bc_detail.ng-pdp .container,
    .ng-pdp .container,
    .ng-pdp__header .container,
    .ng-pdp__gallery .container,
    .ng-pdp__body .container,
    .ng-pdp__body .container.js-pin-container {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }
}
.ng-pdp__gallery .ng-abGallery {
    margin: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
}
.ng-pdp__gallery--full .ng-abGallery {
    margin: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 14px !important;
    overflow: hidden;
}
.ng-pdp__gallery--full .ng-abGallery__grid {
    border-radius: 14px !important;
    gap: 6px !important;
    max-height: 520px !important;
    aspect-ratio: 2.4 / 1 !important;
}
/* Esquinas externas redondeadas */
.ng-pdp__gallery--full .ng-abGallery__cell:first-child,
.ng-pdp__gallery--full .ng-abGallery__cell--main {
    border-top-left-radius: 14px !important;
    border-bottom-left-radius: 14px !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}
.ng-pdp__gallery--full .ng-abGallery__cell:nth-child(3) {
    border-top-right-radius: 14px !important;
}
.ng-pdp__gallery--full .ng-abGallery__cell:nth-child(5) {
    border-bottom-right-radius: 14px !important;
}

/* === BODY: contenido + booking aside === */
.ng-pdp__body {
    padding-top: 0;
    padding-bottom: 48px;
}
.ng-pdp__body section.pt-40 { padding-top: 0 !important; }
.ng-pdp__body .container.js-pin-container { padding-top: 0; }
.ng-pdp__body > .container > .row { padding-top: 0; }

.ng-pdp__main {
    padding-right: 56px;
}
@media (max-width: 991px) {
    .ng-pdp__main { padding-right: 12px; }
}

/* === BORDER hairline en separadores estándar del theme === */
.ng-pdp .border-top-light {
    border-color: #ebebeb !important;
}
.ng-pdp .container.mt-40.mb-40 {
    margin-top: 32px !important;
    margin-bottom: 32px !important;
}

/* === MAP / FAQ / REVIEWS / RELATED — espaciado consistente === */
.ng-pdp section.mt-40 { margin-top: 24px !important; }
.ng-pdp section { padding-top: 0; padding-bottom: 0; }

/* === TOUR PDP — secciones unificadas con spacing consistente === */
.ng-pdp__sec {
    padding: 24px 0;
    border-top: 1px solid var(--ng-ab-border);
    margin: 0;
}
.ng-pdp__sec > .container {
    padding-left: 12px;
    padding-right: 12px;
}
.ng-pdp__sec h2,
.ng-pdp__sec h3 {
    font-size: 22px !important;
    font-weight: 600 !important;
    color: #222 !important;
    letter-spacing: -.3px;
    margin: 0 0 14px !important;
}
/* Tour body content sections (dentro de col-lg-8) */
.bc_detail .gotrip-overview {
    padding: 24px 0;
    border-top: 1px solid var(--ng-ab-border);
    margin-top: 24px;
}
.bc_detail .gotrip-overview h3 {
    font-size: 20px !important;
    font-weight: 600 !important;
    margin: 0 0 12px !important;
}
.bc_detail .gotrip-overview .content-text {
    color: #222;
    line-height: 1.6;
}
.bc_detail .ng-pdp__sec--ie {
    padding: 24px 0;
    border-top: 1px solid var(--ng-ab-border);
}
/* Itinerary + Map row */
.bc_detail .ng-pdp__sec--itinerary .row { align-items: flex-start; }
.bc_detail .ng-pdp__sec--itinerary .col-lg-5 #map_content {
    min-height: 360px !important;
    height: 360px !important;
}
/* FAQs section */
.bc_detail .ng-pdp__sec--faqs .row { align-items: flex-start; }
@media (max-width: 991px) {
    .bc_detail .ng-pdp__sec--itinerary .col-lg-5 #map_content {
        min-height: 280px !important;
        height: 280px !important;
        margin-top: 16px;
    }
}
@media (max-width: 767px) {
    .ng-pdp__sec { padding: 18px 0; }
    .ng-pdp__sec h2, .ng-pdp__sec h3 { font-size: 18px !important; margin-bottom: 10px !important; }
    .bc_detail .gotrip-overview { padding: 18px 0; margin-top: 18px; }
    .bc_detail .gotrip-overview h3 { font-size: 18px !important; }
    .bc_detail .ng-pdp__sec--ie { padding: 18px 0; }
}

/* === COMPACTACIÓN DEL PDP === */
/* Section padding-top reducido (era 40px → 24px) */
.bc_detail .bc_content > section.pt-40,
.bc_detail .bc_content > section.pt-40.pb-20 {
    padding-top: 24px !important;
    padding-bottom: 0 !important;
}
/* Dividers entre secciones reducidos */
.bc_detail .container.mt-40.mb-40,
.bc_detail .bc_content .container.mt-40.mb-40 {
    margin-top: 24px !important;
    margin-bottom: 24px !important;
}
/* Border-top-light hairlines uniformes */
.bc_detail .border-top-light,
.bc_detail .mt-50.border-top-light {
    border-color: #ebebeb !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
}
/* Eliminar dobles margin entre secciones */
.bc_detail .bc_content > section + .container.mt-40.mb-40 {
    margin-top: 16px !important;
}
.bc_detail .container.mt-40.mb-40 + section.pt-40,
.bc_detail .container.mt-40.mb-40 + section {
    padding-top: 8px !important;
}
/* Titulos de sección compactos */
.bc_detail h3.text-22,
.bc_detail h2.text-22 {
    font-size: 22px !important;
    font-weight: 600 !important;
    color: #222 !important;
    letter-spacing: -.3px !important;
    margin: 0 0 16px !important;
}
/* Row.y-gap excesivos */
.bc_detail .row.y-gap-30.justify-between.pt-20 { padding-top: 12px !important; }
.bc_detail .row.x-gap-40.y-gap-40 { --bs-gutter-y: 20px; }
.bc_detail .row.x-gap-40.y-gap-40.pt-40 { padding-top: 20px !important; }
/* mt-40 dentro de la columna content */
.bc_detail .mt-40.border-top-light { margin-top: 28px !important; padding-top: 24px; }
.bc_detail .col-12 .row.x-gap-40.y-gap-40.pt-40 { padding-top: 16px !important; }
/* "Tour snapshot" más compacto */
.bc_detail h3.mt-30 { margin-top: 24px !important; }
.bc_detail .row.y-gap-30.justify-between { --bs-gutter-y: 16px; }

/* Map height más razonable */
.bc_detail #map_content {
    min-height: 420px !important;
    height: 420px !important;
}
@media (max-width: 767px) {
    .bc_detail #map_content { min-height: 280px !important; height: 280px !important; }
    .bc_detail .container.mt-40.mb-40 { margin-top: 16px !important; margin-bottom: 16px !important; }
    .bc_detail .bc_content > section.pt-40 { padding-top: 16px !important; }
    .bc_detail h3.text-22, .bc_detail h2.text-22 { font-size: 19px !important; margin-bottom: 12px !important; }
}

/* === MOBILE QC === */
@media (max-width: 767px) {
    .ng-pdp__header { padding: 10px 0 6px; }
    .ng-pdp__header h1 { font-size: 19px !important; margin-bottom: 2px !important; }
    .ng-pdp__header .ng-pdpHead__meta { font-size: 12.5px; gap: 4px; }
    .ng-pdp__gallery { padding: 0 !important; margin: 0 !important; }
    .ng-pdp__gallery--full { padding: 0 !important; }
    .ng-pdp__body { padding-bottom: 16px; padding-top: 0; }
    .ng-pdp__main,
    .ng-pdp__aside {
        padding-right: 12px !important;
        padding-left: 12px !important;
    }
}

/* === MOBILE: galería al tope, full-bleed, sin márgenes === */
@media (max-width: 767px) {
    /* Variable para alinear la galería con el bottom del header flotante NautyGo */
    body.ng-pdp__gallery-top { --ng-header-offset: 76px; }

    /* Sube la galería hasta top:0 absorbiendo el espacio que deja el header flotante */
    body.ng-pdp__gallery-top .ng-pdp__gallery {
        margin: calc(var(--ng-header-offset) * -1) 0 0 !important;
        padding: 0 !important;
        width: 100% !important;
        position: relative;
        z-index: 1;
    }
    body.ng-pdp__gallery-top .ng-pdp__gallery .container {
        padding: 0 !important;
        max-width: 100% !important;
    }
    body.ng-pdp__gallery-top .ng-pdp__gallery .ng-abGallery {
        margin: 0 !important;
        border-radius: 0 !important;
        aspect-ratio: auto !important;
    }
    body.ng-pdp__gallery-top .ng-pdp__gallery .ng-abGallery__grid {
        border-radius: 0 !important;
    }
    /* Ocultar botón "Show all N photos" en mobile — el tap en la imagen abre el lightbox */
    body.ng-pdp__gallery-top .ng-pdp__gallery .ng-abGallery__showAll { display: none !important; }
    /* Dots/counter empujados hacia abajo para no quedar tapados por el header */
    body.ng-pdp__gallery-top .ng-abGallery__counter {
        top: calc(var(--ng-header-offset) + 8px) !important;
    }
    /* Header un poco más arriba ya que la galería viene primero */
    body.ng-pdp__gallery-top .ng-pdp__header {
        padding: 12px 0 4px;
    }
    /* Date strip más compacto para que entre el booking en viewport */
    body.ng-pdp__gallery-top .ng-dateStrip {
        margin-top: 12px !important;
        padding: 10px 12px 8px !important;
        border-radius: 12px !important;
    }
    body.ng-pdp__gallery-top .ng-dateStrip__head {
        margin-bottom: 8px !important;
    }
    body.ng-pdp__gallery-top .ng-dateStrip__title { font-size: 14px !important; }
}

/* === MOBILE: compresión vertical agresiva para subir el CTA "Reservar Ahora" === */
@media (max-width: 767px) {
    /* Quitar gap del row entre col-main y col-aside (mobile no usa columns) */
    body.ng-pdp__gallery-top .ng-pdp__body .row,
    body.ng-pdp__gallery-top .ng-pdp__body > .container > .row {
        --bs-gutter-y: 0 !important;
        gap: 0 !important;
    }
    body.ng-pdp__gallery-top .row.y-gap-30 { --bs-gutter-y: 0 !important; }

    /* Header del PDP: padding compacto, título a tamaño normal (22px mobile) */
    body.ng-pdp__gallery-top .ng-pdp__header { padding: 8px 0 4px !important; }
    body.ng-pdp__gallery-top .ng-pdp__header .ng-pdpHead { gap: 4px !important; }
    /* Rating chip ya aparece en el booking form → ocultar meta para no duplicar */
    body.ng-pdp__gallery-top .ng-pdp__header .ng-pdpHead__meta { display: none !important; }

    /* === "Pick your day" ultra-compacto === */
    body.ng-pdp__gallery-top .ng-dateStrip {
        margin-top: 6px !important;
        padding: 6px 4px !important;
        border-radius: 10px !important;
        border: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
    }
    /* Quitar el head completo: "Pick your day" + nav. Las flechas las dejamos como overlay opcional */
    body.ng-pdp__gallery-top .ng-dateStrip__head { display: none !important; }
    body.ng-pdp__gallery-top .ng-dateStrip__hint { display: none !important; }
    body.ng-pdp__gallery-top .ng-dateStrip__track { gap: 4px !important; }
    body.ng-pdp__gallery-top .ng-dateStrip__day {
        padding: 5px 2px !important;
        border-radius: 9px !important;
        gap: 0 !important;
    }
    body.ng-pdp__gallery-top .ng-dateStrip__num { font-size: 14px !important; line-height: 1.1 !important; }
    body.ng-pdp__gallery-top .ng-dateStrip__dow { font-size: 9.5px !important; }
    body.ng-pdp__gallery-top .ng-dateStrip__mon { display: none !important; }
    body.ng-pdp__gallery-top .ng-dateStrip__price { font-size: 10px !important; margin-top: 1px !important; }

    /* Booking form: padding interno, header precio y CTA -> arriba */
    body.ng-pdp__gallery-top .bc_single_book { margin-top: 8px !important; }
    body.ng-pdp__gallery-top .bc_detail .bc_single_book #bc_boat_book_app,
    body.ng-pdp__gallery-top .bc_detail .bc_single_book .px-30.py-30 {
        padding: 16px !important;
        border-radius: 12px !important;
    }
    body.ng-pdp__gallery-top .bc-book-header { margin-bottom: 8px !important; gap: 8px !important; }
    body.ng-pdp__gallery-top .bc-book-priceChip { font-size: 9.5px !important; padding: 2px 6px !important; }
    body.ng-pdp__gallery-top .bc-book-price { font-size: 18px !important; }
    body.ng-pdp__gallery-top .bc-book-priceRow { gap: 2px !important; }

    /* FECHA DE INICIO card más compacta */
    body.ng-pdp__gallery-top .bc-book-dateCard { padding: 7px 9px !important; gap: 8px !important; }
    body.ng-pdp__gallery-top .bc-book-dateIcon { width: 32px !important; height: 32px !important; border-radius: 8px !important; }
    body.ng-pdp__gallery-top .bc-book-dateIcon svg { width: 15px !important; height: 15px !important; }
    body.ng-pdp__gallery-top .bc-book-dateLabel { font-size: 10px !important; letter-spacing: .04em !important; }
    body.ng-pdp__gallery-top .bc-book-dateTitle { font-size: 13px !important; }
    body.ng-pdp__gallery-top .bc-book-dateHelper { font-size: 10.5px !important; margin-top: 1px !important; }

    /* CTA */
    body.ng-pdp__gallery-top .submit-group { margin-top: 8px !important; }
    body.ng-pdp__gallery-top .booking-cta { padding: 11px 16px !important; font-size: 15px !important; }
    body.ng-pdp__gallery-top .booking-note { font-size: 11px !important; margin-top: 4px !important; }

    /* Trust badges fuera del fold inicial → reducir su impacto */
    body.ng-pdp__gallery-top .booking-bottom-trust {
        margin-top: 10px !important;
        padding-top: 10px !important;
        gap: 8px !important;
    }

    /* Vendor block (logo del proveedor arriba del booking) — colapsar margen */
    body.ng-pdp__gallery-top .bc_single_book .vendor_info,
    body.ng-pdp__gallery-top .bc_single_book .bc_avatar_block,
    body.ng-pdp__gallery-top .bc_single_book .bc_avatar { margin-bottom: 8px !important; }
}
/* Forzar el row del body a tener gutter horizontal correcto */
.ng-pdp__body .row,
.ng-pdp__body > .container > .row {
    --bs-gutter-x: 24px !important;
    margin-left: calc(var(--bs-gutter-x, 24px) * -.5) !important;
    margin-right: calc(var(--bs-gutter-x, 24px) * -.5) !important;
}
.ng-pdp__body .row > [class*="col-"] {
    padding-left: calc(var(--bs-gutter-x, 24px) * .5) !important;
    padding-right: calc(var(--bs-gutter-x, 24px) * .5) !important;
}

/* === Stats highlights (Airbnb-style: chips individuales) === */
.ng-pdpStats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
    padding: 24px 0 8px;
    border: 0;
    background: transparent;
    margin: 0;
}
.ng-pdpStats__item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    background: #fff;
    border: 1px solid rgba(34,34,34,.08);
    border-radius: 14px;
    box-shadow: 0 1px 2px rgba(13,27,42,.03);
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.ng-pdpStats__item:hover {
    border-color: rgba(34,34,34,.14);
    box-shadow: 0 8px 20px -12px rgba(13,27,42,.14);
    transform: translateY(-1px);
}
.ng-pdpStats__item:last-child { border-right: 1px solid rgba(34,34,34,.08); }
.ng-pdpStats__icon {
    flex: 0 0 36px;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: #f5f6f8;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #0d1b2a;
}
.ng-pdpStats__icon i { font-size: 18px; }
.ng-pdpStats__text { min-width: 0; }
.ng-pdpStats__value {
    font-size: 18px;
    font-weight: 700;
    color: #0d1b2a;
    line-height: 1.1;
    margin-bottom: 2px;
    letter-spacing: -.3px;
}
.ng-pdpStats__name {
    font-size: 11.5px;
    color: #717171;
    font-weight: 600;
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: .06em;
}

@media (max-width: 767px) {
    .ng-pdpStats {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
        padding: 16px 0 0;
    }
    .ng-pdpStats__item {
        padding: 8px 4px;
        border-radius: 0 !important;
        border: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
    }
    .ng-pdpStats__icon {
        width: 30px;
        height: 30px;
        flex-basis: 30px;
        border-radius: 8px;
    }
    .ng-pdpStats__icon i { font-size: 15px; }
    .ng-pdpStats__value { font-size: 15px; }
    .ng-pdpStats__name { font-size: 10.5px; }
}

/* === Border-top-light visual cleanup === */
.ng-pdp .container.mt-40.mb-40 { margin: 32px auto !important; }
.ng-pdp .border-top-light { border-color: #ebebeb !important; }

/* --- Fin PDP final layout --- */


/* ===========================================================
   MAPA — escala de grises azules (Leaflet/OSM)
   =========================================================== */
.bc_detail #map_content,
.bc_detail .leaflet-container {
    background: #d8e2ec !important;
}

/* Filtro sobre los tiles: grises con tinte azul (Airbnb / Stripe-like) */
.bc_detail .leaflet-tile-pane {
    filter: grayscale(0.95) brightness(1.04) contrast(0.92) sepia(0.18) hue-rotate(185deg) saturate(0.55);
    -webkit-filter: grayscale(0.95) brightness(1.04) contrast(0.92) sepia(0.18) hue-rotate(185deg) saturate(0.55);
}

/* El círculo primary se ve sobre los tiles filtrados (no se filtra por estar en otro pane) */
.bc_detail .leaflet-overlay-pane svg path {
    /* No filter: queda con el azul vivo */
}

/* Esquinas redondeadas + sombra sutil estilo Airbnb */
.bc_detail #map_content {
    border-radius: 12px !important;
    overflow: hidden;
    border: 1px solid #ebebeb;
}

/* Zoom controls + attribution se ocultan vía JS, pero por si acaso CSS */
.bc_detail .leaflet-control-zoom,
.bc_detail .leaflet-control-attribution {
    display: none !important;
}
.leaflet-touch .leaflet-control-attribution {
    box-shadow: none;
    display: none !important;
}


/* ===========================================================
   PDP HEADER + FORM — Airbnb × Apple hybrid (clean, refined)
   =========================================================== */

/* Tipografía SF Pro / system-ui */
.ng-pdp,
.ng-pdpHead,
.bc_detail .form-book {
    font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'SF Pro Text', 'Inter', 'Helvetica Neue', Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* === HEADER LIMPIO (título + rating + share/save) === */
.ng-pdpHead {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    padding: 0;
}
.ng-pdpHead__left { min-width: 0; flex: 1; }
.ng-pdpHead__title {
    font-size: 28px !important;
    font-weight: 600 !important;
    color: #222;
    letter-spacing: -.5px;
    line-height: 1.18;
    margin: 0 0 6px;
}
.ng-pdpHead__meta {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    color: #222;
    flex-wrap: wrap;
}
.ng-pdpHead__rating {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: #222;
    font-weight: 500;
}
.ng-pdpHead__rating svg { color: #222; }
.ng-pdpHead__rating strong { font-weight: 600; }
.ng-pdpHead__sep { color: #222; opacity: .5; }
.ng-pdpHead__reviews,
.ng-pdpHead__loc a {
    color: #222 !important;
    text-decoration: underline;
    text-decoration-color: #222;
    text-underline-offset: 3px;
    font-weight: 500;
}
.ng-pdpHead__reviews:hover,
.ng-pdpHead__loc a:hover { color: #222; opacity: .85; }
.ng-pdpHead__loc {
    display: inline-flex;
    align-items: center;
    gap: 5px;
}
.ng-pdpHead__loc svg { color: #222; }
.ng-pdpHead__right {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
}
.ng-pdpHead__btn {
    display: inline-flex !important;
    align-items: center;
    gap: 8px;
    padding: 8px 12px !important;
    background: transparent !important;
    border: none !important;
    color: #222 !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    border-radius: 8px !important;
    cursor: pointer;
    text-decoration: underline !important;
    text-underline-offset: 3px;
    transition: background .15s ease;
    box-shadow: none !important;
}
.ng-pdpHead__btn:hover {
    background: #f7f7f7 !important;
    color: #222 !important;
    text-decoration: underline !important;
}
.ng-pdpHead__btn svg { color: #222; flex-shrink: 0; }

/* Mobile header — solo título + rating (si existe). Resto oculto. */
@media (max-width: 767px) {
    .ng-pdpHead { flex-direction: column; gap: 6px; }
    .ng-pdpHead__title { font-size: 22px !important; letter-spacing: -.4px; }
    .ng-pdpHead__meta { font-size: 13px; gap: 4px !important; }
    /* Ocultar separadores, reviews link, location y botones share/save */
    .ng-pdpHead__sep,
    .ng-pdpHead__reviews,
    .ng-pdpHead__loc,
    .ng-pdpHead__right { display: none !important; }
}


/* === FORM-BOOK INTERIOR (Apple-Airbnb hybrid) === */
/* Outer card sin borde/padding (respeta lo que el usuario set) */
/* Estilizamos el INTERIOR */

/* === BOOKING FORM — balance compact + respirable === */
.bc_detail .bc_single_book #bc_boat_book_app,
.bc_detail .bc_single_book #bc_tour_book_app,
.bc_detail .bc_single_book .px-30.py-30 {
    border: 1px solid #e5e7eb !important;
    border-radius: 18px !important;
    box-shadow: 0 4px 16px rgba(0,0,0,.06) !important;
    background: #fff !important;
    padding: 20px !important;
    overflow: hidden;
}
/* Header */
.bc-book-header { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 16px; }
.bc-book-priceWrap { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.bc-book-priceChip {
    display: inline-flex; align-items: center;
    background: #111; color: #fff;
    padding: 3px 8px; border-radius: 999px;
    font-size: 9px; font-weight: 700;
    letter-spacing: .1em; text-transform: uppercase;
    align-self: flex-start; line-height: 1.3;
}
.bc-book-priceRow { display: flex; align-items: baseline; gap: 3px; line-height: 1; flex-wrap: wrap; }
.bc-book-price { font-size: 22px; font-weight: 900; color: #111; letter-spacing: -.5px; line-height: 1; }
.bc-book-priceUnit { font-size: 11px; color: #555; font-weight: 500; }
.bc-book-ratingChip { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.bc-book-ratingChip > div:first-child { text-align: right; }
.bc-book-ratingLabel { font-size: 11px; color: #111; font-weight: 700; line-height: 1.1; }
.bc-book-ratingReviews { font-size: 10px; color: #555; line-height: 1.1; margin-top: 1px; }
.bc-book-ratingScore {
    display: inline-flex; align-items: center; gap: 3px;
    background: #111; color: #fff;
    padding: 5px 8px; border-radius: 8px;
    font-size: 12px; font-weight: 800; flex-shrink: 0;
}
.bc-book-ratingScore svg { color: #ffb703; width: 11px; height: 11px; }
/* Trust */
.bc-book-trustRow { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; margin-bottom: 10px; }
.bc-book-trustBadge {
    display: flex; align-items: center; gap: 6px;
    background: #eefaf2; border-radius: 10px;
    padding: 7px 10px; color: #119b3f;
    font-size: 11.5px; font-weight: 600; line-height: 1.2;
}
.bc-book-trustBadge svg { flex-shrink: 0; width: 14px; height: 14px; }
/* Date — CTA secundario destacado (charcoal border + accent line + arrow anim) */
.bc_detail .form-book .bc-book-dateCard,
.bc-book-dateCard {
    display: grid !important;
    grid-template-columns: 48px 1fr 18px !important;
    gap: 14px !important;
    align-items: center !important;
    background: #fff !important;
    border: 2px solid #111 !important;
    border-radius: 16px !important;
    padding: 16px 18px !important;
    cursor: pointer;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease !important;
    margin-bottom: 14px !important;
    position: relative !important;
    box-shadow: 0 4px 14px -6px rgba(0,0,0,.18) !important;
    overflow: hidden !important;
    min-height: 0 !important;
}
/* Accent line izquierda: barra naranja sutil que indica "acción" */
.bc-book-dateCard::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 4px;
    background: linear-gradient(180deg, #ff5a00, #ffb703);
    pointer-events: none;
}
.bc-book-dateCard:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 20px -6px rgba(0,0,0,.25);
}
.bc-book-dateCard:hover .bc-book-dateArrow {
    transform: translateX(4px);
    color: #ff5a00;
}
.bc-book-dateIcon {
    width: 48px; height: 48px;
    background: #111; color: #fff;
    border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 2px 6px -1px rgba(0,0,0,.20);
}
.bc-book-dateIcon svg { width: 22px; height: 22px; }
.bc-book-dateArrow {
    color: #111;
    transition: transform .2s ease, color .2s ease;
}
.bc-book-dateContent { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.bc-book-dateLabel {
    font-size: 10px; font-weight: 800; letter-spacing: .12em;
    text-transform: uppercase; color: #ff5a00; line-height: 1.2;
}
.bc-book-dateTitle { font-size: 16px; font-weight: 800; color: #111; line-height: 1.2; }
.bc-book-dateHelper { font-size: 11.5px; color: #555; line-height: 1.3; margin-top: 2px; }
.bc-book-dateArrow svg { width: 16px; height: 16px; }
/* Fees */
.bc-book-feesCard {
    background: #fff; border: 1px solid #e5e7eb;
    border-radius: 14px; padding: 4px 16px;
    margin-bottom: 14px;
}
.bc-book-feeRow {
    display: grid; grid-template-columns: 34px 1fr auto;
    gap: 12px; align-items: center;
    padding: 11px 0;
    border-bottom: 1px solid #f0f1f4;
}
.bc-book-feeRow:last-child { border-bottom: 0; }
.bc-book-feeIcon {
    width: 34px; height: 34px;
    background: #f3f4f7; color: #111;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
}
.bc-book-feeIcon svg { width: 17px; height: 17px; }
.bc-book-feeLabel {
    font-size: 13px; color: #111; font-weight: 600;
    display: flex; align-items: center; gap: 6px;
}
.bc-book-feeLabel .info {
    width: 12px; height: 12px; border-radius: 50%;
    background: #d1d5db; color: #fff;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 8px; font-weight: 700; cursor: help;
}
.bc-book-feePrice { font-size: 15px; font-weight: 800; color: #111; }
/* Total */
.bc-book-totalRow {
    display: flex; justify-content: space-between; align-items: center;
    padding: 12px 16px; background: #f9fafb;
    border: 1px solid #e5e7eb; border-radius: 14px;
    margin-bottom: 14px;
}
.bc-book-totalLabel { font-size: 14px; font-weight: 700; color: #111; }
.bc-book-totalPrice { font-size: 18px; font-weight: 900; color: #111; }
/* CTA — naranja gradient llamativo */
.booking-cta {
    width: 100%;
    border: none !important;
    border-radius: 14px !important;
    padding: 15px 20px !important;
    background: linear-gradient(135deg, #ff5a00 0%, #ffb703 100%) !important;
    color: #fff !important;
    font-size: 16px !important;
    font-weight: 900 !important;
    cursor: pointer;
    box-shadow: 0 6px 16px -4px rgba(255,122,0,.45),
                0 2px 6px rgba(255,122,0,.20) !important;
    transition: all 0.2s ease;
    display: flex !important;
    align-items: center; justify-content: center;
    gap: 10px;
    text-decoration: none !important;
    margin-top: 10px !important;
    letter-spacing: -.2px;
    text-transform: none !important;
    line-height: 1 !important;
}
.booking-cta:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 22px -4px rgba(255,122,0,.55),
                0 4px 10px rgba(255,122,0,.28) !important;
    background: linear-gradient(135deg, #ff4d00 0%, #ffa600 100%) !important;
    color: #fff !important;
}
.booking-cta:active { transform: translateY(0); }
.booking-cta svg { width: 18px; height: 18px; flex-shrink: 0; }
/* Note */
.booking-note {
    color: #555;
    text-align: center;
    font-size: 12px;
    margin-top: 10px;
    font-weight: 500;
    display: flex; align-items: center; justify-content: center; gap: 6px;
    line-height: 1.3;
}
.booking-note svg { color: #555; flex-shrink: 0; width: 12px; height: 12px; }
/* Bottom trust */
.booking-bottom-trust {
    border-top: 1px solid #e5e7eb;
    margin-top: 24px; padding-top: 20px;
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
}
.booking-bottom-item {
    color: #111;
    display: flex; align-items: flex-start; gap: 9px;
    font-size: 11px; line-height: 1.35;
}
.booking-bottom-item__icon { width: 18px; height: 18px; color: #111; flex-shrink: 0; }
.booking-bottom-item strong { display: block; color: #111; font-size: 11px; font-weight: 800; line-height: 1.3; }
.booking-bottom-item span { display: block; color: #555; font-size: 10.5px; margin-top: 3px; line-height: 1.3; }
/* Mobile */
@media (max-width: 767px) {
    .bc_detail .bc_single_book #bc_boat_book_app,
    .bc_detail .bc_single_book #bc_tour_book_app,
    .bc_detail .bc_single_book .px-30.py-30 { padding: 12px !important; border-radius: 14px !important; }
    .bc-book-price { font-size: 20px; }
    .bc-book-ratingChip { flex-direction: column; gap: 3px; align-items: flex-end; }
    .bc-book-trustRow { grid-template-columns: 1fr; }
    .bc-book-dateCard { grid-template-columns: 36px 1fr 14px; padding: 8px 10px; gap: 9px; }
    .bc-book-dateIcon { width: 36px; height: 36px; border-radius: 9px; }
    .bc-book-dateIcon svg { width: 17px; height: 17px; }
    .bc-book-dateTitle { font-size: 13px; }
    .bc-book-feeRow { grid-template-columns: 28px 1fr auto; gap: 9px; padding: 6px 0; }
    .bc-book-feeIcon { width: 28px; height: 28px; border-radius: 8px; }
    .bc-book-feeIcon svg { width: 14px; height: 14px; }
    .bc-book-feeLabel { font-size: 12px; }
    .bc-book-feePrice { font-size: 13px; }
    .booking-cta { font-size: 15px !important; padding: 12px 16px !important; }
    .booking-bottom-trust { grid-template-columns: 1fr 1fr; }
    .booking-bottom-item:last-child { grid-column: span 2; }
}

/* Header del form (precio + rating badge) — respirable */
.bc_detail .bc_single_book .d-flex.justify-between {
    align-items: flex-start !important;
    padding-bottom: 0;
    border-bottom: none;
    margin-bottom: 0;
}

/* Precio principal — más prominente */
.bc_detail .bc_single_book .text-20.fw-500.text-dark-1 {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: #222 !important;
    letter-spacing: -.4px;
}
.bc_detail .bc_single_book span.value small {
    color: #717171 !important;
    font-weight: 400;
    font-size: 14px;
    margin-left: 4px;
}

/* Score badge */
.bc_detail .bc_single_book .size-40.bg-blue-1 {
    background: #222 !important;
    border-radius: 8px !important;
    width: 36px !important;
    height: 36px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.bc_detail .bc_single_book .size-40 .text-white {
    font-size: 13px !important;
    font-weight: 700 !important;
}
.bc_detail .bc_single_book .text-14.text-right .lh-15.fw-500 {
    color: #222 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
}
.bc_detail .bc_single_book .text-14.text-right .lh-15.text-light-1 {
    color: #717171 !important;
    font-size: 12px !important;
}

/* Tabs Book/Enquiry — compactas */
.bc_detail .nav-enquiry {
    display: flex !important;
    gap: 4px !important;
    margin: 10px -16px 8px !important;
    padding: 0 16px !important;
    border-bottom: 1px solid #ebebeb !important;
}
.bc_detail .nav-enquiry .enquiry-item {
    flex: 1;
    padding: 8px 4px !important;
    text-align: center !important;
    cursor: pointer;
    color: #717171 !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    border-bottom: 2px solid transparent !important;
    margin-bottom: -1px !important;
    background: transparent !important;
    transition: color .15s ease, border-color .15s ease;
}
.bc_detail .nav-enquiry .enquiry-item.active {
    color: #222 !important;
    border-bottom-color: #222 !important;
    font-weight: 600 !important;
}

/* Form fields — RESPIRABLE (todo unificado en una caja) */
.bc_detail .form-book .form-content {
    padding-top: 0 !important;
}
.bc_detail .form-book .row.y-gap-20 {
    --bs-gutter-y: 0 !important;
    margin: 0 !important;
}
.bc_detail .form-book .row.y-gap-20 > [class*="col-"] {
    padding: 0 !important;
}
.bc_detail .form-book .pt-20 {
    padding-top: 0 !important;
}

/* Wrapper unificado — sin border duplicado (el outer card ya tiene) */
.bc_detail .form-book .form-content > .row {
    border: none !important;
    border-radius: 0 !important;
    overflow: visible;
    margin-top: 14px !important;
}

/* .form-book interior: SIN border/padding/shadow propios (solo el outer card los tiene) */
.bc_detail .bc_single_book .form-book,
.bc_detail #bc_boat_book_app .form-book,
.bc_detail [id$="_book_app"] .form-book {
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    background: transparent !important;
    width: auto !important;
}
.bc_detail .form-book .form-content {
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
}

/* Cada field con grid layout — SOLO los fields legacy, NO el .bc-book-dateCard renovado */
.bc_detail .form-book .searchMenu-guests:not(.bc-book-dateCard),
.bc_detail .form-book .searchMenu-date:not(.bc-book-dateCard),
.bc_detail .form-book .searchMenu-location:not(.bc-book-dateCard) {
    padding: 14px 40px 14px 14px !important;
    border: none !important;
    border-bottom: 1px solid #ebebeb !important;
    border-radius: 0 !important;
    background: #fff !important;
    transition: background .2s ease, box-shadow .2s ease !important;
    min-height: 64px !important;
    display: flex !important;
    grid-template-columns: 32px 1fr !important;
    align-items: center !important;
    gap: 12px !important;
    position: relative !important;
    cursor: pointer !important;
}
/* El contenedor del label+valor pasa al grid col 2 automáticamente */
.bc_detail .form-book .searchMenu-guests:not(.bc-book-dateCard) > div:not([data-x-dd]):not([data-x-dd-toggle]),
.bc_detail .form-book .searchMenu-date:not(.bc-book-dateCard) > div,
.bc_detail .form-book .form-date-field:not(.bc-book-dateCard) > div:first-of-type,
.bc_detail .form-book .form-date-search:not(.bc-book-dateCard) > div:first-of-type,
.bc_detail .form-book .searchMenu-location:not(.bc-book-dateCard) > div:first-of-type {
    grid-column: 2;
}

/* Iconos leading: círculos con bg primary suave — grid item, vertical-center perfecto */
.bc_detail .form-book .searchMenu-date::before,
.bc_detail .form-book .form-date-field::before,
.bc_detail .form-book .form-date-search::before,
.bc_detail .form-book .searchMenu-guests:not(.form-date-field):not(.form-date-search)::before,
.bc_detail .form-book .searchMenu-location::before {
    content: '';
    grid-column: 1;
    grid-row: 1;
    align-self: center;
    justify-self: start;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background-color: rgba(53, 84, 209, .10);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 16px 16px;
    transition: background-color .2s ease, transform .2s ease;
    pointer-events: none;
}
.bc_detail .form-book .searchMenu-date::before,
.bc_detail .form-book .form-date-field::before,
.bc_detail .form-book .form-date-search::before,
.bc_detail .form-book .searchMenu-guests.form-date-field::before,
.bc_detail .form-book .searchMenu-guests.form-date-search::before {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%233554D1' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4' width='18' height='18' rx='2.5'/><line x1='16' y1='2' x2='16' y2='6'/><line x1='8' y1='2' x2='8' y2='6'/><line x1='3' y1='10' x2='21' y2='10'/></svg>") !important;
    background-size: 16px 16px !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    background-color: rgba(53, 84, 209, .10) !important;
}
.bc_detail .form-book .searchMenu-guests::before {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%233554D1' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><path d='M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2'/><circle cx='9' cy='7' r='4'/><path d='M23 21v-2a4 4 0 0 0-3-3.87'/><path d='M16 3.13a4 4 0 0 1 0 7.75'/></svg>");
}
.bc_detail .form-book .searchMenu-location::before {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%233554D1' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><path d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/><circle cx='12' cy='10' r='3'/></svg>");
}
/* === Extra prices section (form-section-group) === */
.bc_detail .form-book .form-section-group {
    background: #fafafa !important;
    border: 1px solid #ebebeb !important;
    border-radius: 10px !important;
    padding: 12px 14px !important;
    margin-top: 10px !important;
}
.bc_detail .form-book .form-section-group .form-section-title {
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: .5px !important;
    color: #717171 !important;
    font-weight: 700 !important;
    margin: 0 0 8px !important;
    padding-bottom: 8px;
    border-bottom: 1px solid #ebebeb;
    display: flex;
    align-items: center;
    gap: 8px;
}
.bc_detail .form-book .form-section-group .form-section-title::before {
    content: '';
    width: 16px; height: 16px;
    flex-shrink: 0;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23717171' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><line x1='12' y1='1' x2='12' y2='23'/><path d='M17 5H9.5a3.5 3.5 0 0 0 0 7h5a3.5 3.5 0 0 1 0 7H6'/></svg>") no-repeat center;
    background-size: contain;
}
.bc_detail .form-book .form-section-group .extra-price-wrap,
.bc_detail .form-book .form-section-group .form-group {
    padding: 6px 0 !important;
    font-size: 14px !important;
    color: #222 !important;
    border: none !important;
}

/* Anular cualquier estilo previo de .px-20.py-10 que estaba aplicando $ a TODO field */
.bc_detail .form-book .px-20.py-10:not(.searchMenu-guests):not(.searchMenu-date):not(.searchMenu-location):not(.form-section-group) {
    background: transparent !important;
    padding: 8px 0 !important;
    min-height: 0 !important;
    border: none !important;
}

/* DATE FIELD: highlight especial (es la acción principal de CRO) */
.bc_detail .form-book .searchMenu-date {
    background: linear-gradient(180deg, rgba(53,84,209,.025) 0%, rgba(53,84,209,0) 100%) !important;
    box-shadow: inset 0 0 0 1px rgba(53,84,209,.12);
}
.bc_detail .form-book .searchMenu-date:hover::before,
.bc_detail .form-book .form-date-field:hover::before,
.bc_detail .form-book .form-date-search:hover::before {
    background-color: rgba(53, 84, 209, .18) !important;
}

/* Hover en cualquier field */
.bc_detail .form-book .searchMenu-guests:hover,
.bc_detail .form-book .searchMenu-date:hover,
.bc_detail .form-book .searchMenu-location:hover {
    background-color: #f7f9ff !important;
}
.bc_detail .form-book .searchMenu-guests:hover::before,
.bc_detail .form-book .searchMenu-location:hover::before {
    background-color: rgba(53, 84, 209, .18);
}

/* Chevron derecha (clickeable indicator) */
/* En el form-book renovado (.bc-book-dateCard) ya proveemos ícono y flecha SVG —
   anular los pseudo-elementos viejos para que no se dupliquen. */
.bc_detail .form-book .bc-book-dateCard::before,
.bc_detail .form-book .bc-book-dateCard::after {
    content: none !important;
    display: none !important;
    background: none !important;
}
.bc_detail .form-book .searchMenu-date::after,
.bc_detail .form-book .searchMenu-guests::after,
.bc_detail .form-book .searchMenu-location::after {
    content: '';
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    width: 14px;
    height: 14px;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%233554D1' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='9 18 15 12 9 6'/></svg>");
    background-repeat: no-repeat;
    background-size: contain;
    opacity: .65;
    transition: opacity .2s ease, transform .2s ease;
}
.bc_detail .form-book .searchMenu-date:hover::after,
.bc_detail .form-book .searchMenu-guests:hover::after,
.bc_detail .form-book .searchMenu-location:hover::after {
    opacity: 1;
    transform: translateY(-50%) translateX(3px);
}

/* Pulse subtle en el date para llamar atención CRO */
@keyframes ng-cro-pulse {
    0%, 100% { box-shadow: inset 0 0 0 1px rgba(53,84,209,.12), 0 0 0 0 rgba(53,84,209,0); }
    50% { box-shadow: inset 0 0 0 1px rgba(53,84,209,.30), 0 0 0 6px rgba(53,84,209,0); }
}
.bc_detail .form-book .searchMenu-date {
    animation: ng-cro-pulse 2.6s ease-in-out infinite;
}
.bc_detail .form-book .searchMenu-date:hover {
    animation: none;
}
.bc_detail .form-book .form-content .row > [class*="col-"]:last-child .searchMenu-guests,
.bc_detail .form-book .form-content .row > [class*="col-"]:last-child .searchMenu-date,
.bc_detail .form-book .form-content .row > [class*="col-"]:last-child .searchMenu-location {
    border-bottom: none !important;
}
.bc_detail .form-book .searchMenu-guests:hover,
.bc_detail .form-book .searchMenu-date:hover,
.bc_detail .form-book .searchMenu-location:hover {
    background: #fafafa !important;
}
.bc_detail .form-book .searchMenu-guests:focus-within,
.bc_detail .form-book .searchMenu-date:focus-within,
.bc_detail .form-book .searchMenu-location:focus-within {
    background: #f7f7f7 !important;
    box-shadow: none !important;
}
.bc_detail .form-book .searchMenu-guests:focus-within,
.bc_detail .form-book .searchMenu-date:focus-within,
.bc_detail .form-book .searchMenu-location:focus-within {
    border-color: #222 !important;
    box-shadow: 0 0 0 1px #222 inset !important;
}

/* Labels del form (UPPERCASE small Airbnb-style) */
.bc_detail .form-book .searchMenu-guests h4,
.bc_detail .form-book .searchMenu-date h4,
.bc_detail .form-book h4.text-15.fw-500 {
    font-size: 9px !important;
    text-transform: uppercase !important;
    letter-spacing: .4px !important;
    color: #222 !important;
    font-weight: 800 !important;
    margin-bottom: 2px !important;
    line-height: 1 !important;
}

/* Valores */
.bc_detail .form-book .searchMenu-guests .text-15,
.bc_detail .form-book .searchMenu-date .text-14,
.bc_detail .form-book .searchMenu-date .text-15,
.bc_detail .form-book .check-in-out-render {
    font-size: 13px !important;
    color: #222 !important;
    font-weight: 500 !important;
    text-align: left;
}

/* Counter +/- buttons compactos */
.bc_detail .form-book .button.-outline-blue-1.size-38,
.bc_detail .form-book .js-up,
.bc_detail .form-book .js-down {
    width: 26px !important;
    height: 26px !important;
    border-radius: 50% !important;
    border: 1px solid #b0b0b0 !important;
    color: #222 !important;
    background: #fff !important;
    transition: border-color .15s ease, background .15s ease;
}
.bc_detail .form-book .button.-outline-blue-1.size-38:hover,
.bc_detail .form-book .js-up:hover,
.bc_detail .form-book .js-down:hover {
    border-color: #222 !important;
    background: #f7f7f7 !important;
}
.bc_detail .form-book .js-up i,
.bc_detail .form-book .js-down i { font-size: 10px !important; color: #222 !important; }
.bc_detail .form-book .js-counter input {
    border: none !important;
    background: transparent !important;
    font-weight: 700 !important;
    color: #222 !important;
    width: 30px !important;
    text-align: center !important;
    font-size: 14px !important;
}

/* CTA Reservar — CRO optimized: bold, big, with arrow */
/* Legacy CTA (cuando NO usa el nuevo .booking-cta) — compacto */
.bc_detail .form-book button[type="submit"]:not(.booking-cta),
.bc_detail .form-book .button.-dark-1:not(.booking-cta),
.bc_detail .bc_single_book .button.-dark-1:not(.booking-cta),
.bc_detail .ng-cro-cta:not(.booking-cta) {
    display: inline-flex !important; align-items: center !important; justify-content: center !important;
    gap: 8px !important; width: 100% !important; padding: 12px 18px !important;
    border-radius: 10px !important; font-weight: 700 !important; font-size: 15px !important;
    border: 0 !important; margin-top: 14px !important; cursor: pointer;
    line-height: 1.2 !important; text-transform: none !important;
    background: #0d1b2a !important; color: #fff !important;
    box-shadow: 0 4px 12px -4px rgba(13, 27, 42, .30) !important;
    transition: transform .2s, box-shadow .2s, background .2s !important;
}
.bc_detail .form-book button[type="submit"]:not(.booking-cta):hover,
.bc_detail .form-book .button.-dark-1:not(.booking-cta):hover,
.bc_detail .bc_single_book .button.-dark-1:not(.booking-cta):hover,
.bc_detail .ng-cro-cta:not(.booking-cta):hover {
    background: #1a2b48 !important;
}
.bc_detail .ng-cro-cta__arrow {
    transition: transform .2s ease;
}
.bc_detail .form-book button[type="submit"]:hover,
.bc_detail .form-book .button.-dark-1:hover,
.bc_detail .bc_single_book .button.-dark-1:hover,
.bc_detail .ng-cro-cta:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, .15) !important;
    filter: brightness(1.04);
}
.bc_detail .ng-cro-cta:hover .ng-cro-cta__arrow {
    transform: translateX(4px);
}

/* === CRO Trust badges (debajo del precio) === */
.bc_detail .ng-cro-trust {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
    margin-top: 10px;
    padding-bottom: 14px;
    border-bottom: 1px solid #f0f0f0;
}
.bc_detail .ng-cro-trust__item {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    font-weight: 500;
    color: #008a05;
    line-height: 1.2;
}
.bc_detail .ng-cro-trust__item svg {
    color: #008a05;
    flex-shrink: 0;
}

/* === CRO disclaimer (debajo del CTA) === */
.bc_detail .ng-cro-disclaimer {
    text-align: center;
    font-size: 13px;
    color: #717171;
    margin-top: 12px;
    line-height: 1.4;
    font-weight: 500;
}
.bc_detail .form-book button[type="submit"]:hover,
.bc_detail .form-book .button.-dark-1:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(225, 65, 63, .35) !important;
    filter: brightness(1.04);
}

/* Total breakdown — respirable */
.bc_detail .form-book .total,
.bc_detail .form-book .item_total,
.bc_detail .booking-total,
.bc_detail .form-book .total-fee {
    border-top: 1px solid #ebebeb !important;
    padding-top: 16px !important;
    margin-top: 16px !important;
    color: #222 !important;
    font-size: 15px !important;
    font-weight: 600 !important;
}

/* Disclaimers */
.bc_detail .form-book .text-light-1,
.bc_detail .form-book .text-13.text-light-1 {
    color: #717171 !important;
    text-align: center;
    font-size: 12px !important;
    margin-top: 12px !important;
}

/* Margenes globales del wrap */
.bc_detail .form-book .mt-20,
.bc_detail .bc_single_book .mt-20 { margin-top: 14px !important; }
.bc_detail .form-book .mt-30,
.bc_detail .bc_single_book .mt-30 { margin-top: 16px !important; }
.bc_detail .form-book .pt-30 { padding-top: 14px !important; }
.bc_detail .form-book .pb-30 { padding-bottom: 14px !important; }
.bc_detail .form-book .pt-20 { padding-top: 0 !important; }

/* Bloques extras (precios extra) */
.bc_detail .form-book .extra-price-list .item,
.bc_detail .form-book .extra-fees .item {
    padding: 10px 0 !important;
    border: none !important;
    border-bottom: 1px solid #f0f0f0 !important;
    font-size: 14px !important;
    color: #222 !important;
}
.bc_detail .form-book .extra-price-list .item:last-child { border-bottom: none !important; }

/* "PRECIOS EXTRA:" label - estilo title section */
.bc_detail .form-book .px-20.py-10 {
    padding: 10px 14px !important;
    background: #fafafa !important;
}
.bc_detail .form-book .px-20.py-10:has(span:only-child),
.bc_detail .form-book .px-20.py-10 > span:only-child {
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .5px !important;
    color: #717171 !important;
    border-radius: 16px !important;
}

/* Ocultar widget del owner/operador */
.bc_detail .owner-info,
.owner-info.widget-boxrounded-4 {
    display: none !important;
}

/* === FIN PDP Hybrid Style === */


/* ===========================================================
   "Cosas que debes saber" — sección Airbnb-style
   =========================================================== */
.ab-know-section { padding: 32px 0 !important; }
.ab-section-title {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: #222 !important;
    letter-spacing: -.4px;
    margin: 0 0 24px !important;
}
.ab-know-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}
.ab-know-col { min-width: 0; }
.ab-know-h {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #222 !important;
    letter-spacing: -.2px;
    margin: 0 0 16px !important;
}
.ab-know-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.ab-know-list li {
    font-size: 15px;
    color: #222;
    line-height: 1.5;
    padding: 10px 0;
    border-bottom: 1px solid #ebebeb;
}
.ab-know-list li:last-child { border-bottom: none; }

@media (max-width: 991px) {
    .ab-know-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; padding: 24px; }
}
@media (max-width: 767px) {
    .ab-know-section { padding: 20px 0 !important; }
    .ab-section-title { font-size: 19px !important; margin: 0 0 16px !important; }
    .ab-know-grid { grid-template-columns: 1fr; gap: 20px; padding: 16px; }
    .ab-know-h { font-size: 15px !important; margin: 0 0 10px !important; }
    .ab-know-list li { font-size: 14px; padding: 8px 0; }
}


/* ===========================================================
   PDP DEEP POLISH — refinamiento exhaustivo
   =========================================================== */

/* === Tipografía global de la PDP === */
.bc_detail {
    color: #222;
    -webkit-font-smoothing: antialiased;
}
.bc_detail p, .bc_detail .description, .bc_detail .content-text {
    color: #222;
    line-height: 1.6;
    font-size: 16px;
    font-weight: 400;
}

/* === Section titles uniformes (Airbnb) === */
.bc_detail h2,
.bc_detail h3.text-22,
.bc_detail .gotrip-overview h3,
.bc_detail .description-title,
.bc_detail .ng-pdpInfo__title {
    font-size: 22px !important;
    font-weight: 600 !important;
    color: #222 !important;
    letter-spacing: -.4px !important;
    line-height: 1.2 !important;
    margin: 0 0 16px !important;
}
.bc_detail h5.text-16 {
    font-size: 17px !important;
    font-weight: 600 !important;
    color: #222 !important;
    letter-spacing: -.2px !important;
    margin-bottom: 14px !important;
}

/* === Stats bar (Airbnb highlights con cards finas) === */
.ng-pdpStats {
    background: transparent;
    border-radius: 0;
    border: none;
    padding: 0;
    margin-bottom: 24px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 10px;
}
.ng-pdpStats__item {
    padding: 12px 14px;
    border: 1px solid var(--ng-ab-border);
    border-right: 1px solid var(--ng-ab-border) !important;
    border-radius: var(--ng-ab-radius);
    background: #fff;
    box-shadow: var(--ng-ab-shadow-sm);
    display: flex;
    align-items: center;
    gap: 10px;
}
.ng-pdpStats__item:last-child { border-right: 1px solid var(--ng-ab-border) !important; }

/* MOBILE/TABLET: stats sin fondo / borde / sombra (forzado) */
@media (max-width: 991px) {
    .ng-pdpStats,
    body.frontend-page .ng-pdpStats,
    body.frontend-page .bc_detail .ng-pdpStats {
        background: transparent !important;
        background-color: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
    }
    .ng-pdpStats__item,
    .ng-pdpStats__item:last-child,
    .ng-pdpStats__item:hover,
    body.frontend-page .ng-pdpStats__item,
    body.frontend-page .bc_detail .ng-pdpStats__item,
    body.frontend-page .bc_detail .ng-pdpStats > .ng-pdpStats__item {
        background: transparent !important;
        background-color: transparent !important;
        border: 0 !important;
        border-right: 0 !important;
        border-radius: 0 !important;
        box-shadow: none !important;
        transform: none !important;
    }
}
.ng-pdpStats__icon {
    background: var(--ng-ab-bg-cream);
    border: none;
    width: 36px;
    height: 36px;
    border-radius: var(--ng-ab-radius-sm);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.ng-pdpStats__icon i { font-size: 18px; color: var(--ng-ab-text); }
.ng-pdpStats__value {
    font-size: 19px;
    font-weight: 700;
    letter-spacing: -.3px;
}
.ng-pdpStats__name {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .4px;
    font-weight: 600;
    color: #717171;
}

/* === Overview / About (sin borders extras) === */
.bc_detail .gotrip-overview {
    padding: 8px 0 24px;
    border: none;
    margin: 0;
}
.bc_detail .gotrip-overview .content-text {
    color: #222;
    font-size: 16px;
    line-height: 1.65;
}
.bc_detail .btn-showmore {
    color: #222 !important;
    text-decoration: underline !important;
    font-weight: 600 !important;
    text-underline-offset: 3px;
}

/* === Specs (sobre la embarcación) === */
.bc_detail .col-12.gotrip-overview + .col-12,
.bc_detail .list-disc {
    list-style: none !important;
    padding-left: 0 !important;
    margin: 0 !important;
}
.bc_detail .list-disc li {
    list-style: none !important;
    padding: 6px 0 !important;
    font-size: 15px !important;
    color: #222 !important;
    border-bottom: none;
    position: relative;
    padding-left: 28px !important;
}
.bc_detail .list-disc li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #f0f0f0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23222' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
    background-size: 60%;
    background-repeat: no-repeat;
    background-position: center;
}

/* === Amenities / Attributes — grid Airbnb-style sin borders === */
.bc_detail .g-attributes {
    padding: 16px 0;
    border-bottom: none;
}
.bc_detail .g-attributes h5 {
    font-size: 18px !important;
    font-weight: 600 !important;
    margin-bottom: 16px !important;
}
.bc_detail .g-attributes .row.list-disc {
    --bs-gutter-y: 0;
    --bs-gutter-x: 16px;
}
.bc_detail .g-attributes .item {
    padding: 8px 0 !important;
    display: flex !important;
    align-items: center;
    gap: 12px;
    font-size: 15px;
    color: #222;
    border-bottom: none;
}
.bc_detail .g-attributes .item i {
    width: 22px;
    height: 22px;
    font-size: 18px;
    color: #222;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.bc_detail .g-attributes .item img {
    width: 22px;
    height: 22px;
    object-fit: contain;
    flex-shrink: 0;
}

/* === FAQ — Airbnb accordion === */
.bc_detail .accordion .accordion-item {
    border: none !important;
    border-bottom: 1px solid #ebebeb !important;
    border-radius: 0 !important;
    background: transparent !important;
}
.bc_detail .accordion .accordion-item:last-child {
    border-bottom: none !important;
}
.bc_detail .accordion-button,
.bc_detail .accordion .btn {
    background: transparent !important;
    border: none !important;
    padding: 18px 0 !important;
    font-weight: 600 !important;
    font-size: 16px !important;
    color: #222 !important;
    box-shadow: none !important;
    width: 100% !important;
    text-align: left !important;
}
.bc_detail .accordion-button:not(.collapsed) {
    background: transparent !important;
    color: #222 !important;
    box-shadow: none !important;
}
.bc_detail .accordion-body {
    padding: 0 0 18px !important;
    color: #222 !important;
    font-size: 15px !important;
    line-height: 1.6 !important;
}

/* === Reviews section === */
.bc_detail .review-content,
.bc_detail .reviews-list {
    padding: 24px 0;
}
.bc_detail .review-list-item,
.bc_detail .review-item,
.bc_detail .review-card {
    padding: 20px 0 !important;
    border-bottom: 1px solid #ebebeb !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}
.bc_detail .review-list-item:last-child,
.bc_detail .review-item:last-child {
    border-bottom: none !important;
}
.bc_detail .review-author,
.bc_detail .review-name,
.bc_detail .review-list-item .name {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #222 !important;
}
.bc_detail .review-date,
.bc_detail .review-list-item .date {
    color: #717171 !important;
    font-size: 13px !important;
}
.bc_detail .review-text,
.bc_detail .review-list-item .review-text {
    color: #222 !important;
    font-size: 15px !important;
    line-height: 1.55 !important;
    margin-top: 8px !important;
}
.bc_detail .review-stars-wrapper {
    color: #222;
}

/* "Where you'll be" map section */
.bc_detail .g-location h3,
.bc_detail .map-area h3 {
    font-size: 22px !important;
    font-weight: 600 !important;
    letter-spacing: -.4px !important;
    margin-bottom: 8px !important;
}
.bc_detail .g-location .mb-20 {
    color: #717171 !important;
    font-size: 15px !important;
    margin-bottom: 16px !important;
}

/* === Map container refinement (fine border + soft shadow) === */
.bc_detail #map_content {
    border: 1px solid var(--ng-ab-border) !important;
    border-radius: var(--ng-ab-radius-md) !important;
    height: 460px !important;
    box-shadow: var(--ng-ab-shadow-sm) !important;
}

/* === Espaciado entre secciones — solo dividers principales === */
.bc_detail .border-top-light {
    border-color: #ebebeb !important;
    margin: 0 !important;
}
.bc_detail .container.mt-40.mb-40 {
    margin: 32px auto !important;
}
/* Quita borders innecesarios en bloques anidados */
.bc_detail .ng-pdpInfo__section {
    border-bottom: none !important;
    padding: 16px 0 !important;
}
.bc_detail .row.attribute-list .col-lg-6,
.bc_detail .row.attribute-list .col-md-6 {
    border-bottom: none !important;
}

/* === Botón "RESERVAR AHORA" en uppercase de Airbnb-style === */
.bc_detail .form-book button[type="submit"] {
    text-transform: none !important;
}
.bc_detail .bc_single_book .button.-dark-1::first-letter {
    text-transform: uppercase;
}

/* === Mobile: ajuste de stats y secciones === */
@media (max-width: 767px) {
    .ng-pdpStats {
        padding: 12px;
        margin-bottom: 14px;
    }
    .ng-pdpStats__value { font-size: 16px; }
    .ng-pdpStats__name { font-size: 11px; }
    .bc_detail h2,
    .bc_detail h3.text-22 { font-size: 19px !important; }
    .bc_detail .gotrip-overview { padding: 18px 0; }
    .bc_detail .gotrip-overview .content-text { font-size: 15px; }
    .bc_detail .g-attributes { padding: 18px 0; }
    .bc_detail .accordion-button { padding: 14px 0 !important; font-size: 15px !important; }
    .bc_detail #map_content { height: 320px !important; }
}

/* === FIN PDP DEEP POLISH === */


/* ===========================================================
   HOME REFINEMENT LAYER — finos borders + multi-layer shadows
   Aplica a TODAS las secciones del home/listings
   =========================================================== */

/* --- Cards de listing (tour, boat, location) — refinamiento elegante.
       NOTA: .ng-oCard tiene su propia shadow con color acento (var(--ng-acc))
       definida en blocks/offer-block/style1.blade.php — se excluye aquí --- */
body.ng-hero-page .ng-tourCard,
body:not(.bc_detail) .ng-tourCard {
    box-shadow: var(--ng-ab-shadow-card) !important;
    transition: transform .25s var(--ng-ab-ease), box-shadow .25s var(--ng-ab-ease-soft) !important;
}
body.ng-hero-page .ng-tourCard:hover,
body:not(.bc_detail) .ng-tourCard:hover {
    transform: translateY(-3px) !important;
    box-shadow: var(--ng-ab-shadow-md) !important;
}

/* --- Location cards: border ultra-fino + shadow on hover --- */
body.ng-hero-page .ng-locCard,
body:not(.bc_detail) .ng-locCard {
    border: 1px solid var(--ng-ab-border) !important;
    background: #fff !important;
    box-shadow: var(--ng-ab-shadow-sm) !important;
    transition: box-shadow .2s var(--ng-ab-ease), border-color .2s var(--ng-ab-ease) !important;
}
body.ng-hero-page .ng-locCard:hover,
body:not(.bc_detail) .ng-locCard:hover {
    box-shadow: var(--ng-ab-shadow-md) !important;
    border-color: var(--ng-ab-border-2) !important;
    transform: translateY(-1px) !important;
}

/* --- Botones del home (More, CTA, etc.) --- */
body.ng-hero-page .button.-md,
body:not(.bc_detail) .button.-md,
body.ng-hero-page .button.-blue-1.bg-blue-1-05,
body:not(.bc_detail) .button.-blue-1.bg-blue-1-05 {
    border-radius: var(--ng-ab-radius-pill) !important;
    transition: transform .15s var(--ng-ab-ease), box-shadow .2s var(--ng-ab-ease) !important;
    box-shadow: var(--ng-ab-shadow-sm) !important;
}
body.ng-hero-page .button.-md:hover,
body:not(.bc_detail) .button.-md:hover {
    box-shadow: var(--ng-ab-shadow-md) !important;
    transform: translateY(-1px) !important;
}

/* --- Smart-search dropdown del hero (refinado) --- */
.ng-smart-search__dropdown,
.ng-hero__suggest {
    border: 1px solid var(--ng-ab-border) !important;
    border-radius: var(--ng-ab-radius-md) !important;
    box-shadow: var(--ng-ab-shadow-md) !important;
    background: #fff !important;
}
.ng-smart-search__dropdown .item:hover,
.ng-hero__suggest a:hover {
    background: var(--ng-ab-bg-cream) !important;
}

/* --- Search bar pill (hero) --- */
.ng-hero__searchBar {
    box-shadow: var(--ng-ab-shadow-md) !important;
    border: 1px solid var(--ng-ab-border) !important;
}

/* --- Section title + badges del home --- */
body.ng-hero-page .sectionTitle__title,
body:not(.bc_detail) .sectionTitle__title {
    font-weight: 600 !important;
    letter-spacing: -.4px;
}

/* --- Header pill (ya existe, solo refino la sombra) --- */
@media (min-width: 1200px) {
    .header__container {
        box-shadow: var(--ng-ab-shadow-sm), 0 4px 14px -4px rgba(13, 27, 42, .08) !important;
        border: 1px solid var(--ng-ab-border) !important;
    }
}

/* --- Featured items (íconos + título) --- */
body.ng-hero-page .ng-featuredItem,
body:not(.bc_detail) .ng-featuredItem {
    border-radius: var(--ng-ab-radius-md) !important;
    transition: background .2s var(--ng-ab-ease), box-shadow .2s var(--ng-ab-ease) !important;
}
body.ng-hero-page .ng-featuredItem:hover,
body:not(.bc_detail) .ng-featuredItem:hover {
    background: var(--ng-ab-bg-cream) !important;
}

/* --- Cookie banner / Modal / Footer también con tokens --- */
.modal-content {
    border: 1px solid var(--ng-ab-border) !important;
    border-radius: var(--ng-ab-radius-lg) !important;
    box-shadow: var(--ng-ab-shadow-lg) !important;
}

/* --- FAB search button (mobile) --- */
.ng-fab-search {
    box-shadow: var(--ng-ab-shadow-md) !important;
    border-radius: var(--ng-ab-radius-pill) !important;
}

/* --- Image hover smooth en cards (Airbnb-style) --- */
body.ng-hero-page .ng-tourCard__bg,
body:not(.bc_detail) .ng-tourCard__bg {
    transition: transform .55s var(--ng-ab-ease) !important;
}
body.ng-hero-page .ng-tourCard:hover .ng-tourCard__bg,
body:not(.bc_detail) .ng-tourCard:hover .ng-tourCard__bg {
    transform: scale(1.05) !important;
}

/* --- Toggle pills, chips, badges con shadow sutil --- */
body.ng-hero-page .ng-hero__tabs--toggle,
body:not(.bc_detail) .ng-hero__tabs--toggle {
    box-shadow: var(--ng-ab-shadow-sm) !important;
    border: 1px solid var(--ng-ab-border) !important;
}

/* ===========================================================
   AUTO-HIDE HEADER ON SCROLL (todas las páginas)
   - Cerca del top: header en su posición original (absolute en home, fixed default en resto)
   - Scroll DOWN pasado el threshold: header se oculta (slide up)
   - Scroll UP pasado el threshold: header se pega arriba y queda visible
   - El FAB ng-fab-search (solo home) se baja para no superponerse con el header pinned
   El JS que aplica las clases vive en Layout/parts/header.blade.php
   =========================================================== */
.header.js-header {
    will-change: transform;
}
/* Pinned: header se desliza hacia abajo CON animación (entrada elegante) */
body.ng-header-pinned .header.js-header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    transform: translateY(0);
    z-index: 99 !important;
    transition: transform .35s cubic-bezier(.2,.7,.25,1);
}
/* Hidden: instantáneo (evita el "flash" del header al cruzar el threshold) */
body.ng-header-hidden .header.js-header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    transform: translateY(-110%);
    z-index: 999 !important;
    transition: none !important;
}
.ng-fab-search {
    transition: transform .35s cubic-bezier(.2,.7,.25,1),
                opacity .25s ease,
                box-shadow .2s ease,
                top .35s cubic-bezier(.2,.7,.25,1) !important;
}
body.ng-hero-page.ng-header-pinned .ng-fab-search.is-visible {
    top: 96px !important;
}
@media (max-width: 1199px) {
    body.ng-hero-page.ng-header-pinned .ng-fab-search.is-visible {
        top: 65px !important;
    }
}
/* === Mobile: FAB compacto, look del header === */
@media (max-width: 767px) {
    /* Base del FAB en mobile: blanco casi sólido (sin blur — evita bug de cards en swipe) */
    body.ng-hero-page .ng-fab-search {
        background: rgba(255, 255, 255, .96) !important;
        -webkit-backdrop-filter: none !important;
        backdrop-filter: none !important;
        border: 1px solid rgba(13, 27, 42, .06) !important;
        box-shadow:
            0 1px 2px rgba(13, 27, 42, .04),
            0 8px 24px -12px rgba(13, 27, 42, .16),
            inset 0 1px 0 rgba(255, 255, 255, .55) !important;
        padding: 6px 16px 6px 8px !important;
        font-size: 13px !important;
        gap: 8px !important;
        transition: top .35s cubic-bezier(.2,.7,.25,1),
                    transform .35s cubic-bezier(.2,.7,.25,1),
                    opacity .25s ease,
                    box-shadow .25s ease,
                    background .25s ease,
                    border-color .25s ease,
                    max-width .35s cubic-bezier(.2,.7,.25,1) !important;
    }
    /* Icono más compacto */
    body.ng-hero-page .ng-fab-search .ng-fab-search__icon {
        width: 26px !important;
        height: 26px !important;
        font-size: 12px !important;
    }
    /* Ocultar "tours, yates o destinos" — solo dejamos "Buscar" en TODOS los estados */
    body.ng-hero-page .ng-fab-search .ng-fab-search__text {
        display: none !important;
    }
    body.ng-hero-page .ng-fab-search .ng-fab-search__label strong {
        font-weight: 600 !important;
        font-size: 13px !important;
    }
    /* Cuando header pinned: el FAB se integra dentro del header pill — SIN fondo propio
       (usa el blur del header, evita doble capa de blur que se ve pesada) */
    body.ng-hero-page.ng-header-pinned .ng-fab-search.is-visible {
        top: 14px !important;
        max-width: calc(100vw - 140px) !important;
        z-index: 99 !important;
        background: transparent !important;
        -webkit-backdrop-filter: none !important;
        backdrop-filter: none !important;
        border: 0 !important;
        box-shadow: none !important;
    }
}

/* Featured items section: separar más del siguiente bloque */
.bc_wrap .bc-featured-item {
    margin-bottom: 90px !important;
}

/* Columna de resultados en listing /tour /boat: sin padding/margin */
.ng-listing-col {
    padding: 0 !important;
    margin: 0 !important;
}

/* --- FIN HOME REFINEMENT --- */

/* Newsletter mailchimp section oculta en todas las páginas */
section.mailchimp,
.mailchimp.bg-dark-2 {
    display: none !important;
}


/* =============================================================
   AIRBNB UNIFIED POLISH — homogenización top-tier del home/listings
   Capa final: backgrounds gris suave, radios consistentes,
   panel-feel en secciones, ritmo vertical uniforme.
   ============================================================= */

/* Tokens extra del sistema unificado */
:root {
    --ng-ab-bg-app:        #fbfbfb;   /* gris global muy suave (canvas) */
    --ng-ab-bg-panel:      #f6f7f9;   /* gris panel (sección alterna)  */
    --ng-ab-bg-panel-2:    #f3f4f7;   /* gris panel más marcado       */
    --ng-ab-bg-tinted:     #f0f2f5;   /* gris tinted (accent suave)   */
    --ng-ab-bg-warm:       #fbf9f6;   /* off-white cálido             */
    --ng-ab-section-pad-y: 56px;
    --ng-ab-section-pad-y-md: 40px;
    --ng-ab-section-pad-y-sm: 28px;
    --ng-ab-container-radius: 24px;
}

/* Canvas global suave (no afecta secciones con bg explícito) */
body.frontend-page:not(.bc_detail) {
    background: var(--ng-ab-bg-app);
}

/* --- Ritmo vertical homogéneo en home + listings --- */
body.ng-hero-page section.bc-featured-item,
body.ng-hero-page section.bc-list-locations,
body.ng-hero-page section.ng-offerSlider,
body.ng-hero-page section.boat-list-item,
body.ng-hero-page section.tour-list-item,
body.ng-hero-page section.bc-faq-lists,
body.ng-hero-page section.ng-feature-section,
body.ng-hero-page section.ng-whyUs {
    padding-top: var(--ng-ab-section-pad-y) !important;
    padding-bottom: var(--ng-ab-section-pad-y) !important;
}
@media (max-width: 991px) {
    body.ng-hero-page section.bc-featured-item,
    body.ng-hero-page section.bc-list-locations,
    body.ng-hero-page section.ng-offerSlider,
    body.ng-hero-page section.boat-list-item,
    body.ng-hero-page section.tour-list-item,
    body.ng-hero-page section.bc-faq-lists,
    body.ng-hero-page section.ng-feature-section,
    body.ng-hero-page section.ng-whyUs {
        padding-top: var(--ng-ab-section-pad-y-md) !important;
        padding-bottom: var(--ng-ab-section-pad-y-md) !important;
    }
}
@media (max-width: 575px) {
    body.ng-hero-page section.bc-featured-item,
    body.ng-hero-page section.bc-list-locations,
    body.ng-hero-page section.ng-offerSlider,
    body.ng-hero-page section.boat-list-item,
    body.ng-hero-page section.tour-list-item,
    body.ng-hero-page section.bc-faq-lists,
    body.ng-hero-page section.ng-feature-section,
    body.ng-hero-page section.ng-whyUs {
        padding-top: var(--ng-ab-section-pad-y-sm) !important;
        padding-bottom: var(--ng-ab-section-pad-y-sm) !important;
    }
}

/* --- Backgrounds alternados estilo Airbnb ---
   Los WRAPPERS (que añadimos en cada bloque) controlan el bg,
   no la <section> interna, para no romper bordes ni shadows. */
body.ng-hero-page .ng-offerSlider-wrap,
body.ng-hero-page .ng-feature-wrap,
body.ng-hero-page .ng-whyUs-wrap {
    background: transparent;
}

body.ng-hero-page .bc-list-locations-wrap {
    background: var(--ng-ab-bg-panel);
}

/* Sección de tours/boats listings: bg blanco + overlap sobre el hero
   Aplica en cualquier página donde existan estas secciones (listings /boat, /tour, etc.) */
section.boat-list-item,
section.tour-list-item {
    background: #fff;
    margin-top: -100px;
    position: relative;
    border-radius: 30px;
}
@media (max-width: 991px) {
    section.boat-list-item,
    section.tour-list-item {
        border-radius: 20px;
    }
}

/* Featured items: bg warm para diferenciarlo */
body.ng-hero-page .ng-feature-wrap {
    background: var(--ng-ab-bg-warm);
}

/* FAQ: gris panel */
body.ng-hero-page section.bc-faq-lists {
    background: var(--ng-ab-bg-panel);
}

/* Why Choose Us: blanco con plus */
body.ng-hero-page .ng-whyUs-wrap {
    background: #fff;
}

/* Separadores visuales sutiles entre wraps consecutivos */
body.ng-hero-page > * + .ng-offerSlider-wrap,
body.ng-hero-page > * + .bc-list-locations-wrap,
body.ng-hero-page > * + .ng-feature-wrap,
body.ng-hero-page > * + .ng-whyUs-wrap,
body.ng-hero-page > * + .ng-faqs-wrap {
    /* deja respirar entre secciones (el ritmo vertical lo da el padding) */
}

/* --- Section title homogéneo (todas las secciones) --- */
body.ng-hero-page .sectionTitle__title {
    font-size: clamp(20px, 2.4vw, 28px) !important;
    line-height: 1.2 !important;
    font-weight: 700 !important;
    letter-spacing: -.5px !important;
    color: var(--ng-ab-text) !important;
}
body.ng-hero-page .sectionTitle__text {
    font-size: 14.5px !important;
    color: var(--ng-ab-text-2) !important;
    margin-top: 6px !important;
    letter-spacing: -.1px !important;
}

/* Header de sección con menos espacio inferior y más respiración arriba */
body.ng-hero-page .sectionTitle.-md {
    margin-bottom: 8px;
}

/* --- Cards globales: radius 16px (más Airbnb) en home --- */
body.ng-hero-page .ng-tourCard,
body.ng-hero-page .ng-oCard {
    border-radius: var(--ng-ab-radius-lg) !important;
    overflow: hidden !important;
}
body.ng-hero-page .ng-tourCard__bg,
body.ng-hero-page .ng-oCard .ng-oCard__bg,
body.ng-hero-page .ng-oCard__bg {
    border-radius: 0 !important; /* dentro del card ya recortado */
}

/* --- Location cards: chip-style más limpio en home --- */
body.ng-hero-page .ng-locCard {
    border-radius: var(--ng-ab-radius-md) !important;
    background: #fff !important;
    border: 1px solid var(--ng-ab-border) !important;
}

/* --- "More" pill: estética Airbnb plana --- */
body.ng-hero-page .button.-md.-blue-1.bg-blue-1-05 {
    background: #fff !important;
    color: var(--ng-ab-text) !important;
    border: 1px solid var(--ng-ab-border-2) !important;
    border-radius: var(--ng-ab-radius-pill) !important;
    font-weight: 600 !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
}
body.ng-hero-page .button.-md.-blue-1.bg-blue-1-05:hover {
    background: var(--ng-ab-text) !important;
    color: #fff !important;
    border-color: var(--ng-ab-text) !important;
    transform: translateY(-1px) !important;
}
body.ng-hero-page .button.-md.-blue-1.bg-blue-1-05:hover .icon-arrow-top-right,
body.ng-hero-page .button.-md.-blue-1.bg-blue-1-05:hover * {
    color: #fff !important;
}

/* --- Featured items (íconos a la izquierda) -- panel-feel suave --- */
body.ng-hero-page .ng-feature-section .ng-feature-h {
    padding: 14px 16px !important;
    border-radius: var(--ng-ab-radius-md) !important;
    background: #fff !important;
    border: 1px solid var(--ng-ab-border) !important;
    transition: transform .2s var(--ng-ab-ease),
                box-shadow .2s var(--ng-ab-ease),
                border-color .2s var(--ng-ab-ease) !important;
}
body.ng-hero-page .ng-feature-section .ng-feature-h:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--ng-ab-shadow-card) !important;
    border-color: var(--ng-ab-border-2) !important;
}

/* --- FAQ block: cards estilo Airbnb --- */
body.ng-hero-page .ng-faqs .accordion__item,
body.ng-hero-page .ng-faqs .accordion-item {
    background: #fff !important;
    border: 1px solid var(--ng-ab-border) !important;
    border-radius: var(--ng-ab-radius-md) !important;
    margin-bottom: 10px !important;
    box-shadow: var(--ng-ab-shadow-sm);
    overflow: hidden;
}
body.ng-hero-page .ng-faqs .accordion__button,
body.ng-hero-page .ng-faqs .accordion-button {
    font-weight: 600 !important;
    letter-spacing: -.1px;
    color: var(--ng-ab-text) !important;
}

/* --- Why Choose Us cards: alinea con el resto del sistema --- */
body.ng-hero-page .ng-whyUs__card {
    border-radius: var(--ng-ab-radius-lg) !important;
    box-shadow: var(--ng-ab-shadow-card) !important;
}

/* --- Container width consistente y centered --- */
body.ng-hero-page .container {
    max-width: 1300px;
}

/* --- Microajuste: slider arrows redondeados consistentes --- */
body.ng-hero-page .ng-arrow,
body.ng-hero-page [class*="js-prev"],
body.ng-hero-page [class*="js-next"] {
    background: #fff !important;
    border: 1px solid var(--ng-ab-border-2) !important;
    box-shadow: var(--ng-ab-shadow-sm) !important;
    border-radius: var(--ng-ab-radius-pill) !important;
}

/* --- Footer top divider con tone gris suave --- */
.footer-style-1 { background: var(--ng-ab-bg-panel) !important; }

/* --- Eliminar separadores duros de header-margin en home --- */
body.ng-hero-page .header-margin { display: none !important; }
@media (max-width: 767px) {
    .header-margin { margin-top: 75px !important; }
}

/* --- Scroll-behavior smooth (UX premium) --- */
html { scroll-behavior: smooth; }

/* --- Selección de texto coherente --- */
::selection {
    background: rgba(13, 27, 42, .12);
    color: var(--ng-ab-text);
}

/* --- Mobile: padding lateral global más generoso para que respire --- */
@media (max-width: 575px) {
    body.ng-hero-page .container {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }
}

/* === FIN AIRBNB UNIFIED POLISH === */


/* =============================================================
   AIRBNB DEEP POLISH — FAQ + Footer + WhyChooseUs + secciones
   Refinamiento final, todo coherente, sensación "premium".
   ============================================================= */

/* ----- Tokens de pulido fino ----- */
:root {
    --ng-ab-fg:           #0d1b2a;
    --ng-ab-fg-2:         #2b3543;
    --ng-ab-muted:        #5e6675;
    --ng-ab-muted-2:      #8a93a3;
    --ng-ab-bg-faint:     #f5f6f8;
    --ng-ab-ring:         0 0 0 1px rgba(13,27,42,.06);
    --ng-ab-divider:      linear-gradient(to right,
                              transparent 0%,
                              rgba(13,27,42,.08) 20%,
                              rgba(13,27,42,.08) 80%,
                              transparent 100%);
}

/* ----- Eyebrow universal (label encima del título) ----- */
body.frontend-page .sectionTitle.-md::before {
    /* opcional: si quisiéramos agregarle eyebrow, lo definimos por sección */
}

/* Section title gap más respirado y CTA "More" alineado al final */
body.ng-hero-page section .row.y-gap-20.justify-between.items-end {
    align-items: flex-end !important;
}

/* =============================================================
   FAQ — Airbnb-style accordion premium
   ============================================================= */
body.frontend-page section.bc-faq-lists {
    background: linear-gradient(180deg, #fff 0%, var(--ng-ab-bg-faint) 100%) !important;
}
body.frontend-page section.bc-faq-lists .sectionTitle__title {
    font-size: clamp(22px, 2.4vw, 30px) !important;
    font-weight: 700 !important;
    letter-spacing: -.6px !important;
}
body.frontend-page section.bc-faq-lists .accordion {
    max-width: 820px;
    margin: 0 auto;
    --bs-gutter-y: 12px !important;
}
body.frontend-page section.bc-faq-lists .accordion__item {
    background: #fff !important;
    border: 1px solid var(--ng-ab-border) !important;
    border-radius: 16px !important;
    padding: 18px 22px !important;
    box-shadow: 0 1px 2px rgba(13,27,42,.04) !important;
    transition: box-shadow .2s var(--ng-ab-ease),
                border-color .2s var(--ng-ab-ease),
                transform .2s var(--ng-ab-ease) !important;
    overflow: hidden;
}
body.frontend-page section.bc-faq-lists .accordion__item:hover {
    box-shadow: 0 8px 24px -12px rgba(13,27,42,.14),
                0 2px 6px rgba(13,27,42,.04) !important;
    border-color: var(--ng-ab-border-2) !important;
}
body.frontend-page section.bc-faq-lists .accordion__item.is-active {
    box-shadow: 0 12px 36px -16px rgba(13,27,42,.20),
                0 3px 8px rgba(13,27,42,.06) !important;
    border-color: var(--ng-ab-border-2) !important;
}
body.frontend-page section.bc-faq-lists .accordion__button {
    cursor: pointer;
    gap: 16px;
}
/* Icono "+" / "-" rediseñado: círculo charcoal con plus blanco */
body.frontend-page section.bc-faq-lists .accordion__icon {
    width: 36px !important;
    height: 36px !important;
    background: var(--ng-ab-bg-faint) !important;
    border-radius: 50% !important;
    color: var(--ng-ab-fg) !important;
    margin-right: 0 !important;
    flex-shrink: 0;
    transition: background .2s var(--ng-ab-ease), color .2s var(--ng-ab-ease);
}
body.frontend-page section.bc-faq-lists .accordion__item.is-active .accordion__icon {
    background: var(--ng-ab-fg) !important;
    color: #fff !important;
}
body.frontend-page section.bc-faq-lists .accordion__button .button {
    color: var(--ng-ab-fg) !important;
    font-weight: 600 !important;
    font-size: 15.5px !important;
    line-height: 1.4 !important;
    letter-spacing: -.15px !important;
    padding: 0 !important;
    text-align: left;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}
body.frontend-page section.bc-faq-lists .accordion__content .pt-20 {
    padding-top: 14px !important;
    padding-left: 52px !important;
}
body.frontend-page section.bc-faq-lists .accordion__content p {
    color: var(--ng-ab-muted) !important;
    font-size: 14.5px !important;
    line-height: 1.65 !important;
    margin: 0;
}
@media (max-width: 575px) {
    body.frontend-page section.bc-faq-lists .accordion__item { padding: 14px 16px !important; border-radius: 14px !important; }
    body.frontend-page section.bc-faq-lists .accordion__button .button { font-size: 14.5px !important; }
    body.frontend-page section.bc-faq-lists .accordion__icon { width: 30px !important; height: 30px !important; }
    body.frontend-page section.bc-faq-lists .accordion__content .pt-20 { padding-left: 0 !important; padding-top: 10px !important; }
    body.frontend-page section.bc-faq-lists .accordion__content p { font-size: 13.5px !important; }
}

/* PDP FAQ variant (faq2.blade.php → div.bc-faq-lists.ng-faq-fixed):
   El theme aplica utility classes (px-20 py-20, pl-60, size-40) que generan
   demasiado padding. Aquí reducimos y unificamos con el look premium. */
/* Anular gutters de la row interna y el padding de los col-12 que envuelven
   cada FAQ item — esos generan doble padding sobre el px-20 del item. */
body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion.-simple {
    --bs-gutter-x: 0 !important;
    --bs-gutter-y: 10px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}
body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion.-simple > .col-12 {
    padding-left: 0 !important;
    padding-right: 0 !important;
}
body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion {
    --bs-gutter-y: 10px !important;
}
body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__item {
    padding: 14px 18px !important;
    border: 1px solid var(--ng-ab-border, rgba(13,27,42,.08)) !important;
    border-radius: 14px !important;
    background: #fff !important;
    box-shadow: 0 1px 2px rgba(13,27,42,.04) !important;
    transition: box-shadow .2s ease, border-color .2s ease !important;
}
body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__item:hover {
    box-shadow: 0 6px 18px -10px rgba(13,27,42,.12), 0 2px 6px rgba(13,27,42,.04) !important;
    border-color: var(--ng-ab-border-2, rgba(13,27,42,.14)) !important;
}
body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__item.is-active {
    box-shadow: 0 10px 28px -14px rgba(13,27,42,.18), 0 3px 8px rgba(13,27,42,.06) !important;
    border-color: var(--ng-ab-border-2, rgba(13,27,42,.14)) !important;
}
body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__button {
    gap: 12px !important;
    cursor: pointer;
}
body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__icon {
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    background: var(--ng-ab-bg-faint, #f5f6f8) !important;
    border-radius: 50% !important;
    color: var(--ng-ab-fg, #0d1b2a) !important;
    margin-right: 0 !important;
    flex-shrink: 0;
    transition: background .2s ease, color .2s ease;
}
body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__item.is-active .accordion__icon {
    background: var(--ng-ab-fg, #0d1b2a) !important;
    color: #fff !important;
}
body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__button .button {
    color: var(--ng-ab-fg, #0d1b2a) !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    line-height: 1.4 !important;
    letter-spacing: -.15px !important;
    padding: 0 !important;
    text-align: left;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}
body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__content .pt-20 {
    padding-top: 10px !important;
    padding-left: 44px !important;
}
body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__content p {
    color: var(--ng-ab-muted, #5a6675) !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    margin: 0;
}
@media (max-width: 575px) {
    body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__item { padding: 12px 14px !important; border-radius: 12px !important; }
    body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__button { gap: 10px !important; }
    body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__button .button { font-size: 14px !important; }
    body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__icon { width: 28px !important; height: 28px !important; min-width: 28px !important; }
    body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__content .pt-20 { padding-left: 0 !important; padding-top: 8px !important; }
    body.frontend-page .bc-faq-lists.ng-faq-fixed .accordion__content p { font-size: 13px !important; }
}

/* =============================================================
   WHY CHOOSE US — refinamiento icónico
   ============================================================= */
body.frontend-page .ng-whyUs {
    background: #fff !important;
}
body.frontend-page .ng-whyUs__head {
    padding-bottom: 36px !important;
}
body.frontend-page .ng-whyUs__title {
    /* hero-ish */
}
body.frontend-page .ng-whyUs__eyebrow {
    background: var(--ng-ab-bg-faint);
    color: var(--ng-ab-fg) !important;
    padding: 4px 12px;
    border-radius: 999px;
    font-size: 11px !important;
    letter-spacing: .14em !important;
    margin-bottom: 12px;
}
body.frontend-page .ng-whyUs__card {
    background: #fff !important;
    border: 1px solid var(--ng-ab-border) !important;
    border-radius: 20px !important;
    padding: 28px !important;
    gap: 14px !important;
    box-shadow: 0 1px 2px rgba(13,27,42,.04),
                0 8px 24px -16px rgba(13,27,42,.10) !important;
    transition: transform .25s var(--ng-ab-ease),
                box-shadow .25s var(--ng-ab-ease),
                border-color .25s var(--ng-ab-ease) !important;
}
body.frontend-page .ng-whyUs__card:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 2px 4px rgba(13,27,42,.05),
                0 18px 36px -16px rgba(13,27,42,.18) !important;
    border-color: var(--ng-ab-border-2) !important;
}
body.frontend-page .ng-whyUs__icon {
    width: 56px !important;
    height: 56px !important;
    border-radius: 14px !important;
    background: var(--ng-ab-bg-faint) !important;
    box-shadow: inset 0 0 0 1px var(--ng-ab-border);
}
body.frontend-page .ng-whyUs__icon img {
    width: 30px !important;
    height: 30px !important;
}
body.frontend-page .ng-whyUs__title {
    font-size: 17px !important;
    font-weight: 600 !important;
    color: var(--ng-ab-fg) !important;
    letter-spacing: -.2px !important;
    margin-top: 6px !important;
}
body.frontend-page .ng-whyUs__desc {
    font-size: 14px !important;
    color: var(--ng-ab-muted) !important;
    line-height: 1.6 !important;
}
@media (max-width: 575px) {
    body.frontend-page .ng-whyUs__card { padding: 20px !important; border-radius: 16px !important; }
    body.frontend-page .ng-whyUs__icon { width: 48px !important; height: 48px !important; border-radius: 12px !important; }
    body.frontend-page .ng-whyUs__icon img { width: 26px !important; height: 26px !important; }
    body.frontend-page .ng-whyUs__title { font-size: 15.5px !important; }
    body.frontend-page .ng-whyUs__desc { font-size: 13.5px !important; }
}

/* =============================================================
   FOOTER — pulido Airbnb premium
   ============================================================= */
.footer {
    background: var(--ng-ab-fg) !important;
    color: #fff !important;
    position: relative;
}
.footer.bg-blue-1,
.footer.bg-dark-1,
.footer.bg-dark-2,
.footer.bg-dark-3 {
    background: var(--ng-ab-fg) !important;
}
.footer .container { padding-top: 12px; padding-bottom: 12px; }

/* Top "newsletter" bar oculta (ya estaba), pero refuerzo */
section.mailchimp { display: none !important; }

/* Footer columnas */
.footer .footer_one {
    padding-top: 64px !important;
    padding-bottom: 48px !important;
}
.footer .footer_one h5,
.footer h5 {
    font-size: 13.5px !important;
    font-weight: 700 !important;
    color: #fff !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
    margin-bottom: 22px !important;
    opacity: .96;
}
.footer .footer_one a,
.footer .footer_one p,
.footer .footer_one li,
.footer .footer_one .menu li a {
    color: rgba(255,255,255,.72) !important;
    font-size: 14px !important;
    line-height: 1.95 !important;
    transition: color .15s var(--ng-ab-ease);
}
.footer .footer_one a:hover {
    color: #fff !important;
    text-decoration: none !important;
}
.footer .footer_one ul {
    list-style: none;
    padding-left: 0;
    margin: 0;
}
.footer .footer_one ul li {
    margin-bottom: 6px;
}

/* Divider sutil arriba del bottom-bar */
.footer .footer_middle_area {
    border-top: 1px solid rgba(255,255,255,.10) !important;
    padding-top: 22px !important;
    padding-bottom: 22px !important;
    margin-top: 0;
}
.footer .footer_middle_area,
.footer .footer_middle_area * {
    color: rgba(255,255,255,.70) !important;
    font-size: 13.5px !important;
}
.footer .footer_middle_area a:hover { color: #fff !important; }

/* Menú de footer (currency / lang switcher) */
.footer .menu-footer .menu__nav > li > a {
    color: rgba(255,255,255,.72) !important;
    font-size: 13.5px !important;
}
.footer .menu-footer .menu__nav > li:hover > a { color: #fff !important; }

/* Iconos sociales: chips redondos con halo */
.footer .footer_one .d-flex.x-gap-15 a,
.footer .footer_one [class*="icon-facebook"],
.footer .footer_one [class*="icon-instagram"],
.footer .footer_one [class*="icon-twitter"],
.footer .footer_one [class*="icon-linkedin"],
.footer .footer_one [class*="icon-youtube"] {
    transition: opacity .2s var(--ng-ab-ease), transform .2s var(--ng-ab-ease);
}

/* Mobile: footer más compacto */
@media (max-width: 991px) {
    .footer .footer_one { padding-top: 44px !important; padding-bottom: 28px !important; }
    .footer .footer_one h5 { margin-bottom: 14px !important; }
}
@media (max-width: 575px) {
    .footer .footer_middle_area {
        flex-direction: column;
        gap: 12px;
        text-align: center;
    }
    .footer .footer_middle_area .row.justify-between { justify-content: center !important; }
}

/* =============================================================
   FOOTER MOBILE — columnas como slider horizontal (patrón "destinos")
   Carrusel con scroll + snap + dots, reduce la altura a una columna.
   ============================================================= */
@media (max-width: 767px) {
    .footer .footer_one { padding-top: 32px !important; padding-bottom: 14px !important; }
    .footer .footer_one h5 { margin-bottom: 12px !important; }

    .footer .footer_one > .row {
        display: grid !important;
        grid-auto-flow: column !important;
        grid-auto-columns: 66% !important;          /* deja asomar la siguiente columna */
        gap: 0 !important;
        margin: 0 -12px !important;                  /* sangra hasta los bordes de pantalla */
        padding: 0 12px 12px !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        scroll-snap-type: x mandatory !important;
        scroll-behavior: smooth !important;
        -webkit-overflow-scrolling: touch !important;
        scrollbar-width: none !important;
    }
    .footer .footer_one > .row::-webkit-scrollbar { display: none !important; }

    /* cada columna = card con padding 12px */
    .footer .footer_one > .row > [class*="col-"] {
        width: auto !important;
        max-width: none !important;
        flex: 0 0 auto !important;
        padding: 12px !important;
        margin-right: 8px !important;
        border-radius: 12px !important;
        background: rgba(255,255,255,.04) !important;
        border: 1px solid rgba(255,255,255,.07) !important;
        scroll-snap-align: start !important;
    }
    .footer .footer_one > .row > [class*="col-"]:last-child { margin-right: 0 !important; }
}

/* En pantallas muy angostas, columnas un poco más anchas para legibilidad */
@media (max-width: 480px) {
    .footer .footer_one > .row { grid-auto-columns: 76% !important; }
}

/* Dots de paginación del slider del footer (mobile only) */
.ng-footerSlider__dots { display: none; }
@media (max-width: 767px) {
    .ng-footerSlider__dots {
        display: flex !important;
        justify-content: center;
        gap: 6px;
        margin-top: 4px;
        margin-bottom: 2px;
    }
    .ng-footerSlider__dot {
        width: 6px; height: 6px;
        border-radius: 50%;
        background: rgba(255,255,255,.25);
        transition: background .25s ease, transform .25s ease;
        cursor: pointer; border: 0; padding: 0;
    }
    .ng-footerSlider__dot.is-on {
        background: #fff;
        transform: scale(1.4);
    }
}

/* =============================================================
   SECCIONES — más homogeneidad: head row alineada, "More" derecha
   ============================================================= */
body.ng-hero-page section .container > .row.y-gap-20.justify-between.items-end,
body.ng-hero-page section .container > .row.y-gap-20.justify-between {
    margin-bottom: 6px;
}

/* La sección de Featured Items tiene el title centered, déjala así */
body.ng-hero-page section.ng-feature-section .row.justify-center.text-center {
    margin-bottom: 8px;
}

/* Refuerzo: todas las "card-grid" rows tienen gutter consistente */
body.ng-hero-page section .row.pt-40,
body.ng-hero-page section .row.pt-60 {
    padding-top: 28px !important;
}
@media (max-width: 575px) {
    body.ng-hero-page section .row.pt-40,
    body.ng-hero-page section .row.pt-60 {
        padding-top: 18px !important;
    }
}

@media (max-width: 767.98px) {
    html body .row.y-gap-30 {
        --bs-gutter-x: 12px !important;
        row-gap: 18px !important;
    }
}

/* =============================================================
   HEADER — refinamiento de pill cuando NO está en home
   (sin border-bottom para que no se duplique con el shadow del pill)
   ============================================================= */
body:not(.ng-hero-page) .header.js-header {
    background: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: saturate(180%) blur(14px);
    border-bottom: 0 !important;
    box-shadow: none !important;
}

/* Menú del header: peso 700 en desktop */
@media (min-width: 1200px) {
    .header .header-menu .menu li a {
        cursor: pointer;
        color: inherit;
        font-weight: 700;
    }
}

/* =============================================================
   GLOBAL TYPE SCALE refinamiento
   (NO color global: cada card / contexto define el suyo)
   ============================================================= */
body.frontend-page h1, body.frontend-page h2, body.frontend-page h3,
body.frontend-page h4, body.frontend-page h5, body.frontend-page h6 {
    letter-spacing: -.2px;
}

/* =============================================================
   BREADCRUMB — minimalista
   ============================================================= */
body.frontend-page .breadcrumb,
body.frontend-page .breadcrumbs,
body.frontend-page nav[aria-label*="breadcrumb"] {
    font-size: 13px;
    color: var(--ng-ab-muted-2);
}

/* =============================================================
   SLIDER / SWIPER pagination dots refinada
   ============================================================= */
body.frontend-page .swiper-pagination-bullet {
    background: var(--ng-ab-muted-2) !important;
    opacity: .35 !important;
    width: 6px !important; height: 6px !important;
    transition: opacity .2s ease, transform .2s ease;
}
body.frontend-page .swiper-pagination-bullet-active {
    background: var(--ng-ab-fg) !important;
    opacity: 1 !important;
    transform: scale(1.35);
}

/* =============================================================
   "DIVIDERS" entre secciones (subliminales)
   ============================================================= */
body.ng-hero-page > .bc-list-locations-wrap + .bc-list-locations-wrap::before,
body.ng-hero-page > .ng-feature-wrap + .ng-feature-wrap::before {
    /* placeholder por si hace falta */
}

/* === FIN AIRBNB DEEP POLISH === */


/* =============================================================
   TESTIMONIAL — multi-card grid premium (estilo Airbnb)
   Estructura: section-bg (foto con velo blanco) → header + grid 3
   ============================================================= */

/* Sección: foto de fondo con velo claro para que sea sutil */
body.frontend-page section.ng-testi {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    padding-top: 72px !important;
    padding-bottom: 64px !important;
}
body.frontend-page section.ng-testi .section-bg__item { z-index: 0; }
body.frontend-page section.ng-testi .section-bg__item img {
    object-fit: cover;
    width: 100%;
    height: 100%;
    opacity: .28;
}
body.frontend-page section.ng-testi::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg,
        rgba(251,251,251,.92) 0%,
        rgba(251,251,251,.84) 60%,
        rgba(251,251,251,.95) 100%);
    z-index: 0;
    pointer-events: none;
}
body.frontend-page section.ng-testi > .container { position: relative; z-index: 1; }

@media (max-width: 991px) {
    body.frontend-page section.ng-testi { padding-top: 52px !important; padding-bottom: 44px !important; }
}
@media (max-width: 575px) {
    body.frontend-page section.ng-testi { padding-top: 40px !important; padding-bottom: 32px !important; }
}

/* Header */
body.frontend-page .ng-testi__head { text-align: center; }
body.frontend-page .ng-testi__eyebrow {
    display: inline-block;
    background: rgba(13,27,42,.06);
    color: var(--ng-ab-fg);
    padding: 4px 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    margin-bottom: 10px;
}
body.frontend-page section.ng-testi .sectionTitle__title {
    color: var(--ng-ab-fg) !important;
    font-size: clamp(22px, 2.6vw, 32px) !important;
    font-weight: 700 !important;
    letter-spacing: -.5px !important;
}
body.frontend-page section.ng-testi .sectionTitle__text {
    color: var(--ng-ab-muted) !important;
    font-size: 14.5px !important;
    max-width: 580px;
    margin: 6px auto 0 !important;
}

/* === Card === */
.ng-tCard {
    height: 100%;
    background: #fff;
    border: 1px solid var(--ng-ab-border);
    border-radius: 18px;
    padding: 24px 22px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    box-shadow:
        0 1px 2px rgba(13,27,42,.04),
        0 12px 28px -16px rgba(13,27,42,.14);
    transition: transform .25s var(--ng-ab-ease),
                box-shadow .25s var(--ng-ab-ease),
                border-color .25s var(--ng-ab-ease);
}
.ng-tCard:hover {
    transform: translateY(-3px);
    box-shadow:
        0 2px 4px rgba(13,27,42,.05),
        0 20px 40px -18px rgba(13,27,42,.20);
    border-color: var(--ng-ab-border-2);
}

/* Stars row */
.ng-tCard__stars {
    display: inline-flex;
    gap: 2px;
    color: #e5e7eb;
}
.ng-tCard__star.is-on { color: #f5b50a; }

/* Heading (categoría / título del item) */
.ng-tCard__heading {
    font-size: 15px;
    font-weight: 600;
    color: var(--ng-ab-fg);
    margin: 0;
    line-height: 1.35;
    letter-spacing: -.15px;
}

/* Quote body */
.ng-tCard__quote {
    font-size: 14.5px;
    line-height: 1.6;
    color: var(--ng-ab-fg-2);
    margin: 0;
    flex: 1 1 auto;
    /* Clamp opcional para mantener altura uniforme */
    display: -webkit-box;
    -webkit-line-clamp: 6;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Author footer */
.ng-tCard__author {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 4px;
    padding-top: 16px;
    border-top: 1px solid var(--ng-ab-border);
}
.ng-tCard__avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    overflow: hidden;
    background: var(--ng-ab-bg-faint);
    color: var(--ng-ab-fg);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--ng-ab-border-2);
}
.ng-tCard__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.ng-tCard__initials {
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .04em;
}
.ng-tCard__meta {
    display: flex;
    flex-direction: column;
    min-width: 0;
}
.ng-tCard__name {
    font-size: 14px;
    font-weight: 600;
    color: var(--ng-ab-fg);
    line-height: 1.25;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ng-tCard__job {
    font-size: 12.5px;
    color: var(--ng-ab-muted);
    line-height: 1.25;
    margin-top: 2px;
}

/* === Nav (prev / pagination / next) === */
.ng-testi__nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    margin-top: 28px;
}
.ng-testi__navBtn {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: #fff;
    border: 1px solid var(--ng-ab-border-2);
    color: var(--ng-ab-fg);
    box-shadow: var(--ng-ab-shadow-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background .2s var(--ng-ab-ease),
                color .2s var(--ng-ab-ease),
                transform .2s var(--ng-ab-ease);
}
.ng-testi__navBtn:hover {
    background: var(--ng-ab-fg);
    color: #fff;
    transform: translateY(-1px);
}
body.frontend-page .ng-testi .js-testimonials-pag .pagination__item,
body.frontend-page .ng-testi .pagination.-dots > div,
body.frontend-page .ng-testi .swiper-pagination-bullet {
    background: rgba(13,27,42,.22) !important;
    opacity: 1 !important;
    width: 6px !important;
    height: 6px !important;
    margin: 0 4px !important;
    border-radius: 50%;
    transition: transform .2s var(--ng-ab-ease), background .2s var(--ng-ab-ease);
}
body.frontend-page .ng-testi .js-testimonials-pag .pagination__item.is-active,
body.frontend-page .ng-testi .pagination.-dots > div.is-active,
body.frontend-page .ng-testi .swiper-pagination-bullet-active {
    background: var(--ng-ab-fg) !important;
    transform: scale(1.4);
}

@media (max-width: 575px) {
    .ng-tCard { padding: 20px 18px; border-radius: 16px; gap: 12px; }
    .ng-tCard__heading { font-size: 14.5px; }
    .ng-tCard__quote { font-size: 14px; -webkit-line-clamp: 5; }
    .ng-tCard__avatar { width: 40px; height: 40px; }
    .ng-tCard__name { font-size: 13.5px; }
    .ng-tCard__job { font-size: 12px; }
    .ng-testi__navBtn { width: 38px; height: 38px; }
    .ng-testi__nav { gap: 10px; margin-top: 22px; }
}

/* Sección "trusted by" (logos) */
body.frontend-page section.ng-testi-trusted {
    background: var(--ng-ab-bg-app);
    padding-top: 36px !important;
    padding-bottom: 36px !important;
    border-top: 1px solid var(--ng-ab-border);
}
body.frontend-page .ng-testi-trusted__label {
    color: var(--ng-ab-muted-2);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .14em;
    font-weight: 600;
}
body.frontend-page .ng-testi-trusted__logo img {
    max-height: 36px;
    width: auto;
    opacity: .55;
    filter: grayscale(100%);
    transition: opacity .2s var(--ng-ab-ease), filter .2s var(--ng-ab-ease);
}
body.frontend-page .ng-testi-trusted__logo img:hover {
    opacity: 1;
    filter: grayscale(0%);
}

/* Flechas inline del slider (style_3) — chips overlay */
body.frontend-page .ng-testi__slider {
    position: relative;
    padding: 4px;
}
body.frontend-page .ng-testi__slider .section-slider-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: #fff;
    border: 1px solid var(--ng-ab-border-2);
    color: var(--ng-ab-fg);
    box-shadow: var(--ng-ab-shadow-md);
    z-index: 5;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background .2s var(--ng-ab-ease),
                color .2s var(--ng-ab-ease),
                transform .2s var(--ng-ab-ease);
}
body.frontend-page .ng-testi__slider .section-slider-nav.-prev {
    left: -22px;
}
body.frontend-page .ng-testi__slider .section-slider-nav.-next {
    right: -22px;
}
body.frontend-page .ng-testi__slider .section-slider-nav:hover {
    background: var(--ng-ab-fg);
    color: #fff;
    transform: translateY(-50%) scale(1.05);
}
@media (max-width: 575px) {
    body.frontend-page .ng-testi__slider .section-slider-nav { display: none !important; }
}

/* Bottom row: stats + trusted logos */
body.frontend-page .ng-testi__bottom {
    margin-top: 48px;
    padding-top: 32px;
    border-top: 1px solid var(--ng-ab-border-2);
}
body.frontend-page .ng-testi__stats {
    display: flex;
    gap: 32px;
    flex-wrap: wrap;
}
body.frontend-page .ng-testi__stat .ng-testi__statNum {
    font-size: clamp(26px, 2.4vw, 34px);
    font-weight: 700;
    color: var(--ng-ab-fg);
    line-height: 1.1;
    letter-spacing: -.5px;
}
body.frontend-page .ng-testi__stat .ng-testi__statLabel {
    font-size: 13.5px;
    color: var(--ng-ab-muted);
    margin-top: 4px;
}
body.frontend-page .ng-testi__statStars {
    display: inline-flex;
    gap: 2px;
    color: #f5b50a;
    margin-top: 6px;
}
body.frontend-page .ng-testi-trusted__logo img {
    max-height: 36px;
    width: auto;
    opacity: .55;
    filter: grayscale(100%);
    transition: opacity .2s var(--ng-ab-ease), filter .2s var(--ng-ab-ease);
}
body.frontend-page .ng-testi-trusted__logo img:hover {
    opacity: 1;
    filter: grayscale(0%);
}
@media (max-width: 575px) {
    body.frontend-page .ng-testi__bottom { margin-top: 36px; padding-top: 24px; }
    body.frontend-page .ng-testi__stats { gap: 24px; }
}

/* === FIN TESTIMONIAL polish === */


/* =============================================================
   PDP REVIEWS — mismo lenguaje premium que testimonial
   Sección .bc-reviews (boat/tour/hotel detail)
   ============================================================= */

body.frontend-page section.bc-reviews {
    background: transparent;
    margin-top: 16px;
}

/* Header título "Guest reviews" */
body.frontend-page section.bc-reviews h3.text-22 {
    font-size: clamp(20px, 2.2vw, 26px) !important;
    font-weight: 700 !important;
    color: var(--ng-ab-fg) !important;
    letter-spacing: -.4px !important;
}

/* === Score summary (col-xl-3) === */
body.frontend-page section.bc-reviews .col-xl-3 {
    position: relative;
}
body.frontend-page section.bc-reviews .col-xl-3 > .d-flex.items-center.mt-20 {
    margin-top: 18px !important;
}
/* Score chip grande */
body.frontend-page section.bc-reviews .flex-center.bg-blue-1.rounded-4.size-70 {
    background: var(--ng-ab-fg) !important;
    border-radius: 14px !important;
    width: 60px !important;
    height: 60px !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    letter-spacing: -.4px;
}
body.frontend-page section.bc-reviews .text-16.text-dark-1.fw-500 {
    font-size: 15px !important;
    color: var(--ng-ab-fg) !important;
    font-weight: 600 !important;
}
body.frontend-page section.bc-reviews .text-15.text-light-1 {
    color: var(--ng-ab-muted-2) !important;
}

/* Review summary bars */
body.frontend-page section.bc-reviews .review-sumary {
    margin-top: 8px;
}
body.frontend-page section.bc-reviews .review-sumary .item {
    padding: 4px 0;
}
body.frontend-page section.bc-reviews .review-sumary .text-15.fw-500 {
    color: var(--ng-ab-fg-2) !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
}
body.frontend-page section.bc-reviews .review-sumary .text-15.text-light-1 {
    color: var(--ng-ab-muted-2) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
}
body.frontend-page section.bc-reviews .progressBar {
    height: 6px !important;
    border-radius: 999px;
    overflow: hidden;
    background: transparent;
    margin-top: 6px !important;
}
body.frontend-page section.bc-reviews .progressBar__bg {
    background: var(--ng-ab-bg-faint) !important;
    border-radius: 999px;
}
body.frontend-page section.bc-reviews .progressBar__bar {
    background: var(--ng-ab-fg) !important;
    border-radius: 999px;
}

/* === Review list (col-xl-8) — cada item es una card === */
body.frontend-page section.bc-reviews .review-list .row.y-gap-40 {
    --bs-gutter-y: 16px !important;
}
body.frontend-page section.bc-reviews .review-item {
    background: #fff;
    border: 1px solid var(--ng-ab-border);
    border-radius: 18px;
    padding: 22px 24px;
    box-shadow:
        0 1px 2px rgba(13,27,42,.04),
        0 12px 28px -18px rgba(13,27,42,.12);
    transition: box-shadow .25s var(--ng-ab-ease),
                border-color .25s var(--ng-ab-ease),
                transform .25s var(--ng-ab-ease);
    margin: 0 !important;
}
body.frontend-page section.bc-reviews .review-item:hover {
    border-color: var(--ng-ab-border-2);
    box-shadow:
        0 2px 4px rgba(13,27,42,.05),
        0 18px 36px -16px rgba(13,27,42,.18);
}

/* Header del review: avatar + nombre + fecha */
body.frontend-page section.bc-reviews .review-item .row.x-gap-20.y-gap-20.items-center {
    --bs-gutter-x: 14px !important;
}
body.frontend-page section.bc-reviews .review-item .avatar {
    width: 44px !important;
    height: 44px !important;
    border-radius: 50%;
    object-fit: cover;
    border: 1px solid var(--ng-ab-border-2);
}
body.frontend-page section.bc-reviews .review-item .avatar-text {
    width: 44px !important;
    height: 44px !important;
    border-radius: 50%;
    background: var(--ng-ab-bg-faint);
    color: var(--ng-ab-fg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 14px;
    border: 1px solid var(--ng-ab-border-2);
}
body.frontend-page section.bc-reviews .review-item .fw-500.lh-15 {
    color: var(--ng-ab-fg) !important;
    font-weight: 600 !important;
    font-size: 14.5px !important;
}
body.frontend-page section.bc-reviews .review-item .text-14.text-light-1.lh-15 {
    color: var(--ng-ab-muted-2) !important;
    font-size: 12.5px !important;
    margin-top: 2px !important;
}

/* Título del review */
body.frontend-page section.bc-reviews .review-item h5.fw-500.text-blue-1 {
    color: var(--ng-ab-fg) !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    margin-top: 16px !important;
    letter-spacing: -.15px;
}

/* Contenido del review */
body.frontend-page section.bc-reviews .review-item p.text-15.text-dark-1 {
    color: var(--ng-ab-fg-2) !important;
    font-size: 14.5px !important;
    line-height: 1.6 !important;
    margin-top: 8px !important;
}

/* Estrellas */
body.frontend-page section.bc-reviews .review-item .review-star {
    margin-top: 10px;
    gap: 3px;
}
body.frontend-page section.bc-reviews .review-item .review-star.text-blue-1 li {
    color: #f5b50a !important;
    font-size: 13px;
}
body.frontend-page section.bc-reviews .review-item .review-star li .fa-star-o {
    color: #e5e7eb !important;
}

/* Fotos del review */
body.frontend-page section.bc-reviews .review-item .row.x-gap-30.y-gap-30.pt-20 img {
    border-radius: 12px !important;
    border: 1px solid var(--ng-ab-border);
    max-height: 120px;
    object-fit: cover;
    transition: transform .25s var(--ng-ab-ease);
}
body.frontend-page section.bc-reviews .review-item .row.x-gap-30.y-gap-30.pt-20 img:hover {
    transform: scale(1.02);
}

/* Pagination text + divider */
body.frontend-page section.bc-reviews .border-top-light {
    border-color: var(--ng-ab-border) !important;
}
body.frontend-page section.bc-reviews .review-pag-text {
    color: var(--ng-ab-muted-2) !important;
    font-size: 13.5px !important;
    margin-top: 12px;
}
body.frontend-page section.bc-reviews .bc-pagination {
    margin-top: 16px;
}

/* === Review form === */
body.frontend-page section.bc-reviews .review-form {
    background: var(--ng-ab-bg-faint);
    border: 1px solid var(--ng-ab-border);
    border-radius: 20px;
    padding: 28px;
    margin-top: 16px;
}
body.frontend-page section.bc-reviews .review-form h3 {
    color: var(--ng-ab-fg) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    letter-spacing: -.3px;
}
body.frontend-page section.bc-reviews .review-form .text-15.text-dark-1 {
    color: var(--ng-ab-muted) !important;
    font-size: 13.5px !important;
}
body.frontend-page section.bc-reviews .review-form .form-input input,
body.frontend-page section.bc-reviews .review-form .form-input textarea {
    background: #fff !important;
    border: 1px solid var(--ng-ab-border-2) !important;
    border-radius: 12px !important;
    padding: 14px 16px !important;
    font-size: 14.5px !important;
    color: var(--ng-ab-fg) !important;
    transition: border-color .2s var(--ng-ab-ease), box-shadow .2s var(--ng-ab-ease);
}
body.frontend-page section.bc-reviews .review-form .form-input input:focus,
body.frontend-page section.bc-reviews .review-form .form-input textarea:focus {
    border-color: var(--ng-ab-fg) !important;
    box-shadow: 0 0 0 3px rgba(13,27,42,.08) !important;
    outline: none !important;
}
body.frontend-page section.bc-reviews .review-form .form-input label {
    color: var(--ng-ab-muted-2) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
}
body.frontend-page section.bc-reviews .review-form .item .text-15.fw-500 {
    color: var(--ng-ab-fg) !important;
    font-size: 13.5px !important;
}
body.frontend-page section.bc-reviews .review-form .rates i {
    font-size: 14px;
    transition: color .15s var(--ng-ab-ease), transform .15s var(--ng-ab-ease);
    cursor: pointer;
}
body.frontend-page section.bc-reviews .review-form .rates i.grey { color: #e5e7eb; }
body.frontend-page section.bc-reviews .review-form .rates i:hover { transform: scale(1.2); }
body.frontend-page section.bc-reviews .review-form button[type="submit"] {
    border-radius: 999px !important;
    background: var(--ng-ab-fg) !important;
    color: #fff !important;
    padding: 14px 24px !important;
    font-weight: 600 !important;
    transition: transform .15s var(--ng-ab-ease), box-shadow .2s var(--ng-ab-ease);
    border: 0 !important;
}
body.frontend-page section.bc-reviews .review-form button[type="submit"]:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 24px -10px rgba(13,27,42,.30);
}

body.frontend-page section.bc-reviews .review-message {
    background: var(--ng-ab-bg-faint);
    border: 1px solid var(--ng-ab-border);
    border-radius: 14px;
    padding: 18px 22px;
    color: var(--ng-ab-fg-2);
    font-size: 14.5px;
    text-align: center;
}
body.frontend-page section.bc-reviews .review-message a {
    color: var(--ng-ab-fg);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 3px;
}

@media (max-width: 575px) {
    body.frontend-page section.bc-reviews .review-item { padding: 18px 16px; border-radius: 14px; }
    body.frontend-page section.bc-reviews .review-form { padding: 20px; border-radius: 16px; }
    body.frontend-page section.bc-reviews .review-item .avatar,
    body.frontend-page section.bc-reviews .review-item .avatar-text { width: 40px !important; height: 40px !important; }
}

/* === FIN PDP REVIEWS polish === */


/* =============================================================
   PDP AIRBNB DEEP POLISH — todo el detalle (boat + tour)
   Mismo lenguaje del home, aplicado a TODAS las secciones.
   ============================================================= */

/* Canvas suave (extiende a PDP) */
body.frontend-page {
    background: var(--ng-ab-bg-app);
}

/* Container width consistente */
body.frontend-page .bc_detail .container,
body.frontend-page .ng-pdp .container {
    max-width: 1300px;
}

/* === Page header (título + share) === */
body.frontend-page .ng-pdp__header {
    padding-top: 18px;
    padding-bottom: 14px;
}
body.frontend-page .ng-pdpHead {
    gap: 16px;
}
@media (max-width: 991px) {
    body.frontend-page .ng-pdp__header {
        padding-top: 10px !important;
        padding-bottom: 0px !important;
        background: white;
        border-radius: 20px;
        margin-top: -20px;
        position: relative;
        z-index: 99;
    }
}
body.frontend-page .ng-pdpHead__title {
    font-size: clamp(22px, 2.5vw, 32px) !important;
    font-weight: 700 !important;
    letter-spacing: -.6px !important;
    color: var(--ng-ab-fg) !important;
    line-height: 1.2 !important;
    margin: 0 !important;
}
body.frontend-page .ng-pdpHead__meta {
    font-size: 13.5px;
    color: var(--ng-ab-muted) !important;
    margin-top: 6px;
}
body.frontend-page .ng-pdpHead__rating {
    color: var(--ng-ab-fg) !important;
    font-weight: 600;
}
body.frontend-page .ng-pdpHead__reviews,
body.frontend-page .ng-pdpHead__loc {
    color: var(--ng-ab-fg) !important;
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-color: rgba(13,27,42,.25);
}
body.frontend-page .ng-pdpHead__reviews:hover,
body.frontend-page .ng-pdpHead__loc:hover {
    text-decoration-color: var(--ng-ab-fg);
}
body.frontend-page .ng-pdpHead__btn {
    background: transparent;
    border: 0;
    color: var(--ng-ab-fg);
    padding: 8px 12px;
    border-radius: 999px;
    font-weight: 600;
    font-size: 13.5px;
    transition: background .15s var(--ng-ab-ease);
}
body.frontend-page .ng-pdpHead__btn:hover {
    background: var(--ng-ab-bg-faint);
}

/* === ng-pdpInfo (About / Specs / Attributes) — section cards === */
body.frontend-page .ng-pdpInfo {
    padding-top: 28px !important;
}
body.frontend-page .ng-pdpInfo__section {
    padding: 28px 0 !important;
    border-bottom: 1px solid var(--ng-ab-border) !important;
}
body.frontend-page .ng-pdpInfo__section:first-child { padding-top: 0 !important; }
body.frontend-page .ng-pdpInfo__section:last-child { border-bottom: none !important; }
body.frontend-page .ng-pdpInfo__title {
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--ng-ab-fg) !important;
    letter-spacing: -.3px !important;
    margin-bottom: 16px !important;
}
body.frontend-page .ng-pdpInfo__content {
    font-size: 15px !important;
    line-height: 1.65 !important;
    color: var(--ng-ab-fg-2) !important;
}
body.frontend-page .ng-pdpInfo__content p { color: var(--ng-ab-fg-2) !important; }

/* g-attributes (Specs/atributos en grid) */
body.frontend-page .ng-pdpInfo .g-attributes h5 {
    color: var(--ng-ab-fg) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
    opacity: .8;
    margin-bottom: 12px !important;
}
body.frontend-page .ng-pdpInfo .g-attributes .item {
    border-bottom: 1px solid var(--ng-ab-border) !important;
    padding: 12px 0 !important;
    color: var(--ng-ab-fg-2);
    font-size: 14px;
}
body.frontend-page .ng-pdpInfo .g-attributes .item i {
    color: var(--ng-ab-fg) !important;
    opacity: .65;
}

/* === Stats bar — sin wrapper, chips individuales === */
body.frontend-page .ng-pdpStats { background: transparent !important; border: 0 !important; padding: 12px 0 0 !important; box-shadow: none !important; }

/* === "Things you should know" section — flat (sin card wrapper) === */
body.frontend-page section.ab-know-section {
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 32px 0 !important;
    margin-top: 0 !important;
    box-shadow: none !important;
}
body.frontend-page section.ab-know-section > .container {
    /* padding-left: var(--bs-gutter-x, 24px) !important; */
    /* padding-right: var(--bs-gutter-x, 24px) !important; */
}
body.frontend-page .ab-section-title {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--ng-ab-fg) !important;
    letter-spacing: -.4px !important;
    margin-bottom: 20px !important;
}
body.frontend-page .ab-know-h {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: var(--ng-ab-fg) !important;
    letter-spacing: -.1px !important;
    margin-bottom: 12px !important;
}
body.frontend-page .ab-know-list li {
    color: var(--ng-ab-fg-2) !important;
    font-size: 14px !important;
    border-bottom: 1px solid var(--ng-ab-border) !important;
    padding: 10px 0;
}
@media (max-width: 575px) {
    body.frontend-page section.ab-know-section { padding: 20px !important; border-radius: 16px; }
    body.frontend-page .ab-section-title { font-size: 18px !important; }
}

/* === Map section — wrapper card === */
body.frontend-page .bc_detail #map_content,
body.frontend-page .bc_detail [id^="map_"] {
    border-radius: 20px !important;
    overflow: hidden !important;
    border: 1px solid var(--ng-ab-border);
    box-shadow:
        0 1px 2px rgba(13,27,42,.04),
        0 16px 32px -18px rgba(13,27,42,.14);
}

/* === PDP FAQ (div.bc-faq-lists con accordion) === */
body.frontend-page .bc_detail .bc-faq-lists,
body.frontend-page .ng-pdp .bc-faq-lists {
    background: #fff;
    border: 1px solid var(--ng-ab-border);
    border-radius: 20px;
    padding: 32px !important;
    margin: 0;
    box-shadow:
        0 1px 2px rgba(13,27,42,.04),
        0 12px 28px -18px rgba(13,27,42,.10);
}
body.frontend-page .bc_detail .bc-faq-lists h2.text-22,
body.frontend-page .ng-pdp .bc-faq-lists h2.text-22 {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--ng-ab-fg) !important;
    letter-spacing: -.4px !important;
    line-height: 1.25 !important;
    margin: 0 !important;
}
body.frontend-page .bc_detail .bc-faq-lists .accordion .accordion__item,
body.frontend-page .ng-pdp .bc-faq-lists .accordion .accordion__item {
    background: #fff !important;
    border: 1px solid var(--ng-ab-border) !important;
    border-radius: 14px !important;
    padding: 16px 20px !important;
    box-shadow: 0 1px 2px rgba(13,27,42,.04) !important;
    transition: box-shadow .2s var(--ng-ab-ease),
                border-color .2s var(--ng-ab-ease);
    overflow: hidden;
}
body.frontend-page .bc_detail .bc-faq-lists .accordion__item:hover,
body.frontend-page .ng-pdp .bc-faq-lists .accordion__item:hover {
    box-shadow: 0 8px 24px -12px rgba(13,27,42,.14),
                0 2px 6px rgba(13,27,42,.04) !important;
    border-color: var(--ng-ab-border-2) !important;
}
body.frontend-page .bc_detail .bc-faq-lists .accordion__icon,
body.frontend-page .ng-pdp .bc-faq-lists .accordion__icon {
    width: 32px !important;
    height: 32px !important;
    background: var(--ng-ab-bg-faint) !important;
    border-radius: 50% !important;
    color: var(--ng-ab-fg) !important;
    margin-right: 14px !important;
    flex-shrink: 0;
}
body.frontend-page .bc_detail .bc-faq-lists .accordion__item.is-active .accordion__icon,
body.frontend-page .ng-pdp .bc-faq-lists .accordion__item.is-active .accordion__icon {
    background: var(--ng-ab-fg) !important;
    color: #fff !important;
}
body.frontend-page .bc_detail .bc-faq-lists .accordion__button .button,
body.frontend-page .ng-pdp .bc-faq-lists .accordion__button .button {
    color: var(--ng-ab-fg) !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    line-height: 1.4 !important;
    letter-spacing: -.1px !important;
    padding: 0 !important;
    text-align: left;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}
body.frontend-page .bc_detail .bc-faq-lists .accordion__content .pt-20,
body.frontend-page .ng-pdp .bc-faq-lists .accordion__content .pt-20 {
    padding-top: 12px !important;
    padding-left: 46px !important;
}
body.frontend-page .bc_detail .bc-faq-lists .accordion__content p,
body.frontend-page .ng-pdp .bc-faq-lists .accordion__content p {
    color: var(--ng-ab-muted) !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    margin: 0;
}
@media (max-width: 575px) {
    body.frontend-page .bc_detail .bc-faq-lists,
    body.frontend-page .ng-pdp .bc-faq-lists { padding: 20px !important; border-radius: 16px; }
    body.frontend-page .bc_detail .bc-faq-lists .accordion__item,
    body.frontend-page .ng-pdp .bc-faq-lists .accordion__item { padding: 12px 14px !important; }
    body.frontend-page .bc_detail .bc-faq-lists .accordion__content .pt-20,
    body.frontend-page .ng-pdp .bc-faq-lists .accordion__content .pt-20 { padding-left: 0 !important; }
}

/* === Border-top-light dividers en PDP: más sutiles === */
body.frontend-page .bc_detail .border-top-light,
body.frontend-page .ng-pdp .border-top-light {
    border-top-color: var(--ng-ab-border) !important;
}

/* === Mobile booking inline: form completo debajo del date-strip === */
.ng-pdp .ng-pdp__book-backdrop,
.ng-pdp .ng-pdp__book-close { display: none !important; }
@media (max-width: 991px) {
    /* Aside vacío (el form fue movido por JS) → ocultarlo */
    body.ng-pdp__book-inline .ng-pdp__aside { display: none !important; }
    /* .bc_single_book inline: card limpia full-width */
    body.ng-pdp__book-inline .bc_single_book {
        width: 100% !important;
        margin: 16px 0 !important;
    }
    body.ng-pdp__book-inline .bc_single_book .owner-info {
        padding: 12px !important;
        margin-bottom: 12px !important;
        border-radius: 12px !important;
    }
    body.ng-pdp__book-inline #bc_boat_book_app {
        padding: 18px !important;
        border-radius: 16px !important;
        border: 1px solid rgba(13,27,42,.08) !important;
        background: #fff !important;
        box-shadow: 0 4px 12px -4px rgba(13,27,42,.10) !important;
        width: 100% !important;
        box-sizing: border-box;
    }
}
/* === Mobile bottom-sheet (cuando body.ng-pdp__book-open) ===
   El form ya está movido inline por JS; cuando se abre el pop, lo posicionamos
   fixed como sheet desde abajo. Aplica a .bc_single_book directamente — funciona
   independientemente de dónde esté en el DOM. */
@media (max-width: 991px) {
    body.ng-pdp__book-open {
        overflow: hidden !important;
        height: 100vh !important;
    }
    body.ng-pdp__book-open .ng-pdp__book-backdrop {
        display: block !important;
        position: fixed;
        inset: 0;
        background: rgba(13, 27, 42, .45);
        z-index: 9998;
        backdrop-filter: blur(4px);
        -webkit-backdrop-filter: blur(4px);
        animation: ngBookFade .2s ease;
        touch-action: none;
    }
    body.ng-pdp__book-open .bc_single_book {
        position: fixed !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        top: auto !important;
        height: auto !important;
        max-height: calc(100vh - 56px) !important;
        max-height: calc(100dvh - 56px) !important;
        z-index: 9999 !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch;
        touch-action: auto !important;
        background: #ffffff !important;
        border-radius: 18px 18px 0 0 !important;
        box-shadow: 0 -8px 28px -12px rgba(13, 27, 42, .25) !important;
        padding: 20px 16px calc(20px + env(safe-area-inset-bottom, 0px)) 16px !important;
        margin: 0 !important;
        width: 100vw !important;
        animation: ngBookSheet .28s cubic-bezier(0.16, 1, 0.3, 1);
        display: block !important;
    }
    /* Drag-indicator (handle) arriba del sheet */
    body.ng-pdp__book-open .bc_single_book::before {
        content: '';
        position: sticky;
        top: 0;
        left: 50%;
        display: block;
        width: 40px;
        height: 4px;
        margin: -8px auto 14px;
        background: rgba(13,27,42,.18);
        border-radius: 999px;
        pointer-events: none;
    }
    body.ng-pdp__book-open .bc_single_book #bc_boat_book_app {
        padding: 18px !important;
        box-shadow: none !important;
        border: 0 !important;
        margin: 0 !important;
    }
    body.ng-pdp__book-open .bc_single_book > .ng-pdp__book-close {
        display: flex !important;
        align-items: center;
        justify-content: center;
        position: sticky;
        top: 4px;
        margin-left: auto;
        margin-bottom: 4px;
        z-index: 10;
        width: 34px;
        height: 34px;
        border-radius: 50%;
        background: rgba(13,27,42,.06);
        color: #0d1b2a;
        border: 0;
        cursor: pointer;
        padding: 0;
        float: right;
    }
    body.ng-pdp__book-open .bc-more-book-mobile { display: none !important; }
}
@keyframes ngBookFade { from { opacity: 0; } to { opacity: 1; } }
/* === Daterangepicker: z-index alto cuando hay sheet === */
.daterangepicker { z-index: 10002 !important; }
/* Bottom-sheet iOS-style scopeado al modal de booking (no afecta otras pages) */
@media (max-width: 991px) {
    body.ng-pdp__book-inline .daterangepicker {
        position: fixed !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        top: 80px !important;
        transform: none !important;
        margin: 0 !important;
        width: 100vw !important;
        max-width: 100vw !important;
        max-height: none !important;
        height: auto !important;
        border-radius: 18px 18px 0 0 !important;
        border: 0 !important;
        box-shadow: 0 -8px 28px -12px rgba(13,27,42,.30) !important;
        background: #fff !important;
        padding: 22px 16px calc(80px + env(safe-area-inset-bottom, 0px)) 16px !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch;
        touch-action: auto !important;
        animation: ngBookSheet .28s cubic-bezier(0.16, 1, 0.3, 1);
    }
    /* Drag-indicator (handle) arriba del sheet */
    body.ng-pdp__book-inline .daterangepicker::before {
        content: '';
        display: block !important;
        position: absolute;
        top: 8px;
        left: 50%;
        width: 40px;
        height: 4px;
        margin-left: -20px;
        background: rgba(13,27,42,.18);
        border-radius: 999px;
        pointer-events: none;
        opacity: 1 !important;
    }
    body.ng-pdp__book-inline .daterangepicker::after { display: none !important; }
    /* Solo 1 calendario visible */
    body.ng-pdp__book-inline .daterangepicker.show-calendar .drp-calendar.right {
        display: none !important;
    }
    body.ng-pdp__book-inline .daterangepicker .drp-calendar {
        max-width: 100% !important;
        width: 100% !important;
        padding: 0 !important;
        float: none !important;
    }
    body.ng-pdp__book-inline .daterangepicker .drp-calendar.left {
        clear: none !important;
        margin: 0 !important;
        border-left: 0 !important;
    }
    /* Ranges sidebar oculta */
    body.ng-pdp__book-inline .daterangepicker .ranges { display: none !important; }
    /* Mes header: grande y prominente */
    body.ng-pdp__book-inline .daterangepicker .month {
        font-size: 17px !important;
        font-weight: 700 !important;
        color: #0d1b2a !important;
        line-height: 44px !important;
    }
    /* Botones prev/next month: círculos tappeables */
    body.ng-pdp__book-inline .daterangepicker .calendar-table th.prev,
    body.ng-pdp__book-inline .daterangepicker .calendar-table th.next {
        width: 40px !important;
        height: 40px !important;
        background: rgba(13,27,42,.05) !important;
        border-radius: 50% !important;
        cursor: pointer;
    }
    body.ng-pdp__book-inline .daterangepicker .calendar-table th.prev:hover,
    body.ng-pdp__book-inline .daterangepicker .calendar-table th.next:hover {
        background: rgba(13,27,42,.10) !important;
    }
    /* Tabla: convertir tbody en grid 7×6 con celdas cuadradas centradas */
    body.ng-pdp__book-inline .daterangepicker .calendar-table {
        padding: 0 !important;
        border: 0 !important;
        background: transparent !important;
    }
    body.ng-pdp__book-inline .daterangepicker .calendar-table table {
        width: 100% !important;
        margin-top: 6px !important;
        border-collapse: separate !important;
        border-spacing: 0 !important;
    }
    /* Thead día-de-semana en grid también para alinear perfecto con tbody */
    body.ng-pdp__book-inline .daterangepicker .calendar-table thead tr:last-child {
        display: grid !important;
        grid-template-columns: repeat(7, 1fr) !important;
    }
    body.ng-pdp__book-inline .daterangepicker .calendar-table thead tr:last-child th {
        font-size: 11px !important;
        font-weight: 600 !important;
        color: #5a6675 !important;
        text-transform: uppercase;
        letter-spacing: .05em;
        height: 34px !important;
        line-height: 1 !important;
        background: transparent !important;
        border: 0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }
    /* tbody: grid layout para celdas cuadradas */
    body.ng-pdp__book-inline .daterangepicker .calendar-table tbody {
        display: grid !important;
        grid-template-columns: repeat(7, 1fr) !important;
        gap: 4px 0 !important;
    }
    body.ng-pdp__book-inline .daterangepicker .calendar-table tbody tr {
        display: contents !important;
    }
    body.ng-pdp__book-inline .daterangepicker td {
        width: 100% !important;
        height: auto !important;
        aspect-ratio: 1 / 1 !important;
        padding: 0 !important;
        font-size: 15px !important;
        line-height: 1 !important;
        border: 0 !important;
        background: transparent !important;
        color: #0d1b2a !important;
        font-weight: 500 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        border-radius: 50% !important;
        position: relative;
    }
    body.ng-pdp__book-inline .daterangepicker td.available { cursor: pointer; }
    body.ng-pdp__book-inline .daterangepicker td.available:hover {
        background: rgba(13,27,42,.08) !important;
    }
    body.ng-pdp__book-inline .daterangepicker td.off,
    body.ng-pdp__book-inline .daterangepicker td.off.disabled,
    body.ng-pdp__book-inline .daterangepicker td.disabled {
        color: rgba(13,27,42,.25) !important;
        background: transparent !important;
        cursor: default !important;
    }
    body.ng-pdp__book-inline .daterangepicker td.today {
        font-weight: 700 !important;
        color: #0d1b2a !important;
        box-shadow: inset 0 0 0 2px #0d1b2a !important;
    }
    body.ng-pdp__book-inline .daterangepicker td.active,
    body.ng-pdp__book-inline .daterangepicker td.start-date,
    body.ng-pdp__book-inline .daterangepicker td.end-date {
        background: #0d1b2a !important;
        color: #fff !important;
        font-weight: 700 !important;
        box-shadow: none !important;
    }
    body.ng-pdp__book-inline .daterangepicker td.in-range {
        background: rgba(13,27,42,.08) !important;
        color: #0d1b2a !important;
        border-radius: 0 !important;
    }
    /* Botonera Apply/Cancel: pegada al fondo del sheet */
    body.ng-pdp__book-inline .daterangepicker .drp-buttons {
        position: fixed !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        background: #fff !important;
        border-top: 1px solid rgba(13,27,42,.08) !important;
        padding: 12px 16px calc(12px + env(safe-area-inset-bottom, 0px)) !important;
        display: flex !important;
        gap: 10px !important;
        align-items: center !important;
        justify-content: flex-end !important;
        z-index: 5;
        margin: 0 !important;
    }
    body.ng-pdp__book-inline .daterangepicker .drp-buttons .drp-selected {
        flex: 1 1 auto;
        font-size: 12px !important;
        color: #5a6675 !important;
        padding: 0 !important;
        line-height: 1.3 !important;
    }
    body.ng-pdp__book-inline .daterangepicker .drp-buttons .btn {
        font-size: 14px !important;
        font-weight: 600 !important;
        padding: 11px 20px !important;
        border-radius: 999px !important;
        line-height: 1 !important;
        border: 0 !important;
        cursor: pointer;
    }
    body.ng-pdp__book-inline .daterangepicker .drp-buttons .btn.btn-default,
    body.ng-pdp__book-inline .daterangepicker .drp-buttons .cancelBtn {
        background: rgba(13,27,42,.06) !important;
        color: #0d1b2a !important;
    }
    body.ng-pdp__book-inline .daterangepicker .drp-buttons .btn.btn-primary,
    body.ng-pdp__book-inline .daterangepicker .drp-buttons .applyBtn {
        background: #0d1b2a !important;
        color: #fff !important;
    }
}
@keyframes ngBookFade {
    from { opacity: 0; }
    to { opacity: 1; }
}
@keyframes ngBookSlide {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}
@keyframes ngBookSheet {
    from { transform: translateY(100%); }
    to { transform: translateY(0); }
}

/* === Sticky bottom mobile book bar — simple 1-row layout === */
body.frontend-page .bc-more-book-mobile {
    background: rgba(255,255,255,.97) !important;
    backdrop-filter: saturate(180%) blur(14px);
    -webkit-backdrop-filter: saturate(180%) blur(14px);
    border-top: 1px solid var(--ng-ab-border) !important;
    box-shadow: 0 -8px 24px -12px rgba(13,27,42,.12);
    padding: 0 !important;
}
/* Bar como pill flotante en mobile — márgenes en los 4 lados */
@media (max-width: 991px) {
    body.frontend-page.ng-pdp__book-inline .bc-more-book-mobile {
        position: fixed !important;
        left: 12px !important;
        right: 12px !important;
        bottom: calc(12px + env(safe-area-inset-bottom, 0px)) !important;
        width: auto !important;
        transform: translateY(calc(100% + 30px));
        opacity: 0;
        pointer-events: none;
        transition: transform .25s cubic-bezier(0.16, 1, 0.3, 1), opacity .2s ease;
        border-radius: 999px !important;
        border-top: 0 !important;
        background: linear-gradient(135deg, #ff5a00 0%, #ffb703 100%) !important;
        box-shadow:
            0 4px 12px -4px rgba(255,122,0,.45),
            0 12px 28px -8px rgba(255,122,0,.30) !important;
        z-index: 9999;
        overflow: hidden;
    }
    /* Textos del bar en blanco sobre el gradient naranja */
    body.frontend-page.ng-pdp__book-inline .bc-more-book-mobile .g-price .fr_text {
        color: rgba(255,255,255,.85) !important;
    }
    body.frontend-page.ng-pdp__book-inline .bc-more-book-mobile .g-price .text-price {
        color: #fff !important;
    }
    body.frontend-page.ng-pdp__book-inline .bc-more-book-mobile .g-price .price-unit {
        color: rgba(255,255,255,.85) !important;
    }
    /* Botón "Reservar Ahora" interno — negro con texto blanco sobre el bar gradient */
    body.frontend-page.ng-pdp__book-inline .bc-more-book-mobile .right .btn-primary {
        background: #111 !important;
        color: #fff !important;
        border-radius: 999px !important;
        padding: 11px 18px !important;
        font-weight: 900 !important;
        font-size: 14px !important;
        letter-spacing: -.2px !important;
        line-height: 1 !important;
        border: 0 !important;
        box-shadow: 0 4px 12px -4px rgba(0,0,0,.35) !important;
        transition: background .2s ease, transform .2s ease, box-shadow .2s ease !important;
        white-space: nowrap;
        display: inline-flex !important;
        align-items: center;
    }
    body.frontend-page.ng-pdp__book-inline .bc-more-book-mobile .right .btn-primary:hover {
        background: #1a2b48 !important;
        transform: translateY(-1px);
        box-shadow: 0 8px 18px -4px rgba(0,0,0,.45) !important;
        color: #fff !important;
    }
    /* Container interno: padding más compacto porque la pill ya tiene radius */
    body.frontend-page.ng-pdp__book-inline .bc-more-book-mobile .container {
        padding: 8px 14px 8px 18px !important;
        min-height: 56px !important;
    }
    /* Ocultar la barra mientras el menú hamburguesa está abierto (no intercepta taps).
       :has() para browsers modernos + body.ng-menu-opened (JS) fallback universal. */
    body.frontend-page:has(.header.is-menu-opened) .bc-more-book-mobile,
    body.ng-menu-opened .bc-more-book-mobile {
        display: none !important;
    }
    body.frontend-page.ng-pdp__book-inline.ng-pdp__book-show-bar .bc-more-book-mobile {
        transform: translateY(0);
        opacity: 1;
        pointer-events: auto;
    }
}
/* Container: ancho completo, flex row sin wrap, vertical-centered */
body.frontend-page .bc-more-book-mobile .container {
    max-width: none !important;
    width: 100% !important;
    height: auto !important;
    min-height: 60px !important;
    padding: 10px 16px calc(10px + env(safe-area-inset-bottom, 0px)) !important;
    margin: 0 !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
}
/* LEFT: precio en una sola línea (DE $X /día), nada más */
body.frontend-page .bc-more-book-mobile .left {
    flex: 1 1 auto !important;
    max-width: none !important;
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
}
/* Ocultar stars y review text en mobile bar — solo precio */
body.frontend-page .bc-more-book-mobile .service-review { display: none !important; }
/* g-price: prefix + precio + /día en una sola fila */
body.frontend-page .bc-more-book-mobile .g-price {
    display: inline-flex !important;
    align-items: baseline !important;
    gap: 5px !important;
    line-height: 1 !important;
    flex-wrap: nowrap !important;
    white-space: nowrap !important;
}
body.frontend-page .bc-more-book-mobile .g-price .prefix {
    display: inline-flex !important;
    line-height: 1 !important;
}
body.frontend-page .bc-more-book-mobile .g-price .fr_text {
    color: var(--ng-ab-muted-2) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    text-transform: uppercase;
    letter-spacing: .06em;
}
body.frontend-page .bc-more-book-mobile .g-price .price {
    display: inline-flex !important;
    align-items: baseline !important;
    gap: 3px !important;
    line-height: 1 !important;
}
body.frontend-page .bc-more-book-mobile .g-price .onsale { display: none !important; }
body.frontend-page .bc-more-book-mobile .g-price .text-price {
    color: var(--ng-ab-fg) !important;
    font-weight: 700 !important;
    font-size: 17px !important;
    line-height: 1 !important;
}
body.frontend-page .bc-more-book-mobile .g-price .price-unit {
    color: var(--ng-ab-muted) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
}
/* RIGHT: botón pill, ancho natural, alineado a la derecha */
body.frontend-page .bc-more-book-mobile .right {
    flex: 0 0 auto !important;
    max-width: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    text-align: right;
}
body.frontend-page .bc-more-book-mobile .right .btn-primary {
    background: var(--ng-ab-fg) !important;
    color: #fff !important;
    border-radius: 999px !important;
    padding: 11px 20px !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    border: 0 !important;
    white-space: nowrap !important;
    display: inline-flex !important;
    align-items: center !important;
    line-height: 1 !important;
    transition: transform .15s var(--ng-ab-ease), box-shadow .2s var(--ng-ab-ease);
}
body.frontend-page .bc-more-book-mobile .right .btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 24px -10px rgba(13,27,42,.30);
}
@media (max-width: 575px) {
    body.frontend-page .bc-more-book-mobile .container {
        display: flex !important;
        padding: 9px 12px calc(9px + env(safe-area-inset-bottom, 0px)) !important;
        gap: 8px;
    }
}
/* Pantallas muy chicas: comprimir font del precio y botón */
@media (max-width: 380px) {
    body.frontend-page .bc-more-book-mobile .container { padding: 9px 12px calc(9px + env(safe-area-inset-bottom, 0px)) !important; gap: 8px !important; }
    body.frontend-page .bc-more-book-mobile .g-price .text-price { font-size: 15px !important; }
    body.frontend-page .bc-more-book-mobile .g-price .fr_text { font-size: 10px !important; }
    body.frontend-page .bc-more-book-mobile .right .btn-primary { padding: 10px 14px !important; font-size: 13px !important; }
}

/* === Breadcrumb del final: más sutil === */
body.frontend-page .bc_detail nav.breadcrumb,
body.frontend-page .bc_detail .breadcrumb-wrap,
body.frontend-page .ng-pdp nav.breadcrumb {
    margin-top: 24px;
    padding: 16px 0;
    border-top: 1px solid var(--ng-ab-border);
}
body.frontend-page .bc_detail .breadcrumb a,
body.frontend-page .bc_detail .breadcrumb span {
    font-size: 13px;
    color: var(--ng-ab-muted) !important;
}

/* === Form-book sidebar: refuerzo de border-radius y card-feel === */
body.frontend-page .bc_detail .form-book {
    border-radius: 18px !important;
}

/* === Ritmo vertical: separar secciones del PDP === */
body.frontend-page .bc_detail .container.mt-40.mb-40 .border-top-light,
body.frontend-page .ng-pdp .container.mt-40.mb-40 .border-top-light {
    display: none !important; /* los reemplazamos con margin entre cards */
}
body.frontend-page .bc_detail section,
body.frontend-page .ng-pdp section {
    margin-top: 28px;
}
body.frontend-page .bc_detail .ng-pdp__body section,
body.frontend-page .ng-pdp .ng-pdp__body section { margin-top: 0; }

@media (max-width: 991px) {
    body.frontend-page .bc_detail section,
    body.frontend-page .ng-pdp section { margin-top: 10px; }
}

/* === Tipografía global en PDP === */
body.frontend-page .bc_detail h2,
body.frontend-page .ng-pdp h2 { letter-spacing: -.4px; }
body.frontend-page .bc_detail h3,
body.frontend-page .ng-pdp h3 { letter-spacing: -.3px; }

/* === FIN PDP AIRBNB DEEP POLISH === */


/* =============================================================
   PDP TIER-1 ELEVATION — todo en cards premium, ritmo y respiro
   ============================================================= */

/* Bg sutil al canvas del PDP para que las cards floten */
body.frontend-page .bc_detail {
    background: var(--ng-ab-bg-app);
}

/* Ritmo vertical entre cards del PDP */
body.frontend-page .bc_detail .ng-pdp__body > .container > .row > .ng-pdp__main > * + *,
body.frontend-page .ng-pdp .ng-pdp__body > .container > .row > .ng-pdp__main > * + * {
    margin-top: 18px;
}

/* === ng-pdpInfo: ahora es UNA card grande con secciones internas === */
body.frontend-page .ng-pdpInfo {
    background: #fff;
    border: 1px solid var(--ng-ab-border);
    border-radius: 22px;
    padding: 6px 28px !important;
    margin: 18px 0 0 !important;
    box-shadow:
        0 1px 2px rgba(13,27,42,.04),
        0 16px 36px -20px rgba(13,27,42,.12);
}
body.frontend-page .ng-pdpInfo__section {
    padding: 0 !important;
    border: none !important;
}
body.frontend-page .ng-pdpInfo__section:first-child { padding-top: 0 !important; }
body.frontend-page .ng-pdpInfo__section:last-child { border-bottom: none !important; padding-bottom: 0 !important; }
body.frontend-page .ng-pdpInfo__title {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--ng-ab-fg) !important;
    letter-spacing: -.4px !important;
    margin-bottom: 14px !important;
}
@media (max-width: 575px) {
    body.frontend-page .ng-pdpInfo { padding: 4px 0px !important; border-radius: 18px; }
    body.frontend-page .ng-pdpInfo__title { font-size: 19px !important; }
}

/* === Gallery: radius más generoso === */
body.frontend-page .ng-pdp__gallery,
body.frontend-page .ng-pdp__gallery * {
    border-radius: 20px;
}
body.frontend-page .ng-pdp__gallery .gallery-airbnb__main img,
body.frontend-page .ng-pdp__gallery img {
    border-radius: 16px !important;
}
@media (max-width: 767px) {
    body.frontend-page .ng-pdp__gallery .gallery-airbnb__main img,
    body.frontend-page .ng-pdp__gallery img {
        border-radius: 0 !important;
    }
}

/* === Date strip: bigger radius alineado al sistema === */
body.frontend-page .bc_detail .ng-dateStrip {
    border-radius: 22px !important;
    padding: 22px 24px 18px !important;
    margin-top: 18px !important;
    box-shadow:
        0 1px 2px rgba(13,27,42,.04),
        0 16px 36px -20px rgba(13,27,42,.12) !important;
}

/* === PDP MOBILE: Read more progresivo en About this boat === */
@media (max-width: 991px) {
    body.frontend-page .ng-pdpInfo__content {
        max-height: var(--ng-readmore-h, 70vh);
        overflow: hidden;
        position: relative;
        transition: max-height .35s cubic-bezier(0.16, 1, 0.3, 1);
    }
    body.frontend-page .ng-pdpInfo__content.is-fully-expanded {
        max-height: none !important;
    }
    body.frontend-page .ng-pdpInfo__content:not(.is-fully-expanded)::after {
        content: '';
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0;
        height: 80px;
        background: linear-gradient(to bottom, rgba(255,255,255,0), #fff 90%);
        pointer-events: none;
    }
    body.frontend-page .ng-pdpInfo__readMore {
        display: block;
        width: 100%;
        background: #f3f4f7;
        color: #0d1b2a;
        border: 0;
        border-radius: 25px;
        padding: 14px 22px;
        font-size: 14.5px;
        font-weight: 600;
        margin-top: 14px;
        cursor: pointer;
        transition: background .15s ease, transform .15s ease;
        text-align: center;
        letter-spacing: -.1px;
    }
    body.frontend-page .ng-pdpInfo__readMore:hover,
    body.frontend-page .ng-pdpInfo__readMore:active {
        background: #e8eaef;
    }
}

/* === PDP MOBILE compactar todo el layout — menos aire, más densidad === */
@media (max-width: 991px) {
    /* Container principal: menos padding lateral */
    body.frontend-page .ng-pdp .container,
    body.frontend-page .bc_detail .container {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }
    /* Gap entre secciones principales (gallery, strip, stats, info) */
    body.frontend-page .ng-pdp__body .row.y-gap-30,
    body.frontend-page .bc_detail .row.y-gap-30 {
        --bs-gutter-y: 16px !important;
    }
    /* Separadores con mt-40/mb-40 → casi nada */
    body.frontend-page .bc_detail .container.mt-40.mb-40,
    body.frontend-page .ng-pdp .container.mt-40.mb-40 {
        margin-top: 2px !important;
        margin-bottom: 2px !important;
    }
    /* Sections con pt-40 → pt compacto */
    body.frontend-page .bc_detail section.pt-40,
    body.frontend-page .ng-pdp section.pt-40 {
        padding-top: 20px !important;
    }
    body.frontend-page .bc_detail .pb-40,
    body.frontend-page .ng-pdp .pb-40 { padding-bottom: 20px !important; }
    body.frontend-page .bc_detail .mt-40,
    body.frontend-page .ng-pdp .mt-40 { margin-top: 16px !important; }
    /* Things you should know */
    body.frontend-page section.ab-know-section {
        padding: 18px 0 !important;
    }
    body.frontend-page .ab-section-title {
        font-size: 18px !important;
        margin-bottom: 12px !important;
    }
    body.frontend-page .ab-know-h { font-size: 14px !important; margin-bottom: 6px !important; }
    body.frontend-page .ab-know-list li { padding: 6px 0 !important; font-size: 13.5px !important; }
    /* PDP Info: padding section reducido */
    body.frontend-page .ng-pdpInfo__section {
        padding-top: 18px !important;
        padding-bottom: 18px !important;
        padding: 0 !important;
        border: none;
    }
    body.frontend-page .ng-pdpInfo__title {
        font-size: 17px !important;
        margin-bottom: 10px !important;
    }
    body.frontend-page .ng-pdpInfo__content { font-size: 14.5px !important; line-height: 1.5 !important; }
    body.frontend-page .ng-pdpInfo__content h2 { font-size: 16px !important; }
    body.frontend-page .ng-pdpInfo__content h3 { font-size: 15px !important; }
    body.frontend-page .ng-pdpInfo__content h4,
    body.frontend-page .ng-pdpInfo__content h5,
    body.frontend-page .ng-pdpInfo__content h6 { font-size: 14.5px !important; }
    body.frontend-page .ng-pdpInfo__content p { margin-bottom: 10px !important; }
    /* Stats: cuadrícula compacta */
    body.frontend-page .ng-pdpStats {
        gap: 8px !important;
        padding: 14px !important;
        margin-top: 12px !important;
        border-radius: 14px !important;
    }
    body.frontend-page .ng-pdpStats__item { gap: 8px !important; }
    body.frontend-page .ng-pdpStats__icon { font-size: 18px !important; }
    body.frontend-page .ng-pdpStats__value { font-size: 15px !important; line-height: 1.1 !important; }
    body.frontend-page .ng-pdpStats__name { font-size: 11px !important; line-height: 1.2 !important; }
    /* Reviews section */
    body.frontend-page section.bc-reviews {
        padding: 16px 14px !important;
        border-radius: 14px !important;
        margin-top: 12px !important;
    }
    body.frontend-page section.bc-reviews h3.text-22 { font-size: 18px !important; }
    body.frontend-page section.bc-reviews .review-item { padding: 12px 0 !important; }
    body.frontend-page section.bc-reviews .review-item h5 { font-size: 14.5px !important; margin-top: 10px !important; }
    body.frontend-page section.bc-reviews .review-item p { font-size: 13.5px !important; margin-top: 6px !important; line-height: 1.5 !important; }
    /* Border separators redundantes ocultos */
    body.frontend-page .bc_detail .border-top-light,
    body.frontend-page .ng-pdp .border-top-light {
        display: none !important;
    }
    /* layout-pt-lg al fondo: menos espacio */
    body.frontend-page .layout-pt-lg { padding-top: 16px !important; }
    /* Gallery: aspect-ratio mobile (+10% más altura que 16/11) */
    body.frontend-page .ng-abGallery__grid { aspect-ratio: 4 / 3 !important; }
    /* Owner-info card: padding más tight */
    body.frontend-page .owner-info { padding: 12px !important; margin-bottom: 12px !important; border-radius: 12px !important; }
    body.frontend-page .owner-info .media-heading { font-size: 14px !important; }
    body.frontend-page .owner-info p { font-size: 12px !important; margin: 2px 0 0 !important; }
    /* Breadcrumb del fondo: padding tight */
    body.frontend-page .blog-breadcrumb { padding: 8px 0 !important; }
    body.frontend-page .blog-breadcrumb .text-14 { font-size: 11.5px !important; }
}

/* === Date-strip MOBILE refinement: card compacta, sofisticada, homogénea === */
@media (max-width: 575px) {
    body.frontend-page .bc_detail .ng-dateStrip,
    body.frontend-page .ng-pdp .ng-dateStrip {
        margin-top: 12px !important;
        padding: 14px 14px 12px !important;
        border-radius: 16px !important;
        border: 1px solid rgba(13,27,42,.06) !important;
        box-shadow:
            0 1px 2px rgba(13,27,42,.04),
            0 8px 20px -14px rgba(13,27,42,.10) !important;
    }
    /* Header en una línea horizontal: título compacto + nav inline */
    body.frontend-page .ng-dateStrip .ng-dateStrip__head {
        margin-bottom: 12px !important;
        gap: 8px !important;
        align-items: center !important;
    }
    body.frontend-page .ng-dateStrip .ng-dateStrip__title {
        font-size: 14px !important;
        font-weight: 600 !important;
        letter-spacing: -.1px !important;
        line-height: 1.2 !important;
        color: #0d1b2a !important;
    }
    body.frontend-page .ng-dateStrip .ng-dateStrip__sub { display: none !important; }
    body.frontend-page .ng-dateStrip .ng-dateStrip__nav { gap: 6px !important; }
    body.frontend-page .ng-dateStrip .ng-dateStrip__range {
        font-size: 11.5px !important;
        font-weight: 500 !important;
        color: #5a6675 !important;
        min-width: 0 !important;
        padding: 0 4px !important;
        white-space: nowrap;
    }
    body.frontend-page .ng-dateStrip .ng-dateStrip__navBtn {
        width: 28px !important;
        height: 28px !important;
        background: rgba(13,27,42,.05) !important;
    }
    body.frontend-page .ng-dateStrip .ng-dateStrip__navBtn svg {
        width: 13px !important;
        height: 13px !important;
    }
    /* Day track: 5 columnas compactas con gap mínimo */
    body.frontend-page .ng-dateStrip .ng-dateStrip__track {
        grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
        gap: 6px !important;
    }
    /* Day cell: pill vertical premium, padding tight, borde hairline */
    body.frontend-page .ng-dateStrip .ng-dateStrip__day {
        padding: 8px 2px !important;
        border-radius: 10px !important;
        border: 1px solid rgba(13,27,42,.08) !important;
        gap: 1px !important;
        background: #fff !important;
        min-height: 72px !important;
        justify-content: center !important;
    }
    body.frontend-page .ng-dateStrip .ng-dateStrip__day:hover:not(:disabled):not(.is-blocked) {
        border-color: #0d1b2a !important;
        transform: none !important;
        box-shadow: 0 4px 12px -6px rgba(13,27,42,.18) !important;
    }
    body.frontend-page .ng-dateStrip .ng-dateStrip__day.is-today {
        border-color: rgba(13,27,42,.40) !important;
    }
    body.frontend-page .ng-dateStrip .ng-dateStrip__day.is-selected {
        background: #0d1b2a !important;
        border-color: #0d1b2a !important;
        box-shadow: 0 8px 16px -10px rgba(13,27,42,.35) !important;
    }
    /* Typography por elemento: DOW (Mon), num (18), mon oculto, precio compacto */
    body.frontend-page .ng-dateStrip .ng-dateStrip__dow {
        font-size: 10px !important;
        font-weight: 600 !important;
        letter-spacing: .04em !important;
        color: #5a6675 !important;
        line-height: 1 !important;
    }
    body.frontend-page .ng-dateStrip .ng-dateStrip__num {
        font-size: 17px !important;
        font-weight: 700 !important;
        line-height: 1.1 !important;
        letter-spacing: -.4px !important;
        margin: 1px 0 !important;
    }
    /* Ocultar el "Mayo" debajo del número — ya está en el rango header */
    body.frontend-page .ng-dateStrip .ng-dateStrip__mon { display: none !important; }
    body.frontend-page .ng-dateStrip .ng-dateStrip__price {
        font-size: 10.5px !important;
        font-weight: 600 !important;
        color: #0d1b2a !important;
        line-height: 1 !important;
        margin-top: 3px !important;
        letter-spacing: -.2px !important;
    }
    body.frontend-page .ng-dateStrip .ng-dateStrip__day.is-selected .ng-dateStrip__dow {
        color: rgba(255,255,255,.72) !important;
    }
    body.frontend-page .ng-dateStrip .ng-dateStrip__day.is-selected .ng-dateStrip__num,
    body.frontend-page .ng-dateStrip .ng-dateStrip__day.is-selected .ng-dateStrip__price {
        color: #fff !important;
    }
    body.frontend-page .ng-dateStrip .ng-dateStrip__hint {
        font-size: 11px !important;
        margin-top: 8px !important;
        color: #5a6675 !important;
    }
}

/* === Things you should know: FLAT, sin card ni sombra === */
body.frontend-page section.ab-know-section {
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding: 32px 0 !important;
    margin-top: 0 !important;
}
body.frontend-page .ab-section-title {
    font-size: 22px !important;
    margin-bottom: 18px !important;
}
body.frontend-page .ab-know-h { font-size: 15px !important; }
body.frontend-page .ab-know-list li { padding: 12px 0 !important; }
@media (max-width: 575px) {
    body.frontend-page section.ab-know-section { padding: 22px 0 !important; }
}

/* === FAQ del PDP: mismo lenguaje === */
body.frontend-page .bc_detail .bc-faq-lists,
body.frontend-page .ng-pdp .bc-faq-lists {
    border-radius: 22px !important;
    padding: 32px 36px !important;
    margin: 0 !important;
    box-shadow:
        0 1px 2px rgba(13,27,42,.04),
        0 16px 36px -20px rgba(13,27,42,.12) !important;
}
body.frontend-page .bc_detail .bc-faq-lists h2.text-22,
body.frontend-page .ng-pdp .bc-faq-lists h2.text-22 {
    font-size: 24px !important;
    line-height: 1.2 !important;
}
@media (max-width: 575px) {
    body.frontend-page .bc_detail .bc-faq-lists,
    body.frontend-page .ng-pdp .bc-faq-lists { padding: 0 !important; border-radius: 18px; }
    body.frontend-page .bc_detail .bc-faq-lists h2.text-22,
    body.frontend-page .ng-pdp .bc-faq-lists h2.text-22 { font-size: 20px !important; }
}

/* === Map: integrado como card === */
body.frontend-page .bc_detail #map_content,
body.frontend-page .bc_detail [id^="map_"] {
    border-radius: 22px !important;
    min-height: 320px;
}

/* === Reviews: la sección entera como card === */
body.frontend-page section.bc-reviews {
    background: #fff;
    border: 1px solid var(--ng-ab-border);
    border-radius: 22px;
    padding: 36px !important;
    margin-top: 18px !important;
    box-shadow:
        0 1px 2px rgba(13,27,42,.04),
        0 16px 36px -20px rgba(13,27,42,.12);
}
body.frontend-page section.bc-reviews h3.text-22 {
    font-size: 22px !important;
}
/* Cada review item ya NO necesita su propia card pesada -> hairline divider */
body.frontend-page section.bc-reviews .review-item {
    background: transparent !important;
    border: 0 !important;
    border-bottom: 1px solid var(--ng-ab-border) !important;
    border-radius: 0 !important;
    padding: 22px 0 !important;
    box-shadow: none !important;
    margin: 0 !important;
}
body.frontend-page section.bc-reviews .review-item:last-child {
    border-bottom: 0 !important;
}
body.frontend-page section.bc-reviews .review-item:hover {
    background: transparent !important;
    transform: none !important;
    box-shadow: none !important;
}
@media (max-width: 575px) {
    body.frontend-page section.bc-reviews { padding: 22px 20px !important; border-radius: 18px; }
    body.frontend-page section.bc-reviews .review-item { padding: 18px 0 !important; }
}

/* === Containers que separaban con border-top-light: ahora invisibles === */
body.frontend-page .bc_detail .container.mt-40.mb-40,
body.frontend-page .ng-pdp .container.mt-40.mb-40 {
    margin-top: 4px !important;
    margin-bottom: 4px !important;
}
body.frontend-page .bc_detail .container.mt-40.mb-40 .border-top-light,
body.frontend-page .ng-pdp .container.mt-40.mb-40 .border-top-light {
    display: none !important;
}

/* === Form-book sidebar: radius y sombra unificados === */
body.frontend-page .bc_detail .form-book,
body.frontend-page .ng-pdp .form-book {
    border-radius: 22px !important;
    border: 1px solid var(--ng-ab-border) !important;
    box-shadow:
        0 1px 2px rgba(13,27,42,.04),
        0 20px 44px -22px rgba(13,27,42,.16) !important;
    padding: 24px !important;
}
@media (max-width: 991px) {
    body.frontend-page .bc_detail .form-book,
    body.frontend-page .ng-pdp .form-book { padding: 20px !important; border-radius: 18px !important; }
}

/* === Header del PDP: respiro arriba === */
body.frontend-page .ng-pdp__header {
    padding-top: 32px !important;
    padding-bottom: 12px !important;
}
@media (max-width: 991px) {
    body.frontend-page .ng-pdp__header {
        padding-top: 20px !important;
        padding-bottom: 0 !important;
    }
}

/* === Galería: separación con resto === */
body.frontend-page .ng-pdp__gallery {
    margin-bottom: 0;
}

/* Sección sticky del aside debe tener gap arriba en mobile */
@media (max-width: 991px) {
    body.frontend-page .ng-pdp__aside { margin-top: 8px; }
}

/* === FIN PDP TIER-1 ELEVATION === */


/* =============================================================
   LISTING PAGES — /boat y /tour (search)
   Airbnb-style: sidebar como card, cards limpios, sort pill,
   paginación redondeada, header limpio.
   ============================================================= */

/* Body bg ya aplicado globalmente (ng-ab-bg-app) */

/* === Hero del listing (cuando layout != grid) === */
body.frontend-page section.bg-light-2 {
    background: transparent !important;
    padding-top: 32px !important;
    padding-bottom: 24px !important;
}
body.frontend-page section.bg-light-2 h1.text-30,
body.frontend-page section.bg-light-2 h1 {
    font-size: clamp(22px, 2.6vw, 32px) !important;
    font-weight: 700 !important;
    color: var(--ng-ab-fg) !important;
    letter-spacing: -.5px !important;
    line-height: 1.2 !important;
    margin: 0 0 14px !important;
}

/* === Sidebar de filtros: card grande premium === */
body.frontend-page .bc_form_filter,
body.frontend-page form.bc_filter {
    background: #fff;
    border: 1px solid var(--ng-ab-border);
    border-radius: 20px;
    padding: 22px;
    box-shadow:
        0 1px 2px rgba(13,27,42,.04),
        0 12px 28px -18px rgba(13,27,42,.12);
    position: sticky;
    top: 96px;
}
@media (max-width: 991px) {
    body.frontend-page .bc_form_filter,
    body.frontend-page form.bc_filter { position: static; padding: 18px; border-radius: 16px; }
}
body.frontend-page .bc_form_filter aside.sidebar,
body.frontend-page form.bc_filter aside.sidebar {
    --bs-gutter-y: 0 !important;
    padding: 0 !important;
}
body.frontend-page .bc_form_filter .sidebar__item,
body.frontend-page form.bc_filter .sidebar__item {
    padding: 18px 0 !important;
    border-bottom: 1px solid var(--ng-ab-border) !important;
}
body.frontend-page .bc_form_filter .sidebar__item:first-child {
    padding-top: 0 !important;
}
body.frontend-page .bc_form_filter .sidebar__item:last-child {
    padding-bottom: 0 !important;
    border-bottom: 0 !important;
}
body.frontend-page .bc_form_filter .sidebar__item h5 {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--ng-ab-fg) !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
    margin: 0 0 14px !important;
}

/* Price range slider refinement */
body.frontend-page .bc_form_filter .irs--flat .irs-line,
body.frontend-page .bc_form_filter .irs-line {
    background: var(--ng-ab-bg-faint) !important;
    height: 4px !important;
    border-radius: 999px !important;
    top: 26px !important;
}
body.frontend-page .bc_form_filter .irs--flat .irs-bar,
body.frontend-page .bc_form_filter .irs-bar {
    background: var(--ng-ab-fg) !important;
    height: 4px !important;
    top: 26px !important;
}
body.frontend-page .bc_form_filter .irs--flat .irs-handle,
body.frontend-page .bc_form_filter .irs-handle {
    background: #fff !important;
    border: 2px solid var(--ng-ab-fg) !important;
    box-shadow: 0 2px 8px -2px rgba(13,27,42,.30) !important;
    width: 18px !important;
    height: 18px !important;
    top: 20px !important;
    border-radius: 50% !important;
    cursor: pointer;
}
body.frontend-page .bc_form_filter .irs--flat .irs-handle > i,
body.frontend-page .bc_form_filter .irs-handle > i,
body.frontend-page .bc_form_filter .irs-handle > i:first-child {
    display: none !important;
}
body.frontend-page .bc_form_filter .irs--flat .irs-from,
body.frontend-page .bc_form_filter .irs--flat .irs-to,
body.frontend-page .bc_form_filter .irs--flat .irs-single {
    background: var(--ng-ab-fg) !important;
    color: #fff !important;
    font-weight: 600 !important;
    border-radius: 6px !important;
    padding: 2px 6px !important;
    font-size: 11px !important;
}
body.frontend-page .bc_form_filter .irs--flat .irs-from::before,
body.frontend-page .bc_form_filter .irs--flat .irs-to::before,
body.frontend-page .bc_form_filter .irs--flat .irs-single::before {
    border-top-color: var(--ng-ab-fg) !important;
}
body.frontend-page .bc_form_filter .irs--flat .irs-min,
body.frontend-page .bc_form_filter .irs--flat .irs-max {
    background: transparent !important;
    color: var(--ng-ab-muted-2) !important;
    font-size: 11px !important;
}
body.frontend-page .bc_form_filter .js-price-searchPage .text-15.text-dark-1,
body.frontend-page .bc_form_filter .js-lower,
body.frontend-page .bc_form_filter .js-upper {
    color: var(--ng-ab-fg) !important;
    font-weight: 700 !important;
    font-size: 14.5px !important;
}

/* Checkbox custom (sidebar) — chips redondeados */
body.frontend-page .sidebar-checkbox {
    margin: 6px 0;
}
body.frontend-page .sidebar-checkbox label {
    display: flex !important;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    font-size: 13.5px;
    color: var(--ng-ab-fg-2) !important;
    padding: 6px 0;
    transition: color .15s ease;
}
body.frontend-page .sidebar-checkbox label:hover {
    color: var(--ng-ab-fg) !important;
}
body.frontend-page .sidebar-checkbox input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border: 1.5px solid var(--ng-ab-border-2);
    border-radius: 6px;
    background: #fff;
    flex-shrink: 0;
    cursor: pointer;
    position: relative;
    transition: background .15s ease, border-color .15s ease;
}
body.frontend-page .sidebar-checkbox input[type="checkbox"]:hover {
    border-color: var(--ng-ab-fg);
}
body.frontend-page .sidebar-checkbox input[type="checkbox"]:checked {
    background: var(--ng-ab-fg);
    border-color: var(--ng-ab-fg);
}
body.frontend-page .sidebar-checkbox input[type="checkbox"]:checked::after {
    content: "";
    position: absolute;
    left: 4px; top: 1px;
    width: 6px; height: 11px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}
body.frontend-page .sidebar-checkbox .text-light-1,
body.frontend-page .sidebar-checkbox .text-14 {
    color: var(--ng-ab-muted-2) !important;
    font-size: 12px !important;
    margin-left: auto;
}

/* Clear filter button */
body.frontend-page .bc-clear-filter,
body.frontend-page .bc-clear-filter button,
body.frontend-page form.bc_filter button[type="submit"],
body.frontend-page .bc_form_filter button {
    background: var(--ng-ab-fg) !important;
    color: #fff !important;
    border: 0 !important;
    border-radius: 999px !important;
    padding: 10px 20px !important;
    font-weight: 600 !important;
    font-size: 13.5px !important;
    transition: transform .15s ease, box-shadow .15s ease;
    width: 100%;
    cursor: pointer;
}
body.frontend-page .bc_form_filter button:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 20px -10px rgba(13,27,42,.30);
}

/* === Results header (count + sort) === */
body.frontend-page .result-count,
body.frontend-page .text-18.fw-500.result-count {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: var(--ng-ab-fg) !important;
    letter-spacing: -.2px;
}
body.frontend-page .bc-form-order .dropdown.orderby {
    background: #fff;
    border: 1px solid var(--ng-ab-border-2);
    border-radius: 999px;
    font-size: 13.5px;
    font-weight: 600;
    color: var(--ng-ab-fg) !important;
    transition: border-color .2s ease, box-shadow .2s ease;
}
body.frontend-page .bc-form-order .dropdown.orderby:hover {
    border-color: var(--ng-ab-fg);
    box-shadow: 0 4px 12px -6px rgba(13,27,42,.18);
}
body.frontend-page .bc-form-order .dropdown.orderby .dropdown-menu {
    border: 1px solid var(--ng-ab-border) !important;
    border-radius: 14px !important;
    box-shadow: var(--ng-ab-shadow-md) !important;
    padding: 8px !important;
    min-width: 200px;
}
body.frontend-page .bc-form-order .dropdown.orderby .dropdown-menu a {
    padding: 8px 12px !important;
    border-radius: 8px !important;
    font-size: 13.5px;
    color: var(--ng-ab-fg-2) !important;
}
body.frontend-page .bc-form-order .dropdown.orderby .dropdown-menu a:hover {
    background: var(--ng-ab-bg-faint) !important;
    color: var(--ng-ab-fg) !important;
}

/* Divider entre header de resultados y grid */
body.frontend-page .ajax-search-result .pt-30.mt-30.border-top-light {
    border-top: 0 !important;
    margin-top: 16px !important;
    padding-top: 4px !important;
}

/* === Cards del listing (refuerzo radius + sombra negra visible) === */
body.frontend-page .ajax-search-result .ng-tourCard {
    border-radius: 18px !important;
    overflow: hidden !important;
    box-shadow:
        0 1px 2px rgba(0, 0, 0, .08),
        0 8px 24px -10px rgba(0, 0, 0, .25) !important;
    transition: transform .25s var(--ng-ab-ease),
                box-shadow .25s var(--ng-ab-ease) !important;
}
body.frontend-page .ajax-search-result .ng-tourCard:hover {
    transform: translateY(-3px) !important;
    box-shadow:
        0 2px 4px rgba(0, 0, 0, .10),
        0 20px 40px -14px rgba(0, 0, 0, .35) !important;
}

/* Lista en mode "list" (loop-list) — misma sombra negra */
body.frontend-page .ajax-search-result .item-loop-wrap.inner-loop-wrap {
    background: #fff;
    border: 1px solid var(--ng-ab-border);
    border-radius: 18px;
    overflow: hidden;
    box-shadow:
        0 1px 2px rgba(0, 0, 0, .08),
        0 8px 24px -10px rgba(0, 0, 0, .25);
    transition: transform .25s var(--ng-ab-ease),
                box-shadow .25s var(--ng-ab-ease),
                border-color .25s var(--ng-ab-ease);
}
body.frontend-page .ajax-search-result .item-loop-wrap.inner-loop-wrap:hover {
    transform: translateY(-2px);
    border-color: var(--ng-ab-border-2);
    box-shadow:
        0 2px 4px rgba(13,27,42,.05),
        0 18px 36px -18px rgba(13,27,42,.18);
}

/* === Paginación premium === */
body.frontend-page .bc-pagination {
    margin-top: 28px;
}
body.frontend-page .bc-pagination .pagination,
body.frontend-page .bc-pagination ul.pagination {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin: 0;
    padding: 0;
    list-style: none;
}
body.frontend-page .bc-pagination .pagination .page-item .page-link,
body.frontend-page .bc-pagination ul.pagination li a,
body.frontend-page .bc-pagination ul.pagination li span {
    min-width: 38px;
    height: 38px;
    border-radius: 50% !important;
    background: #fff !important;
    border: 1px solid var(--ng-ab-border-2) !important;
    color: var(--ng-ab-fg-2) !important;
    font-weight: 600 !important;
    font-size: 13.5px !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    transition: background .15s ease, color .15s ease, transform .15s ease, border-color .15s ease;
}
body.frontend-page .bc-pagination .pagination .page-item .page-link:hover,
body.frontend-page .bc-pagination ul.pagination li a:hover {
    background: var(--ng-ab-fg) !important;
    color: #fff !important;
    border-color: var(--ng-ab-fg) !important;
    transform: translateY(-1px);
}
body.frontend-page .bc-pagination .pagination .page-item.active .page-link,
body.frontend-page .bc-pagination ul.pagination li.active a,
body.frontend-page .bc-pagination ul.pagination li.active span {
    background: var(--ng-ab-fg) !important;
    color: #fff !important;
    border-color: var(--ng-ab-fg) !important;
}
body.frontend-page .bc-pagination .pagination .page-item.disabled .page-link {
    opacity: .35;
}
body.frontend-page .custom-pagination {
    border-top: 0 !important;
    padding-top: 4px !important;
    margin-top: 0 !important;
}

/* === Mobile filter button (sticky bottom) === */
@media (max-width: 991px) {
    body.frontend-page .filterPopup {
        border-top-left-radius: 20px;
        border-top-right-radius: 20px;
    }
}

/* === Grid layout: form search dentro del sidebar === */
body.frontend-page .gotrip-form-search-grid {
    background: #fff !important;
    border: 1px solid var(--ng-ab-border) !important;
    border-radius: 16px !important;
    padding: 18px !important;
    box-shadow: var(--ng-ab-shadow-sm);
}
body.frontend-page .gotrip-form-search-grid h5 {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--ng-ab-fg) !important;
    letter-spacing: -.1px;
    margin-bottom: 12px !important;
}

/* === FIN LISTING PAGES === */


/* =============================================================
   CALL-TO-ACTION style_2 — hero card premium con bg image
   ============================================================= */

/* Reset del wrapper Livewire para que no aplique margen extra */
body.frontend-page .bc-call-to-action.style_2 {
    margin: 28px 0 !important;
}

/* Container del CTA: ya viene con .container de Bootstrap */
body.frontend-page .bc-call-to-action.style_2 > .container {
    padding-left: var(--bs-gutter-x, 24px) !important;
    padding-right: var(--bs-gutter-x, 24px) !important;
}

/* Card del CTA: hero card con imagen de fondo */
body.frontend-page .bc-call-to-action.style_2 .context,
body.frontend-page .bc_wrap .page-template-content .bc-call-to-action.style_2 .context {
    position: relative;
    isolation: isolate;
    background-color: var(--ng-ab-fg) !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    border-radius: 24px !important;
    padding: 64px 56px !important;
    min-height: 320px;
    overflow: hidden;
    color: #fff !important;
    display: flex;
    align-items: center;
    box-shadow:
        0 1px 2px rgba(13,27,42,.04),
        0 24px 56px -24px rgba(13,27,42,.30),
        0 6px 14px rgba(13,27,42,.10);
    transition: transform .35s var(--ng-ab-ease), box-shadow .35s var(--ng-ab-ease);
}
body.frontend-page .bc-call-to-action.style_2 .context:hover {
    transform: translateY(-3px);
    box-shadow:
        0 2px 4px rgba(13,27,42,.06),
        0 32px 64px -24px rgba(13,27,42,.40),
        0 10px 20px rgba(13,27,42,.14);
}

/* Overlay degradado sobre la imagen para legibilidad */
body.frontend-page .bc-call-to-action.style_2 .context::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg,
        rgba(13,27,42,.78) 0%,
        rgba(13,27,42,.58) 50%,
        rgba(13,27,42,.42) 100%);
    z-index: 0;
    pointer-events: none;
}
body.frontend-page .bc-call-to-action.style_2 .context > .row {
    position: relative;
    z-index: 1;
    align-items: center;
    margin: 0;
    width: 100%;
}

/* Título grande, peso 700 */
body.frontend-page .bc-call-to-action.style_2 .context .title,
body.frontend-page .bc_wrap .page-template-content .bc-call-to-action.style_2 .context .title {
    font-size: clamp(28px, 3.4vw, 44px) !important;
    font-weight: 700 !important;
    color: #fff !important;
    line-height: 1.15 !important;
    letter-spacing: -.7px !important;
    margin: 0 0 12px !important;
    text-shadow: 0 2px 8px rgba(0,0,0,.18);
}

/* Subtítulo en blanco semi */
body.frontend-page .bc-call-to-action.style_2 .context .sub_title,
body.frontend-page .bc_wrap .page-template-content .bc-call-to-action.style_2 .context .sub_title {
    font-size: clamp(15px, 1.4vw, 18px) !important;
    color: rgba(255,255,255,.88) !important;
    line-height: 1.55 !important;
    margin: 0 !important;
    max-width: 560px;
    font-weight: 400;
}

/* Botón CTA: pill blanco con hover charcoal-inverted */
body.frontend-page .bc-call-to-action.style_2 .context .btn-more,
body.frontend-page .bc_wrap .page-template-content .bc-call-to-action.style_2 .context .btn-more {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 10px;
    float: none !important;
    background: #fff !important;
    color: var(--ng-ab-fg) !important;
    padding: 16px 30px !important;
    border-radius: 999px !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    letter-spacing: -.1px !important;
    text-decoration: none !important;
    margin: 0 !important;
    transition: transform .2s var(--ng-ab-ease),
                box-shadow .25s var(--ng-ab-ease),
                background .2s var(--ng-ab-ease),
                color .2s var(--ng-ab-ease) !important;
    box-shadow: 0 6px 16px -6px rgba(0,0,0,.25);
    white-space: nowrap;
}
body.frontend-page .bc-call-to-action.style_2 .context .btn-more::after {
    content: "→";
    font-size: 18px;
    transition: transform .25s var(--ng-ab-ease);
}
body.frontend-page .bc-call-to-action.style_2 .context .btn-more:hover {
    background: var(--ng-ab-fg) !important;
    color: #fff !important;
    transform: translateY(-2px);
    box-shadow: 0 14px 28px -10px rgba(0,0,0,.40);
    border-radius: 999px !important;
}
body.frontend-page .bc-call-to-action.style_2 .context .btn-more:hover::after {
    transform: translateX(4px);
}

/* Columna derecha: alinea el botón a la derecha */
body.frontend-page .bc-call-to-action.style_2 .context .row > .col-md-4 {
    display: flex;
    justify-content: flex-end;
}
body.frontend-page .bc-call-to-action.style_2 .context .row > .col-md-8 {
    padding-right: 32px;
}

/* Si no hay link/botón, ocultar col-md-4 vacío */
body.frontend-page .bc-call-to-action.style_2 .context .row > .col-md-4:empty {
    display: none;
}

/* Eyebrow opcional (decorative) arriba del título */
body.frontend-page .bc-call-to-action.style_2 .context .title::before {
    content: "";
    display: block;
    width: 36px;
    height: 3px;
    background: #fff;
    opacity: .85;
    margin-bottom: 18px;
    border-radius: 999px;
}

/* === Responsive === */
@media (max-width: 991px) {
    body.frontend-page .bc-call-to-action.style_2 .context {
        padding: 48px 36px !important;
        min-height: 280px;
        border-radius: 22px !important;
    }
}
@media (max-width: 767px) {
    body.frontend-page .bc-call-to-action.style_2 .context,
    body.frontend-page .bc_wrap .page-template-content .bc-call-to-action.style_2 .context {
        padding: 36px 24px !important;
        min-height: 0;
        border-radius: 20px !important;
        text-align: center;
    }
    body.frontend-page .bc-call-to-action.style_2 .context .row > .col-md-8 {
        padding-right: 0 !important;
    }
    body.frontend-page .bc-call-to-action.style_2 .context .row > .col-md-4 {
        justify-content: center;
        margin-top: 22px;
    }
    body.frontend-page .bc-call-to-action.style_2 .context .title::before {
        margin-left: auto;
        margin-right: auto;
    }
    body.frontend-page .bc-call-to-action.style_2 .context .sub_title {
        margin-left: auto !important;
        margin-right: auto !important;
    }
    body.frontend-page .bc-call-to-action.style_2 .context .btn-more {
        padding: 14px 26px !important;
        font-size: 14.5px !important;
    }
}

/* === FIN CALL-TO-ACTION style_2 === */


/* =============================================================
   MOBILE-FIRST PREMIUM — cada sección perfecta en mobile
   Inspirado en Apple App Store, Airbnb, Booking mobile.
   ============================================================= */

@media (max-width: 767px) {

    /* ===== HOME ===== */

    /* Section headers (todas las secciones del home en mobile) */
    body.ng-hero-page .sectionTitle__title {
        font-size: 22px !important;
        line-height: 1.2 !important;
        font-weight: 700 !important;
        letter-spacing: -.4px !important;
        margin: 0 !important;
    }
    body.ng-hero-page .sectionTitle__text {
        font-size: 13.5px !important;
        color: var(--ng-ab-muted) !important;
        line-height: 1.45 !important;
        margin-top: 4px !important;
    }

    /* Padding lateral consistente en TODOS los containers del home */
    body.ng-hero-page .container {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    /* ===== Sección Featured Items — 2 columnas en mobile (tight) ===== */
    body.ng-hero-page section.ng-feature-section {
        padding-top: 24px !important;
        padding-bottom: 24px !important;
    }
    body.ng-hero-page section.ng-feature-section .container {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }

    /* Header: alineado a la izquierda dentro del container */
    body.ng-hero-page section.ng-feature-section .ng-feature-section__head {
        justify-content: flex-start !important;
        text-align: left !important;
        margin: 0 !important;
        padding: 0 0 14px !important;
        --bs-gutter-x: 0 !important;
        --bs-gutter-y: 0 !important;
    }
    body.ng-hero-page section.ng-feature-section .ng-feature-section__head > .col-auto {
        width: 100% !important;
        max-width: 100% !important;
        flex: 0 0 100% !important;
        padding: 0 !important;
    }
    body.ng-hero-page section.ng-feature-section .ng-feature-section__head .sectionTitle.-md {
        text-align: left !important;
    }
    body.ng-hero-page section.ng-feature-section .ng-feature-section__head .sectionTitle__title {
        text-align: left !important;
        font-size: 22px !important;
        font-weight: 700 !important;
        letter-spacing: -.4px !important;
        line-height: 1.2 !important;
        margin: 0 !important;
    }
    body.ng-hero-page section.ng-feature-section .ng-feature-section__head .sectionTitle__text {
        text-align: left !important;
        font-size: 13.5px !important;
        margin-top: 4px !important;
        color: var(--ng-ab-muted) !important;
    }

    /* Row de cards: gap mínimo */
    body.ng-hero-page section.ng-feature-section .row.y-gap-20:not(.ng-feature-section__head) {
        --bs-gutter-y: 6px !important;
        --bs-gutter-x: 6px !important;
        row-gap: 6px !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    body.ng-hero-page section.ng-feature-section .row > [class*="col-"]:not(.col-auto) {
        width: 50% !important;
        max-width: 50% !important;
        flex: 0 0 50% !important;
        padding-left: 3px !important;
        padding-right: 3px !important;
        margin-top: 0 !important;
        margin-bottom: 0 !important;
    }

    /* Card de cada feature: vertical (icono arriba + texto debajo, centrado) */
    body.ng-hero-page section.ng-feature-section .ng-feature-h {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 8px !important;
        padding: 12px !important;
        border-radius: 12px !important;
        height: 100% !important;
        background: #fff !important;
        border: 1px solid rgba(13,27,42,.06) !important;
        box-shadow: 0 1px 2px rgba(13,27,42,.04) !important;
    }
    body.ng-hero-page section.ng-feature-section .ng-feature-h__icon {
        flex: 0 0 44px !important;
        width: 44px !important;
        height: 44px !important;
        border-radius: 12px !important;
        background: #f3f5f9 !important;
        align-items: center;
        justify-content: center;
    }
    body.ng-hero-page section.ng-feature-section .ng-feature-h__icon img {
        width: 28px !important; height: 28px !important;
        object-fit: contain;
    }
    body.ng-hero-page section.ng-feature-section .ng-feature-h__body {
        text-align: left;
    }
    body.ng-hero-page section.ng-feature-section .ng-feature-h__title {
        font-size: 13.5px !important;
        font-weight: 700 !important;
        color: #0d1b2a !important;
        line-height: 1.25 !important;
        margin: 0 0 4px !important;
        letter-spacing: -.1px !important;
    }
    body.ng-hero-page section.ng-feature-section .ng-feature-h__sub {
        font-size: 12px !important;
        color: #5e6675 !important;
        line-height: 1.4 !important;
        margin: 0 !important;
    }
    /* Sub-mobile (<=380px): un poco más compacto */
    @media (max-width: 380px) {
        body.ng-hero-page section.ng-feature-section .ng-feature-h { padding: 12px !important; }
        body.ng-hero-page section.ng-feature-section .ng-feature-h__icon {
            flex: 0 0 38px !important; width: 38px !important; height: 38px !important;
        }
        body.ng-hero-page section.ng-feature-section .ng-feature-h__icon img {
            width: 24px !important; height: 24px !important;
        }
        body.ng-hero-page section.ng-feature-section .ng-feature-h__title { font-size: 13px !important; }
        body.ng-hero-page section.ng-feature-section .ng-feature-h__sub { font-size: 11.5px !important; }
    }

    /* ===== Sección Boats / Tours listing (cards horizontales con swiper) ===== */
    body.ng-hero-page section.boat-list-item .ng-tourCard,
    body.ng-hero-page section.tour-list-item .ng-tourCard {
        border-radius: 18px !important;
    }
    body.ng-hero-page section.boat-list-item,
    body.ng-hero-page section.tour-list-item {
        padding-top: 28px !important;
        padding-bottom: 24px !important;
    }

    /* ===== Offer block slider ===== */
    body.ng-hero-page .ng-offerSlider {
        padding-top: 24px !important;
        padding-bottom: 24px !important;
    }
    body.ng-hero-page .ng-offerSlider__head {
        padding-bottom: 16px !important;
    }
    body.ng-hero-page .ng-oCard {
        border-radius: 16px !important;
    }

    /* ===== Why Choose Us ===== */
    body.ng-hero-page .ng-whyUs {
        padding-top: 28px !important;
        padding-bottom: 28px !important;
    }
    body.ng-hero-page .ng-whyUs__head {
        padding-bottom: 18px !important;
    }
    body.ng-hero-page .ng-whyUs__card {
        padding: 18px !important;
        border-radius: 16px !important;
        gap: 12px !important;
    }
    body.ng-hero-page .ng-whyUs__icon {
        width: 44px !important; height: 44px !important;
        border-radius: 12px !important;
    }
    body.ng-hero-page .ng-whyUs__icon img {
        width: 24px !important; height: 24px !important;
    }
    body.ng-hero-page .ng-whyUs__title { font-size: 15px !important; }
    body.ng-hero-page .ng-whyUs__desc { font-size: 13.5px !important; }
    body.ng-hero-page section.ng-whyUs .row.y-gap-30,
    body.ng-hero-page section.ng-whyUs .row {
        --bs-gutter-y: 10px !important;
        row-gap: 10px !important;
    }

    /* ===== Testimonial ===== */
    body.frontend-page section.ng-testi { padding-top: 32px !important; padding-bottom: 32px !important; }
    body.frontend-page .ng-tCard {
        padding: 18px 16px !important;
        border-radius: 16px !important;
        gap: 10px !important;
    }
    body.frontend-page .ng-tCard__heading { font-size: 14.5px !important; }
    body.frontend-page .ng-tCard__quote {
        font-size: 14px !important;
        -webkit-line-clamp: 5;
    }
    body.frontend-page .ng-tCard__avatar { width: 40px !important; height: 40px !important; }
    body.frontend-page .ng-tCard__name { font-size: 14px !important; }
    body.frontend-page .ng-tCard__job { font-size: 12px !important; }

    /* ===== FAQ — mobile-first nativo (estilo iOS Settings) ===== */
    body.frontend-page section.bc-faq-lists {
        padding-top: 24px !important;
        padding-bottom: 28px !important;
        background: transparent !important;
    }
    body.frontend-page section.bc-faq-lists .container {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    /* Header alineado a la izquierda (native mobile feel) */
    body.frontend-page section.bc-faq-lists .row.justify-center.text-center {
        justify-content: flex-start !important;
        text-align: left !important;
    }
    body.frontend-page section.bc-faq-lists .row.justify-center.text-center > .col-auto {
        text-align: left !important;
        width: 100% !important;
        max-width: 100% !important;
        flex: 0 0 100% !important;
    }
    body.frontend-page section.bc-faq-lists .sectionTitle.-md {
        text-align: left !important;
    }
    body.frontend-page section.bc-faq-lists .sectionTitle__title {
        font-size: 22px !important;
        line-height: 1.2 !important;
        font-weight: 700 !important;
        letter-spacing: -.4px !important;
        margin: 0 0 4px !important;
        text-align: left !important;
    }
    body.frontend-page section.bc-faq-lists .sectionTitle__text {
        font-size: 13.5px !important;
        text-align: left !important;
    }

    /* Container del accordion: full-width sin restricciones */
    body.frontend-page section.bc-faq-lists .row.y-gap-30.justify-center.pt-40 {
        padding-top: 16px !important;
        --bs-gutter-y: 10px !important;
        --bs-gutter-x: 0 !important;
        margin: 0 !important;
    }
    body.frontend-page section.bc-faq-lists .row.y-gap-30 > .col-xl-8.col-lg-10 {
        width: 100% !important;
        max-width: 100% !important;
        flex: 0 0 100% !important;
        padding: 0 !important;
    }
    body.frontend-page section.bc-faq-lists .accordion {
        --bs-gutter-y: 10px !important;
        margin: 0 !important;
    }
    body.frontend-page section.bc-faq-lists .accordion > .col-12 {
        padding: 0 !important;
    }

    /* === Cards iOS style: bg blanco, radius pronunciado, sombra suave === */
    body.frontend-page section.bc-faq-lists .accordion__item {
        background: #fff !important;
        border: 1px solid rgba(13,27,42,.06) !important;
        border-radius: 16px !important;
        padding: 4px 4px !important;
        margin: 0 !important;
        box-shadow: 0 1px 2px rgba(13,27,42,.04) !important;
        transition: box-shadow .25s ease, border-color .25s ease, transform .15s ease !important;
        overflow: hidden;
    }
    body.frontend-page section.bc-faq-lists .accordion__item:active {
        transform: scale(.995);
    }
    body.frontend-page section.bc-faq-lists .accordion__item.is-active {
        box-shadow: 0 1px 2px rgba(13,27,42,.04), 0 12px 28px -16px rgba(13,27,42,.18) !important;
        border-color: rgba(13,27,42,.10) !important;
    }

    /* Button row (tap target grande, full-width) */
    body.frontend-page section.bc-faq-lists .accordion__button {
        padding: 14px 14px !important;
        gap: 14px !important;
        min-height: 56px;
        align-items: center !important;
        cursor: pointer;
    }

    /* Icono +/- (chip charcoal-suave, hover invertido cuando activo) */
    body.frontend-page section.bc-faq-lists .accordion__icon {
        width: 32px !important;
        height: 32px !important;
        flex: 0 0 32px !important;
        margin-right: 0 !important;
        border-radius: 50% !important;
        background: #f3f5f9 !important;
        color: #0d1b2a !important;
        font-size: 14px;
    }
    body.frontend-page section.bc-faq-lists .accordion__item.is-active .accordion__icon {
        background: #0d1b2a !important;
        color: #fff !important;
    }

    /* Question text: legible, wrap correctamente */
    body.frontend-page section.bc-faq-lists .accordion__button .button {
        font-size: 14.5px !important;
        font-weight: 600 !important;
        color: #0d1b2a !important;
        line-height: 1.35 !important;
        letter-spacing: -.1px !important;
        padding: 0 !important;
        text-align: left;
        white-space: normal !important;
        background: transparent !important;
        border: 0 !important;
        box-shadow: none !important;
        flex: 1 1 auto;
        min-width: 0;
    }

    /* Content: indentación alineada al texto de la pregunta */
    body.frontend-page section.bc-faq-lists .accordion__content .pt-20 {
        padding: 0 14px 14px 60px !important;  /* 14 left + 32 icon + 14 gap = 60 */
    }
    body.frontend-page section.bc-faq-lists .accordion__content p {
        font-size: 13.5px !important;
        line-height: 1.55 !important;
        color: #5e6675 !important;
        margin: 0 !important;
    }
    body.frontend-page section.bc-faq-lists .accordion__content h5 {
        font-size: 14px !important;
        font-weight: 600 !important;
        color: #0d1b2a !important;
        margin: 0 0 8px !important;
        text-align: left !important;
        padding: 0 !important;
        border: 0 !important;
    }

    /* Sub-mobile (<=380px) */
    @media (max-width: 380px) {
        body.frontend-page section.bc-faq-lists .accordion__item { border-radius: 14px !important; }
        body.frontend-page section.bc-faq-lists .accordion__button { padding: 12px !important; gap: 12px !important; }
        body.frontend-page section.bc-faq-lists .accordion__icon { width: 28px !important; height: 28px !important; flex: 0 0 28px !important; }
        body.frontend-page section.bc-faq-lists .accordion__button .button { font-size: 14px !important; }
        body.frontend-page section.bc-faq-lists .accordion__content .pt-20 { padding-left: 52px !important; }
    }

    /* ===== CTA style_2 ===== */
    body.frontend-page .bc-call-to-action.style_2 { margin: 20px 0 !important; }
    body.frontend-page .bc-call-to-action.style_2 .context {
        padding: 32px 22px !important;
        border-radius: 20px !important;
        min-height: 0;
    }
    body.frontend-page .bc-call-to-action.style_2 .context .title {
        font-size: 26px !important;
        line-height: 1.15 !important;
    }
    body.frontend-page .bc-call-to-action.style_2 .context .sub_title {
        font-size: 14.5px !important;
    }
    body.frontend-page .bc-call-to-action.style_2 .context .btn-more {
        padding: 12px 22px !important;
        font-size: 14px !important;
    }

    /* ===== Header hero (form-search-all-service) ===== */
    body.ng-hero-page .ng-hero {
        padding-bottom: 130px !important;
        z-index: 0;
    }
    body.ng-hero-page .ng-hero__title {
        font-size: 26px !important;
        line-height: 1.15 !important;
        letter-spacing: -.4px !important;
        margin-bottom: 8px !important;
    }
    body.ng-hero-page .ng-hero__subtitle {
        font-size: 13.5px !important;
        line-height: 1.45 !important;
    }

    /* Ritmo vertical homogéneo entre TODAS las secciones del home */
    body.ng-hero-page section + section,
    body.ng-hero-page .ng-feature-wrap + *,
    body.ng-hero-page .bc-list-locations-wrap + *,
    body.ng-hero-page .ng-offerSlider-wrap + *,
    body.ng-hero-page .ng-feature-wrap + * {
        margin-top: 0;
    }

    /* ===== Botones "More" mobile más grandes y tappables ===== */
    body.ng-hero-page .button.-md.-blue-1.bg-blue-1-05 {
        padding: 10px 20px !important;
        font-size: 13.5px !important;
    }
}

/* === FIN MOBILE-FIRST PREMIUM === */

/* ============================================================================
   PDP UNIFIED DESIGN SYSTEM — homogéneo, sofisticado, coherente
   Aplica a TODOS los bloques del PDP (boat + tour) para igualar el lenguaje
   visual: card hairline, radius unificado, headings tipados, ritmo consistente.
   ============================================================================ */
:root {
    --pdp-card-radius: 18px;
    --pdp-card-padding: 22px;
    --pdp-card-padding-mob: 16px;
    --pdp-card-border: 1px solid #e8eaef;
    --pdp-card-shadow: 0 1px 2px rgba(0,0,0,.04), 0 4px 14px -6px rgba(0,0,0,.08);
    --pdp-section-gap: 24px;
    --pdp-h1: 24px;
    --pdp-h2: 20px;
    --pdp-h3: 17px;
    --pdp-text: 14.5px;
    --pdp-muted: #5a6675;
    --pdp-fg: #111111;
    --pdp-divider: #ebebeb;
}
/* CARDS UNIFICADAS (todas las secciones) */
body.frontend-page .ng-pdp .ng-dateStrip,
body.frontend-page .ng-pdp section.ab-know-section .container > div,
body.frontend-page .ng-pdp .ng-pdpStats,
body.frontend-page .ng-pdp section.bc-reviews,
body.frontend-page .ng-pdp .bc-faq-lists.ng-faq-fixed .accordion__item,
body.frontend-page .ng-pdp .owner-info,
body.frontend-page .bc_detail .ng-dateStrip,
body.frontend-page .bc_detail section.bc-reviews,
body.frontend-page .bc_detail .owner-info {
    border-radius: var(--pdp-card-radius) !important;
    border: var(--pdp-card-border) !important;
    background: #fff !important;
    box-shadow: var(--pdp-card-shadow) !important;
}
/* HEADINGS UNIFICADOS */
body.frontend-page .ng-pdp h2,
body.frontend-page .ng-pdp .ab-section-title,
body.frontend-page .ng-pdp section.bc-reviews h3.text-22,
body.frontend-page .ng-pdp .bc-faq-lists h2,
body.frontend-page .bc_detail h2.text-22,
body.frontend-page .ng-pdpInfo__title {
    color: var(--pdp-fg) !important;
    font-weight: 700 !important;
    letter-spacing: -.3px !important;
    line-height: 1.25 !important;
}
body.frontend-page .ng-pdp h2,
body.frontend-page .ng-pdp .ab-section-title,
body.frontend-page .bc_detail h2.text-22,
body.frontend-page .bc_detail h3.text-22 {
    font-size: var(--pdp-h2) !important;
}
body.frontend-page .ng-pdpInfo__title {
    font-size: var(--pdp-h2) !important;
}
body.frontend-page .ng-pdp .ab-know-h {
    font-size: var(--pdp-h3) !important;
    font-weight: 700 !important;
    color: var(--pdp-fg) !important;
}
/* TEXTO BODY UNIFICADO */
body.frontend-page .ng-pdp .ng-pdpInfo__content,
body.frontend-page .ng-pdp .ab-know-list li,
body.frontend-page .ng-pdp section.bc-reviews .review-item p {
    color: var(--pdp-fg) !important;
    font-size: var(--pdp-text) !important;
    line-height: 1.55 !important;
}
/* DIVIDERS HAIRLINE EN UN SOLO LADO (no más double-line) */
body.frontend-page .ng-pdp .border-top-light,
body.frontend-page .bc_detail .border-top-light {
    border-top: 1px solid var(--pdp-divider) !important;
    opacity: .8;
}
/* MOBILE: paddings reducidos, cards sin sombra agresiva */
@media (max-width: 767px) {
    body.frontend-page .ng-pdp .ng-dateStrip,
    body.frontend-page .ng-pdp section.bc-reviews,
    body.frontend-page .ng-pdp .owner-info,
    body.frontend-page .bc_detail .ng-dateStrip,
    body.frontend-page .bc_detail section.bc-reviews,
    body.frontend-page .bc_detail .owner-info {
        padding: 0 !important;
        box-shadow: none !important;
    }
    /* Date strip mobile: sin padding/borde/sombra (solo los chips de días) */
    body.frontend-page .bc_detail .ng-dateStrip {
        padding: 0 !important;
        box-shadow: none !important;
        border: none !important;
    }
    /* Headings mobile escalan ligeramente */
    body.frontend-page .ng-pdp h2,
    body.frontend-page .ng-pdp .ab-section-title,
    body.frontend-page .bc_detail h2.text-22,
    body.frontend-page .bc_detail h3.text-22,
    body.frontend-page .ng-pdpInfo__title { font-size: 18px !important; }
    body.frontend-page .ng-pdp .ab-know-h { font-size: 15px !important; }
    body.frontend-page .ng-pdp .ng-pdpInfo__content,
    body.frontend-page .ng-pdp .ab-know-list li { font-size: 14px !important; line-height: 1.5 !important; }
}

/* === FIX: scroll vertical de página no se bloquea al swipear cards horizontalmente === */
/* El navegador maneja gestos verticales nativos; Swiper sólo recibe los horizontales. */
.js-section-slider,
.js-section-slider .swiper-wrapper,
.js-section-slider .swiper-slide,
.js-cars-slider,
.js-cars-slider .swiper-wrapper,
.js-cars-slider .swiper-slide,
.cardImage-slider,
.cardImage-slider .swiper-wrapper,
.cardImage-slider .swiper-slide,
.js-cardImage-slider,
.js-cardImage-slider .swiper-wrapper,
.js-cardImage-slider .swiper-slide {
    touch-action: pan-y !important;
}

/* === FAQ list · ajustes mobile === */
@media (max-width: 575px) {
    .bc-faq-lists .col-lg-8 {
        padding: 0 !important;
    }
    body.frontend-page .bc_detail .bc-faq-lists,
    body.frontend-page .ng-pdp .bc-faq-lists {
        border: none !important;
        box-shadow: none !important;
    }
}

/* === Reviews · padding interno === */
.bc-reviews .row {
    padding: 10px;
}

/* === Hero media col · sin padding en mobile/tablet === */
@media (max-width: 767px) {
    .ng-hero__mediaCol {
        padding: 0;
    }
}
