/* NuevoDrive Brand Color System */
:root {
    /* Primary Brand Colors */
    --nuevodrive-terracotta: #D65A29;
    --nuevodrive-terracotta-hover: #B84B20;
    --nuevodrive-terracotta-light: #E8774A;
    --nuevodrive-sunrise: #F1B02D;
    --nuevodrive-sunrise-light: #F4C04E;
    --nuevodrive-navy: #24364C;
    --nuevodrive-navy-light: #344A61;
    --nuevodrive-slate: #4F5D73;
    --nuevodrive-slate-light: #6B7A8F;
    --nuevodrive-beige: #F7F4EF;
    --nuevodrive-beige-light: #FDFCF9;
    --nuevodrive-white: #FFFFFF;
    
    /* Semantic Color Mappings */
    --nd-primary: var(--nuevodrive-terracotta);
    --nd-primary-hover: var(--nuevodrive-terracotta-hover);
    --nd-secondary: var(--nuevodrive-sunrise);
    --nd-text-primary: #1a1a1a;
    --nd-text-secondary: #2c2c2c;
    --nd-text-muted: #404040;
    --nd-bg-primary: var(--nuevodrive-beige);
    --nd-bg-secondary: var(--nuevodrive-beige-light);
    --nd-bg-dark: var(--nuevodrive-navy);
    --nd-border: #E2DDD5;
    --nd-border-light: #EEEBE6;
    
    /* Success/Warning/Error States */
    --nd-success: #2E8B57;
    --nd-warning: var(--nuevodrive-sunrise);
    --nd-error: #C5483C;
    --nd-info: var(--nuevodrive-terracotta);
}

/* Override Bootstrap Light Theme */
[data-bs-theme="light"] {
    --bs-primary: var(--nd-primary);
    --bs-primary-rgb: 214, 90, 41;
    --bs-secondary: var(--nd-secondary);
    --bs-secondary-rgb: 241, 176, 45;
    --bs-body-bg: var(--nd-bg-primary);
    --bs-body-color: var(--nd-text-primary);
    --bs-text-muted: var(--nd-text-muted);
    --bs-border-color: var(--nd-border);
    --bs-secondary-bg: var(--nd-bg-secondary);
    --bs-tertiary-bg: var(--nd-bg-secondary);
}

/* Force White-Gray Header Override */
.navbar.navbar-expand-lg, .nuevodrive-header {
    background-color: #f8f9fa !important;
    border-bottom: 1px solid #dee2e6 !important;
    box-shadow: 0 2px 4px rgba(0,0,0,0.08) !important;
}

.navbar .navbar-brand, .nuevodrive-header .navbar-brand {
    color: #24364C !important;
}

.navbar .navbar-brand img, .nuevodrive-header .navbar-brand img {
    height: 120px;
    width: auto;
    max-width: 600px;
    display: inline-block;
    object-fit: contain;
    filter: brightness(1.1) contrast(1.2);
}

.navbar .nav-link, .nuevodrive-header .nav-link {
    color: #4F5D73 !important;
}

.navbar .nav-link:hover, .nuevodrive-header .nav-link:hover {
    color: #D65A29 !important;
    transition: color 0.3s ease;
}

.navbar .navbar-toggler, .nuevodrive-header .navbar-toggler {
    border-color: #4F5D73 !important;
}

/* FORCE DARK TEXT FOR ALL ELEMENTS - MAXIMUM SPECIFICITY */
html *, html body *, html body, body, p, h1, h2, h3, h4, h5, h6, span, div, li, a, 
.nav-link, .navbar-nav .nav-link, .navbar .nav-link, .nuevodrive-header .nav-link {
    color: #1a1a1a !important;
}

.text-muted, .text-muted * {
    color: #404040 !important;
}

.card-title, .card-text, .card *, .card-body * {
    color: #1a1a1a !important;
}

.navbar .navbar-toggler-icon, .nuevodrive-header .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2879, 93, 115, 0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}

/* Navigation Styling */
.navbar {
    box-shadow: 0 2px 4px rgba(0,0,0,0.08);
    backdrop-filter: blur(10px);
}

.navbar-nav {
    align-items: center;
    gap: 0.5rem;
}

.navbar-nav .nav-item {
    display: flex;
    align-items: center;
}

.navbar-nav .nav-link {
    white-space: nowrap;
    margin: 0 0.25rem;
    color: #1a1a1a !important;
}

.navbar-nav .nav-link:hover {
    color: var(--nd-primary) !important;
    transition: color 0.3s ease;
}

.navbar-toggler {
    border-color: var(--nd-text-secondary);
}

.navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2836, 54, 76, 0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* Typography Hierarchy */
h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
    color: var(--nd-text-primary);
    font-weight: 600;
}

.text-primary { color: var(--nd-primary) !important; }
.text-secondary { color: var(--nd-text-secondary) !important; }
.text-muted { color: var(--nd-text-muted) !important; }

/* Enhanced text contrast for better readability */
body { color: var(--nd-text-primary) !important; }
p { color: var(--nd-text-primary) !important; }
.lead { color: var(--nd-text-secondary) !important; }
li { color: var(--nd-text-primary) !important; }

/* SPECIFIC OVERRIDE - FORCE NAVIGATION AND CONTENT TEXT TO BE DARK */
.navbar *, .nav-link *, .navbar .nav-link, .navbar-nav .nav-link,
.container *, .row *, .col *, 
.card *, .btn:not(.btn-primary):not(.btn-success):not(.btn-danger):not(.btn-warning):not(.btn-info) *,
main *, footer *, section:not(.hero-section):not([style*="background"]) * {
    color: #1a1a1a !important;
}

/* Extra specific navigation link override */
.navbar .navbar-nav .nav-link,
.navbar-nav li a.nav-link,
.nav-link.fw-medium,
.navbar .nav-link,
.nuevodrive-header .nav-link,
a.nav-link.fw-medium.px-3 {
    color: #1a1a1a !important;
}

/* Override any white text from other CSS files */
body .navbar .nav-link,
body .navbar-nav .nav-link,
body .nuevodrive-header .nav-link {
    color: #1a1a1a !important;
}

/* ULTRA SPECIFIC NAVIGATION TEXT OVERRIDE - HIGHEST PRIORITY */
html body .navbar-expand-lg .navbar-nav .nav-link.fw-medium.px-3,
html body .navbar .navbar-nav .nav-item .nav-link,
html body .navbar-nav .nav-item a[href] {
    color: #1a1a1a !important;
}

/* Keep hero sections and dark backgrounds with light text */
.hero-section, .hero-section *, 
[style*="background-color: #2c3e50"], [style*="background-color: #2c3e50"] *,
[style*="background: linear-gradient"] *, 
.bg-dark *, .bg-primary *,
[style*="color: #ffffff"], [style*="color: #ecf0f1"] {
    color: #ffffff !important;
}

/* Specific override for sections with dark backgrounds */
div[style*="background-color: #2c3e50"] h4,
div[style*="background-color: #2c3e50"] p,
div[style*="background-color: #2c3e50"] span {
    color: #ffffff !important;
}

/* Exception for buttons that should keep their intended colors */
.btn-primary, .btn-primary *, .btn-success, .btn-success *, 
.btn-danger, .btn-danger *, .btn-warning, .btn-warning *,
.btn-info, .btn-info *, .btn-secondary, .btn-secondary * {
    color: inherit !important;
}
span { color: var(--nd-text-primary) !important; }
small { color: var(--nd-text-secondary) !important; }
.card-body { color: var(--nd-text-primary) !important; }
.card-text { color: var(--nd-text-primary) !important; }
.list-group-item { color: var(--nd-text-primary) !important; }

/* Button System */
.btn-primary {
    background-color: var(--nd-primary);
    border-color: var(--nd-primary);
    color: var(--nd-white);
    font-weight: 500;
    transition: all 0.3s ease;
}

.btn-primary:hover, .btn-primary:focus {
    background-color: var(--nd-primary-hover);
    border-color: var(--nd-primary-hover);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(214, 90, 41, 0.3);
}

.btn-secondary {
    background-color: transparent;
    border: 2px solid var(--nd-primary);
    color: var(--nd-primary);
    font-weight: 500;
}

.btn-secondary:hover, .btn-secondary:focus {
    background-color: var(--nd-primary);
    border-color: var(--nd-primary);
    color: var(--nd-white);
}

.btn-success {
    background-color: var(--nd-success);
    border-color: var(--nd-success);
}

.btn-warning {
    background-color: var(--nd-warning);
    border-color: var(--nd-warning);
    color: var(--nd-text-primary);
}

/* Navigation & Header */
.navbar {
    background-color: var(--nd-bg-dark) !important;
    border-bottom: 1px solid var(--nd-primary);
}

.navbar-brand {
    color: var(--nd-white) !important;
    font-weight: 700;
}

.navbar-nav .nav-link {
    color: rgba(255, 255, 255, 0.85) !important;
    font-weight: 500;
}

.navbar-nav .nav-link:hover {
    color: var(--nd-secondary) !important;
}

/* Hero Sections */
.hero-section {
    background: linear-gradient(135deg, var(--nd-bg-primary) 0%, var(--nd-bg-secondary) 100%);
    color: var(--nd-text-primary);
}

.hero-cta {
    background-color: var(--nd-primary);
    color: var(--nd-white);
    padding: 0.75rem 2rem;
    border-radius: 0.5rem;
    font-weight: 600;
    text-decoration: none;
    display: inline-block;
    transition: all 0.3s ease;
}

.hero-cta:hover {
    background-color: var(--nd-primary-hover);
    color: var(--nd-white);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(214, 90, 41, 0.4);
}

/* Cards & Content Blocks */
.card {
    background-color: var(--nd-white);
    border: 1px solid var(--nd-border-light);
    box-shadow: 0 2px 8px rgba(36, 54, 76, 0.08);
    transition: all 0.3s ease;
}

.card:hover {
    box-shadow: 0 4px 16px rgba(36, 54, 76, 0.12);
    transform: translateY(-2px);
}

.card-header {
    background-color: var(--nd-bg-secondary);
    border-bottom: 1px solid var(--nd-border);
    color: var(--nd-text-primary);
}

/* Forms */
.form-control {
    background-color: var(--nd-white);
    border: 1px solid var(--nd-border);
    color: var(--nd-text-primary);
}

.form-control:focus {
    border-color: var(--nd-primary);
    box-shadow: 0 0 0 0.2rem rgba(214, 90, 41, 0.25);
}

.form-label {
    color: var(--nd-text-primary);
    font-weight: 500;
}

.form-control {
    color: var(--nd-text-primary) !important;
}

.form-control::placeholder {
    color: var(--nd-text-muted) !important;
}

/* Alerts & Badges */
.alert-success {
    background-color: rgba(46, 139, 87, 0.1);
    border-color: var(--nd-success);
    color: var(--nd-success);
}

.alert-warning {
    background-color: rgba(241, 176, 45, 0.1);
    border-color: var(--nd-warning);
    color: var(--nd-text-primary);
}

.alert-danger {
    background-color: rgba(197, 72, 60, 0.1);
    border-color: var(--nd-error);
    color: var(--nd-error);
}

.alert-info {
    background-color: rgba(214, 90, 41, 0.1);
    border-color: var(--nd-primary);
    color: var(--nd-primary);
}

.badge {
    font-weight: 500;
}

.bg-primary {
    background-color: var(--nd-primary) !important;
}

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

/* Footer */
footer {
    background-color: var(--nd-bg-dark) !important;
    color: var(--nd-white);
}

footer h5, footer h6 {
    color: var(--nd-white);
}

footer .text-muted {
    color: rgba(255, 255, 255, 0.7) !important;
}

footer a {
    color: var(--nd-secondary);
}

footer a:hover {
    color: var(--nd-white);
}

/* Stats & Metrics */
.metric-card {
    background: linear-gradient(135deg, var(--nd-primary) 0%, var(--nd-primary-hover) 100%);
    color: var(--nd-white);
    border-radius: 1rem;
    padding: 1.5rem;
    text-align: center;
}

.metric-value {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--nd-white);
}

.metric-label {
    color: rgba(255, 255, 255, 0.9);
    font-weight: 500;
}

/* Testimonials */
.testimonial-card {
    background-color: var(--nd-white);
    border-left: 4px solid var(--nd-primary);
    box-shadow: 0 2px 12px rgba(36, 54, 76, 0.1);
}

.testimonial-rating {
    color: var(--nd-secondary);
}

/* Progress Bars */
.progress {
    background-color: var(--nd-bg-secondary);
}

.progress-bar {
    background-color: var(--nd-primary);
}

/* Tables */
.table {
    color: var(--nd-text-primary);
}

.table th {
    background-color: var(--nd-bg-secondary);
    color: var(--nd-text-primary);
    border-color: var(--nd-border);
}

.table td {
    border-color: var(--nd-border-light);
}

.table-hover tbody tr:hover {
    background-color: var(--nd-bg-secondary);
}

/* Utility Classes */
.bg-nuevodrive-beige {
    background-color: var(--nd-bg-primary) !important;
}

.bg-nuevodrive-navy {
    background-color: var(--nd-bg-dark) !important;
    color: var(--nd-white);
}

.text-nuevodrive-terracotta {
    color: var(--nd-primary) !important;
}

.text-nuevodrive-sunrise {
    color: var(--nd-secondary) !important;
}

.border-nuevodrive {
    border-color: var(--nd-border) !important;
}

/* Responsive Adjustments */
@media (max-width: 768px) {
    .hero-cta {
        padding: 0.6rem 1.5rem;
        font-size: 0.9rem;
    }
    
    .metric-value {
        font-size: 2rem;
    }
}

/* Smooth Transitions */
* {
    transition: color 0.3s ease, background-color 0.3s ease, border-color 0.3s ease;
}

/* Custom Focus States */
.btn:focus,
.form-control:focus,
.form-select:focus {
    outline: 2px solid var(--nd-primary);
    outline-offset: 2px;
}