@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* ─── Design Tokens ──────────────────────────────────────────── */
:root {
    --bw-bg:           #070b14;
    --bw-sidebar:      #0d1117;
    --bw-surface:      #111827;
    --bw-surface-2:    #1a2438;
    --bw-border:       #1e2d40;
    --bw-green:        #10b981;
    --bw-green-dim:    rgba(16, 185, 129, 0.15);
    --bw-green-glow:   rgba(16, 185, 129, 0.08);
    --bw-amber:        #f59e0b;
    --bw-amber-dim:    rgba(245, 158, 11, 0.15);
    --bw-red:          #ef4444;
    --bw-red-dim:      rgba(239, 68, 68, 0.15);
    --bw-cyan:         #06b6d4;
    --bw-text:         #e2e8f0;
    --bw-text-dim:     #94a3b8;
    --bw-text-muted:   #64748b;
    --bw-font-body:    'Plus Jakarta Sans', sans-serif;
    --bw-font-mono:    'JetBrains Mono', monospace;
    --bw-radius:       6px;
    --bw-radius-lg:    10px;
    --bw-transition:   150ms ease;
    --bw-grid-dot:     rgba(255, 255, 255, 0.04);

    /* ── Bootstrap overrides ──────────────────────────────────── */

    --bs-body-bg:                    var(--bw-bg);
    --bs-body-color:                 var(--bw-text);
    --bs-body-font-family:           var(--bw-font-body);
    --bs-body-font-size:             0.9rem;
    --bs-body-line-height:           1.6;

    --bs-primary:                    var(--bw-green);
    --bs-primary-rgb:                16, 185, 129;
    --bs-secondary:                  var(--bw-text-muted);
    --bs-secondary-rgb:              100, 116, 139;
    --bs-success:                    var(--bw-green);
    --bs-success-rgb:                16, 185, 129;
    --bs-warning:                    var(--bw-amber);
    --bs-warning-rgb:                245, 158, 11;
    --bs-danger:                     var(--bw-red);
    --bs-danger-rgb:                 239, 68, 68;
    --bs-info:                       var(--bw-cyan);
    --bs-info-rgb:                   6, 182, 212;
    --bs-light:                      var(--bw-surface-2);
    --bs-dark:                       var(--bw-sidebar);

    --bs-border-color:               var(--bw-border);
    --bs-border-color-translucent:   rgba(30, 45, 64, 0.8);
    --bs-border-radius:              var(--bw-radius);
    --bs-border-radius-sm:           4px;
    --bs-border-radius-lg:           var(--bw-radius-lg);
    --bs-border-radius-xl:           12px;

    --bs-link-color:                 var(--bw-green);
    --bs-link-color-rgb:             16, 185, 129;
    --bs-link-hover-color:           #34d399;
    --bs-link-decoration:            none;

    /* cards */
    --bs-card-bg:                    var(--bw-surface);
    --bs-card-border-color:          var(--bw-border);
    --bs-card-border-radius:         var(--bw-radius-lg);
    --bs-card-cap-bg:                var(--bw-surface-2);
    --bs-card-color:                 var(--bw-text);

    /* tables */
    --bs-table-bg:                   transparent;
    --bs-table-color:                var(--bw-text);
    --bs-table-border-color:         var(--bw-border);
    --bs-table-striped-bg:           rgba(255, 255, 255, 0.025);
    --bs-table-hover-bg:             var(--bw-green-glow);
    --bs-table-active-bg:            var(--bw-green-dim);

    /* forms */
    --bs-form-control-bg:            var(--bw-surface);
    --bs-input-bg:                   var(--bw-surface);
    --bs-input-border-color:         var(--bw-border);
    --bs-input-color:                var(--bw-text);
    --bs-input-focus-border-color:   var(--bw-green);
    --bs-input-focus-box-shadow:     0 0 0 3px var(--bw-green-dim);
    --bs-input-placeholder-color:    var(--bw-text-muted);

    /* modals */
    --bs-modal-bg:                   var(--bw-surface);
    --bs-modal-border-color:         var(--bw-border);
    --bs-modal-content-bg:           var(--bw-surface);
    --bs-modal-header-border-color:  var(--bw-border);
    --bs-modal-footer-border-color:  var(--bw-border);
    --bs-modal-color:                var(--bw-text);

    /* dropdowns */
    --bs-dropdown-bg:                var(--bw-surface);
    --bs-dropdown-border-color:      var(--bw-border);
    --bs-dropdown-link-color:        var(--bw-text);
    --bs-dropdown-link-hover-bg:     var(--bw-green-dim);
    --bs-dropdown-link-hover-color:  var(--bw-green);
    --bs-dropdown-link-active-bg:    var(--bw-green);
    --bs-dropdown-divider-bg:        var(--bw-border);

    /* pagination */
    --bs-pagination-bg:              var(--bw-surface);
    --bs-pagination-border-color:    var(--bw-border);
    --bs-pagination-color:           var(--bw-text-dim);
    --bs-pagination-hover-bg:        var(--bw-surface-2);
    --bs-pagination-hover-color:     var(--bw-text);
    --bs-pagination-hover-border:    var(--bw-border);
    --bs-pagination-active-bg:       var(--bw-green);
    --bs-pagination-active-border:   var(--bw-green);
    --bs-pagination-disabled-bg:     var(--bw-surface);
    --bs-pagination-disabled-color:  var(--bw-text-muted);

    /* badges */
    --bs-badge-font-size:            0.7rem;
    --bs-badge-font-weight:          600;
    --bs-badge-border-radius:        4px;

    /* list-group */
    --bs-list-group-bg:              var(--bw-surface);
    --bs-list-group-border-color:    var(--bw-border);
    --bs-list-group-color:           var(--bw-text);
    --bs-list-group-hover-bg:        var(--bw-surface-2);
    --bs-list-group-active-bg:       var(--bw-green);
    --bs-list-group-active-border-color: var(--bw-green);

    /* nav tabs */
    --bs-nav-tabs-border-color:      var(--bw-border);
    --bs-nav-tabs-link-hover-border-color: var(--bw-border);
    --bs-nav-tabs-link-active-color: var(--bw-text);
    --bs-nav-tabs-link-active-bg:    var(--bw-surface);
    --bs-nav-tabs-link-active-border-color: var(--bw-border) var(--bw-border) var(--bw-surface);

    /* alert */
    --bs-alert-bg:                   var(--bw-surface);
    --bs-alert-border-color:         var(--bw-border);
    --bs-alert-color:                var(--bw-text);
}

/* ─── Light Theme ────────────────────────────────────────────── */
[data-theme="light"] {
    --bw-grid-dot:     rgba(0, 0, 0, 0.06);
    --bw-bg:           #f0f4f8;
    --bw-sidebar:      #ffffff;
    --bw-surface:      #ffffff;
    --bw-surface-2:    #f1f5f9;
    --bw-border:       #e2e8f0;
    --bw-green:        #059669;
    --bw-green-dim:    rgba(5, 150, 105, 0.1);
    --bw-green-glow:   rgba(5, 150, 105, 0.05);
    --bw-amber:        #d97706;
    --bw-amber-dim:    rgba(217, 119, 6, 0.1);
    --bw-red:          #dc2626;
    --bw-red-dim:      rgba(220, 38, 38, 0.1);
    --bw-cyan:         #0891b2;
    --bw-text:         #0f172a;
    --bw-text-dim:     #475569;
    --bw-text-muted:   #94a3b8;

    --bs-body-bg:                    #f0f4f8;
    --bs-body-color:                 #0f172a;
    --bs-primary:                    #059669;
    --bs-primary-rgb:                5, 150, 105;
    --bs-success:                    #059669;
    --bs-success-rgb:                5, 150, 105;
    --bs-warning:                    #d97706;
    --bs-warning-rgb:                217, 119, 6;
    --bs-danger:                     #dc2626;
    --bs-danger-rgb:                 220, 38, 38;
    --bs-info:                       #0891b2;
    --bs-info-rgb:                   8, 145, 178;
    --bs-light:                      #f1f5f9;
    --bs-dark:                       #0f172a;

    --bs-border-color:               #e2e8f0;
    --bs-border-color-translucent:   rgba(226, 232, 240, 0.8);

    --bs-link-color:                 #059669;
    --bs-link-color-rgb:             5, 150, 105;
    --bs-link-hover-color:           #047857;

    --bs-card-bg:                    #ffffff;
    --bs-card-border-color:          #e2e8f0;
    --bs-card-cap-bg:                #f8fafc;
    --bs-card-color:                 #0f172a;

    --bs-table-color:                #0f172a;
    --bs-table-border-color:         #e2e8f0;
    --bs-table-striped-bg:           rgba(0, 0, 0, 0.02);
    --bs-table-hover-bg:             rgba(5, 150, 105, 0.05);
    --bs-table-active-bg:            rgba(5, 150, 105, 0.1);

    --bs-form-control-bg:            #ffffff;
    --bs-input-bg:                   #ffffff;
    --bs-input-border-color:         #e2e8f0;
    --bs-input-color:                #0f172a;
    --bs-input-focus-border-color:   #059669;
    --bs-input-focus-box-shadow:     0 0 0 3px rgba(5, 150, 105, 0.12);
    --bs-input-placeholder-color:    #94a3b8;

    --bs-modal-bg:                   #ffffff;
    --bs-modal-border-color:         #e2e8f0;
    --bs-modal-content-bg:           #ffffff;
    --bs-modal-header-border-color:  #e2e8f0;
    --bs-modal-footer-border-color:  #e2e8f0;
    --bs-modal-color:                #0f172a;

    --bs-dropdown-bg:                #ffffff;
    --bs-dropdown-border-color:      #e2e8f0;
    --bs-dropdown-link-color:        #0f172a;
    --bs-dropdown-link-hover-bg:     rgba(5, 150, 105, 0.08);
    --bs-dropdown-link-hover-color:  #059669;
    --bs-dropdown-link-active-bg:    #059669;

    --bs-pagination-bg:              #ffffff;
    --bs-pagination-border-color:    #e2e8f0;
    --bs-pagination-color:           #475569;
    --bs-pagination-hover-bg:        #f1f5f9;
    --bs-pagination-hover-color:     #0f172a;
    --bs-pagination-active-bg:       #059669;
    --bs-pagination-active-border:   #059669;
    --bs-pagination-disabled-bg:     #f8fafc;
    --bs-pagination-disabled-color:  #94a3b8;

    --bs-list-group-bg:              #ffffff;
    --bs-list-group-border-color:    #e2e8f0;
    --bs-list-group-color:           #0f172a;
    --bs-list-group-hover-bg:        #f8fafc;

    --bs-nav-tabs-border-color:      #e2e8f0;
    --bs-nav-tabs-link-active-bg:    #ffffff;
    --bs-nav-tabs-link-active-border-color: #e2e8f0 #e2e8f0 #ffffff;
}

[data-theme="light"]::-webkit-scrollbar-thumb      { background: #cbd5e1; }
[data-theme="light"]::-webkit-scrollbar-thumb:hover{ background: #94a3b8; }

[data-theme="light"] body {
    background-color: #f0f4f8;
    color: #0f172a;
}

[data-theme="light"] .btn-close {
    filter: none;
}

[data-theme="light"] .modal-backdrop.show { opacity: 0.5; background: #0f172a; }

[data-theme="light"] .alert-success  { background-color: rgba(5,150,105,0.08);  border-color: rgba(5,150,105,0.25);  color: #065f46; }
[data-theme="light"] .alert-warning  { background-color: rgba(217,119,6,0.08);  border-color: rgba(217,119,6,0.25);  color: #92400e; }
[data-theme="light"] .alert-danger   { background-color: rgba(220,38,38,0.08);  border-color: rgba(220,38,38,0.25);  color: #991b1b; }
[data-theme="light"] .alert-info     { background-color: rgba(8,145,178,0.08);  border-color: rgba(8,145,178,0.25);  color: #155e75; }
[data-theme="light"] .alert-secondary{ background-color: #f8fafc;               border-color: #e2e8f0;               color: #475569; }

[data-theme="light"] .badge.bg-secondary, [data-theme="light"] .bg-secondary {
    background-color: #f1f5f9 !important;
    color: #475569 !important;
    border-color: #e2e8f0;
}

[data-theme="light"] .badge.bg-dark, [data-theme="light"] .bg-dark {
    background-color: #0f172a !important;
    color: #f8fafc !important;
}

[data-theme="light"] .table thead > tr > th {
    background-color: #f8fafc;
    color: #64748b;
}

[data-theme="light"] .nav-tabs .nav-link:hover {
    background: #f1f5f9;
    border-color: #e2e8f0 #e2e8f0 transparent;
}

[data-theme="light"] .nav-tabs .nav-link.active {
    color: #059669;
    background: #ffffff;
    border-color: #e2e8f0 #e2e8f0 #ffffff;
}

[data-theme="light"] .nav-pills .nav-link:hover  { background: #f1f5f9; color: #0f172a; }
[data-theme="light"] .nav-pills .nav-link.active  { background: rgba(5,150,105,0.1); color: #059669; }

[data-theme="light"] .text-muted     { color: #94a3b8 !important; }
[data-theme="light"] .text-secondary { color: #475569 !important; }
[data-theme="light"] .text-primary   { color: #059669 !important; }
[data-theme="light"] .text-success   { color: #059669 !important; }
[data-theme="light"] .text-warning   { color: #d97706 !important; }
[data-theme="light"] .text-danger    { color: #dc2626 !important; }
[data-theme="light"] .text-info      { color: #0891b2 !important; }

[data-theme="light"] hr { border-color: #e2e8f0; }

[data-theme="light"] pre {
    background: #f8fafc;
    border-color: #e2e8f0;
    color: #475569;
}

[data-theme="light"] .input-group-text {
    background-color: #f8fafc;
    border-color: #e2e8f0;
    color: #64748b;
}

[data-theme="light"] .dropdown-menu {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

[data-theme="light"] .accordion-button {
    background-color: #f8fafc;
    color: #0f172a;
}

[data-theme="light"] .accordion-button:not(.collapsed) {
    background-color: rgba(5, 150, 105, 0.08);
    color: #059669;
}

[data-theme="light"] .accordion-button::after { filter: none; }

[data-theme="light"] .list-group-item-action:hover,
[data-theme="light"] .list-group-item-action:focus { background-color: #f8fafc; }

[data-theme="light"] .page-link:hover {
    background-color: #f1f5f9;
    border-color: #cbd5e1;
    color: #0f172a;
}

[data-theme="light"] .progress { background-color: #e2e8f0; }

[data-theme="light"] #blazor-error-ui {
    background: #ffffff;
    border-top-color: #e2e8f0;
    box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.1);
    color: #0f172a;
}

[data-theme="light"] .blazor-error-boundary {
    background: rgba(220,38,38,0.08);
    border-color: rgba(220,38,38,0.25);
    color: #991b1b;
}

/* ─── Base ───────────────────────────────────────────────────── */
*, *::before, *::after {
    box-sizing: border-box;
}

html {
    height: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body {
    height: 100%;
    margin: 0;
    font-family: var(--bw-font-body);
    font-size: 0.9rem;
    color: var(--bw-text);
    background-color: var(--bw-bg);
    line-height: 1.6;
}

/* ─── Scrollbars ─────────────────────────────────────────────── */
::-webkit-scrollbar            { width: 6px; height: 6px; }
::-webkit-scrollbar-track      { background: transparent; }
::-webkit-scrollbar-thumb      { background: #1e3352; border-radius: 3px; }
::-webkit-scrollbar-thumb:hover{ background: #2d4a6e; }

/* ─── Typography ─────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
    color: var(--bw-text);
    font-weight: 600;
    letter-spacing: -0.025em;
    margin-bottom: 0.5rem;
    line-height: 1.2;
}

h1 { font-size: 1.75rem; }
h2 { font-size: 1.4rem; }
h3 { font-size: 1.15rem; }
h4 { font-size: 1rem; }
h5 { font-size: 0.9rem; }

h1:focus { outline: none; }

p { margin-bottom: 0.75rem; }

a, .btn-link {
    color: var(--bw-green);
    text-decoration: none;
    transition: color var(--bw-transition);
}

a:hover, .btn-link:hover {
    color: #34d399;
}

code, pre, .font-monospace {
    font-family: var(--bw-font-mono);
    font-size: 0.82rem;
}

pre {
    background: var(--bw-surface);
    border: 1px solid var(--bw-border);
    border-radius: var(--bw-radius);
    padding: 1rem;
    color: var(--bw-text-dim);
    overflow-x: auto;
}

/* ─── Buttons ────────────────────────────────────────────────── */
.btn {
    font-family: var(--bw-font-body);
    font-size: 0.82rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    border-radius: var(--bw-radius);
    padding: 0.4rem 0.9rem;
    transition: all var(--bw-transition);
    border-width: 1px;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus {
    box-shadow: 0 0 0 3px var(--bw-green-dim);
    outline: none;
}

.btn-primary {
    background-color: var(--bw-green);
    border-color: var(--bw-green);
    color: #070b14;
    font-weight: 600;
}

.btn-primary:hover, .btn-primary:focus {
    background-color: #0ea572;
    border-color: #0ea572;
    color: #070b14;
}

.btn-secondary {
    background-color: var(--bw-surface-2);
    border-color: var(--bw-border);
    color: var(--bw-text-dim);
}

.btn-secondary:hover {
    background-color: #243352;
    border-color: #2d4a6e;
    color: var(--bw-text);
}

.btn-outline-primary {
    border-color: var(--bw-green);
    color: var(--bw-green);
    background: transparent;
}

.btn-outline-primary:hover {
    background-color: var(--bw-green-dim);
    border-color: var(--bw-green);
    color: var(--bw-green);
}

.btn-outline-secondary {
    border-color: var(--bw-border);
    color: var(--bw-text-dim);
    background: transparent;
}

.btn-outline-secondary:hover {
    background-color: var(--bw-surface-2);
    color: var(--bw-text);
    border-color: #2d4a6e;
}

.btn-outline-success {
    border-color: var(--bw-green);
    color: var(--bw-green);
}

.btn-outline-success:hover {
    background-color: var(--bw-green-dim);
    color: var(--bw-green);
    border-color: var(--bw-green);
}

.btn-outline-warning {
    border-color: var(--bw-amber);
    color: var(--bw-amber);
}

.btn-outline-warning:hover {
    background-color: var(--bw-amber-dim);
    color: var(--bw-amber);
    border-color: var(--bw-amber);
}

.btn-outline-danger {
    border-color: var(--bw-red);
    color: var(--bw-red);
}

.btn-outline-danger:hover {
    background-color: var(--bw-red-dim);
    color: var(--bw-red);
    border-color: var(--bw-red);
}

.btn-danger {
    background-color: var(--bw-red);
    border-color: var(--bw-red);
    color: #fff;
}

.btn-sm {
    font-size: 0.75rem;
    padding: 0.25rem 0.6rem;
    border-radius: 4px;
}

.btn-lg {
    font-size: 0.95rem;
    padding: 0.55rem 1.2rem;
    border-radius: var(--bw-radius-lg);
}

/* ─── Cards ──────────────────────────────────────────────────── */
.card {
    background-color: var(--bw-surface);
    border: 1px solid var(--bw-border);
    border-radius: var(--bw-radius-lg);
    color: var(--bw-text);
}

.card-header {
    background-color: var(--bw-surface-2);
    border-bottom: 1px solid var(--bw-border);
    padding: 0.75rem 1.25rem;
    font-weight: 600;
    font-size: 0.85rem;
    letter-spacing: 0.01em;
}

.card-body {
    padding: 1.25rem;
}

.card-footer {
    background-color: var(--bw-surface-2);
    border-top: 1px solid var(--bw-border);
    padding: 0.75rem 1.25rem;
}

.card-title {
    font-size: 0.95rem;
    font-weight: 600;
    margin-bottom: 0.4rem;
}

/* ─── Tables ─────────────────────────────────────────────────── */
.table {
    color: var(--bw-text);
    border-color: var(--bw-border);
    font-size: 0.85rem;
    margin-bottom: 0;
    font-feature-settings: 'tnum' on;
}

.table > :not(caption) > * > * {
    background-color: transparent;
    border-bottom-color: var(--bw-border);
    padding: 0.6rem 0.75rem;
}

.table thead > tr > th {
    background-color: var(--bw-surface-2);
    color: var(--bw-text-muted);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border-bottom: 1px solid var(--bw-border);
    white-space: nowrap;
}

.table-hover > tbody > tr:hover > * {
    background-color: var(--bw-green-glow);
    color: var(--bw-text);
}

.table-striped > tbody > tr:nth-of-type(odd) > * {
    background-color: rgba(255, 255, 255, 0.02);
}

.table-bordered { border-color: var(--bw-border); }
.table-bordered > :not(caption) > * > * { border-color: var(--bw-border); }

/* ─── Forms ──────────────────────────────────────────────────── */
.form-control, .form-select, .form-check-input {
    background-color: var(--bw-surface);
    border: 1px solid var(--bw-border);
    border-radius: var(--bw-radius);
    color: var(--bw-text);
    font-family: var(--bw-font-body);
    font-size: 0.875rem;
    transition: border-color var(--bw-transition), box-shadow var(--bw-transition);
}

.form-control::placeholder {
    color: var(--bw-text-muted);
}

.form-control:focus, .form-select:focus, .form-check-input:focus {
    background-color: var(--bw-surface);
    border-color: var(--bw-green);
    color: var(--bw-text);
    box-shadow: 0 0 0 3px var(--bw-green-dim);
    outline: none;
}

.form-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%2364748b' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3E%3C/svg%3E");
}

.form-check-input {
    background-color: var(--bw-surface-2);
    border-color: var(--bw-border);
}

.form-check-input:checked {
    background-color: var(--bw-green);
    border-color: var(--bw-green);
}

.form-label {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--bw-text-dim);
    margin-bottom: 0.3rem;
    letter-spacing: 0.01em;
}

.form-text {
    color: var(--bw-text-muted);
    font-size: 0.75rem;
}

.input-group-text {
    background-color: var(--bw-surface-2);
    border-color: var(--bw-border);
    color: var(--bw-text-dim);
    font-size: 0.875rem;
}

.form-floating > .form-control-plaintext::placeholder,
.form-floating > .form-control::placeholder {
    color: var(--bw-text-muted);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder,
.form-floating > .form-control:focus::placeholder {
    text-align: start;
}

/* ─── Badges ─────────────────────────────────────────────────── */
.badge {
    font-family: var(--bw-font-mono);
    font-size: 0.68rem;
    font-weight: 500;
    letter-spacing: 0.02em;
    border-radius: 4px;
    padding: 0.25em 0.5em;
}

.badge.bg-primary, .bg-primary   { background-color: var(--bw-green) !important; color: #070b14 !important; }
.badge.bg-success, .bg-success   { background-color: var(--bw-green) !important; color: #070b14 !important; }
.badge.bg-warning, .bg-warning   { background-color: var(--bw-amber) !important; color: #070b14 !important; }
.badge.bg-danger,  .bg-danger    { background-color: var(--bw-red)   !important; color: #fff    !important; }
.badge.bg-secondary,.bg-secondary{ background-color: var(--bw-surface-2) !important; color: var(--bw-text-dim) !important; border: 1px solid var(--bw-border); }
.badge.bg-dark,     .bg-dark     { background-color: var(--bw-sidebar) !important; color: var(--bw-text-dim) !important; }
.badge.bg-info,     .bg-info     { background-color: var(--bw-cyan) !important; color: #070b14 !important; }

/* ─── Alerts ─────────────────────────────────────────────────── */
.alert {
    border-radius: var(--bw-radius-lg);
    border-width: 1px;
    font-size: 0.875rem;
    padding: 0.75rem 1rem;
}

.alert-success  { background-color: var(--bw-green-dim); border-color: rgba(16,185,129,0.3); color: #34d399; }
.alert-warning  { background-color: var(--bw-amber-dim); border-color: rgba(245,158,11,0.3); color: #fbbf24; }
.alert-danger   { background-color: var(--bw-red-dim);   border-color: rgba(239,68,68,0.3);  color: #f87171; }
.alert-info     { background-color: rgba(6,182,212,0.1); border-color: rgba(6,182,212,0.3);  color: #22d3ee; }
.alert-secondary{ background-color: var(--bw-surface-2); border-color: var(--bw-border);     color: var(--bw-text-dim); }

/* ─── Validation ─────────────────────────────────────────────── */
.valid.modified:not([type=checkbox])    { outline: 1px solid var(--bw-green); }
.invalid                                { outline: 1px solid var(--bw-red); }
.validation-message                     { color: #f87171; font-size: 0.78rem; margin-top: 0.2rem; }

/* ─── Nav tabs / pills ───────────────────────────────────────── */
.nav-tabs {
    border-bottom: 1px solid var(--bw-border);
    gap: 0.15rem;
}

.nav-tabs .nav-link {
    color: var(--bw-text-muted);
    border: 1px solid transparent;
    border-radius: var(--bw-radius) var(--bw-radius) 0 0;
    font-size: 0.82rem;
    font-weight: 500;
    padding: 0.5rem 0.9rem;
    transition: color var(--bw-transition), background var(--bw-transition);
}

.nav-tabs .nav-link:hover {
    color: var(--bw-text);
    border-color: var(--bw-border) var(--bw-border) transparent;
    background: var(--bw-surface-2);
}

.nav-tabs .nav-link.active {
    color: var(--bw-green);
    background: var(--bw-surface);
    border-color: var(--bw-border) var(--bw-border) var(--bw-surface);
}

.nav-pills .nav-link {
    color: var(--bw-text-dim);
    border-radius: var(--bw-radius);
    font-size: 0.82rem;
    font-weight: 500;
    padding: 0.4rem 0.85rem;
}

.nav-pills .nav-link:hover {
    background: var(--bw-surface-2);
    color: var(--bw-text);
}

.nav-pills .nav-link.active {
    background-color: var(--bw-green-dim);
    color: var(--bw-green);
}

/* ─── Pagination ─────────────────────────────────────────────── */
.pagination { gap: 2px; }

.page-link {
    background-color: var(--bw-surface);
    border-color: var(--bw-border);
    color: var(--bw-text-dim);
    font-size: 0.8rem;
    font-family: var(--bw-font-mono);
    border-radius: var(--bw-radius) !important;
    padding: 0.3rem 0.65rem;
    transition: all var(--bw-transition);
}

.page-link:hover {
    background-color: var(--bw-surface-2);
    color: var(--bw-text);
    border-color: #2d4a6e;
}

.page-item.active .page-link {
    background-color: var(--bw-green);
    border-color: var(--bw-green);
    color: #070b14;
    font-weight: 600;
}

.page-item.disabled .page-link {
    background-color: var(--bw-surface);
    color: var(--bw-text-muted);
    border-color: var(--bw-border);
    opacity: 0.5;
}

/* ─── Dropdowns ──────────────────────────────────────────────── */
.dropdown-menu {
    background-color: var(--bw-surface);
    border: 1px solid var(--bw-border);
    border-radius: var(--bw-radius-lg);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
    padding: 0.35rem;
    font-size: 0.85rem;
}

.dropdown-item {
    border-radius: var(--bw-radius);
    color: var(--bw-text-dim);
    padding: 0.45rem 0.75rem;
    transition: all var(--bw-transition);
}

.dropdown-item:hover, .dropdown-item:focus {
    background-color: var(--bw-green-dim);
    color: var(--bw-green);
}

.dropdown-item.active {
    background-color: var(--bw-green);
    color: #070b14;
}

.dropdown-divider { border-color: var(--bw-border); margin: 0.3rem 0; }

/* ─── Modals ─────────────────────────────────────────────────── */
.modal-content {
    background-color: var(--bw-surface);
    border: 1px solid var(--bw-border);
    border-radius: var(--bw-radius-lg);
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.6);
}

.modal-header {
    border-bottom: 1px solid var(--bw-border);
    padding: 1rem 1.25rem;
}

.modal-title { font-size: 1rem; font-weight: 600; }

.modal-footer {
    border-top: 1px solid var(--bw-border);
    padding: 0.75rem 1.25rem;
    gap: 0.5rem;
}

.modal-backdrop.show { opacity: 0.7; }

.btn-close {
    filter: invert(1) opacity(0.5);
}
.btn-close:hover {
    filter: invert(1) opacity(0.8);
}

/* ─── List group ─────────────────────────────────────────────── */
.list-group-item {
    background-color: var(--bw-surface);
    border-color: var(--bw-border);
    color: var(--bw-text);
    font-size: 0.875rem;
    transition: background var(--bw-transition);
}

.list-group-item-action:hover,
.list-group-item-action:focus {
    background-color: var(--bw-surface-2);
    color: var(--bw-text);
}

.list-group-item.active {
    background-color: var(--bw-green-dim);
    border-color: rgba(16, 185, 129, 0.3);
    color: var(--bw-green);
}

/* ─── Progress ───────────────────────────────────────────────── */
.progress {
    background-color: var(--bw-surface-2);
    border-radius: 999px;
    height: 6px;
}

.progress-bar {
    background-color: var(--bw-green);
    border-radius: 999px;
}

/* ─── Spinners ───────────────────────────────────────────────── */
.spinner-border { color: var(--bw-green); }
.spinner-grow   { color: var(--bw-green); }

/* ─── Accordion ──────────────────────────────────────────────── */
.accordion-item {
    background-color: var(--bw-surface);
    border: 1px solid var(--bw-border);
}

.accordion-button {
    background-color: var(--bw-surface-2);
    color: var(--bw-text);
    font-size: 0.875rem;
    font-weight: 500;
}

.accordion-button:not(.collapsed) {
    background-color: var(--bw-green-dim);
    color: var(--bw-green);
    box-shadow: none;
}

.accordion-button::after {
    filter: invert(0.6);
}

/* ─── Tooltips & Popovers ────────────────────────────────────── */
.tooltip .tooltip-inner {
    background-color: var(--bw-surface-2);
    border: 1px solid var(--bw-border);
    color: var(--bw-text);
    font-size: 0.78rem;
    border-radius: var(--bw-radius);
}

.popover {
    background-color: var(--bw-surface);
    border: 1px solid var(--bw-border);
}

.popover-header {
    background-color: var(--bw-surface-2);
    border-bottom: 1px solid var(--bw-border);
    color: var(--bw-text);
}

.popover-body { color: var(--bw-text-dim); }

/* ─── BudWatch Utility Components ───────────────────────────── */

/* Dark card with green-tinted left accent */
.bw-card {
    background: var(--bw-surface);
    border: 1px solid var(--bw-border);
    border-radius: var(--bw-radius-lg);
    padding: 1.25rem;
    position: relative;
    overflow: hidden;
}

.bw-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 3px;
    height: 100%;
    background: var(--bw-green);
    opacity: 0.25;
    transition: opacity var(--bw-transition);
}

.bw-card:hover::before { opacity: 1; }

.bw-card-accent-amber::before { background: var(--bw-amber); }
.bw-card-accent-red::before   { background: var(--bw-red);   }

/* Badges */
.bw-badge-green {
    display: inline-flex;
    align-items: center;
    gap: 0.3em;
    background: var(--bw-green-dim);
    color: var(--bw-green);
    border: 1px solid rgba(16,185,129,0.25);
    border-radius: 4px;
    font-family: var(--bw-font-mono);
    font-size: 0.7rem;
    font-weight: 500;
    padding: 0.2em 0.55em;
    letter-spacing: 0.02em;
}

.bw-badge-amber {
    display: inline-flex;
    align-items: center;
    gap: 0.3em;
    background: var(--bw-amber-dim);
    color: var(--bw-amber);
    border: 1px solid rgba(245,158,11,0.25);
    border-radius: 4px;
    font-family: var(--bw-font-mono);
    font-size: 0.7rem;
    font-weight: 500;
    padding: 0.2em 0.55em;
    letter-spacing: 0.02em;
}

.bw-badge-red {
    display: inline-flex;
    align-items: center;
    gap: 0.3em;
    background: var(--bw-red-dim);
    color: var(--bw-red);
    border: 1px solid rgba(239,68,68,0.25);
    border-radius: 4px;
    font-family: var(--bw-font-mono);
    font-size: 0.7rem;
    font-weight: 500;
    padding: 0.2em 0.55em;
    letter-spacing: 0.02em;
}

/* Large numeric stat display */
.bw-stat-value {
    font-family: var(--bw-font-mono);
    font-size: 2rem;
    font-weight: 600;
    color: var(--bw-text);
    letter-spacing: -0.06em;
    line-height: 1;
    font-feature-settings: 'tnum' on;
}

.bw-stat-value.bw-stat-green   { color: var(--bw-green); }
.bw-stat-value.bw-stat-amber   { color: var(--bw-amber); }
.bw-stat-value.bw-stat-red     { color: var(--bw-red);   }

.bw-stat-label {
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--bw-text-muted);
    margin-top: 0.25rem;
}

/* Section title with decorative rule */
.bw-section-title {
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--bw-text-muted);
    margin-bottom: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--bw-border);
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.bw-section-title::before {
    content: '';
    width: 3px;
    height: 0.8em;
    background: var(--bw-green);
    border-radius: 2px;
    flex-shrink: 0;
    opacity: 0.7;
}

.bw-section-title::after {
    content: '';
    flex: 1;
}

/* Inline data pill */
.bw-data-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35em;
    background: var(--bw-surface-2);
    border: 1px solid var(--bw-border);
    border-radius: 999px;
    font-family: var(--bw-font-mono);
    font-size: 0.72rem;
    padding: 0.15em 0.6em;
    color: var(--bw-text-dim);
}

/* ─── Blazor Error UI ────────────────────────────────────────── */
.blazor-error-boundary {
    background: var(--bw-red-dim);
    border: 1px solid rgba(239, 68, 68, 0.3);
    border-radius: var(--bw-radius);
    padding: 0.75rem 1rem;
    color: #fca5a5;
    font-size: 0.875rem;
}

.blazor-error-boundary::after {
    content: "A render error has occurred.";
}

#blazor-error-ui {
    background: var(--bw-surface);
    border-top: 1px solid var(--bw-border);
    box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.4);
    bottom: 0;
    box-sizing: border-box;
    color: var(--bw-text);
    display: none;
    left: 0;
    padding: 0.75rem 1.5rem;
    position: fixed;
    width: 100%;
    z-index: 2000;
    font-size: 0.875rem;
    align-items: center;
    gap: 1rem;
}

#blazor-error-ui .reload {
    color: var(--bw-green);
    font-weight: 600;
    margin-left: 0.5rem;
}

#blazor-error-ui .dismiss {
    cursor: pointer;
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--bw-text-muted);
    font-size: 1rem;
}

/* ─── Misc helpers ───────────────────────────────────────────── */
.text-muted      { color: var(--bw-text-muted) !important; }
.text-secondary  { color: var(--bw-text-dim)   !important; }
.text-primary    { color: var(--bw-green)       !important; }
.text-success    { color: var(--bw-green)       !important; }
.text-warning    { color: var(--bw-amber)       !important; }
.text-danger     { color: var(--bw-red)         !important; }
.text-info       { color: var(--bw-cyan)        !important; }

.bg-body         { background-color: var(--bw-bg)      !important; }
.bg-surface      { background-color: var(--bw-surface) !important; }

hr {
    border-color: var(--bw-border);
    opacity: 1;
}

.darker-border-checkbox.form-check-input {
    border-color: #2d4a6e;
}

/* Content top padding for page body */
.content {
    padding-top: 1.1rem;
}
