/* Custom styles for Home Buyer Readiness Score application - Blue and Gold Theme */

:root {
    /* Professional Blue and Gold Color Palette with Teal Accents */
    --primary-blue: #0B3A83;
    --primary-blue-light: #1F6FEB;
    --primary-blue-dark: #0A3272;
    --accent-gold: #F5C518;
    --accent-gold-light: #F5C518;
    --accent-gold-dark: #E1B512;
    --accent-teal: #009688;
    --accent-teal-light: #26A69A;
    --accent-teal-dark: #00695C;
    --background-blue: #0B1220;
    --background-blue-light: #23324A;
    --text-gold: #F5C518;
    --text-blue-light: #F8FAFC;
    --text-ink: #0F172A;
    
    /* FORCE Override ALL Bootstrap purple/violet colors */
    --bs-primary: #0B3A83 !important;
    --bs-primary-rgb: 11, 58, 131 !important;
    --bs-secondary: #F5C518 !important;
    --bs-success: #F5C518 !important;
    --bs-info: #009688 !important;
    --bs-warning: #F5C518 !important;
    --bs-light: #F8FAFC !important;
    --bs-dark: #0B1220 !important;
}

/* Override Bootstrap variables for blue and gold theme */
body {
    background-color: var(--background-blue) !important;
    color: var(--text-blue-light) !important;
}

/* AGGRESSIVE Bootstrap overrides - NO PURPLE ANYWHERE */
.text-primary, .link-primary {
    color: var(--accent-gold) !important;
}

.text-secondary, .link-secondary {
    color: var(--text-blue-light) !important;
}

.text-info, .link-info {
    color: var(--accent-gold) !important;
}

.text-warning, .link-warning {
    color: var(--accent-gold) !important;
}

.text-success, .link-success {
    color: var(--accent-gold) !important;
}

.border-primary {
    border-color: var(--accent-gold) !important;
}

.border-secondary {
    border-color: var(--primary-blue) !important;
}

.bg-primary {
    background-color: var(--primary-blue) !important;
    color: var(--accent-gold) !important;
}

.bg-secondary {
    background-color: var(--background-blue-light) !important;
    color: var(--text-blue-light) !important;
}

/* Force all links to be gold, never purple */
a, a:hover, a:focus, a:active, a:visited {
    color: var(--accent-gold) !important;
    text-decoration: none;
}

/* Use teal accents to soften harsh whites and make easier on eyes */
.card-body {
    background-color: rgba(0, 150, 136, 0.08) !important; /* More visible teal background */
}

.form-control, .form-select {
    background-color: rgba(0, 150, 136, 0.12) !important;
    border-color: rgba(0, 150, 136, 0.3) !important;
    color: var(--text-blue-light) !important;
}

.form-control:focus, .form-select:focus {
    background-color: rgba(0, 150, 136, 0.18) !important;
    border-color: var(--accent-teal) !important;
    box-shadow: 0 0 0 0.2rem rgba(0, 150, 136, 0.35) !important;
    color: var(--text-blue-light) !important;
}

/* Ensure placeholder text is visible */
.form-control::placeholder, .form-select::placeholder {
    color: rgba(248, 250, 252, 0.6) !important;
    opacity: 1 !important;
}

/* Ensure input labels and form text are visible */
.form-label, .form-text, label {
    color: var(--text-blue-light) !important;
}

/* Fix any input type variations */
input[type="text"], input[type="email"], input[type="number"], 
input[type="tel"], input[type="password"], textarea {
    color: var(--text-blue-light) !important;
    background-color: rgba(0, 150, 136, 0.12) !important;
}

/* Fix button spacing on congratulations screen */
.next-steps-cta .btn {
    margin-bottom: 15px !important;
    margin-right: 10px !important;
}

/* Ensure buttons don't overlap on mobile */
@media (max-width: 768px) {
    .next-steps-cta .btn {
        margin-bottom: 20px !important;
        margin-right: 0 !important;
        width: 100%;
        display: block;
    }
}

/* Soften modal and container backgrounds */
.modal-content {
    background-color: rgba(0, 150, 136, 0.06) !important;
}

/* Add visible teal accents to tables and lists */
.table tbody tr:hover {
    background-color: rgba(0, 150, 136, 0.15) !important;
}

/* Make navbar and headers use teal accents */
.navbar {
    background: linear-gradient(135deg, var(--primary-blue), var(--accent-teal)) !important;
}

/* Add teal to score components and highlights */
.score-component {
    border-left: 4px solid var(--accent-teal) !important;
}

/* Teal borders for cards */
.card {
    border: 2px solid rgba(0, 150, 136, 0.2) !important;
}

/* Secondary buttons get teal styling */
.btn-secondary {
    background-color: var(--accent-teal) !important;
    border-color: var(--accent-teal) !important;
    color: white !important;
}

.btn-secondary:hover {
    background-color: var(--accent-teal-dark) !important;
    border-color: var(--accent-teal-dark) !important;
}

/* Info elements use teal */
.alert-info {
    background-color: rgba(0, 150, 136, 0.15) !important;
    border-color: var(--accent-teal) !important;
    color: var(--accent-teal-dark) !important;
}

/* Add teal to progress bars and indicators */
.progress-bar {
    background: linear-gradient(90deg, var(--accent-teal), var(--accent-teal-light)) !important;
}

/* Teal accents for badges and labels */
.badge.bg-info {
    background-color: var(--accent-teal) !important;
}

/* Use teal for list group hover states */
.list-group-item:hover {
    background-color: rgba(0, 150, 136, 0.12) !important;
}

/* Force all Bootstrap buttons to use our theme */
.btn-outline-primary {
    color: var(--accent-gold) !important;
    border-color: var(--accent-gold) !important;
}

.btn-outline-primary:hover {
    background-color: var(--accent-gold) !important;
    border-color: var(--accent-gold) !important;
    color: var(--primary-blue-dark) !important;
}

/* Card enhancements */
.card {
    border: 2px solid var(--accent-gold);
    border-radius: 8px;
    background-color: var(--background-blue-light) !important;
    box-shadow: 0 4px 12px rgba(251, 191, 36, 0.2);
}

.card-header {
    background: linear-gradient(135deg, var(--primary-blue), var(--primary-blue-dark)) !important;
    border-bottom: 2px solid var(--accent-gold);
    border-radius: 6px 6px 0 0 !important;
    color: var(--accent-gold) !important;
}

.card-body {
    background-color: var(--background-blue-light) !important;
    color: var(--text-blue-light) !important;
}

/* Navbar styling */
.navbar-dark {
    background: linear-gradient(135deg, var(--primary-blue-dark), var(--primary-blue)) !important;
}

.navbar-brand, .nav-link {
    color: var(--accent-gold) !important;
}

.navbar-brand:hover, .nav-link:hover {
    color: var(--accent-gold-light) !important;
}

/* Form styling */
.form-control, .form-select {
    background-color: var(--background-blue-light) !important;
    border: 2px solid var(--primary-blue-light) !important;
    color: var(--text-blue-light) !important;
}

.form-control:focus, .form-select:focus {
    border-color: var(--accent-gold) !important;
    border-width: 2px !important;
    box-shadow: 0 0 0 0.3rem rgba(251, 191, 36, 0.4) !important;
    background-color: var(--background-blue-light) !important;
}

.form-label {
    font-weight: 500;
    margin-bottom: 0.5rem;
    color: var(--text-blue-light) !important;
}

.form-text {
    color: var(--text-blue-light) !important;
    opacity: 0.8;
}

/* Button styling with blue and gold theme */
.btn-primary {
    background: linear-gradient(135deg, var(--primary-blue), var(--primary-blue-light)) !important;
    border-color: var(--primary-blue) !important;
    color: var(--accent-gold) !important;
    font-weight: 600;
}

.btn-primary:hover {
    background: linear-gradient(135deg, var(--primary-blue-dark), var(--primary-blue)) !important;
    border-color: var(--accent-gold) !important;
    color: var(--accent-gold-light) !important;
}

.btn-secondary {
    background-color: var(--background-blue) !important;
    border-color: var(--text-blue-light) !important;
    color: var(--text-blue-light) !important;
}

.btn-info {
    background: linear-gradient(135deg, var(--accent-gold), var(--accent-gold-light)) !important;
    border-color: var(--accent-gold) !important;
    color: var(--primary-blue-dark) !important;
    font-weight: 600;
}

.btn-info:hover {
    background: linear-gradient(135deg, var(--accent-gold-dark), var(--accent-gold)) !important;
    color: var(--primary-blue-dark) !important;
}

/* Score display styling */
.score-display {
    font-size: 3rem;
    font-weight: bold;
    text-align: center;
    padding: 2rem;
    border-radius: 50%;
    width: 150px;
    height: 150px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    border: 3px solid var(--accent-gold);
    color: var(--primary-blue-dark) !important;
}

.score-a { 
    background: linear-gradient(135deg, var(--accent-gold), var(--accent-gold-light)) !important;
    color: var(--primary-blue-dark) !important;
}
.score-b { 
    background: linear-gradient(135deg, var(--primary-blue-light), #60a5fa) !important;
    color: var(--accent-gold) !important;
}
.score-c { 
    background: linear-gradient(135deg, #f59e0b, var(--accent-gold)) !important;
    color: var(--primary-blue-dark) !important;
}
.score-d { 
    background: linear-gradient(135deg, var(--background-blue), var(--background-blue-light)) !important;
    color: var(--accent-gold) !important;
}
.score-f { 
    background: linear-gradient(135deg, #dc2626, #ef4444) !important;
    color: white !important;
}

/* Progress bars for drivers */
.driver-progress {
    margin-bottom: 1rem;
}

.driver-progress .progress {
    height: 25px;
    background-color: var(--background-blue) !important;
}

.driver-progress .progress-bar {
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    font-size: 0.9rem;
    background: linear-gradient(135deg, var(--primary-blue), var(--primary-blue-light)) !important;
    color: var(--accent-gold) !important;
}

/* Plan card styling for profile page */
.plan-card {
    border: 2px solid #e2e8f0 !important;
    border-radius: 1rem !important;
    padding: 1.5rem !important;
    transition: all 0.3s ease !important;
    margin-bottom: 1rem !important;
    background-color: white !important;
    color: var(--primary-blue) !important;
}

.plan-card h5 {
    color: var(--primary-blue) !important;
    font-weight: 700 !important;
}

.plan-card .price-display {
    font-size: 2.25rem !important;
    font-weight: 700 !important;
    color: var(--primary-blue) !important;
    margin-bottom: 0.25rem !important;
}

.plan-card * {
    color: var(--primary-blue) !important;
}

.plan-card.current {
    border-color: var(--accent-gold) !important;
    background-color: #fef3c7 !important;
    color: var(--accent-gold-dark) !important;
}

.plan-card.current * {
    color: var(--accent-gold-dark) !important;
}

.plan-card.recommended {
    border-color: var(--primary-blue-light) !important;
    background-color: #dbeafe !important;
    color: var(--primary-blue-dark) !important;
}

.plan-card.recommended * {
    color: var(--primary-blue-dark) !important;
}

/* Checklist styling */
.checklist-item {
    padding: 1rem;
    margin-bottom: 0.5rem;
    border-left: 4px solid var(--accent-gold);
    background: var(--background-blue-light) !important;
    border-radius: 0 4px 4px 0;
    color: var(--text-blue-light) !important;
}

.checklist-item .points-badge {
    font-size: 0.8rem;
    padding: 0.25rem 0.5rem;
    background-color: var(--accent-gold) !important;
    color: var(--primary-blue-dark) !important;
}

/* Table enhancements */
.table {
    color: var(--text-blue-light) !important;
}

.table th {
    border-top: none;
    font-weight: 600;
    color: var(--accent-gold) !important;
    background-color: var(--primary-blue) !important;
}

.table td {
    vertical-align: middle;
    border-color: var(--primary-blue) !important;
    background-color: var(--background-blue-light) !important;
}

.table-hover tbody tr:hover {
    background-color: var(--primary-blue) !important;
}

/* Badge styling */
.badge {
    font-size: 0.8rem;
    padding: 0.5rem 0.75rem;
}

.badge.bg-success {
    background: linear-gradient(135deg, var(--accent-gold), var(--accent-gold-light)) !important;
    color: var(--primary-blue-dark) !important;
}

.badge.bg-info {
    background: linear-gradient(135deg, var(--primary-blue-light), #60a5fa) !important;
    color: var(--accent-gold) !important;
}

/* Alert styling */
.alert {
    border: 2px solid var(--accent-gold);
    color: var(--text-blue-light) !important;
    box-shadow: 0 2px 8px rgba(251, 191, 36, 0.15);
}

.alert-info {
    background-color: rgba(59, 130, 246, 0.1) !important;
    border-color: var(--primary-blue-light) !important;
    color: var(--text-blue-light) !important;
}

.alert-secondary {
    background-color: rgba(51, 65, 85, 0.5) !important;
    border-color: var(--background-blue-light) !important;
    color: var(--text-blue-light) !important;
}

.alert-warning {
    background-color: rgba(251, 191, 36, 0.1) !important;
    border-color: var(--accent-gold) !important;
    color: var(--text-blue-light) !important;
}

/* Modal enhancements */
.modal-content {
    background: var(--background-blue-light) !important;
    border: 2px solid var(--accent-gold);
    color: var(--text-blue-light) !important;
    box-shadow: 0 8px 25px rgba(251, 191, 36, 0.3);
}

.modal-header {
    border-bottom: 2px solid var(--accent-gold);
    background: linear-gradient(135deg, var(--primary-blue), var(--primary-blue-dark)) !important;
}

.modal-title {
    color: var(--accent-gold) !important;
}

.modal-footer {
    border-top: 2px solid var(--accent-gold);
}

.btn-close {
    filter: brightness(0) saturate(100%) invert(85%) sepia(47%) saturate(347%) hue-rotate(177deg) brightness(93%) contrast(92%);
}

/* Responsive adjustments */
@media (max-width: 768px) {
    .score-display {
        font-size: 2rem;
        width: 120px;
        height: 120px;
    }
    
    .card-body {
        padding: 1rem;
    }
    
    .table-responsive {
        font-size: 0.9rem;
    }
    
    /* Mobile fixes for Guss section */
    .guss-section .d-flex {
        flex-direction: column !important;
        text-align: center !important;
    }
    
    .guss-section img {
        margin-right: 0 !important;
        margin-bottom: 1rem !important;
        height: 60px !important;
        image-rendering: auto !important;
    }
    
    .guss-section .text-md-start {
        text-align: center !important;
    }
    
    /* Reduce gap between sections on mobile */
    .guss-section {
        padding-top: 2rem !important;
        padding-bottom: 2rem !important;
    }
}

/* Loading spinner */
.spinner-border {
    width: 3rem;
    height: 3rem;
    color: var(--accent-gold) !important;
}

.spinner-border-sm {
    color: var(--accent-gold) !important;
}

/* Error states */
.is-invalid {
    border-color: #dc2626 !important;
}

.invalid-feedback {
    display: block;
    width: 100%;
    margin-top: 0.25rem;
    font-size: 0.875rem;
    color: #dc2626 !important;
}

/* Success states */
.alert-success {
    background-color: rgba(251, 191, 36, 0.1) !important;
    border-color: var(--accent-gold) !important;
    color: var(--text-blue-light) !important;
}

/* Section dividers */
.border-bottom {
    border-color: var(--accent-gold) !important;
}

/* Input group styling */
.input-group-text {
    background: var(--primary-blue) !important;
    border-color: var(--primary-blue) !important;
    color: var(--accent-gold) !important;
}

/* Summary cards */
.card .card-body h2 {
    margin-bottom: 0;
    color: var(--accent-gold) !important;
}

.card .card-body h5 {
    color: var(--text-blue-light) !important;
    font-weight: 500;
}

/* Text colors for better visibility */
.text-muted {
    color: var(--text-blue-light) !important;
    opacity: 0.8;
}

.text-info {
    color: var(--accent-gold) !important;
}

.text-success {
    color: var(--accent-gold-light) !important;
}

h1, h2, h3, h4, h5, h6 {
    color: var(--text-blue-light) !important;
}

p, div, span, small {
    color: var(--text-blue-light) !important;
}

/* Celebration Styles for Ready Borrowers - Blue and Gold Theme */
.congratulations-container {
    background: linear-gradient(135deg, var(--primary-blue), var(--primary-blue-light), var(--accent-gold));
    border-radius: 20px;
    padding: 3rem 2rem;
    margin: 2rem 0;
    position: relative;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(30, 58, 138, 0.4);
}

.congratulations-container::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, rgba(251,191,36,0.2) 0%, transparent 70%);
    animation: shimmer 3s ease-in-out infinite;
}

@keyframes shimmer {
    0%, 100% { transform: rotate(0deg); }
    50% { transform: rotate(180deg); }
}

.celebration-wrapper {
    position: relative;
    z-index: 2;
}

.celebration-icons {
    font-size: 3rem;
    margin-bottom: 1rem;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1rem;
}

.celebration-star {
    color: var(--accent-gold);
    animation: twinkle 1.5s ease-in-out infinite alternate;
}

.celebration-home {
    color: #ffffff;
    animation: bounce 2s ease-in-out infinite;
}

@keyframes twinkle {
    0% { transform: scale(1) rotate(0deg); opacity: 0.8; }
    100% { transform: scale(1.2) rotate(10deg); opacity: 1; }
}

@keyframes bounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}

.congratulations-text {
    font-family: 'Georgia', serif;
    font-size: 3rem;
    font-weight: bold;
    text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
    color: #ffffff !important;
    animation: pulse-text 2s ease-in-out infinite;
}

@media (max-width: 768px) {
    .congratulations-text {
        font-size: 2rem;
    }
}

@media (max-width: 480px) {
    .congratulations-text {
        font-size: 1.5rem;
    }
}

@keyframes pulse-text {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.05); }
}

.gradient-text {
    background: linear-gradient(45deg, #fff, var(--accent-gold), #fff);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.ready-message h4 {
    color: #ffffff !important;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.5);
}

.ready-message p {
    color: #f8f9fa !important;
    font-size: 1.2rem;
}

.ready-badges {
    display: flex;
    justify-content: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.ready-badge {
    font-size: 1rem;
    padding: 0.75rem 1.5rem;
    border-radius: 25px;
    background: rgba(255,255,255,0.9) !important;
    color: var(--primary-blue-dark) !important;
    font-weight: bold;
    animation: badge-glow 2s ease-in-out infinite alternate;
}

@keyframes badge-glow {
    0% { box-shadow: 0 0 5px rgba(255,255,255,0.5); }
    100% { box-shadow: 0 0 20px rgba(255,255,255,0.8), 0 0 30px rgba(251,191,36,0.4); }
}

.pulse-button {
    animation: pulse-button 2s ease-in-out infinite;
    font-weight: bold;
    text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
    position: relative;
    overflow: hidden;
}

@keyframes pulse-button {
    0%, 100% { 
        transform: scale(1);
        box-shadow: 0 4px 15px rgba(251,191,36,0.4);
    }
    50% { 
        transform: scale(1.05);
        box-shadow: 0 6px 25px rgba(251,191,36,0.6);
    }
}

.pulse-button::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
    transition: left 0.5s;
}

.pulse-button:hover::before {
    left: 100%;
}

/* Agent Dashboard "IT'S GO TIME" Celebration - Blue and Gold */
.its-go-time-banner {
    background: linear-gradient(45deg, var(--primary-blue), var(--primary-blue-light), var(--accent-gold), var(--primary-blue-dark));
    background-size: 400% 400%;
    animation: gradient 3s ease infinite;
    border-radius: 15px;
    padding: 2rem;
    margin: 1rem 0;
    box-shadow: 0 10px 30px rgba(0,0,0,0.3);
    position: relative;
    overflow: hidden;
}

.its-go-time-banner::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: linear-gradient(45deg, transparent, rgba(251,191,36,0.2), transparent);
    transform: rotate(45deg);
    animation: shimmer 2s infinite;
}

@keyframes gradient {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

.go-time-effects {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2rem;
    position: relative;
    z-index: 2;
}

.go-time-icon {
    font-size: 3rem;
    color: #fff;
    animation: bounce 2s infinite;
    text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
}

.go-time-text {
    text-align: center;
}

.pulse-text {
    animation: pulseGlow 2s infinite;
    text-shadow: 0 0 10px rgba(251,191,36,0.8);
    color: #ffffff !important;
}

@keyframes pulseGlow {
    0% { 
        transform: scale(1);
        text-shadow: 0 0 10px rgba(251,191,36,0.5);
    }
    50% { 
        transform: scale(1.02);
        text-shadow: 0 0 20px rgba(251,191,36,0.8);
    }
    100% { 
        transform: scale(1);
        text-shadow: 0 0 10px rgba(251,191,36,0.5);
    }
}

/* Grade display for agent dashboard */
.grade-display {
    padding: 1rem;
    border-radius: 10px;
    border: 2px solid var(--accent-gold);
    background: linear-gradient(135deg, var(--primary-blue), var(--primary-blue-light)) !important;
    color: var(--accent-gold) !important;
}

/* Lender information styling - Blue and Gold */
.lender-info-card {
    background: linear-gradient(135deg, var(--primary-blue) 0%, var(--primary-blue-dark) 100%) !important;
    border: 2px solid var(--accent-gold);
    border-radius: 10px;
    color: var(--accent-gold) !important;
    padding: 1.5rem;
    margin: 1rem 0;
}

/* Action item checkbox styling */
.action-item-checkbox {
    transform: scale(1.2);
    margin-top: 0.125rem;
    accent-color: var(--accent-gold);
}

.action-item-checkbox:not(:checked) + .form-check-label {
    color: var(--accent-gold) !important;
    font-weight: 500;
}

.action-item-checkbox:checked + .form-check-label {
    color: var(--accent-gold-light) !important;
    font-weight: 600;
}

/* Hover effect for better interaction feedback */
.form-check:hover .action-item-checkbox:not(:checked) + .form-check-label {
    color: var(--accent-gold-light) !important;
}

/* Action item card hover effect */
.card:has(.action-item-checkbox:not(:checked)):hover {
    border-color: var(--accent-gold) !important;
    box-shadow: 0 0 10px rgba(251, 191, 36, 0.25);
}

/* Celebration animations */
@keyframes celebrationSlideIn {
    from {
        opacity: 0;
        transform: translateY(-50px) scale(0.8);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes confettiFall {
    0% {
        transform: translateY(-100vh) rotate(0deg);
        opacity: 1;
    }
    100% {
        transform: translateY(100vh) rotate(360deg);
        opacity: 0;
    }
}

/* Celebration icons animation */
.celebration-icons i {
    animation: celebrationBounce 2s infinite ease-in-out;
}

.celebration-icons i:nth-child(2) {
    animation-delay: 0.2s;
}

.celebration-icons i:nth-child(3) {
    animation-delay: 0.4s;
}

.celebration-icons i:nth-child(4) {
    animation-delay: 0.6s;
}

.celebration-icons i:nth-child(5) {
    animation-delay: 0.8s;
}

@keyframes celebrationBounce {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-10px);
    }
}

/* Credit report display styling */
.bg-primary {
    background: linear-gradient(135deg, var(--primary-blue), var(--primary-blue-light)) !important;
    color: var(--accent-gold) !important;
}

.bg-dark {
    background: var(--background-blue-light) !important;
    color: var(--text-blue-light) !important;
}

/* Ensure visibility of all text elements */
.small, small {
    color: var(--text-blue-light) !important;
    opacity: 0.9;
}

.visually-hidden {
    color: var(--text-blue-light) !important;
}

/* Fix for option elements */
option {
    background-color: var(--background-blue-light) !important;
    color: var(--text-blue-light) !important;
}

/* Dropdown styling */
.dropdown-menu {
    background-color: var(--background-blue-light) !important;
    border: 1px solid var(--primary-blue) !important;
}

.dropdown-item {
    color: var(--text-blue-light) !important;
}

.dropdown-item:hover {
    background-color: var(--primary-blue) !important;
    color: var(--accent-gold) !important;
}

/* AI Chat Interface Styling */
#chatHistory {
    background: var(--background-blue) !important;
    border: 2px solid var(--primary-blue-light) !important;
}

.chat-message {
    margin: 10px 0;
}

.chat-message.user {
    display: flex;
    justify-content: flex-end;
}

.chat-message.ai {
    display: flex;
    justify-content: flex-start;
}

.chat-bubble {
    max-width: 80%;
    padding: 12px 16px;
    border-radius: 18px;
    margin: 5px;
    word-wrap: break-word;
}

.chat-bubble.user {
    background: linear-gradient(135deg, var(--primary-blue), var(--primary-blue-light)) !important;
    color: var(--accent-gold) !important;
    border: 1px solid var(--primary-blue-light);
}

.chat-bubble.ai {
    background: linear-gradient(135deg, var(--accent-gold), var(--accent-gold-light)) !important;
    color: var(--primary-blue-dark) !important;
    border: 1px solid var(--accent-gold-dark);
}

.chat-icon {
    margin: 0 8px;
    align-self: flex-end;
    color: var(--accent-gold);
}

.quick-question-btn {
    background-color: var(--background-blue-light) !important;
    border: 1px solid var(--accent-gold) !important;
    color: var(--accent-gold) !important;
    transition: all 0.3s ease;
}

.quick-question-btn:hover {
    background: linear-gradient(135deg, var(--accent-gold), var(--accent-gold-light)) !important;
    color: var(--primary-blue-dark) !important;
    border-color: var(--accent-gold-light) !important;
}