/* ==========================================================================
   footer.css — pied de page sombre, 4 colonnes en grille responsive.
   BEM : .site-footer / .site-footer__column / .site-footer__heading
   ========================================================================== */

.site-footer {
	background-color: var(--color-surface);
	color: var(--color-text);
	border-top: 1px solid var(--color-border);
	margin-top: auto;
}

.site-footer__inner {
	display: grid;
	gap: var(--space-xl);
	padding-block: var(--space-2xl);
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	align-items: start;
}

@media (max-width: 960px) {
	.site-footer__inner {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 600px) {
	.site-footer__inner {
		grid-template-columns: 1fr;
		gap: var(--space-lg);
	}
}

/* ---------------------------------------------------------- Colonnes */

.site-footer__column {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.site-footer__heading {
	font-size: var(--fs-sm);
	font-weight: var(--fw-bold);
	text-transform: uppercase;
	letter-spacing: var(--ls-widest);
	color: var(--color-text);
	margin-bottom: var(--space-2xs);
}

/* Colonne 1 — branding */

.site-footer__logo {
	display: inline-block;
	max-width: 200px;
}

.site-footer__logo img {
	max-height: 48px;
	width: auto;
}

.site-footer__brand-text {
	font-size: var(--fs-xl);
	font-weight: var(--fw-bold);
	text-transform: uppercase;
	letter-spacing: var(--ls-wide);
	color: var(--color-text);
}

.site-footer__tagline {
	font-size: var(--fs-sm);
	line-height: var(--lh-base);
	color: var(--color-text-muted);
	max-width: 280px;
}

.site-footer__tagline p {
	margin: 0 0 var(--space-xs);
}

.site-footer__tagline p:last-child {
	margin-bottom: 0;
}

.site-footer__tagline a {
	color: var(--color-accent);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.site-footer__tagline a:hover,
.site-footer__tagline a:focus-visible {
	color: var(--color-accent-light);
}

/* Bloc contact libre (wysiwyg) */
.site-footer__contact-content {
	font-size: var(--fs-sm);
	line-height: var(--lh-base);
	color: var(--color-text-muted);
}

.site-footer__contact-content p {
	margin: 0 0 var(--space-xs);
}

.site-footer__contact-content p:last-child {
	margin-bottom: 0;
}

.site-footer__contact-content a {
	color: var(--color-text);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out);
}

.site-footer__contact-content a:hover,
.site-footer__contact-content a:focus-visible {
	color: var(--color-accent);
	border-bottom-color: var(--color-accent);
}

/* Intro texte au-dessus des icônes sociales */
.site-footer__social-intro {
	font-size: var(--fs-sm);
	line-height: var(--lh-base);
	color: var(--color-text-muted);
	margin-bottom: var(--space-md);
}

.site-footer__social-intro p {
	margin: 0 0 var(--space-2xs);
}

.site-footer__social-intro p:last-child {
	margin-bottom: 0;
}

.site-footer__social-intro a {
	color: var(--color-accent);
}

/* Colonne 2 — adresse */

.site-footer__address {
	font-size: var(--fs-sm);
	line-height: var(--lh-base);
	color: var(--color-text-muted);
	font-style: normal;
}

.site-footer__address p {
	font-size: inherit;
	color: inherit;
	line-height: inherit;
}

.site-footer__contact {
	font-size: var(--fs-sm);
}

.site-footer__contact a {
	color: var(--color-text-muted);
	transition: color var(--duration-fast) var(--ease-out);
}

.site-footer__contact a:hover,
.site-footer__contact a:focus-visible {
	color: var(--color-accent);
}

/* Colonne 3 — navigation */

.site-footer__nav-list {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
}

.site-footer__nav-list .menu-item > a,
.site-footer__nav-list a {
	display: inline-block;
	padding: var(--space-3xs) 0;
	font-size: var(--fs-sm);
	color: var(--color-text-muted);
	transition: color var(--duration-fast) var(--ease-out), padding-left var(--duration-base) var(--ease-out);
}

.site-footer__nav-list .menu-item > a:hover,
.site-footer__nav-list .menu-item.current-menu-item > a {
	color: var(--color-accent);
	padding-left: var(--space-2xs);
}

/* Colonne 4 — social */

.social-icons--footer {
	gap: var(--space-2xs);
}

.social-icons--footer .social-icons__link {
	width: 40px;
	height: 40px;
	border: 1px solid var(--color-border-strong);
}

.social-icons--footer .social-icons__link:hover,
.social-icons--footer .social-icons__link:focus-visible {
	color: var(--color-accent);
	border-color: var(--color-accent);
}

/* ---------------------------------------------------------- Bandeau bas (copyright) */

.site-footer__bottom {
	border-top: 1px solid var(--color-border);
	padding-block: var(--space-md);
}

.site-footer__copyright {
	font-size: var(--fs-xs);
	color: var(--color-text-muted);
	text-align: center;
	letter-spacing: var(--ls-wide);
}
