/* ==========================================================================
   MIH Mega Menu — Frontend Styles
   Matches the look & feel shown in the design screenshots.
   Brand orange: #f47920
   ========================================================================== */

/* ── Custom properties ──────────────────────────────────────────────── */
.mih-mm-nav {
    --mm-orange:      #f47920;
    --mm-bar-height:  54px;
    --mm-text:        #1e1e1e;
    --mm-muted:       #555;
    --mm-link-hover:  #f47920;
    --mm-panel-bg:    #fff;
    --mm-panel-shadow: 0 8px 32px rgba(0,0,0,.12);
    --mm-radius:      0 0 6px 6px;
    --mm-tab-bg:      #fef3e8;
    --mm-border:      #e8e8e8;
    --mm-font:        inherit;
    --mm-speed:       .18s;
}

/* ── Nav wrapper ────────────────────────────────────────────────────── */
.mih-mm-nav {
    display: flex;
    align-items: stretch;
    position: relative;
    font-family: var(--mm-font);
    -webkit-font-smoothing: antialiased;
}

/* ── Bar ────────────────────────────────────────────────────────────── */
.mih-mm-bar {
    display: flex;
    align-items: stretch;
    min-height: var(--mm-bar-height);
    flex: 1;
    position: relative;          /* panels are positioned relative to this */
}

/* ── Individual nav item ────────────────────────────────────────────── */
.mih-mm-item {
    position: static;            /* panels break out to .mih-mm-bar */
    display: flex;
    align-items: center;
}

.mih-mm-item-label {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 0 16px;
    height: 100%;
    color: #fff;
    font-size: 12.5px;
    font-weight: 700;
    letter-spacing: .6px;
    text-transform: uppercase;
    text-decoration: none;
    white-space: nowrap;
    cursor: pointer;
    transition: opacity var(--mm-speed);
}

.mih-mm-item-label:hover {
    opacity: .85;
}

/* Arrow chevron */
.mih-mm-arrow {
    width: 10px;
    height: 6px;
    flex-shrink: 0;
    transition: transform var(--mm-speed);
    color: inherit;
}

.mih-mm-item.mih-mm-open > .mih-mm-item-label .mih-mm-arrow {
    transform: rotate(180deg);
}

/* ── Button-style item (HPU) ────────────────────────────────────────── */
.mih-mm-item-button .mih-mm-item-label {
    background-color: #005f73;
    border-radius: 4px;
    padding: 6px 16px;
    margin: 8px 6px;
    height: auto;
}

/* ── Dropdown panel (shared) ────────────────────────────────────────── */
.mih-mm-panel {
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    z-index: 9990;
    background: var(--mm-panel-bg);
    border-radius: var(--mm-radius);
    box-shadow: var(--mm-panel-shadow);

    /* Hidden state — panel starts slightly BELOW its final position so
       the opening slide never overlaps the bar above it. */
    opacity: 0;
    transform: translateY(6px);
    pointer-events: none;
    transition:
        opacity     var(--mm-speed) ease,
        transform   var(--mm-speed) ease,
        visibility  0s linear var(--mm-speed);
    visibility: hidden;
}

/* Visible state — triggered by JS adding .mih-mm-open on the item */
.mih-mm-item.mih-mm-open > .mih-mm-panel {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
    visibility: visible;
    transition:
        opacity   var(--mm-speed) ease,
        transform var(--mm-speed) ease;
}

/* ── Inner layout container ─────────────────────────────────────────── */
.mih-mm-inner {
    display: grid;
    gap: 0;
    padding: 28px 32px;
}

/* Simple 1-col: links + featured */
.mih-mm-panel--simple-1col .mih-mm-inner,
.mih-mm-panel--simple-2col .mih-mm-inner {
    grid-template-columns: 1fr 300px;
    gap: 32px;
    align-items: start;
}

/* Tabs: sidebar + panels + featured */
.mih-mm-inner--tabs {
    grid-template-columns: 210px 1fr 300px;
    gap: 0;
    padding: 0;
    align-items: stretch;
}

/* Stickers: grid area + labels column */
.mih-mm-inner--stickers {
    grid-template-columns: 1fr 220px;
    gap: 0;
    padding: 0;
    align-items: stretch;
}

/* ── Link columns (simple layouts) ─────────────────────────────────── */
.mih-mm-links {
    display: grid;
    gap: 2px 24px;
    align-content: start;
}

.mih-mm-links--1col {
    grid-template-columns: 1fr;
}

.mih-mm-links--2col {
    grid-template-columns: 1fr 1fr;
}

.mih-mm-col {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.mih-mm-links a,
.mih-mm-col a {
    color: var(--mm-text);
    text-decoration: none;
    font-size: 14.5px;
    font-weight: 400;
    line-height: 1.4;
    padding: 4px 0;
    transition: color var(--mm-speed);
}

.mih-mm-links a:hover,
.mih-mm-col a:hover {
    color: var(--mm-orange);
}

.mih-mm-view-all-row {
    grid-column: 1 / -1;
    margin-top: 10px;
}

/* ── View-all links ─────────────────────────────────────────────────── */
.mih-mm-view-all {
    color: var(--mm-orange) !important;
    font-weight: 600;
    font-size: 14px;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-top: 8px;
    transition: opacity var(--mm-speed);
}

.mih-mm-view-all:hover {
    opacity: .8;
}

/* ── Tab sidebar ────────────────────────────────────────────────────── */
.mih-mm-tab-sidebar {
    background: var(--mm-tab-bg);
    border-top: 3px solid var(--mm-orange);
    display: flex;
    flex-direction: column;
    padding: 8px 0;
    border-radius: 0 0 0 6px;
}

.mih-mm-tab {
    all: unset;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 20px 10px 18px;
    font-size: 12.5px;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: var(--mm-text);
    cursor: pointer;
    gap: 10px;
    transition: background var(--mm-speed), color var(--mm-speed);
    border-left: 3px solid transparent;
    box-sizing: border-box;
}

.mih-mm-tab:hover {
    background: rgba(244,121,32,.10);
    color: var(--mm-orange);
}

.mih-mm-tab.is-active {
    background: var(--mm-orange);
    color: #fff;
    border-left-color: var(--mm-orange);
}

.mih-mm-tab-arrow {
    width: 6px;
    height: 10px;
    flex-shrink: 0;
    color: inherit;
}

.mih-mm-tab.is-active .mih-mm-tab-arrow {
    color: #fff;
}

.mih-mm-tab-viewall {
    margin-top: auto;
    padding: 12px 18px 8px;
}

/* ── Tab panels ─────────────────────────────────────────────────────── */
.mih-mm-tab-panels {
    padding: 24px 28px;
    display: flex;
    flex-direction: column;
}

.mih-mm-tab-panel {
    display: none;
    flex-direction: column;
    gap: 4px;
}

.mih-mm-tab-panel.is-active {
    display: flex;
}

.mih-mm-tab-panel a {
    color: var(--mm-text);
    text-decoration: none;
    font-size: 14.5px;
    font-weight: 400;
    padding: 4px 0;
    transition: color var(--mm-speed);
}

.mih-mm-tab-panel a:hover {
    color: var(--mm-orange);
}

/* ── Featured products ──────────────────────────────────────────────── */
.mih-mm-featured {
    border-left: 1px solid var(--mm-border);
    padding: 24px 20px 24px 28px;
}

.mih-mm-featured-heading {
    font-size: 16px;
    font-weight: 700;
    color: var(--mm-text);
    margin: 0 0 16px;
    padding: 0;
}

.mih-mm-featured-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.mih-mm-product-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    border: 1px solid var(--mm-border);
    border-radius: 6px;
    padding: 12px;
    text-decoration: none;
    color: var(--mm-text);
    transition: border-color var(--mm-speed), box-shadow var(--mm-speed);
    background: #fff;
}

.mih-mm-product-card:hover {
    border-color: #ccc;
    box-shadow: 0 2px 12px rgba(0,0,0,.08);
}

.mih-mm-product-thumb {
    width: 100%;
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 8px;
}

.mih-mm-product-thumb img {
    max-width: 100%;
    max-height: 90px;
    width: auto;
    height: auto;
    object-fit: contain;
    display: block;
}

.mih-mm-product-name {
    font-size: 13px;
    font-weight: 500;
    text-align: center;
    line-height: 1.3;
    color: var(--mm-text);
}

/* ── Stickers & Labels ──────────────────────────────────────────────── */
.mih-mm-stickers-area {
    padding: 24px 28px;
    border-right: 1px solid var(--mm-border);
}

.mih-mm-labels-area {
    padding: 24px 24px;
    background: #fafafa;
    border-radius: 0 0 6px 0;
}

.mih-mm-section-title {
    font-size: 17px;
    font-weight: 700;
    color: var(--mm-text);
    margin: 0 0 16px;
    padding: 0;
}

.mih-mm-labels-area .mih-mm-section-title {
    margin-bottom: 14px;
}

.mih-mm-labels-area a {
    display: block;
    color: var(--mm-text);
    text-decoration: none;
    font-size: 14.5px;
    padding: 5px 0;
    transition: color var(--mm-speed);
}

.mih-mm-labels-area a:hover {
    color: var(--mm-orange);
}

/* Sticker grid: 4 columns */
.mih-mm-stickers-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
    margin-bottom: 16px;
}

.mih-mm-sticker-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 7px;
    padding: 12px 8px;
    border: 1px solid var(--mm-border);
    border-radius: 6px;
    text-decoration: none;
    color: var(--mm-text);
    background: #fff;
    text-align: center;
    transition: border-color var(--mm-speed), box-shadow var(--mm-speed);
}

.mih-mm-sticker-card:hover {
    border-color: #ccc;
    box-shadow: 0 2px 10px rgba(0,0,0,.07);
    color: var(--mm-orange);
}

.mih-mm-sticker-card img {
    display: block;
    width: 48px;
    height: 48px;
    object-fit: contain;
}

.mih-mm-sticker-card span {
    font-size: 12px;
    font-weight: 500;
    line-height: 1.25;
}

/* ── Elementor editor: keep bar looking natural; panels stay hidden.
   Hover still works in the preview canvas via JS.
   Add a subtle indicator so the client knows items have dropdowns. ── */
/* Tooltip-style badge: hover a dropdown item in the editor canvas to see 'click to preview' */
.elementor-editor-active .mih-mm-has-dropdown > .mih-mm-item-label {
    position: relative;
}
.elementor-editor-active .mih-mm-has-dropdown > .mih-mm-item-label::after {
    content: 'click to preview';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
    background: rgba(0,0,0,.75);
    color: #fff;
    font-size: 10px;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: none;
    padding: 3px 7px;
    border-radius: 3px;
    pointer-events: none;
    opacity: 0;
    transition: opacity .15s;
    z-index: 10000;
}
.elementor-editor-active .mih-mm-has-dropdown > .mih-mm-item-label:hover::after {
    opacity: 1;
}
/* While the panel is open in editor, swap hint to 'click to close' */
.elementor-editor-active .mih-mm-item.mih-mm-open > .mih-mm-item-label::after {
    content: 'click to close';
    opacity: 0;
}
.elementor-editor-active .mih-mm-item.mih-mm-open > .mih-mm-item-label:hover::after {
    opacity: 1;
}

/* ── Responsive — mobile ─────────────────────────────────────────────── */
@media (max-width: 900px) {
    .mih-mm-nav {
        flex-direction: column;
        align-items: stretch;
    }

    .mih-mm-bar {
        flex-direction: column;
        min-height: auto;
    }

    .mih-mm-item {
        flex-direction: column;
        align-items: stretch;
        border-bottom: 1px solid rgba(255,255,255,.15);
    }

    .mih-mm-item-label {
        padding: 12px 18px;
        height: auto;
    }

    .mih-mm-panel {
        position: static;
        opacity: 1;
        transform: none;
        pointer-events: auto;
        visibility: visible;
        box-shadow: none;
        border-radius: 0;
        display: none;
    }

    .mih-mm-item.mih-mm-open > .mih-mm-panel {
        display: block;
    }

    .mih-mm-inner,
    .mih-mm-inner--tabs,
    .mih-mm-inner--stickers {
        grid-template-columns: 1fr;
    }

    .mih-mm-links--2col {
        grid-template-columns: 1fr;
    }

    .mih-mm-featured {
        border-left: none;
        border-top: 1px solid var(--mm-border);
        padding: 16px;
    }

    .mih-mm-featured-grid {
        grid-template-columns: 1fr 1fr;
    }

    .mih-mm-inner--tabs .mih-mm-featured,
    .mih-mm-inner--stickers .mih-mm-labels-area {
        border-left: none;
        border-top: 1px solid var(--mm-border);
    }

    .mih-mm-stickers-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 500px) {
    .mih-mm-stickers-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .mih-mm-featured-grid {
        grid-template-columns: 1fr;
    }
}
