/**
 * umbral-frontend.css
 * Estilos personalizados del Frontend público — Umbral CMS
 * Bootstrap 5.3 como base · Century Gothic vía font-face local o Google Fonts
 *
 * Paleta oficial Umbral:
 *   Gris oscuro texto : #3b3a3a / #777777 / #646464
 *   Naranja primario  : #ff6000 / #FF6F2D
 *   Amarillo dorado   : #FFBA26 / #FFC600
 *   Teal/Turquesa     : #42B0B7
 *   Azul              : #1655AD / #6c86ab
 *   Verde             : #92C344
 *   Morado            : #9E83B2
 *   Blanco            : #ffffff
 */

/* ─────────────────────────────────────────────────────────────────────────────
   VARIABLES CSS — Paleta y configuración global
   ───────────────────────────────────────────────────────────────────────────── */
:root {
    /* Colores principales */
    --umbral-orange:        #ff6000;
    --umbral-orange-light:  #FF6F2D;
    --umbral-gold:          #FFBA26;
    --umbral-gold-dark:     #FFB30F;
    --umbral-teal:          #42B0B7;
    --umbral-blue:          #1655AD;
    --umbral-blue-light:    #6c86ab;
    --umbral-green:         #92C344;
    --umbral-purple:        #9E83B2;

    /* Grises */
    --umbral-gray-dark:     #3b3a3a;
    --umbral-gray-mid:      #646464;
    --umbral-gray:          #777777;
    --umbral-gray-light:    #797979;

    /* Fondos */
    --umbral-bg-header:     #ffffff;
    --umbral-bg-navbar:     var(--umbral-orange);       /* barra de menú */
    --umbral-bg-footer:     var(--umbral-gray);
    --umbral-bg-footer-bot: var(--umbral-gray-mid);

    /* Topbar */
    --umbral-topbar-height: 90px;

    /* Transiciones */
    --umbral-transition: 0.22s ease;

    --orange-tone-1: #f38f01; /* Naranja Vibrante */
    --orange-tone-2: #ff6000; /* Naranja Suave */
    --orange-tone-3: #ff7200; /* Naranja Claro */
    --orange-tone-4: #ff7e00; /* Naranja Muy Claro */

    --sp-radius-btn:    6px;
}

.content-wrapper {
    max-width: 1400px;
    margin-inline: auto;
    width: 100%;
}

.banner-container {
    padding: 0;
    overflow: hidden;
    line-height: 0; /* Elimina espacios extra debajo de la imagen */
}

.banner-container img {
    width: 100%;
    height: auto;
    min-height: 300px; /* Altura mínima aceptable en móvil */
    object-fit: cover;
}

@media (min-width: 1025px) {
    .banner-container img {
        min-height: 423px; /* Altura original para desktop */
    }
}

/* ─────────────────────────────────────────────────────────────────────────────
   TIPOGRAFÍA — Century Gothic (fallback system-ui para dispositivos sin ella)
   Si se usa Google Fonts, reemplazar con @import de Nunito o similar.
   ───────────────────────────────────────────────────────────────────────────── */
body.umbral-body {
    /*font-family: 'Century Gothic', 'CenturyGothic', 'AppleGothic', Tahoma, sans-serif;*/
    color: var(--umbral-gray-dark);
    background-color: #ffffff;
    font-family: 'Open Sans', sans-serif;
}

/* Acento naranja reutilizable */
.umbral-accent {
    color: var(--umbral-orange) !important;
}

.umbral-accent-icon {
    color: var(--umbral-orange);
}


/* ─────────────────────────────────────────────────────────────────────────────
   TOPBAR — Área superior: logo + contacto + redes  (solo escritorio ≥ lg)
   ───────────────────────────────────────────────────────────────────────────── */
.umbral-topbar {
    background-color: var(--umbral-bg-header);
    min-height: var(--umbral-topbar-height);
    padding: 12px 0;
    border-bottom: 1px solid #f0f0f0;
}

/* Logo en topbar */
.umbral-logo-link {
    display: inline-block;
    transition: opacity var(--umbral-transition);
}
.umbral-logo-link:hover { opacity: 0.85; }
.umbral-logo { max-height: 160px; }

/* Bloque de contacto alineado a la derecha */
.umbral-topbar-contact { line-height: 1.35; }

/* Teléfonos */
.umbral-phones { font-size: 1.05rem; font-weight: 600; }
.umbral-phone-link {
    color: var(--umbral-gray-dark);
    text-decoration: none;
    transition: color var(--umbral-transition);
}
.umbral-phone-link:hover { color: var(--umbral-orange); }

/* Email */
.umbral-email { font-size: 0.9rem; }
.umbral-email-link {
    color: var(--umbral-gray-dark);
    text-decoration: none;
    transition: color var(--umbral-transition);
}
.umbral-email-link:hover { color: var(--umbral-orange); }

/* Texto "síguenos en" */
.umbral-siguenos {
    font-size: 0.8rem;
    color: var(--umbral-gray);
    font-style: italic;
}


/* ─────────────────────────────────────────────────────────────────────────────
   REDES SOCIALES — Iconos (topbar, navbar móvil, offcanvas, footer)
   ───────────────────────────────────────────────────────────────────────────── */
.umbral-social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    color: #ffffff;
    font-size: 0.85rem;
    text-decoration: none;
    transition: transform var(--umbral-transition), opacity var(--umbral-transition);
}
.umbral-social-link:hover {
    color: #ffffff;
    opacity: 0.82;
    transform: scale(1.1);
}

/* Colores específicos por red */
.umbral-social-facebook  { background-color: #1877f2; }
.umbral-social-instagram { background: radial-gradient(circle at 30% 107%, #fdf497 0%, #fd5949 45%, #d6249f 60%, #285aeb 90%); }

/* Tamaño grande (offcanvas y footer) */
.umbral-social-lg {
    width: 38px;
    height: 38px;
    font-size: 1rem;
}


/* ─────────────────────────────────────────────────────────────────────────────
   NAVBAR — Barra de menú horizontal (escritorio)
   Degradado naranja: simula el diseño original de tabla
   ───────────────────────────────────────────────────────────────────────────── */
.umbral-navbar {
    /*background: linear-gradient(to bottom, #ff7a1a 0%, var(--umbral-orange) 50%, #d94f00 100%);
    /border-top: 1px solid rgba(255,255,255,0.15);
    border-bottom: 2px solid #c04400;*/
    min-height: 42px;
}

/* Ítems del menú desktop */
.umbral-nav-menu {
    list-style: none;
    margin: 0;
    padding: 0;
}

.umbral-nav-menu .nav-item { position: relative; }

.umbral-nav-menu .nav-link {
    color: #ffffff !important;
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    padding: 10px 6px;
    white-space: nowrap;
    /*transition: background-color var(--umbral-transition), color var(--umbral-transition);
    border-right: 1px solid rgba(255,255,255,0.18);*/
}

.umbral-nav-menu .nav-item:first-child .nav-link { border-left: 1px solid rgba(255,255,255,0.18); }

.umbral-nav-menu .nav-link:hover,
.umbral-nav-menu .nav-link:focus {
    background-color: rgba(0,0,0,0.18);
    color: #ffffff !important;
}

.umbral-nav-menu .nav-link.active {
    /*background-color: rgba(0,0,0,0.25);
    color: var(--umbral-gold) !important;*/
    background-color: var(--umbral-teal);
    color: #ffffff !important;
}

/* Ítems con color especial: Registro y Contáctanos */
/*.umbral-nav-registro .nav-link  { background-color: rgba(255,198,0,0.22); }
.umbral-nav-contacto .nav-link  { background-color: rgba(0,0,0,0.2); }

.umbral-nav-registro .nav-link:hover { background-color: rgba(255,198,0,0.38); }
.umbral-nav-contacto .nav-link:hover { background-color: rgba(0,0,0,0.35); }*/


/* ─────────────────────────────────────────────────────────────────────────────
   NAVBAR MÓVIL / TABLET — Rediseño v3
   Solo aplica en < lg (991.98px), sin tocar el desktop
   ───────────────────────────────────────────────────────────────────────────── */

@media (max-width: 991.98px) {

    /* ── Barra general ── */
    .umbral-navbar {
        min-height: 70px;
        background-color: #ffffff;
        border-bottom: 3px solid var(--umbral-orange);
        padding: 0 !important;
    }

    /* ── Toggler hamburguesa ── */
    .umbral-toggler {
        width: 40px;
        height: 40px;
        border-radius: 9px !important;
        background-color: #fff3e8 !important;
        border: 1.5px solid rgba(255, 96, 0, 0.22) !important;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0 !important;
        flex-shrink: 0;
        transition: background-color var(--umbral-transition), border-color var(--umbral-transition);
        order: 1;
    }
    .umbral-toggler:focus {
        box-shadow: 0 0 0 3px rgba(255, 96, 0, 0.18) !important;
    }
    .umbral-toggler:hover {
        background-color: #ffe8d6 !important;
        border-color: rgba(255, 96, 0, 0.4) !important;
    }
    .umbral-toggler .navbar-toggler-icon {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='%23ff6000' stroke-width='2.5' stroke-linecap='round' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E") !important;
        width: 20px;
        height: 20px;
    }

    /* ── Logo: centrado en móvil ── */
    .umbral-navbar-brand-mobile {
        line-height: 1;
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
        /*order: 2;*/
        margin: 0 !important;
    }

    /* ── Chip de teléfonos: oculto en móvil ── */
    .umbral-navbar-phone-chip {
        display: none;
    }

    /* ── Redes sociales: cuadradas, mismo tamaño ── */
    .umbral-mobile-social {
        order: 3;
        gap: 7px !important;
        margin-left: auto;
    }
    .umbral-mobile-social .umbral-social-link {
        width: 34px;
        height: 34px;
        border-radius: 9px;
        font-size: 0.85rem;
        flex-shrink: 0;
    }
}

/* ── Tablet (768px – 991px) — sobreescribe lo anterior ── */
@media (min-width: 768px) and (max-width: 991.98px) {

    .umbral-navbar { min-height: 70px; }

    .umbral-toggler {
        width: 46px;
        height: 46px;
        border-radius: 11px !important;
    }
    .umbral-toggler .navbar-toggler-icon {
        width: 22px;
        height: 22px;
    }

    /* Logo: sale del centrado absoluto, vuelve al flujo izquierda */
    .umbral-navbar-brand-mobile {
        position: static;
        transform: none;
        margin-left: 10px !important;
        order: 2;
    }
    .umbral-navbar-brand-mobile img { width: 92px !important; }

    /* Chip de teléfonos: visible, empuja todo lo que sigue a la derecha */
    .umbral-navbar-phone-chip {
        display: flex !important;
        align-items: center;
        gap: 9px;
        background: #fff3e8;
        border: 1px solid rgba(255, 96, 0, 0.18);
        border-radius: 9px;
        padding: 6px 12px;
        text-decoration: none;
        transition: background-color var(--umbral-transition);
        margin-left: auto;
        order: 3;
        flex-shrink: 0;
    }
    .umbral-navbar-phone-chip:hover { background: #ffe8d6; }

    .umbral-navbar-phone-icon {
        width: 22px;
        height: 22px;
        background: var(--umbral-orange);
        border-radius: 5px;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
    }
    .umbral-navbar-phone-icon i {
        color: #fff;
        font-size: 0.7rem;
    }
    .umbral-navbar-phone-numbers {
        display: flex;
        flex-direction: column;
        line-height: 1.3;
    }
    .umbral-navbar-phone-numbers span {
        font-size: 0.75rem;
        font-weight: 600;
        color: var(--umbral-gray-dark);
        white-space: nowrap;
    }

    /* Redes en tablet: sin margin-left (ya lo tiene el chip) */
    .umbral-mobile-social {
        margin-left: 0 !important;
        order: 4;
    }
    .umbral-mobile-social .umbral-social-link {
        width: 38px;
        height: 38px;
        border-radius: 10px;
        font-size: 0.9rem;
    }
}


/* ─────────────────────────────────────────────────────────────────────────────
   OFFCANVAS — Menú lateral móvil/tablet — REDISEÑO v2
   ─────────────────────────────────────────────────────────────────────────────
   Paleta oscura coherente con el header, íconos con fondo pill,
   indicador activo con barra naranja lateral, agrupación por secciones.
   ───────────────────────────────────────────────────────────────────────────── */

/* ── Contenedor principal ── */
.umbral-offcanvas {
    background-color: #1a1a2e;
    max-width: 300px;
    width: 85vw;
    border-right: 1px solid rgba(255, 255, 255, 0.06);
}

/* ── Header ── */
.umbral-offcanvas .offcanvas-header {
    background: linear-gradient(135deg, #1c1c2e 0%, #2a1f3d 100%);
    padding: 1.1rem 1.25rem 1rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    align-items: flex-start;
}

/* Logo en offcanvas (img) */
.umbral-offcanvas- .offcanvas-header- a img {
    filter: brightness(0) invert(1);   /* fuerza versión blanca del logo */
}

/* Botón cerrar */
.umbral-offcanvas-close {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.08) !important;
    opacity: 1 !important;
    filter: invert(1);
    transition: background-color var(--umbral-transition);
    flex-shrink: 0;
    margin-top: 2px;
}
.umbral-offcanvas-close:hover {
    background: rgba(255, 255, 255, 0.15) !important;
}

/* ── Body ── */
.umbral-offcanvas .offcanvas-body {
    background-color: #1a1a2e;
    padding: 0.5rem 0 0;
    display: flex;
    flex-direction: column;
}

/* ── Etiquetas de sección (CONTENIDO / ACCIÓN) ── */
.umbral-offcanvas-nav-label {
    padding: 0.6rem 1.25rem 0.3rem;
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.25);
    user-select: none;
}

/* ── Lista de navegación ── */
.umbral-offcanvas-nav {
    gap: 0;
    padding: 0.25rem 0;
}

.umbral-offcanvas-nav .nav-link {
    display: flex;
    align-items: center;
    gap: 14px;
    color: rgba(255, 255, 255, 0.65);
    font-size: 0.875rem;
    font-weight: 500;
    padding: 0.7rem 1.25rem;
    border-bottom: none;                    /* sin separadores planos */
    position: relative;
    transition:
        background-color var(--umbral-transition),
        color var(--umbral-transition),
        padding-left var(--umbral-transition);
}

/* Barra lateral indicador hover */
.umbral-offcanvas-nav .nav-link::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%) scaleY(0);
    width: 3px;
    height: 60%;
    background: var(--umbral-orange);
    border-radius: 0 3px 3px 0;
    transition: transform var(--umbral-transition);
}

/* Ícono envuelto en píldora */
.umbral-offcanvas-nav .nav-link i {
    width: 32px;
    height: 32px;
    background: rgba(255, 255, 255, 0.07);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.55);
    flex-shrink: 0;
    transition: background-color var(--umbral-transition), color var(--umbral-transition);
}

/* ── Hover ── */
.umbral-offcanvas-nav .nav-link:hover,
.umbral-offcanvas-nav .nav-link:focus {
    background-color: rgba(255, 255, 255, 0.04);
    color: #ffffff;
    padding-left: 1.25rem;              /* sin desplazamiento de texto */
}
.umbral-offcanvas-nav .nav-link:hover::before,
.umbral-offcanvas-nav .nav-link:focus::before {
    transform: translateY(-50%) scaleY(1);
}
.umbral-offcanvas-nav .nav-link:hover i,
.umbral-offcanvas-nav .nav-link:focus i {
    background: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.9);
}

/* ── Estado activo ── */
.umbral-offcanvas-nav .nav-link.active {
    color: var(--umbral-orange);
    font-weight: 600;
    background: linear-gradient(90deg, rgba(255, 96, 0, 0.12) 0%, transparent 100%);
}
.umbral-offcanvas-nav .nav-link.active::before {
    transform: translateY(-50%) scaleY(1);
}
.umbral-offcanvas-nav .nav-link.active i {
    background: rgba(255, 96, 0, 0.2);
    color: var(--umbral-orange);
}

/* ── Divider fino entre grupos ── */
.umbral-offcanvas-section-divider {
    height: 1px;
    background: rgba(255, 255, 255, 0.06);
    margin: 0.4rem 1.25rem;
}

/* ── CTA "Línea de ayuda" ── */
.umbral-offcanvas-cta {
    margin: 0.5rem 1rem 0.25rem;
    background: linear-gradient(135deg, var(--umbral-orange) 0%, var(--umbral-orange-light) 100%);
    border-radius: 10px;
    padding: 0.75rem 1rem;
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    transition: opacity var(--umbral-transition), transform var(--umbral-transition);
}
.umbral-offcanvas-cta:hover {
    opacity: 0.92;
    transform: translateY(-1px);
}
.umbral-offcanvas-cta-icon {
    font-size: 1.4rem;
    flex-shrink: 0;
}
.umbral-offcanvas-cta-text {
    display: flex;
    flex-direction: column;
}
.umbral-offcanvas-cta-title {
    color: #fff;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.3px;
    line-height: 1.2;
}
.umbral-offcanvas-cta-numbers {
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.72rem;
    margin-top: 2px;
}

/* ── Contacto rápido ── */
.umbral-offcanvas-contact {
    margin-top: auto;
    padding: 1rem 1.25rem;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(0, 0, 0, 0.2);
}

.umbral-offcanvas-contact-item {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}
.umbral-offcanvas-contact-item:last-of-type { margin-bottom: 0; }

.umbral-offcanvas-contact-icon {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    background: rgba(255, 96, 0, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.umbral-offcanvas-contact-icon i {
    font-size: 0.75rem;
    color: var(--umbral-orange);
}

.umbral-offcanvas-contact-link {
    color: rgba(255, 255, 255, 0.6);
    text-decoration: none;
    font-size: 0.825rem;
    transition: color var(--umbral-transition);
}
.umbral-offcanvas-contact-link:hover { color: #ffffff; }

/* ── Redes sociales ── */
.umbral-offcanvas-contact .umbral-social-link {
    width: 36px;
    height: 36px;
    border-radius: 9px;
    font-size: 0.85rem;
}
.umbral-offcanvas-contact .umbral-social-link.umbral-social-facebook {
    background: #1877f2;
    color: #fff;
}
.umbral-offcanvas-contact .umbral-social-link.umbral-social-instagram {
    background: linear-gradient(135deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
    color: #fff;
}






















/* ─────────────────────────────────────────────────────────────────────────────
   CONTENIDO PRINCIPAL
   ───────────────────────────────────────────────────────────────────────────── */
#umbral-main { min-height: 60vh; }


/* ─────────────────────────────────────────────────────────────────────────────
   FOOTER PRINCIPAL
   ───────────────────────────────────────────────────────────────────────────── */
.umbral-footer-main {
    background-color: var(--umbral-bg-footer);
    padding: 2.5rem 0 2rem;
}

.umbral-footer-heading {
    color: #ffffff;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 1rem;
    padding-bottom: 0.4rem;
    border-bottom: 2px solid var(--umbral-orange);
    display: inline-block;
}

/* Lista de links del footer */
.umbral-footer-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.umbral-footer-list li { margin-bottom: 0.45rem; }

.umbral-footer-link {
    color: rgba(255,255,255,0.85);
    font-size: 0.875rem;
    text-decoration: none;
    transition: color var(--umbral-transition), padding-left var(--umbral-transition);
    display: inline-block;
}
.umbral-footer-link:hover {
    color: var(--umbral-gold);
    padding-left: 4px;
}
.umbral-footer-link i { color: var(--umbral-orange); }

/* Teléfonos y email del footer */
.umbral-footer-phones,
.umbral-footer-email {
    font-size: 0.875rem;
}
.umbral-footer-phone-link,
.umbral-footer-email-link {
    color: rgba(255,255,255,0.9);
    text-decoration: none;
    transition: color var(--umbral-transition);
}
.umbral-footer-phone-link:hover,
.umbral-footer-email-link:hover { color: var(--umbral-gold); }

/* "Síguenos en" en footer */
.umbral-siguenos-footer {
    font-size: 0.8rem;
    color: rgba(255,255,255,0.7);
    font-style: italic;
}

/* Redes en footer (heredan .umbral-social-link + .umbral-social-lg) */
.umbral-footer-social { flex-wrap: wrap; }


/* ─────────────────────────────────────────────────────────────────────────────
   FOOTER BOTTOM — Franja inferior oscura con borde dorado
   ───────────────────────────────────────────────────────────────────────────── */
.umbral-footer-bottom {
    background-color: var(--umbral-bg-footer-bot);
    border-bottom: 8px solid var(--umbral-gold);
    padding: 0.85rem 0;
}

/* Texto legal */
.umbral-footer-legal {
    font-size: 0.82rem;
    color: rgba(255,255,255,0.9);
}
.umbral-footer-legal-link {
    color: rgba(255,255,255,0.85);
    text-decoration: none;
    transition: color var(--umbral-transition);
}
.umbral-footer-legal-link:hover { color: var(--umbral-gold); }

/* Separador | */
.umbral-footer-separator { color: rgba(255,255,255,0.4); }

/* Menú secundario del footer */
.umbral-footer-nav { display: flex; flex-wrap: wrap; justify-content: center; gap: 0.15rem; align-items: center; }

.umbral-footer-nav-link {
    color: rgba(255,255,255,0.85);
    font-size: 0.8rem;
    text-decoration: none;
    transition: color var(--umbral-transition);
}
.umbral-footer-nav-link:hover { color: var(--umbral-gold); }
.umbral-footer-nav-link.umbral-accent { color: var(--umbral-gold) !important; }
.umbral-footer-nav-link.umbral-accent:hover { color: #ffffff !important; }

.text-blue-light {
    color: var(--umbral-blue-light);
}

.text-gray-mid {
    color: var(--umbral-gray-mid);
}

.text-gray {
    color: var(--umbral-gray);
}

.section-badge--gold-dark { background-color: var(--umbral-gold-dark); }
.section-badge--green  { background-color: var(--umbral-green); }
.section-badge--teal   { background-color: var(--umbral-teal); }
.section-badge--blue   { background-color: var(--umbral-blue); }
.section-badge--orange { background-color: var(--umbral-orange); }

.section-badge {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: 'Nunito', sans-serif;
    font-weight: 700;
    font-size: 1.1rem;
    color: white;
    width: 100%;
}

/* Header vacío del carousel — misma altura que los demás card-headers */
.umbral-carousel-header {
    min-height: 52px;
    opacity: 0;
    pointer-events: none;
    background-color: transparent !important;
    border-bottom: none !important;
}

.section-badge .badge-btn {
    background: rgba(255,255,255,0.25);
    border: none;
    border-radius: 50%;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 0.8rem;
    cursor: pointer;
    text-decoration: none;
}

.section-badge a {
    color: #ffffff;
    text-decoration: none;
}

/* Texto intro responsivo */
.w-md-75 { width: 75% !important; }

@media (max-width: 767.98px) {
    .w-md-75 { width: 100% !important; }
}

/* ─────────────────────────────────────────────────────────────────────────────
   RESPONSIVE TWEAKS
   ───────────────────────────────────────────────────────────────────────────── */

/* Tablet (md) */
/* Navbar móvil: distribución de 3 elementos */
@media (max-width: 991.98px) {
    .umbral-navbar .container-xl {
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
    /*.umbral-navbar-brand-mobile {
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
    }*/
}

/* Móvil (sm) */
@media (max-width: 575.98px) {
    .umbral-footer-nav { gap: 0.1rem; }
    .umbral-footer-nav-link { font-size: 0.72rem; }
}

/* Para pantallas grandes (min-width: 992px) */
@media (min-width: 992px) {
    /* ESTILO PARA EL FONDO AMARILLO DE ANCHO COMPLETO */
    /* Este div mantiene su color original para desktop */
    .menu-full-width-bg- {
        background-color: var(--umbral-gold-dark); /* Usa tu color de escritorio si es diferente al warning */
        /* Aquí puedes definir un color específico para desktop, si bg-warning no es suficiente */
    }

    /* Asignación de tonos por posición para el degradado en escritorio */
    .menu-degradado .nav-item:nth-child(1) {
      background-color: var(--orange-tone-1);
    }
    .menu-degradado .nav-item:nth-child(2) {
      background-color: var(--orange-tone-2);
    }
    .menu-degradado .nav-item:nth-child(3) {
      background-color: var(--orange-tone-3);
    }
    .menu-degradado .nav-item:nth-child(4) {
      background-color: var(--orange-tone-4);
    }
    .menu-degradado .nav-item:nth-child(5) {
      background-color: var(--orange-tone-1);
    }
    .menu-degradado .nav-item:nth-child(6) {
      background-color: var(--orange-tone-2);
    }
    .menu-degradado .nav-item:nth-child(7) {
      background-color: var(--orange-tone-3);
    }
    .menu-degradado .nav-item:nth-child(8) {
      background-color: var(--orange-tone-4);
    }

}

/* =========================================
   Alertas Personalizadas (Formularios)
   ========================================= */

/* Éxito (Verde) */
.contact-alert-success {
    background: #eaf7f0;
    border-left: 4px solid #28a745;
    border-radius: var(--sp-radius-btn);
    color: #1a6633;
    padding: 1rem 1.25rem;
    font-size: .92rem;
    margin-bottom: 1.25rem;
}

/* Error (Rojo) */
.contact-alert-error {
    background: #fff4f4;
    border-left: 4px solid #dc3545;
    border-radius: var(--sp-radius-btn);
    color: #9b1c1c;
    padding: 1rem 1.25rem;
    font-size: .92rem;
    margin-bottom: 1.25rem;
}

/* Información (Azul) */
.contact-alert-info {
    background: #eef5fb;
    border-left: 4px solid #0d6efd;
    border-radius: var(--sp-radius-btn);
    color: #0a3d70;
    padding: 1rem 1.25rem;
    font-size: .92rem;
    margin-bottom: 1.25rem;
}

/* Advertencia (Amarillo/Naranja) */
.contact-alert-warning {
    background: #fff9e6;
    border-left: 4px solid #ffc107;
    border-radius: var(--sp-radius-btn);
    color: #856404;
    padding: 1rem 1.25rem;
    font-size: .92rem;
    margin-bottom: 1.25rem;
}

.custom-alert-close {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    line-height: 1;
    font-size: 1rem;
    opacity: .7;
}

.custom-alert-close:hover {
    opacity: 1;
}

/* Color heredado del contenedor padre */
.contact-alert-error .custom-alert-close   { color: #9b1c1c; }
.contact-alert-info .custom-alert-close    { color: #1e40af; }
.contact-alert-success .custom-alert-close { color: #166534; }
.contact-alert-warning .custom-alert-close { color: #92400e; }