/* Accessibilite : contrastes, focus, lien d'evitement, pages legales */

.skip-link {
    position: absolute;
    left: -9999px;
    top: 0;
    z-index: 1000;
    padding: 0.5rem 1rem;
    background: #084586;
    color: #fff;
    font-family: Verdana, Geneva, sans-serif;
    font-size: 14px;
    text-decoration: none;
}

.skip-link:focus {
    left: 0.5rem;
    top: 0.5rem;
    outline: 3px solid #fff;
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

a:focus:not(:focus-visible),
button:focus:not(:focus-visible),
.menu-trigger:focus:not(:focus-visible) {
    outline: none;
}

a:focus-visible,
button:focus-visible,
.menu-trigger:focus-visible {
    outline: 3px solid #084586;
    outline-offset: 2px;
}

.legal-content {
    max-width: 52rem;
    margin: 0 auto;
    padding: 0 1rem 2rem;
    font-family: Verdana, Geneva, sans-serif;
    font-size: 14px;
    line-height: 1.6;
    color: #003366;
    text-align: left;
}

.legal-content h1 {
    font-size: 1.5rem;
    color: #003366;
    text-align: center;
}

.legal-content h2 {
    font-size: 1.15rem;
    color: #084586;
    margin-top: 1.5rem;
}

.legal-content ul {
    margin: 0.5rem 0 1rem 1.5rem;
}

.legal-content a {
    color: #084586;
}

.footer-legal {
    font-family: Verdana, Geneva, sans-serif;
    font-size: 12px;
    text-align: center;
    padding: 0.25rem;
}

.footer-legal a {
    color: #003366;
    margin: 0 0.5rem;
}

@media (prefers-reduced-motion: reduce) {
    * {
        animation: none !important;
        transition: none !important;
    }
}
