/**
 * Toggle sidebar (☰): sembunyikan / tampilkan menu + konten menyesuaikan lebar.
 */
@media (min-width: 1024px) {
    html.portal-sidebar-collapsed body.maternal-portal-body .maternal-app-frame,
    html.portal-sidebar-collapsed body.admin-portal-body .app-shell,
    html.portal-sidebar-collapsed body.staff-portal-body .app-shell,
    html.portal-sidebar-collapsed body.admin-nifas-ringkasan-body .app-shell,
    body.portal-sidebar-collapsed.maternal-portal-body .maternal-app-frame,
    body.portal-sidebar-collapsed.admin-portal-body .app-shell,
    body.portal-sidebar-collapsed.staff-portal-body .app-shell,
    body.portal-sidebar-collapsed.admin-nifas-ringkasan-body .app-shell {
        padding-left: 0 !important;
        margin-left: 0 !important;
        transition: padding-left 0.2s ease-out;
    }

    html:not(.portal-sidebar-collapsed) body.maternal-portal-body:not(.portal-sidebar-collapsed) .maternal-app-frame,
    html:not(.portal-sidebar-collapsed) body.admin-portal-body:not(.portal-sidebar-collapsed) .app-shell,
    html:not(.portal-sidebar-collapsed) body.staff-portal-body:not(.portal-sidebar-collapsed) .app-shell {
        transition: padding-left 0.2s ease-out;
    }

    html.portal-sidebar-collapsed #maternal-sidebar,
    html.portal-sidebar-collapsed #admin-sidebar,
    html.portal-sidebar-collapsed #staff-sidebar,
    html.portal-sidebar-collapsed #nifas-ringkasan-sidebar,
    body.portal-sidebar-collapsed #maternal-sidebar,
    body.portal-sidebar-collapsed #admin-sidebar,
    body.portal-sidebar-collapsed #staff-sidebar,
    body.portal-sidebar-collapsed #nifas-ringkasan-sidebar {
        transform: translate3d(-110%, 0, 0) !important;
        visibility: hidden !important;
        pointer-events: none !important;
    }

    html:not(.portal-sidebar-collapsed) body.maternal-portal-body:not(.portal-sidebar-collapsed) #maternal-sidebar,
    body.maternal-portal-body:not(.portal-sidebar-collapsed) #maternal-sidebar {
        transform: translateX(0) !important;
        visibility: visible !important;
        pointer-events: auto !important;
    }

    html:not(.portal-sidebar-collapsed) body.admin-portal-body:not(.portal-sidebar-collapsed) #admin-sidebar,
    body.admin-portal-body:not(.portal-sidebar-collapsed) #admin-sidebar,
    html:not(.portal-sidebar-collapsed) body.staff-portal-body:not(.portal-sidebar-collapsed) #staff-sidebar,
    body.staff-portal-body:not(.portal-sidebar-collapsed) #staff-sidebar,
    html:not(.portal-sidebar-collapsed) body.admin-nifas-ringkasan-body:not(.portal-sidebar-collapsed) #nifas-ringkasan-sidebar,
    body.admin-nifas-ringkasan-body:not(.portal-sidebar-collapsed) #nifas-ringkasan-sidebar {
        transform: translateX(0) !important;
        visibility: visible !important;
        pointer-events: auto !important;
    }
}

[data-portal-sidebar-toggle],
.portal-sidebar-toggle-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    touch-action: manipulation;
    padding: 0;
    border: none;
    background: transparent;
    line-height: 0;
    vertical-align: middle;
    -webkit-tap-highlight-color: transparent;
}

/* Ikon ☰ / ✕ (SVG) */
.portal-sidebar-toggle-btn .portal-sidebar-toggle-icon {
    display: block;
    width: 1.5rem;
    height: 1.5rem;
    flex-shrink: 0;
    pointer-events: none;
}

.portal-sidebar-toggle-btn .portal-sidebar-toggle-icon--close {
    display: none;
}

.portal-sidebar-toggle-btn[aria-expanded="true"] .portal-sidebar-toggle-icon--open {
    display: none;
}

.portal-sidebar-toggle-btn[aria-expanded="true"] .portal-sidebar-toggle-icon--close {
    display: block;
}

/* Admin / staff: tombol kotak jelas di header putih */
.portal-sidebar-toggle-btn--admin {
    min-width: 2.75rem;
    min-height: 2.75rem;
    padding: 0.5rem;
    border-radius: 0.5rem;
    border: 1px solid rgba(229, 231, 235, 0.9);
    background-color: #fff;
    color: #374151;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
    transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.portal-sidebar-toggle-btn--admin:hover {
    background-color: #f9fafb;
    border-color: #d1d5db;
    color: #111827;
}

.portal-sidebar-toggle-btn--admin:focus-visible {
    outline: 2px solid #b11e6f;
    outline-offset: 2px;
}

.portal-sidebar-toggle-btn--admin .portal-sidebar-toggle-icon {
    width: 1.375rem;
    height: 1.375rem;
}

/* Portal pengguna (maternal) */
.portal-sidebar-toggle-btn--maternal {
    min-width: 2.75rem;
    min-height: 2.75rem;
    padding: 0.5rem;
    border-radius: 0.75rem;
    color: #b11e6f;
    background: transparent;
}

.portal-sidebar-toggle-btn--maternal:hover {
    background-color: rgba(177, 30, 111, 0.08);
}

.portal-sidebar-toggle-btn--maternal:focus-visible {
    outline: 2px solid #b11e6f;
    outline-offset: 2px;
}

@media (max-width: 1023px) {
    #maternal-sidebar.portal-sidebar--mobile-open,
    #maternal-sidebar.maternal-sidebar--open {
        transform: translate3d(0, 0, 0) !important;
        visibility: visible !important;
        pointer-events: auto !important;
        z-index: 110 !important;
    }

    #admin-sidebar.portal-sidebar--mobile-open,
    #staff-sidebar.portal-sidebar--mobile-open,
    #nifas-ringkasan-sidebar.portal-sidebar--mobile-open {
        transform: translate3d(0, 0, 0) !important;
        visibility: visible !important;
        pointer-events: auto !important;
        z-index: 60 !important;
    }
}
