/* Aristo Mega Menu v1.0.0 — by Jalal Shamim */

/* ── TRIGGER (shortcode only) ── */
.amm-trigger-wrap { display: inline-block; }
.amm-trigger {
    display: inline-flex !important;
    align-items: center;
    gap: 4px;
    color: inherit !important;
    text-decoration: none !important;
    font-size: inherit !important;
    font-family: inherit !important;
    font-weight: inherit !important;
    cursor: pointer;
    white-space: nowrap;
    background: none !important;
    border: none !important;
    padding: 0 !important;
}
.amm-caret {
    display: inline-block;
    width: 0; height: 0;
    border-top: 5px solid currentColor;
    border-right: 4px solid transparent;
    border-left: 4px solid transparent;
    margin-left: 3px;
    transition: transform 0.2s ease;
}

/* ── PANEL (fixed overlay) ── */
.amm-panel,
#amm-panel {
    display: block !important;
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    top: 80px;
    width: 100vw !important;
    z-index: 9999999 !important;
    border-top: 3px solid #1e2d4d;
    box-shadow: 0 8px 40px rgba(0,0,0,0.2);
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(-10px) !important;
    pointer-events: none !important;
    transition: opacity 0.22s ease, transform 0.22s ease, visibility 0s linear 0.22s !important;
}
.amm-panel.amm-open,
#amm-panel.amm-open {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
    pointer-events: auto !important;
    transition: opacity 0.22s ease, transform 0.22s ease, visibility 0s linear 0s !important;
}

/* If panel ends up inside a menu li somehow, force it out visually */
li.aristo-mm-trigger .amm-panel,
li.aristo-mm-trigger #amm-panel {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    top: 80px !important;
    width: 100vw !important;
}

/* ── INNER ROW ── */
.amm-inner {
    display: flex !important;
    flex-direction: row !important;
    align-items: stretch !important;
    min-height: 300px;
    max-height: 520px;
    overflow: hidden;
}

/* ── LEFT SIDEBAR ── */
.amm-sidebar {
    width: 220px !important;
    min-width: 220px !important;
    flex-shrink: 0 !important;
    overflow-y: auto;
    scrollbar-width: none;
}
.amm-sidebar::-webkit-scrollbar { display: none; }
.amm-tabs { list-style: none !important; margin: 0 !important; padding: 0 !important; }
.amm-tab {
    display: block !important;
    padding: 14px 18px !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    cursor: pointer !important;
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;
    border-left: 3px solid transparent !important;
    list-style: none !important;
    margin: 0 !important;
    transition: background 0.15s ease !important;
}
.amm-tab:hover { background: #162240 !important; border-left-color: #fff !important; }
.amm-tab.amm-active { background: #162240 !important; font-weight: 600 !important; border-left-color: #fff !important; }

/* ── MIDDLE ── */
.amm-regions-wrap {
    width: 180px !important;
    min-width: 180px !important;
    flex-shrink: 0 !important;
    background: #f5f6f8 !important;
    border-right: 1px solid #e5e7eb !important;
    overflow-y: auto;
}
.amm-regions { list-style: none !important; margin: 0 !important; padding: 10px 0 !important; display: none !important; }
.amm-regions.amm-active { display: block !important; }
.amm-region {
    display: block !important;
    padding: 11px 16px !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    cursor: pointer !important;
    border-left: 3px solid transparent !important;
    list-style: none !important;
    margin: 0 !important;
    transition: background 0.12s ease !important;
}
.amm-region:hover { background: #fff !important; font-weight: 600 !important; border-left-color: #1e2d4d !important; }
.amm-region.amm-active { background: #fff !important; font-weight: 600 !important; border-left-color: #1e2d4d !important; }

/* ── RIGHT CITIES WRAP ── */
.amm-cities-wrap {
    flex: 1 1 auto !important;
    padding: 22px 28px !important;
    overflow-y: auto;
    min-width: 0;
}
.amm-cities { display: none !important; }
.amm-cities.amm-active {
    display: block !important;
    animation: ammFade 0.18s ease;
}
@keyframes ammFade { from { opacity:0; transform:translateX(4px); } to { opacity:1; transform:none; } }

/* ── FLAT cities (no states) — current behaviour preserved ── */
.amm-cities-flat {
    display: flex !important;
    flex-direction: row !important;
    gap: 0 24px !important;
}
.amm-city-col {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    flex: 1 1 0 !important;
    min-width: 130px;
}
.amm-city-col li {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
.amm-city-col a {
    display: block !important;
    padding: 4px 0 !important;
    font-size: 13px !important;
    text-decoration: none !important;
    line-height: 1.55 !important;
    transition: color 0.12s ease, padding-left 0.12s ease !important;
    background: transparent !important;
}
.amm-city-col a:hover { color: #1e2d4d !important; padding-left: 5px !important; }

/* ── STATES grid (new feature) ── */
.amm-states-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 18px 24px !important;
    margin-top: 0;
}
/* If region also had flat cities above, separate the states section */
.amm-cities-flat + .amm-states-grid {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid #eef0f4;
}

.amm-state-block { min-width: 0; }

.amm-state-name {
    display: block !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    margin-bottom: 5px !important;
    padding-bottom: 4px !important;
    border-bottom: 1px solid #eef0f4 !important;
    transition: color 0.12s ease !important;
    background: transparent !important;
}
.amm-state-name:hover { opacity: 0.75 !important; }

.amm-state-cities {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
.amm-state-cities li {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
.amm-state-cities a {
    display: block !important;
    padding: 3px 0 !important;
    font-size: 12.5px !important;
    text-decoration: none !important;
    line-height: 1.55 !important;
    transition: color 0.12s ease, padding-left 0.12s ease !important;
    background: transparent !important;
}
.amm-state-cities a:hover { color: #1e2d4d !important; padding-left: 4px !important; }

/* ── Elementor nav fixes ── */
li.aristo-mm-trigger { position: static !important; overflow: visible !important; }
li.aristo-mm-trigger > ul,
li.aristo-mm-trigger > .sub-menu { display: none !important; }

/* ── MOBILE ── */
@media (max-width: 1024px) {
    #amm-panel {
        position: static !important;
        opacity: 1 !important;
        visibility: visible !important;
        transform: none !important;
        pointer-events: none !important;
        max-height: 0 !important;
        overflow: hidden !important;
        transition: max-height 0.35s ease !important;
        border-top: none !important;
        box-shadow: none !important;
        top: auto !important;
    }
    #amm-panel.amm-open { max-height: 3000px !important; pointer-events: auto !important; }
    .amm-inner { flex-direction: column !important; max-height: none !important; }
    .amm-sidebar, .amm-regions-wrap { width: 100% !important; min-width: 100% !important; }
    .amm-regions-wrap { border-right: none !important; border-top: 1px solid #e5e7eb !important; }
    .amm-cities-wrap { padding: 16px !important; }
    .amm-cities-flat { flex-wrap: wrap !important; }
    .amm-states-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 540px) {
    .amm-states-grid { grid-template-columns: 1fr !important; }
}
