/* Accessibility and WCAG Compliance Fixes */

/* Color Contrast Improvements */
.btn-primary {
    background-color: var(--accent-dark) !important;
    color: white !important;
    /* Enhanced focus visibility */
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.btn-primary:focus {
    outline: 2px solid #ffffff !important;
    outline-offset: 2px;
    box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.3) !important;
}

.btn-primary:hover {
    background-color: #d4592f !important;
    transform: translateY(-1px);
}

/* Navigation Focus Indicators */
.nav-links a {
    border-radius: 4px;
    outline: 2px solid transparent;
    outline-offset: 2px;
}

.nav-links a:focus {
    outline: 2px solid white !important;
    outline-offset: 2px;
    background-color: rgba(255, 255, 255, 0.1) !important;
}

/* Dropdown Keyboard Accessibility */
.dropdown-menu a:focus {
    outline: 2px solid var(--accent-dark) !important;
    outline-offset: 2px;
}

/* Skip Navigation Link */
.skip-nav {
    position: absolute;
    top: -40px;
    left: 6px;
    background: var(--contrast);
    color: white;
    padding: 8px 16px;
    text-decoration: none;
    border-radius: 0 0 4px 4px;
    z-index: 9999;
    font-weight: bold;
    transition: top 0.3s ease;
}

.skip-nav:focus {
    top: 0;
    outline: 2px solid white;
    outline-offset: 2px;
}

/* Form Focus Indicators */
.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus {
    outline: 2px solid var(--accent-dark);
    outline-offset: 2px;
    border-color: var(--accent-dark);
    box-shadow: 0 0 0 2px rgba(239, 106, 62, 0.2);
}

/* Mobile Menu Accessibility */
.hamburger-icon {
    border-radius: 4px;
    outline: 2px solid transparent;
    outline-offset: 2px;
    padding: 8px;
}

.hamburger-icon:focus {
    outline: 2px solid white !important;
    outline-offset: 2px;
    background-color: rgba(255, 255, 255, 0.1);
}

.mobile-menu .close-icon {
    border-radius: 4px;
    outline: 2px solid transparent;
    outline-offset: 2px;
    padding: 8px;
}

.mobile-menu .close-icon:focus {
    outline: 2px solid var(--base-bg) !important;
    outline-offset: 2px;
}

/* Improved Card Text Contrast */
.card {
    color: #e0e0e0 !important;
}

.card p {
    color: #d0d0d0 !important;
}

/* Form Accessibility Improvements */
.contact-form label {
    display: block;
    font-weight: 600;
    margin-bottom: 0.5rem;
    color: var(--contrast);
    font-size: 0.95rem;
}

.contact-form fieldset {
    border: none;
    padding: 0;
    margin: 0;
}

.contact-form legend {
    font-weight: bold;
    font-size: 1.1rem;
    margin-bottom: 1rem;
}

/* Error States for Forms */
.form-error {
    border-color: #dc3545 !important;
    background-color: #fff5f5;
}

.error-message {
    color: #dc3545;
    font-size: 0.875rem;
    margin-top: 0.25rem;
    display: block;
    font-weight: 500;
}

.form-help {
    color: #666;
    font-size: 0.8rem;
    margin-top: 0.25rem;
    display: block;
    font-style: italic;
}

/* Invalid field styling */
[aria-invalid="true"] {
    border-color: #dc3545 !important;
    box-shadow: 0 0 0 2px rgba(220, 53, 69, 0.2) !important;
}

/* Focus trap for modals */
.focus-trap {
    outline: none;
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    .btn-primary {
        border: 2px solid currentColor;
    }
    
    .nav-links a:focus,
    .contact-form input:focus,
    .contact-form textarea:focus,
    .contact-form select:focus {
        outline: 3px solid currentColor;
    }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
    .btn-primary,
    .nav-links a,
    .dropdown-menu,
    .mobile-menu {
        transition: none !important;
        animation: none !important;
    }
}
