/* ─── Theme tokens ────────────────────────
   Semantic colors used by both MudBlazor chrome and custom inline styles.
   Dark values flip when ThemeService sets html[data-theme="dark"].
   Brand/semantic accents (#00B5A6 teal, status colors) are intentionally
   theme-independent and stay hardcoded at call sites. */
:root {
    --sd-surface: #FFFFFF;
    --sd-bg-subtle: #F9FAFB;
    --sd-border: #E9ECEF;
    --sd-text: #212529;
    --sd-text-secondary: #6C757D;
    --sd-text-muted: #9CA3AF;
    --sd-accent-soft: #E6FAF8;
    --sd-success-soft: #D8F3DC;
    --sd-success-text: #2D6A4F;
    --sd-danger-soft: #FFF5F5;
    --sd-danger-text: #E63946;
    --sd-warning-soft: #FEF3C7;
    --sd-warning-text: #92400E;
    --sd-info-soft: #DBEAFE;
    --sd-info-text: #1E40AF;
    --sd-absence-soft: #EDE9FE;
    --sd-absence-text: #5B21B6;
}
html[data-theme="dark"] {
    --sd-surface: #1E1E1E;
    --sd-bg-subtle: #181818;
    --sd-border: #2D2D2D;
    --sd-text: #E6E6E6;
    --sd-text-secondary: #B0B0B0;
    --sd-text-muted: #8A8A8A;
    --sd-accent-soft: #0E2E2B;
    --sd-success-soft: #16341F;
    --sd-success-text: #5FD98A;
    --sd-danger-soft: #3A1C1F;
    --sd-danger-text: #F5808B;
    --sd-warning-soft: #3A2E10;
    --sd-warning-text: #FCD34D;
    --sd-info-soft: #1E2A47;
    --sd-info-text: #93C5FD;
    --sd-absence-soft: #2E2547;
    --sd-absence-text: #C4B5FD;
}

html, body {
    font-family: 'Inter', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    margin: 0;
    padding: 0;
}

h1:focus { outline: none; }

/* ─── Sidebar ─────────────────────────── */
.sidebar-drawer {
    border-right: 1px solid var(--sd-border) !important;
}

.sidebar-brand { border-bottom: none; }

.nav-group-label {
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: var(--sd-text-muted);
    padding: 0 16px;
    margin-top: 8px;
    margin-bottom: 4px;
}

/* ─── Mobile bottom nav ───────────────── */
.bottom-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    height: 56px;
    border-top: 1px solid var(--sd-border) !important;
    background: var(--sd-surface);
    border-radius: 0 !important;
    padding-bottom: env(safe-area-inset-bottom);
}
.bottom-nav-inner { width: 100%; height: 100%; padding: 4px 0; }
.bottom-nav-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    font-size: 0.65rem;
    color: #6C757D;
    text-decoration: none;
    padding: 4px 12px;
    min-width: 48px;
    min-height: 48px;
    justify-content: center;
    transition: color 0.15s;
}
.bottom-nav-item:hover { color: #00B5A6; }
.bottom-nav-item--active,
.bottom-nav-item--active:hover { color: #00B5A6; font-weight: 600; }

/* ─── Main content ────────────────────── */
.main-content {
    padding-bottom: calc(56px + env(safe-area-inset-bottom) + 16px);
}
@media (min-width: 960px) {
    .main-content { padding-bottom: 0; }
}

/* ─── Cards ───────────────────────────── */
.stat-card {
    border: 1px solid var(--sd-border);
    border-radius: 12px;
    padding: 20px;
    background: var(--sd-surface);
}

.section-card {
    border: 1px solid var(--sd-border);
    border-radius: 12px;
    padding: 20px;
    background: var(--sd-surface);
}

/* ─── Notification bell ───────────────── */
.notification-bell { position: relative; }
.notification-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #E63946;
}

/* ─── Sync status ─────────────────────── */
.sync-indicator {
    font-size: 0.7rem;
    color: var(--sd-text-muted);
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 0 16px;
    margin-bottom: 8px;
}

/* ─── Context switcher ────────────────── */
.context-switcher {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: 8px;
    cursor: pointer;
    transition: background 0.15s;
}
.context-switcher:hover { background: var(--sd-bg-subtle); }

/* ─── Forefallende kanban ─────────────── */
.kanban-card {
    padding: 12px;
    border-radius: 8px;
    margin-bottom: 8px;
    background: var(--sd-surface);
}
.kanban-card--overdue { border-left: 3px solid #E63946; }
.kanban-card--thisweek { border-left: 3px solid #F4A261; }
.kanban-card--thismonth { border: 1px solid var(--sd-border); }
.kanban-card--later { border: 1px solid var(--sd-border); }

/* ─── Week view ───────────────────────── */
.week-day-header {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--sd-text-secondary);
    text-transform: uppercase;
    padding: 8px 0;
    border-bottom: 1px solid var(--sd-border);
}
.week-day-header--today {
    color: #00B5A6;
    border-bottom: 2px solid #00B5A6;
}

/* ─── Status badges ───────────────────── */
.status-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.75rem;
    font-weight: 500;
    padding: 2px 10px;
    border-radius: 12px;
}
.status-badge--open { background: #FEE2E2; color: #DC2626; }
.status-badge--inprogress { background: #FEF3C7; color: #D97706; }
.status-badge--closed { background: #D1FAE5; color: #059669; }
.status-badge--draft { background: #F3F4F6; color: #6B7280; }
.status-badge--submitted { background: #DBEAFE; color: #2563EB; }
.status-badge--approved { background: #D1FAE5; color: #059669; }
.status-badge--rejected { background: #FEE2E2; color: #DC2626; }

/* ─── Risk matrix ─────────────────────── */
.risk-cell {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 0.85rem;
    border-radius: 6px;
}
.risk-low { background: #D1FAE5; color: #059669; }
.risk-medium { background: #FEF3C7; color: #D97706; }
.risk-high { background: #FED7AA; color: #C2410C; }
.risk-critical { background: #FEE2E2; color: #DC2626; }

/* ─── Cert badges ─────────────────────── */
.cert-ok { color: #059669; }
.cert-expiring { color: #D97706; }
.cert-expired { color: #DC2626; }

/* ─── Blazor error ────────────────────── */
#blazor-error-ui {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}
#blazor-error-ui .dismiss {
    cursor: pointer;
    position: absolute;
    right: 0.75rem;
    top: 0.5rem;
}
.blazor-error-boundary {
    background: #b32121;
    padding: 1rem;
    color: white;
}
.blazor-error-boundary::after { content: "En feil har oppstatt." }

/* ─── Wizard steps ────────────────────── */
.wizard-step {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    border-radius: 8px;
    font-size: 0.85rem;
    color: #6C757D;
}
.wizard-step--active { color: #00B5A6; font-weight: 600; background: #EEF2FF; }
.wizard-step--completed { color: #059669; }

/* ─── Shepherd Tour ──────────────────── */
/* Theme tokens (not hardcoded greys) so the welcome tour follows dark mode:
   the CDN shepherd.css ships a white popup, which made the tour unreadable/
   out of place when html[data-theme="dark"] is active. */
.shepherd-element {
    font-family: 'Inter', sans-serif !important;
    border-radius: 12px !important;
    box-shadow: 0 8px 32px rgba(0,0,0,0.12) !important;
    background: var(--sd-surface) !important;
    color: var(--sd-text) !important;
}
.shepherd-arrow:before {
    background: var(--sd-surface) !important;
}
.shepherd-header {
    padding: 16px 16px 0 !important;
    background: transparent !important;
}
.shepherd-title {
    font-weight: 700 !important;
    font-size: 1rem !important;
    color: var(--sd-text) !important;
}
.shepherd-text {
    padding: 8px 16px 16px !important;
    font-size: 0.9rem !important;
    color: var(--sd-text-secondary) !important;
    line-height: 1.5 !important;
}
.shepherd-cancel-icon {
    color: var(--sd-text-muted) !important;
}
.shepherd-footer {
    padding: 0 16px 16px !important;
}
.shepherd-button-primary {
    background: #00B5A6 !important;
    border-radius: 8px !important;
    font-weight: 600 !important;
    text-transform: none !important;
}
.shepherd-button-secondary {
    background: transparent !important;
    color: var(--sd-text-secondary) !important;
    text-transform: none !important;
}

/* ─── Responsive helpers ──────────────── */
.touch-target { min-width: 48px; min-height: 48px; }

/* ─── Settings (Innstillinger) ────────────
   Mobile-first: hub list → section detail.
   Desktop ≥960px: persistent left rail + content (per admin-settings spec). */
.settings-layout {
    display: block;
    animation: settings-fade-in 0.18s ease-out;
}
@keyframes settings-fade-in {
    from { opacity: 0; transform: translateY(4px); }
    to   { opacity: 1; transform: none; }
}

/* Rail doubles as the mobile hub */
.settings-rail { min-width: 0; }
.settings-content { min-width: 0; }

/* Mobile: show either hub or section, never both */
.settings-layout:not(.has-section) .settings-content { display: none; }
.settings-layout.has-section .settings-rail { display: none; }

.settings-group-label {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--sd-text-muted);
    margin: 20px 4px 8px;
}
.settings-group-label:first-of-type { margin-top: 12px; }

.settings-group-card {
    border: 1px solid var(--sd-border);
    border-radius: 12px;
    background: var(--sd-surface);
    overflow: hidden;
}

.settings-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    min-height: 56px;
    cursor: pointer;
    text-decoration: none;
    color: var(--sd-text);
    transition: background 0.15s;
    border-bottom: 1px solid var(--sd-border);
}
.settings-row:last-child { border-bottom: none; }
.settings-row:hover { background: var(--sd-bg-subtle); }
.settings-row--active {
    background: var(--sd-accent-soft);
    box-shadow: inset 3px 0 0 #00B5A6;
}
.settings-row--active:hover { background: var(--sd-accent-soft); }

.settings-row-icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sd-bg-subtle);
    color: #00B5A6;
}
.settings-row--active .settings-row-icon { background: var(--sd-surface); }

.settings-row-text { flex: 1; min-width: 0; }
.settings-row-title { font-size: 0.9rem; font-weight: 600; line-height: 1.3; }
.settings-row-desc {
    font-size: 0.75rem;
    color: var(--sd-text-secondary);
    line-height: 1.35;
    margin-top: 1px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.settings-row-match {
    font-size: 0.75rem;
    color: #00B5A6;
    font-weight: 500;
    margin-top: 1px;
}
.settings-row-chevron { flex-shrink: 0; color: var(--sd-text-muted); display: flex; }

/* Section detail */
.settings-section-header {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 16px;
}
.settings-section-icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sd-accent-soft);
    color: #00B5A6;
}

/* Setting row inside section cards: label/description left, control right */
.setting-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 10px 0;
}
.setting-row + .setting-row { border-top: 1px solid var(--sd-border); }
.setting-row-text { flex: 1; min-width: 0; }
.setting-row-control { flex-shrink: 0; }

/* Desktop: persistent rail + content */
@media (min-width: 960px) {
    .settings-layout,
    .settings-layout.has-section {
        display: grid;
        grid-template-columns: 296px minmax(0, 1fr);
        gap: 24px;
        align-items: start;
    }
    .settings-layout:not(.has-section) .settings-content,
    .settings-layout.has-section .settings-rail { display: block; }

    .settings-rail {
        position: sticky;
        top: 80px;
        max-height: calc(100vh - 96px);
        overflow-y: auto;
        padding-right: 4px;
    }
    /* Compact rail on desktop: hide row descriptions and chevrons */
    .settings-rail .settings-row-desc { display: none; }
    .settings-rail .settings-row-chevron { display: none; }
    .settings-rail .settings-row { min-height: 44px; padding: 10px 12px; }
    .settings-rail .settings-row-icon { width: 32px; height: 32px; }
    /* Search results keep their match captions visible */
    .settings-rail .settings-row-match { display: block; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   OWNER CONSOLE  (admin.solodoc.no)
   ───────────────────────────────────────────────────────────────────────────
   A dedicated visual layer for the Solodoc staff operations console. Scoped
   entirely under `sd-admin-*` classes so it never leaks into the tenant app.

   Direction: "instrument panel" — refined, quiet confidence. A grounded navy
   sidebar rail anchors the console in both themes; amber is the single sharp
   accent reserved for the owner / super-admin identity; the brand teal drives
   active + interactive states. Editorial serif (Newsreader) for the wordmark
   and page titles gives the console its own gravitas, distinct from the app.
   Phase 2 pages style themselves against the tokens documented in
   docs/admin-design-brief.md.
   ══════════════════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Newsreader:opsz,wght@6..72,400;6..72,500;6..72,600&display=swap');

:root {
    /* Console identity — theme-independent brand anchors */
    --sd-admin-navy: #16233E;
    --sd-admin-navy-2: #1E3050;
    --sd-admin-amber: #F59E0B;
    --sd-admin-amber-soft: rgba(245, 158, 11, 0.12);
    --sd-admin-teal: #00B5A6;
    --sd-admin-teal-soft: rgba(0, 181, 166, 0.10);

    /* Rail (navy in both themes) — its own local token set */
    --sd-admin-rail-bg: #16233E;
    --sd-admin-rail-grad: radial-gradient(120% 80% at 0% 0%, #20355A 0%, #16233E 52%, #111C32 100%);
    --sd-admin-rail-text: #C5CEDD;
    --sd-admin-rail-text-strong: #FFFFFF;
    --sd-admin-rail-muted: #75839B;
    --sd-admin-rail-hover: rgba(255, 255, 255, 0.06);
    --sd-admin-rail-active: rgba(0, 181, 166, 0.14);
    --sd-admin-rail-border: rgba(255, 255, 255, 0.07);

    /* Canvas + cards — follow the active theme */
    --sd-admin-canvas: #F4F6F9;
    --sd-admin-card: #FFFFFF;
    --sd-admin-card-border: #E4E8EE;
    --sd-admin-card-shadow: 0 1px 2px rgba(16, 28, 50, 0.04), 0 8px 24px -16px rgba(16, 28, 50, 0.18);
    --sd-admin-card-shadow-hover: 0 2px 4px rgba(16, 28, 50, 0.06), 0 16px 36px -18px rgba(16, 28, 50, 0.28);
}
html[data-theme="dark"] {
    --sd-admin-rail-bg: #10192C;
    --sd-admin-rail-grad: radial-gradient(120% 80% at 0% 0%, #182842 0%, #111C32 55%, #0C1525 100%);
    --sd-admin-canvas: #14161A;
    --sd-admin-card: #1E2024;
    --sd-admin-card-border: #2E323A;
    --sd-admin-card-shadow: 0 1px 2px rgba(0, 0, 0, 0.4), 0 10px 28px -18px rgba(0, 0, 0, 0.7);
    --sd-admin-card-shadow-hover: 0 2px 6px rgba(0, 0, 0, 0.5), 0 18px 40px -18px rgba(0, 0, 0, 0.8);
}

/* ─── Console shell ─────────────────────── */
.sd-admin-shell .main-content { background: var(--sd-admin-canvas); }

/* ─── Sidebar rail ──────────────────────── */
.sd-admin-rail {
    background: var(--sd-admin-rail-bg) !important;
    background-image: var(--sd-admin-rail-grad) !important;
    border-right: none !important;
    color: var(--sd-admin-rail-text);
    display: flex;
    flex-direction: column;
}

/* Brand lockup */
.sd-admin-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 22px 20px 18px;
    min-width: 0;
}
.sd-admin-brand__mark {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    flex-shrink: 0;
    box-shadow: 0 0 0 1px var(--sd-admin-rail-border), 0 6px 16px -6px rgba(0, 0, 0, 0.5);
}
.sd-admin-brand__name {
    font-family: 'Newsreader', 'Inter', serif;
    font-weight: 500;
    font-size: 1.32rem;
    line-height: 1.05;
    letter-spacing: -0.01em;
    color: var(--sd-admin-rail-text-strong);
}
.sd-admin-brand__tag {
    margin-top: 3px;
    font-size: 0.6rem;
    font-weight: 700;
    letter-spacing: 0.22em;
    color: var(--sd-admin-amber);
    display: flex;
    align-items: center;
    gap: 6px;
}
.sd-admin-brand__tag::before {
    content: "";
    width: 14px;
    height: 1px;
    background: linear-gradient(90deg, var(--sd-admin-amber), transparent);
}

.sd-admin-rail-divider {
    height: 1px;
    margin: 2px 20px 10px;
    background: var(--sd-admin-rail-border);
}

/* Nav menu */
.sd-admin-nav { padding: 0 12px; }
.sd-admin-nav .nav-group-label {
    color: var(--sd-admin-rail-muted);
    font-size: 0.62rem;
    letter-spacing: 0.16em;
    padding: 0 12px;
    margin: 14px 0 6px;
}
.sd-admin-nav .nav-group-label:first-child { margin-top: 4px; }

.sd-admin-nav .mud-nav-link {
    color: var(--sd-admin-rail-text) !important;
    border-radius: 9px;
    margin: 2px 0;
    padding: 9px 12px !important;
    min-height: 42px;
    font-size: 0.875rem;
    font-weight: 500;
    transition: background 0.14s ease, color 0.14s ease;
    position: relative;
}
.sd-admin-nav .mud-nav-link .mud-icon-root {
    color: var(--sd-admin-rail-muted) !important;
    font-size: 1.25rem;
    transition: color 0.14s ease;
}
.sd-admin-nav .mud-nav-link:hover {
    background: var(--sd-admin-rail-hover) !important;
    color: var(--sd-admin-rail-text-strong) !important;
}
.sd-admin-nav .mud-nav-link:hover .mud-icon-root {
    color: var(--sd-admin-rail-text) !important;
}
.sd-admin-nav .mud-nav-link.active {
    background: var(--sd-admin-rail-active) !important;
    color: var(--sd-admin-rail-text-strong) !important;
    font-weight: 600;
}
.sd-admin-nav .mud-nav-link.active .mud-icon-root {
    color: var(--sd-admin-teal) !important;
}
/* Active marker — a quiet teal tick on the left edge */
.sd-admin-nav .mud-nav-link.active::before {
    content: "";
    position: absolute;
    left: 2px;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 18px;
    border-radius: 0 3px 3px 0;
    background: var(--sd-admin-teal);
}

/* Unhandled-count badge on nav links (Henvendelser / Tilbakemeldinger).
   Amber = a genuine "needs attention" signal per the design brief. */
.sd-admin-nav .mud-nav-link .mud-nav-link-text {
    width: 100%;
}
.sd-admin-navlink-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    width: 100%;
}
.sd-admin-nav-count {
    flex: 0 0 auto;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    line-height: 1;
    color: var(--sd-admin-amber);
    background: var(--sd-admin-amber-soft);
    border: 1px solid var(--sd-admin-amber);
}

/* Rail footer (user + logout) */
.sd-admin-rail-footer {
    padding: 14px 16px 18px;
    border-top: 1px solid var(--sd-admin-rail-border);
    margin-top: 4px;
}
.sd-admin-rail-footer__user {
    display: flex;
    align-items: center;
    gap: 9px;
    margin-bottom: 12px;
    min-width: 0;
}
.sd-admin-rail-footer__avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--sd-admin-rail-text-strong);
    background: linear-gradient(135deg, var(--sd-admin-navy-2), #2C4673);
    box-shadow: inset 0 0 0 1px var(--sd-admin-rail-border);
}
.sd-admin-rail-footer__email {
    font-size: 0.74rem;
    color: var(--sd-admin-rail-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
}
.sd-admin-rail-footer .mud-button-root {
    color: var(--sd-admin-rail-text) !important;
    border-color: var(--sd-admin-rail-border) !important;
    text-transform: none;
    border-radius: 9px;
}
.sd-admin-rail-footer .mud-button-root:hover {
    background: var(--sd-admin-rail-hover) !important;
    border-color: rgba(255, 255, 255, 0.16) !important;
}

/* ─── Top app bar ───────────────────────── */
.sd-admin-appbar {
    background: var(--sd-admin-card) !important;
    color: var(--sd-text) !important;
    border-bottom: 1px solid var(--sd-admin-card-border) !important;
    backdrop-filter: saturate(1.1);
}
.sd-admin-appbar__title {
    font-family: 'Newsreader', 'Inter', serif;
    font-weight: 500;
    font-size: 1.18rem;
    letter-spacing: -0.01em;
}

/* ─── Context ribbon (under the app bar) ─── */
.sd-admin-ribbon {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    padding: 9px 20px;
    background: var(--sd-admin-navy);
    background-image: linear-gradient(90deg, var(--sd-admin-navy) 0%, var(--sd-admin-navy-2) 100%);
    border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}
.sd-admin-ribbon__badge {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    color: var(--sd-admin-amber);
    padding: 3px 10px;
    border-radius: 999px;
    background: var(--sd-admin-amber-soft);
    box-shadow: inset 0 0 0 1px rgba(245, 158, 11, 0.28);
}
.sd-admin-ribbon__note {
    color: #9FAEC4;
    font-size: 0.76rem;
}
.sd-admin-ribbon__link {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #DCE4F0;
    font-size: 0.74rem;
    font-weight: 500;
    text-decoration: none;
    padding: 4px 10px;
    border-radius: 7px;
    transition: background 0.14s ease, color 0.14s ease;
}
.sd-admin-ribbon__link:hover {
    background: rgba(255, 255, 255, 0.08);
    color: #FFFFFF;
}

/* ─── Page header (dashboard + Phase 2 pages) ─── */
.sd-admin-page-head { margin-bottom: 28px; }
.sd-admin-page-eyebrow {
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    color: var(--sd-admin-teal);
    text-transform: uppercase;
    margin-bottom: 6px;
}
.sd-admin-title {
    font-family: 'Newsreader', 'Inter', serif;
    font-weight: 500;
    font-size: 2rem;
    line-height: 1.1;
    letter-spacing: -0.018em;
    color: var(--sd-text);
    margin: 0;
}
.sd-admin-subtitle {
    margin-top: 7px;
    font-size: 0.92rem;
    color: var(--sd-text-secondary);
    max-width: 60ch;
}
.sd-admin-section-title {
    font-family: 'Newsreader', 'Inter', serif;
    font-weight: 500;
    font-size: 1.3rem;
    letter-spacing: -0.01em;
    color: var(--sd-text);
    display: flex;
    align-items: baseline;
    gap: 10px;
}
.sd-admin-section-title::after {
    content: "";
    flex: 1;
    height: 1px;
    background: var(--sd-admin-card-border);
}

/* ─── Cards ─────────────────────────────── */
.sd-admin-card {
    background: var(--sd-admin-card);
    border: 1px solid var(--sd-admin-card-border);
    border-radius: 14px;
    box-shadow: var(--sd-admin-card-shadow);
    transition: box-shadow 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}
.sd-admin-card--link { cursor: pointer; }
.sd-admin-card--link:hover {
    box-shadow: var(--sd-admin-card-shadow-hover);
    border-color: var(--sd-admin-teal);
    transform: translateY(-2px);
}

/* KPI / metric card */
.sd-admin-kpi {
    padding: 18px 18px 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    height: 100%;
    position: relative;
    overflow: hidden;
}
.sd-admin-kpi__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}
.sd-admin-kpi__label {
    font-size: 0.74rem;
    font-weight: 600;
    letter-spacing: 0.01em;
    color: var(--sd-text-secondary);
}
.sd-admin-kpi__icon {
    width: 32px;
    height: 32px;
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sd-admin-teal-soft);
    color: var(--sd-admin-teal);
    flex-shrink: 0;
}
.sd-admin-kpi__icon .mud-icon-root { font-size: 1.1rem; }
.sd-admin-kpi__value {
    font-family: 'Newsreader', 'Inter', serif;
    font-weight: 500;
    font-size: 2.1rem;
    line-height: 1;
    letter-spacing: -0.02em;
    color: var(--sd-text);
    font-variant-numeric: tabular-nums;
}
.sd-admin-kpi__meta {
    font-size: 0.74rem;
    color: var(--sd-text-muted);
}
/* Attention variant — amber accent for unhandled / alert counts */
.sd-admin-kpi--alert .sd-admin-kpi__icon {
    background: var(--sd-admin-amber-soft);
    color: var(--sd-admin-amber);
}
.sd-admin-kpi--alert .sd-admin-kpi__value { color: var(--sd-warning-text); }

/* Shortcut card */
.sd-admin-shortcut {
    padding: 18px;
    height: 100%;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.sd-admin-shortcut__top {
    display: flex;
    align-items: center;
    gap: 11px;
}
.sd-admin-shortcut__icon {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sd-admin-navy);
    color: #FFFFFF;
    flex-shrink: 0;
}
html[data-theme="dark"] .sd-admin-shortcut__icon { background: var(--sd-admin-navy-2); }
.sd-admin-shortcut__icon .mud-icon-root { font-size: 1.2rem; }
.sd-admin-shortcut__title {
    font-size: 0.98rem;
    font-weight: 600;
    color: var(--sd-text);
}
.sd-admin-shortcut__desc {
    font-size: 0.84rem;
    line-height: 1.5;
    color: var(--sd-text-secondary);
    flex: 1;
}
.sd-admin-shortcut__cue {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 0.76rem;
    font-weight: 600;
    color: var(--sd-admin-teal);
    opacity: 0;
    transform: translateX(-4px);
    transition: opacity 0.18s ease, transform 0.18s ease;
}
.sd-admin-card--link:hover .sd-admin-shortcut__cue {
    opacity: 1;
    transform: translateX(0);
}

/* ─── Entrance choreography ─────────────── */
@keyframes sdAdminRise {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}
.sd-admin-rise {
    opacity: 0;
    animation: sdAdminRise 0.5s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
@media (prefers-reduced-motion: reduce) {
    .sd-admin-rise { animation: none; opacity: 1; }
    .sd-admin-card--link:hover { transform: none; }
}

/* ─── Analyse page (/admin/analyse) ─────────── */
.sd-admin-card.pa-0 { padding: 0; }

/* Dependency-free trend bars (CSS only — no charting library) */
.sd-an-trend__title {
    font-size: 0.74rem;
    font-weight: 600;
    color: var(--sd-text-secondary);
    margin-bottom: 14px;
}
.sd-an-bars {
    display: flex;
    align-items: flex-end;
    gap: 6px;
    height: 140px;
}
.sd-an-bars__col {
    flex: 1 1 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    min-width: 0;
}
.sd-an-bars__track {
    width: 100%;
    height: 110px;
    display: flex;
    align-items: flex-end;
    border-radius: 6px 6px 0 0;
    background: var(--sd-admin-teal-soft);
}
.sd-an-bars__fill {
    width: 100%;
    min-height: 2px;
    border-radius: 6px 6px 0 0;
    background: var(--sd-admin-teal);
    transition: height 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.sd-an-bars__fill--alt { background: var(--sd-admin-navy); }
html[data-theme="dark"] .sd-an-bars__fill--alt { background: var(--sd-admin-navy-2); }
.sd-an-bars__label {
    font-size: 0.62rem;
    color: var(--sd-text-muted);
    text-transform: capitalize;
}
.sd-an-trend__foot {
    margin-top: 14px;
    font-size: 0.8rem;
    color: var(--sd-text-secondary);
}
.sd-an-trend__foot strong {
    font-family: 'Newsreader', 'Inter', serif;
    font-weight: 500;
    letter-spacing: -0.01em;
    color: var(--sd-text);
}
.sd-an-trend__empty {
    font-size: 0.84rem;
    color: var(--sd-text-muted);
    padding: 28px 0;
}

/* Dormant-tenant amber alert strip (used sparingly, per the brief) */
.sd-an-alert {
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 11px 14px;
    margin-bottom: 14px;
    border-radius: 10px;
    background: var(--sd-admin-amber-soft);
    color: var(--sd-warning-text);
    font-size: 0.84rem;
    font-weight: 500;
}
.sd-an-alert .mud-icon-root { color: var(--sd-admin-amber); }

/* Usage table */
.sd-an-table { background: transparent; }
.sd-an-table .mud-table-root { background: transparent; }
.sd-an-sub { color: var(--sd-text-muted); font-size: 0.78rem; }
.sd-an-cell-name { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.sd-an-cell-name__text { font-weight: 600; color: var(--sd-text); }
.sd-an-dormant-date { color: var(--sd-warning-text); }

.sd-an-tag {
    display: inline-flex;
    align-items: center;
    padding: 1px 8px;
    border-radius: 999px;
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}
.sd-an-tag--dormant,
.sd-an-tag--frozen {
    background: var(--sd-admin-amber-soft);
    color: var(--sd-warning-text);
}
.sd-an-tag--power {
    background: var(--sd-admin-teal-soft);
    color: var(--sd-admin-teal);
}

.sd-an-note {
    font-size: 0.74rem;
    color: var(--sd-text-muted);
}
