/* Mobile drawer menu.
   Owns only the sidebar shell below 780px; page layouts keep their own adaptive CSS. */

@media (max-width: 779px) {
    body.mobile-menu-open {
        overflow: hidden;
    }

    .admin-layout {
        padding-top: 64px;
    }

    .admin-layout .main-content {
        padding-top: 16px;
    }

    .sidebar,
    body.sidebar-collapsed .sidebar {
        position: fixed;
        inset: 0 0 auto 0;
        z-index: 1200;
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: flex-start;
        width: 100%;
        max-width: 100vw;
        min-width: 0;
        height: 64px;
        min-height: 64px;
        max-height: 64px;
        padding: 10px 12px;
        border-right: 0;
        border-bottom: 1px solid var(--stroke);
        overflow: visible;
        background:
            radial-gradient(circle at 18% 0%, rgba(79, 124, 255, 0.16), transparent 36%),
            linear-gradient(180deg, rgba(6, 15, 31, 0.98), rgba(8, 18, 35, 0.96));
        box-shadow: 0 12px 28px rgba(2, 6, 23, 0.22);
        backdrop-filter: blur(16px);
    }

    .sidebar__brand,
    body.sidebar-collapsed .sidebar__brand {
        display: flex;
        align-items: center;
        justify-content: flex-start;
        flex: 0 0 auto;
        margin: 0;
        padding: 0;
    }

    .sidebar__brand-logo,
    body.sidebar-collapsed .sidebar__brand-logo {
        display: none;
    }

    .sidebar__toggle,
    body.sidebar-collapsed .sidebar__toggle {
        position: static;
        z-index: 2;
        width: 44px;
        height: 44px;
        flex: 0 0 44px;
    }

    .sidebar__nav,
    body.sidebar-collapsed .sidebar__nav,
    .sidebar__account,
    body.sidebar-collapsed .sidebar__account {
        display: none;
    }

    body.mobile-menu-open .sidebar,
    body.mobile-menu-open.sidebar-collapsed .sidebar {
        inset: 0;
        z-index: 5000;
        display: grid;
        grid-template-columns: 1fr;
        grid-template-rows: 60px minmax(0, 1fr) auto;
        gap: 0;
        align-items: stretch;
        height: 100dvh;
        min-height: 100dvh;
        max-height: 100dvh;
        padding: 0;
        overflow: hidden;
        border-bottom: 0;
        background:
            radial-gradient(circle at 18% 0%, rgba(79, 124, 255, 0.20), transparent 34%),
            linear-gradient(180deg, rgba(6, 15, 31, 0.99), rgba(8, 18, 35, 0.99));
    }

    body.mobile-menu-open .sidebar__brand,
    body.mobile-menu-open.sidebar-collapsed .sidebar__brand {
        min-height: 60px;
        padding: 8px 12px;
        border-bottom: 1px solid rgba(148, 163, 184, 0.14);
        background: rgba(6, 15, 31, 0.72);
    }

    body.mobile-menu-open .sidebar__toggle,
    body.mobile-menu-open.sidebar-collapsed .sidebar__toggle {
        width: 44px;
        height: 44px;
        flex-basis: 44px;
    }

    body.mobile-menu-open .sidebar__nav,
    body.mobile-menu-open.sidebar-collapsed .sidebar__nav {
        display: grid;
        align-content: start;
        gap: 6px;
        min-height: 0;
        margin: 0;
        padding: 10px 12px 12px;
        overflow-x: hidden;
        overflow-y: auto;
        background: transparent;
        scrollbar-width: thin;
        scrollbar-color: rgba(203, 213, 225, 0.52) rgba(15, 23, 42, 0.34);
    }

    body.mobile-menu-open .sidebar__link,
    body.mobile-menu-open.sidebar-collapsed .sidebar__link {
        display: flex;
        align-items: center;
        justify-content: flex-start;
        gap: 10px;
        width: 100%;
        min-height: 44px;
        padding: 9px 12px;
        border-radius: 13px;
        font-size: 14px;
        transform: none;
    }

    body.mobile-menu-open .sidebar__label,
    body.mobile-menu-open.sidebar-collapsed .sidebar__label {
        display: inline;
        min-width: 0;
        white-space: normal;
        overflow-wrap: anywhere;
    }

    body.mobile-menu-open .sidebar__icon,
    body.mobile-menu-open.sidebar-collapsed .sidebar__icon {
        flex: 0 0 22px;
        width: 22px;
        height: 22px;
    }

    body.mobile-menu-open .sidebar__icon svg,
    body.mobile-menu-open.sidebar-collapsed .sidebar__icon svg {
        width: 20px;
        height: 20px;
    }

    body.mobile-menu-open .sidebar__account,
    body.mobile-menu-open.sidebar-collapsed .sidebar__account {
        display: grid;
        gap: 8px;
        margin: 0 12px 12px;
        padding: 10px 12px;
        border: 1px solid rgba(148, 163, 184, 0.14);
        border-radius: 14px;
        background: rgba(15, 23, 42, 0.50);
    }

    body.mobile-menu-open .sidebar__account-main,
    body.mobile-menu-open.sidebar-collapsed .sidebar__account-main {
        display: grid;
        grid-template-columns: 34px minmax(0, 1fr);
        gap: 9px;
        align-items: center;
    }

    body.mobile-menu-open .sidebar__account-avatar,
    body.mobile-menu-open.sidebar-collapsed .sidebar__account-avatar {
        width: 34px;
        height: 34px;
        border-radius: 11px;
        font-size: 14px;
    }

    body.mobile-menu-open .sidebar__account-text,
    body.mobile-menu-open.sidebar-collapsed .sidebar__account-text {
        display: grid;
        min-width: 0;
    }

    body.mobile-menu-open .sidebar__account-name,
    body.mobile-menu-open.sidebar-collapsed .sidebar__account-name {
        font-size: 13px;
    }

    body.mobile-menu-open .sidebar__account-meta,
    body.mobile-menu-open.sidebar-collapsed .sidebar__account-meta {
        font-size: 11px;
    }

    body.mobile-menu-open .sidebar__account-locations,
    body.mobile-menu-open.sidebar-collapsed .sidebar__account-locations {
        display: flex;
        gap: 5px;
        max-height: 44px;
        overflow-y: auto;
    }

    body.mobile-menu-open .sidebar__account-location,
    body.mobile-menu-open.sidebar-collapsed .sidebar__account-location {
        padding: 4px 8px;
        font-size: 10px;
    }

    body.mobile-menu-open .sidebar__account-actions,
    body.mobile-menu-open.sidebar-collapsed .sidebar__account-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 6px;
    }

    body.mobile-menu-open .sidebar__account-btn,
    body.mobile-menu-open.sidebar-collapsed .sidebar__account-btn {
        min-height: 34px;
        padding: 7px 8px;
        border-radius: 10px;
        font-size: 12px;
        line-height: 1.1;
    }
}

@media (max-width: 370px) {
    body.mobile-menu-open .sidebar__nav,
    body.mobile-menu-open.sidebar-collapsed .sidebar__nav {
        gap: 5px;
        padding-inline: 10px;
    }

    body.mobile-menu-open .sidebar__link,
    body.mobile-menu-open.sidebar-collapsed .sidebar__link {
        min-height: 42px;
        padding: 8px 10px;
        font-size: 13px;
    }
}
