/* _content/Mathos.App/Components/Layout/AdminLayout.razor.rz.scp.css */
/* ═══════════════════════════════════════════════
   Admin Shell — dark sidebar + header layout
   ═══════════════════════════════════════════════ */

.admin-shell[b-ja7fx1prfn] {
    min-height: 100vh;
    display: flex;
    background: #0b0f19;
    color: #e5e7eb;
}

/* ── Sidebar ── */
.admin-sidebar[b-ja7fx1prfn] {
    width: 260px;
    min-width: 260px;
    background: #070a12;
    border-right: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    flex-direction: column;
    padding: 1.25rem 0.75rem;
    overflow-y: auto;
    height: 100vh;
    position: sticky;
    top: 0;
}

/* Brand */
.admin-brand[b-ja7fx1prfn] {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    font-weight: 800;
    font-size: 1.05rem;
    letter-spacing: 0.3px;
    padding: 0 0.5rem;
    margin-bottom: 1.25rem;
    color: white;
    text-decoration: none;
}

.admin-brand:hover[b-ja7fx1prfn] {
    color: white;
}

.brand-icon[b-ja7fx1prfn] {
    width: 30px;
    height: 30px;
    border-radius: 8px;
    flex-shrink: 0;
}

/* ── Nav ── */
.admin-nav[b-ja7fx1prfn] {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

/* Standalone link (Dashboard) */
.admin-link[b-ja7fx1prfn] {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    color: rgba(255, 255, 255, 0.65);
    text-decoration: none;
    padding: 0.55rem 0.75rem;
    border-radius: 8px;
    font-size: 0.875rem;
    font-weight: 500;
    transition: background 120ms ease, color 120ms ease;
    white-space: nowrap;
}

.admin-link:hover[b-ja7fx1prfn] {
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.95);
}

.admin-link.active[b-ja7fx1prfn] {
    background: rgba(99, 102, 241, 0.2);
    color: white;
}

.admin-link.sub[b-ja7fx1prfn] {
    padding-left: 2.5rem;
    font-size: 0.82rem;
}

/* Nav icon (inline SVGs) */
.nav-icon[b-ja7fx1prfn] {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    opacity: 0.7;
}

.admin-link.active .nav-icon[b-ja7fx1prfn],
.nav-group-toggle:hover .nav-icon[b-ja7fx1prfn] {
    opacity: 1;
}

/* ── Nav Groups ── */
.nav-group[b-ja7fx1prfn] {
    display: flex;
    flex-direction: column;
}

.nav-group-toggle[b-ja7fx1prfn] {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    width: 100%;
    padding: 0.55rem 0.75rem;
    border: none;
    background: transparent;
    color: rgba(255, 255, 255, 0.65);
    font-size: 0.875rem;
    font-weight: 500;
    border-radius: 8px;
    cursor: pointer;
    transition: background 120ms ease, color 120ms ease;
    text-align: left;
    white-space: nowrap;
}

.nav-group-toggle:hover[b-ja7fx1prfn] {
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.95);
}

.chevron[b-ja7fx1prfn] {
    width: 14px;
    height: 14px;
    margin-left: auto;
    opacity: 0.4;
    transition: transform 200ms ease;
    flex-shrink: 0;
}

.nav-group-toggle.open .chevron[b-ja7fx1prfn] {
    transform: rotate(180deg);
}

.nav-group-items[b-ja7fx1prfn] {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    padding: 0.15rem 0 0.25rem;
}

/* ── Content wrapper (header + main) ── */
.admin-content-wrapper[b-ja7fx1prfn] {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
    overflow: hidden;
}

/* ── Header bar ── */
.admin-header[b-ja7fx1prfn] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 2rem;
    background: #0d1117;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    flex-shrink: 0;
}

.admin-search-wrapper[b-ja7fx1prfn] {
    position: relative;
    flex: 1;
    max-width: 420px;
}

.search-icon[b-ja7fx1prfn] {
    position: absolute;
    left: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    height: 16px;
    color: rgba(255, 255, 255, 0.35);
    pointer-events: none;
}

.admin-search[b-ja7fx1prfn] {
    width: 100%;
    padding: 0.5rem 0.75rem 0.5rem 2.25rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: #e5e7eb;
    font-size: 0.85rem;
    outline: none;
    transition: border-color 150ms ease, background 150ms ease;
}

.admin-search[b-ja7fx1prfn]::placeholder {
    color: rgba(255, 255, 255, 0.35);
}

.admin-search:focus[b-ja7fx1prfn] {
    border-color: rgba(99, 102, 241, 0.5);
    background: rgba(255, 255, 255, 0.07);
}

/* ── Search dropdown ── */
.search-dropdown[b-ja7fx1prfn] {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    background: #161d2e;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 10px;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.4);
    overflow: hidden;
    z-index: 100;
    max-height: 360px;
    overflow-y: auto;
}

.search-loading[b-ja7fx1prfn],
.search-empty[b-ja7fx1prfn] {
    padding: 0.85rem 1rem;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.4);
    text-align: center;
}

.search-result[b-ja7fx1prfn] {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    width: 100%;
    padding: 0.6rem 0.85rem;
    border: none;
    background: transparent;
    color: #e5e7eb;
    font-size: 0.84rem;
    text-align: left;
    cursor: pointer;
    transition: background 80ms ease;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.search-result:last-child[b-ja7fx1prfn] {
    border-bottom: none;
}

.search-result:hover[b-ja7fx1prfn],
.search-result.selected[b-ja7fx1prfn] {
    background: rgba(99, 102, 241, 0.15);
}

.search-badge[b-ja7fx1prfn] {
    flex-shrink: 0;
    padding: 0.15rem 0.45rem;
    border-radius: 4px;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.badge-tutor[b-ja7fx1prfn] {
    background: rgba(99, 102, 241, 0.2);
    color: #a5b4fc;
}

.badge-parent[b-ja7fx1prfn] {
    background: rgba(59, 130, 246, 0.2);
    color: #93c5fd;
}

.badge-student[b-ja7fx1prfn] {
    background: rgba(20, 184, 166, 0.2);
    color: #5eead4;
}

.search-name[b-ja7fx1prfn] {
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.search-email[b-ja7fx1prfn] {
    color: rgba(255, 255, 255, 0.4);
    font-size: 0.78rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-left: auto;
}

.admin-header-right[b-ja7fx1prfn] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-shrink: 0;
}

.header-env-badge[b-ja7fx1prfn] {
    padding: 0.2rem 0.5rem;
    background: rgba(239, 68, 68, 0.15);
    color: #fca5a5;
    border: 1px solid rgba(239, 68, 68, 0.25);
    border-radius: 4px;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.admin-email[b-ja7fx1prfn] {
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.5);
    white-space: nowrap;
}

/* ── Main content ── */
.admin-main[b-ja7fx1prfn] {
    flex: 1;
    padding: 2rem;
    overflow-y: auto;
}

.admin-main h1[b-ja7fx1prfn] {
    margin-bottom: 1.25rem;
    font-weight: 800;
}

/* ── STAGING badge (sidebar bottom) ── */
.admin-env[b-ja7fx1prfn] {
    margin-top: auto;
    padding-top: 1rem;
    text-align: center;
}

.admin-env-pill[b-ja7fx1prfn] {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    background: rgba(239, 68, 68, 0.12);
    color: #fca5a5;
    border: 1px solid rgba(239, 68, 68, 0.2);
    border-radius: 6px;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

/* ═══════════════════════════════════════════════
   Shared admin page styles (cards, etc.)
   ═══════════════════════════════════════════════ */

.admin-cards[b-ja7fx1prfn] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.25rem;
    margin-top: 1.5rem;
}

.admin-card[b-ja7fx1prfn] {
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 14px;
    padding: 1.25rem;
    text-decoration: none;
    color: white;
    transition: transform 120ms ease, border-color 120ms ease;
}

.admin-card:hover[b-ja7fx1prfn] {
    transform: translateY(-2px);
    border-color: rgba(255, 255, 255, 0.25);
}

.admin-card h3[b-ja7fx1prfn] {
    margin: 0 0 0.25rem 0;
}

.admin-card p[b-ja7fx1prfn] {
    margin: 0;
    opacity: 0.7;
    font-size: 0.95rem;
}

.muted[b-ja7fx1prfn] {
    opacity: 0.65;
}
/* _content/Mathos.App/Components/Layout/MainLayout.razor.rz.scp.css */
.page[b-8vumgl0uhn] {
    position: relative;
    display: flex;
    flex-direction: column;
}

main[b-8vumgl0uhn] {
    flex: 1;
}

.sidebar[b-8vumgl0uhn] {
    background-image: linear-gradient(180deg, rgb(5, 39, 103) 0%, #3a0647 70%);
}

.top-row[b-8vumgl0uhn] {
    background-color: #f7f7f7;
    border-bottom: 1px solid #d6d5d5;
    justify-content: flex-end;
    height: 3.5rem;
    display: flex;
    align-items: center;
}

    .top-row[b-8vumgl0uhn]  a, .top-row[b-8vumgl0uhn]  .btn-link {
        white-space: nowrap;
        margin-left: 1.5rem;
        text-decoration: none;
    }

    .top-row[b-8vumgl0uhn]  a:hover, .top-row[b-8vumgl0uhn]  .btn-link:hover {
        text-decoration: underline;
    }

    .top-row[b-8vumgl0uhn]  a:first-child {
        overflow: hidden;
        text-overflow: ellipsis;
    }

@media (max-width: 640.98px) {
    .top-row[b-8vumgl0uhn] {
        justify-content: space-between;
    }

    .top-row[b-8vumgl0uhn]  a, .top-row[b-8vumgl0uhn]  .btn-link {
        margin-left: 0;
    }
}

@media (min-width: 641px) {
    .page[b-8vumgl0uhn] {
        flex-direction: row;
    }

    .sidebar[b-8vumgl0uhn] {
        width: 250px;
        height: 100vh;
        position: sticky;
        top: 0;
    }

    .top-row[b-8vumgl0uhn] {
        position: sticky;
        top: 0;
        z-index: 1;
    }

    .top-row.auth[b-8vumgl0uhn]  a:first-child {
        flex: 1;
        text-align: right;
        width: 0;
    }

    .top-row[b-8vumgl0uhn], article[b-8vumgl0uhn] {
        padding-left: 2rem !important;
        padding-right: 1.5rem !important;
    }
}

#blazor-error-ui[b-8vumgl0uhn] {
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss[b-8vumgl0uhn] {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }
/* _content/Mathos.App/Components/Layout/NavMenu.razor.rz.scp.css */
.topbar[b-t3qn4c16v7] {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: #0b1220;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.topbar-inner[b-t3qn4c16v7] {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.75rem 1rem;
    max-width: 1100px;
    margin: 0 auto;
}

.brand[b-t3qn4c16v7] {
    color: white;
    text-decoration: none;
    font-weight: 700;
    letter-spacing: 0.2px;
}

.nav-toggle[b-t3qn4c16v7] {
    display: none;
}

.nav-toggle-label[b-t3qn4c16v7] {
    display: none;
    cursor: pointer;
    width: 2.75rem;
    height: 2.25rem;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
    background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") no-repeat center/1.35rem rgba(255, 255, 255, 0.06);
}

.nav-links[b-t3qn4c16v7] {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    flex: 1;
}

.spacer[b-t3qn4c16v7] {
    flex: 1;
}

.nav-link[b-t3qn4c16v7] {
    color: rgba(255,255,255,0.85);
    text-decoration: none;
    padding: 0.5rem 0.75rem;
    border-radius: 8px;
}

.nav-link:hover[b-t3qn4c16v7] {
    background: rgba(255,255,255,0.08);
    color: white;
}

.nav-link.active[b-t3qn4c16v7] {
    background: rgba(255,255,255,0.12);
    color: white;
}

.sign-in[b-t3qn4c16v7] {
    border: 1px solid rgba(255,255,255,0.18);
}

@media (max-width: 760px) {
    .nav-toggle-label[b-t3qn4c16v7] {
        display: inline-block;
        margin-left: auto;
    }

    .nav-links[b-t3qn4c16v7] {
        display: none;
        position: absolute;
        left: 0;
        right: 0;
        top: 100%;
        background: #0b1220;
        border-bottom: 1px solid rgba(255,255,255,0.08);
        padding: 0.5rem 1rem 0.75rem;
        flex-direction: column;
        align-items: stretch;
        gap: 0.25rem;
    }

    .spacer[b-t3qn4c16v7] {
        display: none;
    }

    .nav-toggle:checked ~ .nav-links[b-t3qn4c16v7] {
        display: flex;
    }
}
/* _content/Mathos.App/Components/Layout/ParentLayout.razor.rz.scp.css */
/* Root parent shell */
.parent-shell[b-06402di9zd] {
    min-height: 100vh;
    display: flex;
    background: #0b0f19;
    color: #e5e7eb;
}

/* Sidebar */
.parent-sidebar[b-06402di9zd] {
    width: 240px;
    background: #070a12;
    border-right: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    flex-direction: column;
    padding: 1.25rem 1rem;
}

/* Brand */
.parent-brand[b-06402di9zd] {
    font-weight: 800;
    font-size: 1.1rem;
    margin-bottom: 1.5rem;
    letter-spacing: 0.3px;
    color: white;
    text-decoration: none;
    display: flex;
    align-items: center;
}

.parent-brand-logo[b-06402di9zd] {
    height: 26px;
    width: 26px;
    border-radius: 6px;
    margin-right: 0.35rem;
    flex-shrink: 0;
}

/* Nav */
.parent-nav[b-06402di9zd] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.parent-nav a[b-06402di9zd] {
    color: rgba(255, 255, 255, 0.78);
    text-decoration: none;
    padding: 0.6rem 0.75rem;
    border-radius: 10px;
    transition: background 120ms ease, color 120ms ease;
}

.parent-nav a:hover[b-06402di9zd] {
    background: rgba(255, 255, 255, 0.08);
    color: white;
}

.parent-nav a.active[b-06402di9zd] {
    background: rgba(99, 102, 241, 0.25);
    color: white;
}

/* Sidebar footer */
.parent-sidebar-footer[b-06402di9zd] {
    margin-top: auto;
    padding-top: 1rem;
}

.parent-env[b-06402di9zd] {
    font-size: 0.75rem;
    color: #fca5a5;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 0.75rem;
}

.parent-signout[b-06402di9zd] {
    background: none;
    border: 1px solid rgba(255,255,255,0.15);
    color: rgba(255,255,255,0.6);
    padding: 0.5rem 0.75rem;
    border-radius: 8px;
    cursor: pointer;
    font-size: 0.85rem;
    width: 100%;
    transition: all 120ms;
}

.parent-signout:hover[b-06402di9zd] {
    color: white;
    border-color: rgba(255,255,255,0.3);
}

/* Main content */
.parent-main[b-06402di9zd] {
    flex: 1;
    padding: 2rem;
    overflow-y: auto;
}

/* Topbar */
.parent-topbar[b-06402di9zd] {
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}

.parent-greeting[b-06402di9zd] {
    font-weight: 600;
    font-size: 0.95rem;
    color: rgba(255,255,255,0.7);
}

/* Page title */
.parent-main h1[b-06402di9zd] {
    margin-bottom: 1.25rem;
    font-weight: 800;
}
/* _content/Mathos.App/Components/Layout/PublicLayout.razor.rz.scp.css */
.public-shell[b-tkhv1rntzi] {
    min-height: 100vh;
    background: #070a12;
    color: white;
}

.staging-banner[b-tkhv1rntzi] {
    background: #d00000;
    color: white;
    text-align: center;
    padding: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
/* _content/Mathos.App/Components/Layout/TutorLayout.razor.rz.scp.css */
/* Root tutor shell */
.tutor-shell[b-ex09ig2ody] {
    min-height: 100vh;
    display: flex;
    background: #0b0f19;
    color: #e5e7eb;
}

/* Sidebar */
.tutor-sidebar[b-ex09ig2ody] {
    width: 240px;
    background: #070a12;
    border-right: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    flex-direction: column;
    padding: 1.25rem 1rem;
}

/* Brand */
.tutor-brand[b-ex09ig2ody] {
    font-weight: 800;
    font-size: 1.1rem;
    margin-bottom: 1.5rem;
    letter-spacing: 0.3px;
    color: white;
    text-decoration: none;
    display: flex;
    align-items: center;
}

.tutor-brand-logo[b-ex09ig2ody] {
    height: 26px;
    width: 26px;
    border-radius: 6px;
    margin-right: 0.35rem;
    flex-shrink: 0;
}

.tutor-brand-sub[b-ex09ig2ody] {
    font-weight: 400;
    color: #10b981;
    font-size: 0.85rem;
    margin-left: 0.25rem;
}

/* Nav */
.tutor-nav[b-ex09ig2ody] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.tutor-nav a[b-ex09ig2ody] {
    color: rgba(255, 255, 255, 0.78);
    text-decoration: none;
    padding: 0.6rem 0.75rem;
    border-radius: 10px;
    transition: background 120ms ease, color 120ms ease;
}

.tutor-nav a:hover[b-ex09ig2ody] {
    background: rgba(255, 255, 255, 0.08);
    color: white;
}

.tutor-nav a.active[b-ex09ig2ody] {
    background: rgba(16, 185, 129, 0.25);
    color: white;
}

/* Sidebar footer */
.tutor-sidebar-footer[b-ex09ig2ody] {
    margin-top: auto;
    padding-top: 1rem;
}

.tutor-env[b-ex09ig2ody] {
    font-size: 0.75rem;
    color: #fca5a5;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 0.75rem;
}

.tutor-signout[b-ex09ig2ody] {
    background: none;
    border: 1px solid rgba(255,255,255,0.15);
    color: rgba(255,255,255,0.6);
    padding: 0.5rem 0.75rem;
    border-radius: 8px;
    cursor: pointer;
    font-size: 0.85rem;
    width: 100%;
    transition: all 120ms;
}

.tutor-signout:hover[b-ex09ig2ody] {
    color: white;
    border-color: rgba(255,255,255,0.3);
}

/* Main content */
.tutor-main[b-ex09ig2ody] {
    flex: 1;
    padding: 2rem;
    overflow-y: auto;
}

/* Topbar */
.tutor-topbar[b-ex09ig2ody] {
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}

.tutor-greeting[b-ex09ig2ody] {
    font-weight: 600;
    font-size: 0.95rem;
    color: rgba(255,255,255,0.7);
}

/* Page title */
.tutor-main h1[b-ex09ig2ody] {
    margin-bottom: 1.25rem;
    font-weight: 800;
}
/* _content/Mathos.App/Components/Pages/admin/Assignments.razor.rz.scp.css */
/* ═══════════════════════════════════════════════
   Assignments — admin page
   ═══════════════════════════════════════════════ */

/* ── Filter bar ── */
.filter-bar[b-3ju38uprjm] {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    align-items: flex-end;
    margin-bottom: 1.25rem;
    padding: 1rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
}

.filter-group[b-3ju38uprjm] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.filter-label[b-3ju38uprjm] {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
}

.filter-input[b-3ju38uprjm] {
    padding: 0.45rem 0.65rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: white;
    font-size: 0.82rem;
    font-family: inherit;
    min-width: 140px;
}

.filter-input:focus[b-3ju38uprjm] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.filter-actions[b-3ju38uprjm] {
    display: flex;
    gap: 0.5rem;
    align-items: flex-end;
}

.btn-apply[b-3ju38uprjm] {
    padding: 0.45rem 1rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: #a5b4fc;
    font-weight: 700;
    font-size: 0.82rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-apply:hover[b-3ju38uprjm] {
    background: rgba(99, 102, 241, 0.35);
}

.btn-clear[b-3ju38uprjm] {
    padding: 0.45rem 1rem;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    font-size: 0.82rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-clear:hover[b-3ju38uprjm] {
    background: rgba(255, 255, 255, 0.04);
}

/* ── Loading ── */
.loading-row[b-3ju38uprjm] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 3rem 0;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.9rem;
}

.spinner[b-3ju38uprjm] {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: spin-b-3ju38uprjm 0.6s linear infinite;
}

@keyframes spin-b-3ju38uprjm {
    to { transform: rotate(360deg); }
}

.empty-state[b-3ju38uprjm] {
    text-align: center;
    padding: 2.5rem 1rem;
    color: rgba(255, 255, 255, 0.35);
    font-size: 0.88rem;
}

/* ── Results summary ── */
.results-summary[b-3ju38uprjm] {
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 0.75rem;
}

/* ── Data table ── */
.data-table-wrap[b-3ju38uprjm] {
    overflow-x: auto;
}

.data-table[b-3ju38uprjm] {
    width: 100%;
    border-collapse: collapse;
}

.data-table th[b-3ju38uprjm] {
    text-align: left;
    padding: 0.6rem 0.75rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.data-table td[b-3ju38uprjm] {
    padding: 0.55rem 0.75rem;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.75);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.data-table tbody tr[b-3ju38uprjm] {
    cursor: pointer;
    transition: background 120ms ease;
}

.data-table tbody tr:hover[b-3ju38uprjm] {
    background: rgba(255, 255, 255, 0.02);
}

.data-table tbody tr.expanded-parent[b-3ju38uprjm] {
    background: rgba(99, 102, 241, 0.04);
}

.data-table tbody tr.detail-row[b-3ju38uprjm] {
    cursor: default;
}

.data-table tbody tr.detail-row:hover[b-3ju38uprjm] {
    background: none;
}

.col-chevron[b-3ju38uprjm] {
    width: 36px;
    text-align: center;
}

.chevron-icon[b-3ju38uprjm] {
    width: 16px;
    height: 16px;
    color: rgba(255, 255, 255, 0.35);
    transition: transform 150ms ease;
}

.chevron-icon.open[b-3ju38uprjm] {
    transform: rotate(90deg);
}

.col-num[b-3ju38uprjm] {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.col-timestamp[b-3ju38uprjm] {
    white-space: nowrap;
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.78rem;
}

.col-overdue[b-3ju38uprjm] {
    color: #f87171 !important;
    font-weight: 700;
}

.text-muted[b-3ju38uprjm] {
    color: rgba(255, 255, 255, 0.3);
}

.entity-link[b-3ju38uprjm] {
    background: none;
    border: none;
    padding: 0;
    color: #a5b4fc;
    font-size: inherit;
    font-family: inherit;
    cursor: pointer;
    text-decoration: none;
    transition: color 120ms ease;
}

.entity-link:hover[b-3ju38uprjm] {
    color: #c7d2fe;
    text-decoration: underline;
}

/* ── Badges ── */
.badge[b-3ju38uprjm] {
    display: inline-flex;
    align-items: center;
    padding: 0.12rem 0.45rem;
    border-radius: 5px;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    white-space: nowrap;
}

.badge-draft[b-3ju38uprjm] { background: rgba(100, 116, 139, 0.15); color: #94a3b8; }
.badge-assigned[b-3ju38uprjm] { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }
.badge-submitted[b-3ju38uprjm] { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }
.badge-marked[b-3ju38uprjm] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-default[b-3ju38uprjm] { background: rgba(100, 116, 139, 0.15); color: #94a3b8; }

/* Difficulty badges */
.badge-diff-1[b-3ju38uprjm] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-diff-2[b-3ju38uprjm] { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }
.badge-diff-3[b-3ju38uprjm] { background: rgba(239, 68, 68, 0.15); color: #f87171; }

/* ── Detail row ── */
.detail-row td[b-3ju38uprjm] {
    padding: 0 !important;
    border-bottom: 1px solid rgba(99, 102, 241, 0.15) !important;
}

.detail-panel[b-3ju38uprjm] {
    padding: 1.25rem 1.5rem;
    background: rgba(99, 102, 241, 0.03);
}

.detail-section[b-3ju38uprjm] {
    margin-bottom: 1.25rem;
}

.detail-section:last-child[b-3ju38uprjm] {
    margin-bottom: 0;
}

.detail-section h4[b-3ju38uprjm] {
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.5);
    margin: 0 0 0.5rem;
}

/* Topic tags */
.topic-tags[b-3ju38uprjm] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.topic-tag[b-3ju38uprjm] {
    padding: 0.2rem 0.5rem;
    background: rgba(99, 102, 241, 0.1);
    border: 1px solid rgba(99, 102, 241, 0.2);
    border-radius: 6px;
    font-size: 0.75rem;
    color: #c7d2fe;
}

/* Detail table (questions) */
.detail-table[b-3ju38uprjm] {
    width: 100%;
    border-collapse: collapse;
}

.detail-table th[b-3ju38uprjm] {
    text-align: left;
    padding: 0.4rem 0.6rem;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: rgba(255, 255, 255, 0.35);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.detail-table td[b-3ju38uprjm] {
    padding: 0.35rem 0.6rem;
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.7);
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.col-comment[b-3ju38uprjm] {
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: rgba(255, 255, 255, 0.45);
    font-style: italic;
}

/* Info rows (submission) */
.info-row[b-3ju38uprjm] {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 0.3rem;
    font-size: 0.82rem;
}

.info-label[b-3ju38uprjm] {
    color: rgba(255, 255, 255, 0.4);
    font-weight: 600;
    min-width: 80px;
}

.submission-link[b-3ju38uprjm] {
    color: #a5b4fc;
    text-decoration: none;
    word-break: break-all;
}

.submission-link:hover[b-3ju38uprjm] {
    text-decoration: underline;
}

/* PDF links */
.pdf-links[b-3ju38uprjm] {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.btn-pdf[b-3ju38uprjm] {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.4rem 0.85rem;
    background: rgba(59, 130, 246, 0.1);
    border: 1px solid rgba(59, 130, 246, 0.25);
    border-radius: 8px;
    color: #93c5fd;
    font-size: 0.78rem;
    font-weight: 600;
    text-decoration: none;
    transition: background 120ms ease;
}

.btn-pdf:hover[b-3ju38uprjm] {
    background: rgba(59, 130, 246, 0.2);
}

.btn-pdf-scheme[b-3ju38uprjm] {
    background: rgba(245, 158, 11, 0.1);
    border-color: rgba(245, 158, 11, 0.25);
    color: #fbbf24;
}

.btn-pdf-scheme:hover[b-3ju38uprjm] {
    background: rgba(245, 158, 11, 0.2);
}

.btn-icon[b-3ju38uprjm] {
    width: 14px;
    height: 14px;
}

/* ── Pagination ── */
.pagination[b-3ju38uprjm] {
    display: flex;
    gap: 0.35rem;
    justify-content: center;
    margin-top: 1.5rem;
}

.page-btn[b-3ju38uprjm] {
    padding: 0.35rem 0.7rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 6px;
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.78rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 120ms ease;
}

.page-btn:hover:not(:disabled):not(.active)[b-3ju38uprjm] {
    background: rgba(255, 255, 255, 0.08);
}

.page-btn.active[b-3ju38uprjm] {
    background: rgba(99, 102, 241, 0.25);
    border-color: rgba(99, 102, 241, 0.4);
    color: #a5b4fc;
}

.page-btn:disabled[b-3ju38uprjm] {
    opacity: 0.3;
    cursor: not-allowed;
}

.page-ellipsis[b-3ju38uprjm] {
    padding: 0.35rem 0.4rem;
    color: rgba(255, 255, 255, 0.3);
    font-size: 0.78rem;
}
/* _content/Mathos.App/Components/Pages/admin/AuditLog.razor.rz.scp.css */
/* ═══════════════════════════════════════════════
   Audit Log — admin audit log page
   ═══════════════════════════════════════════════ */

/* ── Filter bar ── */
.filter-bar[b-t4xyx7djvw] {
    display: flex;
    gap: 0.75rem;
    align-items: flex-end;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
    padding: 1rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
}

.filter-group[b-t4xyx7djvw] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.filter-label[b-t4xyx7djvw] {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
}

.filter-select[b-t4xyx7djvw],
.filter-input[b-t4xyx7djvw] {
    padding: 0.45rem 0.65rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: white;
    font-size: 0.82rem;
    font-family: inherit;
    min-width: 130px;
}

.filter-select:focus[b-t4xyx7djvw],
.filter-input:focus[b-t4xyx7djvw] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.filter-input[b-t4xyx7djvw]::placeholder {
    color: rgba(255, 255, 255, 0.25);
}

.filter-select option[b-t4xyx7djvw] {
    background: #1a2035;
    color: white;
}

.filter-actions[b-t4xyx7djvw] {
    display: flex;
    gap: 0.4rem;
    align-items: flex-end;
}

.btn-apply[b-t4xyx7djvw] {
    padding: 0.45rem 1rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: white;
    font-weight: 600;
    font-size: 0.82rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-apply:hover[b-t4xyx7djvw] {
    background: rgba(99, 102, 241, 0.35);
}

.btn-clear[b-t4xyx7djvw] {
    padding: 0.45rem 0.85rem;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    font-size: 0.82rem;
    cursor: pointer;
    transition: color 120ms ease, border-color 120ms ease;
}

.btn-clear:hover[b-t4xyx7djvw] {
    color: white;
    border-color: rgba(255, 255, 255, 0.25);
}

/* ── Loading ── */
.loading-row[b-t4xyx7djvw] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 3rem 0;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.9rem;
}

.spinner[b-t4xyx7djvw] {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: spin-b-t4xyx7djvw 0.6s linear infinite;
}

@keyframes spin-b-t4xyx7djvw {
    to { transform: rotate(360deg); }
}

/* ── Results summary ── */
.results-summary[b-t4xyx7djvw] {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 0.75rem;
}

.empty-state[b-t4xyx7djvw] {
    text-align: center;
    padding: 2.5rem 1rem;
    color: rgba(255, 255, 255, 0.35);
    font-size: 0.88rem;
}

/* ── Data table ── */
.data-table-wrap[b-t4xyx7djvw] {
    overflow-x: auto;
}

.data-table[b-t4xyx7djvw] {
    width: 100%;
    border-collapse: collapse;
}

.data-table th[b-t4xyx7djvw] {
    text-align: left;
    padding: 0.6rem 0.75rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.data-table td[b-t4xyx7djvw] {
    padding: 0.55rem 0.75rem;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.75);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.data-table tbody tr[b-t4xyx7djvw] {
    cursor: pointer;
    transition: background 120ms ease;
}

.data-table tbody tr:hover[b-t4xyx7djvw] {
    background: rgba(255, 255, 255, 0.02);
}

.data-table tbody tr.row-expanded[b-t4xyx7djvw] {
    background: rgba(99, 102, 241, 0.04);
}

.data-table tbody tr.detail-row[b-t4xyx7djvw] {
    cursor: default;
}

.data-table tbody tr.detail-row:hover[b-t4xyx7djvw] {
    background: none;
}

/* Columns */
.col-expand[b-t4xyx7djvw] {
    width: 32px;
    text-align: center;
}

.col-timestamp[b-t4xyx7djvw] {
    white-space: nowrap;
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.78rem;
}

.col-user[b-t4xyx7djvw] {
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.col-reason[b-t4xyx7djvw] {
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Expand chevron */
.expand-chevron[b-t4xyx7djvw] {
    display: inline-flex;
    transition: transform 200ms ease;
    color: rgba(255, 255, 255, 0.3);
}

.expand-chevron svg[b-t4xyx7djvw] {
    width: 14px;
    height: 14px;
}

.expand-chevron.expanded[b-t4xyx7djvw] {
    transform: rotate(90deg);
    color: #a5b4fc;
}

/* ── Badges ── */
.badge[b-t4xyx7djvw] {
    display: inline-flex;
    align-items: center;
    padding: 0.12rem 0.45rem;
    border-radius: 5px;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    white-space: nowrap;
}

.badge-created[b-t4xyx7djvw] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-updated[b-t4xyx7djvw] { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }
.badge-deleted[b-t4xyx7djvw] { background: rgba(239, 68, 68, 0.15); color: #f87171; }
.badge-auth[b-t4xyx7djvw] { background: rgba(99, 102, 241, 0.15); color: #a5b4fc; }
.badge-auth-fail[b-t4xyx7djvw] { background: rgba(249, 115, 22, 0.15); color: #fb923c; }
.badge-payment[b-t4xyx7djvw] { background: rgba(16, 185, 129, 0.15); color: #6ee7b7; }
.badge-payment-fail[b-t4xyx7djvw] { background: rgba(239, 68, 68, 0.15); color: #f87171; }
.badge-safeguarding[b-t4xyx7djvw] { background: rgba(236, 72, 153, 0.15); color: #f9a8d4; }
.badge-admin[b-t4xyx7djvw] { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }
.badge-gdpr[b-t4xyx7djvw] { background: rgba(168, 85, 247, 0.15); color: #c4b5fd; }
.badge-default[b-t4xyx7djvw] { background: rgba(100, 116, 139, 0.15); color: #94a3b8; }

/* ── Entity links ── */
.entity-link[b-t4xyx7djvw] {
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.76rem;
    color: #a5b4fc;
    text-decoration: none;
    transition: color 120ms ease;
}

.entity-link:hover[b-t4xyx7djvw] {
    color: #c7d2fe;
    text-decoration: underline;
}

.entity-id[b-t4xyx7djvw] {
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.76rem;
    color: rgba(255, 255, 255, 0.5);
}

/* ── Detail panel (expanded row) ── */
.detail-panel[b-t4xyx7djvw] {
    padding: 1rem 1.5rem;
    background: rgba(255, 255, 255, 0.02);
    border-radius: 8px;
    margin: 0.25rem 0;
}

.detail-section[b-t4xyx7djvw] {
    margin-bottom: 0.75rem;
}

.detail-label[b-t4xyx7djvw] {
    display: block;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 0.25rem;
}

.detail-text[b-t4xyx7djvw] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.75);
    line-height: 1.5;
    margin: 0;
}

.detail-code-inline[b-t4xyx7djvw] {
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.6);
    background: rgba(255, 255, 255, 0.04);
    padding: 0.15rem 0.4rem;
    border-radius: 4px;
}

.detail-json-grid[b-t4xyx7djvw] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-top: 0.5rem;
}

@media (max-width: 800px) {
    .detail-json-grid[b-t4xyx7djvw] {
        grid-template-columns: 1fr;
    }
}

.detail-json-block[b-t4xyx7djvw] {
    min-width: 0;
}

.json-pre[b-t4xyx7djvw] {
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
    padding: 0.75rem 1rem;
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.72rem;
    color: rgba(255, 255, 255, 0.65);
    line-height: 1.5;
    overflow-x: auto;
    max-height: 300px;
    overflow-y: auto;
    margin: 0.25rem 0 0;
    white-space: pre;
}

.detail-empty[b-t4xyx7djvw] {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.3);
    font-style: italic;
    margin: 0;
}

/* ── Pagination ── */
.pagination[b-t4xyx7djvw] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    margin-top: 1.5rem;
    padding-bottom: 1rem;
}

.page-btn[b-t4xyx7djvw] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    height: 34px;
    padding: 0 0.5rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 120ms ease, color 120ms ease;
}

.page-btn:hover:not(:disabled)[b-t4xyx7djvw] {
    background: rgba(99, 102, 241, 0.15);
    color: white;
}

.page-btn.active[b-t4xyx7djvw] {
    background: rgba(99, 102, 241, 0.25);
    border-color: rgba(99, 102, 241, 0.4);
    color: #a5b4fc;
}

.page-btn:disabled[b-t4xyx7djvw] {
    opacity: 0.3;
    cursor: not-allowed;
}

.page-btn svg[b-t4xyx7djvw] {
    width: 16px;
    height: 16px;
}

.page-ellipsis[b-t4xyx7djvw] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    color: rgba(255, 255, 255, 0.3);
    font-size: 0.85rem;
}
/* _content/Mathos.App/Components/Pages/admin/Curriculum.razor.rz.scp.css */
/* ═══════════════════════════════════════════════
   Curriculum — admin tree view
   ═══════════════════════════════════════════════ */

/* ── Page header ── */
.page-header[b-r14m3jvm1k] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.25rem;
}

.page-header h1[b-r14m3jvm1k] {
    font-size: 1.35rem;
    font-weight: 700;
    color: white;
    margin: 0;
}

.btn-add-spec[b-r14m3jvm1k] {
    padding: 0.5rem 1rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: #a5b4fc;
    font-weight: 700;
    font-size: 0.82rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-add-spec:hover[b-r14m3jvm1k] {
    background: rgba(99, 102, 241, 0.35);
}

/* ── Error banner ── */
.error-banner[b-r14m3jvm1k] {
    padding: 0.65rem 1rem;
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-radius: 8px;
    color: #f87171;
    font-size: 0.82rem;
    margin-bottom: 1rem;
}

/* ── Loading / Empty ── */
.loading-row[b-r14m3jvm1k] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 3rem 0;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.9rem;
}

.spinner[b-r14m3jvm1k] {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: spin-b-r14m3jvm1k 0.6s linear infinite;
}

@keyframes spin-b-r14m3jvm1k {
    to { transform: rotate(360deg); }
}

.empty-state[b-r14m3jvm1k] {
    text-align: center;
    padding: 2.5rem 1rem;
    color: rgba(255, 255, 255, 0.35);
    font-size: 0.88rem;
}

/* ── Tree structure ── */
.tree-spec[b-r14m3jvm1k] {
    margin-bottom: 0.5rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 10px;
    overflow: hidden;
}

.tree-children[b-r14m3jvm1k] {
    padding-left: 0.25rem;
}

.tree-domain[b-r14m3jvm1k] {
    border-top: 1px solid rgba(255, 255, 255, 0.04);
}

/* ── Tree rows ── */
.tree-row[b-r14m3jvm1k] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.6rem 0.75rem;
    transition: background 120ms ease;
    flex-wrap: wrap;
}

.tree-row:hover[b-r14m3jvm1k] {
    background: rgba(255, 255, 255, 0.02);
}

.tree-row.expanded[b-r14m3jvm1k] {
    background: rgba(99, 102, 241, 0.04);
}

.tree-row.editing[b-r14m3jvm1k] {
    background: rgba(99, 102, 241, 0.06);
    padding: 0.75rem;
}

/* Level-specific indentation */
.tree-row-spec[b-r14m3jvm1k] {
    padding-left: 0.75rem;
}

.tree-row-domain[b-r14m3jvm1k] {
    padding-left: 2rem;
}

.tree-row-node[b-r14m3jvm1k] {
    padding-left: 3.5rem;
}

/* ── Toggle button ── */
.tree-toggle[b-r14m3jvm1k] {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    color: rgba(255, 255, 255, 0.35);
    transition: color 120ms ease;
}

.tree-toggle:hover[b-r14m3jvm1k] {
    color: rgba(255, 255, 255, 0.6);
}

.chevron-icon[b-r14m3jvm1k] {
    width: 16px;
    height: 16px;
    transition: transform 150ms ease;
}

.chevron-icon.open[b-r14m3jvm1k] {
    transform: rotate(90deg);
}

/* ── Names ── */
.spec-name[b-r14m3jvm1k] {
    font-weight: 700;
    font-size: 0.92rem;
    color: white;
}

.domain-name[b-r14m3jvm1k] {
    font-weight: 600;
    font-size: 0.86rem;
    color: rgba(255, 255, 255, 0.85);
}

.node-name[b-r14m3jvm1k] {
    font-weight: 500;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.75);
}

/* ── Counts ── */
.domain-count[b-r14m3jvm1k],
.node-count[b-r14m3jvm1k] {
    font-size: 0.72rem;
    color: rgba(255, 255, 255, 0.3);
    margin-left: auto;
    margin-right: 0.25rem;
}

/* ── Badges ── */
.badge[b-r14m3jvm1k] {
    display: inline-flex;
    align-items: center;
    padding: 0.1rem 0.4rem;
    border-radius: 5px;
    font-size: 0.66rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    white-space: nowrap;
}

.badge-active[b-r14m3jvm1k] {
    background: rgba(34, 197, 94, 0.15);
    color: #4ade80;
}

.badge-inactive[b-r14m3jvm1k] {
    background: rgba(100, 116, 139, 0.15);
    color: #94a3b8;
}

.badge-code[b-r14m3jvm1k] {
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.5);
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.68rem;
    letter-spacing: 0;
    text-transform: none;
}

.badge-order[b-r14m3jvm1k] {
    background: rgba(255, 255, 255, 0.04);
    color: rgba(255, 255, 255, 0.3);
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.66rem;
    letter-spacing: 0;
    text-transform: none;
}

/* Tier badges */
.badge-both[b-r14m3jvm1k] {
    background: rgba(100, 116, 139, 0.15);
    color: #94a3b8;
}

.badge-foundation[b-r14m3jvm1k] {
    background: rgba(59, 130, 246, 0.15);
    color: #93c5fd;
}

.badge-higher[b-r14m3jvm1k] {
    background: rgba(147, 51, 234, 0.15);
    color: #c084fc;
}

/* ── Row actions ── */
.row-actions[b-r14m3jvm1k] {
    display: flex;
    gap: 0.25rem;
    margin-left: 0.5rem;
    opacity: 0;
    transition: opacity 120ms ease;
}

.tree-row:hover .row-actions[b-r14m3jvm1k] {
    opacity: 1;
}

.btn-action[b-r14m3jvm1k] {
    padding: 0.2rem 0.5rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 5px;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.7rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 120ms ease;
}

.btn-action:hover[b-r14m3jvm1k] {
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.8);
}

.btn-action.btn-danger[b-r14m3jvm1k] {
    color: rgba(248, 113, 113, 0.6);
    border-color: rgba(248, 113, 113, 0.15);
}

.btn-action.btn-danger:hover[b-r14m3jvm1k] {
    background: rgba(239, 68, 68, 0.1);
    color: #f87171;
    border-color: rgba(239, 68, 68, 0.3);
}

.btn-reorder[b-r14m3jvm1k] {
    padding: 0.15rem 0.35rem;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 4px;
    color: rgba(255, 255, 255, 0.25);
    font-size: 0.6rem;
    cursor: pointer;
    line-height: 1;
    transition: all 120ms ease;
}

.btn-reorder:hover[b-r14m3jvm1k] {
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.6);
    border-color: rgba(255, 255, 255, 0.15);
}

/* ── Add child button ── */
.btn-add-child[b-r14m3jvm1k] {
    display: block;
    width: calc(100% - 2rem);
    margin: 0.35rem 1rem;
    padding: 0.4rem;
    background: none;
    border: 1px dashed rgba(99, 102, 241, 0.2);
    border-radius: 6px;
    color: rgba(99, 102, 241, 0.5);
    font-size: 0.75rem;
    font-weight: 600;
    cursor: pointer;
    text-align: center;
    transition: all 120ms ease;
}

.btn-add-child:hover[b-r14m3jvm1k] {
    border-color: rgba(99, 102, 241, 0.4);
    color: #a5b4fc;
    background: rgba(99, 102, 241, 0.04);
}

/* ── Add / Edit forms ── */
.add-form-panel[b-r14m3jvm1k] {
    padding: 0.75rem 1rem;
    background: rgba(99, 102, 241, 0.04);
    border: 1px solid rgba(99, 102, 241, 0.12);
    border-radius: 8px;
    margin: 0.5rem 0.75rem;
}

.add-form-domain[b-r14m3jvm1k] {
    margin-left: 2rem;
}

.add-form-node[b-r14m3jvm1k] {
    margin-left: 3.5rem;
}

.add-form-title[b-r14m3jvm1k] {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 0.5rem;
}

.inline-form[b-r14m3jvm1k] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.form-input[b-r14m3jvm1k] {
    padding: 0.4rem 0.6rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    color: white;
    font-size: 0.82rem;
    font-family: inherit;
    min-width: 160px;
}

.form-input:focus[b-r14m3jvm1k] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.form-input-sm[b-r14m3jvm1k] {
    min-width: 100px;
    max-width: 120px;
}

.form-input-xs[b-r14m3jvm1k] {
    min-width: 60px;
    max-width: 80px;
}

.toggle-label[b-r14m3jvm1k] {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.6);
    cursor: pointer;
    white-space: nowrap;
}

.toggle-label input[type="checkbox"][b-r14m3jvm1k] {
    accent-color: #6366f1;
}

.btn-save[b-r14m3jvm1k] {
    padding: 0.4rem 0.85rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 6px;
    color: #a5b4fc;
    font-weight: 700;
    font-size: 0.78rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-save:hover[b-r14m3jvm1k] {
    background: rgba(99, 102, 241, 0.35);
}

.btn-cancel[b-r14m3jvm1k] {
    padding: 0.4rem 0.85rem;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    font-size: 0.78rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-cancel:hover[b-r14m3jvm1k] {
    background: rgba(255, 255, 255, 0.04);
}
/* _content/Mathos.App/Components/Pages/admin/Gdpr.razor.rz.scp.css */
/* ═══════════════════════════════════════════════
   GDPR & Data Protection — admin page
   ═══════════════════════════════════════════════ */

/* ── Tabs ── */
.tab-bar[b-g03loa52lh] {
    display: flex;
    gap: 0.25rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    margin-bottom: 1.5rem;
    overflow-x: auto;
}

.tab[b-g03loa52lh] {
    padding: 0.6rem 1.2rem;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    color: rgba(255, 255, 255, 0.45);
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    white-space: nowrap;
    transition: color 150ms ease, border-color 150ms ease;
}

.tab:hover[b-g03loa52lh] {
    color: rgba(255, 255, 255, 0.7);
}

.tab.active[b-g03loa52lh] {
    color: #a5b4fc;
    border-bottom-color: #6366f1;
}

/* ── Filter bar ── */
.filter-bar[b-g03loa52lh] {
    display: flex;
    gap: 0.75rem;
    align-items: flex-end;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
    padding: 1rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
}

.filter-group[b-g03loa52lh] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.filter-label[b-g03loa52lh] {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
}

.filter-input[b-g03loa52lh] {
    padding: 0.45rem 0.65rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: white;
    font-size: 0.82rem;
    font-family: inherit;
    min-width: 130px;
}

.filter-input:focus[b-g03loa52lh] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.filter-input[b-g03loa52lh]::placeholder {
    color: rgba(255, 255, 255, 0.25);
}

.filter-actions[b-g03loa52lh] {
    display: flex;
    gap: 0.4rem;
    align-items: flex-end;
}

.btn-apply[b-g03loa52lh] {
    padding: 0.45rem 1rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: white;
    font-weight: 600;
    font-size: 0.82rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-apply:hover[b-g03loa52lh] {
    background: rgba(99, 102, 241, 0.35);
}

.btn-clear[b-g03loa52lh] {
    padding: 0.45rem 0.85rem;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    font-size: 0.82rem;
    cursor: pointer;
    transition: color 120ms ease, border-color 120ms ease;
}

.btn-clear:hover[b-g03loa52lh] {
    color: white;
    border-color: rgba(255, 255, 255, 0.25);
}

/* ── Loading ── */
.loading-row[b-g03loa52lh] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 3rem 0;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.9rem;
}

.spinner[b-g03loa52lh] {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: spin-b-g03loa52lh 0.6s linear infinite;
}

@keyframes spin-b-g03loa52lh {
    to { transform: rotate(360deg); }
}

/* ── Results summary ── */
.results-summary[b-g03loa52lh] {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 0.75rem;
}

.empty-state[b-g03loa52lh] {
    text-align: center;
    padding: 2.5rem 1rem;
    color: rgba(255, 255, 255, 0.35);
    font-size: 0.88rem;
}

/* ── Data table ── */
.data-table-wrap[b-g03loa52lh] {
    overflow-x: auto;
}

.data-table[b-g03loa52lh] {
    width: 100%;
    border-collapse: collapse;
}

.data-table th[b-g03loa52lh] {
    text-align: left;
    padding: 0.6rem 0.75rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.data-table td[b-g03loa52lh] {
    padding: 0.55rem 0.75rem;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.75);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.data-table tbody tr[b-g03loa52lh] {
    transition: background 120ms ease;
}

.data-table tbody tr:hover[b-g03loa52lh] {
    background: rgba(255, 255, 255, 0.02);
}

/* Columns */
.col-timestamp[b-g03loa52lh] {
    white-space: nowrap;
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.78rem;
}

.col-email[b-g03loa52lh] {
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.col-entity-id[b-g03loa52lh] {
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.76rem;
    color: rgba(255, 255, 255, 0.5);
}

.col-reason[b-g03loa52lh] {
    max-width: 220px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.col-ip[b-g03loa52lh] {
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.76rem;
    color: rgba(255, 255, 255, 0.45);
}

.col-num[b-g03loa52lh] {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.col-entity-type[b-g03loa52lh] {
    font-weight: 600;
}

/* ── Badges ── */
.badge[b-g03loa52lh] {
    display: inline-flex;
    align-items: center;
    padding: 0.12rem 0.45rem;
    border-radius: 5px;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    white-space: nowrap;
}

.badge-export[b-g03loa52lh] { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }
.badge-deletion[b-g03loa52lh] { background: rgba(239, 68, 68, 0.15); color: #f87171; }
.badge-admin-export[b-g03loa52lh] { background: rgba(168, 85, 247, 0.15); color: #c4b5fd; }
.badge-admin-deletion[b-g03loa52lh] { background: rgba(168, 85, 247, 0.2); color: #e9d5ff; border: 1px solid rgba(168, 85, 247, 0.3); }
.badge-default[b-g03loa52lh] { background: rgba(100, 116, 139, 0.15); color: #94a3b8; }

/* ── Retention report ── */
.retention-summary[b-g03loa52lh] {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-bottom: 1.5rem;
}

@media (max-width: 640px) {
    .retention-summary[b-g03loa52lh] {
        grid-template-columns: 1fr;
    }
}

.retention-card[b-g03loa52lh] {
    padding: 1.25rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    text-align: center;
}

.retention-card-label[b-g03loa52lh] {
    display: block;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 0.35rem;
}

.retention-card-value[b-g03loa52lh] {
    display: block;
    font-size: 1.8rem;
    font-weight: 800;
    color: white;
    font-variant-numeric: tabular-nums;
}

.card-deleted[b-g03loa52lh] {
    border-color: rgba(245, 158, 11, 0.2);
}

.card-deleted .retention-card-value[b-g03loa52lh] {
    color: #fbbf24;
}

.card-old[b-g03loa52lh] {
    border-color: rgba(239, 68, 68, 0.2);
}

.card-old .retention-card-value[b-g03loa52lh] {
    color: #f87171;
}

.col-old[b-g03loa52lh] {
    color: rgba(239, 68, 68, 0.7) !important;
}

.col-old-val[b-g03loa52lh] {
    color: #f87171 !important;
    font-weight: 700;
}

.col-deleted-val[b-g03loa52lh] {
    color: #fbbf24 !important;
}

.info-note[b-g03loa52lh] {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    padding: 0.85rem 1rem;
    background: rgba(59, 130, 246, 0.08);
    border: 1px solid rgba(59, 130, 246, 0.2);
    border-radius: 10px;
    margin-bottom: 1.25rem;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.6);
    line-height: 1.5;
}

.info-icon[b-g03loa52lh] {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    color: #60a5fa;
    margin-top: 0.1rem;
}

.generated-at[b-g03loa52lh] {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.3);
    margin-top: 1rem;
    text-align: right;
}

/* ── Admin Actions ── */
.actions-panel[b-g03loa52lh] {
    max-width: 640px;
}

.actions-header h2[b-g03loa52lh] {
    font-size: 1.1rem;
    font-weight: 700;
    color: white;
    margin: 0 0 0.35rem;
}

.actions-desc[b-g03loa52lh] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.5);
    line-height: 1.5;
    margin: 0 0 1.5rem;
}

.actions-form[b-g03loa52lh] {
    padding: 1.25rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    margin-bottom: 1rem;
}

.form-group[b-g03loa52lh] {
    margin-bottom: 1rem;
}

.form-label[b-g03loa52lh] {
    display: block;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: rgba(255, 255, 255, 0.45);
    margin-bottom: 0.35rem;
}

.form-input[b-g03loa52lh],
.form-textarea[b-g03loa52lh] {
    width: 100%;
    padding: 0.55rem 0.75rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: white;
    font-size: 0.85rem;
    font-family: inherit;
    box-sizing: border-box;
}

.form-input:focus[b-g03loa52lh],
.form-textarea:focus[b-g03loa52lh] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.form-input[b-g03loa52lh]::placeholder,
.form-textarea[b-g03loa52lh]::placeholder {
    color: rgba(255, 255, 255, 0.25);
}

.form-textarea[b-g03loa52lh] {
    resize: vertical;
    min-height: 70px;
}

.actions-buttons[b-g03loa52lh] {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.btn-export[b-g03loa52lh],
.btn-delete[b-g03loa52lh] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.55rem 1.1rem;
    border-radius: 8px;
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease, opacity 120ms ease;
    border: 1px solid;
}

.btn-export[b-g03loa52lh] {
    background: rgba(59, 130, 246, 0.15);
    border-color: rgba(59, 130, 246, 0.35);
    color: #93c5fd;
}

.btn-export:hover:not(:disabled)[b-g03loa52lh] {
    background: rgba(59, 130, 246, 0.3);
}

.btn-delete[b-g03loa52lh] {
    background: rgba(239, 68, 68, 0.15);
    border-color: rgba(239, 68, 68, 0.35);
    color: #f87171;
}

.btn-delete:hover:not(:disabled)[b-g03loa52lh] {
    background: rgba(239, 68, 68, 0.3);
}

.btn-export:disabled[b-g03loa52lh],
.btn-delete:disabled[b-g03loa52lh] {
    opacity: 0.35;
    cursor: not-allowed;
}

.btn-icon[b-g03loa52lh] {
    width: 16px;
    height: 16px;
}

.spinner-sm[b-g03loa52lh] {
    width: 14px;
    height: 14px;
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-top-color: currentColor;
    border-radius: 50%;
    animation: spin-b-g03loa52lh 0.6s linear infinite;
}

/* ── Delete confirmation ── */
.delete-confirm-panel[b-g03loa52lh] {
    margin-top: 1rem;
    padding: 1.25rem;
    background: rgba(239, 68, 68, 0.06);
    border: 1px solid rgba(239, 68, 68, 0.25);
    border-radius: 12px;
}

.delete-confirm-warning[b-g03loa52lh] {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.warning-icon[b-g03loa52lh] {
    width: 22px;
    height: 22px;
    flex-shrink: 0;
    color: #f87171;
    margin-top: 0.1rem;
}

.delete-confirm-warning strong[b-g03loa52lh] {
    color: #f87171;
    font-size: 0.9rem;
}

.delete-confirm-warning p[b-g03loa52lh] {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.6);
    line-height: 1.5;
    margin: 0.35rem 0 0;
}

.confirm-input[b-g03loa52lh] {
    border-color: rgba(239, 68, 68, 0.3) !important;
}

.delete-confirm-actions[b-g03loa52lh] {
    display: flex;
    gap: 0.6rem;
    margin-top: 0.75rem;
}

.btn-delete-confirm[b-g03loa52lh] {
    padding: 0.5rem 1.1rem;
    background: rgba(239, 68, 68, 0.25);
    border: 1px solid rgba(239, 68, 68, 0.5);
    border-radius: 8px;
    color: #fca5a5;
    font-weight: 700;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-delete-confirm:hover:not(:disabled)[b-g03loa52lh] {
    background: rgba(239, 68, 68, 0.4);
}

.btn-delete-confirm:disabled[b-g03loa52lh] {
    opacity: 0.35;
    cursor: not-allowed;
}

.btn-cancel[b-g03loa52lh] {
    padding: 0.5rem 1rem;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: color 120ms ease, border-color 120ms ease;
}

.btn-cancel:hover[b-g03loa52lh] {
    color: white;
    border-color: rgba(255, 255, 255, 0.25);
}

/* ── Action result ── */
.action-result[b-g03loa52lh] {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    margin-top: 1rem;
    padding: 1rem;
    border-radius: 10px;
}

.result-success[b-g03loa52lh] {
    background: rgba(34, 197, 94, 0.1);
    border: 1px solid rgba(34, 197, 94, 0.25);
}

.result-error[b-g03loa52lh] {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.25);
}

.result-icon[b-g03loa52lh] {
    font-size: 1.1rem;
    font-weight: 800;
    flex-shrink: 0;
}

.result-success .result-icon[b-g03loa52lh] { color: #4ade80; }
.result-error .result-icon[b-g03loa52lh] { color: #f87171; }

.result-message[b-g03loa52lh] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.8);
    line-height: 1.5;
    margin: 0;
}

.result-meta[b-g03loa52lh] {
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.45);
    margin: 0.25rem 0 0;
}

.result-meta code[b-g03loa52lh] {
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.74rem;
    color: rgba(255, 255, 255, 0.55);
    background: rgba(255, 255, 255, 0.04);
    padding: 0.1rem 0.35rem;
    border-radius: 4px;
}
/* _content/Mathos.App/Components/Pages/admin/Index.razor.rz.scp.css */
/* ═══════════════════════════════════════════════
   Admin Dashboard — stat cards, alerts, activity
   ═══════════════════════════════════════════════ */

/* ── Stat cards grid ── */
.stat-grid[b-whkz2p2t7y] {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin-bottom: 2rem;
}

@media (max-width: 1200px) {
    .stat-grid[b-whkz2p2t7y] { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px) {
    .stat-grid[b-whkz2p2t7y] { grid-template-columns: repeat(2, 1fr); }
}

.stat-card[b-whkz2p2t7y] {
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    padding: 1.25rem;
    border-left: 3px solid transparent;
    transition: transform 120ms ease, border-color 120ms ease;
}

.stat-card:hover[b-whkz2p2t7y] {
    transform: translateY(-1px);
    border-color: rgba(255, 255, 255, 0.15);
}

.stat-label[b-whkz2p2t7y] {
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.5);
    margin-bottom: 0.5rem;
}

.stat-value[b-whkz2p2t7y] {
    font-size: 1.75rem;
    font-weight: 800;
    color: white;
    line-height: 1.1;
}

/* Colour accents */
.stat-indigo[b-whkz2p2t7y] { border-left-color: #6366f1; }
.stat-blue[b-whkz2p2t7y]   { border-left-color: #3b82f6; }
.stat-teal[b-whkz2p2t7y]   { border-left-color: #14b8a6; }
.stat-amber[b-whkz2p2t7y]  { border-left-color: #f59e0b; }
.stat-slate[b-whkz2p2t7y]  { border-left-color: #64748b; }
.stat-green[b-whkz2p2t7y]  { border-left-color: #22c55e; }
.stat-emerald[b-whkz2p2t7y] { border-left-color: #10b981; }

/* ── Sections ── */
.dash-section[b-whkz2p2t7y] {
    margin-bottom: 2rem;
}

.dash-section h2[b-whkz2p2t7y] {
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
    color: rgba(255, 255, 255, 0.85);
}

/* ── Alerts ── */
.alerts-list[b-whkz2p2t7y] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.alert-row[b-whkz2p2t7y] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    padding: 0.85rem 1rem;
    text-decoration: none;
    color: #e5e7eb;
    transition: background 120ms ease, border-color 120ms ease;
    border-left: 3px solid transparent;
}

.alert-row:hover[b-whkz2p2t7y] {
    background: #161d2e;
    border-color: rgba(255, 255, 255, 0.15);
}

.alert-danger[b-whkz2p2t7y]  { border-left-color: #ef4444; }
.alert-warning[b-whkz2p2t7y] { border-left-color: #f59e0b; }
.alert-info[b-whkz2p2t7y]    { border-left-color: #3b82f6; }

.alert-icon[b-whkz2p2t7y] {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
}

.alert-icon svg[b-whkz2p2t7y] {
    width: 20px;
    height: 20px;
}

.alert-danger .alert-icon[b-whkz2p2t7y]  { color: #ef4444; }
.alert-warning .alert-icon[b-whkz2p2t7y] { color: #f59e0b; }
.alert-info .alert-icon[b-whkz2p2t7y]    { color: #3b82f6; }

.alert-content[b-whkz2p2t7y] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-shrink: 0;
}

.alert-title[b-whkz2p2t7y] {
    font-weight: 700;
    font-size: 0.88rem;
    white-space: nowrap;
}

.alert-count[b-whkz2p2t7y] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 6px;
    border-radius: 11px;
    font-size: 0.72rem;
    font-weight: 700;
    color: white;
}

.alert-danger .alert-count[b-whkz2p2t7y]  { background: rgba(239, 68, 68, 0.3); }
.alert-warning .alert-count[b-whkz2p2t7y] { background: rgba(245, 158, 11, 0.3); }
.alert-info .alert-count[b-whkz2p2t7y]    { background: rgba(59, 130, 246, 0.3); }

.alert-message[b-whkz2p2t7y] {
    flex: 1;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.55);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.alert-arrow[b-whkz2p2t7y] {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    color: rgba(255, 255, 255, 0.25);
}

/* ── Quick actions ── */
.quick-grid[b-whkz2p2t7y] {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.75rem;
}

@media (max-width: 900px) {
    .quick-grid[b-whkz2p2t7y] { grid-template-columns: repeat(2, 1fr); }
}

.quick-card[b-whkz2p2t7y] {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    padding: 0.85rem 1rem;
    text-decoration: none;
    color: rgba(255, 255, 255, 0.8);
    font-size: 0.88rem;
    font-weight: 600;
    transition: background 120ms ease, transform 120ms ease, color 120ms ease;
}

.quick-card:hover[b-whkz2p2t7y] {
    background: #161d2e;
    transform: translateY(-1px);
    color: white;
}

.quick-card svg[b-whkz2p2t7y] {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    color: #6366f1;
}

/* ── Activity timeline ── */
.activity-list[b-whkz2p2t7y] {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.activity-row[b-whkz2p2t7y] {
    display: flex;
    align-items: baseline;
    gap: 1rem;
    padding: 0.6rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    font-size: 0.82rem;
}

.activity-row:last-child[b-whkz2p2t7y] {
    border-bottom: none;
}

.activity-time[b-whkz2p2t7y] {
    flex-shrink: 0;
    width: 72px;
    color: rgba(255, 255, 255, 0.4);
    font-size: 0.75rem;
    font-variant-numeric: tabular-nums;
}

.activity-details[b-whkz2p2t7y] {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.4rem;
    flex: 1;
}

.activity-action[b-whkz2p2t7y] {
    font-weight: 600;
    color: rgba(255, 255, 255, 0.85);
}

.activity-entity[b-whkz2p2t7y] {
    padding: 0.1rem 0.4rem;
    background: rgba(99, 102, 241, 0.15);
    border-radius: 4px;
    font-size: 0.72rem;
    font-weight: 600;
    color: #a5b4fc;
}

.activity-user[b-whkz2p2t7y] {
    color: rgba(255, 255, 255, 0.4);
    font-size: 0.75rem;
}

.activity-reason[b-whkz2p2t7y] {
    margin-top: 0.25rem;
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.35);
    font-style: italic;
    padding-left: calc(72px + 1rem);
}

/* ── Error state ── */
.dash-error[b-whkz2p2t7y] {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.25);
    border-radius: 10px;
    padding: 1.5rem;
    text-align: center;
}

.dash-error p[b-whkz2p2t7y] {
    margin: 0 0 1rem;
    color: #fca5a5;
}

.btn-retry[b-whkz2p2t7y] {
    padding: 0.5rem 1.25rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: white;
    font-weight: 600;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-retry:hover[b-whkz2p2t7y] {
    background: rgba(99, 102, 241, 0.35);
}
/* _content/Mathos.App/Components/Pages/admin/Messages.razor.rz.scp.css */
/* ═══════════════════════════════════════════════
   Messages Audit — admin page
   ═══════════════════════════════════════════════ */

/* ── Page header ── */
.page-header[b-9mt7qcxm70] {
    display: flex;
    align-items: baseline;
    gap: 0.75rem;
    margin-bottom: 1.25rem;
}

.page-header h1[b-9mt7qcxm70] {
    font-size: 1.35rem;
    font-weight: 700;
    color: white;
    margin: 0;
}

.page-subtitle[b-9mt7qcxm70] {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.3);
}

/* ── Tabs ── */
.tab-bar[b-9mt7qcxm70] {
    display: flex;
    gap: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    margin-bottom: 1.5rem;
}

.tab[b-9mt7qcxm70] {
    padding: 0.6rem 1.25rem;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    color: rgba(255, 255, 255, 0.4);
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: all 120ms ease;
}

.tab:hover[b-9mt7qcxm70] {
    color: rgba(255, 255, 255, 0.6);
}

.tab.active[b-9mt7qcxm70] {
    color: #a5b4fc;
    border-bottom-color: #6366f1;
}

/* ── Loading / Error / Empty ── */
.loading-row[b-9mt7qcxm70] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 3rem 0;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.9rem;
}

.spinner[b-9mt7qcxm70] {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: spin-b-9mt7qcxm70 0.6s linear infinite;
}

@keyframes spin-b-9mt7qcxm70 {
    to { transform: rotate(360deg); }
}

.error-banner[b-9mt7qcxm70] {
    padding: 0.65rem 1rem;
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-radius: 8px;
    color: #f87171;
    font-size: 0.82rem;
    margin-bottom: 1rem;
}

.empty-state[b-9mt7qcxm70] {
    text-align: center;
    padding: 2.5rem 1rem;
    color: rgba(255, 255, 255, 0.35);
    font-size: 0.88rem;
}

/* ── Filter bar ── */
.filter-bar[b-9mt7qcxm70] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.filter-input[b-9mt7qcxm70] {
    padding: 0.4rem 0.6rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    color: white;
    font-size: 0.82rem;
    font-family: inherit;
    min-width: 180px;
}

.filter-input:focus[b-9mt7qcxm70] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.filter-select[b-9mt7qcxm70] {
    padding: 0.4rem 0.6rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    color: white;
    font-size: 0.82rem;
    font-family: inherit;
}

.filter-select option[b-9mt7qcxm70] {
    background: #1a1f2e;
    color: white;
}

.btn-apply[b-9mt7qcxm70] {
    padding: 0.4rem 0.85rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 6px;
    color: #a5b4fc;
    font-weight: 700;
    font-size: 0.78rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-apply:hover[b-9mt7qcxm70] {
    background: rgba(99, 102, 241, 0.35);
}

.btn-clear[b-9mt7qcxm70] {
    padding: 0.4rem 0.85rem;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    font-size: 0.78rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-clear:hover[b-9mt7qcxm70] {
    background: rgba(255, 255, 255, 0.04);
}

/* ── Active filter banner ── */
.active-filter-banner[b-9mt7qcxm70] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    background: rgba(99, 102, 241, 0.06);
    border: 1px solid rgba(99, 102, 241, 0.15);
    border-radius: 8px;
    margin-bottom: 0.75rem;
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.5);
}

.active-filter-banner span[b-9mt7qcxm70] {
    font-weight: 600;
    color: #a5b4fc;
}

.btn-clear-filter[b-9mt7qcxm70] {
    margin-left: auto;
    padding: 0.2rem 0.5rem;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 4px;
    color: rgba(255, 255, 255, 0.4);
    font-size: 0.7rem;
    cursor: pointer;
    transition: all 120ms ease;
}

.btn-clear-filter:hover[b-9mt7qcxm70] {
    background: rgba(255, 255, 255, 0.04);
    color: rgba(255, 255, 255, 0.7);
}

/* ── Data table ── */
.data-table-wrap[b-9mt7qcxm70] {
    overflow-x: auto;
    margin-bottom: 0.75rem;
}

.data-table[b-9mt7qcxm70] {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.8rem;
}

.data-table th[b-9mt7qcxm70] {
    text-align: left;
    padding: 0.55rem 0.75rem;
    font-weight: 700;
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: rgba(255, 255, 255, 0.35);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    white-space: nowrap;
}

.data-table td[b-9mt7qcxm70] {
    padding: 0.55rem 0.75rem;
    color: rgba(255, 255, 255, 0.7);
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.data-table tbody tr[b-9mt7qcxm70] {
    cursor: pointer;
    transition: background 120ms ease;
}

.data-table tbody tr:hover[b-9mt7qcxm70] {
    background: rgba(255, 255, 255, 0.02);
}

.row-deleted[b-9mt7qcxm70] {
    opacity: 0.55;
}

.row-deleted:hover[b-9mt7qcxm70] {
    opacity: 0.75;
}

.row-expanded[b-9mt7qcxm70] {
    background: rgba(99, 102, 241, 0.04) !important;
}

.col-name[b-9mt7qcxm70] {
    font-weight: 600;
    white-space: nowrap;
}

.col-count[b-9mt7qcxm70] {
    font-weight: 700;
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.82rem;
}

.col-timestamp[b-9mt7qcxm70] {
    white-space: nowrap;
    color: rgba(255, 255, 255, 0.4);
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.72rem;
}

.col-content[b-9mt7qcxm70] {
    max-width: 400px;
    word-break: break-word;
    line-height: 1.45;
}

/* ── Badges ── */
.badge[b-9mt7qcxm70] {
    display: inline-flex;
    align-items: center;
    padding: 0.1rem 0.4rem;
    border-radius: 5px;
    font-size: 0.64rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.badge-parent[b-9mt7qcxm70] {
    background: rgba(59, 130, 246, 0.15);
    color: #93c5fd;
}

.badge-tutor[b-9mt7qcxm70] {
    background: rgba(16, 185, 129, 0.15);
    color: #6ee7b7;
}

.badge-active[b-9mt7qcxm70] {
    background: rgba(34, 197, 94, 0.15);
    color: #4ade80;
}

.badge-expired[b-9mt7qcxm70] {
    background: rgba(100, 116, 139, 0.15);
    color: #94a3b8;
}

/* ── View button ── */
.btn-view[b-9mt7qcxm70] {
    padding: 0.2rem 0.6rem;
    background: rgba(99, 102, 241, 0.12);
    border: 1px solid rgba(99, 102, 241, 0.25);
    border-radius: 5px;
    color: #a5b4fc;
    font-size: 0.72rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 120ms ease;
}

.btn-view:hover[b-9mt7qcxm70] {
    background: rgba(99, 102, 241, 0.25);
}

/* ── Pagination ── */
.pagination[b-9mt7qcxm70] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.5rem 0;
}

.page-info[b-9mt7qcxm70] {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.35);
}

.page-buttons[b-9mt7qcxm70] {
    display: flex;
    gap: 0.35rem;
}

.btn-page[b-9mt7qcxm70] {
    padding: 0.35rem 0.75rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    font-size: 0.75rem;
    cursor: pointer;
    transition: all 120ms ease;
}

.btn-page:hover:not(:disabled)[b-9mt7qcxm70] {
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.8);
}

.btn-page:disabled[b-9mt7qcxm70] {
    opacity: 0.3;
    cursor: not-allowed;
}
/* _content/Mathos.App/Components/Pages/admin/ParentDetail.razor.rz.scp.css */
/* ═══════════════════════════════════════════════
   Parent Detail — admin detail page
   ═══════════════════════════════════════════════ */

/* ── Loading / Error ── */
.detail-loading[b-njumsd9d14] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 3rem 0;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.9rem;
}

.spinner[b-njumsd9d14] {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: spin-b-njumsd9d14 0.6s linear infinite;
}

.spinner-sm[b-njumsd9d14] {
    display: inline-block;
    width: 14px;
    height: 14px;
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-top-color: white;
    border-radius: 50%;
    animation: spin-b-njumsd9d14 0.6s linear infinite;
    margin-right: 6px;
    vertical-align: middle;
}

@keyframes spin-b-njumsd9d14 {
    to { transform: rotate(360deg); }
}

.detail-error[b-njumsd9d14] {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.25);
    border-radius: 10px;
    padding: 1.5rem;
    text-align: center;
}

.detail-error p[b-njumsd9d14] {
    margin: 0 0 1rem;
    color: #fca5a5;
}

.btn-retry[b-njumsd9d14] {
    padding: 0.5rem 1.25rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: white;
    font-weight: 600;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-retry:hover[b-njumsd9d14] {
    background: rgba(99, 102, 241, 0.35);
}

/* ── Header ── */
.detail-header[b-njumsd9d14] {
    margin-bottom: 1.5rem;
}

.btn-back[b-njumsd9d14] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: none;
    border: none;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.82rem;
    cursor: pointer;
    padding: 0;
    margin-bottom: 1rem;
    transition: color 120ms ease;
}

.btn-back:hover[b-njumsd9d14] {
    color: white;
}

.btn-back svg[b-njumsd9d14] {
    width: 16px;
    height: 16px;
}

.header-info h1[b-njumsd9d14] {
    font-size: 1.5rem;
    font-weight: 800;
    color: white;
    margin: 0 0 0.5rem;
}

.header-meta[b-njumsd9d14] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.meta-item[b-njumsd9d14] {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.45);
}

.header-stats[b-njumsd9d14] {
    display: flex;
    gap: 1.5rem;
    margin-top: 1rem;
}

.mini-stat[b-njumsd9d14] {
    display: flex;
    flex-direction: column;
    align-items: center;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    padding: 0.75rem 1.25rem;
    min-width: 80px;
}

.mini-stat-value[b-njumsd9d14] {
    font-size: 1.25rem;
    font-weight: 800;
    color: white;
}

.mini-stat-label[b-njumsd9d14] {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    margin-top: 0.15rem;
}

/* ── Tabs ── */
.tab-bar[b-njumsd9d14] {
    display: flex;
    gap: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    margin-bottom: 1.5rem;
}

.tab-btn[b-njumsd9d14] {
    padding: 0.65rem 1.25rem;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    color: rgba(255, 255, 255, 0.45);
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: color 120ms ease, border-color 120ms ease;
}

.tab-btn:hover[b-njumsd9d14] {
    color: rgba(255, 255, 255, 0.75);
}

.tab-btn.active[b-njumsd9d14] {
    color: #a5b4fc;
    border-bottom-color: #6366f1;
}

/* ── Info grid (Account tab) ── */
.info-grid[b-njumsd9d14] {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

@media (max-width: 800px) {
    .info-grid[b-njumsd9d14] { grid-template-columns: 1fr; }
}

.info-card[b-njumsd9d14] {
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    padding: 1.25rem;
}

.info-card.full-width[b-njumsd9d14] {
    grid-column: 1 / -1;
}

.info-card h3[b-njumsd9d14] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.92rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.85);
    margin: 0 0 1rem;
}

.card-icon[b-njumsd9d14] {
    width: 18px;
    height: 18px;
    color: #6366f1;
}

.info-row[b-njumsd9d14] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.4rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.info-row:last-child[b-njumsd9d14] {
    border-bottom: none;
}

.info-label[b-njumsd9d14] {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.45);
    font-weight: 500;
}

.info-value[b-njumsd9d14] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.85);
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.empty-inline[b-njumsd9d14] {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.3);
    font-style: italic;
}

/* ── Stripe ID styling ── */
.stripe-id[b-njumsd9d14] {
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.78rem;
    background: rgba(255, 255, 255, 0.04);
    padding: 0.15rem 0.4rem;
    border-radius: 4px;
    color: rgba(255, 255, 255, 0.65);
    user-select: all;
}

/* ── Badges ── */
.badge[b-njumsd9d14] {
    display: inline-flex;
    align-items: center;
    padding: 0.15rem 0.5rem;
    border-radius: 6px;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.badge-active[b-njumsd9d14] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-inactive[b-njumsd9d14] { background: rgba(100, 116, 139, 0.2); color: #94a3b8; }
.badge-plan[b-njumsd9d14] { background: rgba(99, 102, 241, 0.15); color: #a5b4fc; }
.badge-expired[b-njumsd9d14] { background: rgba(239, 68, 68, 0.15); color: #f87171; }
.badge-expiring[b-njumsd9d14] { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }
.badge-primary-contact[b-njumsd9d14] { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }

.badge-completed[b-njumsd9d14] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-confirmed[b-njumsd9d14] { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }
.badge-cancelled[b-njumsd9d14] { background: rgba(239, 68, 68, 0.15); color: #f87171; }
.badge-pending[b-njumsd9d14] { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }

/* ── Buttons ── */
.btn-primary[b-njumsd9d14] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.6rem 1.25rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: white;
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-primary:hover[b-njumsd9d14] { background: rgba(99, 102, 241, 0.35); }
.btn-primary:disabled[b-njumsd9d14] { opacity: 0.4; cursor: not-allowed; }

.btn-icon-danger[b-njumsd9d14] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: none;
    border: 1px solid transparent;
    border-radius: 6px;
    color: rgba(255, 255, 255, 0.3);
    cursor: pointer;
    transition: color 120ms ease, background 120ms ease;
    padding: 0;
}

.btn-icon-danger:hover[b-njumsd9d14] {
    color: #f87171;
    background: rgba(239, 68, 68, 0.1);
    border-color: rgba(239, 68, 68, 0.2);
}

.btn-icon-danger svg[b-njumsd9d14] {
    width: 15px;
    height: 15px;
}

/* ── Data tables ── */
.data-table-wrap[b-njumsd9d14] {
    overflow-x: auto;
}

.data-table[b-njumsd9d14] {
    width: 100%;
    border-collapse: collapse;
}

.data-table th[b-njumsd9d14] {
    text-align: left;
    padding: 0.6rem 0.75rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.data-table td[b-njumsd9d14] {
    padding: 0.65rem 0.75rem;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.75);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.data-table tbody tr:hover[b-njumsd9d14] {
    background: rgba(255, 255, 255, 0.02);
}

.clickable-row[b-njumsd9d14] {
    cursor: pointer;
    transition: background 120ms ease;
}

.clickable-row:hover[b-njumsd9d14] {
    background: rgba(99, 102, 241, 0.08) !important;
}

.empty-state[b-njumsd9d14] {
    text-align: center;
    padding: 2.5rem 1rem;
    color: rgba(255, 255, 255, 0.35);
    font-size: 0.88rem;
}

/* ── Notes ── */
.notes-section[b-njumsd9d14] {
    max-width: 700px;
}

.note-form[b-njumsd9d14] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 1.5rem;
}

.note-input[b-njumsd9d14] {
    width: 100%;
    padding: 0.75rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: white;
    font-size: 0.85rem;
    font-family: inherit;
    resize: vertical;
    min-height: 60px;
}

.note-input:focus[b-njumsd9d14] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.note-input[b-njumsd9d14]::placeholder {
    color: rgba(255, 255, 255, 0.25);
}

.notes-list[b-njumsd9d14] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.note-card[b-njumsd9d14] {
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    padding: 0.85rem 1rem;
}

.note-header[b-njumsd9d14] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.note-author[b-njumsd9d14] {
    font-size: 0.78rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.65);
}

.note-date[b-njumsd9d14] {
    font-size: 0.72rem;
    color: rgba(255, 255, 255, 0.3);
    flex: 1;
}

.note-content[b-njumsd9d14] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.7);
    line-height: 1.5;
    margin: 0;
    white-space: pre-wrap;
}
/* _content/Mathos.App/Components/Pages/admin/Payments.razor.rz.scp.css */
/* ═══════════════════════════════════════════════
   Payments & Revenue — admin page
   ═══════════════════════════════════════════════ */

/* ── Tabs ── */
.tab-bar[b-w9ueis728q] {
    display: flex;
    gap: 0.25rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    margin-bottom: 1.5rem;
    overflow-x: auto;
}

.tab[b-w9ueis728q] {
    padding: 0.6rem 1.2rem;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    color: rgba(255, 255, 255, 0.45);
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    white-space: nowrap;
    transition: color 150ms ease, border-color 150ms ease;
}

.tab:hover[b-w9ueis728q] {
    color: rgba(255, 255, 255, 0.7);
}

.tab.active[b-w9ueis728q] {
    color: #a5b4fc;
    border-bottom-color: #6366f1;
}

/* ── Loading ── */
.loading-row[b-w9ueis728q] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 3rem 0;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.9rem;
}

.spinner[b-w9ueis728q] {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: spin-b-w9ueis728q 0.6s linear infinite;
}

@keyframes spin-b-w9ueis728q {
    to { transform: rotate(360deg); }
}

.empty-state[b-w9ueis728q] {
    text-align: center;
    padding: 2.5rem 1rem;
    color: rgba(255, 255, 255, 0.35);
    font-size: 0.88rem;
}

/* ── Stat cards ── */
.stats-grid[b-w9ueis728q] {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.stat-card[b-w9ueis728q] {
    padding: 1.25rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.stat-label[b-w9ueis728q] {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
}

.stat-value[b-w9ueis728q] {
    font-size: 1.5rem;
    font-weight: 800;
    color: white;
    font-variant-numeric: tabular-nums;
}

.card-subs[b-w9ueis728q] {
    border-color: rgba(99, 102, 241, 0.25);
}

.card-subs .stat-value[b-w9ueis728q] {
    color: #a5b4fc;
}

.card-revenue[b-w9ueis728q] {
    border-color: rgba(16, 185, 129, 0.25);
    background: rgba(16, 185, 129, 0.04);
}

.card-revenue .stat-value[b-w9ueis728q] {
    color: #4ade80;
}

.card-commission[b-w9ueis728q] {
    border-color: rgba(16, 185, 129, 0.2);
}

.card-commission .stat-value[b-w9ueis728q] {
    color: #6ee7b7;
}

.card-refunds[b-w9ueis728q] {
    border-color: rgba(239, 68, 68, 0.2);
}

.card-refunds .stat-value[b-w9ueis728q] {
    color: #f87171;
    font-size: 1.1rem;
}

/* ── Section headings ── */
h2[b-w9ueis728q] {
    font-size: 1.05rem;
    font-weight: 700;
    margin: 1.5rem 0 0.75rem;
    color: rgba(255, 255, 255, 0.85);
}

/* ── Sessions note ── */
.sessions-note[b-w9ueis728q] {
    margin-top: 1rem;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.45);
}

.sessions-value[b-w9ueis728q] {
    font-weight: 800;
    color: white;
    font-size: 1.1rem;
}

/* ── Data table ── */
.data-table-wrap[b-w9ueis728q] {
    overflow-x: auto;
}

.data-table[b-w9ueis728q] {
    width: 100%;
    border-collapse: collapse;
}

.data-table th[b-w9ueis728q] {
    text-align: left;
    padding: 0.6rem 0.75rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.data-table td[b-w9ueis728q] {
    padding: 0.55rem 0.75rem;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.75);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.data-table tbody tr[b-w9ueis728q] {
    transition: background 120ms ease;
}

.data-table tbody tr:hover[b-w9ueis728q] {
    background: rgba(255, 255, 255, 0.02);
}

.col-num[b-w9ueis728q] {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.col-timestamp[b-w9ueis728q] {
    white-space: nowrap;
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.78rem;
}

.col-stripe[b-w9ueis728q] {
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.74rem;
    color: rgba(255, 255, 255, 0.4);
    max-width: 160px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.col-refund[b-w9ueis728q] {
    color: #f87171 !important;
    font-weight: 700;
}

/* ── Badges ── */
.badge[b-w9ueis728q] {
    display: inline-flex;
    align-items: center;
    padding: 0.12rem 0.45rem;
    border-radius: 5px;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    white-space: nowrap;
}

/* Status badges */
.badge-completed[b-w9ueis728q] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-confirmed[b-w9ueis728q] { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }
.badge-cancelled[b-w9ueis728q] { background: rgba(239, 68, 68, 0.15); color: #f87171; }
.badge-default[b-w9ueis728q] { background: rgba(100, 116, 139, 0.15); color: #94a3b8; }

/* Plan badges */
.badge-standard[b-w9ueis728q] { background: rgba(99, 102, 241, 0.15); color: #a5b4fc; }
.badge-twin[b-w9ueis728q] { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }
.badge-family[b-w9ueis728q] { background: rgba(16, 185, 129, 0.15); color: #6ee7b7; }
.badge-bulk[b-w9ueis728q] { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }
.badge-none[b-w9ueis728q] { background: rgba(100, 116, 139, 0.1); color: rgba(255, 255, 255, 0.35); }

/* ── Export panel ── */
.export-panel[b-w9ueis728q] {
    max-width: 640px;
}

.export-header h2[b-w9ueis728q] {
    margin-top: 0;
}

.export-desc[b-w9ueis728q] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.5);
    line-height: 1.5;
    margin: 0 0 1.25rem;
}

.info-note[b-w9ueis728q] {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    padding: 0.85rem 1rem;
    background: rgba(59, 130, 246, 0.08);
    border: 1px solid rgba(59, 130, 246, 0.2);
    border-radius: 10px;
    margin-bottom: 1.25rem;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.6);
    line-height: 1.5;
}

.info-note code[b-w9ueis728q] {
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.76rem;
    color: rgba(255, 255, 255, 0.7);
    background: rgba(255, 255, 255, 0.06);
    padding: 0.1rem 0.3rem;
    border-radius: 4px;
}

.info-icon[b-w9ueis728q] {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    color: #60a5fa;
    margin-top: 0.1rem;
}

.export-form[b-w9ueis728q] {
    padding: 1.25rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    margin-bottom: 1rem;
}

.export-fields[b-w9ueis728q] {
    display: flex;
    gap: 1rem;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}

.filter-group[b-w9ueis728q] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.filter-label[b-w9ueis728q] {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
}

.filter-input[b-w9ueis728q] {
    padding: 0.45rem 0.65rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: white;
    font-size: 0.82rem;
    font-family: inherit;
    min-width: 150px;
}

.filter-input:focus[b-w9ueis728q] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.btn-export[b-w9ueis728q] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.55rem 1.25rem;
    background: rgba(16, 185, 129, 0.2);
    border: 1px solid rgba(16, 185, 129, 0.4);
    border-radius: 8px;
    color: #6ee7b7;
    font-weight: 700;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-export:hover:not(:disabled)[b-w9ueis728q] {
    background: rgba(16, 185, 129, 0.35);
}

.btn-export:disabled[b-w9ueis728q] {
    opacity: 0.35;
    cursor: not-allowed;
}

.btn-icon[b-w9ueis728q] {
    width: 16px;
    height: 16px;
}

.spinner-sm[b-w9ueis728q] {
    width: 14px;
    height: 14px;
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-top-color: currentColor;
    border-radius: 50%;
    animation: spin-b-w9ueis728q 0.6s linear infinite;
}

.export-warning[b-w9ueis728q] {
    font-size: 0.82rem;
    color: #f87171;
    margin-top: 0.5rem;
}

.export-columns[b-w9ueis728q] {
    margin-top: 1rem;
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.35);
}

.export-columns-label[b-w9ueis728q] {
    font-weight: 600;
    color: rgba(255, 255, 255, 0.45);
}

.export-columns code[b-w9ueis728q] {
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.72rem;
    color: rgba(255, 255, 255, 0.5);
    display: block;
    margin-top: 0.25rem;
    background: rgba(255, 255, 255, 0.03);
    padding: 0.5rem 0.75rem;
    border-radius: 6px;
    border: 1px solid rgba(255, 255, 255, 0.06);
}
/* _content/Mathos.App/Components/Pages/admin/QuestionBank.razor.rz.scp.css */
/* ═══════════════════════════════════════════════
   Question Bank — admin page
   ═══════════════════════════════════════════════ */

/* ── Alerts ── */
.alert-error[b-mqz3p99k1g] {
    padding: 0.65rem 1rem;
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-radius: 8px;
    color: #f87171;
    font-size: 0.85rem;
    margin-bottom: 1rem;
}

.alert-success[b-mqz3p99k1g] {
    padding: 0.65rem 1rem;
    background: rgba(34, 197, 94, 0.1);
    border: 1px solid rgba(34, 197, 94, 0.3);
    border-radius: 8px;
    color: #4ade80;
    font-size: 0.85rem;
    margin-bottom: 1rem;
}

/* ── Filter bar ── */
.filter-bar[b-mqz3p99k1g] {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    align-items: flex-end;
    margin-bottom: 1rem;
    padding: 1rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
}

.filter-group[b-mqz3p99k1g] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.filter-label[b-mqz3p99k1g] {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
}

.filter-input[b-mqz3p99k1g] {
    padding: 0.45rem 0.65rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: white;
    font-size: 0.82rem;
    font-family: inherit;
    min-width: 120px;
}

.filter-topic[b-mqz3p99k1g] {
    min-width: 220px;
}

.filter-input:focus[b-mqz3p99k1g] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.filter-actions[b-mqz3p99k1g] {
    display: flex;
    gap: 0.5rem;
    align-items: flex-end;
}

.btn-clear[b-mqz3p99k1g] {
    padding: 0.45rem 1rem;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    font-size: 0.82rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-clear:hover[b-mqz3p99k1g] {
    background: rgba(255, 255, 255, 0.04);
}

/* ── Actions bar ── */
.actions-bar[b-mqz3p99k1g] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.count-summary[b-mqz3p99k1g] {
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.4);
}

.btn-add[b-mqz3p99k1g] {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.5rem 1rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: #a5b4fc;
    font-weight: 700;
    font-size: 0.82rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-add:hover[b-mqz3p99k1g] {
    background: rgba(99, 102, 241, 0.35);
}

.btn-icon[b-mqz3p99k1g] {
    width: 16px;
    height: 16px;
}

/* ── Loading ── */
.loading-row[b-mqz3p99k1g] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 3rem 0;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.9rem;
}

.spinner[b-mqz3p99k1g] {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: spin-b-mqz3p99k1g 0.6s linear infinite;
}

@keyframes spin-b-mqz3p99k1g {
    to { transform: rotate(360deg); }
}

.empty-state[b-mqz3p99k1g] {
    text-align: center;
    padding: 2.5rem 1rem;
    color: rgba(255, 255, 255, 0.35);
    font-size: 0.88rem;
}

/* ── Data table ── */
.data-table-wrap[b-mqz3p99k1g] {
    overflow-x: auto;
}

.data-table[b-mqz3p99k1g] {
    width: 100%;
    border-collapse: collapse;
}

.data-table th[b-mqz3p99k1g] {
    text-align: left;
    padding: 0.6rem 0.75rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.data-table td[b-mqz3p99k1g] {
    padding: 0.55rem 0.75rem;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.75);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.data-table tbody tr[b-mqz3p99k1g] {
    transition: background 120ms ease;
}

.data-table tbody tr:hover[b-mqz3p99k1g] {
    background: rgba(255, 255, 255, 0.02);
}

.col-topic[b-mqz3p99k1g] {
    color: rgba(255, 255, 255, 0.45);
    font-size: 0.78rem;
}

.col-num[b-mqz3p99k1g] {
    text-align: right;
    font-variant-numeric: tabular-nums;
    font-weight: 700;
}

.col-actions[b-mqz3p99k1g] {
    display: flex;
    gap: 0.35rem;
}

/* ── Badges ── */
.badge[b-mqz3p99k1g] {
    display: inline-flex;
    align-items: center;
    padding: 0.12rem 0.45rem;
    border-radius: 5px;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    white-space: nowrap;
}

/* Difficulty */
.badge-diff-1[b-mqz3p99k1g] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-diff-2[b-mqz3p99k1g] { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }
.badge-diff-3[b-mqz3p99k1g] { background: rgba(239, 68, 68, 0.15); color: #f87171; }

/* Tier */
.badge-tier-both[b-mqz3p99k1g] { background: rgba(100, 116, 139, 0.15); color: #94a3b8; }
.badge-tier-foundation[b-mqz3p99k1g] { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }
.badge-tier-higher[b-mqz3p99k1g] { background: rgba(168, 85, 247, 0.15); color: #c4b5fd; }

/* Active status */
.badge-active[b-mqz3p99k1g] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-inactive[b-mqz3p99k1g] { background: rgba(100, 116, 139, 0.15); color: #64748b; }

/* ── Action buttons ── */
.btn-action[b-mqz3p99k1g] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    padding: 0;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 6px;
    color: rgba(255, 255, 255, 0.5);
    cursor: pointer;
    transition: background 120ms ease, color 120ms ease;
}

.btn-action:hover[b-mqz3p99k1g] {
    background: rgba(255, 255, 255, 0.1);
    color: white;
}

.btn-action-danger:hover[b-mqz3p99k1g] {
    background: rgba(239, 68, 68, 0.15);
    color: #f87171;
}

.action-icon[b-mqz3p99k1g] {
    width: 14px;
    height: 14px;
}

/* ═══════════════════════════════════════════════
   Modal
   ═══════════════════════════════════════════════ */

.modal-overlay[b-mqz3p99k1g] {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.65);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 3rem 1rem;
    z-index: 1000;
    overflow-y: auto;
}

.modal-content[b-mqz3p99k1g] {
    width: 100%;
    max-width: 680px;
    background: #0f1623;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 16px;
    box-shadow: 0 25px 60px rgba(0, 0, 0, 0.5);
}

.modal-header[b-mqz3p99k1g] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.modal-header h3[b-mqz3p99k1g] {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 700;
    color: white;
}

.modal-close[b-mqz3p99k1g] {
    background: none;
    border: none;
    color: rgba(255, 255, 255, 0.4);
    font-size: 1.5rem;
    cursor: pointer;
    line-height: 1;
    padding: 0 0.25rem;
    transition: color 120ms ease;
}

.modal-close:hover[b-mqz3p99k1g] {
    color: white;
}

.modal-body[b-mqz3p99k1g] {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.modal-footer[b-mqz3p99k1g] {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    padding: 1rem 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

/* ── Form fields ── */
.form-row[b-mqz3p99k1g] {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.form-group[b-mqz3p99k1g] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    flex: 1;
    min-width: 120px;
}

.form-group-wide[b-mqz3p99k1g] {
    flex: 1 1 100%;
}

.form-label[b-mqz3p99k1g] {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
}

.form-input[b-mqz3p99k1g] {
    padding: 0.5rem 0.65rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: white;
    font-size: 0.85rem;
    font-family: inherit;
}

.form-input:focus[b-mqz3p99k1g] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.form-textarea[b-mqz3p99k1g] {
    resize: vertical;
    min-height: 80px;
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.82rem;
    line-height: 1.5;
}

/* ── LaTeX preview ── */
.latex-header[b-mqz3p99k1g] {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.btn-preview[b-mqz3p99k1g] {
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.72rem;
    font-weight: 600;
    padding: 0.2rem 0.5rem;
    cursor: pointer;
    transition: background 120ms ease, color 120ms ease;
}

.btn-preview:hover[b-mqz3p99k1g] {
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.8);
}

.latex-preview[b-mqz3p99k1g] {
    padding: 0.85rem 1rem;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.9rem;
    min-height: 40px;
    overflow-x: auto;
    margin-top: 0.35rem;
}

/* ── Modal buttons ── */
.btn-cancel[b-mqz3p99k1g] {
    padding: 0.5rem 1rem;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-cancel:hover[b-mqz3p99k1g] {
    background: rgba(255, 255, 255, 0.04);
}

.btn-save[b-mqz3p99k1g] {
    padding: 0.5rem 1.25rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: #a5b4fc;
    font-weight: 700;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-save:hover:not(:disabled)[b-mqz3p99k1g] {
    background: rgba(99, 102, 241, 0.35);
}

.btn-save:disabled[b-mqz3p99k1g] {
    opacity: 0.35;
    cursor: not-allowed;
}
/* _content/Mathos.App/Components/Pages/admin/Safeguarding.razor.rz.scp.css */
/* ═══════════════════════════════════════════════
   Safeguarding Concerns — admin page
   ═══════════════════════════════════════════════ */

/* ── Filter bar ── */
.filter-bar[b-eo9y6c2jfq] {
    display: flex;
    gap: 0.75rem;
    align-items: flex-end;
    flex-wrap: wrap;
    margin-bottom: 1rem;
    padding: 1rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
}

.filter-group[b-eo9y6c2jfq] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.filter-label[b-eo9y6c2jfq] {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
}

.filter-select[b-eo9y6c2jfq],
.filter-input[b-eo9y6c2jfq] {
    padding: 0.45rem 0.65rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: white;
    font-size: 0.82rem;
    font-family: inherit;
    min-width: 120px;
}

.filter-select:focus[b-eo9y6c2jfq],
.filter-input:focus[b-eo9y6c2jfq] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.filter-select option[b-eo9y6c2jfq] {
    background: #1a2035;
    color: white;
}

.filter-actions[b-eo9y6c2jfq] {
    display: flex;
    gap: 0.4rem;
    align-items: flex-end;
}

.btn-apply[b-eo9y6c2jfq] {
    padding: 0.45rem 1rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: white;
    font-weight: 600;
    font-size: 0.82rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-apply:hover[b-eo9y6c2jfq] {
    background: rgba(99, 102, 241, 0.35);
}

.btn-clear[b-eo9y6c2jfq] {
    padding: 0.45rem 0.85rem;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    font-size: 0.82rem;
    cursor: pointer;
    transition: color 120ms ease, border-color 120ms ease;
}

.btn-clear:hover[b-eo9y6c2jfq] {
    color: white;
    border-color: rgba(255, 255, 255, 0.25);
}

/* ── Create section ── */
.create-section[b-eo9y6c2jfq] {
    margin-bottom: 1.5rem;
}

.btn-log-concern[b-eo9y6c2jfq] {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.5rem 1rem;
    background: rgba(236, 72, 153, 0.15);
    border: 1px solid rgba(236, 72, 153, 0.35);
    border-radius: 8px;
    color: #f9a8d4;
    font-weight: 700;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-log-concern:hover[b-eo9y6c2jfq] {
    background: rgba(236, 72, 153, 0.25);
}

.btn-icon[b-eo9y6c2jfq] {
    width: 16px;
    height: 16px;
}

.create-form[b-eo9y6c2jfq] {
    margin-top: 0.75rem;
    padding: 1.25rem;
    background: #121826;
    border: 1px solid rgba(236, 72, 153, 0.2);
    border-radius: 12px;
}

.form-row[b-eo9y6c2jfq] {
    display: flex;
    gap: 1rem;
    margin-bottom: 0.75rem;
    flex-wrap: wrap;
}

.form-group[b-eo9y6c2jfq] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    flex: 1;
    min-width: 150px;
}

.form-group.full-width[b-eo9y6c2jfq] {
    flex-basis: 100%;
    margin-bottom: 0.75rem;
}

.form-label[b-eo9y6c2jfq] {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: rgba(255, 255, 255, 0.45);
}

.form-input[b-eo9y6c2jfq],
.form-select[b-eo9y6c2jfq],
.form-textarea[b-eo9y6c2jfq] {
    padding: 0.5rem 0.7rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: white;
    font-size: 0.85rem;
    font-family: inherit;
    box-sizing: border-box;
}

.form-input:focus[b-eo9y6c2jfq],
.form-select:focus[b-eo9y6c2jfq],
.form-textarea:focus[b-eo9y6c2jfq] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.form-input[b-eo9y6c2jfq]::placeholder,
.form-textarea[b-eo9y6c2jfq]::placeholder {
    color: rgba(255, 255, 255, 0.25);
}

.form-select option[b-eo9y6c2jfq] {
    background: #1a2035;
    color: white;
}

.form-textarea[b-eo9y6c2jfq] {
    resize: vertical;
    min-height: 60px;
    width: 100%;
}

.form-actions[b-eo9y6c2jfq] {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.btn-submit[b-eo9y6c2jfq] {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.5rem 1.2rem;
    background: rgba(236, 72, 153, 0.2);
    border: 1px solid rgba(236, 72, 153, 0.4);
    border-radius: 8px;
    color: #f9a8d4;
    font-weight: 700;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-submit:hover:not(:disabled)[b-eo9y6c2jfq] {
    background: rgba(236, 72, 153, 0.35);
}

.btn-submit:disabled[b-eo9y6c2jfq] {
    opacity: 0.4;
    cursor: not-allowed;
}

.btn-cancel[b-eo9y6c2jfq] {
    padding: 0.5rem 1rem;
    background: none;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
}

.btn-cancel:hover[b-eo9y6c2jfq] {
    color: white;
    border-color: rgba(255, 255, 255, 0.25);
}

.alert-error[b-eo9y6c2jfq] {
    background: rgba(239, 68, 68, 0.12);
    border: 1px solid rgba(239, 68, 68, 0.3);
    color: #fca5a5;
    padding: 0.6rem 0.85rem;
    border-radius: 8px;
    margin-bottom: 0.5rem;
    font-size: 0.85rem;
}

.spinner-sm[b-eo9y6c2jfq] {
    width: 14px;
    height: 14px;
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-top-color: currentColor;
    border-radius: 50%;
    animation: spin-b-eo9y6c2jfq 0.6s linear infinite;
}

/* ── Loading ── */
.loading-row[b-eo9y6c2jfq] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 3rem 0;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.9rem;
}

.spinner[b-eo9y6c2jfq] {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: spin-b-eo9y6c2jfq 0.6s linear infinite;
}

@keyframes spin-b-eo9y6c2jfq {
    to { transform: rotate(360deg); }
}

/* ── Results summary ── */
.results-summary[b-eo9y6c2jfq] {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 0.75rem;
}

.empty-state[b-eo9y6c2jfq] {
    text-align: center;
    padding: 2.5rem 1rem;
    color: rgba(255, 255, 255, 0.35);
    font-size: 0.88rem;
}

/* ── Data table ── */
.data-table-wrap[b-eo9y6c2jfq] {
    overflow-x: auto;
}

.data-table[b-eo9y6c2jfq] {
    width: 100%;
    border-collapse: collapse;
}

.data-table th[b-eo9y6c2jfq] {
    text-align: left;
    padding: 0.6rem 0.75rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.data-table td[b-eo9y6c2jfq] {
    padding: 0.55rem 0.75rem;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.75);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.data-table tbody tr[b-eo9y6c2jfq] {
    cursor: pointer;
    transition: background 120ms ease;
}

.data-table tbody tr:hover[b-eo9y6c2jfq] {
    background: rgba(255, 255, 255, 0.02);
}

.data-table tbody tr.row-expanded[b-eo9y6c2jfq] {
    background: rgba(236, 72, 153, 0.04);
}

.data-table tbody tr.detail-row[b-eo9y6c2jfq] {
    cursor: default;
}

.data-table tbody tr.detail-row:hover[b-eo9y6c2jfq] {
    background: none;
}

/* Columns */
.col-expand[b-eo9y6c2jfq] {
    width: 32px;
    text-align: center;
}

.col-timestamp[b-eo9y6c2jfq] {
    white-space: nowrap;
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.78rem;
}

.col-email[b-eo9y6c2jfq] {
    max-width: 160px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.text-muted[b-eo9y6c2jfq] {
    color: rgba(255, 255, 255, 0.3);
}

/* Expand chevron */
.expand-chevron[b-eo9y6c2jfq] {
    display: inline-flex;
    transition: transform 200ms ease;
    color: rgba(255, 255, 255, 0.3);
}

.expand-chevron svg[b-eo9y6c2jfq] {
    width: 14px;
    height: 14px;
}

.expand-chevron.expanded[b-eo9y6c2jfq] {
    transform: rotate(90deg);
    color: #f9a8d4;
}

/* Entity links */
.entity-link[b-eo9y6c2jfq] {
    color: #a5b4fc;
    text-decoration: none;
    transition: color 120ms ease;
}

.entity-link:hover[b-eo9y6c2jfq] {
    color: #c7d2fe;
    text-decoration: underline;
}

/* ── Badges ── */
.badge[b-eo9y6c2jfq] {
    display: inline-flex;
    align-items: center;
    padding: 0.12rem 0.45rem;
    border-radius: 5px;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    white-space: nowrap;
}

/* Severity */
.badge-critical[b-eo9y6c2jfq] { background: rgba(239, 68, 68, 0.2); color: #f87171; }
.badge-high[b-eo9y6c2jfq] { background: rgba(249, 115, 22, 0.2); color: #fb923c; }
.badge-medium[b-eo9y6c2jfq] { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }
.badge-low[b-eo9y6c2jfq] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }

/* Category */
.badge-behaviour[b-eo9y6c2jfq] { background: rgba(239, 68, 68, 0.12); color: #fca5a5; }
.badge-welfare[b-eo9y6c2jfq] { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }
.badge-disclosure[b-eo9y6c2jfq] { background: rgba(168, 85, 247, 0.15); color: #c4b5fd; }
.badge-online[b-eo9y6c2jfq] { background: rgba(245, 158, 11, 0.12); color: #fcd34d; }
.badge-other[b-eo9y6c2jfq] { background: rgba(100, 116, 139, 0.15); color: #94a3b8; }

/* Status */
.badge-open[b-eo9y6c2jfq] { background: rgba(239, 68, 68, 0.15); color: #f87171; }
.badge-resolved[b-eo9y6c2jfq] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-default[b-eo9y6c2jfq] { background: rgba(100, 116, 139, 0.15); color: #94a3b8; }

/* ── Detail panel ── */
.detail-panel[b-eo9y6c2jfq] {
    padding: 1rem 1.5rem;
    background: rgba(255, 255, 255, 0.02);
    border-radius: 8px;
    margin: 0.25rem 0;
}

.detail-section[b-eo9y6c2jfq] {
    margin-bottom: 0.75rem;
}

.detail-label[b-eo9y6c2jfq] {
    display: block;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 0.25rem;
}

.detail-text[b-eo9y6c2jfq] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.75);
    line-height: 1.5;
    margin: 0;
    white-space: pre-wrap;
}

.detail-meta[b-eo9y6c2jfq] {
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.35);
    margin-top: 0.75rem;
    padding-top: 0.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.detail-meta strong[b-eo9y6c2jfq] {
    color: rgba(255, 255, 255, 0.55);
}

/* ── Update form (inside detail) ── */
.update-form[b-eo9y6c2jfq] {
    margin-top: 1rem;
    padding-top: 0.75rem;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.update-form h3[b-eo9y6c2jfq] {
    font-size: 0.82rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.6);
    margin: 0 0 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.update-actions[b-eo9y6c2jfq] {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.btn-save[b-eo9y6c2jfq] {
    padding: 0.45rem 1rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: #a5b4fc;
    font-weight: 600;
    font-size: 0.82rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-save:hover:not(:disabled)[b-eo9y6c2jfq] {
    background: rgba(99, 102, 241, 0.35);
}

.btn-save:disabled[b-eo9y6c2jfq] {
    opacity: 0.4;
    cursor: not-allowed;
}

.btn-resolve[b-eo9y6c2jfq] {
    padding: 0.45rem 1rem;
    background: rgba(34, 197, 94, 0.15);
    border: 1px solid rgba(34, 197, 94, 0.35);
    border-radius: 8px;
    color: #4ade80;
    font-weight: 600;
    font-size: 0.82rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-resolve:hover:not(:disabled)[b-eo9y6c2jfq] {
    background: rgba(34, 197, 94, 0.3);
}

.btn-resolve:disabled[b-eo9y6c2jfq] {
    opacity: 0.4;
    cursor: not-allowed;
}

/* ── Pagination ── */
.pagination[b-eo9y6c2jfq] {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    margin-top: 1.5rem;
    padding-bottom: 1rem;
}

.page-btn[b-eo9y6c2jfq] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    height: 34px;
    padding: 0 0.5rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 120ms ease, color 120ms ease;
}

.page-btn:hover:not(:disabled)[b-eo9y6c2jfq] {
    background: rgba(99, 102, 241, 0.15);
    color: white;
}

.page-btn.active[b-eo9y6c2jfq] {
    background: rgba(99, 102, 241, 0.25);
    border-color: rgba(99, 102, 241, 0.4);
    color: #a5b4fc;
}

.page-btn:disabled[b-eo9y6c2jfq] {
    opacity: 0.3;
    cursor: not-allowed;
}

.page-btn svg[b-eo9y6c2jfq] {
    width: 16px;
    height: 16px;
}

.page-ellipsis[b-eo9y6c2jfq] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    color: rgba(255, 255, 255, 0.3);
    font-size: 0.85rem;
}
/* _content/Mathos.App/Components/Pages/admin/StudentDetail.razor.rz.scp.css */
/* ═══════════════════════════════════════════════
   Student Detail — admin detail page
   ═══════════════════════════════════════════════ */

/* ── Loading / Error ── */
.detail-loading[b-lcxjx34s9n] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 3rem 0;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.9rem;
}

.spinner[b-lcxjx34s9n] {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: spin-b-lcxjx34s9n 0.6s linear infinite;
}

.spinner-sm[b-lcxjx34s9n] {
    display: inline-block;
    width: 14px;
    height: 14px;
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-top-color: white;
    border-radius: 50%;
    animation: spin-b-lcxjx34s9n 0.6s linear infinite;
    margin-right: 6px;
    vertical-align: middle;
}

@keyframes spin-b-lcxjx34s9n {
    to { transform: rotate(360deg); }
}

.detail-error[b-lcxjx34s9n] {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.25);
    border-radius: 10px;
    padding: 1.5rem;
    text-align: center;
}

.detail-error p[b-lcxjx34s9n] {
    margin: 0 0 1rem;
    color: #fca5a5;
}

.btn-retry[b-lcxjx34s9n] {
    padding: 0.5rem 1.25rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: white;
    font-weight: 600;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-retry:hover[b-lcxjx34s9n] {
    background: rgba(99, 102, 241, 0.35);
}

/* ── Header ── */
.detail-header[b-lcxjx34s9n] {
    margin-bottom: 1.5rem;
}

.btn-back[b-lcxjx34s9n] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: none;
    border: none;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.82rem;
    cursor: pointer;
    padding: 0;
    margin-bottom: 1rem;
    transition: color 120ms ease;
}

.btn-back:hover[b-lcxjx34s9n] {
    color: white;
}

.btn-back svg[b-lcxjx34s9n] {
    width: 16px;
    height: 16px;
}

.header-info h1[b-lcxjx34s9n] {
    font-size: 1.5rem;
    font-weight: 800;
    color: white;
    margin: 0 0 0.5rem;
}

.header-meta[b-lcxjx34s9n] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.meta-item[b-lcxjx34s9n] {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.45);
}

.header-stats[b-lcxjx34s9n] {
    display: flex;
    gap: 1.5rem;
    margin-top: 1rem;
    flex-wrap: wrap;
}

.mini-stat[b-lcxjx34s9n] {
    display: flex;
    flex-direction: column;
    align-items: center;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    padding: 0.75rem 1.25rem;
    min-width: 80px;
}

.mini-stat-danger[b-lcxjx34s9n] {
    border-color: rgba(239, 68, 68, 0.3);
    background: rgba(239, 68, 68, 0.06);
}

.mini-stat-danger .mini-stat-value[b-lcxjx34s9n] {
    color: #f87171;
}

.mini-stat-value[b-lcxjx34s9n] {
    font-size: 1.25rem;
    font-weight: 800;
    color: white;
}

.mini-stat-label[b-lcxjx34s9n] {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    margin-top: 0.15rem;
}

/* ── Tabs ── */
.tab-bar[b-lcxjx34s9n] {
    display: flex;
    gap: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    margin-bottom: 1.5rem;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.tab-btn[b-lcxjx34s9n] {
    padding: 0.65rem 1.25rem;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    color: rgba(255, 255, 255, 0.45);
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: color 120ms ease, border-color 120ms ease;
    white-space: nowrap;
    flex-shrink: 0;
}

.tab-btn:hover[b-lcxjx34s9n] {
    color: rgba(255, 255, 255, 0.75);
}

.tab-btn.active[b-lcxjx34s9n] {
    color: #a5b4fc;
    border-bottom-color: #6366f1;
}

/* ── Info grid (Profile tab) ── */
.info-grid[b-lcxjx34s9n] {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

@media (max-width: 800px) {
    .info-grid[b-lcxjx34s9n] { grid-template-columns: 1fr; }
}

.info-card[b-lcxjx34s9n] {
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    padding: 1.25rem;
}

.info-card.full-width[b-lcxjx34s9n] {
    grid-column: 1 / -1;
}

.info-card h3[b-lcxjx34s9n] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.92rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.85);
    margin: 0 0 1rem;
}

.card-icon[b-lcxjx34s9n] {
    width: 18px;
    height: 18px;
    color: #6366f1;
}

.info-row[b-lcxjx34s9n] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.4rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.info-row:last-child[b-lcxjx34s9n] {
    border-bottom: none;
}

.info-label[b-lcxjx34s9n] {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.45);
    font-weight: 500;
}

.info-value[b-lcxjx34s9n] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.85);
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.info-block[b-lcxjx34s9n] {
    padding: 0.5rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.info-block:last-child[b-lcxjx34s9n] {
    border-bottom: none;
}

.info-text[b-lcxjx34s9n] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.7);
    line-height: 1.5;
    margin: 0.35rem 0 0;
    white-space: pre-wrap;
}

.dim[b-lcxjx34s9n] {
    color: rgba(255, 255, 255, 0.3);
}

.empty-inline[b-lcxjx34s9n] {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.3);
    font-style: italic;
}

/* ── Badges ── */
.badge[b-lcxjx34s9n] {
    display: inline-flex;
    align-items: center;
    padding: 0.15rem 0.5rem;
    border-radius: 6px;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

/* Year / exam / tier */
.badge-year[b-lcxjx34s9n] { background: rgba(99, 102, 241, 0.15); color: #a5b4fc; }
.badge-exam[b-lcxjx34s9n] { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }
.badge-tier[b-lcxjx34s9n] { background: rgba(14, 165, 233, 0.15); color: #7dd3fc; }

/* Status */
.badge-active[b-lcxjx34s9n] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-inactive[b-lcxjx34s9n] { background: rgba(100, 116, 139, 0.2); color: #94a3b8; }
.badge-primary-contact[b-lcxjx34s9n] { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }

/* Session status */
.badge-completed[b-lcxjx34s9n] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-confirmed[b-lcxjx34s9n] { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }
.badge-cancelled[b-lcxjx34s9n] { background: rgba(239, 68, 68, 0.15); color: #f87171; }
.badge-pending[b-lcxjx34s9n] { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }

/* Assignment status */
.badge-draft[b-lcxjx34s9n] { background: rgba(100, 116, 139, 0.2); color: #94a3b8; }
.badge-assigned[b-lcxjx34s9n] { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }
.badge-submitted[b-lcxjx34s9n] { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }
.badge-marked[b-lcxjx34s9n] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }

/* Sharing preferences */
.badge-share-yes[b-lcxjx34s9n] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-share-no[b-lcxjx34s9n] { background: rgba(100, 116, 139, 0.2); color: #94a3b8; }

/* Severity badges */
.badge-severity-critical[b-lcxjx34s9n] { background: rgba(239, 68, 68, 0.2); color: #f87171; }
.badge-severity-high[b-lcxjx34s9n] { background: rgba(249, 115, 22, 0.2); color: #fb923c; }
.badge-severity-medium[b-lcxjx34s9n] { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }
.badge-severity-low[b-lcxjx34s9n] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }

/* Resolved / open */
.badge-resolved[b-lcxjx34s9n] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-open[b-lcxjx34s9n] { background: rgba(239, 68, 68, 0.15); color: #f87171; }

/* Attempts */
.badge-attempts[b-lcxjx34s9n] { background: rgba(100, 116, 139, 0.15); color: #94a3b8; font-size: 0.7rem; }

/* ── Buttons ── */
.btn-primary[b-lcxjx34s9n] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.6rem 1.25rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: white;
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-primary:hover[b-lcxjx34s9n] { background: rgba(99, 102, 241, 0.35); }
.btn-primary:disabled[b-lcxjx34s9n] { opacity: 0.4; cursor: not-allowed; }

.btn-icon-danger[b-lcxjx34s9n] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: none;
    border: 1px solid transparent;
    border-radius: 6px;
    color: rgba(255, 255, 255, 0.3);
    cursor: pointer;
    transition: color 120ms ease, background 120ms ease;
    padding: 0;
}

.btn-icon-danger:hover[b-lcxjx34s9n] {
    color: #f87171;
    background: rgba(239, 68, 68, 0.1);
    border-color: rgba(239, 68, 68, 0.2);
}

.btn-icon-danger svg[b-lcxjx34s9n] {
    width: 15px;
    height: 15px;
}

/* ── Data tables ── */
.data-table-wrap[b-lcxjx34s9n] {
    overflow-x: auto;
}

.data-table[b-lcxjx34s9n] {
    width: 100%;
    border-collapse: collapse;
}

.data-table th[b-lcxjx34s9n] {
    text-align: left;
    padding: 0.6rem 0.75rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.data-table td[b-lcxjx34s9n] {
    padding: 0.65rem 0.75rem;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.75);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.data-table tbody tr:hover[b-lcxjx34s9n] {
    background: rgba(255, 255, 255, 0.02);
}

.clickable-row[b-lcxjx34s9n] {
    cursor: pointer;
    transition: background 120ms ease;
}

.clickable-row:hover[b-lcxjx34s9n] {
    background: rgba(99, 102, 241, 0.08) !important;
}

.empty-state[b-lcxjx34s9n] {
    text-align: center;
    padding: 2.5rem 1rem;
    color: rgba(255, 255, 255, 0.35);
    font-size: 0.88rem;
}

/* ── Progress tab ── */
.progress-domain[b-lcxjx34s9n] {
    margin-bottom: 1.5rem;
}

.progress-domain-title[b-lcxjx34s9n] {
    font-size: 0.92rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.85);
    margin: 0 0 0.75rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.progress-row[b-lcxjx34s9n] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem 0;
}

.progress-topic[b-lcxjx34s9n] {
    flex: 0 0 200px;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.7);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

@media (max-width: 700px) {
    .progress-topic[b-lcxjx34s9n] { flex: 0 0 120px; font-size: 0.75rem; }
}

.progress-bar-track[b-lcxjx34s9n] {
    flex: 1;
    height: 10px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 5px;
    overflow: hidden;
}

.progress-bar-fill[b-lcxjx34s9n] {
    height: 100%;
    border-radius: 5px;
    transition: width 400ms ease;
}

.bar-green[b-lcxjx34s9n] { background: #22c55e; }
.bar-amber[b-lcxjx34s9n] { background: #f59e0b; }
.bar-red[b-lcxjx34s9n] { background: #ef4444; }

.progress-pct[b-lcxjx34s9n] {
    flex: 0 0 48px;
    text-align: right;
    font-size: 0.8rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.75);
}

/* ── Notes ── */
.notes-section[b-lcxjx34s9n] {
    max-width: 700px;
}

.note-form[b-lcxjx34s9n] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 1.5rem;
}

.note-input[b-lcxjx34s9n] {
    width: 100%;
    padding: 0.75rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: white;
    font-size: 0.85rem;
    font-family: inherit;
    resize: vertical;
    min-height: 60px;
}

.note-input:focus[b-lcxjx34s9n] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.note-input[b-lcxjx34s9n]::placeholder {
    color: rgba(255, 255, 255, 0.25);
}

.notes-list[b-lcxjx34s9n] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.note-card[b-lcxjx34s9n] {
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    padding: 0.85rem 1rem;
}

.note-header[b-lcxjx34s9n] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.note-author[b-lcxjx34s9n] {
    font-size: 0.78rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.65);
}

.note-date[b-lcxjx34s9n] {
    font-size: 0.72rem;
    color: rgba(255, 255, 255, 0.3);
    flex: 1;
}

.note-content[b-lcxjx34s9n] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.7);
    line-height: 1.5;
    margin: 0;
    white-space: pre-wrap;
}
/* _content/Mathos.App/Components/Pages/admin/SystemHealth.razor.rz.scp.css */
/* ═══════════════════════════════════════════════
   System Health — admin monitoring page
   ═══════════════════════════════════════════════ */

/* ── Page header ── */
.page-header[b-7bmt6fs01j] {
    margin-bottom: 1.25rem;
}

.page-header h1[b-7bmt6fs01j] {
    font-size: 1.35rem;
    font-weight: 700;
    color: white;
    margin: 0;
}

/* ── Tabs ── */
.tab-bar[b-7bmt6fs01j] {
    display: flex;
    gap: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    margin-bottom: 1.5rem;
}

.tab[b-7bmt6fs01j] {
    padding: 0.6rem 1.25rem;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    color: rgba(255, 255, 255, 0.4);
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: all 120ms ease;
}

.tab:hover[b-7bmt6fs01j] {
    color: rgba(255, 255, 255, 0.6);
}

.tab.active[b-7bmt6fs01j] {
    color: #a5b4fc;
    border-bottom-color: #6366f1;
}

/* ── Loading / Error / Empty ── */
.loading-row[b-7bmt6fs01j] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 3rem 0;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.9rem;
}

.spinner[b-7bmt6fs01j] {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: spin-b-7bmt6fs01j 0.6s linear infinite;
}

@keyframes spin-b-7bmt6fs01j {
    to { transform: rotate(360deg); }
}

.error-banner[b-7bmt6fs01j] {
    padding: 0.65rem 1rem;
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-radius: 8px;
    color: #f87171;
    font-size: 0.82rem;
    margin-bottom: 1rem;
}

.empty-state[b-7bmt6fs01j] {
    text-align: center;
    padding: 2.5rem 1rem;
    color: rgba(255, 255, 255, 0.35);
    font-size: 0.88rem;
}

/* ── Health tab ── */

.health-header[b-7bmt6fs01j] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.25rem;
}

.overall-status[b-7bmt6fs01j] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 700;
    font-size: 1rem;
}

.overall-healthy[b-7bmt6fs01j] {
    color: #4ade80;
}

.overall-healthy .status-dot[b-7bmt6fs01j] {
    background: #10b981;
    box-shadow: 0 0 8px rgba(16, 185, 129, 0.4);
}

.overall-degraded[b-7bmt6fs01j] {
    color: #fbbf24;
}

.overall-degraded .status-dot[b-7bmt6fs01j] {
    background: #f59e0b;
    box-shadow: 0 0 8px rgba(245, 158, 11, 0.4);
}

.overall-unhealthy[b-7bmt6fs01j] {
    color: #f87171;
}

.overall-unhealthy .status-dot[b-7bmt6fs01j] {
    background: #ef4444;
    box-shadow: 0 0 8px rgba(239, 68, 68, 0.4);
}

.btn-refresh[b-7bmt6fs01j] {
    padding: 0.4rem 0.85rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 6px;
    color: #a5b4fc;
    font-weight: 700;
    font-size: 0.78rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-refresh:hover[b-7bmt6fs01j] {
    background: rgba(99, 102, 241, 0.35);
}

.health-grid[b-7bmt6fs01j] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.health-card[b-7bmt6fs01j] {
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 10px;
    padding: 1rem;
    border-left: 3px solid transparent;
}

.health-card.status-healthy[b-7bmt6fs01j] {
    border-left-color: #10b981;
}

.health-card.status-degraded[b-7bmt6fs01j] {
    border-left-color: #f59e0b;
}

.health-card.status-unhealthy[b-7bmt6fs01j] {
    border-left-color: #ef4444;
}

.health-card-header[b-7bmt6fs01j] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.status-dot[b-7bmt6fs01j] {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}

.status-healthy .status-dot[b-7bmt6fs01j] {
    background: #10b981;
    box-shadow: 0 0 6px rgba(16, 185, 129, 0.4);
}

.status-degraded .status-dot[b-7bmt6fs01j] {
    background: #f59e0b;
    box-shadow: 0 0 6px rgba(245, 158, 11, 0.4);
}

.status-unhealthy .status-dot[b-7bmt6fs01j] {
    background: #ef4444;
    box-shadow: 0 0 6px rgba(239, 68, 68, 0.4);
}

.health-card-name[b-7bmt6fs01j] {
    font-weight: 700;
    font-size: 0.88rem;
    color: white;
    text-transform: capitalize;
}

.health-card-status[b-7bmt6fs01j] {
    font-size: 0.78rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.6);
    margin-bottom: 0.35rem;
}

.health-card-desc[b-7bmt6fs01j] {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.4);
    line-height: 1.4;
    margin-bottom: 0.35rem;
}

.health-card-duration[b-7bmt6fs01j] {
    font-size: 0.68rem;
    color: rgba(255, 255, 255, 0.25);
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
}

/* ── Webhooks tab ── */

.stats-grid[b-7bmt6fs01j] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.stat-card[b-7bmt6fs01j] {
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 10px;
    padding: 0.85rem 1rem;
}

.stat-card.stat-danger[b-7bmt6fs01j] {
    border-color: rgba(239, 68, 68, 0.2);
}

.stat-label[b-7bmt6fs01j] {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: rgba(255, 255, 255, 0.35);
    margin-bottom: 0.25rem;
}

.stat-value[b-7bmt6fs01j] {
    font-size: 1.25rem;
    font-weight: 700;
    color: white;
}

.stat-danger .stat-value[b-7bmt6fs01j] {
    color: #f87171;
}

.stat-sub[b-7bmt6fs01j] {
    font-size: 0.72rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.35);
}

/* Last failure banner */
.last-failure-banner[b-7bmt6fs01j] {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    padding: 0.6rem 0.85rem;
    background: rgba(239, 68, 68, 0.06);
    border: 1px solid rgba(239, 68, 68, 0.15);
    border-radius: 8px;
    margin-bottom: 1rem;
    font-size: 0.78rem;
}

.last-failure-label[b-7bmt6fs01j] {
    font-weight: 700;
    color: #f87171;
}

.last-failure-type[b-7bmt6fs01j] {
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.72rem;
    color: rgba(255, 255, 255, 0.6);
    background: rgba(255, 255, 255, 0.04);
    padding: 0.1rem 0.4rem;
    border-radius: 4px;
}

.last-failure-time[b-7bmt6fs01j] {
    color: rgba(255, 255, 255, 0.35);
}

.last-failure-msg[b-7bmt6fs01j] {
    color: rgba(255, 255, 255, 0.4);
    font-size: 0.72rem;
}

/* Filter bar */
.filter-bar[b-7bmt6fs01j] {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 0.75rem;
    padding: 0.5rem 0;
}

.toggle-label[b-7bmt6fs01j] {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.6);
    cursor: pointer;
}

.toggle-label input[type="checkbox"][b-7bmt6fs01j] {
    accent-color: #6366f1;
}

/* Data table */
.data-table-wrap[b-7bmt6fs01j] {
    overflow-x: auto;
    margin-bottom: 0.75rem;
}

.data-table[b-7bmt6fs01j] {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.8rem;
}

.data-table th[b-7bmt6fs01j] {
    text-align: left;
    padding: 0.55rem 0.75rem;
    font-weight: 700;
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: rgba(255, 255, 255, 0.35);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    white-space: nowrap;
}

.data-table td[b-7bmt6fs01j] {
    padding: 0.55rem 0.75rem;
    color: rgba(255, 255, 255, 0.7);
    border-bottom: 1px solid rgba(255, 255, 255, 0.03);
}

.data-table tbody tr:hover[b-7bmt6fs01j] {
    background: rgba(255, 255, 255, 0.02);
}

.row-failed[b-7bmt6fs01j] {
    background: rgba(239, 68, 68, 0.03);
}

.row-failed:hover[b-7bmt6fs01j] {
    background: rgba(239, 68, 68, 0.06) !important;
}

.col-mono[b-7bmt6fs01j] {
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: 0.72rem;
}

.col-timestamp[b-7bmt6fs01j] {
    white-space: nowrap;
    color: rgba(255, 255, 255, 0.4);
}

.col-error[b-7bmt6fs01j] {
    font-size: 0.72rem;
    color: rgba(248, 113, 113, 0.7);
    max-width: 300px;
}

/* Badges */
.badge[b-7bmt6fs01j] {
    display: inline-flex;
    align-items: center;
    padding: 0.1rem 0.4rem;
    border-radius: 5px;
    font-size: 0.64rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.badge-success[b-7bmt6fs01j] {
    background: rgba(34, 197, 94, 0.15);
    color: #4ade80;
}

.badge-failed[b-7bmt6fs01j] {
    background: rgba(239, 68, 68, 0.15);
    color: #f87171;
}

/* Pagination */
.pagination[b-7bmt6fs01j] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.5rem 0;
}

.page-info[b-7bmt6fs01j] {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.35);
}

.page-buttons[b-7bmt6fs01j] {
    display: flex;
    gap: 0.35rem;
}

.btn-page[b-7bmt6fs01j] {
    padding: 0.35rem 0.75rem;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 6px;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 600;
    font-size: 0.75rem;
    cursor: pointer;
    transition: all 120ms ease;
}

.btn-page:hover:not(:disabled)[b-7bmt6fs01j] {
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.8);
}

.btn-page:disabled[b-7bmt6fs01j] {
    opacity: 0.3;
    cursor: not-allowed;
}
/* _content/Mathos.App/Components/Pages/admin/TutorDetail.razor.rz.scp.css */
/* ═══════════════════════════════════════════════
   Tutor Detail — admin detail page
   ═══════════════════════════════════════════════ */

/* ── Loading / Error ── */
.detail-loading[b-k3dcl7km83] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 3rem 0;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.9rem;
}

.spinner[b-k3dcl7km83] {
    width: 20px;
    height: 20px;
    border: 2px solid rgba(255, 255, 255, 0.15);
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: spin-b-k3dcl7km83 0.6s linear infinite;
}

.spinner-sm[b-k3dcl7km83] {
    display: inline-block;
    width: 14px;
    height: 14px;
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-top-color: white;
    border-radius: 50%;
    animation: spin-b-k3dcl7km83 0.6s linear infinite;
    margin-right: 6px;
    vertical-align: middle;
}

@keyframes spin-b-k3dcl7km83 {
    to { transform: rotate(360deg); }
}

.detail-error[b-k3dcl7km83] {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.25);
    border-radius: 10px;
    padding: 1.5rem;
    text-align: center;
}

.detail-error p[b-k3dcl7km83] {
    margin: 0 0 1rem;
    color: #fca5a5;
}

.btn-retry[b-k3dcl7km83] {
    padding: 0.5rem 1.25rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: white;
    font-weight: 600;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-retry:hover[b-k3dcl7km83] {
    background: rgba(99, 102, 241, 0.35);
}

/* ── Header ── */
.detail-header[b-k3dcl7km83] {
    margin-bottom: 1.5rem;
}

.btn-back[b-k3dcl7km83] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: none;
    border: none;
    color: rgba(255, 255, 255, 0.5);
    font-size: 0.82rem;
    cursor: pointer;
    padding: 0;
    margin-bottom: 1rem;
    transition: color 120ms ease;
}

.btn-back:hover[b-k3dcl7km83] {
    color: white;
}

.btn-back svg[b-k3dcl7km83] {
    width: 16px;
    height: 16px;
}

.header-info h1[b-k3dcl7km83] {
    font-size: 1.5rem;
    font-weight: 800;
    color: white;
    margin: 0 0 0.5rem;
}

.header-meta[b-k3dcl7km83] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.meta-item[b-k3dcl7km83] {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.45);
}

.header-stats[b-k3dcl7km83] {
    display: flex;
    gap: 1.5rem;
    margin-top: 1rem;
}

.mini-stat[b-k3dcl7km83] {
    display: flex;
    flex-direction: column;
    align-items: center;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    padding: 0.75rem 1.25rem;
    min-width: 80px;
}

.mini-stat-value[b-k3dcl7km83] {
    font-size: 1.25rem;
    font-weight: 800;
    color: white;
}

.mini-stat-label[b-k3dcl7km83] {
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    margin-top: 0.15rem;
}

/* ── Tabs ── */
.tab-bar[b-k3dcl7km83] {
    display: flex;
    gap: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    margin-bottom: 1.5rem;
}

.tab-btn[b-k3dcl7km83] {
    padding: 0.65rem 1.25rem;
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    color: rgba(255, 255, 255, 0.45);
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: color 120ms ease, border-color 120ms ease;
}

.tab-btn:hover[b-k3dcl7km83] {
    color: rgba(255, 255, 255, 0.75);
}

.tab-btn.active[b-k3dcl7km83] {
    color: #a5b4fc;
    border-bottom-color: #6366f1;
}

/* ── Info grid (Profile + Verification) ── */
.info-grid[b-k3dcl7km83] {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

@media (max-width: 800px) {
    .info-grid[b-k3dcl7km83] { grid-template-columns: 1fr; }
}

.info-card[b-k3dcl7km83] {
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    padding: 1.25rem;
}

.info-card.full-width[b-k3dcl7km83] {
    grid-column: 1 / -1;
}

.info-card h3[b-k3dcl7km83] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.92rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.85);
    margin: 0 0 1rem;
}

.card-icon[b-k3dcl7km83] {
    width: 18px;
    height: 18px;
    color: #6366f1;
}

.info-row[b-k3dcl7km83] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.4rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.info-row:last-child[b-k3dcl7km83] {
    border-bottom: none;
}

.info-label[b-k3dcl7km83] {
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.45);
    font-weight: 500;
}

.info-value[b-k3dcl7km83] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.85);
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.info-text[b-k3dcl7km83] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.7);
    line-height: 1.5;
    margin: 0;
    white-space: pre-wrap;
}

/* ── Photo upload ── */
.photo-section[b-k3dcl7km83] {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.photo-avatar[b-k3dcl7km83] {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    overflow: hidden;
    background: rgba(99, 102, 241, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.photo-avatar img[b-k3dcl7km83] {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.avatar-initials[b-k3dcl7km83] {
    font-weight: 700;
    font-size: 1.25rem;
    color: #a5b4fc;
}

.photo-controls[b-k3dcl7km83] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.upload-btn[b-k3dcl7km83] {
    display: inline-block;
    padding: 0.45rem 0.85rem;
    background: rgba(99, 102, 241, 0.15);
    border: 1px solid rgba(99, 102, 241, 0.3);
    border-radius: 8px;
    color: #a5b4fc;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 0.15s;
    text-align: center;
}

.upload-btn:hover[b-k3dcl7km83] {
    background: rgba(99, 102, 241, 0.25);
}

.photo-hint[b-k3dcl7km83] {
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.35);
}

.photo-error[b-k3dcl7km83] {
    font-size: 0.78rem;
    color: #f87171;
}

.photo-success[b-k3dcl7km83] {
    font-size: 0.78rem;
    color: #4ade80;
}

/* ── Badges ── */
.badge[b-k3dcl7km83] {
    display: inline-flex;
    align-items: center;
    padding: 0.15rem 0.5rem;
    border-radius: 6px;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.badge-active[b-k3dcl7km83] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-inactive[b-k3dcl7km83] { background: rgba(100, 116, 139, 0.2); color: #94a3b8; }
.badge-verified[b-k3dcl7km83] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-unverified[b-k3dcl7km83] { background: rgba(239, 68, 68, 0.15); color: #f87171; }
.badge-expired[b-k3dcl7km83] { background: rgba(239, 68, 68, 0.15); color: #f87171; }
.badge-expiring[b-k3dcl7km83] { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }

.badge-completed[b-k3dcl7km83] { background: rgba(34, 197, 94, 0.15); color: #4ade80; }
.badge-confirmed[b-k3dcl7km83] { background: rgba(59, 130, 246, 0.15); color: #93c5fd; }
.badge-cancelled[b-k3dcl7km83] { background: rgba(239, 68, 68, 0.15); color: #f87171; }
.badge-pending[b-k3dcl7km83] { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }

/* ── Buttons ── */
.btn-link[b-k3dcl7km83] {
    background: none;
    border: none;
    color: #818cf8;
    font-size: 0.78rem;
    font-weight: 600;
    cursor: pointer;
    padding: 0;
    text-decoration: underline;
}

.btn-link:hover[b-k3dcl7km83] { color: #a5b4fc; }

.btn-danger[b-k3dcl7km83] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.6rem 1.25rem;
    background: rgba(239, 68, 68, 0.15);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-radius: 8px;
    color: #f87171;
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-danger:hover[b-k3dcl7km83] { background: rgba(239, 68, 68, 0.25); }
.btn-danger svg[b-k3dcl7km83] { width: 16px; height: 16px; }

.btn-success[b-k3dcl7km83] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.6rem 1.25rem;
    background: rgba(34, 197, 94, 0.15);
    border: 1px solid rgba(34, 197, 94, 0.3);
    border-radius: 8px;
    color: #4ade80;
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-success:hover[b-k3dcl7km83] { background: rgba(34, 197, 94, 0.25); }
.btn-success svg[b-k3dcl7km83] { width: 16px; height: 16px; }

.btn-primary[b-k3dcl7km83] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.6rem 1.25rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 8px;
    color: white;
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-primary:hover[b-k3dcl7km83] { background: rgba(99, 102, 241, 0.35); }
.btn-primary:disabled[b-k3dcl7km83] { opacity: 0.4; cursor: not-allowed; }

.btn-icon-danger[b-k3dcl7km83] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: none;
    border: 1px solid transparent;
    border-radius: 6px;
    color: rgba(255, 255, 255, 0.3);
    cursor: pointer;
    transition: color 120ms ease, background 120ms ease;
    padding: 0;
}

.btn-icon-danger:hover[b-k3dcl7km83] {
    color: #f87171;
    background: rgba(239, 68, 68, 0.1);
    border-color: rgba(239, 68, 68, 0.2);
}

.btn-icon-danger svg[b-k3dcl7km83] {
    width: 15px;
    height: 15px;
}

/* ── Data tables ── */
.data-table-wrap[b-k3dcl7km83] {
    overflow-x: auto;
}

.data-table[b-k3dcl7km83] {
    width: 100%;
    border-collapse: collapse;
}

.data-table th[b-k3dcl7km83] {
    text-align: left;
    padding: 0.6rem 0.75rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: rgba(255, 255, 255, 0.4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.data-table td[b-k3dcl7km83] {
    padding: 0.65rem 0.75rem;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.75);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.data-table tbody tr:hover[b-k3dcl7km83] {
    background: rgba(255, 255, 255, 0.02);
}

.empty-state[b-k3dcl7km83] {
    text-align: center;
    padding: 2.5rem 1rem;
    color: rgba(255, 255, 255, 0.35);
    font-size: 0.88rem;
}

/* ── Notes ── */
.notes-section[b-k3dcl7km83] {
    max-width: 700px;
}

.note-form[b-k3dcl7km83] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 1.5rem;
}

.note-input[b-k3dcl7km83] {
    width: 100%;
    padding: 0.75rem;
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: white;
    font-size: 0.85rem;
    font-family: inherit;
    resize: vertical;
    min-height: 60px;
}

.note-input:focus[b-k3dcl7km83] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.note-input[b-k3dcl7km83]::placeholder {
    color: rgba(255, 255, 255, 0.25);
}

.notes-list[b-k3dcl7km83] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.note-card[b-k3dcl7km83] {
    background: #121826;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    padding: 0.85rem 1rem;
}

.note-header[b-k3dcl7km83] {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.note-author[b-k3dcl7km83] {
    font-size: 0.78rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.65);
}

.note-date[b-k3dcl7km83] {
    font-size: 0.72rem;
    color: rgba(255, 255, 255, 0.3);
    flex: 1;
}

.note-content[b-k3dcl7km83] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.7);
    line-height: 1.5;
    margin: 0;
    white-space: pre-wrap;
}

/* ── Modal ── */
.modal-overlay[b-k3dcl7km83] {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 200;
    backdrop-filter: blur(4px);
}

.modal-card[b-k3dcl7km83] {
    background: #161d2e;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 14px;
    padding: 1.5rem;
    width: 90%;
    max-width: 460px;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.5);
}

.modal-card h3[b-k3dcl7km83] {
    font-size: 1.05rem;
    font-weight: 700;
    color: white;
    margin: 0 0 0.5rem;
}

.modal-desc[b-k3dcl7km83] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.55);
    margin: 0 0 1rem;
    line-height: 1.4;
}

.modal-textarea[b-k3dcl7km83] {
    width: 100%;
    padding: 0.65rem;
    background: #0d1117;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: white;
    font-size: 0.85rem;
    font-family: inherit;
    resize: vertical;
    margin-bottom: 0.75rem;
}

.modal-textarea:focus[b-k3dcl7km83] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.modal-textarea[b-k3dcl7km83]::placeholder {
    color: rgba(255, 255, 255, 0.25);
}

.modal-error[b-k3dcl7km83] {
    font-size: 0.82rem;
    color: #f87171;
    margin-bottom: 0.75rem;
}

.modal-actions[b-k3dcl7km83] {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
}

.btn-cancel[b-k3dcl7km83] {
    padding: 0.5rem 1rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: rgba(255, 255, 255, 0.6);
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-cancel:hover[b-k3dcl7km83] { background: rgba(255, 255, 255, 0.08); }

.btn-confirm[b-k3dcl7km83] {
    padding: 0.5rem 1.25rem;
    border-radius: 8px;
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 120ms ease;
    border: 1px solid;
}

.btn-confirm:disabled[b-k3dcl7km83] { opacity: 0.4; cursor: not-allowed; }

.btn-confirm.btn-danger[b-k3dcl7km83] {
    background: rgba(239, 68, 68, 0.2);
    border-color: rgba(239, 68, 68, 0.4);
    color: #f87171;
}

.btn-confirm.btn-danger:hover:not(:disabled)[b-k3dcl7km83] { background: rgba(239, 68, 68, 0.3); }

.btn-confirm.btn-success[b-k3dcl7km83] {
    background: rgba(34, 197, 94, 0.2);
    border-color: rgba(34, 197, 94, 0.4);
    color: #4ade80;
}

.btn-confirm.btn-success:hover:not(:disabled)[b-k3dcl7km83] { background: rgba(34, 197, 94, 0.3); }

/* ── Verification edit ── */
.verification-header-actions[b-k3dcl7km83] {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 1rem;
}

.btn-edit[b-k3dcl7km83] {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.5rem 1rem;
    background: rgba(99, 102, 241, 0.15);
    border: 1px solid rgba(99, 102, 241, 0.3);
    border-radius: 8px;
    color: #a5b4fc;
    font-weight: 600;
    font-size: 0.82rem;
    cursor: pointer;
    transition: background 120ms ease;
}

.btn-edit:hover[b-k3dcl7km83] { background: rgba(99, 102, 241, 0.25); }
.btn-edit svg[b-k3dcl7km83] { width: 14px; height: 14px; }

.edit-form-group[b-k3dcl7km83] {
    margin-bottom: 0.85rem;
}

.edit-label[b-k3dcl7km83] {
    display: block;
    font-size: 0.82rem;
    color: rgba(255, 255, 255, 0.5);
    margin-bottom: 0.3rem;
    font-weight: 500;
}

.edit-input[b-k3dcl7km83] {
    width: 100%;
    padding: 0.55rem 0.65rem;
    background: #0b0f19;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 8px;
    color: white;
    font-size: 0.85rem;
    box-sizing: border-box;
    font-family: inherit;
}

.edit-input:focus[b-k3dcl7km83] {
    outline: none;
    border-color: rgba(99, 102, 241, 0.5);
}

.edit-checkbox-label[b-k3dcl7km83] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.75);
    font-weight: 600;
    cursor: pointer;
}

.edit-checkbox-label input[type="checkbox"][b-k3dcl7km83] {
    accent-color: #6366f1;
    width: 18px;
    height: 18px;
    cursor: pointer;
}

.edit-actions[b-k3dcl7km83] {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
}

.verification-error[b-k3dcl7km83] {
    background: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.25);
    border-radius: 8px;
    padding: 0.6rem 0.75rem;
    color: #fca5a5;
    font-size: 0.82rem;
    margin-bottom: 0.75rem;
}

.verification-success[b-k3dcl7km83] {
    background: rgba(34, 197, 94, 0.1);
    border: 1px solid rgba(34, 197, 94, 0.25);
    border-radius: 8px;
    padding: 0.6rem 0.75rem;
    color: #4ade80;
    font-size: 0.82rem;
    margin-bottom: 1rem;
}
/* _content/Mathos.App/Components/Pages/Contact.razor.rz.scp.css */
.page-hero[b-8feony0k6z] {
    padding: 0.75rem 0 1.25rem;
}

.page-hero h1[b-8feony0k6z] {
    margin: 0 0 0.5rem;
    font-size: 2.2rem;
    color: white;
}

.page-hero p[b-8feony0k6z] {
    margin: 0;
    color: rgba(255,255,255,0.72);
    max-width: 70ch;
}

.grid[b-8feony0k6z] {
    margin-top: 1.25rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.card[b-8feony0k6z] {
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 18px;
    background: rgba(255,255,255,0.05);
    padding: 1.1rem;
}

.card h2[b-8feony0k6z] {
    margin: 0 0 0.6rem;
    color: white;
    font-size: 1.25rem;
}

.card p[b-8feony0k6z], .card li[b-8feony0k6z] {
    color: rgba(255,255,255,0.75);
}

.card ul[b-8feony0k6z] {
    margin: 0.25rem 0 0;
    padding-left: 1.25rem;
}

.span-2[b-8feony0k6z] {
    grid-column: 1 / -1;
}

.email a[b-8feony0k6z] {
    color: white;
    font-weight: 800;
    text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,0.25);
}

.email a:hover[b-8feony0k6z] {
    border-bottom-color: rgba(255,255,255,0.75);
}

.note[b-8feony0k6z] {
    margin-top: 0.75rem;
    color: rgba(255,255,255,0.7);
    font-size: 0.95rem;
}

@media (max-width: 900px) {
    .grid[b-8feony0k6z] {
        grid-template-columns: 1fr;
    }
}
/* _content/Mathos.App/Components/Pages/Home.razor.rz.scp.css */
.hero[b-nzqnudejzc] {
    padding: 2.5rem 0 1.5rem;
}

.hero-inner[b-nzqnudejzc] {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 2rem;
    align-items: center;
}

.hero-copy h1[b-nzqnudejzc] {
    font-size: 3rem;
    line-height: 1.05;
    margin: 0 0 1rem;
    color: white;
}

.lead[b-nzqnudejzc] {
    margin: 0 0 1.5rem;
    font-size: 1.1rem;
    color: rgba(255,255,255,0.75);
}

.cta-row[b-nzqnudejzc] {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-bottom: 1.25rem;
}

.cta[b-nzqnudejzc] {
    text-decoration: none;
    padding: 0.8rem 1rem;
    border-radius: 14px;
    font-weight: 700;
}

.cta.primary[b-nzqnudejzc] {
    background: rgba(255,255,255,0.92);
    color: #0b1220;
}

.cta.secondary[b-nzqnudejzc] {
    border: 1px solid rgba(255,255,255,0.18);
    color: white;
}

.trust[b-nzqnudejzc] {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.pill[b-nzqnudejzc] {
    border: 1px solid rgba(255,255,255,0.14);
    background: rgba(255,255,255,0.06);
    color: rgba(255,255,255,0.85);
    padding: 0.35rem 0.6rem;
    border-radius: 999px;
    font-size: 0.9rem;
}

.hero-card[b-nzqnudejzc] {
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 18px;
    overflow: hidden;
    background: rgba(255,255,255,0.06);
    box-shadow: 0 25px 80px rgba(0,0,0,0.35);
}

.card-top[b-nzqnudejzc] {
    display: flex;
    gap: 0.35rem;
    padding: 0.75rem;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.dot[b-nzqnudejzc] {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: rgba(255,255,255,0.25);
}

.card-body[b-nzqnudejzc] {
    padding: 1rem;
    display: grid;
    gap: 0.85rem;
}

.metric-label[b-nzqnudejzc] {
    font-size: 0.85rem;
    color: rgba(255,255,255,0.65);
}

.metric-value[b-nzqnudejzc] {
    font-size: 1.05rem;
    font-weight: 800;
    color: white;
}

.metric-value.ok[b-nzqnudejzc] {
    color: rgba(52, 211, 153, 0.95);
}

.metric-bar[b-nzqnudejzc] {
    margin-top: 0.5rem;
    height: 10px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(99,102,241,0.95), rgba(168,85,247,0.85));
}

.features[b-nzqnudejzc] {
    margin-top: 2.5rem;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

.feature[b-nzqnudejzc] {
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 18px;
    background: rgba(255,255,255,0.05);
    padding: 1.1rem;
}

.feature h3[b-nzqnudejzc] {
    margin: 0 0 0.5rem;
    color: white;
}

.feature p[b-nzqnudejzc] {
    margin: 0;
    color: rgba(255,255,255,0.72);
}

@media (max-width: 900px) {
    .hero-inner[b-nzqnudejzc] {
        grid-template-columns: 1fr;
    }

    .hero-copy h1[b-nzqnudejzc] {
        font-size: 2.35rem;
    }

    .features[b-nzqnudejzc] {
        grid-template-columns: 1fr;
    }
}
/* _content/Mathos.App/Components/Pages/HowItWorks.razor.rz.scp.css */
.page-hero[b-z9rhatjncx] {
    padding: 0.75rem 0 1.25rem;
}

.page-hero h1[b-z9rhatjncx] {
    margin: 0 0 0.5rem;
    font-size: 2.2rem;
    color: white;
}

.page-hero p[b-z9rhatjncx] {
    margin: 0;
    color: rgba(255,255,255,0.72);
    max-width: 60ch;
}

.grid[b-z9rhatjncx] {
    margin-top: 1.25rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.card[b-z9rhatjncx] {
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 18px;
    background: rgba(255,255,255,0.05);
    padding: 1.1rem;
}

.card h2[b-z9rhatjncx] {
    margin: 0 0 0.6rem;
    color: white;
    font-size: 1.25rem;
}

.card p[b-z9rhatjncx], .card li[b-z9rhatjncx] {
    color: rgba(255,255,255,0.75);
}

.card ol[b-z9rhatjncx] {
    margin: 0.25rem 0 0;
    padding-left: 1.25rem;
}

.span-2[b-z9rhatjncx] {
    grid-column: 1 / -1;
}

.pill-row[b-z9rhatjncx] {
    margin-top: 0.9rem;
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.pill[b-z9rhatjncx] {
    border: 1px solid rgba(255,255,255,0.14);
    background: rgba(255,255,255,0.06);
    color: rgba(255,255,255,0.85);
    padding: 0.35rem 0.6rem;
    border-radius: 999px;
    font-size: 0.9rem;
}

@media (max-width: 900px) {
    .grid[b-z9rhatjncx] {
        grid-template-columns: 1fr;
    }
}
/* _content/Mathos.App/Components/Pages/JoinTheTeam.razor.rz.scp.css */
.page-hero[b-gqhx6b087h] {
    padding: 0.75rem 0 1.25rem;
}

.page-hero h1[b-gqhx6b087h] {
    margin: 0 0 0.5rem;
    font-size: 2.2rem;
    color: white;
}

.page-hero p[b-gqhx6b087h] {
    margin: 0;
    color: rgba(255,255,255,0.72);
    max-width: 70ch;
}

.grid[b-gqhx6b087h] {
    margin-top: 1.25rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.card[b-gqhx6b087h] {
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 18px;
    background: rgba(255,255,255,0.05);
    padding: 1.1rem;
}

.card h2[b-gqhx6b087h] {
    margin: 0 0 0.6rem;
    color: white;
    font-size: 1.25rem;
}

.card p[b-gqhx6b087h], .card li[b-gqhx6b087h] {
    color: rgba(255,255,255,0.75);
}

.card ul[b-gqhx6b087h] {
    margin: 0.25rem 0 0;
    padding-left: 1.25rem;
}

.span-2[b-gqhx6b087h] {
    grid-column: 1 / -1;
}

.commission-card p[b-gqhx6b087h] {
    font-size: 1.05rem;
}

/* ── Steps ── */

.steps[b-gqhx6b087h] {
    margin-top: 2rem;
}

.steps h2[b-gqhx6b087h] {
    color: white;
    font-size: 1.5rem;
    margin: 0 0 1rem;
}

.steps-row[b-gqhx6b087h] {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 1rem;
}

.step[b-gqhx6b087h] {
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 18px;
    background: rgba(255,255,255,0.05);
    padding: 1.25rem;
    text-align: center;
}

.step-number[b-gqhx6b087h] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    background: #6366f1;
    color: white;
    font-weight: 700;
    font-size: 0.95rem;
    margin-bottom: 0.6rem;
}

.step h3[b-gqhx6b087h] {
    margin: 0 0 0.4rem;
    color: white;
    font-size: 1.1rem;
}

.step p[b-gqhx6b087h] {
    margin: 0;
    color: rgba(255,255,255,0.7);
    font-size: 0.95rem;
}

/* ── CTA section ── */

.cta-section[b-gqhx6b087h] {
    margin-top: 2.5rem;
    padding: 2rem 0;
    text-align: center;
}

.cta-section h2[b-gqhx6b087h] {
    color: white;
    font-size: 1.5rem;
    margin: 0 0 0.5rem;
}

.cta-section p[b-gqhx6b087h] {
    color: rgba(255,255,255,0.6);
    margin: 0 0 1.25rem;
}

.cta-section .cta.primary[b-gqhx6b087h] {
    display: inline-block;
    background: #6366f1;
    color: white;
    padding: 0.65rem 1.5rem;
    border-radius: 10px;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.15s;
}

.cta-section .cta.primary:hover[b-gqhx6b087h] {
    background: #4f46e5;
}

@media (max-width: 900px) {
    .grid[b-gqhx6b087h] {
        grid-template-columns: 1fr;
    }
    .steps-row[b-gqhx6b087h] {
        grid-template-columns: 1fr;
    }
}
/* _content/Mathos.App/Components/Pages/Pricing.razor.rz.scp.css */
.page-hero[b-7sqr81a2nv] {
    padding: 0.75rem 0 1.25rem;
}

.page-hero h1[b-7sqr81a2nv] {
    margin: 0 0 0.5rem;
    font-size: 2.2rem;
    color: white;
}

.page-hero p[b-7sqr81a2nv] {
    margin: 0;
    color: rgba(255,255,255,0.72);
    max-width: 70ch;
}

/* Section headings */
.section-title[b-7sqr81a2nv] {
    margin: 2.5rem 0 0.25rem;
    color: white;
    font-size: 1.4rem;
}

.section-sub[b-7sqr81a2nv] {
    margin: 0 0 1rem;
    color: rgba(255,255,255,0.55);
}

/* Plan cards */
.plan-grid[b-7sqr81a2nv] {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}

.plan[b-7sqr81a2nv] {
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 16px;
    background: rgba(255,255,255,0.04);
    padding: 1.25rem;
    text-align: center;
    position: relative;
}

.plan.popular[b-7sqr81a2nv] {
    border-color: #6366f1;
    background: rgba(99,102,241,0.08);
}

.pop-label[b-7sqr81a2nv] {
    position: absolute;
    top: -9px;
    left: 50%;
    transform: translateX(-50%);
    background: #6366f1;
    color: white;
    font-size: 0.65rem;
    font-weight: 700;
    padding: 0.15rem 0.6rem;
    border-radius: 20px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.plan h3[b-7sqr81a2nv] {
    margin: 0.2rem 0;
    font-size: 1.1rem;
    color: white;
}

.plan-for[b-7sqr81a2nv] {
    color: rgba(255,255,255,0.5);
    font-size: 0.85rem;
    margin: 0 0 0.75rem;
}

.plan-price[b-7sqr81a2nv] {
    font-size: 1.8rem;
    font-weight: 800;
    color: white;
}

.plan-price span[b-7sqr81a2nv] {
    font-size: 0.85rem;
    color: rgba(255,255,255,0.5);
    font-weight: 400;
}

/* Annual equivalent */
.plan-equiv[b-7sqr81a2nv] {
    margin: 0.25rem 0 0;
    color: rgba(255,255,255,0.45);
    font-size: 0.8rem;
}

/* Save badge */
.save-badge[b-7sqr81a2nv] {
    background: #22c55e;
    color: white;
    font-size: 0.7rem;
    font-weight: 700;
    padding: 0.2rem 0.5rem;
    border-radius: 20px;
    vertical-align: middle;
    margin-left: 0.4rem;
}

/* Trial note */
.trial-note[b-7sqr81a2nv] {
    margin-top: 1rem;
    text-align: center;
    color: rgba(255,255,255,0.6);
    font-size: 0.92rem;
}

.trial-note strong[b-7sqr81a2nv] {
    color: rgba(255,255,255,0.9);
}

.session-note[b-7sqr81a2nv] {
    text-align: center;
    color: rgba(255,255,255,0.4);
    font-size: 0.8rem;
    margin-top: 0.75rem;
    margin-bottom: 0;
}

/* CTA row */
.cta-row[b-7sqr81a2nv] {
    text-align: center;
    margin-top: 1.25rem;
}

.cta[b-7sqr81a2nv] {
    display: inline-block;
    text-decoration: none;
    padding: 0.8rem 1.25rem;
    border-radius: 14px;
    font-weight: 800;
}

.cta.primary[b-7sqr81a2nv] {
    background: rgba(255,255,255,0.92);
    color: #0b1220;
}

.cta.secondary[b-7sqr81a2nv] {
    border: 1px solid rgba(255,255,255,0.18);
    color: white;
}

/* Features grid */
.features-grid[b-7sqr81a2nv] {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-top: 0.75rem;
}

.feature-card[b-7sqr81a2nv] {
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 16px;
    background: rgba(255,255,255,0.04);
    padding: 1.25rem;
}

.feature-card h3[b-7sqr81a2nv] {
    margin: 0 0 0.6rem;
    color: white;
    font-size: 1.15rem;
}

.feature-card ul[b-7sqr81a2nv] {
    margin: 0;
    padding-left: 1.25rem;
    color: rgba(255,255,255,0.72);
}

.feature-card li[b-7sqr81a2nv] {
    margin: 0.3rem 0;
}

.feature-cta[b-7sqr81a2nv] {
    margin-top: 1rem;
}

/* Commission display */
.commission[b-7sqr81a2nv] {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
}

.commission-rate[b-7sqr81a2nv] {
    font-size: 2rem;
    font-weight: 900;
    color: white;
}

.commission-label[b-7sqr81a2nv] {
    color: rgba(255,255,255,0.6);
}

/* Refund grid */
.refund-grid[b-7sqr81a2nv] {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-top: 0.75rem;
}

.refund-item[b-7sqr81a2nv] {
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 14px;
    background: rgba(255,255,255,0.03);
    padding: 1rem;
}

.refund-item h3[b-7sqr81a2nv] {
    margin: 0 0 0.35rem;
    color: white;
    font-size: 1rem;
}

.refund-item p[b-7sqr81a2nv] {
    margin: 0;
    color: rgba(255,255,255,0.6);
    font-size: 0.9rem;
    line-height: 1.5;
}

/* Fine print */
.fineprint[b-7sqr81a2nv] {
    margin-top: 2rem;
    padding-top: 1.25rem;
    border-top: 1px solid rgba(255,255,255,0.08);
    color: rgba(255,255,255,0.5);
    font-size: 0.9rem;
}

.fineprint a[b-7sqr81a2nv] {
    color: white;
    font-weight: 700;
    text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,0.25);
}

.fineprint a:hover[b-7sqr81a2nv] {
    border-bottom-color: rgba(255,255,255,0.75);
}

/* Responsive */
@media (max-width: 900px) {
    .plan-grid[b-7sqr81a2nv] {
        grid-template-columns: repeat(2, 1fr);
    }

    .features-grid[b-7sqr81a2nv] {
        grid-template-columns: 1fr;
    }

    .refund-grid[b-7sqr81a2nv] {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 500px) {
    .plan-grid[b-7sqr81a2nv] {
        grid-template-columns: 1fr;
    }
}
/* _content/Mathos.App/Components/Pages/Privacy.razor.rz.scp.css */
.page-hero[b-u8q1j2wpmn] {
    padding: 0.75rem 0 1.25rem;
}

.page-hero h1[b-u8q1j2wpmn] {
    margin: 0 0 0.5rem;
    font-size: 2.2rem;
    color: white;
}

.page-hero p[b-u8q1j2wpmn] {
    margin: 0;
    color: rgba(255,255,255,0.72);
    max-width: 75ch;
}

.policy-card[b-u8q1j2wpmn] {
    margin-top: 1.25rem;
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 18px;
    background: rgba(255,255,255,0.05);
    padding: 1.5rem 1.5rem 1.75rem;
}

.policy-meta[b-u8q1j2wpmn] {
    display: flex;
    gap: 1.5rem;
    font-size: 0.82rem;
    color: rgba(255,255,255,0.5);
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.policy-card h2[b-u8q1j2wpmn] {
    margin: 1.75rem 0 0.6rem;
    color: white;
    font-size: 1.15rem;
}

.policy-card h2:first-of-type[b-u8q1j2wpmn] {
    margin-top: 0;
}

.policy-card h3[b-u8q1j2wpmn] {
    margin: 1.25rem 0 0.4rem;
    color: rgba(255,255,255,0.9);
    font-size: 1rem;
}

.policy-card p[b-u8q1j2wpmn], .policy-card li[b-u8q1j2wpmn] {
    color: rgba(255,255,255,0.75);
    line-height: 1.65;
}

.policy-card p[b-u8q1j2wpmn] {
    margin: 0.4rem 0 0.6rem;
}

.policy-card ul[b-u8q1j2wpmn] {
    margin: 0.25rem 0 0.9rem;
    padding-left: 1.25rem;
}

.policy-card li[b-u8q1j2wpmn] {
    margin-bottom: 0.25rem;
}

.policy-card a[b-u8q1j2wpmn] {
    color: white;
    font-weight: 700;
    text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,0.25);
}

.policy-card a:hover[b-u8q1j2wpmn] {
    border-bottom-color: rgba(255,255,255,0.75);
}

.policy-card strong[b-u8q1j2wpmn] {
    color: rgba(255,255,255,0.92);
}

.policy-footer[b-u8q1j2wpmn] {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(255,255,255,0.08);
    font-size: 0.82rem;
    color: rgba(255,255,255,0.45);
}
/* _content/Mathos.App/Components/Pages/Safeguarding.razor.rz.scp.css */
.page-hero[b-pv4num6i4c] {
    padding: 0.75rem 0 1.25rem;
}

.page-hero h1[b-pv4num6i4c] {
    margin: 0 0 0.5rem;
    font-size: 2.2rem;
    color: white;
}

.page-hero p[b-pv4num6i4c] {
    margin: 0;
    color: rgba(255,255,255,0.72);
    max-width: 75ch;
}

.safeguarding-content[b-pv4num6i4c] {
    margin-top: 1.25rem;
    max-width: 75ch;
}

.safeguarding-content h2[b-pv4num6i4c] {
    margin: 2rem 0 0.6rem;
    color: white;
    font-size: 1.15rem;
}

.safeguarding-content h2:first-of-type[b-pv4num6i4c] {
    margin-top: 0;
}

.safeguarding-content p[b-pv4num6i4c], .safeguarding-content li[b-pv4num6i4c] {
    color: rgba(255,255,255,0.75);
    line-height: 1.65;
}

.safeguarding-content p[b-pv4num6i4c] {
    margin: 0.4rem 0 0.6rem;
}

.safeguarding-content ul[b-pv4num6i4c] {
    margin: 0.25rem 0 0.9rem;
    padding-left: 1.25rem;
}

.safeguarding-content li[b-pv4num6i4c] {
    margin-bottom: 0.25rem;
}

.safeguarding-content a[b-pv4num6i4c] {
    color: white;
    font-weight: 700;
    text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,0.25);
}

.safeguarding-content a:hover[b-pv4num6i4c] {
    border-bottom-color: rgba(255,255,255,0.75);
}

.safeguarding-content strong[b-pv4num6i4c] {
    color: rgba(255,255,255,0.92);
}

.emergency[b-pv4num6i4c] {
    background: rgba(239, 68, 68, 0.12);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-radius: 10px;
    padding: 0.75rem 1rem;
}

.safeguarding-footer[b-pv4num6i4c] {
    margin-top: 2.5rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(255,255,255,0.08);
    font-size: 0.82rem;
    color: rgba(255,255,255,0.45);
}
/* _content/Mathos.App/Components/Pages/SignIn.razor.rz.scp.css */
.page-hero[b-9903ppgvtj] {
    padding: 0.75rem 0 1.25rem;
}

.page-hero h1[b-9903ppgvtj] {
    margin: 0 0 0.5rem;
    font-size: 2.2rem;
    color: white;
}

.page-hero p[b-9903ppgvtj] {
    margin: 0;
    color: rgba(255,255,255,0.72);
    max-width: 75ch;
}

.grid[b-9903ppgvtj] {
    margin-top: 1.25rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

.card[b-9903ppgvtj] {
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 18px;
    background: rgba(255,255,255,0.05);
    padding: 1.1rem;
}

.card h2[b-9903ppgvtj] {
    margin: 0 0 0.6rem;
    color: white;
    font-size: 1.25rem;
}

.card p[b-9903ppgvtj], .card li[b-9903ppgvtj] {
    color: rgba(255,255,255,0.75);
}

.card ul[b-9903ppgvtj] {
    margin: 0.25rem 0 0;
    padding-left: 1.25rem;
}

.span-2[b-9903ppgvtj] {
    grid-column: 1 / -1;
}

.cta-row[b-9903ppgvtj] {
    margin-top: 0.9rem;
    display: flex;
    gap: 0.6rem;
    flex-wrap: wrap;
}

.cta[b-9903ppgvtj] {
    display: inline-block;
    text-decoration: none;
    padding: 0.8rem 1rem;
    border-radius: 14px;
    font-weight: 800;
}

.cta.primary[b-9903ppgvtj] {
    background: rgba(255,255,255,0.92);
    color: #0b1220;
}

.cta.secondary[b-9903ppgvtj] {
    border: 1px solid rgba(255,255,255,0.18);
    color: white;
}

@media (max-width: 900px) {
    .grid[b-9903ppgvtj] {
        grid-template-columns: 1fr;
    }
}
/* _content/Mathos.App/Components/Pages/Terms.razor.rz.scp.css */
.page-hero[b-s5k1xqz7xw] {
    padding: 0.75rem 0 1.25rem;
}

.page-hero h1[b-s5k1xqz7xw] {
    margin: 0 0 0.5rem;
    font-size: 2.2rem;
    color: white;
}

.page-hero p[b-s5k1xqz7xw] {
    margin: 0;
    color: rgba(255,255,255,0.72);
    max-width: 75ch;
}

.policy-card[b-s5k1xqz7xw] {
    margin-top: 1.25rem;
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 18px;
    background: rgba(255,255,255,0.05);
    padding: 1.5rem 1.5rem 1.75rem;
}

.policy-meta[b-s5k1xqz7xw] {
    display: flex;
    gap: 1.5rem;
    font-size: 0.82rem;
    color: rgba(255,255,255,0.5);
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.policy-card h2[b-s5k1xqz7xw] {
    margin: 1.75rem 0 0.6rem;
    color: white;
    font-size: 1.15rem;
}

.policy-card h2:first-of-type[b-s5k1xqz7xw] {
    margin-top: 0;
}

.policy-card h3[b-s5k1xqz7xw] {
    margin: 1.25rem 0 0.4rem;
    color: rgba(255,255,255,0.9);
    font-size: 1rem;
}

.policy-card p[b-s5k1xqz7xw], .policy-card li[b-s5k1xqz7xw] {
    color: rgba(255,255,255,0.75);
    line-height: 1.65;
}

.policy-card p[b-s5k1xqz7xw] {
    margin: 0.4rem 0 0.6rem;
}

.policy-card ul[b-s5k1xqz7xw] {
    margin: 0.25rem 0 0.9rem;
    padding-left: 1.25rem;
}

.policy-card li[b-s5k1xqz7xw] {
    margin-bottom: 0.25rem;
}

.policy-card a[b-s5k1xqz7xw] {
    color: white;
    font-weight: 700;
    text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,0.25);
}

.policy-card a:hover[b-s5k1xqz7xw] {
    border-bottom-color: rgba(255,255,255,0.75);
}

.policy-card strong[b-s5k1xqz7xw] {
    color: rgba(255,255,255,0.92);
}

.policy-footer[b-s5k1xqz7xw] {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(255,255,255,0.08);
    font-size: 0.82rem;
    color: rgba(255,255,255,0.45);
}
/* _content/Mathos.App/Components/Pages/TutorAgreement.razor.rz.scp.css */
.page-hero[b-uxmcjo6t44] {
    padding: 0.75rem 0 1.25rem;
}

.page-hero h1[b-uxmcjo6t44] {
    margin: 0 0 0.5rem;
    font-size: 2.2rem;
    color: white;
}

.page-hero p[b-uxmcjo6t44] {
    margin: 0;
    color: rgba(255,255,255,0.72);
    max-width: 75ch;
}

.policy-card[b-uxmcjo6t44] {
    margin-top: 1.25rem;
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 18px;
    background: rgba(255,255,255,0.05);
    padding: 1.5rem 1.5rem 1.75rem;
}

.policy-meta[b-uxmcjo6t44] {
    display: flex;
    gap: 1.5rem;
    font-size: 0.82rem;
    color: rgba(255,255,255,0.5);
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.policy-card h2[b-uxmcjo6t44] {
    margin: 1.75rem 0 0.6rem;
    color: white;
    font-size: 1.15rem;
}

.policy-card h2:first-of-type[b-uxmcjo6t44] {
    margin-top: 0;
}

.policy-card h3[b-uxmcjo6t44] {
    margin: 1.25rem 0 0.4rem;
    color: rgba(255,255,255,0.9);
    font-size: 1rem;
}

.policy-card p[b-uxmcjo6t44], .policy-card li[b-uxmcjo6t44] {
    color: rgba(255,255,255,0.75);
    line-height: 1.65;
}

.policy-card p[b-uxmcjo6t44] {
    margin: 0.4rem 0 0.6rem;
}

.policy-card ul[b-uxmcjo6t44] {
    margin: 0.25rem 0 0.9rem;
    padding-left: 1.25rem;
}

.policy-card li[b-uxmcjo6t44] {
    margin-bottom: 0.25rem;
}

.policy-card a[b-uxmcjo6t44] {
    color: white;
    font-weight: 700;
    text-decoration: none;
    border-bottom: 1px solid rgba(255,255,255,0.25);
}

.policy-card a:hover[b-uxmcjo6t44] {
    border-bottom-color: rgba(255,255,255,0.75);
}

.policy-card strong[b-uxmcjo6t44] {
    color: rgba(255,255,255,0.92);
}

.policy-footer[b-uxmcjo6t44] {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(255,255,255,0.08);
    font-size: 0.82rem;
    color: rgba(255,255,255,0.45);
}
