/*
 * SmartWedding mega-menu
 * Folosește dropdown-ul nativ Bootstrap 4 ca container — extindem stilurile peste.
 * Pe desktop (>= 992px): mega-menu pe full-width container, 3 coloane semantice.
 * Pe mobile (< 992px): se transformă în accordion submeniu (clasic Bootstrap collapse).
 *
 * Paletă aliniată cu destination.css:
 *   --mm-ink:           #32236F  (dark purple — titluri/text)
 *   --mm-ink-soft:      #3E3F66  (body text)
 *   --mm-muted:         #6b6781
 *   --mm-accent:        #6A49F2  (primary purple)
 *   --mm-accent-dark:   #4c2fb5
 *   --mm-accent-soft:   #EAE4FB  (lavender pal — hover bg)
 *   --mm-line:          #e4dff8  (border subtil)
 *   --mm-bg:            #F6F4FE  (lavender bg pentru footer)
 */

.navbar .megamenu {
    --mm-ink: #32236F;
    --mm-ink-soft: #3E3F66;
    --mm-muted: #6b6781;
    --mm-accent: #6A49F2;
    --mm-accent-dark: #4c2fb5;
    --mm-accent-soft: #EAE4FB;
    --mm-line: #e4dff8;
    --mm-bg: #F6F4FE;
}

/* ---------------------------------------------------------------------------
 * Top-level toggle ("Servicii ▾") — suprimăm caret-ul nativ Bootstrap și
 * folosim SVG-ul nostru, ca să avem un singur indicator vizual.
 * ------------------------------------------------------------------------- */
.navbar .megamenu__toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.navbar .megamenu__toggle::after {
    display: none !important;
}

.navbar .megamenu__caret {
    flex: 0 0 auto;
    display: inline-block;
    transition: transform 180ms ease;
    color: currentColor;
    opacity: 0.85;
}

.navbar .nav-item.has-megamenu > .nav-link[aria-expanded="true"] .megamenu__caret {
    transform: rotate(180deg);
}

/* ---------------------------------------------------------------------------
 * Desktop layout (≥ 992px)
 * ------------------------------------------------------------------------- */
@media (min-width: 992px) {
    .navbar .has-megamenu {
        position: static;
    }

    .navbar .megamenu {
        left: 0;
        right: 0;
        width: 100%;
        padding: 0;
        margin-top: 8px;
        border: 0;
        border-radius: 18px;
        overflow: hidden;
        box-shadow:
            0 24px 48px rgba(50, 35, 111, 0.16),
            0 6px 14px rgba(50, 35, 111, 0.08),
            0 0 0 1px var(--mm-line);
        background: #fff;
        animation: smwMegamenuFade 180ms ease-out;
    }

    .navbar .megamenu__cols {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0;
        padding: 28px 0 24px;
    }

    .navbar .megamenu__col {
        padding: 0 24px;
        position: relative;
    }

    .navbar .megamenu__col + .megamenu__col::before {
        content: "";
        position: absolute;
        top: 4px;
        bottom: 4px;
        left: 0;
        width: 1px;
        background: var(--mm-line);
    }

    .navbar .megamenu__title {
        font-size: 0.74rem;
        text-transform: uppercase;
        letter-spacing: 0.14em;
        font-weight: 700;
        color: var(--mm-accent);
        margin: 0 0 14px;
    }

    .navbar .megamenu__list {
        list-style: none;
        padding: 0;
        margin: 0;
    }

    .navbar .megamenu__list li + li {
        margin-top: 4px;
    }

    .navbar .megamenu__link {
        display: flex;
        align-items: flex-start;
        gap: 14px;
        padding: 12px 14px;
        color: var(--mm-ink);
        text-decoration: none;
        border-radius: 12px;
        transition:
            background-color 160ms ease,
            color 160ms ease,
            transform 160ms ease;
        position: relative;
    }

    .navbar .megamenu__link:hover,
    .navbar .megamenu__link:focus {
        background-color: var(--mm-accent-soft);
        color: var(--mm-accent-dark);
        text-decoration: none;
        outline: none;
    }

    .navbar .megamenu__link:focus-visible {
        box-shadow: 0 0 0 2px var(--mm-accent);
    }

    .navbar .megamenu__icon {
        flex: 0 0 auto;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 38px;
        height: 38px;
        border-radius: 10px;
        background: var(--mm-accent-soft);
        color: var(--mm-accent);
        font-size: 1.15rem;
        line-height: 1;
        margin-top: 2px;
        transition: background-color 160ms ease, color 160ms ease;
    }

    .navbar .megamenu__link:hover .megamenu__icon,
    .navbar .megamenu__link:focus .megamenu__icon {
        background: var(--mm-accent);
        color: #fff;
    }

    .navbar .megamenu__label {
        display: block;
        font-weight: 600;
        font-size: 0.96rem;
        line-height: 1.3;
        color: var(--mm-ink);
    }

    .navbar .megamenu__link:hover .megamenu__label,
    .navbar .megamenu__link:focus .megamenu__label {
        color: var(--mm-accent-dark);
    }

    .navbar .megamenu__sub {
        display: block;
        font-size: 0.78rem;
        color: var(--mm-muted);
        margin-top: 3px;
        line-height: 1.4;
    }

    .navbar .megamenu__badge {
        display: inline-block;
        margin-left: 8px;
        padding: 2px 8px;
        font-size: 0.62rem;
        font-weight: 700;
        line-height: 1.3;
        color: #fff;
        background: linear-gradient(135deg, #ff5e3a, #ff2a68);
        border-radius: 999px;
        vertical-align: middle;
        letter-spacing: 0.06em;
        text-transform: uppercase;
    }

    .navbar .megamenu__footer {
        margin: 0;
        padding: 18px 28px;
        background: var(--mm-bg);
        border-top: 1px solid var(--mm-line);
        display: flex;
        justify-content: space-between;
        align-items: center;
        gap: 24px;
        font-size: 0.88rem;
    }

    .navbar .megamenu__footer-text {
        display: flex;
        flex-direction: column;
        line-height: 1.4;
    }

    .navbar .megamenu__footer-text strong {
        color: var(--mm-ink);
        font-weight: 600;
        font-size: 0.92rem;
    }

    .navbar .megamenu__footer-text span {
        color: var(--mm-muted);
        font-size: 0.8rem;
        margin-top: 2px;
    }

    .navbar .megamenu__cta {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        padding: 10px 22px;
        background: var(--mm-accent);
        color: #fff !important;
        font-weight: 600;
        font-size: 0.88rem;
        border-radius: 999px;
        text-decoration: none;
        transition: background-color 160ms ease, transform 160ms ease;
        flex: 0 0 auto;
        white-space: nowrap;
    }

    .navbar .megamenu__cta:hover,
    .navbar .megamenu__cta:focus {
        background: var(--mm-accent-dark);
        color: #fff !important;
        text-decoration: none;
        transform: translateX(2px);
    }

    .navbar .megamenu__cta svg {
        transition: transform 160ms ease;
    }

    .navbar .megamenu__cta:hover svg {
        transform: translateX(3px);
    }
}

/* ---------------------------------------------------------------------------
 * Mobile / tablet layout (< 992px) — listă simplă, "in linie in jos"
 * Pe mobile, ierarhia vizuală a mega-meniului (3 coloane × titluri secțiune
 * × carduri cu sub-descriere × footer CTA) devine zgomot — toate item-urile
 * sunt deja stack vertical, deci secționarea nu mai aduce informație.
 * Reducem la o listă flată cu iconiță mică inline + label + badge opțional.
 * ------------------------------------------------------------------------- */
@media (max-width: 991.98px) {
    /* ------------------------------------------------------------------
     * Drawer scrollabil:
     * Tema pune `.navbar-collapse` ca `position: absolute` (white_header)
     * sau ca block normal (header default) — în ambele cazuri, dacă
     * conținutul depășește înălțimea viewportului, drawer-ul se taie și
     * userul nu poate ajunge la "Intră în cont". Forțăm scroll intern.
     * ------------------------------------------------------------------ */
    header .navbar-collapse {
        max-height: calc(100vh - 80px);
        max-height: calc(100dvh - 80px); /* dvh pe iOS Safari, cade pe vh dacă lipsește */
        overflow-y: auto;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior: contain;
    }

    /* ------------------------------------------------------------------
     * Aliniere "Servicii" pe mobile:
     * Tema setează `body { text-align: center }` la `< 767px`
     * (responsive.css). Cum `.megamenu__toggle` e `display: inline-flex`
     * (inline-level), moștenește centrarea și apare offset față de
     * "Acasă" / "Blog" care sunt `display: block`. Forțăm aliniere stânga
     * pe nav-item-ul cu mega-menu și pe toggle-ul însuși.
     * ------------------------------------------------------------------ */
    .navbar .nav-item.has-megamenu {
        text-align: left;
    }
    .navbar .megamenu__toggle {
        justify-content: flex-start;
        padding-left: 8px;
    }

    /* Containerul mega-meniului — fără carcasă vizuală pe mobil */
    .navbar .megamenu {
        position: static;
        float: none;
        width: 100%;
        padding: 4px 0 8px;
        margin-top: 0;
        border: 0;
        box-shadow: none;
        background: transparent;
        border-radius: 0;
        max-height: none;
        overflow: visible;
    }

    .navbar .megamenu__cols {
        display: block;
    }

    /* Eliminăm separarea pe coloane — toate item-urile curg ca o listă flată */
    .navbar .megamenu__col {
        padding: 0;
    }
    .navbar .megamenu__col + .megamenu__col {
        margin-top: 0;
        padding-top: 0;
        border-top: 0;
    }

    /* Ascundem ierarhia secundară (titluri secțiune, sub-descrieri, footer CTA)
       — nu mai aduc valoare când totul e deja stack vertical pe mobil */
    .navbar .megamenu__title,
    .navbar .megamenu__sub,
    .navbar .megamenu__footer {
        display: none;
    }

    .navbar .megamenu__list {
        list-style: none;
        padding: 0;
        margin: 0;
    }

    /* Link-urile devin nav-link-uri normale, simple, in linie */
    .navbar .megamenu__link {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 8px 4px;
        color: var(--mm-ink);
        text-decoration: none;
        border-radius: 6px;
    }

    .navbar .megamenu__link:hover,
    .navbar .megamenu__link:focus {
        background-color: var(--mm-accent-soft);
        color: var(--mm-accent-dark);
        outline: none;
    }

    /* Iconiță inline mică, fără "badge" colorat — doar glyph în accent */
    .navbar .megamenu__icon {
        flex: 0 0 auto;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 20px;
        height: 20px;
        background: transparent;
        color: var(--mm-accent);
        font-size: 1.05rem;
        border-radius: 0;
    }

    .navbar .megamenu__label {
        font-weight: 500;
        font-size: 0.95rem;
        color: var(--mm-ink);
        line-height: 1.3;
    }

    /* Badge "NOU" — păstrat (e o info utilă), dar mai discret */
    .navbar .megamenu__badge {
        display: inline-block;
        margin-left: 6px;
        padding: 1px 6px;
        font-size: 0.6rem;
        font-weight: 700;
        color: #fff;
        background: linear-gradient(135deg, #ff5e3a, #ff2a68);
        border-radius: 999px;
        letter-spacing: 0.06em;
        vertical-align: middle;
    }
}

/* ---------------------------------------------------------------------------
 * Animație fade-in
 * ------------------------------------------------------------------------- */
@keyframes smwMegamenuFade {
    from {
        opacity: 0;
        transform: translateY(-6px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
