/* ======================================================= */
/* ==           Global & Base Element Styles            == */
/* ======================================================= */

:root {
    /* Global Brand & App Colors */
    --OTS-Green: #0cb14b; /*OTS Green from logo*/
    --OTS-Blue: #0071bc; /*OTS Blue from logo*/
    --bordergray: #e7e7e7; /* Light border gray */
}

html, body {
    height: 100%;
    /*font-family: 'Inter', sans-serif;*/
    /*font-family: 'Open Sans', sans-serif;*/
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    /*font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;*/
}

body {
    background-color: #f8f9fa;
}

h1:focus {
    outline: none;
}

a, .btn-link {
    color: #006bb7;
}

/* ======================================================= */
/* ==       Bootstrap Overrides & Form Styles           == */
/* ======================================================= */

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
    box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.card {
    margin-bottom: 1.5rem;
}

.form-label {
    font-weight: 500;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
    text-align: start;
}

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.readonly-output {
    background-color: #e9ecef;
}

.form-control.readonly-output:focus {
    box-shadow: none;
    border-color: #ced4da;
}

/* ======================================================= */
/* ==       Application Components & Utilities          == */
/* ======================================================= */

.content {
    padding-top: 1.1rem;
}

.otsblue {
    color: #0063a8;
}

/* --- Validation Styles --- */
.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

/* --- Blazor Error UI --- */
.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1TEAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

#blazor-error-ui {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

/* ======================================================= */
/* ==               NEW: SPINNER STYLES                 == */
/* ======================================================= */
.spinner-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6);
    z-index: 1050; /* Ensure it's on top */
    display: flex;
    justify-content: center;
    align-items: center;
}

    .spinner-overlay .spinner-border {
        width: 5rem;
        height: 5rem;
    }

/* ======================================================= */
/* ==           CONDENSED LAYOUT STYLES                 == */
/* ======================================================= */
/*.layout-condensed .card {
    margin-bottom: 0.5rem;
}

.layout-condensed .card-body, .layout-condensed .card-header {
    padding: 0.5rem 0.75rem;
}

.layout-condensed h5, .layout-condensed h6 {
    font-size: 1rem;
    margin-bottom: 0;
}

.layout-condensed .g-3 {
    --bs-gutter-x: 0.75rem;
    --bs-gutter-y: 0.5rem;
}

.layout-condensed .form-label {
    font-size: 0.8rem;
    margin-bottom: 0.1rem;
}

.layout-condensed .mb-2 {
    margin-bottom: 0.25rem !important;
}

.layout-condensed .mb-3 {
    margin-bottom: 0.5rem !important;
}*/

/* ======================================================= */
/* ==         HYPER-CONDENSED LAYOUT STYLES             == */
/* ======================================================= */
/*.layout-hyper-condensed .card {
    margin-bottom: 0.25rem;
}

.layout-hyper-condensed .card-body, .layout-hyper-condensed .card-header {
    padding: 0.25rem 0.5rem;
}

.layout-hyper-condensed h5, .layout-hyper-condensed h6 {
    font-size: 0.9rem;
    margin-bottom: 0;
}

.layout-hyper-condensed .g-3 {
    --bs-gutter-x: 0.5rem;
    --bs-gutter-y: 0.25rem;
}

.layout-hyper-condensed .form-label {
    font-size: 0.75rem;
    margin-bottom: 0;
}

.layout-hyper-condensed .form-check-label {
    font-size: 0.8rem;
}

.layout-hyper-condensed .mb-2, .layout-hyper-condensed .mb-3 {
    margin-bottom: 0.25rem !important;
}*/

/* ======================================================= */
/* ==            DARK MODE OVERRIDES                     == */
/* ======================================================= */

[data-bs-theme="dark"] {
    --OTS-Green: #2ed573;
    --OTS-Blue: #3ea6ff;
    --bordergray: #495057;

    /* --- Telerik / Kendo UI dark mode overrides --- */
    /* Surfaces & backgrounds */
    --kendo-color-app-surface: #212529;
    --kendo-color-on-app-surface: #dee2e6;
    --kendo-color-surface: #2b3035;
    --kendo-color-surface-alt: #212529;
    --kendo-color-subtle: #adb5bd;
    /* Borders */
    --kendo-color-border: rgba(222, 226, 230, 0.15);
    --kendo-color-border-alt: rgba(222, 226, 230, 0.25);
    /* Base (grid headers, buttons, toolbar) */
    --kendo-color-base: #343a40;
    --kendo-color-base-hover: #3d444b;
    --kendo-color-base-active: #495057;
    --kendo-color-base-subtle: #2b2f33;
    --kendo-color-base-subtle-hover: #343a40;
    --kendo-color-base-subtle-active: #3d444b;
    --kendo-color-base-emphasis: rgba(222, 226, 230, 0.25);
    --kendo-color-on-base: #dee2e6;
    --kendo-color-base-on-subtle: #dee2e6;
    --kendo-color-base-on-surface: #dee2e6;
    /* Primary */
    --kendo-color-primary: #3d8bfd;
    --kendo-color-primary-hover: #6ea8fe;
    --kendo-color-primary-active: #86b6fe;
    --kendo-color-primary-subtle: #0a2f64;
    --kendo-color-primary-subtle-hover: #0c3b7d;
    --kendo-color-primary-subtle-active: #0e4896;
    --kendo-color-on-primary: #000000;
    --kendo-color-primary-on-subtle: #9ec5fe;
    --kendo-color-primary-on-surface: #6ea8fe;
    --kendo-color-primary-emphasis: rgba(61, 139, 253, 0.5);
    /* Secondary */
    --kendo-color-secondary: #adb5bd;
    --kendo-color-secondary-hover: #bdc4cb;
    --kendo-color-secondary-active: #ced4da;
    --kendo-color-secondary-subtle: #343a40;
    --kendo-color-secondary-subtle-hover: #3d444b;
    --kendo-color-secondary-subtle-active: #495057;
    --kendo-color-on-secondary: #000000;
    --kendo-color-secondary-on-subtle: #dee2e6;
    --kendo-color-secondary-on-surface: #adb5bd;
    /* Success */
    --kendo-color-success: #479f76;
    --kendo-color-success-subtle: #0b3622;
    --kendo-color-on-success: #000000;
    --kendo-color-success-on-subtle: #a3cfbb;
    /* Error */
    --kendo-color-error: #e35d6a;
    --kendo-color-error-subtle: #58151c;
    --kendo-color-on-error: #000000;
    --kendo-color-error-on-subtle: #f1aeb5;
    /* Warning */
    --kendo-color-warning: #ffcd39;
    --kendo-color-warning-subtle: #4d3c05;
    --kendo-color-on-warning: #000000;
    --kendo-color-warning-on-subtle: #ffe69c;
    /* Info */
    --kendo-color-info: #3dd5f3;
    --kendo-color-info-subtle: #055160;
    --kendo-color-on-info: #000000;
    --kendo-color-info-on-subtle: #9eeaf9;
    /* Light / Dark / Inverse (swap them) */
    --kendo-color-light: #343a40;
    --kendo-color-light-hover: #3d444b;
    --kendo-color-light-active: #495057;
    --kendo-color-light-subtle: #1a1d21;
    --kendo-color-on-light: #dee2e6;
    --kendo-color-light-on-subtle: #adb5bd;
    --kendo-color-light-on-surface: #343a40;
    --kendo-color-dark: #f8f9fa;
    --kendo-color-dark-hover: #e9ecef;
    --kendo-color-dark-active: #dee2e6;
    --kendo-color-dark-subtle: #adb5bd;
    --kendo-color-on-dark: #212529;
    --kendo-color-dark-on-subtle: #212529;
    --kendo-color-dark-on-surface: #f8f9fa;
    --kendo-color-inverse: #f8f9fa;
    --kendo-color-inverse-hover: #e9ecef;
    --kendo-color-inverse-active: #dee2e6;
    --kendo-color-inverse-subtle: #adb5bd;
    --kendo-color-on-inverse: #212529;
    --kendo-color-inverse-on-subtle: #212529;
    --kendo-color-inverse-on-surface: #f8f9fa;
    /* Chart series — brighten for dark backgrounds */
    --kendo-color-series-a: #3d8bfd;
    --kendo-color-series-b: #8c68cd;
    --kendo-color-series-c: #79dfc1;
    --kendo-color-series-d: #479f76;
    --kendo-color-series-e: #e35d6a;
    --kendo-color-series-f: #ffcd39;
}

[data-bs-theme="dark"] body {
    background-color: #212529;
}

[data-bs-theme="dark"] a,
[data-bs-theme="dark"] .btn-link {
    color: #6cb4ff;
}

[data-bs-theme="dark"] .otsblue {
    color: #6cb4ff;
}

[data-bs-theme="dark"] .readonly-output {
    background-color: #343a40;
}

[data-bs-theme="dark"] .form-control.readonly-output:focus {
    border-color: #495057;
}

[data-bs-theme="dark"] .btn:focus,
[data-bs-theme="dark"] .btn:active:focus,
[data-bs-theme="dark"] .btn-link.nav-link:focus,
[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-check-input:focus {
    box-shadow: 0 0 0 0.1rem #212529, 0 0 0 0.25rem #258cfb;
}

[data-bs-theme="dark"] .darker-border-checkbox.form-check-input {
    border-color: #6c757d;
}

[data-bs-theme="dark"] #blazor-error-ui {
    color-scheme: dark only;
    background: #443300;
    color: #ffc107;
    box-shadow: 0 -1px 2px rgba(255, 255, 255, 0.1);
}

[data-bs-theme="dark"] .validation-message {
    color: #ff6b6b;
}

/* Reconnect modal */
[data-bs-theme="dark"] #components-reconnect-modal {
    background-color: #2b2f33;
    color: #dee2e6;
    box-shadow: 0 3px 6px 2px rgba(0, 0, 0, 0.5);
}