:root, html[data-theme=light] {
    /* Your custom variables */
    --primary-color: #039490;
    --secondary-color: #f6d6df;
    --background-color: faf0e6;
    --accent-color: #4bd4d4;
    --text-color: #fff;
    --text-color-inv: #000;
    --font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    /* Override Bootstrap variables for light theme */
    --bs-primary: var(--primary-color);
    --bs-secondary: var(--secondary-color);
    --bs-secondary-color: var(--secondary-color);
    --bs-secondary-color-rgb: 33, 37, 41;
    --bs-body-bg: var(--background-color);
    --bs-body-color: var(--text-color);
    --bs-font-family-base: var(--font-family);
    --bs-cu-btn-active-color: var(--bs-primary);
    --bs-cu-btn-active-bg: var(--accent-color);
    --bs-cu-btn-active-border-color: var(--bs-primary);
    --bs-btn-hover-bg: var(--accent-color);
    --bs-btn-border-color: var(--bs-primary);
    --bs-link-color: var(--bs-primary);
    --bs-link-color-rgb: rgb(from var(--bs-primary) r g b);
    --bs-link-decoration: underline;
    --bs-link-hover-color: rgb(from var(--bs-primary) calc(r * 1.2) calc(g * 1.2) calc(b * 1.2));
    --bs-link-hover-color-rgb: rgb(from var(--bs-link-hover-color) r g b);
    --bs-nav-underline-link-active-color: var(--text-color);
    /* Unchanged variables*/
    --bs-success: #198754;
    --bs-info: #0dcaf0;
    --bs-warning: #ffc107;
    --bs-danger: #dc3545;
    --bs-light: #f8f9fa;
    --bs-dark: #212529;
    --bs-primary-rgb: 13, 110, 253;
    --bs-secondary-rgb: 108, 117, 125;
    --bs-success-rgb: 25, 135, 84;
    --bs-info-rgb: 13, 202, 240;
    --bs-warning-rgb: 255, 193, 7;
    --bs-danger-rgb: 220, 53, 69;
    --bs-light-rgb: 248, 249, 250;
    --bs-dark-rgb: 33, 37, 41;
    --bs-primary-text-emphasis: #052c65;
    --bs-secondary-text-emphasis: #2b2f32;
    --bs-success-text-emphasis: #0a3622;
    --bs-info-text-emphasis: #055160;
    --bs-warning-text-emphasis: #664d03;
    --bs-danger-text-emphasis: #58151c;
    --bs-light-text-emphasis: #495057;
    --bs-dark-text-emphasis: #495057;
    --bs-primary-bg-subtle: #cfe2ff;
    --bs-secondary-bg-subtle: #e2e3e5;
    --bs-success-bg-subtle: #d1e7dd;
    --bs-info-bg-subtle: #cff4fc;
    --bs-warning-bg-subtle: #fff3cd;
    --bs-danger-bg-subtle: #f8d7da;
    --bs-light-bg-subtle: #fcfcfd;
    --bs-dark-bg-subtle: #ced4da;
    --bs-primary-border-subtle: #9ec5fe;
    --bs-secondary-border-subtle: #c4c8cb;
    --bs-success-border-subtle: #a3cfbb;
    --bs-info-border-subtle: #9eeaf9;
    --bs-warning-border-subtle: #ffe69c;
    --bs-danger-border-subtle: #f1aeb5;
    --bs-light-border-subtle: #e9ecef;
    --bs-dark-border-subtle: #adb5bd;
    --bs-white-rgb: 255, 255, 255;
    --bs-black-rgb: 0, 0, 0;
    --bs-font-sans-serif: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --bs-font-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --bs-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));
    --bs-body-font-family: var(--bs-font-sans-serif);
    --bs-body-font-size: 1rem;
    --bs-body-font-weight: 400;
    --bs-body-line-height: 1.5;
    --bs-body-color: #212529;
    --bs-body-color-rgb: 33, 37, 41;
    --bs-body-bg: #fff;
    --bs-body-bg-rgb: 255, 255, 255;
    --bs-emphasis-color: #000;
    --bs-emphasis-color-rgb: 0, 0, 0;
    --bs-secondary-bg: #e9ecef;
    --bs-secondary-bg-rgb: 233, 236, 239;
    --bs-tertiary-color: rgba(33, 37, 41, 0.5);
    --bs-tertiary-color-rgb: 33, 37, 41;
    --bs-tertiary-bg: #f8f9fa;
    --bs-tertiary-bg-rgb: 248, 249, 250;
    --bs-heading-color: inherit;
    --bs-code-color: #d63384;
    --bs-highlight-color: #212529;
    --bs-highlight-bg: #fff3cd;
    --bs-border-width: 1px;
    --bs-border-style: solid;
    --bs-border-color: var(--bs-primary);
    --bs-border-color-translucent: rgba(0, 0, 0, 0.175);
    --bs-border-radius: 0.375rem;
    --bs-border-radius-sm: 0.25rem;
    --bs-border-radius-lg: 0.5rem;
    --bs-border-radius-xl: 1rem;
    --bs-border-radius-xxl: 2rem;
    --bs-border-radius-2xl: var(--bs-border-radius-xxl);
    --bs-border-radius-pill: 50rem;
    --bs-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    --bs-box-shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    --bs-box-shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.175);
    --bs-box-shadow-inset: inset 0 1px 2px rgba(0, 0, 0, 0.075);
    --bs-focus-ring-width: 0.25rem;
    --bs-focus-ring-opacity: 0.25;
    --bs-focus-ring-color: rgba(13, 110, 253, 0.25);
    --bs-form-valid-color: #198754;
    --bs-form-valid-border-color: #198754;
    --bs-form-invalid-color: #dc3545;
    --bs-form-invalid-border-color: #dc3545;
}

[data-theme="dark"] {
    /* Your custom variables for dark theme */
    --primary-color: #0056b3;
    --background-color: #121212;
    --text-color: #ffffff;
    /* Override Bootstrap variables for dark theme */
    --bs-primary: var(--primary-color);
    --bs-body-bg: var(--background-color);
    --bs-body-color: var(--text-color);
    --bs-link-color: #5a9fd6; /* Adjust for dark theme */
    /* Ensure other elements like cards, modals adapt */
    --bs-card-bg: #1e1e1e;
    --bs-card-color: var(--text-color);
}

[data-theme="circle-up"] {
    /* Your custom variables for CircleUp theme */
    --primary-color: #039490; /* Example primary color for CircleUp */
    --background-color: faf0e6; /* Example background color for CircleUp */
    --text-color: #343434; /* Example text color for CircleUp */
    --accent-color: #4bd4d4;
    /* Override Bootstrap variables for CircleUp theme */
    --bs-primary: var(--primary-color);
    --bs-body-bg: var(--background-color);
    --bs-body-color: var(--text-color);
    --bs-link-color: #4bd4d4; /* Adjust for CircleUp theme */
    /* Ensure other elements like cards, modals adapt */
    --bs-card-bg: #ffffff;
    --bs-card-color: var(--text-color);
}

/* Apply to body and specific elements (as before) */
body {
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color);
    font-family: var(--bs-font-family-base);
}

small.text-muted {
    color: #a0a0a0 !important;
}

.gradient-bg {
    min-height: 100vh;
    background: linear-gradient(135deg, var(--bs-primary) 0%, var(--accent-color) 50%, var(--bs-secondary-color) 100%);
    /*background: linear-gradient(135deg, #0f766e 0%, #14b8a6 50%, #0ea5e9 100%);
     Teal-cyan diagonal – feels fresh and motivational for a goals app */
    /* Alternatives: 
       - Subtler: linear-gradient(to bottom right, #115e59, #0d9488, #0891b2);
       - Darker/vibrant: linear-gradient(135deg, #0c4a6e, #0369a1, #0891b2);
    */
    color: #fff; /* White text for contrast */
}

.glass-card {
    background: rgba(255, 255, 255, 0.62); /* Semi-transparent white/light */
    backdrop-filter: blur(12px); /* Frosted glass – main effect */
    -webkit-backdrop-filter: blur(12px); /* Safari/iOS support */
    border: 1px solid rgba(255, 255, 255, 0.18); /* Subtle bright edge */
    border-radius: 1.25rem; /* Bootstrap-ish rounded (20px) */
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15); /* Soft depth shadow */
    overflow: hidden; /* Keep children inside radius */
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

    .glass-card:hover {
        transform: translateY(-4px);
        box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2);
    }

/* Optional: Darker variant if gradient is light */
.glass-card-dark {
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.btn:hover {
    background: oklch(from var(--primary-color) calc(l + 0.15) c h / 0.12);
    color: var(--primary-color);
}

.btn-primary {
    background-color: var(--accent-color);
    color: white;
    border-color: white;
}

.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 var(--accent-color);
}

.btn-outline-primary {
    background-color: white;
    color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.btn-outline-primary:hover {
    background-color: var(--accent-color);
    color: white;
    border-color: var(--primary-color);
}

.btn-check:checked + .btn, .btn.active, .btn.show, .btn:first-child:active, :not(.btn-check) + .btn:active {
    color: var(--bs-cu-btn-active-color);
    background-color: var(--bs-cu-btn-active-bg) !important;
    border-color: var(--bs-cu-btn-active-border-color);
}

a, .btn-link {
    color: var(--bs-link-color);
    background-color: transparent;
    border: none;
}

a:hover, .btn-link:hover {
    color: var(--bs-link-hover-color);
}

input.form-control, input.form-control:focus {
    background-color: oklch(from var(--accent-color) calc(l + 0.15) c h / 0.12);
}

.top-row {
    background-color: var(--primary-color);
    border-bottom: 1px solid #d6d5d5;
}

/* Moved from MainLayout.razor.css for theming */
.sidebar {
    background-image: linear-gradient(180deg, rgb(5, 39, 103) 0%, #3a0647 70%);
}

/* Add overrides for other Bootstrap components if needed, e.g., .card, .navbar */
.toggle-filter .nav-link, .toggle-filter .nav-link.active {
    color: var(--text-color);
}

.progress-bar {
    --bs-progress-bar-bg: var(--primary-color);
}

.progress-circle {
    width: 150px;
    height: 150px;
    border-radius: 50%;
    background: conic-gradient(#0d6efd 0%, #e9ecef 0);
    display: flex;
    align-items: center;
    justify-content: center;
    --percent: 0;
}

.progress-value {
    font-size: 1.5rem;
    font-weight: bold;
    color: #0d6efd;
}

.card-text {
    color: var(--text-color-inv);
}

.btn-main {
    font-size:medium
}

.circle-card.border-primary {
    border: var(--bs-card-border-width) solid var(--accent-color) !important;    
}

.circle-card {
    --bs-card-border-color: var(--bs-border-color-translucent);
    --bs-card-border-radius: var(--bs-border-radius);
    border: var(--bs-card-border-width) solid var(--bs-card-border-color);
    border-radius: var(--bs-card-border-radius);
}
