/* MudBlazor + ATM brand bridge — loaded inside portal/admin layouts only */

.mud-layout-root.atm-admin-shell,
.mud-layout.atm-admin-shell {
    background: var(--background);
    min-height: 100vh;
}

.admin-needs-database {
    margin: 0 0 1rem;
    color: #ef4444;
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.4;
}

.mud-layout .mud-drawer {
    border-right: 1px solid var(--border);
}

.mud-layout .mud-drawer .mud-nav-link {
    border-radius: 0.5rem;
    margin: 0.125rem 0.5rem;
}

.mud-layout .mud-drawer .mud-nav-link.active {
    background: var(--sidebar-accent);
}

.mud-layout .mud-appbar {
    border-bottom: 1px solid var(--border);
}

.atm-glass-card.mud-card {
    background: color-mix(in oklab, var(--card) 85%, transparent);
    backdrop-filter: blur(12px);
    border: 1px solid color-mix(in oklab, var(--border) 60%, transparent);
}

.atm-mud-content {
    max-width: 72rem;
    margin: 0 auto;
    padding: 1.5rem 1rem 3rem;
    width: 100%;
}

.atm-portal-content {
    position: relative;
    z-index: 1;
    display: flex;
    flex: 1;
    flex-direction: column;
    width: 100%;
    max-width: 80rem;
    margin-inline: auto;
    padding: 2rem 1rem 3rem;
    box-sizing: border-box;
}

@media (min-width: 640px) {
    .atm-portal-content {
        padding: 2.5rem 1.5rem 3.5rem;
    }
}

@media (min-width: 1024px) {
    .atm-portal-content {
        padding: 3rem 2rem 4rem;
    }
}

.atm-page-header__back {
    text-transform: none;
    font-weight: 500;
    padding-left: 0;
}

.atm-admin-stat-card .mud-card-content {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.atm-admin-stat-card__icon {
    opacity: 0.7;
    margin-bottom: 0.5rem;
}

.atm-admin-form-actions {
    position: sticky;
    bottom: 0;
    z-index: 2;
    padding: 1rem 0;
    background: linear-gradient(to top, var(--background) 70%, transparent);
}

@media (min-width: 960px) {
    .atm-mud-content {
        padding: 2rem 1.5rem 3rem;
    }
}
