:root,
html[data-theme="dark"] {
    color-scheme: dark;
    --bg: #0a121a;
    --bg-2: #0e1723;
    --panel: #121d2a;
    --panel-rgb: 18, 29, 42;
    --panel-soft: #162638;
    --panel-strong: #071019;
    --surface: #f7faf8;
    --text: #eaf4ff;
    --text-rgb: 234, 244, 255;
    --muted: #98aabc;
    --line: rgba(124, 240, 214, 0.2);
    --line-strong: rgba(124, 240, 214, 0.32);
    --accent: #22d0b6;
    --accent-rgb: 34, 208, 182;
    --accent-strong: #18bca4;
    --accent-hover: #48e6cf;
    --accent-ink: #02221d;
    --success: #5ee098;
    --success-rgb: 94, 224, 152;
    --warning: #ffd166;
    --warning-rgb: 255, 209, 102;
    --danger: #ff6b7d;
    --danger-rgb: 255, 107, 125;
    --signal: #ffd166;
    --grid-rgb: 124, 240, 214;
    --grid-opacity: 0.028;
    --body-bg: linear-gradient(180deg, #0e1723 0%, #0a121a 100%);
    --glass-bg: rgba(var(--panel-rgb), 0.92);
    --glass-bg-strong: rgba(var(--panel-rgb), 0.97);
    --input-bg: rgba(255, 255, 255, 0.035);
    --input-bg-focus: rgba(var(--accent-rgb), 0.08);
    --row-hover: rgba(var(--accent-rgb), 0.055);
    --row-alt: rgba(255, 255, 255, 0.022);
    --table-head-bg: #102033;
    --table-sticky-bg: #101b28;
    --dropdown-bg: #101b28;
    --modal-backdrop: rgba(3, 8, 18, 0.72);
    --footer-bg: rgba(10, 18, 26, 0.94);
    --bubble-bg: #eaf4ff;
    --bubble-text: #0a121a;
    --shadow: 0 20px 55px rgba(0, 0, 0, 0.36);
    --shadow-soft: 0 14px 34px rgba(0, 0, 0, 0.26);
    --focus-ring: rgba(var(--accent-rgb), 0.18);
}

html[data-theme="light"] {
    color-scheme: light;
    --bg: #f4fbf7;
    --bg-2: #edf8f3;
    --panel: #ffffff;
    --panel-rgb: 255, 255, 255;
    --panel-soft: #eaf6f1;
    --panel-strong: #dceee7;
    --surface: #12221d;
    --text: #14221d;
    --text-rgb: 20, 34, 29;
    --muted: #61746c;
    --line: rgba(30, 73, 60, 0.16);
    --line-strong: rgba(30, 73, 60, 0.28);
    --accent: #0f9f8f;
    --accent-rgb: 15, 159, 143;
    --accent-strong: #0c8076;
    --accent-hover: #14b8a6;
    --accent-ink: #f5fffc;
    --success: #15803d;
    --success-rgb: 21, 128, 61;
    --warning: #b45309;
    --warning-rgb: 180, 83, 9;
    --danger: #dc2626;
    --danger-rgb: 220, 38, 38;
    --signal: #65a30d;
    --grid-rgb: 32, 161, 142;
    --grid-opacity: 0.055;
    --body-bg: linear-gradient(180deg, #f6fcf9 0%, #edf8f3 58%, #f9fffc 100%);
    --glass-bg: rgba(var(--panel-rgb), 0.84);
    --glass-bg-strong: rgba(var(--panel-rgb), 0.96);
    --input-bg: rgba(20, 34, 29, 0.045);
    --input-bg-focus: rgba(15, 159, 143, 0.08);
    --row-hover: rgba(15, 159, 143, 0.07);
    --row-alt: rgba(20, 34, 29, 0.025);
    --table-head-bg: #e3f3ed;
    --table-sticky-bg: #f8fefa;
    --dropdown-bg: #ffffff;
    --modal-backdrop: rgba(12, 27, 22, 0.42);
    --footer-bg: rgba(248, 254, 250, 0.94);
    --bubble-bg: #ffffff;
    --bubble-text: #14221d;
    --shadow: 0 22px 55px rgba(28, 75, 58, 0.14);
    --shadow-soft: 0 14px 34px rgba(28, 75, 58, 0.1);
    --focus-ring: rgba(var(--accent-rgb), 0.16);
}

* {
    box-sizing: border-box;
}

html {
    min-width: 320px;
}

body {
    margin: 0;
    min-height: 100vh;
    font-family: Inter, "Segoe UI", Arial, sans-serif;
    background:
        linear-gradient(rgba(var(--grid-rgb), var(--grid-opacity)) 1px, transparent 1px),
        linear-gradient(90deg, rgba(var(--grid-rgb), var(--grid-opacity)) 1px, transparent 1px),
        var(--body-bg);
    background-attachment: fixed;
    background-size: 44px 44px, 44px 44px, auto;
    color: var(--text);
    overflow-x: hidden;
}

html[data-theme="dark"] body {
    background:
        radial-gradient(circle at top left, rgba(var(--accent-rgb), 0.16), transparent 35%),
        radial-gradient(circle at bottom right, rgba(var(--warning-rgb), 0.1), transparent 30%),
        var(--body-bg);
    background-attachment: fixed;
    background-size: auto;
}

button,
input,
select {
    font: inherit;
}

button {
    min-height: 36px;
    padding: 8px 14px;
    border: 1px solid transparent;
    border-radius: 8px;
    background: var(--accent);
    color: var(--accent-ink);
    cursor: pointer;
    font-size: 13px;
    font-weight: 700;
    transition: background 0.15s ease, border-color 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
}

button:hover {
    background: var(--accent-hover);
    box-shadow: 0 8px 20px rgba(var(--accent-rgb), 0.2);
    transform: translateY(-1px);
}

button:disabled {
    cursor: not-allowed;
    opacity: 0.55;
    transform: none;
    box-shadow: none;
}

button.secondary,
.quick-actions button,
.filter-actions button {
    background: rgba(var(--text-rgb), 0.08);
    border-color: var(--line);
    color: var(--text);
}

button.secondary:hover,
.quick-actions button:hover,
.filter-actions button:hover {
    background: rgba(var(--accent-rgb), 0.16);
    border-color: rgba(var(--accent-rgb), 0.45);
}

html[data-theme="dark"] button:not(.danger-btn) {
    background: rgba(var(--accent-rgb), 0.14);
    border-color: var(--line);
    color: var(--text);
}

html[data-theme="dark"] button:not(.danger-btn):hover {
    background: rgba(var(--accent-rgb), 0.24);
    border-color: rgba(var(--accent-rgb), 0.48);
    box-shadow: 0 8px 20px rgba(var(--accent-rgb), 0.18);
}

input,
select {
    width: 100%;
    min-height: 36px;
    padding: 8px 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--input-bg);
    color: var(--text);
    font-size: 13px;
    outline: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

input:focus,
select:focus {
    border-color: rgba(var(--accent-rgb), 0.72);
    background: var(--input-bg-focus);
    box-shadow: 0 0 0 3px var(--focus-ring);
}

.password-field {
    position: relative;
    width: 100%;
}

.password-field input {
    padding-right: 66px;
}

.password-field input::-ms-reveal,
.password-field input::-ms-clear {
    display: none;
}

.password-toggle {
    position: absolute;
    top: 50%;
    right: 6px;
    min-height: 26px;
    padding: 4px 8px;
    border-color: var(--line);
    background: rgba(var(--text-rgb), 0.08);
    color: var(--muted);
    font-size: 11px;
    line-height: 1;
    transform: translateY(-50%);
    z-index: 1;
}

.password-toggle:hover {
    background: rgba(var(--accent-rgb), 0.14);
    border-color: rgba(var(--accent-rgb), 0.4);
    color: var(--text);
    transform: translateY(-50%);
    box-shadow: none;
}

input[type="file"] {
    padding: 7px;
    color: var(--muted);
}

select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}

select option {
    background: var(--panel);
    color: var(--text);
}

table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}

.table-scroll table thead th {
    position: sticky;
    top: 0;
    z-index: 4;
    background: var(--table-head-bg);
}

.table-scroll table thead th:first-child {
    z-index: 5;
}

th,
td {
    padding: 11px 12px;
    border-bottom: 1px solid var(--line);
    font-size: 13px;
    text-align: left;
}

th {
    color: var(--muted);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: uppercase;
}

.sortable-table th.sortable-header {
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
}

.sortable-table th.sortable-header:hover {
    color: var(--text);
    background: rgba(var(--accent-rgb), 0.12);
}

.sortable-table th.sortable-header:focus-visible {
    outline: 2px solid var(--focus-ring);
    outline-offset: -2px;
}

.sort-indicator {
    display: inline-block;
    margin-left: 6px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 900;
    text-transform: none;
}

.sortable-table th.sorted-asc,
.sortable-table th.sorted-desc {
    color: var(--text);
}

.sortable-table th.sorted-asc .sort-indicator,
.sortable-table th.sorted-desc .sort-indicator {
    color: var(--accent);
}

tr:hover td {
    background: var(--row-hover);
}

tbody tr:nth-child(even) td {
    background: var(--row-alt);
}

.page {
    display: none;
    padding-bottom: 84px;
}

.page.active,
.sub-page.active {
    display: block;
}

.sub-page {
    display: none;
}

.glass {
    background: var(--glass-bg);
    border: 1px solid var(--line);
    border-radius: 8px;
    box-shadow: var(--shadow);
    backdrop-filter: blur(18px) saturate(1.12);
}

.center-wrapper {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.auth-card {
    width: min(420px, 100%);
    position: relative;
    padding: 32px;
    text-align: center;
}

.brand-mark {
    width: 58px;
    height: 58px;
    object-fit: contain;
    margin-bottom: 14px;
    filter: drop-shadow(0 10px 18px rgba(var(--accent-rgb), 0.18));
}

.brand h1 {
    margin: 0 0 6px;
    font-size: 24px;
    letter-spacing: 0;
}

.brand p {
    margin: 0 0 24px;
    color: var(--muted);
    font-size: 13px;
}

.theme-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 34px;
    padding: 7px 11px;
    border-color: var(--line);
    background: rgba(var(--text-rgb), 0.055);
    color: var(--text);
    white-space: nowrap;
}

.theme-toggle:hover {
    background: rgba(var(--accent-rgb), 0.14);
    border-color: rgba(var(--accent-rgb), 0.42);
}

.theme-toggle-icon {
    width: 17px;
    height: 17px;
    display: inline-block;
    border: 2px solid currentColor;
    border-radius: 50%;
    background: linear-gradient(90deg, currentColor 0 50%, transparent 50% 100%);
}

html[data-theme="light"] .theme-toggle-icon {
    background: linear-gradient(90deg, transparent 0 50%, currentColor 50% 100%);
}

.auth-theme-toggle {
    width: 100%;
    margin-bottom: 14px;
}

.login-section {
    display: grid;
    gap: 10px;
}

.login-section input {
    border-color: var(--line);
    background: var(--input-bg);
}

.remember-row {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: fit-content;
    color: var(--muted);
    font-size: 12px;
    font-weight: 700;
}

.remember-row input {
    width: auto;
    min-height: auto;
    accent-color: var(--accent);
}

#loginBtn {
    width: 100%;
    white-space: nowrap;
}

.auth-switch {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 18px;
    color: var(--muted);
    font-size: 12px;
}

.auth-switch button {
    min-height: 32px;
}

.registration-section {
    display: grid;
    gap: 10px;
    text-align: left;
}

.auth-note {
    margin: 0;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.4;
}

.auth-note.success {
    color: var(--success);
}

.auth-note.warning,
.table-note {
    color: var(--warning);
}

.error,
.error-text {
    color: var(--danger);
    font-size: 12px;
}

.divider {
    position: relative;
    margin: 24px 0 16px;
    color: var(--muted);
    font-size: 12px;
    text-align: center;
}

.divider span {
    position: relative;
    z-index: 1;
    padding: 0 10px;
    background: var(--panel);
}

.divider::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 1px;
    background: var(--line);
}

.restore-section {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.file-upload {
    display: block;
    padding: 12px;
    border: 1px dashed var(--line-strong);
    border-radius: 8px;
    color: var(--muted);
    cursor: pointer;
}

.file-upload:hover {
    border-color: rgba(var(--accent-rgb), 0.7);
    color: var(--text);
}

.file-upload input {
    display: none;
}

.navbar {
    position: sticky;
    top: 0;
    z-index: 800;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 14px 20px;
    background: var(--footer-bg);
    backdrop-filter: blur(18px) saturate(1.12);
    border-right: 0;
    border-left: 0;
    border-top: 0;
    border-bottom-color: var(--line);
    border-radius: 0;
}

.nav-left {
    display: flex;
    align-items: center;
    gap: 20px;
    min-width: 0;
}

.nav-logo {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    flex: 0 0 auto;
    font-size: 17px;
    font-weight: 800;
    letter-spacing: 0;
}

.nav-logo img {
    width: 30px;
    height: 30px;
    object-fit: contain;
    filter: drop-shadow(0 8px 16px rgba(var(--accent-rgb), 0.2));
}

.nav-menu {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.nav-menu-toggle {
    display: none;
    align-items: center;
    flex-direction: column;
    justify-content: center;
    width: 40px;
    height: 38px;
    padding: 0;
    border-color: var(--line);
    background: rgba(var(--text-rgb), 0.055);
    color: var(--text);
}

.nav-menu-toggle span {
    display: block;
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
    transition: transform 0.18s ease, opacity 0.18s ease;
}

.nav-menu-toggle span + span {
    margin-top: 4px;
}

.navbar.nav-menu-open .nav-menu-toggle span:nth-child(1) {
    transform: translateY(6px) rotate(45deg);
}

.navbar.nav-menu-open .nav-menu-toggle span:nth-child(2) {
    opacity: 0;
}

.navbar.nav-menu-open .nav-menu-toggle span:nth-child(3) {
    transform: translateY(-6px) rotate(-45deg);
}

.nav-link {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 6px 10px;
    border: 1px solid transparent;
    border-radius: 8px;
    color: var(--muted);
    cursor: pointer;
    font-size: 13px;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.nav-link:hover {
    background: rgba(var(--text-rgb), 0.07);
    color: var(--text);
}

.nav-link.active {
    background: rgba(var(--accent-rgb), 0.16);
    border-color: rgba(var(--accent-rgb), 0.4);
    color: var(--text);
    box-shadow: inset 0 -2px 0 rgba(var(--accent-rgb), 0.7);
}

.nav-right {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 0 0 auto;
}

.username {
    color: var(--muted);
    font-size: 13px;
}

.profile-button {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-height: 32px;
    max-width: 230px;
    padding: 6px 10px;
    border-color: var(--line);
    background: rgba(var(--text-rgb), 0.055);
    color: var(--text);
}

.profile-button .username {
    display: block;
    max-width: 100%;
    color: inherit;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.admin-notification-button {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 32px;
    width: auto;
    padding: 6px 10px;
    border-color: var(--line);
    background: rgba(var(--text-rgb), 0.055);
    color: var(--text);
    white-space: nowrap;
}

.admin-notification-button.has-alerts {
    border-color: rgba(var(--warning-rgb), 0.5);
    background: rgba(var(--warning-rgb), 0.13);
}

.notification-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border: 1px solid rgba(var(--accent-rgb), 0.38);
    border-radius: 999px;
    background: rgba(var(--accent-rgb), 0.14);
    color: var(--text);
    font-size: 11px;
    font-weight: 800;
    line-height: 1;
}

.admin-notification-button.has-alerts .notification-badge {
    border-color: rgba(var(--warning-rgb), 0.55);
    background: rgba(var(--warning-rgb), 0.2);
    color: var(--warning);
}

.user-menu {
    position: relative;
}

.user-menu-caret {
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
}

.user-menu-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    z-index: 1200;
    display: grid;
    width: 190px;
    gap: 6px;
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--glass-bg-strong);
    box-shadow: var(--shadow-soft);
    backdrop-filter: blur(16px);
}

.user-menu-dropdown.hidden {
    display: none;
}

.user-menu-dropdown button {
    justify-content: flex-start;
    width: 100%;
    border-color: transparent;
    background: transparent;
    color: var(--text);
    text-align: left;
}

.user-menu-dropdown button:hover {
    background: rgba(var(--accent-rgb), 0.14);
    border-color: rgba(var(--accent-rgb), 0.32);
    box-shadow: none;
}

.hidden-file-input {
    display: none;
}

.timezone-select {
    width: auto;
    min-width: 96px;
    min-height: 32px;
    padding: 5px 28px 5px 10px;
    font-size: 12px;
}

.page-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin: 20px;
    padding: 22px;
}

.page-hero h2 {
    margin: 5px 0 6px;
    color: var(--text);
    font-size: 26px;
    line-height: 1.15;
}

.page-hero p {
    max-width: 760px;
    margin: 0;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.45;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 14px;
}

.container .page-hero {
    margin-right: 0;
    margin-left: 0;
}

.about-hero {
    overflow: hidden;
}

.about-mark {
    width: clamp(72px, 10vw, 116px);
    height: clamp(72px, 10vw, 116px);
    object-fit: contain;
    filter: drop-shadow(0 16px 28px rgba(var(--accent-rgb), 0.22));
}

.about-layout {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin: 0 20px 96px;
}

.about-panel {
    min-width: 0;
    padding: 18px;
}

.about-intro {
    grid-column: 1 / -1;
}

.about-panel h3 {
    margin: 5px 0 8px;
    font-size: 18px;
}

.about-panel p {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.6;
}

.about-list {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.about-list li {
    display: grid;
    gap: 3px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
}

.about-list strong {
    color: var(--text);
    font-size: 13px;
}

.about-list span {
    color: var(--muted);
    font-size: 12px;
    line-height: 1.45;
}

.about-meta {
    display: grid;
    grid-template-columns: minmax(100px, auto) 1fr;
    gap: 9px 14px;
    align-items: center;
    font-size: 13px;
}

.about-meta span {
    color: var(--muted);
}

.about-meta strong {
    color: var(--text);
    overflow-wrap: anywhere;
}

.howto-layout {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin: 0 20px 96px;
}

.howto-panel {
    min-width: 0;
    padding: 18px;
}

.howto-wide {
    grid-column: 1 / -1;
}

.howto-panel h3 {
    margin: 5px 0 10px;
    font-size: 18px;
}

.howto-steps {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
    counter-reset: howto-step;
}

.howto-steps li {
    position: relative;
    display: grid;
    gap: 4px;
    min-height: 54px;
    padding: 10px 10px 10px 48px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
    counter-increment: howto-step;
}

.howto-steps li::before {
    content: counter(howto-step);
    position: absolute;
    top: 11px;
    left: 12px;
    display: grid;
    width: 26px;
    height: 26px;
    place-items: center;
    border-radius: 8px;
    background: rgba(var(--accent-rgb), 0.16);
    color: var(--accent);
    font-size: 12px;
    font-weight: 800;
}

.howto-steps strong {
    color: var(--text);
    font-size: 13px;
}

.howto-steps span {
    color: var(--muted);
    font-size: 12px;
    line-height: 1.45;
}

.faq-list {
    display: grid;
    gap: 8px;
}

.faq-list details {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
    overflow: hidden;
}

.faq-list summary {
    padding: 11px 12px;
    color: var(--text);
    cursor: pointer;
    font-size: 13px;
    font-weight: 800;
}

.faq-list p {
    margin: 0;
    padding: 0 12px 12px;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.55;
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    min-height: 20px;
    color: var(--accent);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

.section-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 12px;
}

.section-header h3 {
    margin: 3px 0 0;
}

.section-header button {
    flex: 0 0 auto;
}

.section-header-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    flex-wrap: wrap;
}

.controls {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 14px;
    margin: 20px;
    padding: 16px;
    position: relative;
    z-index: 100;
}

.command-panel {
    border-color: var(--line-strong);
}

.section > .controls {
    margin: 0 0 16px;
}

.dashboard-controls {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    align-items: end;
}

.dashboard-actions {
    min-width: min(100%, 280px);
}

.dashboard-actions .inline {
    align-items: stretch;
}

.dashboard-actions button {
    flex: 1 1 130px;
}

.resources-controls,
.user-management-controls {
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
}

.influx-controls,
.breaks-controls {
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

.compact-controls {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.compact-controls button {
    width: auto;
}

.admin-notification-panel {
    display: grid;
    grid-template-columns: minmax(220px, 360px) 1fr;
    gap: 16px;
    align-items: center;
    margin: 20px;
    padding: 16px;
}

.admin-notification-panel p {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
    overflow-wrap: anywhere;
}

.admin-notification-stat-grid,
.admin-notification-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 10px;
}

.admin-notification-stat {
    min-width: 0;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
}

.admin-notification-stat span {
    display: block;
    color: var(--text);
    font-size: 24px;
    font-weight: 800;
    line-height: 1.1;
}

.admin-notification-stat small {
    display: block;
    margin-top: 5px;
    color: var(--muted);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
}

.control-group,
.form-group {
    display: flex;
    flex-direction: column;
    gap: 7px;
}

.control-group label,
.form-group label {
    color: var(--muted);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: uppercase;
}

.field-hint {
    color: var(--muted);
    font-size: 12px;
    line-height: 1.35;
}

.control-group.filters {
    grid-column: span 3;
}

.inline,
.filter-buttons,
.upload-buttons,
.button-row {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.button-row button {
    flex: 1 1 150px;
}

.break-view-toggle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.break-view-toggle button {
    min-height: 34px;
    padding: 8px 14px;
}

.break-view-toggle button.active {
    background: var(--accent);
    border-color: var(--accent);
    color: var(--accent-ink);
    box-shadow: 0 8px 18px rgba(var(--accent-rgb), 0.2);
}

.coverage-subnav {
    justify-content: flex-end;
    margin: 0 0 16px;
}

#breaksPage .breaks-controls {
    grid-template-columns: minmax(0, 2fr) minmax(280px, 0.85fr);
    align-items: stretch;
    gap: 12px;
}

.coverage-command-center {
    padding: 14px;
}

.coverage-control-section {
    min-width: 0;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.026);
}

.coverage-upload-section {
    grid-row: span 2;
}

.coverage-filter-section {
    grid-column: 1 / -1;
}

.coverage-control-heading {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}

.coverage-control-heading strong {
    color: var(--text);
    font-size: 13px;
    font-weight: 900;
}

.coverage-upload-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 10px;
}

.coverage-upload-card {
    min-width: 0;
    display: grid;
    grid-template-rows: auto auto auto;
    gap: 8px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--panel-rgb), 0.42);
}

.coverage-upload-card label {
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.coverage-upload-card input[type="file"] {
    width: 100%;
    min-height: 34px;
    padding: 6px;
    border-radius: 8px;
    font-size: 12px;
}

.coverage-delete-source {
    min-height: 32px;
    padding: 7px 10px;
    font-size: 12px;
}

.coverage-scope-grid,
.coverage-filter-grid,
.coverage-action-grid {
    display: grid;
    gap: 10px;
}

.coverage-scope-grid {
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.coverage-filter-grid {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.coverage-filter-grid .multi-filter {
    min-width: 0;
}

.coverage-action-grid {
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.coverage-action-grid button {
    width: 100%;
}

@media (max-width: 1080px) {
    #breaksPage .breaks-controls {
        grid-template-columns: minmax(0, 1fr);
    }

    .coverage-upload-section {
        grid-row: auto;
    }
}

#breaksPage .coverage-subnav {
    display: flex;
    width: auto;
    justify-content: flex-start;
    margin: 0 20px 16px;
    padding: 10px 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--glass-bg);
}

#breaksPage .coverage-subnav button,
#breaksPage .section-header .break-view-toggle button {
    min-width: 116px;
}

#breaksPage #breaksTable th,
#breaksPage #breaksTable td,
#breaksPage #breakAgentTable th,
#breaksPage #breakAgentTable td {
    min-width: 104px;
    text-align: center;
    vertical-align: middle;
}

#breaksPage #breaksTable th:first-child,
#breaksPage #breaksTable td:first-child,
#breaksPage #breakAgentTable th:first-child,
#breaksPage #breakAgentTable td:first-child {
    position: sticky;
    left: 0;
    z-index: 2;
    min-width: 140px;
    text-align: left;
    background: var(--table-sticky-bg);
    box-shadow: 8px 0 14px rgba(0, 0, 0, 0.12);
}

#breaksPage #breaksTable thead th:first-child,
#breaksPage #breakAgentTable thead th:first-child {
    z-index: 4;
}

.break-recommendation-panel {
    margin-top: 14px;
}

.break-recommendation-header {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 12px;
}

.break-recommendation-header h4 {
    margin: 0;
    color: var(--text);
    font-size: 16px;
}

.break-recommendation-header p {
    margin: 4px 0 0;
    color: var(--muted);
    font-size: 12px;
}

.break-recommendation-badge {
    padding: 6px 9px;
    border: 1px solid rgba(var(--warning-rgb), 0.42);
    border-radius: 8px;
    background: rgba(var(--warning-rgb), 0.12);
    color: var(--warning);
    font-size: 12px;
    font-weight: 800;
}

#breakRecommendationTable th,
#breakRecommendationTable td {
    min-width: 130px;
    text-align: left;
    vertical-align: top;
}

#breakRecommendationTable th:last-child,
#breakRecommendationTable td:last-child {
    min-width: 220px;
}

.filter-buttons button {
    flex: 1 1 auto;
}

.actions-wide {
    grid-column: span 2;
}

.action-align {
    justify-content: flex-end;
}

button.danger-btn {
    background: rgba(var(--danger-rgb), 0.12);
    border-color: rgba(var(--danger-rgb), 0.38);
    color: var(--danger);
}

button.danger-btn:hover {
    background: rgba(var(--danger-rgb), 0.18);
    border-color: rgba(var(--danger-rgb), 0.58);
    box-shadow: 0 8px 20px rgba(var(--danger-rgb), 0.15);
}

.cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 14px;
    margin: 0 20px 22px;
}

.card {
    padding: 18px;
    position: relative;
    overflow: hidden;
}

.cards .card {
    min-height: 104px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.card h3 {
    margin: 0;
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

.card p {
    margin: 10px 0 0;
    font-size: 28px;
    font-weight: 800;
    letter-spacing: 0;
}

.card small {
    display: block;
    margin-top: 6px;
    color: var(--muted);
    font-size: 11px;
}

.productive-cards {
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.productive-cards .card h3 {
    line-height: 1.35;
}

.dashboard-executive-cards {
    grid-template-columns: repeat(auto-fit, minmax(165px, 1fr));
}

.dashboard-executive-cards .card p {
    font-size: clamp(18px, 2vw, 25px);
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.dashboard-executive-cards .card h3 {
    line-height: 1.25;
}

.dashboard-alerts {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 10px;
    margin: 12px 20px 0;
}

.dashboard-alert-card {
    min-width: 0;
    padding: 10px 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
}

.dashboard-alert-card span {
    display: block;
    color: var(--muted);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.dashboard-alert-card strong {
    display: block;
    margin-top: 5px;
    color: var(--text);
    font-size: 12px;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

.dashboard-alert-card.bad {
    border-color: rgba(var(--danger-rgb), 0.45);
    background: rgba(var(--danger-rgb), 0.11);
}

.dashboard-alert-card.warn {
    border-color: rgba(var(--warning-rgb), 0.45);
    background: rgba(var(--warning-rgb), 0.1);
}

.dashboard-alert-card.info {
    border-color: rgba(var(--accent-rgb), 0.42);
    background: rgba(var(--accent-rgb), 0.1);
}

.cards .card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 3px;
    background: linear-gradient(90deg, var(--accent), var(--signal), var(--success));
    border-radius: 8px 8px 0 0;
}

.has-card-tooltip {
    position: relative;
}

.card.has-card-tooltip,
.queue-influx-card.has-card-tooltip,
.queue-detail-item.has-card-tooltip,
.critical-queue-metric.has-card-tooltip,
.dashboard-alert-card.has-card-tooltip,
.mtd-metric-card.has-card-tooltip,
.backlog-summary-grid > div.has-card-tooltip,
.mtd-volume-summary > div.has-card-tooltip {
    padding-right: 34px;
}

.card-tooltip-trigger {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: 5;
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    width: 15px;
    height: 15px;
    margin: 0;
    border: 1px solid rgba(var(--accent-rgb), 0.42);
    border-radius: 50%;
    background: rgba(var(--panel-rgb), 0.92);
    color: var(--accent);
    font-size: 10px;
    font-weight: 900;
    line-height: 1;
    text-transform: lowercase;
    cursor: help;
    pointer-events: auto;
    user-select: none;
}

.dashboard-alert-card .card-tooltip-trigger,
.critical-queue-metric .card-tooltip-trigger,
.backlog-summary-grid > div .card-tooltip-trigger,
.mtd-volume-summary > div .card-tooltip-trigger {
    top: 6px;
    right: 6px;
    width: 14px;
    height: 14px;
    font-size: 9px;
}

.card-tooltip-trigger:hover,
.card-tooltip-trigger:focus-visible {
    border-color: rgba(var(--accent-rgb), 0.78);
    background: rgba(var(--accent-rgb), 0.2);
    box-shadow: 0 0 0 3px rgba(var(--accent-rgb), 0.12);
    outline: none;
}

.floating-card-tooltip {
    position: fixed;
    z-index: 9999;
    min-width: 220px;
    max-width: min(360px, calc(100vw - 24px));
    padding: 10px 12px;
    border: 1px solid rgba(var(--accent-rgb), 0.48);
    border-radius: 8px;
    background: rgba(var(--panel-rgb), 0.98);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.36);
    color: var(--text);
    font-size: 12px;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: 0;
    text-align: left;
    text-transform: none;
    white-space: normal;
    opacity: 0;
    transform: translateY(4px);
    transition: opacity 0.14s ease, transform 0.14s ease;
    pointer-events: none;
}

.floating-card-tooltip.visible {
    opacity: 1;
    transform: translateY(0);
}

.floating-card-tooltip[hidden] {
    display: none;
}

.has-card-tooltip > .card-tooltip-trigger,
.card.has-card-tooltip > .card-tooltip-trigger,
.queue-influx-card.has-card-tooltip > .card-tooltip-trigger,
.queue-detail-item.has-card-tooltip > .card-tooltip-trigger,
.critical-queue-metric.has-card-tooltip > .card-tooltip-trigger,
.dashboard-alert-card.has-card-tooltip > .card-tooltip-trigger,
.mtd-metric-card.has-card-tooltip > .card-tooltip-trigger,
.backlog-summary-grid > div.has-card-tooltip > .card-tooltip-trigger,
.mtd-volume-summary > div.has-card-tooltip > .card-tooltip-trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    min-width: 16px;
    max-width: 16px;
    height: 16px;
    min-height: 16px;
    max-height: 16px;
    padding: 0;
    overflow: visible;
    color: var(--accent);
    font-size: 0;
    line-height: 1;
    text-transform: none;
    letter-spacing: 0;
}

.has-card-tooltip > .card-tooltip-trigger::before,
.card.has-card-tooltip > .card-tooltip-trigger::before,
.queue-influx-card.has-card-tooltip > .card-tooltip-trigger::before,
.queue-detail-item.has-card-tooltip > .card-tooltip-trigger::before,
.critical-queue-metric.has-card-tooltip > .card-tooltip-trigger::before,
.dashboard-alert-card.has-card-tooltip > .card-tooltip-trigger::before,
.mtd-metric-card.has-card-tooltip > .card-tooltip-trigger::before,
.backlog-summary-grid > div.has-card-tooltip > .card-tooltip-trigger::before,
.mtd-volume-summary > div.has-card-tooltip > .card-tooltip-trigger::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 6px;
    width: 2px;
    height: 6px;
    border-radius: 2px;
    background: currentColor;
    transform: translateX(-50%);
}

.has-card-tooltip > .card-tooltip-trigger::after,
.card.has-card-tooltip > .card-tooltip-trigger::after,
.queue-influx-card.has-card-tooltip > .card-tooltip-trigger::after,
.queue-detail-item.has-card-tooltip > .card-tooltip-trigger::after,
.critical-queue-metric.has-card-tooltip > .card-tooltip-trigger::after,
.dashboard-alert-card.has-card-tooltip > .card-tooltip-trigger::after,
.mtd-metric-card.has-card-tooltip > .card-tooltip-trigger::after,
.backlog-summary-grid > div.has-card-tooltip > .card-tooltip-trigger::after,
.mtd-volume-summary > div.has-card-tooltip > .card-tooltip-trigger::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 3px;
    width: 2.5px;
    height: 2.5px;
    border-radius: 50%;
    background: currentColor;
    transform: translateX(-50%);
}

.section,
.container {
    margin: 22px 20px;
}

.section {
    padding: 0;
    background: transparent;
}

.section h3 {
    margin: 0 0 12px;
    color: var(--text);
    font-size: 16px;
    font-weight: 800;
    letter-spacing: 0;
}

.section .section-header h3 {
    margin: 3px 0 0;
}

.roster-header {
    margin-top: 18px;
}

.resource-filter-panel,
.roster-filter-panel {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
    align-items: end;
    gap: 10px;
    margin-bottom: 14px;
}

.resource-filter-panel input,
.resource-filter-panel select,
.roster-filter-panel input,
.roster-filter-panel select {
    font-size: 12px;
}

.resource-filter-actions button,
.roster-filter-actions button {
    width: 100%;
}

.resource-filter-meta,
.roster-filter-meta {
    width: 100%;
    margin: 0 0 10px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 700;
}

.queue-container {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.critical-queue-container {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    align-items: stretch;
    gap: 12px;
}

.queue-card {
    min-width: 220px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--glass-bg-strong);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.queue-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow);
}

.critical-queue-summary {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    padding: 8px 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
}

.critical-queue-summary strong {
    color: var(--text);
    font-size: 13px;
}

.critical-queue-summary span {
    color: var(--muted);
    font-size: 11px;
}

.critical-market-group {
    padding: 0;
    border: 1px solid var(--line);
    border-radius: 8px;
    overflow: hidden;
}

.critical-market-group.highest-risk {
    border-color: rgba(var(--danger-rgb), 0.42);
    box-shadow: inset 0 0 0 1px rgba(var(--danger-rgb), 0.12);
}

.critical-market-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 14px;
    cursor: pointer;
    list-style: none;
}

.critical-market-summary::-webkit-details-marker {
    display: none;
}

.critical-market-summary::after {
    content: "+";
    color: var(--muted);
    font-size: 18px;
    font-weight: 900;
}

.critical-market-group[open] .critical-market-summary::after {
    content: "-";
}

.critical-market-name {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 7px;
    color: var(--text);
    font-size: 14px;
    font-weight: 900;
}

.critical-market-name em,
.critical-new-badge {
    display: inline-flex;
    align-items: center;
    min-height: 18px;
    padding: 2px 6px;
    border: 1px solid rgba(var(--danger-rgb), 0.42);
    border-radius: 8px;
    background: rgba(var(--danger-rgb), 0.12);
    color: var(--danger);
    font-size: 9px;
    font-style: normal;
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.critical-market-summary small {
    display: block;
    margin-top: 2px;
    color: var(--muted);
    font-size: 11px;
}

.critical-market-stats {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 6px;
}

.critical-market-stats span {
    padding: 5px 7px;
    border: 1px solid var(--line);
    border-radius: 8px;
    color: var(--muted);
    background: rgba(var(--text-rgb), 0.04);
    font-size: 10px;
    font-weight: 800;
}

.critical-market-queues {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 235px), 1fr));
    grid-auto-rows: minmax(335px, auto);
    gap: 10px;
    padding: 0 12px 12px;
}

.critical-queue-card {
    min-width: 0;
    height: 100%;
    display: grid;
    gap: 8px;
    padding: 10px;
    grid-template-rows: auto auto minmax(46px, 1fr) auto;
    overflow: hidden;
}

.critical-queue-card.warn {
    border-color: rgba(var(--warning-rgb), 0.35);
}

.critical-queue-card.bad {
    border-color: rgba(var(--danger-rgb), 0.42);
}

.critical-queue-card.new-critical {
    box-shadow: inset 0 0 0 1px rgba(var(--danger-rgb), 0.18);
}

.critical-queue-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 8px;
}

.critical-queue-tags {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 5px;
}

.critical-queue-head h4 {
    display: -webkit-box;
    margin: 2px 0 0;
    color: var(--text);
    font-size: 12px;
    line-height: 1.25;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    overflow-wrap: anywhere;
}

.critical-queue-head small,
.critical-queue-status {
    color: var(--muted);
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

.critical-queue-head > strong {
    color: var(--text);
    font-size: 18px;
    line-height: 1;
    white-space: nowrap;
}

.critical-queue-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
}

.critical-queue-metric {
    min-width: 0;
    padding: 6px 7px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.035);
}

.critical-queue-metric span {
    display: block;
    color: var(--muted);
    font-size: 8px;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

.critical-queue-metric strong {
    display: block;
    margin-top: 3px;
    color: var(--text);
    font-size: 11px;
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.critical-queue-metric.metric-good {
    border-color: rgba(var(--success-rgb), 0.38);
    background: rgba(var(--success-rgb), 0.1);
}

.critical-queue-metric.metric-warn {
    border-color: rgba(var(--warning-rgb), 0.42);
    background: rgba(var(--warning-rgb), 0.12);
}

.critical-queue-metric.metric-bad {
    border-color: rgba(var(--danger-rgb), 0.45);
    background: rgba(var(--danger-rgb), 0.13);
}

.critical-queue-metric.metric-good strong {
    color: var(--success);
}

.critical-queue-metric.metric-warn strong {
    color: var(--warning);
}

.critical-queue-metric.metric-bad strong {
    color: var(--danger);
}

.critical-queue-card .critical-queue-action {
    display: -webkit-box;
    align-self: start;
    margin: 0;
    color: var(--text);
    font-size: 11px;
    font-weight: 850;
    line-height: 1.28;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    overflow: hidden;
    overflow-wrap: anywhere;
}

.critical-queue-card.bad .critical-queue-action {
    color: var(--danger);
}

.critical-queue-card.warn .critical-queue-action {
    color: var(--warning);
}

.critical-queue-view {
    justify-self: start;
    width: auto;
    min-height: 28px;
    padding: 5px 10px;
    font-size: 11px;
}

.button-spinner {
    width: 12px;
    height: 12px;
    border: 2px solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    animation: button-spin 0.8s linear infinite;
}

button.is-loading {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    opacity: 0.8;
    cursor: wait;
}

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

.good {
    background: rgba(var(--success-rgb), 0.14);
}

.warn {
    background: rgba(var(--warning-rgb), 0.14);
}

.bad {
    background: rgba(var(--danger-rgb), 0.14);
}

.sla-stoplight-cell {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    min-width: 0;
    white-space: nowrap;
}

.sla-stoplight {
    width: 11px;
    height: 11px;
    flex: 0 0 auto;
    border: 1px solid rgba(255, 255, 255, 0.75);
    border-radius: 50%;
    background: var(--muted);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.08), 0 0 12px rgba(255, 255, 255, 0.18);
}

.sla-stoplight.good {
    background: var(--success);
    box-shadow: 0 0 0 2px rgba(var(--success-rgb), 0.18), 0 0 12px rgba(var(--success-rgb), 0.5);
}

.sla-stoplight.warn {
    background: var(--warning);
    box-shadow: 0 0 0 2px rgba(var(--warning-rgb), 0.18), 0 0 12px rgba(var(--warning-rgb), 0.5);
}

.sla-stoplight.bad {
    background: var(--danger);
    box-shadow: 0 0 0 2px rgba(var(--danger-rgb), 0.18), 0 0 12px rgba(var(--danger-rgb), 0.5);
}

.sla-stoplight.no-volume {
    background: var(--muted);
    box-shadow: none;
    opacity: 0.55;
}

.sla-neutral-cell {
    color: var(--muted);
}

.empty-state {
    width: 100%;
    margin: 0;
    padding: 18px;
    color: var(--muted);
    text-align: center;
}

.reset-confirm {
    padding: 20px;
    text-align: center;
}

.table-wrapper {
    padding: 0;
    max-width: 100%;
    min-width: 0;
    overflow: hidden !important;
}

.table-scroll {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: visible !important;
}

.forecast-controls {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.mtd-controls {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.mtd-report-tabs {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: center;
    gap: 8px;
    width: calc(100% - 40px);
    max-width: 760px;
    margin: 14px 20px 18px;
    padding: 8px;
}

.mtd-report-tabs button {
    justify-content: center;
    min-height: 38px;
    padding: 9px 16px;
    white-space: nowrap;
}

.mtd-report-tabs button.active {
    background: var(--accent);
    border-color: var(--accent);
    color: var(--accent-ink);
    box-shadow: 0 8px 18px rgba(var(--accent-rgb), 0.2);
}

.mtd-report-search {
    margin: 0 0 12px;
    grid-template-columns: minmax(220px, 420px);
}

.mtd-report-panel {
    display: none;
}

.mtd-report-panel.active {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 18px;
}

.mtd-report-panel-empty.active {
    min-height: 120px;
}

.mtd-cards .card small {
    display: block;
    margin-top: 6px;
    color: var(--muted);
    font-size: 12px;
}

.mtd-cards {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 155px), 1fr));
    gap: 10px;
    margin-bottom: 18px;
}

.mtd-cards .card {
    min-height: 96px;
    padding: 14px;
}

.mtd-cards .card p {
    margin-top: 10px;
    font-size: 24px;
    line-height: 1.1;
}

.mtd-summary-card {
    padding: 18px;
}

.mtd-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
    gap: 12px;
}

.mtd-summary-item {
    min-height: 108px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.035);
}

.mtd-summary-item span {
    display: block;
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
}

.mtd-summary-item strong {
    display: block;
    margin-top: 8px;
    color: var(--text);
    font-size: 18px;
    line-height: 1.25;
}

.mtd-summary-item small {
    display: block;
    margin-top: 8px;
    color: var(--muted);
    line-height: 1.35;
}

.mtd-performance-summary {
    margin: 10px 0 12px;
    padding: 12px;
}

.mtd-weekly-matrix-section {
    display: grid;
    gap: 12px;
}

.mtd-weekly-matrix-section .section-header {
    align-items: flex-start;
}

.mtd-matrix-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
}

.mtd-matrix-toggle {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 6px;
    border: 1px solid rgba(var(--border-rgb), 0.72);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.035);
}

.mtd-matrix-toggle button {
    min-height: 32px;
    padding: 7px 10px;
    border-color: transparent;
    background: transparent;
    box-shadow: none;
    color: var(--muted);
    font-size: 0.78rem;
}

.mtd-matrix-toggle button.active {
    background: rgba(var(--accent-rgb), 0.16);
    border-color: rgba(var(--accent-rgb), 0.42);
    color: var(--text);
}

.mtd-matrix-summary {
    margin: 0;
    padding: 12px;
}

.mtd-matrix-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 170px), 1fr));
    gap: 10px;
}

.mtd-matrix-summary-grid > div {
    min-width: 0;
    padding: 10px 12px;
    border: 1px solid rgba(var(--border-rgb), 0.72);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.03);
}

.mtd-matrix-summary-grid span,
.mtd-matrix-summary-grid small {
    display: block;
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.mtd-matrix-summary-grid strong {
    display: block;
    margin-top: 4px;
    color: var(--text);
    font-size: 1rem;
    line-height: 1.25;
}

.mtd-matrix-wrapper {
    padding: 0;
    max-width: 100%;
    min-width: 0;
}

#mtdWeeklyMatrixTable {
    min-width: max-content;
}

#mtdWeeklyMatrixTable th,
#mtdWeeklyMatrixTable td {
    min-width: 132px;
    white-space: nowrap;
    text-align: right;
}

#mtdWeeklyMatrixTable th:first-child,
#mtdWeeklyMatrixTable td:first-child {
    position: sticky;
    left: 0;
    z-index: 2;
    min-width: 190px;
    text-align: left;
    background: var(--table-sticky-bg);
}

#mtdWeeklyMatrixTable thead th:first-child {
    z-index: 3;
    background: var(--table-head-bg);
}

#mtdWeeklyMatrixTable .mtd-matrix-total-row td {
    border-top: 2px solid rgba(var(--accent-rgb), 0.34);
    background: rgba(var(--accent-rgb), 0.08);
    font-weight: 800;
}

#mtdWeeklyMatrixTable caption {
    caption-side: bottom;
    padding-top: 10px;
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 800;
    text-align: left;
}

.mtd-performance-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 180px), 1fr));
    gap: 10px;
}

.mtd-performance-grid > div {
    min-width: 0;
    border: 1px solid rgba(var(--border-rgb), 0.72);
    border-radius: 8px;
    padding: 10px 12px;
    background: rgba(var(--text-rgb), 0.03);
}

.mtd-performance-grid span,
.mtd-performance-grid small {
    display: block;
    color: var(--muted);
    font-size: 0.74rem;
    font-weight: 800;
}

.mtd-performance-grid strong {
    display: block;
    margin-top: 4px;
    color: var(--text);
    font-size: 1.04rem;
    line-height: 1.25;
}

.mtd-visual-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
    gap: 16px;
}

.mtd-chart-card {
    min-width: 0;
    min-height: 230px;
    padding: 14px;
}

.mtd-breakdown {
    min-width: 0;
    min-height: 280px;
    padding: 14px;
}

.mtd-metric-trend-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
    gap: 14px;
}

.mtd-metric-card {
    min-height: 260px;
    padding: 14px;
    display: grid;
    gap: 10px;
    align-content: start;
}

.mtd-metric-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.mtd-metric-card-head span,
.mtd-metric-card small {
    color: var(--muted);
    font-size: 0.74rem;
    font-weight: 800;
    text-transform: uppercase;
}

.mtd-metric-card h4 {
    margin: 2px 0 0;
    font-size: 1rem;
}

.mtd-metric-card strong {
    color: var(--text);
    font-size: 1.15rem;
    line-height: 1.2;
    white-space: nowrap;
}

.mtd-metric-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.mtd-metric-stats > div {
    min-width: 0;
    padding: 8px;
    border: 1px solid rgba(var(--border-rgb), 0.7);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.03);
}

.mtd-metric-stats span,
.mtd-metric-stats small {
    display: block;
    color: var(--muted);
    font-size: 0.68rem;
    font-weight: 800;
    text-transform: uppercase;
}

.mtd-metric-stats b {
    display: block;
    margin-top: 3px;
    font-size: 0.9rem;
    overflow-wrap: anywhere;
}

.mtd-mini-chart {
    display: block;
    width: 100%;
    height: auto;
    min-height: 150px;
}

.mtd-mini-grid {
    stroke: rgba(var(--border-rgb), 0.6);
    stroke-width: 1;
}

.mtd-mini-axis {
    stroke: rgba(var(--text-rgb), 0.25);
    stroke-width: 1.25;
}

.mtd-mini-area {
    fill: rgba(var(--accent-rgb), 0.1);
}

.mtd-mini-line {
    fill: none;
    stroke: var(--accent);
    stroke-width: 3;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.mtd-mini-line.output {
    stroke: var(--success);
}

.mtd-mini-line.aht {
    stroke: var(--warning);
}

.mtd-mini-line.sla {
    stroke: var(--danger);
}

.mtd-mini-target {
    fill: none;
    stroke: rgba(var(--text-rgb), 0.58);
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: 6 5;
}

.mtd-mini-dot {
    fill: var(--surface);
    stroke: var(--accent);
    stroke-width: 2;
}

.mtd-mini-dot.output {
    stroke: var(--success);
}

.mtd-mini-dot.aht {
    stroke: var(--warning);
}

.mtd-mini-dot.sla {
    stroke: var(--danger);
}

.mtd-mini-label {
    fill: var(--muted);
    font-size: 10px;
    font-weight: 800;
}

.mtd-trend-panel {
    display: grid;
    min-width: 0;
    gap: 12px;
}

.mtd-trend-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 112px), 1fr));
    gap: 8px;
}

.mtd-trend-summary > div {
    min-width: 0;
    border: 1px solid rgba(var(--border-rgb), 0.72);
    border-radius: 8px;
    padding: 8px 10px;
    background: rgba(var(--surface-rgb), 0.44);
}

.mtd-trend-summary span,
.mtd-trend-summary small {
    display: block;
    color: var(--muted);
    font-size: 0.72rem;
    font-weight: 700;
}

.mtd-trend-summary strong {
    display: block;
    margin-top: 2px;
    color: var(--text);
    font-size: 1rem;
    white-space: nowrap;
}

.mtd-chart-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 16px;
    color: var(--muted);
    font-size: 0.75rem;
    font-weight: 800;
}

.mtd-chart-legend span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.mtd-chart-legend i {
    display: inline-block;
    width: 18px;
    height: 8px;
    border-radius: 999px;
}

.mtd-chart-legend i.volume {
    background: rgba(var(--accent-rgb), 0.24);
    border: 1px solid rgba(var(--accent-rgb), 0.42);
}

.mtd-chart-legend i.line {
    height: 3px;
    background: var(--accent);
}

.mtd-chart-legend i.average {
    height: 3px;
    background: var(--warning);
}

.mtd-chart-legend i.moving {
    height: 3px;
    background: var(--success);
}

.mtd-chart {
    display: block;
    width: 100%;
    height: auto;
    min-height: 180px;
}

.mtd-trend-chart {
    min-width: 640px;
    min-height: 230px;
}

#mtdPage,
#mtdPage .section,
#mtdPage .card,
#mtdPage .glass {
    max-width: 100%;
    min-width: 0;
}

#mtdDailyTrendChart,
#mtdDemandCoverageChart {
    overflow-x: auto;
}

.mtd-chart text {
    fill: var(--muted);
    font-size: 11px;
    font-weight: 700;
}

.mtd-chart-grid {
    stroke: rgba(var(--border-rgb), 0.68);
    stroke-width: 1;
}

.mtd-chart-axis-line {
    stroke: rgba(var(--text-rgb), 0.25);
    stroke-width: 1.25;
}

.mtd-chart-area {
    fill: rgba(var(--accent-rgb), 0.12);
}

.mtd-chart-bar {
    fill: rgba(var(--accent-rgb), 0.2);
    stroke: rgba(var(--accent-rgb), 0.38);
    stroke-width: 1;
}

.mtd-chart-bar.clipped {
    fill: rgba(var(--warning-rgb), 0.26);
    stroke: rgba(var(--warning-rgb), 0.7);
}

.mtd-chart-target {
    stroke: rgba(var(--warning-rgb), 0.76);
    stroke-dasharray: 6 5;
    stroke-width: 2;
}

.mtd-chart-line {
    fill: none;
    stroke: var(--accent);
    stroke-width: 3;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.mtd-chart-moving {
    fill: none;
    stroke: var(--success);
    stroke-width: 2.4;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-dasharray: 7 5;
}

.mtd-chart-average {
    stroke: rgba(var(--warning-rgb), 0.86);
    stroke-width: 2;
    stroke-dasharray: 7 5;
}

.mtd-chart-average-label,
.mtd-chart-peak-label,
.mtd-chart-low-label {
    fill: var(--text);
    font-weight: 900;
}

.mtd-chart-peak-line {
    stroke: rgba(var(--warning-rgb), 0.75);
    stroke-width: 1.5;
    stroke-dasharray: 4 4;
}

.mtd-chart-dot {
    stroke: rgba(var(--text-rgb), 0.55);
    stroke-width: 2;
}

.mtd-chart-dot.good {
    fill: var(--success);
}

.mtd-chart-dot.warn {
    fill: var(--warning);
}

.mtd-chart-dot.bad {
    fill: var(--danger);
}

.mtd-chart-dot.peak,
.mtd-chart-dot.clipped {
    fill: var(--warning);
}

.mtd-chart-dot.low {
    fill: var(--accent);
}

.mtd-chart-note {
    margin: -2px 0 0;
    color: var(--muted);
    font-size: 0.78rem;
    line-height: 1.35;
}

.mtd-volume-bars {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(30px, 1fr);
    align-items: end;
    gap: 8px;
    min-height: 235px;
    overflow-x: auto;
}

.mtd-volume-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 140px), 1fr));
    gap: 10px;
    margin-bottom: 14px;
}

.mtd-volume-summary > div {
    padding: 10px 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--panel-rgb), 0.55);
}

.mtd-volume-summary span,
.mtd-volume-summary small {
    display: block;
    color: var(--muted);
    font-size: 0.76rem;
    font-weight: 700;
}

.mtd-volume-summary strong {
    display: block;
    margin-top: 4px;
    font-size: 1.05rem;
}

.mtd-volume-bar {
    display: grid;
    grid-template-rows: 18px minmax(150px, 1fr) auto;
    gap: 6px;
    min-width: 34px;
    text-align: center;
}

.mtd-volume-bar b {
    color: var(--text);
    font-size: 0.68rem;
    line-height: 1;
}

.mtd-volume-bar span {
    align-self: end;
    display: block;
    width: 100%;
    min-height: 4px;
    border-radius: 6px 6px 2px 2px;
    background: linear-gradient(180deg, rgba(var(--accent-rgb), 0.92), rgba(var(--success-rgb), 0.62));
    box-shadow: 0 8px 18px rgba(var(--accent-rgb), 0.16);
}

.mtd-volume-bar.warn span {
    background: linear-gradient(180deg, rgba(var(--warning-rgb), 0.92), rgba(var(--accent-rgb), 0.48));
}

.mtd-volume-bar.bad span {
    background: linear-gradient(180deg, rgba(var(--danger-rgb), 0.92), rgba(var(--warning-rgb), 0.52));
}

.mtd-volume-bar small {
    color: var(--muted);
    font-size: 10px;
    font-weight: 700;
    white-space: nowrap;
}

.mtd-breakdown-row {
    padding: 12px 0;
    border-bottom: 1px solid var(--line);
}

.mtd-breakdown-row:last-child {
    border-bottom: 0;
}

.mtd-breakdown-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 8px;
}

.mtd-breakdown-head strong {
    min-width: 0;
    overflow-wrap: anywhere;
}

.mtd-breakdown-track {
    height: 8px;
    overflow: hidden;
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.08);
}

.mtd-breakdown-track span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: var(--accent);
}

.mtd-breakdown-row small {
    display: block;
    margin-top: 7px;
    color: var(--muted);
    font-size: 12px;
}

#mtdRiskTable,
#mtdWeeklyRiskTable {
    min-width: 1740px;
}

#mtdRiskTable th,
#mtdRiskTable td,
#mtdWeeklyRiskTable th,
#mtdWeeklyRiskTable td {
    min-width: 110px;
    vertical-align: middle;
}

#mtdRiskTable th:nth-child(2),
#mtdRiskTable td:nth-child(2),
#mtdWeeklyRiskTable th:nth-child(2),
#mtdWeeklyRiskTable td:nth-child(2) {
    min-width: 220px;
}

#mtdRiskTable caption,
#mtdWeeklyRiskTable caption {
    caption-side: bottom;
    padding-top: 10px;
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 800;
    text-align: left;
}

@media (max-width: 980px) {
    .mtd-visual-grid {
        grid-template-columns: 1fr;
    }
}

.forecast-focus-group {
    min-width: 220px;
}

.forecast-cards .card small {
    display: block;
    margin-top: 6px;
    color: var(--muted);
    font-size: 12px;
}

.forecast-insight-card {
    padding: 20px;
}

.forecast-insight-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(240px, 1fr);
    gap: 18px;
    align-items: stretch;
}

.forecast-insight-main h3 {
    margin: 4px 0 10px;
}

.forecast-insight-copy {
    margin: 0;
    color: var(--muted);
    line-height: 1.55;
}

.forecast-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 14px;
}

.forecast-insight-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 16px;
}

.forecast-chip {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 6px 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--accent-rgb), 0.08);
    color: var(--text);
    font-size: 12px;
    font-weight: 700;
}

.forecast-insight-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.forecast-insight-item {
    min-height: 86px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.03);
}

.forecast-insight-item span {
    display: block;
    color: var(--muted);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
}

.forecast-insight-item strong {
    display: block;
    margin-top: 8px;
    font-size: 22px;
    line-height: 1.2;
}

.forecast-next-row td {
    box-shadow: inset 0 2px 0 rgba(var(--accent-rgb), 0.55);
}

#forecastQueueTable th,
#forecastQueueTable td,
#forecastIntervalModalTable th,
#forecastIntervalModalTable td {
    min-width: 130px;
}

@media (max-width: 980px) {
    .forecast-insight-grid {
        grid-template-columns: 1fr;
    }

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

@media (max-width: 640px) {
    .forecast-insight-metrics {
        grid-template-columns: 1fr;
    }
}

#dataTable,
#breaksTable,
#breakAgentTable,
#influxTable,
#forecastQueueTable,
#forecastIntervalTable,
#mtdRiskTable,
#mtdWeeklyRiskTable {
    min-width: max-content;
}

#mtdRiskTable,
#mtdWeeklyRiskTable {
    min-width: 1740px;
}

.break-agent-time {
    display: block;
    line-height: 1.35;
    white-space: nowrap;
}

.muted-cell {
    display: block;
    color: var(--muted);
    font-size: 11px;
    line-height: 1.35;
}

.break-gantt-card {
    padding: 0;
    overflow: hidden;
}

.break-gantt {
    width: 100%;
    overflow: auto;
}

.break-gantt-inner {
    --gantt-hour-width: 58px;
    --gantt-interval-width: 54px;
    --gantt-interval-count: 24;
    --gantt-track-width: calc(var(--gantt-hour-width) * 24);
    --gantt-grid-step: var(--gantt-hour-width);
    min-width: calc(440px + var(--gantt-track-width));
}

.break-gantt-header,
.break-gantt-row {
    display: grid;
    grid-template-columns: 118px 210px 112px var(--gantt-track-width);
}

.break-gantt-employee {
    display: grid;
    grid-template-columns: 118px 210px 112px var(--gantt-track-width);
    grid-template-rows: repeat(2, 40px);
    border-bottom: 1px solid var(--line);
}

.break-gantt-header {
    position: sticky;
    top: 0;
    z-index: 3;
    border-bottom: 1px solid var(--line);
    background: var(--table-head-bg);
}

.break-gantt-heading,
.break-gantt-meta {
    min-width: 0;
    padding: 10px 12px;
    border-right: 1px solid var(--line);
    color: var(--text);
    font-size: 12px;
    font-weight: 800;
    overflow-wrap: anywhere;
}

.break-gantt-meta {
    display: flex;
    align-items: center;
    background: rgba(var(--text-rgb), 0.025);
}

.break-gantt-header > :nth-child(1),
.break-gantt-employee > :nth-child(1) {
    position: sticky;
    left: 0;
    z-index: 5;
    background: var(--table-sticky-bg);
}

.break-gantt-header > :nth-child(2),
.break-gantt-employee > :nth-child(2) {
    position: sticky;
    left: 118px;
    z-index: 5;
    background: var(--table-sticky-bg);
}

.break-gantt-header > :nth-child(3),
.break-gantt-employee > :nth-child(3),
.break-gantt-employee > :nth-child(5) {
    position: sticky;
    left: 328px;
    z-index: 5;
    background: var(--table-sticky-bg);
}

.break-gantt-header > :nth-child(1),
.break-gantt-header > :nth-child(2),
.break-gantt-header > :nth-child(3) {
    z-index: 7;
    background: var(--table-head-bg);
}

.break-gantt-row {
    border-bottom: 1px solid var(--line);
}

.break-gantt-employee:last-child,
.break-gantt-row:last-child {
    border-bottom: 0;
}

.break-gantt-identity {
    grid-row: 1 / span 2;
}

.break-gantt-employee .break-gantt-track-label {
    align-items: flex-start;
    flex-direction: column;
    justify-content: center;
    gap: 2px;
    font-size: 11px;
}

.break-gantt-employee .break-gantt-track-label small {
    color: var(--muted);
    font-size: 10px;
    font-weight: 800;
}

.break-gantt-name {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.break-gantt-name small {
    color: var(--muted);
    font-size: 10px;
    font-weight: 700;
}

.break-gantt-axis {
    display: grid;
    grid-template-columns: repeat(var(--gantt-interval-count), minmax(var(--gantt-interval-width), 1fr));
    width: var(--gantt-track-width);
}

.break-gantt-hour {
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 2px;
    padding: 7px 5px;
    border-right: 1px solid var(--line);
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    text-align: center;
}

.break-timeline-date {
    display: block;
    color: var(--muted);
    font-size: 9px;
    font-weight: 800;
    line-height: 1;
}

.break-gantt-hour strong,
.coverage-time-cell strong,
.break-gantt-summary-cell small strong {
    display: block;
    color: var(--text);
    font-size: 11px;
    font-weight: 900;
    line-height: 1.1;
}

.coverage-time-cell {
    min-width: 118px;
    text-align: center;
}

.break-gantt-summary-row {
    display: grid;
    grid-template-columns: 328px 112px var(--gantt-track-width);
    grid-template-rows: repeat(2, auto);
    border-bottom: 1px solid var(--line);
    background: rgba(var(--text-rgb), 0.018);
}

.break-gantt-summary-row > :nth-child(1) {
    position: sticky;
    left: 0;
    z-index: 6;
    background: var(--table-sticky-bg);
}

.break-gantt-summary-row > :nth-child(2),
.break-gantt-summary-row > :nth-child(4) {
    position: sticky;
    left: 328px;
    z-index: 6;
    background: var(--table-sticky-bg);
}

.break-gantt-summary-label {
    grid-row: 1 / span 2;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 3px;
    padding: 8px 14px;
    border-right: 1px solid var(--line);
    color: var(--muted);
    overflow-wrap: anywhere;
}

.break-gantt-summary-label strong {
    color: var(--text);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.break-gantt-summary-label span {
    color: var(--muted);
    font-size: 10px;
    font-weight: 800;
}

.break-gantt-summary-row > .break-gantt-track-label {
    min-width: 0;
    display: flex;
    align-items: center;
    padding: 8px 12px;
    border-right: 1px solid var(--line);
    color: var(--text);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
}

.break-gantt-summary-grid {
    display: grid;
    grid-template-columns: repeat(var(--gantt-interval-count), minmax(var(--gantt-interval-width), 1fr));
    width: var(--gantt-track-width);
}

.break-gantt-summary-cell {
    min-width: 0;
    min-height: 34px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    align-content: center;
    align-items: center;
    gap: 2px;
    padding: 5px 3px;
    border-right: 1px solid var(--line);
    color: var(--text);
    text-align: center;
}

.break-gantt-summary-cell small,
.break-gantt-summary-cell span,
.break-gantt-summary-cell em {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.break-gantt-summary-cell small {
    grid-column: 1 / -1;
    color: var(--muted);
    font-size: 9px;
    font-weight: 800;
    line-height: 1.15;
    white-space: normal;
}

.break-gantt-summary-cell span,
.break-gantt-summary-cell em {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 2px;
    font-size: 11px;
    font-style: normal;
    font-weight: 900;
}

.break-gantt-summary-cell b {
    color: var(--muted);
    font-size: 9px;
    font-weight: 900;
}

.break-gantt-summary-cell.good {
    background: rgba(var(--success-rgb), 0.1);
}

.break-gantt-summary-cell.warning {
    background: rgba(var(--warning-rgb), 0.12);
}

.break-gantt-summary-cell.danger {
    background: rgba(var(--danger-rgb), 0.12);
}

.break-gantt-track {
    position: relative;
    height: 40px;
    background:
        repeating-linear-gradient(
            to right,
            rgba(var(--text-rgb), 0.06) 0,
            rgba(var(--text-rgb), 0.06) 1px,
            transparent 1px,
            transparent var(--gantt-grid-step)
        ),
        linear-gradient(180deg, rgba(var(--text-rgb), 0.025), transparent);
}

.break-gantt-track.actual-track {
    background:
        repeating-linear-gradient(
            to right,
            rgba(var(--text-rgb), 0.06) 0,
            rgba(var(--text-rgb), 0.06) 1px,
            transparent 1px,
            transparent var(--gantt-grid-step)
        ),
        linear-gradient(180deg, rgba(var(--accent-rgb), 0.055), rgba(var(--text-rgb), 0.012));
}

.break-gantt-bar {
    position: absolute;
    left: var(--left);
    top: 6px;
    z-index: 2;
    min-width: 6px;
    width: var(--width);
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 8px;
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 8px;
    color: #07111c;
    font-size: 10px;
    font-weight: 900;
    line-height: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.12);
}

.break-gantt-bar.shift {
    top: 11px;
    z-index: 1;
    height: 18px;
    background: rgba(var(--accent-rgb), 0.22);
    border-color: rgba(var(--accent-rgb), 0.38);
    color: var(--text);
}

.break-gantt-bar.short-first {
    background: #67e8f9;
}

.break-gantt-bar.meal {
    background: #fbbf24;
}

.break-gantt-bar.short-last {
    background: #93c5fd;
}

.break-gantt-bar.other-break {
    background: #cbd5e1;
}

.break-gantt-bar.activity {
    background: #bef264;
}

.break-gantt-bar.absent {
    background: #fca5a5;
}

.break-gantt-bar.actual-idle {
    background: #99f6e4;
}

.break-gantt-bar.actual-task {
    background: #86efac;
}

.break-gantt-bar.actual-activity {
    background: #c4b5fd;
}

.break-gantt-bar.actual-rest {
    background: #fdba74;
}

.break-gantt-bar.actual-offline {
    background: #f87171;
}

.break-gantt-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 12px;
    border-bottom: 1px solid var(--line);
}

.break-gantt-timeline-status {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 10px 12px;
    border-bottom: 1px solid var(--line);
    background: rgba(var(--accent-rgb), 0.07);
}

.break-gantt-timeline-status strong {
    color: var(--text);
    font-size: 12px;
    font-weight: 900;
}

.break-gantt-timeline-status span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
}

.break-gantt-legend span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
}

.break-gantt-legend i {
    width: 12px;
    height: 12px;
    border-radius: 4px;
    border: 1px solid rgba(var(--text-rgb), 0.14);
}

.break-gantt-legend i.shift {
    background: rgba(var(--accent-rgb), 0.3);
}

.break-gantt-legend i.short-first {
    background: #67e8f9;
}

.break-gantt-legend i.meal {
    background: #fbbf24;
}

.break-gantt-legend i.short-last {
    background: #93c5fd;
}

.break-gantt-legend i.other-break {
    background: #cbd5e1;
}

.break-gantt-legend i.activity {
    background: #bef264;
}

.break-gantt-legend i.absent {
    background: #fca5a5;
}

.break-gantt-legend i.actual-idle {
    background: #99f6e4;
}

.break-gantt-legend i.actual-task {
    background: #86efac;
}

.break-gantt-legend i.actual-activity {
    background: #c4b5fd;
}

.break-gantt-legend i.actual-rest {
    background: #fdba74;
}

.break-gantt-legend i.actual-offline {
    background: #f87171;
}

#dataTable th,
#dataTable td {
    min-width: 150px;
    max-width: 190px;
    text-align: center;
    vertical-align: middle;
    line-height: 1.3;
    white-space: normal;
    overflow-wrap: anywhere;
}

#dataTable th:first-child,
#dataTable td:first-child {
    position: sticky;
    left: 0;
    z-index: 2;
    min-width: 170px;
    max-width: 190px;
    background: var(--table-sticky-bg);
    text-align: left;
    box-shadow: 8px 0 18px rgba(0, 0, 0, 0.12);
}

#dataTable.dashboard-queue-table th:nth-child(3),
#dataTable.dashboard-queue-table td:nth-child(3) {
    min-width: 260px;
    max-width: 360px;
    text-align: left;
}

#dataTable.dashboard-queue-table th:nth-child(7),
#dataTable.dashboard-queue-table td:nth-child(7),
#dataTable.dashboard-queue-table .expected-output-cell {
    min-width: 190px;
    max-width: 240px;
}

#dataTable.dashboard-queue-table th:last-child,
#dataTable.dashboard-queue-table td:last-child,
#dataTable.dashboard-queue-table .table-action-cell {
    min-width: 96px;
    max-width: 110px;
}

#dataTable.dashboard-queue-table .queue-capacity-link {
    width: 100%;
    justify-content: center;
}

#dataTable.dashboard-queue-table .queue-capacity-link span,
#dataTable.dashboard-queue-table .queue-capacity-link small {
    display: block;
    max-width: 100%;
    overflow-wrap: anywhere;
}

#dataTable.interval-table th:first-child,
#dataTable.interval-table td:first-child,
#dataTable .interval-sticky-cell {
    position: sticky;
    left: 0;
    background: var(--table-sticky-bg);
    color: var(--text);
    text-align: center;
}

#dataTable.interval-table tbody .interval-sticky-cell {
    z-index: 6;
}

#dataTable.interval-table thead .interval-sticky-cell {
    z-index: 9;
}

#dataTable.interval-table thead tr:nth-child(2) th {
    z-index: 3;
}

#dataTable.interval-table .interval-sticky-cell {
    box-shadow: none;
    border-right: 1px solid var(--line-strong);
}

#dataTable.interval-table thead tr:nth-child(2) .interval-queue-header {
    left: auto;
    min-width: 150px;
    max-width: 190px;
    background: var(--table-head-bg);
    color: var(--muted);
    text-align: center;
    box-shadow: none;
    border-right: 1px solid var(--line);
}

#dataTable.interval-table thead tr:nth-child(2) .interval-queue-header:first-child {
    left: auto;
    z-index: 3;
    background: var(--table-head-bg);
    text-align: center;
    box-shadow: none;
}

#dataTable.interval-table .interval-lob-start {
    border-left: 3px solid rgba(var(--accent-rgb), 0.75);
}

#dataTable.interval-table .interval-running-row td {
    font-weight: 800;
    box-shadow: inset 0 2px 0 rgba(var(--accent-rgb), 0.55), inset 0 -1px 0 rgba(var(--accent-rgb), 0.18);
}

#dataTable.interval-table .interval-running-row .interval-running-label {
    background:
        linear-gradient(135deg, rgba(var(--accent-rgb), 0.16), rgba(var(--accent-rgb), 0.05)),
        var(--table-sticky-bg);
    text-align: left;
}

.interval-running-title,
.interval-running-note,
.interval-running-badge {
    display: block;
}

.interval-running-title {
    color: var(--text);
    font-size: 13px;
    font-weight: 800;
    line-height: 1.2;
}

.interval-running-note {
    margin-top: 4px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 700;
    line-height: 1.25;
    text-transform: uppercase;
}

#dataTable.interval-table .interval-running-cell {
    position: relative;
    background-clip: padding-box;
}

.interval-expected-output {
    display: block;
    margin-top: 4px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 800;
    line-height: 1.2;
}

.interval-expected-output.ahead {
    color: var(--success);
}

.interval-expected-output.behind {
    color: var(--danger);
}

.interval-running-badge {
    margin-bottom: 6px;
    color: var(--accent);
    font-size: 10px;
    font-weight: 800;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 0;
}

#dataTable.interval-table th:first-child,
#dataTable.interval-table td:first-child {
    min-width: 170px;
}

#influxTable th,
#influxTable td {
    min-width: 140px;
    text-align: center;
    vertical-align: middle;
}

#influxTable th span,
#influxTable th small {
    display: block;
}

#influxTable th small {
    margin-top: 4px;
    color: var(--text);
    font-size: 11px;
    font-weight: 700;
    text-transform: none;
}

#influxTable th:first-child,
#influxTable td:first-child {
    min-width: 260px;
    max-width: 360px;
    text-align: left;
    white-space: normal;
    overflow-wrap: anywhere;
}

#influxTable tr.good td {
    background: rgba(var(--success-rgb), 0.12);
}

#influxTable tr.warn td {
    background: rgba(var(--warning-rgb), 0.12);
}

#influxTable tr.bad td {
    background: rgba(var(--danger-rgb), 0.12);
}

#dataTable thead th {
    position: sticky;
    top: 0;
    z-index: 4;
    background: var(--table-head-bg);
}

#dataTable thead th:first-child {
    z-index: 5;
}

.multi-filter {
    position: relative;
    min-width: 150px;
    flex: 1 1 150px;
    height: 36px;
}

.multi-filter-label {
    min-width: 0;
    height: 36px;
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 6px 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--input-bg);
    cursor: pointer;
    overflow: hidden;
    font-size: 11px;
}

.multi-filter-label .placeholder {
    min-height: 0;
    display: inline;
    color: var(--text);
    font-size: 11px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.multi-filter-label:hover,
.multi-filter.active .multi-filter-label {
    border-color: rgba(var(--accent-rgb), 0.7);
}

.chip {
    max-width: 72px;
    padding: 2px 6px;
    border-radius: 8px;
    background: rgba(var(--accent-rgb), 0.18);
    color: var(--text);
    font-size: 10px;
    line-height: 1.35;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.chip.more {
    background: rgba(var(--danger-rgb), 0.18);
    color: var(--danger);
}

.multi-filter-dropdown {
    position: fixed !important;
    z-index: 999999;
    width: 240px;
    max-width: calc(100vw - 24px);
    max-height: 260px;
    display: none;
    padding: 10px;
    overflow-y: auto;
    overflow-x: hidden;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--dropdown-bg);
    font-size: 11px;
    box-shadow: var(--shadow);
}

.filter-header {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 10px;
}

.filter-actions {
    display: flex;
    justify-content: space-between;
    gap: 8px;
}

.filter-actions button {
    min-height: 30px;
    padding: 4px 8px;
    font-size: 10px;
}

.filter-search {
    min-height: 30px;
    padding: 6px 8px;
    font-size: 11px;
}

.multi-option {
    display: flex;
    align-items: flex-start;
    gap: 6px;
    padding: 6px 7px;
    border-radius: 8px;
    cursor: pointer;
}

.multi-option span {
    min-width: 0;
    color: var(--text);
    font-size: 11px;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.multi-option:hover {
    background: var(--row-hover);
}

.multi-option input {
    width: auto;
    min-height: auto;
    margin-top: 1px;
    accent-color: var(--accent);
}

.dashboard-controls select,
.influx-controls select,
.breaks-controls select,
.control-group.filters select {
    font-size: 12px;
}

select option {
    font-size: 12px;
}

.loading-overlay {
    position: fixed;
    inset: 0;
    z-index: 1200;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--modal-backdrop);
    backdrop-filter: blur(8px);
}

.loading-overlay.hidden,
.modal.hidden,
.hidden {
    display: none;
}

.spinner {
    width: 42px;
    height: 42px;
    border: 4px solid rgba(var(--text-rgb), 0.18);
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

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

.upload-progress-panel {
    width: min(420px, calc(100vw - 32px));
    max-width: calc(100vw - 32px);
    min-width: 0;
    padding: 22px;
}

.upload-progress-panel h3 {
    margin: 0 0 8px;
    max-width: 100%;
    font-size: 18px;
    line-height: 1.3;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.upload-progress-panel p,
.upload-progress-meta {
    margin: 0 0 12px;
    max-width: 100%;
    min-width: 0;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.45;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.backup-restore-loading-panel {
    width: min(460px, calc(100vw - 32px));
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 8px;
    padding: 24px;
}

.backup-restore-loading-panel .spinner {
    margin-bottom: 4px;
}

.backup-restore-loading-panel h3 {
    margin: 0;
    color: var(--text);
    font-size: 18px;
}

.backup-restore-loading-panel p {
    margin: 0;
    max-width: 100%;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.45;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.upload-progress-meta {
    display: flex;
    justify-content: flex-end;
}

.upload-progress-meta span {
    min-width: 0;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.upload-progress-track {
    height: 10px;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.08);
}

#uploadProgressFill {
    width: 0;
    height: 100%;
    border-radius: 8px;
    background: var(--accent);
    transition: width 0.15s ease;
}

.footer {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 700;
    padding: 8px 20px 10px;
    border-top: 1px solid var(--line);
    background: var(--footer-bg);
    color: var(--muted);
    font-size: 12px;
    overflow: hidden;
}

.footer-content {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 14px;
    align-items: center;
}

.footer-right {
    color: var(--text);
    opacity: 0.85;
}

.ticker {
    width: 100%;
    overflow: hidden;
    color: var(--accent);
    white-space: nowrap;
}

.ticker-track {
    display: inline-block;
    white-space: nowrap;
    animation: tickerMove 50s linear infinite;
    will-change: transform;
}

@keyframes tickerMove {
    0% {
        transform: translateX(100%);
    }
    100% {
        transform: translateX(-100%);
    }
}

.form-group {
    margin-bottom: 10px;
}

.error-text {
    min-height: 14px;
    margin-top: 2px;
}

.input-error {
    border-color: var(--danger) !important;
    box-shadow: 0 0 0 3px rgba(var(--danger-rgb), 0.18);
}

.modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px;
    background: var(--modal-backdrop);
    backdrop-filter: blur(6px);
}

#appModal {
    z-index: 1305;
}

.modal-content {
    width: min(420px, 100%);
    max-height: calc(100vh - 36px);
    padding: 20px;
    overflow: auto;
    animation: modalFade 0.18s ease;
}

.queue-detail-modal {
    width: min(860px, 100%);
}

.queue-influx-modal {
    width: min(860px, 100%);
}

.queue-capacity-modal {
    width: min(1040px, 100%);
}

.forecast-interval-modal {
    width: min(980px, 100%);
}

.break-optimization-modal {
    width: min(1120px, 100%);
}

.backup-modal {
    width: min(620px, 100%);
}

.db-columns-modal {
    width: min(560px, 100%);
}

.upload-alias-modal {
    width: min(980px, 100%);
}

.data-source-sample-modal {
    width: min(1180px, 100%);
}

.data-source-sample-scroll {
    max-height: min(62vh, 620px);
}

.data-source-sample-scroll table {
    min-width: max-content;
}

.data-source-sample-scroll td,
.data-source-sample-scroll th {
    max-width: 360px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.database-schema-modal {
    width: min(1180px, 100%);
}

.schema-map {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin: 16px 0;
}

.schema-column {
    display: grid;
    align-content: start;
    gap: 10px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.035);
}

.schema-column-title {
    color: var(--accent);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
}

.schema-node {
    display: grid;
    gap: 5px;
    padding: 11px;
    border: 1px solid rgba(var(--accent-rgb), 0.28);
    border-radius: 8px;
    background: rgba(var(--panel-rgb), 0.78);
}

.schema-node.primary {
    border-color: rgba(var(--accent-rgb), 0.72);
    box-shadow: 0 0 0 1px rgba(var(--accent-rgb), 0.12), 0 10px 24px rgba(0, 0, 0, 0.12);
}

.schema-node strong {
    color: var(--text);
    font-size: 14px;
}

.schema-node span,
.schema-arrow,
.schema-join {
    color: var(--muted);
    font-size: 12px;
    line-height: 1.4;
}

.schema-arrow {
    position: relative;
    padding-left: 18px;
    font-weight: 800;
}

.schema-arrow::before {
    content: "->";
    position: absolute;
    left: 0;
    color: var(--accent);
}

.schema-split {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.schema-join {
    padding: 7px 9px;
    border: 1px dashed rgba(var(--accent-rgb), 0.4);
    border-radius: 999px;
    text-align: center;
    font-weight: 800;
}

.schema-relationship-table {
    max-height: min(42vh, 420px);
}

@media (max-width: 980px) {
    .schema-map {
        grid-template-columns: 1fr;
    }
}

.user-modal {
    width: min(440px, 100%);
}

.profile-modal {
    width: min(480px, 100%);
}

.admin-notifications-modal {
    width: min(860px, 100%);
}

.admin-notifications-modal .admin-notification-stats {
    margin-bottom: 14px;
}

.admin-notifications-list {
    display: grid;
    gap: 14px;
    max-height: min(58vh, 560px);
    overflow: auto;
    padding-right: 4px;
}

.admin-notification-group {
    display: grid;
    gap: 10px;
}

.admin-notification-group h4 {
    margin: 0;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.admin-notification-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
}

.admin-notification-main {
    min-width: 0;
}

.admin-notification-main strong {
    display: block;
    overflow-wrap: anywhere;
}

.admin-notification-main small {
    display: block;
    margin-top: 4px;
    color: var(--muted);
    font-size: 12px;
}

.admin-notification-main p {
    margin: 6px 0 0;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.admin-notification-actions {
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
}

.profile-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
}

.profile-summary strong {
    display: block;
    margin-top: 3px;
    overflow-wrap: anywhere;
}

.profile-pill {
    flex: 0 0 auto;
    padding: 5px 9px;
    border: 1px solid rgba(var(--accent-rgb), 0.38);
    border-radius: 8px;
    background: rgba(var(--accent-rgb), 0.12);
    color: var(--accent);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.user-active-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 4px;
    color: var(--text);
    font-size: 13px;
    font-weight: 700;
}

.user-active-toggle input {
    width: auto;
    min-height: auto;
    accent-color: var(--accent);
}

.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
}

.modal-header h3 {
    margin: 0;
}

.queue-detail-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 10px;
}

.queue-detail-item {
    min-width: 0;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
    overflow: hidden;
}

.queue-detail-action {
    width: 100%;
    min-height: 0;
    text-align: left;
    cursor: pointer;
}

.queue-detail-action:hover {
    border-color: rgba(var(--accent-rgb), 0.55);
    background: rgba(var(--accent-rgb), 0.11);
}

.metric-cell {
    font-weight: 800;
}

.metric-good {
    color: var(--success);
}

.metric-warn {
    color: var(--warning);
}

.metric-bad {
    color: var(--danger);
}

td.metric-good,
.queue-detail-item.metric-good,
.queue-influx-card.metric-good {
    border-color: rgba(var(--success-rgb), 0.42);
    background: rgba(var(--success-rgb), 0.12);
}

td.metric-warn,
.queue-detail-item.metric-warn,
.queue-influx-card.metric-warn {
    border-color: rgba(var(--warning-rgb), 0.45);
    background: rgba(var(--warning-rgb), 0.13);
}

td.metric-bad,
.queue-detail-item.metric-bad,
.queue-influx-card.metric-bad {
    border-color: rgba(var(--danger-rgb), 0.46);
    background: rgba(var(--danger-rgb), 0.13);
}

.queue-detail-item.metric-source {
    border-color: rgba(var(--accent-rgb), 0.38);
    background: rgba(var(--accent-rgb), 0.1);
}

.queue-detail-item span {
    display: block;
    color: var(--muted);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: uppercase;
}

.queue-detail-item strong {
    display: block;
    margin-top: 6px;
    max-width: 100%;
    font-size: 17px;
    line-height: 1.28;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.queue-detail-item small {
    display: block;
    margin-top: 6px;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.3;
}

.queue-detail-item.wide {
    grid-column: span 2;
}

.queue-detail-note {
    margin: 14px 0 0;
    color: var(--muted);
    font-size: 13px;
}

.queue-influx-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}

#queueInfluxCaptureArea,
#queueCapacityCaptureArea {
    padding: 12px;
    border-radius: 8px;
    background: var(--panel);
    color: var(--text);
}

.queue-influx-report-header {
    margin-bottom: 12px;
}

.queue-influx-report-header h4 {
    margin: 0;
    color: var(--text);
    font-size: 20px;
}

.queue-influx-report-header p {
    margin: 6px 0 0;
    color: var(--muted);
    font-size: 13px;
}

.queue-influx-card {
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
}

.queue-influx-card span,
.queue-influx-card small {
    display: block;
    color: var(--muted);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: uppercase;
}

.queue-influx-card strong {
    display: block;
    margin-top: 6px;
    font-size: 18px;
}

.queue-influx-chart {
    margin-bottom: 14px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
    overflow-x: auto;
}

.queue-influx-chart svg {
    display: block;
    width: 100%;
    min-width: 620px;
    height: auto;
}

.queue-influx-chart-empty {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
}

#queueInfluxTable {
    min-width: 720px;
}

#queueCapacityTable {
    min-width: 1480px;
}

#backlogReportTable {
    min-width: 1580px;
}

#backlogSummaryCaptureArea {
    padding: 14px;
    background: var(--panel);
    color: var(--text);
}

.backlog-summary-card {
    display: grid;
    gap: 14px;
}

.backlog-summary-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--line);
}

.backlog-summary-header h3 {
    margin: 3px 0 4px;
}

.backlog-summary-header p {
    max-width: 820px;
    margin: 0;
    color: var(--muted);
    font-size: 13px;
}

.backlog-summary-stamp {
    flex: 0 0 auto;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}

.backlog-summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 170px), 1fr));
    gap: 10px;
}

.backlog-summary-grid > div {
    min-width: 0;
    padding: 11px 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.035);
}

.backlog-summary-grid span,
.backlog-summary-grid small {
    display: block;
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
}

.backlog-summary-grid strong {
    display: block;
    margin-top: 5px;
    color: var(--text);
    font-size: 18px;
}

.backlog-summary-grid small {
    margin-top: 5px;
    line-height: 1.3;
    text-transform: none;
}

.backlog-simple-table {
    min-width: 1180px;
}

.backlog-simple-table td small {
    display: block;
    margin-top: 3px;
    color: var(--muted);
    font-size: 11px;
}

.backlog-controls select[multiple] {
    min-height: 92px;
}

.table-sort-button {
    width: 100%;
    min-height: 0;
    padding: 0;
    border: 0;
    background: transparent;
    color: inherit;
    font: inherit;
    text-align: inherit;
    cursor: pointer;
}

.table-sort-button:hover {
    color: var(--accent);
}

.table-link {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    min-height: 0;
    padding: 4px 8px;
    border-color: rgba(var(--accent-rgb), 0.28);
    background: rgba(var(--accent-rgb), 0.08);
    color: var(--text);
    font-size: 12px;
    font-weight: 800;
}

.table-link small {
    color: var(--muted);
    font-size: 10px;
    font-weight: 700;
    line-height: 1.1;
}

.table-link.metric-good {
    color: var(--success);
}

.table-link.metric-warn {
    color: var(--warning);
}

.table-link.metric-bad {
    color: var(--danger);
}

#queueInfluxTable th {
    background: var(--table-head-bg);
}

#queueInfluxTable th,
#queueInfluxTable td {
    min-width: 120px;
    text-align: center;
    vertical-align: middle;
}

#queueInfluxTable th:first-child,
#queueInfluxTable td:first-child {
    text-align: left;
}

.modal-help {
    margin: 0 0 14px;
    color: var(--muted);
    font-size: 13px;
}

.nav-internal-link {
    display: none !important;
}

.global-filter-chips {
    margin: 12px 0;
    padding: 10px 12px;
}

.command-sticky-strip {
    position: sticky;
    top: 72px;
    z-index: 15;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    margin: 12px 0 16px;
    padding: 10px 12px;
    border: 1px solid var(--line);
}

.command-sticky-strip span {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    min-height: 28px;
    padding: 4px 8px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: rgba(var(--panel-rgb), 0.62);
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}

.command-sticky-strip strong {
    color: var(--text);
}

.global-filter-chip-row,
.decision-filter-row,
.upload-center-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

.global-filter-chip {
    padding: 6px 9px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: rgba(var(--text-rgb), 0.04);
    color: var(--muted);
    font-size: 12px;
}

.global-filter-chip strong {
    color: var(--text);
}

.decision-action-queue {
    padding: 12px;
}

.top-actions-now {
    margin-bottom: 10px;
    padding: 12px;
}

.top-actions-list {
    display: grid;
    gap: 8px;
}

.top-action-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 10px;
    align-items: start;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.035);
}

.top-action-item strong,
.top-action-item small {
    display: block;
    overflow-wrap: anywhere;
}

.top-action-item small {
    margin-top: 3px;
    color: var(--muted);
}

.top-action-buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 6px;
}

.now-next-later-board {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.decision-board-card {
    display: grid;
    gap: 8px;
    min-height: 100%;
}

.decision-board-card h3 {
    margin: 0;
}

.decision-board-list {
    display: grid;
    gap: 8px;
}

.decision-board-list > div {
    padding: 9px 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.035);
}

.decision-board-list strong,
.decision-board-list small {
    display: block;
    overflow-wrap: anywhere;
}

.decision-board-list small {
    margin-top: 3px;
    color: var(--muted);
}

.decision-action-list {
    display: grid;
    gap: 10px;
}

.decision-action-card {
    display: grid;
    grid-template-columns: 46px minmax(0, 1fr) minmax(170px, 230px);
    gap: 12px;
    padding: 12px;
    border: 1px solid var(--line);
    border-left-width: 4px;
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.035);
}

.decision-action-card.critical {
    border-left-color: var(--danger);
}

.decision-action-card.warning,
.decision-action-card.watch {
    border-left-color: var(--warning);
}

.decision-action-card.info {
    border-left-color: var(--accent);
}

.decision-action-rank {
    color: var(--muted);
    font-weight: 900;
}

.decision-action-main,
.decision-action-head,
.decision-action-side {
    min-width: 0;
}

.decision-action-head {
    display: grid;
    gap: 3px;
}

.decision-action-head strong,
.decision-action-main p,
.decision-action-main small {
    overflow-wrap: anywhere;
}

.decision-action-main p {
    margin: 8px 0 4px;
    color: var(--text);
    font-weight: 700;
}

.decision-action-main small,
.decision-action-side small {
    color: var(--muted);
}

.decision-source-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 8px;
}

.decision-source-row > span,
.severity-badge,
.confidence-badge,
.source-status {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 22px;
    padding: 3px 7px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: rgba(var(--text-rgb), 0.05);
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
}

.severity-badge.critical,
.confidence-badge.missing,
.source-status.missing {
    border-color: rgba(var(--danger-rgb), 0.45);
    background: rgba(var(--danger-rgb), 0.12);
    color: var(--danger);
}

.severity-badge.warning,
.severity-badge.watch,
.confidence-badge.low,
.source-status.warn {
    border-color: rgba(var(--warning-rgb), 0.45);
    background: rgba(var(--warning-rgb), 0.12);
    color: var(--warning);
}

.confidence-badge.high,
.source-status.loaded {
    border-color: rgba(var(--success-rgb), 0.42);
    background: rgba(var(--success-rgb), 0.1);
    color: var(--success);
}

.confidence-badge.medium {
    color: var(--accent);
}

.decision-action-side {
    display: grid;
    gap: 5px;
    align-content: start;
}

.decision-action-side span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
}

.dashboard-change-summary {
    padding: 12px;
}

.change-summary-group {
    display: grid;
    grid-template-columns: minmax(140px, 180px) repeat(auto-fit, minmax(180px, 1fr));
    gap: 8px;
    align-items: start;
    padding: 8px 0;
    border-bottom: 1px solid var(--line);
}

.change-summary-group:last-child {
    border-bottom: 0;
}

.change-summary-group span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
}

.change-summary-group strong {
    font-size: 12px;
}

.command-drilldown-grid,
.data-confidence-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 10px;
}

.command-drilldown-card {
    height: auto;
    text-align: left;
}

.command-drilldown-card span,
.command-drilldown-card small {
    display: block;
    color: var(--muted);
}

.command-drilldown-card strong {
    display: block;
    margin: 4px 0;
    color: var(--text);
}

.defcon-level-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 12px;
}

.defcon-card {
    align-items: flex-start;
    min-height: 100%;
    border-top: 4px solid rgba(var(--accent-rgb), 0.7);
}

.defcon-card h3,
.defcon-check-card h3 {
    margin: 8px 0 6px;
}

.defcon-card p,
.defcon-check-card p {
    color: var(--muted);
    margin: 0 0 10px;
}

.defcon-card dl {
    display: grid;
    gap: 6px;
    margin: 0;
}

.defcon-card dt {
    color: var(--text);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
}

.defcon-card dd {
    color: var(--muted);
    margin: 0 0 6px;
    line-height: 1.45;
}

.defcon-badge {
    display: inline-flex;
    width: fit-content;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(var(--text-rgb), 0.08);
    color: var(--text);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.02em;
}

.defcon-level-5 {
    border-top-color: rgba(var(--success-rgb), 0.75);
}

.defcon-level-4 {
    border-top-color: rgba(var(--accent-rgb), 0.8);
}

.defcon-level-3 {
    border-top-color: rgba(var(--warning-rgb), 0.85);
}

.defcon-level-2 {
    border-top-color: rgba(249, 115, 22, 0.9);
}

.defcon-level-1 {
    border-top-color: rgba(var(--danger-rgb), 0.95);
}

.defcon-checklist-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 10px;
}

.defcon-template-card pre {
    margin: 0;
    white-space: pre-wrap;
    color: var(--text);
    font: 700 13px/1.7 ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace;
}

.readiness-card.loaded {
    border-color: rgba(var(--success-rgb), 0.32);
}

.readiness-card.warn {
    border-color: rgba(var(--warning-rgb), 0.32);
}

.readiness-card.missing {
    border-color: rgba(var(--danger-rgb), 0.32);
}

.critical-confidence-row {
    margin-top: -4px;
}

.queue-360-layout {
    display: grid;
    gap: 12px;
}

.queue-360-summary {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.035);
}

.queue-360-summary-actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
}

.queue-360-summary h4,
.queue-360-summary p {
    margin: 0;
}

.queue-360-summary p {
    margin-top: 5px;
    color: var(--muted);
}

.queue-360-main-driver {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 170px), 1fr));
    gap: 8px;
}

.queue-driver-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 180px), 1fr));
    gap: 8px;
}

.queue-driver-card {
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.035);
}

.queue-driver-card.active {
    border-color: rgba(var(--warning-rgb), 0.45);
    background: rgba(var(--warning-rgb), 0.08);
}

.queue-driver-card strong,
.queue-driver-card span,
.queue-driver-card small {
    display: block;
}

.queue-driver-card span,
.queue-driver-card small {
    margin-top: 4px;
    color: var(--muted);
    font-size: 12px;
}

.queue-360-rca-card {
    padding: 12px;
}

.queue-360-tabs,
.queue-360-section-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.queue-360-tabs span,
.queue-360-section-chips span,
.queue-360-section-chips button {
    min-height: 0;
    padding: 5px 8px;
    border: 1px solid var(--line);
    border-radius: 6px;
    background: rgba(var(--text-rgb), 0.035);
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    cursor: pointer;
}

.queue-360-section-chips button:hover {
    border-color: rgba(var(--accent-rgb), 0.52);
    color: var(--text);
}

.queue-360-section {
    display: grid;
    gap: 8px;
}

.section-header.compact {
    margin-bottom: 0;
}

.data-confidence-item {
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.035);
}

.data-confidence-item span {
    display: block;
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
}

.data-confidence-item.loaded strong {
    color: var(--success);
}

.data-confidence-item.missing strong {
    color: var(--danger);
}

.data-confidence-item.neutral strong {
    color: var(--muted);
}

.pu-heatmap-cell {
    min-width: 88px;
    text-align: center;
}

.critical-queue-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 6px;
}

.table-action-cell button {
    margin: 2px;
}

.queue-rca-modal {
    width: min(980px, calc(100vw - 28px));
}

.queue-rca-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 12px 0;
}

.queue-rca-header-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin: 6px 0;
}

.command-priority-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.9fr);
    gap: 18px;
    align-items: start;
}

.early-warning-list,
.data-quality-list,
.pu-load-grid {
    display: grid;
    gap: 10px;
}

.early-warning-card,
.data-quality-card,
.pu-load-card {
    display: grid;
    gap: 8px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--panel-rgb), 0.55);
}

.early-warning-card > div:first-child,
.early-warning-actions,
.queue-360-summary-actions,
.what-if-grid,
.coverage-cell-people {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.early-warning-card p,
.data-quality-card p,
.pu-load-card p {
    margin: 0;
    color: var(--muted);
}

.scope-note {
    margin: 0 0 10px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}

.scope-warning {
    display: block;
    color: var(--warning) !important;
    font-weight: 900;
}

.data-readiness-grid,
.help-playbook-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
    gap: 12px;
}

.action-log-form {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 190px), 1fr));
    gap: 10px;
    padding: 12px;
}

.action-log-form label {
    display: grid;
    gap: 5px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}

.action-log-form .wide {
    grid-column: 1 / -1;
}

.action-log-form textarea {
    min-height: 78px;
    resize: vertical;
}

.handoff-preview {
    max-height: 520px;
    padding: 14px;
    overflow: auto;
    white-space: pre-wrap;
    line-height: 1.45;
}

.action-type-badge {
    display: inline-flex;
    width: fit-content;
    padding: 3px 7px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: rgba(var(--accent-rgb), 0.1);
    color: var(--accent);
    font-size: 11px;
    font-weight: 900;
}

.escalation-mode-content {
    display: grid;
    gap: 8px;
}

.escalation-mode-content p {
    margin: 0;
}

.recovery-eta-line {
    color: var(--accent);
    font-weight: 800;
}

.what-if-grid label {
    display: grid;
    gap: 4px;
    min-width: 140px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}

.pu-heatmap-cell-button {
    display: grid;
    gap: 2px;
    width: 100%;
    min-height: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    color: inherit;
    text-align: center;
    cursor: pointer;
}

.coverage-cell-modal {
    width: min(760px, calc(100vw - 28px));
}

@media (max-width: 960px) {
    .command-priority-grid {
        grid-template-columns: 1fr;
    }
}

.rca-helper-text {
    margin: 10px 0 0;
}

.rca-preview {
    max-height: min(52vh, 520px);
    margin: 0;
    padding: 14px;
    overflow: auto;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--panel-rgb), 0.78);
    color: var(--text);
    font: 12px/1.55 Consolas, "Courier New", monospace;
    white-space: pre-wrap;
    overflow-wrap: anywhere;
}

.pu-heatmap-cell strong,
.pu-heatmap-cell small {
    display: block;
}

.pu-heatmap-cell small {
    color: var(--muted);
    font-size: 10px;
}

.pu-heatmap-cell.safe {
    background: rgba(var(--success-rgb), 0.1);
}

.pu-heatmap-cell.watch {
    background: rgba(var(--warning-rgb), 0.14);
    color: var(--warning);
}

.pu-heatmap-cell.gap {
    background: rgba(var(--danger-rgb), 0.14);
    color: var(--danger);
}

.pu-heatmap-cell.empty {
    color: var(--muted);
}

.break-optimization-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 12px;
}

.break-optimization-toolbar .form-group {
    margin: 0;
    min-width: 230px;
}

.break-optimization-required-hc {
    max-width: 280px;
}

.break-optimization-toolbar-actions {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 8px;
}

.break-optimization-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 8px;
    margin-bottom: 10px;
}

.break-optimization-stat {
    min-width: 0;
    padding: 9px 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
}

.break-optimization-stat span {
    display: block;
    color: var(--muted);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
}

.break-optimization-stat strong {
    display: block;
    margin-top: 5px;
    font-size: 15px;
    line-height: 1.3;
    overflow-wrap: anywhere;
}

.break-optimization-stat strong.good,
.break-optimization-delta.good,
.break-optimization-count.remaining.good {
    color: var(--success);
}

.break-optimization-stat strong.bad,
.break-optimization-delta.bad,
.break-optimization-count.remaining.bad {
    color: var(--danger);
}

.break-optimization-stat strong.neutral,
.break-optimization-delta.neutral {
    color: var(--muted);
}

.break-optimization-visual {
    margin-bottom: 12px;
}

.break-optimization-compare-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 8px;
    margin-bottom: 10px;
}

.break-optimization-chart {
    display: grid;
    gap: 4px;
    max-height: min(260px, 34vh);
    padding: 10px;
    overflow: auto;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.03);
}

.break-optimization-chart-row {
    display: grid;
    grid-template-columns: 58px minmax(140px, 1fr) 56px 66px 66px 64px 72px 52px;
    align-items: center;
    gap: 8px;
    min-height: 30px;
    font-size: 12px;
}

.break-optimization-time {
    color: var(--muted);
    font-weight: 800;
}

.break-optimization-time small {
    display: block;
    max-width: 58px;
    margin-top: 2px;
    overflow: hidden;
    color: var(--muted);
    font-size: 9px;
    line-height: 1.1;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.break-optimization-demand {
    height: 12px;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.06);
}

.break-optimization-demand i {
    display: block;
    height: 100%;
    border-radius: 8px;
    background: linear-gradient(90deg, var(--accent), var(--warning));
}

.break-optimization-count {
    padding: 3px 6px;
    border: 1px solid var(--line);
    border-radius: 8px;
    text-align: center;
    font-weight: 800;
}

.break-optimization-count.old {
    background: rgba(var(--text-rgb), 0.04);
}

.break-optimization-count.new {
    background: rgba(var(--accent-rgb), 0.1);
    border-color: rgba(var(--accent-rgb), 0.34);
}

.break-optimization-count.remaining {
    background: rgba(var(--success-rgb), 0.1);
    border-color: rgba(var(--success-rgb), 0.28);
}

.break-optimization-count.remaining.bad {
    background: rgba(var(--danger-rgb), 0.1);
    border-color: rgba(var(--danger-rgb), 0.34);
}

.break-optimization-count.warn {
    background: rgba(var(--warning-rgb), 0.12);
    border-color: rgba(var(--warning-rgb), 0.36);
    color: var(--warning);
}

.break-optimization-delta {
    font-weight: 900;
    text-align: right;
}

.break-optimization-empty {
    margin-bottom: 10px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
    color: var(--muted);
    font-size: 13px;
}

#breakOptimizationTable {
    min-width: 1320px;
}

#breakOptimizationTable th,
#breakOptimizationTable td {
    text-align: center;
    vertical-align: middle;
}

#breakOptimizationTable th:first-child,
#breakOptimizationTable td:first-child,
#breakOptimizationTable th:nth-child(2),
#breakOptimizationTable td:nth-child(2) {
    text-align: left;
}

#breakOptimizationTable th:first-child,
#breakOptimizationTable td:first-child {
    position: sticky;
    left: 0;
    z-index: 2;
    background: var(--table-sticky-bg);
    min-width: 116px;
    box-shadow: 8px 0 14px rgba(0, 0, 0, 0.12);
}

#breakOptimizationTable th:nth-child(2),
#breakOptimizationTable td:nth-child(2) {
    position: sticky;
    left: 116px;
    z-index: 2;
    background: var(--table-sticky-bg);
    min-width: 180px;
}

#breakOptimizationTable thead th:first-child,
#breakOptimizationTable thead th:nth-child(2) {
    z-index: 6;
}

.break-opt-time-input {
    min-width: 108px;
    max-width: 130px;
    margin: 0 auto;
    text-align: center;
}

.break-opt-flag {
    color: var(--muted);
    font-size: 11px;
}

.break-opt-move {
    font-size: 12px;
    font-weight: 800;
}

.break-opt-move.neutral {
    color: var(--muted);
}

.break-opt-move.warn {
    color: var(--warning);
}

.backup-select-actions {
    display: flex;
    gap: 8px;
    margin-bottom: 10px;
}

.backup-options {
    display: grid;
    gap: 8px;
    max-height: min(360px, 50vh);
    overflow: auto;
}

.backup-option {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
}

.backup-option.required {
    border-color: rgba(var(--accent-rgb), 0.45);
    background: rgba(var(--accent-rgb), 0.1);
}

.backup-option input {
    width: auto;
    min-height: auto;
    accent-color: var(--accent);
}

.backup-option strong,
.backup-option small {
    display: block;
}

.backup-option small,
.backup-count {
    color: var(--muted);
    font-size: 12px;
}

.db-columns-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 8px;
    max-height: min(420px, 55vh);
    overflow: auto;
}

.db-column-chip {
    min-width: 0;
    padding: 9px 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
    color: var(--text);
    font-size: 13px;
    overflow-wrap: anywhere;
}

.upload-alias-layout {
    display: grid;
    grid-template-columns: minmax(240px, 320px) minmax(0, 1fr);
    gap: 14px;
    align-items: start;
}

.upload-alias-form {
    min-width: 0;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: rgba(var(--text-rgb), 0.04);
}

.upload-alias-form textarea {
    width: 100%;
    min-height: 150px;
    resize: vertical;
}

.upload-alias-form select {
    width: 100%;
}

.upload-alias-actions {
    margin-top: 10px;
}

.upload-alias-table-wrap {
    min-width: 0;
}

#uploadAliasTable {
    min-width: 780px;
}

#uploadAliasTable td:nth-child(3) {
    min-width: 260px;
    white-space: normal;
    overflow-wrap: anywhere;
}

@media (max-width: 560px) {
    .queue-detail-grid {
        grid-template-columns: 1fr;
    }

    .queue-detail-item.wide {
        grid-column: span 1;
    }

    .upload-alias-layout {
        grid-template-columns: 1fr;
    }
}

.modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 16px;
}

@keyframes modalFade {
    from {
        opacity: 0;
        transform: translateY(-8px) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

#assistantBot {
    position: fixed;
    right: 20px;
    bottom: 58px;
    z-index: 1301;
    width: 82px;
    height: 60px;
    cursor: grab;
    isolation: isolate;
    --bot-line: #2f78b7;
    user-select: none;
    animation: idleFloat 4s ease-in-out infinite;
}

#assistantBot::before,
#assistantBot::after {
    content: "";
    position: absolute;
    z-index: -1;
}

#assistantBot::before {
    left: 14px;
    bottom: -2px;
    width: 54px;
    height: 8px;
    border-radius: 50%;
    background: rgba(10, 18, 26, 0.18);
    filter: blur(2px);
}

#assistantBot::after {
    top: 24px;
    right: 5px;
    z-index: 4;
    display: block;
    width: 6px;
    height: 11px;
    border: 2px solid #ffffff;
    border-radius: 72% 46% 64% 50% / 72% 62% 42% 48%;
    background:
        radial-gradient(ellipse at 36% 22%, rgba(255, 255, 255, 0.92) 0 18%, transparent 20%),
        linear-gradient(180deg, #9ed9f4 0%, #5fa9dc 100%);
    pointer-events: none;
    opacity: 0;
    box-shadow:
        inset 0 0 0 1px rgba(79, 166, 211, 0.72),
        0 5px 10px rgba(0, 0, 0, 0.2);
    transform: translateY(2px) scale(0.76) rotate(16deg);
    animation: botPanicDrop 1.6s ease-in-out infinite;
}

#assistantBot:has(.bot-critical)::after {
    opacity: 1;
}

.bot-face {
    position: relative;
    width: 136px;
    height: 92px;
    margin-top: 0;
    overflow: hidden;
    border: 4px solid #ffffff;
    border-radius: 49% 51% 43% 42% / 56% 54% 37% 36%;
    background:
        radial-gradient(ellipse at 30% 16%, rgba(255, 255, 255, 0.95) 0 15%, transparent 16%),
        radial-gradient(ellipse at 12% 36%, rgba(255, 255, 255, 0.9) 0 5%, transparent 6%),
        radial-gradient(ellipse at 72% 34%, rgba(255, 255, 255, 0.62) 0 4%, transparent 5%),
        radial-gradient(ellipse at 55% 42%, rgba(91, 168, 211, 0.62) 0 37%, transparent 38%),
        radial-gradient(ellipse at 47% 78%, rgba(91, 168, 211, 0.68) 0 39%, transparent 40%),
        linear-gradient(180deg, #9ed9f4 0%, #8fd0ee 48%, #86c4e8 100%);
    box-shadow:
        0 10px 18px rgba(0, 0, 0, 0.3),
        inset 0 0 0 3px rgba(79, 166, 211, 0.92),
        inset 0 11px 18px rgba(255, 255, 255, 0.25),
        inset 0 -12px 24px rgba(56, 122, 185, 0.22);
    animation: slimeWobble 4.2s ease-in-out infinite;
    scale: 0.6;
    transform-origin: top left;
    transition: background 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease, border-radius 0.2s ease;
}

.bot-face::before {
    content: "";
    position: absolute;
    z-index: 1;
    top: 7px;
    left: 31px;
    width: 52px;
    height: 18px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.86);
    transform: rotate(-22deg);
}

.bot-face::after {
    content: "";
    position: absolute;
    z-index: 0;
    left: 23px;
    bottom: 12px;
    width: 83px;
    height: 26px;
    border-radius: 48% 52% 52% 44%;
    background: rgba(78, 153, 205, 0.52);
    filter: blur(0.2px);
}

.eye {
    position: absolute;
    z-index: 2;
    top: 41px;
    width: 40px;
    height: 20px;
    border-radius: 999px;
    background: transparent;
    box-shadow: none;
    animation: none;
    transition: width 0.16s ease, height 0.16s ease, transform 0.16s ease, border-radius 0.16s ease;
}

.eye::before {
    content: "";
    position: absolute;
    inset: 1px 0 auto;
    height: 16px;
    border-top: 3px solid var(--bot-line);
    border-radius: 50%;
}

.brow {
    position: absolute;
    z-index: 2;
    top: 47px;
    width: 14px;
    height: 4px;
    border-radius: 999px;
    background: var(--bot-line);
    opacity: 0;
    transition: transform 0.16s ease, opacity 0.16s ease;
}

.brow.left {
    left: 60px;
    transform: rotate(28deg);
}

.brow.right {
    right: 56px;
    transform: rotate(-28deg);
}

.cheek {
    position: absolute;
    z-index: 2;
    top: 52px;
    width: 28px;
    height: 12px;
    border-radius: 999px;
    background: rgba(255, 203, 244, 0.72);
    opacity: 0;
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.cheek::before {
    content: "";
    position: absolute;
    top: 2px;
    left: 11px;
    width: 3px;
    height: 9px;
    border-radius: 999px;
    background: var(--bot-line);
    box-shadow:
        8px 0 0 var(--bot-line),
        -8px 0 0 var(--bot-line);
    opacity: 0;
    transform: rotate(9deg);
    transition: opacity 0.18s ease;
}

.cheek.left {
    left: 13px;
}

.cheek.right {
    right: 13px;
}

.eye.left {
    left: 19px;
}

.eye.left::before {
    transform: rotate(16deg);
}

.eye.right {
    right: 19px;
}

.eye.right::before {
    transform: rotate(-11deg);
}

.mouth {
    position: absolute;
    z-index: 2;
    bottom: 18px;
    left: 50%;
    width: 10px;
    height: 3px;
    border: 0;
    border-radius: 999px;
    background: rgba(47, 120, 183, 0.38);
    opacity: 0;
    display: none;
    transform: translateX(-50%);
    transition: width 0.16s ease, height 0.16s ease, border 0.16s ease, transform 0.16s ease, opacity 0.16s ease;
}

.mouth.smile {
    width: 16px;
    height: 7px;
    border-bottom: 2px solid var(--bot-line);
    border-radius: 0 0 999px 999px;
    background: transparent;
    opacity: 0.45;
}

.mouth.sad {
    bottom: 14px;
    height: 7px;
    border-top: 2px solid var(--bot-line);
    border-bottom: 0;
    border-radius: 999px 999px 0 0;
    background: transparent;
    opacity: 0.45;
}

.mouth.flat {
    bottom: 18px;
    width: 14px;
    height: 3px;
    border: 0;
    border-radius: 999px;
    background: rgba(47, 120, 183, 0.44);
    opacity: 0;
}

.bot-happy {
    background:
        radial-gradient(ellipse at 30% 16%, rgba(255, 255, 255, 0.95) 0 15%, transparent 16%),
        radial-gradient(ellipse at 12% 36%, rgba(255, 255, 255, 0.9) 0 5%, transparent 6%),
        radial-gradient(ellipse at 72% 34%, rgba(255, 255, 255, 0.62) 0 4%, transparent 5%),
        radial-gradient(ellipse at 55% 42%, rgba(91, 168, 211, 0.62) 0 37%, transparent 38%),
        radial-gradient(ellipse at 47% 78%, rgba(91, 168, 211, 0.68) 0 39%, transparent 40%),
        linear-gradient(180deg, #9ed9f4 0%, #8fd0ee 48%, #86c4e8 100%);
}

.bot-happy .eye {
    top: 38px;
    width: 36px;
    height: 18px;
}

.bot-happy .eye.left {
    left: 25px;
}

.bot-happy .eye.right {
    right: 25px;
}

.bot-happy .eye.left::before {
    transform: rotate(4deg);
}

.bot-happy .eye.right::before {
    transform: rotate(-4deg);
}

.bot-happy .cheek {
    opacity: 1;
    transform: rotate(3deg);
}

.bot-happy .cheek::before {
    opacity: 1;
}

.bot-happy .brow {
    opacity: 0;
}

.bot-happy .mouth.smile {
    opacity: 0;
}

.bot-warning {
    background:
        radial-gradient(ellipse at 30% 16%, rgba(255, 255, 255, 0.95) 0 15%, transparent 16%),
        radial-gradient(ellipse at 12% 36%, rgba(255, 255, 255, 0.9) 0 5%, transparent 6%),
        radial-gradient(ellipse at 72% 34%, rgba(255, 255, 255, 0.62) 0 4%, transparent 5%),
        radial-gradient(ellipse at 55% 42%, rgba(91, 168, 211, 0.62) 0 37%, transparent 38%),
        radial-gradient(ellipse at 47% 78%, rgba(91, 168, 211, 0.68) 0 39%, transparent 40%),
        linear-gradient(180deg, #9ed9f4 0%, #8fd0ee 48%, #86c4e8 100%);
}

.bot-warning .eye {
    top: 42px;
    width: 34px;
    height: 17px;
}

.bot-warning .eye.left::before {
    transform: rotate(15deg);
}

.bot-warning .eye.right::before {
    transform: rotate(-15deg);
}

.bot-warning .eye::after {
    content: "";
    position: absolute;
    top: 7px;
    width: 10px;
    height: 2px;
    border-radius: 999px;
    background: var(--bot-line);
    opacity: 0.76;
}

.bot-warning .eye.left::after {
    right: -2px;
    transform: rotate(16deg);
}

.bot-warning .eye.right::after {
    left: -2px;
    transform: rotate(-16deg);
}

.bot-warning .brow.left {
    left: 61px;
    transform: rotate(30deg) translateY(1px);
}

.bot-warning .brow.right {
    right: 57px;
    transform: rotate(-30deg) translateY(1px);
}

.bot-critical {
    background:
        radial-gradient(ellipse at 30% 16%, rgba(255, 255, 255, 0.95) 0 15%, transparent 16%),
        radial-gradient(ellipse at 12% 36%, rgba(255, 255, 255, 0.9) 0 5%, transparent 6%),
        radial-gradient(ellipse at 72% 34%, rgba(255, 255, 255, 0.62) 0 4%, transparent 5%),
        radial-gradient(ellipse at 55% 42%, rgba(91, 168, 211, 0.62) 0 37%, transparent 38%),
        radial-gradient(ellipse at 47% 78%, rgba(91, 168, 211, 0.68) 0 39%, transparent 40%),
        linear-gradient(180deg, #9ed9f4 0%, #8fd0ee 48%, #86c4e8 100%);
    animation: shake 0.4s infinite;
}

.bot-critical .brow.left {
    opacity: 0;
}

.bot-critical .brow.right {
    opacity: 0;
}

.bot-critical .eye {
    top: 27px;
    width: 36px;
    height: 36px;
    border: 2px solid rgba(79, 166, 211, 0.45);
    border-radius: 50%;
    background:
        radial-gradient(circle at 30% 24%, rgba(255, 255, 255, 0.92) 0 14%, transparent 15%),
        linear-gradient(180deg, rgba(242, 251, 255, 0.92) 0%, rgba(195, 225, 248, 0.82) 100%);
    box-shadow:
        inset 0 5px 8px rgba(255, 255, 255, 0.62),
        inset 0 -5px 9px rgba(71, 139, 205, 0.2);
}

.bot-critical .eye.left {
    left: 25px;
}

.bot-critical .eye.right {
    right: 25px;
}

.bot-critical .eye::before {
    inset: auto;
    top: 11px;
    left: 11px;
    width: 15px;
    height: 15px;
    border: 0;
    border-radius: 50%;
    background:
        radial-gradient(circle at 38% 33%, rgba(238, 251, 255, 0.96) 0 24%, transparent 26%),
        #6aa8df;
    box-shadow: inset 0 -2px 3px rgba(38, 105, 174, 0.26);
}

.bot-critical .eye.left::before {
    transform: rotate(-8deg);
}

.bot-critical .eye.right::before {
    transform: rotate(8deg);
}

.bot-critical .eye::after {
    content: "";
    position: absolute;
    right: 7px;
    bottom: 5px;
    width: 6px;
    height: 4px;
    border-radius: 50%;
    background: rgba(47, 120, 183, 0.45);
}

.bot-critical .mouth.flat,
.bot-critical .mouth.sad {
    opacity: 0;
}

.bot-sad {
    background:
        radial-gradient(ellipse at 30% 16%, rgba(255, 255, 255, 0.95) 0 15%, transparent 16%),
        radial-gradient(ellipse at 12% 36%, rgba(255, 255, 255, 0.9) 0 5%, transparent 6%),
        radial-gradient(ellipse at 72% 34%, rgba(255, 255, 255, 0.62) 0 4%, transparent 5%),
        radial-gradient(ellipse at 55% 42%, rgba(91, 168, 211, 0.62) 0 37%, transparent 38%),
        radial-gradient(ellipse at 47% 78%, rgba(91, 168, 211, 0.68) 0 39%, transparent 40%),
        linear-gradient(180deg, #9ed9f4 0%, #8fd0ee 48%, #86c4e8 100%);
}

.bot-sad .eye {
    top: 42px;
    width: 36px;
    height: 17px;
}

.bot-sad .eye.left {
    left: 25px;
}

.bot-sad .eye.right {
    right: 25px;
}

.bot-sad .eye.left::before {
    transform: rotate(-9deg);
}

.bot-sad .eye.right::before {
    transform: rotate(9deg);
}

.bot-sad .eye::after {
    display: none;
}

.bot-sad .eye.left::after {
    transform: rotate(-5deg);
}

.bot-sad .eye.right::after {
    transform: rotate(5deg);
}

.bot-sad .brow {
    opacity: 0;
}

.bot-sad .cheek {
    top: 56px;
    opacity: 0.42;
}

.bot-sad .mouth.sad {
    bottom: 15px;
    width: 14px;
    height: 11px;
    opacity: 1;
    transform: translateX(-50%) rotate(12deg);
}

.bot-thinking {
    background:
        radial-gradient(ellipse at 30% 16%, rgba(255, 255, 255, 0.95) 0 15%, transparent 16%),
        radial-gradient(ellipse at 12% 36%, rgba(255, 255, 255, 0.9) 0 5%, transparent 6%),
        radial-gradient(ellipse at 72% 34%, rgba(255, 255, 255, 0.62) 0 4%, transparent 5%),
        radial-gradient(ellipse at 55% 42%, rgba(91, 168, 211, 0.62) 0 37%, transparent 38%),
        radial-gradient(ellipse at 47% 78%, rgba(91, 168, 211, 0.68) 0 39%, transparent 40%),
        linear-gradient(180deg, #9ed9f4 0%, #8fd0ee 48%, #86c4e8 100%);
}

.bot-thinking .eye {
    top: 42px;
    width: 40px;
    height: 18px;
    border-radius: 8px;
}

.bot-thinking .eye.left {
    left: 19px;
}

.bot-thinking .eye.right {
    right: 19px;
}

.bot-thinking .eye.left::before {
    transform: rotate(6deg);
}

.bot-thinking .eye.right::before {
    transform: rotate(-6deg);
}

.bot-thinking .brow.left {
    left: 60px;
    transform: rotate(37deg) translateY(1px);
}

.bot-thinking .brow.right {
    right: 56px;
    transform: rotate(-37deg) translateY(1px);
}

.bot-talking .mouth {
    animation: talk 0.42s ease-in-out infinite;
    opacity: 0.45;
}

.bot-listening .eye {
    top: 39px;
    width: 38px;
    height: 20px;
}

.bot-listening .eye.left {
    left: 21px;
}

.bot-listening .eye.right {
    right: 21px;
}

.bot-listening .eye.left::before {
    transform: rotate(-15deg);
}

.bot-listening .eye.right::before {
    transform: rotate(15deg);
}

.bot-listening .brow {
    top: 38px;
    width: 17px;
    opacity: 0;
}

.bot-listening .brow.left {
    left: 47px;
    transform: rotate(11deg);
}

.bot-listening .brow.right {
    right: 47px;
    transform: rotate(-11deg);
}

.bot-listening .cheek {
    opacity: 0.84;
}

.bot-listening .cheek::before {
    opacity: 1;
}

.bot-listening .mouth.smile {
    opacity: 0;
}

.bot-bubble {
    position: absolute;
    right: 94px;
    bottom: 58px;
    min-width: 150px;
    max-width: 240px;
    padding: 12px 14px;
    border: 1px solid var(--line);
    border-radius: 14px 14px 6px 14px;
    background: var(--bubble-bg);
    color: var(--bubble-text);
    font-size: 13px;
    line-height: 1.5;
    white-space: normal;
    overflow-wrap: break-word;
    box-shadow: var(--shadow);
    animation: popIn 0.25s ease;
}

.bot-bubble::after {
    content: "";
    position: absolute;
    right: -8px;
    bottom: 10px;
    border-top: 8px solid transparent;
    border-bottom: 8px solid transparent;
    border-left: 10px solid var(--bubble-bg);
}

.bot-chat {
    position: fixed;
    right: 20px;
    bottom: 130px;
    z-index: 1300;
    width: min(340px, calc(100vw - 28px));
    height: min(480px, calc(100vh - 170px));
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: var(--glass-bg-strong);
    box-shadow: var(--shadow);
}

.bot-chat.hidden {
    display: none;
}

.chat-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
    border-bottom: 1px solid var(--line);
    background: var(--table-head-bg);
}

.chat-header .title {
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: 13px;
    font-weight: 800;
}

.chat-header #botStatus {
    color: var(--muted);
    font-size: 10px;
    font-weight: 600;
}

.close-btn {
    min-width: 32px;
    padding: 0;
    background: transparent;
    color: var(--muted);
}

.chat-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 12px;
    overflow-y: auto;
}

.chat-msg {
    max-width: 78%;
    padding: 10px 12px;
    border-radius: 8px;
    font-size: 13px;
    line-height: 1.45;
}

.chat-msg.bot {
    align-self: flex-start;
    border: 1px solid rgba(var(--accent-rgb), 0.25);
    background: rgba(var(--accent-rgb), 0.12);
}

.chat-msg.user {
    align-self: flex-end;
    background: var(--accent);
    color: var(--accent-ink);
    font-weight: 700;
}

.chat-msg small {
    display: block;
    margin-bottom: 4px;
    color: inherit;
    font-size: 10px;
    opacity: 0.65;
}

.quick-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 10px;
}

.quick-actions button {
    min-height: 30px;
    padding: 6px 10px;
    font-size: 11px;
}

.chat-input-area {
    display: flex;
    gap: 8px;
    padding: 10px;
    border-top: 1px solid var(--line);
}

.chat-input-area input {
    flex: 1;
}

.chat-input-area button {
    width: auto;
}

.chat-body::-webkit-scrollbar,
.multi-filter-dropdown::-webkit-scrollbar,
.table-scroll::-webkit-scrollbar {
    height: 8px;
    width: 8px;
}

.chat-body::-webkit-scrollbar-thumb,
.multi-filter-dropdown::-webkit-scrollbar-thumb,
.table-scroll::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: rgba(var(--text-rgb), 0.2);
}

@keyframes floatBot {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-4px);
    }
}

@keyframes slimeWobble {
    0%, 100% {
        border-radius: 49% 51% 43% 42% / 56% 54% 37% 36%;
    }
    35% {
        border-radius: 51% 49% 44% 41% / 54% 56% 36% 38%;
    }
    70% {
        border-radius: 48% 52% 42% 44% / 57% 52% 38% 35%;
    }
}

@keyframes botPanicDrop {
    0%, 100% {
        transform: translateY(2px) scale(0.82) rotate(16deg);
    }
    35% {
        transform: translateY(-2px) scale(0.96) rotate(23deg);
    }
    58% {
        transform: translateY(0) scale(0.9) rotate(12deg);
    }
}

@keyframes blink {
    0%, 90%, 100% {
        height: 13px;
    }
    95% {
        height: 1px;
    }
}

@keyframes talk {
    0%, 100% {
        transform: translateX(-50%) scaleX(1);
    }
    50% {
        transform: translateX(-50%) scaleX(1.4);
    }
}

@keyframes popIn {
    from {
        opacity: 0;
        transform: scale(0.92);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes shake {
    0%, 100% {
        transform: translateX(0);
    }
    25% {
        transform: translateX(-2px);
    }
    75% {
        transform: translateX(2px);
    }
}

@keyframes tear {
    0% {
        opacity: 0;
        transform: translateY(0);
    }
    50% {
        opacity: 1;
    }
    100% {
        opacity: 0;
        transform: translateY(6px);
    }
}

@keyframes idleFloat {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-6px);
    }
}

#breaksTable tr.good td {
    background: rgba(var(--success-rgb), 0.12);
}

#breaksTable tr.warning td {
    background: rgba(var(--warning-rgb), 0.12);
}

#breaksTable tr.danger td {
    background: rgba(var(--danger-rgb), 0.12);
}

.table-pager {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    padding: 10px 2px 0;
    color: var(--muted);
    font-size: 12px;
}

.table-pager button {
    min-height: 32px;
    padding: 6px 10px;
}

@media (max-width: 920px) {
    .navbar,
    .nav-left {
        align-items: flex-start;
        flex-direction: column;
    }

    .nav-right {
        width: 100%;
        justify-content: space-between;
    }

    .control-group.filters {
        grid-column: 1 / -1;
    }

    .actions-wide {
        grid-column: 1 / -1;
    }
}

@media (max-width: 680px) {
    .controls,
    .cards,
    .page-hero,
    .about-layout,
    .howto-layout,
    .section,
    .container {
        margin-right: 12px;
        margin-left: 12px;
    }

    .page-hero,
    .section-header {
        align-items: stretch;
        flex-direction: column;
    }

    .container .page-hero {
        margin-right: 0;
        margin-left: 0;
    }

    .page-hero h2 {
        font-size: 22px;
    }

    .about-layout {
        grid-template-columns: 1fr;
        margin-bottom: 92px;
    }

    .howto-layout {
        grid-template-columns: 1fr;
        margin-bottom: 92px;
    }

    .about-intro,
    .howto-wide {
        grid-column: auto;
    }

    .about-mark {
        align-self: center;
    }

    .controls,
    .cards {
        grid-template-columns: 1fr;
    }

    .mtd-report-tabs {
        width: calc(100% - 24px);
        margin-right: 12px;
        margin-left: 12px;
    }

    .mtd-report-search {
        grid-template-columns: 1fr;
    }

    .mtd-matrix-toolbar,
    .mtd-matrix-toggle {
        width: 100%;
    }

    .mtd-matrix-toggle button {
        flex: 1 1 110px;
    }

    .inline,
    .filter-buttons {
        align-items: stretch;
        flex-direction: column;
    }

    #breaksPage .coverage-subnav {
        margin: 0 12px 14px;
        padding: 8px;
    }

    #breaksPage .coverage-subnav,
    #breaksPage .section-header .break-view-toggle {
        width: 100%;
    }

    #breaksPage .coverage-subnav button,
    #breaksPage .section-header .break-view-toggle button {
        flex: 1 1 120px;
        width: 100%;
    }

    .footer-content {
        grid-template-columns: 1fr;
        gap: 4px;
    }

    #assistantBot {
        right: 12px;
        bottom: 86px;
    }

    .bot-chat {
        right: 12px;
        bottom: 154px;
    }
}

@media (max-width: 760px) {
    body {
        background-size: 34px 34px, 34px 34px, auto;
    }

    html[data-theme="dark"] body {
        background-size: auto;
    }

    .navbar {
        gap: 10px;
        padding: 10px 12px;
    }

    .nav-left,
    .nav-menu,
    .nav-right {
        width: 100%;
        min-width: 0;
    }

    .nav-left {
        gap: 10px;
    }

    .nav-logo {
        width: 100%;
        font-size: 15px;
    }

    .nav-logo img {
        width: 26px;
        height: 26px;
    }

    .nav-menu {
        flex-wrap: nowrap;
        gap: 6px;
        padding-bottom: 4px;
        overflow-x: auto;
        overscroll-behavior-x: contain;
        scrollbar-width: thin;
    }

    .nav-link {
        flex: 0 0 auto;
        min-height: 34px;
        padding: 7px 10px;
        white-space: nowrap;
    }

    .nav-right {
        display: grid;
        grid-template-columns: minmax(92px, 1fr) minmax(84px, 1fr);
        gap: 8px;
    }

    .timezone-select,
    .theme-toggle,
    .user-menu,
    #logoutBtn {
        width: 100%;
        min-width: 0;
    }

    .profile-button {
        width: 100%;
        max-width: none;
        justify-content: space-between;
    }

    .admin-notification-button {
        width: 100%;
        justify-content: space-between;
    }

    .admin-notification-panel,
    .admin-notification-item {
        grid-template-columns: 1fr;
    }

    .admin-notification-stat-grid,
    .admin-notification-stats {
        grid-template-columns: 1fr;
    }

    .admin-notification-actions {
        justify-content: stretch;
    }

    .admin-notification-actions button {
        flex: 1 1 120px;
    }

    .user-menu-dropdown {
        right: auto;
        left: 0;
        width: min(260px, calc(100vw - 24px));
    }

    .page {
        padding-bottom: 112px;
    }

    .page-hero {
        padding: 16px;
    }

    .page-hero p {
        font-size: 13px;
    }

    .controls {
        gap: 10px;
        padding: 12px;
    }

    .control-group.filters {
        grid-column: 1 / -1;
    }

    .button-row,
    .upload-buttons {
        align-items: stretch;
        flex-direction: column;
    }

    .button-row button,
    .upload-buttons button,
    .section-header-actions button,
    .forecast-insight-actions button {
        width: 100%;
    }

    .cards .card {
        min-height: 92px;
    }

    .card {
        padding: 14px;
    }

    .card p {
        font-size: 22px;
        line-height: 1.2;
        overflow-wrap: anywhere;
    }

    .critical-queue-container {
        grid-template-columns: 1fr;
        grid-auto-rows: auto;
    }

    .critical-queue-card {
        min-height: 0;
    }

    .resource-filter-panel,
    .roster-filter-panel {
        grid-template-columns: 1fr;
    }

    .queue-card {
        width: 100%;
        min-width: 0;
    }

    .table-wrapper {
        border-radius: 8px;
    }

    .table-scroll {
        -webkit-overflow-scrolling: touch;
    }

    th,
    td {
        padding: 9px 10px;
        font-size: 12px;
    }

    th {
        font-size: 10px;
    }

    .modal {
        align-items: flex-end;
        padding: 10px;
    }

    .modal-content,
    .queue-detail-modal,
    .queue-influx-modal,
    .queue-capacity-modal,
    .forecast-interval-modal,
    .break-optimization-modal,
    .backup-modal,
    .db-columns-modal,
    .upload-alias-modal,
    .user-modal,
    .profile-modal {
        width: 100%;
        max-height: calc(100vh - 20px);
        padding: 16px;
        border-radius: 8px;
    }

    .modal-header {
        align-items: flex-start;
        gap: 10px;
    }

    .modal-actions {
        align-items: stretch;
        flex-direction: column-reverse;
    }

    .modal-actions button {
        width: 100%;
    }

    .profile-summary {
        align-items: stretch;
        flex-direction: column;
    }

    .break-optimization-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .break-optimization-toolbar .form-group,
    .break-optimization-required-hc {
        min-width: 0;
        max-width: none;
    }

    .break-optimization-toolbar-actions {
        display: grid;
        grid-template-columns: 1fr;
    }
}

@media (max-width: 1100px) {
    #dashboardPage .navbar {
        align-items: stretch;
        flex-direction: column;
        gap: 10px;
    }

    #dashboardPage .nav-left {
        position: relative;
        flex-flow: row wrap;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        gap: 10px;
    }

    #dashboardPage .nav-logo {
        flex: 1 1 auto;
        width: auto;
        min-width: 0;
    }

    #dashboardPage .nav-logo span {
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    #dashboardPage .nav-menu-toggle {
        display: inline-flex;
        flex: 0 0 auto;
    }

    #dashboardPage .nav-menu {
        order: 3;
        display: none;
        grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
        width: 100%;
        max-height: min(420px, 68vh);
        margin-top: 2px;
        padding: 8px;
        overflow: auto;
        border: 1px solid var(--line);
        border-radius: 8px;
        background: var(--glass-bg-strong);
        box-shadow: var(--shadow-soft);
        backdrop-filter: blur(16px);
        overscroll-behavior: contain;
        scrollbar-width: thin;
    }

    #dashboardPage .navbar.nav-menu-open .nav-menu {
        display: grid;
    }

    #dashboardPage .nav-link {
        justify-content: flex-start;
        width: 100%;
        min-height: 38px;
        padding: 9px 10px;
        white-space: nowrap;
    }

    #dashboardPage .nav-right {
        width: 100%;
        justify-content: space-between;
    }
}

@media (max-width: 760px) {
    .command-sticky-strip {
        top: 8px;
    }

    .now-next-later-board,
    .top-action-item {
        grid-template-columns: 1fr;
    }

    .decision-action-card {
        grid-template-columns: 1fr;
    }

    .decision-action-side {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        align-items: center;
    }

    .queue-360-summary {
        flex-direction: column;
    }
}

@media (max-width: 520px) {
    .center-wrapper {
        align-items: stretch;
        padding: 12px;
    }

    .auth-card {
        align-self: center;
        padding: 22px 16px;
    }

    .brand h1 {
        font-size: 21px;
    }

    .navbar {
        position: sticky;
    }

    .nav-right {
        grid-template-columns: 1fr 1fr;
    }

    .theme-toggle,
    #logoutBtn,
    .timezone-select,
    .profile-button {
        min-height: 34px;
        padding: 6px 8px;
        font-size: 12px;
    }

    .controls,
    .cards,
    .page-hero,
    .about-layout,
    .howto-layout,
    .section,
    .container {
        margin-right: 8px;
        margin-left: 8px;
    }

    .mtd-report-tabs {
        width: calc(100% - 16px);
        margin-right: 8px;
        margin-left: 8px;
    }

    .page-hero {
        margin-top: 12px;
        padding: 14px;
    }

    .page-hero h2 {
        font-size: 21px;
    }

    .section-header h3 {
        font-size: 15px;
    }

    .controls {
        margin-top: 12px;
    }

    .inline,
    .filter-buttons,
    .compact-controls,
    .section-header-actions {
        align-items: stretch;
        flex-direction: column;
        width: 100%;
    }

    .compact-controls button,
    .filter-buttons button {
        width: 100%;
    }

    .multi-filter,
    #breaksPage .breaks-controls .control-group.filters .multi-filter {
        flex: 1 1 auto;
        min-width: 0;
        width: 100%;
    }

    .multi-filter-dropdown {
        left: 8px !important;
        width: calc(100vw - 16px) !important;
        max-height: min(420px, 72vh);
    }

    #breaksPage #breaksTable th:first-child,
    #breaksPage #breaksTable td:first-child,
    #breaksPage #breakAgentTable th:first-child,
    #breaksPage #breakAgentTable td:first-child {
        min-width: 112px;
    }

    .break-gantt-inner {
        min-width: calc(308px + var(--gantt-track-width));
    }

    .break-gantt-header,
    .break-gantt-row {
        grid-template-columns: 84px 132px 92px var(--gantt-track-width);
    }

    .break-gantt-employee {
        grid-template-columns: 84px 132px 92px var(--gantt-track-width);
    }

    .break-gantt-header > :nth-child(2),
    .break-gantt-employee > :nth-child(2) {
        left: 84px;
    }

    .break-gantt-header > :nth-child(3),
    .break-gantt-employee > :nth-child(3),
    .break-gantt-employee > :nth-child(5) {
        left: 216px;
    }

    .break-gantt-summary-row {
        grid-template-columns: 216px 92px var(--gantt-track-width);
    }

    .break-gantt-summary-row > :nth-child(2),
    .break-gantt-summary-row > :nth-child(4) {
        left: 216px;
    }

    .break-gantt-heading,
    .break-gantt-meta,
    .break-gantt-summary-label,
    .break-gantt-summary-row > .break-gantt-track-label {
        padding: 8px;
        font-size: 10px;
    }

    .break-gantt-name small,
    .break-gantt-employee .break-gantt-track-label small {
        font-size: 9px;
    }

    .break-gantt-bar {
        font-size: 9px;
    }

    .bot-chat {
        right: 8px;
        bottom: 138px;
        width: calc(100vw - 16px);
        height: min(460px, calc(100vh - 162px));
    }

    .bot-bubble {
        right: 96px;
        max-width: calc(100vw - 118px);
    }

    footer {
        font-size: 11px;
    }
}

/* Modern RTA command shell: display-only redesign, calculations remain in existing modules. */
#dashboardPage {
    --bg: #f3f6fb;
    --bg-2: #eef3f8;
    --panel: #ffffff;
    --panel-rgb: 255, 255, 255;
    --panel-soft: #f5f7fb;
    --panel-strong: #e8eef6;
    --text: #111827;
    --text-rgb: 17, 24, 39;
    --muted: #667085;
    --line: #d9e2ee;
    --line-strong: #c5d2e4;
    --accent: #2563eb;
    --accent-rgb: 37, 99, 235;
    --accent-strong: #1d4ed8;
    --accent-hover: #3b82f6;
    --accent-ink: #ffffff;
    --success: #16a34a;
    --success-rgb: 22, 163, 74;
    --warning: #f97316;
    --warning-rgb: 249, 115, 22;
    --danger: #dc2626;
    --danger-rgb: 220, 38, 38;
    --body-bg: #f3f6fb;
    --glass-bg: #ffffff;
    --glass-bg-strong: #ffffff;
    --input-bg: #f8fafc;
    --input-bg-focus: #eef5ff;
    --row-hover: #f2f7ff;
    --row-alt: #fafcff;
    --table-head-bg: #f6f8fb;
    --table-sticky-bg: #ffffff;
    --dropdown-bg: #ffffff;
    --shadow: 0 18px 45px rgba(15, 23, 42, 0.10);
    --shadow-soft: 0 10px 28px rgba(15, 23, 42, 0.08);
    min-height: 100vh;
    background: #f3f6fb;
    color: var(--text);
}

#dashboardPage .navbar {
    --panel: #07111f;
    --panel-rgb: 7, 17, 31;
    --text: #f8fafc;
    --text-rgb: 248, 250, 252;
    --muted: #9fb0c7;
    --line: rgba(148, 163, 184, 0.24);
    --accent: #3b82f6;
    --accent-rgb: 59, 130, 246;
    --glass-bg: #07111f;
    --glass-bg-strong: #07111f;
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 80;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 304px;
    height: 100vh;
    padding: 18px 12px;
    border: 0;
    border-right: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 0;
    background: #07111f;
    box-shadow: 12px 0 34px rgba(15, 23, 42, 0.22);
    overflow-y: auto;
}

#dashboardPage .nav-left,
#dashboardPage .nav-menu,
#dashboardPage .nav-right {
    display: grid;
    width: 100%;
    gap: 12px;
}

#dashboardPage .nav-logo {
    justify-content: flex-start;
    width: 100%;
    padding: 8px 8px 14px;
    border-bottom: 1px solid rgba(148, 163, 184, 0.18);
}

#dashboardPage .nav-logo img {
    width: 28px;
    height: 28px;
}

#dashboardPage .nav-logo span {
    color: #f8fafc;
    font-size: 16px;
    font-weight: 900;
}

#dashboardPage .nav-menu {
    display: grid;
    grid-template-columns: 1fr;
}

#dashboardPage .nav-link {
    display: flex;
    align-items: center;
    min-height: 44px;
    padding: 11px 12px;
    border: 1px solid transparent;
    border-radius: 10px;
    color: #d9e6f7;
    font-size: 14px;
    font-weight: 800;
}

#dashboardPage .nav-link:hover {
    border-color: rgba(96, 165, 250, 0.28);
    background: rgba(59, 130, 246, 0.12);
    color: #ffffff;
}

#dashboardPage .nav-link.active {
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    color: #ffffff;
    box-shadow: 0 12px 26px rgba(37, 99, 235, 0.34);
}

#dashboardPage .sidebar-escalation-card {
    display: grid;
    gap: 8px;
    margin-top: 16px;
    padding: 14px;
    border: 1px solid rgba(148, 163, 184, 0.22);
    border-radius: 12px;
    background: rgba(15, 23, 42, 0.72);
}

#dashboardPage .sidebar-escalation-card strong {
    color: #fb923c;
    font-size: 20px;
}

#dashboardPage .sidebar-escalation-card strong.critical {
    color: #f87171;
}

#dashboardPage .sidebar-escalation-card strong.warning,
#dashboardPage .sidebar-escalation-card strong.watch {
    color: #fb923c;
}

#dashboardPage .sidebar-escalation-card strong.safe {
    color: #4ade80;
}

#dashboardPage .sidebar-escalation-card small {
    color: #cbd5e1;
    line-height: 1.45;
}

#dashboardPage .sidebar-escalation-card button {
    justify-content: flex-start;
    min-height: 32px;
    padding: 6px 0;
    border: 0;
    background: transparent;
    color: #60a5fa;
    box-shadow: none;
}

#dashboardPage .nav-right {
    margin-top: auto;
    padding-top: 14px;
    border-top: 1px solid rgba(148, 163, 184, 0.18);
}

#dashboardPage .timezone-select,
#dashboardPage .admin-notification-button,
#dashboardPage .theme-toggle,
#dashboardPage .nav-right > button {
    width: 100%;
}

#dashboardPage .user-menu {
    width: 100%;
}

#dashboardPage .profile-button {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) auto;
    grid-template-rows: auto auto;
    gap: 2px 10px;
    width: 100%;
    padding: 10px;
    border-color: rgba(148, 163, 184, 0.22);
    background: rgba(15, 23, 42, 0.86);
    color: #f8fafc;
    text-align: left;
}

#dashboardPage .profile-avatar {
    grid-row: 1 / 3;
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: #334155;
    color: #ffffff;
    font-size: 13px;
    font-weight: 900;
}

#dashboardPage .profile-button .username {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#dashboardPage .user-role-label {
    color: #cbd5e1;
    font-size: 12px;
}

#dashboardPage .user-menu-caret {
    grid-column: 3;
    grid-row: 1 / 3;
    align-self: center;
}

#dashboardPage > .sub-page {
    margin-left: 304px;
    padding: 18px 22px 96px;
}

#dashboardPage > .sub-page:not(.active) {
    display: none;
}

#dashboardPage .page-hero {
    margin-bottom: 14px;
    padding: 18px 20px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #ffffff;
    box-shadow: var(--shadow-soft);
}

#dashboardPage .page-hero h2 {
    color: #0f172a;
    font-size: 26px;
}

#dashboardPage .page-hero p {
    max-width: 880px;
    color: #64748b;
}

#dashboardPage .glass,
#dashboardPage .card,
#dashboardPage .section,
#dashboardPage .controls {
    border-color: var(--line);
    background: #ffffff;
    box-shadow: var(--shadow-soft);
    backdrop-filter: none;
}

#dashboardPage .section {
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
}

#dashboardPage .section-header {
    margin-bottom: 8px;
}

#dashboardPage .section-header h3 {
    color: #111827;
    font-size: 17px;
}

#dashboardPage .eyebrow {
    color: #2563eb;
    letter-spacing: 0;
}

#dashboardPage .command-panel,
#dashboardPage .global-filter-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: end;
    margin-bottom: 12px;
    padding: 10px 12px;
    border-radius: 12px;
}

#dashboardPage .control-group {
    min-width: 160px;
}

#dashboardPage .control-group label {
    color: #475569;
    font-size: 11px;
}

#dashboardPage input,
#dashboardPage select,
#dashboardPage textarea {
    border-color: #d7e1ef;
    background: #f8fafc;
    color: #111827;
}

#dashboardPage button {
    border-radius: 8px;
}

#dashboardPage .command-sticky-strip {
    position: sticky;
    top: 0;
    z-index: 30;
    display: grid;
    grid-template-columns: repeat(7, minmax(120px, 1fr));
    gap: 0;
    margin: 0 0 14px;
    padding: 0;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #ffffff;
    box-shadow: 0 16px 34px rgba(15, 23, 42, 0.10);
    overflow: hidden;
}

#dashboardPage .command-sticky-strip span {
    display: grid;
    gap: 4px;
    min-height: 70px;
    padding: 13px 16px;
    border: 0;
    border-right: 1px dashed #cbd5e1;
    border-radius: 0;
    background: #ffffff;
    color: #64748b;
}

#dashboardPage .command-sticky-strip span:last-child {
    border-right: 0;
}

#dashboardPage .command-sticky-strip small {
    color: #475569;
    font-size: 11px;
    font-weight: 900;
}

#dashboardPage .command-sticky-strip strong {
    color: #111827;
    font-size: 16px;
}

#dashboardPage .decision-center-section {
    display: grid;
    grid-template-columns: minmax(420px, 0.9fr) minmax(0, 1.1fr);
    gap: 12px;
}

#dashboardPage .decision-center-section > .section-header {
    grid-column: 1 / -1;
}

#dashboardPage .top-actions-now,
#dashboardPage .decision-action-queue,
#dashboardPage .early-warning-center,
#dashboardPage .escalation-mode-panel,
#dashboardPage .data-quality-alerts,
#dashboardPage .pu-load-balancer,
#dashboardPage .dashboard-change-summary {
    border-radius: 14px;
}

#dashboardPage .top-action-item {
    grid-template-columns: 74px minmax(0, 1fr) auto;
    border-color: #e2e8f0;
    background: #ffffff;
}

#dashboardPage .top-action-rank {
    display: grid;
    gap: 6px;
    justify-items: start;
}

#dashboardPage .top-action-rank > strong {
    color: #0f172a;
    font-size: 13px;
}

#dashboardPage .decision-action-card {
    grid-template-columns: 48px minmax(0, 1fr) minmax(160px, 210px);
    border-color: #e2e8f0;
    background: #ffffff;
}

#dashboardPage .now-next-later-board {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

#dashboardPage .decision-board-card {
    border-radius: 14px;
}

#dashboardPage .decision-board-card:nth-child(1) h3 {
    color: #b91c1c;
}

#dashboardPage .decision-board-card:nth-child(2) h3 {
    color: #ea580c;
}

#dashboardPage .decision-board-card:nth-child(3) h3 {
    color: #1d4ed8;
}

#dashboardPage .cards {
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 10px;
}

#dashboardPage .cards .card {
    min-height: 104px;
    border-radius: 14px;
}

#dashboardPage .cards .card h3 {
    color: #475569;
    font-size: 12px;
}

#dashboardPage .cards .card p {
    color: #111827;
    font-size: 24px;
}

#dashboardPage .command-priority-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

#dashboardPage .early-warning-card,
#dashboardPage .data-quality-card,
#dashboardPage .pu-load-card,
#dashboardPage .queue-driver-card,
#dashboardPage .data-confidence-item {
    border-color: #e2e8f0;
    background: #ffffff;
    border-radius: 12px;
}

#dashboardPage table {
    color: #111827;
    border-collapse: separate;
    border-spacing: 0;
}

#dashboardPage th {
    background: #f8fafc;
    color: #334155;
    font-size: 11px;
    text-transform: none;
}

#dashboardPage td {
    border-bottom: 1px solid #edf2f7;
    color: #111827;
}

#dashboardPage tbody tr:hover td {
    background: #f8fbff;
}

#dashboardPage .table-wrapper {
    border-radius: 14px;
    overflow: hidden;
}

#dashboardPage .severity-badge,
#dashboardPage .confidence-badge,
#dashboardPage .source-status,
#dashboardPage .action-type-badge,
#dashboardPage .decision-source-row > span {
    border-radius: 999px;
    font-size: 11px;
}

#dashboardPage .severity-badge.critical,
#dashboardPage .confidence-badge.missing,
#dashboardPage .source-status.missing {
    border-color: #fecaca;
    background: #fee2e2;
    color: #b91c1c;
}

#dashboardPage .severity-badge.warning,
#dashboardPage .severity-badge.watch,
#dashboardPage .confidence-badge.low,
#dashboardPage .source-status.warn {
    border-color: #fed7aa;
    background: #ffedd5;
    color: #c2410c;
}

#dashboardPage .confidence-badge.high,
#dashboardPage .source-status.loaded {
    border-color: #bbf7d0;
    background: #dcfce7;
    color: #15803d;
}

#dashboardPage .confidence-badge.medium {
    border-color: #fde68a;
    background: #fef3c7;
    color: #a16207;
}

#dashboardPage .queue-360-layout,
#dashboardPage .queue-rca-modal,
#dashboardPage .queue-detail-modal,
#dashboardPage .modal-content {
    color: #111827;
}

#dashboardPage .queue-360-summary,
#dashboardPage .queue-360-section,
#dashboardPage .queue-360-main-driver,
#dashboardPage .queue-360-rca-card {
    border-color: #e2e8f0;
    background: #ffffff;
    border-radius: 14px;
}

#dashboardPage .queue-360-section {
    padding: 12px;
    box-shadow: var(--shadow-soft);
}

#dashboardPage .queue-360-section-chips {
    position: sticky;
    top: 80px;
    z-index: 5;
    padding: 8px;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    background: #ffffff;
}

#dashboardPage #coveragePuHeatmapSection {
    order: -1;
}

#dashboardPage #breaksPage .coverage-command-center {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

#dashboardPage .data-readiness-grid {
    margin-bottom: 12px;
}

.footer {
    margin-left: 304px;
}

@media (max-width: 1180px) {
    #dashboardPage .navbar {
        position: sticky;
        top: 0;
        width: 100%;
        height: auto;
        max-height: none;
        padding: 10px;
        border-right: 0;
        border-bottom: 1px solid rgba(148, 163, 184, 0.2);
    }

    #dashboardPage > .sub-page {
        margin-left: 0;
        padding: 14px;
    }

    #dashboardPage .sidebar-escalation-card {
        display: none;
    }

    #dashboardPage .nav-menu {
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    }

    #dashboardPage .nav-right {
        grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    }

    #dashboardPage .command-sticky-strip,
    #dashboardPage .decision-center-section,
    #dashboardPage .command-priority-grid,
    #dashboardPage .now-next-later-board {
        grid-template-columns: 1fr;
    }

    .footer {
        margin-left: 0;
    }
}

/* Sidebar bottom polish from the dashboard mockup: minimal user card, compact
   logout, and notification count moved onto the user card. */
#dashboardPage .admin-notification-button,
.page .admin-notification-button {
    display: none !important;
}

#dashboardPage .nav-right {
    gap: 8px;
    padding-top: 14px;
}

#dashboardPage .user-menu,
.page .user-menu {
    position: relative;
}

#dashboardPage .user-notification-trigger,
.page .user-notification-trigger {
    position: absolute;
    top: -7px;
    left: 12px;
    z-index: 3;
    display: inline-grid;
    place-items: center;
    width: 22px;
    min-width: 22px;
    height: 22px;
    min-height: 22px;
    padding: 0;
    border: 2px solid #07111f;
    border-radius: 999px;
    background: #f59e0b;
    color: #111827;
    font-size: 10px;
    font-weight: 950;
    line-height: 1;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.28);
}

#dashboardPage .user-notification-trigger.hidden,
.page .user-notification-trigger.hidden {
    display: none !important;
}

#dashboardPage .user-notification-trigger:hover,
.page .user-notification-trigger:hover {
    background: #fbbf24;
    color: #020617;
}

#dashboardPage .profile-button,
.page .profile-button {
    min-height: 62px;
    padding: 9px 10px;
    border-color: rgba(148, 163, 184, 0.22);
    border-radius: 10px;
    background: rgba(15, 23, 42, 0.72);
}

#dashboardPage .profile-button:hover,
.page .profile-button:hover {
    background: rgba(30, 41, 59, 0.9);
}

#dashboardPage .profile-avatar,
.page .profile-avatar {
    width: 36px;
    height: 36px;
    background: linear-gradient(135deg, #1e3a8a, #1e293b);
}

#dashboardPage .profile-button .username,
.page .profile-button .username {
    color: #f8fafc;
    font-size: 12px;
    line-height: 1.25;
}

#dashboardPage .user-role-label,
.page .user-role-label {
    color: #aab7c8;
    font-size: 10px;
    letter-spacing: 0;
}

#dashboardPage .user-menu-caret,
.page .user-menu-caret {
    opacity: 0.84;
}

#dashboardPage .logout-button,
.page .logout-button {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 18px;
    min-height: 38px;
    padding: 8px 11px;
    border-color: rgba(148, 163, 184, 0.16);
    border-radius: 10px;
    background: rgba(15, 23, 42, 0.58);
    color: #fecaca;
}

#dashboardPage .logout-button .control-icon-img,
.page .logout-button .control-icon-img {
    grid-column: 2;
    filter: brightness(0) saturate(100%) invert(84%) sepia(27%) saturate(629%) hue-rotate(306deg) brightness(103%) contrast(99%);
}

#dashboardPage .logout-button span:not(.control-icon),
.page .logout-button span:not(.control-icon) {
    grid-column: 1;
    grid-row: 1;
}

#dashboardPage .logout-button:hover,
.page .logout-button:hover {
    border-color: rgba(248, 113, 113, 0.36);
    background: rgba(127, 29, 29, 0.22);
    color: #fee2e2;
}

#dashboardPage .timezone-control,
#dashboardPage .theme-toggle {
    min-height: 38px;
    border-color: rgba(148, 163, 184, 0.18);
    background: rgba(15, 23, 42, 0.54);
}

/* Final sidebar mockup alignment: minimal bottom user panel. */
#dashboardPage > .navbar {
    width: 286px;
    padding: 10px;
    background:
        radial-gradient(circle at 4% 0, rgba(37, 99, 235, 0.16), transparent 30%),
        linear-gradient(180deg, #07111f 0%, #081424 48%, #07111f 100%) !important;
}

#dashboardPage > .sub-page {
    margin-left: 286px;
}

#dashboardPage .nav-logo {
    min-height: 50px;
    padding: 8px 10px 12px;
}

#dashboardPage .nav-logo img {
    width: 24px;
    height: 24px;
}

#dashboardPage .nav-logo span {
    font-size: 14px;
    letter-spacing: 0;
}

#dashboardPage .nav-menu {
    gap: 8px;
}

#dashboardPage .nav-link {
    min-height: 38px;
    padding: 9px 11px;
    border-radius: 8px;
    color: #dbe7f6;
    font-size: 13px;
    font-weight: 750;
}

#dashboardPage .nav-icon {
    width: 17px;
    height: 17px;
    opacity: 0.92;
}

#dashboardPage .nav-link.active {
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    box-shadow: 0 10px 22px rgba(37, 99, 235, 0.3);
}

#dashboardPage .sidebar-escalation-card {
    margin-top: 20px;
    padding: 14px;
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgba(15, 23, 42, 0.72), rgba(15, 23, 42, 0.52));
}

#dashboardPage .sidebar-escalation-card .eyebrow {
    color: #fbbf24;
    font-size: 10px;
}

#dashboardPage .sidebar-escalation-card strong {
    color: #fb923c;
    font-size: 18px;
}

#dashboardPage .sidebar-escalation-card small {
    color: #c8d3e2;
    font-size: 12px;
}

#dashboardPage .sidebar-escalation-card button {
    min-height: 26px;
    padding: 2px 0;
    color: #60a5fa;
}

#dashboardPage .nav-right {
    gap: 8px;
    margin: 16px -10px -10px;
    padding: 16px 12px 18px;
    border-top: 1px solid rgba(148, 163, 184, 0.22);
    border-radius: 10px 10px 0 0;
    background:
        radial-gradient(circle at 14% 14%, rgba(96, 165, 250, 0.14), transparent 36%),
        rgba(8, 20, 36, 0.94);
}

#dashboardPage .nav-right > .timezone-control,
#dashboardPage .nav-right > .theme-toggle {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: 0;
    padding: 0;
    border: 0;
    opacity: 0;
    pointer-events: none;
    overflow: hidden;
}

#dashboardPage .user-menu {
    width: 100%;
}

#dashboardPage .profile-button {
    min-height: 54px;
    padding: 8px 10px;
    border: 0;
    border-radius: 8px;
    background: transparent;
}

#dashboardPage .profile-button:hover {
    background: rgba(96, 165, 250, 0.1);
}

#dashboardPage .profile-avatar {
    width: 36px;
    height: 36px;
    border: 0;
    background: linear-gradient(135deg, #64748b, #334155);
}

#dashboardPage .profile-avatar img {
    filter: brightness(0) invert(1);
}

#dashboardPage .profile-button .username {
    font-size: 12px;
    line-height: 1.2;
}

#dashboardPage .user-role-label {
    color: #cbd5e1;
    font-size: 11px;
    text-transform: none;
}

#dashboardPage .user-notification-trigger {
    top: 3px;
    left: 32px;
    width: 20px;
    min-width: 20px;
    height: 20px;
    min-height: 20px;
    border-color: #081424;
}

#dashboardPage .sidebar-last-login {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 26px;
    padding: 2px 10px 0;
    color: #b8c5d7;
    font-size: 11px;
}

#dashboardPage .logout-button {
    grid-template-columns: minmax(0, 1fr) 18px;
    min-height: 28px;
    padding: 4px 10px;
    border: 0;
    background: transparent;
    color: #cbd5e1;
}

#dashboardPage .logout-button span {
    font-size: 0;
}

#dashboardPage .logout-button span::before {
    content: "Sign out";
    font-size: 11px;
}

#dashboardPage .logout-button .control-icon-img {
    justify-self: end;
    opacity: 0.92;
    filter: brightness(0) saturate(100%) invert(82%) sepia(13%) saturate(425%) hue-rotate(175deg) brightness(93%) contrast(91%);
}

#dashboardPage .logout-button:hover {
    background: rgba(96, 165, 250, 0.1);
    color: #ffffff;
}

@media (max-width: 1180px) {
    #dashboardPage > .navbar {
        width: 100%;
    }

    #dashboardPage > .sub-page {
        margin-left: 0;
    }

    #dashboardPage .nav-right {
        margin: 0;
        border-radius: 10px;
    }
}

/* Cross-page visual unification: login, dashboard, and admin use one WFM shell. */
:root,
html[data-theme="dark"],
html[data-theme="light"] {
    --bg: #f5f7fb;
    --bg-2: #eef3f9;
    --panel: #ffffff;
    --panel-rgb: 255, 255, 255;
    --panel-soft: #f8fafc;
    --panel-strong: #e7edf6;
    --surface: #101828;
    --text: #101828;
    --text-rgb: 16, 24, 40;
    --muted: #667085;
    --line: #dce5f1;
    --line-strong: #cbd7e7;
    --accent: #2563eb;
    --accent-rgb: 37, 99, 235;
    --accent-strong: #1d4ed8;
    --accent-hover: #3b82f6;
    --accent-ink: #ffffff;
    --success: #15803d;
    --success-rgb: 21, 128, 61;
    --warning: #c2410c;
    --warning-rgb: 194, 65, 12;
    --danger: #b91c1c;
    --danger-rgb: 185, 28, 28;
    --signal: #2563eb;
    --body-bg: #f5f7fb;
    --glass-bg: #ffffff;
    --glass-bg-strong: #ffffff;
    --input-bg: #f8fafc;
    --input-bg-focus: #eef5ff;
    --row-hover: #eef5ff;
    --row-alt: #fbfdff;
    --table-head-bg: #f8fafc;
    --table-sticky-bg: #ffffff;
    --dropdown-bg: #ffffff;
    --footer-bg: rgba(245, 247, 251, 0.94);
    --shadow: 0 20px 55px rgba(15, 23, 42, 0.10);
    --shadow-soft: 0 10px 26px rgba(15, 23, 42, 0.08);
    --focus-ring: rgba(37, 99, 235, 0.18);
}

body {
    background:
        radial-gradient(circle at 0 0, rgba(37, 99, 235, 0.09), transparent 26%),
        var(--body-bg);
    color: var(--text);
}

.glass,
.card,
.section,
.controls,
.modal-content,
.auth-card,
.admin-notification-panel,
.admin-notification-stat,
.profile-summary {
    border-color: var(--line);
    border-radius: 12px;
    background: var(--panel);
    color: var(--text);
    box-shadow: var(--shadow-soft);
}

input,
select,
textarea {
    border-color: var(--line);
    border-radius: 8px;
    background: var(--input-bg);
    color: var(--text);
}

input:focus,
select:focus,
textarea:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--focus-ring);
}

button,
.table-link {
    border-radius: 8px;
}

button:not(.danger-btn),
.table-link {
    border-color: rgba(37, 99, 235, 0.26);
    background: rgba(37, 99, 235, 0.1);
    color: var(--accent-strong);
}

button:not(.danger-btn):hover,
.table-link:hover {
    border-color: rgba(37, 99, 235, 0.42);
    background: rgba(37, 99, 235, 0.16);
}

.center-wrapper {
    min-height: 100vh;
    background:
        radial-gradient(circle at 12% 0, rgba(59, 130, 246, 0.24), transparent 32%),
        linear-gradient(180deg, #07111f, #081424 54%, #07111f);
}

.auth-card {
    max-width: 430px;
    border: 1px solid rgba(148, 163, 184, 0.24);
    border-radius: 12px;
    background: rgba(15, 23, 42, 0.78);
    color: #f8fbff;
    box-shadow: 0 24px 70px rgba(2, 6, 23, 0.42);
}

.auth-card .brand h1,
.auth-card .login-section,
.auth-card .remember-row,
.auth-card .auth-switch {
    color: #f8fbff;
}

.auth-card .brand p,
.auth-card .auth-switch span {
    color: #aab7c8;
}

.auth-card input {
    border-color: rgba(148, 163, 184, 0.28);
    background: rgba(15, 23, 42, 0.74);
    color: #f8fbff;
}

.auth-card input::placeholder {
    color: #94a3b8;
}

.auth-card .theme-toggle,
.auth-card .secondary {
    border-color: rgba(148, 163, 184, 0.24);
    background: rgba(15, 23, 42, 0.62);
    color: #dbeafe;
}

.auth-card #loginBtn:not(:disabled) {
    border-color: rgba(96, 165, 250, 0.52);
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    color: #ffffff;
}

.auth-card #loginBtn:disabled {
    opacity: 0.56;
}

#adminPage {
    min-height: 100vh;
    background: #f5f7fb;
}

#adminPage > .navbar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 80;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 286px;
    height: 100vh;
    padding: 10px;
    border: 0;
    border-right: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 0;
    background:
        radial-gradient(circle at 4% 0, rgba(37, 99, 235, 0.16), transparent 30%),
        linear-gradient(180deg, #07111f 0%, #081424 48%, #07111f 100%) !important;
    box-shadow: 12px 0 34px rgba(15, 23, 42, 0.22);
}

#adminPage > .container {
    margin: 0 20px 22px 306px;
    padding-top: 16px;
}

#adminPage .nav-logo {
    justify-content: flex-start;
    width: 100%;
    min-height: 50px;
    padding: 8px 10px 12px;
    border-bottom: 1px solid rgba(148, 163, 184, 0.18);
}

#adminPage .nav-logo span {
    color: #f8fbff;
    font-size: 14px;
    font-weight: 900;
}

#adminPage .nav-logo img {
    width: 24px;
    height: 24px;
}

#adminPage .nav-right {
    display: grid;
    width: 100%;
    gap: 8px;
    margin: 16px -10px -10px;
    padding: 16px 12px 18px;
    border-top: 1px solid rgba(148, 163, 184, 0.22);
    border-radius: 10px 10px 0 0;
    background:
        radial-gradient(circle at 14% 14%, rgba(96, 165, 250, 0.14), transparent 36%),
        rgba(8, 20, 36, 0.94);
}

#adminPage .theme-toggle {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
    overflow: hidden;
}

#adminPage .profile-button,
#adminPage .logout-button,
#adminPage .nav-right > [data-action="show-page"] {
    border: 0;
    background: transparent;
}

#adminPage .nav-right > [data-action="show-page"] {
    min-height: 30px;
    justify-content: flex-start;
    color: #93c5fd;
}

#adminPage .profile-button {
    min-height: 54px;
    padding: 8px 10px;
}

#adminPage .sidebar-last-login {
    padding: 2px 10px 0;
    color: #b8c5d7;
    font-size: 11px;
}

#adminPage .logout-button {
    min-height: 28px;
    padding: 4px 10px;
    color: #cbd5e1;
}

#adminPage .page-hero,
#adminPage .section,
#adminPage .admin-notification-panel,
#adminPage .admin-notification-stat {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #ffffff;
    color: var(--text);
    box-shadow: var(--shadow-soft);
}

@media (max-width: 1180px) {
    #adminPage > .navbar {
        position: sticky;
        width: 100%;
        height: auto;
    }

    #adminPage > .container {
        margin: 12px;
        padding-top: 0;
    }

    #adminPage .nav-right {
        margin: 0;
        border-radius: 10px;
    }
}

/* Real SVG icon rendering. These image icons are used because CSS masks were
   being overridden in parts of the dashboard shell. Bot styles are untouched. */
#dashboardPage .nav-icon,
#dashboardPage .strip-icon,
#dashboardPage .control-icon-img,
#dashboardPage .menu-icon-img,
.page .control-icon-img,
.page .menu-icon-img {
    display: inline-block;
    flex: 0 0 auto;
    width: 18px;
    height: 18px;
    object-fit: contain;
    opacity: 0.9;
}

#dashboardPage .nav-icon,
#dashboardPage .control-icon-img,
#dashboardPage .menu-icon-img,
.page .control-icon-img,
.page .menu-icon-img {
    filter: brightness(0) saturate(100%) invert(86%) sepia(10%) saturate(654%) hue-rotate(181deg) brightness(99%) contrast(92%);
}

#dashboardPage .nav-link.active .nav-icon,
#dashboardPage .nav-link:hover .nav-icon,
#dashboardPage .profile-button:hover .profile-avatar img,
#dashboardPage .user-menu-dropdown button:hover .menu-icon-img,
.page .profile-button:hover .profile-avatar img,
.page .user-menu-dropdown button:hover .menu-icon-img {
    opacity: 1;
    filter: brightness(0) invert(1);
}

#dashboardPage .strip-icon {
    grid-row: 1 / 3;
    align-self: center;
    width: 20px;
    height: 20px;
    padding: 2px;
    border-radius: 6px;
    background: var(--wcc-light-primary-soft, #eaf1ff);
    filter: none;
}

#dashboardPage .command-sticky-strip span:nth-child(1) .strip-icon,
#dashboardPage .command-sticky-strip span:nth-child(3) .strip-icon,
#dashboardPage .command-sticky-strip span:nth-child(4) .strip-icon {
    background: rgba(220, 38, 38, 0.1);
}

#dashboardPage .command-sticky-strip span:nth-child(5) .strip-icon {
    background: rgba(34, 197, 94, 0.11);
}

#dashboardPage .command-sticky-strip span::before,
#dashboardPage .nav-link::before,
#dashboardPage .control-icon,
#dashboardPage .user-menu-dropdown button::before,
.page .control-icon,
.page .user-menu-dropdown button::before {
    display: none !important;
}

#dashboardPage .nav-link {
    justify-content: flex-start;
    gap: 10px;
    text-align: left;
}

#dashboardPage .timezone-control,
#dashboardPage .admin-notification-button,
#dashboardPage .theme-toggle,
#dashboardPage .profile-button,
#dashboardPage .logout-button,
.page .admin-notification-button,
.page .theme-toggle,
.page .profile-button,
.page .logout-button {
    border-radius: 10px;
}

#dashboardPage .profile-avatar img,
.page .profile-avatar img {
    width: 18px;
    height: 18px;
    opacity: 0.95;
    filter: brightness(0) saturate(100%) invert(83%) sepia(36%) saturate(728%) hue-rotate(185deg) brightness(103%) contrast(98%);
}

#dashboardPage .user-menu-dropdown button,
.page .user-menu-dropdown button {
    padding-left: 10px;
}

#dashboardPage .command-sticky-strip span {
    display: grid;
    grid-template-columns: 26px minmax(0, 1fr);
    gap: 3px 8px;
}

#dashboardPage .command-sticky-strip small,
#dashboardPage .command-sticky-strip strong {
    grid-column: 2;
}

#dashboardPage .page-hero,
#dashboardPage .top-actions-now,
#dashboardPage .decision-action-queue,
#dashboardPage .decision-board-card,
#dashboardPage .early-warning-center,
#dashboardPage .escalation-mode-panel,
#dashboardPage .data-quality-alerts,
#dashboardPage .pu-load-balancer,
#dashboardPage .dashboard-change-summary,
#dashboardPage .table-wrapper,
#dashboardPage .controls,
#dashboardPage .card,
#dashboardPage .cards .card {
    border-radius: 12px;
}

#dashboardPage .top-action-item,
#dashboardPage .decision-board-list > div,
#dashboardPage .early-warning-card,
#dashboardPage .data-quality-card,
#dashboardPage .pu-load-card,
#dashboardPage .queue-detail-item,
#dashboardPage .global-filter-chips,
#dashboardPage .global-filter-chip,
#dashboardPage .multi-filter-button,
#dashboardPage .multi-filter-menu,
#dashboardPage .command-quick-uploads summary,
#dashboardPage .command-quick-uploads .quick-upload-grid {
    border-radius: 10px;
}

/* UI design correction layer: this is intentionally last. It resolves late
   hardcoded colors, makes Lucide icons visible, and aligns shell controls. */
#dashboardPage {
    background: var(--wcc-light-bg, #f5f7fb) !important;
    color: var(--wcc-light-text, #101828);
}

#dashboardPage .navbar {
    overflow-x: visible;
    overflow-y: auto;
    background:
        radial-gradient(circle at 8% 2%, rgba(59, 130, 246, 0.24), transparent 34%),
        linear-gradient(180deg, var(--wcc-sidebar-bg, #07111f), var(--wcc-sidebar-bg-2, #0d1a2e)) !important;
}

#dashboardPage .nav-logo span {
    color: var(--wcc-sidebar-text, #f8fbff);
}

#dashboardPage .nav-link {
    gap: 10px;
    color: var(--wcc-sidebar-muted, #c7d2e5);
    opacity: 0.94;
}

#dashboardPage .nav-link::before,
#dashboardPage .control-icon,
#dashboardPage .user-menu-dropdown button::before,
.page .control-icon,
.page .user-menu-dropdown button::before {
    content: "";
    display: inline-block;
    flex: 0 0 18px;
    width: 18px;
    height: 18px;
    border: 0;
    border-radius: 0;
    background: currentColor;
    opacity: 0.96;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: contain;
    mask-size: contain;
}

#dashboardPage .nav-link[data-icon="home"]::before {
    -webkit-mask-image: url("icons/lucide/icons/layout-dashboard.svg");
    mask-image: url("icons/lucide/icons/layout-dashboard.svg");
}

#dashboardPage .nav-link[data-icon="search"]::before {
    -webkit-mask-image: url("icons/lucide/icons/search.svg");
    mask-image: url("icons/lucide/icons/search.svg");
}

#dashboardPage .nav-link[data-icon="activity"]::before {
    -webkit-mask-image: url("icons/lucide/icons/activity.svg");
    mask-image: url("icons/lucide/icons/activity.svg");
}

#dashboardPage .nav-link[data-icon="handoff"]::before {
    -webkit-mask-image: url("icons/lucide/icons/clipboard-list.svg");
    mask-image: url("icons/lucide/icons/clipboard-list.svg");
}

#dashboardPage .nav-link[data-icon="chart"]::before {
    -webkit-mask-image: url("icons/lucide/icons/chart-column.svg");
    mask-image: url("icons/lucide/icons/chart-column.svg");
}

#dashboardPage .nav-link[data-icon="database"]::before {
    -webkit-mask-image: url("icons/lucide/icons/database.svg");
    mask-image: url("icons/lucide/icons/database.svg");
}

#dashboardPage .nav-link[data-icon="help"]::before {
    -webkit-mask-image: url("icons/lucide/icons/life-buoy.svg");
    mask-image: url("icons/lucide/icons/life-buoy.svg");
}

#dashboardPage .nav-link[data-icon="settings"]::before {
    -webkit-mask-image: url("icons/lucide/icons/settings.svg");
    mask-image: url("icons/lucide/icons/settings.svg");
}

#dashboardPage .nav-link:hover {
    color: #ffffff;
    background: rgba(96, 165, 250, 0.14);
}

#dashboardPage .nav-link.active {
    color: #ffffff;
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    box-shadow: 0 10px 24px rgba(37, 99, 235, 0.3);
}

#dashboardPage .nav-right,
.page .nav-right {
    position: relative;
    z-index: 100;
}

#dashboardPage .timezone-control,
#dashboardPage .admin-notification-button,
#dashboardPage .theme-toggle,
#dashboardPage .profile-button,
#dashboardPage .logout-button,
.page .admin-notification-button,
.page .theme-toggle,
.page .profile-button,
.page .logout-button {
    min-height: 38px;
    border: 1px solid rgba(148, 163, 184, 0.24);
    border-radius: 10px;
    background: rgba(15, 23, 42, 0.74);
    color: #eef5ff;
    box-shadow: none;
}

#dashboardPage .timezone-control,
#dashboardPage .admin-notification-button,
#dashboardPage .logout-button,
.page .admin-notification-button,
.page .logout-button {
    display: flex;
    align-items: center;
    gap: 9px;
    width: 100%;
    padding: 8px 10px;
    text-align: left;
}

#dashboardPage .timezone-control:hover,
#dashboardPage .admin-notification-button:hover,
#dashboardPage .theme-toggle:hover,
#dashboardPage .profile-button:hover,
#dashboardPage .logout-button:hover,
.page .admin-notification-button:hover,
.page .theme-toggle:hover,
.page .profile-button:hover,
.page .logout-button:hover {
    border-color: rgba(96, 165, 250, 0.46);
    background: rgba(30, 41, 59, 0.9);
}

#dashboardPage .control-copy,
.page .control-copy {
    display: grid;
    min-width: 0;
    gap: 1px;
    line-height: 1.1;
}

#dashboardPage .control-copy small,
.page .control-copy small {
    color: #9fb0c7;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
}

#dashboardPage .control-copy strong,
.page .control-copy strong {
    color: #f8fbff;
    font-size: 12px;
    font-weight: 900;
}

#dashboardPage .control-icon-timezone {
    color: #93c5fd;
    -webkit-mask-image: url("icons/lucide/icons/globe.svg");
    mask-image: url("icons/lucide/icons/globe.svg");
}

#dashboardPage .control-icon-notification,
.page .control-icon-notification {
    color: #fbbf24;
    -webkit-mask-image: url("icons/lucide/icons/bell-ring.svg");
    mask-image: url("icons/lucide/icons/bell-ring.svg");
}

#dashboardPage .control-icon-logout,
.page .control-icon-logout {
    color: #fca5a5;
    -webkit-mask-image: url("icons/lucide/icons/log-out.svg");
    mask-image: url("icons/lucide/icons/log-out.svg");
}

#dashboardPage .timezone-select {
    width: 100%;
    min-width: 0;
    min-height: 18px;
    padding: 0 20px 0 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: #f8fbff;
    font-size: 12px;
    font-weight: 900;
    box-shadow: none;
}

#dashboardPage .timezone-select:focus {
    outline: none;
    box-shadow: none;
}

#dashboardPage .timezone-select option {
    color: #111827;
}

#dashboardPage .admin-notification-button {
    justify-content: flex-start;
}

#dashboardPage .notification-badge,
.page .notification-badge {
    margin-left: auto;
    border-color: rgba(251, 191, 36, 0.34);
    background: rgba(251, 191, 36, 0.16);
    color: #fde68a;
}

#dashboardPage .theme-toggle,
.page .theme-toggle {
    justify-content: flex-start;
    gap: 9px;
    width: 100%;
    padding: 8px 10px;
}

#dashboardPage .theme-toggle-icon,
.page .theme-toggle-icon {
    width: 18px;
    height: 18px;
    border: 0;
    border-radius: 0;
    background: currentColor !important;
    color: #a5b4fc;
    -webkit-mask: url("icons/lucide/icons/moon-star.svg") center / contain no-repeat;
    mask: url("icons/lucide/icons/moon-star.svg") center / contain no-repeat;
}

html[data-theme="light"] #dashboardPage .theme-toggle-icon,
html[data-theme="light"] .page .theme-toggle-icon {
    color: #f59e0b;
    -webkit-mask-image: url("icons/lucide/icons/sun.svg");
    mask-image: url("icons/lucide/icons/sun.svg");
}

#dashboardPage .profile-button,
.page .profile-button {
    display: grid;
    grid-template-columns: 36px minmax(0, 1fr) 18px;
    grid-template-rows: auto auto;
    gap: 2px 9px;
    width: 100%;
    padding: 8px 10px;
    text-align: left;
}

#dashboardPage .profile-avatar,
.page .profile-avatar {
    position: relative;
    grid-row: 1 / 3;
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border: 1px solid rgba(96, 165, 250, 0.28);
    border-radius: 999px;
    background: rgba(37, 99, 235, 0.18);
    color: transparent;
    font-size: 0;
}

#dashboardPage .profile-avatar::before,
.page .profile-avatar::before {
    content: "";
    width: 18px;
    height: 18px;
    background: #bfdbfe;
    -webkit-mask: url("icons/lucide/icons/user-round.svg") center / contain no-repeat;
    mask: url("icons/lucide/icons/user-round.svg") center / contain no-repeat;
}

#dashboardPage .profile-button .username,
.page .profile-button .username {
    color: #f8fbff;
    font-size: 12px;
    font-weight: 900;
}

#dashboardPage .user-role-label,
.page .user-role-label {
    color: #9fb0c7;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
}

#dashboardPage .user-menu-caret,
.page .user-menu-caret {
    align-self: center;
    width: 16px;
    height: 16px;
    color: #c7d2e5;
    font-size: 0;
    -webkit-mask: url("icons/lucide/icons/chevron-down.svg") center / contain no-repeat;
    mask: url("icons/lucide/icons/chevron-down.svg") center / contain no-repeat;
    background: currentColor;
}

#dashboardPage .user-menu-dropdown,
.page .user-menu-dropdown {
    position: absolute;
    right: 0;
    bottom: calc(100% + 8px);
    top: auto;
    z-index: 5000;
    width: min(260px, calc(100vw - 28px));
    padding: 8px;
    border: 1px solid rgba(148, 163, 184, 0.26);
    border-radius: 12px;
    background: #0f1b2d;
    color: #f8fbff;
    box-shadow: 0 18px 42px rgba(2, 6, 23, 0.42);
}

.page .user-menu-dropdown {
    top: calc(100% + 8px);
    bottom: auto;
}

#dashboardPage .user-menu-dropdown::after,
.page .user-menu-dropdown::after {
    content: "";
    position: absolute;
    right: 18px;
    bottom: -6px;
    width: 10px;
    height: 10px;
    border-right: 1px solid rgba(148, 163, 184, 0.26);
    border-bottom: 1px solid rgba(148, 163, 184, 0.26);
    background: #0f1b2d;
    transform: rotate(45deg);
}

.page .user-menu-dropdown::after {
    top: -6px;
    bottom: auto;
    border: 0;
    border-left: 1px solid rgba(148, 163, 184, 0.26);
    border-top: 1px solid rgba(148, 163, 184, 0.26);
}

#dashboardPage .user-menu-dropdown button,
.page .user-menu-dropdown button {
    display: flex;
    align-items: center;
    gap: 9px;
    min-height: 34px;
    width: 100%;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: #dbeafe;
    box-shadow: none;
}

#dashboardPage .user-menu-dropdown button:hover,
.page .user-menu-dropdown button:hover {
    background: rgba(96, 165, 250, 0.16);
    color: #ffffff;
}

#dashboardPage .user-menu-dropdown button[data-menu-icon="profile"]::before,
.page .user-menu-dropdown button[data-menu-icon="profile"]::before {
    -webkit-mask-image: url("icons/lucide/icons/user-round-cog.svg");
    mask-image: url("icons/lucide/icons/user-round-cog.svg");
}

#dashboardPage .user-menu-dropdown button[data-menu-icon="backup"]::before,
.page .user-menu-dropdown button[data-menu-icon="backup"]::before {
    -webkit-mask-image: url("icons/lucide/icons/database-backup.svg");
    mask-image: url("icons/lucide/icons/database-backup.svg");
}

#dashboardPage .user-menu-dropdown button[data-menu-icon="restore"]::before,
.page .user-menu-dropdown button[data-menu-icon="restore"]::before {
    -webkit-mask-image: url("icons/lucide/icons/archive-restore.svg");
    mask-image: url("icons/lucide/icons/archive-restore.svg");
}

#dashboardPage .logout-button,
.page .logout-button {
    justify-content: flex-start;
    color: #fecaca;
}

#dashboardPage .page-hero,
#dashboardPage .top-actions-now,
#dashboardPage .decision-action-queue,
#dashboardPage .decision-board-card,
#dashboardPage .early-warning-center,
#dashboardPage .escalation-mode-panel,
#dashboardPage .data-quality-alerts,
#dashboardPage .pu-load-balancer,
#dashboardPage .dashboard-change-summary,
#dashboardPage .table-wrapper,
#dashboardPage .controls,
#dashboardPage .card,
#dashboardPage .cards .card {
    border: 1px solid var(--wcc-card-border, #dce5f1);
    border-radius: 12px;
    background: var(--wcc-light-card, #ffffff);
    color: var(--wcc-light-text, #101828);
    box-shadow: var(--wcc-card-shadow, 0 8px 22px rgba(15, 23, 42, 0.07));
}

#dashboardPage .section {
    border: 0;
    background: transparent;
    box-shadow: none;
}

#dashboardPage .top-action-item,
#dashboardPage .decision-board-list > div,
#dashboardPage .early-warning-card,
#dashboardPage .data-quality-card,
#dashboardPage .pu-load-card,
#dashboardPage .queue-detail-item,
#dashboardPage .global-filter-chips,
#dashboardPage .global-filter-chip,
#dashboardPage input,
#dashboardPage select,
#dashboardPage textarea,
#dashboardPage .multi-filter-button,
#dashboardPage .multi-filter-menu,
#dashboardPage .command-quick-uploads summary,
#dashboardPage .command-quick-uploads .quick-upload-grid {
    border-color: var(--wcc-card-border, #dce5f1);
    background: var(--wcc-light-card-soft, #f8fafc);
    color: var(--wcc-light-text, #101828);
}

#dashboardPage .command-sticky-strip,
#dashboardPage .command-sticky-strip span {
    border-color: var(--wcc-card-border, #dce5f1);
    background: var(--wcc-light-card, #ffffff);
}

#dashboardPage .command-sticky-strip span::before {
    border: 0;
    border-radius: 0;
    background: var(--wcc-light-primary, #2563eb);
}

#dashboardPage .command-sticky-strip span:nth-child(1)::before {
    -webkit-mask-image: url("icons/lucide/icons/shield-alert.svg");
    mask-image: url("icons/lucide/icons/shield-alert.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(2)::before {
    -webkit-mask-image: url("icons/lucide/icons/zap.svg");
    mask-image: url("icons/lucide/icons/zap.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(3)::before {
    -webkit-mask-image: url("icons/lucide/icons/triangle-alert.svg");
    mask-image: url("icons/lucide/icons/triangle-alert.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(4)::before {
    -webkit-mask-image: url("icons/lucide/icons/users.svg");
    mask-image: url("icons/lucide/icons/users.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(5)::before {
    -webkit-mask-image: url("icons/lucide/icons/database.svg");
    mask-image: url("icons/lucide/icons/database.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(6)::before {
    -webkit-mask-image: url("icons/lucide/icons/clock.svg");
    mask-image: url("icons/lucide/icons/clock.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(7)::before {
    -webkit-mask-image: url("icons/lucide/icons/sliders-horizontal.svg");
    mask-image: url("icons/lucide/icons/sliders-horizontal.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(1)::before,
#dashboardPage .command-sticky-strip span:nth-child(3)::before,
#dashboardPage .command-sticky-strip span:nth-child(4)::before {
    background-color: var(--wcc-light-danger, #b91c1c);
}

#dashboardPage .command-sticky-strip span:nth-child(5)::before {
    background-color: var(--wcc-light-success, #15803d);
}

#dashboardPage .page-hero h2,
#dashboardPage .section-header h3,
#dashboardPage .card h3,
#dashboardPage .card p,
#dashboardPage .top-action-name,
#dashboardPage .decision-action-main p,
#dashboardPage .decision-action-preview-head span,
#dashboardPage td {
    color: var(--wcc-light-text, #101828);
}

#dashboardPage .page-hero p,
#dashboardPage .card small,
#dashboardPage .top-actions-header,
#dashboardPage .top-action-reason,
#dashboardPage .decision-action-footnote,
#dashboardPage .decision-action-main small,
#dashboardPage th {
    color: var(--wcc-light-muted, #667085);
}

html[data-theme="dark"] #dashboardPage .top-action-item,
html[data-theme="dark"] #dashboardPage .decision-board-list > div,
html[data-theme="dark"] #dashboardPage .early-warning-card,
html[data-theme="dark"] #dashboardPage .data-quality-card,
html[data-theme="dark"] #dashboardPage .pu-load-card,
html[data-theme="dark"] #dashboardPage .queue-detail-item,
html[data-theme="dark"] #dashboardPage .global-filter-chips,
html[data-theme="dark"] #dashboardPage .global-filter-chip,
html[data-theme="dark"] #dashboardPage input,
html[data-theme="dark"] #dashboardPage select,
html[data-theme="dark"] #dashboardPage textarea,
html[data-theme="dark"] #dashboardPage .multi-filter-button,
html[data-theme="dark"] #dashboardPage .multi-filter-menu,
html[data-theme="dark"] #dashboardPage .command-quick-uploads summary,
html[data-theme="dark"] #dashboardPage .command-quick-uploads .quick-upload-grid {
    background: var(--wcc-light-card-soft, #111b2b);
    color: var(--wcc-light-text, #eaf1fb);
}

@media (max-width: 1180px) {
    #dashboardPage .user-menu-dropdown,
    .page .user-menu-dropdown {
        top: calc(100% + 8px);
        bottom: auto;
        right: auto;
        left: 0;
    }

    #dashboardPage .user-menu-dropdown::after,
    .page .user-menu-dropdown::after {
        top: -6px;
        bottom: auto;
        right: auto;
        left: 18px;
        border: 0;
        border-left: 1px solid rgba(148, 163, 184, 0.26);
        border-top: 1px solid rgba(148, 163, 184, 0.26);
    }
}
/* Absolute final consistency lock. Do not place visual overrides after this. */
body {
    background:
        radial-gradient(circle at 0 0, rgba(37, 99, 235, 0.09), transparent 26%),
        #f5f7fb;
    color: #101828;
}

.center-wrapper {
    background:
        radial-gradient(circle at 12% 0, rgba(59, 130, 246, 0.24), transparent 32%),
        linear-gradient(180deg, #07111f, #081424 54%, #07111f);
}

.auth-card {
    border: 1px solid rgba(148, 163, 184, 0.24);
    border-radius: 12px;
    background: rgba(15, 23, 42, 0.78);
    color: #f8fbff;
    box-shadow: 0 24px 70px rgba(2, 6, 23, 0.42);
}

.auth-card .brand h1,
.auth-card .remember-row,
.auth-card .auth-switch {
    color: #f8fbff;
}

.auth-card .brand p,
.auth-card .auth-switch span {
    color: #aab7c8;
}

.auth-card input {
    border-color: rgba(148, 163, 184, 0.28);
    background: rgba(15, 23, 42, 0.74);
    color: #f8fbff;
}

.auth-card input::placeholder {
    color: #94a3b8;
}

.auth-card .theme-toggle,
.auth-card .secondary {
    border-color: rgba(148, 163, 184, 0.24);
    background: rgba(15, 23, 42, 0.62);
    color: #dbeafe;
}

.auth-card #loginBtn:not(:disabled) {
    border-color: rgba(96, 165, 250, 0.52);
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    color: #ffffff;
}

#dashboardPage > .navbar,
#adminPage > .navbar {
    width: 286px;
    padding: 10px;
    background:
        radial-gradient(circle at 4% 0, rgba(37, 99, 235, 0.16), transparent 30%),
        linear-gradient(180deg, #07111f 0%, #081424 48%, #07111f 100%) !important;
}

#dashboardPage > .sub-page {
    margin-left: 286px;
}

#adminPage {
    min-height: 100vh;
    background: #f5f7fb;
}

#adminPage > .navbar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 80;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100vh;
    border: 0;
    border-right: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 0;
    box-shadow: 12px 0 34px rgba(15, 23, 42, 0.22);
}

#adminPage > .container {
    margin: 0 20px 22px 306px;
    padding-top: 16px;
}

#dashboardPage .nav-logo,
#adminPage .nav-logo {
    min-height: 50px;
    padding: 8px 10px 12px;
    border-bottom: 1px solid rgba(148, 163, 184, 0.18);
}

#dashboardPage .nav-logo span,
#adminPage .nav-logo span {
    color: #f8fbff;
    font-size: 14px;
    font-weight: 900;
}

#dashboardPage .nav-menu {
    gap: 8px;
}

#dashboardPage .nav-link {
    min-height: 38px;
    padding: 9px 11px;
    border-radius: 8px;
    color: #dbe7f6;
    font-size: 13px;
    font-weight: 750;
}

#dashboardPage .nav-icon {
    width: 17px;
    height: 17px;
}

#dashboardPage .nav-link.active {
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    box-shadow: 0 10px 22px rgba(37, 99, 235, 0.3);
}

#dashboardPage .nav-right,
#adminPage .nav-right {
    display: grid;
    width: 100%;
    gap: 8px;
    margin: 16px -10px -10px;
    padding: 16px 12px 18px;
    border-top: 1px solid rgba(148, 163, 184, 0.22);
    border-radius: 10px 10px 0 0;
    background:
        radial-gradient(circle at 14% 14%, rgba(96, 165, 250, 0.14), transparent 36%),
        rgba(8, 20, 36, 0.94);
}

#dashboardPage .nav-right > .timezone-control,
#dashboardPage .nav-right > .theme-toggle,
#adminPage .theme-toggle {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: 0;
    padding: 0;
    border: 0;
    opacity: 0;
    pointer-events: none;
    overflow: hidden;
}

#dashboardPage .profile-button,
#adminPage .profile-button {
    min-height: 54px;
    padding: 8px 10px;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: #f8fbff;
}

#dashboardPage .profile-button:hover,
#adminPage .profile-button:hover {
    background: rgba(96, 165, 250, 0.1);
}

#dashboardPage .profile-avatar,
#adminPage .profile-avatar {
    width: 36px;
    height: 36px;
    border: 0;
    background: linear-gradient(135deg, #64748b, #334155);
}

#dashboardPage .profile-avatar::before,
#adminPage .profile-avatar::before,
#dashboardPage .nav-link::before,
#dashboardPage .command-sticky-strip span::before,
#adminPage .user-menu-dropdown button::before,
#dashboardPage .user-menu-dropdown button::before {
    display: none !important;
}

#dashboardPage .profile-avatar img,
#adminPage .profile-avatar img {
    width: 18px;
    height: 18px;
    filter: brightness(0) invert(1);
}

#dashboardPage .profile-button .username,
#adminPage .profile-button .username {
    color: #f8fafc;
    font-size: 12px;
    line-height: 1.2;
}

#dashboardPage .user-role-label,
#adminPage .user-role-label {
    color: #cbd5e1;
    font-size: 11px;
    text-transform: none;
}

#dashboardPage .sidebar-last-login,
#adminPage .sidebar-last-login {
    padding: 2px 10px 0;
    color: #b8c5d7;
    font-size: 11px;
}

#dashboardPage .logout-button,
#adminPage .logout-button {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 18px;
    min-height: 28px;
    padding: 4px 10px;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: #cbd5e1;
}

#dashboardPage .logout-button:hover,
#adminPage .logout-button:hover {
    background: rgba(96, 165, 250, 0.1);
    color: #ffffff;
}

#adminPage .nav-right > [data-action="show-page"] {
    min-height: 30px;
    justify-content: flex-start;
    border: 0;
    background: transparent;
    color: #93c5fd;
}

#dashboardPage .page-hero,
#dashboardPage .top-actions-now,
#dashboardPage .decision-action-queue,
#dashboardPage .decision-board-card,
#dashboardPage .early-warning-center,
#dashboardPage .escalation-mode-panel,
#dashboardPage .data-quality-alerts,
#dashboardPage .pu-load-balancer,
#dashboardPage .dashboard-change-summary,
#dashboardPage .table-wrapper,
#dashboardPage .controls,
#dashboardPage .card,
#adminPage .page-hero,
#adminPage .section,
#adminPage .admin-notification-panel,
#adminPage .admin-notification-stat {
    border: 1px solid #dce5f1;
    border-radius: 12px;
    background: #ffffff;
    color: #101828;
    box-shadow: 0 10px 26px rgba(15, 23, 42, 0.08);
}

#dashboardPage .section {
    border: 0;
    background: transparent;
    box-shadow: none;
}

@media (max-width: 1180px) {
    #dashboardPage > .navbar,
    #adminPage > .navbar {
        position: sticky;
        width: 100%;
        height: auto;
    }

    #dashboardPage > .sub-page,
    #adminPage > .container {
        margin-left: 0;
    }

    #adminPage > .container {
        margin: 12px;
        padding-top: 0;
    }

    #dashboardPage .nav-right,
    #adminPage .nav-right {
        margin: 0;
        border-radius: 10px;
    }
}

/* Final interface consistency pass: keep this block last so light/dark surfaces,
   Lucide masks, and corner radii stay consistent across all views. */
#dashboardPage {
    background: var(--wcc-light-bg) !important;
    color: var(--wcc-light-text);
}

#dashboardPage .navbar {
    background:
        radial-gradient(circle at 10% 4%, rgba(59, 130, 246, 0.2), transparent 30%),
        linear-gradient(180deg, var(--wcc-sidebar-bg), var(--wcc-sidebar-bg-2)) !important;
    color: var(--wcc-sidebar-text);
    border-right: 1px solid rgba(148, 163, 184, 0.2);
    box-shadow: 12px 0 30px rgba(2, 6, 23, 0.18);
}

#dashboardPage .navbar h1,
#dashboardPage .sidebar-footer strong,
#dashboardPage .sidebar-escalation-card strong {
    color: var(--wcc-sidebar-text);
}

#dashboardPage .nav-link {
    color: var(--wcc-sidebar-muted);
    opacity: 0.9;
    border-radius: 10px;
}

#dashboardPage .nav-link::before {
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
    border: 0;
    border-radius: 0;
    background: currentColor;
    opacity: 0.92;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: contain;
    mask-size: contain;
}

#dashboardPage .nav-link:hover {
    color: #ffffff;
    background: rgba(96, 165, 250, 0.13);
}

#dashboardPage .nav-link.active {
    color: #ffffff;
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    box-shadow: 0 10px 24px rgba(37, 99, 235, 0.28);
}

#dashboardPage .page-hero,
#dashboardPage .top-actions-now,
#dashboardPage .decision-action-queue,
#dashboardPage .decision-board-card,
#dashboardPage .early-warning-center,
#dashboardPage .escalation-mode-panel,
#dashboardPage .data-quality-alerts,
#dashboardPage .pu-load-balancer,
#dashboardPage .dashboard-change-summary,
#dashboardPage .queue-360-summary,
#dashboardPage .queue-360-section,
#dashboardPage .queue-360-main-driver,
#dashboardPage .queue-360-rca-card,
#dashboardPage .action-log-form,
#dashboardPage .handoff-preview,
#dashboardPage .howto-panel,
#dashboardPage .about-panel,
#dashboardPage .table-wrapper,
#dashboardPage .controls,
#dashboardPage .card,
#dashboardPage .cards .card,
.modal-card,
.rca-modal-card {
    border: 1px solid var(--wcc-card-border);
    border-radius: 12px;
    background: var(--wcc-light-card);
    color: var(--wcc-light-text);
    box-shadow: var(--wcc-card-shadow);
}

#dashboardPage .section {
    background: transparent;
    border: 0;
    box-shadow: none;
}

#dashboardPage .page-hero {
    padding: 14px 16px;
    background:
        linear-gradient(135deg, var(--wcc-light-primary-soft), transparent 52%),
        var(--wcc-light-card);
}

#dashboardPage .page-hero h2 {
    color: var(--wcc-light-text);
    font-size: 21px;
}

#dashboardPage .page-hero p,
#dashboardPage .section-header p,
#dashboardPage .eyebrow,
#dashboardPage .helper-text,
#dashboardPage .decision-action-footnote,
#dashboardPage .decision-action-preview-head,
#dashboardPage .top-actions-header,
#dashboardPage .top-action-reason,
#dashboardPage .decision-action-main small,
#dashboardPage .decision-board-list small,
#dashboardPage .cards .card h3,
#dashboardPage th {
    color: var(--wcc-light-muted);
}

#dashboardPage .section-header h3,
#dashboardPage .top-action-name,
#dashboardPage .top-action-rank,
#dashboardPage .decision-action-preview-head span,
#dashboardPage .decision-action-head strong,
#dashboardPage .decision-action-main p,
#dashboardPage .decision-board-list strong,
#dashboardPage .cards .card p,
#dashboardPage .queue-detail-item strong,
#dashboardPage td {
    color: var(--wcc-light-text);
}

#dashboardPage .global-filter-chips,
#dashboardPage .command-quick-uploads summary,
#dashboardPage .command-quick-uploads .quick-upload-grid,
#dashboardPage input,
#dashboardPage select,
#dashboardPage textarea,
#dashboardPage .multi-filter-menu,
#dashboardPage .top-action-item,
#dashboardPage .decision-board-list > div,
#dashboardPage .early-warning-card,
#dashboardPage .data-quality-card,
#dashboardPage .pu-load-card,
#dashboardPage .queue-detail-item {
    border: 1px solid var(--wcc-card-border);
    border-radius: 10px;
    background: var(--wcc-light-card-soft);
    color: var(--wcc-light-text);
}

#dashboardPage .command-quick-uploads {
    background: transparent;
    border: 0;
    box-shadow: none;
}

#dashboardPage .command-quick-uploads summary {
    border-radius: 999px;
    color: var(--wcc-light-muted);
}

#dashboardPage input,
#dashboardPage select,
#dashboardPage textarea {
    min-height: 32px;
}

#dashboardPage input:focus,
#dashboardPage select:focus,
#dashboardPage textarea:focus {
    border-color: var(--wcc-light-primary);
    box-shadow: 0 0 0 3px var(--wcc-light-primary-soft);
}

#dashboardPage button,
#dashboardPage .table-link,
#dashboardPage .queue-360-section-chips button {
    border-radius: 8px;
}

#dashboardPage .command-sticky-strip {
    overflow: hidden;
    border: 1px solid var(--wcc-card-border);
    border-radius: 12px;
    background: var(--wcc-light-card);
    box-shadow: var(--wcc-card-shadow);
}

#dashboardPage .command-sticky-strip span {
    border-right: 1px solid var(--wcc-card-border);
    background: transparent;
}

#dashboardPage .command-sticky-strip span:last-child {
    border-right: 0;
}

#dashboardPage .command-sticky-strip span::before {
    width: 18px;
    height: 18px;
    border: 0;
    border-radius: 0;
    background-color: var(--wcc-light-primary);
    opacity: 1;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: contain;
    mask-size: contain;
}

#dashboardPage .command-sticky-strip span:nth-child(1)::before,
#dashboardPage .command-sticky-strip span:nth-child(3)::before,
#dashboardPage .command-sticky-strip span:nth-child(4)::before {
    background-color: var(--wcc-light-danger);
}

#dashboardPage .command-sticky-strip span:nth-child(5)::before {
    background-color: var(--wcc-light-success);
}

#dashboardPage .command-sticky-strip small {
    color: var(--wcc-light-muted);
}

#dashboardPage .command-sticky-strip strong {
    color: var(--wcc-light-text);
}

#dashboardPage .command-sticky-strip span:nth-child(1) strong,
#dashboardPage .command-sticky-strip span:nth-child(4) strong {
    color: var(--wcc-light-danger);
}

#dashboardPage .command-sticky-strip span:nth-child(5) strong {
    border: 1px solid rgba(34, 197, 94, 0.22);
    background: rgba(34, 197, 94, 0.12);
    color: var(--wcc-light-success);
}

#dashboardPage table {
    color: var(--wcc-light-text);
}

#dashboardPage th {
    border-bottom-color: var(--wcc-card-border);
    background: var(--wcc-light-card-soft);
}

#dashboardPage td {
    border-bottom-color: var(--wcc-card-border);
    background: var(--wcc-light-card);
}

#dashboardPage tbody tr:hover td {
    background: var(--wcc-light-primary-soft);
}

#dashboardPage .severity-badge,
#dashboardPage .confidence-badge,
#dashboardPage .source-status,
#dashboardPage .action-type-badge,
#dashboardPage .decision-source-row > span,
#dashboardPage .status-pill {
    border-radius: 999px;
    font-weight: 850;
}

#dashboardPage .severity-badge.critical,
#dashboardPage .confidence-badge.missing,
#dashboardPage .source-status.missing {
    border-color: rgba(220, 38, 38, 0.24);
    background: rgba(220, 38, 38, 0.1);
    color: var(--wcc-light-danger);
}

#dashboardPage .severity-badge.warning,
#dashboardPage .severity-badge.watch,
#dashboardPage .confidence-badge.low,
#dashboardPage .source-status.warn {
    border-color: rgba(245, 158, 11, 0.28);
    background: rgba(245, 158, 11, 0.12);
    color: var(--wcc-light-warning);
}

#dashboardPage .confidence-badge.high,
#dashboardPage .source-status.loaded,
#dashboardPage .severity-badge.safe {
    border-color: rgba(34, 197, 94, 0.24);
    background: rgba(34, 197, 94, 0.11);
    color: var(--wcc-light-success);
}

#dashboardPage .confidence-badge.medium,
#dashboardPage .source-status.partial {
    border-color: rgba(37, 99, 235, 0.24);
    background: var(--wcc-light-primary-soft);
    color: var(--wcc-light-primary);
}

html[data-theme="dark"] #dashboardPage .top-action-item,
html[data-theme="dark"] #dashboardPage .decision-board-list > div,
html[data-theme="dark"] #dashboardPage .early-warning-card,
html[data-theme="dark"] #dashboardPage .data-quality-card,
html[data-theme="dark"] #dashboardPage .pu-load-card,
html[data-theme="dark"] #dashboardPage .queue-detail-item,
html[data-theme="dark"] #dashboardPage .global-filter-chips,
html[data-theme="dark"] #dashboardPage .command-quick-uploads summary,
html[data-theme="dark"] #dashboardPage .command-quick-uploads .quick-upload-grid,
html[data-theme="dark"] #dashboardPage input,
html[data-theme="dark"] #dashboardPage select,
html[data-theme="dark"] #dashboardPage textarea,
html[data-theme="dark"] #dashboardPage .multi-filter-menu {
    background: var(--wcc-light-card-soft);
    color: var(--wcc-light-text);
}

html[data-theme="dark"] #dashboardPage .command-sticky-strip span:nth-child(5) strong {
    border-color: rgba(74, 222, 128, 0.3);
    background: rgba(74, 222, 128, 0.12);
    color: #bbf7d0;
}

/* Cross-view consistency normalization: keeps the redesign cohesive across every module. */
#dashboardPage {
    --wcc-radius-sm: 8px;
    --wcc-radius-md: 10px;
    --wcc-radius-lg: 12px;
    --wcc-radius-xl: 14px;
}

#dashboardPage .page-hero,
#dashboardPage .card,
#dashboardPage .glass,
#dashboardPage .table-wrapper,
#dashboardPage .top-actions-now,
#dashboardPage .decision-action-queue,
#dashboardPage .early-warning-center,
#dashboardPage .escalation-mode-panel,
#dashboardPage .data-quality-alerts,
#dashboardPage .pu-load-balancer,
#dashboardPage .dashboard-change-summary,
#dashboardPage .queue-360-summary,
#dashboardPage .queue-360-section,
#dashboardPage .queue-360-main-driver,
#dashboardPage .queue-360-rca-card,
#dashboardPage .modal-content,
#dashboardPage .queue-detail-modal,
#dashboardPage .queue-influx-modal,
#dashboardPage .queue-capacity-modal,
#dashboardPage .forecast-interval-modal,
#dashboardPage .break-optimization-modal,
#dashboardPage .data-source-sample-modal,
#dashboardPage .database-schema-modal {
    border-color: var(--wcc-card-border);
    border-radius: var(--wcc-radius-xl);
    background: var(--wcc-light-card);
    color: var(--wcc-light-text);
    box-shadow: var(--wcc-card-shadow);
}

#dashboardPage .section {
    background: transparent;
    box-shadow: none;
}

#dashboardPage .top-action-item,
#dashboardPage .decision-action-card,
#dashboardPage .decision-board-list > div,
#dashboardPage .queue-driver-card,
#dashboardPage .data-confidence-item,
#dashboardPage .coverage-control-section,
#dashboardPage .coverage-upload-card,
#dashboardPage .readiness-card,
#dashboardPage .data-quality-card,
#dashboardPage .early-warning-card,
#dashboardPage .pu-load-card,
#dashboardPage .action-log-form,
#dashboardPage .handoff-preview {
    border-color: var(--wcc-card-border);
    border-radius: var(--wcc-radius-lg);
    background: var(--wcc-light-card);
    color: var(--wcc-light-text);
}

#dashboardPage .top-action-item {
    border-radius: 0;
    box-shadow: none;
}

#dashboardPage .command-quick-uploads summary,
#dashboardPage .command-quick-uploads .quick-upload-grid,
#dashboardPage .global-filter-chips,
#dashboardPage .global-filter-chip,
#dashboardPage input,
#dashboardPage select,
#dashboardPage textarea,
#dashboardPage .multi-filter-button,
#dashboardPage .multi-filter-menu {
    border-color: var(--wcc-card-border);
    background: var(--wcc-light-card-soft);
    color: var(--wcc-light-text);
}

#dashboardPage .command-sticky-strip,
#dashboardPage .command-sticky-strip span {
    border-color: var(--wcc-card-border);
    background: var(--wcc-light-card);
}

#dashboardPage .command-sticky-strip span::before,
#dashboardPage .nav-link::before {
    background-color: currentColor;
}

#dashboardPage .command-sticky-strip span:nth-child(1)::before,
#dashboardPage .command-sticky-strip span:nth-child(3)::before,
#dashboardPage .command-sticky-strip span:nth-child(4)::before {
    background-color: var(--wcc-light-danger);
}

#dashboardPage .command-sticky-strip span:nth-child(2)::before,
#dashboardPage .command-sticky-strip span:nth-child(6)::before,
#dashboardPage .command-sticky-strip span:nth-child(7)::before {
    background-color: var(--wcc-light-primary);
}

#dashboardPage .command-sticky-strip span:nth-child(5)::before {
    background-color: var(--wcc-light-success);
}

#dashboardPage .command-sticky-strip small,
#dashboardPage .page-hero p,
#dashboardPage .card small,
#dashboardPage .decision-action-main small,
#dashboardPage .top-action-reason,
#dashboardPage .decision-board-list small,
#dashboardPage .queue-detail-item span,
#dashboardPage .queue-detail-item small,
#dashboardPage th {
    color: var(--wcc-light-muted);
}

#dashboardPage .command-sticky-strip strong,
#dashboardPage .page-hero h2,
#dashboardPage .section-header h3,
#dashboardPage .card h3,
#dashboardPage .card p,
#dashboardPage .decision-action-head strong,
#dashboardPage .top-action-name,
#dashboardPage .queue-detail-item strong,
#dashboardPage td {
    color: var(--wcc-light-text);
}

#dashboardPage table {
    color: var(--wcc-light-text);
}

#dashboardPage th {
    background: var(--wcc-light-card-soft);
}

#dashboardPage td {
    border-bottom-color: var(--wcc-card-border);
}

#dashboardPage tbody tr:hover td {
    background: var(--wcc-light-primary-soft);
}

#dashboardPage .nav-link {
    color: var(--wcc-sidebar-muted);
}

#dashboardPage .nav-link:hover,
#dashboardPage .nav-link.active {
    color: var(--wcc-sidebar-text);
}

#dashboardPage .nav-link.active {
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
}

html[data-theme="dark"] #dashboardPage .nav-link.active {
    background: linear-gradient(135deg, #2563eb, #1e40af);
}

#dashboardPage .severity-badge,
#dashboardPage .confidence-badge,
#dashboardPage .source-status,
#dashboardPage .action-type-badge,
#dashboardPage .decision-source-row > span {
    border-width: 1px;
    border-style: solid;
}

@media (max-width: 380px) {
    .nav-right {
        grid-template-columns: 1fr;
    }

    .nav-logo {
        font-size: 14px;
    }

    button,
    input,
    select {
        font-size: 12px;
    }

    .card p {
        font-size: 20px;
    }

    .break-gantt-inner {
        min-width: calc(274px + var(--gantt-track-width));
    }

    .break-gantt-header,
    .break-gantt-row,
    .break-gantt-employee {
        grid-template-columns: 74px 112px 88px var(--gantt-track-width);
    }

    .break-gantt-header > :nth-child(2),
    .break-gantt-employee > :nth-child(2) {
        left: 74px;
    }

    .break-gantt-header > :nth-child(3),
    .break-gantt-employee > :nth-child(3),
    .break-gantt-employee > :nth-child(5) {
        left: 186px;
    }

    .break-gantt-summary-row {
        grid-template-columns: 186px 88px var(--gantt-track-width);
    }

    .break-gantt-summary-row > :nth-child(2),
    .break-gantt-summary-row > :nth-child(4) {
        left: 186px;
    }
}

/* Final color and icon polish for the RTA shell. */
#dashboardPage {
    --wcc-light-bg: #f5f7fb;
    --wcc-light-card: #ffffff;
    --wcc-light-card-soft: #f8fafc;
    --wcc-light-text: #101828;
    --wcc-light-muted: #667085;
    --wcc-light-line: #d8e1ee;
    --wcc-light-primary: #2563eb;
    --wcc-light-primary-soft: #eaf1ff;
    --wcc-light-success: #15803d;
    --wcc-light-warning: #c2410c;
    --wcc-light-danger: #b91c1c;
    --wcc-sidebar-bg: #07111f;
    --wcc-sidebar-bg-2: #0d1a2e;
    --wcc-sidebar-text: #f8fbff;
    --wcc-sidebar-muted: #d7e3f5;
    --wcc-card-border: #dce5f1;
    --wcc-card-shadow: 0 8px 22px rgba(15, 23, 42, 0.07);
    background: var(--wcc-light-bg);
}

html[data-theme="dark"] #dashboardPage {
    --wcc-light-bg: #0f1726;
    --wcc-light-card: #172236;
    --wcc-light-card-soft: #111b2b;
    --wcc-light-text: #eaf1fb;
    --wcc-light-muted: #aab7c8;
    --wcc-light-line: rgba(148, 163, 184, 0.22);
    --wcc-light-primary: #60a5fa;
    --wcc-light-primary-soft: rgba(96, 165, 250, 0.14);
    --wcc-light-success: #4ade80;
    --wcc-light-warning: #fb923c;
    --wcc-light-danger: #f87171;
    --wcc-sidebar-bg: #050b16;
    --wcc-sidebar-bg-2: #0a1324;
    --wcc-sidebar-text: #f8fbff;
    --wcc-sidebar-muted: #d7e3f5;
    --wcc-card-border: rgba(148, 163, 184, 0.22);
    --wcc-card-shadow: 0 12px 28px rgba(0, 0, 0, 0.22);
    background: var(--wcc-light-bg);
    color: var(--wcc-light-text);
}

#dashboardPage .navbar {
    background:
        radial-gradient(circle at 0 0, rgba(37, 99, 235, 0.28), transparent 34%),
        linear-gradient(180deg, var(--wcc-sidebar-bg), var(--wcc-sidebar-bg-2));
}

#dashboardPage .nav-logo span {
    color: var(--wcc-sidebar-text);
}

#dashboardPage .nav-link {
    gap: 10px;
    color: var(--wcc-sidebar-muted);
    opacity: 0.96;
}

#dashboardPage .nav-link::before {
    content: "";
    display: inline-block;
    flex: 0 0 22px;
    width: 22px;
    height: 22px;
    border: 1px solid rgba(203, 213, 225, 0.28);
    border-radius: 7px;
    background-color: currentColor;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 14px 14px;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: 14px 14px;
    mask-size: 14px 14px;
    opacity: 0.92;
}

#dashboardPage .nav-link[data-icon="home"]::before {
    -webkit-mask-image: url("icons/lucide/icons/layout-dashboard.svg");
    mask-image: url("icons/lucide/icons/layout-dashboard.svg");
}

#dashboardPage .nav-link[data-icon="search"]::before {
    -webkit-mask-image: url("icons/lucide/icons/search.svg");
    mask-image: url("icons/lucide/icons/search.svg");
}

#dashboardPage .nav-link[data-icon="activity"]::before {
    -webkit-mask-image: url("icons/lucide/icons/activity.svg");
    mask-image: url("icons/lucide/icons/activity.svg");
}

#dashboardPage .nav-link[data-icon="handoff"]::before {
    -webkit-mask-image: url("icons/lucide/icons/repeat-2.svg");
    mask-image: url("icons/lucide/icons/repeat-2.svg");
}

#dashboardPage .nav-link[data-icon="chart"]::before {
    -webkit-mask-image: url("icons/lucide/icons/chart-column.svg");
    mask-image: url("icons/lucide/icons/chart-column.svg");
}

#dashboardPage .nav-link[data-icon="database"]::before {
    -webkit-mask-image: url("icons/lucide/icons/database.svg");
    mask-image: url("icons/lucide/icons/database.svg");
}

#dashboardPage .nav-link[data-icon="help"]::before {
    -webkit-mask-image: url("icons/lucide/icons/hand-helping.svg");
    mask-image: url("icons/lucide/icons/hand-helping.svg");
}

#dashboardPage .nav-link[data-icon="settings"]::before {
    -webkit-mask-image: url("icons/lucide/icons/settings.svg");
    mask-image: url("icons/lucide/icons/settings.svg");
}

#dashboardPage .nav-link:hover {
    background: rgba(96, 165, 250, 0.16);
    color: #ffffff;
}

#dashboardPage .nav-link.active::before {
    border-color: rgba(255, 255, 255, 0.34);
    background-color: #ffffff;
}

#dashboardPage .page-hero,
#dashboardPage .glass,
#dashboardPage .card,
#dashboardPage .controls,
#dashboardPage .top-action-item,
#dashboardPage .decision-action-card,
#dashboardPage .decision-board-card,
#dashboardPage .early-warning-card,
#dashboardPage .data-quality-card,
#dashboardPage .pu-load-card,
#dashboardPage .queue-driver-card,
#dashboardPage .data-confidence-item {
    border-color: var(--wcc-card-border);
    background: var(--wcc-light-card);
    color: var(--wcc-light-text);
    box-shadow: var(--wcc-card-shadow);
}

#dashboardPage .page-hero {
    background:
        linear-gradient(135deg, var(--wcc-light-primary-soft), transparent 46%),
        var(--wcc-light-card);
}

#dashboardPage .page-hero h2,
#dashboardPage .section-header h3,
#dashboardPage .decision-action-head strong,
#dashboardPage .top-action-name,
#dashboardPage .cards .card p,
#dashboardPage .queue-detail-item strong,
#dashboardPage td {
    color: var(--wcc-light-text);
}

#dashboardPage .page-hero p,
#dashboardPage .global-filter-chip,
#dashboardPage .decision-action-main small,
#dashboardPage .top-action-reason,
#dashboardPage .decision-board-list small,
#dashboardPage .cards .card h3,
#dashboardPage th {
    color: var(--wcc-light-muted);
}

#dashboardPage input,
#dashboardPage select,
#dashboardPage textarea,
#dashboardPage .command-quick-uploads summary,
#dashboardPage .global-filter-chips {
    border-color: var(--wcc-card-border);
    background: var(--wcc-light-card-soft);
    color: var(--wcc-light-text);
}

#dashboardPage .command-sticky-strip {
    border-color: var(--wcc-card-border);
    background: var(--wcc-light-card);
}

#dashboardPage .command-sticky-strip span {
    border-right-color: var(--wcc-card-border);
    background: var(--wcc-light-card);
}

#dashboardPage .command-sticky-strip span::before {
    border-color: rgba(var(--accent-rgb), 0.28);
    background-color: var(--wcc-light-primary);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: 15px 15px;
    mask-size: 15px 15px;
}

#dashboardPage .command-sticky-strip span:nth-child(1)::before {
    -webkit-mask-image: url("icons/lucide/icons/shield-alert.svg");
    mask-image: url("icons/lucide/icons/shield-alert.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(2)::before {
    -webkit-mask-image: url("icons/lucide/icons/zap.svg");
    mask-image: url("icons/lucide/icons/zap.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(3)::before {
    -webkit-mask-image: url("icons/lucide/icons/triangle-alert.svg");
    mask-image: url("icons/lucide/icons/triangle-alert.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(4)::before {
    -webkit-mask-image: url("icons/lucide/icons/users.svg");
    mask-image: url("icons/lucide/icons/users.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(5)::before {
    -webkit-mask-image: url("icons/lucide/icons/database.svg");
    mask-image: url("icons/lucide/icons/database.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(6)::before {
    -webkit-mask-image: url("icons/lucide/icons/clock.svg");
    mask-image: url("icons/lucide/icons/clock.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(7)::before {
    -webkit-mask-image: url("icons/lucide/icons/sliders-horizontal.svg");
    mask-image: url("icons/lucide/icons/sliders-horizontal.svg");
}

#dashboardPage .command-sticky-strip small {
    color: var(--wcc-light-muted);
}

#dashboardPage .command-sticky-strip strong {
    color: var(--wcc-light-text);
}

#dashboardPage table,
#dashboardPage th {
    border-color: var(--wcc-card-border);
}

#dashboardPage th {
    background: var(--wcc-light-card-soft);
}

#dashboardPage td {
    border-bottom-color: var(--wcc-card-border);
}

html[data-theme="dark"] #dashboardPage tbody tr:hover td {
    background: rgba(96, 165, 250, 0.08);
}

html[data-theme="dark"] #dashboardPage .severity-badge.critical,
html[data-theme="dark"] #dashboardPage .confidence-badge.missing,
html[data-theme="dark"] #dashboardPage .source-status.missing {
    border-color: rgba(248, 113, 113, 0.36);
    background: rgba(248, 113, 113, 0.14);
    color: #fecaca;
}

html[data-theme="dark"] #dashboardPage .severity-badge.warning,
html[data-theme="dark"] #dashboardPage .severity-badge.watch,
html[data-theme="dark"] #dashboardPage .confidence-badge.low,
html[data-theme="dark"] #dashboardPage .source-status.warn {
    border-color: rgba(251, 146, 60, 0.36);
    background: rgba(251, 146, 60, 0.14);
    color: #fed7aa;
}

html[data-theme="dark"] #dashboardPage .confidence-badge.high,
html[data-theme="dark"] #dashboardPage .source-status.loaded {
    border-color: rgba(74, 222, 128, 0.32);
    background: rgba(74, 222, 128, 0.13);
    color: #bbf7d0;
}

html[data-theme="dark"] #dashboardPage .confidence-badge.medium {
    border-color: rgba(250, 204, 21, 0.32);
    background: rgba(250, 204, 21, 0.12);
    color: #fde68a;
}

/* Compact RTA density pass. Display-only; operational formulas and parsers remain untouched. */
#dashboardPage {
    font-size: 13px;
}

#dashboardPage .navbar {
    width: 286px;
    padding: 14px 10px;
}

#dashboardPage .nav-left,
#dashboardPage .nav-menu,
#dashboardPage .nav-right {
    gap: 8px;
}

#dashboardPage .nav-logo {
    padding: 6px 8px 10px;
}

#dashboardPage .nav-logo span {
    font-size: 15px;
}

#dashboardPage .nav-link {
    min-height: 38px;
    padding: 9px 11px;
    color: #edf4ff;
    font-size: 13px;
    font-weight: 850;
    opacity: 1;
}

#dashboardPage .sidebar-escalation-card {
    gap: 6px;
    margin-top: 10px;
    padding: 11px;
}

#dashboardPage .sidebar-escalation-card strong {
    font-size: 18px;
}

#dashboardPage .profile-button {
    grid-template-columns: 36px minmax(0, 1fr) auto;
    padding: 8px;
}

#dashboardPage .profile-avatar {
    width: 36px;
    height: 36px;
    font-size: 12px;
}

#dashboardPage > .sub-page {
    margin-left: 286px;
    padding: 12px 16px 84px;
}

#dashboardPage .page-hero {
    margin-bottom: 8px;
    padding: 10px 14px;
    border-radius: 12px;
}

#dashboardPage .page-hero h2 {
    font-size: 20px;
    line-height: 1.12;
}

#dashboardPage .page-hero p {
    margin-top: 4px;
    font-size: 12px;
    line-height: 1.35;
}

#dashboardPage .section {
    margin: 12px 0;
}

#dashboardPage .section-header {
    margin-bottom: 6px;
}

#dashboardPage .section-header h3 {
    font-size: 15px;
}

#dashboardPage .eyebrow {
    font-size: 10px;
}

#dashboardPage .command-quick-uploads {
    margin-bottom: 8px;
    padding: 0;
    border-radius: 10px;
    background: transparent;
    box-shadow: none;
}

#dashboardPage .command-quick-uploads summary {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 6px 10px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #ffffff;
    color: #475569;
    font-size: 12px;
    font-weight: 800;
    cursor: pointer;
}

#dashboardPage .command-quick-uploads .quick-upload-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 8px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #ffffff;
}

#dashboardPage .global-filter-chips {
    min-height: 34px;
    margin-bottom: 8px;
    padding: 7px 10px;
}

#dashboardPage .global-filter-chip {
    padding: 4px 8px;
    font-size: 11px;
}

#dashboardPage .command-sticky-strip {
    grid-template-columns: repeat(7, minmax(98px, 1fr));
    margin-bottom: 10px;
    border-radius: 12px;
}

#dashboardPage .command-sticky-strip span {
    min-height: 62px;
    padding: 9px 11px;
    gap: 3px;
    overflow: hidden;
    position: relative;
}

#dashboardPage .command-sticky-strip span::before {
    content: "";
    width: 20px;
    height: 20px;
    border: 1px solid #bfdbfe;
    border-radius: 50%;
    background: #eff6ff;
    grid-row: 1 / 3;
    align-self: center;
}

#dashboardPage .command-sticky-strip span {
    grid-template-columns: 24px minmax(0, 1fr);
}

#dashboardPage .command-sticky-strip small,
#dashboardPage .command-sticky-strip strong {
    grid-column: 2;
}

#dashboardPage .command-sticky-strip small {
    font-size: 10px;
    line-height: 1.1;
    white-space: nowrap;
}

#dashboardPage .command-sticky-strip strong {
    min-width: 0;
    font-size: 14px;
    line-height: 1.18;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

#dashboardPage .command-sticky-strip span:nth-child(1) strong,
#dashboardPage .command-sticky-strip span:nth-child(4) strong {
    color: #dc2626;
}

#dashboardPage .command-sticky-strip span:nth-child(5) strong {
    display: inline-flex;
    width: fit-content;
    padding: 2px 8px;
    border-radius: 999px;
    background: #fef3c7;
    color: #a16207;
    font-size: 12px;
}

#dashboardPage .decision-center-section {
    grid-template-columns: minmax(420px, 0.98fr) minmax(0, 1.02fr);
    gap: 10px;
}

#dashboardPage .top-actions-now,
#dashboardPage .decision-action-queue,
#dashboardPage .early-warning-center,
#dashboardPage .escalation-mode-panel,
#dashboardPage .data-quality-alerts,
#dashboardPage .pu-load-balancer,
#dashboardPage .dashboard-change-summary,
#dashboardPage .decision-board-card,
#dashboardPage .cards .card {
    border-radius: 10px;
}

#dashboardPage .decision-support-panel {
    margin: 0;
    padding: 0;
}

#dashboardPage .decision-support-panel .section-header {
    margin-bottom: 6px;
}

#dashboardPage .decision-support-panel .section-header h3 {
    font-size: 15px;
}

#dashboardPage .decision-action-queue {
    grid-column: 1 / -1;
}

#dashboardPage .top-actions-now {
    padding: 8px;
}

#dashboardPage .top-actions-table {
    display: grid;
    gap: 0;
}

#dashboardPage .top-actions-header,
#dashboardPage .top-action-item {
    display: grid;
    grid-template-columns: 34px 74px minmax(120px, 1.05fr) 86px minmax(170px, 1.25fr) 104px auto;
    gap: 8px;
    align-items: center;
}

#dashboardPage .top-actions-header {
    padding: 0 8px 6px;
    color: #64748b;
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
}

#dashboardPage .top-action-item {
    min-height: 42px;
    padding: 7px 8px;
    border: 0;
    border-top: 1px solid #edf2f7;
    border-radius: 0;
    background: #ffffff;
}

#dashboardPage .top-action-name,
#dashboardPage .top-action-reason {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#dashboardPage .top-action-name {
    color: #111827;
    font-size: 12px;
}

#dashboardPage .top-action-reason {
    color: #475569;
    font-size: 11px;
}

#dashboardPage .top-action-rank {
    color: #334155;
    font-size: 12px;
}

#dashboardPage .top-action-buttons {
    gap: 4px;
}

#dashboardPage .decision-action-queue {
    padding: 8px;
    max-height: none;
    overflow: visible;
}

#dashboardPage .decision-action-preview-head {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 6px;
    color: #64748b;
    font-size: 11px;
}

#dashboardPage .decision-action-preview-head span {
    color: #111827;
    font-size: 12px;
    font-weight: 900;
}

#dashboardPage .decision-action-footnote {
    display: block;
    margin-top: 6px;
    color: #64748b;
    font-size: 11px;
}

#dashboardPage .decision-action-list {
    gap: 7px;
}

#dashboardPage .decision-action-card {
    grid-template-columns: 34px minmax(0, 1fr) 126px;
    gap: 8px;
    min-height: 82px;
    padding: 8px;
    border-left-width: 3px;
    border-radius: 10px;
}

#dashboardPage .decision-action-rank {
    font-size: 12px;
}

#dashboardPage .decision-action-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 5px;
}

#dashboardPage .decision-action-head strong {
    flex: 1 1 100%;
    font-size: 14px;
    line-height: 1.2;
}

#dashboardPage .decision-action-head small {
    flex: 1 1 100%;
}

#dashboardPage .decision-action-main p {
    display: -webkit-box;
    margin: 5px 0 3px;
    color: #111827;
    font-size: 12px;
    font-weight: 800;
    line-height: 1.25;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

#dashboardPage .decision-action-main small {
    font-size: 11px;
    line-height: 1.25;
}

#dashboardPage .decision-source-row {
    gap: 4px;
    margin-top: 5px;
}

#dashboardPage .decision-action-side {
    gap: 4px;
}

#dashboardPage .decision-action-side strong {
    font-size: 13px;
}

#dashboardPage button,
#dashboardPage .table-link,
#dashboardPage .queue-360-section-chips button {
    min-height: 30px;
    padding: 6px 10px;
    font-size: 12px;
}

#dashboardPage .severity-badge,
#dashboardPage .confidence-badge,
#dashboardPage .source-status,
#dashboardPage .action-type-badge,
#dashboardPage .decision-source-row > span {
    min-height: 20px;
    padding: 2px 7px;
    font-size: 10px;
}

#dashboardPage .now-next-later-board,
#dashboardPage .command-priority-grid,
#dashboardPage .cards {
    gap: 10px;
}

#dashboardPage .now-next-later-board {
    grid-template-columns: 1fr;
}

#dashboardPage .decision-board-card {
    padding: 10px;
}

#dashboardPage .decision-board-card h3 {
    font-size: 14px;
}

#dashboardPage .decision-board-list {
    gap: 5px;
}

#dashboardPage .decision-board-list > div {
    padding: 7px 8px;
}

#dashboardPage .decision-board-list strong {
    font-size: 12px;
}

#dashboardPage .decision-board-list small {
    font-size: 11px;
}

#dashboardPage .cards {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}

#dashboardPage .cards .card {
    min-height: 82px;
    padding: 10px 12px;
}

#dashboardPage .cards .card h3 {
    font-size: 11px;
}

#dashboardPage .cards .card p {
    font-size: 20px;
}

#dashboardPage .early-warning-card,
#dashboardPage .data-quality-card,
#dashboardPage .pu-load-card {
    gap: 6px;
    padding: 9px;
}

#dashboardPage .early-warning-card p,
#dashboardPage .data-quality-card p,
#dashboardPage .pu-load-card p {
    font-size: 12px;
    line-height: 1.3;
}

#dashboardPage th,
#dashboardPage td {
    padding: 7px 8px;
    font-size: 12px;
}

#dashboardPage th {
    font-size: 10px;
}

#dashboardPage .queue-detail-item strong {
    font-size: 15px;
}

.footer {
    margin-left: 286px;
    padding: 4px 14px 5px;
    font-size: 11px;
}

.footer-content {
    min-height: 22px;
}

.ticker {
    line-height: 18px;
}

#dashboardPage > .sub-page {
    padding-bottom: 128px;
}

@media (max-width: 1180px) {
    #dashboardPage .navbar {
        width: 100%;
    }

    #dashboardPage > .sub-page {
        margin-left: 0;
    }

    #dashboardPage .top-actions-header {
        display: none;
    }

    #dashboardPage .top-action-item {
        grid-template-columns: 32px 72px minmax(0, 1fr);
    }

    #dashboardPage .top-action-item .action-type-badge,
    #dashboardPage .top-action-item .confidence-badge,
    #dashboardPage .top-action-reason,
    #dashboardPage .top-action-buttons {
        grid-column: 3;
    }

    .footer {
        margin-left: 0;
    }
}

/* UI design correction layer: this block must stay after the compact density
   pass so the final color, radius, dropdown, and Lucide icon rules win. */
#dashboardPage {
    background: var(--wcc-light-bg, #f5f7fb) !important;
    color: var(--wcc-light-text, #101828);
}

#dashboardPage .navbar {
    overflow-x: visible;
    overflow-y: auto;
    background:
        radial-gradient(circle at 8% 2%, rgba(59, 130, 246, 0.24), transparent 34%),
        linear-gradient(180deg, var(--wcc-sidebar-bg, #07111f), var(--wcc-sidebar-bg-2, #0d1a2e)) !important;
}

#dashboardPage .nav-logo span {
    color: var(--wcc-sidebar-text, #f8fbff);
}

#dashboardPage .nav-link {
    gap: 10px;
    color: var(--wcc-sidebar-muted, #c7d2e5);
    opacity: 0.94;
}

#dashboardPage .nav-link::before,
#dashboardPage .control-icon,
#dashboardPage .user-menu-dropdown button::before,
.page .control-icon,
.page .user-menu-dropdown button::before {
    content: "";
    display: inline-block;
    flex: 0 0 18px;
    width: 18px;
    height: 18px;
    border: 0;
    border-radius: 0;
    background: currentColor;
    opacity: 0.96;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: contain;
    mask-size: contain;
}

#dashboardPage .nav-link[data-icon="home"]::before {
    -webkit-mask-image: url("icons/lucide/icons/layout-dashboard.svg");
    mask-image: url("icons/lucide/icons/layout-dashboard.svg");
}

#dashboardPage .nav-link[data-icon="search"]::before {
    -webkit-mask-image: url("icons/lucide/icons/search.svg");
    mask-image: url("icons/lucide/icons/search.svg");
}

#dashboardPage .nav-link[data-icon="activity"]::before {
    -webkit-mask-image: url("icons/lucide/icons/activity.svg");
    mask-image: url("icons/lucide/icons/activity.svg");
}

#dashboardPage .nav-link[data-icon="handoff"]::before {
    -webkit-mask-image: url("icons/lucide/icons/clipboard-list.svg");
    mask-image: url("icons/lucide/icons/clipboard-list.svg");
}

#dashboardPage .nav-link[data-icon="chart"]::before {
    -webkit-mask-image: url("icons/lucide/icons/chart-column.svg");
    mask-image: url("icons/lucide/icons/chart-column.svg");
}

#dashboardPage .nav-link[data-icon="database"]::before {
    -webkit-mask-image: url("icons/lucide/icons/database.svg");
    mask-image: url("icons/lucide/icons/database.svg");
}

#dashboardPage .nav-link[data-icon="help"]::before {
    -webkit-mask-image: url("icons/lucide/icons/life-buoy.svg");
    mask-image: url("icons/lucide/icons/life-buoy.svg");
}

#dashboardPage .nav-link[data-icon="settings"]::before {
    -webkit-mask-image: url("icons/lucide/icons/settings.svg");
    mask-image: url("icons/lucide/icons/settings.svg");
}

#dashboardPage .nav-link:hover {
    color: #ffffff;
    background: rgba(96, 165, 250, 0.14);
}

#dashboardPage .nav-link.active {
    color: #ffffff;
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    box-shadow: 0 10px 24px rgba(37, 99, 235, 0.3);
}

#dashboardPage .nav-right,
.page .nav-right {
    position: relative;
    z-index: 100;
}

#dashboardPage .timezone-control,
#dashboardPage .admin-notification-button,
#dashboardPage .theme-toggle,
#dashboardPage .profile-button,
#dashboardPage .logout-button,
.page .admin-notification-button,
.page .theme-toggle,
.page .profile-button,
.page .logout-button {
    min-height: 38px;
    border: 1px solid rgba(148, 163, 184, 0.24);
    border-radius: 10px;
    background: rgba(15, 23, 42, 0.74);
    color: #eef5ff;
    box-shadow: none;
}

#dashboardPage .timezone-control,
#dashboardPage .admin-notification-button,
#dashboardPage .logout-button,
.page .admin-notification-button,
.page .logout-button {
    display: flex;
    align-items: center;
    gap: 9px;
    width: 100%;
    padding: 8px 10px;
    text-align: left;
}

#dashboardPage .timezone-control:hover,
#dashboardPage .admin-notification-button:hover,
#dashboardPage .theme-toggle:hover,
#dashboardPage .profile-button:hover,
#dashboardPage .logout-button:hover,
.page .admin-notification-button:hover,
.page .theme-toggle:hover,
.page .profile-button:hover,
.page .logout-button:hover {
    border-color: rgba(96, 165, 250, 0.46);
    background: rgba(30, 41, 59, 0.9);
}

#dashboardPage .control-copy,
.page .control-copy {
    display: grid;
    min-width: 0;
    gap: 1px;
    line-height: 1.1;
}

#dashboardPage .control-copy small,
.page .control-copy small {
    color: #9fb0c7;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
}

#dashboardPage .control-copy strong,
.page .control-copy strong {
    color: #f8fbff;
    font-size: 12px;
    font-weight: 900;
}

#dashboardPage .control-icon-timezone {
    color: #93c5fd;
    -webkit-mask-image: url("icons/lucide/icons/globe.svg");
    mask-image: url("icons/lucide/icons/globe.svg");
}

#dashboardPage .control-icon-notification,
.page .control-icon-notification {
    color: #fbbf24;
    -webkit-mask-image: url("icons/lucide/icons/bell-ring.svg");
    mask-image: url("icons/lucide/icons/bell-ring.svg");
}

#dashboardPage .control-icon-logout,
.page .control-icon-logout {
    color: #fca5a5;
    -webkit-mask-image: url("icons/lucide/icons/log-out.svg");
    mask-image: url("icons/lucide/icons/log-out.svg");
}

#dashboardPage .timezone-select {
    width: 100%;
    min-width: 0;
    min-height: 18px;
    padding: 0 20px 0 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: #f8fbff;
    font-size: 12px;
    font-weight: 900;
    box-shadow: none;
}

#dashboardPage .timezone-select:focus {
    outline: none;
    box-shadow: none;
}

#dashboardPage .timezone-select option {
    color: #111827;
}

#dashboardPage .admin-notification-button {
    justify-content: flex-start;
}

#dashboardPage .notification-badge,
.page .notification-badge {
    margin-left: auto;
    border-color: rgba(251, 191, 36, 0.34);
    background: rgba(251, 191, 36, 0.16);
    color: #fde68a;
}

#dashboardPage .theme-toggle,
.page .theme-toggle {
    justify-content: flex-start;
    gap: 9px;
    width: 100%;
    padding: 8px 10px;
}

#dashboardPage .theme-toggle-icon,
.page .theme-toggle-icon {
    width: 18px;
    height: 18px;
    border: 0;
    border-radius: 0;
    background: currentColor !important;
    color: #a5b4fc;
    -webkit-mask: url("icons/lucide/icons/moon-star.svg") center / contain no-repeat;
    mask: url("icons/lucide/icons/moon-star.svg") center / contain no-repeat;
}

html[data-theme="light"] #dashboardPage .theme-toggle-icon,
html[data-theme="light"] .page .theme-toggle-icon {
    color: #f59e0b;
    -webkit-mask-image: url("icons/lucide/icons/sun.svg");
    mask-image: url("icons/lucide/icons/sun.svg");
}

#dashboardPage .profile-button,
.page .profile-button {
    display: grid;
    grid-template-columns: 36px minmax(0, 1fr) 18px;
    grid-template-rows: auto auto;
    gap: 2px 9px;
    width: 100%;
    padding: 8px 10px;
    text-align: left;
}

#dashboardPage .profile-avatar,
.page .profile-avatar {
    position: relative;
    grid-row: 1 / 3;
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border: 1px solid rgba(96, 165, 250, 0.28);
    border-radius: 999px;
    background: rgba(37, 99, 235, 0.18);
    color: transparent;
    font-size: 0;
}

#dashboardPage .profile-avatar::before,
.page .profile-avatar::before {
    content: "";
    width: 18px;
    height: 18px;
    background: #bfdbfe;
    -webkit-mask: url("icons/lucide/icons/user-round.svg") center / contain no-repeat;
    mask: url("icons/lucide/icons/user-round.svg") center / contain no-repeat;
}

#dashboardPage .profile-button .username,
.page .profile-button .username {
    color: #f8fbff;
    font-size: 12px;
    font-weight: 900;
}

#dashboardPage .user-role-label,
.page .user-role-label {
    color: #9fb0c7;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
}

#dashboardPage .user-menu-caret,
.page .user-menu-caret {
    align-self: center;
    width: 16px;
    height: 16px;
    color: #c7d2e5;
    font-size: 0;
    -webkit-mask: url("icons/lucide/icons/chevron-down.svg") center / contain no-repeat;
    mask: url("icons/lucide/icons/chevron-down.svg") center / contain no-repeat;
    background: currentColor;
}

#dashboardPage .user-menu-dropdown,
.page .user-menu-dropdown {
    position: absolute;
    right: 0;
    bottom: calc(100% + 8px);
    top: auto;
    z-index: 5000;
    width: min(260px, calc(100vw - 28px));
    padding: 8px;
    border: 1px solid rgba(148, 163, 184, 0.26);
    border-radius: 12px;
    background: #0f1b2d;
    color: #f8fbff;
    box-shadow: 0 18px 42px rgba(2, 6, 23, 0.42);
}

.page .user-menu-dropdown {
    top: calc(100% + 8px);
    bottom: auto;
}

#dashboardPage .user-menu-dropdown::after,
.page .user-menu-dropdown::after {
    content: "";
    position: absolute;
    right: 18px;
    bottom: -6px;
    width: 10px;
    height: 10px;
    border-right: 1px solid rgba(148, 163, 184, 0.26);
    border-bottom: 1px solid rgba(148, 163, 184, 0.26);
    background: #0f1b2d;
    transform: rotate(45deg);
}

.page .user-menu-dropdown::after {
    top: -6px;
    bottom: auto;
    border: 0;
    border-left: 1px solid rgba(148, 163, 184, 0.26);
    border-top: 1px solid rgba(148, 163, 184, 0.26);
}

#dashboardPage .user-menu-dropdown button,
.page .user-menu-dropdown button {
    display: flex;
    align-items: center;
    gap: 9px;
    min-height: 34px;
    width: 100%;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: #dbeafe;
    box-shadow: none;
}

#dashboardPage .user-menu-dropdown button:hover,
.page .user-menu-dropdown button:hover {
    background: rgba(96, 165, 250, 0.16);
    color: #ffffff;
}

#dashboardPage .user-menu-dropdown button[data-menu-icon="profile"]::before,
.page .user-menu-dropdown button[data-menu-icon="profile"]::before {
    -webkit-mask-image: url("icons/lucide/icons/user-round-cog.svg");
    mask-image: url("icons/lucide/icons/user-round-cog.svg");
}

#dashboardPage .user-menu-dropdown button[data-menu-icon="backup"]::before,
.page .user-menu-dropdown button[data-menu-icon="backup"]::before {
    -webkit-mask-image: url("icons/lucide/icons/database-backup.svg");
    mask-image: url("icons/lucide/icons/database-backup.svg");
}

#dashboardPage .user-menu-dropdown button[data-menu-icon="restore"]::before,
.page .user-menu-dropdown button[data-menu-icon="restore"]::before {
    -webkit-mask-image: url("icons/lucide/icons/archive-restore.svg");
    mask-image: url("icons/lucide/icons/archive-restore.svg");
}

#dashboardPage .logout-button,
.page .logout-button {
    justify-content: flex-start;
    color: #fecaca;
}

#dashboardPage .page-hero,
#dashboardPage .top-actions-now,
#dashboardPage .decision-action-queue,
#dashboardPage .decision-board-card,
#dashboardPage .early-warning-center,
#dashboardPage .escalation-mode-panel,
#dashboardPage .data-quality-alerts,
#dashboardPage .pu-load-balancer,
#dashboardPage .dashboard-change-summary,
#dashboardPage .table-wrapper,
#dashboardPage .controls,
#dashboardPage .card,
#dashboardPage .cards .card {
    border: 1px solid var(--wcc-card-border, #dce5f1);
    border-radius: 12px;
    background: var(--wcc-light-card, #ffffff);
    color: var(--wcc-light-text, #101828);
    box-shadow: var(--wcc-card-shadow, 0 8px 22px rgba(15, 23, 42, 0.07));
}

#dashboardPage .section {
    border: 0;
    background: transparent;
    box-shadow: none;
}

#dashboardPage .top-action-item,
#dashboardPage .decision-board-list > div,
#dashboardPage .early-warning-card,
#dashboardPage .data-quality-card,
#dashboardPage .pu-load-card,
#dashboardPage .queue-detail-item,
#dashboardPage .global-filter-chips,
#dashboardPage .global-filter-chip,
#dashboardPage input,
#dashboardPage select,
#dashboardPage textarea,
#dashboardPage .multi-filter-button,
#dashboardPage .multi-filter-menu,
#dashboardPage .command-quick-uploads summary,
#dashboardPage .command-quick-uploads .quick-upload-grid {
    border-color: var(--wcc-card-border, #dce5f1);
    background: var(--wcc-light-card-soft, #f8fafc);
    color: var(--wcc-light-text, #101828);
}

#dashboardPage .command-sticky-strip,
#dashboardPage .command-sticky-strip span {
    border-color: var(--wcc-card-border, #dce5f1);
    background: var(--wcc-light-card, #ffffff);
}

#dashboardPage .command-sticky-strip span::before {
    border: 0;
    border-radius: 0;
    background: var(--wcc-light-primary, #2563eb);
}

#dashboardPage .command-sticky-strip span:nth-child(1)::before {
    -webkit-mask-image: url("icons/lucide/icons/shield-alert.svg");
    mask-image: url("icons/lucide/icons/shield-alert.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(2)::before {
    -webkit-mask-image: url("icons/lucide/icons/zap.svg");
    mask-image: url("icons/lucide/icons/zap.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(3)::before {
    -webkit-mask-image: url("icons/lucide/icons/triangle-alert.svg");
    mask-image: url("icons/lucide/icons/triangle-alert.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(4)::before {
    -webkit-mask-image: url("icons/lucide/icons/users.svg");
    mask-image: url("icons/lucide/icons/users.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(5)::before {
    -webkit-mask-image: url("icons/lucide/icons/database.svg");
    mask-image: url("icons/lucide/icons/database.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(6)::before {
    -webkit-mask-image: url("icons/lucide/icons/clock.svg");
    mask-image: url("icons/lucide/icons/clock.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(7)::before {
    -webkit-mask-image: url("icons/lucide/icons/sliders-horizontal.svg");
    mask-image: url("icons/lucide/icons/sliders-horizontal.svg");
}

#dashboardPage .command-sticky-strip span:nth-child(1)::before,
#dashboardPage .command-sticky-strip span:nth-child(3)::before,
#dashboardPage .command-sticky-strip span:nth-child(4)::before {
    background-color: var(--wcc-light-danger, #b91c1c);
}

#dashboardPage .command-sticky-strip span:nth-child(5)::before {
    background-color: var(--wcc-light-success, #15803d);
}

#dashboardPage .page-hero h2,
#dashboardPage .section-header h3,
#dashboardPage .card h3,
#dashboardPage .card p,
#dashboardPage .top-action-name,
#dashboardPage .decision-action-main p,
#dashboardPage .decision-action-preview-head span,
#dashboardPage td {
    color: var(--wcc-light-text, #101828);
}

#dashboardPage .page-hero p,
#dashboardPage .card small,
#dashboardPage .top-actions-header,
#dashboardPage .top-action-reason,
#dashboardPage .decision-action-footnote,
#dashboardPage .decision-action-main small,
#dashboardPage th {
    color: var(--wcc-light-muted, #667085);
}

html[data-theme="dark"] #dashboardPage .top-action-item,
html[data-theme="dark"] #dashboardPage .decision-board-list > div,
html[data-theme="dark"] #dashboardPage .early-warning-card,
html[data-theme="dark"] #dashboardPage .data-quality-card,
html[data-theme="dark"] #dashboardPage .pu-load-card,
html[data-theme="dark"] #dashboardPage .queue-detail-item,
html[data-theme="dark"] #dashboardPage .global-filter-chips,
html[data-theme="dark"] #dashboardPage .global-filter-chip,
html[data-theme="dark"] #dashboardPage input,
html[data-theme="dark"] #dashboardPage select,
html[data-theme="dark"] #dashboardPage textarea,
html[data-theme="dark"] #dashboardPage .multi-filter-button,
html[data-theme="dark"] #dashboardPage .multi-filter-menu,
html[data-theme="dark"] #dashboardPage .command-quick-uploads summary,
html[data-theme="dark"] #dashboardPage .command-quick-uploads .quick-upload-grid {
    background: var(--wcc-light-card-soft, #111b2b);
    color: var(--wcc-light-text, #eaf1fb);
}

@media (max-width: 1180px) {
    #dashboardPage .user-menu-dropdown,
    .page .user-menu-dropdown {
        top: calc(100% + 8px);
        bottom: auto;
        right: auto;
        left: 0;
    }

    #dashboardPage .user-menu-dropdown::after,
    .page .user-menu-dropdown::after {
        top: -6px;
        bottom: auto;
        right: auto;
        left: 18px;
        border: 0;
        border-left: 1px solid rgba(148, 163, 184, 0.26);
        border-top: 1px solid rgba(148, 163, 184, 0.26);
    }
}

/* True EOF auth/footer consistency lock.
   Appended last so legacy duplicate UI rules above cannot override login and footer polish. */
html:has(#loginPage.active),
body:has(#loginPage.active) {
    min-height: 100%;
    overflow: hidden;
}

body:has(#loginPage.active) {
    background: #f5f7fb;
}

#loginPage.active {
    min-height: 100vh;
    padding-bottom: 0;
    overflow: hidden;
}

#loginPage.active .center-wrapper {
    min-height: 100vh;
    height: 100vh;
    padding: 24px;
    overflow: hidden;
    background:
        radial-gradient(circle at 28% 18%, rgba(37, 99, 235, 0.14), transparent 34%),
        linear-gradient(135deg, #f8fbff 0%, #eef4fb 54%, #f6f8fb 100%);
}

#loginPage.active .auth-card {
    width: min(420px, calc(100vw - 32px));
    max-height: calc(100vh - 48px);
    overflow: visible;
    border: 1px solid #d8e2ef;
    background: rgba(255, 255, 255, 0.94);
    color: #101828;
    box-shadow: 0 24px 70px rgba(15, 23, 42, 0.16);
}

#loginPage.active .auth-card .brand h1,
#loginPage.active .auth-card .login-section,
#loginPage.active .auth-card .remember-row,
#loginPage.active .auth-card .auth-switch {
    color: #101828;
}

#loginPage.active .auth-card .brand p,
#loginPage.active .auth-card .auth-switch span {
    color: #667085;
}

#loginPage.active .auth-card input {
    min-height: 36px;
    border: 1px solid #cfd9e7;
    background: #ffffff;
    color: #101828;
}

#loginPage.active .auth-card input::placeholder {
    color: #7d89a1;
}

#loginPage.active .auth-card .password-wrapper button {
    min-height: 26px;
    color: #2563eb;
}

#loginPage.active .auth-theme-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: auto;
    min-width: 118px;
    min-height: 32px;
    margin: 12px auto 16px;
    padding: 6px 13px;
    border-radius: 999px;
    border: 1px solid #cfd9e7;
    background: #f8fafc;
    color: #101828;
    box-shadow: none;
}

#loginPage.active .auth-theme-toggle .theme-toggle-icon {
    width: 15px;
    height: 15px;
    background: #2563eb;
}

#loginPage.active .auth-theme-toggle .theme-toggle-text {
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
}

#loginPage.active #loginBtn {
    min-height: 36px;
    border-radius: 8px;
}

#loginPage.active .auth-card .secondary {
    min-height: 34px;
    border-radius: 8px;
}

body:has(#loginPage.active) .footer {
    display: none;
}

html[data-theme="dark"] body:has(#loginPage.active) {
    background: #07111f;
}

html[data-theme="dark"] #loginPage.active .center-wrapper {
    background:
        radial-gradient(circle at 28% 18%, rgba(37, 99, 235, 0.22), transparent 34%),
        linear-gradient(135deg, #0f2544 0%, #07111f 58%, #050b14 100%);
}

html[data-theme="dark"] #loginPage.active .auth-card {
    border-color: rgba(148, 163, 184, 0.24);
    background: rgba(15, 23, 42, 0.9);
    color: #f8fbff;
    box-shadow: 0 26px 76px rgba(0, 0, 0, 0.28);
}

html[data-theme="dark"] #loginPage.active .auth-card .brand h1,
html[data-theme="dark"] #loginPage.active .auth-card .login-section,
html[data-theme="dark"] #loginPage.active .auth-card .remember-row,
html[data-theme="dark"] #loginPage.active .auth-card .auth-switch {
    color: #f8fbff;
}

html[data-theme="dark"] #loginPage.active .auth-card .brand p,
html[data-theme="dark"] #loginPage.active .auth-card .auth-switch span {
    color: #a9b6ca;
}

html[data-theme="dark"] #loginPage.active .auth-card input {
    border-color: rgba(148, 163, 184, 0.28);
    background: rgba(15, 23, 42, 0.78);
    color: #f8fbff;
}

html[data-theme="dark"] #loginPage.active .auth-card input::placeholder {
    color: #95a3b8;
}

html[data-theme="dark"] #loginPage.active .auth-theme-toggle {
    border-color: rgba(147, 197, 253, 0.52);
    background: rgba(30, 41, 59, 0.7);
    color: #f8fbff;
}

html[data-theme="dark"] #loginPage.active .auth-theme-toggle .theme-toggle-icon {
    background: #93c5fd;
}

.footer {
    min-height: 32px;
    height: 32px;
    margin-left: 286px;
    padding: 3px 14px;
    border-top: 1px solid var(--wcc-card-border, #dce5f1);
    background: rgba(245, 247, 251, 0.97);
    color: var(--wcc-light-muted, #667085);
    box-shadow: 0 -10px 24px rgba(15, 23, 42, 0.06);
}

.footer-content {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 14px;
    min-height: 24px;
    font-size: 11px;
}

.ticker {
    min-width: 0;
    height: 0;
    line-height: 0;
    overflow: hidden;
}

.ticker-track {
    animation: none;
    transform: none;
}

#dashboardPage > .sub-page,
#adminPage.page {
    padding-bottom: 48px;
}

html[data-theme="dark"] .footer {
    border-top-color: rgba(148, 163, 184, 0.18);
    background: rgba(8, 15, 28, 0.96);
    color: #a9b6ca;
    box-shadow: 0 -12px 28px rgba(0, 0, 0, 0.22);
}

@media (max-width: 1180px) {
    .footer {
        left: 0;
        margin-left: 0;
    }
}

@media (max-height: 720px) {
    #loginPage.active .center-wrapper {
        padding: 14px;
    }

    #loginPage.active .auth-card {
        transform: scale(0.94);
    }
}

/* Final dark-mode contrast pass.
   Keep text readable on dark cards without changing the app's calculation/rendering logic. */
html[data-theme="dark"] body:not(:has(#loginPage.active)) {
    background: #08111f;
    color: #eaf1fb;
}

html[data-theme="dark"] #dashboardPage,
html[data-theme="dark"] #adminPage {
    --wcc-light-bg: #08111f;
    --wcc-light-card: #111c2e;
    --wcc-light-card-soft: #0d1728;
    --wcc-light-text: #eaf1fb;
    --wcc-light-muted: #aab8cc;
    --wcc-card-border: rgba(148, 163, 184, 0.24);
    background: #08111f;
    color: #eaf1fb;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage) :is(.page-hero, .card, .cards .card, .section, .table-wrapper, .controls, .admin-card, .admin-panel, .command-panel, .about-panel, .howto-panel, .mtd-report-panel, .source-card, .upload-card, .data-quality-card, .early-warning-card, .pu-load-card, .top-action-item, .decision-board-card, .decision-board-list > div, .queue-detail-item, .global-filter-chips, .global-filter-chip, .multi-filter-menu, .command-quick-uploads summary, .command-quick-uploads .quick-upload-grid) {
    border-color: rgba(148, 163, 184, 0.24);
    background: #111c2e;
    color: #eaf1fb;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage) :is(h1, h2, h3, h4, h5, h6, p, label, li, td, th, strong, b, .page-title, .page-hero h2, .section-header h3, .card h3, .card p, .top-action-name, .decision-action-main p, .decision-action-preview-head span, .queue-name, .metric-value, .kpi-value) {
    color: #eaf1fb;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage) :is(small, .muted, .helper-text, .page-hero p, .card small, .top-actions-header, .top-action-reason, .decision-action-footnote, .decision-action-main small, .metric-label, .section-kicker, .subtle, th) {
    color: #aab8cc;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage) :is(input, select, textarea, .multi-filter-button, .filter-chip, .btn.secondary, button.secondary) {
    border-color: rgba(148, 163, 184, 0.28);
    background: #0d1728;
    color: #eaf1fb;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage) :is(input, textarea)::placeholder {
    color: #91a0b5;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage) :is(table, thead, tbody, tr) {
    color: #eaf1fb;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage) thead th {
    border-bottom-color: rgba(148, 163, 184, 0.24);
    background: #0d1728;
    color: #c8d4e6;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage) tbody td {
    border-bottom-color: rgba(148, 163, 184, 0.16);
    color: #eaf1fb;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage) tbody tr:hover {
    background: rgba(96, 165, 250, 0.08);
}

html[data-theme="dark"] :is(.modal-content, .queue-detail-modal, .queue-influx-modal, .queue-capacity-modal, .forecast-interval-modal, .break-optimization-modal, .backup-modal, .db-columns-modal, .upload-alias-modal, .data-source-sample-modal, .database-schema-modal, .user-modal, .profile-modal, .admin-notifications-modal, .queue-rca-modal, .coverage-cell-modal) {
    border-color: rgba(148, 163, 184, 0.24);
    background: #111c2e;
    color: #eaf1fb;
}

html[data-theme="dark"] :is(.modal-content, .queue-detail-modal, .queue-influx-modal, .queue-capacity-modal, .forecast-interval-modal, .break-optimization-modal, .backup-modal, .db-columns-modal, .upload-alias-modal, .data-source-sample-modal, .database-schema-modal, .user-modal, .profile-modal, .admin-notifications-modal, .queue-rca-modal, .coverage-cell-modal) :is(h1, h2, h3, h4, h5, h6, p, label, li, td, th, strong, b) {
    color: inherit;
}

html[data-theme="dark"] :is(.modal-content, .queue-detail-modal, .queue-influx-modal, .queue-capacity-modal, .forecast-interval-modal, .break-optimization-modal, .backup-modal, .db-columns-modal, .upload-alias-modal, .data-source-sample-modal, .database-schema-modal, .user-modal, .profile-modal, .admin-notifications-modal, .queue-rca-modal, .coverage-cell-modal) :is(small, .muted, .helper-text, .modal-help) {
    color: #aab8cc;
}

html[data-theme="dark"] :is(.modal-content, .queue-detail-modal, .queue-influx-modal, .queue-capacity-modal, .forecast-interval-modal, .break-optimization-modal, .backup-modal, .db-columns-modal, .upload-alias-modal, .data-source-sample-modal, .database-schema-modal, .user-modal, .profile-modal, .admin-notifications-modal, .queue-rca-modal, .coverage-cell-modal) :is(input, select, textarea, pre) {
    border-color: rgba(148, 163, 184, 0.28);
    background: #0d1728;
    color: #eaf1fb;
}

html[data-theme="dark"] :is(.severity-badge.critical, .status-critical, .badge-critical) {
    border-color: rgba(248, 113, 113, 0.38);
    background: rgba(248, 113, 113, 0.14);
    color: #fecaca;
}

html[data-theme="dark"] :is(.severity-badge.warning, .severity-badge.watch, .status-warning, .status-watch, .badge-warning, .badge-watch) {
    border-color: rgba(251, 146, 60, 0.38);
    background: rgba(251, 146, 60, 0.14);
    color: #fed7aa;
}

html[data-theme="dark"] :is(.status-safe, .badge-safe, .confidence-badge.high) {
    border-color: rgba(74, 222, 128, 0.34);
    background: rgba(74, 222, 128, 0.13);
    color: #bbf7d0;
}

html[data-theme="dark"] .confidence-badge.medium {
    border-color: rgba(250, 204, 21, 0.34);
    background: rgba(250, 204, 21, 0.12);
    color: #fde68a;
}

html[data-theme="dark"] :is(.confidence-badge.low, .confidence-badge.missing, .source-status.missing, .status-missing, .badge-missing) {
    border-color: rgba(248, 113, 113, 0.38);
    background: rgba(248, 113, 113, 0.14);
    color: #fecaca;
}

/* User menu preferences: timezone and theme live with the current-user controls. */
#dashboardPage .user-menu-section,
.page .user-menu-section {
    display: grid;
    gap: 8px;
    margin: 0 0 8px;
    padding: 0 0 8px;
    border-bottom: 1px solid rgba(148, 163, 184, 0.22);
}

#dashboardPage .user-menu-control,
.page .user-menu-control {
    display: flex;
    align-items: center;
    gap: 9px;
    min-height: 40px;
    padding: 7px 9px;
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 9px;
    background: rgba(15, 23, 42, 0.42);
    color: #f8fbff;
}

#dashboardPage .user-menu-control-copy,
.page .user-menu-control-copy {
    display: grid;
    gap: 3px;
    min-width: 0;
    width: 100%;
}

#dashboardPage .user-menu-control small,
.page .user-menu-control small {
    color: #a9b6ca;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

#dashboardPage .user-menu-control .timezone-select,
.page .user-menu-control .timezone-select {
    width: 100%;
    min-height: 28px;
    padding: 3px 26px 3px 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: #f8fbff;
    font-size: 12px;
    font-weight: 800;
    box-shadow: none;
}

#dashboardPage .user-menu-control .timezone-select:focus,
.page .user-menu-control .timezone-select:focus {
    outline: 2px solid rgba(96, 165, 250, 0.45);
    outline-offset: 2px;
}

#dashboardPage .user-menu-theme-toggle,
.page .user-menu-theme-toggle {
    justify-content: flex-start;
    min-height: 38px;
    border: 1px solid rgba(148, 163, 184, 0.2);
    background: rgba(96, 165, 250, 0.12);
    color: #dbeafe;
}

#dashboardPage .user-menu-theme-toggle::before,
.page .user-menu-theme-toggle::before {
    display: none;
}

#dashboardPage .user-menu-theme-toggle:hover,
.page .user-menu-theme-toggle:hover {
    border-color: rgba(96, 165, 250, 0.45);
    background: rgba(96, 165, 250, 0.2);
    color: #ffffff;
}

html[data-theme="light"] #dashboardPage .user-menu-control,
html[data-theme="light"] .page .user-menu-control {
    border-color: #d8e2ef;
    background: #f8fafc;
    color: #101828;
}

html[data-theme="light"] #dashboardPage .user-menu-control small,
html[data-theme="light"] .page .user-menu-control small {
    color: #667085;
}

html[data-theme="light"] #dashboardPage .user-menu-control .timezone-select,
html[data-theme="light"] .page .user-menu-control .timezone-select {
    color: #101828;
}

html[data-theme="light"] #dashboardPage .user-menu-theme-toggle,
html[data-theme="light"] .page .user-menu-theme-toggle {
    border-color: #d8e2ef;
    background: #eef4ff;
    color: #1d4ed8;
}

/* Dark button readability guard. Scope excludes the assistant bot mount. */
html[data-theme="dark"] :is(#dashboardPage, #adminPage, .modal) button:not(.danger-btn) {
    color: #eaf1fb;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage, .modal) button:not(.secondary):not(.danger-btn):not(.profile-button):not(.user-notification-trigger):not(.theme-toggle) {
    border-color: rgba(96, 165, 250, 0.36);
    background: #2563eb;
    color: #ffffff;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage, .modal) button.secondary {
    border-color: rgba(148, 163, 184, 0.28);
    background: #0d1728;
    color: #eaf1fb;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage, .modal) button:not(.danger-btn):hover {
    color: #ffffff;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage, .modal) button.danger-btn {
    color: #fecaca;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage) .user-menu-dropdown button:not(.user-menu-theme-toggle) {
    border: 0;
    background: transparent;
    color: #dbeafe;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage) .user-menu-dropdown button:not(.user-menu-theme-toggle):hover {
    background: rgba(96, 165, 250, 0.16);
    color: #ffffff;
}

/* Admin panel final polish: align the standalone admin shell with the Command Center sidebar. */
#adminPage {
    background:
        radial-gradient(circle at 0 0, rgba(37, 99, 235, 0.08), transparent 28%),
        #f5f7fb;
}

#adminPage > .navbar {
    overflow-x: visible;
    overflow-y: auto;
    justify-content: space-between;
    gap: 14px;
}

#adminPage > .container {
    width: auto;
    max-width: none;
    margin: 0 20px 56px 306px;
    padding: 18px 0 0;
}

#adminPage .nav-logo {
    flex: 0 0 auto;
}

#adminPage .nav-right {
    position: relative;
    z-index: 100;
    display: grid;
    gap: 8px;
}

#adminPage .user-menu {
    position: relative;
}

#adminPage .user-menu-dropdown {
    right: 0;
    bottom: calc(100% + 8px);
    top: auto;
}

#adminPage .user-menu-dropdown::after {
    top: auto;
    bottom: -6px;
    right: 18px;
    left: auto;
    border: 0;
    border-right: 1px solid rgba(148, 163, 184, 0.26);
    border-bottom: 1px solid rgba(148, 163, 184, 0.26);
}

#adminPage .user-menu-theme-toggle {
    position: static;
    width: 100%;
    height: auto;
    margin: 0;
    padding: 8px 10px;
    opacity: 1;
    pointer-events: auto;
    overflow: visible;
}

#adminPage .admin-back-button {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 9px;
    width: 100%;
    min-height: 34px;
    padding: 7px 10px;
    border: 1px solid rgba(147, 197, 253, 0.2);
    border-radius: 9px;
    background: rgba(96, 165, 250, 0.1);
    color: #dbeafe;
    box-shadow: none;
}

#adminPage .admin-back-button:hover {
    border-color: rgba(147, 197, 253, 0.38);
    background: rgba(96, 165, 250, 0.18);
    color: #ffffff;
}

#adminPage .admin-back-button .control-icon-img {
    width: 16px;
    height: 16px;
    filter: brightness(0) invert(1);
}

#adminPage .page-hero {
    display: flex;
    align-items: center;
    min-height: 92px;
    margin: 0 0 14px;
    padding: 14px 16px;
    background:
        linear-gradient(135deg, rgba(37, 99, 235, 0.09), transparent 48%),
        #ffffff;
}

#adminPage .page-hero h2 {
    margin: 4px 0;
    color: #101828;
    font-size: 22px;
    line-height: 1.12;
}

#adminPage .page-hero p {
    color: #667085;
    font-size: 12px;
}

#adminPage .section {
    margin-bottom: 14px;
    padding: 14px;
    border: 1px solid #dce5f1;
    border-radius: 12px;
    background: #ffffff;
    color: #101828;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.07);
}

#adminPage .section-header {
    margin-bottom: 10px;
    gap: 10px;
}

#adminPage .section-header h3 {
    margin: 2px 0 0;
    color: #101828;
    font-size: 15px;
}

#adminPage .section-header-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

#adminPage .controls,
#adminPage .card.table-wrapper,
#adminPage .admin-notification-panel {
    border: 1px solid #dce5f1;
    border-radius: 10px;
    background: #f8fafc;
    color: #101828;
    box-shadow: none;
}

#adminPage .compact-controls {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    padding: 10px;
}

#adminPage .admin-notification-panel {
    grid-template-columns: minmax(260px, 420px) minmax(0, 1fr);
    gap: 12px;
    padding: 12px;
}

#adminPage .admin-notification-stat {
    border: 1px solid #dce5f1;
    border-radius: 10px;
    background: #ffffff;
    box-shadow: none;
}

#adminPage .table-scroll {
    border-radius: 9px;
}

#adminPage table {
    width: 100%;
    border-collapse: collapse;
}

#adminPage th {
    background: #eef4fb;
    color: #475467;
    font-size: 11px;
}

#adminPage td {
    color: #101828;
    font-size: 12px;
}

html[data-theme="dark"] #adminPage {
    background:
        radial-gradient(circle at 0 0, rgba(96, 165, 250, 0.13), transparent 28%),
        #08111f;
}

html[data-theme="dark"] #adminPage .page-hero,
html[data-theme="dark"] #adminPage .section {
    border-color: rgba(148, 163, 184, 0.24);
    background: #111c2e;
    color: #eaf1fb;
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.2);
}

html[data-theme="dark"] #adminPage .page-hero h2,
html[data-theme="dark"] #adminPage .section-header h3,
html[data-theme="dark"] #adminPage td {
    color: #eaf1fb;
}

html[data-theme="dark"] #adminPage .page-hero p,
html[data-theme="dark"] #adminPage .eyebrow,
html[data-theme="dark"] #adminPage th {
    color: #aab8cc;
}

html[data-theme="dark"] #adminPage .controls,
html[data-theme="dark"] #adminPage .card.table-wrapper,
html[data-theme="dark"] #adminPage .admin-notification-panel,
html[data-theme="dark"] #adminPage .admin-notification-stat {
    border-color: rgba(148, 163, 184, 0.24);
    background: #0d1728;
    color: #eaf1fb;
    box-shadow: none;
}

html[data-theme="dark"] #adminPage th {
    background: #111c2e;
}

@media (max-width: 1180px) {
    #adminPage > .navbar {
        position: sticky;
        width: 100%;
        height: auto;
        overflow: visible;
    }

    #adminPage > .container {
        margin: 12px;
        padding-top: 0;
    }

    #adminPage .user-menu-dropdown {
        top: calc(100% + 8px);
        bottom: auto;
        right: auto;
        left: 0;
    }

    #adminPage .user-menu-dropdown::after {
        top: -6px;
        bottom: auto;
        right: auto;
        left: 18px;
        border: 0;
        border-left: 1px solid rgba(148, 163, 184, 0.26);
        border-top: 1px solid rgba(148, 163, 184, 0.26);
    }

    #adminPage .admin-notification-panel {
        grid-template-columns: 1fr;
    }
}

/* Whole-app UI consistency pass: pages, submenus, dense tables, and modals. */
#dashboardPage .sub-page {
    color: var(--wcc-light-text, #101828);
}

#dashboardPage .sub-page > .page-hero {
    min-height: auto;
    margin: 0 0 14px;
    padding: 14px 16px;
    border: 1px solid var(--wcc-card-border, #dce5f1);
    border-radius: 12px;
    background:
        linear-gradient(135deg, rgba(37, 99, 235, 0.08), transparent 48%),
        var(--wcc-light-card, #ffffff);
    box-shadow: var(--wcc-card-shadow, 0 8px 22px rgba(15, 23, 42, 0.07));
}

#dashboardPage .sub-page > .page-hero h2 {
    margin: 3px 0 4px;
    color: var(--wcc-light-text, #101828);
    font-size: 21px;
    line-height: 1.14;
}

#dashboardPage .sub-page > .page-hero p {
    max-width: 920px;
    color: var(--wcc-light-muted, #667085);
    font-size: 12px;
}

#dashboardPage .sub-page .section,
#dashboardPage .sub-page .howto-panel,
#dashboardPage .sub-page .about-panel,
#dashboardPage .sub-page .mtd-report-panel,
#dashboardPage .sub-page .mtd-summary-card,
#dashboardPage .sub-page .mtd-weekly-matrix-section,
#dashboardPage .sub-page .forecast-insight-card,
#dashboardPage .sub-page .break-recommendation-panel,
#dashboardPage .sub-page .break-gantt-card,
#dashboardPage .sub-page .handoff-preview,
#dashboardPage .sub-page .action-log-form {
    border: 1px solid var(--wcc-card-border, #dce5f1);
    border-radius: 12px;
    background: var(--wcc-light-card, #ffffff);
    color: var(--wcc-light-text, #101828);
    box-shadow: var(--wcc-card-shadow, 0 8px 22px rgba(15, 23, 42, 0.07));
}

#dashboardPage .sub-page .section {
    margin-bottom: 14px;
    padding: 14px;
}

#dashboardPage .sub-page .section-header {
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 10px;
}

#dashboardPage .sub-page .section-header h3,
#dashboardPage .sub-page .howto-panel h3,
#dashboardPage .sub-page .about-panel h3,
#dashboardPage .sub-page .card h3 {
    color: var(--wcc-light-text, #101828);
    font-size: 15px;
    line-height: 1.2;
}

#dashboardPage .sub-page .eyebrow {
    color: var(--wcc-light-muted, #667085);
    font-size: 10px;
    letter-spacing: 0;
}

#dashboardPage .sub-page .card,
#dashboardPage .sub-page .cards .card,
#dashboardPage .sub-page .table-wrapper,
#dashboardPage .sub-page .controls {
    border: 1px solid var(--wcc-card-border, #dce5f1);
    border-radius: 10px;
    background: var(--wcc-light-card-soft, #f8fafc);
    color: var(--wcc-light-text, #101828);
    box-shadow: none;
}

#dashboardPage .sub-page .cards {
    gap: 10px;
}

#dashboardPage .sub-page .cards .card {
    min-height: 84px;
    padding: 11px 12px;
}

#dashboardPage .sub-page .cards .card p {
    margin: 5px 0 2px;
    font-size: clamp(18px, 2vw, 24px);
    line-height: 1.08;
}

#dashboardPage .sub-page .cards .card small,
#dashboardPage .sub-page .about-list span,
#dashboardPage .sub-page .howto-steps span,
#dashboardPage .sub-page .empty-state {
    color: var(--wcc-light-muted, #667085);
}

#dashboardPage .sub-page .controls,
#dashboardPage .sub-page .command-panel {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 190px), 1fr));
    gap: 10px;
    padding: 12px;
}

#dashboardPage .sub-page .control-group {
    min-width: 0;
}

#dashboardPage .sub-page .control-group label,
#dashboardPage .sub-page .form-group label,
#dashboardPage .sub-page .action-log-form label {
    color: var(--wcc-light-muted, #667085);
    font-size: 11px;
    font-weight: 800;
}

#dashboardPage .sub-page :is(input, select, textarea, .multi-filter-button) {
    min-height: 34px;
    border: 1px solid var(--wcc-card-border, #dce5f1);
    border-radius: 8px;
    background: var(--wcc-light-card, #ffffff);
    color: var(--wcc-light-text, #101828);
}

#dashboardPage .sub-page .inline,
#dashboardPage .sub-page .button-row,
#dashboardPage .sub-page .section-header-actions,
#dashboardPage .sub-page .dashboard-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

#dashboardPage .sub-page button,
#dashboardPage .sub-page .file-upload span {
    min-height: 32px;
    padding: 6px 10px;
    font-size: 12px;
}

#dashboardPage .sub-page .table-wrapper {
    overflow: hidden;
}

#dashboardPage .sub-page .table-scroll {
    max-width: 100%;
    border-radius: 9px;
}

#dashboardPage .sub-page table {
    min-width: max-content;
    width: 100%;
    border-collapse: collapse;
}

#dashboardPage .sub-page th {
    position: sticky;
    top: 0;
    z-index: 2;
    border-bottom: 1px solid var(--wcc-card-border, #dce5f1);
    background: #eef4fb;
    color: #475467;
    font-size: 11px;
    white-space: nowrap;
}

#dashboardPage .sub-page td {
    border-bottom: 1px solid rgba(216, 226, 239, 0.72);
    color: var(--wcc-light-text, #101828);
    font-size: 12px;
    vertical-align: top;
}

#dashboardPage .command-drilldown-grid,
#dashboardPage .help-playbook-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
    gap: 10px;
}

#dashboardPage .command-drilldown-card {
    display: grid;
    align-content: start;
    min-height: 96px;
    padding: 12px;
    text-align: left;
    border: 1px solid var(--wcc-card-border, #dce5f1);
    border-radius: 10px;
    background: var(--wcc-light-card-soft, #f8fafc);
    box-shadow: none;
}

#dashboardPage .command-drilldown-card:hover {
    border-color: rgba(37, 99, 235, 0.34);
    background: #eef4ff;
    transform: translateY(-1px);
}

#dashboardPage .command-drilldown-card strong {
    color: var(--wcc-light-text, #101828);
    font-size: 14px;
}

#dashboardPage .command-drilldown-card span,
#dashboardPage .command-drilldown-card small {
    color: var(--wcc-light-muted, #667085);
}

#dashboardPage .howto-layout,
#dashboardPage .about-layout {
    gap: 12px;
}

#dashboardPage .howto-panel,
#dashboardPage .about-panel {
    padding: 14px;
}

#dashboardPage .about-list {
    gap: 8px;
}

#dashboardPage .about-list li,
#dashboardPage .howto-steps li,
#dashboardPage .faq-list details {
    border: 1px solid var(--wcc-card-border, #dce5f1);
    border-radius: 9px;
    background: var(--wcc-light-card-soft, #f8fafc);
}

#dashboardPage .faq-list details {
    padding: 10px 12px;
}

#dashboardPage .faq-list summary {
    cursor: pointer;
    color: var(--wcc-light-text, #101828);
    font-weight: 800;
}

#dashboardPage .data-setup-danger-zone {
    border-color: rgba(185, 28, 28, 0.18);
    background: #fff7f7;
}

#dashboardPage .data-setup-danger-zone > summary {
    cursor: pointer;
}

#dashboardPage #breaksPage .coverage-command-center {
    grid-template-columns: 1fr;
}

#dashboardPage #breaksPage .coverage-control-section {
    border: 1px solid var(--wcc-card-border, #dce5f1);
    border-radius: 10px;
    background: var(--wcc-light-card, #ffffff);
    padding: 12px;
}

#dashboardPage #breaksPage .coverage-upload-section:not([open]) {
    padding-bottom: 8px;
}

.modal {
    padding: 18px;
}

.modal-content,
.queue-detail-modal,
.queue-influx-modal,
.queue-capacity-modal,
.forecast-interval-modal,
.break-optimization-modal,
.backup-modal,
.db-columns-modal,
.upload-alias-modal,
.data-source-sample-modal,
.database-schema-modal,
.user-modal,
.profile-modal,
.admin-notifications-modal,
.queue-rca-modal,
.coverage-cell-modal {
    display: flex;
    flex-direction: column;
    max-height: min(88vh, 920px);
    padding: 0;
    overflow: auto;
    border: 1px solid var(--wcc-card-border, #dce5f1);
    border-radius: 12px;
    background: var(--wcc-light-card, #ffffff);
    color: var(--wcc-light-text, #101828);
}

.modal-content > :not(.modal-header):not(.modal-actions) {
    margin-right: 16px;
    margin-left: 16px;
}

.modal-content > :first-child:not(.modal-header) {
    margin-top: 16px;
}

.modal-header {
    position: sticky;
    top: 0;
    z-index: 3;
    padding: 14px 16px;
    border-bottom: 1px solid var(--wcc-card-border, #dce5f1);
    background: var(--wcc-light-card, #ffffff);
}

.modal-header h3,
.modal-content > h3:first-child {
    margin: 0;
    color: var(--wcc-light-text, #101828);
    font-size: 17px;
}

.modal-content > h3:first-child {
    padding: 16px 16px 0;
}

.modal-help {
    color: var(--wcc-light-muted, #667085);
    font-size: 12px;
    line-height: 1.45;
}

.modal-content :is(.table-scroll, .queue-influx-body, .break-optimization-body, .rca-preview, .admin-notifications-list, .schema-map, .db-columns-list, .backup-table-list, #queueDetailBody) {
    min-height: 0;
    overflow: auto;
}

.modal-actions {
    position: sticky;
    bottom: 0;
    z-index: 3;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
    margin: 14px 0 0;
    padding: 12px 16px;
    border-top: 1px solid var(--wcc-card-border, #dce5f1);
    background: var(--wcc-light-card, #ffffff);
}

.modal-actions button,
.modal-header button {
    min-height: 32px;
    padding: 6px 10px;
    font-size: 12px;
}

.form-group,
.registration-section .form-group,
.upload-alias-form,
.break-optimization-toolbar .form-group {
    min-width: 0;
}

.modal-content :is(input, select, textarea) {
    width: 100%;
    min-height: 34px;
    border-radius: 8px;
}

.queue-rca-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    padding: 6px;
    border: 1px solid var(--wcc-card-border, #dce5f1);
    border-radius: 10px;
    background: var(--wcc-light-card-soft, #f8fafc);
}

.queue-rca-tabs button {
    min-height: 30px;
    padding: 5px 9px;
}

.rca-preview {
    white-space: pre-wrap;
    word-break: break-word;
}

html[data-theme="dark"] #dashboardPage .sub-page > .page-hero,
html[data-theme="dark"] #dashboardPage .sub-page .section,
html[data-theme="dark"] #dashboardPage .sub-page .howto-panel,
html[data-theme="dark"] #dashboardPage .sub-page .about-panel,
html[data-theme="dark"] #dashboardPage .sub-page .mtd-report-panel,
html[data-theme="dark"] #dashboardPage .sub-page .mtd-summary-card,
html[data-theme="dark"] #dashboardPage .sub-page .mtd-weekly-matrix-section,
html[data-theme="dark"] #dashboardPage .sub-page .forecast-insight-card,
html[data-theme="dark"] #dashboardPage .sub-page .break-recommendation-panel,
html[data-theme="dark"] #dashboardPage .sub-page .break-gantt-card,
html[data-theme="dark"] #dashboardPage .sub-page .handoff-preview,
html[data-theme="dark"] #dashboardPage .sub-page .action-log-form,
html[data-theme="dark"] #dashboardPage .sub-page .card,
html[data-theme="dark"] #dashboardPage .sub-page .cards .card,
html[data-theme="dark"] #dashboardPage .sub-page .table-wrapper,
html[data-theme="dark"] #dashboardPage .sub-page .controls,
html[data-theme="dark"] #dashboardPage .command-drilldown-card,
html[data-theme="dark"] #dashboardPage #breaksPage .coverage-control-section {
    border-color: rgba(148, 163, 184, 0.24);
    background: #111c2e;
    color: #eaf1fb;
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.18);
}

html[data-theme="dark"] #dashboardPage .sub-page :is(h2, h3, h4, strong, td, .card p, .command-drilldown-card strong, .faq-list summary) {
    color: #eaf1fb;
}

html[data-theme="dark"] #dashboardPage .sub-page :is(p, small, .eyebrow, .empty-state, .about-list span, .howto-steps span, th) {
    color: #aab8cc;
}

html[data-theme="dark"] #dashboardPage .sub-page :is(input, select, textarea, .multi-filter-button),
html[data-theme="dark"] .modal-content :is(input, select, textarea, pre) {
    border-color: rgba(148, 163, 184, 0.28);
    background: #0d1728;
    color: #eaf1fb;
}

html[data-theme="dark"] #dashboardPage .sub-page th,
html[data-theme="dark"] .queue-rca-tabs,
html[data-theme="dark"] #dashboardPage .about-list li,
html[data-theme="dark"] #dashboardPage .howto-steps li,
html[data-theme="dark"] #dashboardPage .faq-list details {
    border-color: rgba(148, 163, 184, 0.24);
    background: #0d1728;
}

html[data-theme="dark"] .modal-content,
html[data-theme="dark"] .modal-header,
html[data-theme="dark"] .modal-actions {
    border-color: rgba(148, 163, 184, 0.24);
    background: #111c2e;
    color: #eaf1fb;
}

html[data-theme="dark"] .modal-header h3,
html[data-theme="dark"] .modal-content > h3:first-child {
    color: #eaf1fb;
}

@media (max-width: 900px) {
    #dashboardPage .howto-layout,
    #dashboardPage .about-layout {
        grid-template-columns: 1fr;
    }

    .modal {
        padding: 10px;
    }

    .modal-content,
    .queue-detail-modal,
    .queue-influx-modal,
    .queue-capacity-modal,
    .forecast-interval-modal,
    .break-optimization-modal,
    .backup-modal,
    .db-columns-modal,
    .upload-alias-modal,
    .data-source-sample-modal,
    .database-schema-modal,
    .user-modal,
    .profile-modal,
    .admin-notifications-modal,
    .queue-rca-modal,
    .coverage-cell-modal {
        width: min(100%, 100vw - 20px);
        max-height: calc(100vh - 20px);
    }
}

/* Final table and capture polish */
html[data-theme="light"] {
    --table-head-bg: #eef4ff;
    --table-sticky-bg: #ffffff;
    --table-row-bg: #ffffff;
    --table-row-alt: #f8fafc;
    --table-row-hover: #eef4ff;
    --table-border: #dce5f1;
    --table-text: #101828;
    --table-muted: #667085;
}

html[data-theme="dark"] {
    --table-head-bg: #0f1b2d;
    --table-sticky-bg: #111c2e;
    --table-row-bg: #111c2e;
    --table-row-alt: #0d1728;
    --table-row-hover: rgba(96, 165, 250, 0.12);
    --table-border: rgba(148, 163, 184, 0.22);
    --table-text: #eaf1fb;
    --table-muted: #aab8cc;
}

:is(#dashboardPage, #adminPage, .modal-content) :is(.table-wrapper, .table-scroll) {
    border: 1px solid var(--table-border);
    background: var(--table-row-bg);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage, .modal-content) :is(.table-wrapper, .table-scroll) {
    box-shadow: 0 16px 32px rgba(0, 0, 0, 0.22);
}

:is(#dashboardPage, #adminPage, .modal-content) table {
    background: var(--table-row-bg);
    color: var(--table-text);
}

:is(#dashboardPage, #adminPage, .modal-content) :is(th, td) {
    border-bottom-color: var(--table-border);
}

:is(#dashboardPage, #adminPage, .modal-content) th {
    background: var(--table-head-bg) !important;
    color: var(--table-muted) !important;
    border-bottom: 1px solid var(--table-border);
}

:is(#dashboardPage, #adminPage, .modal-content) td {
    background: var(--table-row-bg);
    color: var(--table-text);
}

:is(#dashboardPage, #adminPage, .modal-content) tbody tr:nth-child(even) td {
    background: var(--table-row-alt);
}

:is(#dashboardPage, #adminPage, .modal-content) tbody tr:hover td {
    background: var(--table-row-hover);
    color: var(--table-text);
}

:is(#dashboardPage, #adminPage, .modal-content) :is(
    #dataTable,
    #breaksTable,
    #breakAgentTable,
    #mtdWeeklyMatrixTable,
    .interval-table
) :is(td:first-child, .interval-sticky-cell) {
    background: var(--table-sticky-bg);
    color: var(--table-text);
    border-right: 1px solid var(--table-border);
}

#dashboardPage :is(#dataTable, #breaksTable, #breakAgentTable, #mtdWeeklyMatrixTable, .interval-table) tbody tr:nth-child(even) :is(td:first-child, .interval-sticky-cell),
#adminPage :is(#dataTable, #breaksTable, #breakAgentTable, #mtdWeeklyMatrixTable, .interval-table) tbody tr:nth-child(even) :is(td:first-child, .interval-sticky-cell),
.modal-content :is(#dataTable, #breaksTable, #breakAgentTable, #mtdWeeklyMatrixTable, .interval-table) tbody tr:nth-child(even) :is(td:first-child, .interval-sticky-cell) {
    background: var(--table-sticky-bg);
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage, .modal-content) :is(
    .metric-positive,
    .metric-good,
    .success,
    .good,
    .safe,
    .trend-up
) {
    color: #86efac !important;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage, .modal-content) :is(
    .metric-negative,
    .metric-bad,
    .danger,
    .bad,
    .critical,
    .trend-down
) {
    color: #fca5a5 !important;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage, .modal-content) :is(
    .metric-warning,
    .warning,
    .watch,
    .partial
) {
    color: #fde68a !important;
}

html[data-theme="dark"] :is(#dashboardPage, #adminPage, .modal-content) button:not(.primary-btn):not(.danger-btn):not(.tab-btn):not(.nav-btn) {
    color: #eaf1fb;
}

body.capture-rendering {
    background: #f8fafc !important;
    color: #101828 !important;
}

body.capture-rendering :is(
    #queueCapacityCaptureArea,
    #queueInfluxCaptureArea,
    #forecastIntervalCaptureArea,
    #backlogSummaryCaptureArea,
    #priorityCheckerCaptureArea,
    .capture-area,
    .capture-panel
) {
    border: 1px solid #dce5f1 !important;
    background: #ffffff !important;
    color: #101828 !important;
    box-shadow: none !important;
}

body.capture-rendering :is(
    #queueCapacityCaptureArea,
    #queueInfluxCaptureArea,
    #forecastIntervalCaptureArea,
    #backlogSummaryCaptureArea,
    #priorityCheckerCaptureArea,
    .capture-area,
    .capture-panel
) :is(.card, .metric-card, .queue-card, .summary-card, .panel, .table-wrapper, .table-scroll) {
    border-color: #dce5f1 !important;
    background: #ffffff !important;
    color: #101828 !important;
    box-shadow: none !important;
}

body.capture-rendering :is(
    #queueCapacityCaptureArea,
    #queueInfluxCaptureArea,
    #forecastIntervalCaptureArea,
    #backlogSummaryCaptureArea,
    #priorityCheckerCaptureArea,
    .capture-area,
    .capture-panel
) :is(h1, h2, h3, h4, p, small, span, strong, label, td) {
    color: #101828 !important;
}

body.capture-rendering :is(
    #queueCapacityCaptureArea,
    #queueInfluxCaptureArea,
    #forecastIntervalCaptureArea,
    #backlogSummaryCaptureArea,
    #priorityCheckerCaptureArea,
    .capture-area,
    .capture-panel
) th {
    position: static !important;
    background: #e8f0ff !important;
    color: #182230 !important;
    border-color: #d8e2ef !important;
}

body.capture-rendering :is(
    #queueCapacityCaptureArea,
    #queueInfluxCaptureArea,
    #forecastIntervalCaptureArea,
    #backlogSummaryCaptureArea,
    #priorityCheckerCaptureArea,
    .capture-area,
    .capture-panel
) td {
    background: #ffffff !important;
    color: #101828 !important;
    border-color: #d8e2ef !important;
}

body.capture-rendering :is(
    #queueCapacityCaptureArea,
    #queueInfluxCaptureArea,
    #forecastIntervalCaptureArea,
    #backlogSummaryCaptureArea,
    #priorityCheckerCaptureArea,
    .capture-area,
    .capture-panel
) tbody tr:nth-child(even) td {
    background: #f8fafc !important;
}

html:not([data-theme="light"]) #dashboardPage #dataTable.dashboard-queue-table :is(th:first-child, td:first-child),
html[data-theme="dark"] #dashboardPage #dataTable.dashboard-queue-table :is(th:first-child, td:first-child),
html:not([data-theme="light"]) #dashboardPage #dataTable.interval-table :is(th:first-child, td:first-child, .interval-sticky-cell),
html[data-theme="dark"] #dashboardPage #dataTable.interval-table :is(th:first-child, td:first-child, .interval-sticky-cell),
html:not([data-theme="light"]) :is(#breaksTable, #breakAgentTable, #mtdWeeklyMatrixTable, #breakOptimizationTable) :is(th:first-child, td:first-child),
html[data-theme="dark"] :is(#breaksTable, #breakAgentTable, #mtdWeeklyMatrixTable, #breakOptimizationTable) :is(th:first-child, td:first-child) {
    background: #111c2e !important;
    color: #eaf1fb !important;
    border-color: rgba(148, 163, 184, 0.24) !important;
}

html:not([data-theme="light"]) #dashboardPage #dataTable.dashboard-queue-table tbody tr:nth-child(even) td:first-child,
html[data-theme="dark"] #dashboardPage #dataTable.dashboard-queue-table tbody tr:nth-child(even) td:first-child,
html:not([data-theme="light"]) #dashboardPage #dataTable.interval-table tbody tr:nth-child(even) :is(td:first-child, .interval-sticky-cell),
html[data-theme="dark"] #dashboardPage #dataTable.interval-table tbody tr:nth-child(even) :is(td:first-child, .interval-sticky-cell) {
    background: #0d1728 !important;
}

html:not([data-theme="light"]) #dashboardPage #dataTable.dashboard-queue-table tbody tr:hover td:first-child,
html[data-theme="dark"] #dashboardPage #dataTable.dashboard-queue-table tbody tr:hover td:first-child,
html:not([data-theme="light"]) #dashboardPage #dataTable.interval-table tbody tr:hover :is(td:first-child, .interval-sticky-cell),
html[data-theme="dark"] #dashboardPage #dataTable.interval-table tbody tr:hover :is(td:first-child, .interval-sticky-cell) {
    background: #16243a !important;
    color: #ffffff !important;
}

/* DEFCON playbook redesign */
.defcon-process-shell {
    display: grid;
    gap: 14px;
}

.defcon-severity-rail {
    display: grid;
    grid-template-columns: auto minmax(160px, 1fr) auto;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: linear-gradient(90deg, rgba(34, 197, 94, 0.12), rgba(245, 158, 11, 0.12), rgba(239, 68, 68, 0.12));
}

.defcon-rail-label {
    color: var(--text);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.defcon-rail-label.danger {
    color: var(--danger);
}

.defcon-rail-line {
    position: relative;
    height: 10px;
    border-radius: 999px;
    background: linear-gradient(90deg, #22c55e 0%, #38bdf8 24%, #facc15 48%, #f97316 72%, #ef4444 100%);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.3);
}

.defcon-rail-line::before,
.defcon-rail-line::after {
    content: "";
    position: absolute;
    top: -4px;
    width: 2px;
    height: 18px;
    background: rgba(255, 255, 255, 0.75);
}

.defcon-rail-line::before {
    left: 50%;
}

.defcon-rail-line::after {
    right: 0;
}

.defcon-level-grid {
    grid-template-columns: repeat(5, minmax(220px, 1fr));
    align-items: stretch;
}

.defcon-card {
    position: relative;
    display: grid;
    gap: 10px;
    padding: 14px;
    border-top: 0;
    border-left: 6px solid var(--defcon-color, var(--accent));
    background:
        linear-gradient(135deg, rgba(var(--defcon-rgb, 37, 99, 235), 0.13), transparent 42%),
        var(--panel);
    overflow: hidden;
}

.defcon-card::after {
    content: "";
    position: absolute;
    inset: auto 12px 12px auto;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: rgba(var(--defcon-rgb, 37, 99, 235), 0.12);
}

.defcon-card-head {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.defcon-icon {
    display: inline-grid;
    width: 34px;
    height: 34px;
    place-items: center;
    border: 1px solid rgba(var(--defcon-rgb, 37, 99, 235), 0.34);
    border-radius: 10px;
    background: rgba(var(--defcon-rgb, 37, 99, 235), 0.14);
}

.defcon-icon img {
    width: 18px;
    height: 18px;
    filter: var(--icon-filter, none);
}

.defcon-badge {
    border: 1px solid rgba(var(--defcon-rgb, 37, 99, 235), 0.34);
    background: rgba(var(--defcon-rgb, 37, 99, 235), 0.14);
    color: var(--defcon-color, var(--accent));
}

.defcon-card h3,
.defcon-card p,
.defcon-card dl {
    position: relative;
    z-index: 1;
}

.defcon-indicator-row {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 8px 10px;
    border: 1px solid rgba(var(--defcon-rgb, 37, 99, 235), 0.24);
    border-radius: 10px;
    background: rgba(var(--defcon-rgb, 37, 99, 235), 0.09);
}

.defcon-indicator-row span,
.defcon-indicator-row strong {
    color: var(--defcon-color, var(--accent));
    font-size: 11px;
    font-weight: 900;
}

.defcon-level-5 {
    --defcon-color: #16a34a;
    --defcon-rgb: 22, 163, 74;
}

.defcon-level-4 {
    --defcon-color: #0284c7;
    --defcon-rgb: 2, 132, 199;
}

.defcon-level-3 {
    --defcon-color: #ca8a04;
    --defcon-rgb: 202, 138, 4;
}

.defcon-level-2 {
    --defcon-color: #ea580c;
    --defcon-rgb: 234, 88, 12;
}

.defcon-level-1 {
    --defcon-color: #dc2626;
    --defcon-rgb: 220, 38, 38;
}

html[data-theme="dark"] .defcon-card {
    background:
        linear-gradient(135deg, rgba(var(--defcon-rgb, 37, 99, 235), 0.22), transparent 46%),
        #111c2e;
}

html[data-theme="dark"] .defcon-icon img {
    filter: invert(1) brightness(1.8);
}

html[data-theme="dark"] .defcon-level-5 {
    --defcon-color: #86efac;
}

html[data-theme="dark"] .defcon-level-4 {
    --defcon-color: #7dd3fc;
}

html[data-theme="dark"] .defcon-level-3 {
    --defcon-color: #fde68a;
}

html[data-theme="dark"] .defcon-level-2 {
    --defcon-color: #fdba74;
}

html[data-theme="dark"] .defcon-level-1 {
    --defcon-color: #fca5a5;
}

@media (max-width: 1400px) {
    .defcon-level-grid {
        grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    }
}

@media (max-width: 720px) {
    .defcon-severity-rail {
        grid-template-columns: 1fr;
    }

    .defcon-rail-line::before,
    .defcon-rail-line::after {
        display: none;
    }
}

/* Priority Queue Checker */
.priority-checker-card {
    display: grid;
    gap: 14px;
}

.priority-checker-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    align-items: start;
}

.priority-checker-head h3 {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 4px;
}

.priority-checker-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
    align-items: end;
}

.manual-hc-fallback {
    display: grid;
    gap: 5px;
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
}

.manual-hc-fallback input {
    width: 132px;
    min-height: 34px;
    border-radius: 10px;
}

.section-title-icon,
.button-icon {
    width: 16px;
    height: 16px;
    flex: 0 0 auto;
}

.priority-checker-kpis {
    display: grid;
    grid-template-columns: repeat(4, minmax(160px, 1fr));
    gap: 10px;
}

.priority-checker-kpis > div {
    display: grid;
    gap: 4px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: rgba(var(--accent-rgb), 0.06);
}

.priority-checker-kpis span,
.priority-checker-kpis small {
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
}

.priority-checker-kpis span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.priority-checker-kpis span img {
    width: 14px;
    height: 14px;
    opacity: 0.9;
}

.priority-checker-kpis strong {
    color: var(--text);
    font-size: 22px;
    line-height: 1;
}

.priority-checker-capture-area {
    background: var(--panel);
    color: var(--text);
}

.priority-capture-report-header {
    display: none;
    gap: 10px;
    padding: 6px 2px 18px;
}

.priority-capture-report-header h3 {
    margin: 0;
    color: var(--text);
    font-size: 30px;
    line-height: 1.08;
    letter-spacing: 0;
}

.priority-capture-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 18px;
    color: var(--muted);
    font-size: 12px;
}

.priority-capture-meta strong {
    color: var(--text);
}

.priority-capture-cards {
    display: none;
    gap: 10px;
    margin: 0 0 14px;
}

.priority-capture-card {
    position: relative;
    isolation: isolate;
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    grid-template-areas:
        "icon label"
        "icon value"
        "icon note";
    align-items: center;
    column-gap: 14px;
    row-gap: 3px;
    min-height: 88px;
    padding: 14px 18px 14px 20px;
    border: 1px solid var(--priority-card-border, rgba(148, 163, 184, 0.32));
    border-radius: 12px;
    background: var(--priority-card-bg, #f8fafc);
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.06);
    overflow: hidden;
}

.priority-capture-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
    background: var(--priority-card-accent, #2563eb);
}

.priority-capture-icon {
    grid-area: icon;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 10px;
    background: var(--priority-card-accent, #2563eb);
    z-index: 1;
}

.priority-capture-icon svg {
    width: 20px;
    height: 20px;
    color: #ffffff;
    opacity: 0.96;
}

.priority-capture-cards span:not(.priority-capture-icon),
.priority-capture-cards small {
    grid-area: label;
    color: #475569;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.priority-capture-cards small {
    grid-area: note;
    text-transform: none;
    letter-spacing: 0;
}

.priority-capture-cards strong {
    grid-area: value;
    color: #0f172a;
    font-size: 22px;
    line-height: 1.05;
}

.priority-capture-blue {
    --priority-card-accent: #2563eb;
    --priority-card-bg: #eff6ff;
    --priority-card-border: #bfdbfe;
    --priority-icon-bg: #dbeafe;
}

.priority-capture-indigo {
    --priority-card-accent: #4f46e5;
    --priority-card-bg: #eef2ff;
    --priority-card-border: #c7d2fe;
    --priority-icon-bg: #e0e7ff;
}

.priority-capture-red {
    --priority-card-accent: #dc2626;
    --priority-card-bg: #fef2f2;
    --priority-card-border: #fecaca;
    --priority-icon-bg: #fee2e2;
}

.priority-capture-green {
    --priority-card-accent: #16a34a;
    --priority-card-bg: #f0fdf4;
    --priority-card-border: #bbf7d0;
    --priority-icon-bg: #dcfce7;
}

.priority-capture-amber {
    --priority-card-accent: #d97706;
    --priority-card-bg: #fffbeb;
    --priority-card-border: #fde68a;
    --priority-icon-bg: #fef3c7;
}

.priority-capture-purple {
    --priority-card-accent: #7c3aed;
    --priority-card-bg: #f5f3ff;
    --priority-card-border: #ddd6fe;
    --priority-icon-bg: #ede9fe;
}

.priority-checker-capture-area.is-capturing {
    padding: 28px 30px;
    border-radius: 12px;
    background: #ffffff;
    color: #0f172a;
    box-sizing: border-box;
    overflow: hidden;
}

.priority-checker-capture-area.is-capturing .priority-capture-report-header {
    display: grid;
}

.priority-checker-capture-area.is-capturing .priority-capture-cards {
    display: grid;
    grid-template-columns: repeat(6, minmax(120px, 1fr));
    gap: 14px;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.priority-checker-capture-area.is-capturing .priority-action-col {
    display: none !important;
}

.priority-checker-capture-area.is-capturing .priority-capture-hide-col {
    display: none !important;
}

.priority-checker-capture-area.is-capturing .priority-checker-table-wrap {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    overflow: hidden;
}

.priority-checker-capture-area.is-capturing #priorityCheckerTable {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    table-layout: fixed;
}

.priority-checker-capture-area.is-capturing #priorityCheckerTable th,
.priority-checker-capture-area.is-capturing #priorityCheckerTable td {
    box-sizing: border-box;
    overflow-wrap: anywhere;
}

.priority-checker-table-wrap {
    border: 1px solid var(--table-border, var(--line));
    border-radius: 12px;
}

.priority-rank-pill {
    display: inline-flex;
    min-width: 42px;
    justify-content: center;
    padding: 4px 8px;
    border: 1px solid rgba(59, 130, 246, 0.28);
    border-radius: 999px;
    background: rgba(59, 130, 246, 0.12);
    color: #2563eb;
    font-size: 11px;
    font-weight: 900;
}

.priority-rank-pill.warning {
    border-color: rgba(245, 158, 11, 0.34);
    background: rgba(245, 158, 11, 0.14);
    color: #b45309;
}

.priority-rank-pill.critical {
    border-color: rgba(239, 68, 68, 0.34);
    background: rgba(239, 68, 68, 0.14);
    color: #dc2626;
}

html[data-theme="dark"] .priority-checker-kpis > div {
    background: rgba(96, 165, 250, 0.09);
}

html[data-theme="dark"] .priority-rank-pill {
    color: #93c5fd;
}

html[data-theme="dark"] .priority-rank-pill.warning {
    color: #fcd34d;
}

html[data-theme="dark"] .priority-rank-pill.critical {
    color: #fca5a5;
}

@media (max-width: 980px) {
    .priority-checker-head {
        grid-template-columns: 1fr;
    }

    .priority-checker-actions {
        justify-content: flex-start;
    }

    .priority-checker-kpis {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 560px) {
    .priority-checker-kpis {
        grid-template-columns: 1fr;
    }
}

/* Final visibility polish for theme controls and login contrast. */
.theme-toggle-icon {
    width: 18px !important;
    height: 18px !important;
    flex: 0 0 18px;
    border: 0 !important;
    border-radius: 0 !important;
    background: currentColor !important;
    -webkit-mask: url("icons/lucide/icons/moon.svg") center / 18px 18px no-repeat;
    mask: url("icons/lucide/icons/moon.svg") center / 18px 18px no-repeat;
}

html[data-theme="light"] .theme-toggle-icon {
    -webkit-mask-image: url("icons/lucide/icons/sun.svg");
    mask-image: url("icons/lucide/icons/sun.svg");
}

#loginPage .auth-card button:not(.danger-btn),
#loginPage .auth-card .theme-toggle,
#loginPage .auth-card .secondary,
#loginPage .auth-card .password-toggle {
    border-color: rgba(148, 163, 184, 0.34);
    background: rgba(15, 23, 42, 0.72);
    color: #f8fbff;
}

#loginPage .auth-card button:not(.danger-btn):hover,
#loginPage .auth-card .theme-toggle:hover,
#loginPage .auth-card .secondary:hover,
#loginPage .auth-card .password-toggle:hover {
    border-color: rgba(96, 165, 250, 0.62);
    background: rgba(37, 99, 235, 0.24);
    color: #ffffff;
}

#loginPage .auth-card #loginBtn:not(:disabled) {
    border-color: rgba(96, 165, 250, 0.72);
    background: linear-gradient(135deg, #2563eb, #1d4ed8);
    color: #ffffff;
}

#loginPage .auth-card #loginBtn:disabled {
    border-color: rgba(148, 163, 184, 0.28);
    background: rgba(15, 23, 42, 0.42);
    color: #cbd5e1;
    opacity: 1;
}

#dashboardPage .user-menu .theme-toggle,
#adminPage .user-menu .theme-toggle {
    color: #eaf1fb;
}

/* File-safe icons: avoid SVG masks/backgrounds that Chrome blocks on local file:// pages. */
.theme-toggle-icon,
#dashboardPage .theme-toggle-icon,
#adminPage .theme-toggle-icon,
.page .theme-toggle-icon,
#loginPage.active .auth-theme-toggle .theme-toggle-icon {
    position: relative;
    width: 18px !important;
    height: 18px !important;
    flex: 0 0 18px;
    border: 0 !important;
    border-radius: 50% !important;
    background: transparent !important;
    color: currentColor;
    -webkit-mask: none !important;
    mask: none !important;
    -webkit-mask-image: none !important;
    mask-image: none !important;
}

.theme-toggle-icon::before,
#dashboardPage .theme-toggle-icon::before,
#adminPage .theme-toggle-icon::before,
.page .theme-toggle-icon::before {
    content: "";
    position: absolute;
    inset: 2px;
    border: 2px solid currentColor;
    border-radius: 50%;
    background: transparent;
}

html[data-theme="dark"] .theme-toggle-icon::after {
    content: "";
    position: absolute;
    right: 1px;
    top: 0;
    width: 13px;
    height: 13px;
    border-radius: 50%;
    background: #0f172a;
}

html[data-theme="light"] .theme-toggle-icon::before {
    inset: 4px;
    background: currentColor;
    box-shadow:
        0 -7px 0 -5px currentColor,
        0 7px 0 -5px currentColor,
        7px 0 0 -5px currentColor,
        -7px 0 0 -5px currentColor,
        5px 5px 0 -5px currentColor,
        -5px 5px 0 -5px currentColor,
        5px -5px 0 -5px currentColor,
        -5px -5px 0 -5px currentColor;
}

html[data-theme="light"] .theme-toggle-icon::after {
    content: none;
}

#dashboardPage .user-menu-caret,
#adminPage .user-menu-caret,
.page .user-menu-caret {
    width: auto;
    height: auto;
    color: #c7d2e5;
    font-size: 13px;
    line-height: 1;
    background: transparent !important;
    -webkit-mask: none !important;
    mask: none !important;
    -webkit-mask-image: none !important;
    mask-image: none !important;
}

.help-nav-card {
    text-align: left;
}

.help-nav-card > span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    margin-bottom: 8px;
    border-radius: 10px;
    background: rgba(var(--accent-rgb), 0.14);
    color: var(--accent-strong);
    font-size: 12px;
    font-weight: 900;
}

.help-dashboard-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-top: 16px;
}

.help-wide-panel {
    grid-column: 1 / -1;
}

.help-step-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-top: 12px;
}

.help-step-grid > div {
    display: grid;
    gap: 5px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: var(--panel-soft);
}

.help-step-grid strong {
    color: var(--text);
    font-size: 13px;
}

.help-step-grid span {
    color: var(--muted);
    font-size: 12px;
    line-height: 1.45;
}

@media (max-width: 1100px) {
    .help-dashboard-grid,
    .help-step-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 720px) {
    .help-dashboard-grid,
    .help-step-grid {
        grid-template-columns: 1fr;
    }
}
