/* Screen reader only styles */
.sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* Skip navigation links */
.skip-link {
    position: absolute;
    top: -40px;
    left: 6px;
    z-index: 1000;
    background-color: #000;
    color: #fff;
    padding: 8px;
    text-decoration: none;
    border-radius: 4px;
    transition: top 0.3s;
}

.skip-link:focus {
    top: 6px;
}

/* Focus indicators for better keyboard navigation */
a:focus,
button:focus,
input:focus,
textarea:focus,
select:focus {
    outline: 3px solid #005fcc;
    outline-offset: 2px;
}

/* Improve color contrast for links - WCAG 2.1 AA compliant colors */
a {
    color: #0066cc;
}

a:hover {
    color: #004c99;
}

/* Override problematic color contrasts from loginPage.css */
/* Ensure sufficient contrast for all text elements */

/* Fix header navigation menu links - original has white text on unclear background */
.header-nav-menu ul li a {
    color: #ffffff !important;
    background-color: rgba(0, 0, 0, 0.8) !important;
    border: 2px solid transparent !important;
    padding: 8px 12px !important;
    border-radius: 4px !important;
    margin: 2px !important;
    display: inline-block !important;
    transition: all 0.3s ease !important;
}

.header-nav-menu ul li a:hover,
.header-nav-menu ul li a:focus {
    color: #000000 !important;
    background-color: #b5d600 !important;
    border-color: #b5d600 !important;
    outline: 3px solid #ffffff !important;
    outline-offset: 2px !important;
}

/* Specific focus styles for header navigation */
.header-nav ul li a:focus,
.header-nav-logo a:focus {
    outline: 3px solid #b5d600 !important;
    outline-offset: 2px !important;
    border-radius: 4px !important;
}

/* Enhanced focus for burger menu button */
.burger:focus {
    outline: 3px solid #b5d600 !important;
    outline-offset: 2px !important;
    border-radius: 4px !important;
    background-color: rgba(181, 214, 0, 0.2) !important;
}

/* Fix contact section text colors - ensure sufficient contrast on #FAFAFA background */
.kontakt__title,
.kontakt__subtitle,
.kontakt__list-text,
.kontakt__list-link {
    color: #333333 !important; /* Changed from #555 to #333 for better contrast */
}

.kontakt__list-link:hover,
.kontakt__list-link:focus {
    color: #000000 !important;
    outline: 3px solid #b5d600 !important;
    outline-offset: 2px !important;
    text-decoration: underline !important;
}

/* Fix impressum section text colors - ensure sufficient contrast on white background */
.impressum__title,
.impressum__list-text,
.impressum__list-link,
.impressum__logo-title {
    color: #333333 !important; /* Changed from #555 to #333 for better contrast */
}

.impressum__list-link:hover,
.impressum__list-link:focus,
.impressum__logo-title:hover,
.impressum__logo-title:focus,
.impressum__logo-link:focus {
    color: #000000 !important;
    outline: 3px solid #b5d600 !important;
    outline-offset: 2px !important;
    text-decoration: underline !important;
}

/* Fix button contrast for online appointment button - keeping CI green #b5d600 */
.kontakt__onlinetermin {
    background-color: #b5d600 !important; /* Keep CI green */
    color: #000000 !important; /* Use black text for better contrast on green background */
    border-color: #000000 !important; /* Black border for definition */
    font-weight: bold !important; /* Bold text for better readability */
}

.kontakt__onlinetermin:hover,
.kontakt__onlinetermin:focus {
    background-color: #000000 !important;
    color: #b5d600 !important;
    border-color: #b5d600 !important;
    outline: 3px solid #b5d600 !important;
    outline-offset: 2px !important;
}

/* Fix job listing colors for better contrast */
.jobs__item-title,
.jobs__item-address,
.job__title,
.job__subtitle,
.job__list-item,
.job__note,
.job__contacts-title,
.job__contacts-list-title,
.job__contacts-list-text {
    color: #333333 !important; /* Changed from #555 to #333 for better contrast */
}

.jobs__item-link {
    color: #b5d600 !important; /* Keep CI green */
    background-color: #000000 !important; /* Add black background for contrast */
    padding: 4px 8px !important;
    border-radius: 4px !important;
    font-weight: bold !important;
}

.jobs__item-link:hover,
.jobs__item-link:visited {
    color: #000000 !important;
    background-color: #b5d600 !important;
    text-decoration: none !important;
}

/* Fix footer text colors */
.footer__menu-link {
    color: #ffffff !important; /* Ensure white text on dark background */
}

.footer__partner-title {
    color: #ffffff !important;
}

/* Fix form input borders for better visibility */
.header-form input {
    border: 2px solid #666666 !important;
    color: #000000 !important;
}

.header-form input:focus {
    border-color: #005fcc !important;
    outline: 3px solid rgba(0, 95, 204, 0.25) !important;
}

/* Fix button color for better contrast */
.header-form button {
    background-color: #d11850 !important; /* Darker red for better contrast */
    color: #ffffff !important;
}

.header-form button:hover {
    background-color: #b01443 !important;
}

/* Ensure pagination elements have sufficient contrast - keeping CI green */
.jobs__pagination a,
.jobs__pagination span,
.jobs__pagination .active a {
    color: #000000 !important;
    border-color: #b5d600 !important;
}

.jobs__pagination a {
    background-color: #b5d600 !important;
    color: #000000 !important; /* Black text on green background for better contrast */
    font-weight: bold !important;
}

.jobs__pagination span,
.jobs__pagination .active a {
    background-color: #ffffff !important;
    color: #000000 !important;
}

/* Fix questionnaire colors for better accessibility */
.questionnaire__question {
    background-color: #e8e8e8 !important; /* Darker background for better contrast */
    color: #000000 !important;
}

.questionnaire__answer {
    background-color: #4a5a61 !important; /* Darker background for better contrast */
    color: #ffffff !important;
}

/* Keep CI green but ensure accessibility through background contrast */
.green-color {
    color: #b5d600 !important; /* Keep CI green */
    background-color: #000000 !important; /* Add black background for contrast when needed */
    padding: 2px 4px !important;
    border-radius: 3px !important;
}

.red-color {
    color: #d11850 !important; /* Darker red instead of #ff2663 */
}

/* Focus styles for interactive elements */
.btn:focus,
.form-control:focus {
    box-shadow: 0 0 0 3px rgba(0, 95, 204, 0.25);
}

/* Make sure images have proper contrast */
img {
    max-width: 100%;
    height: auto;
}

/* Improve readability */
p, li, div, span {
    line-height: 1.5;
}

/* Accessible form styles */
label {
    font-weight: bold;
    margin-bottom: 5px;
    display: block;
}

input[type="text"],
input[type="email"],
input[type="tel"],
textarea {
    border: 2px solid #666;
    padding: 8px;
    font-size: 16px;
}

input:invalid {
    border-color: #d73527;
}

input:valid {
    border-color: #28a745;
}

/* Error message styles */
.error-message {
    color: #d73527;
    font-weight: bold;
    margin-top: 5px;
}

/* Success message styles */
.success-message {
    color: #28a745;
    font-weight: bold;
    margin-top: 5px;
}

/* Accessibility compliance badge */
.accessibility-badge {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 1000;
    background: linear-gradient(135deg, #b5d600 0%, #8ba800 100%);
    color: #000000;
    padding: 12px 16px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: bold;
    text-decoration: none;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
    border: 2px solid #000000;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 8px;
    max-width: 180px;
}

.accessibility-badge:hover,
.accessibility-badge:focus {
    background: linear-gradient(135deg, #000000 0%, #333333 100%);
    color: #b5d600;
    border-color: #b5d600;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4);
    text-decoration: none;
    outline: 3px solid #b5d600;
    outline-offset: 2px;
}

.accessibility-badge-icon {
    width: 24px;
    height: 24px;
    background-color: #000000;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    color: #b5d600;
    font-weight: bold;
    flex-shrink: 0;
}

.accessibility-badge:hover .accessibility-badge-icon,
.accessibility-badge:focus .accessibility-badge-icon {
    background-color: #b5d600;
    color: #000000;
}

.accessibility-badge-text {
    line-height: 1.2;
    font-size: 11px;
}

.accessibility-badge-title {
    font-size: 12px;
    font-weight: bold;
    margin-bottom: 2px;
    display: block;
}

/* Mobile responsive badge */
@media (max-width: 768px) {
    .accessibility-badge {
        bottom: 15px;
        right: 15px;
        padding: 10px 12px;
        font-size: 10px;
        max-width: 150px;
    }
    
    .accessibility-badge-icon {
        width: 20px;
        height: 20px;
        font-size: 12px;
    }
    
    .accessibility-badge-text {
        font-size: 9px;
    }
    
    .accessibility-badge-title {
        font-size: 10px;
    }
}