@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

:root {
    --primary-light: #3498db;
    --primary-color: #3498db;
    --bg-light: #f8f9fa;
    --bg-dark: #2d3436;
    --card-dark: #1e2325;
    --text-muted: #6c757d;
}

body {
    font-family: 'Poppins', sans-serif;
    transition: background-color 0.3s, color 0.3s;
}

/* Light Mode Styles */
[data-bs-theme="light"] body {
    background-color: #f0f2f5;
    color: #212529;
}
[data-bs-theme="light"] .btn-primary {
    background-color: var(--primary-light);
    border-color: var(--primary-light);
}

/* Dark Mode Styles */
[data-bs-theme="dark"] body {
    background-color: var(--bg-dark);
    color: #e0e0e0;
}
[data-bs-theme="dark"] .btn-primary {
    background-color: var(--primary-light);
    border-color: var(--primary-light);
}

/* Dark Mode Component Overrides */
[data-bs-theme="dark"] .card {
    background-color: var(--card-dark);
    border-color: rgba(255,255,255,0.05);
    color: #e0e0e0;
}

[data-bs-theme="dark"] .card-header {
    border-bottom-color: rgba(255,255,255,0.1);
}

[data-bs-theme="dark"] .table {
    color: #e0e0e0;
    --bs-table-color: #e0e0e0;
    --bs-table-bg: transparent;
    --bs-table-border-color: rgba(255,255,255,0.1);
    --bs-table-striped-color: #e0e0e0;
    --bs-table-striped-bg: rgba(255, 255, 255, 0.05);
    --bs-table-hover-color: #e0e0e0;
    --bs-table-hover-bg: rgba(255, 255, 255, 0.075);
}

[data-bs-theme="dark"] .text-muted {
    color: #adb5bd !important;
}

[data-bs-theme="dark"] .modal-content {
    background-color: var(--card-dark);
    border-color: rgba(255,255,255,0.1);
    color: #e0e0e0;
}

[data-bs-theme="dark"] .modal-header,
[data-bs-theme="dark"] .modal-footer {
    border-color: rgba(255,255,255,0.1);
}

[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select {
    background-color: rgba(255,255,255,0.05);
    border-color: rgba(255,255,255,0.1);
    color: #e0e0e0;
}

[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-select:focus {
    background-color: rgba(255,255,255,0.1);
    border-color: var(--primary-light);
    color: #fff;
}

[data-bs-theme="dark"] .dropdown-menu {
    background-color: var(--card-dark);
    border-color: rgba(255,255,255,0.1);
}

[data-bs-theme="dark"] .dropdown-item {
    color: #e0e0e0;
}

[data-bs-theme="dark"] .dropdown-item:hover {
    background-color: rgba(255,255,255,0.1);
    color: #fff;
}

[data-bs-theme="dark"] .nav-tabs .nav-link {
    color: #adb5bd;
}

[data-bs-theme="dark"] .nav-tabs .nav-link.active {
    background-color: var(--card-dark);
    border-color: rgba(255,255,255,0.1) rgba(255,255,255,0.1) var(--card-dark);
    color: #fff;
}

[data-bs-theme="dark"] .list-group-item {
    background-color: var(--card-dark);
    border-color: rgba(255,255,255,0.1);
    color: #e0e0e0;
}

[data-bs-theme="dark"] .list-group-item-action:hover {
    background-color: rgba(255,255,255,0.05);
}

/* Common Utilities */
.text-primary-custom { color: var(--primary-light); }
.bg-primary-custom { background-color: var(--primary-light); }
.bg-primary-soft { background-color: rgba(52, 152, 219, 0.1); color: #3498db; }
.bg-success-soft { background-color: rgba(46, 204, 113, 0.1); color: #2ecc71; }
.bg-warning-soft { background-color: rgba(241, 196, 15, 0.1); color: #f1c40f; }
.bg-danger-soft { background-color: rgba(231, 76, 60, 0.1); color: #e74c3c; }
.bg-purple-soft { background-color: rgba(155, 89, 182, 0.1); color: #9b59b6; }

/* Logo Theme Switching */
[data-bs-theme="dark"] .logo-light { display: none !important; }
[data-bs-theme="dark"] .logo-dark { display: inline-block !important; }
[data-bs-theme="light"] .logo-dark { display: none !important; }
[data-bs-theme="light"] .logo-light { display: inline-block !important; }
[data-bs-theme="auto"] .logo-light { display: inline-block !important; } /* Default fallback */
[data-bs-theme="auto"] .logo-dark { display: none !important; }
