﻿#header-outer[data-format=centered-menu] #top .span_9,#header-outer[data-format=centered-menu] #top .span_9 .sf-menu:not(.buttons) {
    left:0;
    position:relative;
    text-align:center;
    width:100%;
    z-index:1
}
#header-outer[data-format=centered-menu] #top nav>.sf-menu>li {
    float:none;
    display:inline-block
}
#header-outer[data-format=centered-menu] #top nav>.sf-menu>.megamenu {
    position:static
}
#header-outer[data-format=centered-menu] #top nav>.sf-menu>li ul {
    text-align:left
}
#header-outer[data-format=centered-menu] #top .span_3,#header-outer[data-format=centered-menu] #top nav>.buttons {
    z-index:10;
    position:absolute
}
#header-outer[data-format=centered-menu] #top .span_3 {
    left:0
}
#header-outer[data-format=centered-menu] .logo-spacing {
    visibility:hidden;
    pointer-events:none;
    z-index:-100
}
@media only screen and (max-width:999px) {
    #header-outer[data-format=centered-menu] .logo-spacing {
        display:none
    }
    #header-outer #top #logo img {
        height: 40px !important; 
        max-height: 40px !important;
    }
}
#header-outer[data-format=centered-menu] .logo-spacing img {
    margin-bottom:0
}
#header-outer[data-format=centered-menu] #top .span_3 {
    position:relative;
    margin-right:0
}
#header-outer[data-format=centered-menu] #top .span_9,#header-outer[data-format=centered-menu] #top .span_9 .sf-menu:not(.buttons) {
    position:static
}
#header-outer[data-format=centered-menu] #top .span_9,#header-outer[data-format=centered-menu] #top .span_9 nav {
    -webkit-flex-grow:1;
    -moz-flex-grow:1;
    -ms-flex-positive:1;
    -ms-flex-grow:1;
    flex-grow:1
}
#header-outer[data-format=centered-menu] #top .span_3,#header-outer[data-format=centered-menu] #top nav>.buttons {
    height:100%
}
@media only screen and (max-width:999px) {
    #header-outer[data-format=centered-menu] #top .span_9 {
        text-align:right;
        z-index:10000;
        left:auto
    }
}

#header-outer .nectar-ext-menu-item .image-layer-outer,#header-outer .nectar-ext-menu-item .image-layer,#header-outer .nectar-ext-menu-item .color-overlay,#slide-out-widget-area .nectar-ext-menu-item .image-layer-outer,#slide-out-widget-area .nectar-ext-menu-item .color-overlay,#slide-out-widget-area .nectar-ext-menu-item .image-layer {
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    overflow:hidden;
}
.nectar-ext-menu-item .inner-content {
    position:relative;
    z-index:10;
    width:100%;
}
.nectar-ext-menu-item .image-layer {
    background-size:cover;
    background-position:center;
    transition:opacity 0.25s ease 0.1s;
}
.nectar-ext-menu-item .image-layer video {
    object-fit:cover;
    width:100%;
    height:100%;
}
#header-outer nav .nectar-ext-menu-item .image-layer:not(.loaded) {
    background-image:none!important;
}
#header-outer nav .nectar-ext-menu-item .image-layer {
    opacity:0;
}
#header-outer nav .nectar-ext-menu-item .image-layer.loaded {
    opacity:1;
}
.nectar-ext-menu-item span[class*="inherit-h"] + .menu-item-desc {
    margin-top:0.4rem;
}
#mobile-menu .nectar-ext-menu-item .title,#slide-out-widget-area .nectar-ext-menu-item .title,.nectar-ext-menu-item .menu-title-text,.nectar-ext-menu-item .menu-item-desc {
    position:relative;
}
.nectar-ext-menu-item .menu-item-desc {
    display:block;
    line-height:1.4em;
}
body #slide-out-widget-area .nectar-ext-menu-item .menu-item-desc {
    line-height:1.4em;
}
#mobile-menu .nectar-ext-menu-item .title,#slide-out-widget-area .nectar-ext-menu-item:not(.style-img-above-text) .title,.nectar-ext-menu-item:not(.style-img-above-text) .menu-title-text,.nectar-ext-menu-item:not(.style-img-above-text) .menu-item-desc,.nectar-ext-menu-item:not(.style-img-above-text) i:before,.nectar-ext-menu-item:not(.style-img-above-text) .svg-icon {
    color:#fff;
}
#mobile-menu .nectar-ext-menu-item.style-img-above-text .title {
    color:inherit;
}
.sf-menu li ul li a .nectar-ext-menu-item .menu-title-text:after {
    display:none;
}
.menu-item .widget-area-active[data-margin="default"] > div:not(:last-child) {
    margin-bottom:20px;
}
.nectar-ext-menu-item.style-img-above-text .inner-content {
    text-align:center;
}
#header-outer .nectar-ext-menu-item.style-img-above-text .image-layer-outer,#slide-out-widget-area .nectar-ext-menu-item.style-img-above-text .image-layer-outer {
    position:relative;
    height:auto;
    width:auto;
    overflow:visible;
    margin-bottom:10px;
    display:inline-block;
}
#header-outer .nectar-ext-menu-item.style-img-above-text .image-layer,#slide-out-widget-area .nectar-ext-menu-item.style-img-above-text .image-layer {
    position:relative;
    width:60px;
    height:60px;
    transition:none;
    opacity:1;
}
#header-outer .nectar-ext-menu-item.style-img-above-text .image-layer.loaded,#slide-out-widget-area .nectar-ext-menu-item.style-img-above-text .image-layer.loaded {
    opacity:1;
}
#header-outer .nectar-ext-menu-item.style-img-above-text .image-layer-outer:after,#slide-out-widget-area .nectar-ext-menu-item.style-img-above-text .image-layer-outer:after {
    display:none;
}
.nectar-ext-menu-item.style-img-above-text .image-layer {
    background-color:transparent;
}
    
ul.custom-sf-menu .sub-menu {
margin-left: 12px;
}

ul.sf-menu .sub-menu {
margin-left: 12px;
}

@media only screen and (min-width: 1451px) {
    #header-outer, #top, #top .container, #top .row, #top .col, nav, ul.sf-menu, ul.sf-menu > li, .span_9, .span_3, #header-space {
        overflow: visible !important;
    }

    #header-outer {
        z-index: 99999 !important;
    }

    ul.sf-menu > li {
        position: relative !important;
        z-index: auto;
    }

    ul.sf-menu > li > ul.sub-menu {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        z-index: 999999;
        background-color: #fff;
        box-shadow: 0 4px 12px rgba(0,0,0,0.15);
        min-width: 250px;
        padding: 10px 0;
        border-top: 3px solid #0e2f77;
        pointer-events: auto;
        margin-left: 12px;
        margin-top: 10px;
    }

    ul.sf-menu > li > ul.sub-menu::before {
        content: "";
        position: absolute;
        top: -10px;
        left: 0;
        width: 100%;
        height: 10px;
        background: transparent;
        display: block;
    }

    ul.sf-menu > li:hover > ul.sub-menu,
    ul.sf-menu > li.sfHover > ul.sub-menu,
    ul.sf-menu > li:focus-within > ul.sub-menu,
    ul.sf-menu > li.menu-item-has-children:hover > ul.sub-menu {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        height: auto !important;
    }
    
    ul.sf-menu > li > ul.sub-menu li {
        display: block;
        width: 100%;
        float: none;
    }

    ul.sf-menu > li > ul.sub-menu li a {
        display: block;
        padding: 8px 20px;
        color: #333;
        line-height: 1.4;
        font-size: 14px;
        background: transparent;
    }

    ul.sf-menu > li > ul.sub-menu li a:hover {
        background-color: #f5f5f5;
        color: #0e2f77;
    }
    
    ul.sf-menu ul.sub-menu li {
        position: relative;
    }
    
    ul.sf-menu ul.sub-menu li:hover > ul.sub-menu {
        display: block !important;
        top: 0;
        left: 100%;
        margin-top: -5px;
    }
}

/* Responsive Menu Toggle Icon (Hamburger) */
.slide-out-widget-area-toggle {
    position: relative;
    z-index: 1000002; /* Higher z-index to ensure clickable over overlay */
}

.slide-out-widget-area-toggle a {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 48px !important;
    height: 48px !important;
    position: relative;
    z-index: 1000002;
    border-radius: 50% !important; /* Important for round shape */
    -webkit-border-radius: 50% !important; /* Webkit prefix */
    -moz-border-radius: 50% !important; /* Moz prefix */
    background-color: var(--secondary-color, #d5dbff) !important; /* Secondary color background */
    transition: background-color 0.2s ease;
    box-shadow: none !important; /* Remove any potential box shadow */
    text-decoration: none !important;
    overflow: hidden !important; /* Ensure content stays inside */
}

.slide-out-widget-area-toggle a:hover {
    background-color: rgba(0,0,0,0.05);
}

/* Ensure inner elements don't block clicks or mess up layout */
.slide-out-widget-area-toggle a > span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.slide-out-widget-area-toggle .lines-button {
    display: block !important;
    width: 22px !important;
    /* height: 18px !important;  */
    cursor: pointer;
    position: absolute !important; /* Stack them if there are two */
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    background: transparent !important;
    overflow: visible !important; /* Critical for showing pseudo-elements */
}

/* Hide the hover-effect duplicate if not needed or ensure it aligns */
.slide-out-widget-area-toggle .lines-button.hover-effect {
    opacity: 0; /* Hide the duplicate for now to avoid visual clutter */
}

.lines-button .lines {
    width: 22px;
    height: 2px;
    background-color: var(--main-color, #0e2f77) !important;
    position: absolute;
    top: 50%;
    left: 0;
    margin-top: -1px; /* Center vertically */
    display: block;
    transition: background-color 0.2s ease;
    border-radius: 2px;
}

.lines-button .lines::before,
.lines-button .lines::after {
    content: '';
    width: 22px;
    height: 2px;
    background-color: var(--main-color, #0e2f77) !important;
    position: absolute;
    left: 0;
    transition: transform 0.45s ease, top 0.3s ease, bottom 0.3s ease, background-color 0.2s ease; /* Updated transition */
    border-radius: 2px;
    display: block !important;
    visibility: visible !important;
}

.lines-button .lines::before {
    top: -6px;
}

.lines-button .lines::after {
    top: 6px;
}

/* Close State Animation (X shape) */
.lines-button.close .lines {
    background-color: transparent !important;
}

.lines-button.close .lines::before {
    top: 0;
    transform: rotate(45deg);
}

.lines-button.close .lines::after {
    top: 0;
    transform: rotate(-45deg);
}


/* Visibility Control */
.slide-out-widget-area-toggle {
    display: none;
}

/* Ensure header stays on top of the slide-out menu GLOBALLY so the toggle button is accessible */
#header-outer {
    z-index: 1000001 !important;
}

/* Push menu content down so it's not hidden behind the header */
#slide-out-widget-area {
    /*padding-top: 100px !important;*/ /* Ensure content starts below header */
    z-index: 999999 !important;
}

#slide-out-widget-area .inner-wrap {
    padding-bottom: 40px; /* Add some bottom padding for scrolling */
    padding-top: 100px !important; /* Ensure content starts below the header/close button */
}

@media only screen and (max-width: 1500px) {
    .slide-out-widget-area-toggle {
        display: block !important;
        float: none !important;
        margin-left: 0;
        margin-top: 0;
        transform: none !important;
    }
    
    /* FIX: Mobile Layout to prevent overlap and align Logo and Menu */
    /* Increased specificity to override theme defaults */
    #header-outer {
        /* padding-top: 12px !important; 
        padding-bottom: 12px !important;  */
    }

    #header-outer #top .row {
        display: flex !important;
        flex-direction: row !important; /* Ensure row direction */
        justify-content: space-between !important;
        align-items: center !important;
        flex-wrap: nowrap !important;
        height: auto !important;
        min-height: 60px !important; /* Match desktop content height */
    }

    /* FIX: Ensure container is full width on "mobile" range up to 1500px to match mobile look */
    #header-outer header#top > .container {
        width: 100% !important;
        max-width: none !important;
        padding: 0 40px !important; /* Add padding to prevent edge touching */
    }

    /* UNWRAP COLUMNS to allow mixed reordering */
    body #header-outer[data-format] #top .row .col.span_3,
    body #header-outer #top .row .col.span_9 {
        display: contents !important;
    }

    /* LOGO: Center (Order 2) */
    body #header-outer[data-format] #top .row .col.span_3 #logo {
        order: 2 !important;
        flex: 0 1 auto !important;
        margin: 0 auto !important;
        display: flex !important;
        justify-content: center !important;
    }

    /* MENU BUTTON: Left (Order 1) */
    body #header-outer #top .row .col.span_9 .slide-out-widget-area-toggle {
        display: block !important; /* Ensure visible */
        order: 1 !important; /* First item */
        margin-right: 0 !important;
        margin-left: 0 !important;
        position: relative !important;
        right: auto !important;
        top: auto !important;
        transform: none !important;
        width: 48px !important;
    }

    /* USER ICON: Right (Order 3) */
    body #header-outer #top .row .col.span_9 .mobile-user-account {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 48px !important; /* Match menu button width */
        height: 48px !important;
        position: relative !important;
        top: auto !important;
        left: auto !important;
        order: 3 !important; /* Last item */
        margin-right: 0 !important;
        margin-left: 0 !important;
        z-index: 1002 !important;
    }
    
    /* Hide potentially interfering elements */
    body #header-outer #top .row .col.span_9 .mobile-only {
        display: none !important;
    }

    /* Ensure Logo Image is constrained */
    #header-outer #top #logo img {
        max-width: 180px !important; 
        /* height: 60px !important;
        max-height: 60px !important; */
        margin: 0 !important;
        display: block !important;
        position: relative;
    }
    
    /* Hide regular menu on mobile */
    .sf-menu-container,
    .custom-sf-menu,
    #header-outer nav > ul.custom-sf-menu {
        display: none !important;
    }

        .sf-menu-container,
    .sf-menu,
    #header-outer nav > ul.sf-menu {
        display: none !important;
    }

    /* Ensure mobile menu container is visible */
    .mobile-only {
        display: block !important;
    }

    /* Icon fix using FontAwesome */
    .icon-salient-m-user:before {
        content: "\f007" !important;
        font-family: FontAwesome !important;
        font-size: 24px !important;
        color: var(--main-color, #0e2f77) !important;
    }
}

@media only screen and (min-width: 1501px) {
    .slide-out-widget-area-toggle,
    .mobile-only {
        display: none !important;
    }
    
    .sf-menu-container {
        display: block !important;
    }
}

/* Slide Out Menu Styling Enhancements */
#slide-out-widget-area.slide-out-from-right {
    position: fixed;
    top: 0;
    right: -100%; /* Hidden by default */
    width: 350px; /* Reduced width */
    max-width: 90%;
    height: 100%;
    background-color: #fff;
    z-index: 999999;
    pointer-events: none;
    transition: transform 0.4s cubic-bezier(0.2, 0.9, 0.3, 1), right 0.4s ease;
    box-shadow: -5px 0 20px rgba(0,0,0,0.1);
    overflow-y: auto;
}

#slide-out-widget-area.open {
    right: 0 !important;
    transform: translateX(0);
    pointer-events: auto;
}

#slide-out-widget-area-bg {
    position: fixed !important;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.5);
    z-index: 999998;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.4s ease, visibility 0.4s ease;
}

#slide-out-widget-area-bg.open {
    /* opacity: 1; */
    visibility: visible;
    pointer-events: auto;
}

.slide_out_area_close {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 1000000;
    display: none;
    width: 30px;
    height: 30px;
    cursor: pointer;
}

.slide_out_area_close.open {
    display: block;
}

.slide_out_area_close .close-wrap {
    width: 30px;
    height: 30px;
    position: relative;
    display: block;
}

.slide_out_area_close .close-line {
    position: absolute;
    width: 30px;
    height: 2px;
    background-color: #333;
    top: 50%;
    left: 0;
}

.slide_out_area_close .close-line1 {
    transform: rotate(45deg);
}

.slide_out_area_close .close-line2 {
    transform: rotate(-45deg);
}

/* Fix for arrow positioning relative to list item */
#slide-out-widget-area .menu-item {
    position: relative !important;
}

#slide-out-widget-area .menu-item a {
    position: relative;
    z-index: 10;
    display: block;
    padding: 18px 25px; /* Increased vertical padding */
    color: var(--main-color, #0e2f77) !important;
    font-size: 16px;
    font-weight: 600;
    border-bottom: none !important;
    text-decoration: none;
    transition: color 0.2s ease, background-color 0.2s ease;
}

#slide-out-widget-area .menu-item a:hover {
    color: var(--secondary-color, #d5dbff) !important;
    background-color: transparent !important; /* Remove background for clean underline effect */
}

/* Underline Animation */
#slide-out-widget-area .menu-item a::after {
    content: '';
    display: block;
    position: absolute;
    bottom: 5px; /* Position from bottom */
    left: 25px; /* Match left padding */
    width: 0;
    height: 2px;
    background-color: var(--accent-color, #f1ad3e) !important;
    transition: width 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    opacity: 0;
}

#slide-out-widget-area .menu-item a:hover::after {
    width: calc(100% - 50px); /* Full width minus left/right padding (25+25) */
    opacity: 1;
}

#slide-out-widget-area .sub-menu {
    display: none;
    background-color: transparent !important;
}

#slide-out-widget-area .sub-menu a {
    padding-left: 40px;
    font-weight: normal;
    font-size: 15px;
    color: var(--main-light, #335c85) !important;
}

#slide-out-widget-area .sub-menu a:hover {
    color: var(--accent-color, #f1ad3e) !important;
}

/* Adjust underline for submenu items */
#slide-out-widget-area .sub-menu a::after {
    left: 40px !important; /* Match submenu left padding */
}

#slide-out-widget-area .sub-menu a:hover::after {
    width: calc(100% - 65px) !important; /* 40px left + 25px right */
}

#slide-out-widget-area .ocm-dropdown-arrow2 {
    position: absolute;
    right: 0;
    top: 0;
    margin-top: 0;
    /* width: 50px; */
    height: 65px; /* Reduced clickable area */
    display: flex !important;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 100;
    color: #0e2f77 !important; /* Hardcode color to ensure visibility */
    transition: transform 0.3s ease;
    background-color: transparent; /* Debug: change to rgba(0,0,0,0.05) if needed */
    pointer-events: auto;
}

/* Robust arrow using borders */
#slide-out-widget-area .ocm-dropdown-arrow2::after {
    content: '';
    display: block;
    width: 9px; /* Reduced arrow size */
    height: 9px; /* Reduced arrow size */
    border-right: 2px solid #0e2f77; /* Thinner stroke */
    border-bottom: 2px solid #0e2f77;
    transform: rotate(45deg);
    margin-top: -4px;
}

/* Hide the icon if we are using the CSS arrow to avoid double arrows, 
   or we can keep it if we trust it. Let's hide the i if we use the after. 
   Actually, let's just style the i if it exists, but the user says it's not appearing.
   So the ::after method is safer. 
*/
#slide-out-widget-area .ocm-dropdown-arrow2 i {
    display: none;
}

/* Ensure arrow stays in place when submenu opens */
#slide-out-widget-area .menu-item.open > .ocm-dropdown-arrow2 {
    transform: rotate(180deg);
    color: var(--accent-color, #f1ad3e);
}

@media only screen and (max-width: 1500px) {
    #slide-out-widget-area .ocm-dropdown-arrow {
        display: none !important;
    }
}

/* FIX: Ensure mobile menu text is always visible */
#slide-out-widget-area .off-canvas-menu-container,
#slide-out-widget-area .menu,
#slide-out-widget-area .menu-item,
#slide-out-widget-area .menu-item a {
    opacity: 1 !important;
    visibility: visible !important;
    display: block;
}

#slide-out-widget-area .menu-item a {
    /* color: #333 !important; Removed to allow theme variables */
}

/* Ensure submenu is visible when open */
#slide-out-widget-area .sub-menu {
    display: none; /* Controlled by JS */
    opacity: 1 !important;
    visibility: visible !important;
    position: relative !important;
    /* background: #f9f9f9 !important; */
    box-shadow: none !important;
    top: auto !important;
    left: auto !important;
    transform: none !important;
}

#slide-out-widget-area .menu-item.open > .sub-menu {
    display: block !important;
    max-width: 260px;
}

/* FIX: Ensure inner-wrap is visible when open */
body.material-ocm-open #slide-out-widget-area .inner-wrap {
    opacity: 1 !important;
}



/* DESKTOP ONLY STYLES (>= 1501px) */
@media only screen and (min-width: 1501px) {
    /* Estilos nucleares para forzar el menú */

/* Fix overlap: Make span_9 relative and use flexbox to position elements */
    #header-outer #top .row .col.span_9 {
        position: relative !important;
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        padding-right: 0 !important;
    }

    /* Reset básico para el contenedor */
    .sf-menu-container {
        display: block !important;
        overflow: visible !important;
        z-index: 99999 !important;
        position: relative !important;
    }

    /* Reset para la lista principal */
    ul.custom-sf-menu {
        margin: 0 !important;
        padding: 0 !important;
        list-style: none !important;
        display: flex !important; /* Usar flexbox para asegurar horizontalidad */
        flex-wrap: nowrap !important; /* Evitar que las secciones cambien de renglón */
        position: relative !important;
        z-index: 99999 !important;
        overflow: visible !important;
    }

/* Spacing for desktop menu items */
ul.custom-sf-menu > li {
    position: relative !important;
    display: block !important;
    margin-right: 35px !important; /* Increased spacing */
    overflow: visible !important;
    flex-shrink: 0 !important;
}

ul.custom-sf-menu > li > a {
    display: block !important;
    padding: 15px 5px !important;
    text-decoration: none !important;
    color: #333 !important;
    font-weight: bold !important;
    white-space: nowrap !important;
    letter-spacing: 0.5px !important; /* Improve readability */
}

    ul.sf-menu {
        margin: 0 !important;
        padding: 0 !important;
        list-style: none !important;
        display: flex !important; /* Usar flexbox para asegurar horizontalidad */
        flex-wrap: nowrap !important; /* Evitar que las secciones cambien de renglón */
        position: relative !important;
        z-index: 99999 !important;
        overflow: visible !important;
    }


/* SUBMENÚS - La parte crítica */
ul.custom-sf-menu .sub-menu {
    display: none !important; /* Oculto por defecto */
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    background-color: #ffffff !important;
    min-width: 250px !important;
    z-index: 100000 !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
    border: 1px solid #eee !important;
    padding: 10px 0 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: opacity 0.2s ease, visibility 0.2s ease !important;
}

ul.sf-menu .sub-menu {
    display: none !important; /* Oculto por defecto */
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    background-color: #ffffff !important;
    min-width: 250px !important;
    z-index: 100000 !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
    border: 1px solid #eee !important;
    padding: 10px 0 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: opacity 0.2s ease, visibility 0.2s ease !important;
}

/* REGLA DE VISIBILIDAD AL HOVER - CSS PURO */
ul.custom-sf-menu li:hover > .sub-menu,
ul.custom-sf-menu li:focus-within > .sub-menu {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
}

ul.sf-menu li:hover > .sub-menu,
ul.sf-menu li:focus-within > .sub-menu {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
}

/* Estilos de items de submenú - Override forzoso de opacidad */
ul.custom-sf-menu .sub-menu li,
#header-outer[data-format="centered-menu"] #top nav > ul.custom-sf-menu > li > ul.sub-menu > li,
#header-outer #top nav > ul.custom-sf-menu > li > ul.sub-menu > li {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
}

ul.sf-menu .sub-menu li,
#header-outer[data-format="centered-menu"] #top nav > ul.sf-menu > li > ul.sub-menu > li,
#header-outer #top nav > ul.sf-menu > li > ul.sub-menu > li {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
}

/* CORRECCIÓN DE TEXTO INVISIBLE - ALTA ESPECIFICIDAD Y ESTILO */
body #header-outer ul.custom-sf-menu .sub-menu li a,
body #header-outer ul.custom-sf-menu .sub-menu li.nectar-regular-menu-item a {
    display: block !important;
    padding: 10px 20px !important;
    color: var(--main-color, #0e2f77) !important; /* Color principal */
    font-weight: bold !important; /* Mismo peso que las secciones (bold) */
    font-family: inherit !important; /* Heredar tipografía del menú principal */
    text-transform: inherit !important; /* Heredar transformación (mayúsculas/minúsculas) */
    letter-spacing: inherit !important; /* Heredar espaciado */
    border-bottom: none !important; /* SIN LÍNEAS DE SEPARACIÓN */
    text-decoration: none !important;
    background: transparent !important;
    font-size: 15px !important; /* Aumentado de 13px a 15px */
    line-height: 1.5 !important;
    text-align: left !important;
    height: auto !important;
    width: auto !important;
    position: relative !important;
    transition: color 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important; /* Transición suave */
}

/* Efecto de subrayado animado al hover (simulando animated_underline del tema) */
body #header-outer ul.custom-sf-menu .sub-menu li a::after,
body #header-outer ul.custom-sf-menu .sub-menu li.nectar-regular-menu-item a::after {
    content: '' !important;
    display: block !important;
    position: absolute !important;
    bottom: 5px !important;
    left: 20px !important;
    width: 0 !important;
    height: 2px !important;
    background-color: var(--accent-color, #f1ad3e) !important; /* Color secundario confirmado */
    transition: width 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
    opacity: 0 !important;
}

body #header-outer ul.custom-sf-menu .sub-menu li a:hover::after,
body #header-outer ul.custom-sf-menu .sub-menu li.nectar-regular-menu-item a:hover::after {
    width: calc(100% - 40px) !important; /* Ancho menos padding */
    opacity: 1 !important;
}

body #header-outer ul.custom-sf-menu .sub-menu li a span.menu-title-text,
body #header-outer ul.custom-sf-menu .sub-menu li.nectar-regular-menu-item a span.menu-title-text {
    color: inherit !important; /* Heredar del enlace para mantener la transición */
    font-size: 15px !important; /* Aumentado de 13px a 15px */
    font-weight: bold !important; /* Mismo peso */
    visibility: visible !important;
    opacity: 1 !important;
    display: inline-block !important;
    text-indent: 0 !important;
}

/* -----*/
body #header-outer ul.sf-menu .sub-menu li a,
body #header-outer ul.sf-menu .sub-menu li.nectar-regular-menu-item a {
    display: block !important;
    padding: 10px 20px !important;
    color: var(--main-color, #0e2f77) !important; /* Color principal */
    font-weight: bold !important; /* Mismo peso que las secciones (bold) */
    font-family: inherit !important; /* Heredar tipografía del menú principal */
    text-transform: inherit !important; /* Heredar transformación (mayúsculas/minúsculas) */
    letter-spacing: inherit !important; /* Heredar espaciado */
    border-bottom: none !important; /* SIN LÍNEAS DE SEPARACIÓN */
    text-decoration: none !important;
    background: transparent !important;
    font-size: 15px !important; /* Aumentado de 13px a 15px */
    line-height: 1.5 !important;
    text-align: left !important;
    height: auto !important;
    width: auto !important;
    position: relative !important;
    transition: color 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important; /* Transición suave */
}

/* Efecto de subrayado animado al hover (simulando animated_underline del tema) */
body #header-outer ul.sf-menu .sub-menu li a::after,
body #header-outer ul.sf-menu .sub-menu li.nectar-regular-menu-item a::after {
    content: '' !important;
    display: block !important;
    position: absolute !important;
    bottom: 5px !important;
    left: 20px !important;
    width: 0 !important;
    height: 2px !important;
    background-color: var(--accent-color, #f1ad3e) !important; /* Color secundario confirmado */
    transition: width 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
    opacity: 0 !important;
}

body #header-outer ul.sf-menu .sub-menu li a:hover::after,
body #header-outer ul.sf-menu .sub-menu li.nectar-regular-menu-item a:hover::after {
    width: calc(100% - 40px) !important; /* Ancho menos padding */
    opacity: 1 !important;
}

body #header-outer ul.sf-menu .sub-menu li a span.menu-title-text,
body #header-outer ul.sf-menu .sub-menu li.nectar-regular-menu-item a span.menu-title-text {
    color: inherit !important; /* Heredar del enlace para mantener la transición */
    font-size: 15px !important; /* Aumentado de 13px a 15px */
    font-weight: bold !important; /* Mismo peso */
    visibility: visible !important;
    opacity: 1 !important;
    display: inline-block !important;
    text-indent: 0 !important;
}
/*-------*/

body #header-outer ul.sf-menu .sub-menu li a span.menu-title-text,
body #header-outer ul.sf-menu .sub-menu li.nectar-regular-menu-item a span.menu-title-text {
    color: inherit !important; /* Heredar del enlace para mantener la transición */
    font-size: 15px !important; /* Aumentado de 13px a 15px */
    font-weight: bold !important; /* Mismo peso */
    visibility: visible !important;
    opacity: 1 !important;
    display: inline-block !important;
    text-indent: 0 !important;
}

body #header-outer ul.custom-sf-menu .sub-menu li a:hover,
body #header-outer ul.custom-sf-menu .sub-menu li.nectar-regular-menu-item a:hover {
    background-color: transparent !important; /* Quitar fondo azul claro */
    color: var(--secondary-color, #d5dbff) !important; /* Color secundario al hover */
}

body #header-outer ul.sf-menu .sub-menu li a:hover,
body #header-outer ul.sf-menu .sub-menu li.nectar-regular-menu-item a:hover {
    background-color: transparent !important; /* Quitar fondo azul claro */
    color: var(--secondary-color, #d5dbff) !important; /* Color secundario al hover */
}

/* Eliminar reglas redundantes anteriores para hover del span */
body #header-outer ul.custom-sf-menu .sub-menu li a:hover span.menu-title-text,
body #header-outer ul.custom-sf-menu .sub-menu li.nectar-regular-menu-item a:hover span.menu-title-text {
    color: inherit !important; /* Usar el color del padre (link) */
}

/* Submenús de segundo nivel (hacia la derecha) */
ul.custom-sf-menu .sub-menu li:hover > .sub-menu {
    top: 0 !important;
    left: 100% !important;
    margin-top: -10px !important;
}

body #header-outer ul.sf-menu .sub-menu li a:hover span.menu-title-text,
body #header-outer ul.sf-menu .sub-menu li.nectar-regular-menu-item a:hover span.menu-title-text {
    color: inherit !important; /* Usar el color del padre (link) */
}

/* Submenús de segundo nivel (hacia la derecha) */
ul.sf-menu .sub-menu li:hover > .sub-menu {
    top: 0 !important;
    left: 100% !important;
    margin-top: -10px !important;
}

    /* ACCOUNT ICON: Visible on Desktop */
    body #header-outer #top .row .col.span_9 .mobile-user-account {
        display: flex !important;
        position: relative !important; /* Not absolute */
        right: auto !important;
        top: auto !important;
        transform: none !important;
        margin-left: 20px !important; /* Space from menu */
        margin-right: 0 !important;
        z-index: 1000 !important;
        align-items: center;
        justify-content: center;
    }

    body #header-outer #top .row .col.span_9 .mobile-user-account svg {
        width: 24px;
        height: 24px;
        stroke: var(--main-color, #0e2f77);
        stroke-width: 2px;
        transition: all 0.2s ease;
    }

    body #header-outer #top .row .col.span_9 .mobile-user-account:hover svg {
        stroke: var(--accent-color, #f1ad3e) !important;
        transform: scale(1.1);
    }
} 

#logo {
    vertical-align: middle;
}

.row>* {
    width: auto !important;
}

/* --- Imported Styles from slide-out-right-material.css --- */
#slide-out-widget-area.slide-out-from-right .inner-wrap {
    opacity: 0;
}

body.material-ocm-open #slide-out-widget-area.slide-out-from-right .inner-wrap {
    opacity: 1;
}

#slide-out-widget-area.slide-out-from-right #slide-out-widget-area .inner > div,
#slide-out-widget-area.slide-out-from-right .inner {
    width: auto;
}
body #slide-out-widget-area .off-canvas-social-links li:first-child a{padding-left:0}body #slide-out-widget-area .off-canvas-social-links li a i:after{z-index:10000}body #slide-out-widget-area .off-canvas-social-links li{padding:0}body #slide-out-widget-area .off-canvas-social-links li a{height:24px;display:block;width:auto;line-height:38px;opacity:1;padding:0 14px;box-sizing:content-box;text-align:center}body #slide-out-widget-area .off-canvas-social-links li i:before{z-index:10;display:block;position:relative}body.material #slide-out-widget-area .off-canvas-social-links li i{height:26px;width:auto}body.material[data-slide-out-widget-area-style=slide-out-from-right] #slide-out-widget-area .off-canvas-social-links li i{font-size:20px}body #slide-out-widget-area .off-canvas-social-links li i{line-height:28px;display:block;position:relative;top:auto;backface-visibility:hidden;transition:color .2s ease;vertical-align:middle}@media only screen and (min-width:1000px){body .follow-body.slide_out_area_close{opacity:1;right:0;transform:translateY(-50%) translateX(-36.55vw)}}body[data-full-width-header=false].admin-bar #slide-out-widget-area .slide_out_area_close{top:50px}body #header-outer.side-widget-open{box-shadow:none}body .nectar-social.fixed{transition:transform .45s cubic-bezier(.15,.2,.1,1)}.ocm-effect-wrap.material-ocm-open .nectar-social.fixed{-webkit-transform:scale(0);transform:scale(0)}.ocm-effect-wrap.material-ocm-open .swiper-container .slider-next,.ocm-effect-wrap.material-ocm-open .swiper-container .slider-prev{transition:background-color .2s linear,opacity .45s cubic-bezier(.15,.2,.1,1);-webkit-transition:background-color .2s linear,opacity .45s cubic-bezier(.15,.2,.1,1)}.ocm-effect-wrap.material-ocm-open .nectar-slider-wrap[data-full-width=true] .swiper-container .slider-next,.ocm-effect-wrap.material-ocm-open .nectar-slider-wrap[data-full-width=true] .swiper-container .slider-prev{opacity:0!important}#fp-nav.material-ocm-open li{-webkit-transform:scale(0);transform:scale(0)}body.material #slide-out-widget-area.slide-out-from-right .off-canvas-menu-container .current-menu-item>a{opacity:1}body .ocm-effect-wrap-shadow{-ms-transition:transform .8s cubic-bezier(.15,.2,.1,1);-webkit-transition:transform .8s cubic-bezier(.15,.2,.1,1);transition:transform .8s cubic-bezier(.15,.2,.1,1);-ms-transform-origin:right;-webkit-transform-origin:right;transform-origin:right;position:fixed;left:0;top:0;width:100%;height:100%;content:'';display:block;z-index:1;box-shadow:0 80px 145px rgba(0,0,0,.33)}body.admin-bar.material-ocm-open{position:fixed;left:0;width:100%;height:100%;top:0}.material-ocm-open .container-wrap{pointer-events:none}.ocm-effect-wrap .ocm-effect-wrap-inner{backface-visibility:hidden}.ocm-effect-wrap.material-ocm-open .ocm-effect-wrap-inner{-webkit-transform:scale(1.007)!important;transform:scale(1.007)!important;-webkit-transform-origin:center;transform-origin:center}body .ocm-effect-wrap.material-ocm-open{-webkit-transition:transform .8s cubic-bezier(.15,.2,.1,1);transition:transform .8s cubic-bezier(.15,.2,.1,1);-webkit-transform:scale(.835) translateX(-466px) translateZ(0)!important;transform:scale(.835) translateX(-466px) translateZ(0)!important;height:100%}body .ocm-effect-wrap-shadow.material-ocm-open{-webkit-transition:transform .8s cubic-bezier(.15,.2,.1,1);transition:transform .8s cubic-bezier(.15,.2,.1,1);transform:scale(.825) translateX(-476px) translateZ(0)!important;height:100%}@media only screen and (max-width:450px){body .ocm-effect-wrap-shadow{-webkit-transition:transform .8s cubic-bezier(.15,.2,.1,1);transition:transform .8s cubic-bezier(.15,.2,.1,1)}body .ocm-effect-wrap.material-ocm-open{-webkit-transform:scale(.84) translateX(-93vw) translateZ(0)!important;transform:scale(.84) translateX(-93vw) translateZ(0)!important}body .ocm-effect-wrap-shadow.material-ocm-open{-webkit-transform:scale(.83) translateX(-94vw) translateZ(0)!important;transform:scale(.83) translateX(-94vw) translateZ(0)!important}}@media only screen and (min-width:1000px){body .ocm-effect-wrap.material-ocm-open{-webkit-transform-origin:center;transform-origin:center;-webkit-transform:scale(.8) translateX(-32vw) translateZ(0)!important;transform:scale(.8) translateX(-32vw) translateZ(0)!important}body .ocm-effect-wrap-shadow.material-ocm-open{-webkit-transform-origin:center;transform-origin:center;-webkit-transform:scale(.79) translateX(-33.6vw) translateZ(0)!important;transform:scale(.79) translateX(-33.6vw) translateZ(0)!important}body .follow-body.slide_out_area_close{-ms-transform:translateY(-50%) translateX(-35.55vw);-webkit-transform:translateY(-50%) translateX(-35.55vw);transform:translateY(-50%) translateX(-35.55vw)}body[data-boxed-style="1"] .ocm-effect-wrap.material-ocm-open{-ms-transform-origin:center;-webkit-transform-origin:center;transform-origin:center;-webkit-transform:scale(.85) translateX(-29.6vw) translateZ(0)!important;transform:scale(.85) translateX(-29.6vw) translateZ(0)!important}body[data-boxed-style="1"] .ocm-effect-wrap.material-ocm-open .ocm-effect-wrap-inner{-webkit-transform:none!important;transform:none!important}}.material-ocm-open #ajax-content-wrap{cursor:pointer}#slide-out-widget-area.slide-out-from-right .nectar-global-section .full-width-content{width:100%!important;left:0!important;margin:0!important}#slide-out-widget-area.slide-out-from-right .bottom-meta-wrap,#slide-out-widget-area.slide-out-from-right .inner>div{-webkit-transform:translateX(110px);-webkit-transition:all .8s cubic-bezier(.15,.2,.1,1);transform:translateX(110px);transition:all .8s cubic-bezier(.15,.2,.1,1)}#slide-out-widget-area.slide-out-from-right.material-open .bottom-meta-wrap,#slide-out-widget-area.slide-out-from-right.material-open .inner>div{-ms-transform:translateX(0);-webkit-transform:translateX(0);transform:translateX(0)}

.off-canvas-menu-container.mobile-only {
        margin: -10px -10px -10px -50px;
}
