:root {
    --sidebar-width: 280px;
}

/* ===== Theme utility layer ===== */

.theme-surface {
    background: var(--surface, var(--bs-body-bg)) !important;
    color: var(--text, var(--bs-body-color)) !important;
    border-color: var(--border-color, rgba(0, 0, 0, 0.08)) !important;
}

.theme-surface-soft {
    background: var(--surface-soft, color-mix(in srgb, var(--surface, #fff) 92%, var(--primary, #0d6efd) 8%)) !important;
    color: var(--text, var(--bs-body-color)) !important;
    border-color: var(--border-color, rgba(0, 0, 0, 0.08)) !important;
}

.theme-muted {
    color: var(--muted, var(--bs-secondary-color)) !important;
}

.theme-label {
    color: var(--muted, var(--bs-secondary-color)) !important;
    font-size: 0.78rem;
    font-weight: 600;
}

.theme-border {
    border-color: var(--border-color, rgba(0, 0, 0, 0.08)) !important;
}

.theme-table-head th,
.theme-table-head td {
    background: var(--surface-soft, color-mix(in srgb, var(--surface, #fff) 92%, var(--primary, #0d6efd) 8%)) !important;
    color: var(--muted, var(--bs-secondary-color)) !important;
    border-color: var(--border-color, rgba(0, 0, 0, 0.08)) !important;
    font-weight: 700;
}

.theme-table-head th[aria-sort] {
    position: relative;
    padding: 0 !important;
}

.theme-table-sort-button {
    width: 100%;
    min-height: 36px;
    border: 0;
    background: transparent;
    color: inherit;
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.52rem 0.9rem;
    font: inherit;
    font-weight: inherit;
    text-align: left;
    transition: color 0.18s ease, background 0.18s ease;
}

.theme-table-sort-button:hover,
.theme-table-sort-button:focus-visible {
    background: color-mix(in srgb, var(--surface, #fff) 74%, var(--primary, #0d6efd) 26%);
    color: var(--text-main, var(--bs-body-color));
    outline: none;
}

.theme-table-sort-button__label {
    min-width: 0;
}

.theme-table-sort-button__icon {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.78rem;
    line-height: 1;
    flex: 0 0 auto;
}

.theme-table-head th[aria-sort="ascending"] .theme-table-sort-button,
.theme-table-head th[aria-sort="descending"] .theme-table-sort-button {
    color: var(--text-main, var(--bs-body-color));
}

.theme-table-head th[aria-sort="ascending"] .theme-table-sort-button__icon,
.theme-table-head th[aria-sort="descending"] .theme-table-sort-button__icon {
    color: var(--primary, var(--bs-primary));
}

.theme-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    padding: 0.35rem 0.55rem;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 600;
    background: var(--surface-soft, color-mix(in srgb, var(--surface, #fff) 90%, var(--primary, #0d6efd) 10%));
    color: var(--text, var(--bs-body-color));
    border: 1px solid var(--border-color, rgba(0, 0, 0, 0.08));
}

.theme-badge-soft {
    background: var(--surface-soft, color-mix(in srgb, var(--surface, #fff) 90%, var(--primary, #0d6efd) 10%)) !important;
    color: var(--text, var(--bs-body-color)) !important;
    border: 1px solid var(--border-color, rgba(0, 0, 0, 0.08)) !important;
}

.theme-badge-success {
    background: color-mix(in srgb, #198754 18%, var(--surface, #fff)) !important;
    color: var(--text, var(--bs-body-color)) !important;
    border: 1px solid color-mix(in srgb, #198754 35%, var(--border-color, rgba(0, 0, 0, 0.08))) !important;
}

.theme-badge-danger {
    background: color-mix(in srgb, #dc3545 18%, var(--surface, #fff)) !important;
    color: var(--text, var(--bs-body-color)) !important;
    border: 1px solid color-mix(in srgb, #dc3545 35%, var(--border-color, rgba(0, 0, 0, 0.08))) !important;
}

.theme-badge-warning {
    background: color-mix(in srgb, #fd7e14 18%, var(--surface, #fff)) !important;
    color: var(--text, var(--bs-body-color)) !important;
    border: 1px solid color-mix(in srgb, #fd7e14 35%, var(--border-color, rgba(0, 0, 0, 0.08))) !important;
}

.theme-badge-info {
    background: color-mix(in srgb, #0dcaf0 18%, var(--surface, #fff)) !important;
    color: var(--text, var(--bs-body-color)) !important;
    border: 1px solid color-mix(in srgb, #0dcaf0 35%, var(--border-color, rgba(0, 0, 0, 0.08))) !important;
}

.theme-link {
    color: var(--primary, var(--bs-primary)) !important;
    text-decoration: none;
}

.theme-link:hover {
    filter: brightness(0.95);
    text-decoration: underline;
}

.theme-empty {
    color: var(--muted, var(--bs-secondary-color)) !important;
    text-align: center;
    padding: 1rem 0;
}

html[data-theme="custom"] {

    --surface: #ffffff;
    --surface-soft: #fef7f1;
    --text: #21323a;
    --muted: #5f6f76;
    --border-color: rgba(9, 124, 135, 0.18);
    --primary: #097C87;

    --sidebar-bg: linear-gradient(180deg, #097C87 0%, #23CED9 100%);
    --sidebar-muted: #F9D779;
    --sidebar-text: #f8fffe;
    --sidebar-active: linear-gradient(135deg, #FCA47C 0%, #F9D779 100%);
    --sidebar-hover: rgba(255,255,255,0.16);

    --app-bg: linear-gradient(180deg, #fffdf9 0%, #f7fffe 55%, #f6fbf7 100%);
    --surface: rgba(255,255,255,0.97);
    --surface-strong: #ffffff;
    --surface-muted: #fff9ef;

    --card-border: #dbeeed;
    --card-shadow: 0 14px 30px rgba(9, 124, 135, 0.10);

    --text-main: #21323a;
    --text-muted: #61747c;
    --text-soft: #88a0a4;

    --primary: #097C87;
    --primary-hover: #076771;
    --primary-soft: #e7f9fb;

    --success-soft: #eef8f0;
    --warning-soft: #fff6da;
    --danger-soft: #fff0e9;

    --pill-border: #d6e9e7;
    --pill-border-hover: #bcded9;
    --pill-bg: #ffffff;
    --pill-bg-hover: #f6fffe;
    --pill-selected-bg: #e7f9fb;
    --pill-selected-border: #23CED9;
    --pill-selected-text: #076771;

    --input-bg: #ffffff;
    --input-border: #cfe7e5;
    --table-head-bg: #f9fffe;
    --table-border: #deefed;
    --table-row-hover: #f5fffd;
    --topbar-bg: rgba(255,255,255,0.86);

    --btn-outline-neutral-bg: transparent;
    --btn-outline-neutral-border: #cfe2df;
    --btn-outline-neutral-text: #2d5056;
    --btn-outline-neutral-hover-bg: #f7fffd;
    --btn-outline-neutral-hover-text: #16363b;

    --bs-body-bg: #fffdf9;
    --bs-body-color: #21323a;
    --bs-primary: #097C87;
    --bs-secondary: #23CED9;
    --bs-success: #A1CCA6;
    --bs-info: #23CED9;
    --bs-warning: #F9D779;
    --bs-danger: #FCA47C;
    --bs-light: #fff9ef;
    --bs-dark: #21323a;
    --bs-border-color: #deefed;
    --bs-link-color: #097C87;
    --bs-link-hover-color: #076771;
}

html[data-theme="dark"] {

    --surface: #111827;
    --surface-soft: #1f2937;
    --text: #f3f4f6;
    --muted: #cbd5e1;
    --border-color: rgba(255, 255, 255, 0.12);
    --primary: #60a5fa;

    --sidebar-bg: linear-gradient(180deg, #0d1524 0%, #121c2f 100%);
    --sidebar-muted: #9fb0c7;
    --sidebar-text: #edf3fb;
    --sidebar-active: linear-gradient(135deg, #4f8df7 0%, #2563eb 100%);
    --sidebar-hover: rgba(255,255,255,0.06);

    --app-bg: linear-gradient(180deg, #0b1220 0%, #111827 100%);
    --surface: rgba(20, 29, 45, 0.96);
    --surface-strong: #162133;
    --surface-muted: #1b2840;

    --card-border: #304159;
    --card-shadow: 0 16px 34px rgba(0, 0, 0, 0.34);

    --text-main: #edf3fb;
    --text-muted: #b8c4d6;
    --text-soft: #90a0b7;

    --primary: #7ab2ff;
    --primary-hover: #5b9bff;
    --primary-soft: #162946;

    --success-soft: #123021;
    --warning-soft: #3a2a13;
    --danger-soft: #3a171c;

    --pill-border: #40536d;
    --pill-border-hover: #536883;
    --pill-bg: #152033;
    --pill-bg-hover: #1a2940;
    --pill-selected-bg: #17345f;
    --pill-selected-border: #7ab2ff;
    --pill-selected-text: #e4f0ff;

    --input-bg: #101a2b;
    --input-border: #41546f;
    --table-head-bg: #182539;
    --table-border: #304159;
    --table-row-hover: #16253a;
    --topbar-bg: rgba(11, 18, 32, 0.88);

    --btn-outline-neutral-bg: transparent;
    --btn-outline-neutral-border: #445874;
    --btn-outline-neutral-text: #d9e3f0;
    --btn-outline-neutral-hover-bg: #182539;
    --btn-outline-neutral-hover-text: #ffffff;

    --bs-body-bg: #0b1220;
    --bs-body-color: #edf3fb;
    --bs-primary: #7ab2ff;
    --bs-secondary: #9fb0c7;
    --bs-success: #7dd3a0;
    --bs-info: #67d4ff;
    --bs-warning: #f8cf76;
    --bs-danger: #ff9e9e;
    --bs-light: #1b2840;
    --bs-dark: #edf3fb;
    --bs-border-color: #304159;
    --bs-link-color: #7ab2ff;
    --bs-link-hover-color: #a8ccff;
}

* {
    box-sizing: border-box;
}

body {
    background: var(--app-bg);
    min-height: 100vh;
    color: var(--text-main);
    font-family: Inter, "Segoe UI", Roboto, Arial, sans-serif;
}

a {
    color: var(--primary);
    text-decoration: none;
}

a:hover {
    color: var(--primary-hover);
}

.app-shell {
    min-height: 100vh;
}

.app-sidebar {
    width: var(--sidebar-width);
    background: var(--sidebar-bg);
    color: var(--sidebar-text);
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    padding: 1.35rem 1rem;
    overflow-y: auto;
    border-right: 1px solid rgba(255,255,255,0.06);
    box-shadow: 8px 0 24px rgba(15, 23, 42, 0.14);
}

.sidebar-brand {
    display: block;
    text-decoration: none;
    color: #fff;
    margin-bottom: 1.75rem;
    padding: 0.35rem 0.45rem;
    border-radius: 1rem;
}

.sidebar-brand-title {
    font-size: 1.28rem;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -0.02em;
}

.sidebar-brand-sub {
    color: var(--sidebar-muted);
    font-size: 0.83rem;
    margin-top: 0.22rem;
}

.sidebar-section-title {
    color: var(--sidebar-muted);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin: 1.35rem 0 0.7rem;
    padding: 0 0.6rem;
    font-weight: 700;
}

.sidebar-section {
    margin-top: 0.9rem;
}

.sidebar-section:first-of-type {
    margin-top: 0;
}

.sidebar-section-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    border: 0;
    background: transparent;
    color: var(--sidebar-muted);
    padding: 0.25rem 0.6rem 0.55rem;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 700;
    transition: color 0.18s ease, background 0.18s ease;
}

.sidebar-section-toggle:hover {
    color: #ffffff;
}

.sidebar-section-toggle:focus-visible {
    outline: 2px solid rgba(255,255,255,0.38);
    outline-offset: 2px;
    border-radius: 0.75rem;
}

.sidebar-section-title-text {
    text-align: left;
}

.sidebar-section-chevron {
    width: 0.7rem;
    height: 0.7rem;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg);
    transition: transform 0.18s ease;
    flex: 0 0 auto;
    margin-right: 0.15rem;
}

.sidebar-section-toggle[aria-expanded="true"] .sidebar-section-chevron {
    transform: rotate(225deg);
}

.sidebar-section .sidebar-nav {
    padding-bottom: 0.15rem;
}

.sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: 0.38rem;
}

.sidebar-link {
    color: var(--sidebar-text);
    text-decoration: none;
    padding: 0.8rem 0.9rem;
    border-radius: 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    transition: background 0.18s ease, color 0.18s ease, transform 0.12s ease, box-shadow 0.18s ease;
    font-size: 0.95rem;
}

.sidebar-link:hover {
    background: var(--sidebar-hover);
    color: #fff;
    transform: translateX(1px);
}

.sidebar-link.current-page {
    background: var(--sidebar-active);
    color: #fff;
    box-shadow: 0 10px 22px rgba(37, 99, 235, 0.28);
}

.sidebar-link-main {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 0;
}

.sidebar-icon {
    width: 1.2rem;
    text-align: center;
    opacity: 0.96;
    flex: 0 0 auto;
    font-size: 0.98rem;
}

.sidebar-label {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-weight: 500;
}

.sidebar-link-muted {
    color: rgba(255,255,255,0.74);
    font-size: 0.74rem;
    flex: 0 0 auto;
}

.sidebar-badge {
    font-size: 0.68rem;
    background: rgba(255,255,255,0.18);
    color: #fff;
    padding: 0.2rem 0.46rem;
    border-radius: 999px;
    font-weight: 600;
}

.app-main {
    margin-left: var(--sidebar-width);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.app-topbar {
    background: var(--topbar-bg);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--card-border);
    padding: 1rem 1.5rem;
    position: sticky;
    top: 0;
    z-index: 30;
}

.app-topbar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.app-topbar-title {
    font-size: 1.15rem;
    font-weight: 700;
    margin: 0;
    letter-spacing: -0.02em;
    color: var(--text-main);
}

.app-topbar-subtitle {
    font-size: 0.87rem;
    color: var(--text-muted);
    margin: 0.15rem 0 0;
}

.app-content {
    padding: 1.5rem;
}

.card {
    background: var(--surface);
    border: 1px solid var(--card-border);
    border-radius: 1.15rem;
    box-shadow: var(--card-shadow);
}

/* Theme-aware list groups and light utility surfaces */
.list-group {
    --bs-list-group-bg: var(--surface);
    --bs-list-group-border-color: var(--card-border);
    --bs-list-group-color: var(--text-main);
    --bs-list-group-action-color: var(--text-main);
    --bs-list-group-action-hover-color: var(--text-main);
    --bs-list-group-action-active-color: var(--text-main);
    --bs-list-group-action-hover-bg: var(--table-row-hover);
    --bs-list-group-action-active-bg: var(--surface-muted);
    --bs-list-group-active-bg: var(--primary);
    --bs-list-group-active-border-color: var(--primary);
}

.list-group-item,
.list-group-item-action {
    background: var(--surface) !important;
    color: var(--text-main) !important;
    border-color: var(--card-border) !important;
}

.list-group-item-action:hover,
.list-group-item-action:focus {
    background: var(--table-row-hover) !important;
    color: var(--text-main) !important;
}

.list-group-item .text-muted,
.list-group-item small,
.list-group-item .small {
    color: var(--text-muted) !important;
}

.list-group-item .badge,
.card .badge,
.app-content .badge {
    color: inherit;
}

.bg-light,
.card .bg-light,
.app-content .bg-light,
.text-bg-light {
    background: var(--surface-muted) !important;
    color: var(--text-main) !important;
    border-color: var(--card-border) !important;
}

.table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--text-main);
    --bs-table-border-color: var(--table-border);
    --bs-table-striped-color: var(--text-main);
    --bs-table-hover-color: var(--text-main);
    color: var(--text-main) !important;
}

.table > :not(caption) > * > * {
    padding-top: 0.82rem;
    padding-bottom: 0.82rem;
    border-color: var(--table-border) !important;
    color: var(--text-main) !important;
    background-color: transparent !important;
}

.table thead.table-light th,
.table thead th,
.table-light th {
    background: var(--table-head-bg) !important;
    color: var(--text-main) !important;
    font-size: 0.84rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    border-bottom: 1px solid var(--table-border) !important;
}

.table tbody tr:hover > * {
    background: var(--table-row-hover) !important;
    color: var(--text-main) !important;
}

.table td,
.table th,
.table span,
.table small,
.table strong,
.table div,
.table p,
.table a,
.table .text-muted {
    color: inherit !important;
}

.table a {
    color: var(--primary) !important;
    font-weight: 500;
}

.table a:hover {
    color: var(--primary-hover) !important;
}

.table .badge.text-bg-light {
    background: var(--surface-muted) !important;
    color: var(--text-main) !important;
    border: 1px solid var(--card-border);
}

html[data-theme="dark"] .table .badge.text-bg-light {
    color: var(--text-main) !important;
    border-color: var(--card-border);
}

.form-label {
    font-weight: 600;
    color: var(--text-main);
    margin-bottom: 0.45rem;
}

.form-control,
.form-select {
    border-radius: 0.9rem;
    border: 1px solid var(--input-border);
    padding: 0.68rem 0.85rem;
    background: var(--input-bg);
    color: var(--text-main);
    box-shadow: none;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 0.22rem rgba(59, 130, 246, 0.14);
    background: var(--input-bg);
    color: var(--text-main);
}

.form-control::placeholder {
    color: var(--text-soft);
}

.form-select option {
    background: var(--surface-strong);
    color: var(--text-main);
}

textarea.form-control {
    min-height: 110px;
}

.form-text {
    color: var(--text-muted);
    font-size: 0.82rem;
}

.form-check-input {
    border-color: #94a3b8;
    background-color: transparent;
}

.form-check-input:checked {
    background-color: var(--primary);
    border-color: var(--primary);
}

.btn {
    border-radius: 0.9rem;
    font-weight: 600;
    padding: 0.62rem 0.95rem;
    transition: all 0.18s ease;
}

.btn-primary {
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);
    border-color: var(--primary-hover);
    color: #ffffff;
    box-shadow: 0 8px 18px rgba(37, 99, 235, 0.18);
}

.btn-primary:hover,
.btn-primary:focus {
    filter: brightness(0.98);
    transform: translateY(-1px);
    color: #ffffff;
}

.btn-outline-primary {
    border-color: rgba(96, 165, 250, 0.35);
    color: var(--primary);
    background: transparent;
}

.btn-outline-primary:hover {
    background: var(--primary-soft);
    border-color: rgba(96, 165, 250, 0.5);
    color: var(--primary-hover);
}

.btn-outline-secondary {
    border-color: var(--btn-outline-neutral-border);
    color: var(--btn-outline-neutral-text);
    background: var(--btn-outline-neutral-bg);
}

.btn-outline-secondary:hover {
    background: var(--btn-outline-neutral-hover-bg);
    border-color: var(--btn-outline-neutral-border);
    color: var(--btn-outline-neutral-hover-text);
}

.alert {
    border-radius: 1rem;
    border: 1px solid transparent;
}

.alert-info {
    background: var(--primary-soft);
    border-color: rgba(96, 165, 250, 0.18);
    color: var(--text-main);
}

.alert-success {
    background: var(--success-soft);
    border-color: rgba(34,197,94,0.18);
    color: var(--text-main);
}

.alert-warning {
    background: var(--warning-soft);
    border-color: rgba(245,158,11,0.18);
    color: var(--text-main);
}

.alert-danger {
    background: var(--danger-soft);
    border-color: rgba(239,68,68,0.18);
    color: var(--text-main);
}

.badge {
    border-radius: 999px;
    padding: 0.48em 0.7em;
    font-weight: 600;
    letter-spacing: 0.01em;
}

.text-muted {
    color: var(--text-muted) !important;
}

.display-6 {
    letter-spacing: -0.03em;
}

.theme-switcher-wrap {
    min-width: 220px;
}

.theme-switcher {
    background: var(--input-bg);
    color: var(--text-main);
    border: 1px solid var(--input-border);
    border-radius: 0.85rem;
    padding: 0.5rem 0.75rem;
    font-size: 0.9rem;
    font-weight: 600;
}

.mobile-menu-btn {
    display: none;
}

.offcanvas-sidebar {
    background: var(--sidebar-bg);
    color: var(--sidebar-text);
}

.offcanvas-sidebar .offcanvas-title {
    color: #fff;
    font-weight: 700;
}

.offcanvas-sidebar .btn-close {
    filter: invert(1);
}

.cf-pill-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 0.55rem;
    width: 100%;
}

.cf-pill-option {
    position: relative;
    display: block;
    border: 1px solid var(--pill-border);
    border-radius: 0.8rem;
    background: var(--pill-bg);
    transition: all 0.18s ease;
    cursor: pointer;
    overflow: hidden;
    width: 100%;
}

.cf-pill-option:hover {
    border-color: var(--pill-border-hover);
    background: var(--pill-bg-hover);
}

.cf-pill-option input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.cf-pill-option-body {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.65rem 0.75rem;
    min-height: 42px;
    width: 100%;
}

.cf-pill-check {
    width: 0.95rem;
    height: 0.95rem;
    border-radius: 999px;
    border: 2px solid #7b8aa2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.62rem;
    font-weight: 700;
    color: transparent;
    flex: 0 0 auto;
    transition: all 0.18s ease;
    background: transparent;
    line-height: 1;
}

html[data-theme="custom"] .cf-pill-check {
    background: #fff;
    border-color: #c7d2e3;
}

.cf-pill-label {
    font-size: 0.88rem;
    font-weight: 500;
    color: var(--text-main);
    line-height: 1.15;
    width: 100%;
}

.cf-pill-option.is-selected {
    border-color: var(--pill-selected-border);
    background: var(--pill-selected-bg);
    box-shadow: 0 3px 10px rgba(37, 99, 235, 0.08);
}

.cf-pill-option.is-selected .cf-pill-check {
    border-color: var(--pill-selected-border);
    background: var(--pill-selected-border);
    color: #fff;
}

.cf-pill-option.is-selected .cf-pill-label {
    color: var(--pill-selected-text);
    font-weight: 600;
}

.app-content h1,
.app-content h2,
.app-content h3,
.app-content h4,
.app-content h5,
.app-content h6,
.card h1,
.card h2,
.card h3,
.card h4,
.card h5,
.card h6,
.card .h1,
.card .h2,
.card .h3,
.card .h4,
.card .h5,
.card .h6 {
    color: var(--text-main) !important;
}

.app-content .text-dark,
.app-content .text-black,
.app-content .text-body,
.app-content .text-body-emphasis,
.card .text-dark,
.card .text-black,
.card .text-body,
.card .text-body-emphasis {
    color: var(--text-main) !important;
}

.app-content .text-secondary,
.app-content .text-muted,
.card .text-secondary,
.card .text-muted,
.card small,
.card .small {
    color: var(--text-muted) !important;
}

.card .fs-1,
.card .fs-2,
.card .fs-3,
.card .fs-4,
.card .fs-5,
.card .fs-6,
.card .display-1,
.card .display-2,
.card .display-3,
.card .display-4,
.card .display-5,
.card .display-6,
.card .fw-semibold,
.card .fw-bold,
.card .fw-bolder {
    color: var(--text-main) !important;
}

.card label,
.card .form-label {
    color: var(--text-main) !important;
}

.app-content .badge.text-bg-light {
    background: var(--surface-muted) !important;
    color: var(--text-main) !important;
    border: 1px solid var(--card-border);
}

.metric-number,
.summary-number,
.stat-number,
.kpi-number,
.record-count {
    color: var(--text-main) !important;
}

.metric-label,
.summary-label,
.stat-label,
.kpi-label,
.section-kicker {
    color: var(--text-muted) !important;
}

@media (max-width: 991.98px) {
    .app-sidebar {
        display: none;
    }

    .app-main {
        margin-left: 0;
    }

    .app-topbar {
        padding: 0.9rem 1rem;
    }

    .app-content {
        padding: 1rem;
    }

    .mobile-menu-btn {
        display: inline-flex;
    }

    .theme-switcher-wrap {
        min-width: 150px;
    }
}

@media (max-width: 575.98px) {
    .cf-pill-grid {
        grid-template-columns: 1fr;
    }

    .cf-pill-option-body {
        padding: 0.6rem 0.7rem;
        min-height: 40px;
    }

    .cf-pill-label {
        font-size: 0.86rem;
    }

    .app-topbar-inner {
        align-items: flex-start;
        flex-direction: column;
    }

    .theme-switcher-wrap {
        width: 100%;
    }

    .theme-switcher {
        width: 100%;
    }
}

/* ===== People directory themed layout ===== */
.people-dir-hero,
.people-dir-filter,
.people-dir-card {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    border-radius: 1.25rem;
}

.people-dir-hero {
    overflow: hidden;
}

.people-dir-hero__accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-danger), var(--bs-warning));
}

.people-dir-hero__body {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.5rem;
}

.people-dir-kicker {
    color: var(--primary, var(--bs-primary));
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.people-dir-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.75rem, 2.2vw, 2.25rem);
    font-weight: 700;
    letter-spacing: -0.03em;
}

.people-dir-subtitle {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    max-width: 42rem;
}

.people-dir-actions,
.people-dir-card__tools,
.people-dir-row-actions,
.people-dir-filter__buttons,
.people-dir-quickfilters {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.people-dir-filter {
    padding: 1.25rem;
}

.people-dir-filter__grid {
    display: grid;
    gap: 1rem;
    align-items: end;
    grid-template-columns: minmax(18rem, 1.5fr) repeat(3, minmax(10rem, 0.8fr)) auto;
}

.people-dir-field {
    display: grid;
    gap: 0.35rem;
}

.people-dir-control {
    background-color: var(--input-bg, var(--surface, var(--bs-body-bg))) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
    border-color: var(--input-border, var(--border-color, var(--bs-border-color))) !important;
    border-radius: 0.85rem !important;
    min-height: 2.75rem;
}

.people-dir-control:focus {
    border-color: var(--primary, var(--bs-primary)) !important;
    box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--primary, var(--bs-primary)) 20%, transparent) !important;
}

.people-dir-filter__buttons {
    min-width: 10rem;
}

.people-dir-quickfilters {
    margin-top: 1rem;
}

.people-dir-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    min-height: 1.9rem;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    border: 1px solid var(--pill-border, var(--border-color, var(--bs-border-color)));
    background: var(--pill-bg, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.78rem;
    font-weight: 600;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
}

.people-dir-pill:hover,
.people-dir-pill.is-selected {
    color: var(--pill-selected-text, var(--primary, var(--bs-primary)));
    border-color: var(--pill-selected-border, var(--primary, var(--bs-primary)));
    background: var(--pill-selected-bg, var(--primary-soft, var(--surface-soft)));
    text-decoration: none;
}

.people-dir-pill--blue {
    background: color-mix(in srgb, var(--bs-info) 25%, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
}

.people-dir-pill--green {
    background: color-mix(in srgb, var(--bs-success) 26%, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
}

.people-dir-pill--gold {
    background: color-mix(in srgb, var(--bs-warning) 32%, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
}

.people-dir-pill--coral {
    background: color-mix(in srgb, var(--bs-danger) 24%, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
}

.people-dir-card__header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.25rem;
    border-bottom: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
}

.people-dir-section-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.people-dir-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.25rem;
    min-height: 2.25rem;
    padding: 0.25rem 0.7rem;
    border-radius: 999px;
    background: var(--primary-soft, var(--surface-soft));
    color: var(--primary, var(--bs-primary));
    font-weight: 700;
}

.people-dir-table-wrap {
    border-radius: 0 0 1.25rem 1.25rem;
}

.people-dir-table {
    color: var(--text-main, var(--bs-body-color));
    min-width: 980px;
}

.people-dir-table th,
.people-dir-table td {
    padding: 0.95rem 1.25rem;
    border-color: var(--table-border, var(--border-color, var(--bs-border-color))) !important;
    vertical-align: middle;
}

.people-dir-table tbody tr:hover td {
    background: var(--table-row-hover, var(--surface-soft)) !important;
}

.people-dir-id {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-variant-numeric: tabular-nums;
}

.people-dir-person {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 14rem;
}

.people-dir-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--bs-info) 30%, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    flex: 0 0 auto;
}

.people-dir-name {
    color: var(--text-main, var(--bs-body-color)) !important;
    font-weight: 700;
}

.people-dir-contact {
    min-width: 13rem;
    color: var(--text-main, var(--bs-body-color));
}

.people-dir-icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 0.7rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    border: 1px solid transparent;
    text-decoration: none;
}

.people-dir-icon-btn:hover {
    color: var(--primary, var(--bs-primary));
    border-color: var(--pill-border-hover, var(--border-color, var(--bs-border-color)));
    background: var(--pill-bg-hover, var(--surface-soft));
    text-decoration: none;
}

.theme-action-primary,
.btn-primary.theme-action-primary {
    background-color: var(--primary, var(--bs-primary)) !important;
    border-color: var(--primary, var(--bs-primary)) !important;
    color: #fff !important;
    font-weight: 400 !important;
}

.theme-action-primary:hover,
.btn-primary.theme-action-primary:hover {
    background-color: var(--primary-hover, var(--primary, var(--bs-primary))) !important;
    border-color: var(--primary-hover, var(--primary, var(--bs-primary))) !important;
}

.theme-action-outline,
.btn-outline-secondary.theme-action-outline {
    background: var(--btn-outline-neutral-bg, transparent) !important;
    border-color: var(--btn-outline-neutral-border, var(--border-color, var(--bs-border-color))) !important;
    color: var(--btn-outline-neutral-text, var(--text-main, var(--bs-body-color))) !important;
    font-weight: 400 !important;
}

.theme-action-outline:hover,
.btn-outline-secondary.theme-action-outline:hover {
    background: var(--btn-outline-neutral-hover-bg, var(--surface-soft)) !important;
    color: var(--btn-outline-neutral-hover-text, var(--text-main, var(--bs-body-color))) !important;
}

@media (max-width: 1199.98px) {
    .people-dir-filter__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .people-dir-field--search,
    .people-dir-filter__buttons {
        grid-column: 1 / -1;
    }
}

@media (max-width: 575.98px) {
    .people-dir-hero__body,
    .people-dir-filter,
    .people-dir-card__header {
        padding: 1rem;
    }

    .people-dir-filter__grid {
        grid-template-columns: 1fr;
    }

    .people-dir-field--search,
    .people-dir-filter__buttons {
        grid-column: auto;
    }
}

/* ===== Person profile themed layout ===== */
.person-profile-page {
    color: var(--text-main, var(--bs-body-color));
}

.profile-shell,
.profile-panel {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    border-radius: 1.25rem;
}

.profile-hero {
    overflow: hidden;
}

.profile-hero-accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-danger), var(--bs-warning));
}

.profile-hero-body {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.5rem;
}

.profile-identity-block {
    min-width: 0;
}

.profile-title-line,
.profile-household-line,
.profile-header-actions,
.profile-access-actions,
.profile-heading-with-dot,
.profile-heading-with-bar,
.profile-section-heading-row,
.profile-mini-pills {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.profile-section-heading-row {
    justify-content: space-between;
}

.profile-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.75rem, 2.4vw, 2.45rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.035em;
}

.profile-subtitle,
.profile-muted,
.profile-notes-text {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.profile-subtitle {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-top: 0.45rem;
    font-size: 0.92rem;
}

.profile-household-line {
    margin-top: 0.65rem;
    font-size: 0.92rem;
}

.profile-access-bar {
    padding: 1.25rem;
}

.profile-access-grid {
    display: grid;
    gap: 0.85rem 1rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.profile-access-item,
.profile-info-row {
    display: flex;
    align-items: baseline;
    gap: 0.4rem;
    min-width: 0;
}

.profile-access-empty {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.profile-panel {
    padding: 1.5rem;
}

.profile-section-title,
.profile-subsection-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.profile-subsection-title {
    font-size: 0.82rem;
}

.profile-heading-dot {
    width: 0.75rem;
    height: 0.75rem;
    border-radius: 999px;
    background: var(--bs-info, var(--primary, var(--bs-primary)));
    flex: 0 0 auto;
}

.profile-title-accent {
    width: 6rem;
    height: 0.25rem;
    border-radius: 999px;
    background: var(--bs-warning, var(--primary-soft, var(--surface-soft)));
}

.profile-side-accent {
    width: 0.42rem;
    height: 2rem;
    border-radius: 999px;
    background: var(--bs-info, var(--primary, var(--bs-primary)));
    flex: 0 0 auto;
}

.profile-side-accent-coral {
    background: var(--bs-danger, var(--primary, var(--bs-primary)));
}

.profile-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem 1.75rem;
}

.profile-info-stack {
    display: grid;
    gap: 0.85rem;
}

.profile-task-list {
    display: grid;
    gap: 0.8rem;
}

.profile-task-card {
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
    padding: 0.9rem 1rem;
    background: var(--surface-soft, var(--surface, var(--bs-body-bg)));
}

.profile-task-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
}

.profile-task-title {
    font-weight: 600;
}

.profile-task-date {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.84rem;
    white-space: nowrap;
}

.profile-task-meta {
    margin-top: 0.4rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.9rem;
    line-height: 1.45;
}

.profile-info-row-wide {
    grid-column: 1 / -1;
}

.profile-info-label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.88rem;
    font-weight: 500;
    white-space: nowrap;
}

.profile-info-value,
.profile-family-name {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 500;
    min-width: 0;
    overflow-wrap: anywhere;
}

.profile-icon-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 0.7rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color))) !important;
    border: 1px solid transparent;
    text-decoration: none !important;
    line-height: 1;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.profile-icon-action-sm {
    width: 1.65rem;
    height: 1.65rem;
    border-radius: 0.55rem;
    font-size: 0.84rem;
}

.profile-icon-action:hover {
    color: var(--primary, var(--bs-primary)) !important;
    border-color: var(--pill-border-hover, var(--border-color, var(--bs-border-color)));
    background: var(--pill-bg-hover, var(--surface-soft));
}

.profile-status-pill,
.profile-mini-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1.75rem;
    padding: 0.32rem 0.7rem;
    border-radius: 999px;
    border: 1px solid var(--pill-border, var(--border-color, var(--bs-border-color)));
    background: var(--pill-bg, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.76rem;
    font-weight: 500;
    line-height: 1;
    white-space: nowrap;
}

.profile-status-success {
    background: color-mix(in srgb, var(--bs-success) 28%, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
    border-color: color-mix(in srgb, var(--bs-success) 45%, var(--card-border, var(--bs-border-color)));
}

.profile-status-warning {
    background: color-mix(in srgb, var(--bs-warning) 34%, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
    border-color: color-mix(in srgb, var(--bs-warning) 45%, var(--card-border, var(--bs-border-color)));
}

.profile-status-info,
.profile-status-soft {
    background: var(--primary-soft, var(--surface-soft));
    color: var(--primary, var(--bs-primary));
    border-color: var(--pill-selected-border, var(--primary, var(--bs-primary)));
}

.profile-status-muted {
    background: var(--surface-muted, var(--surface-soft));
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.profile-notes-text {
    font-size: 0.95rem;
    line-height: 1.65;
    white-space: pre-wrap;
}

.profile-table-wrap,
.profile-family-table {
    overflow: hidden;
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
}

.profile-table th,
.profile-table td {
    padding: 0.85rem 1rem;
    border-color: var(--table-border, var(--border-color, var(--bs-border-color))) !important;
}

.profile-table thead th {
    background: var(--table-head-bg, var(--surface-soft)) !important;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color))) !important;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.profile-family-table {
    display: grid;
}

.profile-family-row {
    display: grid;
    grid-template-columns: 3rem minmax(7rem, 1fr) minmax(4.5rem, 0.7fr) 3rem 4.5rem;
    gap: 0.55rem;
    align-items: center;
    padding: 0.82rem 0.95rem;
    border-top: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.9rem;
}

.profile-family-row:first-child {
    border-top: 0;
}

.profile-family-head {
    background: var(--table-head-bg, var(--surface-soft));
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.profile-family-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.2rem;
}

.profile-family-empty {
    padding: 1rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    text-align: center;
}

.person-profile-page .btn-primary,
.person-profile-page .btn-primary.theme-action-primary {
    background-color: var(--primary, var(--bs-primary)) !important;
    border-color: var(--primary, var(--bs-primary)) !important;
    color: #fff !important;
    font-weight: 400 !important;
}

.person-profile-page .btn-primary:hover,
.person-profile-page .btn-primary.theme-action-primary:hover {
    background-color: var(--primary-hover, var(--primary, var(--bs-primary))) !important;
    border-color: var(--primary-hover, var(--primary, var(--bs-primary))) !important;
}

.person-profile-page .btn-outline-secondary {
    background: var(--btn-outline-neutral-bg, transparent) !important;
    border-color: var(--btn-outline-neutral-border, var(--border-color, var(--bs-border-color))) !important;
    color: var(--btn-outline-neutral-text, var(--text-main, var(--bs-body-color))) !important;
    font-weight: 400 !important;
}

.person-profile-page .btn-outline-secondary:hover {
    background: var(--btn-outline-neutral-hover-bg, var(--surface-soft)) !important;
    color: var(--btn-outline-neutral-hover-text, var(--text-main, var(--bs-body-color))) !important;
}

.person-profile-page .btn-outline-danger {
    background: transparent !important;
    border-color: color-mix(in srgb, var(--bs-danger) 45%, var(--border-color, var(--bs-border-color))) !important;
    color: var(--bs-danger) !important;
    font-weight: 400 !important;
}

.person-profile-page .btn-outline-danger:hover {
    background: color-mix(in srgb, var(--bs-danger) 16%, var(--surface, var(--bs-body-bg))) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
}

@media (max-width: 1199.98px) {
    .profile-access-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .profile-hero-body,
    .profile-access-bar,
    .profile-panel {
        padding: 1rem;
    }

    .profile-info-grid,
    .profile-access-grid {
        grid-template-columns: 1fr;
    }

    .profile-family-row {
        grid-template-columns: 2.5rem minmax(6rem, 1fr) minmax(4rem, 0.7fr) 2.5rem 4rem;
        padding-left: 0.75rem;
        padding-right: 0.75rem;
        font-size: 0.84rem;
    }
}


/* ===== Event detail themed layout ===== */
.event-detail-page {
    color: var(--text-main, var(--bs-body-color));
}

.event-detail-hero,
.event-detail-panel,
.event-detail-metric {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    border-radius: 1.25rem;
}

.event-detail-hero {
    overflow: hidden;
}

.event-detail-hero__accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-danger), var(--bs-warning));
}

.event-detail-hero__body {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.5rem;
}

.event-detail-identity {
    min-width: 0;
}

.event-detail-title-row,
.event-detail-actions,
.event-detail-row-actions,
.event-detail-section-row,
.event-detail-heading-with-bar,
.event-detail-category-title {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.event-detail-action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
}

.event-detail-section-row {
    justify-content: space-between;
}

.event-detail-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.75rem, 2.4vw, 2.45rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.035em;
}

.event-detail-subtitle,
.event-detail-muted,
.event-detail-note-text {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color))) !important;
}

.event-detail-subtitle {
    margin-top: 0.55rem;
    max-width: 46rem;
    font-size: 0.95rem;
    line-height: 1.6;
}

.event-detail-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.event-detail-metric {
    padding: 1.15rem;
    position: relative;
    overflow: hidden;
}

.event-detail-metric::after {
    content: "";
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 0.72rem;
    height: 0.72rem;
    border-radius: 999px;
    background: var(--primary, var(--bs-primary));
}

.event-detail-metric--blue::after { background: var(--bs-info, var(--primary, var(--bs-primary))); }
.event-detail-metric--green::after { background: var(--bs-success, var(--primary, var(--bs-primary))); }
.event-detail-metric--gold::after { background: var(--bs-warning, var(--primary, var(--bs-primary))); }
.event-detail-metric--coral::after { background: var(--bs-danger, var(--primary, var(--bs-primary))); }

.event-detail-metric__label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 0.55rem;
}

.event-detail-metric__value {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.event-detail-panel {
    padding: 1.5rem;
}

.event-detail-section-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.event-detail-title-accent {
    width: 6rem;
    height: 0.25rem;
    border-radius: 999px;
    background: var(--bs-warning, var(--primary-soft, var(--surface-soft)));
}

.event-detail-side-accent {
    width: 0.42rem;
    height: 2rem;
    border-radius: 999px;
    background: var(--bs-info, var(--primary, var(--bs-primary)));
    flex: 0 0 auto;
}

.event-detail-side-accent-coral { background: var(--bs-danger, var(--primary, var(--bs-primary))); }
.event-detail-side-accent-green { background: var(--bs-success, var(--primary, var(--bs-primary))); }

.event-detail-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem 1.75rem;
}

.event-detail-info-stack {
    display: grid;
    gap: 0.85rem;
}

.event-detail-info-row {
    display: flex;
    align-items: baseline;
    gap: 0.4rem;
    min-width: 0;
}

.event-detail-label,
.event-detail-note-label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.88rem;
    font-weight: 500;
    white-space: nowrap;
}

.event-detail-note-label {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 0.45rem;
}

.event-detail-value,
.event-detail-visitor-name {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 500;
    min-width: 0;
    overflow-wrap: anywhere;
}

.event-detail-note-box,
.event-detail-category-card,
.event-detail-empty {
    background: var(--surface-soft, var(--surface-muted, var(--bs-light)));
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
}

.event-detail-note-box,
.event-detail-category-card {
    padding: 1rem;
}

.event-detail-empty {
    padding: 2rem 1rem;
    text-align: center;
}

.event-detail-table-wrap {
    overflow-x: auto;
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
}

.event-detail-table {
    min-width: 860px;
    color: var(--text-main, var(--bs-body-color));
}

.event-detail-table th,
.event-detail-table td {
    padding: 0.95rem 1rem;
    border-color: var(--table-border, var(--border-color, var(--bs-border-color))) !important;
    vertical-align: middle;
}

.event-detail-table tbody tr:hover td {
    background: var(--table-row-hover, var(--surface-soft)) !important;
}

.event-detail-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1.75rem;
    padding: 0.34rem 0.72rem;
    border-radius: 999px;
    border: 1px solid var(--pill-border, var(--border-color, var(--bs-border-color)));
    color: var(--primary, var(--bs-primary));
    font-size: 0.76rem;
    font-weight: 600;
    line-height: 1;
    white-space: nowrap;
}

.event-detail-pill--blue {
    background: color-mix(in srgb, var(--bs-info) 25%, var(--surface, var(--bs-body-bg)));
}

.event-detail-pill--green {
    background: color-mix(in srgb, var(--bs-success) 26%, var(--surface, var(--bs-body-bg)));
}

.event-detail-pill--gold {
    background: color-mix(in srgb, var(--bs-warning) 32%, var(--surface, var(--bs-body-bg)));
}

.event-detail-pill--coral {
    background: color-mix(in srgb, var(--bs-danger) 24%, var(--surface, var(--bs-body-bg)));
}

.event-detail-category-dot {
    width: 0.8rem;
    height: 0.8rem;
    border-radius: 999px;
    flex: 0 0 auto;
}

@media (max-width: 1199.98px) {
    .event-detail-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .event-detail-hero__body,
    .event-detail-panel {
        padding: 1rem;
    }

    .event-detail-metrics,
    .event-detail-info-grid {
        grid-template-columns: 1fr;
    }

    .event-detail-actions,
    .event-detail-actions .btn,
    .event-detail-row-actions,
    .event-detail-row-actions .btn,
    .event-detail-row-actions form,
    .event-detail-row-actions form .btn {
        width: 100%;
    }
}

/* ===== Master calendar themed layout ===== */
.master-calendar-page {
    color: var(--text-main, var(--bs-body-color));
}

.mc-hero,
.mc-filter,
.mc-card,
.mc-side-card {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    border-radius: 1.25rem;
}

.mc-hero { overflow: hidden; }
.mc-hero__accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-danger), var(--bs-warning));
}
.mc-hero__body,
.mc-card__header,
.mc-actions,
.mc-card__tools,
.mc-viewbar,
.mc-filter__actions,
.mc-filter__toggles,
.mc-legend-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem;
}
.mc-hero__body,
.mc-card__header { justify-content: space-between; padding: 1.5rem; }
.mc-kicker {
    color: var(--primary, var(--bs-primary));
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.mc-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.75rem, 2.2vw, 2.3rem);
    font-weight: 700;
    letter-spacing: -0.03em;
}
.mc-subtitle { color: var(--text-muted, var(--muted, var(--bs-secondary-color))); max-width: 48rem; }
.mc-viewbar { border-top: 1px solid var(--table-border, var(--border-color)); background: var(--table-head-bg, var(--surface-soft)); padding: 1rem 1.5rem; }
.mc-viewbar-label { color: var(--text-muted, var(--muted)); font-weight: 600; }
.mc-view-pill {
    border: 1px solid var(--pill-border, var(--border-color));
    background: var(--pill-bg, var(--surface));
    color: var(--btn-outline-neutral-text, var(--text-main)) !important;
    border-radius: 999px;
    padding: 0.45rem 1rem;
    text-decoration: none !important;
    font-size: 0.9rem;
    font-weight: 600;
}
.mc-view-pill:hover,
.mc-view-pill.is-selected {
    background: var(--pill-selected-bg, var(--primary-soft));
    border-color: var(--pill-selected-border, var(--primary));
    color: var(--pill-selected-text, var(--primary)) !important;
}
.mc-filter { padding: 1.25rem; }
.mc-filter__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(10rem, 1fr)) auto;
    gap: 1rem;
    align-items: end;
}
.mc-filter__toggles { grid-column: 1 / -1; }
.mc-toggle,
.mc-legend {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    border: 1px solid var(--pill-border, var(--border-color));
    background: var(--pill-bg, var(--surface));
    color: var(--text-main, var(--bs-body-color));
    border-radius: 999px;
    padding: 0.42rem 0.75rem;
    font-size: 0.86rem;
    font-weight: 600;
}
.mc-toggle .form-check-input { margin: 0; }
.mc-field { display: grid; gap: 0.35rem; }
.mc-control {
    background-color: var(--input-bg, var(--surface)) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
    border-color: var(--input-border, var(--border-color)) !important;
    border-radius: 0.85rem !important;
    min-height: 2.75rem;
}
.mc-legend-row { margin-top: 1rem; }
.mc-legend-dot { width: 0.65rem; height: 0.65rem; border-radius: 999px; }
.mc-legend-dot-event { background: var(--bs-info); }
.mc-legend-dot-class { background: var(--bs-success); }
.mc-legend-dot-selected { background: var(--bs-warning); }
.mc-legend-dot-today { background: var(--bs-danger); }
.mc-section-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}
.mc-month-head,
.mc-month-grid,
.mc-week-grid { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); }
.mc-month-head,
.mc-week-head { background: var(--table-head-bg, var(--surface-soft)); color: var(--text-muted, var(--muted)); font-size: 0.76rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; }
.mc-month-head > div,
.mc-week-head-cell { padding: 0.85rem 1rem; border-right: 1px solid var(--table-border, var(--border-color)); }
.mc-month-head > div:last-child,
.mc-week-head-cell:last-child { border-right: 0; }
.mc-day {
    min-height: 8.7rem;
    padding: 0.65rem;
    border-right: 1px solid var(--table-border, var(--border-color));
    border-top: 1px solid var(--table-border, var(--border-color));
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color)) !important;
    text-decoration: none !important;
    transition: background 0.18s ease, box-shadow 0.18s ease;
}
.mc-day:hover { background: var(--table-row-hover, var(--surface-soft)); }
.mc-day.is-outside { opacity: 0.64; background: color-mix(in srgb, var(--surface, #fff) 88%, var(--text-muted, #888) 3%); }
.mc-day.is-today { background: color-mix(in srgb, var(--bs-danger) 14%, var(--surface, #fff)); }
.mc-day.is-selected { background: color-mix(in srgb, var(--bs-warning) 22%, var(--surface, #fff)); box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--bs-warning) 62%, var(--border-color)); }
.mc-day__header { display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; margin-bottom: 0.45rem; }
.mc-day-number { display: inline-flex; align-items: center; justify-content: center; width: 1.75rem; height: 1.75rem; border-radius: 999px; font-weight: 700; }
.mc-day.is-today .mc-day-number { background: var(--bs-danger); color: var(--primary, #097C87); }
.mc-day.is-selected .mc-day-number { background: var(--bs-warning); color: var(--primary, #097C87); }
.mc-day-count,
.mc-count-pill { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; background: var(--primary-soft, var(--surface-soft)); color: var(--primary, var(--bs-primary)); font-size: 0.75rem; font-weight: 700; padding: 0.15rem 0.5rem; }
.mc-day-list { display: grid; gap: 0.32rem; }
.mc-month-item {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    min-width: 0;
    border-left: 0.32rem solid var(--item-color, var(--bs-info));
    border-radius: 0.55rem;
    padding: 0.28rem 0.42rem;
    background: color-mix(in srgb, var(--item-color, var(--bs-info)) 15%, var(--surface, #fff));
    color: var(--primary, var(--bs-primary));
}
.mc-item-class { --item-color: var(--bs-success); }
.mc-month-time,
.mc-week-time { flex: 0 0 auto; font-size: 0.7rem; font-weight: 700; color: var(--text-muted, var(--muted)); }
.mc-month-title { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 0.78rem; font-weight: 600; }
.mc-day-empty,
.mc-empty-day,
.mc-day-more { color: var(--text-muted, var(--muted)); font-size: 0.82rem; }
.mc-week-wrap { overflow-x: auto; }
.mc-week-wrap > .mc-week-grid { min-width: 1080px; }
.mc-week-head-cell { display: grid; gap: 0.2rem; }
.mc-week-day { min-height: 22rem; border-right: 1px solid var(--table-border, var(--border-color)); border-top: 1px solid var(--table-border, var(--border-color)); padding: 0.8rem; background: var(--surface, var(--bs-body-bg)); }
.mc-week-day.is-today { background: color-mix(in srgb, var(--bs-danger) 10%, var(--surface, #fff)); }
.mc-week-day.is-selected { background: color-mix(in srgb, var(--bs-warning) 18%, var(--surface, #fff)); }
.mc-week-item,
.mc-selected-card,
.mc-list-row {
    display: block;
    color: var(--text-main, var(--bs-body-color)) !important;
    border: 1px solid var(--table-border, var(--border-color));
    border-left: 0.35rem solid var(--item-color, var(--bs-info));
    border-radius: 0.9rem;
    background: var(--surface, var(--bs-body-bg));
    padding: 0.85rem;
    text-decoration: none !important;
}
.mc-week-item + .mc-week-item { margin-top: 0.75rem; }
.mc-week-item:hover,
.mc-selected-card:hover,
.mc-list-row:hover { background: var(--table-row-hover, var(--surface-soft)); }
.mc-week-item__top,
.mc-selected-card__top { display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; margin-bottom: 0.45rem; }
.mc-kind-pill { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; padding: 0.25rem 0.6rem; font-size: 0.7rem; font-weight: 700; }
.mc-kind-event { background: color-mix(in srgb, var(--bs-info) 24%, var(--surface, #fff)); color: var(--primary, var(--bs-primary)); }
.mc-kind-class { background: color-mix(in srgb, var(--bs-success) 26%, var(--surface, #fff)); color: var(--primary, var(--bs-primary)); }
.mc-week-title,
.mc-selected-title,
.mc-list-title { font-weight: 700; color: var(--text-main, var(--bs-body-color)); }
.mc-week-meta { color: var(--text-muted, var(--muted)); font-size: 0.78rem; margin-top: 0.2rem; }
.mc-open-link { display: inline-flex; margin-top: 0.65rem; border: 1px solid var(--pill-border, var(--border-color)); border-radius: 0.65rem; padding: 0.35rem 0.65rem; color: var(--btn-outline-neutral-text, var(--text-main)); font-size: 0.76rem; font-weight: 600; }
.mc-side-card { padding: 1.25rem; }
.mc-side-heading { display: flex; align-items: flex-start; gap: 0.75rem; margin-bottom: 1rem; }
.mc-side-accent { display: inline-block; width: 0.42rem; height: 2rem; border-radius: 999px; }
.mc-side-accent-gold { background: var(--bs-warning); }
.mc-side-accent-blue { background: var(--bs-info); }
.mc-selected-list,
.mc-info-stack,
.mc-list-view { display: grid; gap: 0.8rem; }
.mc-list-row { display: grid; grid-template-columns: 5rem minmax(0, 1fr) auto; align-items: center; gap: 1rem; }
.mc-list-date { color: var(--text-muted, var(--muted)); font-weight: 700; }
@media (max-width: 1199.98px) {
    .mc-filter__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .mc-filter__toggles,
    .mc-filter__actions { grid-column: 1 / -1; }
    .mc-month-head,
    .mc-month-grid { min-width: 960px; }
    .mc-card { overflow-x: auto; }
}
@media (max-width: 575.98px) {
    .mc-hero__body,
    .mc-card__header,
    .mc-filter { padding: 1rem; }
    .mc-filter__grid { grid-template-columns: 1fr; }
    .mc-filter__toggles,
    .mc-filter__actions { grid-column: auto; }
    .mc-list-row { grid-template-columns: 1fr; }
}



/* ===== Household directory/profile themed layout ===== */
.household-theme-page,
.household-profile-page {
    color: var(--text-main, var(--bs-body-color));
}

.household-dir-hero,
.household-dir-filter,
.household-dir-card,
.household-profile-shell,
.household-profile-panel {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    border-radius: 1.25rem;
}

.household-dir-hero,
.household-profile-hero {
    overflow: hidden;
}

.household-dir-hero__accent,
.household-profile-hero__accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-danger), var(--bs-warning));
}

.household-dir-hero__body,
.household-profile-hero__body {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.5rem;
}

.household-dir-kicker {
    color: var(--primary, var(--bs-primary));
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.household-dir-title,
.household-profile-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.75rem, 2.2vw, 2.35rem);
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.1;
}

.household-dir-subtitle,
.household-profile-subtitle,
.household-profile-muted,
.household-profile-notes,
.household-profile-preline {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.household-dir-actions,
.household-dir-card__tools,
.household-dir-row-actions,
.household-dir-filter__buttons,
.household-dir-quickfilters,
.household-profile-actions,
.household-profile-title-line,
.household-profile-subtitle,
.household-profile-heading-row,
.household-profile-heading-with-bar,
.household-profile-member-actions,
.household-members-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.household-dir-filter,
.household-profile-panel {
    padding: 1.25rem;
}

.household-dir-filter__grid {
    display: grid;
    gap: 1rem;
    align-items: end;
    grid-template-columns: minmax(18rem, 1.5fr) repeat(2, minmax(10rem, 0.8fr)) auto;
}

.household-dir-field {
    display: grid;
    gap: 0.35rem;
}

.household-dir-control {
    background-color: var(--input-bg, var(--surface, var(--bs-body-bg))) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
    border-color: var(--input-border, var(--border-color, var(--bs-border-color))) !important;
    border-radius: 0.85rem !important;
    min-height: 2.75rem;
}

.household-dir-quickfilters {
    margin-top: 1rem;
}

.household-dir-pill,
.household-profile-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    min-height: 1.9rem;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    border: 1px solid var(--pill-border, var(--border-color, var(--bs-border-color)));
    background: var(--pill-bg, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.78rem;
    font-weight: 600;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
}

.household-dir-pill:hover,
.household-dir-pill.is-selected {
    color: var(--pill-selected-text, var(--primary, var(--bs-primary)));
    border-color: var(--pill-selected-border, var(--primary, var(--bs-primary)));
    background: var(--pill-selected-bg, var(--primary-soft, var(--surface-soft)));
    text-decoration: none;
}

.household-dir-pill--blue,
.household-profile-pill--blue { background: color-mix(in srgb, var(--bs-info) 25%, var(--surface, var(--bs-body-bg))); color: var(--primary, var(--bs-primary)); }
.household-dir-pill--green,
.household-profile-pill--green { background: color-mix(in srgb, var(--bs-success) 26%, var(--surface, var(--bs-body-bg))); color: var(--primary, var(--bs-primary)); }
.household-dir-pill--gold,
.household-profile-pill--gold { background: color-mix(in srgb, var(--bs-warning) 32%, var(--surface, var(--bs-body-bg))); color: var(--primary, var(--bs-primary)); }
.household-dir-pill--coral,
.household-profile-pill--coral { background: color-mix(in srgb, var(--bs-danger) 24%, var(--surface, var(--bs-body-bg))); color: var(--primary, var(--bs-primary)); }

.household-dir-card__header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.25rem;
    border-bottom: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
}

.household-dir-section-title,
.household-profile-section-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.household-dir-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.25rem;
    min-height: 2.25rem;
    padding: 0.25rem 0.7rem;
    border-radius: 999px;
    background: var(--primary-soft, var(--surface-soft));
    color: var(--primary, var(--bs-primary));
    font-weight: 700;
}

.household-dir-table {
    color: var(--text-main, var(--bs-body-color));
    min-width: 920px;
}

.household-dir-table th,
.household-dir-table td {
    padding: 0.95rem 1.25rem;
    border-color: var(--table-border, var(--border-color, var(--bs-border-color))) !important;
    vertical-align: middle;
}

.household-dir-table tbody tr:hover td {
    background: var(--table-row-hover, var(--surface-soft)) !important;
}

.household-dir-id {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-variant-numeric: tabular-nums;
}

.household-dir-family {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-width: 14rem;
}

.household-dir-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--bs-info) 30%, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
    font-size: 0.9rem;
    font-weight: 700;
    flex: 0 0 auto;
}

.household-dir-name,
.household-member-name {
    color: var(--text-main, var(--bs-body-color)) !important;
    font-weight: 700;
}

.household-dir-contact {
    min-width: 13rem;
    color: var(--text-main, var(--bs-body-color));
}

.household-dir-icon-btn,
.household-profile-icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 0.7rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color))) !important;
    border: 1px solid transparent;
    text-decoration: none !important;
}

.household-dir-icon-btn:hover,
.household-profile-icon-btn:hover {
    color: var(--primary, var(--bs-primary)) !important;
    border-color: var(--pill-border-hover, var(--border-color, var(--bs-border-color)));
    background: var(--pill-bg-hover, var(--surface-soft));
}

.household-profile-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem 1.75rem;
}

.household-profile-info-row {
    display: flex;
    align-items: baseline;
    gap: 0.4rem;
    min-width: 0;
}

.household-profile-info-row-wide {
    grid-column: 1 / -1;
}

.household-profile-info-label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.88rem;
    font-weight: 500;
    white-space: nowrap;
}

.household-profile-info-value {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 500;
    min-width: 0;
    overflow-wrap: anywhere;
}

.household-profile-title-accent {
    width: 6rem;
    height: 0.25rem;
    border-radius: 999px;
    background: var(--bs-warning, var(--primary-soft));
}

.household-profile-side-accent {
    width: 0.42rem;
    height: 2rem;
    border-radius: 999px;
    background: var(--bs-info, var(--primary));
    flex: 0 0 auto;
}

.household-profile-side-accent-coral {
    background: var(--bs-danger, var(--primary));
}

.household-profile-preline,
.household-profile-notes {
    white-space: pre-line;
}

.household-members-table-wrap {
    overflow-x: auto;
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
}

.household-members-table {
    min-width: 860px;
}

.household-members-row {
    display: grid;
    grid-template-columns: 56px minmax(180px, 1.4fr) 90px 64px 130px 100px 82px;
    gap: 0.65rem;
    align-items: center;
    padding: 0.85rem 1rem;
    border-top: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    color: var(--text-main, var(--bs-body-color));
}

.household-members-row:first-child {
    border-top: 0;
}

.household-members-head {
    background: var(--table-head-bg, var(--surface-soft));
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.household-members-empty {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    padding: 1.25rem;
    text-align: center;
}

@media (max-width: 1199.98px) {
    .household-dir-filter__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .household-dir-field--search,
    .household-dir-filter__buttons {
        grid-column: 1 / -1;
    }
}

@media (max-width: 575.98px) {
    .household-dir-hero__body,
    .household-profile-hero__body,
    .household-dir-filter,
    .household-dir-card__header,
    .household-profile-panel {
        padding: 1rem;
    }
    .household-dir-filter__grid,
    .household-profile-info-grid {
        grid-template-columns: 1fr;
    }
    .household-profile-info-row-wide,
    .household-dir-field--search,
    .household-dir-filter__buttons {
        grid-column: auto;
    }
}


/* ===== Master calendar app themed layout ===== */
.calendar-hero,
.calendar-toolbar-card,
.calendar-surface,
.calendar-side-card {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    border-radius: 1.25rem;
}

.calendar-hero {
    overflow: hidden;
}

.calendar-hero__accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-danger), var(--bs-warning));
}

.calendar-hero__body {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1.5rem;
}

.calendar-hero__kicker {
    color: var(--primary, var(--bs-primary));
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.calendar-hero__title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.75rem, 2.2vw, 2.35rem);
    font-weight: 700;
    letter-spacing: -0.03em;
}

.calendar-hero__subtitle {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    max-width: 42rem;
}

.calendar-hero__actions,
.calendar-view-tabs,
.calendar-toolbar-actions,
.calendar-source-pills,
.calendar-nav {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.calendar-view-tabs {
    border-top: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--table-head-bg, var(--surface-soft));
    padding: 1rem 1.5rem;
}

.calendar-view-tabs__label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.88rem;
    font-weight: 700;
}

.calendar-view-tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2rem;
    padding: 0.35rem 0.95rem;
    border-radius: 999px;
    border: 1px solid var(--pill-border, var(--border-color, var(--bs-border-color)));
    background: var(--pill-bg, var(--surface, var(--bs-body-bg)));
    color: var(--btn-outline-neutral-text, var(--text-main, var(--bs-body-color)));
    text-decoration: none;
    font-size: 0.86rem;
    font-weight: 600;
}

.calendar-view-tab:hover,
.calendar-view-tab.is-selected {
    color: var(--pill-selected-text, var(--primary, var(--bs-primary)));
    border-color: var(--pill-selected-border, var(--primary, var(--bs-primary)));
    background: var(--pill-selected-bg, var(--primary-soft, var(--surface-soft)));
    text-decoration: none;
}

.calendar-toolbar-card__body {
    padding: 1.25rem;
}

.calendar-toolbar-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr)) auto;
    gap: 1rem;
    align-items: end;
}

.calendar-source-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.55rem 0.8rem;
    border: 1px solid var(--pill-border, var(--border-color, var(--bs-border-color)));
    border-radius: 999px;
    background: var(--pill-bg, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
}

.calendar-source-pill .swatch {
    width: 0.8rem;
    height: 0.8rem;
    border-radius: 999px;
    display: inline-block;
}

.calendar-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 1rem;
}

.calendar-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.8rem;
    flex-wrap: wrap;
    padding: 1.25rem 1.25rem 0;
}

.calendar-head-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.2rem;
    font-weight: 700;
    margin: 0;
}

.calendar-grid-weekdays,
.calendar-month-row {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.75rem;
}

.calendar-grid-weekdays {
    padding: 0 1.25rem;
    margin: 1rem 0 0.5rem;
}

.calendar-weekday-label {
    padding: 0.15rem 0.5rem;
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-weight: 800;
}

.calendar-month-wrap,
.calendar-week-wrap,
.calendar-list-wrap {
    padding: 0 1.25rem 1.25rem;
}

.calendar-day {
    position: relative;
    display: block;
    min-height: 10.5rem;
    cursor: pointer;
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
    padding: 0.8rem;
    background: var(--surface-strong, var(--surface, var(--bs-body-bg)));
    text-decoration: none;
    color: inherit;
    transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.calendar-day:hover {
    border-color: var(--primary, var(--bs-primary));
    box-shadow: 0 0.55rem 1.15rem rgba(0,0,0,.10);
    transform: translateY(-1px);
}

.calendar-day.is-outside {
    opacity: 0.72;
    background: color-mix(in srgb, var(--surface-muted, var(--surface, #fff)) 72%, transparent);
}

.calendar-day.is-today {
    border-color: color-mix(in srgb, var(--bs-danger) 55%, var(--primary, var(--bs-primary)));
    background: color-mix(in srgb, var(--bs-danger) 10%, var(--surface-strong, var(--surface, var(--bs-body-bg))));
}

.calendar-day.is-selected {
    background: color-mix(in srgb, var(--bs-warning) 18%, var(--surface-strong, var(--surface, var(--bs-body-bg))));
    border-color: var(--bs-warning, var(--primary, var(--bs-primary)));
}

.calendar-day-top,
.calendar-day-items {
    position: relative;
    z-index: 2;
}

.calendar-day-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.7rem;
}

.calendar-day-date-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    color: inherit;
    text-decoration: none;
}

.calendar-day-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2rem;
    height: 2rem;
    padding: 0 0.55rem;
    border-radius: 0.75rem;
    background: var(--surface-muted, color-mix(in srgb, var(--surface, #fff) 85%, var(--primary, #0d6efd) 15%));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--border-color, rgba(0,0,0,.08));
    font-size: 1rem;
    font-weight: 800;
}

.calendar-day.is-today .calendar-day-number {
    background: color-mix(in srgb, var(--bs-danger) 22%, var(--surface-strong, #fff));
}

.calendar-day.is-selected .calendar-day-number {
    background: color-mix(in srgb, var(--bs-warning) 28%, var(--surface-strong, #fff));
}

.calendar-day-meta,
.calendar-empty {
    font-size: 0.76rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-weight: 600;
}

.calendar-day-items {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.calendar-item {
    --item-accent: var(--primary, var(--bs-primary));
    --item-surface: color-mix(in srgb, var(--item-accent) 18%, var(--surface-strong, #fff));
    display: flex;
    align-items: stretch;
    gap: 0.55rem;
    border-radius: 0.85rem;
    padding: 0.48rem 0.6rem;
    font-size: 0.79rem;
    line-height: 1.15;
    color: var(--text-main, var(--bs-body-color));
    background: linear-gradient(135deg, var(--item-surface) 0%, color-mix(in srgb, var(--item-accent) 8%, var(--surface-strong, #fff)) 100%);
    border: 1px solid color-mix(in srgb, var(--item-accent) 40%, var(--border-color, rgba(0,0,0,.08)));
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0,0,0,.06);
}

.calendar-item:hover {
    border-color: var(--item-accent);
    box-shadow: 0 8px 18px rgba(0,0,0,.11);
}

.calendar-item.is-link {
    text-decoration: none;
}

.calendar-item-swatch {
    width: 0.38rem;
    align-self: stretch;
    border-radius: 0.5rem;
    flex: 0 0 0.38rem;
    background: var(--item-accent);
}

.calendar-item-main {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
}

.calendar-item-row {
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.calendar-item-time {
    font-weight: 800;
    white-space: nowrap;
    font-size: 0.7rem;
    color: color-mix(in srgb, var(--text-main, var(--bs-body-color)) 88%, var(--item-accent) 12%);
}

.calendar-item-title {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 800;
    color: var(--text-main, var(--bs-body-color));
}

.calendar-item-teachers {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 0.69rem;
    color: color-mix(in srgb, var(--text-main, var(--bs-body-color)) 72%, var(--item-accent) 28%);
    font-weight: 600;
}

.calendar-item-more {
    font-size: 0.74rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    padding-left: 0.2rem;
    font-weight: 700;
}

.calendar-week-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.75rem;
}

.calendar-week-column {
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
    background: var(--surface-strong, var(--surface, var(--bs-body-bg)));
    min-height: 26rem;
    display: flex;
    flex-direction: column;
}

.calendar-week-column.is-today {
    border-color: color-mix(in srgb, var(--bs-danger) 55%, var(--primary, var(--bs-primary)));
    background: color-mix(in srgb, var(--bs-danger) 7%, var(--surface-strong, var(--surface, var(--bs-body-bg))));
}

.calendar-week-column.is-selected {
    background: color-mix(in srgb, var(--bs-warning) 14%, var(--surface-strong, var(--surface, var(--bs-body-bg))));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--bs-warning) 70%, transparent);
}

.calendar-week-heading {
    padding: 0.9rem 0.9rem 0.65rem;
    border-bottom: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--table-head-bg, var(--surface-soft));
    border-top-left-radius: 1rem;
    border-top-right-radius: 1rem;
}

.calendar-week-link {
    text-decoration: none;
    color: inherit;
    display: block;
}

.calendar-week-heading .dow {
    font-size: 0.72rem;
    text-transform: uppercase;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    letter-spacing: 0.08em;
    font-weight: 800;
}

.calendar-week-heading .dom {
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--text-main, var(--bs-body-color));
}

.calendar-week-body {
    padding: 0.8rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.calendar-agenda,
.calendar-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.calendar-side-card + .calendar-side-card {
    margin-top: 1rem;
}

.calendar-agenda-item,
.calendar-list-item {
    display: block;
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    border-left: 0.42rem solid var(--item-accent, var(--primary, var(--bs-primary)));
    border-radius: 0.95rem;
    padding: 0.85rem 0.9rem;
    text-decoration: none;
    color: inherit;
    background: var(--surface-strong, var(--surface, var(--bs-body-bg)));
}

.calendar-agenda-item:hover,
.calendar-list-item:hover {
    border-color: color-mix(in srgb, var(--item-accent, var(--primary, var(--bs-primary))) 42%, var(--table-border, var(--border-color, var(--bs-border-color))));
    border-left-color: var(--item-accent, var(--primary, var(--bs-primary)));
    box-shadow: 0 0.5rem 1rem rgba(0,0,0,.08);
    text-decoration: none;
}

.calendar-list-item {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
}

.calendar-list-item__date {
    text-align: center;
    border-right: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    padding-right: 0.75rem;
}

.calendar-list-item__day {
    font-weight: 800;
    color: var(--text-main, var(--bs-body-color));
}

.calendar-list-item__dow,
.calendar-list-item__meta,
.calendar-list-item__detail {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.82rem;
}

.calendar-list-item__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    align-items: center;
    margin-bottom: 0.25rem;
}

.calendar-list-item__title {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 700;
}

.calendar-list-item__action {
    color: var(--primary, var(--bs-primary));
    font-size: 0.82rem;
    font-weight: 700;
}

.calendar-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    border-radius: 999px;
    padding: 0.22rem 0.6rem;
    font-size: 0.72rem;
    font-weight: 800;
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--surface-muted, var(--surface-soft));
}

.calendar-upcoming-item {
    text-decoration: none;
    color: inherit;
    display: block;
}

.calendar-upcoming-item + .calendar-upcoming-item {
    margin-top: 0.9rem;
}

@media (max-width: 1399.98px) {
    .calendar-toolbar-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .calendar-toolbar-actions { grid-column: 1 / -1; }
}

@media (max-width: 1199.98px) {
    .calendar-shell { grid-template-columns: 1fr; }
}

@media (max-width: 991.98px) {
    .calendar-grid-weekdays,
    .calendar-month-row,
    .calendar-week-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 767.98px) {
    .calendar-toolbar-grid,
    .calendar-grid-weekdays,
    .calendar-month-row,
    .calendar-week-grid { grid-template-columns: 1fr; }
    .calendar-grid-weekdays { display: none; }
    .calendar-list-item { grid-template-columns: 1fr; }
    .calendar-list-item__date { text-align: left; border-right: 0; padding-right: 0; }
}

/* ===== My schedule assignments merged themed layout ===== */
.assignment-page {
    color: var(--text-main, var(--bs-body-color));
}

.assignment-surface,
.assignment-section,
.assignment-side-card {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    border-radius: 1.25rem;
}

.assignment-hero { overflow: hidden; }

.assignment-hero-accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-danger), var(--bs-warning));
}

.assignment-hero-body {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.5rem;
}

.assignment-kicker,
.assignment-section-kicker {
    color: var(--primary, var(--bs-primary));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.assignment-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.75rem, 2.2vw, 2.25rem);
    font-weight: 700;
    letter-spacing: -0.03em;
}

.assignment-subtitle,
.assignment-card-meta,
.assignment-date-inline,
.assignment-empty-text,
.assignment-class-next,
.assignment-empty-small,
.assignment-row-note,
.assignment-section-subtitle,
.assignment-muted-action {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.assignment-actions,
.assignment-filter-buttons,
.assignment-quickfilters,
.assignment-card-topline,
.assignment-section-header,
.assignment-section-badges,
.assignment-side-heading,
.assignment-class-top {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.assignment-metrics-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.assignment-metric-card {
    padding: 1.1rem 1.2rem;
    position: relative;
    overflow: hidden;
}

.assignment-metric-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 0.35rem;
    background: var(--primary, var(--bs-primary));
}

.assignment-metric-card--pending::before { background: var(--bs-warning); }
.assignment-metric-card--approved::before { background: var(--bs-success); }
.assignment-metric-card--week::before { background: var(--bs-info); }
.assignment-metric-card--classes::before { background: var(--bs-danger); }

.assignment-metric-label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.assignment-metric-value {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.55rem;
    font-weight: 700;
    margin-top: 0.35rem;
}

.assignment-filter { padding: 1.25rem; }

.assignment-filter-grid {
    display: grid;
    gap: 1rem;
    align-items: end;
}

.assignment-filter-grid-merged {
    grid-template-columns: minmax(14rem, 1fr) minmax(12rem, 0.7fr) auto;
}

.assignment-filter-field {
    display: grid;
    gap: 0.35rem;
}

.assignment-control {
    background-color: var(--input-bg, var(--surface, var(--bs-body-bg))) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
    border-color: var(--input-border, var(--border-color, var(--bs-border-color))) !important;
    border-radius: 0.85rem !important;
    min-height: 2.75rem;
}

.assignment-quickfilters { margin-top: 1rem; }

.assignment-pill,
.assignment-section-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    min-height: 1.85rem;
    padding: 0.35rem 0.72rem;
    border-radius: 999px;
    border: 1px solid var(--pill-border, var(--border-color, var(--bs-border-color)));
    background: var(--pill-bg, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.76rem;
    font-weight: 650;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
}

.assignment-pill:hover,
.assignment-pill.is-selected {
    color: var(--pill-selected-text, var(--primary, var(--bs-primary)));
    border-color: var(--pill-selected-border, var(--primary, var(--bs-primary)));
    background: var(--pill-selected-bg, var(--primary-soft, var(--surface-soft)));
    text-decoration: none;
}

.assignment-pill-blue {
    background: color-mix(in srgb, var(--bs-info) 24%, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
}

.assignment-pill-green {
    background: color-mix(in srgb, var(--bs-success) 28%, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
}

.assignment-pill-gold {
    background: color-mix(in srgb, var(--bs-warning) 34%, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
}

.assignment-pill-coral {
    background: color-mix(in srgb, var(--bs-danger) 24%, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
}

.assignment-section { overflow: hidden; }

.assignment-section-header {
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--surface-muted, var(--surface-soft, var(--surface, var(--bs-body-bg))));
}

.assignment-section-record-merged > .assignment-section-header {
    background: #ffffff;
}

.assignment-section-title,
.assignment-side-title,
.assignment-card-title,
.assignment-class-name,
.assignment-empty-title,
.assignment-class-title-inline {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 700;
}

.assignment-section-title { font-size: 1.06rem; }
.assignment-section-subtitle { font-size: 0.86rem; margin-top: 0.2rem; }
.assignment-section-body { padding: 0; }
.assignment-record-body-merged { padding: 0; }

.assignment-record-table-merged {
    min-width: 1120px;
}

.assignment-record-table th,
.assignment-record-table td {
    vertical-align: middle;
    padding: 0.8rem 0.9rem;
}

.assignment-record-table thead th {
    font-size: 0.78rem;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.assignment-record-table tbody td {
    font-size: 0.9rem;
}

.assignment-record-table tbody tr.assignment-row-pending > td {
    background: color-mix(in srgb, var(--bs-warning) 14%, var(--surface, var(--bs-body-bg))) !important;
    border-color: color-mix(in srgb, var(--bs-warning) 38%, var(--table-border, var(--border-color, var(--bs-border-color)))) !important;
}

.assignment-record-table tbody tr.assignment-row-pending:hover > td {
    background: color-mix(in srgb, var(--bs-warning) 19%, var(--surface, var(--bs-body-bg))) !important;
}

.assignment-record-table tbody tr.assignment-row-pending > td:first-child {
    box-shadow: inset 0.35rem 0 0 color-mix(in srgb, var(--bs-warning) 72%, var(--primary, var(--bs-primary)));
}

.assignment-record-class,
.assignment-record-date,
.assignment-record-time,
.assignment-record-status-cell,
.assignment-record-responded-cell {
    white-space: nowrap;
}

.assignment-record-program {
    max-width: 230px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.assignment-row-note {
    max-width: 260px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 0.78rem;
    margin-top: 0.1rem;
}

.assignment-action-col,
.assignment-action-cell {
    min-width: 260px;
}

.assignment-row-response-form {
    display: grid;
    grid-template-columns: 7.5rem minmax(8rem, 1fr) auto;
    align-items: center;
    gap: 0.4rem;
    justify-content: end;
}

.assignment-row-response-select,
.assignment-row-response-note {
    min-height: 2.1rem !important;
    padding: 0.38rem 0.55rem !important;
    border-radius: 0.7rem !important;
    font-size: 0.82rem;
}

.assignment-row-save {
    min-height: 2.1rem;
    padding: 0.38rem 0.65rem !important;
    border-radius: 0.7rem !important;
    font-size: 0.82rem;
}

.assignment-muted-action {
    font-size: 0.84rem;
}

.assignment-side-card {
    padding: 1.1rem;
}

.assignment-side-card-compact {
    padding: 1rem;
}

.assignment-side-heading {
    margin-bottom: 0.9rem;
}

.assignment-side-heading-compact {
    margin-bottom: 0.75rem;
}

.assignment-side-title {
    font-size: 0.9rem;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.assignment-side-accent {
    width: 0.38rem;
    height: 1.75rem;
    border-radius: 999px;
    background: var(--primary, var(--bs-primary));
    flex: 0 0 auto;
}

.assignment-side-accent-gold { background: var(--bs-warning); }
.assignment-side-accent-blue { background: var(--bs-info); }
.assignment-side-accent-green { background: var(--bs-success); }

.assignment-next-card,
.assignment-class-card {
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
    background: var(--surface-strong, var(--surface, var(--bs-body-bg)));
    padding: 0.9rem;
}

.assignment-next-card-compact,
.assignment-class-card-compact {
    padding: 0.85rem;
}

.assignment-class-list,
.assignment-class-list-compact {
    display: grid;
    gap: 0.6rem;
}

.assignment-class-card-compact .assignment-class-name,
.assignment-class-card-text {
    min-width: 0;
}

.assignment-class-card-compact .assignment-class-name,
.assignment-class-card-compact .assignment-card-meta,
.assignment-class-card-compact .assignment-class-next {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.assignment-class-top {
    justify-content: space-between;
    flex-wrap: nowrap;
}

.assignment-class-next {
    font-size: 0.78rem;
    margin-top: 0.25rem;
}

.assignment-empty-small,
.assignment-empty-state {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    border: 1px dashed var(--table-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
    padding: 1rem;
    text-align: center;
}

@media (max-width: 1199.98px) {
    .assignment-action-col,
    .assignment-action-cell {
        min-width: 320px;
    }
}

@media (max-width: 991.98px) {
    .assignment-metrics-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .assignment-filter-grid,
    .assignment-filter-grid-merged {
        grid-template-columns: 1fr;
    }

    .assignment-filter-buttons {
        align-items: stretch;
    }

    .assignment-filter-buttons .btn {
        flex: 1 1 auto;
    }
}

@media (max-width: 575.98px) {
    .assignment-hero-body,
    .assignment-filter,
    .assignment-section-header,
    .assignment-side-card {
        padding: 1rem;
    }

    .assignment-metrics-grid {
        grid-template-columns: 1fr;
    }

    .assignment-row-response-form {
        grid-template-columns: 1fr;
    }

    .assignment-row-save {
        width: 100%;
    }
}

/* ===== Home dashboard themed layout ===== */
.dashboard-page {
    color: var(--text-main, var(--bs-body-color));
}

.dashboard-accent-blue {
    --dashboard-accent: var(--bs-info, var(--primary, var(--bs-primary)));
    --dashboard-accent-soft: color-mix(in srgb, var(--bs-info, var(--primary, var(--bs-primary))) 14%, var(--surface, var(--bs-body-bg)) 86%);
    --dashboard-accent-border: color-mix(in srgb, var(--bs-info, var(--primary, var(--bs-primary))) 38%, var(--card-border, var(--bs-border-color)) 62%);
}

.dashboard-accent-green {
    --dashboard-accent: var(--bs-success, var(--primary, var(--bs-primary)));
    --dashboard-accent-soft: color-mix(in srgb, var(--bs-success, var(--primary, var(--bs-primary))) 16%, var(--surface, var(--bs-body-bg)) 84%);
    --dashboard-accent-border: color-mix(in srgb, var(--bs-success, var(--primary, var(--bs-primary))) 40%, var(--card-border, var(--bs-border-color)) 60%);
}

.dashboard-accent-gold {
    --dashboard-accent: var(--bs-warning, var(--primary, var(--bs-primary)));
    --dashboard-accent-soft: color-mix(in srgb, var(--bs-warning, var(--primary, var(--bs-primary))) 22%, var(--surface, var(--bs-body-bg)) 78%);
    --dashboard-accent-border: color-mix(in srgb, var(--bs-warning, var(--primary, var(--bs-primary))) 48%, var(--card-border, var(--bs-border-color)) 52%);
}

.dashboard-accent-coral {
    --dashboard-accent: var(--bs-danger, var(--primary, var(--bs-primary)));
    --dashboard-accent-soft: color-mix(in srgb, var(--bs-danger, var(--primary, var(--bs-primary))) 18%, var(--surface, var(--bs-body-bg)) 82%);
    --dashboard-accent-border: color-mix(in srgb, var(--bs-danger, var(--primary, var(--bs-primary))) 42%, var(--card-border, var(--bs-border-color)) 58%);
}

.dashboard-home-hero,
.dashboard-panel,
.dashboard-metric {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--bs-border-color));
    border-radius: 1.25rem;
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
}

.dashboard-home-hero {
    overflow: hidden;
}

.dashboard-home-hero__accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-danger), var(--bs-warning));
}

.dashboard-home-hero__body,
.dashboard-panel-heading,
.dashboard-panel-header,
.dashboard-chart-heading,
.dashboard-upcoming-top {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.dashboard-home-hero__body {
    padding: 1.5rem;
}

.dashboard-home-kicker {
    color: var(--primary, var(--bs-primary));
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.dashboard-home-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.8rem, 2.5vw, 2.35rem);
    font-weight: 700;
    letter-spacing: -0.035em;
}

.dashboard-home-subtitle,
.dashboard-panel-subtitle,
.dashboard-chart-subtitle,
.dashboard-metric__hint,
.dashboard-recent-muted,
.dashboard-upcoming-time,
.dashboard-upcoming-detail,
.dashboard-attention-detail,
.dashboard-record-tabs__subtitle {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.dashboard-home-actions,
.dashboard-recent-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
}

.dashboard-metrics-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.dashboard-metric {
    padding: 1.2rem;
}

.dashboard-metric__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.dashboard-metric__dot {
    width: 0.62rem;
    height: 0.62rem;
    border-radius: 999px;
    background: var(--dashboard-accent, var(--primary, var(--bs-primary)));
    box-shadow: 0 0 0 0.28rem var(--surface, var(--bs-body-bg));
}

.dashboard-metric__value {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.55rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    margin-top: 0.75rem;
}

.dashboard-metric__hint {
    font-size: 0.78rem;
    margin-top: 0.2rem;
}

.dashboard-main-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(20rem, 0.85fr);
    gap: 1.25rem;
    align-items: start;
}

.dashboard-main-column,
.dashboard-side-column,
.dashboard-attention-list,
.dashboard-upcoming-list,
.dashboard-mini-stat-grid,
.dashboard-record-tab-list {
    display: grid;
    gap: 1rem;
}

.dashboard-panel {
    overflow: hidden;
}

.dashboard-panel-pad {
    padding: 1.25rem;
}

.dashboard-panel-header {
    padding: 1.15rem 1.25rem;
    border-bottom: 1px solid var(--table-border, var(--card-border, var(--bs-border-color)));
    background: var(--table-head-bg, var(--surface-soft, var(--bs-body-bg)));
}

.dashboard-panel-header--compact {
    padding: 1rem 1.25rem;
}

.dashboard-section-title,
.dashboard-side-title,
.dashboard-chart-title,
.dashboard-module__title,
.dashboard-upcoming-title,
.dashboard-attention-title,
.dashboard-recent-title {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 700;
}

.dashboard-section-title {
    font-size: 1.08rem;
    letter-spacing: -0.01em;
}

.dashboard-side-title {
    font-size: 0.84rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.dashboard-small-pill,
.dashboard-record-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    border-radius: 999px;
    border: 1px solid var(--dashboard-accent-border, var(--pill-border, var(--bs-border-color)));
    background: var(--dashboard-accent-soft, var(--surface-soft, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
    font-size: 0.69rem;
    font-weight: 500;
    line-height: 1;
    min-height: 1.42rem;
    padding: 0.28rem 0.58rem;
    white-space: nowrap;
}

.dashboard-small-pill {
    border-color: var(--card-border, var(--bs-border-color));
    background: var(--table-head-bg, var(--surface-soft, var(--bs-body-bg)));
}

.dashboard-record-badge--blue { --dashboard-accent: var(--bs-info); --dashboard-accent-soft: color-mix(in srgb, var(--bs-info) 14%, var(--surface, var(--bs-body-bg)) 86%); --dashboard-accent-border: color-mix(in srgb, var(--bs-info) 38%, var(--card-border, var(--bs-border-color)) 62%); }
.dashboard-record-badge--green { --dashboard-accent: var(--bs-success); --dashboard-accent-soft: color-mix(in srgb, var(--bs-success) 16%, var(--surface, var(--bs-body-bg)) 84%); --dashboard-accent-border: color-mix(in srgb, var(--bs-success) 40%, var(--card-border, var(--bs-border-color)) 60%); }
.dashboard-record-badge--gold { --dashboard-accent: var(--bs-warning); --dashboard-accent-soft: color-mix(in srgb, var(--bs-warning) 22%, var(--surface, var(--bs-body-bg)) 78%); --dashboard-accent-border: color-mix(in srgb, var(--bs-warning) 48%, var(--card-border, var(--bs-border-color)) 52%); }
.dashboard-record-badge--coral { --dashboard-accent: var(--bs-danger); --dashboard-accent-soft: color-mix(in srgb, var(--bs-danger) 18%, var(--surface, var(--bs-body-bg)) 82%); --dashboard-accent-border: color-mix(in srgb, var(--bs-danger) 42%, var(--card-border, var(--bs-border-color)) 58%); }

.dashboard-module-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.dashboard-module-grid--primary {
    grid-template-columns: repeat(auto-fit, minmax(17rem, 1fr));
    gap: 1.1rem;
}

.dashboard-module {
    display: grid;
    grid-template-columns: minmax(0, 6.4rem) minmax(0, 1fr);
    gap: 1rem;
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--bs-border-color));
    border-left: 0.28rem solid var(--card-border, var(--bs-border-color));
    border-radius: 1.15rem;
    background: var(--surface, var(--bs-body-bg));
    padding: 1.05rem;
    text-decoration: none;
    min-height: 11.25rem;
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    transition: transform 0.16s ease, border-color 0.16s ease, background 0.16s ease, box-shadow 0.16s ease;
}

.dashboard-module:hover {
    color: var(--text-main, var(--bs-body-color));
    border-color: var(--card-border, var(--bs-border-color));
    transform: translateY(-2px);
    box-shadow: 0 18px 34px rgba(15, 23, 42, 0.10);
    text-decoration: none;
}

.dashboard-module__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 5.9rem;
    height: 5.9rem;
    flex: 0 0 auto;
    overflow: hidden;
    align-self: start;
}

.dashboard-module__icon-img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
    object-position: center;
}

.dashboard-module__body {
    display: grid;
    gap: 0.48rem;
    min-width: 0;
    align-content: start;
}

.dashboard-module__desc {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.88rem;
    line-height: 1.52;
}

.dashboard-module .dashboard-record-badge {
    border-color: var(--card-border, var(--bs-border-color));
    background: var(--table-head-bg, var(--surface-soft, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
}

.dashboard-financial-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(15rem, 0.75fr);
    gap: 1.25rem;
    padding: 1.25rem;
}

.dashboard-giving-chart {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(2.4rem, 1fr));
    align-items: end;
    gap: 0.75rem;
    min-height: 14rem;
    border: 1px solid var(--table-border, var(--card-border, var(--bs-border-color)));
    border-radius: 1rem;
    background: color-mix(in srgb, var(--surface, var(--bs-body-bg)) 96%, var(--bs-warning) 4%);
    padding: 1rem;
}

.dashboard-giving-bar-wrap {
    display: grid;
    align-items: end;
    gap: 0.45rem;
    min-width: 0;
}

.dashboard-giving-bar {
    width: 100%;
    min-height: 1.1rem;
    border-radius: 0.85rem 0.85rem 0.42rem 0.42rem;
    background: linear-gradient(180deg, var(--bs-success) 0%, var(--primary, var(--bs-primary)) 100%);
    border: 1px solid color-mix(in srgb, var(--bs-success) 45%, var(--table-border, var(--bs-border-color)) 55%);
}

.dashboard-giving-label,
.dashboard-giving-total {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.68rem;
    font-weight: 500;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dashboard-mini-stat {
    border: 1px solid var(--table-border, var(--card-border, var(--bs-border-color)));
    border-radius: 1rem;
    background: var(--table-head-bg, var(--surface-soft, var(--bs-body-bg)));
    padding: 1rem;
}

.dashboard-mini-stat__label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.dashboard-mini-stat__value {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.25rem;
    font-weight: 700;
    margin-top: 0.18rem;
}

.dashboard-empty-box {
    border: 1px dashed var(--table-border, var(--card-border, var(--bs-border-color)));
    border-radius: 1rem;
    background: var(--table-head-bg, var(--surface-soft, var(--bs-body-bg)));
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    padding: 1rem;
    text-align: center;
}

.dashboard-recent-layout {
    display: grid;
    grid-template-columns: 12rem minmax(0, 1fr);
}

.dashboard-record-tabs {
    background: var(--table-head-bg, var(--surface-soft, var(--bs-body-bg)));
    border-right: 1px solid var(--table-border, var(--card-border, var(--bs-border-color)));
    padding: 1rem;
}

.dashboard-record-tabs__header {
    margin-bottom: 0.8rem;
}

.dashboard-record-tabs__title {
    color: var(--primary, var(--bs-primary));
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.dashboard-record-tabs__subtitle {
    font-size: 0.72rem;
    margin-top: 0.15rem;
}

.dashboard-record-tab {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 0.65rem;
    border: 1px solid var(--dashboard-accent-border, var(--card-border, var(--bs-border-color)));
    border-radius: 0.85rem;
    background: var(--dashboard-accent-soft, var(--surface, var(--bs-body-bg)));
    color: var(--btn-outline-neutral-text, var(--text-main, var(--bs-body-color)));
    padding: 0.55rem 0.72rem;
    font-size: 0.83rem;
    font-weight: 500;
    text-align: left;
    text-decoration: none;
    cursor: pointer;
    appearance: none;
    transition: background 0.16s ease, border-color 0.16s ease, transform 0.16s ease;
}

.dashboard-record-tab:hover,
.dashboard-record-tab.is-selected {
    color: var(--primary, var(--bs-primary));
    background: color-mix(in srgb, var(--dashboard-accent, var(--primary, var(--bs-primary))) 20%, var(--surface, var(--bs-body-bg)) 80%);
    border-color: var(--dashboard-accent, var(--primary, var(--bs-primary)));
    transform: translateY(-1px);
    text-decoration: none;
}

.dashboard-record-tab--blue { --dashboard-accent: var(--bs-info); --dashboard-accent-soft: color-mix(in srgb, var(--bs-info) 10%, var(--surface, var(--bs-body-bg)) 90%); --dashboard-accent-border: color-mix(in srgb, var(--bs-info) 34%, var(--card-border, var(--bs-border-color)) 66%); }
.dashboard-record-tab--green { --dashboard-accent: var(--bs-success); --dashboard-accent-soft: color-mix(in srgb, var(--bs-success) 12%, var(--surface, var(--bs-body-bg)) 88%); --dashboard-accent-border: color-mix(in srgb, var(--bs-success) 35%, var(--card-border, var(--bs-border-color)) 65%); }
.dashboard-record-tab--gold { --dashboard-accent: var(--bs-warning); --dashboard-accent-soft: color-mix(in srgb, var(--bs-warning) 18%, var(--surface, var(--bs-body-bg)) 82%); --dashboard-accent-border: color-mix(in srgb, var(--bs-warning) 44%, var(--card-border, var(--bs-border-color)) 56%); }
.dashboard-record-tab--coral { --dashboard-accent: var(--bs-danger); --dashboard-accent-soft: color-mix(in srgb, var(--bs-danger) 14%, var(--surface, var(--bs-body-bg)) 86%); --dashboard-accent-border: color-mix(in srgb, var(--bs-danger) 38%, var(--card-border, var(--bs-border-color)) 62%); }

.dashboard-record-tab__count {
    border-radius: 999px;
    background: var(--surface, var(--bs-body-bg));
    color: var(--primary, var(--bs-primary));
    min-width: 1.4rem;
    padding: 0.14rem 0.44rem;
    font-size: 0.68rem;
    font-weight: 700;
    text-align: center;
}

.dashboard-recent-table-wrap {
    overflow-x: auto;
}

.dashboard-recent-panels {
    min-width: 0;
}

.dashboard-recent-panel {
    min-width: 0;
}

.dashboard-recent-panel__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.15rem 0.85rem;
    border-bottom: 1px solid var(--table-border, var(--card-border, var(--bs-border-color)));
    background: color-mix(in srgb, var(--surface-soft, var(--table-head-bg, var(--bs-body-bg))) 70%, var(--surface, var(--bs-body-bg)) 30%);
}

.dashboard-recent-table {
    min-width: 46rem;
}

.dashboard-recent-row {
    display: grid;
    grid-template-columns: 4.5rem minmax(10rem, 1.25fr) 7.5rem minmax(10rem, 1fr) 6.5rem 5.5rem;
    gap: 0.75rem;
    align-items: center;
    padding: 0.9rem 1.15rem;
    border-top: 1px solid var(--table-border, var(--card-border, var(--bs-border-color)));
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.88rem;
}

.dashboard-recent-head {
    border-top: 0;
    background: var(--table-head-bg, var(--surface-soft, var(--bs-body-bg)));
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.dashboard-recent-row:not(.dashboard-recent-head):hover {
    background: var(--table-row-hover, var(--surface-soft, var(--bs-body-bg)));
}

.dashboard-recent-id {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-variant-numeric: tabular-nums;
}

.dashboard-small-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1.85rem;
    border: 1px solid var(--btn-outline-neutral-border, var(--card-border, var(--bs-border-color)));
    border-radius: 0.65rem;
    background: var(--btn-outline-neutral-bg, transparent);
    color: var(--btn-outline-neutral-text, var(--text-main, var(--bs-body-color)));
    padding: 0.35rem 0.65rem;
    font-size: 0.75rem;
    font-weight: 500;
    text-decoration: none;
}

.dashboard-small-action:hover {
    background: var(--btn-outline-neutral-hover-bg, var(--surface-soft, var(--bs-body-bg)));
    color: var(--btn-outline-neutral-hover-text, var(--text-main, var(--bs-body-color)));
    text-decoration: none;
}

.dashboard-side-heading {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
}

.dashboard-side-accent {
    width: 0.42rem;
    min-height: 2.1rem;
    border-radius: 999px;
    background: var(--dashboard-accent, var(--primary, var(--bs-primary)));
    flex: 0 0 auto;
}

.dashboard-side-accent--gold {
    --dashboard-accent: var(--bs-warning);
}

.dashboard-attention-item {
    display: block;
    border: 1px solid color-mix(in srgb, var(--bs-warning) 48%, var(--card-border, var(--bs-border-color)) 52%);
    border-left: 0.28rem solid var(--bs-warning);
    border-radius: 1rem;
    background: color-mix(in srgb, var(--bs-warning) 18%, var(--surface, var(--bs-body-bg)) 82%);
    color: var(--text-main, var(--bs-body-color));
    padding: 1rem;
    text-decoration: none;
    transition: border-color 0.16s ease, background 0.16s ease, transform 0.16s ease, box-shadow 0.16s ease;
}

.dashboard-attention-link:hover,
.dashboard-attention-link:focus {
    background: color-mix(in srgb, var(--bs-warning) 24%, var(--surface, var(--bs-body-bg)) 76%);
    border-color: color-mix(in srgb, var(--bs-warning) 62%, var(--card-border, var(--bs-border-color)) 38%);
    color: var(--text-main, var(--bs-body-color));
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: 0 0.6rem 1.25rem rgba(15, 23, 42, 0.07);
}

.dashboard-attention-title {
    font-size: 0.88rem;
    margin-top: 0.55rem;
}

.dashboard-attention-detail {
    font-size: 0.76rem;
    margin-top: 0.2rem;
}

.dashboard-upcoming-list {
    padding: 1rem;
}

.dashboard-upcoming-item {
    display: block;
    border: 1px solid var(--dashboard-accent-border, var(--card-border, var(--bs-border-color)));
    border-left: 0.28rem solid var(--dashboard-item-accent, var(--dashboard-accent, var(--primary, var(--bs-primary))));
    border-radius: 1rem;
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    padding: 1rem;
    text-decoration: none;
    transition: border-color 0.16s ease, background 0.16s ease, transform 0.16s ease, box-shadow 0.16s ease;
}

.dashboard-upcoming-item:hover,
.dashboard-upcoming-item:focus {
    border-color: var(--dashboard-item-accent, var(--dashboard-accent, var(--primary, var(--bs-primary))));
    background: var(--table-row-hover, var(--surface-soft, var(--surface, var(--bs-body-bg))));
    color: var(--text-main, var(--bs-body-color));
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: 0 0.6rem 1.25rem rgba(15, 23, 42, 0.06);
}

.dashboard-upcoming-top {
    font-size: 0.84rem;
    font-weight: 700;
}

.dashboard-upcoming-time,
.dashboard-upcoming-detail {
    font-size: 0.76rem;
    margin-top: 0.22rem;
}

.dashboard-upcoming-title {
    font-size: 0.9rem;
    margin-top: 0.22rem;
}

@media (max-width: 1199.98px) {
    .dashboard-main-grid,
    .dashboard-financial-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-metrics-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .dashboard-home-hero__body,
    .dashboard-panel-pad,
    .dashboard-panel-header,
    .dashboard-financial-grid,
    .dashboard-upcoming-list {
        padding: 1rem;
    }

    .dashboard-metrics-grid,
    .dashboard-module-grid,
    .dashboard-recent-layout {
        grid-template-columns: 1fr;
    }

    .dashboard-module {
        grid-template-columns: 5.4rem minmax(0, 1fr);
        min-height: 9.75rem;
        padding: 1rem;
        gap: 0.95rem;
    }

    .dashboard-module__icon {
        width: 5.4rem;
        height: 5.4rem;
    }

    .dashboard-record-tabs {
        border-right: 0;
        border-bottom: 1px solid var(--table-border, var(--card-border, var(--bs-border-color)));
    }

    .dashboard-recent-row {
        grid-template-columns: 3.5rem minmax(8rem, 1fr) 6.2rem 8rem 5.5rem 4.75rem;
        padding-left: 0.8rem;
        padding-right: 0.8rem;
        font-size: 0.82rem;
    }
}

/* ===== My assignments clickable side cards ===== */
.assignment-click-card {
    display: block;
    color: var(--text-main, var(--bs-body-color)) !important;
    text-decoration: none !important;
    cursor: pointer;
    transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.assignment-click-card:hover,
.assignment-click-card:focus-visible {
    color: var(--text-main, var(--bs-body-color)) !important;
    border-color: var(--primary, var(--bs-primary)) !important;
    background: var(--table-row-hover, var(--surface-soft, var(--bs-body-bg))) !important;
    box-shadow: 0 10px 22px color-mix(in srgb, var(--primary, var(--bs-primary)) 14%, transparent);
    transform: translateY(-1px);
    outline: 0;
}

.assignment-click-card:focus-visible {
    box-shadow: 0 0 0 0.22rem color-mix(in srgb, var(--primary, var(--bs-primary)) 22%, transparent), var(--card-shadow, none);
}

.assignment-click-card .assignment-card-title,
.assignment-click-card .assignment-class-name {
    color: var(--text-main, var(--bs-body-color)) !important;
}

.assignment-click-card .assignment-card-meta,
.assignment-click-card .assignment-class-next {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color))) !important;
}

/* ===== Events list themed layout ===== */
.events-page {
    color: var(--text-main, var(--bs-body-color));
}

.events-hero,
.events-filter-card,
.events-panel,
.events-metric {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    border-radius: 1.25rem;
}

.events-hero {
    overflow: hidden;
}

.events-hero__accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-danger), var(--bs-warning));
}

.events-hero__body,
.events-panel-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.5rem;
}

.events-panel-header {
    border-bottom: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--table-head-bg, var(--surface-soft));
}

.events-panel-header--compact {
    padding: 1rem 1.25rem;
}

.events-kicker {
    color: var(--primary, var(--bs-primary));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.11em;
    text-transform: uppercase;
}

.events-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.75rem, 2.4vw, 2.35rem);
    font-weight: 700;
    letter-spacing: -0.035em;
}

.events-subtitle,
.events-muted {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color))) !important;
}

.events-actions,
.events-filter-actions,
.events-panel-tools,
.events-followup-top,
.events-upcoming-top {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.events-metrics-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.events-metric {
    padding: 1.25rem;
    position: relative;
    overflow: hidden;
}

.events-metric::after {
    content: "";
    position: absolute;
    top: 1.1rem;
    right: 1.1rem;
    width: 0.65rem;
    height: 0.65rem;
    border-radius: 999px;
    background: var(--events-accent, var(--primary, var(--bs-primary)));
    box-shadow: 0 0 0 0.28rem var(--surface, var(--bs-body-bg));
}

.events-accent-blue { --events-accent: var(--bs-info); --events-accent-soft: color-mix(in srgb, var(--bs-info) 18%, var(--surface, var(--bs-body-bg))); --events-accent-border: color-mix(in srgb, var(--bs-info) 45%, var(--card-border, var(--bs-border-color))); }
.events-accent-green { --events-accent: var(--bs-success); --events-accent-soft: color-mix(in srgb, var(--bs-success) 22%, var(--surface, var(--bs-body-bg))); --events-accent-border: color-mix(in srgb, var(--bs-success) 45%, var(--card-border, var(--bs-border-color))); }
.events-accent-gold { --events-accent: var(--bs-warning); --events-accent-soft: color-mix(in srgb, var(--bs-warning) 28%, var(--surface, var(--bs-body-bg))); --events-accent-border: color-mix(in srgb, var(--bs-warning) 45%, var(--card-border, var(--bs-border-color))); }
.events-accent-coral { --events-accent: var(--bs-danger); --events-accent-soft: color-mix(in srgb, var(--bs-danger) 20%, var(--surface, var(--bs-body-bg))); --events-accent-border: color-mix(in srgb, var(--bs-danger) 45%, var(--card-border, var(--bs-border-color))); }

.events-metric__label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.events-metric__value {
    margin-top: 0.4rem;
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.65rem;
    font-weight: 700;
    line-height: 1.1;
}

.events-metric__hint {
    margin-top: 0.28rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.78rem;
}

.events-filter-card {
    padding: 1.25rem;
}

.events-filter-grid {
    display: grid;
    grid-template-columns: minmax(16rem, 1.4fr) repeat(3, minmax(9rem, 0.8fr)) auto;
    gap: 1rem;
    align-items: end;
}

.events-field {
    display: grid;
    gap: 0.35rem;
}

.events-form-panel-body {
    padding: 1.5rem;
}

.events-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem 1.25rem;
}

.events-form-field--full {
    grid-column: 1 / -1;
}

.events-form-check {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    min-height: 44px;
}

.events-form-actions {
    margin-top: 1.5rem;
}

.events-form-alert {
    margin-bottom: 1.25rem;
}

.events-form-note-list {
    display: grid;
    gap: 0.85rem;
    padding: 1rem;
}

.events-form-note-card {
    display: grid;
    gap: 0.25rem;
    padding: 1rem;
    border: 1px solid var(--card-border, var(--bs-border-color));
    border-left: 0.28rem solid var(--events-item-accent, var(--primary, var(--bs-primary)));
    border-radius: 1rem;
    background: var(--surface, var(--bs-body-bg));
}

.events-form-note-card--blue { --events-item-accent: var(--bs-info); }
.events-form-note-card--green { --events-item-accent: var(--bs-success); }
.events-form-note-card--gold { --events-item-accent: var(--bs-warning); }

.events-control {
    background-color: var(--input-bg, var(--surface, var(--bs-body-bg))) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
    border-color: var(--input-border, var(--border-color, var(--bs-border-color))) !important;
}

.events-main-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(360px, 0.85fr);
    gap: 1.25rem;
    align-items: start;
}

.events-side-stack {
    display: grid;
    gap: 1.25rem;
}

.events-section-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.05rem;
    font-weight: 700;
}

.events-section-title--small {
    font-size: 0.9rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.events-table {
    min-width: 980px;
}

.events-table th,
.events-table td {
    padding: 0.95rem 1.25rem;
    vertical-align: middle;
}

.events-title-cell {
    display: grid;
    gap: 0.18rem;
    padding-left: 0.75rem;
    border-left: 0.25rem solid var(--events-item-accent, var(--primary, var(--bs-primary)));
    color: var(--text-main, var(--bs-body-color)) !important;
    text-decoration: none !important;
}

.events-title-cell:hover .events-title-cell__name {
    color: var(--primary, var(--bs-primary));
}

.events-title-cell__name,
.events-followup-name,
.events-upcoming-title {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 600;
}

.events-title-cell__meta,
.events-upcoming-meta,
.events-followup-event-title,
.events-followup-detail {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.78rem;
    font-weight: 400;
}

.events-category-badge,
.events-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid var(--events-accent-border, var(--pill-border, var(--bs-border-color)));
    background: var(--events-accent-soft, var(--primary-soft, var(--surface-soft)));
    color: var(--primary, var(--bs-primary));
    font-size: 0.72rem;
    font-weight: 500;
    line-height: 1;
    padding: 0.34rem 0.58rem;
    white-space: nowrap;
}

.events-category-badge {
    --events-accent-soft: color-mix(in srgb, var(--events-item-accent, var(--primary, var(--bs-primary))) 16%, var(--surface, var(--bs-body-bg)));
    --events-accent-border: color-mix(in srgb, var(--events-item-accent, var(--primary, var(--bs-primary))) 42%, var(--card-border, var(--bs-border-color)));
}

.events-pill--blue { --events-accent-soft: color-mix(in srgb, var(--bs-info) 20%, var(--surface, var(--bs-body-bg))); --events-accent-border: color-mix(in srgb, var(--bs-info) 42%, var(--card-border, var(--bs-border-color))); }
.events-pill--green { --events-accent-soft: color-mix(in srgb, var(--bs-success) 24%, var(--surface, var(--bs-body-bg))); --events-accent-border: color-mix(in srgb, var(--bs-success) 42%, var(--card-border, var(--bs-border-color))); }
.events-pill--gold { --events-accent-soft: color-mix(in srgb, var(--bs-warning) 32%, var(--surface, var(--bs-body-bg))); --events-accent-border: color-mix(in srgb, var(--bs-warning) 42%, var(--card-border, var(--bs-border-color))); }
.events-pill--muted { --events-accent-soft: var(--surface-muted, var(--surface-soft)); --events-accent-border: var(--card-border, var(--bs-border-color)); color: var(--text-muted, var(--bs-secondary-color)); }

.events-upcoming-card,
.events-followup-card {
    display: block;
    border: 1px solid var(--card-border, var(--bs-border-color));
    border-left: 0.28rem solid var(--events-item-accent, var(--primary, var(--bs-primary)));
    border-radius: 1rem;
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    padding: 1rem;
    text-decoration: none !important;
    transition: border-color 0.16s ease, background 0.16s ease, transform 0.16s ease, box-shadow 0.16s ease;
}

.events-upcoming-card:hover,
.events-upcoming-card:focus,
.events-followup-card:hover,
.events-followup-card:focus {
    border-color: var(--events-item-accent, var(--primary, var(--bs-primary)));
    background: var(--table-row-hover, var(--surface-soft));
    color: var(--text-main, var(--bs-body-color));
    transform: translateY(-1px);
    box-shadow: 0 0.6rem 1.25rem rgba(15, 23, 42, 0.06);
}

.events-side-list {
    display: grid;
    gap: 0.8rem;
    padding: 1rem;
}

.events-upcoming-top,
.events-followup-top {
    justify-content: space-between;
}

.events-upcoming-count-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-top: 0.8rem;
    padding: 0.6rem 0.75rem;
    border: 1px solid var(--table-border, var(--card-border, var(--bs-border-color)));
    border-radius: 0.8rem;
    background: var(--table-head-bg, var(--surface-soft));
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.events-upcoming-count-row strong {
    color: var(--primary, var(--bs-primary));
}

.events-followup-card {
    background: var(--surface, var(--bs-body-bg));
    border-color: var(--card-border, var(--bs-border-color));
}

.events-followup-event-title {
    display: block;
    margin-top: 0.2rem;
}

.events-side-accent {
    width: 0.42rem;
    height: 2rem;
    border-radius: 999px;
    background: var(--primary, var(--bs-primary));
    flex: 0 0 auto;
}

.events-side-accent--gold {
    background: var(--bs-warning);
}

.events-collapse-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: 1px solid var(--btn-outline-neutral-border, var(--card-border, var(--bs-border-color)));
    border-radius: 0.65rem;
    background: var(--surface, var(--bs-body-bg));
    color: var(--primary, var(--bs-primary));
    font-size: 1rem;
    font-weight: 600;
    line-height: 1;
}

.events-collapse-btn:hover,
.events-collapse-btn:focus-visible {
    background: var(--primary-soft, var(--surface-soft));
    outline: 0;
}

.events-empty {
    padding: 1.25rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    text-align: center;
}

.min-width-0 {
    min-width: 0;
}

@media (max-width: 1199.98px) {
    .events-main-grid,
    .events-filter-grid {
        grid-template-columns: 1fr;
    }

    .events-metrics-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .events-field--search,
    .events-filter-actions {
        grid-column: auto;
    }

    .events-form-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .events-hero__body,
    .events-filter-card,
    .events-panel-header {
        padding: 1rem;
    }

    .events-metrics-grid {
        grid-template-columns: 1fr;
    }
}

/* ===== Event dashboard themed layout ===== */
.event-dashboard-page {
    color: var(--text-main, var(--bs-body-color));
}

.event-dashboard-hero,
.event-dashboard-panel,
.event-dashboard-metric {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    border-radius: 1.25rem;
}

.event-dashboard-hero {
    overflow: hidden;
}

.event-dashboard-hero__accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-danger));
}

.event-dashboard-hero__body,
.event-dashboard-panel-header,
.event-dashboard-section-row,
.event-dashboard-actions,
.event-dashboard-side-card__top {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.event-dashboard-hero__body {
    padding: 1.5rem;
}

.event-dashboard-kicker {
    color: var(--primary, var(--bs-primary));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.event-dashboard-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.8rem, 2.4vw, 2.35rem);
    font-weight: 700;
    letter-spacing: -0.035em;
}

.event-dashboard-subtitle,
.event-dashboard-muted,
.event-dashboard-card-text {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.event-dashboard-subtitle {
    max-width: 46rem;
    font-size: 0.92rem;
    line-height: 1.55;
}

.event-dashboard-metrics-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.event-dashboard-metric {
    padding: 1.25rem;
}

.event-dashboard-metric__label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.event-dashboard-metric__value {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.65rem, 2vw, 2.05rem);
    font-weight: 700;
    line-height: 1.1;
    margin-top: 0.55rem;
}

.event-dashboard-metric__hint {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.76rem;
    margin-top: 0.3rem;
}

.event-dashboard-metric::before {
    content: "";
    display: block;
    width: 0.65rem;
    height: 0.65rem;
    border-radius: 999px;
    float: right;
    box-shadow: 0 0 0 0.25rem var(--surface, var(--bs-body-bg));
    background: var(--event-dashboard-accent, var(--primary, var(--bs-primary)));
}

.event-dashboard-accent-blue { --event-dashboard-accent: var(--bs-info); }
.event-dashboard-accent-green { --event-dashboard-accent: var(--bs-success); }
.event-dashboard-accent-gold { --event-dashboard-accent: var(--bs-warning); }
.event-dashboard-accent-coral { --event-dashboard-accent: var(--bs-danger); }

.event-dashboard-main-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(22rem, 0.85fr);
    gap: 1.25rem;
    align-items: start;
}

.event-dashboard-main-stack,
.event-dashboard-side-stack {
    display: grid;
    gap: 1.25rem;
}

.event-dashboard-panel {
    overflow: hidden;
}

.event-dashboard-actions-panel {
    padding: 1.25rem;
}

.event-dashboard-panel-header {
    padding: 1.25rem;
    border-bottom: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--table-head-bg, var(--surface-soft, var(--bs-body-bg)));
}

.event-dashboard-panel-header--compact {
    padding: 1rem 1.25rem;
}

.event-dashboard-section-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: -0.015em;
}

.event-dashboard-section-title--small {
    font-size: 0.9rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.event-dashboard-action-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.event-dashboard-action-card,
.event-dashboard-side-card,
.event-dashboard-followup-card {
    display: block;
    text-decoration: none;
    color: inherit;
    background: var(--surface, var(--bs-body-bg));
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    border-left: 0.25rem solid var(--event-dashboard-item-accent, var(--primary, var(--bs-primary)));
    transition: background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, transform 0.12s ease;
}

.event-dashboard-action-card:hover,
.event-dashboard-side-card:hover,
.event-dashboard-followup-card:hover,
.event-dashboard-action-card:focus,
.event-dashboard-side-card:focus,
.event-dashboard-followup-card:focus {
    background: var(--table-row-hover, var(--surface-soft));
    color: inherit;
    box-shadow: 0 0.45rem 1rem rgba(0, 0, 0, 0.05);
    transform: translateY(-1px);
    text-decoration: none;
}

.event-dashboard-action-card {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    padding: 1rem;
    border-radius: 1rem;
}

.event-dashboard-action-card.event-dashboard-card-accent-blue { --event-dashboard-item-accent: var(--bs-info); }
.event-dashboard-action-card.event-dashboard-card-accent-green { --event-dashboard-item-accent: var(--bs-success); }
.event-dashboard-action-card.event-dashboard-card-accent-gold { --event-dashboard-item-accent: var(--bs-warning); }
.event-dashboard-action-card.event-dashboard-card-accent-coral { --event-dashboard-item-accent: var(--bs-danger); }

.event-dashboard-action-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 0.9rem;
    flex: 0 0 auto;
    color: var(--primary, var(--bs-primary));
    font-size: 1.1rem;
    font-weight: 700;
}

.event-dashboard-soft-blue { background: color-mix(in srgb, var(--bs-info) 22%, var(--surface, var(--bs-body-bg))); }
.event-dashboard-soft-green { background: color-mix(in srgb, var(--bs-success) 24%, var(--surface, var(--bs-body-bg))); }
.event-dashboard-soft-gold { background: color-mix(in srgb, var(--bs-warning) 32%, var(--surface, var(--bs-body-bg))); }
.event-dashboard-soft-coral { background: color-mix(in srgb, var(--bs-danger) 24%, var(--surface, var(--bs-body-bg))); }

.event-dashboard-action-copy,
.event-dashboard-card-title,
.event-dashboard-card-text,
.event-dashboard-action-link {
    display: block;
}

.event-dashboard-card-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.94rem;
    font-weight: 650;
    line-height: 1.25;
}

.event-dashboard-card-text {
    font-size: 0.78rem;
    line-height: 1.45;
    margin-top: 0.25rem;
}

.event-dashboard-action-link {
    color: var(--primary, var(--bs-primary));
    font-size: 0.8rem;
    font-weight: 600;
    margin-top: 0.65rem;
}

.event-dashboard-table {
    min-width: 780px;
}

.event-dashboard-table th,
.event-dashboard-table td {
    padding: 0.95rem 1.25rem;
    vertical-align: middle;
}

.event-dashboard-title-cell {
    display: block;
    padding-left: 0.75rem;
    border-left: 0.25rem solid var(--event-dashboard-item-accent, var(--primary, var(--bs-primary)));
    color: inherit !important;
    text-decoration: none;
}

.event-dashboard-title-cell:hover {
    color: inherit !important;
    text-decoration: none;
}

.event-dashboard-title-cell__name {
    display: block;
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.9rem;
    font-weight: 650;
    line-height: 1.25;
}

.event-dashboard-title-cell__meta {
    display: block;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.76rem;
    margin-top: 0.2rem;
}

.event-dashboard-recent-list {
    display: grid;
}

.event-dashboard-recent-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 7.5rem 6rem 5.5rem;
    gap: 1rem;
    align-items: center;
    padding: 1rem 1.25rem;
    border-top: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
}

.event-dashboard-recent-row:first-child {
    border-top: 0;
}

.event-dashboard-recent-row:hover {
    background: var(--table-row-hover, var(--surface-soft));
}

.event-dashboard-side-list {
    display: grid;
    gap: 0.75rem;
    padding: 1rem;
}

.event-dashboard-side-card,
.event-dashboard-followup-card {
    border-radius: 0.95rem;
    padding: 1rem;
}

.event-dashboard-side-card__top {
    align-items: flex-start;
    flex-wrap: nowrap;
}

.event-dashboard-visitor-count {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
    margin-top: 0.85rem;
    padding: 0.55rem 0.7rem;
    border-radius: 0.8rem;
    background: var(--table-head-bg, var(--surface-soft));
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.74rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.event-dashboard-visitor-count span:last-child {
    color: var(--primary, var(--bs-primary));
}

.event-dashboard-category-badge,
.event-dashboard-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid var(--pill-border, var(--border-color, var(--bs-border-color)));
    font-size: 0.69rem;
    font-weight: 500;
    line-height: 1;
    white-space: nowrap;
}

.event-dashboard-category-badge {
    background: color-mix(in srgb, var(--event-dashboard-item-accent, var(--primary, var(--bs-primary))) 18%, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
    border-color: color-mix(in srgb, var(--event-dashboard-item-accent, var(--primary, var(--bs-primary))) 35%, var(--border-color, var(--bs-border-color)));
    padding: 0.3rem 0.55rem;
}

.event-dashboard-pill {
    padding: 0.32rem 0.6rem;
    background: var(--surface-soft, var(--bs-body-bg));
    color: var(--primary, var(--bs-primary));
}

.event-dashboard-pill--blue { background: color-mix(in srgb, var(--bs-info) 22%, var(--surface, var(--bs-body-bg))); }
.event-dashboard-pill--green { background: color-mix(in srgb, var(--bs-success) 24%, var(--surface, var(--bs-body-bg))); }
.event-dashboard-pill--gold { background: color-mix(in srgb, var(--bs-warning) 32%, var(--surface, var(--bs-body-bg))); }
.event-dashboard-pill--coral { background: color-mix(in srgb, var(--bs-danger) 24%, var(--surface, var(--bs-body-bg))); }
.event-dashboard-pill--muted { background: var(--surface-soft, var(--bs-body-bg)); color: var(--text-muted, var(--muted, var(--bs-secondary-color))); }

.event-dashboard-followup-header {
    align-items: center;
    justify-content: flex-start;
}

.event-dashboard-followup-bar {
    display: inline-block;
    width: 0.38rem;
    height: 2rem;
    border-radius: 999px;
    background: var(--bs-warning, var(--primary, var(--bs-primary)));
    flex: 0 0 auto;
}

.event-dashboard-followup-card .event-dashboard-card-title,
.event-dashboard-side-card .event-dashboard-card-title {
    font-size: 0.9rem;
}

@media (max-width: 1199.98px) {
    .event-dashboard-main-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991.98px) {
    .event-dashboard-metrics-grid,
    .event-dashboard-action-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .event-dashboard-hero__body,
    .event-dashboard-panel-header,
    .event-dashboard-actions-panel {
        padding: 1rem;
    }

    .event-dashboard-metrics-grid,
    .event-dashboard-action-grid {
        grid-template-columns: 1fr;
    }

    .event-dashboard-recent-row {
        grid-template-columns: 1fr;
        gap: 0.65rem;
    }

    .event-dashboard-side-card__top {
        flex-wrap: wrap;
    }
}

/* ===== Shared record comments ===== */
.comments-panel {
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1.25rem;
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    overflow: hidden;
}

.comments-panel__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.1rem 1.25rem;
    border-bottom: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--table-head-bg, var(--surface-soft, var(--surface, var(--bs-body-bg))));
}

.comments-panel__kicker {
    color: var(--primary, var(--bs-primary));
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.comments-panel__title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.comments-panel__count,
.comments-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid var(--pill-border, var(--border-color, var(--bs-border-color)));
    background: var(--pill-bg, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
    font-size: 0.72rem;
    font-weight: 500;
    line-height: 1;
    padding: 0.32rem 0.62rem;
    white-space: nowrap;
}

.comments-pill--gold {
    background: color-mix(in srgb, var(--bs-warning) 32%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-warning) 48%, var(--card-border, var(--bs-border-color)));
}

.comments-panel__body {
    padding: 1.25rem;
}

.comments-form {
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
    background: var(--surface-muted, var(--surface-soft, var(--surface, var(--bs-body-bg))));
    padding: 1rem;
}

.comments-textarea {
    min-height: 5.75rem;
    resize: vertical;
}

.comments-form__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.comments-pin-option {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.84rem;
}

.comments-list {
    display: grid;
    gap: 0.85rem;
}

.comment-card {
    display: grid;
    grid-template-columns: 0.32rem minmax(0, 1fr);
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
    background: var(--surface, var(--bs-body-bg));
    overflow: hidden;
}

.comment-card__accent {
    background: var(--bs-info, var(--primary, var(--bs-primary)));
}

.comment-card--pinned .comment-card__accent {
    background: var(--bs-warning, var(--primary, var(--bs-primary)));
}

.comment-card__content {
    padding: 0.95rem 1rem;
}

.comment-card__meta {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.55rem;
}

.comment-card__author {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.4rem;
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.9rem;
    font-weight: 600;
}

.comment-card__date {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.78rem;
    white-space: nowrap;
}

.comment-card__text {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.92rem;
    line-height: 1.55;
    overflow-wrap: anywhere;
}

.comment-card__edit summary {
    color: var(--primary, var(--bs-primary));
    cursor: pointer;
    font-size: 0.82rem;
    font-weight: 500;
}

.comments-empty {
    border: 1px dashed var(--table-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
    padding: 1.25rem;
    text-align: center;
    background: var(--surface-muted, var(--surface-soft, var(--surface, var(--bs-body-bg))));
}

.comments-empty__title {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 600;
}

.comments-empty__text {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.86rem;
    margin-top: 0.25rem;
}

@media (max-width: 575.98px) {
    .comments-panel__header,
    .comment-card__meta,
    .comments-form__footer {
        align-items: flex-start;
        flex-direction: column;
    }

    .comment-card__date {
        white-space: normal;
    }
}

/* ===== Shared record comments modal workflow refinements ===== */
.comments-panel__heading {
    min-width: 0;
}

.comments-panel__actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.comment-card__actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.comments-modal .modal-content {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color))) !important;
    border-radius: 1.15rem;
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
}

.comments-modal .modal-header,
.comments-modal .modal-footer {
    border-color: var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--table-head-bg, var(--surface-soft, var(--surface, var(--bs-body-bg))));
}

.comments-modal .modal-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.98rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}

.comments-modal .modal-body {
    background: var(--surface, var(--bs-body-bg));
}

.comments-modal .btn-close {
    color: var(--text-main, var(--bs-body-color));
}

@media (max-width: 575.98px) {
    .comments-panel__actions {
        justify-content: flex-start;
        width: 100%;
    }

    .comments-panel__actions .btn {
        width: 100%;
    }
}

/* ===== Shared record comments delete confirmation ===== */
.comments-delete-warning {
    border: 1px solid color-mix(in srgb, var(--bs-danger, #dc3545) 28%, var(--table-border, var(--border-color, var(--bs-border-color))));
    border-radius: 1rem;
    background: color-mix(in srgb, var(--bs-danger, #dc3545) 10%, var(--surface, var(--bs-body-bg)));
    padding: 1rem;
}

.comments-delete-warning__title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.95rem;
    font-weight: 600;
    line-height: 1.35;
}

.comments-delete-warning__text {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.86rem;
    margin-top: 0.25rem;
}

.comments-delete-modal .btn-outline-danger {
    font-weight: 400;
}

/* ===== Education schedule batch page ===== */
.schedule-batch-page {
    display: grid;
    gap: 0;
    color: var(--text-main);
    font-size: 0.96rem;
    line-height: 1.5;
}

.schedule-batch-hero,
.schedule-list-panel,
.schedule-state-panel,
.schedule-note-panel,
.schedule-metric-card {
    border: 1px solid var(--card-border);
    border-radius: 1.25rem;
    box-shadow: var(--card-shadow);
    overflow: hidden;
}

.schedule-batch-hero-accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary), var(--bs-info), var(--bs-warning));
}

.schedule-batch-hero-body {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.5rem;
}

.schedule-batch-hero-copy {
    min-width: 0;
}

.schedule-batch-kicker,
.schedule-date-kicker {
    color: var(--primary);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.schedule-batch-title {
    color: var(--text-main);
    font-size: clamp(1.5rem, 2.2vw, 2rem);
    font-weight: 700;
    letter-spacing: -0.03em;
}

.schedule-batch-subtitle,
.schedule-metric-hint,
.schedule-row-muted,
.schedule-row-note,
.schedule-session-meta-grid,
.schedule-session-note {
    color: var(--text-muted);
}

.schedule-batch-subtitle,
.schedule-note-text,
.schedule-row-note,
.schedule-session-note,
.schedule-form-guidance__copy {
    font-size: 0.94rem;
    line-height: 1.55;
}

.schedule-batch-meta-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem;
    color: var(--text-muted);
    font-size: 0.93rem;
    line-height: 1.45;
}

.schedule-batch-actions,
.schedule-bottom-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.schedule-action-warning,
.schedule-action-danger {
    border-radius: 0.85rem;
    font-weight: 600;
}

.schedule-action-warning {
    background: color-mix(in srgb, var(--bs-warning) 16%, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid color-mix(in srgb, var(--bs-warning) 42%, var(--table-border, var(--card-border)));
}

.schedule-action-warning:hover,
.schedule-action-warning:focus-visible {
    background: color-mix(in srgb, var(--bs-warning) 24%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-warning) 54%, var(--table-border, var(--card-border)));
    color: var(--text-main, var(--bs-body-color));
}

.schedule-action-danger {
    background: color-mix(in srgb, var(--bs-danger) 12%, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid color-mix(in srgb, var(--bs-danger) 36%, var(--table-border, var(--card-border)));
}

.schedule-action-danger:hover,
.schedule-action-danger:focus-visible {
    background: color-mix(in srgb, var(--bs-danger) 18%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-danger) 48%, var(--table-border, var(--card-border)));
    color: var(--text-main, var(--bs-body-color));
}

.schedule-metrics-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.schedule-metric-card {
    padding: 1.15rem;
}

.schedule-metric-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.7rem;
}

.schedule-metric-label {
    color: var(--text-muted);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.schedule-metric-dot {
    width: 0.6rem;
    height: 0.6rem;
    border-radius: 999px;
    box-shadow: 0 0 0 0.35rem var(--surface-muted);
    flex: 0 0 auto;
}

.schedule-dot-primary { background: var(--primary); }
.schedule-dot-info { background: var(--bs-info); }
.schedule-dot-warning { background: var(--bs-warning); }
.schedule-dot-danger { background: var(--bs-danger); }

.schedule-metric-value {
    color: var(--text-main);
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: -0.03em;
}

.schedule-metric-date,
.schedule-metric-text {
    font-size: 1.05rem;
}

.schedule-state-panel {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.25rem;
    border-left: 0.35rem solid var(--bs-info);
}

.schedule-state-panel-posted {
    border-left-color: var(--bs-warning);
}

.schedule-state-title,
.schedule-list-title,
.schedule-date-title,
.schedule-session-title,
.schedule-row-name {
    color: var(--text-main);
    font-weight: 700;
}

.schedule-state-title,
.schedule-list-title {
    font-size: 1.15rem;
    letter-spacing: -0.02em;
}

.schedule-date-title {
    font-size: 1.02rem;
    letter-spacing: -0.02em;
}

.schedule-session-title,
.schedule-row-name {
    font-size: 0.98rem;
    letter-spacing: -0.01em;
}

.schedule-note-panel {
    padding: 1.15rem;
}

.schedule-note-text {
    white-space: pre-line;
    color: var(--text-main);
    margin-top: 0.4rem;
}

.schedule-list-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.25rem;
    background: var(--surface);
    border-bottom: 1px solid var(--table-border);
}

.schedule-date-group-wrap {
    padding: 1.25rem;
    display: grid;
    gap: 1.25rem;
}

.schedule-date-group {
    border: 1px solid var(--table-border);
    border-radius: 1.1rem;
    overflow: hidden;
    background: var(--surface);
}

.schedule-date-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.25rem;
    background: var(--surface);
    border-bottom: 1px solid var(--table-border);
}

.schedule-session-list {
    display: grid;
}

.schedule-session-row {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(240px, 0.85fr);
    gap: 1.25rem;
    padding: 1.15rem 1.25rem;
    border-top: 1px solid var(--table-border);
}

.schedule-session-row:first-child {
    border-top: 0;
}

.schedule-session-row:hover {
    background: var(--table-row-hover);
}

.schedule-session-main {
    display: grid;
    grid-template-columns: 0.35rem minmax(0, 1fr);
    gap: 0.9rem;
    min-width: 0;
}

.schedule-session-accent {
    border-radius: 999px;
    background: var(--bs-info);
}

.schedule-session-title-row,
.schedule-teacher-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.schedule-session-meta-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.35rem 0.9rem;
    margin-top: 0.65rem;
    font-size: 0.93rem;
    line-height: 1.45;
}

.schedule-session-meta-grid span {
    color: var(--text-main);
    font-weight: 600;
}

.schedule-session-note {
    margin-top: 0.65rem;
    font-size: 0.94rem;
}

.schedule-session-teachers {
    min-width: 0;
    overflow-wrap: anywhere;
}

.schedule-teacher-head {
    margin-bottom: 0.6rem;
    color: var(--text-muted);
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.schedule-teacher-check-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.7rem;
    min-width: 0;
}

.schedule-teacher-check {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    border: 1px solid var(--table-border);
    border-radius: 1rem;
    background: var(--surface);
    color: var(--text-main);
    padding: 0.8rem 0.9rem;
    min-height: 4rem;
    transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.schedule-teacher-check:hover {
    background: var(--table-row-hover);
    border-color: color-mix(in srgb, var(--primary) 30%, var(--table-border));
    transform: translateY(-1px);
}

.schedule-teacher-check input[type="checkbox"] {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.schedule-teacher-check__body {
    display: grid;
    gap: 0.18rem;
    min-width: 0;
    flex: 1 1 auto;
}

.schedule-teacher-check__name {
    color: var(--text-main);
    font-size: 0.95rem;
    font-weight: 600;
    line-height: 1.35;
}

.schedule-teacher-check__meta {
    color: var(--text-muted);
    font-size: 0.8rem;
    line-height: 1.3;
}

.schedule-teacher-check__indicator {
    width: 0.9rem;
    height: 0.9rem;
    margin-top: 0.25rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--primary) 22%, var(--table-border));
    background: var(--surface-muted);
    box-shadow: inset 0 0 0 0.2rem var(--surface);
    flex: 0 0 auto;
}

.schedule-teacher-check:has(input[type="checkbox"]:checked) {
    background: color-mix(in srgb, var(--primary-soft) 72%, var(--surface));
    border-color: color-mix(in srgb, var(--primary) 36%, var(--table-border));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--primary) 16%, transparent);
}

.schedule-teacher-check:has(input[type="checkbox"]:checked) .schedule-teacher-check__indicator {
    background: var(--primary);
    border-color: var(--primary);
    box-shadow: inset 0 0 0 0.2rem color-mix(in srgb, var(--surface) 82%, transparent);
}

.schedule-teacher-pill-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    min-width: 0;
}

.schedule-status-pill,
.schedule-teacher-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    border: 1px solid var(--table-border);
    padding: 0.32rem 0.7rem;
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1.2;
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--surface) 70%, transparent);
}

.schedule-status-pill-draft {
    background: color-mix(in srgb, var(--bs-warning) 18%, var(--surface, var(--bs-body-bg)));
    color: var(--text-main);
    border-color: color-mix(in srgb, var(--bs-warning) 48%, var(--table-border));
}

.schedule-status-pill-count {
    background: color-mix(in srgb, var(--primary) 16%, var(--surface, var(--bs-body-bg)));
    color: var(--text-main);
    border-color: color-mix(in srgb, var(--primary) 42%, var(--table-border));
}

.schedule-status-pill-date {
    background: color-mix(in srgb, var(--bs-info) 14%, var(--surface, var(--bs-body-bg)));
    color: var(--text-main);
    border-color: color-mix(in srgb, var(--bs-info) 40%, var(--table-border));
}

.schedule-status-pill-soft {
    background: color-mix(in srgb, var(--bs-secondary) 14%, var(--surface, var(--bs-body-bg)));
    color: var(--text-main);
    border-color: color-mix(in srgb, var(--bs-secondary) 42%, var(--table-border));
}

.schedule-status-pill-selection {
    background: color-mix(in srgb, var(--bs-warning) 16%, var(--surface, var(--bs-body-bg)));
    color: var(--text-main);
    border-color: color-mix(in srgb, var(--bs-warning) 44%, var(--table-border));
}

.schedule-teacher-pill {
    background: color-mix(in srgb, var(--bs-danger) 12%, var(--surface, var(--bs-body-bg)));
    color: var(--text-main);
    border-color: color-mix(in srgb, var(--bs-danger) 36%, var(--table-border));
}

.schedule-status-pill-posted {
    background: color-mix(in srgb, var(--bs-success) 18%, var(--surface, var(--bs-body-bg)));
    color: var(--text-main);
    border-color: color-mix(in srgb, var(--bs-success) 48%, var(--table-border));
}

.schedule-batch-table-wrap {
    overflow-x: auto;
}

.schedule-batch-table-head,
.schedule-batch-row {
    display: grid;
    grid-template-columns: minmax(220px, 1.2fr) minmax(190px, 0.85fr) 110px minmax(150px, 0.75fr) minmax(220px, 0.9fr);
    gap: 1rem;
    align-items: center;
    min-width: 950px;
}

.schedule-batch-table-head {
    background: var(--table-head-bg);
    color: var(--text-muted);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0.85rem 1.25rem;
}

.schedule-batch-row {
    padding: 1rem 1.25rem;
    border-top: 1px solid var(--table-border);
}

.schedule-batch-row:hover {
    background: var(--table-row-hover);
}

.schedule-row-actions {
    display: flex;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.schedule-row-locked {
    display: inline-flex;
    align-items: center;
    border-radius: 0.75rem;
    padding: 0.42rem 0.65rem;
    color: var(--text-muted);
    background: var(--surface-muted);
    border: 1px solid var(--table-border);
    font-size: 0.82rem;
    font-weight: 600;
}

.schedule-empty-state {
    padding: 2.5rem 1.25rem;
    text-align: center;
    color: var(--text-muted);
}

.schedule-bottom-actions {
    margin-top: 1rem;
    justify-content: flex-end;
    padding: 1rem 1.25rem 1.25rem;
}

.schedule-program-picker {
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: var(--surface-muted, var(--surface-soft, var(--surface)));
    padding: 1rem;
}

.schedule-program-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
}

.schedule-program-option {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    margin: 0;
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 0.95rem;
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    padding: 0.75rem 0.85rem;
    min-height: 3.1rem;
    transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

.schedule-program-option .fw-medium {
    font-size: 0.94rem;
    font-weight: 600 !important;
    line-height: 1.35;
}

.schedule-program-option:hover {
    background: var(--table-row-hover, var(--surface-soft));
    border-color: var(--primary, var(--bs-primary));
    transform: translateY(-1px);
}

.schedule-program-option input[type="checkbox"] {
    accent-color: var(--primary, var(--bs-primary));
    margin-top: 0.2rem;
    flex: 0 0 auto;
}

.schedule-program-option:has(input[type="checkbox"]:checked) {
    background: var(--primary-soft, var(--surface-soft, var(--surface)));
    border-color: color-mix(in srgb, var(--primary, var(--bs-primary)) 40%, var(--table-border, var(--card-border)));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--primary, var(--bs-primary)) 24%, transparent);
}

.schedule-batch-form-page {
    display: flex;
    flex-direction: column;
}

.schedule-form-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.3fr) minmax(280px, 0.8fr);
    gap: 1.25rem;
    align-items: start;
}

.schedule-form-panel {
    border: 1px solid var(--card-border, var(--table-border));
    border-radius: 1.25rem;
    overflow: hidden;
    box-shadow: var(--card-shadow);
}

.schedule-form-panel__header {
    padding: 1.15rem 1.25rem;
    border-bottom: 1px solid var(--table-border, var(--card-border));
    background: var(--table-head-bg, var(--surface-soft));
}

.schedule-form-panel__body {
    padding: 1.25rem;
}

.schedule-form-side {
    display: grid;
    gap: 1rem;
    align-self: start;
}

.schedule-form-panel .form-label {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 600;
    font-size: 0.93rem;
}

.schedule-form-panel .form-control,
.schedule-form-panel .form-select,
.schedule-batch-page .btn,
.schedule-row-muted {
    font-size: 0.94rem;
}

.schedule-batch-page .modal-header,
.schedule-batch-page .modal-footer {
    background: var(--table-head-bg, var(--surface-soft));
    border-color: var(--table-border, var(--card-border));
}

.schedule-batch-page .modal-body {
    background: var(--surface, var(--bs-body-bg));
}

.schedule-form-guidance {
    display: grid;
    gap: 0.75rem;
    margin-top: 0.9rem;
}

.schedule-form-guidance__item {
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: var(--surface-muted, var(--surface-soft, var(--surface)));
    padding: 0.9rem 1rem;
}

.schedule-form-guidance__title {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 700;
    margin-bottom: 0.2rem;
}

.schedule-form-guidance__copy {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.94rem;
}

@media (max-width: 991.98px) {
    .schedule-batch-hero-body,
    .schedule-state-panel,
    .schedule-list-header,
    .schedule-date-heading {
        align-items: stretch;
        flex-direction: column;
    }

    .schedule-batch-actions,
    .schedule-bottom-actions {
        justify-content: flex-start;
    }

    .schedule-metrics-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .schedule-session-row {
        grid-template-columns: 1fr;
    }

    .schedule-form-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575.98px) {
    .schedule-metrics-grid,
    .schedule-session-meta-grid,
    .schedule-teacher-check-grid,
    .schedule-program-grid {
        grid-template-columns: 1fr;
    }
}


/* ===== Education dashboard theme refresh ===== */

.edu-dashboard-hero,
.edu-panel,
.edu-metric-card {
    border: 1px solid var(--card-border);
    border-radius: 1.25rem;
    box-shadow: var(--card-shadow);
    overflow: hidden;
}

.edu-dashboard-hero-accent {
    height: 0.45rem;
    background: linear-gradient(90deg, var(--primary), var(--bs-info), var(--bs-warning));
}

.edu-dashboard-hero-body {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
    flex-wrap: wrap;
    padding: 1.5rem;
}

.edu-dashboard-kicker {
    color: var(--primary);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.edu-dashboard-title {
    color: var(--text-main);
    font-size: clamp(1.75rem, 2.4vw, 2.35rem);
    font-weight: 700;
    line-height: 1.12;
    letter-spacing: -0.035em;
    margin: 0.25rem 0 0;
}

.edu-dashboard-subtitle,
.edu-panel-subtitle,
.edu-side-subtitle,
.edu-row-subtitle,
.edu-attention-detail,
.edu-batch-meta {
    color: var(--text-muted);
}

.edu-dashboard-subtitle {
    max-width: 44rem;
    font-size: 0.95rem;
    line-height: 1.65;
    margin: 0.55rem 0 0;
}

.edu-dashboard-actions {
    display: flex;
    gap: 0.55rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.edu-dashboard-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.edu-metric-card {
    padding: 1.15rem;
    position: relative;
}

.edu-metric-card::after {
    content: "";
    position: absolute;
    top: 1.2rem;
    right: 1.2rem;
    width: 0.7rem;
    height: 0.7rem;
    border-radius: 999px;
    box-shadow: 0 0 0 0.35rem var(--surface-strong);
    background: var(--edu-accent);
}

.edu-metric-label {
    color: var(--text-muted);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding-right: 1.5rem;
}

.edu-metric-value {
    color: var(--text-main);
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.04em;
    margin-top: 0.6rem;
}

.edu-metric-hint {
    color: var(--text-muted);
    font-size: 0.78rem;
    margin-top: 0.25rem;
}

.edu-dashboard-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(360px, 0.85fr);
    gap: 1.25rem;
    align-items: start;
}

.edu-dashboard-main,
.edu-dashboard-side {
    display: grid;
    gap: 1.25rem;
}

.edu-panel {
    background: var(--surface);
}

.edu-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    padding: 1.15rem 1.25rem;
    border-bottom: 1px solid var(--table-border);
    background: var(--table-head-bg);
}

.edu-panel-header-compact {
    padding: 1rem 1.15rem;
}

.edu-panel-header--plain {
    background: transparent;
}

.edu-panel-title {
    color: var(--text-main);
    font-size: 1.1rem;
    font-weight: 700;
    margin: 0.25rem 0 0;
}

.edu-panel-subtitle {
    margin: 0.25rem 0 0;
    font-size: 0.86rem;
}

.edu-pill {
    display: inline-flex;
    align-items: center;
    width: max-content;
    border: 1px solid var(--pill-border);
    border-radius: 999px;
    padding: 0.22rem 0.58rem;
    font-size: 0.7rem;
    font-weight: 600;
    line-height: 1.1;
    background: var(--pill-bg);
    color: var(--primary);
}

.edu-pill-blue {
    background: color-mix(in srgb, var(--bs-info) 14%, var(--surface));
    border-color: color-mix(in srgb, var(--bs-info) 40%, var(--card-border));
}

.edu-pill-green {
    background: color-mix(in srgb, var(--bs-success) 18%, var(--surface));
    border-color: color-mix(in srgb, var(--bs-success) 42%, var(--card-border));
}

.edu-pill-gold {
    background: color-mix(in srgb, var(--bs-warning) 24%, var(--surface));
    border-color: color-mix(in srgb, var(--bs-warning) 46%, var(--card-border));
}

.edu-pill-coral {
    background: color-mix(in srgb, var(--bs-danger) 18%, var(--surface));
    border-color: color-mix(in srgb, var(--bs-danger) 42%, var(--card-border));
}

.edu-accent-blue {
    --edu-accent: var(--bs-info);
}

.edu-accent-green {
    --edu-accent: var(--bs-success);
}

.edu-accent-gold {
    --edu-accent: var(--bs-warning);
}

.edu-accent-coral {
    --edu-accent: var(--bs-danger);
}

.edu-tool-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    padding: 1.25rem;
}

.edu-tool-grid--primary {
    grid-template-columns: repeat(auto-fit, minmax(17rem, 1fr));
    gap: 1.1rem;
}

.edu-tool-card,
.edu-attention-item,
.edu-batch-item,
.edu-session-row {
    color: inherit;
    text-decoration: none;
}

.edu-tool-card {
    display: grid;
    grid-template-columns: minmax(0, 6.4rem) minmax(0, 1fr);
    align-items: start;
    gap: 1rem;
    border: 1px solid var(--table-border);
    border-left: 0.28rem solid var(--table-border);
    border-radius: 1.15rem;
    padding: 1rem;
    background: var(--surface);
    min-height: 11.25rem;
    box-shadow: var(--card-shadow);
    transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.edu-tool-card:hover {
    color: inherit;
    background: var(--table-row-hover);
    border-color: var(--table-border);
    transform: translateY(-2px);
    box-shadow: 0 18px 34px rgba(15, 23, 42, 0.10);
}

.edu-attention-item:hover,
.edu-batch-item:hover,
.edu-session-row:hover,
.edu-program-row:hover {
    color: inherit;
    background: var(--table-row-hover);
    border-color: var(--table-border);
}

.edu-tool-icon {
    width: 5.9rem;
    height: 5.9rem;
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.edu-tool-icon-img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
    object-position: center;
}

.edu-tool-copy {
    display: block;
    min-width: 0;
}

.edu-tool-title,
.edu-row-title,
.edu-attention-title,
.edu-batch-title {
    color: var(--text-main);
    font-weight: 700;
}

.edu-tool-title {
    display: block;
    margin-bottom: 0.25rem;
}

.edu-tool-desc {
    display: block;
    color: var(--text-muted);
    font-size: 0.86rem;
    line-height: 1.55;
}

.edu-tool-card .btn-outline-secondary {
    border-color: var(--table-border);
    background: var(--table-head-bg);
}

.edu-table-scroll {
    overflow-x: auto;
}

.edu-program-table {
    min-width: 820px;
}

.edu-program-table-head,
.edu-program-row {
    display: grid;
    grid-template-columns: 1.25fr 100px 110px 110px 120px 90px;
    align-items: center;
    gap: 0.8rem;
}

.edu-program-table-head {
    background: var(--table-head-bg);
    color: var(--text-muted);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0.75rem 1.25rem;
}

.edu-program-row {
    border-top: 1px solid var(--table-border);
    color: var(--text-muted);
    font-size: 0.9rem;
    padding: 0.95rem 1.25rem;
}

.edu-row-primary {
    border-left: 0;
    padding-left: 0;
    min-width: 0;
}

.edu-row-subtitle {
    font-size: 0.76rem;
    margin-top: 0.12rem;
}

.edu-session-list {
    display: grid;
}

.edu-session-row {
    display: grid;
    grid-template-columns: 110px minmax(0, 1.2fr) minmax(0, 1fr) 150px;
    align-items: center;
    gap: 1rem;
    border-top: 1px solid var(--table-border);
    padding: 1rem 1.25rem;
}

.edu-session-row:first-child {
    border-top: 0;
}

.edu-session-class {
    border-left: 0;
    padding-left: 0;
    min-width: 0;
}

.edu-session-date,
.edu-session-class,
.edu-session-teachers {
    display: grid;
    min-width: 0;
}

.edu-session-teachers {
    color: var(--text-muted);
    font-size: 0.85rem;
}

.edu-side-title-row {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    padding: 1.15rem 1.25rem;
    border-bottom: 1px solid var(--table-border);
    background: var(--table-head-bg);
}

.edu-side-title-row--plain {
    background: transparent;
}

.edu-side-accent {
    width: 0.36rem;
    height: 2rem;
    border-radius: 999px;
    background: var(--bs-warning);
    flex: 0 0 auto;
}

.edu-side-title {
    color: var(--text-main);
    font-size: 0.88rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin: 0;
}

.edu-side-subtitle {
    font-size: 0.76rem;
    margin: 0.2rem 0 0;
}

.edu-attention-list,
.edu-batch-list {
    display: grid;
    gap: 0.75rem;
    padding: 1rem;
}

.edu-attention-item,
.edu-batch-item {
    display: grid;
    gap: 0.35rem;
    border: 1px solid var(--table-border);
    border-radius: 1rem;
    background: var(--surface);
    padding: 0.95rem;
    transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

.edu-attention-title {
    font-size: 0.9rem;
}

.edu-attention-detail,
.edu-batch-meta {
    font-size: 0.78rem;
    line-height: 1.55;
}

@media (max-width: 1199.98px) {
    .edu-dashboard-layout {
        grid-template-columns: 1fr;
    }

    .edu-dashboard-side {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .edu-dashboard-metrics,
    .edu-tool-grid,
    .edu-dashboard-side {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .edu-session-row {
        grid-template-columns: 1fr;
        gap: 0.55rem;
    }
}

@media (max-width: 767.98px) {
    .edu-dashboard-hero-body,
    .edu-panel-header {
        align-items: stretch;
    }

    .edu-dashboard-actions,
    .edu-panel-header .btn {
        width: 100%;
    }

    .edu-dashboard-actions .btn,
    .edu-panel-header .btn {
        justify-content: center;
    }

    .edu-dashboard-metrics,
    .edu-tool-grid,
    .edu-dashboard-side {
        grid-template-columns: 1fr;
    }

    .edu-tool-card {
        grid-template-columns: 5.4rem minmax(0, 1fr);
        min-height: 9.75rem;
        padding: 1rem;
        gap: 0.95rem;
    }

    .edu-tool-icon {
        width: 5.4rem;
        height: 5.4rem;
    }

    .edu-program-table {
        min-width: 760px;
    }
}



/* ===== Education class detail themed layout ===== */
.class-detail-page {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.class-detail-shell,
.class-detail-panel,
.class-detail-metric,
.class-detail-card {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    border-radius: 1.25rem;
}

.class-detail-hero {
    overflow: hidden;
}

.class-detail-hero__accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-warning));
}

.class-detail-hero__body {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.5rem;
}

.class-detail-kicker,
.class-detail-section-kicker {
    color: var(--primary, var(--bs-primary));
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.11em;
    text-transform: uppercase;
}

.class-detail-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.75rem, 2.2vw, 2.35rem);
    font-weight: 700;
    letter-spacing: -0.03em;
    margin: 0.15rem 0 0;
}

.class-detail-subtitle,
.class-detail-muted {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.class-detail-actions,
.class-detail-inline-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.class-detail-meta-line {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
    margin-top: 0.75rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.9rem;
}

.class-detail-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.class-detail-metric {
    padding: 1.25rem;
}

.class-detail-metric__top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.class-detail-metric__label,
.class-detail-table-head,
.class-detail-info-label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.class-detail-metric__value {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.7rem;
    font-weight: 700;
    letter-spacing: -0.03em;
}

.class-detail-metric__hint {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.82rem;
    margin-top: 0.2rem;
}

.class-detail-dot {
    width: 0.7rem;
    height: 0.7rem;
    border-radius: 999px;
    box-shadow: 0 0 0 0.25rem var(--surface, var(--bs-body-bg));
    background: var(--primary, var(--bs-primary));
}

.class-detail-dot--green { background: var(--bs-success, var(--primary)); }
.class-detail-dot--gold { background: var(--bs-warning, var(--primary)); }
.class-detail-dot--coral { background: var(--bs-danger, var(--primary)); }

.class-detail-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
    margin-top: 1rem;
}

.class-detail-info-card {
    border: 1px solid var(--table-border, var(--card-border));
    background: var(--table-head-bg, var(--surface-soft));
    border-radius: 1rem;
    padding: 0.9rem 1rem;
}

.class-detail-info-value {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 600;
    margin-top: 0.2rem;
}

.class-detail-main-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(340px, 0.85fr);
    gap: 1.25rem;
    align-items: start;
}

.class-detail-stack {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.class-detail-panel {
    overflow: hidden;
}

.class-detail-panel__header {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.25rem;
    background: var(--table-head-bg, var(--surface-soft));
    border-bottom: 1px solid var(--table-border, var(--card-border));
}

.class-detail-panel__body {
    padding: 1.25rem;
}

.class-detail-panel-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.05rem;
    font-weight: 700;
    margin: 0.15rem 0 0;
}

.class-detail-row-list {
    display: flex;
    flex-direction: column;
}

.class-detail-list-row {
    display: grid;
    grid-template-columns: 110px minmax(0, 1.25fr) minmax(220px, 0.95fr) 150px minmax(110px, auto);
    gap: 0.8rem;
    align-items: center;
    padding: 1rem 1.25rem;
    border-top: 1px solid var(--table-border, var(--card-border));
}

.class-detail-list-row:first-child {
    border-top: 0;
}

.class-detail-list-row:hover,
.class-detail-table-row:hover,
.class-detail-teacher-card:hover {
    background: var(--table-row-hover, var(--surface-soft));
}

.class-detail-row-title,
.class-detail-name {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 700;
}

.class-detail-row-sub {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.82rem;
    margin-top: 0.12rem;
}

.class-detail-accent-line {
    border-left: 4px solid var(--primary, var(--bs-primary));
    padding-left: 0.8rem;
}

.class-detail-accent-line--green { border-left-color: var(--bs-success, var(--primary)); }
.class-detail-accent-line--gold { border-left-color: var(--bs-warning, var(--primary)); }
.class-detail-accent-line--coral { border-left-color: var(--bs-danger, var(--primary)); }

.class-detail-table-scroll {
    overflow-x: auto;
}

.class-detail-roster-table {
    min-width: 780px;
}

.class-detail-table-head,
.class-detail-table-row {
    display: grid;
    grid-template-columns: 72px minmax(220px, 1.4fr) 90px 120px 130px 95px;
    gap: 0.85rem;
    align-items: center;
    padding: 0.9rem 1.25rem;
}

.class-detail-table-head {
    background: var(--table-head-bg, var(--surface-soft));
}

.class-detail-table-row {
    border-top: 1px solid var(--table-border, var(--card-border));
    color: var(--text-main, var(--bs-body-color));
}

.class-detail-teacher-card,
.class-detail-action-card {
    border: 1px solid var(--table-border, var(--card-border));
    border-left: 4px solid var(--primary, var(--bs-primary));
    border-radius: 1rem;
    padding: 1rem;
    background: var(--surface, var(--bs-body-bg));
}

.class-detail-action-card {
    background: var(--table-head-bg, var(--surface-soft));
}

.class-detail-side-accent {
    width: 0.38rem;
    height: 2rem;
    border-radius: 999px;
    background: var(--bs-warning, var(--primary));
    flex: 0 0 auto;
}

.class-detail-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    border-radius: 999px;
    border: 1px solid var(--pill-border, var(--card-border));
    background: var(--pill-bg, var(--surface));
    color: var(--primary, var(--bs-primary));
    padding: 0.28rem 0.58rem;
    font-size: 0.72rem;
    font-weight: 600;
    white-space: nowrap;
}

.class-detail-pill--soft { background: var(--surface-soft, var(--surface)); color: var(--text-main, var(--bs-body-color)); }
.class-detail-pill--blue {
    background: color-mix(in srgb, var(--bs-info) 18%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-info) 42%, var(--card-border, var(--bs-border-color)));
}
.class-detail-pill--green { background: var(--success-soft, var(--surface-soft)); }
.class-detail-pill--gold { background: var(--warning-soft, var(--surface-soft)); }
.class-detail-pill--coral { background: var(--danger-soft, var(--surface-soft)); }

.class-detail-empty {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    text-align: center;
    padding: 2rem 1rem;
}

.class-detail-chart-wrap {
    height: 280px;
}

@media (max-width: 1199.98px) {
    .class-detail-main-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991.98px) {
    .class-detail-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .class-detail-info-grid {
        grid-template-columns: 1fr;
    }
    .class-detail-list-row {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575.98px) {
    .class-detail-hero__body,
    .class-detail-panel__header,
    .class-detail-panel__body {
        padding: 1rem;
    }
    .class-detail-metrics {
        grid-template-columns: 1fr;
    }
}


/* ===== Education person picker and class-detail assignment tools ===== */
.person-picker-shell {
    position: relative;
    z-index: 4;
}

.person-picker-results {
    position: absolute;
    top: calc(100% + 0.35rem);
    left: 0;
    right: 0;
    z-index: 80;
    max-height: 260px;
    overflow: auto;
    border: 1px solid var(--border-color, rgba(0,0,0,.08));
    border-radius: 0.85rem;
    background: var(--surface, var(--bs-body-bg));
    box-shadow: var(--card-shadow, 0 10px 24px rgba(0,0,0,.12));
    display: none;
}

.person-picker-results.is-open {
    display: block;
}

.person-picker-option {
    width: 100%;
    border: 0;
    background: transparent;
    text-align: left;
    padding: 0.75rem 0.9rem;
    border-bottom: 1px solid var(--border-color, rgba(0,0,0,.06));
    color: var(--text-main, var(--bs-body-color));
}

.person-picker-option:last-child {
    border-bottom: 0;
}

.person-picker-option:hover,
.person-picker-option:focus {
    background: var(--table-row-hover, var(--surface-soft));
}

.person-picker-title {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 600;
}

.person-picker-subtitle {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.85rem;
}

.person-picker-selected {
    display: none;
    margin-top: 0.5rem;
    padding: 0.65rem 0.8rem;
    border-radius: 0.85rem;
    border: 1px solid var(--border-color, rgba(0,0,0,.08));
    background: var(--surface-soft, var(--surface));
}

.person-picker-selected.is-visible {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
}

.person-picker-empty {
    padding: 0.75rem 0.9rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.student-filter-shell .student-filter-input {
    margin-bottom: 0.85rem;
}

.student-filter-grid {
    max-height: 360px;
    overflow: auto;
    padding-right: 0.2rem;
}

.student-choice.is-hidden {
    display: none !important;
}


/* ===== Class detail cleanup refinements ===== */
.class-detail-info-grid--wide {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.class-detail-list-row--schedule {
    grid-template-columns: 110px minmax(0, 1.25fr) minmax(220px, 0.95fr) 130px minmax(110px, auto);
}

.class-detail-card-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 1rem 1.25rem;
}

.class-detail-person-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: var(--surface, var(--bs-body-bg));
    padding: 0.85rem 1rem;
}

.class-detail-table td,
.class-detail-table th {
    vertical-align: middle;
}

@media (max-width: 1199.98px) {
    .class-detail-info-grid--wide {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .class-detail-info-grid--wide {
        grid-template-columns: 1fr;
    }
    .class-detail-list-row--schedule {
        grid-template-columns: 1fr;
    }
    .class-detail-person-card {
        align-items: flex-start;
        flex-direction: column;
    }
}


/* ===== Professional student manager modal ===== */
.student-manager-summary-card .class-detail-panel__body {
    display: flex;
    flex-direction: column;
}

.student-manager-summary-grid,
.student-manager-stats {
    display: grid;
    gap: 0.75rem;
}

.student-manager-summary-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.student-manager-stats {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.student-manager-summary-item,
.student-manager-stat {
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: var(--surface-muted, var(--surface-soft));
    padding: 0.85rem;
}

.student-manager-summary-label,
.student-manager-stat__label {
    display: block;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.student-manager-summary-value,
.student-manager-stat__value {
    display: block;
    margin-top: 0.25rem;
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.student-manager-modal__header {
    align-items: flex-start;
    border-bottom-color: var(--table-border, var(--card-border));
    background: linear-gradient(
        180deg,
        color-mix(in srgb, var(--surface-soft, var(--table-head-bg)) 82%, var(--surface, var(--bs-body-bg)) 18%),
        var(--surface, var(--bs-body-bg))
    );
    padding: 1.15rem 1.25rem;
}

.student-manager-modal__dialog {
    max-width: min(1180px, calc(100vw - 1.5rem));
}

.student-manager-modal__content {
    overflow: visible;
    border-radius: 1.3rem;
    box-shadow: var(--card-shadow, 0 18px 42px rgba(0, 0, 0, 0.14));
}

.student-manager-modal__body {
    overflow: visible;
    padding: 1.25rem;
    background:
        radial-gradient(circle at top right, color-mix(in srgb, var(--primary-soft) 55%, transparent) 0, transparent 42%),
        var(--surface, var(--bs-body-bg));
}

.student-manager-modal .modal-content,
.student-manager-modal .tab-content,
.student-manager-modal .tab-pane {
    overflow: visible;
}

.student-manager-tabs {
    gap: 0.5rem;
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: color-mix(in srgb, var(--surface-soft, var(--table-head-bg)) 78%, var(--surface, var(--bs-body-bg)) 22%);
    padding: 0.35rem;
}

.student-manager-tabs .nav-link {
    border-radius: 0.8rem;
    color: var(--text-muted, var(--bs-secondary-color));
    font-size: 0.88rem;
    font-weight: 600;
}

.student-manager-tabs .nav-link.active {
    background: var(--primary, var(--bs-primary));
    color: #ffffff;
}

.student-manager-pane-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.student-manager-pane-header + .person-picker-shell,
.student-manager-pane-header + .student-manager-choice-grid,
.student-manager-pane-header + .student-filter-input {
    position: relative;
    z-index: 2;
}

.student-manager-pane-title {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 700;
    margin-bottom: 0.2rem;
}

.student-manager-choice-grid {
    max-height: 360px;
    overflow: auto;
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: color-mix(in srgb, var(--surface, var(--bs-body-bg)) 88%, var(--surface-soft, var(--table-head-bg)) 12%);
    padding: 0.75rem;
}

.student-manager-choice-grid ul {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.student-manager-choice-grid li,
.student-manager-choice-grid label {
    margin: 0;
}

.student-manager-choice-grid label {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    width: 100%;
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 0.85rem;
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    padding: 0.65rem 0.75rem;
    transition: background 0.18s ease, border-color 0.18s ease;
}

.student-manager-choice-grid label:hover {
    background: var(--table-row-hover, var(--surface-soft));
    border-color: var(--primary, var(--bs-primary));
}

.student-manager-choice-grid input[type="checkbox"] {
    flex: 0 0 auto;
}

.student-manager-assigned-list {
    display: grid;
    gap: 0.75rem;
}

.student-manager-assigned-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: color-mix(in srgb, var(--surface, var(--bs-body-bg)) 90%, var(--surface-soft, var(--table-head-bg)) 10%);
    padding: 0.85rem 1rem;
}

@media (max-width: 991.98px) {
    .student-manager-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .student-manager-choice-grid ul {
        grid-template-columns: 1fr;
    }

    .student-manager-pane-header,
    .student-manager-assigned-row {
        align-items: stretch;
        flex-direction: column;
    }
}

@media (max-width: 575.98px) {
    .student-manager-summary-grid,
    .student-manager-stats {
        grid-template-columns: 1fr;
    }

    .student-manager-tabs {
        align-items: stretch;
        flex-direction: column;
    }

    .student-manager-tabs .nav-item,
    .student-manager-tabs .nav-link {
        width: 100%;
    }
}


/* ===== Attendance session themed experience ===== */
.attendance-session-page,
.attendance-session-form-page {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.attendance-session-hero,
.attendance-session-panel,
.attendance-session-stat-card {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1.25rem;
    box-shadow: var(--card-shadow, none);
}

.attendance-session-hero {
    overflow: hidden;
}

.attendance-session-hero__accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-warning));
}

.attendance-session-hero__body {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.5rem;
}

.attendance-session-hero__content {
    flex: 1 1 480px;
}

.attendance-session-hero--compact .attendance-session-hero__content {
    flex-basis: 420px;
}

.attendance-session-kicker,
.attendance-session-section-kicker {
    color: var(--primary, var(--bs-primary));
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.11em;
    text-transform: uppercase;
}

.attendance-session-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.8rem, 2.3vw, 2.45rem);
    font-weight: 700;
    letter-spacing: -0.03em;
    margin: 0.2rem 0 0;
}

.attendance-session-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 0.75rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.94rem;
}

.attendance-session-actions,
.attendance-session-pill-row,
.attendance-session-quick-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.attendance-session-summary-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: stretch;
}

.attendance-session-note {
    margin-top: 1rem;
    padding: 1rem 1.1rem;
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: var(--surface-soft, var(--surface));
}

.attendance-session-note__label {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.attendance-session-note__text {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    margin-top: 0.4rem;
}

.attendance-session-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    border-radius: 999px;
    border: 1px solid var(--pill-border, var(--card-border));
    background: var(--pill-bg, var(--surface));
    color: var(--primary, var(--bs-primary));
    padding: 0.32rem 0.68rem;
    font-size: 0.75rem;
    font-weight: 700;
}

.attendance-session-pill--soft {
    background: var(--surface-soft, var(--surface));
    color: var(--text-main, var(--bs-body-color));
}

.attendance-session-pill--blue {
    background: color-mix(in srgb, var(--bs-info) 18%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-info) 42%, var(--card-border, var(--bs-border-color)));
}

.attendance-session-pill--green {
    background: color-mix(in srgb, var(--bs-success) 20%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-success) 42%, var(--card-border, var(--bs-border-color)));
}

.attendance-session-pill--gold {
    background: color-mix(in srgb, var(--bs-warning) 24%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-warning) 46%, var(--card-border, var(--bs-border-color)));
}

.attendance-session-metric {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem;
    min-width: 0;
    flex: 1 1 180px;
    padding: 0.9rem 1rem;
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: var(--surface, var(--bs-body-bg));
}

.attendance-session-metric__label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.attendance-session-metric__value {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1;
    white-space: nowrap;
}

.attendance-session-metric--success {
    background: color-mix(in srgb, var(--bs-success) 11%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-success) 35%, var(--card-border, var(--bs-border-color)));
}

.attendance-session-metric--coral {
    background: color-mix(in srgb, var(--bs-danger) 10%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-danger) 35%, var(--card-border, var(--bs-border-color)));
}

.attendance-session-metric--blue {
    background: color-mix(in srgb, var(--bs-info) 10%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-info) 35%, var(--card-border, var(--bs-border-color)));
}

.attendance-session-metric--gold {
    background: color-mix(in srgb, var(--bs-warning) 14%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-warning) 40%, var(--card-border, var(--bs-border-color)));
}

.attendance-session-metric--amber {
    background: color-mix(in srgb, var(--theme-education, var(--bs-primary)) 12%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--theme-education, var(--bs-primary)) 34%, var(--card-border, var(--bs-border-color)));
}

.attendance-session-panel {
    overflow: hidden;
}

.attendance-session-panel__header {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.25rem;
    background: transparent;
    border-bottom: 1px solid var(--table-border, var(--card-border));
}

.attendance-session-panel__body {
    padding: 1.25rem;
}

.attendance-session-quick-actions--header {
    justify-content: flex-end;
}

.attendance-session-panel__title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.08rem;
    font-weight: 700;
    margin: 0.15rem 0 0;
}

.attendance-session-panel__subtitle,
.attendance-session-selected__copy,
.attendance-session-empty__copy {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    margin: 0.35rem 0 0;
}

.attendance-session-teacher-toolbar {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.attendance-session-search {
    flex: 1 1 320px;
}

.attendance-session-teacher-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.attendance-session-summary-chip {
    min-width: 124px;
    padding: 0.8rem 0.9rem;
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: var(--surface-soft, var(--surface));
}

.attendance-session-summary-chip__label {
    display: block;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.attendance-session-summary-chip__value {
    display: block;
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.25rem;
    font-weight: 700;
    margin-top: 0.2rem;
}

.attendance-session-teacher-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.attendance-session-teacher-card {
    display: block;
    margin: 0;
    cursor: pointer;
}

.attendance-session-teacher-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.attendance-session-teacher-card__body {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    height: 100%;
    padding: 1rem;
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: var(--surface, var(--bs-body-bg));
    transition: border-color 0.18s ease, background 0.18s ease, transform 0.18s ease;
}

.attendance-session-teacher-card:hover .attendance-session-teacher-card__body,
.attendance-session-teacher-card.is-selected .attendance-session-teacher-card__body {
    background: var(--table-row-hover, var(--surface-soft));
    border-color: var(--pill-selected-border, var(--primary, var(--bs-primary)));
    transform: translateY(-1px);
}

.attendance-session-teacher-card.is-selected .attendance-session-teacher-card__body {
    box-shadow: inset 0 0 0 1px var(--pill-selected-border, var(--primary, var(--bs-primary)));
}

.attendance-session-teacher-copy {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    min-width: 0;
}

.attendance-session-teacher-name,
.attendance-session-selected__name,
.attendance-session-guidance-item__title,
.attendance-session-empty__title {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 700;
}

.attendance-session-teacher-meta,
.attendance-session-selected__meta,
.attendance-session-guidance-item__copy {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.84rem;
}

.attendance-session-teacher-state {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid var(--pill-border, var(--card-border));
    padding: 0.28rem 0.58rem;
    font-size: 0.72rem;
    font-weight: 700;
    white-space: nowrap;
    background: var(--surface-soft, var(--surface));
    color: var(--text-main, var(--bs-body-color));
}

.attendance-session-teacher-state--pending {
    background: color-mix(in srgb, var(--bs-warning) 20%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-warning) 42%, var(--card-border, var(--bs-border-color)));
}

.attendance-session-teacher-state--approved {
    background: color-mix(in srgb, var(--bs-success) 18%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-success) 42%, var(--card-border, var(--bs-border-color)));
}

.attendance-session-teacher-state--declined {
    background: color-mix(in srgb, var(--bs-danger) 16%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-danger) 42%, var(--card-border, var(--bs-border-color)));
}

.attendance-session-selected {
    display: grid;
    grid-template-columns: minmax(220px, 0.7fr) minmax(0, 1.3fr);
    gap: 1rem;
    margin-top: 1.25rem;
    padding: 1rem;
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: var(--surface-soft, var(--surface));
}

.attendance-session-selected__label {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.attendance-session-selected__list {
    display: grid;
    gap: 0.75rem;
}

.attendance-session-selected__item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 0.9rem 1rem;
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: var(--surface, var(--bs-body-bg));
}

.attendance-session-empty {
    padding: 1.5rem;
    border: 1px dashed var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: var(--surface-soft, var(--surface));
    text-align: center;
}

.attendance-session-empty--compact {
    padding: 1rem;
    margin-top: 1rem;
}

.attendance-session-form-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.85fr);
    gap: 1.25rem;
    align-items: start;
}

.attendance-session-guidance-list {
    display: grid;
    gap: 0.85rem;
    margin-top: 1rem;
}

.attendance-session-guidance-item {
    padding: 0.95rem 1rem;
    border: 1px solid var(--table-border, var(--card-border));
    border-radius: 1rem;
    background: var(--surface-soft, var(--surface));
}

@media (max-width: 1199.98px) {
    .attendance-session-form-layout,
    .attendance-session-selected {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991.98px) {
    .attendance-session-teacher-grid {
        grid-template-columns: 1fr;
    }

    .attendance-session-selected__item,
    .attendance-session-teacher-card__body {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (max-width: 575.98px) {
    .attendance-session-hero__body,
    .attendance-session-panel__header,
    .attendance-session-panel__body {
        padding: 1rem;
    }

    .attendance-session-metric {
        flex-basis: 100%;
    }

    .attendance-session-quick-actions--header {
        justify-content: flex-start;
    }

    .attendance-session-summary-chip {
        min-width: 0;
    }
}


/* ===== Teacher confirmation monitor ===== */
.confirmation-page {
    display: flex;
    flex-direction: column;
}

.confirmation-surface,
.confirmation-section {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    border-radius: 1.25rem;
}

.confirmation-hero {
    overflow: hidden;
}

.confirmation-hero-accent {
    height: 0.5rem;
    background: linear-gradient(
        90deg,
        color-mix(in srgb, var(--primary, var(--bs-primary)) 84%, var(--surface, var(--bs-body-bg)) 16%) 0%,
        color-mix(in srgb, var(--bs-info) 68%, var(--primary, var(--bs-primary)) 32%) 50%,
        color-mix(in srgb, var(--bs-danger) 58%, var(--primary, var(--bs-primary)) 42%) 100%
    );
}

.confirmation-hero-body {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.5rem;
}

.confirmation-kicker,
.confirmation-section-kicker,
.confirmation-date-kicker {
    color: var(--primary, var(--bs-primary));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.confirmation-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.75rem, 2.2vw, 2.25rem);
    font-weight: 700;
    letter-spacing: -0.03em;
}

.confirmation-subtitle,
.confirmation-section-subtitle,
.confirmation-filter-copy,
.confirmation-row-note {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.confirmation-actions,
.confirmation-filter-top,
.confirmation-filter-buttons,
.confirmation-quickfilters,
.confirmation-section-header,
.confirmation-section-badges,
.confirmation-date-header,
.confirmation-date-badges {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.confirmation-metrics-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.confirmation-metric-card {
    padding: 1.1rem 1.2rem;
    position: relative;
    overflow: hidden;
}

.confirmation-metric-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 0.35rem;
    background: var(--primary, var(--bs-primary));
}

.confirmation-metric-card--pending::before { background: var(--bs-warning); }
.confirmation-metric-card--approved::before { background: var(--bs-success); }
.confirmation-metric-card--declined::before { background: var(--bs-danger); }

.confirmation-metric-label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.confirmation-metric-value {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.55rem;
    font-weight: 700;
    margin-top: 0.35rem;
}

.confirmation-filter {
    padding: 1.25rem;
}

.confirmation-filter-top {
    justify-content: space-between;
    margin-bottom: 1rem;
}

.confirmation-filter-summary {
    display: inline-flex;
    align-items: baseline;
    gap: 0.45rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.confirmation-filter-count {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.3rem;
    font-weight: 700;
}

.confirmation-filter-grid {
    display: grid;
    grid-template-columns: repeat(8, minmax(0, 1fr));
    gap: 1rem;
    align-items: end;
}

.confirmation-filter-field {
    display: grid;
    gap: 0.35rem;
}

.confirmation-control {
    background-color: var(--input-bg, var(--surface, var(--bs-body-bg))) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
    border-color: var(--input-border, var(--border-color, var(--bs-border-color))) !important;
    border-radius: 0.85rem !important;
    min-height: 2.75rem;
}

.confirmation-filter-buttons {
    justify-content: flex-end;
}

.confirmation-quickfilters {
    margin-top: 1rem;
}

.confirmation-section {
    overflow: hidden;
}

.confirmation-section-header {
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: transparent;
}

.confirmation-section-title,
.confirmation-date-title,
.confirmation-class-title {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 700;
}

.confirmation-section-title {
    font-size: 1.06rem;
}

.confirmation-section-subtitle {
    font-size: 0.86rem;
    margin-top: 0.2rem;
}

.confirmation-section-body {
    padding: 0;
}

.confirmation-group-list {
    display: grid;
    gap: 1rem;
    padding: 1rem;
}

.confirmation-date-group {
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
    overflow: hidden;
    background: var(--surface-strong, var(--surface, var(--bs-body-bg)));
}

.confirmation-date-header {
    justify-content: space-between;
    padding: 1rem 1.1rem;
    border-bottom: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--surface, var(--bs-body-bg));
}

.confirmation-record-table {
    min-width: 980px;
}

.confirmation-record-table th,
.confirmation-record-table td {
    vertical-align: middle;
    padding: 0.8rem 0.9rem;
}

.confirmation-record-table thead th {
    font-size: 0.78rem;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.confirmation-record-table tbody td {
    font-size: 0.9rem;
    background: var(--surface-strong, var(--surface, var(--bs-body-bg)));
}

.confirmation-record-table tbody tr:hover > td {
    background: var(--table-row-hover, var(--surface-soft, var(--surface, var(--bs-body-bg)))) !important;
}

.confirmation-row--pending > td {
    background: var(--surface-strong, var(--surface, var(--bs-body-bg))) !important;
    border-color: var(--table-border, var(--border-color, var(--bs-border-color))) !important;
}

.confirmation-row--approved > td:first-child,
.confirmation-row--declined > td:first-child,
.confirmation-row--pending > td:first-child {
    box-shadow: inset 0.28rem 0 0 var(--primary, var(--bs-primary));
}

.confirmation-row--approved > td:first-child {
    box-shadow: inset 0.28rem 0 0 var(--bs-success);
}

.confirmation-row--declined > td:first-child {
    box-shadow: inset 0.28rem 0 0 var(--bs-danger);
}

.confirmation-row--pending > td:first-child {
    box-shadow: inset 0.28rem 0 0 var(--bs-warning);
}

.confirmation-row-note,
.confirmation-note-cell {
    max-width: 240px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.confirmation-empty-state,
.confirmation-record-table .theme-empty {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.confirmation-empty-state {
    margin: 1rem;
    border: 1px dashed var(--table-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
    padding: 1.5rem;
    text-align: center;
}

@media (max-width: 1399.98px) {
    .confirmation-filter-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .confirmation-metrics-grid {
        grid-template-columns: 1fr;
    }

    .confirmation-filter-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .confirmation-filter-buttons {
        justify-content: stretch;
    }

    .confirmation-filter-buttons .btn {
        flex: 1 1 0;
    }
}

@media (max-width: 575.98px) {
    .confirmation-hero-body,
    .confirmation-filter,
    .confirmation-section-header,
    .confirmation-group-list {
        padding: 1rem;
    }

.confirmation-filter-grid {
        grid-template-columns: 1fr;
    }
}


/* ===== Users & Access themed layout ===== */
.user-access-page {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.user-access-surface,
.user-access-panel,
.user-access-metric,
.user-access-form-panel,
.user-access-list-card,
.user-access-stat-card {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    border-radius: 1.25rem;
}

.user-access-hero {
    overflow: hidden;
}

.user-access-hero__accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-success), var(--bs-warning));
}

.user-access-hero__body {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1.5rem;
}

.user-access-kicker,
.user-access-section-kicker {
    color: var(--primary, var(--bs-primary));
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.user-access-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.7rem, 2.1vw, 2.25rem);
    font-weight: 700;
    letter-spacing: -0.03em;
    margin: 0;
}

.user-access-subtitle,
.user-access-muted,
.user-access-meta,
.user-access-list-meta,
.user-access-table-note,
.user-access-empty {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.user-access-actions,
.user-access-stat-list,
.user-access-badge-row,
.user-access-toolbar,
.user-access-filter-actions,
.user-access-form-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.user-access-panel__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.85rem;
    flex-wrap: wrap;
    padding: 1.1rem 1.25rem;
    border-bottom: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--surface-muted, var(--surface-soft, var(--surface, var(--bs-body-bg))));
    border-radius: 1.25rem 1.25rem 0 0;
}

.user-access-panel__header--plain {
    background: var(--surface, var(--bs-body-bg));
}

.user-access-panel__body {
    padding: 1.25rem;
}

.user-access-metric-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.user-access-metric {
    padding: 1rem 1.1rem;
    position: relative;
    overflow: hidden;
}

.user-access-metric::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 0.32rem;
    background: var(--primary, var(--bs-primary));
}

.user-access-metric--info::before { background: var(--bs-info); }
.user-access-metric--success::before { background: var(--bs-success); }
.user-access-metric--warning::before { background: var(--bs-warning); }
.user-access-metric--danger::before { background: var(--bs-danger); }

.user-access-metric__label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.user-access-metric__value {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.55rem;
    font-weight: 700;
    margin-top: 0.35rem;
}

.user-access-table-wrap {
    overflow-x: auto;
}

.user-access-table {
    min-width: 980px;
    margin: 0;
}

.user-access-table thead th {
    background: var(--table-head-bg, var(--surface-soft));
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 0.9rem 1rem;
    border-bottom-color: var(--table-border, var(--border-color, var(--bs-border-color)));
    white-space: nowrap;
}

.user-access-table tbody td {
    padding: 1rem;
    border-top-color: var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--surface, var(--bs-body-bg));
    vertical-align: middle;
}

.user-access-table tbody tr:hover td {
    background: var(--table-row-hover, var(--surface-soft));
}

.user-access-primary {
    display: grid;
    gap: 0.18rem;
}

.user-access-name {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 700;
}

.user-access-meta {
    font-size: 0.84rem;
}

.user-access-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1.85rem;
    padding: 0.28rem 0.7rem;
    border-radius: 999px;
    border: 1px solid var(--pill-border, var(--border-color, var(--bs-border-color)));
    background: var(--pill-bg, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.74rem;
    font-weight: 700;
    line-height: 1.2;
    white-space: nowrap;
}

.user-access-pill--success {
    background: color-mix(in srgb, var(--bs-success) 16%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-success) 36%, var(--card-border, var(--bs-border-color)));
}

.user-access-pill--muted {
    background: var(--surface-soft, var(--surface));
    border-color: var(--table-border, var(--border-color, var(--bs-border-color)));
}

.user-access-pill--warning {
    background: color-mix(in srgb, var(--bs-warning) 18%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-warning) 42%, var(--card-border, var(--bs-border-color)));
}

.user-access-pill--danger {
    background: color-mix(in srgb, var(--bs-danger) 14%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-danger) 40%, var(--card-border, var(--bs-border-color)));
}

.user-access-pill--info {
    background: color-mix(in srgb, var(--bs-info) 14%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-info) 36%, var(--card-border, var(--bs-border-color)));
}

.user-access-pill--light {
    background: var(--surface-soft, var(--surface));
}

.user-access-grid-two {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.user-access-list-card {
    overflow: hidden;
}

.user-access-list-card__header {
    padding: 1rem 1.15rem;
    border-bottom: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--surface-muted, var(--surface-soft, var(--surface)));
}

.user-access-list-card__header--plain {
    background: var(--surface, var(--bs-body-bg));
}

.user-access-list-card__title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.02rem;
    font-weight: 700;
    margin: 0;
}

.user-access-list {
    display: grid;
    gap: 0;
}

.user-access-list__item {
    padding: 0.95rem 1.15rem;
    border-top: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
}

.user-access-list__item:first-child {
    border-top: 0;
}

.user-access-list__item:hover {
    background: var(--table-row-hover, var(--surface-soft));
}

.user-access-filter-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1rem;
    align-items: end;
}

.user-access-filter-field {
    display: grid;
    gap: 0.35rem;
}

.user-access-control {
    background-color: var(--input-bg, var(--surface, var(--bs-body-bg))) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
    border-color: var(--input-border, var(--border-color, var(--bs-border-color))) !important;
    border-radius: 0.85rem !important;
    min-height: 2.75rem;
}

.user-access-form-layout {
    display: grid;
    grid-template-columns: minmax(300px, 0.9fr) minmax(0, 1.3fr);
    gap: 1rem;
    align-items: start;
}

.user-access-form-panel {
    overflow: hidden;
}

.user-access-form-panel__header {
    padding: 1rem 1.15rem;
    border-bottom: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--surface-muted, var(--surface-soft, var(--surface)));
}

.user-access-form-panel__body {
    padding: 1.15rem;
}

.user-access-field-stack {
    display: grid;
    gap: 1rem;
}

.user-access-notice {
    padding: 0.9rem 1rem;
    border-radius: 1rem;
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--surface-soft, var(--surface));
    color: var(--text-main, var(--bs-body-color));
}

.user-access-notice--warning {
    background: color-mix(in srgb, var(--bs-warning) 14%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-warning) 36%, var(--card-border, var(--bs-border-color)));
}

.user-access-notice--info {
    background: color-mix(in srgb, var(--bs-info) 12%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-info) 34%, var(--card-border, var(--bs-border-color)));
}

.user-access-notice--danger {
    background: color-mix(in srgb, var(--bs-danger) 12%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-danger) 36%, var(--card-border, var(--bs-border-color)));
}

.user-access-notice--muted {
    background: var(--surface-soft, var(--surface));
}

.user-access-matrix-table,
.user-access-audit-table {
    margin: 0;
}

.user-access-matrix-table thead th,
.user-access-audit-table thead th {
    background: var(--table-head-bg, var(--surface-soft));
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    white-space: nowrap;
}

.user-access-matrix-table td,
.user-access-matrix-table th,
.user-access-audit-table td,
.user-access-audit-table th {
    padding: 0.85rem 0.95rem;
    border-color: var(--table-border, var(--border-color, var(--bs-border-color)));
    vertical-align: middle;
}

.user-access-delete-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
}

.user-access-stat-card {
    padding: 0.95rem 1rem;
}

.user-access-stat-card__label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.user-access-stat-card__value {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 700;
    margin-top: 0.28rem;
}

@media (max-width: 1199.98px) {
    .user-access-metric-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .user-access-filter-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .user-access-grid-two,
    .user-access-form-layout,
    .user-access-delete-grid {
        grid-template-columns: 1fr;
    }

    .user-access-filter-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .user-access-hero__body,
    .user-access-panel__header,
    .user-access-panel__body,
    .user-access-form-panel__header,
    .user-access-form-panel__body,
    .user-access-list-card__header,
    .user-access-list__item {
        padding: 1rem;
    }

    .user-access-metric-grid,
    .user-access-filter-grid {
        grid-template-columns: 1fr;
    }
}

/* ===== Group detail themed workspace ===== */
.group-workspace-page {
    --group-accent: color-mix(in srgb, var(--primary, var(--bs-primary)) 88%, #0f766e 12%);
    --group-accent-deep: color-mix(in srgb, var(--primary, var(--bs-primary)) 82%, #083344 18%);
    --group-ink: var(--text-main, var(--text, var(--bs-body-color)));
}

.group-workspace-shell,
.group-workspace-card {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow, 0 14px 30px rgba(9, 124, 135, 0.10));
    border-radius: 1.25rem;
}

.group-workspace-hero {
    overflow: hidden;
}

.group-workspace-hero-accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-danger), var(--bs-warning));
}

.group-workspace-hero-body {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.5rem;
}

.group-workspace-identity-block {
    min-width: 0;
}

.group-workspace-metric__label,
.group-workspace-info-label {
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.group-workspace-title-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.group-workspace-title {
    font-size: clamp(1.75rem, 2.4vw, 2.45rem);
    font-weight: 700;
    line-height: 1.1;
    color: var(--group-ink);
    letter-spacing: -0.035em;
}

.group-workspace-subtitle,
.group-workspace-context-line,
.group-workspace-actions {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.group-workspace-subtitle,
.group-workspace-card__subtitle,
.group-workspace-role-meta,
.group-workspace-empty,
.group-workspace-metric__hint,
.group-workspace-person__meta {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.group-workspace-subtitle {
    margin-top: 0.45rem;
    font-size: 0.92rem;
}

.group-workspace-context-line {
    margin-top: 0.65rem;
    font-size: 0.92rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.group-workspace-context-label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-weight: 500;
}

.group-workspace-context-divider {
    color: var(--text-soft, var(--muted, var(--bs-secondary-color)));
}

.group-workspace-metric,
.group-workspace-info-row,
.group-workspace-role-item {
    border: 1px solid color-mix(in srgb, var(--group-accent) 14%, var(--border-color, var(--bs-border-color)));
    background: color-mix(in srgb, var(--surface, var(--bs-body-bg)) 92%, transparent);
    box-shadow: 0 10px 24px color-mix(in srgb, var(--group-accent) 7%, transparent);
}

.group-workspace-metric__label,
.group-workspace-info-label {
    color: var(--text-soft, var(--muted, var(--bs-secondary-color)));
    margin-bottom: 0.35rem;
}

.group-workspace-metric__value,
.group-workspace-card__title,
.group-workspace-role-name,
.group-workspace-info-value {
    color: var(--group-ink);
}

.group-workspace-role-name {
    font-weight: 700;
}

.group-workspace-actions {
    justify-content: flex-end;
}

.group-workspace-metric {
    border-radius: 1.35rem;
    padding: 1.15rem 1.2rem;
    height: 100%;
}

.group-workspace-metric__value {
    font-size: 2rem;
    line-height: 1;
    font-weight: 700;
    margin-bottom: 0.35rem;
}

.group-workspace-card {
    padding: 1.35rem;
}

.group-workspace-card__header {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.1rem;
}

.group-workspace-card__title {
    font-size: 1.15rem;
    font-weight: 700;
    margin-bottom: 0.2rem;
}

.group-workspace-card__subtitle {
    font-size: 0.92rem;
    margin-bottom: 0;
}

.group-workspace-info-list,
.group-workspace-role-list {
    display: grid;
    gap: 0.8rem;
}

.group-workspace-info-row {
    border-radius: 1rem;
    padding: 0.9rem 1rem;
}

.group-workspace-info-value {
    font-weight: 600;
}

.group-workspace-description {
    line-height: 1.65;
    color: var(--text-main, var(--text, var(--bs-body-color)));
    white-space: pre-line;
}

.group-workspace-role-item {
    border-radius: 1rem;
    padding: 0.95rem 1rem;
}

.group-workspace-role-top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
}

.group-workspace-role-meta {
    font-size: 0.88rem;
    margin-top: 0.25rem;
}

.group-workspace-role-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    justify-content: flex-end;
}

.group-workspace-modal__dialog {
    max-width: 960px;
}

.group-workspace-modal__content {
    border-radius: 1.25rem;
    overflow: hidden;
}

.group-workspace-modal__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.1rem 1.25rem;
    border-bottom: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    background: var(--surface, var(--bs-body-bg));
}

.group-workspace-modal__body {
    padding: 1.2rem 1.25rem 1.25rem;
    background: var(--surface, var(--bs-body-bg));
}

.group-workspace-table {
    --bs-table-bg: transparent;
    --bs-table-border-color: color-mix(in srgb, var(--group-accent) 12%, var(--border-color, var(--bs-border-color)));
}

.group-workspace-table tbody tr:hover {
    background: color-mix(in srgb, var(--surface-soft, var(--surface, var(--bs-body-bg))) 84%, var(--group-accent) 16%);
}

.group-workspace-person {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-width: 0;
}

.group-workspace-avatar {
    width: 2.6rem;
    height: 2.6rem;
    border-radius: 0.95rem;
    background: linear-gradient(
        135deg,
        color-mix(in srgb, var(--group-accent) 20%, var(--surface, var(--bs-body-bg))),
        color-mix(in srgb, var(--bs-warning, #f59e0b) 18%, var(--surface, var(--bs-body-bg)))
    );
    color: var(--group-accent-deep);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    flex: 0 0 auto;
    border: 1px solid color-mix(in srgb, var(--group-accent) 18%, var(--border-color, var(--bs-border-color)));
}

.group-workspace-person__name {
    font-weight: 700;
}

.group-workspace-role-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--group-accent) 12%, var(--surface, var(--bs-body-bg)));
    color: var(--group-accent-deep);
    font-weight: 700;
    font-size: 0.82rem;
    border: 1px solid color-mix(in srgb, var(--group-accent) 18%, var(--border-color, var(--bs-border-color)));
}

.group-workspace-role-badge-list,
.group-workspace-note-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.group-workspace-note-list {
    flex-direction: column;
    gap: 0.55rem;
}

.group-workspace-note-item {
    min-width: 0;
}

.group-workspace-empty {
    border: 1px dashed color-mix(in srgb, var(--group-accent) 22%, var(--border-color, var(--bs-border-color)));
    border-radius: 1.2rem;
    padding: 2rem 1.25rem;
    text-align: center;
    background: color-mix(in srgb, var(--surface-soft, var(--surface, var(--bs-body-bg))) 72%, transparent);
}

.group-workspace-page .btn-primary,
.group-workspace-page .btn-primary.theme-action-primary {
    background-color: var(--primary, var(--bs-primary)) !important;
    border-color: var(--primary, var(--bs-primary)) !important;
    color: #fff !important;
}

.group-workspace-page .btn-primary:hover,
.group-workspace-page .btn-primary.theme-action-primary:hover {
    background-color: var(--primary-hover, var(--primary, var(--bs-primary))) !important;
    border-color: var(--primary-hover, var(--primary, var(--bs-primary))) !important;
}

.group-workspace-page .btn-outline-secondary,
.group-workspace-page .btn-outline-secondary.theme-action-outline {
    background: var(--btn-outline-neutral-bg, transparent) !important;
    border-color: var(--btn-outline-neutral-border, var(--border-color, var(--bs-border-color))) !important;
    color: var(--btn-outline-neutral-text, var(--text-main, var(--bs-body-color))) !important;
}

.group-workspace-page .btn-outline-secondary:hover,
.group-workspace-page .btn-outline-secondary.theme-action-outline:hover {
    background: var(--btn-outline-neutral-hover-bg, var(--surface-soft)) !important;
    color: var(--btn-outline-neutral-hover-text, var(--text-main, var(--bs-body-color))) !important;
}

.group-workspace-page .btn-outline-danger {
    background: transparent !important;
    border-color: color-mix(in srgb, var(--bs-danger) 45%, var(--border-color, var(--bs-border-color))) !important;
    color: var(--bs-danger) !important;
}

.group-workspace-page .btn-outline-danger:hover {
    background: color-mix(in srgb, var(--bs-danger) 16%, var(--surface, var(--bs-body-bg))) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
}

@media (max-width: 991.98px) {
    .group-workspace-hero-body,
    .group-workspace-card {
        padding: 1rem;
    }

    .group-workspace-actions {
        justify-content: flex-start;
    }

    .group-workspace-modal__dialog {
        margin: 0.75rem;
    }

    .group-workspace-modal__header,
    .group-workspace-modal__body {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

/* ===== Groups module themed layout ===== */
.groups-theme-page,
.groups-form-page,
.groups-confirm-page {
    --groups-accent: color-mix(in srgb, var(--primary, var(--bs-primary)) 88%, #0f766e 12%);
    --groups-accent-deep: color-mix(in srgb, var(--primary, var(--bs-primary)) 82%, #083344 18%);
    color: var(--text-main, var(--bs-body-color));
}

.groups-theme-shell,
.groups-theme-card,
.groups-theme-filter,
.groups-theme-metric,
.groups-form-shell,
.groups-form-panel,
.groups-confirm-shell,
.groups-confirm-panel {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow, 0 14px 30px rgba(9, 124, 135, 0.10));
    border-radius: 1.25rem;
}

.groups-theme-hero,
.groups-form-shell,
.groups-confirm-shell {
    overflow: hidden;
}

.groups-theme-hero-accent,
.groups-form-accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-danger), var(--bs-warning));
}

.groups-confirm-accent {
    height: 0.5rem;
    background: linear-gradient(90deg, var(--bs-danger), var(--bs-warning));
}

.groups-theme-hero-body,
.groups-form-shell-body,
.groups-confirm-shell-body {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.5rem;
}

.groups-theme-identity,
.groups-form-identity,
.groups-confirm-identity {
    min-width: 0;
}

.groups-theme-label,
.groups-form-label,
.groups-confirm-label,
.groups-theme-stat-label,
.groups-theme-section-title,
.groups-form-panel-title,
.groups-confirm-panel-title {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.groups-theme-label,
.groups-form-label,
.groups-confirm-label,
.groups-theme-stat-label {
    color: var(--text-soft, var(--muted, var(--bs-secondary-color)));
}

.groups-theme-title,
.groups-form-title,
.groups-confirm-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.75rem, 2.4vw, 2.45rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.035em;
}

.groups-theme-subtitle,
.groups-theme-context,
.groups-form-subtitle,
.groups-form-context,
.groups-confirm-subtitle,
.groups-confirm-context,
.groups-theme-empty,
.groups-theme-hint,
.groups-form-help-copy,
.groups-confirm-copy,
.groups-confirm-blocker-meta {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.groups-theme-subtitle,
.groups-theme-context,
.groups-theme-actions,
.groups-form-context,
.groups-form-actions,
.groups-confirm-context,
.groups-confirm-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.groups-theme-subtitle,
.groups-form-subtitle,
.groups-confirm-subtitle {
    margin-top: 0.45rem;
    font-size: 0.94rem;
}

.groups-theme-context,
.groups-form-context,
.groups-confirm-context {
    margin-top: 0.65rem;
    font-size: 0.92rem;
}

.groups-theme-context-label,
.groups-form-context-label,
.groups-confirm-context-label {
    font-weight: 500;
}

.groups-theme-context-sep,
.groups-form-context-sep,
.groups-confirm-context-sep {
    color: var(--text-soft, var(--muted, var(--bs-secondary-color)));
}

.groups-theme-actions {
    justify-content: flex-end;
}

.groups-theme-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
}

.groups-theme-metric {
    padding: 1rem 1.1rem;
}

.groups-theme-stat-value {
    color: var(--text-main, var(--bs-body-color));
    font-size: 2rem;
    line-height: 1;
    font-weight: 700;
    margin-top: 0.35rem;
}

.groups-theme-hint {
    font-size: 0.88rem;
    margin-top: 0.3rem;
}

.groups-theme-filter {
    padding: 1.25rem;
}

.groups-theme-filter-grid {
    display: grid;
    grid-template-columns: minmax(0, 2.4fr) minmax(11rem, 1fr) auto;
    gap: 0.85rem;
    align-items: end;
}

.groups-theme-filter-actions {
    display: flex;
    gap: 0.65rem;
}

.groups-theme-card {
    padding: 1.35rem;
}

.groups-theme-card-header,
.groups-form-panel-header,
.groups-confirm-panel-header {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.85rem;
    margin-bottom: 1rem;
}

.groups-theme-section-title,
.groups-form-panel-title,
.groups-confirm-panel-title {
    color: var(--text-main, var(--bs-body-color));
    margin-bottom: 0;
}

.groups-theme-card-subtitle,
.groups-form-panel-subtitle,
.groups-confirm-panel-subtitle {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.92rem;
    margin-top: 0.28rem;
    margin-bottom: 0;
}

.groups-theme-category-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.groups-theme-item-card,
.groups-theme-list-row,
.groups-confirm-blockers li {
    border: 1px solid color-mix(in srgb, var(--groups-accent) 14%, var(--border-color, var(--bs-border-color)));
    background: color-mix(in srgb, var(--surface, var(--bs-body-bg)) 94%, transparent);
    border-radius: 1rem;
}

.groups-theme-item-card {
    padding: 1rem;
    height: 100%;
}

.groups-theme-item-top,
.groups-theme-list-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.85rem;
}

.groups-theme-item-title {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 700;
}

.groups-theme-item-meta,
.groups-theme-table-note,
.groups-form-field-note {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.88rem;
}

.groups-theme-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.85rem;
}

.groups-theme-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1.8rem;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    border: 1px solid var(--pill-border, var(--border-color, var(--bs-border-color)));
    background: var(--pill-bg, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.8rem;
    font-weight: 500;
    text-decoration: none;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.groups-theme-chip:hover {
    background: var(--pill-bg-hover, var(--surface-soft));
    border-color: var(--pill-border-hover, var(--border-color, var(--bs-border-color)));
    color: var(--primary, var(--bs-primary));
}

.groups-theme-list {
    display: grid;
    gap: 0.75rem;
}

.groups-theme-list-row {
    padding: 0.95rem 1rem;
    text-decoration: none;
    color: inherit;
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.groups-theme-list-row:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--groups-accent) 28%, var(--border-color, var(--bs-border-color)));
    background: color-mix(in srgb, var(--surface-soft, var(--surface, var(--bs-body-bg))) 88%, transparent);
    color: inherit;
}

.groups-theme-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1.8rem;
    padding: 0.32rem 0.72rem;
    border-radius: 999px;
    border: 1px solid var(--pill-border, var(--border-color, var(--bs-border-color)));
    background: var(--pill-bg, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.78rem;
    font-weight: 600;
}

.groups-theme-status--active {
    background: color-mix(in srgb, var(--bs-success) 28%, var(--surface, var(--bs-body-bg)));
    color: var(--primary, var(--bs-primary));
    border-color: color-mix(in srgb, var(--bs-success) 45%, var(--card-border, var(--bs-border-color)));
}

.groups-theme-status--inactive {
    background: var(--surface-muted, var(--surface-soft));
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.groups-theme-table-wrap {
    overflow: hidden;
    border-radius: 1rem;
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
}

.groups-theme-table {
    --bs-table-bg: transparent;
    --bs-table-border-color: var(--table-border, var(--border-color, var(--bs-border-color)));
}

.groups-theme-table tbody tr:hover {
    background: color-mix(in srgb, var(--surface-soft, var(--surface, var(--bs-body-bg))) 88%, transparent);
}

.groups-theme-table-person {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    min-width: 0;
}

.groups-theme-avatar {
    width: 2.4rem;
    height: 2.4rem;
    border-radius: 0.85rem;
    background: linear-gradient(
        135deg,
        color-mix(in srgb, var(--groups-accent) 20%, var(--surface, var(--bs-body-bg))),
        color-mix(in srgb, var(--bs-warning, #f59e0b) 18%, var(--surface, var(--bs-body-bg)))
    );
    color: var(--groups-accent-deep);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    flex: 0 0 auto;
    border: 1px solid color-mix(in srgb, var(--groups-accent) 18%, var(--border-color, var(--bs-border-color)));
}

.groups-theme-empty {
    text-align: center;
    padding: 2rem 1.25rem;
    border: 1px dashed color-mix(in srgb, var(--groups-accent) 20%, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
    background: color-mix(in srgb, var(--surface-soft, var(--surface, var(--bs-body-bg))) 72%, transparent);
}

.groups-form-shell-body,
.groups-confirm-shell-body {
    align-items: flex-start;
}

.groups-form-panel,
.groups-confirm-panel {
    padding: 1.35rem;
}

.groups-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.groups-form-field--full {
    grid-column: 1 / -1;
}

.groups-form-check {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    min-height: 2.75rem;
    padding: 0.8rem 0.9rem;
    border-radius: 0.95rem;
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--surface-soft, var(--surface, var(--bs-body-bg)));
}

.groups-form-role-checklist {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.groups-form-role-option {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    min-height: 2.85rem;
    padding: 0.8rem 0.95rem;
    border-radius: 0.95rem;
    border: 1px solid var(--table-border, var(--border-color, var(--bs-border-color)));
    background: var(--surface, var(--bs-body-bg));
    color: inherit;
    cursor: pointer;
    transition: border-color 0.18s ease, background 0.18s ease, transform 0.18s ease;
}

.groups-form-role-option:hover {
    border-color: var(--primary, var(--bs-primary));
    background: var(--surface-soft, var(--surface, var(--bs-body-bg)));
    transform: translateY(-1px);
}

.groups-form-role-option .form-check-input {
    margin: 0;
    flex: 0 0 auto;
}

.groups-form-role-option span {
    min-width: 0;
    font-weight: 600;
}

.groups-form-actions {
    margin-top: 1.35rem;
}

.groups-form-aside-list,
.groups-confirm-blockers {
    display: grid;
    gap: 0.75rem;
}

.groups-form-help-copy {
    line-height: 1.65;
}

.groups-confirm-copy {
    font-size: 0.96rem;
    line-height: 1.65;
}

.groups-confirm-blockers {
    list-style: none;
    padding: 0;
    margin: 0;
}

.groups-confirm-blockers li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.85rem;
    padding: 0.9rem 1rem;
}

.groups-confirm-blocker-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2rem;
    height: 2rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--bs-danger) 18%, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
    font-weight: 700;
}

.groups-confirm-state {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    min-height: 1.85rem;
    padding: 0.35rem 0.78rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 700;
    border: 1px solid color-mix(in srgb, var(--bs-danger) 35%, var(--border-color, var(--bs-border-color)));
    background: color-mix(in srgb, var(--bs-danger) 14%, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
}

.groups-theme-page .btn-primary,
.groups-theme-page .btn-primary.theme-action-primary,
.groups-form-page .btn-primary,
.groups-form-page .btn-primary.theme-action-primary,
.groups-confirm-page .btn-primary,
.groups-confirm-page .btn-primary.theme-action-primary {
    background-color: var(--primary, var(--bs-primary)) !important;
    border-color: var(--primary, var(--bs-primary)) !important;
    color: #fff !important;
}

.groups-theme-page .btn-primary:hover,
.groups-theme-page .btn-primary.theme-action-primary:hover,
.groups-form-page .btn-primary:hover,
.groups-form-page .btn-primary.theme-action-primary:hover,
.groups-confirm-page .btn-primary:hover,
.groups-confirm-page .btn-primary.theme-action-primary:hover {
    background-color: var(--primary-hover, var(--primary, var(--bs-primary))) !important;
    border-color: var(--primary-hover, var(--primary, var(--bs-primary))) !important;
}

.groups-theme-page .btn-outline-secondary,
.groups-theme-page .btn-outline-secondary.theme-action-outline,
.groups-form-page .btn-outline-secondary,
.groups-form-page .btn-outline-secondary.theme-action-outline,
.groups-confirm-page .btn-outline-secondary,
.groups-confirm-page .btn-outline-secondary.theme-action-outline {
    background: var(--btn-outline-neutral-bg, transparent) !important;
    border-color: var(--btn-outline-neutral-border, var(--border-color, var(--bs-border-color))) !important;
    color: var(--btn-outline-neutral-text, var(--text-main, var(--bs-body-color))) !important;
}

.groups-theme-page .btn-outline-secondary:hover,
.groups-theme-page .btn-outline-secondary.theme-action-outline:hover,
.groups-form-page .btn-outline-secondary:hover,
.groups-form-page .btn-outline-secondary.theme-action-outline:hover,
.groups-confirm-page .btn-outline-secondary:hover,
.groups-confirm-page .btn-outline-secondary.theme-action-outline:hover {
    background: var(--btn-outline-neutral-hover-bg, var(--surface-soft)) !important;
    color: var(--btn-outline-neutral-hover-text, var(--text-main, var(--bs-body-color))) !important;
}

.groups-theme-page .btn-outline-danger,
.groups-form-page .btn-outline-danger,
.groups-confirm-page .btn-outline-danger {
    background: transparent !important;
    border-color: color-mix(in srgb, var(--bs-danger) 45%, var(--border-color, var(--bs-border-color))) !important;
    color: var(--bs-danger) !important;
}

.groups-theme-page .btn-outline-danger:hover,
.groups-form-page .btn-outline-danger:hover,
.groups-confirm-page .btn-outline-danger:hover {
    background: color-mix(in srgb, var(--bs-danger) 16%, var(--surface, var(--bs-body-bg))) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
}

@media (max-width: 1199.98px) {
    .groups-theme-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .groups-theme-filter-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .groups-theme-category-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991.98px) {
    .groups-theme-hero-body,
    .groups-form-shell-body,
    .groups-confirm-shell-body,
    .groups-theme-card,
    .groups-theme-filter,
    .groups-form-panel,
    .groups-confirm-panel {
        padding: 1rem;
    }

    .groups-theme-actions {
        justify-content: flex-start;
    }

    .groups-form-grid {
        grid-template-columns: 1fr;
    }

    .groups-form-role-checklist {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575.98px) {
    .groups-theme-metrics,
    .groups-theme-filter-grid {
        grid-template-columns: 1fr;
    }

    .groups-theme-filter-actions {
        flex-direction: column;
    }

    .groups-theme-filter-actions .btn {
        width: 100%;
    }
}

/* ===== Tasks themed module ===== */
.tasks-theme-page,
.tasks-confirm-page {
    --tasks-accent: color-mix(in srgb, var(--primary, var(--bs-primary)) 84%, var(--bs-info) 16%);
    --tasks-accent-strong: color-mix(in srgb, var(--primary, var(--bs-primary)) 78%, var(--bs-dark) 22%);
    color: var(--text-main, var(--bs-body-color));
}

.tasks-theme-shell,
.tasks-theme-card,
.tasks-theme-filter,
.tasks-theme-metric {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow);
    border-radius: 1.25rem;
}

.tasks-theme-hero {
    overflow: hidden;
}

.tasks-theme-hero-accent {
    height: 0.5rem;
    background: linear-gradient(
        90deg,
        var(--primary, var(--bs-primary)),
        color-mix(in srgb, var(--primary, var(--bs-primary)) 68%, var(--bs-info) 32%),
        color-mix(in srgb, var(--bs-info) 62%, var(--bs-warning) 38%)
    );
}

.tasks-theme-hero-body {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.5rem;
}

.tasks-theme-header-block {
    min-width: 0;
}

.tasks-theme-title-row,
.tasks-theme-subtitle,
.tasks-theme-context-line,
.tasks-theme-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.tasks-theme-title-row {
    row-gap: 0.6rem;
}

.tasks-theme-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.75rem, 2.4vw, 2.45rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.035em;
}

.tasks-theme-subtitle,
.tasks-theme-card-subtitle,
.tasks-theme-note,
.tasks-theme-empty,
.tasks-theme-hint,
.tasks-theme-table-note {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.tasks-theme-subtitle {
    margin-top: 0.45rem;
    font-size: 0.94rem;
}

.tasks-theme-context-line {
    margin-top: 0.65rem;
    font-size: 0.92rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
}

.tasks-theme-context-label,
.tasks-theme-stat-label,
.tasks-theme-section-title,
.tasks-theme-subpanel-title,
.tasks-theme-info-label {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.tasks-theme-context-label,
.tasks-theme-stat-label,
.tasks-theme-info-label {
    color: var(--text-soft, var(--muted, var(--bs-secondary-color)));
}

.tasks-theme-actions {
    justify-content: flex-end;
}

.tasks-theme-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.tasks-theme-metric {
    padding: 1.15rem 1.2rem;
}

.tasks-theme-stat-value {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.55rem, 2vw, 2rem);
    font-weight: 760;
    line-height: 1.05;
    margin-top: 0.45rem;
}

.tasks-theme-hint {
    font-size: 0.88rem;
    margin-top: 0.45rem;
}

.tasks-theme-card {
    overflow: hidden;
}

.tasks-theme-card-header {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.1rem 1.25rem;
    border-bottom: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
}

.tasks-theme-card-body {
    padding: 1.2rem 1.25rem 1.25rem;
}

.tasks-theme-section-title {
    color: var(--text-main, var(--bs-body-color));
    margin: 0;
}

.tasks-theme-card-subtitle {
    margin: 0.2rem 0 0;
    font-size: 0.92rem;
}

.tasks-theme-filter {
    margin: 0 1.25rem 1.25rem;
    padding: 1.1rem 1.15rem;
}

.tasks-theme-filter-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 0.95rem 1rem;
    align-items: end;
}

.tasks-theme-filter-grid > div {
    grid-column: span 3;
}

.tasks-theme-filter-grid .tasks-theme-filter-wide {
    grid-column: span 6;
}

.tasks-theme-filter-actions {
    display: flex;
    gap: 0.75rem;
    justify-content: flex-end;
}

.tasks-theme-table-wrap {
    padding: 0 1.25rem 1.25rem;
}

.tasks-theme-table {
    --bs-table-bg: transparent;
    --bs-table-border-color: var(--table-border, var(--border-color, var(--bs-border-color)));
    margin: 0;
}

.tasks-theme-table tbody tr:hover {
    background: var(--table-row-hover, var(--surface-soft, var(--surface, var(--bs-body-bg))));
}

.tasks-theme-pill,
.tasks-theme-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1.85rem;
    padding: 0.28rem 0.7rem;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 700;
    line-height: 1.2;
    white-space: nowrap;
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
}

.tasks-theme-pill--blue {
    background: color-mix(in srgb, var(--bs-info) 12%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-info) 30%, var(--card-border, var(--border-color, var(--bs-border-color))));
}

.tasks-theme-pill--neutral {
    background: var(--surface-soft, var(--surface, var(--bs-body-bg)));
}

.tasks-theme-status--active {
    background: color-mix(in srgb, var(--bs-success) 13%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-success) 34%, var(--card-border, var(--border-color, var(--bs-border-color))));
}

.tasks-theme-status--approved {
    background: color-mix(in srgb, var(--bs-info) 12%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-info) 34%, var(--card-border, var(--border-color, var(--bs-border-color))));
}

.tasks-theme-status--draft {
    background: color-mix(in srgb, var(--bs-warning) 13%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-warning) 36%, var(--card-border, var(--border-color, var(--bs-border-color))));
}

.tasks-theme-status--inactive {
    background: var(--surface-soft, var(--surface, var(--bs-body-bg)));
}

.tasks-theme-status--attention {
    background: color-mix(in srgb, var(--bs-warning) 12%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-warning) 32%, var(--card-border, var(--border-color, var(--bs-border-color))));
}

.tasks-theme-status--pending {
    --tasks-pending-accent: color-mix(in srgb, var(--primary, var(--bs-primary)) 82%, var(--bs-info) 18%);
    background: color-mix(in srgb, var(--tasks-pending-accent) 12%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--tasks-pending-accent) 34%, var(--card-border, var(--border-color, var(--bs-border-color))));
}

.tasks-theme-empty {
    margin: 1.25rem;
    padding: 2rem 1.25rem;
    text-align: center;
    border: 1px dashed color-mix(in srgb, var(--tasks-accent) 22%, var(--card-border, var(--border-color, var(--bs-border-color))));
    border-radius: 1.2rem;
    background: color-mix(in srgb, var(--surface-soft, var(--surface, var(--bs-body-bg))) 76%, transparent);
}

.tasks-theme-list {
    display: grid;
    gap: 0.8rem;
}

.tasks-theme-report-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.tasks-theme-report-list {
    display: grid;
    gap: 0.75rem;
}

.tasks-theme-report-item {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.85rem;
    padding: 0.95rem 1rem;
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    border-radius: 0.95rem;
    background: var(--surface-soft, var(--surface, var(--bs-body-bg)));
}

.tasks-dashboard-page .tasks-theme-report-item {
    background: transparent;
}

.tasks-theme-note {
    color: var(--text-muted, var(--bs-secondary-color));
    font-size: 0.9rem;
}

.tasks-theme-mini-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.tasks-theme-mini-metric {
    padding: 0.95rem 1rem;
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    border-radius: 0.95rem;
    background: var(--surface-soft, var(--surface, var(--bs-body-bg)));
}

.tasks-theme-mini-value {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.35rem;
    font-weight: 760;
    line-height: 1.1;
    margin-top: 0.35rem;
}

.tasks-theme-list-item,
.tasks-theme-item-card,
.tasks-theme-info-row,
.tasks-theme-subpanel {
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
    background: var(--surface, var(--bs-body-bg));
}

.tasks-theme-list-item,
.tasks-theme-item-card {
    padding: 0.95rem 1rem;
}

.tasks-theme-item-title {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 700;
}

.tasks-theme-control-card {
    background:
        linear-gradient(180deg, color-mix(in srgb, var(--surface-soft, var(--surface, var(--bs-body-bg))) 78%, transparent), transparent 68%),
        var(--surface, var(--bs-body-bg));
}

.tasks-theme-control-header {
    align-items: flex-start;
}

.tasks-theme-control-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem;
}

.tasks-theme-control-tile {
    padding: 1rem 1.05rem;
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
    background: var(--surface-soft, var(--surface, var(--bs-body-bg)));
}

.tasks-theme-control-label,
.tasks-theme-control-kicker {
    color: var(--text-soft, var(--muted, var(--bs-secondary-color)));
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.tasks-theme-control-kicker {
    margin-bottom: 0.3rem;
}

.tasks-theme-control-value {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.7rem;
    font-weight: 780;
    line-height: 1.05;
    margin: 0.45rem 0 0.35rem;
}

.tasks-theme-role-title {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.tasks-theme-role-dot {
    width: 0.72rem;
    height: 0.72rem;
    border-radius: 999px;
    flex: 0 0 auto;
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    background: var(--surface-soft, var(--surface, var(--bs-body-bg)));
}

.tasks-theme-role-dot--assigned {
    background: color-mix(in srgb, var(--bs-success) 82%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-success) 42%, var(--card-border, var(--border-color, var(--bs-border-color))));
}

.tasks-theme-role-dot--open {
    background: color-mix(in srgb, var(--bs-warning) 78%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-warning) 42%, var(--card-border, var(--border-color, var(--bs-border-color))));
}

.tasks-theme-rotation-list,
.tasks-theme-assignment-list {
    display: grid;
    gap: 0.75rem;
}

.tasks-theme-rotation-item,
.tasks-theme-assignment-item {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.85rem;
    padding: 0.9rem 1rem;
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    border-radius: 0.95rem;
    background: var(--surface-soft, var(--surface, var(--bs-body-bg)));
}

.tasks-theme-occurrence-card,
.tasks-theme-occurrence-assignment {
    background: transparent;
}

.tasks-theme-control-occurrence {
    border: 0;
    background: transparent;
    border-radius: 0;
}

.tasks-theme-list > .tasks-theme-control-occurrence + .tasks-theme-control-occurrence {
    border-top: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    margin-top: 0.2rem;
    padding-top: 1rem;
}

.tasks-theme-occurrence-header {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
}

.tasks-theme-occurrence-main {
    min-width: 0;
    flex: 1 1 18rem;
}

.tasks-theme-occurrence-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 0.75rem;
    margin-top: 0.45rem;
    align-items: center;
}

.tasks-theme-occurrence-side {
    display: grid;
    gap: 0.9rem;
    justify-items: start;
    flex: 1 1 100%;
}

.tasks-theme-occurrence-control-actions {
    display: inline-flex;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.tasks-theme-occurrence-pills {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 0.55rem;
    width: 100%;
}

.tasks-theme-occurrence-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    min-height: 2rem;
    padding: 0.4rem 0.85rem;
    border-radius: 999px;
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    background: var(--surface-soft, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
    white-space: nowrap;
    min-width: 0;
}

.tasks-theme-occurrence-pill--pending {
    --tasks-pending-accent: color-mix(in srgb, var(--primary, var(--bs-primary)) 82%, var(--bs-info) 18%);
    background: color-mix(in srgb, var(--tasks-pending-accent) 12%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--tasks-pending-accent) 34%, var(--card-border, var(--border-color, var(--bs-border-color))));
}

.tasks-theme-occurrence-pill--approved {
    background: color-mix(in srgb, var(--bs-info) 11%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-info) 34%, var(--card-border, var(--border-color, var(--bs-border-color))));
}

.tasks-theme-occurrence-pill--completed {
    background: color-mix(in srgb, var(--bs-success) 11%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-success) 34%, var(--card-border, var(--border-color, var(--bs-border-color))));
}

.tasks-theme-occurrence-pill--attention {
    background: color-mix(in srgb, var(--bs-warning) 14%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-warning) 36%, var(--card-border, var(--border-color, var(--bs-border-color))));
}

.tasks-theme-occurrence-pill--open {
    background: color-mix(in srgb, var(--bs-danger) 10%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-danger) 30%, var(--card-border, var(--border-color, var(--bs-border-color))));
}

.tasks-theme-occurrence-pill__label {
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-soft, var(--muted, var(--bs-secondary-color)));
}

.tasks-theme-occurrence-pill__value {
    font-size: 0.92rem;
    font-weight: 760;
    line-height: 1;
}

.tasks-theme-occurrence-assignment {
    gap: 1rem;
    align-items: flex-start;
    border: 1px solid color-mix(in srgb, var(--card-border, var(--border-color, var(--bs-border-color))) 78%, transparent);
    border-radius: 0.95rem;
    background: transparent;
    padding: 0.9rem 1rem;
}

.tasks-theme-occurrence-role-group {
    background: transparent;
}

.tasks-theme-occurrence-role-group .tasks-theme-occurrence-assignment {
    background: transparent;
}

.tasks-theme-occurrence-assignment-main {
    min-width: 0;
    flex: 1 1 24rem;
}

.tasks-theme-occurrence-assignment-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem 1rem;
}

.tasks-theme-occurrence-role-name {
    color: var(--tasks-accent-strong, var(--primary, var(--bs-primary)));
    font-size: 1.17rem;
    font-weight: 700;
    line-height: 1.2;
}

.tasks-theme-occurrence-person-link {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.08rem;
    font-weight: 700;
    line-height: 1.2;
    text-decoration: none;
}

.tasks-theme-occurrence-person-link:hover,
.tasks-theme-occurrence-person-link:focus-visible {
    color: var(--text-main, var(--bs-body-color));
    text-decoration: underline;
}

.tasks-theme-occurrence-actions {
    flex: 0 0 auto;
}

.tasks-theme-occurrence-manager-line {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-top: 1rem;
    padding-top: 0.9rem;
    border-top: 1px dashed color-mix(in srgb, var(--card-border, var(--border-color, var(--bs-border-color))) 78%, transparent);
}

.tasks-theme-occurrence-response {
    margin-top: 1rem;
    padding-top: 0.95rem;
    border-top: 1px dashed color-mix(in srgb, var(--card-border, var(--border-color, var(--bs-border-color))) 78%, transparent);
}

.tasks-theme-response-form {
    margin-top: 0.65rem;
}

.tasks-theme-modal {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow);
}

.tasks-theme-modal .modal-header,
.tasks-theme-modal .modal-body {
    padding-left: 1.15rem;
    padding-right: 1.15rem;
}

.tasks-theme-modal .modal-header {
    border-bottom-color: var(--card-border, var(--border-color, var(--bs-border-color)));
}

.tasks-theme-modal .tasks-theme-response-form {
    margin-top: 0;
}

.task-rotation-modal__dialog {
    max-width: 960px;
}

.task-rotation-modal__content {
    border-radius: 1.25rem;
    overflow: hidden;
}

.task-rotation-modal__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.task-rotation-modal__body {
    padding-top: 1rem;
}

.tasks-theme-response-label {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-soft, var(--muted, var(--bs-secondary-color)));
    margin-bottom: 0.45rem;
}

.tasks-theme-response-comment {
    resize: vertical;
    min-height: 4.25rem;
}

.tasks-theme-rotation-card,
.tasks-theme-rotation-entry {
    background: transparent;
}

.tasks-theme-control-rotation {
    background: transparent;
}

.tasks-theme-page .tasks-theme-control-rotation,
.tasks-theme-page .tasks-theme-rotation-entry {
    background: transparent;
}

.tasks-theme-info-stack {
    display: grid;
    gap: 0.75rem;
}

.tasks-theme-control-stack .tasks-theme-info-row {
    background: var(--surface-soft, var(--surface, var(--bs-body-bg)));
}

.tasks-theme-info-row {
    padding: 0.9rem 1rem;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
}

.tasks-theme-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.tasks-theme-field--full {
    grid-column: 1 / -1;
}

.tasks-theme-check {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    min-height: 2.75rem;
}

.tasks-theme-choice-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.7rem;
    min-width: 0;
}

.tasks-theme-choice-option {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    border: 1px solid var(--table-border, var(--card-border, var(--border-color, var(--bs-border-color))));
    border-radius: 1rem;
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    padding: 0.8rem 0.9rem;
    min-height: 4rem;
    transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.tasks-theme-choice-option:hover {
    background: var(--table-row-hover, var(--surface-soft, var(--surface, var(--bs-body-bg))));
    border-color: color-mix(in srgb, var(--primary, var(--bs-primary)) 30%, var(--table-border, var(--card-border, var(--border-color, var(--bs-border-color)))));
    transform: translateY(-1px);
}

.tasks-theme-choice-option input[type="checkbox"] {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.tasks-theme-choice-option__body {
    display: grid;
    gap: 0.18rem;
    min-width: 0;
    flex: 1 1 auto;
}

.tasks-theme-choice-option__name {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.95rem;
    font-weight: 600;
    line-height: 1.35;
}

.tasks-theme-choice-option__indicator {
    width: 0.9rem;
    height: 0.9rem;
    margin-top: 0.25rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--primary, var(--bs-primary)) 22%, var(--table-border, var(--card-border, var(--border-color, var(--bs-border-color)))));
    background: var(--surface-muted, var(--surface-soft, var(--surface, var(--bs-body-bg))));
    box-shadow: inset 0 0 0 0.2rem var(--surface, var(--bs-body-bg));
    flex: 0 0 auto;
}

.tasks-theme-choice-option:has(input[type="checkbox"]:checked) {
    background: color-mix(in srgb, var(--primary-soft, var(--surface-soft, var(--surface, var(--bs-body-bg)))) 72%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--primary, var(--bs-primary)) 36%, var(--table-border, var(--card-border, var(--border-color, var(--bs-border-color)))));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--primary, var(--bs-primary)) 16%, transparent);
}

.tasks-theme-choice-option:has(input[type="checkbox"]:checked) .tasks-theme-choice-option__indicator {
    background: var(--primary, var(--bs-primary));
    border-color: var(--primary, var(--bs-primary));
    box-shadow: inset 0 0 0 0.2rem color-mix(in srgb, var(--surface, var(--bs-body-bg)) 82%, transparent);
}

.tasks-theme-selected-people {
    display: none;
    gap: 0.75rem;
    flex-direction: column;
}

.tasks-theme-selected-people.is-visible {
    display: flex;
}

.tasks-theme-selected-person {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 0.85rem;
    border-radius: 0.9rem;
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    background: var(--surface-soft, var(--surface, var(--bs-body-bg)));
}

.tasks-theme-selected-person__copy {
    min-width: 0;
}

.tasks-theme-selected-person__name {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 600;
    line-height: 1.35;
}

.tasks-theme-selected-person__meta {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.84rem;
}

.tasks-theme-role-summary {
    margin-bottom: 0.9rem;
    padding: 0.8rem 0.9rem;
    border-radius: 0.95rem;
    border: 1px solid color-mix(in srgb, var(--tasks-accent, var(--primary, var(--bs-primary))) 22%, var(--card-border, var(--border-color, var(--bs-border-color))));
    background: color-mix(in srgb, var(--tasks-accent, var(--primary, var(--bs-primary))) 8%, var(--surface, var(--bs-body-bg)));
}

.tasks-theme-role-summary__title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 0.55rem;
}

.tasks-theme-role-summary__metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
}

.tasks-theme-role-summary__metric {
    display: grid;
    gap: 0.18rem;
}

.tasks-theme-role-summary__label {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.76rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.tasks-my-side-card {
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1.15rem;
    box-shadow: var(--card-shadow, 0 14px 30px rgba(0, 0, 0, 0.08));
    overflow: hidden;
}

.tasks-my-side-heading {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    padding: 1rem 1.1rem 0;
}

.tasks-my-side-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1rem;
    font-weight: 700;
}

.tasks-my-side-accent {
    width: 0.35rem;
    min-height: 2rem;
    border-radius: 999px;
    flex: 0 0 auto;
}

.tasks-my-side-accent-blue {
    background: var(--bs-info);
}

.tasks-my-side-accent-gold {
    background: var(--bs-warning);
}

.tasks-my-side-accent-green {
    background: var(--bs-success);
}

.tasks-my-assigned-list {
    display: grid;
    gap: 0.75rem;
}

.tasks-my-assigned-card {
    text-decoration: none;
    color: inherit;
}

.tasks-my-assigned-card:hover {
    color: inherit;
    text-decoration: none;
}

.tasks-my-assigned-topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.tasks-my-assigned-date {
    color: var(--text-muted, var(--bs-secondary-color));
    font-size: 0.82rem;
    font-weight: 600;
}

.tasks-my-assigned-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.98rem;
    font-weight: 700;
}

.tasks-my-assigned-meta {
    margin-top: 0.35rem;
    color: var(--text-muted, var(--bs-secondary-color));
    font-size: 0.9rem;
}

.tasks-my-assigned-footer {
    margin-top: 0.8rem;
}

.tasks-my-next-card {
    display: block;
    text-decoration: none;
    color: inherit;
    transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease;
}

.tasks-my-next-card:hover {
    color: inherit;
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
}

.tasks-my-next-topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.tasks-my-next-date {
    color: var(--text-muted, var(--bs-secondary-color));
    font-size: 0.82rem;
    font-weight: 600;
}

.tasks-my-next-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1rem;
    font-weight: 700;
}

.tasks-my-next-meta,
.tasks-my-next-note,
.tasks-my-empty-small {
    color: var(--text-muted, var(--bs-secondary-color));
    font-size: 0.9rem;
}

.tasks-my-next-meta {
    margin-top: 0.35rem;
}

.tasks-my-next-note {
    margin-top: 0.65rem;
}

.tasks-my-date-list {
    display: grid;
    gap: 0.75rem;
}

.tasks-my-date-card {
    padding: 0.9rem 1rem;
}

.tasks-my-date-value {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 700;
}

.tasks-theme-subpanel {
    padding: 1rem;
}

.tasks-theme-subpanel-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.tasks-confirm-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.75rem;
}

.tasks-confirm-list li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.9rem 1rem;
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    border-radius: 1rem;
    background: var(--surface-soft, var(--surface, var(--bs-body-bg)));
}

.tasks-theme-page .btn-primary,
.tasks-theme-page .btn-primary.theme-action-primary {
    background-color: var(--primary, var(--bs-primary)) !important;
    border-color: var(--primary, var(--bs-primary)) !important;
    color: var(--bs-white) !important;
}

.tasks-theme-page .btn-primary:hover,
.tasks-theme-page .btn-primary.theme-action-primary:hover {
    background-color: var(--primary-hover, var(--primary, var(--bs-primary))) !important;
    border-color: var(--primary-hover, var(--primary, var(--bs-primary))) !important;
}

.tasks-theme-page .btn-outline-secondary,
.tasks-theme-page .btn-outline-secondary.theme-action-outline {
    background: var(--btn-outline-neutral-bg, transparent) !important;
    border-color: var(--btn-outline-neutral-border, var(--border-color, var(--bs-border-color))) !important;
    color: var(--btn-outline-neutral-text, var(--text-main, var(--bs-body-color))) !important;
}

.tasks-theme-page .btn-outline-secondary:hover,
.tasks-theme-page .btn-outline-secondary.theme-action-outline:hover {
    background: var(--btn-outline-neutral-hover-bg, var(--surface-soft)) !important;
    color: var(--btn-outline-neutral-hover-text, var(--text-main, var(--bs-body-color))) !important;
}

.tasks-theme-page .btn-outline-danger {
    background: transparent !important;
    border-color: color-mix(in srgb, var(--bs-danger) 45%, var(--border-color, var(--bs-border-color))) !important;
    color: var(--bs-danger) !important;
}

.tasks-theme-page .btn-outline-danger:hover {
    background: color-mix(in srgb, var(--bs-danger) 16%, var(--surface, var(--bs-body-bg))) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
}

.tasks-theme-page .btn-outline-secondary.theme-action-outline.tasks-theme-action-decline {
    background: color-mix(in srgb, var(--bs-warning) 10%, var(--surface, var(--bs-body-bg))) !important;
    border-color: color-mix(in srgb, var(--bs-warning) 38%, var(--border-color, var(--bs-border-color))) !important;
    color: color-mix(in srgb, var(--bs-warning) 68%, var(--text-main, var(--bs-body-color))) !important;
}

.tasks-theme-page .btn-outline-secondary.theme-action-outline.tasks-theme-action-decline:hover {
    background: color-mix(in srgb, var(--bs-warning) 18%, var(--surface, var(--bs-body-bg))) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
}

.tasks-theme-page .btn-outline-secondary.theme-action-outline.tasks-theme-action-reopen {
    background: color-mix(in srgb, var(--bs-info) 10%, var(--surface, var(--bs-body-bg))) !important;
    border-color: color-mix(in srgb, var(--bs-info) 38%, var(--border-color, var(--bs-border-color))) !important;
    color: color-mix(in srgb, var(--bs-info) 68%, var(--text-main, var(--bs-body-color))) !important;
}

.tasks-theme-page .btn-outline-secondary.theme-action-outline.tasks-theme-action-reopen:hover {
    background: color-mix(in srgb, var(--bs-info) 18%, var(--surface, var(--bs-body-bg))) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
}

.tasks-theme-page .btn-outline-secondary.theme-action-outline.tasks-theme-action-stuck {
    background: color-mix(in srgb, var(--bs-warning) 12%, var(--surface, var(--bs-body-bg))) !important;
    border-color: color-mix(in srgb, var(--bs-warning) 34%, var(--border-color, var(--bs-border-color))) !important;
    color: color-mix(in srgb, var(--bs-warning) 72%, var(--text-main, var(--bs-body-color))) !important;
}

.tasks-theme-page .btn-outline-secondary.theme-action-outline.tasks-theme-action-stuck:hover {
    background: color-mix(in srgb, var(--bs-warning) 20%, var(--surface, var(--bs-body-bg))) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
}

.tasks-theme-page .btn-outline-secondary.theme-action-outline.tasks-theme-action-incomplete {
    background: color-mix(in srgb, var(--bs-danger) 10%, var(--surface, var(--bs-body-bg))) !important;
    border-color: color-mix(in srgb, var(--bs-danger) 34%, var(--border-color, var(--bs-border-color))) !important;
    color: color-mix(in srgb, var(--bs-danger) 68%, var(--text-main, var(--bs-body-color))) !important;
}

.tasks-theme-page .btn-outline-secondary.theme-action-outline.tasks-theme-action-incomplete:hover {
    background: color-mix(in srgb, var(--bs-danger) 18%, var(--surface, var(--bs-body-bg))) !important;
    color: var(--text-main, var(--bs-body-color)) !important;
}

.tasks-report-sheet {
    padding: 1.35rem 1.45rem 1.45rem;
    background: var(--surface, var(--bs-body-bg));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow);
    border-radius: 1.25rem;
}

.tasks-report-filter-card {
    background: var(--surface, var(--bs-body-bg));
    border: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
    box-shadow: var(--card-shadow);
    border-radius: 1.25rem;
}

.tasks-report-filter-card .tasks-theme-card-header {
    padding-left: 1.35rem;
    padding-right: 1.35rem;
    padding-top: 1.25rem;
}

.tasks-report-filter-card .tasks-theme-filter {
    background: var(--surface, var(--bs-body-bg));
    border: 0;
    box-shadow: none;
    border-radius: 0 0 1.25rem 1.25rem;
    padding-left: 1.35rem;
    padding-right: 1.35rem;
    padding-bottom: 1.35rem;
}

.tasks-report-sheet-header {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--card-border, var(--border-color, var(--bs-border-color)));
}

.tasks-report-sheet-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.4rem, 2vw, 1.8rem);
    font-weight: 720;
    margin: 0.2rem 0 0.25rem;
    letter-spacing: -0.03em;
}

.tasks-report-sheet-subtitle {
    max-width: 34rem;
    line-height: 1.45;
}

.tasks-report-sheet-meta {
    display: grid;
    gap: 0.6rem;
    align-content: start;
    min-width: 15rem;
}

.tasks-report-meta-row {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    padding-bottom: 0.35rem;
    border-bottom: 1px dashed var(--card-border, var(--border-color, var(--bs-border-color)));
}

.tasks-report-layout-list,
.tasks-report-column-list {
    display: grid;
    gap: 0.7rem;
}

.tasks-report-layout-list {
    grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
}

.tasks-report-column-list {
    grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
}

.tasks-report-option {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.8rem 0.9rem;
    min-height: 4rem;
    border-radius: 1rem;
    border: 1px solid var(--table-border, var(--card-border, var(--border-color, var(--bs-border-color))));
    background: var(--surface, var(--bs-body-bg));
    color: var(--text-main, var(--bs-body-color));
    transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.tasks-report-option:hover {
    background: var(--table-row-hover, var(--surface-soft, var(--surface, var(--bs-body-bg))));
    border-color: color-mix(in srgb, var(--primary, var(--bs-primary)) 30%, var(--table-border, var(--card-border, var(--border-color, var(--bs-border-color)))));
    transform: translateY(-1px);
}

.tasks-report-option input[type="checkbox"],
.tasks-report-option input[type="radio"] {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.tasks-report-option__body {
    display: grid;
    gap: 0.18rem;
    min-width: 0;
    flex: 1 1 auto;
}

.tasks-report-option__name {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.95rem;
    font-weight: 600;
    line-height: 1.35;
}

.tasks-report-option__meta {
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.8rem;
    line-height: 1.3;
}

.tasks-report-option__indicator {
    width: 0.9rem;
    height: 0.9rem;
    margin-top: 0.25rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--primary, var(--bs-primary)) 22%, var(--table-border, var(--card-border, var(--border-color, var(--bs-border-color)))));
    background: var(--surface-muted, var(--surface-soft, var(--surface, var(--bs-body-bg))));
    box-shadow: inset 0 0 0 0.2rem var(--surface, var(--bs-body-bg));
    flex: 0 0 auto;
}

.tasks-report-option:has(input:checked) {
    background: color-mix(in srgb, var(--primary-soft, var(--surface-soft, var(--surface, var(--bs-body-bg)))) 72%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--primary, var(--bs-primary)) 36%, var(--table-border, var(--card-border, var(--border-color, var(--bs-border-color)))));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--primary, var(--bs-primary)) 16%, transparent);
}

.tasks-report-option:has(input:checked) .tasks-report-option__indicator {
    background: var(--primary, var(--bs-primary));
    border-color: var(--primary, var(--bs-primary));
    box-shadow: inset 0 0 0 0.2rem color-mix(in srgb, var(--surface, var(--bs-body-bg)) 82%, transparent);
}

.tasks-report-preview-note {
    margin-top: 1rem;
    margin-bottom: -0.2rem;
    padding: 0.8rem 0.95rem;
    border-radius: 0.95rem;
    border: 1px solid color-mix(in srgb, var(--bs-warning) 32%, var(--card-border, var(--border-color, var(--bs-border-color))));
    background: color-mix(in srgb, var(--bs-warning) 10%, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.9rem;
}

.tasks-report-table-wrap {
    padding: 1.2rem 0 0;
}

.tasks-report-group-list {
    display: grid;
    gap: 1.75rem;
}

.tasks-report-group {
    display: grid;
    gap: 0.35rem;
}

.tasks-report-group-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--text-main, var(--bs-body-color));
    padding-bottom: 0.2rem;
    border-bottom: 1px solid color-mix(in srgb, var(--card-border, var(--border-color, var(--bs-border-color))) 78%, transparent);
}

.tasks-report-table thead th {
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    vertical-align: middle;
}

.tasks-report-table tbody td {
    padding-top: 0.7rem;
    padding-bottom: 0.7rem;
    vertical-align: top;
}

.tasks-report-date-cell {
    width: 11rem;
}

.tasks-report-date {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 620;
}

.tasks-report-name {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 650;
}

.tasks-report-context {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-top: 0.25rem;
    color: var(--text-muted, var(--muted, var(--bs-secondary-color)));
    font-size: 0.85rem;
}

.tasks-report-table--wide {
    font-size: 0.92rem;
}

.tasks-report-table--wide thead th {
    font-size: 0.74rem;
}

@page {
    size: letter portrait;
    margin: 0.42in 0.45in 0.48in;
}

@media print {
    html,
    body {
        font-size: 13.3px !important;
        line-height: 1.32 !important;
        color: #111 !important;
        background: #fff !important;
    }

    .app-sidebar,
    .app-topbar,
    .offcanvas-sidebar,
    .tasks-report-screen-only {
        display: none !important;
    }

    .app-main {
        margin-left: 0 !important;
        width: 100% !important;
        min-height: auto !important;
    }

    .app-content {
        padding: 0 !important;
        background: #fff !important;
    }

    .tasks-report-page,
    .tasks-theme-page {
        background: #fff !important;
    }

    .tasks-report-sheet {
        border: 0 !important;
        border-radius: 0 !important;
        box-shadow: none !important;
        padding: 0 !important;
    }

    .tasks-report-sheet-header {
        gap: 0.7rem !important;
        padding-bottom: 0.55rem !important;
        margin-bottom: 0.15rem !important;
        border-bottom: 1px solid #1f2937 !important;
        break-inside: avoid;
        page-break-inside: avoid;
    }

    .tasks-report-sheet-title {
        font-size: 20.8px !important;
        line-height: 1.1 !important;
        margin: 0.1rem 0 0.15rem !important;
        letter-spacing: -0.01em !important;
        color: #111 !important;
    }

    .tasks-report-sheet-subtitle,
    .tasks-theme-card-subtitle,
    .tasks-report-context,
    .tasks-theme-note {
        font-size: 11.7px !important;
        line-height: 1.25 !important;
        color: #4b5563 !important;
    }

    .tasks-report-sheet-meta {
        min-width: 11rem !important;
        gap: 0.25rem !important;
    }

    .tasks-report-meta-row {
        gap: 0.45rem !important;
        padding-bottom: 0.16rem !important;
        border-bottom: 1px dotted #cbd5e1 !important;
        font-size: 11.7px !important;
    }

    .tasks-report-table-wrap {
        padding-top: 0.42rem !important;
    }

    .tasks-report-group {
        break-inside: avoid;
        page-break-inside: avoid;
        gap: 0.18rem !important;
        margin-top: 0.28rem !important;
    }

    .tasks-report-group-list {
        gap: 0.8rem !important;
    }

    .tasks-report-group-title {
        font-size: 13.3px !important;
        font-weight: 700 !important;
        line-height: 1.2 !important;
        padding-bottom: 0.1rem !important;
        margin-bottom: 0.02rem !important;
        color: #111 !important;
        border-bottom: 1px solid #d1d5db !important;
        break-after: avoid;
        page-break-after: avoid;
    }

    .tasks-report-table {
        width: 100% !important;
        border-collapse: collapse !important;
        font-size: 11.7px !important;
    }

    .tasks-report-table thead {
        display: table-header-group !important;
    }

    .tasks-report-table tfoot {
        display: table-footer-group !important;
    }

    .tasks-report-table thead th {
        font-size: 10.4px !important;
        letter-spacing: 0.06em !important;
        padding-top: 0.28rem !important;
        padding-bottom: 0.28rem !important;
        color: #374151 !important;
        border-bottom: 1px solid #9ca3af !important;
    }

    .tasks-report-table tbody tr:hover {
        background: transparent !important;
    }

    .tasks-report-table tbody td {
        padding-top: 0.24rem !important;
        padding-bottom: 0.24rem !important;
        padding-left: 0.34rem !important;
        padding-right: 0.34rem !important;
        line-height: 1.22 !important;
        color: #111 !important;
        border-bottom: 1px solid #e5e7eb !important;
        break-inside: avoid;
        page-break-inside: avoid;
    }

    .tasks-report-date-cell {
        width: 18% !important;
    }

    .tasks-report-date,
    .tasks-report-name {
        font-weight: 650 !important;
        color: #111 !important;
    }

    .tasks-theme-empty {
        font-size: 11.7px !important;
        color: #6b7280 !important;
        padding: 0.5rem 0 !important;
    }

    .tasks-report-table--wide {
        font-size: 10.9px !important;
    }

    .tasks-report-table--wide thead th {
        font-size: 9.9px !important;
    }

    .tasks-report-preview-note {
        display: none !important;
    }
}

@media (max-width: 1199.98px) {
    .tasks-theme-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .tasks-theme-control-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .tasks-theme-report-grid {
        grid-template-columns: 1fr;
    }

    .tasks-report-layout-list,
    .tasks-report-column-list {
        grid-template-columns: 1fr;
        gap: 0.65rem;
    }

    .tasks-report-option {
        min-height: auto;
        padding: 0.78rem 0.85rem;
        border-radius: 0.95rem;
        align-items: center;
    }

    .tasks-report-option__body {
        gap: 0.14rem;
    }

    .tasks-report-option__name {
        font-size: 0.93rem;
    }

    .tasks-report-option__meta {
        font-size: 0.79rem;
        line-height: 1.28;
    }

    .tasks-report-option__indicator {
        margin-top: 0;
    }

    .tasks-report-table thead th {
        padding-top: 0.52rem;
        padding-bottom: 0.52rem;
        padding-left: 0.8rem;
        padding-right: 0.8rem;
        font-size: 0.74rem;
        letter-spacing: 0.06em;
    }
}

@media (max-width: 991.98px) {
    .tasks-theme-hero-body,
    .tasks-theme-card,
    .tasks-theme-filter {
        padding: 1rem;
    }

    .tasks-theme-actions {
        justify-content: flex-start;
    }

    .tasks-theme-form-grid,
    .tasks-theme-filter-grid,
    .tasks-theme-choice-grid {
        grid-template-columns: 1fr;
    }

    .tasks-theme-role-summary__metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .tasks-theme-filter-grid > div,
    .tasks-theme-filter-grid .tasks-theme-filter-wide {
        grid-column: auto;
    }

    .tasks-theme-occurrence-assignment-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .tasks-theme-occurrence-pills {
        width: 100%;
    }

    .task-rotation-modal__dialog {
        margin: 0.75rem;
    }

    .tasks-theme-occurrence-manager-line {
        align-items: flex-start;
    }

    .tasks-report-sheet {
        padding: 1.15rem;
    }

    .tasks-report-sheet-meta {
        min-width: 0;
        width: 100%;
    }
}

@media (max-width: 575.98px) {
    .tasks-theme-metrics {
        grid-template-columns: 1fr;
    }

    .tasks-theme-control-grid {
        grid-template-columns: 1fr;
    }

    .tasks-theme-mini-metrics {
        grid-template-columns: 1fr;
    }

    .tasks-theme-occurrence-pills {
        gap: 0.45rem;
    }

    .tasks-theme-filter-actions {
        flex-direction: column;
    }

    .tasks-theme-filter-actions .btn {
        width: 100%;
    }

    .tasks-report-option {
        padding: 0.72rem 0.8rem;
    }

    .tasks-report-option__name {
        font-size: 0.91rem;
    }

    .tasks-report-option__meta {
        font-size: 0.77rem;
    }

    .tasks-report-table thead th {
        padding-top: 0.46rem;
        padding-bottom: 0.46rem;
        padding-left: 0.72rem;
        padding-right: 0.72rem;
        font-size: 0.72rem;
    }
}

/* ===== Giving themed module ===== */
.giving-theme-page,
.giving-form-page,
.giving-confirm-page {
    --giving-accent: #d78b2f;
    --giving-accent-strong: #8b5c16;
    --giving-surface: var(--surface, var(--bs-body-bg));
    --giving-surface-soft: var(--surface-soft, var(--bs-body-bg));
    --giving-border: var(--card-border, var(--border-color, var(--bs-border-color)));
    --giving-border-strong: color-mix(in srgb, var(--giving-accent) 18%, var(--card-border, var(--border-color, var(--bs-border-color))));
}

.giving-theme-shell,
.giving-theme-card,
.giving-theme-panel,
.giving-form-shell,
.giving-form-panel,
.giving-confirm-shell,
.giving-confirm-panel {
    border: 1px solid var(--giving-border);
    border-radius: 1.35rem;
    background: var(--giving-surface);
    box-shadow: var(--card-shadow, 0 16px 36px rgba(15, 23, 42, 0.08));
}

.giving-theme-hero,
.giving-form-shell,
.giving-confirm-shell {
    overflow: hidden;
    position: relative;
}

.giving-theme-hero-accent,
.giving-form-accent,
.giving-confirm-accent {
    position: absolute;
    inset: 0 auto 0 0;
    width: 0.42rem;
    background: linear-gradient(180deg, color-mix(in srgb, var(--giving-accent) 88%, #ffffff 12%) 0%, color-mix(in srgb, var(--giving-accent-strong) 90%, #000000 10%) 100%);
}

.giving-theme-hero-body,
.giving-form-shell-body,
.giving-confirm-shell-body {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1.5rem;
    padding: 1.45rem 1.5rem;
}

.giving-theme-label,
.giving-form-label,
.giving-confirm-label {
    color: var(--giving-accent-strong);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.09em;
    text-transform: uppercase;
}

.giving-theme-title,
.giving-form-title,
.giving-confirm-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.7rem, 2.4vw, 2.15rem);
    font-weight: 750;
    line-height: 1.08;
}

.giving-theme-subtitle,
.giving-form-subtitle,
.giving-confirm-subtitle,
.giving-theme-context,
.giving-form-context,
.giving-confirm-copy,
.giving-theme-card-subtitle,
.giving-form-panel-subtitle,
.giving-confirm-panel-subtitle,
.giving-theme-table-note,
.giving-theme-empty,
.giving-theme-meta,
.giving-theme-note {
    color: var(--text-muted, var(--bs-secondary-color));
    font-size: 0.95rem;
    line-height: 1.6;
}

.giving-theme-context,
.giving-form-context {
    margin-top: 0.75rem;
}

.giving-theme-context-label,
.giving-form-context-label {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 600;
}

.giving-theme-actions,
.giving-form-actions,
.giving-confirm-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.giving-batch-page .giving-theme-shell {
    border-radius: 1.25rem;
}

.giving-batch-page .giving-theme-hero {
    overflow: hidden;
}

.giving-batch-page .giving-theme-hero-accent {
    width: auto;
    height: 0.5rem;
    inset: 0 0 auto 0;
    background: linear-gradient(90deg, var(--primary, var(--bs-primary)), var(--bs-info), var(--bs-danger), var(--bs-warning));
}

.giving-batch-page .giving-theme-hero-body {
    align-items: center;
    flex-wrap: wrap;
    padding: 1.5rem;
}

.giving-batch-header-block {
    min-width: 0;
}

.giving-batch-title-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.giving-batch-page .giving-theme-title {
    font-size: clamp(1.75rem, 2.4vw, 2.45rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.035em;
}

.giving-batch-subtitle,
.giving-batch-context-line {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem;
    color: var(--text-muted, var(--bs-secondary-color));
}

.giving-batch-subtitle {
    margin-top: 0.45rem;
    font-size: 0.92rem;
}

.giving-batch-context-line {
    margin-top: 0.65rem;
    font-size: 0.92rem;
}

.giving-batch-context-label {
    color: var(--text-muted, var(--bs-secondary-color));
    font-weight: 500;
}

.giving-batch-context-divider {
    color: var(--text-soft, var(--bs-secondary-color));
}

.giving-theme-action-warning {
    background: color-mix(in srgb, var(--bs-warning) 16%, var(--surface, var(--bs-body-bg)));
    color: var(--text-main, var(--bs-body-color));
    border: 1px solid color-mix(in srgb, var(--bs-warning) 42%, var(--card-border, var(--bs-border-color)));
}

.giving-theme-action-warning:hover,
.giving-theme-action-warning:focus-visible {
    background: color-mix(in srgb, var(--bs-warning) 24%, var(--surface, var(--bs-body-bg)));
    border-color: color-mix(in srgb, var(--bs-warning) 54%, var(--card-border, var(--bs-border-color)));
    color: var(--text-main, var(--bs-body-color));
}

.giving-theme-action-warning:focus-visible {
    box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--bs-warning) 22%, transparent);
}

.giving-batch-page .giving-theme-metrics {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.giving-batch-metric-card {
    position: relative;
    padding: 1.15rem;
    border-radius: 1.25rem;
}

.giving-batch-metric-card::before {
    display: none;
}

.giving-batch-metric-card .giving-theme-stat-label {
    font-size: 0.72rem;
    letter-spacing: 0.08em;
}

.giving-batch-metric-card .giving-theme-stat-value {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.04em;
    margin-top: 0.6rem;
}

.giving-batch-metric-value--compact {
    font-size: 1.05rem !important;
    letter-spacing: -0.01em !important;
    line-height: 1.35 !important;
}

.giving-batch-metric-card .giving-theme-hint {
    font-size: 0.78rem;
    margin-top: 0.25rem;
}

.giving-theme-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr));
    gap: 1rem;
}

.giving-theme-metric {
    position: relative;
    padding: 1.15rem 1.2rem;
    border: 1px solid var(--giving-border);
    border-radius: 1.15rem;
    background: var(--giving-surface);
    box-shadow: var(--card-shadow, 0 16px 30px rgba(15, 23, 42, 0.06));
    overflow: hidden;
}

.giving-theme-metric::before {
    content: "";
    position: absolute;
    inset: 0.95rem auto 0.95rem 0;
    width: 0.22rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--giving-accent) 78%, #ffffff 22%);
}

.giving-batch-page .giving-theme-metric::before,
.giving-report-page .giving-theme-metric::before {
    content: none;
    display: none;
}

.giving-fund-page .giving-theme-metric::before,
.giving-fund-page .giving-form-accent {
    content: none;
    display: none;
}

.giving-fund-page .giving-theme-hero-accent {
    width: auto;
    height: 0.5rem;
    inset: 0 0 auto 0;
    background: linear-gradient(
        90deg,
        var(--primary, var(--bs-primary)),
        color-mix(in srgb, var(--primary, var(--bs-primary)) 62%, var(--bs-info) 38%),
        color-mix(in srgb, var(--bs-info) 58%, var(--bs-warning) 42%)
    );
}

.giving-fund-page .giving-form-shell {
    overflow: hidden;
}

.giving-fund-page .giving-form-shell-body {
    align-items: center;
    flex-wrap: wrap;
    padding: 1.5rem;
}

.giving-fund-page .giving-form-shell::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 0.5rem;
    background: linear-gradient(
        90deg,
        var(--primary, var(--bs-primary)),
        color-mix(in srgb, var(--primary, var(--bs-primary)) 62%, var(--bs-info) 38%),
        color-mix(in srgb, var(--bs-info) 58%, var(--bs-warning) 42%)
    );
}

.giving-fund-page .giving-theme-card-body {
    padding-top: 0;
}

.giving-theme-stat-label {
    color: var(--text-muted, var(--bs-secondary-color));
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.giving-theme-stat-value {
    color: var(--text-main, var(--bs-body-color));
    font-size: clamp(1.5rem, 2vw, 2rem);
    font-weight: 760;
    line-height: 1.05;
    margin-top: 0.4rem;
}

.giving-theme-hint {
    color: var(--text-muted, var(--bs-secondary-color));
    font-size: 0.88rem;
    margin-top: 0.45rem;
}

.giving-theme-card,
.giving-theme-panel,
.giving-form-panel,
.giving-confirm-panel {
    overflow: hidden;
}

.giving-theme-card-header,
.giving-theme-panel-header,
.giving-form-panel-header,
.giving-confirm-panel-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.1rem 1.25rem;
    border-bottom: 1px solid var(--giving-border);
    background: transparent;
}

.giving-theme-card-body,
.giving-theme-panel-body,
.giving-form-panel-body,
.giving-confirm-panel-body {
    padding: 1.2rem 1.25rem 1.25rem;
}

.giving-theme-section-title,
.giving-form-panel-title,
.giving-confirm-panel-title {
    color: var(--text-main, var(--bs-body-color));
    font-size: 1.04rem;
    font-weight: 700;
    margin: 0;
}

.giving-theme-filter {
    padding: 1.2rem 1.25rem 0;
}

.giving-theme-filter-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 0.95rem 1rem;
    align-items: end;
}

.giving-theme-filter-grid > div {
    grid-column: span 2;
}

.giving-theme-filter-grid .giving-theme-filter-wide {
    grid-column: span 3;
}

.giving-theme-filter-grid .giving-theme-filter-actions {
    grid-column: span 2;
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.giving-theme-filter-grid--reports {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
}

.giving-theme-filter-grid--reports > div,
.giving-theme-filter-grid--reports .giving-theme-filter-wide,
.giving-theme-filter-grid--reports .giving-theme-filter-actions {
    grid-column: span 1;
}

.giving-theme-filter-grid--reports .giving-theme-filter-wide {
    grid-column: span 1;
}

.giving-theme-filter-grid--reports .giving-theme-filter-actions {
    grid-column: 1 / -1;
    align-self: start;
    justify-content: flex-start;
    padding-top: 0.2rem;
}

.giving-theme-table-wrap {
    padding: 0 1.25rem 1.25rem;
}

.giving-theme-table {
    --bs-table-bg: transparent;
    --bs-table-border-color: var(--table-border, var(--giving-border));
    margin: 0;
}

.giving-theme-table > :not(caption) > * > * {
    padding: 0.95rem 1rem;
    border-color: var(--table-border, var(--giving-border));
    vertical-align: middle;
}

.giving-theme-table tbody tr:hover > * {
    background: color-mix(in srgb, var(--giving-accent) 7%, var(--surface-soft, var(--surface, var(--bs-body-bg))));
}

.giving-report-page .giving-theme-metric::before {
    display: none;
}

.giving-report-page .giving-theme-metric {
    padding-left: 1.2rem;
}

.giving-report-page .giving-theme-filter {
    padding-bottom: 1.2rem;
}

.giving-theme-list {
    display: grid;
    gap: 0.8rem;
}

.giving-theme-list-item,
.giving-theme-item-card,
.giving-theme-workflow-step {
    border: 1px solid var(--giving-border);
    border-radius: 1rem;
    background: color-mix(in srgb, var(--giving-surface) 88%, var(--surface-soft, var(--bs-body-bg)) 12%);
    padding: 0.95rem 1rem;
}

.giving-theme-item-title {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 650;
}

.giving-theme-status,
.giving-theme-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.28rem 0.72rem;
    border-radius: 999px;
    border: 1px solid var(--giving-border-strong);
    background: color-mix(in srgb, var(--giving-accent) 10%, var(--giving-surface));
    color: var(--text-main, var(--bs-body-color));
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1;
}

.giving-theme-status--posted,
.giving-theme-status--active,
.giving-theme-pill--success {
    border-color: color-mix(in srgb, var(--bs-success) 40%, var(--giving-border));
    background: color-mix(in srgb, var(--bs-success) 12%, var(--giving-surface));
    color: color-mix(in srgb, var(--bs-success) 88%, var(--text-main, var(--bs-body-color)));
}

.giving-theme-status--open,
.giving-theme-pill--warning {
    border-color: color-mix(in srgb, var(--bs-warning) 42%, var(--giving-border));
    background: color-mix(in srgb, var(--bs-warning) 12%, var(--giving-surface));
    color: color-mix(in srgb, var(--bs-warning) 76%, var(--text-main, var(--bs-body-color)));
}

.giving-theme-status--inactive,
.giving-theme-pill--neutral {
    border-color: var(--giving-border);
    background: color-mix(in srgb, var(--surface-soft, var(--surface, var(--bs-body-bg))) 72%, var(--giving-surface) 28%);
    color: var(--text-muted, var(--bs-secondary-color));
}

.giving-theme-status--danger,
.giving-theme-pill--danger {
    border-color: color-mix(in srgb, var(--bs-danger) 42%, var(--giving-border));
    background: color-mix(in srgb, var(--bs-danger) 10%, var(--giving-surface));
    color: color-mix(in srgb, var(--bs-danger) 84%, var(--text-main, var(--bs-body-color)));
}

.giving-theme-empty {
    text-align: center;
    padding: 2.25rem 1rem;
}

.giving-theme-empty p:last-child {
    margin-bottom: 0;
}

.giving-theme-chart-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.giving-theme-chart-card {
    border: 1px solid var(--giving-border);
    border-radius: 1.15rem;
    background: var(--giving-surface);
    padding: 1rem;
}

.giving-theme-chart-shell {
    max-width: 220px;
    height: 220px;
    margin: 0 auto;
}

.giving-theme-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.giving-theme-form-grid .giving-theme-field--full {
    grid-column: 1 / -1;
}

.giving-theme-check {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.9rem 1rem;
    border: 1px solid var(--giving-border);
    border-radius: 1rem;
    background: color-mix(in srgb, var(--surface-soft, var(--bs-body-bg)) 38%, var(--giving-surface) 62%);
}

.giving-confirm-blockers {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.85rem;
}

.giving-confirm-blockers li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 0.95rem 1rem;
    border: 1px solid var(--giving-border);
    border-radius: 1rem;
    background: color-mix(in srgb, var(--surface-soft, var(--bs-body-bg)) 42%, var(--giving-surface) 58%);
}

.giving-confirm-blocker-count {
    min-width: 2.3rem;
    height: 2.3rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    border: 1px solid var(--giving-border-strong);
    font-weight: 700;
}

.giving-theme-modal .modal-content {
    border: 1px solid var(--giving-border);
    border-radius: 1.2rem;
    overflow: hidden;
    background: var(--giving-surface);
    box-shadow: var(--card-shadow, 0 18px 36px rgba(15, 23, 42, 0.14));
}

.giving-theme-modal .modal-header {
    background: var(--surface, var(--bs-body-bg));
    border-bottom-color: var(--giving-border);
}

.giving-theme-modal .modal-footer {
    border-top-color: var(--giving-border);
}

.giving-theme-report-section {
    border: 1px solid var(--giving-border);
    border-radius: 1.15rem;
    overflow: hidden;
    background: var(--giving-surface);
    box-shadow: var(--card-shadow, 0 12px 28px rgba(15, 23, 42, 0.06));
}

.giving-theme-report-header {
    padding: 1rem 1.1rem 0.95rem;
    background: color-mix(in srgb, var(--giving-surface) 90%, var(--surface-soft, var(--bs-body-bg)) 10%);
    border-bottom: 1px solid var(--giving-border);
}

.giving-theme-report-subtotal > th,
.giving-theme-report-subtotal > td {
    background: color-mix(in srgb, var(--giving-accent) 8%, var(--giving-surface)) !important;
    font-weight: 700;
}

.giving-theme-report-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.2rem;
    border: 1px solid var(--giving-border-strong);
    border-radius: 1.15rem;
    background: color-mix(in srgb, var(--giving-surface) 90%, var(--surface-soft, var(--bs-body-bg)) 10%);
}

.giving-theme-note-cell {
    max-width: 380px;
    white-space: normal;
    overflow-wrap: anywhere;
}

.giving-theme-report-table {
    table-layout: fixed;
    width: 100%;
}

.giving-theme-report-table .col-person { width: 24%; }
.giving-theme-report-table .col-fund { width: 20%; }
.giving-theme-report-table .col-method { width: 14%; }
.giving-theme-report-table .col-amount { width: 12%; }
.giving-theme-report-table .col-note { width: 30%; }

.giving-theme-summary-table th {
    color: var(--text-main, var(--bs-body-color));
    font-weight: 650;
}

.giving-theme-page .btn-outline-secondary,
.giving-theme-page .btn-outline-secondary.theme-action-outline,
.giving-form-page .btn-outline-secondary,
.giving-form-page .btn-outline-secondary.theme-action-outline,
.giving-confirm-page .btn-outline-secondary,
.giving-confirm-page .btn-outline-secondary.theme-action-outline {
    background: var(--btn-outline-neutral-bg, transparent) !important;
    border-color: var(--btn-outline-neutral-border, var(--giving-border)) !important;
    color: var(--btn-outline-neutral-text, var(--text-main, var(--bs-body-color))) !important;
}

.giving-theme-page .btn-outline-secondary:hover,
.giving-theme-page .btn-outline-secondary.theme-action-outline:hover,
.giving-form-page .btn-outline-secondary:hover,
.giving-form-page .btn-outline-secondary.theme-action-outline:hover,
.giving-confirm-page .btn-outline-secondary:hover,
.giving-confirm-page .btn-outline-secondary.theme-action-outline:hover {
    background: var(--btn-outline-neutral-hover-bg, var(--surface-soft)) !important;
    color: var(--btn-outline-neutral-hover-text, var(--text-main, var(--bs-body-color))) !important;
}

.giving-theme-page .btn-outline-danger,
.giving-form-page .btn-outline-danger,
.giving-confirm-page .btn-outline-danger {
    color: var(--bs-danger) !important;
    border-color: color-mix(in srgb, var(--bs-danger) 45%, var(--giving-border)) !important;
}

.giving-theme-page .btn-outline-danger:hover,
.giving-form-page .btn-outline-danger:hover,
.giving-confirm-page .btn-outline-danger:hover {
    color: #fff !important;
}

@media (max-width: 1199.98px) {
    .giving-batch-page .giving-theme-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .giving-theme-filter-grid > div,
    .giving-theme-filter-grid .giving-theme-filter-wide,
    .giving-theme-filter-grid .giving-theme-filter-actions {
        grid-column: span 3;
    }

    .giving-theme-filter-grid--reports {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .giving-theme-filter-grid--reports > div,
    .giving-theme-filter-grid--reports .giving-theme-filter-wide,
    .giving-theme-filter-grid--reports .giving-theme-filter-actions {
        grid-column: span 1;
    }

    .giving-theme-filter-grid--reports .giving-theme-filter-wide {
        grid-column: span 2;
    }

    .giving-theme-filter-grid--reports .giving-theme-filter-actions {
        grid-column: 1 / -1;
    }
}

@media (max-width: 991.98px) {
    .giving-theme-hero-body,
    .giving-form-shell-body,
    .giving-confirm-shell-body,
    .giving-theme-card-header,
    .giving-theme-panel-header,
    .giving-form-panel-header,
    .giving-confirm-panel-header {
        flex-direction: column;
        align-items: stretch;
    }

    .giving-theme-chart-grid,
    .giving-theme-form-grid {
        grid-template-columns: 1fr;
    }

    .giving-batch-page .giving-theme-hero-body {
        padding: 1.25rem;
    }

    .giving-batch-page .giving-theme-metrics {
        grid-template-columns: 1fr;
    }

    .giving-theme-filter-grid > div,
    .giving-theme-filter-grid .giving-theme-filter-wide,
    .giving-theme-filter-grid .giving-theme-filter-actions {
        grid-column: span 6;
    }

    .giving-theme-filter-grid--reports {
        grid-template-columns: 1fr;
    }

    .giving-theme-filter-grid--reports > div,
    .giving-theme-filter-grid--reports .giving-theme-filter-wide,
    .giving-theme-filter-grid--reports .giving-theme-filter-actions {
        grid-column: 1 / -1;
    }
}

@media (max-width: 767.98px) {
    .giving-theme-table-wrap,
    .giving-theme-filter,
    .giving-theme-card-body,
    .giving-theme-panel-body,
    .giving-form-panel-body,
    .giving-confirm-panel-body {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .giving-theme-hero-body,
    .giving-form-shell-body,
    .giving-confirm-shell-body,
    .giving-theme-card-header,
    .giving-theme-panel-header,
    .giving-form-panel-header,
    .giving-confirm-panel-header {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .giving-batch-page .giving-theme-hero-body {
        padding: 1rem;
    }

    .giving-theme-filter-grid > div,
    .giving-theme-filter-grid .giving-theme-filter-wide,
    .giving-theme-filter-grid .giving-theme-filter-actions {
        grid-column: 1 / -1;
    }
}
