/* ───────────────────────────────────────
   Elementor Mega Menu – Plugin Styles v13
   ─────────────────────────────────────── */

.emm-has-mega-menu {
    position: static !important;
}

/* Container is appended to <header> by JS */
.emm-mega-menu-container {
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    width: 100%;
    z-index: 99999;
    box-sizing: border-box;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.22s ease, visibility 0.22s;
}

/* Show via JS class (not :hover, since container is in header) */
.emm-mega-menu-container.emm-visible {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
}

.emm-mega-menu-inner {
    width: 100%;
    overflow: visible;
}

.emm-has-mega-menu > .sub-menu {
    display: none !important;
}

@media (max-width: 1024px) {
    .emm-mega-menu-container {
        position: relative !important;
        top: auto !important;
        left: auto;
        right: auto;
        width: 100%;
        visibility: hidden;
        opacity: 0;
        max-height: 0;
        overflow: hidden;
        transition: opacity 0.3s ease, max-height 0.35s ease, visibility 0.3s;
    }
    .emm-mega-menu-container.emm-visible {
        visibility: visible;
        opacity: 1;
        max-height: 3000px;
    }
}


/* =================================================
   MEGA MENU CARDS – PRODUCTION CSS
   ================================================= */

.mega-card,
.mega-card > .e-con-inner,
.mega-card > .elementor-container,
.mega-card > .elementor-widget-wrap {
    border-radius: 20px !important;
    cursor: pointer;
    overflow: hidden;
    transition:
        transform 360ms cubic-bezier(.16,1,.3,1),
        background-color 520ms cubic-bezier(.22,1,.36,1);
    will-change: transform, background-color;
}

.mega-card:not(.mega-card-default),
.mega-card:not(.mega-card-default) > .e-con-inner,
.mega-card:not(.mega-card-default) > .elementor-container,
.mega-card:not(.mega-card-default) > .elementor-widget-wrap {
    background-color: #f2f3f5 !important;
}

.mega-card:hover,
.mega-card.is-active,
.mega-card:hover > .e-con-inner,
.mega-card.is-active > .e-con-inner,
.mega-card:hover > .elementor-container,
.mega-card.is-active > .elementor-container,
.mega-card:hover > .elementor-widget-wrap,
.mega-card.is-active > .elementor-widget-wrap {
    background-color: #1a1b1e !important;
    transform: translateY(-6px) scale(1.008);
}

.mega-card {
    position: relative;
    transform: translateZ(0);
}

.mega-card::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 20px;
    pointer-events: none;
    opacity: 0;
    transition: opacity 320ms cubic-bezier(.22,1,.36,1);
    box-shadow: 0 28px 60px rgba(0,0,0,.18);
}

.mega-card:hover::after,
.mega-card.is-active::after {
    opacity: 1;
}

.mega-card .elementor-heading-title,
.mega-card p,
.mega-card a,
.mega-card span {
    transition: color 420ms cubic-bezier(.22,1,.36,1);
}

.mega-card:not(.mega-card-default) .elementor-heading-title,
.mega-card:not(.mega-card-default) p,
.mega-card:not(.mega-card-default) a,
.mega-card:not(.mega-card-default) span {
    color: #1a1b1e !important;
}

.mega-card:hover .elementor-heading-title,
.mega-card.is-active .elementor-heading-title,
.mega-card:hover p,
.mega-card.is-active p,
.mega-card:hover a,
.mega-card.is-active a,
.mega-card:hover span,
.mega-card.is-active span {
    color: #ffffff !important;
}

.mega-card .elementor-icon {
    transition: color 420ms cubic-bezier(.22,1,.36,1);
}

.mega-card:not(.mega-card-default) .elementor-icon {
    color: #b7bcc3 !important;
}

.mega-card .elementor-icon svg {
    fill: currentColor !important;
    stroke: currentColor !important;
}

.mega-card .elementor-icon svg * {
    fill: currentColor !important;
    stroke: currentColor !important;
    opacity: 1 !important;
}

.mega-card:hover .elementor-icon,
.mega-card.is-active .elementor-icon {
    color: #1ebfbf !important;
    filter: none !important;
}

.mega-card:hover .elementor-icon svg,
.mega-card.is-active .elementor-icon svg {
    filter: drop-shadow(0 0 12px rgba(30,191,191,.55))
            drop-shadow(0 0 26px rgba(30,191,191,.35));
}

.mega-menu.has-non-default-active .mega-card-default,
.mega-menu.has-non-default-active .mega-card-default > .e-con-inner,
.mega-menu.has-non-default-active .mega-card-default > .elementor-container,
.mega-menu.has-non-default-active .mega-card-default > .elementor-widget-wrap {
    background-color: #f2f3f5 !important;
    transform: none !important;
}

.mega-menu.has-non-default-active .mega-card-default .elementor-heading-title,
.mega-menu.has-non-default-active .mega-card-default p,
.mega-menu.has-non-default-active .mega-card-default a,
.mega-menu.has-non-default-active .mega-card-default span {
    color: #1a1b1e !important;
}

.mega-menu.has-non-default-active .mega-card-default .elementor-icon {
    color: #b7bcc3 !important;
    filter: none !important;
}

@keyframes megaCardBump {
    0%   { transform: translateY(6px) scale(0.985); opacity: .92; }
    55%  { transform: translateY(-3px) scale(1.01); opacity: 1; }
    100% { transform: translateY(0) scale(1); }
}

.mega-menu.is-opening .mega-card:not(.mega-card-default) {
    animation: megaCardBump 520ms cubic-bezier(.16,1,.3,1) both;
}

.mega-menu.is-opening .mega-card:not(.mega-card-default):nth-child(1) { animation-delay: 0ms; }
.mega-menu.is-opening .mega-card:not(.mega-card-default):nth-child(2) { animation-delay: 50ms; }
.mega-menu.is-opening .mega-card:not(.mega-card-default):nth-child(3) { animation-delay: 100ms; }
.mega-menu.is-opening .mega-card:not(.mega-card-default):nth-child(4) { animation-delay: 150ms; }
.mega-menu.is-opening .mega-card:not(.mega-card-default):nth-child(5) { animation-delay: 200ms; }

@media (prefers-reduced-motion: reduce) {
    .mega-card,
    .mega-card::after {
        transition: none !important;
        animation: none !important;
        transform: none !important;
    }
}
