/* ========== CO-ACTIVE MEGA MENU STYLES ========== */

/* Font family for mega menu */
.coactive-mega-menu,
.coactive-mega-menu * {
    font-family: 'Arimo', Helvetica, Arial, Lucida, sans-serif;
}

/* ========== DIVI INTEGRATION ========== */

/* Specific Divi integration */
.et-menu-nav li.has-mega-menu {
    position: static;
}

.et-menu-nav li.has-mega-menu > a::after {
    content: '';
    display: inline-block;
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid currentColor;
    margin-left: 8px;
    vertical-align: middle;
    transition: transform 0.3s ease;
}

.et-menu-nav li.has-mega-menu:hover > a::after {
    transform: rotate(180deg);
}

/* Hide normal Divi submenus when using mega menu */
.et-menu-nav li.has-mega-menu ul.sub-menu {
    display: none !important;
}

.et_pb_menu .et_pb_menu__menu>nav>ul>li>ul {
    left: auto !important;
    top: 80% ! important;
    max-width: 70% !important;
    z-index: 99999 !important;
    box-sizing: border-box !important;
    width: auto !important;
    min-width: 300px !important;
}


/* Main mega menu container */
.coactive-mega-menu {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    width: 100% !important;
    max-width: 100vw !important;
    background: #ffffff !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(-10px) !important;
    transition: all 0.3s ease !important;
    z-index: 99999 !important;
    border-radius: 0 0 24px 24px !important;
    pointer-events: auto !important;
    overflow-x: hidden !important;
    box-sizing: border-box !important;
    contain: layout style paint !important;
}

/* Show mega menu on hover, focus and active */
.et-menu-nav li:hover .coactive-mega-menu,
.et-menu-nav li:focus .coactive-mega-menu,
.et-menu-nav li:active .coactive-mega-menu,
.et-menu-nav li.current-menu-item .coactive-mega-menu,
.coactive-mega-menu:hover {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}

/* Keep mega menu visible when parent link has focus */
.et-menu-nav li:focus-within .coactive-mega-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* Prevent mega menu from closing when clicking parent link */
.et-menu-nav li > a:focus + .coactive-mega-menu {
    opacity: 1;
    visibility: visible;
}

/* Inner mega menu container */
.mega-menu-container {
    max-width: min(700px, calc(100vw - 40px)) !important;
    margin: 0 auto !important;
    padding: clamp(16px, 4vw, 32px) clamp(12px, 3vw, 24px) !important;
    display: flex !important;
    gap: clamp(20px, 8vw, 60px) !important;
    align-items: flex-start !important;
    background: linear-gradient(135deg, #ffffff 0%, #fafafa 100%) !important;
    border-radius: 0 0 24px 24px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    contain: layout style !important;
}

/* Main sections */
.mega-menu-section {
    flex: 1;
    position: relative;
}

/* Section titles */
.mega-menu-section h3 {
    font-size: 12px;
    font-weight: 700;
    color: #2c2c2c;
    margin: 0 0 20px 0;
    text-transform: uppercase;
    letter-spacing: 2px;
    position: relative;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* Decorative line below title */
.mega-menu-section h3::after {
    content: '';
    position: absolute;
    bottom: -10px;
    left: 0;
    width: 50px;
    height: 2px;
    background: #C4347C;
}

/* Course list */
.mega-menu-courses {
    list-style: none;
    padding: 0;
    margin: 0;
}

/* Base styles for course elements */
.mega-menu-courses li {
    margin-bottom: 16px;
    position: relative;
    transition: all 0.3s ease;
    border-radius: 16px;
    padding: 12px 16px;
    background: transparent;
    min-height: 44px;
    display: flex;
    align-items: center;
}

.mega-menu-courses li:last-child {
    margin-bottom: 0;
}

/* Enlaces de cursos */
.mega-menu-courses a {
    display: block;
    text-decoration: none;
    color: inherit;
    padding: 0;
    border: none;
    position: relative;
    border-radius: 8px;
}

/* ========== HOVER GRADIENTS + WHITE TEXT ========== */

/* Co-Active Foundations - Teal/Blue-green gradient */
.mega-menu-courses li:nth-child(1):hover,
li.menu-item-22992398:hover {
    background: linear-gradient(90deg,rgba(21, 95, 90, 1) 0%, rgba(14, 181, 224, 1) 50%) !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 8px 25px rgba(45, 212, 191, 0.4) !important;
    background-size: 200% 200% !important;
    animation: gradientShift 3s ease infinite !important;
    border-radius: 16px !important;
}

.mega-menu-courses li:nth-child(1):hover .course-title,
.mega-menu-courses li:nth-child(1):hover .menu-subtitle,
li.menu-item-22992398:hover .course-title,
li.menu-item-22992398:hover .menu-subtitle {
    color: white !important;
}

/* Ignite the Practice - Purple gradient */
.mega-menu-courses li:nth-child(2):hover,
li.menu-item-22992399:hover {
    background: linear-gradient(90deg,rgba(39, 59, 118, 1) 0%, rgba(197, 61, 139, 1) 50%) !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 8px 25px rgba(168, 85, 247, 0.4) !important;
    background-size: 200% 200% !important;
    animation: gradientShift 3s ease infinite !important;
    border-radius: 16px !important;
}

.mega-menu-courses li:nth-child(2):hover .course-title,
.mega-menu-courses li:nth-child(2):hover .menu-subtitle,
li.menu-item-22992399:hover .course-title,
li.menu-item-22992399:hover .menu-subtitle {
    color: white !important;
}

/* Deepen the Work - Pink/Magenta gradient */
.mega-menu-courses li:nth-child(3):hover,
li.menu-item-22992400:hover {
    background: linear-gradient(90deg,rgba(39, 59, 118, 1) 0%, rgba(197, 30, 139, 1) 20%) !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 8px 25px rgba(236, 72, 153, 0.4) !important;
    background-size: 200% 200% !important;
    animation: gradientShift 3s ease infinite !important;
    border-radius: 16px !important;
}

.mega-menu-courses li:nth-child(3):hover .course-title,
.mega-menu-courses li:nth-child(3):hover .menu-subtitle,
.mega-menu-courses li:nth-child(3):hover .course-badge,
li.menu-item-22992400:hover .course-title,
li.menu-item-22992400:hover .menu-subtitle,
li.menu-item-22992400:hover .course-badge {
    color: white !important;
}

/* Gradient animation - Optimized for performance */
@keyframes gradientShift {
    0%, 100% { 
        background-position: 0% 50%; 
    }
    50% { 
        background-position: 100% 50%; 
    }
}

/* Performance optimizations */
.coactive-mega-menu,
.mega-menu-container,
.mega-menu-courses li {
    will-change: transform, opacity;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

/* Optimized transitions */
.mega-menu-courses li {
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
                background 0.3s cubic-bezier(0.4, 0, 0.2, 1),
                box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.mega-menu-courses .course-title,
.menu-subtitle,
.course-badge {
    transition: color 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

/* Reduce motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
    .coactive-mega-menu,
    .mega-menu-courses li,
    .course-title,
    .menu-subtitle,
    .course-badge {
        transition: none !important;
        animation: none !important;
    }
    
    .mega-menu-courses li:hover {
        transform: none !important;
    }
}

/* Course titles */
.mega-menu-courses .course-title {
    font-size: 16px;
    font-weight: 600;
    color: #2c2c2c;
    margin: 0 0 4px 0;
    line-height: 1.3;
    display: inline-block;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    transition: color 0.3s ease !important;
}

/* Course subtitles */
.menu-subtitle {
    display: block;
    font-size: 11px;
    color: #262626;
    font-weight: 600;
    margin: 0;
    line-height: 1.3;
    margin-top: 2px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    transition: color 0.3s ease !important;
    text-transform: capitalize;
}

/* Badges for special courses */
.course-badge {
    font-weight: 700;
    letter-spacing: 0.5px;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    width: fit-content;
}

.course-badge.cpcc {
    font-size: 7px !important;
    position: absolute;
    background: #C4347C;
    color: white;
    left: 165px;
    box-shadow: 0 2px 8px rgba(196, 52, 124, 0.3);
    top: 2px;
}

.course-badge.coming {
    font-size: 7px !important;
    position: absolute;
    background: #FF9500;
    color: white;
    top: 0px;
    left: 150px;
    box-shadow: 0 2px 8px rgba(255, 149, 0, 0.3);
}

/* Specific hover for badges - CPCC with white background and black text (only for Deepen the Work) */
.course-item:nth-child(3):hover .course-badge.cpcc,
li.menu-item-22992293:hover .course-badge.cpcc {
    background-color: white !important;
    color: #C53D8B !important;
    transform: scale(1.05);
}

/* Master the Art - Título y subtítulo gris */
li.menu-item-22992401 .course-title,
li.menu-item-22992401 .menu-subtitle {
    color: #9CA3AF !important;
}

/* Desktop section headers with line */
.menu-item-with-line {
    position: relative;
}

.menu-item-with-line::after {
    content: '';
    display: block;
    width: 70%;
    height: 1px;
    background-color: #C53D8B;
    margin-top: 5px;
    border-radius: 1px;
}

li.menu-item-22992401:hover .course-title,
li.menu-item-22992401:hover .menu-subtitle {
    color: #9CA3AF !important;
}

/* Master the Art - Mobile version */
li.menu-item-22992401 .course-title-mobile,
li.menu-item-22992401 .menu-subtitle-mobile,
li.menu-item-22992659 .course-title-mobile,
li.menu-item-22992659 .menu-subtitle {
    color: #9CA3AF !important;
}

/* ========== RESPONSIVE DESIGN ========== */

/* ========== TABLET PORTRAIT (768px - 1024px) ========== */
@media (min-width: 768px) and (max-width: 1024px) {
    .coactive-mega-menu {
        position: absolute !important;
        width: 100% !important;
        max-width: calc(100vw - 40px) !important;
        left: 50% !important;
        transform: translateX(-50%) translateY(-10px) !important;
        border-radius: 0 0 16px 16px !important;
        z-index: 99999 !important;
        overflow-x: hidden !important;
    }
    
    .mega-menu-container {
        max-width: min(600px, calc(100vw - 60px)) !important;
        padding: clamp(20px, 3vw, 28px) clamp(16px, 2.5vw, 20px) !important;
        gap: clamp(20px, 4vw, 30px) !important;
        flex-direction: column !important;
        box-sizing: border-box !important;
    }
    
    .mega-menu-section {
        width: 100% !important;
    }
    
    .mega-menu-section h3 {
        font-size: 12px !important;
        margin-bottom: 16px !important;
        letter-spacing: 1.5px !important;
        text-align: center !important;
    }

    .mega-menu-courses .course-title {
        font-size: 16px !important;
        line-height: 1.3 !important;
    }

    .menu-subtitle {
        font-size: 11px !important;
        line-height: 1.4 !important;
    }

    .course-badge {
        font-size: 8px !important;
        padding: 3px 10px !important;
        border-radius: 8px !important;
    }

    .mega-menu-courses li {
        margin-bottom: 18px !important;
        padding: 14px 18px !important;
    }
}

/* ========== DESKTOP (min-width: 1025px) ========== */
@media (min-width: 1025px) {
    .coactive-mega-menu {
        z-index: 99999 !important;
        overflow-x: hidden !important;
    }
    
    .mega-menu-container {
        max-width: min(700px, calc(100vw - 80px)) !important;
        gap: clamp(40px, 6vw, 60px) !important;
        box-sizing: border-box !important;
        flex-direction: row !important;
    }
    
    .mega-menu-section h3 {
        font-size: 12px !important;
        letter-spacing: 2px !important;
        text-align: left !important;
    }

    .mega-menu-courses .course-title {
        font-size: 16px !important;
    }

    .menu-subtitle {
        font-size: 11px !important;
    }

    .course-badge {
        font-size: 7px !important;
        padding: clamp(2px, 0.2vw, 3px) 10px !important;
    }
}

/* ========== LARGE DESKTOP (min-width: 1440px) ========== */
@media (min-width: 1440px) {
    .coactive-mega-menu {
        z-index: 99999 !important;
        overflow-x: hidden !important;
        max-width: 100vw !important;
    }
    
    .mega-menu-container {
        max-width: min(clamp(800px, 60vw, 1000px), calc(100vw - clamp(120px, 15vw, 300px))) !important;
        gap: clamp(60px, 5vw, 120px) !important;
        padding: clamp(32px, 3vw, 56px) clamp(24px, 2.5vw, 48px) !important;
        box-sizing: border-box !important;
        margin: 0 auto !important;
    }
    
    .mega-menu-section h3 {
        font-size: clamp(12px, 1vw, 18px) !important;
        letter-spacing: clamp(2.5px, 0.2vw, 3.5px) !important;
        margin-bottom: clamp(20px, 2vw, 34px) !important;
    }

    .mega-menu-courses .course-title {
        font-size: clamp(16px, 1.2vw, 22px) !important;
        line-height: 1.4 !important;
    }

    .menu-subtitle {
        
        line-height: 1.5 !important;
    }

    .course-badge {
        font-size: clamp(8px, 0.6vw, 12px) !important;
        padding: clamp(2px, 0.2vw, 5px) clamp(10px, 0.8vw, 18px) !important;
        border-radius: clamp(12px, 1vw, 18px) !important;
    }
}

    .course-badge {
        font-size: clamp(10px, 0.4vw, 12px) !important;
        padding: clamp(3px, 0.15vw, 5px) clamp(14px, 0.6vw, 18px) !important;
        border-radius: 16px !important;
    }


/* ========== LANDSCAPE ORIENTATION FOR MOBILE ========== */
@media (max-height: 500px) and (orientation: landscape) and (max-width: 1024px) {
    .coactive-mega-menu {
        height: 100vh !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        padding: 12px !important;
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        z-index: 99999 !important;
        background: rgba(255, 255, 255, 0.98) !important;
        backdrop-filter: blur(10px) !important;
    }
    
    .mega-menu-container {
        flex-direction: row !important;
        gap: 20px !important;
        padding: 16px 12px !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .mega-menu-section h3 {
        font-size: 10px !important;
        margin-bottom: 12px !important;
        letter-spacing: 1px !important;
    }

    .course-title-mobile {
        font-size: 14px !important;
        line-height: 1.2 !important;
    }

    .menu-subtitle-mobile {
        font-size: 11px !important;
        line-height: 1.3 !important;
    }

    .course-badge-mobile {
        font-size: 8px !important;
        padding: 3px 6px !important;
    }
}

/* ========== MOBILE STYLES (768px and below) ========== */
@media (max-width: 768px) {
    /* Ensure mobile menu container is properly sized */
    .coactive-mega-menu {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 100vh !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        background: rgba(255, 255, 255, 0.98) !important;
        backdrop-filter: blur(10px) !important;
        border-radius: 0 !important;
        padding: clamp(16px, 4vw, 20px) !important;
        box-sizing: border-box !important;
        z-index: 99999 !important;
    }
    
    .mega-menu-container {
        background: #ffffff !important;
        border-radius: 0 !important;
        flex-direction: column !important;
        gap: 0 !important;
        padding: 0 !important;
        max-width: 100% !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .mega-menu-section h3 {
        font-size: clamp(10px, 2.5vw, 12px) !important;
        margin-bottom: clamp(16px, 4vw, 18px) !important;
        letter-spacing: 1.5px !important;
    }

    /* Reset desktop hover effects on mobile */
    .mega-menu-courses li:nth-child(1):hover,
    .mega-menu-courses li:nth-child(2):hover,
    .mega-menu-courses li:nth-child(3):hover,
    li.menu-item-22992398:hover,
    li.menu-item-22992399:hover,
    li.menu-item-22992400:hover {
        background: transparent !important;
        transform: none !important;
        box-shadow: none !important;
        animation: none !important;
    }

    .mega-menu-courses li:hover .course-title,
    .mega-menu-courses li:hover .menu-subtitle,
    .mega-menu-courses li:hover .course-badge {
        color: inherit !important;
    }

    /* Mobile course items */
    .course-item-mobile {
        display: flex !important;
        align-items: center !important;
        padding: 16px 0 !important;
        margin: 0 !important;
        border-bottom: 1px solid #f0f0f0 !important;
        background: transparent !important;
        border-radius: 0 !important;
        transition: all 0.3s ease !important;
        min-height: 44px !important;
        box-sizing: border-box !important;
    }

    .course-item-mobile:last-child {
        border-bottom: none !important;
    }

    .course-item-mobile.has-badge-mobile {
        position: relative !important;
    }

    .course-item-mobile.coming-soon-mobile {
        opacity: 0.7 !important;
    }

    /* Mobile course titles */
    .course-title-mobile {
        display: block !important;
        font-size: clamp(16px, 4vw, 18px) !important;
        font-weight: 600 !important;
        color: #2c2c2c !important;
        margin: 0 0 4px 0 !important;
        line-height: 1.3 !important;
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
        transition: color 0.3s ease !important;
    }

    /* Mobile course subtitles */
    .menu-subtitle-mobile {
        display: block !important;
        font-size: clamp(12px, 3vw, 14px) !important;
        color: #666 !important;
        font-weight: 400 !important;
        margin: 0 !important;
        line-height: 1.4 !important;
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
        text-transform: capitalize !important;
        transition: color 0.3s ease !important;
    }

    /* Mobile section headers with line */
    .menu-item-with-line-mobile {
        display: block !important;
        font-weight: 700 !important;
        text-transform: uppercase !important;
        letter-spacing: 1px !important;
        margin: 24px 0 16px 0 !important;
        padding-bottom: 8px !important;
        border-bottom: 2px solid #C4347C !important;
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    }

    .menu-item-with-line-mobile:first-child {
        margin-top: 0 !important;
    }

    /* Mobile badges */
    .course-badge-mobile {
        display: inline-block !important;
        font-size: clamp(8px, 2vw, 10px) !important;
        font-weight: 600 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.5px !important;
        padding: 4px 8px !important;
        border-radius: 4px !important;
        margin-top: 8px !important;
        margin-left: 0 !important;
        vertical-align: middle !important;
        transition: all 0.3s ease !important;
        font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
        box-sizing: border-box !important;
    }

    /* Mobile badges - horizontally centered */
    .course-badge-mobile.cpcc {
        background-color: white !important;
        color: #C53D8B !important;
        font-weight: 700;
        padding: 6px 12px;
        border-radius: 6px;
        font-size: 10px;
        text-transform: uppercase;
        letter-spacing: 0.5px;
        display: block;
        width: fit-content;
        position: absolute;
        top: 20px;
        left: 50%;
        transform: translateX(-50%);
        margin: 0;
        z-index: 10;
    }

    .course-badge-mobile.coming {
        background-color: #FF9500 !important;
        color: white !important;
        font-weight: 600;
        padding: 6px 12px;
        border-radius: 6px;
        font-size: 10px;
        text-transform: uppercase;
        letter-spacing: 0.5px;
        display: block;
        width: fit-content;
        position: absolute;
        top: 20px;
        left: 50%;
        transform: translateX(-50%);
        margin: 0;
        z-index: 10;
    }

    /* Mobile specific hover for course items */
    .course-item-mobile:hover {
        background-color: #f8f9fa !important;
        transform: none !important;
    }

    .course-item-mobile:hover .course-title-mobile {
        color: #C4347C !important;
    }

    /* Mobile gradients for specific items */
    #menu-item-22992656 {
        background: linear-gradient(90deg, #155F5A 0%, #0EB5E0 100%) !important;
        border-radius: 12px;
        padding: 20px 16px;
        margin: 12px 0;
        box-shadow: 0 4px 15px rgba(21, 95, 90, 0.3);
        border-bottom: none;
        display: flex;
        flex-direction: column;
    }

    #menu-item-22992656 .course-title-mobile,
    #menu-item-22992656 .menu-subtitle-mobile {
        color: white !important;
        font-weight: 600;
    }

    #menu-item-22992657 {
        background: linear-gradient(90deg, #273B76 0%, #C53D8B 100%) !important;
        border-radius: 12px;
        padding: 20px 16px;
        margin: 12px 0;
        box-shadow: 0 4px 15px rgba(39, 59, 118, 0.3);
        border-bottom: none;
        display: flex;
        flex-direction: column;
    }

    #menu-item-22992657 .course-title-mobile,
    #menu-item-22992657 .menu-subtitle-mobile {
        color: white !important;
        font-weight: 600;
    }

    #menu-item-22992658 {
        background: linear-gradient(90deg, rgba(39, 59, 118, 0.8) 0%, rgba(197, 30, 139, 1) 20%) !important;
        border-radius: 12px;
        padding: 20px 16px;
        margin: 12px 0;
        box-shadow: 0 4px 15px rgba(39, 59, 118, 0.3);
        border-bottom: none;
        display: flex;
        flex-direction: column;
        position: relative;
    }

    #menu-item-22992658 .course-title-mobile,
    #menu-item-22992658 .menu-subtitle {
        color: white !important;
        font-weight: 600;
    }

    #menu-item-22992659 {
        background: transparent !important;
        border-radius: 0;
        padding: 16px 0;
        margin: 8px 0;
        box-shadow: none;
        border-bottom: 1px solid #f0f0f0;
        display: flex;
        flex-direction: column;
        position: relative;
    }

    #menu-item-22992659 .course-title-mobile,
    #menu-item-22992659 .menu-subtitle {
        color: #9CA3AF !important;
        font-weight: 600;
    }

    /* Adjust padding-top on elements that have badges */
    #menu-item-22992658,
    #menu-item-22992659 {
        padding-top: 60px !important;
    }
}