/* 
 * FluxMenu Base Styling 
 * Confined to FluxMenu components only to prevent theme conflicts 
 */

:root {
    --flux-main-bg: #ffffff;
    --flux-item-color: #334155;
    --flux-item-hover: #6366f1;
    --flux-sub-bg: #ffffff;
    --flux-sub-color: #334155;
    --flux-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --flux-mega-width: 1240px;
}

html,
body {
    overflow-x: hidden !important;
}

/* Suppress Theme Dropdown Arrows */
.flux-menu-container .flux-menu li::after,
.flux-menu-container .flux-menu li::before,
.flux-menu-container .flux-menu a::after,
.flux-menu-container .flux-menu a::before {
    content: none !important;
    display: none !important;
}

/* Base Container Styling */
.flux-menu-container {
    background-color: var(--flux-main-bg) !important;
    width: var(--flux-bar-width, 100%) !important;
    max-width: var(--flux-bar-max-width, 100%) !important;
    margin-top: var(--flux-bar-margin-top, 0) !important;
    margin-bottom: var(--flux-bar-margin-bottom, 0) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    position: relative;
    overflow: visible !important;
    /* CRITICAL: allow dropdowns to escape */
    box-shadow: var(--flux-bar-shadow) !important;
    border: var(--flux-bar-border, none) !important;
    transition: all var(--flux-sticky-speed, 300ms) ease;
    z-index: 9999;
}

/* Menu Only Mode: Inherit theme styling as much as possible */
.flux-menu-only {
    background-color: transparent !important;
    box-shadow: none !important;
    border: none !important;
    width: auto !important;
    display: inline-block;
    /* Allow it to sit inside theme columns */
}

.flux-menu-only .flux-menu-wrapper {
    padding: 0 !important;
}

/* Full Width Navbar Logic - Truly Edge-to-Edge using ::before pseudo element */
/* NOTE: clip-path was removed because it clips absolutely positioned dropdown children */
.flux-menu-full-width {
    width: 100% !important;
    max-width: 100% !important;
    left: 0 !important;
    right: 0 !important;
    border-radius: 0 !important;
    /* Use background on the element itself — no clip-path that would cut off dropdowns */
}

.flux-menu-full-width .flux-navbar-grid {
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 !important;
    padding-top: var(--flux-bar-padding-top, 0) !important;
    padding-bottom: var(--flux-bar-padding-bottom, 0) !important;
    padding-left: var(--flux-bar-padding-left, 30px) !important;
    padding-right: var(--flux-bar-padding-right, 30px) !important;
    /* Breathing room from extreme screen edges */
}

.flux-navbar-grid {
    max-width: var(--flux-sub-row-width, var(--flux-mega-width)) !important;
    margin: 0 auto !important;
    padding-top: var(--flux-bar-padding-top, 0) !important;
    padding-bottom: var(--flux-bar-padding-bottom, 0) !important;
    padding-left: var(--flux-bar-padding-left, 0) !important;
    padding-right: var(--flux-bar-padding-right, 0) !important;
}

/* Navbar Grid & Columns */
.flux-navbar-grid {
    display: flex !important;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 60px;
    gap: 20px;
}

/* Flex Column Adjustments */
.flux-grid-col {
    display: flex;
    align-items: center;
    height: 100%;
}

.flux-grid-left {
    flex-shrink: 0;
}

.flux-grid-center {
    /* flex-grow: 1; */
    display: flex;
    align-items: center;
}

.flux-grid-right {
    flex-shrink: 0;
}

.flux-grid-col {
    display: flex;
    align-items: center;
    height: 100%;
}

/* Removed old layout-specific grid constraints */

.flux-brand-logo {
    flex-shrink: 0;
    transition: all 0.3s ease;
}

.flux-brand-logo img {
    width: var(--flux-logo-width, 150px) !important;
    max-width: none !important;
    height: auto !important;
    display: block;
    transition: width var(--flux-sticky-speed, 300ms) ease;
}

.flux-menu-wrapper {
    display: flex;
    align-items: center;
    height: 100%;
}

.flux-menu {
    display: flex !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    white-space: nowrap !important;
    /* Prevent wrapping */
}

/* Sticky States */
.flux-menu-container.flux-is-sticky {
    position: fixed !important;
    top: var(--flux-sticky-offset, 0px);
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    background-color: var(--flux-sticky-bg, var(--flux-main-bg)) !important;
    z-index: 99999;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.1) !important;
    border-radius: 0 !important;
    transform: translateY(-100%);
    opacity: var(--flux-sticky-op, 1);
    padding: var(--flux-sticky-pad, 10px) 0 !important;
}

.flux-menu-container.flux-is-sticky .flux-navbar-grid {
    max-width: var(--flux-mega-width);
    margin: 0 auto;
}

.flux-menu-container.flux-sticky-active {
    transform: translateY(0);
}

/* Shrink Logo on Sticky */
.flux-menu-container.flux-sticky-shrink .flux-brand-logo img {
    width: var(--flux-shrink-width, 100px) !important;
}

/* Extras Wrapper & Items */
.flux-extras-wrapper {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 15px;
    padding: 0 10px;
    height: 100%;
}

.flux-extra-item {
    display: flex !important;
    align-items: center !important;
    position: relative;
    height: 100%;
}

.flux-search-toggle {
    position: relative !important;
    top: 0 !important;
    left: 0 !important;
}

.flux-extra-item a {
    color: var(--flux-item-color);
    font-size: 20px;
    text-decoration: none;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
}

.flux-extra-item a:hover {
    color: var(--flux-item-hover);
    background: rgba(0, 0, 0, 0.05);
}

.flux-social-extra a {
    color: var(--flux-social-color, var(--flux-item-color));
    font-size: 18px;
    width: 32px;
    height: 32px;
}

.flux-social-extra a:hover {
    color: var(--flux-social-hover, var(--flux-item-hover));
}

/* Search Extra Toggle */
.flux-search-extra .flux-search-form-wrap {
    position: absolute;
    top: 100%;
    right: 0;
    background: #fff;
    padding: 15px;
    box-shadow: var(--flux-shadow);
    border-radius: 8px;
    width: 300px;
    display: none;
    z-index: 100;
}

.flux-search-extra .flux-search-form-wrap.active {
    display: block;
    animation: fluxFadeIn 0.3s ease;
}

/* Cart Extra */
.flux-cart-extra .flux-cart-count {
    position: absolute;
    top: 2px;
    right: 2px;
    background: var(--flux-item-hover);
    color: #fff;
    font-size: 10px;
    min-width: 16px;
    height: 16px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
}

@keyframes fluxFadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}


.flux-menu-container ul.flux-menu {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex;
    align-items: center;
    flex-wrap: nowrap !important;
    width: 100%;
}

.flux-menu-container .flux-menu .flux-menu-item {
    position: relative;
    list-style: none !important;
    margin: 0 !important;
}

/* Item Layout Variations */
.flux-layout-icon-top>a {
    flex-direction: column !important;
    text-align: center;
}

.flux-layout-icon-top .flux-icon {
    margin-right: 0 !important;
    margin-bottom: 8px;
}

.flux-layout-icon-right>a {
    flex-direction: row-reverse !important;
}

.flux-layout-icon-right .flux-icon {
    margin-right: 0 !important;
    margin-left: 10px;
}

/* Grid Columns inside Mega Menu */
.flux-mega-mega>.flux-sub-menu .flux-menu-item.flux-col-1-1 {
    grid-column: span var(--flux-mega-cols);
}

.flux-mega-mega>.flux-sub-menu .flux-menu-item.flux-col-1-2 {
    grid-column: span 2;
}

.flux-mega-mega>.flux-sub-menu .flux-menu-item.flux-col-1-3 {
    grid-column: span 1;
}

.flux-mega-mega>.flux-sub-menu .flux-menu-item.flux-col-2-3 {
    grid-column: span 2;
}

.flux-menu-container .flux-menu .flux-menu-item>a {
    display: flex !important;
    align-items: center !important;
    padding: var(--flux-item-padding) !important;
    text-decoration: none !important;
    color: var(--flux-item-color) !important;
    font-weight: var(--flux-font-weight) !important;
    font-size: var(--flux-font-size) !important;
    letter-spacing: var(--flux-letter-spacing) !important;
    text-transform: var(--flux-text-transform) !important;
    transition: all 0.3s ease !important;
    font-family: var(--flux-font-family) !important;
    line-height: var(--flux-line-height) !important;
    background: transparent !important;
    border: none !important;
    border-radius: var(--flux-item-radius, 0) !important;
    padding: var(--flux-item-padding) !important;
}

/* Mega Tabs Logic (UberMenu Style) */
.flux-submenu-type-mega-tabs {
    display: flex !important;
    flex-direction: row;
    padding: 0 !important;
    min-height: 400px;
    background: var(--flux-sub-bg) !important;
    overflow: hidden;
}

.flux-submenu-type-mega-tabs>.flux-menu-item {
    flex: 0 0 240px;
    /* Sidebar width */
    background: rgba(0, 0, 0, 0.02);
    border-right: 1px solid rgba(0, 0, 0, 0.05);
    position: static;
}

.flux-submenu-type-mega-tabs>.flux-menu-item>a {
    padding: 18px 25px !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.03) !important;
    font-weight: 600 !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    color: var(--flux-sub-color) !important;
    opacity: 0.7;
    transition: all 0.2s ease !important;
}

.flux-submenu-type-mega-tabs>.flux-menu-item:hover>a {
    opacity: 1;
    background: rgba(0, 0, 0, 0.01) !important;
}

.flux-submenu-type-mega-tabs>.flux-menu-item.flux-tab-active>a {
    background-color: var(--flux-sub-bg) !important;
    color: var(--flux-item-hover) !important;
    opacity: 1;
    border-right: none !important;
    margin-right: -1px;
    position: relative;
    z-index: 5;
}

/* Arrow indicator on active tab */
.flux-submenu-type-mega-tabs>.flux-menu-item.flux-tab-active>a::after {
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    border-right: 6px solid var(--flux-sub-bg);
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
}

.flux-submenu-type-mega-tabs>.flux-menu-item>.flux-sub-menu {
    position: absolute !important;
    top: 0 !important;
    left: 240px !important;
    right: 0 !important;
    height: 100% !important;
    width: auto !important;
    background: transparent !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: 40px !important;
    display: grid !important;
    grid-template-columns: repeat(var(--flux-mega-cols, 3), 1fr);
    gap: 35px;
    opacity: 0;
    visibility: hidden;
    transform: translateX(15px) !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.flux-submenu-type-mega-tabs>.flux-menu-item.flux-tab-active>.flux-sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(0) !important;
}

/* UberMenu-style Column Headers */
.flux-menu-container .flux-submenu-type-mega .flux-mega-column>a,
.flux-menu-container .flux-submenu-type-mega-tabs .flux-mega-column>a {
    font-size: 14px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    padding: 0 0 12px 0 !important;
    padding-left: 0 !important;
    margin-bottom: 15px !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08) !important;
    color: var(--flux-item-color) !important;
}

.flux-submenu-type-mega .flux-mega-column .flux-sub-menu,
.flux-submenu-type-mega-tabs .flux-mega-column .flux-sub-menu {
    position: static !important;
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    box-shadow: none !important;
    background: transparent !important;
    transform: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.flux-submenu-type-mega .flux-mega-column .flux-menu-item a,
.flux-submenu-type-mega-tabs .flux-mega-column .flux-menu-item a {
    padding: 6px 0 !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    color: var(--flux-sub-color) !important;
    opacity: 0.8;
}

.flux-submenu-type-mega .flux-mega-column .flux-menu-item a:hover,
.flux-submenu-type-mega-tabs .flux-mega-column .flux-menu-item a:hover {
    opacity: 1;
    color: var(--flux-item-hover) !important;
}

.flux-menu-container .flux-sub-menu {
    transition-duration: var(--flux-anim-speed, 300ms) !important;
}

.flux-menu-container .flux-menu .flux-menu-item:hover>a {
    color: var(--flux-item-hover) !important;
    background-color: transparent !important;
}

/* Icons & Badges */
.flux-icon {
    margin-right: 10px;
    font-size: 18px;
    display: inline-block;
    line-height: 1;
}

/* Force FontAwesome for FA classes */
.flux-icon.fas,
.flux-icon.fa {
    font-family: "Font Awesome 5 Free" !important;
    font-weight: 900 !important;
}

.flux-icon.fab {
    font-family: "Font Awesome 5 Brands" !important;
    font-weight: 400 !important;
}

.flux-icon.far {
    font-family: "Font Awesome 5 Free" !important;
    font-weight: 400 !important;
}

.flux-badge {
    background: var(--flux-item-hover);
    color: white !important;
    font-size: 10px;
    padding: 2px 6px;
    border-radius: 4px;
    margin-left: 8px;
    text-transform: uppercase;
    font-weight: 700;
    line-height: 1;
}

.flux-description {
    display: block;
    font-size: 11px;
    color: inherit;
    opacity: 0.8;
    font-weight: 400;
    margin-top: 4px;
    line-height: 1.2;
}

.flux-item-image {
    margin-top: 10px;
    border-radius: 8px;
    overflow: hidden;
}

.flux-item-image img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* Submenus Base */
.flux-menu-container .flux-sub-menu {
    position: absolute;
    top: 100%;
    left: 0;
    background: var(--flux-sub-bg) !important;
    box-shadow: var(--flux-shadow);
    padding: 0 !important;
    list-style: none !important;
    min-width: var(--flux-flyout-width, 240px);
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all var(--flux-anim-speed, 300ms) cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 9999;
    border-radius: var(--flux-sub-radius) !important;
    margin: 0 !important;
}

/* Interaction Bridge to prevent gaps */
.flux-menu-container .flux-sub-menu::before {
    content: '';
    position: absolute;
    top: -20px;
    left: 0;
    width: 100%;
    height: 20px;
    background: transparent;
}

.flux-menu-container .flux-menu-item.flux-active>.flux-sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* Submenu Arrows */
.flux-dropdown-arrow {
    display: inline-block;
    transition: transform 0.2s ease;
}

.flux-menu-item.flux-active>a .flux-dropdown-arrow {
    transform: rotate(180deg);
}

/* Submenu Type: Flyout */
.flux-submenu-type-flyout {
    min-width: 240px;
}

/* For nested flyouts */
.flux-submenu-type-flyout .flux-menu-item>.flux-sub-menu {
    top: 0 !important;
    left: 100% !important;
    margin-left: 0 !important;
    transform: translateX(10px) !important;
}

.flux-submenu-type-flyout .flux-menu-item.flux-active>.flux-sub-menu {
    transform: translateX(0) !important;
}

/* Submenu Type: Stack */
.flux-submenu-type-stack {
    position: static !important;
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    box-shadow: none !important;
    background: transparent !important;
    border: none !important;
    margin: 10px 0 0 0 !important;
    padding: 0 !important;
    width: 100% !important;
}

.flux-submenu-type-stack>.flux-menu-item {
    width: 100%;
}

.flux-submenu-type-stack>.flux-menu-item>a {
    padding: 6px 0 !important;
    font-size: 13px !important;
    color: inherit !important;
    opacity: 0.8;
}

.flux-submenu-type-stack>.flux-menu-item>a:hover {
    opacity: 1;
    color: var(--flux-item-hover) !important;
}

/* --- MEGA MENU ARCHITECTURE (UberMenu Style) --- */

.flux-has-submenu-mega {
    position: static !important;
}

.flux-menu-container .flux-sub-menu.flux-submenu-type-mega {
    position: absolute !important;
    left: 50% !important;
    top: 100% !important;
    transform: translateX(-50%) translateY(20px) !important;
    width: var(--flux-mega-width, 1140px) !important;
    max-width: calc(100vw - 40px) !important;
    padding: 35px 40px !important;
    display: grid !important;
    --flux-mega-gap: 30px;
    --flux-mega-col-min: max(140px, calc((100% - (var(--flux-mega-cols, 4) - 1) * var(--flux-mega-gap)) / var(--flux-mega-cols, 4)));
    grid-template-columns: repeat(auto-fit, minmax(var(--flux-mega-col-min), 1fr)) !important;
    gap: var(--flux-mega-gap);
    background: var(--flux-sub-bg, #ffffff) !important;
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    box-shadow: 0 40px 120px rgba(0, 0, 0, 0.22), 0 0 30px color-mix(in srgb, var(--flux-item-hover, #6366f1) 15%, transparent) !important;
    border-top: 4px solid var(--flux-item-hover, #6366f1) !important;
    border-radius: 0 0 12px 12px !important;
    z-index: 10000;
    align-items: start !important;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.35s ease, transform 0.35s ease, visibility 0.35s !important;
    pointer-events: none;
}

/* Open States (JS + CSS Fallback) */
.flux-menu-item:hover>.flux-sub-menu.flux-submenu-type-mega,
.flux-menu-item.flux-active>.flux-sub-menu.flux-submenu-type-mega {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateX(-50%) translateY(0) !important;
    pointer-events: auto !important;
}

/* Mega Menu Columns (Level 1) */
.flux-submenu-type-mega>.flux-depth-1 {
    display: flex !important;
    flex-direction: column !important;
    min-width: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
}

/* Header Links (Level 1 in Mega Menu) */
.flux-submenu-type-mega>.flux-depth-1>a {
    display: block !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 1.2px !important;
    color: #1e293b !important;
    margin-bottom: 20px !important;
    padding-bottom: 12px !important;
    border-bottom: 2px solid #f1f5f9 !important;
    transition: all 0.3s ease !important;
}

.flux-submenu-type-mega>.flux-depth-1:hover>a {
    color: var(--flux-item-hover, #6366f1) !important;
    border-bottom-color: var(--flux-item-hover, #6366f1) !important;
}

/* Vertical Stacks inside Mega Menu */
.flux-submenu-type-mega .flux-submenu-type-stack {
    position: static !important;
    display: flex !important;
    flex-direction: column !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
}

.flux-submenu-type-mega .flux-depth-2,
.flux-submenu-type-mega .flux-depth-3,
.flux-submenu-type-mega .flux-depth-4 {
    margin-bottom: 10px !important;
    list-style: none !important;
}

.flux-submenu-type-mega .flux-depth-2>a,
.flux-submenu-type-mega .flux-depth-3>a,
.flux-submenu-type-mega .flux-depth-4>a {
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #64748b !important;
    padding: 2px 0 !important;
    display: inline-block !important;
    transition: all 0.2s ease !important;
}

.flux-submenu-type-mega .flux-depth-2>a:hover {
    color: var(--flux-item-hover, #6366f1) !important;
    transform: translateX(6px);
}

/* Featured Content Block */
.flux-depth-1.flux-mega-column-featured {
    text-align: center !important;
}

.flux-custom-content {
    font-size: 11px !important;
    font-weight: 700 !important;
    color: #94a3b8 !important;
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    margin-bottom: 15px !important;
    display: block !important;
}

.flux-item-image {
    display: block !important;
    margin-bottom: 15px !important;
    position: relative !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1) !important;
}

.flux-item-image img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
    transition: transform 0.5s ease !important;
}

.flux-depth-1:hover .flux-item-image img {
    transform: scale(1.08) !important;
}

/* WooCommerce Price & Sale */
.flux-target-woo-price {
    font-weight: 700 !important;
    color: #1e293b !important;
    font-size: 15px !important;
    margin-top: 5px;
    display: block !important;
}

.flux-target-woo-price del {
    color: #94a3b8 !important;
    font-weight: 400 !important;
    margin-right: 8px;
    font-size: 0.9em;
}

.flux-target-woo-price ins {
    text-decoration: none !important;
    color: #ef4444 !important;
}

.flux-target-woo-sale-badge {
    position: absolute !important;
    top: 15px !important;
    right: 15px !important;
    background: #10b981 !important;
    color: #fff !important;
    padding: 4px 10px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    border-radius: 4px !important;
    box-shadow: 0 4px 10px rgba(16, 185, 129, 0.3) !important;
    z-index: 5;
}

/* Badges (High-End Colors from Reference) */
.flux-badge {
    display: inline-block !important;
    padding: 2px 7px !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    text-transform: uppercase !important;
    color: #ffffff !important;
    border-radius: 3px !important;
    margin-left: 8px !important;
    vertical-align: middle !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
}

/* Specific Badge Colors */
.flux-badge-new {
    background-color: #38bdf8 !important;
}

.flux-badge-sale,
.flux-badge-savings,
.flux-badge-saving {
    background-color: #2dd4bf !important;
}

/* Mobile Toggle */
.flux-mobile-toggle {
    display: none;
    padding: 15px 25px;
    background: var(--flux-main-bg);
    color: var(--flux-item-color);
    font-weight: 700;
    cursor: pointer;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.flux-mobile-toggle i {
    font-size: 24px;
}

/* Mobile Responsive */
@media (max-width: 991px) {
    .flux-mobile-toggle {
        display: flex;
    }

    .flux-menu-container ul.flux-menu {
        flex-direction: column;
        display: none;
        width: 100%;
        background: var(--flux-main-bg);
    }

    .flux-menu-container .flux-menu .flux-menu-item {
        width: 100%;
    }

    .flux-menu-container .flux-menu .flux-menu-item a {
        padding: 15px 25px !important;
        border-bottom: 1px solid rgba(0, 0, 0, 0.05) !important;
    }

    .flux-menu-container .flux-sub-menu {
        position: static;
        width: 100%;
        opacity: 1;
        visibility: visible;
        transform: none;
        box-shadow: none;
        display: none;
        padding-left: 20px !important;
    }

    .flux-menu-item.active>.flux-sub-menu {
        display: block !important;
    }

    .flux-menu-container .flux-mega-mega>.flux-sub-menu {
        display: block !important;
        width: 100% !important;
        max-width: none;
        left: 0 !important;
        transform: none;
        padding: 15px !important;
    }
}

/* Search Bar */
.flux-search-item {
    position: relative;
    display: flex !important;
    align-items: center !important;
}

.flux-search-extra {
    position: relative !important;
}

.flux-search-extra .flux-search-form-wrap {
    position: absolute !important;
    top: 100% !important;
    right: 0 !important;
    width: 380px !important;
    background: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 12px !important;
    box-shadow: 0 20px 40px rgba(15, 23, 42, 0.12) !important;
    padding: 20px !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(10px) !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    z-index: 100000 !important;
    display: block !important;
}

/* Hover bridge for search */
.flux-search-extra::before {
    content: '' !important;
    position: absolute !important;
    bottom: -20px !important;
    right: 0 !important;
    width: 100% !important;
    height: 20px !important;
    background: transparent !important;
    display: none !important;
}

.flux-search-extra:hover::before {
    display: block !important;
}

.flux-search-extra:hover .flux-search-form-wrap,
.flux-search-extra .flux-search-form-wrap.active {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}

@keyframes fluxFadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Social Icons */
.flux-social-items {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 12px !important;
    padding-left: 20px !important;
    margin-left: 10px !important;
    list-style: none !important;
}

.flux-social-items a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 5px !important;
    color: var(--flux-social-color, #334155) !important;
    transition: all 0.3s ease !important;
    text-decoration: none !important;
}

.flux-social-items a:hover {
    color: var(--flux-social-hover, #6366f1) !important;
    transform: translateY(-3px);
}

.flux-social-items i {
    font-size: 18px;
}

/* WooCommerce Cart */
.flux-cart-item {
    position: relative;
    display: flex !important;
    align-items: center !important;
}

.flux-cart-contents {
    position: relative;
    display: flex !important;
    align-items: center;
    justify-content: center;
}

.flux-cart-count {
    position: absolute;
    top: 5px;
    right: 5px;
    background: var(--flux-item-hover);
    color: white;
    font-size: 10px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
}

/* Modal System */
.flux-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(15, 23, 42, 0.8);
    backdrop-filter: blur(8px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 999999;
    opacity: 0;
    visibility: hidden;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.flux-modal-overlay.active {
    opacity: 1;
    visibility: visible;
}

.flux-modal-container {
    background: #fff;
    width: 100%;
    max-width: 600px;
    border-radius: 20px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
    position: relative;
    transform: scale(0.9) translateY(30px);
    transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
    overflow: hidden;
    max-height: 90vh;
}

.flux-modal-overlay.active .flux-modal-container {
    transform: scale(1) translateY(0);
}

.flux-modal-close {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 32px;
    height: 32px;
    background: #f1f5f9;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: #64748b;
    transition: all 0.2s ease;
    z-index: 10;
}

.flux-modal-close:hover {
    background: #e2e8f0;
    color: #0f172a;
    transform: rotate(90deg);
}

.flux-modal-content {
    padding: 40px;
    overflow-y: auto;
    max-height: calc(90vh - 20px);
}

/* Modal Content Types */
.flux-modal-video {
    position: relative;
    padding-bottom: 56.25%;
    /* 16:9 */
    height: 0;
    overflow: hidden;
    border-radius: 12px;
}

.flux-modal-video iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.flux-modal-form-title {
    font-size: 24px;
    font-weight: 800;
    color: #0f172a;
    margin-bottom: 10px;
    text-align: center;
}

.flux-modal-form-desc {
    font-size: 14px;
    color: #64748b;
    margin-bottom: 30px;
    text-align: center;
}

/* Placeholder Forms Styling */
.flux-placeholder-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.flux-placeholder-form input {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    font-size: 14px;
    transition: border-color 0.2s;
}

.flux-placeholder-form input:focus {
    border-color: #6366f1;
    outline: none;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}

.flux-placeholder-form button {
    background: #6366f1;
    color: #fff;
    padding: 14px;
    border: none;
    border-radius: 10px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s;
}

.flux-placeholder-form button:hover {
    background: #4f46e5;
}

/* Mobile Adjustments for Modal */
@media (max-width: 640px) {
    .flux-modal-container {
        max-width: 90vw;
    }

    .flux-modal-content {
        padding: 30px 20px;
    }
}

/* ---------------------------------------------------------------- */
/* AUTHENTICATION MODAL & FORMS (AJAX)                              */
/* ---------------------------------------------------------------- */

.flux-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(10px);
    z-index: 100000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.flux-modal-overlay.active {
    opacity: 1;
    visibility: visible;
}

.flux-modal-container {
    background: #1a1a1a;
    width: 450px;
    max-width: 90vw;
    min-height: 200px;
    border-radius: 16px;
    box-shadow: 0 50px 100px rgba(0, 0, 0, 0.8);
    position: relative;
    padding: 0;
    overflow: hidden;
    transform: scale(0.9) translateY(30px);
    transition: all 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    border: 1px solid #333;
}

.flux-modal-overlay.active .flux-modal-container {
    transform: scale(1) translateY(0);
}

.flux-modal-close {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 32px;
    height: 32px;
    background: #fff;
    color: #000;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 16px;
    transition: all 0.3s;
    z-index: 10;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
}

/* Modal & Auth Form Styling (Premium White) */
.flux-modal-container {
    background: #ffffff !important;
    max-width: 450px;
    width: 90%;
    margin: 0 auto !important;
    border-radius: 12px;
    box-shadow: 0 25px 80px rgba(0, 0, 0, 0.3);
    position: relative;
    overflow: hidden;
    animation: fluxModalIn 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.flux-modal-close {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 32px;
    height: 32px;
    background: #f1f5f9;
    color: #475569;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 14px;
    transition: all 0.3s;
    z-index: 10;
}

.flux-modal-close:hover {
    background: #e2e8f0;
    color: #0f172a;
    transform: rotate(90deg);
}

.flux-modal-content {
    padding: 35px 35px !important;
    overflow-y: auto !important;
    max-height: calc(90vh - 40px) !important;
    scrollbar-width: thin !important;
    scrollbar-color: #cbd5e1 transparent !important;
}

.flux-modal-content::-webkit-scrollbar {
    width: 6px !important;
}

.flux-modal-content::-webkit-scrollbar-track {
    background: transparent !important;
}

.flux-modal-content::-webkit-scrollbar-thumb {
    background: #cbd5e1 !important;
    border-radius: 10px !important;
}

.flux-modal-content::-webkit-scrollbar-thumb:hover {
    background: #94a3b8 !important;
}

.flux-auth-form-container {
    color: #334155 !important;
}

.flux-auth-success-msg {
    text-align: center !important;
    color: #000000 !important;
}

.flux-auth-success-msg h3,
.flux-auth-success-msg p {
    color: #000000 !important;
}

.flux-auth-success-msg h3 {
    font-size: 22px !important;
    font-weight: 700 !important;
    margin: 15px 0 10px 0 !important;
}

.flux-auth-success-msg p {
    font-size: 14px !important;
    margin: 0 0 20px 0 !important;
}

.flux-auth-success-msg > i {
    font-size: 40px !important;
    color: #10b981 !important;
}

.flux-auth-header {
    text-align: center !important;
    margin-bottom: 25px !important;
}

.flux-auth-header h3 {
    font-size: 24px !important;
    font-weight: 700 !important;
    color: #0f172a !important;
    margin: 0 0 8px 0 !important;
}

.flux-auth-header p {
    color: #64748b !important;
    font-size: 14px !important;
    margin: 0 !important;
}

.flux-form-group {
    margin-bottom: 20px !important;
}

.flux-form-group label {
    display: block !important;
    margin-bottom: 8px !important;
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    color: #475569 !important;
    font-weight: 600 !important;
}

.flux-input-wrapper {
    position: relative !important;
    width: 100% !important;
}

.flux-input-wrapper i {
    position: absolute !important;
    left: 16px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    color: #94a3b8 !important;
    font-size: 16px !important;
    z-index: 5 !important;
    pointer-events: none !important;
    line-height: 1 !important;
}

.flux-input-wrapper input {
    width: 100% !important;
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    color: #1e293b !important;
    padding: 12px 15px 12px 45px !important;
    border-radius: 8px !important;
    font-size: 15px !important;
    transition: all 0.3s !important;
    box-shadow: none !important;
    display: block !important;
}

.flux-input-wrapper input:focus {
    border-color: #6366f1 !important;
    background: #ffffff !important;
    outline: none !important;
    box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.1) !important;
}

.flux-input-wrapper input.flux-input-error {
    border-color: #ef4444 !important;
    background: #fef2f2 !important;
}

.flux-input-wrapper input.flux-input-error:focus {
    box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.1) !important;
}

.flux-form-footer {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 25px !important;
    font-size: 13px !important;
}

.flux-rememberme {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    cursor: pointer !important;
    color: #64748b !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    margin: 0 !important;
    user-select: none !important;
}

.flux-rememberme input[type="checkbox"] {
    margin: 0 !important;
    width: 14px !important;
    height: 14px !important;
    cursor: pointer !important;
}

.flux-lost-password {
    color: #6366f1 !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    transition: color 0.2s !important;
}

.flux-lost-password:hover {
    color: #4f46e5 !important;
}

.flux-form-actions {
    margin-top: 10px !important;
}

.flux-auth-btn {
    width: 100% !important;
    background: #6366f1 !important;
    color: #ffffff !important;
    border: none !important;
    padding: 14px !important;
    border-radius: 8px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.3s !important;
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.2) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
}

.flux-auth-btn:hover {
    background: #4f46e5 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 8px 20px rgba(99, 102, 241, 0.3) !important;
}

.flux-auth-switch {
    margin-top: 25px !important;
    text-align: center !important;
    font-size: 14px !important;
    color: #64748b !important;
    border-top: 1px solid #f1f5f9 !important;
    padding-top: 20px !important;
}

.flux-auth-switch a {
    color: #6366f1 !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    transition: color 0.2s !important;
}

.flux-auth-switch a:hover {
    color: #4f46e5 !important;
}

.flux-auth-message {
    margin-top: 20px !important;
    padding: 12px !important;
    border-radius: 6px !important;
    font-size: 14px !important;
    display: none;
    text-align: center !important;
}

.flux-auth-message.success {
    background: rgba(16, 185, 129, 0.1) !important;
    color: #10b981 !important;
    border: 1px solid rgba(16, 185, 129, 0.2) !important;
}

.flux-auth-message.error {
    background: rgba(239, 68, 68, 0.1) !important;
    color: #ef4444 !important;
    border: 1px solid rgba(239, 68, 68, 0.2) !important;
}

.flux-reg-info {
    font-size: 12px;
    color: #aaa;
    margin-bottom: 25px;
    text-align: center;
}

/* Loading Spinner */
.flux-loading-wrapper {
    text-align: center;
    padding: 60px 0;
}

.flux-loader {
    width: 40px;
    height: 40px;
    border: 3px solid rgba(0, 115, 170, 0.1);
    border-radius: 50%;
    border-top-color: #0073aa;
    margin: 0 auto 20px;
    animation: fluxSpin 1s linear infinite;
}

.flux-loading-wrapper span {
    display: block;
    color: #666;
    font-size: 14px;
}

@keyframes fluxSpin {
    to {
        transform: rotate(360deg);
    }
}

/* WooCommerce Cart Dropdown */
.flux-cart-extra {
    position: relative !important;
}

.flux-cart-dropdown {
    position: absolute !important;
    top: 100% !important;
    right: 0 !important;
    width: 380px !important;
    background: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 12px !important;
    box-shadow: 0 20px 40px rgba(15, 23, 42, 0.12) !important;
    padding: 20px !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(10px) !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    z-index: 100000 !important;
}

/* Hover bridge to keep dropdown open when cursor moves to it */
.flux-cart-extra::before {
    content: '' !important;
    position: absolute !important;
    bottom: -20px !important;
    right: 0 !important;
    width: 100% !important;
    height: 20px !important;
    background: transparent !important;
    display: none !important;
}

.flux-cart-extra:hover::before {
    display: block !important;
}

.flux-cart-extra:hover .flux-cart-dropdown {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}

.flux-cart-products {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 15px 0 !important;
    max-height: 240px !important;
    overflow-y: auto !important;
}

.flux-cart-products::-webkit-scrollbar {
    width: 4px !important;
}

.flux-cart-products::-webkit-scrollbar-thumb {
    background: #cbd5e1 !important;
    border-radius: 4px !important;
}

.flux-mini-cart-item {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 10px 0 !important;
    border-bottom: 1px solid #f1f5f9 !important;
    position: relative !important;
}

.flux-mini-cart-item:last-child {
    border-bottom: none !important;
}

/* Remove button */
.flux-mini-cart-item .remove_from_cart_button {
    font-size: 18px !important;
    color: #94a3b8 !important;
    text-decoration: none !important;
    transition: color 0.2s !important;
    cursor: pointer !important;
    line-height: 1 !important;
    order: 0 !important;
    background: none !important;
    border: none !important;
    padding: 0 !important;
}

.flux-mini-cart-item .remove_from_cart_button:hover {
    color: #ef4444 !important;
}

/* Product image */
.flux-cart-img {
    width: 50px !important;
    height: 50px !important;
    min-width: 80px !important;
    min-height: 100px !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    border: 1px solid #e2e8f0 !important;
    flex-shrink: 0 !important;
    display: block !important;
}

.flux-menu-container .flux-cart-dropdown .flux-mini-cart-item .flux-cart-img img,
.flux-menu-container .flux-cart-dropdown .flux-cart-img img,
.flux-cart-dropdown .flux-cart-img img,
.flux-cart-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Product details */
.flux-cart-info {
    flex-grow: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    min-width: 0 !important;
    text-align: left !important;
}

.flux-cart-title {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #1e293b !important;
    text-decoration: none !important;
    white-space: normal !important;
    line-height: 1.3 !important;
    display: block !important;
    transition: color 0.2s !important;
    margin-bottom: 3px !important;
}

.flux-cart-title:hover {
    color: var(--flux-item-hover) !important;
}

.flux-cart-price {
    font-size: 12px !important;
    color: #64748b !important;
    display: block !important;
}

/* Subtotal */
.flux-cart-total {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 15px 0 !important;
    border-top: 1px solid #e2e8f0 !important;
    font-size: 15px !important;
    color: #1e293b !important;
    margin-bottom: 10px !important;
}

.flux-cart-total strong {
    font-weight: 700 !important;
    color: #0f172a !important;
}

/* Actions Buttons */
.flux-cart-actions {
    display: flex !important;
    gap: 10px !important;
    margin-top: 5px !important;
}

.flux-btn-view,
.flux-btn-checkout {
    flex: 1 !important;
    text-align: center !important;
    padding: 10px 15px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border-radius: 8px !important;
    transition: all 0.2s !important;
    display: block !important;
}

.flux-btn-view {
    background: #f1f5f9 !important;
    color: #334155 !important;
    border: 1px solid #e2e8f0 !important;
}

.flux-btn-view:hover {
    background: #e2e8f0 !important;
    color: #0f172a !important;
}

.flux-btn-checkout {
    background: var(--flux-item-hover, #6366f1) !important;
    color: #ffffff !important;
    border: 1px solid transparent !important;
    box-shadow: 0 4px 10px rgba(99, 102, 241, 0.15) !important;
}

.flux-btn-checkout:hover {
    background: #4f46e5 !important;
    box-shadow: 0 6px 15px rgba(99, 102, 241, 0.25) !important;
    transform: translateY(-1px) !important;
}

.flux-cart-empty {
    text-align: center !important;
    padding: 20px 0 !important;
    color: #64748b !important;
    font-size: 14px !important;
}

/* WooCommerce/AJAX Search Dropdown Styles */
.flux-search-input-wrapper {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 2px 8px !important;
    transition: all 0.2s !important;
}

.flux-search-input-wrapper:focus-within {
    border-color: var(--flux-item-hover, #6366f1) !important;
    background: #ffffff !important;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1) !important;
}

.flux-search-field {
    width: 100% !important;
    border: none !important;
    background: transparent !important;
    padding: 8px 10px !important;
    font-size: 14px !important;
    color: #1e293b !important;
    outline: none !important;
    box-shadow: none !important;
}

.flux-search-submit {
    background: none !important;
    border: none !important;
    padding: 6px !important;
    color: #64748b !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 16px !important;
    transition: color 0.2s !important;
}

.flux-search-submit:hover {
    color: var(--flux-item-hover, #6366f1) !important;
}

/* Results wrapper */
.flux-search-results-wrapper {
    margin-top: 15px !important;
    border-top: 1px solid #f1f5f9 !important;
    padding-top: 10px !important;
    max-height: 280px !important;
    overflow-y: auto !important;
}

.flux-search-results-wrapper::-webkit-scrollbar {
    width: 4px !important;
}

.flux-search-results-wrapper::-webkit-scrollbar-thumb {
    background: #cbd5e1 !important;
    border-radius: 4px !important;
}

.flux-search-results-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.flux-search-result-item {
    padding: 8px 0 !important;
    border-bottom: 1px solid #f8fafc !important;
    transition: background 0.2s !important;
}

.flux-search-result-item:last-child {
    border-bottom: none !important;
}

.flux-search-result-item a {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    text-decoration: none !important;
    padding: 4px 8px !important;
    border-radius: 6px !important;
    width: 100% !important;
    height: auto !important;
}

.flux-search-result-item a:hover {
    background: #f8fafc !important;
}

.flux-search-result-thumb {
    width: 40px !important;
    height: 40px !important;
    border-radius: 6px !important;
    overflow: hidden !important;
    border: 1px solid #e2e8f0 !important;
    flex-shrink: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #f8fafc !important;
}

.flux-search-result-thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.flux-search-result-thumb-placeholder {
    color: #94a3b8 !important;
    font-size: 18px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.flux-search-result-info {
    flex-grow: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    min-width: 0 !important;
    text-align: left !important;
}

.flux-search-result-title {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #1e293b !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    display: block !important;
}

.flux-search-result-price {
    font-size: 11px !important;
    font-weight: 700 !important;
    color: var(--flux-item-hover, #6366f1) !important;
}

.flux-search-result-price del {
    color: #94a3b8 !important;
    font-weight: 400 !important;
    margin-right: 4px !important;
}

.flux-search-result-price ins {
    text-decoration: none !important;
}

.flux-search-result-date {
    font-size: 11px !important;
    color: #64748b !important;
}

.flux-search-no-results {
    padding: 15px 0 !important;
    text-align: center !important;
    color: #64748b !important;
    font-size: 13px !important;
}

.flux-search-loading {
    padding: 15px 0 !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
}

/* Spinner animation */
.flux-search-spinner {
    width: 20px !important;
    height: 20px !important;
    border: 2px solid rgba(99, 102, 241, 0.1) !important;
    border-top-color: var(--flux-item-hover, #6366f1) !important;
    border-radius: 50% !important;
    animation: fluxSpin 0.6s linear infinite !important;
}

/* box-shadow: 0 20px 40px rgba(15, 23, 42, 0.12) !important;
padding: 20px !important;
opacity: 0 !important;
visibility: hidden !important;
transform: translateY(10px) !important;
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
z-index: 100000 !important;
} */

/* Hover bridge to keep dropdown open when cursor moves to it */
.flux-cart-extra::before {
    content: '' !important;
    position: absolute !important;
    bottom: -20px !important;
    right: 0 !important;
    width: 100% !important;
    height: 20px !important;
    background: transparent !important;
    display: none !important;
}

.flux-cart-extra:hover::before {
    display: block !important;
}

.flux-cart-extra:hover .flux-cart-dropdown {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}

.flux-cart-products {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 15px 0 !important;
    max-height: 240px !important;
    overflow-y: auto !important;
}

.flux-cart-products::-webkit-scrollbar {
    width: 4px !important;
}

.flux-cart-products::-webkit-scrollbar-thumb {
    background: #cbd5e1 !important;
    border-radius: 4px !important;
}

.flux-mini-cart-item {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 10px 0 !important;
    border-bottom: 1px solid #f1f5f9 !important;
    position: relative !important;
}

.flux-mini-cart-item:last-child {
    border-bottom: none !important;
}

/* Remove button */
.flux-mini-cart-item .remove_from_cart_button {
    font-size: 18px !important;
    color: #94a3b8 !important;
    text-decoration: none !important;
    transition: color 0.2s !important;
    cursor: pointer !important;
    line-height: 1 !important;
    order: 0 !important;
    background: none !important;
    border: none !important;
    padding: 0 !important;
}

.flux-mini-cart-item .remove_from_cart_button:hover {
    color: #ef4444 !important;
}

/* Product image */
.flux-cart-img {
    width: 50px !important;
    height: 50px !important;
    min-width: 80px !important;
    min-height: 100px !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    border: 1px solid #e2e8f0 !important;
    flex-shrink: 0 !important;
    display: block !important;
}

.flux-menu-container .flux-cart-dropdown .flux-mini-cart-item .flux-cart-img img,
.flux-menu-container .flux-cart-dropdown .flux-cart-img img,
.flux-cart-dropdown .flux-cart-img img,
.flux-cart-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Product details */
.flux-cart-info {
    flex-grow: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    min-width: 0 !important;
    text-align: left !important;
}

.flux-cart-title {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #1e293b !important;
    text-decoration: none !important;
    white-space: normal !important;
    line-height: 1.3 !important;
    display: block !important;
    transition: color 0.2s !important;
    margin-bottom: 3px !important;
}

.flux-cart-title:hover {
    color: var(--flux-item-hover) !important;
}

.flux-cart-price {
    font-size: 12px !important;
    color: #64748b !important;
    display: block !important;
}

/* Subtotal */
.flux-cart-total {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 15px 0 !important;
    border-top: 1px solid #e2e8f0 !important;
    font-size: 15px !important;
    color: #1e293b !important;
    margin-bottom: 10px !important;
}

.flux-cart-total strong {
    font-weight: 700 !important;
    color: #0f172a !important;
}

/* Actions Buttons */
.flux-cart-actions {
    display: flex !important;
    gap: 10px !important;
    margin-top: 5px !important;
}

.flux-btn-view,
.flux-btn-checkout {
    flex: 1 !important;
    text-align: center !important;
    padding: 10px 15px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border-radius: 8px !important;
    transition: all 0.2s !important;
    display: block !important;
}

.flux-btn-view {
    background: #f1f5f9 !important;
    color: #334155 !important;
    border: 1px solid #e2e8f0 !important;
}

.flux-btn-view:hover {
    background: #e2e8f0 !important;
    color: #0f172a !important;
}

.flux-btn-checkout {
    background: var(--flux-item-hover, #6366f1) !important;
    color: #ffffff !important;
    border: 1px solid transparent !important;
    box-shadow: 0 4px 10px rgba(99, 102, 241, 0.15) !important;
}

.flux-btn-checkout:hover {
    background: #4f46e5 !important;
    box-shadow: 0 6px 15px rgba(99, 102, 241, 0.25) !important;
    transform: translateY(-1px) !important;
}

.flux-cart-empty {
    text-align: center !important;
    padding: 20px 0 !important;
    color: #64748b !important;
    font-size: 14px !important;
}

/* WooCommerce/AJAX Search Dropdown Styles */
.flux-search-input-wrapper {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 2px 8px !important;
    transition: all 0.2s !important;
}

.flux-search-input-wrapper:focus-within {
    border-color: var(--flux-item-hover, #6366f1) !important;
    background: #ffffff !important;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1) !important;
}

.flux-search-field {
    width: 100% !important;
    border: none !important;
    background: transparent !important;
    padding: 8px 10px !important;
    font-size: 14px !important;
    color: #1e293b !important;
    outline: none !important;
    box-shadow: none !important;
}

.flux-search-submit {
    background: none !important;
    border: none !important;
    padding: 6px !important;
    color: #64748b !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 16px !important;
    transition: color 0.2s !important;
}

.flux-search-submit:hover {
    color: var(--flux-item-hover, #6366f1) !important;
}

/* Results wrapper */
.flux-search-results-wrapper {
    margin-top: 15px !important;
    border-top: 1px solid #f1f5f9 !important;
    padding-top: 10px !important;
    max-height: 280px !important;
    overflow-y: auto !important;
}

.flux-search-results-wrapper::-webkit-scrollbar {
    width: 4px !important;
}

.flux-search-results-wrapper::-webkit-scrollbar-thumb {
    background: #cbd5e1 !important;
    border-radius: 4px !important;
}

.flux-search-results-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.flux-search-result-item {
    padding: 8px 0 !important;
    border-bottom: 1px solid #f8fafc !important;
    transition: background 0.2s !important;
}

.flux-search-result-item:last-child {
    border-bottom: none !important;
}

.flux-search-result-item a {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    text-decoration: none !important;
    padding: 4px 8px !important;
    border-radius: 6px !important;
    width: 100% !important;
    height: auto !important;
}

.flux-search-result-item a:hover {
    background: #f8fafc !important;
}

.flux-search-result-thumb {
    width: 40px !important;
    height: 40px !important;
    border-radius: 6px !important;
    overflow: hidden !important;
    border: 1px solid #e2e8f0 !important;
    flex-shrink: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #f8fafc !important;
}

.flux-search-result-thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.flux-search-result-thumb-placeholder {
    color: #94a3b8 !important;
    font-size: 18px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.flux-search-result-info {
    flex-grow: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    min-width: 0 !important;
    text-align: left !important;
}

.flux-search-result-title {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #1e293b !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    display: block !important;
}

.flux-search-result-price {
    font-size: 11px !important;
    font-weight: 700 !important;
    color: var(--flux-item-hover, #6366f1) !important;
}

.flux-search-result-price del {
    color: #94a3b8 !important;
    font-weight: 400 !important;
    margin-right: 4px !important;
}

.flux-search-result-price ins {
    text-decoration: none !important;
}

.flux-search-result-date {
    font-size: 11px !important;
    color: #64748b !important;
}

.flux-search-no-results {
    padding: 15px 0 !important;
    text-align: center !important;
    color: #64748b !important;
    font-size: 13px !important;
}

.flux-search-loading {
    padding: 15px 0 !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
}

/* Spinner animation */
.flux-search-spinner {
    width: 20px !important;
    height: 20px !important;
    border: 2px solid rgba(99, 102, 241, 0.1) !important;
    border-top-color: var(--flux-item-hover, #6366f1) !important;
    border-radius: 50% !important;
    animation: fluxSpin 0.6s linear infinite !important;
}

body.flux-mobile-menu-open {
    overflow: hidden !important;
}

/* --- MEGA MENU DROPDOWN PANEL IMAGE --- */
.flux-menu-container .flux-sub-menu.flux-submenu-type-mega.flux-has-panel-img {
    --flux-panel-width: clamp(240px, 28vw, 320px);
    --flux-mega-col-min: max(130px, calc((100% - var(--flux-panel-width) - (var(--flux-mega-cols, 4) - 1) * var(--flux-mega-gap, 30px)) / var(--flux-mega-cols, 4)));
    grid-template-columns: repeat(auto-fit, minmax(var(--flux-mega-col-min), 1fr)) var(--flux-panel-width) !important;
    position: absolute !important;
    overflow: hidden !important;
}

.flux-mega-panel-img {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    width: 131% !important;
    grid-column: -1 !important;
    grid-row: 1 / -1 !important;
    align-self: stretch !important;
    min-height: 100% !important;
    margin: -35px -40px -35px 0 !important;
    overflow: hidden !important;
    border-left: 1px solid rgba(255, 255, 255, 0.08) !important;
    background: #111 !important;
    z-index: 1 !important;
}

.flux-mega-panel-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

/* Overlay inside the right-side panel image */
.flux-mega-panel-overlay {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.1) 0%, rgba(0, 0, 0, 0.8) 100%) !important;
    z-index: 2 !important;
    padding: 30px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-end !important;
    box-sizing: border-box !important;
    text-align: left !important;
}

.flux-mega-panel-badge {
    position: absolute !important;
    top: 20px !important;
    left: 20px !important;
    background: #6366f1 !important; /* Indigo badge */
    color: #ffffff !important;
    font-weight: 700 !important;
    font-size: 10px !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    padding: 4px 10px !important;
    border-radius: 4px !important;
    box-shadow: 0 4px 10px rgba(0,0,0,0.3) !important;
    z-index: 3 !important;
}

.flux-mega-panel-body {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.flux-mega-panel-title {
    font-size: 20px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    margin: 0 !important;
    line-height: 1.3 !important;
    text-shadow: 0 2px 4px rgba(0,0,0,0.5) !important;
}

.flux-mega-panel-desc {
    font-size: 13px !important;
    color: #cbd5e1 !important;
    line-height: 1.5 !important;
    margin: 0 !important;
    text-shadow: 0 1px 2px rgba(0,0,0,0.5) !important;
}

.flux-mega-panel-btn {
    align-self: flex-start !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    background: #ffffff !important;
    color: #0f172a !important;
    padding: 10px 20px !important;
    border-radius: 6px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
    transition: all 0.3s ease !important;
}

.flux-mega-panel-btn:hover {
    background: #6366f1 !important;
    color: #ffffff !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(99, 102, 241, 0.4) !important;
}

.flux-mega-panel-btn i {
    font-size: 11px !important;
    transition: transform 0.2s ease !important;
}

.flux-mega-panel-btn:hover i {
    transform: translateX(3px) !important;
}

/* Micro-interaction zoom on hover of the parent menu item */
.flux-menu-item:hover > .flux-sub-menu.flux-submenu-type-mega.flux-has-panel-img .flux-mega-panel-img img {
    transform: scale(1.05) !important;
}

/* Tablet: tighten mega columns and panel before mobile collapse */
@media (max-width: 1200px) {
    .flux-menu-container .flux-sub-menu.flux-submenu-type-mega {
        --flux-mega-gap: 24px;
        --flux-mega-col-min: max(120px, calc((100% - (var(--flux-mega-cols, 4) - 1) * var(--flux-mega-gap)) / var(--flux-mega-cols, 4)));
        padding: 28px 30px !important;
    }

    .flux-menu-container .flux-sub-menu.flux-submenu-type-mega.flux-has-panel-img {
        --flux-panel-width: clamp(200px, 24vw, 280px);
        --flux-mega-col-min: max(110px, calc((100% - var(--flux-panel-width) - (var(--flux-mega-cols, 4) - 1) * var(--flux-mega-gap)) / var(--flux-mega-cols, 4)));
    }

    .flux-mega-panel-img {
        margin: -28px -30px -28px 0 !important;
    }
}

/* Responsive adjustments for mobile/tablets where mega menu is collapsed or narrow */
@media (max-width: 991px) {
    .flux-menu-container .flux-sub-menu.flux-submenu-type-mega {
        grid-template-columns: 1fr !important;
        padding: 15px !important;
    }

    .flux-menu-container .flux-sub-menu.flux-submenu-type-mega.flux-has-panel-img {
        grid-template-columns: 1fr !important;
    }

    .flux-mega-panel-img {
        display: none !important;
    }
}


/* --- FEATURED ITEMS STYLING (Card, Banner, Promo Layouts) --- */

/* Base container for featured cards inside mega menus */
.flux-featured-item {
    grid-column: span 1;
    min-width: 0;
}

.flux-featured-link {
    text-decoration: none !important;
    display: block !important;
    width: 100% !important;
    height: auto !important;
    transition: transform 0.3s ease, box-shadow 0.3s ease !important;
}

.flux-featured-link:hover {
    transform: translateY(-4px) !important;
}

.flux-feat-card {
    position: relative !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15) !important;
    background: #1a1a1a !important; /* Elegant dark card background */
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

/* 1. Card Style: Top Image, Content Below */
.flux-feat-style-card {
    background: #1e1e1e !important;
}

.flux-feat-style-card .flux-feat-img-wrap {
    position: relative !important;
    width: 100% !important;
    aspect-ratio: 16/10 !important;
    overflow: hidden !important;
}

.flux-feat-style-card .flux-feat-img-wrap img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 0.5s ease !important;
}

.flux-featured-link:hover .flux-feat-style-card .flux-feat-img-wrap img {
    transform: scale(1.05) !important;
}

.flux-feat-style-card .flux-feat-body {
    padding: 20px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    text-align: left !important;
}

.flux-feat-style-card .flux-feat-title {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #ffffff !important;
    margin: 0 !important;
    line-height: 1.3 !important;
}

.flux-feat-style-card .flux-feat-desc {
    font-size: 12px !important;
    color: #a0aec0 !important;
    line-height: 1.4 !important;
    margin: 0 !important;
}

/* 2. Banner Style: Full Image with Overlay Text */
.flux-feat-style-banner {
    aspect-ratio: 4/5 !important;
    min-height: 250px !important;
}

.flux-feat-style-banner .flux-feat-img-wrap {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 1 !important;
}

.flux-feat-style-banner .flux-feat-img-wrap img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 0.5s ease !important;
}

.flux-featured-link:hover .flux-feat-style-banner .flux-feat-img-wrap img {
    transform: scale(1.05) !important;
}

/* Dark gradient overlay to ensure text readability on image background */
.flux-feat-style-banner::after {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.1) 0%, rgba(0, 0, 0, 0.85) 100%) !important;
    z-index: 2 !important;
}

.flux-feat-style-banner .flux-feat-body {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    padding: 20px !important;
    z-index: 3 !important;
    text-align: left !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
}

.flux-feat-style-banner .flux-feat-title {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    text-shadow: 0 2px 4px rgba(0,0,0,0.5) !important;
}

.flux-feat-style-banner .flux-feat-desc {
    font-size: 12px !important;
    color: #e2e8f0 !important;
    line-height: 1.4 !important;
    text-shadow: 0 1px 2px rgba(0,0,0,0.5) !important;
}

/* 3. Promo Style: Dark glass card with neon accent and glow */
.flux-feat-style-promo {
    background: rgba(30, 30, 30, 0.75) !important;
    backdrop-filter: blur(10px) !important;
    -webkit-backdrop-filter: blur(10px) !important;
    border: 1px solid rgba(245, 158, 11, 0.25) !important; /* subtle amber border matching featured badge */
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3), 0 0 15px rgba(245, 158, 11, 0.05) !important;
    transition: all 0.3s ease !important;
}

.flux-featured-link:hover .flux-feat-style-promo {
    border-color: rgba(245, 158, 11, 0.6) !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.4), 0 0 25px rgba(245, 158, 11, 0.2) !important;
}

.flux-feat-style-promo .flux-feat-img-wrap {
    position: relative !important;
    width: 100% !important;
    aspect-ratio: 16/10 !important;
    overflow: hidden !important;
}

.flux-feat-style-promo .flux-feat-img-wrap img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 0.5s ease !important;
}

.flux-featured-link:hover .flux-feat-style-promo .flux-feat-img-wrap img {
    transform: scale(1.05) !important;
}

.flux-feat-style-promo .flux-feat-body {
    padding: 20px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    text-align: left !important;
}

.flux-feat-style-promo .flux-feat-title {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #ffffff !important;
}

.flux-feat-style-promo .flux-feat-desc {
    font-size: 12px !important;
    color: #cbd5e0 !important;
    line-height: 1.4 !important;
}

/* Featured Badge styling inside cards */
.flux-feat-badge {
    position: absolute !important;
    top: 12px !important;
    left: 12px !important;
    background: #f59e0b !important; /* Premium Amber */
    color: #000000 !important;
    font-weight: 800 !important;
    font-size: 9px !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    padding: 4px 10px !important;
    border-radius: 20px !important;
    z-index: 10 !important;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2) !important;
    pointer-events: none !important;
}

/* Featured Icon fallback styling */
.flux-feat-icon-wrap {
    width: 100% !important;
    aspect-ratio: 16/10 !important;
    background: #111111 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
}

.flux-feat-icon-wrap i {
    font-size: 40px !important;
    color: #f59e0b !important;
    text-shadow: 0 0 15px rgba(245, 158, 11, 0.3) !important;
}

/* Promo Gallery Layout styles */
.flux-menu-container .flux-sub-menu.flux-submenu-type-mega.flux-gallery-dropdown {
    box-sizing: border-box !important;
    min-width: 200px !important;
    max-width: 813px !important;
    width: 100% !important;
    left: 0 !important;
    transform: translateX(0) translateY(20px) !important;
}

.flux-menu-container .flux-menu-item:hover>.flux-sub-menu.flux-submenu-type-mega.flux-gallery-dropdown,
.flux-menu-container .flux-menu-item.flux-active>.flux-sub-menu.flux-submenu-type-mega.flux-gallery-dropdown {
    transform: translateX(0) translateY(0) !important;
}

.flux-menu-container .flux-sub-menu.flux-submenu-type-mega.flux-gallery-grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 12px !important;
    padding: 20px 25px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    align-items: stretch !important;
}

.flux-gallery-card {
    position: relative !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    min-height: 160px !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2) !important;
    transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.35s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.35s cubic-bezier(0.16, 1, 0.3, 1) !important;
    background: #111111 !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    list-style: none !important;
    margin: 0 !important;
    display: block !important;
}

.flux-gallery-card:hover {
    transform: translateY(-5px) !important;
    box-shadow: 0 20px 35px rgba(0, 0, 0, 0.4), 0 0 15px rgba(99, 102, 241, 0.15) !important;
    border-color: rgba(99, 102, 241, 0.4) !important;
}

.flux-gallery-card img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), filter 0.6s cubic-bezier(0.16, 1, 0.3, 1) !important;
    display: block !important;
}

.flux-gallery-card:hover img {
    transform: scale(1.08) !important;
    filter: brightness(0.65) blur(1px) !important;
}

.flux-gallery-overlay {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: linear-gradient(180deg, rgba(10, 10, 20, 0) 0%, rgba(10, 10, 20, 0.55) 40%, rgba(10, 10, 20, 0.92) 100%) !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-end !important;
    padding: 14px !important;
    box-sizing: border-box !important;
    opacity: 0 !important;
    transition: opacity 0.35s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.flux-gallery-card:hover .flux-gallery-overlay {
    opacity: 1 !important;
}

.flux-gallery-overlay-content {
    transform: translateY(15px) !important;
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
}

.flux-gallery-card:hover .flux-gallery-overlay-content {
    transform: translateY(0) !important;
}

.flux-gallery-title {
    color: #ffffff !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    margin: 0 0 4px 0 !important;
    line-height: 1.3 !important;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.9) !important;
    opacity: 0 !important;
    transform: translateY(8px) !important;
    transition: opacity 0.3s ease 0.04s, transform 0.3s ease 0.04s !important;
    white-space: normal !important;
    word-break: break-word !important;
}

.flux-gallery-card:hover .flux-gallery-title {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

.flux-gallery-desc {
    color: #e2e8f0 !important;
    font-size: 11px !important;
    margin: 0 0 8px 0 !important;
    line-height: 1.4 !important;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.9) !important;
    opacity: 0 !important;
    transform: translateY(8px) !important;
    transition: opacity 0.3s ease 0.08s, transform 0.3s ease 0.08s !important;
    white-space: normal !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.flux-gallery-card:hover .flux-gallery-desc {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

.flux-gallery-btn {
    align-self: flex-start !important;
    padding: 5px 12px !important;
    border-radius: 5px !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.3) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: 0 !important;
    transform: translateY(8px) !important;
    transition: opacity 0.3s ease 0.12s, transform 0.3s ease 0.12s, box-shadow 0.3s !important;
}

.flux-gallery-card:hover .flux-gallery-btn {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

.flux-gallery-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.35) !important;
    filter: brightness(1.15) !important;
}

/* ============================================
   Map & Content Panel Dropdown
   ============================================ */

/* Positioning — same constraints as gallery dropdown */
.flux-menu-container .flux-sub-menu.flux-submenu-type-mega.flux-map-panel-dropdown {
    box-sizing: border-box !important;
    min-width: 200px !important;
    max-width: 813px !important;
    width: 100% !important;
    left: 0 !important;
    transform: translateX(0) translateY(20px) !important;
    /* Layout overrides */
    display: flex !important;
    flex-direction: row !important;
    padding: 0 !important;
    overflow: hidden !important;
    min-height: 300px !important;
    grid-template-columns: none !important;
    gap: 0 !important;
}

/* Open state — same as gallery */
.flux-menu-container .flux-menu-item:hover>.flux-sub-menu.flux-submenu-type-mega.flux-map-panel-dropdown,
.flux-menu-container .flux-menu-item.flux-active>.flux-sub-menu.flux-submenu-type-mega.flux-map-panel-dropdown {
    transform: translateX(0) translateY(0) !important;
}

.flux-map-panel-left {
    flex: 0 0 55% !important;
    min-height: 300px !important;
    position: relative !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    background: #1a1a2e !important;
}

.flux-map-panel-left iframe {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    border: none !important;
    display: block !important;
}

.flux-map-panel-right {
    flex: 0 0 45% !important;
    padding: 24px 22px !important;
    box-sizing: border-box !important;
    background: var(--flux-sub-bg, #ffffff) !important;
    list-style: none !important;
    margin: 0 !important;
    overflow-y: auto !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: stretch !important;
}

/* Ensure any form, iframe, or content inside the right panel fills width properly */
.flux-map-panel-right form,
.flux-map-panel-right iframe,
.flux-map-panel-right > * {
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Ensure iframe video embeds scale responsively with correct aspect ratio */
.flux-map-panel-right iframe[src*="youtube.com"],
.flux-map-panel-right iframe[src*="youtu.be"],
.flux-map-panel-right iframe[src*="vimeo.com"],
.flux-map-panel-right iframe[src*="player.vimeo.com"],
.flux-custom-content-wrap iframe[src*="youtube.com"],
.flux-custom-content-wrap iframe[src*="youtu.be"],
.flux-custom-content-wrap iframe[src*="vimeo.com"],
.flux-custom-content-wrap iframe[src*="player.vimeo.com"],
.flux-map-panel-right video,
.flux-custom-content-wrap video {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    aspect-ratio: 16/9 !important;
    display: block !important;
}

/* Premium styling for contact form inputs and form fields inside dropdowns */
.flux-map-panel-right input[type="text"],
.flux-map-panel-right input[type="email"],
.flux-map-panel-right input[type="tel"],
.flux-map-panel-right input[type="url"],
.flux-map-panel-right textarea,
.flux-map-panel-right select,
.flux-custom-content-wrap input[type="text"],
.flux-custom-content-wrap input[type="email"],
.flux-custom-content-wrap input[type="tel"],
.flux-custom-content-wrap input[type="url"],
.flux-custom-content-wrap textarea,
.flux-custom-content-wrap select {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    padding: 10px 14px !important;
    border: 1px solid rgba(0, 0, 0, 0.12) !important;
    border-radius: 6px !important;
    background: #f8fafc !important;
    color: #1e293b !important;
    font-size: 13px !important;
    line-height: 1.5 !important;
    transition: all 0.3s ease !important;
    margin-bottom: 12px !important;
}

.flux-map-panel-right input[type="text"]:focus,
.flux-map-panel-right input[type="email"]:focus,
.flux-map-panel-right input[type="tel"]:focus,
.flux-map-panel-right input[type="url"]:focus,
.flux-map-panel-right textarea:focus,
.flux-map-panel-right select:focus,
.flux-custom-content-wrap input[type="text"]:focus,
.flux-custom-content-wrap input[type="email"]:focus,
.flux-custom-content-wrap input[type="tel"]:focus,
.flux-custom-content-wrap input[type="url"]:focus,
.flux-custom-content-wrap textarea:focus,
.flux-custom-content-wrap select:focus {
    border-color: var(--flux-item-hover, #6366f1) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15) !important;
    background: #ffffff !important;
}

.flux-map-panel-right input[type="submit"],
.flux-map-panel-right button,
.flux-custom-content-wrap input[type="submit"],
.flux-custom-content-wrap button {
    display: inline-block !important;
    padding: 10px 20px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1.5 !important;
    text-align: center !important;
    white-space: nowrap !important;
    vertical-align: middle !important;
    cursor: pointer !important;
    border: none !important;
    border-radius: 6px !important;
    background: var(--flux-item-hover, #6366f1) !important;
    color: #ffffff !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.15) !important;
}

.flux-map-panel-right input[type="submit"]:hover,
.flux-map-panel-right button:hover,
.flux-custom-content-wrap input[type="submit"]:hover,
.flux-custom-content-wrap button:hover {
    background: var(--flux-item-hover-dark, #4f46e5) !important;
    box-shadow: 0 6px 16px rgba(99, 102, 241, 0.3) !important;
    transform: translateY(-1px) !important;
}

/* ============================================
   Full-Width Custom Content Dropdown
   ============================================ */

/* Positioning — same as gallery & map panel */
.flux-menu-container .flux-sub-menu.flux-submenu-type-mega.flux-custom-content-dropdown {
    box-sizing: border-box !important;
    min-width: 200px !important;
    max-width: 813px !important;
    width: 100% !important;
    left: 0 !important;
    transform: translateX(0) translateY(20px) !important;
    display: block !important;
    padding: 0 !important;
    overflow: hidden !important;
    grid-template-columns: none !important;
    gap: 0 !important;
}

/* Open state */
.flux-menu-container .flux-menu-item:hover>.flux-sub-menu.flux-submenu-type-mega.flux-custom-content-dropdown,
.flux-menu-container .flux-menu-item.flux-active>.flux-sub-menu.flux-submenu-type-mega.flux-custom-content-dropdown {
    transform: translateX(0) translateY(0) !important;
}

.flux-custom-content-wrap {
    display: block !important;
    width: 100% !important;
    padding: 25px 30px !important;
    box-sizing: border-box !important;
    list-style: none !important;
    margin: 0 !important;
}

/* Iframes (video embeds) fill the full width */
.flux-custom-content-wrap iframe {
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
    box-sizing: border-box !important;
}
