/* ==========================================================================
   Brasender Brand Components
   --------------------------------------------------------------------------
   Componentes y overrides de marca. Cargar SIEMPRE después de base.css
   (este archivo override reglas de base.css de forma controlada).

   Convención: cada bloque arranca con un comentario === Sección ===
   y agrupa todas las reglas relacionadas. No mezclar componentes.
   ========================================================================== */


/* ==========================================================================
   === Header (navy full-bleed, mobile + desktop) ===
   ========================================================================== */

.site-header {
    background: var(--brand-navy) !important;     /* gana contra cualquier inline residual */
    color: var(--text-on-dark);
    box-shadow: 0 2px 12px rgba(6, 26, 64, .25);
    /* Respetar el área segura del dispositivo cuando la app corre en
       modo PWA standalone en iPhone: el contenido se renderea bajo el
       notch / Dynamic Island, así que sumamos el inset al padding
       vertical y horizontal. En navegador normal env() es 0 → sin
       cambio. */
    padding-top: calc(10px + env(safe-area-inset-top));
    padding-bottom: 10px;
    padding-left: env(safe-area-inset-left);
    padding-right: env(safe-area-inset-right);
    border-bottom: none;
}

/* Hamburguesa móvil — ícono blanco sobre navy */
.site-header .menu-toggle,
.site-header .menu-toggle i {
    color: var(--text-on-dark);
}

.site-header .menu-toggle {
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    transition: var(--transition-base);
}

.site-header .menu-toggle:hover {
    background: rgba(255, 255, 255, .08);
}

/* En móvil ocultamos la hamburguesa: la nav móvil se hace por la
   bottom-nav (`mobile-nav-panel`), el sidebar lateral solo se
   abre desde escritorio. */
@media (max-width: 767.98px) {
    .site-header .menu-toggle { display: none; }
}

/* Logo: tamaño coherente mobile/desktop, sin height inline */
.site-header .logo-img {
    height: 40px !important;   /* mobile */
    width: auto;
    object-fit: contain;
    transition: var(--transition-base);
}

.site-header .logo-text {
    color: var(--text-on-dark);
}

@media (min-width: 992px) {
    .site-header {
        padding-top: calc(12px + env(safe-area-inset-top));
        padding-bottom: 12px;
    }
    .site-header .logo-img {
        height: 44px !important;
    }
}

/* En modo PWA standalone (app instalada), la Dynamic Island del
   iPhone es físicamente más alta que la status bar plana de
   modelos viejos: aunque env(safe-area-inset-top) ya da el inset
   correcto, visualmente el header queda "pegado" al pill flotante.
   Sumamos respiro extra solo cuando corre como PWA (no toca el
   navegador normal). */
@media (display-mode: standalone) {
    .site-header {
        padding-top: calc(18px + env(safe-area-inset-top));
    }
}

/* ==========================================================================
   === Nav Desktop (sobre navy) ===
   Override de los gradientes celestes anteriores que no encajan con la marca.
   ========================================================================== */

.site-header .nav-desktop a {
    color: var(--text-on-dark);
    background: transparent;
    box-shadow: none;
    font-weight: var(--font-weight-semibold);
    padding: 8px 14px;
    border-radius: var(--radius-md);
    transition: var(--transition-base);
}

.site-header .nav-desktop a:hover {
    background: rgba(255, 255, 255, .10);
    color: var(--text-on-dark);
    box-shadow: none;
    transform: none;
}

.site-header .nav-desktop a.active {
    background: var(--brand-red);
    color: var(--text-on-dark);
    box-shadow: var(--shadow-cta-red);
    transform: none;
}

.site-header .nav-desktop a.active:hover {
    background: var(--brand-red-dark);
}


/* ==========================================================================
   === Acciones del header (search, provincia, cart, login) ===
   ========================================================================== */

.site-header .cart-icon,
.site-header .user-icon {
    color: var(--text-on-dark);
    background: transparent;
    box-shadow: none;
}

.site-header .cart-icon:hover,
.site-header .user-icon:hover {
    color: var(--text-on-dark);
    background: rgba(255, 255, 255, .10);
    transform: none;
    box-shadow: none;
}

/* Badge del carrito — rojo Brasender, contraste sobre navy */
.site-header .cart-count {
    background: var(--brand-red);
    color: var(--text-on-dark);
    font-weight: var(--font-weight-bold);
    box-shadow: 0 0 0 2px var(--brand-navy);   /* anillo navy para separar visualmente */
}

/* Badge de provincia elegida — mismo estilo destacado que el carrito
   (rojo Brasender, bold, anillo navy) para que la sigla se vea bien
   sobre el header. Antes usaba navy-soft y se perdía visualmente. */
.site-header #provinciaTrigger .badge.bg-success {
    background-color: var(--brand-red) !important;
    color: var(--text-on-dark);
    font-weight: var(--font-weight-bold);
    box-shadow: 0 0 0 2px var(--brand-navy);
}

.site-header #provinciaTrigger .badge.bg-danger {
    background-color: var(--brand-red) !important;
    color: var(--text-on-dark);
    box-shadow: 0 0 0 2px var(--brand-navy);
}

/* Search bar (visible en desktop) — input claro sobre navy */
.site-header .search-bar input {
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .18);
    color: var(--text-on-dark);
}

.site-header .search-bar input::placeholder {
    color: rgba(255, 255, 255, .65);
}

.site-header .search-bar input:focus {
    background: rgba(255, 255, 255, .18);
    border-color: var(--brand-yellow);
    outline: none;
}

.site-header .search-bar button {
    background: transparent;
    border: none;
    color: var(--text-on-dark);
}

.site-header .search-bar i {
    color: rgba(255, 255, 255, .75);
}


/* ==========================================================================
   === Canopy (extensión navy debajo del header — la "media luna") ===
   Forma un bloque navy continuo con el header y se curva en la parte
   inferior con un border-radius generoso. El carrusel rojo flota dentro.
   ========================================================================== */

.brand-canopy {
    /* Franja navy independiente (sin contenido). Continúa el header y
       termina con curva. El banner rojo flota debajo, sobresaliendo. */
    height: 100px;
    background: var(--brand-navy);
    border-radius: 0 0 28px 28px;
    margin: 0;
}

@media (min-width: 768px) {
    .brand-canopy {
        height: 130px;
        border-radius: 0 0 40px 40px;
    }
}

/* Wrapper del banner: lo "sube" para que su mitad superior overlap con
   el navy y la inferior quede sobre el fondo claro de la página.
   En móvil mantiene el gutter del antiguo `.container` (12px) para
   que se vea exactamente igual que antes — esa vista NO se toca. En
   desktop el padding es mayor para respirar sin reproducir los huecos
   amplios del `.container` Bootstrap. */
.brand-promo-wrap {
    margin-top: -80px;
    position: relative;
    z-index: 2;
    padding: 0 12px;
}

@media (min-width: 768px) {
    .brand-promo-wrap {
        margin-top: -100px;
        padding: 0 32px;
    }
}


/* ==========================================================================
   === Carrusel de promociones (banner rojo dentro del canopy) ===
   ========================================================================== */

.brand-promo {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    /* Sombra solo en móvil — produce el efecto de «tarjeta flotante»
       sobre el canopy navy que se ve en la vista mobile y NO se
       modifica. En desktop la sombra se percibía como un marco/
       contorno raro y se quita por override más abajo. */
    box-shadow: 0 12px 30px rgba(0, 0, 0, .25);
}

@media (min-width: 768px) {
    .brand-promo {
        box-shadow: none;
    }
}

/* Mismo mecanismo que el carrusel de promos de recargas: scroll
   horizontal NATIVO con snap (inercia táctil del navegador). El
   autoplay/loop infinito lo gestiona carousel-autoplay.js vía
   [data-autoplay-carousel]. */
.brand-promo-track {
    display: flex;
    min-height: 200px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scrollbar-width: none;            /* Firefox: sin barra */
}
.brand-promo-track::-webkit-scrollbar { display: none; }  /* WebKit */

/* Cada slide ocupa el 100% del ancho de la ventana y es un punto de
   anclaje del scroll-snap. */
.brand-promo-slide {
    flex: 0 0 100%;
    width: 100%;
    min-width: 0;
    scroll-snap-align: start;
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 24px 22px;
    background: linear-gradient(135deg, var(--brand-red) 0%, var(--brand-red-dark) 100%);
    color: var(--text-on-dark);
}

/* Variante basada en imagen (modelo HeroPromotion v2).
   El banner ENTERO es una imagen subida por marketing — sin padding,
   sin fondo rojo, sin estrella decorativa: la imagen se encarga del
   diseño completo. El <picture> entrega versión móvil o desktop
   según viewport. */
.brand-promo-slide--image {
    padding: 0;
    background: transparent;
    overflow: hidden;
    border-radius: 16px;
}
/* Sin estrella decorativa en banners-imagen. Doble clase para ganar
   en especificidad a `.brand-promo-slide::before` (que se define
   DESPUÉS y, a igual peso, vencía por orden de cascada). */
.brand-promo-slide.brand-promo-slide--image::before { content: none; }
.brand-promo-link {
    display: block;
    width: 100%;
    line-height: 0;       /* anula gap fantasma debajo del <img> */
    text-decoration: none;
}
.brand-promo-img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 16px;
}

/* Dimensiones unificadas con el resto de la web principal — evita que
   el equipo de marketing tenga que crear imágenes en proporciones
   especiales solo para este banner. `aspect-ratio: 16/9` es el ratio
   estándar de la web (igual que YouTube/HD video). object-fit: cover
   recorta si el admin sube otra proporción.
   Dimensiones recomendadas para el admin:
   - image_desktop: 1280×720 (16:9).
   - image_mobile:   820×1000 (~0.82:1, vertical) — sin este media
     query, mantiene su proporción natural en móvil.
   Histórico: antes 1920×480 (4:1, banner-strip) — ver commit del
   2026-06-02 con el cambio. */
@media (min-width: 768px) {
    .brand-promo-img {
        aspect-ratio: 16 / 9;
        height: auto;
        max-height: 540px;
    }
}

/* Estrella decorativa de fondo (SVG inline) */
.brand-promo-slide::before {
    content: "";
    position: absolute;
    right: -20px;
    top: 50%;
    transform: translateY(-50%);
    width: 220px;
    height: 220px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><polygon points='50,5 61,38 96,38 67,58 78,92 50,72 22,92 33,58 4,38 39,38' fill='white' opacity='0.07'/></svg>") center/contain no-repeat;
    pointer-events: none;
}

.brand-promo-badge {
    flex-shrink: 0;
    background: var(--brand-red-dark);
    color: var(--brand-yellow);
    font-weight: var(--font-weight-black);
    font-size: 1.4rem;
    line-height: 1;
    padding: 10px 12px;
    border-radius: 8px;
    box-shadow: 0 3px 10px rgba(0, 0, 0, .25);
    display: inline-flex;
    align-items: baseline;
    gap: 2px;
    align-self: flex-start;
    margin-top: 4px;
}

.brand-promo-badge small {
    font-size: 0.75rem;
    font-weight: var(--font-weight-bold);
}

.brand-promo-text {
    flex: 1;
    min-width: 0;
}

.brand-promo-title {
    font-size: 1.5rem;
    line-height: 1.05;
    font-weight: var(--font-weight-black);
    color: var(--text-on-dark);
    text-transform: uppercase;
    margin: 0 0 6px;
    letter-spacing: -0.01em;
}

.brand-promo-title .hl {
    color: var(--brand-yellow);
}

.brand-promo-subtitle {
    font-size: 0.95rem;
    color: rgba(255, 255, 255, .92);
    margin: 0 0 14px;
    font-weight: var(--font-weight-medium);
}

.brand-promo-cta {
    display: inline-block;
    background: var(--brand-yellow);
    color: var(--brand-navy);
    font-weight: var(--font-weight-black);
    font-size: 0.85rem;
    letter-spacing: 0.04em;
    padding: 10px 18px;
    border-radius: var(--radius-pill);
    text-transform: uppercase;
    box-shadow: 0 4px 12px rgba(0, 0, 0, .25);
    transition: var(--transition-base);
}

.brand-promo-cta:hover {
    background: var(--brand-yellow-dark);
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, .30);
    color: var(--brand-navy);
}

@media (min-width: 768px) {
    .brand-promo-track { min-height: 240px; }
    .brand-promo-slide { padding: 36px 40px; gap: 28px; }
    .brand-promo-title { font-size: 2.2rem; }
    .brand-promo-subtitle { font-size: 1.05rem; }
    .brand-promo-badge { font-size: 1.8rem; padding: 12px 16px; }
    .brand-promo-slide::before { width: 320px; height: 320px; right: -40px; }
}

/* --- Dots del carrusel: eliminados. El carrusel se controla con
   arrastre táctil (ver brand-carousel.js) y rota solo en bucle. --- */


/* ==========================================================================
   === Quick Services (círculos navy estilo Brasender) ===
   Override de los gradients inline anteriores. El HTML ya no tiene
   `style=` en .service-icon, así que estas reglas ganan limpiamente.
   ========================================================================== */

.quick-services {
    padding: 28px 0 16px;
    background: transparent;
}

/* ── Mobile (<768): scroll horizontal con snap ──────────────────────
   Permite N servicios sin que el último quede solo en una fila. Cada
   ítem hace snap al scroll, igual al patrón de categorías-scroll que
   ya usa la app. Se oculta el scrollbar para look "app móvil". */
.quick-services .services-grid {
    display: flex;
    gap: 8px;
    padding: 0 16px 6px;
    /* Estático: las 4 tarjetas reparten el ancho, sin scroll horizontal.
       (Decisión: hoy son fijas; si se agregan más, se vuelve a un carrusel.) */
    overflow: hidden;
    margin: 0 -16px; /* full-bleed: rompe el container para llegar a los bordes */
}

.quick-services .service-card {
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 8px 4px;
    background: transparent;
    box-shadow: none;
    border-radius: var(--radius-md);
    text-decoration: none;
    transition: var(--transition-base);
}

@media (pointer: fine) {
    .quick-services .service-card:hover { transform: translateY(-2px); }
}

.quick-services .service-icon {
    width: 60px;
    height: 60px;
    background: var(--brand-navy) !important;   /* mata cualquier inline residual */
    color: var(--text-on-dark);
    border-radius: var(--radius-circle);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    box-shadow: var(--shadow-icon-navy);
    transition: var(--transition-base);
}

.quick-services .service-card:hover .service-icon {
    background: var(--brand-navy-dark) !important;
    transform: scale(1.05);
    box-shadow: 0 8px 20px rgba(10, 38, 88, .35);
}

.quick-services .service-info h3 {
    font-size: 0.85rem;
    font-weight: var(--font-weight-bold);
    color: var(--text-strong);
    margin: 0;
    text-align: center;
    line-height: 1.15;
    /* Truncar a 2 líneas máximo para que la altura sea pareja */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ── Tablet+ (≥768): grid auto-fit ──────────────────────────────────
   Centro la grilla, no llenamos todo el ancho. `auto-fit minmax(...)`
   escala automáticamente a 3, 4 o 5 columnas según el ancho real, así
   nunca queda un item solo en una fila. */
@media (min-width: 768px) {
    .quick-services { padding: 36px 0 20px; }
    .quick-services .services-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
        gap: 16px;
        max-width: 720px;
        margin: 0 auto;
        padding: 0;
        overflow: visible;
    }
    .quick-services .service-card { width: auto; }
    .quick-services .service-icon {
        width: 72px;
        height: 72px;
        font-size: 1.7rem;
    }
    .quick-services .service-info h3 { font-size: 1.05rem; }
}


/* ==========================================================================
   === Bottom Nav (mobile-nav-panel) — paleta Brasender ===
   Override de los gradientes celestes anteriores. Items inactivos en navy,
   item activo en rojo Brasender, y el item central (#servicesBtn) sobresale
   como un círculo navy grande con anillo blanco — exacto como el mockup.
   ========================================================================== */

.mobile-nav-panel {
    background: var(--surface-card) !important;
    box-shadow: 0 -2px 12px rgba(10, 38, 88, .08);
    border-top: 1px solid var(--surface-muted);
    border-top-left-radius: 24px;
    border-top-right-radius: 24px;
    padding: 8px 6px env(safe-area-inset-bottom, 8px);
}

/* Reset del item: sin gradientes, sin sombras celestes */
.mobile-nav-item .mobile-nav-icon {
    background: transparent !important;
    box-shadow: none !important;
    color: var(--brand-navy) !important;
    font-size: 1.3rem;
    border-radius: var(--radius-md);
    transition: color .2s, transform .2s;
}

.mobile-nav-item:hover .mobile-nav-icon {
    background: transparent !important;
    color: var(--brand-navy-dark) !important;
    box-shadow: none !important;
    transform: none;
}

.mobile-nav-item:active {
    background: transparent !important;
}

.mobile-nav-item:active .mobile-nav-icon {
    transform: scale(.92);
    box-shadow: none !important;
}

.mobile-nav-item .mobile-nav-label {
    color: var(--brand-navy);
    font-weight: var(--font-weight-semibold);
    font-size: 0.66rem;
    margin-top: 4px;
}

/* Item activo: ícono rojo + label navy bold + barrita roja arriba */
.mobile-nav-item.active .mobile-nav-icon {
    background: transparent !important;
    color: var(--brand-red) !important;
    box-shadow: none !important;
    transform: none !important;
}

.mobile-nav-item.active .mobile-nav-label {
    color: var(--brand-navy-dark);
    font-weight: var(--font-weight-bold);
}

.mobile-nav-item.active::before {
    background: var(--brand-red) !important;
    width: 24px !important;
    height: 3px !important;
    border-radius: 0 0 4px 4px;
}

/* === Item central (#servicesBtn) — círculo navy sobresaliente === */
.mobile-nav-item#servicesBtn {
    position: relative;
}

.mobile-nav-item#servicesBtn .mobile-nav-icon {
    width: 56px !important;
    height: 56px !important;
    background: var(--brand-navy) !important;
    color: var(--text-on-dark) !important;
    border-radius: var(--radius-circle);
    box-shadow: var(--shadow-icon-navy) !important;
    transform: translateY(-18px);
    font-size: 1.45rem;
    border: 4px solid var(--surface-card);   /* anillo blanco que lo separa del nav */
}

.mobile-nav-item#servicesBtn .mobile-nav-label {
    margin-top: -12px;          /* compensa el ícono levantado */
    color: var(--brand-navy-dark);
    font-weight: var(--font-weight-bold);
}

.mobile-nav-item#servicesBtn:hover .mobile-nav-icon,
.mobile-nav-item#servicesBtn:active .mobile-nav-icon {
    background: var(--brand-navy-dark) !important;
    color: var(--text-on-dark) !important;
    transform: translateY(-18px) scale(1.04);
}

/* El item central nunca queda "active" en el sentido de ruta (es un toggle
   del sheet de servicios), así que evitamos que herede el ícono rojo. */
.mobile-nav-item#servicesBtn.active .mobile-nav-icon {
    color: var(--text-on-dark) !important;
}

.mobile-nav-item#servicesBtn.active::before {
    display: none;   /* no necesita la barrita roja arriba */
}

/* === Badge sobre el ícono (ej: "Hab" para Habana, "9" para notificaciones) === */
.mobile-nav-item .mobile-nav-icon {
    position: relative;
}

.mobile-nav-badge {
    position: absolute;
    top: -4px;
    right: -10px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: 9px;
    background: var(--brand-red);
    color: var(--text-on-dark);
    font-size: 0.62rem;
    font-weight: var(--font-weight-bold);
    line-height: 18px;
    text-align: center;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
    pointer-events: none;
    white-space: nowrap;
}

.mobile-nav-item#servicesBtn .mobile-nav-badge {
    top: -22px;     /* compensa el ícono central levantado (translateY -18px) */
    right: 2px;
}

/* === Botón Inicio fijo con imagen (menu.png) === */
.mobile-nav-icon--img {
    display: flex;
    align-items: center;
    justify-content: center;
}

.mobile-nav-icon--img img {
    width: 26px;
    height: 26px;
    object-fit: contain;
    transition: transform .2s;
}

.mobile-nav-item--home:active .mobile-nav-icon--img img {
    transform: scale(.92);
}
