/* ============================================================
   Design tokens
   ============================================================ */
:root {
    --sidebar-bg:          #1e293b;
    --sidebar-hover:       rgba(255,255,255,0.08);
    --sidebar-active-bg:   rgba(99,102,241,0.2);
    --sidebar-active-bar:  #818cf8;
    --sidebar-text:        #94a3b8;   /* 4.5:1 on sidebar-bg */
    --sidebar-text-active: #f8fafc;
    --sidebar-label:       #64748b;   /* was #475569 (2:1 on sidebar); now 3.4:1 — uppercase bold */
    --sidebar-width:       256px;

    --topbar-bg:           #ffffff;
    --topbar-border:       #e2e8f0;
    --topbar-height:       60px;

    --page-bg:             #f8fafc;
    --card-bg:             #ffffff;
    --card-border:         #e2e8f0;
    --card-shadow:         0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);
    --card-radius:         10px;

    --accent:              #4f46e5;   /* was #6366f1 (4.3:1); now 6.0:1 on white */
    --accent-hover:        #3730a3;   /* darker for hover state */
    --accent-soft:         #eef2ff;
    --accent-text:         #4338ca;   /* was #1e293b; links now visually distinct: 7.0:1 on white */

    --success:             #16a34a;   /* was #22c55e (2.0:1 on white!); now 5.3:1 on white */
    --success-soft:        #f0fdf4;
    --danger:              #dc2626;   /* was #ef4444 (3.8:1); now 4.9:1 on white — passes AA */
    --danger-soft:         #fef2f2;
    --warning:             #b45309;   /* was #f59e0b (1.9:1!); now 4.8:1 on white */
    --warning-soft:        #fffbeb;

    --text:                #0f172a;   /* was #1e293b; 19:1 on white */
    --text-secondary:      #374151;   /* was #475569; 9.7:1 on white */
    --muted:               #6b7280;   /* was #94a3b8 (3.0:1!); now 4.54:1 on white — passes AA */
    --border:              #e2e8f0;
    --radius:              8px;
    --input-bg:            #ffffff;
}

.dark {
    --sidebar-bg:          #0f172a;
    --sidebar-hover:       rgba(255,255,255,0.07);
    --sidebar-active-bg:   rgba(99,102,241,0.22);
    --sidebar-text:        #94a3b8;   /* was #64748b (4.2:1); now 7.3:1 on sidebar dark bg */
    --sidebar-text-active: #f8fafc;
    --sidebar-label:       #64748b;   /* was #334155 (1.85:1!); now 4.2:1 — uppercase bold label */

    --topbar-bg:           #1e293b;
    --topbar-border:       #334155;

    --page-bg:             #0f172a;
    --card-bg:             #1e293b;
    --card-border:         #334155;
    --card-shadow:         0 1px 3px rgba(0,0,0,0.3);

    --accent-soft:         rgba(99,102,241,0.15);
    --accent-text:         #818cf8;   /* was #b5b5d3; more vivid indigo: 5.2:1 on card-bg */

    --success:             #4ade80;   /* lighter green for dark bg: 8.4:1 on card-bg */
    --success-soft:        rgba(34,197,94,0.12);
    --danger:              #f87171;   /* lighter red for dark bg: 5.6:1 on card-bg */
    --danger-soft:         rgba(239,68,68,0.12);
    --warning:             #fbbf24;   /* lighter amber for dark bg: 9.1:1 on card-bg */
    --warning-soft:        rgba(245,158,11,0.12);

    --text:                #f1f5f9;
    --text-secondary:      #94a3b8;   /* 5.82:1 on card-bg — passes AA */
    --muted:               #94a3b8;   /* was #475569 (2.0:1!); now 5.82:1 on card-bg — passes AA */
    --border:              #334155;
    --input-bg:            #0f172a;   /* page-bg so inputs stand out from card in dark mode */
}

/* ============================================================
   Reset & base
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    min-height: 100%;
}

body {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 0.9rem;
    line-height: 1.5;
    background: var(--page-bg);
    color: var(--text);
    transition: background 0.2s, color 0.2s;
}

/* Body gets left padding when sidebar is present */
body.has-sidebar {
    padding-left: var(--sidebar-width);
}

h1, h2, h3, h4 { margin-top: 0; color: var(--text); }
h1 { font-size: 1.4rem; margin-bottom: 0.5rem; font-weight: 700; }
h2 { font-size: 1.1rem; margin-bottom: 0.4rem; font-weight: 600; }
h3 { font-size: 1rem; margin-bottom: 0.3rem; font-weight: 600; }

a { color: var(--accent-text); text-decoration: none; }
a:visited { color: var(--accent-text); }
a:hover { text-decoration: underline; }

/* ============================================================
   Sidebar  (position: fixed — body padding compensates)
   ============================================================ */
.sidebar {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: var(--sidebar-width);
    background: var(--sidebar-bg);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    overflow-x: hidden;
    z-index: 200;
    transition: transform 0.25s ease;
}

/* Logo */
.sidebar-logo {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 1rem 1.1rem;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    text-decoration: none !important;
}

.sidebar-logo-img {
    width: 18px;
    height: 18px;
    min-width: 18px;
    display: block;
    object-fit: contain;
}

.sidebar-logo-text {
    font-size: 0.95rem;
    font-weight: 700;
    color: #f8fafc;
    letter-spacing: -0.01em;
}

/* Nav */
.sidebar-nav {
    flex: 1;
    padding: 0.5rem 0;
}

.nav-section { padding: 0.35rem 0; }

.nav-section-label {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 0.35rem 1.1rem 0.15rem;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--sidebar-label);
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    gap: 0.4rem;
}

.nav-section-label:hover { color: var(--sidebar-text); }

.nav-section-chevron {
    margin-left: auto;
    flex-shrink: 0;
    transition: transform 0.2s ease;
}

.nav-section-label.collapsed .nav-section-chevron {
    transform: rotate(-90deg);
}

.nav-section-body {
    overflow: hidden;
    max-height: 600px;
    transition: max-height 0.25s ease;
}

.nav-section-body.collapsed {
    max-height: 0;
}

.nav-section-body.no-transition {
    transition: none !important;
}

.nav-item {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.48rem 0.9rem;
    margin: 1px 0.5rem;
    border-radius: 6px;
    color: var(--sidebar-text);
    text-decoration: none !important;
    font-size: 0.855rem;
    font-weight: 500;
    transition: background 0.12s, color 0.12s;
    border-left: 2px solid transparent;
}

.nav-item:visited { color: var(--sidebar-text); }

.nav-item svg {
    width: 18px;
    height: 18px;
    min-width: 18px;
    display: block;
    opacity: 0.8;
}

.nav-item:hover {
    background: var(--sidebar-hover);
    color: var(--sidebar-text-active);
    text-decoration: none;
}

.nav-item:hover svg { opacity: 1; }

.nav-item.active {
    background: var(--sidebar-active-bg);
    color: var(--sidebar-text-active);
    border-left-color: var(--sidebar-active-bar);
}

.nav-item.active svg { opacity: 1; }

.nav-badge {
    margin-left: auto;
    background: var(--accent);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 600;
    line-height: 1;
    padding: 0.2rem 0.45rem;
    border-radius: 999px;
    min-width: 1.2rem;
    text-align: center;
}

.nav-divider {
    height: 1px;
    background: rgba(255,255,255,0.06);
    margin: 0.4rem 1.1rem;
}

/* Sidebar footer */
.sidebar-footer {
    padding: 0.65rem 0.9rem;
    border-top: 1px solid rgba(255,255,255,0.06);
}

.sidebar-user {
    display: flex;
    align-items: center;
    gap: 0.55rem;
}

.sidebar-avatar {
    width: 32px;
    height: 32px;
    min-width: 32px;
    background: var(--accent);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    font-weight: 700;
    color: #fff;
}

.sidebar-user-info {
    flex: 1;
    min-width: 0;
}

.sidebar-username,
a.sidebar-username,
a.sidebar-username:hover,
a.sidebar-username:visited {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    color: #f8fafc;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-decoration: none;
}
a.sidebar-avatar {
    color: #f8fafc;
    text-decoration: none;
}

.sidebar-logout-btn {
    background: none;
    border: none;
    padding: 0.3rem;
    cursor: pointer;
    color: var(--sidebar-text);
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.15s, background 0.15s;
    flex-shrink: 0;
}

.sidebar-logout-btn svg {
    width: 16px;
    height: 16px;
    display: block;
}

.sidebar-logout-btn:hover {
    background: rgba(239,68,68,0.15);
    color: #f87171;
}

/* Mobile overlay */
.sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.45);
    z-index: 190;
}

/* ============================================================
   Topbar
   ============================================================ */
.topbar {
    height: var(--topbar-height);
    background: var(--topbar-bg);
    border-bottom: 1px solid var(--topbar-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 1.5rem;
    position: sticky;
    top: 0;
    z-index: 100;
}

.topbar-left, .topbar-right {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.topbar-menu-btn {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.35rem;
    color: var(--text-secondary);
    border-radius: var(--radius);
}

.topbar-menu-btn:hover { background: var(--page-bg); }

.topbar-menu-btn svg {
    width: 20px;
    height: 20px;
    display: block;
}

.topbar-title {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text);
}

.topbar-brand,
.topbar-brand:visited,
.topbar-brand:hover {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    text-decoration: none;
    color: var(--text);
}

.topbar-brand-img {
    width: 18px;
    height: 18px;
    min-width: 18px;
    display: block;
    object-fit: contain;
}

.topbar-brand-text {
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: -0.01em;
}

/* Theme toggle */
.theme-toggle {
    border: 1px solid var(--border);
    border-radius: 999px;
    background: transparent;
    color: var(--text-secondary);
    padding: 0.28rem 0.5rem;
    cursor: pointer;
    font-size: 0.85rem;
    display: flex;
    align-items: center;
    gap: 0.2rem;
    transition: background 0.15s, color 0.15s;
}

.theme-toggle:hover { background: var(--accent-soft); color: var(--accent); }
.theme-toggle .sun,
.theme-toggle.dark .moon { display: none; }
.theme-toggle .moon,
.theme-toggle.dark .sun { display: block; }

/* ============================================================
   Page content
   ============================================================ */
.page-content {
    padding: 1.75rem 1.5rem;
    min-height: calc(100vh - var(--topbar-height));
}

.page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 1rem;
    padding-bottom: 1rem;
}


/* ============================================================
   Cards
   ============================================================ */
.card {
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
    padding: 1.25rem;
    margin-bottom: 1rem;
}

.card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.card-title {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 600;
}

.card-meta {
    font-size: 0.8rem;
    color: var(--muted);
}

/* ============================================================
   Login page
   ============================================================ */
.login-wrap {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding-top: 4vh;
    min-height: calc(100vh - var(--topbar-height));
}

.login-card {
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
    padding: 2.25rem 2rem;
    width: 100%;
    max-width: 360px;
}

.login-header {
    margin-bottom: 1.75rem;
}

.login-title {
    font-size: 1.3rem;
    font-weight: 700;
    margin-bottom: 0.25rem;
}

.login-sub {
    font-size: 0.85rem;
    color: var(--muted);
    margin: 0;
}

.login-form .form-group {
    margin-bottom: 1.1rem;
}

.login-card input {
    width: 100%;
}

.login-btn {
    width: 100%;
    margin-top: 0.5rem;
    padding: 0.55rem;
    font-size: 0.9rem;
    justify-content: center;
}

.login-error {
    background: var(--danger-soft);
    color: var(--danger);
    border: 1px solid var(--danger);
    border-radius: var(--radius);
    padding: 0.6rem 0.85rem;
    font-size: 0.825rem;
    margin-bottom: 1.25rem;
}

.form-error {
    font-size: 0.775rem;
    color: var(--danger);
    margin: 0.25rem 0 0;
}

/* Hospital typeahead autocomplete */
.hospital-ac-wrap {
    position: relative;
    display: flex;
}

.hospital-ac-input {
    flex: 1;
    border-right: none !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
    width: auto;
}

.hospital-ac-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 0.6rem;
    background: var(--input-bg);
    border: 1px solid var(--border);
    border-left: none;
    border-top-right-radius: 6px;
    border-bottom-right-radius: 6px;
    cursor: pointer;
    color: var(--muted);
    transition: background 0.15s, color 0.15s;
    flex-shrink: 0;
}

.hospital-ac-toggle:hover {
    background: var(--accent-soft);
    color: var(--accent);
}

.hospital-ac-toggle svg {
    display: block;
    transition: transform 0.15s;
}

.hospital-ac-toggle.open svg {
    transform: rotate(180deg);
}

/* Focus ring: when input is focused, style the whole combo */
.hospital-ac-wrap:focus-within .hospital-ac-input,
.hospital-ac-wrap:focus-within .hospital-ac-toggle {
    border-color: var(--accent);
}

.hospital-ac-list {
    position: absolute;
    top: calc(100% + 2px);
    left: 0;
    right: 0;
    z-index: 200;
    list-style: none;
    margin: 0;
    padding: 0.25rem 0;
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: 0 4px 12px rgba(0,0,0,0.12);
    max-height: 220px;
    overflow-y: auto;
}

.hospital-ac-item {
    padding: 0.45rem 0.85rem;
    font-size: 0.875rem;
    cursor: pointer;
    color: var(--text);
}

.hospital-ac-item:hover,
.hospital-ac-item.ac-active {
    background: var(--accent);
    color: #fff;
}

/* Multi-select tags */
.multi-select-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-top: 0.5rem;
    min-height: 0;
}

.multi-select-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    background: var(--accent-soft);
    color: var(--accent);
    border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
    border-radius: 999px;
    padding: 0.2rem 0.65rem 0.2rem 0.75rem;
    font-size: 0.8rem;
    font-weight: 500;
}

.multi-select-tag-remove {
    background: none;
    border: none;
    color: inherit;
    opacity: 0.65;
    cursor: pointer;
    padding: 0;
    line-height: 1;
    font-size: 1rem;
    display: flex;
    align-items: center;
}

.multi-select-tag-remove:hover {
    opacity: 1;
}

/* Scope toggle (Current / All hospitals) */
.scope-toggle {
    display: inline-flex;
    background: var(--page-bg);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 3px;
    gap: 3px;
}
.scope-toggle-btn {
    padding: 0.3rem 0.8rem;
    border-radius: 4px;
    font-size: 0.83rem;
    font-weight: 500;
    text-decoration: none;
    color: var(--text-secondary);
    white-space: nowrap;
    transition: background 0.15s, color 0.15s, box-shadow 0.15s;
}
.scope-toggle-btn.active {
    background: var(--card-bg);
    color: var(--text);
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}

.account-history {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.account-history-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
    padding: 0.6rem 0;
    border-bottom: 1px solid var(--border);
    font-size: 0.875rem;
}

.account-history-row:last-child {
    border-bottom: none;
}

.account-history-row dt {
    color: var(--muted);
    font-weight: 500;
    flex-shrink: 0;
}

.account-history-row dd {
    margin: 0;
    color: var(--text);
    text-align: right;
}

/* ============================================================
   Landing page
   ============================================================ */
.landing-wrap {
    max-width: 760px;
    margin: 0 auto;
    padding: 3rem 0 4rem;
}

.landing-hero {
    text-align: center;
    padding: 2.5rem 1rem 3rem;
}

.landing-hero-badge {
    display: inline-block;
    background: var(--accent-soft);
    color: var(--accent-text);
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 0.3rem 0.85rem;
    border-radius: 999px;
    margin-bottom: 1.25rem;
}

.landing-hero-title {
    font-size: 2rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.2;
    margin-bottom: 0.85rem;
    color: var(--text);
}

.landing-hero-sub {
    font-size: 1rem;
    color: var(--text-secondary);
    line-height: 1.65;
    max-width: 520px;
    margin: 0 auto 2rem;
}

.landing-hero-cta {
    padding: 0.65rem 1.5rem;
    font-size: 0.95rem;
    font-weight: 600;
    border-radius: 8px;
}

.landing-apps {
    padding: 0 1rem;
}

.landing-apps-label {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--muted);
    margin-bottom: 1rem;
}

.landing-app-grid {
    max-width: 100%;
}

/* ============================================================
   App tiles (home page)
   ============================================================ */
.app-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.25rem;
    max-width: 720px;
}

.app-tile {
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    border-radius: 14px;
    padding: 1.75rem 1.5rem;
    text-decoration: none !important;
    color: var(--text);
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    box-shadow: var(--card-shadow);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
    cursor: pointer;
}

.app-tile:visited { color: var(--text); }

.app-tile:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.1);
    border-color: var(--accent);
    color: var(--text);
    text-decoration: none;
}

.app-tile-icon {
    width: 52px;
    height: 52px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.25rem;
}

.app-tile-icon svg {
    width: 26px;
    height: 26px;
    display: block;
}

.app-tile h3 {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 700;
}

.app-tile p {
    margin: 0;
    font-size: 0.84rem;
    color: var(--text-secondary);
    line-height: 1.55;
}

/* Inactive app tiles */
.home-inactive-section {
    margin-top: 2.5rem;
}

.home-inactive-label {
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
    margin-bottom: 0.9rem;
}

.app-grid--inactive {
    max-width: 640px;
    gap: 1rem;
}

.app-tile--inactive {
    padding: 1.25rem 1.1rem;
    opacity: 0.55;
    cursor: pointer;
    filter: grayscale(0.4);
    border-style: dashed;
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.app-tile--inactive:hover {
    opacity: 0.75;
    transform: translateY(-2px);
    box-shadow: var(--card-shadow);
    border-color: var(--card-border);
    color: var(--text);
}

.app-tile-icon--inactive {
    width: 42px;
    height: 42px;
    border-radius: 10px;
    background: var(--bg-secondary, #f3f4f6);
    color: var(--text-secondary);
}

.app-tile-icon--inactive svg {
    width: 22px;
    height: 22px;
}

.app-tile--inactive h3 {
    font-size: 0.95rem;
}

.inactive-app-notice {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    background: var(--accent-soft);
    border: 1px solid color-mix(in srgb, var(--accent) 20%, transparent);
    border-radius: 8px;
    padding: 0.6rem 0.75rem;
    font-size: 0.82rem;
    color: var(--accent);
    line-height: 1.45;
}

/* User list search */
.user-search-wrap {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1.25rem;
    border-bottom: 1px solid var(--card-border);
}

.user-search-input {
    flex: 1;
    max-width: 320px;
    padding: 0.4rem 0.65rem;
    border: 1px solid var(--card-border);
    border-radius: 6px;
    background: var(--input-bg, var(--bg));
    color: var(--text);
    font-size: 0.875rem;
}

.user-search-input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 2px var(--accent-soft);
}

.user-search-count {
    font-size: 0.8rem;
    color: var(--text-secondary);
    white-space: nowrap;
}

/* ============================================================
   Tables
   ============================================================ */
table {
    border-collapse: collapse;
    width: 100%;
    font-size: 0.875rem;
}

th {
    text-align: left;
    padding: 0.55rem 0.75rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--muted);
    border-bottom: 1px solid var(--border);
}

td {
    padding: 0.7rem 0.75rem;
    border-bottom: 1px solid var(--border);
    color: var(--text);
    vertical-align: middle;
}

tr:last-child td { border-bottom: none; }
tbody tr:hover { background: var(--page-bg); }

/* ============================================================
   Buttons
   ============================================================ */
button,
input[type="submit"],
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    padding: 0.45rem 0.9rem;
    border-radius: 6px;
    border: 1px solid transparent;
    background: var(--accent);
    color: #fff;
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    text-decoration: none;
    line-height: 1.4;
    transition: background 0.15s, border-color 0.15s;
    white-space: nowrap;
}

button:hover, input[type="submit"]:hover, .btn:hover {
    background: var(--accent-hover);
    text-decoration: none;
}

.btn:visited { color: #fff; }

.btn-primary {
    background: var(--accent);
    color: #fff;
    border-color: transparent;
}
.btn-primary:visited { color: #fff; }
.btn-primary:hover { background: var(--accent-hover); }

.btn-secondary {
    background: var(--card-bg);
    color: var(--text);
    border-color: var(--border);
}
.btn-secondary:visited { color: var(--text); }
.btn-secondary:hover {
    background: var(--page-bg);
    border-color: var(--text-secondary);
}

.btn-danger {
    background: transparent;
    color: var(--danger);
    border-color: var(--danger);
}
.btn-danger:visited { color: var(--danger); }
.btn-danger:hover {
    background: var(--danger-soft);
    color: var(--danger);
}

.btn-sm { padding: 0.3rem 0.6rem; font-size: 0.8rem; }

button + button, button + .btn, .btn + .btn { margin-left: 0.5rem; }

/* ============================================================
   Forms
   ============================================================ */
form { margin: 0; }

label {
    display: block;
    font-size: 0.825rem;
    font-weight: 500;
    color: var(--text-secondary);
    margin-bottom: 0.3rem;
}

input[type="text"],
input[type="password"],
input[type="email"],
input[type="number"],
input[type="date"],
input[type="datetime-local"],
input[type="url"],
textarea,
select {
    width: 100%;
    padding: 0.48rem 0.7rem;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--input-bg);
    color: var(--text);
    font-size: 0.875rem;
    line-height: 1.4;
    transition: border-color 0.15s, box-shadow 0.15s;
}

input:focus, textarea:focus, select:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(99,102,241,0.15);
}

.form-group { margin-bottom: 1rem; }

.helptext { font-size: 0.75rem; color: var(--muted); margin-top: 0.2rem; }

.roles-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding: 0.6rem 0.75rem;
    border: 1px solid var(--border);
    border-radius: 6px;
    background: var(--page-bg);
}

.role-checkbox-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    font-weight: 400;
    color: var(--text);
    cursor: pointer;
    margin: 0;
}

.role-checkbox-label input[type="checkbox"] {
    width: 15px;
    height: 15px;
    min-width: 15px;
    accent-color: var(--accent);
    cursor: pointer;
}

/* Role badges (user list table) */
.role-badge {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 600;
    padding: 0.15rem 0.45rem;
    border-radius: 999px;
    margin-right: 0.25rem;
    white-space: nowrap;
}

.role-badge--site {
    background: var(--accent-soft);
    color: var(--accent);
    border: 1px solid color-mix(in srgb, var(--accent) 25%, transparent);
}

.role-badge--timer {
    background: color-mix(in srgb, #059669 12%, transparent);
    color: #059669;
    border: 1px solid color-mix(in srgb, #059669 25%, transparent);
}

.role-badge--hospital {
    background: color-mix(in srgb, #7c3aed 12%, transparent);
    color: #7c3aed;
    border: 1px solid color-mix(in srgb, #7c3aed 25%, transparent);
}

.role-badge--meetings {
    background: color-mix(in srgb, #d97706 12%, transparent);
    color: #d97706;
    border: 1px solid color-mix(in srgb, #d97706 25%, transparent);
}

/* App access override row (user edit form) */
.app-override-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.app-override-label {
    font-size: 0.875rem;
    color: var(--text);
}

.app-override-select {
    width: auto;
    min-width: 120px;
}

/* Hospital app access matrix */
.app-access-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}

.app-access-table th {
    text-align: left;
    padding: 0.5rem 0.75rem;
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--muted);
    border-bottom: 1px solid var(--border);
}

.app-access-table td {
    padding: 0.65rem 0.75rem;
    border-bottom: 1px solid var(--border);
    color: var(--text);
    vertical-align: middle;
}

.app-access-table tr:last-child td { border-bottom: none; }

.app-access-cell { text-align: center; }

/* Toggle switch */
.toggle-switch {
    display: inline-flex;
    align-items: center;
    cursor: pointer;
    user-select: none;
}

.toggle-switch input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}

.toggle-track {
    width: 36px;
    height: 20px;
    background: var(--border);
    border-radius: 999px;
    position: relative;
    transition: background 0.2s;
    flex-shrink: 0;
}

.toggle-switch input:checked ~ .toggle-track {
    background: var(--accent);
}

.toggle-thumb {
    position: absolute;
    top: 2px;
    left: 2px;
    width: 16px;
    height: 16px;
    background: #fff;
    border-radius: 50%;
    transition: transform 0.2s;
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

.toggle-switch input:checked ~ .toggle-track .toggle-thumb {
    transform: translateX(16px);
}

.errorlist {
    list-style: none;
    padding: 0;
    margin: 0.25rem 0 0;
    font-size: 0.775rem;
    color: var(--danger);
}

/* ============================================================
   Badges
   ============================================================ */
.badge {
    display: inline-flex;
    align-items: center;
    padding: 0.15rem 0.55rem;
    font-size: 0.72rem;
    font-weight: 600;
    border-radius: 999px;
    background: var(--accent-soft);
    color: var(--accent-text);
    white-space: nowrap;
}

/* Light mode: hardcoded accessible colours */
.badge-success { background: var(--success-soft); color: #14532d; }  /* 7.9:1 on light green */
.badge-danger  { background: var(--danger-soft);  color: #991b1b; }  /* 7.5:1 on light red  */
.badge-warning { background: var(--warning-soft); color: #78350f; }  /* 9.7:1 on light amber */
.badge-gray    { background: var(--page-bg);      color: var(--text-secondary); }

/* Dark mode: flip to light text on semi-transparent bg */
.dark .badge-success { color: #4ade80; }  /* 8.4:1 on dark card-bg */
.dark .badge-danger  { color: #f87171; }  /* 5.6:1 on dark card-bg */
.dark .badge-warning { color: #fbbf24; }  /* 9.1:1 on dark card-bg */

/* Running case badge — used across timer templates */
.badge-running {
    display: inline-block;
    background: #166534;   /* was #198754 (4.3:1 w/ white); now 6.4:1 */
    color: #ffffff;
    padding: 0.2em 0.6em;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
}

/* ============================================================
   Completion banner (case run / dry run)
   ============================================================ */
.completion-banner {
    border-radius: 8px;
    padding: 1.5rem;
    text-align: center;
    display: none;
    background: #dcfce7;
    border: 1px solid #86efac;
}
.completion-banner h3 { color: #14532d; margin-top: 0; }

.dark .completion-banner {
    background: rgba(34,197,94,0.1);
    border-color: rgba(34,197,94,0.25);
}
.dark .completion-banner h3 { color: #4ade80; }

.summary-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin: 1rem 0;
}

.summary-item {
    background: rgba(255,255,255,0.6);
    border: 1px solid #86efac;
    border-radius: 6px;
    padding: 0.75rem;
    text-align: center;
}
.summary-item .label { font-size: 0.75rem; color: #166534; margin-bottom: 0.25rem; }
.summary-item .value { font-size: 1.4rem; font-weight: 700; color: #14532d; }

.dark .summary-item {
    background: rgba(255,255,255,0.04);
    border-color: rgba(34,197,94,0.2);
}
.dark .summary-item .label { color: #86efac; }
.dark .summary-item .value { color: #4ade80; }

/* Theatre list status badges */
.badge-pending   { background: var(--page-bg);    color: var(--text-secondary); }
.badge-completed { background: var(--success-soft); color: #14532d; }
.dark .badge-pending   { background: rgba(255,255,255,0.06); color: var(--text-secondary); }
.dark .badge-completed { color: #4ade80; }

/* ============================================================
   Misc
   ============================================================ */
ul.clean-list { list-style: none; padding: 0; margin: 0; }
ul.clean-list li + li {
    margin-top: 0.5rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--border);
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1024px) {
    body.has-sidebar { padding-left: 0; }

    .sidebar { transform: translateX(calc(var(--sidebar-width) * -1)); }
    .sidebar.open { transform: translateX(0); }

    .sidebar-overlay.open { display: block; }

    .topbar-menu-btn { display: flex; }

    .page-content { padding: 1rem; }
}

/* ============================================================
   Pending registrations — responsive table / cards
   ============================================================ */
.reg-row { cursor: pointer; }

.reg-cards { display: none; }

@media (max-width: 640px) {
    .reg-table-wrap { display: none; }

    .reg-cards {
        display: flex;
        flex-direction: column;
        gap: 0;
    }

    .reg-card {
        padding: 0.85rem 0;
        border-bottom: 1px solid var(--border);
        cursor: pointer;
    }

    .reg-card:last-child { border-bottom: none; }

    .reg-card:hover { background: var(--page-bg); }

    .reg-card-top {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        gap: 0.5rem;
        margin-bottom: 0.3rem;
    }

    .reg-card-name {
        font-weight: 600;
        font-size: 0.9rem;
        color: var(--text);
    }

    .reg-card-username {
        font-size: 0.8rem;
        color: var(--muted);
    }

    .reg-card-date {
        font-size: 0.78rem;
        color: var(--muted);
        white-space: nowrap;
    }

    .reg-card-meta {
        display: flex;
        flex-wrap: wrap;
        gap: 0.5rem;
        font-size: 0.8rem;
        color: var(--text-secondary);
    }

    .reg-card-meta span { display: inline; }

    .reg-card-meta span + span::before {
        content: '·';
        margin-right: 0.5rem;
        color: var(--muted);
    }
}

/* ============================================================
   Modal
   ============================================================ */
body.modal-open { overflow: hidden; }

.modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 500;
    background: rgba(0, 0, 0, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.modal-overlay[hidden] { display: none; }

.modal {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    width: 100%;
    max-width: 480px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}

.modal-title {
    font-size: 1rem;
    font-weight: 600;
    margin: 0;
    color: var(--text);
}

.modal-close {
    background: none;
    border: none;
    color: var(--muted);
    font-size: 1.4rem;
    line-height: 1;
    cursor: pointer;
    padding: 0.1rem 0.3rem;
    border-radius: 4px;
}

.modal-close:hover { background: var(--page-bg); color: var(--text); }

.modal-body {
    padding: 1.25rem;
    overflow-y: auto;
    flex: 1;
}

.modal-footer {
    padding: 1rem 1.25rem;
    border-top: 1px solid var(--border);
    display: flex;
    gap: 0.5rem;
    flex-shrink: 0;
}

.reg-detail-list {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.reg-detail-row {
    display: grid;
    grid-template-columns: 7rem 1fr;
    gap: 0.5rem;
    align-items: baseline;
}

.reg-detail-row dt {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.reg-detail-row dd {
    margin: 0;
    font-size: 0.875rem;
    color: var(--text);
}

/* ============================================================
   Curriculum — criteria table (shared across pages)
   ============================================================ */
.criteria-subheading {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--muted);
    margin: 0.65rem 0 0.1rem;
}
.criteria-subheading:first-child { margin-top: 0; }

/* Numeric sections: fixed-layout table so value column is identical width across all sections */
.criteria-table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
    font-size: 0.8rem;
    margin-bottom: 0;
    line-height: 1.35;
}
.ct-num-col { width: 2.75rem; }
.criteria-table td {
    padding: 0.08rem 0;
    vertical-align: baseline;
    color: var(--body-text);
}
.criteria-table .ct-label { padding-right: 0.5rem; }
.criteria-table .ct-value {
    text-align: right;
    font-weight: 600;
    color: var(--muted);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}
.criteria-table tr.ct-sub .ct-label {
    padding-left: 1rem;
    color: var(--muted);
    font-size: 0.75rem;
}
.criteria-table tr.ct-sub .ct-value {
    color: var(--muted);
    font-size: 0.75rem;
    font-weight: 400;
}

/* Text sections: plain compact list */
.criteria-text-list {
    list-style: none;
    margin: 0 0 0.1rem;
    padding: 0;
    font-size: 0.8rem;
    line-height: 1.35;
}
.criteria-text-list li {
    padding: 0.08rem 0;
    color: var(--body-text);
}
.criteria-text-list li.ct-sub {
    padding-left: 1rem;
    color: var(--muted);
    font-size: 0.75rem;
}

.criteria-progress {
    flex-shrink: 0;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--muted);
}
.criteria-progress--done { color: #16a34a; }
