@import url('https://fonts.googleapis.com/css2?family=Source+Sans+3:wght@400;600;700&family=Source+Serif+4:wght@600&display=swap');

:root {
    --siq-font-sans: "Source Sans 3", "Segoe UI", Helvetica, Arial, sans-serif;
    --siq-font-serif: "Source Serif 4", Georgia, "Times New Roman", serif;
    --siq-ink: #1f2a35;
    --siq-muted: #6b7a8a;
    --siq-brand-primary: #1f2a35;
    --siq-brand-accent: #ff7a59;
    --siq-brand-bg: #f6f7fb;
    --siq-brand-sidebar-top: #1f2a35;
    --siq-brand-sidebar-bottom: #15202c;
    --siq-accent: var(--siq-brand-accent);
    --siq-bg: var(--siq-brand-bg);
    --siq-notification-panel-bg: #ffffff;
    --siq-notification-header-bg: color-mix(in srgb, var(--siq-brand-bg) 72%, #ffffff);
    --siq-notification-text: var(--siq-ink);
    --siq-notification-muted: var(--siq-muted);
    --siq-notification-border: color-mix(in srgb, var(--siq-brand-primary) 18%, #ffffff);
    --siq-notification-unread-bg: color-mix(in srgb, var(--siq-brand-accent) 10%, #ffffff);
    --siq-notification-unread-border: color-mix(in srgb, var(--siq-brand-accent) 44%, transparent);
    --siq-space-1: 4px;
    --siq-space-2: 8px;
    --siq-space-3: 12px;
    --siq-space-4: 16px;
    --siq-space-5: 20px;
    --siq-space-6: 24px;
    --siq-radius-1: 8px;
    --siq-radius-2: 12px;
    --siq-radius-3: 16px;
    --siq-shadow-1: 0 6px 14px rgba(15, 23, 42, 0.08);
    --siq-shadow-2: 0 14px 28px rgba(15, 23, 42, 0.12);
    /* HLMS aliases (preferred naming moving forward) */
    --hlms-font-sans: var(--siq-font-sans);
    --hlms-font-serif: var(--siq-font-serif);
    --hlms-ink: var(--siq-ink);
    --hlms-muted: var(--siq-muted);
    --hlms-brand-primary: var(--siq-brand-primary);
    --hlms-brand-accent: var(--siq-brand-accent);
    --hlms-brand-bg: var(--siq-brand-bg);
    --hlms-brand-sidebar-top: var(--siq-brand-sidebar-top);
    --hlms-brand-sidebar-bottom: var(--siq-brand-sidebar-bottom);
    --hlms-accent: var(--siq-accent);
    --hlms-bg: var(--siq-bg);
    --hlms-notification-panel-bg: var(--siq-notification-panel-bg);
    --hlms-notification-header-bg: var(--siq-notification-header-bg);
    --hlms-notification-text: var(--siq-notification-text);
    --hlms-notification-muted: var(--siq-notification-muted);
    --hlms-notification-border: var(--siq-notification-border);
    --hlms-notification-unread-bg: var(--siq-notification-unread-bg);
    --hlms-notification-unread-border: var(--siq-notification-unread-border);
    --hlms-space-1: var(--siq-space-1);
    --hlms-space-2: var(--siq-space-2);
    --hlms-space-3: var(--siq-space-3);
    --hlms-space-4: var(--siq-space-4);
    --hlms-space-5: var(--siq-space-5);
    --hlms-space-6: var(--siq-space-6);
    --hlms-radius-1: var(--siq-radius-1);
    --hlms-radius-2: var(--siq-radius-2);
    --hlms-radius-3: var(--siq-radius-3);
    --hlms-shadow-1: var(--siq-shadow-1);
    --hlms-shadow-2: var(--siq-shadow-2);
    --app-topbar: 64px;
    --app-page-max: 1680px;
    --app-surface: #ffffff;
    --app-border: rgba(15, 23, 42, 0.1);
    --app-soft-border: rgba(15, 23, 42, 0.06);
    --app-shadow-soft: 0 10px 24px rgba(15, 23, 42, 0.06);
    --app-shadow-lift: 0 18px 42px rgba(15, 23, 42, 0.1);
    --role-tier-super-bg: color-mix(in srgb, var(--bs-danger) 12%, var(--app-surface));
    --role-tier-super-fg: color-mix(in srgb, var(--bs-danger) 78%, var(--siq-ink));
    --role-tier-admin-bg: color-mix(in srgb, var(--bs-info) 14%, var(--app-surface));
    --role-tier-admin-fg: color-mix(in srgb, var(--bs-info) 72%, var(--siq-ink));
    --role-tier-manager-bg: color-mix(in srgb, var(--bs-warning) 20%, var(--app-surface));
    --role-tier-manager-fg: color-mix(in srgb, var(--bs-warning) 58%, var(--siq-ink));
    --role-tier-learner-bg: color-mix(in srgb, var(--siq-muted) 12%, var(--app-surface));
    --role-tier-learner-fg: color-mix(in srgb, var(--siq-muted) 84%, var(--siq-ink));
    --role-tier-selected-bg: color-mix(in srgb, var(--bs-info) 9%, var(--app-surface));
}

html, body {
    font-family: var(--siq-font-sans);
    color: var(--siq-ink);
    background: var(--siq-bg);
}

h1, h2, h3 {
    font-family: var(--siq-font-serif);
}

h1:focus {
    outline: none;
}

a, .btn-link {
    color: var(--siq-accent);
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

:focus-visible {
    outline: 2px solid var(--siq-accent);
    outline-offset: 2px;
}

.btn-primary {
    color: #fff;
    background-color: var(--siq-accent);
    border-color: var(--siq-accent);
}

.content {
    width: 100%;
    max-width: var(--app-page-max);
    margin-inline: auto;
    padding-top: 1.1rem;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid red;
}

.validation-message {
    color: red;
}

.support-diagnostics {
    max-width: 100%;
    overflow-x: hidden;
}

.support-observability-summary {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
}

.support-observability-section {
    border-top: 1px solid #e5e7eb;
    margin-top: 1rem;
    padding-top: 1rem;
}

.support-section-heading {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.support-section-title {
    color: #111827;
    font-size: 0.92rem;
    font-weight: 700;
}

.support-section-subtitle {
    color: #6b7280;
    font-size: 0.78rem;
    line-height: 1.35;
}

.support-selected-enrollment,
.support-empty-note {
    background: #f8fafc;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    padding: 0.65rem 0.75rem;
}

.support-empty-note {
    color: #64748b;
    font-size: 0.85rem;
}

.support-activity-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.support-activity-column {
    min-width: 0;
}

.support-activity-heading {
    color: #374151;
    font-size: 0.78rem;
    font-weight: 700;
    margin-bottom: 0.45rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.support-diagnostics .small,
.support-diagnostics code,
.support-runtime-row,
.support-runtime-value {
    overflow-wrap: anywhere;
    word-break: break-word;
    white-space: normal;
}

.support-runtime-row {
    max-width: 100%;
    min-width: 0;
    line-height: 1.45;
}

.support-runtime-row code {
    font-size: 0.875em;
}

.support-runtime-value {
    display: inline;
}

@media (max-width: 1200px) {
    .support-observability-summary,
    .support-activity-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 768px) {
    .support-observability-summary,
    .support-activity-grid {
        grid-template-columns: 1fr;
    }

    .support-section-heading {
        flex-direction: column;
    }
}

#blazor-error-ui {
    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 {
    cursor: pointer;
    position: absolute;
    right: 0.75rem;
    top: 0.5rem;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHZpZXdCb3g9IjAgMCA1NiA0OSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTEzLjUgNi41TDEwLjUgMy41TDQgMTBIMRNIMTR2LTAuNVY2LjVaIiBmaWxsPSIjQzMwRDEyIi8+CjxwYXRoIGQ9Ik0yMyAzMy41TDI4IDEwLjVIMTZMMTEgMzIuNUg1VjQ5SDQ5VjMyLjVIMjNaIiBmaWxsPSIjQzMwRDEyIi8+Cjwvc3ZnPgo=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

.blazor-error-boundary::after {
    content: "An error has occurred."
}

.loading-progress {
    position: relative;
    display: block;
    width: 8rem;
    height: 8rem;
    margin: 20vh auto 1rem auto;
}

.loading-progress circle {
    fill: none;
    stroke: #e0e0e0;
    stroke-width: 0.6rem;
    transform-origin: 50% 50%;
    transform: rotate(-90deg);
}

.loading-progress circle:last-child {
    stroke: var(--siq-brand-accent, #ff7a59);
    stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * 0.01 * 2 * 8rem), 500%;
    transition: stroke-dasharray 0.05s ease-in-out;
}

.loading-progress-text {
    position: absolute;
    text-align: center;
    font-weight: bold;
    inset: calc(20vh + 3.25rem) 0 auto 0.2rem;
}

.loading-progress-text:after {
    content: var(--blazor-load-percentage, 0%) "%";
}

.page {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    --app-topbar: 64px;
}

.main {
    flex: 1;
    min-width: 0;
}

.sidebar {
    background: linear-gradient(180deg, var(--siq-brand-sidebar-top, #1f2a35) 0%, color-mix(in srgb, var(--siq-brand-sidebar-top, #1f2a35) 55%, var(--siq-brand-sidebar-bottom, #15202c)) 40%, var(--siq-brand-sidebar-bottom, #15202c) 100%);
    border-right: 1px solid rgba(255, 255, 255, 0.08);
}

.nav-section {
    margin: 0.25rem 0.5rem;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.03);
    transition: border-color 0.2s ease, background 0.2s ease;
}

.sidebar .nav-scrollable .nav.flex-column > .nav-dashboard {
    order: 0;
}

.sidebar .nav-scrollable .nav.flex-column > .nav-section-people {
    order: 10;
}

.sidebar .nav-scrollable .nav.flex-column > .nav-section-content {
    order: 20;
}

.sidebar .nav-scrollable .nav.flex-column > .nav-section-learning {
    order: 30;
}

.sidebar .nav-scrollable .nav.flex-column > .nav-section-reports {
    order: 40;
}

.sidebar .nav-scrollable .nav.flex-column > .nav-section-seats {
    order: 50;
}

.sidebar .nav-scrollable .nav.flex-column > .nav-section-implementation {
    order: 60;
}

.sidebar .nav-scrollable .nav.flex-column > .nav-section-support {
    order: 70;
}

.sidebar .nav-scrollable .nav.flex-column > .nav-section-tools {
    order: 80;
}

.sidebar .nav-scrollable .nav.flex-column > .nav-item:not(.nav-dashboard) {
    order: 90;
}

.nav-section.expanded {
    border-color: color-mix(in srgb, var(--siq-accent) 55%, transparent);
    background: rgba(255, 255, 255, 0.05);
}

.nav-section-toggle {
    width: 100%;
    background: transparent;
    border: 0;
    color: rgba(255, 255, 255, 0.9);
    text-align: left;
    padding: 0.75rem 0.9rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-weight: 600;
    letter-spacing: 0.1px;
    cursor: pointer;
}

.nav-section-label {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.nav-section .chevron {
    display: inline-block;
    transform: rotate(90deg);
    transition: transform 0.18s ease;
    font-size: 0.85rem;
    opacity: 0.8;
}

.nav-section:not(.expanded) .chevron {
    transform: rotate(0deg);
}

.nav-section-items {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    padding: 0 0.5rem 0.6rem 0.5rem;
}

.nav-section-items .nav-link {
    color: rgba(255, 255, 255, 0.85) !important;
    border-radius: 8px;
    padding: 0.45rem 0.75rem;
    height: auto;
    line-height: 1.2;
    margin: 0.1rem 0;
    transition: all 0.15s ease;
}

.nav-section-items .nav-link.active {
    background: linear-gradient(90deg, color-mix(in srgb, var(--siq-accent) 80%, transparent), color-mix(in srgb, var(--siq-accent) 60%, transparent));
    color: #fff !important;
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
}

.nav-section-items .nav-link:hover {
    background: rgba(255, 255, 255, 0.08) !important;
    color: #fff !important;
    transform: translateX(2px);
}

.sidebar .nav-item a {
    padding: 0.45rem 0.85rem;
    height: auto;
    border-radius: 8px;
}

.sidebar .nav-item a:hover {
    background-color: rgba(255, 255, 255, 0.08) !important;
}

.sidebar .nav-item a.active {
    background: linear-gradient(90deg, color-mix(in srgb, var(--siq-accent) 80%, transparent), color-mix(in srgb, var(--siq-accent) 60%, transparent)) !important;
    color: #fff !important;
}

.sidebar-settings {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding: 0.75rem 0 1rem 0;
}

.sidebar .navbar-brand {
    font-size: 1.05rem;
    letter-spacing: 0.4px;
}

.sidebar .top-row {
    background: var(--siq-brand-sidebar-top, #1f2a35) !important;
    backdrop-filter: blur(4px);
    color: #fff;
}
.sidebar .navbar-toggler {
    border-color: rgba(255,255,255,0.5);
}
.sidebar .navbar-toggler-icon {
    filter: invert(1);
}

.navbar.navbar-dark {
    background: var(--siq-brand-sidebar-top, #1f2a35) !important;
    color: #fff;
}
.navbar.navbar-dark .navbar-brand {
    color: #fff !important;
}
.navbar.navbar-dark .navbar-toggler {
    border-color: rgba(255,255,255,0.6);
}
.navbar.navbar-dark .navbar-toggler-icon {
    filter: invert(1);
}

.main .top-row {
    background-color: var(--siq-brand-primary);
    border-bottom: none;
    justify-content: space-between;
    height: 3.5rem;
    display: flex;
    align-items: center;
    color: #fff;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.scope-bar {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 0;
}

.scope-switcher {
    position: relative;
}

.scope-locked-label {
    display: inline-flex;
    align-items: center;
    max-width: 520px;
    min-width: 220px;
    padding: 0.45rem 0.7rem;
    border: 1px solid rgba(15, 23, 42, 0.12);
    border-radius: 12px;
    background: #fff;
    color: #1f2a35;
    font-size: 0.9rem;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    box-shadow: 0 6px 14px rgba(15, 23, 42, 0.08);
}

.scope-switcher-button {
    border: 1px solid rgba(15, 23, 42, 0.12);
    background: #fff;
    border-radius: 12px;
    padding: 0.45rem 0.7rem;
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 220px;
    max-width: 520px;
    text-align: left;
    box-shadow: 0 6px 14px rgba(15, 23, 42, 0.08);
}

.scope-switcher-label {
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #5a6a7a;
    font-weight: 600;
}

.scope-switcher-value {
    font-size: 0.9rem;
    font-weight: 600;
    color: #1f2a35;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.scope-overlay {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.2);
    z-index: 80;
}

.scope-dropdown {
    position: absolute;
    top: calc(100% + 0.65rem);
    left: 0;
    width: min(980px, 82vw);
    background: #fff;
    border-radius: 16px;
    border: 1px solid rgba(15, 23, 42, 0.12);
    box-shadow: 0 22px 34px rgba(15, 23, 42, 0.18);
    padding: 0.85rem;
    z-index: 90;
}

.scope-dropdown-header {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    padding-bottom: 0.6rem;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}
.scope-dropdown-desc {
    font-size: 0.72rem;
    color: #64748b;
    line-height: 1.35;
    padding: 0.25rem 0.1rem 0;
}

.scope-dropdown-body {
    display: grid;
    gap: 1rem;
    padding-top: 0.8rem;
}

.scope-columns {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.6rem;
}

.scope-column {
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 12px;
    padding: 0.5rem;
    background: #f9fafb;
}

.scope-column-title {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #5a6a7a;
    font-weight: 600;
    margin-bottom: 0.35rem;
}

.scope-list {
    background: transparent;
}

.scope-list-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.35rem;
    padding: 0.35rem 0.25rem;
    border-radius: 8px;
}

.scope-list-item.is-selected {
    background: rgba(255, 122, 89, 0.12);
}

.scope-list-item.is-active {
    background: rgba(40, 181, 160, 0.14);
}

.scope-list-item.is-disabled {
    opacity: 0.5;
}

.scope-list-action {
    background: transparent;
    border: 0;
    color: #1f2a35;
    font-weight: 600;
    text-align: left;
    flex: 1;
    padding: 0;
    cursor: pointer;
}

.scope-list-action:disabled {
    color: #6b7a8a;
    cursor: not-allowed;
}

.scope-list-actions {
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.scope-list-select,
.scope-list-next {
    border: 1px solid rgba(15, 23, 42, 0.12);
    background: #fff;
    border-radius: 999px;
    font-size: 0.7rem;
    padding: 0.1rem 0.5rem;
    line-height: 1.2;
    cursor: pointer;
}

.scope-tree-panel {
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 12px;
    padding: 0.6rem;
    background: #f8fafc;
}

.scope-tree {
    background: transparent;
    max-height: 360px;
}

.scope-node {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    width: 100%;
}

.scope-node.is-selected {
    color: var(--siq-brand-accent, #ff7a59);
    font-weight: 700;
}

.scope-node.is-disabled {
    opacity: 0.5;
}

.scope-node-meta {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #6b7a8a;
}

.scope-mobile-dialog .e-dlg-content {
    padding: 0.75rem;
}

.scope-mobile-dialog.e-dialog {
    max-width: 100%;
    width: 100%;
    height: 100%;
    margin: 0;
    border-radius: 0;
    z-index: 1000;
}

.scope-mobile-dialog .e-dlg-content {
    height: 100vh;
    overflow: hidden;
    padding: 0;
    background: #fff;
}

.scope-mobile-shell {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 0.85rem;
    gap: 0.75rem;
    background: #f8fafc;
}

.scope-mobile-tabs {
    display: flex;
    gap: 0.5rem;
    padding: 0.35rem;
    border-radius: 14px;
    border: 1px solid rgba(15, 23, 42, 0.12);
    background: #fff;
}

.scope-mobile-tab {
    flex: 1;
    border: 0;
    background: transparent;
    border-radius: 10px;
    padding: 0.4rem 0.65rem;
    font-weight: 600;
    color: #5a6a7a;
    cursor: pointer;
}

.scope-mobile-tab.is-active {
    background: rgba(255, 122, 89, 0.16);
    color: #1f2a35;
}

.scope-mobile-body {
    flex: 1;
    overflow-y: auto;
    padding: 0.25rem 0 0.75rem 0;
    max-height: calc(100vh - 220px);
}

.scope-mobile-row {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.65rem 0.75rem;
    border-radius: 12px;
    border: 1px solid #e5e7eb;
    background: #fff;
    box-shadow: 0 4px 10px rgba(15, 23, 42, 0.05);
    margin-bottom: 0.65rem;
}

.scope-mobile-row.is-selected {
    background: rgba(255, 122, 89, 0.12);
}

.scope-mobile-row.is-disabled {
    opacity: 0.6;
}

.scope-mobile-select {
    flex: 1;
    border: 0;
    background: transparent;
    text-align: left;
    padding: 0.15rem 0;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    color: #1f2a35;
    font-weight: 700;
}

.scope-mobile-select:disabled {
    color: #6b7a8a;
}

.scope-mobile-name {
    font-size: 1.05rem;
}

.scope-mobile-panel {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.scope-mobile-list {
    display: flex;
    flex-direction: column;
}

.scope-mobile-next {
    border: 1px solid rgba(15, 23, 42, 0.12);
    background: #fff;
    border-radius: 999px;
    font-size: 0.9rem;
    padding: 0.3rem 0.7rem;
    line-height: 1;
    box-shadow: 0 1px 6px rgba(15, 23, 42, 0.08);
    min-width: 38px;
    cursor: pointer;
}

.scope-mobile-drill-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.scope-mobile-header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.scope-mobile-back {
    border: 1px solid rgba(15, 23, 42, 0.15);
    background: #fff;
    border-radius: 999px;
    padding: 0.25rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 600;
    cursor: pointer;
}

.scope-mobile-title {
    font-weight: 700;
    font-size: 1rem;
}

.scope-mobile-breadcrumb {
    font-size: 0.85rem;
    color: #6b7a8a;
}

.scope-mobile-search {
    margin-bottom: 0.75rem;
}

.scope-mobile-hint {
    font-size: 0.85rem;
    color: #4b5563;
    margin: 0 0 0.65rem 0;
}

.scope-mobile-empty {
    font-size: 0.9rem;
    color: #6b7a8a;
    padding: 0.75rem 0.25rem;
}

.scope-selector {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.scope-selector-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #5a6a7a;
}

.scope-selector-controls {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.scope-selector-controls .form-select {
    min-width: 9rem;
}

.scope-breadcrumb {
    font-size: 0.8rem;
    color: #6b7a8a;
}

.scope-loading {
    font-size: 0.85rem;
    color: #6b7a8a;
}

.top-row-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.global-search {
    position: relative;
}

.global-search-toggle {
    border-radius: 999px;
}

.global-search-panel {
    position: absolute;
    top: calc(100% + 0.5rem);
    left: 0;
    width: 360px;
    background: #fff;
    border-radius: 12px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    box-shadow: 0 12px 24px rgba(24, 39, 75, 0.12);
    padding: 0.75rem;
    z-index: 30;
}

.global-search-header {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

.global-search-status {
    padding: 0.75rem 0.25rem;
    color: #6b7a8a;
    font-size: 0.85rem;
}

.global-search-results {
    list-style: none;
    margin: 0.75rem 0 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.global-search-results li a {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    padding: 0.5rem 0.6rem;
    border-radius: 8px;
    text-decoration: none;
    color: #1f2a35;
    border: 1px solid transparent;
}

.global-search-results li a:hover {
    border-color: rgba(255, 122, 89, 0.35);
    background: rgba(255, 122, 89, 0.08);
}

.global-search-type {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #6b7a8a;
}

.global-search-name {
    font-size: 0.95rem;
    font-weight: 600;
}

.global-search-meta {
    font-size: 0.8rem;
    color: #6b7a8a;
}

.audit-pill {
    display: inline-flex;
    align-items: center;
    padding: 0.15rem 0.6rem;
    border-radius: 999px;
    background: rgba(31, 42, 53, 0.07);
    border: 1px solid rgba(31, 42, 53, 0.1);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: #475569;
    white-space: nowrap;
}

.dashboard-hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

.dashboard-hero-scope {
    text-align: right;
    min-width: 12rem;
}

.dashboard-hero-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #6b7a8a;
}

.dashboard-hero-value {
    font-size: 0.95rem;
    color: #2d3e50;
    font-weight: 600;
}

.dashboard-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.dashboard-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.stat-card {
    border-radius: 14px;
    padding: 1.1rem 1.25rem;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #fff;
    box-shadow: 0 2px 16px rgba(15, 23, 42, 0.07), 0 0 0 1px rgba(15, 23, 42, 0.025);
    transition: box-shadow 0.15s ease;
}

.stat-card:hover {
    box-shadow: 0 4px 20px rgba(15, 23, 42, 0.1), 0 0 0 1px rgba(15, 23, 42, 0.04);
}

.stat-label {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #64748b;
    margin-bottom: 0.2rem;
}

.stat-value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.1;
    color: #111827;
}

.stat-subtitle {
    font-size: 0.8rem;
    color: #94a3b8;
    margin-top: 0.15rem;
}

.dashboard-surface {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.5rem;
    padding: 1.2rem;
    border-radius: 12px;
    background: #f8fafc;
    border: 1px solid rgba(0, 0, 0, 0.06);
}

.dashboard-list {
    margin: 0.75rem 0 0 0;
    padding: 0;
}

.dashboard-list li {
    margin-bottom: 0.4rem;
}

.dashboard-list a {
    text-decoration: none;
    color: #2d3e50;
}

.dashboard-list a:hover {
    color: var(--siq-brand-accent, #ff7a59);
    text-decoration: underline;
}

.data-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.data-toolbar-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.data-toolbar-meta {
    font-size: 0.85rem;
    color: #6b7a8a;
}

.main .top-row > a, .main .navbar a {
    white-space: nowrap;
}

.main .top-row a, .main .navbar a {
    color: #f1f5f9;
    text-decoration: none;
}

.main .top-row a:hover, .main .navbar a:hover {
    color: var(--siq-accent);
    text-decoration: underline;
}

.sidebar .top-row {
    background: var(--siq-brand-sidebar-top, #1f2a35) !important;
    height: 3.5rem;
    padding: 0 !important;
}

.sidebar .top-row .container-fluid {
    padding: 0;
    height: 100%;
    position: relative;
}

.sidebar .navbar-brand {
    font-size: 1.1rem;
    color: white;
    font-weight: 600;
    padding: 0;
    height: 100%;
    display: flex;
    align-items: center;
}

.sidebar .navbar-brand:hover {
    color: rgba(255, 255, 255, 0.9);
}

.brand-logo {
    height: 24px;
    width: auto;
    max-width: 140px;
    object-fit: contain;
}

.brand-logo-nav {
    height: 3.5rem;
    width: auto;
    max-width: 220px;
    object-fit: contain;
    display: block;
}

.learner-nav-portal-badge {
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.55);
    border: 1px solid rgba(255, 255, 255, 0.25);
    border-radius: 4px;
    padding: 1px 5px;
    line-height: 1.4;
    white-space: nowrap;
}

.learner-nav-brand {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    margin: 0 !important;
    display: flex;
    align-items: center;
}

.sidebar .oi {
    width: 1rem;
    height: 1rem;
    vertical-align: text-top;
    top: -2px;
    position: relative;
}

.sidebar .nav-item {
    font-size: 0.9rem;
    padding-bottom: 0.5rem;
}

.sidebar .nav-item:first-of-type {
    padding-top: 1rem;
}

.sidebar .nav-item:last-of-type {
    padding-bottom: 1rem;
}

.sidebar .nav-item a {
    color: rgba(255, 255, 255, 0.9) !important;
    border-radius: 6px;
    height: 3rem;
    display: flex;
    align-items: center;
    line-height: 3rem;
    text-decoration: none;
    padding: 0.5rem 1rem;
    transition: all 0.2s ease;
}

.sidebar .nav-item a.active {
    background-color: color-mix(in srgb, var(--siq-accent) 80%, transparent) !important;
    color: white !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.sidebar .nav-item a:hover {
    background-color: color-mix(in srgb, var(--siq-accent) 20%, transparent) !important;
    color: white !important;
    transform: translateX(2px);
}

.sidebar .nav-scrollable {
    display: none;
    flex-direction: column;
    height: calc(100vh - 56px);
}

.sidebar .nav-scrollable.collapse.show {
    display: block;
}

.sidebar .sidebar-settings {
    margin-top: auto;
    padding-bottom: 1rem;
}

.sidebar .sidebar-settings-link {
    color: rgba(255, 255, 255, 0.7) !important;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 0.25rem 0.5rem;
}

.sidebar .sidebar-settings-link:hover,
.sidebar .sidebar-settings-link.active {
    color: var(--siq-accent) !important;
    text-decoration: underline;
    background: transparent !important;
}

.sidebar .navbar-toggler {
    background-color: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.2);
}

.sidebar .navbar-toggler:focus {
    border-color: color-mix(in srgb, var(--siq-accent) 50%, transparent);
    box-shadow: 0 0 0 0.1rem color-mix(in srgb, var(--siq-accent) 25%, transparent);
}

a:focus-visible,
button:focus-visible,
.nav-link:focus-visible,
.nav-section-toggle:focus-visible,
.form-control:focus-visible,
.form-select:focus-visible {
    outline: 2px solid #1f7a5c;
    outline-offset: 2px;
}

.table-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
    justify-content: flex-end;
    align-items: center;
}

/* Enforce consistent table action button appearance across all pages */
.table-actions .btn {
    font-size: 0.78rem !important;
    padding: 0.2rem 0.55rem !important;
    border-radius: 6px !important;
    font-weight: 500;
    white-space: nowrap;
    line-height: 1.4;
}

/* Neutralize pill-shaped action buttons */
.table-actions .rounded-pill {
    border-radius: 6px !important;
}

/* Icon-only action buttons — give them a consistent square shape */
.table-actions .btn:has(i:only-child),
.table-actions .btn-icon {
    width: 30px;
    height: 30px;
    padding: 0 !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px !important;
}

/* ── AppRowMenu ─────────────────────────────────────────────────────────── */
.row-menu {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 2px;
}

.row-menu-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1040;
}

/* Shared base for all icon buttons in a row */
.row-menu-btn,
.row-menu-primary-btn,
.row-menu-quick-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    padding: 0;
    border: 1px solid transparent;
    border-radius: 6px;
    background: transparent;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s, color 0.15s, opacity 0.12s;
    font-size: 1rem;
}

/* Primary action — always visible, accent colour */
.row-menu-primary-btn {
    color: var(--hlms-accent, #ff7a59);
    opacity: 0.8;
}

.row-menu-primary-btn:hover {
    background: rgba(255, 122, 89, 0.1);
    border-color: rgba(255, 122, 89, 0.2);
    opacity: 1;
}

/* Quick actions strip — always visible, muted at rest */
.row-menu-quick {
    display: inline-flex;
    align-items: center;
    gap: 2px;
}

.row-menu-quick-btn {
    color: var(--hlms-text-muted, #64748b);
}

.row-menu-quick-btn:hover {
    background: rgba(15, 23, 42, 0.07);
    border-color: rgba(15, 23, 42, 0.12);
    color: var(--hlms-text, #1e293b);
}

.row-menu-quick-btn.danger {
    color: #dc3545;
}

.row-menu-quick-btn.danger:hover {
    background: rgba(220, 53, 69, 0.07);
    border-color: rgba(220, 53, 69, 0.15);
    color: #b91c2c;
}

/* ⋮ button — always visible but muted; brightens on hover */
.row-menu-btn {
    color: var(--hlms-text-muted, #64748b);
    opacity: 0.45;
}

tr:hover .row-menu-btn,
.row-menu.open .row-menu-btn {
    opacity: 1;
}

.row-menu-btn:hover,
.row-menu.open .row-menu-btn {
    background: rgba(15, 23, 42, 0.07);
    border-color: rgba(15, 23, 42, 0.12);
    color: var(--hlms-text, #1e293b);
    opacity: 1;
}

.row-menu-list {
    position: absolute;
    right: 0;
    top: calc(100% + 4px);
    z-index: 1050;
    min-width: 160px;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 8px;
    box-shadow: 0 4px 16px rgba(15, 23, 42, 0.12);
    padding: 0.3rem 0;
    display: flex;
    flex-direction: column;
}

.row-menu-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.42rem 0.85rem;
    background: transparent;
    border: none;
    width: 100%;
    text-align: left;
    font-size: 0.83rem;
    font-weight: 500;
    color: var(--hlms-text, #1e293b);
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.12s, color 0.12s;
    text-decoration: none;
}

.row-menu-item:hover {
    background: rgba(15, 23, 42, 0.05);
    color: var(--hlms-text, #1e293b);
}

.row-menu-item.danger {
    color: #dc3545;
}

.row-menu-item.danger:hover {
    background: rgba(220, 53, 69, 0.07);
    color: #b91c2c;
}

.row-menu-item i {
    width: 14px;
    text-align: center;
    flex-shrink: 0;
    opacity: 0.75;
}

/* Actions column — always right-align the ⋮ button */
.app-table th:last-child,
.app-table td:last-child {
    text-align: right;
    white-space: nowrap;
}

/* Section label inside a drawer form */
.form-section-divider {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--siq-muted, #64748b);
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    padding-bottom: 0.25rem;
}

/* Bulk-action bar shown when rows are selected */
.bulk-action-bar {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem 0.85rem;
    background: rgba(255, 122, 89, 0.07);
    border: 1px solid rgba(255, 122, 89, 0.25);
    border-radius: 8px;
    margin-bottom: 0.5rem;
    font-size: 0.85rem;
}

.user-bulk-action-bar {
    justify-content: space-between;
    flex-wrap: wrap;
    background: color-mix(in srgb, var(--bs-info) 8%, var(--app-surface));
    border-color: color-mix(in srgb, var(--bs-info) 22%, var(--app-border));
}

.bulk-action-main,
.bulk-action-group,
.bulk-action-danger,
.bulk-selected-count {
    display: flex;
    align-items: center;
}

.bulk-action-main {
    gap: 0.85rem;
    flex-wrap: wrap;
}

.bulk-action-group,
.bulk-action-danger {
    gap: 0.45rem;
    flex-wrap: wrap;
}

.bulk-selected-count {
    gap: 0.4rem;
    color: var(--siq-ink);
    font-weight: 700;
}

.bulk-selected-count i {
    color: var(--bs-info);
}

.bulk-context {
    color: var(--siq-muted);
    font-size: 0.8rem;
}

.bulk-action-divider {
    width: 1px;
    height: 1.35rem;
    background: var(--app-border);
    margin-inline: 0.2rem;
}

.bulk-confirmation {
    display: grid;
    gap: 0.45rem;
    color: var(--siq-ink);
    font-size: 0.9rem;
}

.bulk-confirmation-label {
    display: inline-flex;
    min-width: 3.8rem;
    color: var(--siq-muted);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.row-menu-divider {
    height: 1px;
    background: rgba(15, 23, 42, 0.08);
    margin: 0.3rem 0;
}

/* Keep row-menu list above table rows on hover */
tr:hover .row-menu-list {
    z-index: 1050;
}

/* Allow dropdown to overflow the table clip container when open */
.app-table-wrap:has(.row-menu.open),
.table-responsive:has(.row-menu.open) {
    overflow: visible;
}

.navbar-toggler {
    appearance: none;
    border-color: rgba(255, 255, 255, 0.6);
}

.navbar-dark .navbar-brand {
    color: #fff;
}

.navbar-dark .navbar-toggler-icon {
    background-image: 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, 1%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

.collapse {
    display: none;
}

.collapse.show {
    display: block;
}

.nav-icon {
    margin-right: 8px;
}

.toast-message {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 1100;
    padding: 0.75rem 1rem;
    border-radius: 8px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.18);
    min-width: 260px;
    max-width: 420px;
    font-size: 0.9rem;
    transition: opacity 0.3s;
}

.app-card {
    border-radius: 12px;
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: #fff;
    box-shadow: 0 8px 18px rgba(24, 39, 75, 0.06);
}

.app-page {
    display: flex;
    flex-direction: column;
    gap: var(--siq-space-4);
}

.page-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
    padding: 0 0 1.1rem 0;
    border-bottom: 1px solid rgba(15, 23, 42, 0.1);
    background: transparent;
}

.page-header > div:first-child,
.page-header .header-intro {
    min-width: min(100%, 280px);
    flex: 1 1 320px;
}

.page-header .fw-semibold.fs-5 {
    font-size: 1.35rem !important;
    font-weight: 700 !important;
    line-height: 1.2;
    letter-spacing: -0.01em;
    color: #111827;
}

.page-header .text-muted.small {
    max-width: 64ch;
    margin-top: 0.15rem;
    line-height: 1.35;
}

.page-breadcrumb {
    margin-bottom: 0.3rem;
}

.page-breadcrumb .breadcrumb {
    font-size: 0.75rem;
    font-weight: 500;
    line-height: 1;
    gap: 0;
}

.page-breadcrumb .breadcrumb-item {
    color: var(--siq-muted, #6b7280);
}

.page-breadcrumb .breadcrumb-item + .breadcrumb-item::before {
    content: "/";
    color: #c5cdd6;
    font-weight: 400;
    padding: 0 0.35rem;
}

.page-breadcrumb .breadcrumb-item a {
    color: var(--siq-muted, #6b7280);
    text-decoration: none;
}

.page-breadcrumb .breadcrumb-item a:hover {
    color: var(--siq-primary, #ff7a59);
    text-decoration: none;
}

.page-breadcrumb .breadcrumb-item.active {
    color: #9ca3af;
    font-weight: 400;
}

.page-kicker {
    margin-bottom: 0.25rem;
    color: var(--siq-muted);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.header-actions,
.content-actions,
.header-search {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
    flex: 1 1 360px;
    min-width: min(100%, 280px);
}

/* Inside the page-header, segmented-bar sits on transparent background — no need for its own card */
.page-header .segmented-bar {
    background: #fff;
    border-color: rgba(15, 23, 42, 0.14);
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.07);
}

/* Primary CTA in page header should stand out more */
.page-header .segmented-btn.primary {
    box-shadow: 0 2px 10px rgba(255, 122, 89, 0.35);
}

.header-actions .search-box,
.content-actions .search-box,
.header-search .search-box {
    min-width: min(100%, 260px);
}

.page-help-inline {
    padding: 0 6px;
}

.page-help-content p,
.page-help-content li {
    color: #374151;
    line-height: 1.5;
}

.help-page-list {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    max-height: 62vh;
    overflow: auto;
}

.help-page-item {
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    background: #fff;
    color: #111827;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.65rem 0.75rem;
    text-align: left;
    width: 100%;
}

.help-page-item:hover,
.help-page-item.active {
    border-color: rgba(255, 122, 89, 0.55);
    background: #fff8f5;
}

.help-page-item small {
    color: #64748b;
    display: block;
    font-size: 0.74rem;
    margin-top: 0.1rem;
}

.help-editor {
    font-family: Consolas, Monaco, monospace;
    min-height: 360px;
}

.search-box,
.e-control-wrapper.search-box {
    max-width: 360px;
}

.page-title {
    margin: 0;
}

.page-subtitle {
    margin: 0;
    color: var(--siq-muted);
}

.app-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--siq-space-3);
    margin-bottom: var(--siq-space-3);
}

.app-toolbar-actions,
.app-toolbar-filters {
    display: flex;
    align-items: center;
    gap: var(--siq-space-2);
    flex-wrap: wrap;
}

.app-toolbar-meta {
    color: var(--siq-muted);
    font-size: 0.9rem;
}

.app-pagination {
    display: flex;
    align-items: center;
    gap: var(--siq-space-3);
    flex-wrap: wrap;
}

.app-pagination .pagination {
    margin-bottom: 0;
}

.app-pagination .page-link {
    border-radius: var(--siq-radius-1);
}

.app-table-wrap {
    background: #fff;
    border-radius: 10px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: none;
    overflow: hidden;
}

.app-table th {
    font-size: 0.73rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #64748b;
    background: #f8fafc;
    background: #f8fafc;
    border-bottom: 1px solid var(--app-border);
    white-space: nowrap;
}

.app-table td,
.app-table th {
    vertical-align: middle;
    padding: 0.72rem 0.85rem;
}

.app-table td {
    border-color: rgba(15, 23, 42, 0.05);
    color: #1e293b;
    font-size: 0.9rem;
}

.app-table tbody tr:hover {
    background: rgba(248, 250, 252, 0.9);
}

.app-table .sortable-header-button {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    color: inherit;
    font: inherit;
    letter-spacing: inherit;
    text-transform: inherit;
}

.app-table .sortable-header-button.active {
    color: var(--siq-ink);
}

.app-table .sortable-header-button i {
    color: var(--siq-muted);
    font-size: 0.76rem;
    opacity: 0.72;
}

.app-table .sortable-header-button.active i {
    color: var(--siq-ink);
    opacity: 1;
}

.user-manager-table tbody tr.is-selected {
    background: var(--role-tier-selected-bg);
}

.user-manager-table tbody tr.is-selected:hover {
    background: color-mix(in srgb, var(--bs-info) 12%, var(--app-surface));
}

.user-row-select:checked {
    background-color: var(--bs-info);
    border-color: var(--bs-info);
}

.user-cell {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 16rem;
}

.entity-cell {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 14rem;
}

.user-avatar,
.entity-avatar {
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    font-size: 0.72rem;
    font-weight: 700;
}

.entity-avatar {
    background: color-mix(in srgb, var(--siq-accent) 12%, var(--app-surface));
    color: color-mix(in srgb, var(--siq-accent) 72%, var(--siq-ink));
}

.user-identity,
.entity-identity {
    display: grid;
    min-width: 0;
    line-height: 1.25;
}

.user-name,
.entity-name {
    color: var(--siq-ink);
    font-weight: 700;
}

.user-meta,
.entity-meta {
    color: var(--siq-muted);
    font-size: 0.8rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.selected-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.selected-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    min-height: 1.85rem;
    padding: 0.2rem 0.55rem;
    border: 1px solid var(--app-border);
    border-radius: 999px;
    background: color-mix(in srgb, var(--bs-info) 8%, var(--app-surface));
    color: var(--siq-ink);
    font-size: 0.82rem;
    font-weight: 600;
}

.selected-chip .btn-close {
    width: 0.55rem;
    height: 0.55rem;
    padding: 0.2rem;
    opacity: 0.55;
}

.assignment-picker-list {
    display: grid;
    gap: 0.35rem;
    max-height: 14rem;
    overflow: auto;
    padding: 0.35rem;
    border: 1px solid var(--app-border);
    border-radius: var(--siq-radius-1);
    background: color-mix(in srgb, var(--siq-muted) 4%, var(--app-surface));
}

.assignment-picker-item {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    width: 100%;
    min-height: 2rem;
    padding: 0.35rem 0.5rem;
    border: 1px solid transparent;
    border-radius: var(--siq-radius-1);
    background: transparent;
    color: var(--siq-ink);
    font-size: 0.84rem;
    text-align: left;
}

.assignment-picker-item:hover:not(:disabled),
.assignment-picker-item:focus-visible {
    border-color: var(--app-border);
    background: var(--app-surface);
}

.assignment-picker-item.is-selected {
    color: var(--siq-muted);
    opacity: 0.72;
}

.entity-chip {
    display: inline-flex;
    align-items: center;
    min-height: 1.35rem;
    padding: 0.12rem 0.5rem;
    border-radius: var(--siq-radius-1);
    background: color-mix(in srgb, var(--siq-muted) 10%, var(--app-surface));
    color: color-mix(in srgb, var(--siq-muted) 86%, var(--siq-ink));
    font-size: 0.74rem;
    font-weight: 700;
    line-height: 1;
}

.entity-chip-info {
    background: color-mix(in srgb, var(--bs-info) 12%, var(--app-surface));
    color: color-mix(in srgb, var(--bs-info) 72%, var(--siq-ink));
}

.metric-count {
    color: var(--siq-ink);
    font-variant-numeric: tabular-nums;
    font-weight: 700;
}

.enrollment-user-cell {
    min-width: 13rem;
}

.enrollment-course-cell {
    min-width: 14rem;
    max-width: 22rem;
}

.progress-metric {
    position: relative;
    display: inline-flex;
    align-items: center;
    width: 4.4rem;
    height: 1.35rem;
    overflow: hidden;
    border-radius: var(--siq-radius-1);
    background: color-mix(in srgb, var(--siq-muted) 10%, var(--app-surface));
}

.progress-metric-bar {
    position: absolute;
    inset: 0 auto 0 0;
    background: color-mix(in srgb, var(--bs-info) 22%, transparent);
}

.progress-metric-label {
    position: relative;
    z-index: 1;
    width: 100%;
    color: var(--siq-ink);
    font-size: 0.74rem;
    font-variant-numeric: tabular-nums;
    font-weight: 700;
    text-align: center;
}

.role-stack {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 0.55rem;
}

.role-chip-group {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
}

.role-pill {
    display: inline-flex;
    align-items: center;
    min-height: 1.35rem;
    padding: 0.12rem 0.5rem;
    border-radius: var(--siq-radius-1);
    font-size: 0.74rem;
    font-weight: 700;
    line-height: 1;
}

.role-scope-code {
    color: var(--siq-muted);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 0.72rem;
    letter-spacing: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.tier-super {
    background: var(--role-tier-super-bg);
    color: var(--role-tier-super-fg);
}

.tier-admin {
    background: var(--role-tier-admin-bg);
    color: var(--role-tier-admin-fg);
}

.tier-manager {
    background: var(--role-tier-manager-bg);
    color: var(--role-tier-manager-fg);
}

.tier-learner {
    background: var(--role-tier-learner-bg);
    color: var(--role-tier-learner-fg);
}

.empty-dash {
    color: color-mix(in srgb, var(--siq-muted) 70%, var(--app-surface));
    font-size: 0.84rem;
}

.user-manager-table .row-menu-primary-btn,
.organization-manager-table .row-menu-primary-btn,
.cohort-manager-table .row-menu-primary-btn,
.group-manager-table .row-menu-primary-btn,
.enrollment-manager-table .row-menu-primary-btn,
.role-assignment-table .row-menu-primary-btn,
.tenancy-manager-table .row-menu-primary-btn,
.content-manager-table .row-menu-primary-btn,
.entitlement-manager-table .row-menu-primary-btn,
.seat-manager-table .row-menu-primary-btn {
    color: var(--siq-muted);
    opacity: 0.8;
}

.user-manager-table .row-menu-primary-btn:hover,
.organization-manager-table .row-menu-primary-btn:hover,
.cohort-manager-table .row-menu-primary-btn:hover,
.group-manager-table .row-menu-primary-btn:hover,
.enrollment-manager-table .row-menu-primary-btn:hover,
.role-assignment-table .row-menu-primary-btn:hover,
.tenancy-manager-table .row-menu-primary-btn:hover,
.content-manager-table .row-menu-primary-btn:hover,
.entitlement-manager-table .row-menu-primary-btn:hover,
.seat-manager-table .row-menu-primary-btn:hover {
    background: color-mix(in srgb, var(--siq-muted) 10%, transparent);
    border-color: color-mix(in srgb, var(--siq-muted) 22%, transparent);
    color: var(--siq-ink);
}

.organization-manager-table tbody tr.is-selected,
.group-manager-table tbody tr.is-selected,
.enrollment-manager-table tbody tr.is-selected,
.assignment-manager-table tbody tr.is-selected,
.role-assignment-table tbody tr.is-selected,
.tenancy-manager-table tbody tr.is-selected,
.content-manager-table tbody tr.is-selected,
.seat-manager-table tbody tr.is-selected {
    background: var(--role-tier-selected-bg);
}

.organization-manager-table tbody tr.is-selected:hover,
.group-manager-table tbody tr.is-selected:hover,
.enrollment-manager-table tbody tr.is-selected:hover,
.assignment-manager-table tbody tr.is-selected:hover,
.role-assignment-table tbody tr.is-selected:hover,
.tenancy-manager-table tbody tr.is-selected:hover,
.content-manager-table tbody tr.is-selected:hover,
.seat-manager-table tbody tr.is-selected:hover {
    background: color-mix(in srgb, var(--bs-info) 12%, var(--app-surface));
}

.app-table tbody tr:hover .table-actions .btn {
    opacity: 1;
}

/* Action buttons visible by default; brighten on row hover */
.app-table tbody tr .table-actions .btn {
    transition: opacity 0.1s ease, box-shadow 0.1s ease;
}

/* Normalize any remaining filled secondary/info buttons inside table-actions to outline style */
.table-actions .btn-secondary:not(.btn-outline-secondary) {
    color: #475569;
    background: transparent;
    border-color: rgba(15, 23, 42, 0.22);
}
.table-actions .btn-secondary:not(.btn-outline-secondary):hover {
    background: rgba(15, 23, 42, 0.06);
    border-color: rgba(15, 23, 42, 0.32);
}
.table-actions .btn-info:not(.btn-outline-info) {
    color: #0369a1;
    background: transparent;
    border-color: rgba(3, 105, 161, 0.35);
}
.table-actions .btn-info:not(.btn-outline-info):hover {
    background: rgba(3, 105, 161, 0.06);
}

.app-split {
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
}

.app-grid-2 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.app-grid-3 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.app-split-panel {
    position: sticky;
    top: 5rem;
}

.app-panel {
    border-radius: 14px;
    border: 1px solid rgba(15, 23, 42, 0.09);
    background: #fff;
    box-shadow: 0 2px 16px rgba(15, 23, 42, 0.07), 0 0 0 1px rgba(15, 23, 42, 0.025);
    padding: 1rem;
}

.app-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin: -1rem -1rem 0.9rem;
    padding: 0.75rem 1rem;
    background: rgba(248, 250, 252, 0.9);
    border-bottom: 1px solid rgba(15, 23, 42, 0.07);
    border-radius: 14px 14px 0 0;
}

.app-panel-header > div:first-child {
    min-width: 0;
    flex: 1;
}

.app-form {
    display: grid;
    gap: 0.85rem;
}

.app-form .form-label {
    font-weight: 600;
    color: #1f2a35;
}

.form-hint {
    font-size: 0.8rem;
    color: #6b7a8a;
}

.app-form-actions {
    display: flex;
    gap: 0.6rem;
    margin-top: 0.5rem;
}

.app-empty {
    padding: 2.25rem 1.5rem;
    text-align: center;
    color: #6b7a8a;
    border: 1px dashed rgba(100, 116, 139, 0.28);
    border-radius: 12px;
    background: #f8fafc;
}

.app-loading {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    min-height: 96px;
    padding: 1rem 1.1rem;
    color: var(--siq-muted);
    border: 1px solid var(--app-soft-border);
    border-radius: 12px;
    background: #fff;
    box-shadow: var(--app-shadow-soft);
}

.app-loading::before {
    content: "";
    width: 1.1rem;
    height: 1.1rem;
    border: 2px solid rgba(100, 116, 139, 0.28);
    border-top-color: var(--siq-accent);
    border-radius: 999px;
    animation: app-spin 0.8s linear infinite;
}

@keyframes app-spin {
    to { transform: rotate(360deg); }
}

.app-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.15rem 0.55rem;
    border-radius: 999px;
    background: rgba(31, 42, 53, 0.1);
    font-size: 0.75rem;
    font-weight: 600;
    color: #1f2a35;
}

.app-badge-danger {
    background: rgba(214, 64, 64, 0.15);
    color: #b93838;
}

.app-badge-success {
    background: rgba(22, 163, 74, 0.14);
    color: #14713a;
}

.app-badge-warning {
    background: rgba(217, 119, 6, 0.14);
    color: #9a5b05;
}

.app-badge-secondary {
    background: rgba(100, 116, 139, 0.16);
    color: #475569;
}

.wizard-steps {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.45rem;
}

.wizard-step {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    border: 1px solid var(--app-border);
    border-radius: 999px;
    color: var(--siq-muted);
    font-weight: 700;
    background: #fff;
}

.wizard-step.active {
    color: #fff;
    background: var(--siq-accent);
    border-color: var(--siq-accent);
}

.wizard-step.complete {
    color: #14713a;
    background: rgba(22, 163, 74, 0.12);
    border-color: rgba(22, 163, 74, 0.22);
}

.app-btn {
    border-radius: 8px;
}

.status-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    border-radius: 999px;
    padding: 0.2rem 0.6rem;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    background: rgba(15, 23, 42, 0.08);
    color: #1f2a35;
    text-transform: uppercase;
}

.status-success {
    background: rgba(40, 181, 160, 0.2);
    color: #1d6b62;
}

.status-warning {
    background: rgba(255, 184, 77, 0.25);
    color: #b46a00;
}

.status-danger {
    background: rgba(214, 64, 64, 0.2);
    color: #b93838;
}

.status-muted {
    background: rgba(148, 163, 184, 0.2);
    color: #64748b;
}

/* Seat usage progress bar */
.seat-bar {
    height: 6px;
    background: rgba(148, 163, 184, 0.25);
    border-radius: 3px;
    overflow: hidden;
    min-width: 60px;
}
.seat-bar-fill {
    height: 100%;
    border-radius: 3px;
    background: #28b5a0;
    transition: width .3s ease;
}
.seat-bar-fill.warning { background: #e8a838; }
.seat-bar-fill.danger  { background: #d64040; }

/* Drawer inline tab nav */
.drawer-tabs {
    display: flex;
    border-bottom: 1px solid var(--bs-border-color, #dee2e6);
    margin: -1.25rem -1.25rem 1.25rem;
    padding: 0 1.25rem;
    gap: 0;
}
.drawer-tab {
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    padding: .5rem 1rem;
    font-size: .8125rem;
    color: var(--siq-muted, #6b7a8a);
    cursor: pointer;
    margin-bottom: -1px;
    transition: color .15s, border-color .15s;
}
.drawer-tab.active {
    color: var(--siq-brand-primary, #1f2a35);
    border-bottom-color: var(--siq-brand-accent, #ff7a59);
    font-weight: 600;
}
.drawer-tab:hover:not(.active) {
    color: var(--siq-ink, #1f2a35);
}

.layout-shell {
    position: relative;
}

/* Sub-nav shell: rail + content side by side */
.subnav-shell {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
}

.subnav-rail {
    width: 176px;
    flex-shrink: 0;
    background: #fff;
    border: 1px solid var(--bs-border-color, #dee2e6);
    border-radius: var(--siq-radius-2, 12px);
    box-shadow: var(--siq-shadow-1);
    padding: .375rem 0;
    position: sticky;
    top: calc(var(--app-topbar, 64px) + 1rem);
}

.subnav-content {
    flex: 1;
    min-width: 0;
}

.subnav-item {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .5rem .875rem;
    background: none;
    border: none;
    border-left: 3px solid transparent;
    text-align: left;
    width: 100%;
    font-size: .8125rem;
    color: var(--siq-muted, #6b7a8a);
    cursor: pointer;
    transition: background .12s, color .12s, border-color .12s;
}
.subnav-item:hover {
    background: var(--siq-brand-bg, #f6f7fb);
    color: var(--siq-ink, #1f2a35);
}
.subnav-item.active {
    color: var(--siq-ink, #1f2a35);
    background: rgba(255, 122, 89, .08);
    border-left-color: var(--siq-brand-accent, #ff7a59);
    font-weight: 600;
}
.subnav-icon {
    font-size: .9375rem;
    width: 1.125rem;
    text-align: center;
    flex-shrink: 0;
}
.subnav-label {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.subnav-count {
    margin-left: auto;
    font-size: .6875rem;
    background: rgba(31,42,53,.1);
    color: var(--siq-muted, #6b7a8a);
    border-radius: 100px;
    padding: .1em .45em;
    min-width: 1.25em;
    text-align: center;
    flex-shrink: 0;
}
.subnav-divider {
    height: 1px;
    background: var(--bs-border-color, #dee2e6);
    margin: .375rem .875rem;
}

/* Mobile: horizontal scrollable pills */
@media (max-width: 767.98px) {
    .subnav-shell {
        flex-direction: column;
        gap: .5rem;
    }
    .subnav-rail {
        width: 100%;
        display: flex;
        flex-direction: row;
        overflow-x: auto;
        scrollbar-width: none;
        position: static;
        border-radius: var(--siq-radius-2, 12px);
        padding: .375rem .5rem;
        gap: .25rem;
    }
    .subnav-rail::-webkit-scrollbar { display: none; }
    .subnav-item {
        width: auto;
        flex-shrink: 0;
        border-left: none;
        border-radius: .375rem;
        padding: .375rem .75rem;
        white-space: nowrap;
    }
    .subnav-item.active {
        background: var(--siq-brand-primary, #1f2a35);
        color: #fff;
        border-left-color: transparent;
    }
    .subnav-item.active .subnav-count { background: rgba(255,255,255,.25); color: #fff; }
    .subnav-count { display: none; }
    .subnav-divider { display: none; }
}

.grid-shell {
    min-width: 0;
}

.content-surface {
    overflow: visible;
}

.bulk-toolbar {
    position: sticky;
    top: calc(var(--app-topbar) + 0.75rem);
    z-index: 20;
    margin-bottom: 0.75rem;
    padding: 0.75rem 0.9rem;
    border: 1px solid rgba(255, 122, 89, 0.24);
    border-radius: 12px;
    background: #fff7f4;
    box-shadow: var(--app-shadow-soft);
    transform: translateY(-4px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 140ms ease, transform 140ms ease;
}

.bulk-toolbar.show {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
}

.bulk-toolbar > div {
    flex-wrap: wrap;
}

.data-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-bottom: 0.75rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid rgba(15, 23, 42, 0.07);
    background: transparent;
}

.data-toolbar-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.data-toolbar-actions .form-control {
    width: min(320px, 100%);
}

.data-toolbar-meta {
    color: var(--siq-muted);
    font-size: 0.88rem;
    font-weight: 600;
}

/* ─── Panel Bar ──────────────────────────────────────────────────────────────
   Single compact header+toolbar row inside a panel.
   Replaces app-panel-header + panel-toolbar with ONE bar.
   Usage: First child of .app-panel.
   ─────────────────────────────────────────────────────────────────────────── */
.panel-bar {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin: -1rem -1rem 0.75rem;
    padding: 0.65rem 1rem;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    background: rgba(248, 250, 252, 0.85);
    border-radius: 14px 14px 0 0;
    min-height: 48px;
}

.panel-bar-title {
    font-size: 0.9rem;
    font-weight: 700;
    color: #1f2a35;
    white-space: nowrap;
    flex-shrink: 0;
}

.panel-bar-count {
    font-size: 0.78rem;
    color: var(--siq-muted);
    font-weight: 400;
    white-space: nowrap;
    margin-left: 0.2rem;
}

.panel-bar-search {
    flex: 1 1 140px;
    min-width: 120px;
    max-width: 240px;
}

.panel-bar-actions {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    flex-shrink: 0;
    margin-left: auto;
}

.panel-bar .audit-pill {
    flex-shrink: 0;
}

/* ─── Panel Toolbar ──────────────────────────────────────────────────────────
   Canonical toolbar for search, filters, export inside a panel.
   Usage: <div class="panel-toolbar"> inside an .app-panel, after the header.
   ─────────────────────────────────────────────────────────────────────────── */
.panel-toolbar {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    padding: 0.6rem 0 0.75rem;
    margin-bottom: 0.5rem;
    border-bottom: 1px solid rgba(15, 23, 42, 0.07);
}

.panel-toolbar-search {
    flex: 1 1 180px;
    min-width: 140px;
    max-width: 300px;
}

.panel-toolbar-actions {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: wrap;
    margin-left: auto;
}

/* Toolbar action buttons — lightweight ghost style */
.toolbar-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.28rem 0.65rem;
    font-size: 0.82rem;
    font-weight: 600;
    color: #475569;
    background: transparent;
    border: 1px solid rgba(15, 23, 42, 0.15);
    border-radius: 6px;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.1s, border-color 0.1s, color 0.1s;
    line-height: 1.4;
}
.toolbar-btn:hover {
    background: rgba(15, 23, 42, 0.05);
    border-color: rgba(15, 23, 42, 0.25);
    color: #1f2a35;
}
.toolbar-btn.active {
    background: rgba(255, 122, 89, 0.08);
    border-color: rgba(255, 122, 89, 0.3);
    color: var(--siq-accent);
}
.toolbar-btn.primary {
    background: var(--siq-accent);
    border-color: var(--siq-accent);
    color: #fff;
    box-shadow: 0 2px 8px rgba(255, 122, 89, 0.28);
}
.toolbar-btn.primary:hover {
    background: color-mix(in srgb, var(--siq-accent) 90%, #000);
    box-shadow: 0 3px 12px rgba(255, 122, 89, 0.38);
}

.app-tabs {
    gap: 0.25rem;
    border-bottom-color: rgba(15, 23, 42, 0.1);
}

.app-tabs .nav-link {
    border-radius: 8px 8px 0 0;
    color: #475569;
    font-weight: 600;
}

.app-tabs .nav-link.active {
    color: #111827;
    border-color: rgba(15, 23, 42, 0.1) rgba(15, 23, 42, 0.1) #fff;
}

.segmented-bar {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.25rem;
    padding: 0.2rem;
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 10px;
    background: #f8fafc;
    box-shadow: 0 1px 4px rgba(15, 23, 42, 0.06);
    max-width: 100%;
}

.segmented-btn {
    min-height: 34px;
    padding: 0.3rem 0.75rem;
    border: 0;
    border-radius: 7px;
    background: transparent;
    color: #334155;
    font-size: 0.85rem;
    font-weight: 600;
    white-space: nowrap;
    max-width: 100%;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    cursor: pointer;
    transition: background 0.1s ease, color 0.1s ease;
}

.segmented-btn:hover {
    background: #fff;
    color: #111827;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.08);
}

.segmented-btn.primary {
    color: #fff;
    background: var(--siq-accent);
    box-shadow: 0 2px 8px rgba(255, 122, 89, 0.3);
}

.segmented-btn.primary:hover {
    background: color-mix(in srgb, var(--siq-accent) 90%, #000);
    box-shadow: 0 3px 12px rgba(255, 122, 89, 0.4);
    color: #fff;
}

.segmented-btn:disabled,
.segmented-btn:disabled:hover {
    opacity: 0.45;
    cursor: not-allowed;
    background: transparent;
    box-shadow: none;
}

/* ─── Unified Drawer System ─────────────────────────────────────────────────
   All drawers (filter panels, edit forms) use the same base classes.
   Width is controlled by .filters-drawer (narrow) vs .edit-drawer (wide).
   Open/closed via adding .open class. Backdrop via .drawer-backdrop.
   ─────────────────────────────────────────────────────────────────────────── */

.drawer-backdrop,
.filters-hitbox {
    position: fixed;
    inset: var(--app-topbar) 0 0 0;
    background: rgba(15, 23, 42, 0.38);
    backdrop-filter: blur(3px);
    z-index: 1040;
    animation: fadeIn 150ms ease;
}

.drawer,
.filters-drawer,
.edit-drawer,
.app-drawer {
    position: fixed;
    top: var(--app-topbar);
    right: 0;
    height: calc(100vh - var(--app-topbar));
    width: min(600px, 100%);
    background: #fff;
    border-left: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: -2px 0 8px rgba(15, 23, 42, 0.05), -12px 0 48px rgba(15, 23, 42, 0.12);
    transform: translateX(100%);
    transition: transform 260ms cubic-bezier(0.22, 1, 0.36, 1);
    z-index: 1050;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.filters-drawer {
    width: min(340px, 100%);
}

.edit-drawer.wide {
    width: min(780px, 96vw);
}

.edit-drawer.xl {
    width: min(1020px, 97vw);
}

.drawer.open,
.filters-drawer.open,
.edit-drawer.open,
.app-drawer.open,
.app-drawer.show {
    transform: translateX(0);
}

.filters-drawer:not(.open),
.edit-drawer:not(.open) {
    display: none;
}

/* Header — accent stripe + generous padding */
.drawer-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 1.25rem 1.5rem 1.125rem;
    border-bottom: 1px solid rgba(15, 23, 42, 0.07);
    flex-shrink: 0;
    gap: 1rem;
    position: relative;
}
.drawer-header::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg,
        var(--siq-brand-accent, #ff7a59) 0%,
        color-mix(in srgb, var(--siq-brand-accent, #ff7a59) 55%, var(--siq-brand-primary, #1f2a35)) 100%
    );
}

.drawer-header-text {
    flex: 1;
    min-width: 0;
    padding-top: 0.2rem;
}

.drawer-title {
    font-size: 1.0625rem;
    font-weight: 700;
    color: #111827;
    line-height: 1.25;
}

.drawer-subtitle {
    font-size: 0.8125rem;
    color: var(--siq-muted);
    margin-top: 0.3rem;
    line-height: 1.4;
}

/* Close button — bordered icon button */
.drawer-close {
    appearance: none;
    border: 1px solid rgba(15, 23, 42, 0.13);
    background: rgba(15, 23, 42, 0.03);
    color: var(--siq-muted);
    width: 32px;
    height: 32px;
    min-width: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    cursor: pointer;
    padding: 0;
    transition: background 0.15s, border-color 0.15s, color 0.15s;
    flex-shrink: 0;
    margin-top: 0.125rem;
}
.drawer-close svg {
    width: 14px;
    height: 14px;
    stroke-width: 2.5;
}
.drawer-close:hover {
    background: rgba(15, 23, 42, 0.08);
    border-color: rgba(15, 23, 42, 0.22);
    color: #111827;
}
.drawer-close:active {
    background: rgba(15, 23, 42, 0.13);
}

/* Body */
.drawer-body,
.drawer-form {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

/* Footer — clean white, comfortably sized actions */
.drawer-footer {
    padding: 1rem 1.5rem;
    border-top: 1px solid rgba(15, 23, 42, 0.08);
    display: flex;
    gap: 0.625rem;
    justify-content: flex-end;
    align-items: center;
    flex-shrink: 0;
    background: #fff;
}
.drawer-footer .btn {
    font-size: 0.875rem;
    font-weight: 500;
    padding: 0.45rem 1.125rem;
}
.drawer-footer .btn-primary {
    font-weight: 600;
    padding: 0.475rem 1.375rem;
}

/* ─── Drawer form controls — scoped overrides ───────────────────────────────
   Labels become compact uppercase field labels (Linear / HubSpot style).
   Controls get brand-accent focus rings and a subtle resting background.
   No page-level markup changes required — applies automatically to all drawers.
   ─────────────────────────────────────────────────────────────────────────── */
.edit-drawer .form-label,
.filters-drawer .form-label {
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #4b5563;
    margin-bottom: 0.3rem;
    line-height: 1.3;
}

.edit-drawer .form-control,
.edit-drawer .form-select,
.filters-drawer .form-control,
.filters-drawer .form-select {
    font-size: 0.875rem;
    border-color: rgba(15, 23, 42, 0.16);
    border-radius: 8px;
    background-color: #f8f9fb;
    padding: 0.45rem 0.75rem;
    height: auto;
    transition: border-color 0.15s, box-shadow 0.15s, background-color 0.15s;
}
.edit-drawer .form-control:focus,
.edit-drawer .form-select:focus,
.filters-drawer .form-control:focus,
.filters-drawer .form-select:focus {
    border-color: var(--siq-brand-accent, #ff7a59);
    background-color: #fff;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--siq-brand-accent, #ff7a59) 14%, transparent);
    outline: none;
}
.edit-drawer .form-control::placeholder,
.filters-drawer .form-control::placeholder {
    color: rgba(107, 122, 138, 0.6);
    font-style: italic;
}

.edit-drawer .input-group-text,
.filters-drawer .input-group-text {
    font-size: 0.875rem;
    background: rgba(15, 23, 42, 0.04);
    border-color: rgba(15, 23, 42, 0.16);
    color: var(--siq-muted);
    border-radius: 8px;
}
.edit-drawer .input-group > .form-control,
.edit-drawer .input-group > .form-select {
    border-radius: 8px 0 0 8px;
}
.edit-drawer .input-group > .input-group-text:last-child {
    border-radius: 0 8px 8px 0;
}

/* Field group: subtle card for related fields (optional utility) */
.drawer-field-group {
    background: rgba(15, 23, 42, 0.025);
    border: 1px solid rgba(15, 23, 42, 0.07);
    border-radius: 10px;
    padding: 1rem 1rem 0.75rem;
}

/* Section label: visual separator between logical field groups */
.drawer-section-label {
    font-size: 0.6875rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--siq-muted);
    margin-bottom: 0.75rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid rgba(15, 23, 42, 0.07);
}

.catalog-choice-list {
    display: grid;
    gap: 4px;
    max-height: 320px;
    overflow: auto;
    border: 1px solid var(--siq-border);
    border-radius: 8px;
    background: var(--siq-card);
    padding: 6px;
}

.catalog-choice-row {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 10px;
    align-items: flex-start;
    min-height: 44px;
    padding: 8px;
    border-radius: 8px;
    cursor: pointer;
}

.catalog-choice-row:hover {
    background: var(--siq-surface);
}

.catalog-choice-title {
    display: block;
    color: var(--siq-text);
    font-weight: 600;
    line-height: 1.2;
}

.catalog-choice-meta {
    display: block;
    margin-top: 2px;
    color: var(--siq-muted);
    font-size: 0.78rem;
    line-height: 1.2;
}

.status-info {
    background: rgba(80, 136, 214, 0.2);
    color: #2a5ea7;
}

.admin-shell .main {
    background: radial-gradient(circle at 15% 10%, color-mix(in srgb, var(--siq-brand-accent, #ff7a59) 12%, transparent), transparent 45%),
                radial-gradient(circle at 85% 0%, color-mix(in srgb, var(--siq-brand-primary, #1f2a35) 10%, transparent), transparent 40%),
                var(--siq-brand-bg, #f6f7fb);
}

.admin-shell .content {
    padding-top: 1.5rem;
    padding-bottom: 2rem;
}

/* Compact button sizing for admin pages — keeps density consistent */
.admin-shell .btn:not(.btn-lg):not(.btn-xs) {
    font-size: 0.875rem;
    padding: 0.25rem 0.625rem;
    line-height: 1.5;
    border-radius: 6px;
}

.admin-shell .btn-group .btn:not(.btn-lg):not(.btn-xs) {
    border-radius: 0;
}

.admin-shell .top-row.auth {
    background: rgba(255, 255, 255, 0.92);
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 10px 20px rgba(15, 23, 42, 0.06);
    backdrop-filter: blur(10px);
}

.admin-shell .top-row-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.profile-menu-wrapper {
    position: relative;
}

.profile-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #fff;
    box-shadow: 0 8px 16px rgba(15, 23, 42, 0.08);
    font-weight: 700;
    color: #1f2a35;
}

.profile-chip .chip-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--siq-brand-accent, #f97352), color-mix(in srgb, var(--siq-brand-accent, #f97352) 60%, #fff));
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    letter-spacing: 0.02em;
}

.profile-chip .chip-name {
    max-width: 180px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.profile-chip .chip-caret {
    font-size: 0.85rem;
    color: #6b7a8a;
}

.mobile-chip {
    padding: 4px 6px;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.16);
    color: #fff;
    box-shadow: none;
}
.mobile-chip .chip-avatar {
    width: 24px;
    height: 24px;
    background: var(--siq-brand-accent, #ff7a59);
    color: #0b1520;
    font-weight: 800;
}
.mobile-chip .chip-caret {
    color: #fff;
}

.mobile-quickbar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: 64px;
    background: #0d1626;
    border-top: 1px solid rgba(255, 255, 255, 0.18);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    align-items: center;
    padding: 0 6px;
    z-index: 1300;
}
.mobile-quickbar .quick-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    color: #fff;
    text-decoration: none;
    height: 100%;
    border: 0;
    background: transparent;
    font-weight: 700;
    text-align: center;
}
.mobile-quickbar .quick-btn .oi {
    font-size: 1.35rem;
    line-height: 1;
    color: var(--siq-brand-accent, #ff7a59);
}
.mobile-quickbar .quick-icon {
    font-size: 1.35rem;
    line-height: 1;
    color: var(--siq-brand-accent, #ff7a59);
}
.mobile-quickbar .quick-btn .quick-label {
    font-size: 0.7rem;
    letter-spacing: 0.02em;
    color: #f8fafc;
}
.mobile-quickbar .quick-dots {
    font-size: 1.3rem;
    line-height: 1;
    color: var(--siq-brand-accent, #ff7a59);
}
.mobile-quickbar .quick-btn:hover,
.mobile-quickbar .quick-btn:focus-visible {
    color: var(--siq-brand-accent, #ff7a59);
}
.mobile-quickbar .quick-btn.active,
.mobile-quickbar .quick-btn.nav-link.active {
    color: var(--siq-brand-accent, #ff7a59);
}

.profile-menu {
    position: absolute;
    right: 0;
    top: calc(100% + 6px);
    min-width: 170px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 12px;
    overflow: hidden;
    z-index: 2000;
    background: #fff;
    text-align: left;
    box-shadow: 0 18px 32px rgba(15, 23, 42, 0.18);
    padding: 6px 0;
}

.profile-menu .dropdown-item {
    padding: 8px 14px;
    font-weight: 600;
    width: 100%;
    text-align: left;
    display: block;
    color: #0f172a;
    background: transparent;
    border: 0;
    text-decoration: none;
}

.profile-menu a.dropdown-item,
.profile-menu button.dropdown-item {
    color: #0f172a !important;
}

.profile-menu .dropdown-item:hover {
    background: rgba(15, 23, 42, 0.06);
    color: #0f172a;
}

.profile-menu .dropdown-item.text-danger {
    color: #c63f3f;
}

/* Nav sidebar profile menu — dark background needs light text to override the white-card !important above */
.nav-profile-menu a.dropdown-item,
.nav-profile-menu button.dropdown-item {
    color: #f1f5f9 !important;
    background: transparent;
}

.nav-profile-menu .dropdown-item:hover {
    background: rgba(255, 255, 255, 0.08);
    color: #fff !important;
}

.nav-profile-menu .dropdown-item.text-danger,
.nav-profile-menu button.dropdown-item.text-danger {
    color: #f47373 !important;
}

.admin-shell .scope-bar {
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 14px;
    padding: 0.45rem 0.75rem;
    box-shadow: 0 8px 16px rgba(15, 23, 42, 0.08);
}

.admin-shell .scope-loading {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.8rem;
    border-radius: 999px;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    color: #5b6b7a;
    font-size: 0.8rem;
    box-shadow: 0 6px 12px rgba(15, 23, 42, 0.08);
}

.admin-shell .scope-selector-label {
    color: #506070;
}

.admin-shell .scope-selector-controls .form-select {
    border-color: rgba(15, 23, 42, 0.15);
    background-color: #fff;
    box-shadow: 0 3px 8px rgba(15, 23, 42, 0.06);
}

.admin-shell .global-search-toggle {
    border: 1px solid rgba(15, 23, 42, 0.12);
    background: #fff;
}

.admin-shell .global-search-panel {
    box-shadow: 0 18px 30px rgba(15, 23, 42, 0.14);
}

.admin-shell .top-row-actions a {
    font-weight: 600;
}

.admin-shell .sidebar {
    box-shadow: 8px 0 24px rgba(15, 23, 42, 0.25);
}

.admin-dashboard {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.admin-dashboard .app-panel {
    border-radius: 16px;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    padding: 1.25rem;
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.08);
}

.admin-dashboard .app-panel-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
    font-weight: 700;
    color: #1f2a35;
}

.admin-dashboard .app-panel-header span:first-child {
    font-size: 1rem;
}

.admin-hero {
    align-items: stretch;
    background: linear-gradient(130deg, var(--siq-brand-sidebar-top, #1f2a35), color-mix(in srgb, var(--siq-brand-sidebar-top, #1f2a35) 60%, #314355) 55%, var(--siq-brand-sidebar-bottom, #15202c));
    color: #f4f7fb;
    border-radius: 18px;
    padding: 1.75rem;
    box-shadow: 0 18px 30px rgba(15, 23, 42, 0.2);
    position: relative;
    overflow: hidden;
    animation: learnerRise 0.4s ease both;
}

.admin-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 12% 15%, color-mix(in srgb, var(--siq-brand-accent, #ff7a59) 22%, transparent), transparent 45%),
                radial-gradient(circle at 85% 10%, color-mix(in srgb, var(--siq-brand-primary, #1f2a35) 30%, transparent), transparent 40%);
    opacity: 0.75;
    pointer-events: none;
}

.admin-hero-copy {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
    position: relative;
    z-index: 1;
}

.admin-eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-size: 0.7rem;
    color: rgba(244, 247, 251, 0.7);
}

.admin-hero-title {
    margin: 0;
    font-size: 2rem;
}

.admin-subtitle {
    margin: 0;
    color: rgba(244, 247, 251, 0.75);
}

.admin-hero-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.admin-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    border-radius: 999px;
    padding: 0.25rem 0.7rem;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    background: rgba(255, 255, 255, 0.12);
    color: #f8fbff;
    font-weight: 600;
}

.admin-pill-accent {
    background: rgba(40, 181, 160, 0.3);
}

.admin-hero-card {
    background: rgba(255, 255, 255, 0.95);
    color: #1f2a35;
    border-radius: 14px;
    padding: 1.25rem;
    min-width: 240px;
    align-self: center;
    box-shadow: 0 16px 26px rgba(15, 23, 42, 0.2);
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.admin-hero-card-title {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #6b7a8a;
    margin-bottom: 0.75rem;
}

.admin-hero-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
    gap: 0.8rem;
    text-align: center;
}

.admin-hero-metrics-triple {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.6rem;
}

.admin-metric-value {
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 1.1;
}

.admin-metric-label {
    font-size: 0.75rem;
    color: #6b7a8a;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.admin-hero-meta-list {
    display: grid;
    gap: 0.4rem;
    font-size: 0.9rem;
}

.admin-meta-label {
    display: block;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #6b7a8a;
}

.admin-actions .dashboard-actions .btn {
    border-radius: 10px;
    font-weight: 600;
}

.admin-actions .dashboard-actions .btn-outline-secondary {
    border-color: rgba(31, 42, 53, 0.18);
    color: #2b3b4f;
    background: #fff;
    box-shadow: 0 6px 12px rgba(15, 23, 42, 0.06);
}

.admin-actions .dashboard-actions .btn-outline-secondary:hover {
    border-color: rgba(255, 122, 89, 0.6);
    color: #ff7a59;
    transform: translateY(-1px);
}

.admin-actions .dashboard-actions .btn-primary {
    box-shadow: 0 10px 18px rgba(255, 122, 89, 0.35);
}

.admin-section-subtitle {
    margin: -0.4rem 0 0.85rem;
    color: #5f6f82;
    font-size: 0.85rem;
}

.admin-stats .stat-card {
    animation: learnerRise 0.45s ease both;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #fff;
    position: relative;
}

.admin-stats .stat-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 4px;
    border-radius: 12px 12px 0 0;
    background: linear-gradient(90deg, var(--siq-brand-accent, #ff7a59), color-mix(in srgb, var(--siq-brand-primary, #1f2a35) 60%, var(--siq-brand-accent, #ff7a59)));
}

.admin-surface .app-panel {
    animation: learnerRise 0.5s ease both;
}

.admin-surface {
    background: transparent;
    border: none;
    padding: 0;
}

.catalog-panel .app-panel-header {
    margin-bottom: 0.5rem;
}

.catalog-panel-label {
    font-weight: 600;
}

.catalog-panel-toggle {
    margin-left: auto;
    border-radius: 999px;
    width: 30px;
    height: 30px;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.catalog-panel-collapsed .catalog-panel-label,
.catalog-panel-collapsed .catalog-list {
    display: none;
}

.catalog-panel-collapsed .app-panel-header {
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
    margin-bottom: 0;
}

.catalog-list {
    max-height: 68vh;
    overflow-y: auto;
    padding-right: 0.25rem;
}

.catalog-list-item {
    padding: 0.55rem 0.75rem;
    border-radius: 10px;
    margin: 0.25rem 0;
}

.catalog-list-item.active {
    background: color-mix(in srgb, var(--siq-brand-accent, #ff7a59) 12%, transparent);
    border-color: color-mix(in srgb, var(--siq-brand-accent, #ff7a59) 40%, transparent);
}

.catalog-list-title {
    font-size: 0.9rem;
}

.catalog-list-meta {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.lp-player-shell {
    padding: 1.5rem;
}

.lp-player {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.lp-player-hero {
    display: flex;
    justify-content: space-between;
    gap: 1.5rem;
    padding: 1.75rem;
    border-radius: 18px;
    background: linear-gradient(130deg, #1f2a35, #314355 55%, #2b3b4f);
    color: #f4f7fb;
    box-shadow: 0 18px 30px rgba(15, 23, 42, 0.2);
    animation: learnerRise 0.4s ease both;
}

.lp-player-hero-copy {
    max-width: 560px;
}

.lp-player-title {
    margin: 0.35rem 0 0.4rem;
    font-size: 2rem;
    font-family: var(--siq-font-serif);
}

.lp-player-subtitle {
    margin: 0;
    color: rgba(244, 247, 251, 0.75);
}

.lp-player-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.9rem;
}

.lp-player-hero-card {
    background: rgba(255, 255, 255, 0.95);
    color: #1f2a35;
    border-radius: 14px;
    padding: 1.25rem;
    min-width: 240px;
    align-self: center;
    box-shadow: 0 16px 26px rgba(15, 23, 42, 0.2);
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.lp-player-hero-card-title {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #6b7a8a;
}

.lp-player-progress {
    height: 8px;
    background: rgba(148, 163, 184, 0.35);
    border-radius: 999px;
    overflow: hidden;
}

.lp-player-progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--siq-brand-accent, #ff7a59), color-mix(in srgb, var(--siq-brand-primary, #1f2a35) 50%, var(--siq-brand-accent, #ff7a59)));
    border-radius: 999px;
    transition: width 0.4s ease;
}

.lp-player-progress-meta {
    font-size: 0.85rem;
    color: #5b6b7a;
}

.lp-completion-banner {
    display: flex;
    align-items: center;
    gap: 1rem;
    background: linear-gradient(135deg, color-mix(in srgb, var(--siq-brand-accent, #ff7a59) 12%, #fff), color-mix(in srgb, var(--siq-brand-primary, #1f2a35) 8%, #fff));
    border: 1.5px solid color-mix(in srgb, var(--siq-brand-accent, #ff7a59) 30%, transparent);
    border-radius: 12px;
    padding: 1.25rem 1.5rem;
    margin-bottom: 1.5rem;
}
.lp-completion-icon { font-size: 2rem; flex-shrink: 0; }
.lp-completion-title { font-size: 1.1rem; font-weight: 700; color: var(--siq-brand-primary, #1f2a35); }
.lp-completion-sub { font-size: 0.9rem; color: #4b5563; margin-top: 2px; }

.lp-player-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 2fr);
    gap: 1.5rem;
}

.lp-player-list {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.lp-player-item {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 14px;
    background: #fff;
    padding: 0.75rem 0.9rem;
    text-align: left;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.lp-player-item:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 20px rgba(15, 23, 42, 0.08);
    border-color: rgba(255, 122, 89, 0.4);
}

.lp-player-item.is-active {
    border-color: rgba(255, 122, 89, 0.7);
    box-shadow: 0 12px 22px rgba(255, 122, 89, 0.2);
}

.lp-player-item.is-complete .lp-player-item-order {
    background: rgba(40, 181, 160, 0.2);
    color: #1d6b62;
    border-color: rgba(40, 181, 160, 0.6);
}

.lp-player-item-order {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    border: 1px solid rgba(15, 23, 42, 0.12);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    color: #1f2a35;
    background: rgba(148, 163, 184, 0.2);
}

.lp-player-item-title {
    font-weight: 700;
    color: #1f2a35;
}

.lp-player-item-meta {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.8rem;
    color: #6b7a8a;
}

.lp-player-panel {
    min-height: 320px;
}

.lp-player-panel-title {
    font-weight: 700;
    font-size: 1.1rem;
}

.lp-player-panel-meta {
    font-size: 0.85rem;
    color: #6b7a8a;
}

.lp-player-panel-description {
    color: #4b5b6b;
    margin: 0.75rem 0 1rem;
}

.lp-player-stepper {
    display: flex;
    gap: 0.5rem;
}

.lp-player-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    align-items: center;
}

@media (max-width: 991.98px) {
    .lp-player-hero {
        flex-direction: column;
    }

    .lp-player-hero-card {
        width: 100%;
        align-self: stretch;
    }

    .lp-player-grid {
        grid-template-columns: 1fr;
    }
}

.learner-shell {
    padding: 1.5rem;
    min-height: 100vh;
    background: radial-gradient(circle at 10% 10%, color-mix(in srgb, var(--siq-brand-primary, #1f2a35) 12%, transparent), transparent 45%),
                radial-gradient(circle at 80% 0%, color-mix(in srgb, var(--siq-brand-accent, #ff7a59) 14%, transparent), transparent 40%),
                var(--siq-brand-bg, #f6f7fb);
}

.learner-brand-bar {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.55rem 0.9rem;
    border-radius: 14px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: rgba(255, 255, 255, 0.85);
    box-shadow: 0 10px 18px rgba(15, 23, 42, 0.08);
    margin-bottom: 1.25rem;
    flex-wrap: nowrap;
}

.learner-brand-logo {
    width: 32px;
    height: 32px;
    border-radius: 10px;
    object-fit: contain;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.08);
}

.learner-brand-text {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    flex-wrap: nowrap;
    min-width: 0;
    flex: 1 1 auto;
}

.learner-brand-name {
    font-weight: 700;
    color: #1f2a35;
    white-space: nowrap;
    font-size: 1rem;
}

.learner-brand-subtitle {
    font-size: 0.78rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--siq-accent, #ff7a59);
    font-weight: 700;
    white-space: nowrap;
}

.learner-brand-divider {
    color: rgba(15,23,42,0.35);
    font-weight: 700;
}

@media (max-width: 420px) {
    .learner-brand-text {
        flex-wrap: wrap;
    }
}

/* Branding page — color pickers */
.color-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
}
.color-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.color-input-row {
    display: flex;
    align-items: center;
    gap: 8px;
}
.color-input-row .form-control-color {
    width: 44px;
    height: 38px;
    padding: 2px;
    flex-shrink: 0;
}
.brand-logo-preview {
    max-height: 60px;
    max-width: 180px;
    object-fit: contain;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    padding: 4px;
}

/* Version history drawer */
.version-history-drawer {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    padding: 12px 16px;
}
.version-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
    max-height: 260px;
    overflow-y: auto;
}
.version-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px 8px;
    border-radius: 6px;
    background: #fff;
    border: 1px solid #e2e8f0;
}
.version-item.active {
    border-color: var(--siq-brand-accent, #ff7a59);
    background: #fff8f5;
}
.version-swatches {
    display: flex;
    gap: 3px;
    flex-shrink: 0;
}
.version-swatch {
    width: 16px;
    height: 16px;
    border-radius: 3px;
    border: 1px solid rgba(0,0,0,.1);
    display: inline-block;
}
.version-meta {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-grow: 1;
    font-size: .8rem;
    color: #64748b;
}
.version-date {
    font-weight: 500;
}

/* Sidebar preview */
.brand-preview-sidebar {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 110px;
    padding: 12px 8px;
}
.brand-preview-logo-area {
    display: flex;
    align-items: center;
    gap: 6px;
    color: #fff;
    font-weight: 600;
    font-size: .85rem;
}
.brand-preview-logo-placeholder {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    background: rgba(255,255,255,.2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1rem;
    color: #fff;
    flex-shrink: 0;
}
.brand-preview-name {
    color: #fff;
    font-size: .8rem;
    font-weight: 600;
    max-width: 80px;
}
.brand-preview-nav-items {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.brand-preview-nav-item {
    padding: 4px 8px;
    border-radius: 5px;
    color: rgba(255,255,255,.7);
    font-size: .78rem;
    cursor: default;
}
.brand-preview-nav-item.active {
    background: rgba(255,255,255,.15);
    color: #fff;
}
.brand-preview-main {
    flex: 1;
    display: flex;
    flex-direction: column;
}
.brand-preview-heading {
    font-weight: 700;
    font-size: 1.1rem;
    margin-bottom: 8px;
}
.brand-preview-btn {
    border: none;
    color: #fff;
    border-radius: 6px;
    padding: 6px 14px;
    font-size: .85rem;
    font-weight: 600;
    cursor: default;
}

/* Learner announcements */
.learner-announcements {
    margin-bottom: 12px;
}
.learner-pages-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.learner-page-link {
    display: inline-block;
    padding: 6px 14px;
    background: #f1f5f9;
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    font-size: .85rem;
    color: var(--siq-brand-primary, #1f2a35);
    text-decoration: none;
    transition: background .15s;
}
.learner-page-link:hover {
    background: #e2e8f0;
}
.cms-body {
    font-size: .95rem;
    line-height: 1.6;
}

.brand-preview {
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 16px;
    background: var(--brand-bg, #f8fafc);
    color: #0f172a;
    box-shadow: 0 6px 16px rgba(15, 23, 42, 0.08);
}
.brand-preview-cover {
    height: 120px;
    border-radius: 8px;
    background-size: cover;
    background-position: center;
    margin-bottom: 12px;
    border: 1px solid #e2e8f0;
}
.brand-preview-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
    border-bottom: 1px solid #e2e8f0;
    padding-bottom: 8px;
}
.brand-preview-title {
    font-weight: 700;
    color: var(--brand-primary, #0f6fff);
}
.brand-preview-logo {
    color: var(--brand-accent, #ff7a59);
    font-weight: 600;
}
.brand-preview-body p {
    margin: 0 0 6px 0;
}

.certificate-preview-frame {
    width: 100%;
    height: 340px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    box-shadow: 0 6px 16px rgba(15, 23, 42, 0.08);
    background: #fff;
}

.e-grid {
    font-family: var(--siq-font-sans);
    border-radius: 12px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 10px 20px rgba(15, 23, 42, 0.08);
}

.e-grid .e-headercell {
    background: #f2f4f8;
    color: #1f2a35;
    font-weight: 700;
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.06em;
}

.e-grid .e-row:hover {
    background: rgba(255, 122, 89, 0.08);
}

.e-grid .e-pager {
    border-top: 1px solid rgba(15, 23, 42, 0.08);
    background: #f8fafc;
}

.learner-hero {
    display: flex;
    gap: 1.5rem;
    align-items: stretch;
    justify-content: space-between;
    padding: 1.75rem;
    border-radius: 18px;
    background: linear-gradient(130deg, var(--siq-brand-sidebar-top, #1f2a35), color-mix(in srgb, var(--siq-brand-sidebar-top, #1f2a35) 60%, #314355) 55%, var(--siq-brand-sidebar-bottom, #15202c));
    color: #f4f7fb;
    box-shadow: 0 18px 30px rgba(15, 23, 42, 0.2);
    animation: learnerRise 0.4s ease both;
    position: relative;
    overflow: hidden;
}
.learner-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 12% 15%, color-mix(in srgb, var(--siq-brand-accent, #ff7a59) 22%, transparent), transparent 45%),
                radial-gradient(circle at 85% 10%, color-mix(in srgb, var(--siq-brand-primary, #1f2a35) 30%, transparent), transparent 40%);
    opacity: 0.8;
    pointer-events: none;
}
.learner-hero > * {
    position: relative;
    z-index: 1;
}

.learner-hero-copy {
    max-width: 520px;
}

.learner-hero-copy h1 {
    font-size: 2rem;
    margin: 0.35rem 0 0.4rem;
}

.learner-eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.14em;
    font-size: 0.7rem;
    color: rgba(244, 247, 251, 0.7);
}

.learner-subtitle {
    margin: 0;
    color: rgba(244, 247, 251, 0.75);
}

.learner-hero-card {
    background: rgba(255, 255, 255, 0.95);
    color: #1f2a35;
    border-radius: 14px;
    padding: 1.25rem;
    min-width: 240px;
    align-self: center;
}

.learner-hero-card-title {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #6b7a8a;
    margin-bottom: 0.75rem;
}

.learner-hero-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.8rem;
}

.learner-metric-value {
    font-size: 1.4rem;
    font-weight: 700;
}

.learner-metric-label {
    font-size: 0.75rem;
    color: #6b7a8a;
}

.learner-hero-overdue {
    margin-top: 0.75rem;
    font-size: 0.8rem;
    font-weight: 600;
    color: #dc3545;
    display: flex;
    align-items: center;
    gap: 0.3rem;
}

.learner-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
    margin-top: 1.5rem;
}

.learner-card {
    border-radius: 16px;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    padding: 1.25rem;
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.08);
    animation: learnerRise 0.45s ease both;
}

.learner-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 1rem;
}

.learner-path-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.learner-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.learner-card-title {
    font-weight: 700;
    font-size: 1rem;
    color: #1f2a35;
}

.learner-card-meta {
    font-size: 0.85rem;
    color: #6b7a8a;
}

.learner-card-meta-line {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.learner-due {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    color: #64748b;
    font-size: 0.82rem;
    font-weight: 700;
    white-space: nowrap;
}

.learner-due::before {
    content: "";
    width: 0.38rem;
    height: 0.38rem;
    border-radius: 999px;
    background: #94a3b8;
}

.learner-due-overdue {
    color: #dc3545;
}

.learner-due-overdue::before {
    background: #dc3545;
}

.learner-card-body {
    margin-top: 0.75rem;
}

.learner-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 0.2rem 0.65rem;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    background: rgba(31, 42, 53, 0.08);
    color: #2b3b4f;
    font-weight: 600;
    white-space: nowrap;
}

.learner-pill-accent {
    background: rgba(40, 181, 160, 0.2);
    color: #1d6b62;
}

.learner-pill-success {
    background: rgba(32, 178, 116, 0.2);
    color: #1c6f4d;
}

.learner-pill-muted {
    background: rgba(148, 163, 184, 0.2);
    color: #64748b;
}

.learner-pill-danger {
    background: rgba(214, 64, 64, 0.2);
    color: #b93838;
}

.learner-progress {
    height: 8px;
    background: #e2e8f0;
    border-radius: 999px;
    overflow: hidden;
    margin: 0.75rem 0 0.85rem;
}

.learner-progress-bar {
    height: 100%;
    width: var(--progress, 0%);
    background: linear-gradient(90deg, var(--siq-brand-accent, #ff7a59), color-mix(in srgb, var(--siq-brand-primary, #1f2a35) 50%, var(--siq-brand-accent, #ff7a59)));
    border-radius: 999px;
    transition: width 0.4s ease;
}

.learner-actions {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    flex-wrap: wrap;
}
.learner-qr {
    width: 96px;
    height: 96px;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    padding: 4px;
    background: #fff;
}

.learner-queue {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.learner-btn {
    border-radius: 10px;
    border: 1px solid transparent;
    padding: 0.4rem 0.85rem;
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
}

.learner-btn-primary {
    background: var(--siq-brand-accent, #ff7a59);
    color: #fff;
    border-color: var(--siq-brand-accent, #ff7a59);
}

.learner-btn-primary:hover {
    background: color-mix(in srgb, var(--siq-brand-accent, #ff7a59) 85%, #000);
}

.learner-btn-outline {
    background: #fff;
    border-color: rgba(31, 42, 53, 0.2);
    color: var(--siq-brand-primary, #1f2a35);
}

.learner-btn-outline:hover {
    border-color: var(--siq-brand-accent, #ff7a59);
    color: var(--siq-brand-accent, #ff7a59);
}

/* Big launch button for Up Next card */
.learner-btn-launch {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-width: 5rem;
    min-height: 3.5rem;
    padding: 0.75rem 1.5rem;
    background: #22a06b;
    color: #fff;
    border: none;
    border-radius: 14px;
    font-size: 1.1rem;
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 4px 14px rgba(34, 160, 107, 0.45);
    transition: background 0.15s, transform 0.1s, box-shadow 0.15s;
    letter-spacing: 0.01em;
}

.learner-btn-launch:hover {
    background: #1a8c5a;
    box-shadow: 0 6px 18px rgba(34, 160, 107, 0.55);
    transform: translateY(-1px);
}

.learner-btn-launch:active {
    transform: translateY(0);
    box-shadow: 0 2px 8px rgba(34, 160, 107, 0.4);
}

.learner-btn-launch-icon {
    font-size: 1.3rem;
    line-height: 1;
}

.learner-view-all-row {
    margin-top: 1rem;
    text-align: center;
}

/* Transcript table */
.transcript-table-card {
    padding: 0;
    overflow: hidden;
}

.transcript-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}

.transcript-table thead th {
    background: #f4f6f8;
    padding: 0.65rem 1rem;
    font-weight: 600;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #4b5563;
    border-bottom: 1px solid #e5e7eb;
    white-space: nowrap;
}

.transcript-table th.sortable {
    cursor: pointer;
    user-select: none;
}

.transcript-table th.sortable:hover { color: var(--siq-brand-accent, #ff7a59); }
.transcript-table th.sort-asc::after  { content: " ↑"; opacity: 0.7; }
.transcript-table th.sort-desc::after { content: " ↓"; opacity: 0.7; }

.transcript-table tbody tr {
    border-bottom: 1px solid #f0f2f4;
    transition: background 0.1s;
}

.transcript-table tbody tr:last-child { border-bottom: none; }
.transcript-table tbody tr:hover { background: #f9fafb; }

.transcript-table td {
    padding: 0.7rem 1rem;
    vertical-align: middle;
    color: #1f2a35;
}

.transcript-course-cell {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}

.transcript-course-name { font-weight: 500; }
.transcript-course-id   { font-size: 0.75rem; }
.transcript-date        { white-space: nowrap; color: #6b7a8a; }

.transcript-status-badge {
    display: inline-block;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
}

.badge-success { background: #dcfce7; color: #166534; }
.badge-info    { background: #dbeafe; color: #1e40af; }
.badge-danger  { background: #fee2e2; color: #991b1b; }
.badge-muted   { background: #f3f4f6; color: #6b7280; }

@media (max-width: 640px) {
    .transcript-table thead th:nth-child(n+4),
    .transcript-table tbody td:nth-child(n+4) { display: none; }
}

.learner-muted {
    font-size: 0.8rem;
    color: #6b7a8a;
}

.learner-section {
    margin-top: 2rem;
}

.learner-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.learner-section-header h2 {
    margin: 0;
}

.learner-section-subtitle {
    margin: 0.35rem 0 0;
    color: #6b7a8a;
}

.learner-link {
    font-weight: 600;
    color: var(--siq-brand-accent, #ff7a59);
    text-decoration: none;
}

.learner-link:hover {
    text-decoration: underline;
}

.learner-summary-list {
    display: grid;
    gap: 0.75rem;
}

.learner-next-card {
    border-top: 4px solid color-mix(in srgb, var(--siq-brand-primary, #1f2a35) 60%, var(--siq-brand-accent, #ff7a59));
}

.learner-summary-card {
    border-top: 4px solid color-mix(in srgb, var(--siq-brand-accent, #ff7a59) 60%, transparent);
}

.learner-summary-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.9rem;
    color: #2b3b4f;
}

.learner-summary-overdue {
    color: #dc3545;
}

.learner-empty {
    text-align: center;
    color: #6b7a8a;
    border: 1px dashed rgba(15, 23, 42, 0.15);
    background: rgba(255, 255, 255, 0.6);
}

.learner-queue-title {
    font-weight: 700;
    font-size: 1.1rem;
}

.learner-queue-meta {
    color: #6b7a8a;
    font-size: 0.85rem;
    margin-top: 0.25rem;
}

.learner-detail-card {
    margin-top: 1.5rem;
}

.learner-detail-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0.75rem;
}

.learner-detail-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.65rem 0.75rem;
    border-radius: 10px;
    background: #f8fafc;
}

.learner-detail-title {
    font-weight: 600;
}

.learner-detail-meta {
    font-size: 0.8rem;
    color: #6b7a8a;
    margin-top: 0.15rem;
}

@keyframes learnerRise {
    from {
        opacity: 0;
        transform: translateY(12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ── Training Records page ───────────────────────────── */

.training-table .training-col-actions  { width: 110px; text-align: center; }
.training-table .training-col-time     { width: 80px; }
.training-table .training-col-activity { width: 130px; white-space: nowrap; }
.training-table .training-col-date     { width: 120px; white-space: nowrap; }
.training-table td.training-overdue    { color: #dc3545; font-weight: 500; }

.training-row { cursor: pointer; }

.training-inline-progress {
    height: 4px;
    background: #e2e8f0;
    border-radius: 999px;
    margin-top: 5px;
    overflow: hidden;
    max-width: 80px;
}
.training-inline-bar {
    height: 100%;
    background: #3b82f6;
    border-radius: 999px;
    transition: width 0.3s ease;
}

/* Certificate icon button in table */
.training-cert-btn {
    width: 32px;
    height: 32px;
    border: none;
    background: transparent;
    color: #f5a623;
    border-radius: 8px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    transition: background 0.15s, color 0.15s, transform 0.12s;
}
.training-cert-btn:hover {
    background: rgba(245, 166, 35, 0.12);
    transform: scale(1.1);
}

.training-col-actions {
    width: 48px;
    text-align: center;
}

@media (max-width: 640px) {
    .training-table .training-col-time,
    .training-table .training-col-activity,
    .training-table .training-col-date { display: none; }
}

.training-toolbar {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    flex-wrap: wrap;
}

.learner-filter-select {
    height: 36px;
    padding: 0 0.75rem;
    border: 1px solid rgba(31, 42, 53, 0.2);
    border-radius: 10px;
    background: #fff;
    font-size: 0.85rem;
    color: #1f2a35;
    cursor: pointer;
}

.learner-search-input {
    height: 36px;
    padding: 0 0.75rem;
    border: 1px solid rgba(31, 42, 53, 0.2);
    border-radius: 10px;
    background: #fff;
    font-size: 0.85rem;
    color: #1f2a35;
    min-width: 180px;
}
.learner-search-input:focus, .learner-filter-select:focus {
    outline: none;
    border-color: var(--siq-brand-accent, #ff7a59);
    box-shadow: 0 0 0 3px rgba(255, 122, 89, 0.12);
}

.training-card-grid {
    grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
}

.training-record-card {
    cursor: pointer;
    transition: box-shadow 0.18s ease, transform 0.18s ease;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.training-record-card:hover {
    box-shadow: 0 20px 40px rgba(15, 23, 42, 0.13);
    transform: translateY(-2px);
}

.training-card-complete {
    border-left: 3px solid #20b274;
}

.training-card-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
}

.training-card-title {
    font-weight: 700;
    font-size: 0.95rem;
    color: #1f2a35;
    line-height: 1.35;
    flex: 1;
}

.training-card-badges {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    flex-shrink: 0;
}

.training-cert-badge {
    font-size: 1rem;
    line-height: 1;
}

.training-card-meta {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.78rem;
    color: #6b7a8a;
    margin-top: 0.5rem;
    flex-wrap: wrap;
}

.training-meta-sep {
    opacity: 0.5;
}

.training-activity {
    font-style: italic;
}

/* ── Drawer ──────────────────────────────────────────── */

.training-drawer-overlay {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.35);
    z-index: 1040;
    animation: fadeIn 0.2s ease both;
}

.training-drawer {
    position: fixed;
    top: 0;
    right: 0;
    height: 100%;
    width: 400px;
    max-width: 96vw;
    background: #fff;
    z-index: 1050;
    display: flex;
    flex-direction: column;
    box-shadow: -6px 0 40px rgba(15, 23, 42, 0.18);
    animation: slideInRight 0.25s cubic-bezier(.4,0,.2,1) both;
}

@keyframes slideInRight {
    from { transform: translateX(100%); opacity: 0; }
    to   { transform: translateX(0);    opacity: 1; }
}

@keyframes fadeIn {
    from { opacity: 0; }
    to   { opacity: 1; }
}

.training-drawer-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 1.25rem 1.25rem 1rem;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    flex-shrink: 0;
}

.training-drawer-eyebrow {
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #6b7a8a;
    margin-bottom: 0.2rem;
}

.training-drawer-title {
    font-weight: 700;
    font-size: 1.05rem;
    color: #1f2a35;
    line-height: 1.35;
}

.training-drawer-close {
    background: none;
    border: none;
    font-size: 1.4rem;
    line-height: 1;
    color: #6b7a8a;
    cursor: pointer;
    padding: 0 0.25rem;
    flex-shrink: 0;
    border-radius: 6px;
    transition: background 0.15s, color 0.15s;
}
.training-drawer-close:hover { background: rgba(31,42,53,0.07); color: #1f2a35; }

.training-drawer-body {
    flex: 1;
    overflow-y: auto;
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

/* Meta grid */
.training-drawer-meta-grid {
    display: flex;
    flex-direction: column;
    gap: 0;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 12px;
    overflow: hidden;
}

.training-drawer-meta-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.6rem 0.9rem;
    border-bottom: 1px solid rgba(15, 23, 42, 0.06);
    font-size: 0.88rem;
}
.training-drawer-meta-item:last-child { border-bottom: none; }

.training-drawer-meta-label {
    color: #6b7a8a;
    font-size: 0.8rem;
    font-weight: 500;
    flex-shrink: 0;
}

.training-drawer-meta-value { color: #1f2a35; font-weight: 500; }

.training-score-value { font-size: 1rem; font-weight: 700; color: #1f2a35; }
.training-score-unit { font-size: 0.75rem; font-weight: 500; color: #6b7a8a; margin-left: 1px; }

.training-drawer-progress-wrap {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.training-drawer-progress-bar {
    width: 100px;
    height: 6px;
    background: rgba(15,23,42,0.1);
    border-radius: 999px;
    overflow: hidden;
}
.training-drawer-progress-fill {
    height: 100%;
    background: #3b82f6;
    border-radius: 999px;
    transition: width 0.3s ease;
}
.training-drawer-progress-pct { font-size: 0.82rem; color: #6b7a8a; }

/* Certificate card */
.training-cert-card {
    border: 1px solid rgba(32, 178, 116, 0.3);
    border-radius: 14px;
    background: linear-gradient(135deg, #f0fdf4 0%, #ecfdf5 100%);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.training-cert-card-header {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem 1rem 0.75rem;
}

.training-cert-icon {
    font-size: 2rem;
    color: #f5a623;
    line-height: 1;
    flex-shrink: 0;
    margin-top: 2px;
}

.training-cert-card-title {
    font-weight: 700;
    font-size: 0.95rem;
    color: #14532d;
}

.training-cert-card-date {
    font-size: 0.8rem;
    color: #166534;
    margin-top: 0.15rem;
}

.training-cert-card-template {
    font-size: 0.75rem;
    color: #4a6b5a;
    margin-top: 0.15rem;
    font-style: italic;
}

.training-cert-actions {
    padding: 0 1rem 0.75rem;
}

.training-cert-download-btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
}

/* Visibility toggle */
.training-cert-visibility {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
    border-top: 1px solid rgba(32, 178, 116, 0.2);
    background: rgba(255,255,255,0.55);
}

.training-visibility-toggle {
    position: relative;
    display: inline-block;
    width: 42px;
    height: 24px;
    flex-shrink: 0;
    cursor: pointer;
}

.training-visibility-toggle input { opacity: 0; width: 0; height: 0; }

.training-visibility-slider {
    position: absolute;
    inset: 0;
    background: #cbd5e1;
    border-radius: 999px;
    transition: background 0.2s;
    cursor: pointer;
}
.training-visibility-slider::before {
    content: "";
    position: absolute;
    width: 18px;
    height: 18px;
    left: 3px;
    top: 3px;
    background: #fff;
    border-radius: 50%;
    transition: transform 0.2s;
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

.training-visibility-toggle input:checked + .training-visibility-slider { background: #20b274; }
.training-visibility-toggle input:checked + .training-visibility-slider::before { transform: translateX(18px); }

.training-visibility-label { display: flex; flex-direction: column; gap: 0; }
.training-visibility-title { font-size: 0.85rem; font-weight: 600; color: #1f2a35; }
.training-visibility-hint { font-size: 0.75rem; color: #6b7a8a; }

/* Share URL row */
.training-cert-share {
    padding: 0.75rem 1rem 1rem;
    border-top: 1px solid rgba(32, 178, 116, 0.2);
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    background: rgba(255,255,255,0.55);
}

.training-share-url-row {
    display: flex;
    gap: 0;
    border: 1px solid rgba(15, 23, 42, 0.18);
    border-radius: 10px;
    overflow: hidden;
}

.training-share-url-input {
    flex: 1;
    border: none;
    padding: 0.5rem 0.75rem;
    font-size: 0.8rem;
    color: #1f2a35;
    background: #fff;
    cursor: pointer;
    min-width: 0;
    outline: none;
}

.training-share-copy-btn {
    border: none;
    border-left: 1px solid rgba(15, 23, 42, 0.12);
    background: #f4f6f8;
    color: #1f2a35;
    font-size: 0.82rem;
    font-weight: 600;
    padding: 0.5rem 0.85rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 0.35rem;
    transition: background 0.15s;
    white-space: nowrap;
}
.training-share-copy-btn:hover { background: #e8ecf0; }
.training-share-copy-btn.copied { background: #dcfce7; color: #166534; }

.training-share-open-link {
    font-size: 0.8rem;
    color: #166534;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 0.3rem;
}
.training-share-open-link:hover { text-decoration: underline; }

.training-type-badge {
    display: inline-block;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    background: rgba(99, 102, 241, 0.1);
    color: #6366f1;
    border: 1px solid rgba(99, 102, 241, 0.25);
    border-radius: 4px;
    padding: 1px 5px;
    margin-left: 6px;
    vertical-align: middle;
}

.training-cert-none {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.85rem 1rem;
    border: 1px dashed rgba(15,23,42,0.15);
    border-radius: 12px;
    color: #6b7a8a;
    font-size: 0.85rem;
}
.training-cert-none-icon { font-size: 1.2rem; opacity: 0.5; }

@media (max-width: 767.98px) {
    .page {
        --app-topbar: 56px;
        padding-bottom: calc(64px + 24px + env(safe-area-inset-bottom));
    }
    .learner-shell {
        padding: 1rem;
    }

    .admin-hero {
        flex-direction: column;
        margin-top: 1rem;
    }

    .admin-hero-card {
        width: 100%;
        align-self: stretch;
    }

    .learner-hero {
        flex-direction: column;
    }

    .learner-hero-card {
        width: 100%;
    }

    .learner-brand-bar {
        flex-direction: row;
        align-items: center;
    }

    .learner-section-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .learner-detail-row {
        flex-direction: column;
        align-items: flex-start;
    }
    .main .top-row:not(.auth) {
        display: none;
    }

    .main .top-row.auth {
        justify-content: flex-start;
        height: auto;
        padding-top: 0.5rem;
        padding-bottom: 0.5rem;
        flex-direction: column;
        align-items: stretch;
        gap: 0.5rem;
    }

    .main .top-row .btn-link {
        display: none;
    }

    .main .top-row a, .main .navbar a {
        white-space: nowrap;
    }

    .admin-shell .content,
    .content {
        padding-top: 0.85rem;
        padding-bottom: calc(3rem + 120px + env(safe-area-inset-bottom));
    }

    .drawer,
    .filters-drawer,
    .edit-drawer,
    .app-drawer {
        top: var(--app-topbar);
        bottom: calc(64px + env(safe-area-inset-bottom));
        height: auto;
        max-height: calc(100dvh - var(--app-topbar) - 64px - env(safe-area-inset-bottom));
    }

    .drawer-body,
    .drawer-form {
        min-height: 0;
    }

    .drawer-footer {
        flex-wrap: wrap;
        align-items: stretch;
        padding: 0.8rem;
    }

    .drawer-footer .btn {
        flex: 1 1 100%;
        justify-content: center;
    }

    .main {
        padding-bottom: calc(64px + 32px + env(safe-area-inset-bottom));
    }

    .sidebar .nav-scrollable.collapse {
        display: none;
    }
    .sidebar .nav-scrollable.collapse.show {
        display: block;
    }

    .scope-breadcrumb {
        display: none;
    }

    .scope-selector-controls .form-select {
        min-width: 100%;
    }

    .scope-switcher-button {
        width: 100%;
        min-width: 0;
    }

    .scope-dropdown {
        width: 92vw;
        left: 0;
        right: 0;
    }

    .scope-dropdown-body {
        grid-template-columns: 1fr;
    }

    .scope-columns {
        grid-template-columns: 1fr;
    }

    .dashboard-hero {
        flex-direction: column;
        align-items: flex-start;
    }

    .dashboard-hero-scope {
        text-align: left;
    }

    .global-search-panel {
        width: 100%;
        left: 0;
        right: 0;
    }

    .data-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .data-toolbar-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .app-split {
        grid-template-columns: 1fr;
    }

    .app-split-panel {
        position: static;
    }

    .app-grid-2 {
        grid-template-columns: 1fr;
    }

    .sidebar {
        position: fixed;
        top: 0;
        left: 0;
        height: 56px;
        width: 100%;
        z-index: 30;
        background: transparent;
    }

    .sidebar .nav-scrollable {
        position: fixed;
        top: 56px;
        left: 0;
        width: 280px;
        height: calc(100vh - 56px);
        background: linear-gradient(180deg, #1f2a35 0%, #1b2733 35%, #15202c 100%);
        transform: translateX(-100%);
        transition: transform 0.2s ease;
    }

    .sidebar .nav-scrollable.collapse {
        display: block;
    }

    .sidebar .nav-scrollable.collapse.show {
        transform: translateX(0);
    }

    .scope-bar {
        width: 100%;
    }

    .top-row-actions {
        width: 100%;
        justify-content: flex-end;
    }

    .profile-menu-wrapper {
        width: 100%;
        display: flex;
        justify-content: flex-end;
    }

    .profile-chip {
        max-width: 100%;
    }

    .main .top-row.auth {
        position: sticky;
        top: 56px;
        z-index: 25;
        padding-inline: 1rem;
    }
    .btn,
    .form-control,
    .form-select {
        min-height: 40px;
    }

    .btn-sm {
        padding: 0.4rem 0.75rem;
    }

    .app-table thead {
        display: none;
    }

    .app-table tr {
        display: block;
        border: 1px solid rgba(15, 23, 42, 0.08);
        border-radius: 12px;
        padding: 0.5rem 0.75rem;
        margin-bottom: 0.75rem;
        background: #fff;
    }

    .app-table td {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        padding: 0.35rem 0;
        min-width: 0;
    }

    .app-table td::before {
        content: attr(data-label);
        font-weight: 600;
        color: var(--siq-muted);
        text-transform: uppercase;
        letter-spacing: 0.05em;
        font-size: 0.7rem;
    }

    .app-table td:not([data-label]) {
        justify-content: flex-start;
    }

    .app-table td > * {
        min-width: 0;
    }

    .app-table td:not([data-label])::before {
        display: none;
    }

    /* Mobile-friendly action menus */
    .app-table tr,
    .app-table td {
        overflow: visible;
    }

    .app-table .dropdown,
    .app-table .dropstart,
    .app-table .dropend,
    .app-table .dropup {
        position: relative;
    }

    .app-table .dropdown-menu {
        position: static;
        float: none;
        width: 100%;
        margin-top: 0.4rem;
        box-shadow: 0 10px 24px rgba(15, 23, 42, 0.12);
    }

    .app-table .dropstart .dropdown-menu,
    .app-table .dropend .dropdown-menu,
    .app-table .dropup .dropdown-menu {
        transform: none !important;
    }

    .app-table .dropdown-menu.show {
        display: block;
    }

    .app-table .dropdown-toggle {
        width: 100%;
        display: inline-flex;
        align-items: center;
        justify-content: space-between;
    }

    .app-table td[data-label="Actions"] {
        justify-content: flex-end;
    }

    .app-table td[data-label="Actions"]::before {
        display: none;
    }

    .app-table td[data-label="Actions"] .dropdown-toggle {
        width: 100%;
        padding: 0.55rem 0.9rem;
        border-radius: 12px;
        background: #fff;
        border: 1px solid #d8dee7;
        box-shadow: 0 2px 8px rgba(15, 23, 42, 0.08);
        gap: 0.45rem;
        justify-content: flex-start;
    }

    .app-table td[data-label="Actions"] .dropdown-toggle i {
        font-size: 1rem;
        color: #64748b;
    }

    .app-table td[data-label="Actions"] .dropdown-toggle::before {
        content: "Actions";
        font-weight: 600;
        color: #111827;
        font-size: 0.95rem;
    }

    .app-table td[data-label="Actions"] .dropdown-toggle::after {
        content: "▾";
        margin-left: auto;
        color: #64748b;
        font-size: 0.9rem;
    }
}

@media (min-width: 768px) {
    .page {
        flex-direction: row;
    }

    .sidebar {
        width: 250px;
        height: 100vh;
        position: sticky;
        top: 0;
    }

    .main {
        flex: 1;
    }

    .main .top-row {
        position: sticky;
        top: 0;
        z-index: 1;
    }

    .main .top-row.auth .btn-link {
        display: inline-block;
    }

    .sidebar .nav-scrollable {
        display: flex !important;
        flex-direction: column;
        overflow-y: auto;
    }

    .sidebar .navbar-toggler {
        display: none;
    }
}

@media (max-width: 767.98px) {
    .content {
        padding-inline: 0.85rem !important;
    }

    .sidebar .nav-scrollable.collapse:not(.show) {
        display: none !important;
    }

    .page-header {
        padding: 0 0 0.85rem 0;
        margin-bottom: 0.85rem;
        flex-direction: column;
    }

    .page-header > div:first-child,
    .page-header .header-intro {
        flex: 0 1 auto;
        min-width: 0;
        width: 100%;
    }

    .page-header,
    .header-actions,
    .content-actions,
    .header-search,
    .data-toolbar,
    .data-toolbar-actions {
        align-items: stretch;
        width: 100%;
    }

    .header-actions,
    .content-actions,
    .header-search,
    .data-toolbar-actions {
        justify-content: stretch;
        flex: 1 1 auto;
        min-width: 0;
        flex-direction: column;
    }

    .header-actions > *,
    .content-actions > *,
    .header-search > *,
    .data-toolbar-actions > *,
    .segmented-bar {
        width: 100%;
    }

    .segmented-bar {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
    }

    .search-box,
    .e-control-wrapper.search-box {
        max-width: none;
    }

    .segmented-btn,
    .data-toolbar-actions .btn,
    .content-actions .btn,
    .header-actions .btn {
        justify-content: center;
        min-width: 0;
        width: 100%;
        white-space: normal;
    }

    .app-panel {
        padding: 0.8rem;
        border-radius: 10px;
    }

    .panel-bar {
        align-items: stretch;
        margin: -0.8rem -0.8rem 0.75rem;
        padding: 0.65rem 0.8rem;
        gap: 0.5rem;
    }

    .panel-bar > div:first-child {
        width: 100%;
        min-width: 0;
    }

    .panel-bar-title,
    .panel-bar-count,
    .panel-bar-subtitle {
        white-space: normal;
    }

    .panel-bar-actions {
        width: 100%;
        margin-left: 0;
        flex: 1 1 100%;
        flex-wrap: wrap;
        align-items: stretch;
    }

    .panel-bar-search,
    .panel-bar-actions .form-control,
    .panel-bar-actions .form-select,
    .panel-bar-actions .toolbar-btn {
        flex: 1 1 100%;
        max-width: none;
        width: 100%;
        justify-content: center;
    }

    .app-table .entity-cell,
    .app-table .entity-identity,
    .app-table .entity-meta {
        min-width: 0;
        max-width: 100%;
    }

    .app-table .entity-meta,
    .app-table .role-scope-code {
        white-space: normal;
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .app-panel-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .bulk-toolbar {
        top: calc(var(--app-topbar) + 0.5rem);
    }
}

/* Drawer pattern */
/* Drawer system is defined above (~line 1697). These are legacy aliases. */
.app-drawer-backdrop { /* see .drawer-backdrop */ }
.overlay { top: var(--app-topbar) !important; height: calc(100vh - var(--app-topbar)) !important; }

/* Login page */
.login-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--app-bg, #f8fafc);
    padding: 2rem 1rem;
}

.login-card {
    width: 100%;
    max-width: 400px;
    background: #fff;
    border-radius: 16px;
    border: 1px solid var(--app-soft-border, rgba(100,116,139,0.18));
    box-shadow: 0 8px 32px rgba(24, 39, 75, 0.1);
    padding: 2.5rem 2rem;
}

.login-card-logo {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--siq-accent, #ff7a59);
    margin-bottom: 0.25rem;
    letter-spacing: -0.01em;
}

.login-card-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #1f2a35;
    margin-bottom: 0.25rem;
}

.login-card-subtitle {
    font-size: 0.85rem;
    color: #6b7a8a;
    margin-bottom: 1.75rem;
}

.login-divider {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    color: #9ca3af;
    font-size: 0.8rem;
    margin: 1.25rem 0;
}

.login-divider::before,
.login-divider::after {
    content: "";
    flex: 1;
    height: 1px;
    background: rgba(100, 116, 139, 0.2);
}

/* AppEmpty structured content */
.app-empty-icon {
    font-size: 2rem;
    margin-bottom: 0.5rem;
    opacity: 0.55;
}

.app-empty-title {
    font-weight: 600;
    font-size: 0.95rem;
    color: #374151;
    margin-bottom: 0.25rem;
}

.app-empty-message {
    font-size: 0.85rem;
    color: #6b7a8a;
}

/* Stat grid used on dashboard pages */
.stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

/* Page content two-column surface */
.page-surface {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1rem;
    margin-bottom: 1.5rem;
}

/* ── Signature UI ── */
@import url('https://fonts.googleapis.com/css2?family=Dancing+Script:wght@600&display=swap');

.signature-terms {
    background: #fefce8;
    border-left: 3px solid #ca8a04;
    border-radius: 0 6px 6px 0;
}

.signature-preview-box {
    border: 1px solid #d1d5db;
    border-radius: 6px;
    padding: 12px 16px;
    background: #fff;
    min-height: 60px;
    display: flex;
    align-items: center;
}

.signature-preview-name,
.signature-name-cursive {
    font-family: 'Dancing Script', 'Brush Script MT', 'Segoe Script', cursive;
    font-size: 1.9rem;
    color: #1a2b5a;
    line-height: 1.2;
}

.signature-evidence-card {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    padding: 1rem 1.25rem;
}

.signature-evidence-terms {
    background: #fefce8;
    border-left: 3px solid #ca8a04;
    padding: 8px 12px;
    margin-bottom: 1rem;
    border-radius: 0 6px 6px 0;
    font-size: 0.875rem;
    color: #374151;
}

.signature-evidence-sig {
    border-bottom: 2px solid #374151;
    padding-bottom: 6px;
    margin-bottom: 10px;
}

.signature-pad-wrap {
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    background: #fff;
    min-height: 180px;
    overflow: hidden;
}

.signature-pad-canvas {
    display: block;
    width: 100%;
    height: 180px;
    touch-action: none;
    cursor: crosshair;
}

.signature-evidence-image {
    display: block;
    width: 100%;
    max-width: 420px;
    max-height: 140px;
    object-fit: contain;
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
}


/* Learner CMS footer */
.learner-footer {
    padding: 1rem 2rem;
    border-top: 1px solid var(--app-border, rgba(15,23,42,0.1));
    background: var(--app-surface, #fff);
    color: var(--siq-muted, #6b7a8a);
    font-size: 0.875rem;
    line-height: 1.6;
}
.learner-footer a {
    color: var(--siq-muted, #6b7a8a);
    text-decoration: none;
}
.learner-footer a:hover {
    color: var(--siq-accent, #ff7a59);
    text-decoration: underline;
}

/* ── Microsoft Teams host-theme overrides ─────────────────────────────────────
   Teams sets data-teams-theme="dark" or "contrast" on <body> via the
   registerOnThemeChangeHandler in teams.js.  We re-map our CSS custom
   properties so every component gets the right palette automatically.
   These rules only activate inside a Teams iframe — they have zero effect
   in a normal browser session.
   --------------------------------------------------------------------------- */

body[data-teams-theme="dark"] {
    --siq-ink:                 #e8edf2;
    --siq-muted:               #8c96a2;
    --siq-bg:                  #1f2a35;
    --siq-brand-bg:            #1f2a35;
    --siq-brand-primary:       #e8edf2;
    --siq-brand-accent:        #ff9a7a;
    --siq-accent:              #ff9a7a;
    --siq-brand-sidebar-top:   #141e28;
    --siq-brand-sidebar-bottom:#0e1820;
    --app-surface:             #253242;
    --app-border:              rgba(255, 255, 255, 0.1);
    --app-soft-border:         rgba(255, 255, 255, 0.06);
    --app-shadow-soft:         0 10px 24px rgba(0, 0, 0, 0.3);
    --app-shadow-lift:         0 18px 42px rgba(0, 0, 0, 0.4);
    --siq-shadow-1:            0 6px 14px rgba(0, 0, 0, 0.3);
    --siq-shadow-2:            0 14px 28px rgba(0, 0, 0, 0.4);
    color-scheme: dark;
}

body[data-teams-theme="dark"] body,
body[data-teams-theme="dark"] {
    background-color: var(--siq-brand-bg);
    color: var(--siq-ink);
}

body[data-teams-theme="dark"] .card,
body[data-teams-theme="dark"] .modal-content,
body[data-teams-theme="dark"] .offcanvas,
body[data-teams-theme="dark"] .dropdown-menu,
body[data-teams-theme="dark"] .app-panel {
    background-color: var(--app-surface);
    border-color: var(--app-border);
    color: var(--siq-ink);
}

body[data-teams-theme="dark"] .card-header,
body[data-teams-theme="dark"] .modal-header,
body[data-teams-theme="dark"] .modal-footer {
    background-color: rgba(255, 255, 255, 0.04);
    border-color: var(--app-border);
}

body[data-teams-theme="dark"] .form-control,
body[data-teams-theme="dark"] .form-select {
    background-color: #1a2535;
    border-color: rgba(255, 255, 255, 0.15);
    color: var(--siq-ink);
}

body[data-teams-theme="dark"] .form-control:focus,
body[data-teams-theme="dark"] .form-select:focus {
    background-color: #1a2535;
    border-color: var(--siq-accent);
    color: var(--siq-ink);
    box-shadow: 0 0 0 0.2rem rgba(255, 154, 122, 0.25);
}

body[data-teams-theme="dark"] .form-control::placeholder {
    color: var(--siq-muted);
    opacity: 1;
}

body[data-teams-theme="dark"] .table {
    --bs-table-bg: transparent;
    --bs-table-striped-bg: rgba(255, 255, 255, 0.03);
    --bs-table-hover-bg: rgba(255, 255, 255, 0.05);
    --bs-table-border-color: var(--app-border);
    color: var(--siq-ink);
}

body[data-teams-theme="dark"] .table thead th {
    background-color: rgba(255, 255, 255, 0.05);
    color: var(--siq-muted);
}

body[data-teams-theme="dark"] .nav-link,
body[data-teams-theme="dark"] .sidebar-link {
    color: rgba(232, 237, 242, 0.75);
}

body[data-teams-theme="dark"] .nav-link:hover,
body[data-teams-theme="dark"] .sidebar-link:hover,
body[data-teams-theme="dark"] .nav-link.active {
    color: #fff;
    background-color: rgba(255, 255, 255, 0.08);
}

body[data-teams-theme="dark"] .alert-info {
    background-color: rgba(13, 110, 253, 0.15);
    border-color: rgba(13, 110, 253, 0.3);
    color: #9ec5fe;
}

body[data-teams-theme="dark"] .alert-success {
    background-color: rgba(25, 135, 84, 0.15);
    border-color: rgba(25, 135, 84, 0.3);
    color: #75b798;
}

body[data-teams-theme="dark"] .alert-warning {
    background-color: rgba(255, 193, 7, 0.15);
    border-color: rgba(255, 193, 7, 0.3);
    color: #ffc107;
}

body[data-teams-theme="dark"] .alert-danger {
    background-color: rgba(220, 53, 69, 0.15);
    border-color: rgba(220, 53, 69, 0.3);
    color: #ea868f;
}

body[data-teams-theme="dark"] .badge.bg-light {
    background-color: rgba(255, 255, 255, 0.12) !important;
    color: var(--siq-ink) !important;
}

body[data-teams-theme="dark"] .text-muted {
    color: var(--siq-muted) !important;
}

body[data-teams-theme="dark"] .border,
body[data-teams-theme="dark"] .border-top,
body[data-teams-theme="dark"] .border-bottom {
    border-color: var(--app-border) !important;
}

body[data-teams-theme="dark"] hr {
    border-color: var(--app-border);
    opacity: 1;
}

/* ── High-contrast (accessible) theme ─────────────────────────────────────── */

body[data-teams-theme="contrast"] {
    --siq-ink:                 #ffffff;
    --siq-muted:               #ffff00;
    --siq-bg:                  #000000;
    --siq-brand-bg:            #000000;
    --siq-brand-primary:       #ffffff;
    --siq-brand-accent:        #ffff00;
    --siq-accent:              #ffff00;
    --siq-brand-sidebar-top:   #000000;
    --siq-brand-sidebar-bottom:#000000;
    --app-surface:             #000000;
    --app-border:              #ffffff;
    --app-soft-border:         #ffffff;
    --app-shadow-soft:         none;
    --app-shadow-lift:         none;
    --siq-shadow-1:            none;
    --siq-shadow-2:            none;
    color-scheme: dark;
}

body[data-teams-theme="contrast"] {
    background-color: #000;
    color: #fff;
}

body[data-teams-theme="contrast"] .card,
body[data-teams-theme="contrast"] .modal-content,
body[data-teams-theme="contrast"] .offcanvas,
body[data-teams-theme="contrast"] .dropdown-menu,
body[data-teams-theme="contrast"] .app-panel {
    background-color: #000;
    border: 2px solid #fff;
    color: #fff;
}

body[data-teams-theme="contrast"] .card-header,
body[data-teams-theme="contrast"] .modal-header,
body[data-teams-theme="contrast"] .modal-footer {
    background-color: #000;
    border-color: #fff;
}

body[data-teams-theme="contrast"] .form-control,
body[data-teams-theme="contrast"] .form-select {
    background-color: #000;
    border: 2px solid #fff;
    color: #fff;
}

body[data-teams-theme="contrast"] .form-control:focus,
body[data-teams-theme="contrast"] .form-select:focus {
    background-color: #000;
    border-color: #ffff00;
    color: #fff;
    box-shadow: 0 0 0 2px #ffff00;
}

body[data-teams-theme="contrast"] .form-control::placeholder {
    color: #ffff00;
    opacity: 1;
}

body[data-teams-theme="contrast"] a,
body[data-teams-theme="contrast"] a:visited {
    color: #ffff00;
    text-decoration: underline;
}

body[data-teams-theme="contrast"] a:hover,
body[data-teams-theme="contrast"] a:focus {
    color: #fff;
    outline: 2px solid #fff;
    outline-offset: 2px;
}

body[data-teams-theme="contrast"] .btn {
    border: 2px solid #fff;
}

body[data-teams-theme="contrast"] .btn-primary {
    background-color: #000;
    border-color: #ffff00;
    color: #ffff00;
}

body[data-teams-theme="contrast"] .btn-primary:hover,
body[data-teams-theme="contrast"] .btn-primary:focus {
    background-color: #ffff00;
    border-color: #ffff00;
    color: #000;
}

body[data-teams-theme="contrast"] .btn-secondary,
body[data-teams-theme="contrast"] .btn-outline-secondary {
    background-color: #000;
    border-color: #fff;
    color: #fff;
}

body[data-teams-theme="contrast"] .btn-secondary:hover,
body[data-teams-theme="contrast"] .btn-outline-secondary:hover {
    background-color: #fff;
    color: #000;
}

body[data-teams-theme="contrast"] .table {
    --bs-table-bg: #000;
    --bs-table-striped-bg: #111;
    --bs-table-hover-bg: #1a1a1a;
    --bs-table-border-color: #fff;
    color: #fff;
}

body[data-teams-theme="contrast"] .nav-link,
body[data-teams-theme="contrast"] .sidebar-link {
    color: #fff;
    text-decoration: underline;
}

body[data-teams-theme="contrast"] .nav-link.active,
body[data-teams-theme="contrast"] .sidebar-link.active {
    color: #ffff00;
    outline: 2px solid #ffff00;
}

body[data-teams-theme="contrast"] .alert {
    border: 2px solid #fff;
    color: #fff;
    background-color: #000;
}

body[data-teams-theme="contrast"] .badge {
    border: 1px solid currentColor;
}

body[data-teams-theme="contrast"] .text-muted {
    color: #ffff00 !important;
}

body[data-teams-theme="contrast"] hr {
    border-color: #fff;
    opacity: 1;
}

body[data-teams-theme="contrast"] :focus-visible {
    outline: 3px solid #ffff00;
    outline-offset: 2px;
}

/* ── Teams layout base (all themes) ──────────────────────────────────────────
   Remove the LMS chrome (sidebar, topbar) when rendered inside a Teams iframe.
   TeamsLayout already handles this at the Razor level; these rules are a safety
   net for any bootstrap utilities that might leak through.
   --------------------------------------------------------------------------- */

body.in-teams .app-sidebar,
body.in-teams .topbar {
    display: none !important;
}

body.in-teams .app-content-area,
body.in-teams .page-content {
    margin-left: 0 !important;
    padding-top: 0 !important;
}
