/**
 * Kaveh Mega Menu Styles
 * A robust, feature-rich mega menu for Elementor
 */

/* ========================================
   BASE STYLES
   ======================================== */

.kaveh-megamenu {
    position: relative;
    width: 100%;
}

.kaveh-megamenu *,
.kaveh-megamenu *::before,
.kaveh-megamenu *::after {
    box-sizing: border-box;
}

/* ========================================
   DESKTOP MENU
   ======================================== */

.kaveh-megamenu__desktop {
    display: flex;
    width: 100%;
}

.kaveh-megamenu__list {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    margin: 0;
    padding: 0;
    width: 100%;
}

.kaveh-megamenu__item {
    position: relative;
    display: flex;
    align-items: center;
}

.kaveh-megamenu__link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    text-decoration: none;
    color: inherit;
    transition: all 0.3s ease;
    white-space: nowrap;
    position: relative;
}

.kaveh-megamenu__link-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.kaveh-megamenu__link-icon svg {
    fill: currentColor;
}

.kaveh-megamenu__indicator {
    display: inline-flex;
    align-items: center;
    margin-inline-start: 4px;
    transition: transform 0.3s ease;
}

.kaveh-megamenu__indicator svg {
    fill: currentColor;
}

.kaveh-megamenu__item:hover > .kaveh-megamenu__link .kaveh-megamenu__indicator,
.kaveh-megamenu__item.is-open > .kaveh-megamenu__link .kaveh-megamenu__indicator {
    transform: rotate(180deg);
}

/* Badge */
.kaveh-megamenu__badge {
    position: absolute;
    top: 0;
    inset-inline-end: 0;
    transform: translate(50%, -50%);
    padding: 2px 8px;
    font-size: 10px;
    font-weight: 600;
    line-height: 1.4;
    border-radius: 10px;
    color: #fff;
    white-space: nowrap;
    z-index: 5;
}

/* ========================================
   DROPDOWN MENU
   ======================================== */

.kaveh-megamenu__sub {
    position: absolute;
    top: 100%;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
}

.kaveh-megamenu__item:hover > .kaveh-megamenu__sub,
.kaveh-megamenu__item.is-open > .kaveh-megamenu__sub {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.kaveh-megamenu__dropdown {
    left: 0;
    list-style: none;
    margin: 0;
    padding: 8px 0;
    background: #fff;
    border-radius: 4px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
    min-width: 200px;
}

[dir="rtl"] .kaveh-megamenu__dropdown {
    left: auto;
    right: 0;
}

.kaveh-megamenu__dropdown li {
    position: relative;
}

.kaveh-megamenu__dropdown a {
    display: block;
    padding: 10px 20px;
    color: inherit;
    text-decoration: none;
    transition: all 0.2s ease;
    white-space: nowrap;
}

.kaveh-megamenu__dropdown a:hover {
    background-color: rgba(0, 0, 0, 0.04);
}

/* Nested dropdown */
.kaveh-megamenu__dropdown-sub {
    position: absolute;
    top: 0;
    left: 100%;
    list-style: none;
    margin: 0;
    padding: 8px 0;
    background: #fff;
    border-radius: 4px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
    min-width: 180px;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

[dir="rtl"] .kaveh-megamenu__dropdown-sub {
    left: auto;
    right: 100%;
}

.kaveh-megamenu__dropdown li:hover > .kaveh-megamenu__dropdown-sub {
    opacity: 1;
    visibility: visible;
}

/* ========================================
   MEGA MENU PANEL
   ======================================== */

.kaveh-megamenu__mega {
    background: #fff;
    border-radius: 4px;
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.15);
    padding: 20px;
    overflow: visible;
    height: auto;
    min-height: 0;
}

.kaveh-megamenu__mega-inner {
    width: 100%;
    height: auto;
    display: block;
}

/* Ensure Elementor content inside mega menu displays at full height */
.kaveh-megamenu__mega .elementor,
.kaveh-megamenu__mega .elementor-inner,
.kaveh-megamenu__mega .elementor-section-wrap,
.kaveh-megamenu__mega .elementor-section,
.kaveh-megamenu__mega .elementor-container,
.kaveh-megamenu__mega .elementor-row,
.kaveh-megamenu__mega .elementor-column,
.kaveh-megamenu__mega .elementor-column-wrap,
.kaveh-megamenu__mega .elementor-widget-wrap {
    height: auto !important;
    min-height: 0 !important;
}

/* Mega Menu Width Options */
.kaveh-megamenu__mega.mega-width-full {
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: var(--container-max-width, 1200px);
}

.kaveh-megamenu__mega.mega-width-full-screen {
    left: 0;
    right: 0;
    width: 100vw;
    margin-left: calc(-50vw + 50%);
    border-radius: 0;
}

.kaveh-megamenu__mega.mega-width-auto {
    width: max-content;
    max-width: calc(100vw - 40px);
}

.kaveh-megamenu__mega.mega-width-custom {
    max-width: calc(100vw - 40px);
}

/* Mega Menu Position Options */
.kaveh-megamenu__mega.mega-pos-left {
    left: 0;
    transform: none;
}

.kaveh-megamenu__mega.mega-pos-center {
    left: 50%;
    transform: translateX(-50%);
}

.kaveh-megamenu__mega.mega-pos-right {
    left: auto;
    right: 0;
    transform: none;
}

[dir="rtl"] .kaveh-megamenu__mega.mega-pos-left {
    left: auto;
    right: 0;
}

[dir="rtl"] .kaveh-megamenu__mega.mega-pos-right {
    right: auto;
    left: 0;
}

/* Ensure Elementor content renders properly */
.kaveh-megamenu__mega .elementor {
    width: 100%;
    height: auto;
}

/* Remove any height restrictions from Elementor elements */
.kaveh-megamenu__mega .elementor-element {
    height: auto;
}

.kaveh-megamenu__mega .elementor-section-boxed > .elementor-container {
    max-width: 100%;
}

/* Ensure all nested Elementor content displays properly */
.kaveh-megamenu__mega .elementor-section.elementor-section-boxed,
.kaveh-megamenu__mega .elementor-section.elementor-section-full_width {
    width: 100%;
    height: auto;
}

.kaveh-megamenu__mega .elementor-widget {
    height: auto;
}

/* Force mega menu content to display fully - override any conflicting styles */
.kaveh-megamenu__mega,
.kaveh-megamenu__mega *:not(svg):not(path) {
    max-height: none !important;
}

.kaveh-megamenu__mega .e-con,
.kaveh-megamenu__mega .e-con-inner,
.kaveh-megamenu__mega .e-child {
    height: auto !important;
    min-height: 0 !important;
}

/* Flexbox container fix for newer Elementor versions */
.kaveh-megamenu__mega .elementor-element.elementor-element-edit-mode {
    height: auto;
}

.kaveh-megamenu__mega .elementor-section > .elementor-container {
    height: auto;
    min-height: 0;
}

.kaveh-megamenu__mega .elementor-column-gap-default > .elementor-column > .elementor-element-populated {
    height: auto;
}

/* ========================================
   ANIMATIONS
   ======================================== */

/* Fade */
.kaveh-megamenu__sub.anim-fade {
    transform: translateY(0);
}

/* Fade Up */
.kaveh-megamenu__sub.anim-fade-up {
    transform: translateY(10px);
}

.kaveh-megamenu__item:hover > .kaveh-megamenu__sub.anim-fade-up,
.kaveh-megamenu__item.is-open > .kaveh-megamenu__sub.anim-fade-up {
    transform: translateY(0);
}

.kaveh-megamenu__mega.mega-pos-center.anim-fade-up {
    transform: translateX(-50%) translateY(10px);
}

.kaveh-megamenu__item:hover > .kaveh-megamenu__mega.mega-pos-center.anim-fade-up,
.kaveh-megamenu__item.is-open > .kaveh-megamenu__mega.mega-pos-center.anim-fade-up {
    transform: translateX(-50%) translateY(0);
}

.kaveh-megamenu__mega.mega-width-full.anim-fade-up {
    transform: translateX(-50%) translateY(10px);
}

.kaveh-megamenu__item:hover > .kaveh-megamenu__mega.mega-width-full.anim-fade-up,
.kaveh-megamenu__item.is-open > .kaveh-megamenu__mega.mega-width-full.anim-fade-up {
    transform: translateX(-50%) translateY(0);
}

/* Fade Down */
.kaveh-megamenu__sub.anim-fade-down {
    transform: translateY(-10px);
}

.kaveh-megamenu__item:hover > .kaveh-megamenu__sub.anim-fade-down,
.kaveh-megamenu__item.is-open > .kaveh-megamenu__sub.anim-fade-down {
    transform: translateY(0);
}

.kaveh-megamenu__mega.mega-pos-center.anim-fade-down {
    transform: translateX(-50%) translateY(-10px);
}

.kaveh-megamenu__item:hover > .kaveh-megamenu__mega.mega-pos-center.anim-fade-down,
.kaveh-megamenu__item.is-open > .kaveh-megamenu__mega.mega-pos-center.anim-fade-down {
    transform: translateX(-50%) translateY(0);
}

/* Zoom */
.kaveh-megamenu__sub.anim-zoom {
    transform: scale(0.95);
    transform-origin: top center;
}

.kaveh-megamenu__item:hover > .kaveh-megamenu__sub.anim-zoom,
.kaveh-megamenu__item.is-open > .kaveh-megamenu__sub.anim-zoom {
    transform: scale(1);
}

.kaveh-megamenu__mega.mega-pos-center.anim-zoom {
    transform: translateX(-50%) scale(0.95);
}

.kaveh-megamenu__item:hover > .kaveh-megamenu__mega.mega-pos-center.anim-zoom,
.kaveh-megamenu__item.is-open > .kaveh-megamenu__mega.mega-pos-center.anim-zoom {
    transform: translateX(-50%) scale(1);
}

.kaveh-megamenu__mega.mega-width-full.anim-zoom {
    transform: translateX(-50%) scale(0.95);
}

.kaveh-megamenu__item:hover > .kaveh-megamenu__mega.mega-width-full.anim-zoom,
.kaveh-megamenu__item.is-open > .kaveh-megamenu__mega.mega-width-full.anim-zoom {
    transform: translateX(-50%) scale(1);
}

/* ========================================
   MOBILE MENU
   ======================================== */

.kaveh-megamenu__toggle-wrap {
    display: none;
    width: 100%;
}

.kaveh-megamenu__toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 10px;
    color: inherit;
    transition: all 0.3s ease;
}

.kaveh-megamenu__toggle-close {
    display: none;
}

.kaveh-megamenu.menu-open .kaveh-megamenu__toggle-open {
    display: none;
}

.kaveh-megamenu.menu-open .kaveh-megamenu__toggle-close {
    display: flex;
}

/* Overlay */
.kaveh-megamenu__overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 9998;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.kaveh-megamenu.menu-open .kaveh-megamenu__overlay {
    opacity: 1;
    visibility: visible;
}

/* Panel Base */
.kaveh-megamenu__panel {
    position: fixed;
    z-index: 9999;
    background: #fff;
    overflow-y: auto;
    transition: transform 0.3s ease;
}

/* Panel Right */
.kaveh-megamenu__panel--right {
    top: 0;
    right: 0;
    height: 100%;
    width: 300px;
    max-width: 100%;
    transform: translateX(100%);
    box-shadow: -4px 0 20px rgba(0, 0, 0, 0.1);
}

[dir="rtl"] .kaveh-megamenu__panel--right {
    right: auto;
    left: 0;
    transform: translateX(-100%);
    box-shadow: 4px 0 20px rgba(0, 0, 0, 0.1);
}

.kaveh-megamenu.menu-open .kaveh-megamenu__panel--right {
    transform: translateX(0);
}

/* Panel Left */
.kaveh-megamenu__panel--left {
    top: 0;
    left: 0;
    height: 100%;
    width: 300px;
    max-width: 100%;
    transform: translateX(-100%);
    box-shadow: 4px 0 20px rgba(0, 0, 0, 0.1);
}

[dir="rtl"] .kaveh-megamenu__panel--left {
    left: auto;
    right: 0;
    transform: translateX(100%);
    box-shadow: -4px 0 20px rgba(0, 0, 0, 0.1);
}

.kaveh-megamenu.menu-open .kaveh-megamenu__panel--left {
    transform: translateX(0);
}

/* Panel Top */
.kaveh-megamenu__panel--top {
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    max-height: 80vh;
    transform: translateY(-100%);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

.kaveh-megamenu.menu-open .kaveh-megamenu__panel--top {
    transform: translateY(0);
}

/* Close Button */
.kaveh-megamenu__close {
    position: absolute;
    top: 15px;
    inset-inline-end: 15px;
    background: transparent;
    border: none;
    cursor: pointer;
    font-size: 20px;
    padding: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: inherit;
    z-index: 10;
}

/* Mobile List */
.kaveh-megamenu__mobile-list {
    list-style: none;
    margin: 0;
    padding: 50px 0 20px;
}

.kaveh-megamenu__mobile-item {
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.kaveh-megamenu__mobile-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 15px 20px;
    color: inherit;
    text-decoration: none;
    transition: background-color 0.2s ease;
}

.kaveh-megamenu__mobile-link:hover {
    background-color: rgba(0, 0, 0, 0.03);
}

.kaveh-megamenu__mobile-icon {
    display: inline-flex;
}

.kaveh-megamenu__mobile-arrow {
    margin-inline-start: auto;
    display: inline-flex;
    transition: transform 0.3s ease;
}

.kaveh-megamenu__mobile-item.is-open > .kaveh-megamenu__mobile-link .kaveh-megamenu__mobile-arrow {
    transform: rotate(180deg);
}

/* Mobile Submenu */
.kaveh-megamenu__mobile-sub {
    list-style: none;
    margin: 0;
    padding: 0;
    background: rgba(0, 0, 0, 0.03);
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

.kaveh-megamenu__mobile-item.is-open > .kaveh-megamenu__mobile-sub {
    max-height: 500px;
}

.kaveh-megamenu__mobile-sub a {
    display: block;
    padding: 12px 20px 12px 40px;
    color: inherit;
    text-decoration: none;
    font-size: 0.95em;
}

[dir="rtl"] .kaveh-megamenu__mobile-sub a {
    padding: 12px 40px 12px 20px;
}

.kaveh-megamenu__mobile-sub a:hover {
    background-color: rgba(0, 0, 0, 0.03);
}

/* ========================================
   RTL SUPPORT
   ======================================== */

[dir="rtl"] .kaveh-megamenu__indicator {
    margin-inline-start: 4px;
    margin-inline-end: 0;
}

/* ========================================
   ACCESSIBILITY
   ======================================== */

.kaveh-megamenu__item:focus-within > .kaveh-megamenu__sub {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.kaveh-megamenu__toggle:focus,
.kaveh-megamenu__close:focus,
.kaveh-megamenu__link:focus {
    outline: 2px solid currentColor;
    outline-offset: 2px;
}

/* ========================================
   PRINT
   ======================================== */

@media print {
    .kaveh-megamenu__toggle-wrap,
    .kaveh-megamenu__overlay,
    .kaveh-megamenu__panel {
        display: none !important;
    }
    
    .kaveh-megamenu__desktop {
        display: block !important;
    }
    
    .kaveh-megamenu__sub {
        position: static !important;
        opacity: 1 !important;
        visibility: visible !important;
        transform: none !important;
        box-shadow: none !important;
    }
}
