﻿/*
    BrandtInsights Bootstrap Overrides
    Place this file after Bootstrap in Client/wwwroot/css/bootstrap-overrides.css

    Example index.html order:
    <link href="css/bootstrap/bootstrap.min.css" rel="stylesheet" />
    <link href="css/bootstrap-overrides.css" rel="stylesheet" />
*/

:root,
[data-bs-theme="dark"] {
    color-scheme: dark;
    --bi-bg: #070B14;
    --bi-surface: #0D1321;
    --bi-surface-elevated: #121A2B;
    --bi-card: #0F1728;
    --bi-card-hover: #162033;
    --bi-border: rgba(255,255,255,.08);
    --bi-border-strong: rgba(255,255,255,.16);
    --bi-primary: #7C3AED;
    --bi-primary-hover: #9257FF;
    --bi-primary-soft: rgba(124,58,237,.14);
    --bi-primary-glow: rgba(124,58,237,.35);
    --bi-success: #22C55E;
    --bi-danger: #EF4444;
    --bi-warning: #F59E0B;
    --bi-info: #3B82F6;
    --bi-text: #F1F5F9;
    --bi-text-muted: #94A3B8;
    --bi-text-soft: #64748B;
    --bi-hover-bg: rgba(255,255,255,.04);
    --bi-sidebar-bg: #050913;
    --bi-sidebar-hover: rgba(255,255,255,.05);
    --bi-sidebar-active: linear-gradient(135deg,#7C3AED,#9257FF);
    --bi-navbar-bg: rgba(15,23,40,.75);
    --bi-navbar-border: rgba(255,255,255,.08);
    --bi-input-bg: rgba(255,255,255,.03);
    --bi-input-border: rgba(255,255,255,.08);
    --bi-input-focus: rgba(124,58,237,.35);
    --bi-chart-green: #22C55E;
    --bi-chart-red: #EF4444;
    --bi-chart-yellow: #F59E0B;
    --bi-chart-blue: #3B82F6;
    --bi-chart-purple: #A855F7;
    --bi-shadow-sm: 0 2px 8px rgba(0,0,0,.18);
    --bi-shadow: 0 8px 30px rgba(0,0,0,.30);
    --bi-shadow-lg: 0 20px 60px rgba(0,0,0,.45);
    --bi-gradient-primary: linear-gradient(135deg,#7C3AED,#9257FF);
    --bi-gradient-card: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
    --bi-glow-primary: 0 0 30px rgba(124,58,237,.35);
    --bi-glow-success: 0 0 20px rgba(34,197,94,.25);
    --bi-scrollbar-track: transparent;
    --bi-scrollbar-thumb: #1F2937;
    --bi-divider: rgba(255,255,255,.08);
    --bi-table-hover: rgba(255,255,255,.03);
    --bi-overlay: rgba(0,0,0,.5);
    --bi-success-bg: rgba(34,197,94,.12);
    --bi-danger-bg: rgba(239,68,68,.12);
    --bi-warning-bg: rgba(245,158,11,.12);
    --bs-body-bg: var(--bi-bg);
    --bs-body-color: var(--bi-text);
    --bs-primary: var(--bi-primary);
    --bs-secondary: #334155;
    --bs-success: var(--bi-success);
    --bs-danger: var(--bi-danger);
    --bs-warning: var(--bi-warning);
    --bs-info: var(--bi-info);
    --bs-border-color: var(--bi-border);
    --bs-card-bg: var(--bi-card);
    --bs-card-border-color: var(--bi-border);
    --bs-secondary-bg: var(--bi-surface-elevated);
    --bs-tertiary-bg: var(--bi-surface);
    --bs-link-color: #A78BFA;
    --bs-link-hover-color: #C4B5FD;
}

[data-bs-theme="light"] {
    color-scheme: light;
    --bi-bg: #F4F7FC;
    --bi-surface: #FFFFFF;
    --bi-surface-elevated: #F8FAFC;
    --bi-card: #FFFFFF;
    --bi-card-hover: #FCFCFD;
    --bi-border: #E2E8F0;
    --bi-border-strong: #CBD5E1;
    --bi-primary: #7C3AED;
    --bi-primary-hover: #6D28D9;
    --bi-primary-soft: rgba(124,58,237,.10);
    --bi-primary-glow: rgba(124,58,237,.20);
    --bi-success: #16A34A;
    --bi-danger: #DC2626;
    --bi-warning: #D97706;
    --bi-info: #2563EB;
    --bi-text: #0F172A;
    --bi-text-muted: #475569;
    --bi-text-soft: #64748B;
    --bi-hover-bg: rgba(15,23,42,.03);
    --bi-sidebar-bg: #FFFFFF;
    --bi-sidebar-hover: #F8FAFC;
    --bi-sidebar-active: linear-gradient(135deg,#7C3AED,#9257FF);
    --bi-navbar-bg: rgba(255,255,255,.85);
    --bi-navbar-border: #E2E8F0;
    --bi-input-bg: #FFFFFF;
    --bi-input-border: #E2E8F0;
    --bi-input-focus: rgba(124,58,237,.25);
    --bi-chart-green: #16A34A;
    --bi-chart-red: #DC2626;
    --bi-chart-yellow: #D97706;
    --bi-chart-blue: #2563EB;
    --bi-chart-purple: #7C3AED;
    --bi-shadow-sm: 0 2px 8px rgba(15,23,42,.05);
    --bi-shadow: 0 12px 30px rgba(15,23,42,.08);
    --bi-shadow-lg: 0 24px 60px rgba(15,23,42,.12);
    --bi-gradient-primary: linear-gradient(135deg,#7C3AED,#9257FF);
    --bi-gradient-card: linear-gradient(180deg, rgba(255,255,255,.7), rgba(255,255,255,0));
    --bi-glow-primary: 0 0 20px rgba(124,58,237,.18);
    --bi-glow-success: 0 0 12px rgba(22,163,74,.15);
    --bi-scrollbar-track: transparent;
    --bi-scrollbar-thumb: #CBD5E1;
    --bi-divider: #E2E8F0;
    --bi-table-hover: #F8FAFC;
    --bi-overlay: rgba(0,0,0,.25);
    --bi-success-bg: rgba(22,163,74,.10);
    --bi-danger-bg: rgba(220,38,38,.10);
    --bi-warning-bg: rgba(217,119,6,.10);
    --bs-body-bg: var(--bi-bg);
    --bs-body-color: var(--bi-text);
    --bs-primary: var(--bi-primary);
    --bs-secondary: #64748B;
    --bs-success: var(--bi-success);
    --bs-danger: var(--bi-danger);
    --bs-warning: var(--bi-warning);
    --bs-info: var(--bi-info);
    --bs-border-color: var(--bi-border);
    --bs-card-bg: var(--bi-card);
    --bs-card-border-color: var(--bi-border);
    --bs-secondary-bg: var(--bi-surface-elevated);
    --bs-tertiary-bg: var(--bi-surface);
    --bs-link-color: #6D28D9;
    --bs-link-hover-color: #5B21B6;
}

html,
body {
    min-height: 100%;
    background: radial-gradient(circle at top right, rgba(124, 58, 237, 0.16), transparent 32rem), radial-gradient(circle at top left, rgba(59, 130, 246, 0.08), transparent 28rem), var(--bs-body-bg);
    color: var(--bs-body-color);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* Bootstrap component overrides */
.card,
.modal-content,
.dropdown-menu,
.list-group-item,
.offcanvas,
.toast {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.015)), var(--bi-card);
    border: 1px solid var(--bi-border);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.35);
    color: var(--bs-body-color);
}

[data-bs-theme="light"] .card,
[data-bs-theme="light"] .modal-content,
[data-bs-theme="light"] .dropdown-menu,
[data-bs-theme="light"] .list-group-item,
[data-bs-theme="light"] .offcanvas,
[data-bs-theme="light"] .toast {
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
}

.card-header,
.card-footer,
.modal-header,
.modal-footer {
    background: transparent;
    border-color: var(--bi-border);
}

.navbar,
.sidebar,
.bi-sidebar {
    background: rgba(11, 15, 23, 0.86);
    border-color: var(--bi-border);
    backdrop-filter: blur(16px);
}

[data-bs-theme="light"] .navbar,
[data-bs-theme="light"] .sidebar,
[data-bs-theme="light"] .bi-sidebar {
    background: rgba(255, 255, 255, 0.86);
}

.nav-link {
    color: var(--bi-text-muted);
    border-radius: 0.65rem;
    transition: background-color 160ms ease, color 160ms ease, box-shadow 160ms ease;
}

    .nav-link:hover,
    .nav-link:focus {
        color: var(--bi-text);
        background: var(--bi-primary-soft);
    }

    .nav-link.active,
    .nav-pills .nav-link.active,
    .nav-pills .show > .nav-link {
        color: #FFFFFF !important;
        background: linear-gradient(135deg, var(--bi-primary), #4C1D95);
        box-shadow: 0 0 24px var(--bi-primary-glow);
    }

.btn {
    border-radius: 0.6rem;
    font-weight: 500;
    transition: transform 140ms ease, box-shadow 140ms ease, background-color 140ms ease;
}

    .btn:hover {
        transform: translateY(-1px);
    }

.btn-primary {
    --bs-btn-bg: var(--bi-primary);
    --bs-btn-border-color: var(--bi-primary);
    --bs-btn-hover-bg: var(--bi-primary-hover);
    --bs-btn-hover-border-color: var(--bi-primary-hover);
    --bs-btn-active-bg: #5B21B6;
    --bs-btn-active-border-color: #5B21B6;
    box-shadow: 0 0 22px var(--bi-primary-glow);
}

.btn-outline-secondary {
    --bs-btn-color: var(--bi-text);
    --bs-btn-border-color: var(--bi-border-strong);
    --bs-btn-hover-bg: var(--bi-surface-elevated);
    --bs-btn-hover-border-color: var(--bi-primary);
    --bs-btn-hover-color: var(--bi-text);
}

.form-control,
.form-select,
.input-group-text {
    background-color: var(--bi-surface);
    border-color: var(--bi-border);
    color: var(--bi-text);
    border-radius: 0.6rem;
}

    .form-control:focus,
    .form-select:focus {
        background-color: var(--bi-surface);
        color: var(--bi-text);
        border-color: var(--bi-primary);
        box-shadow: 0 0 0 0.2rem var(--bi-primary-soft);
    }

    .form-control::placeholder {
        color: var(--bi-text-soft);
    }

.table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--bi-text);
    --bs-table-border-color: var(--bi-border);
    --bs-table-hover-bg: var(--bi-card-hover);
    color: var(--bi-text);
}

    .table thead th {
        color: var(--bi-text-muted);
        font-size: 0.75rem;
        font-weight: 500;
        text-transform: none;
        border-bottom-color: var(--bi-border-strong);
    }

.badge {
    border-radius: 0.45rem;
    font-weight: 500;
}

.alert {
    border-radius: 0.75rem;
    border-color: var(--bi-border);
}

.alert-success {
    color: #86EFAC;
    background: rgba(34, 197, 94, 0.12);
    border-color: rgba(34, 197, 94, 0.35);
}

.alert-danger {
    color: #FCA5A5;
    background: rgba(239, 68, 68, 0.12);
    border-color: rgba(239, 68, 68, 0.35);
}

.progress {
    height: 0.45rem;
    background-color: var(--bi-surface-elevated);
    border-radius: 999px;
}

.progress-bar {
    background: linear-gradient(90deg, var(--bi-primary), var(--bi-primary-hover));
}

/* BrandtInsights helper classes */
.bi-app-shell {
    min-height: 100vh;
    background: transparent;
}

.bi-card {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.015)), var(--bi-card);
    border: 1px solid var(--bi-border);
    border-radius: 1rem;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.28);
}

.bi-card-hover:hover {
    background-color: var(--bi-card-hover);
    border-color: var(--bi-border-strong);
}

.bi-gradient-primary {
    background: linear-gradient(135deg, var(--bi-primary), #9257FF);
}

.bi-gradient-success {
    background: linear-gradient(135deg, var(--bi-success), #16A34A);
}

.bi-gradient-danger {
    background: linear-gradient(135deg, var(--bi-danger), #DC2626);
}

.bi-muted {
    color: var(--bi-text-muted) !important;
}

.bi-positive {
    color: var(--bi-success) !important;
}

.bi-negative {
    color: var(--bi-danger) !important;
}

.bi-icon-box {
    width: 2.25rem;
    height: 2.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.65rem;
    color: #FFFFFF;
    background: linear-gradient(135deg, var(--bi-primary), #4C1D95);
    box-shadow: 0 0 20px var(--bi-primary-glow);
}

.themetoggler {
    font-size: 1rem;
}
/* Slim scrollbar */
* {
    scrollbar-width: thin;
    scrollbar-color: var(--bi-border-strong) transparent;
}

    *::-webkit-scrollbar {
        width: 8px;
        height: 8px;
    }

    *::-webkit-scrollbar-track {
        background: transparent;
    }

    *::-webkit-scrollbar-thumb {
        background: var(--bi-border-strong);
        border-radius: 999px;
    }

        *::-webkit-scrollbar-thumb:hover {
            background: var(--bi-primary);
        }
