html, body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    background: var(--theme-bg, #f8fafc);
    color: var(--theme-text, #1e293b);
    margin: 0;
    padding: 0;
}

a, .btn-link {
    color: #4a90d9;
}

.btn-primary {
    color: #fff;
    background-color: #4a90d9;
    border-color: #3a7bc8;
    border-radius: 8px;
    font-weight: 500;
}

.btn-primary:hover {
    background-color: #3a7bc8;
    border-color: #2f6ab5;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
    box-shadow: 0 0 0 3px rgba(74, 144, 217, 0.2);
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
    font-size: 0.85rem;
}

.blazor-error-boundary {
    background: #dc2626;
    padding: 1rem 1rem 1rem 1.5rem;
    color: white;
    border-radius: 8px;
    margin: 1rem;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.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;
}

/* Global Radzen overrides for production feel */
.rz-card {
    border-radius: 12px;
    border: 1px solid var(--theme-border, #e2e8f0);
    box-shadow: var(--theme-card-shadow, 0 1px 3px rgba(0,0,0,0.06));
}

.rz-tabview-nav {
    border-bottom: 2px solid var(--theme-border, #e2e8f0);
}

.rz-datatable {
    border-radius: 8px;
    overflow: hidden;
}

/* Theme-aware dashboard wrappers */
.kid-dashboard,
.parent-dashboard {
    min-height: 100vh;
    background: var(--theme-bg, #f8fafc);
    color: var(--theme-text, #1e293b);
    transition: background 0.3s ease, color 0.3s ease;
}

.kid-dashboard .rz-card,
.parent-dashboard .rz-card {
    background: var(--theme-surface, #fff);
    border-color: var(--theme-border, #e2e8f0);
}

.kid-dashboard .rz-tabview-nav,
.parent-dashboard .rz-tabview-nav {
    border-bottom-color: var(--theme-border, #e2e8f0);
}

.kid-dashboard .rz-tabview-content,
.parent-dashboard .rz-tabview-content {
    background: transparent;
}

.kid-dashboard .rz-tabview,
.parent-dashboard .rz-tabview {
    background: transparent;
}

.kid-dashboard .rz-datatable,
.parent-dashboard .rz-datatable,
.kid-dashboard .rz-data-grid,
.parent-dashboard .rz-data-grid {
    background: var(--theme-surface, #fff) !important;
    color: var(--theme-text, #1e293b) !important;
}

.kid-dashboard .rz-data-grid .rz-datatable-thead,
.parent-dashboard .rz-data-grid .rz-datatable-thead {
    background: var(--theme-surface, #fff) !important;
}

.kid-dashboard .rz-data-grid .rz-datatable-thead th,
.parent-dashboard .rz-data-grid .rz-datatable-thead th {
    background: var(--theme-border, #e2e8f0) !important;
    color: var(--theme-text, #1e293b) !important;
    border-color: var(--theme-border, #e2e8f0) !important;
    font-weight: 600 !important;
}

.kid-dashboard .rz-data-grid .rz-datatable-data td,
.parent-dashboard .rz-data-grid .rz-datatable-data td {
    background: var(--theme-surface, #fff) !important;
    color: var(--theme-text, #1e293b) !important;
    border-color: var(--theme-border, #e2e8f0) !important;
}

.kid-dashboard .rz-data-grid .rz-datatable-data tr:hover td,
.parent-dashboard .rz-data-grid .rz-datatable-data tr:hover td {
    background: var(--theme-border, #e2e8f0) !important;
}

.kid-dashboard .rz-pager,
.parent-dashboard .rz-pager {
    background: var(--theme-surface, #fff) !important;
    color: var(--theme-text, #1e293b) !important;
}

.kid-dashboard .rz-pager .rz-pager-element,
.parent-dashboard .rz-pager .rz-pager-element {
    color: var(--theme-text, #1e293b) !important;
}

/* Additional specificity for all table text elements */
.kid-dashboard .rz-datatable *,
.parent-dashboard .rz-datatable *,
.kid-dashboard .rz-data-grid *,
.parent-dashboard .rz-data-grid * {
    color: inherit !important;
}

/* Ensure buttons and links in tables maintain proper contrast */
.kid-dashboard .rz-datatable button,
.parent-dashboard .rz-datatable button,
.kid-dashboard .rz-data-grid button,
.parent-dashboard .rz-data-grid button {
    color: var(--theme-primary, #4a90d9) !important;
}

/* Ensure icons maintain proper visibility */
.kid-dashboard .rz-datatable .rzi,
.parent-dashboard .rz-datatable .rzi,
.kid-dashboard .rz-data-grid .rzi,
.parent-dashboard .rz-data-grid .rzi {
    color: var(--theme-text, #1e293b) !important;
}

.kid-dashboard h4, .kid-dashboard h5, .kid-dashboard h6,
.parent-dashboard h4, .parent-dashboard h5, .parent-dashboard h6 {
    color: var(--theme-text, #1e293b);
}

/* Additional Radzen DataTable/DataGrid overrides for dark mode */
.kid-dashboard .rz-datatable tbody tr,
.parent-dashboard .rz-datatable tbody tr,
.kid-dashboard .rz-datatable-data tr,
.parent-dashboard .rz-datatable-data tr {
    background: var(--theme-surface, #fff) !important;
    color: var(--theme-text, #1e293b) !important;
}

.kid-dashboard .rz-datatable tbody tr:hover,
.parent-dashboard .rz-datatable tbody tr:hover {
    background: var(--theme-border, #e2e8f0) !important;
}

.kid-dashboard .rz-datatable thead tr th,
.parent-dashboard .rz-datatable thead tr th {
    background: var(--theme-border, #e2e8f0) !important;
    color: var(--theme-text, #1e293b) !important;
    border-color: var(--theme-border, #e2e8f0) !important;
    font-weight: 600 !important;
}

.kid-dashboard .rz-datatable tbody tr td,
.parent-dashboard .rz-datatable tbody tr td {
    background: var(--theme-surface, #fff) !important;
    color: var(--theme-text, #1e293b) !important;
    border-color: var(--theme-border, #e2e8f0) !important;
}

/* Backrooms theme special effects */
@keyframes backrooms-flicker {
    0%, 95%, 100% { opacity: 1; }
    96% { opacity: 0.85; }
    97% { opacity: 0.95; }
    98% { opacity: 0.8; }
    99% { opacity: 1; }
}

@keyframes backrooms-hum {
    0%, 100% { filter: brightness(1); }
    50% { filter: brightness(1.02); }
}

@keyframes backrooms-grain {
    0%, 100% { background-position: 0 0; }
    25% { background-position: -5% -5%; }
    50% { background-position: 5% 5%; }
    75% { background-position: -3% 3%; }
}

.backrooms-active {
    animation: backrooms-flicker 8s infinite, backrooms-hum 4s infinite;
    position: relative;
}

.backrooms-active::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 9999;
    opacity: 0.03;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
    animation: backrooms-grain 0.5s steps(4) infinite;
}

.backrooms-active .rz-card {
    box-shadow: 0 2px 12px rgba(75, 63, 0, 0.2), inset 0 0 30px rgba(196, 160, 0, 0.05);
}

/* CRT scan lines for backrooms theme */
@keyframes crt-scanline {
    0% {
        transform: translateY(-100%);
    }
    100% {
        transform: translateY(100vh);
    }
}

.backrooms-active::after {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 10000;
    background: linear-gradient(
        to bottom,
        transparent 50%,
        rgba(0, 0, 0, 0.05) 51%
    );
    background-size: 100% 4px;
    animation: crt-scanline 8s linear infinite;
    opacity: 0.3;
}

/* Request approval buttons - ignore theme */
.request-approve-btn,
.request-deny-btn {
    color: white !important;
}

.request-approve-btn {
    background-color: #22c55e !important;
    border-color: #16a34a !important;
}

.request-approve-btn:hover {
    background-color: #16a34a !important;
    border-color: #15803d !important;
}

.request-deny-btn {
    background-color: #ef4444 !important;
    border-color: #dc2626 !important;
}

.request-deny-btn:hover {
    background-color: #dc2626 !important;
    border-color: #b91c1c !important;
}

/* Transaction amount chips */
.transaction-amount-chip {
    padding: 4px 12px;
    border-radius: 12px;
    font-weight: 600;
    display: inline-block;
}

.transaction-amount-positive {
    background-color: #15803d;
    color: #dcfce7;
}

.transaction-amount-negative {
    background-color: #b91c1c;
    color: #fee2e2;
}

/* Dark mode adjustments for amount chips - swap to light backgrounds */
[data-theme-mode="dark"] .transaction-amount-positive,
.backrooms-active .transaction-amount-positive {
    background-color: #dcfce7;
    color: #15803d;
}

[data-theme-mode="dark"] .transaction-amount-negative,
.backrooms-active .transaction-amount-negative {
    background-color: #fee2e2;
    color: #b91c1c;
}

/* All buttons should have white text regardless of theme */
.rz-button {
    color: white !important;
}

/* Exception: Light variant buttons should use theme color for text */
.rz-button.rz-variant-text,
.rz-button.rz-button-light {
    color: var(--theme-text, #1e293b) !important;
}
