/**
 * Layout — container, grid, header, footer
 */

.container {
	width: 100%;
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--space-lg);
}

.container--wide   { max-width: var(--container-wide); }
.container--narrow { max-width: var(--container-narrow); }

/* ============================================
   HEADER GLOBAL
   ============================================ */

.site-header {
	position: sticky;
	top: 0;
	z-index: var(--z-header);
	background: var(--bg);
	border-bottom: 1px solid var(--border);
	transition: box-shadow var(--transition-base), background var(--transition-base);
}

.site-header.is-scrolled {
	box-shadow: var(--shadow-md);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-lg);
	height: var(--header-height);
}

@media (max-width: 768px) {
	.site-header__inner {
		height: var(--header-height-mobile);
	}
}

/* Logo / branding */
.site-branding {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	text-decoration: none;
	color: var(--text);
}

.site-branding__logo {
	height: 48px;
	width: auto;
	max-width: 200px;
	object-fit: contain;
}

@media (max-width: 768px) {
	.site-branding__logo {
		height: 38px;
		max-width: 160px;
	}
}

/* Le logo SVG contient déjà le monogramme + la baseline,
   donc on n'affiche le bloc texte qu'en fallback (sans logo). */
.site-branding__text {
	display: none;
}

.site-branding__name {
	font-family: var(--font-titles);
	font-weight: 700;
	font-size: var(--fs-lg);
	color: var(--text);
}

.site-branding__tagline {
	font-size: 10px;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--accent);
	margin-top: 2px;
}

/* Nav principale */
.site-nav {
	display: flex;
	align-items: center;
	gap: var(--space-xl);
}

@media (max-width: 1024px) {
	.site-nav {
		display: none;
	}
}

.site-nav__menu {
	display: flex;
	gap: 2px;
	list-style: none;
	padding: 0;
	margin: 0;
	flex-wrap: nowrap;
}

.site-nav__menu li {
	margin: 0;
	flex-shrink: 0;
}

/* Liens du menu : bulle élégante au survol — JAMAIS sur 2 lignes */
.site-nav__link {
	display: inline-block;
	font-weight: 600;
	font-size: 13.5px;
	color: var(--text);
	text-decoration: none;
	padding: 9px 14px;
	border-radius: 999px;
	white-space: nowrap;
	letter-spacing: 0.005em;
	transition: color 0.3s ease, background-color 0.3s ease,
	            transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1),
	            box-shadow 0.3s ease;
	position: relative;
}

.site-nav__link:hover {
	color: var(--accent);
	background: var(--bg-alt);
	transform: translateY(-1px);
	box-shadow: 0 6px 14px -6px rgba(0, 0, 0, 0.12);
}

/* Adapté à l'univers médical : ombre bleue */
body.is-medical .site-nav__link:hover {
	box-shadow: 0 6px 14px -6px rgba(42, 111, 186, 0.3);
}

/* Item actif : bulle plein accent */
.site-nav__link[aria-current="page"],
.site-nav__menu .current-menu-item > .site-nav__link {
	background: linear-gradient(135deg, var(--accent), var(--accent-hover));
	color: var(--on-accent);
	box-shadow: 0 8px 18px -6px rgba(0, 0, 0, 0.2);
}
body.is-medical .site-nav__link[aria-current="page"],
body.is-medical .site-nav__menu .current-menu-item > .site-nav__link {
	box-shadow: 0 8px 20px -6px rgba(42, 111, 186, 0.5);
}

/* Sur écran moyen, on resserre encore pour que tout tienne */
@media (max-width: 1180px) {
	.site-nav__menu { gap: 0; }
	.site-nav__link { padding: 9px 11px; font-size: 13px; }
}

/* Actions header (langue + tel) */
.site-header__actions {
	display: flex;
	align-items: center;
	gap: var(--space-md);
}

.site-header__phone {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	padding: var(--space-sm) var(--space-md);
	background: var(--accent);
	color: var(--on-accent);
	font-weight: 700;
	border-radius: var(--radius-pill);
	text-decoration: none;
	font-size: var(--fs-sm);
	transition: background var(--transition-fast), transform var(--transition-fast);
}

.site-header__phone:hover {
	background: var(--accent-hover);
	color: var(--on-accent);
	transform: translateY(-1px);
}

@media (max-width: 480px) {
	.site-header__phone span {
		display: none;
	}
	.site-header__phone {
		padding: var(--space-sm);
		width: 40px;
		height: 40px;
		justify-content: center;
	}
}

/* Langue */
.lang-switcher {
	display: flex;
	gap: var(--space-xs);
	font-size: var(--fs-sm);
	font-weight: 600;
}

.lang-switcher a {
	color: var(--text-muted);
	padding: var(--space-xs) var(--space-sm);
	border-radius: var(--radius-sm);
	text-decoration: none;
}

.lang-switcher a.is-active {
	color: var(--accent);
	background: var(--bg-alt);
}

/* Burger mobile */
.site-burger {
	display: none;
	width: 44px;
	height: 44px;
	align-items: center;
	justify-content: center;
	border-radius: var(--radius-sm);
}

@media (max-width: 1024px) {
	.site-burger {
		display: inline-flex;
	}
}

.site-burger__lines,
.site-burger__lines::before,
.site-burger__lines::after {
	display: block;
	width: 22px;
	height: 2px;
	background: var(--text);
	transition: transform var(--transition-base), opacity var(--transition-base);
}

.site-burger__lines {
	position: relative;
}

.site-burger__lines::before,
.site-burger__lines::after {
	content: '';
	position: absolute;
	left: 0;
}

.site-burger__lines::before { top: -7px; }
.site-burger__lines::after  { top:  7px; }

.site-burger[aria-expanded="true"] .site-burger__lines               { background: transparent; }
.site-burger[aria-expanded="true"] .site-burger__lines::before       { top: 0; transform: rotate(45deg); }
.site-burger[aria-expanded="true"] .site-burger__lines::after        { top: 0; transform: rotate(-45deg); }

/* Drawer mobile */
.mobile-drawer {
	position: fixed;
	inset: 0;
	background: var(--bg);
	z-index: var(--z-modal);
	transform: translateX(100%);
	transition: transform var(--transition-slow);
	display: flex;
	flex-direction: column;
	padding: var(--header-height-mobile) var(--space-lg) var(--space-xl);
	overflow-y: auto;
}

.mobile-drawer[aria-hidden="false"] {
	transform: translateX(0);
}

.mobile-drawer__menu {
	list-style: none;
	padding: 0;
	margin: var(--space-xl) 0 0;
}

.mobile-drawer__menu li + li {
	margin-top: 0;
	border-top: 1px solid var(--border);
}

.mobile-drawer__menu a {
	display: block;
	padding: var(--space-md) 0;
	font-size: var(--fs-lg);
	font-weight: 600;
	color: var(--text);
	text-decoration: none;
}

/* ============================================
   FOOTER GLOBAL
   ============================================ */

.site-footer {
	background: var(--bg-alt);
	color: var(--text);
	margin-top: var(--space-4xl);
	padding-block: var(--space-3xl) var(--space-xl);
	border-top: 1px solid var(--border);
}

.site-footer__grid {
	display: grid;
	gap: var(--space-2xl);
	grid-template-columns: 1.5fr repeat(3, 1fr);
}

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

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

.site-footer h4 {
	font-family: var(--font-body);
	font-size: var(--fs-sm);
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--accent);
	margin-bottom: var(--space-md);
}

.site-footer ul {
	list-style: none;
	padding: 0;
}

.site-footer ul li + li {
	margin-top: var(--space-sm);
}

.site-footer a {
	color: var(--text-muted);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.site-footer a:hover {
	color: var(--accent);
}

.site-footer__logo {
	height: 56px;
	width: auto;
	max-width: 220px;
}

.site-footer__contact {
	color: var(--text-muted);
	line-height: var(--lh-relaxed);
}

.site-footer__contact strong {
	display: block;
	color: var(--text);
	margin-bottom: var(--space-sm);
}

.site-footer__cpam-badge {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	padding: var(--space-xs) var(--space-md);
	background: rgba(76, 175, 142, 0.12);
	color: var(--color-success);
	border-radius: var(--radius-pill);
	font-size: var(--fs-xs);
	font-weight: 700;
	margin-top: var(--space-md);
}

.site-footer__bottom {
	margin-top: var(--space-2xl);
	padding-top: var(--space-lg);
	border-top: 1px solid var(--border);
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--space-md);
	font-size: var(--fs-xs);
	color: var(--text-muted);
}

.site-footer__bottom a {
	color: var(--text-muted);
}

/* ============================================
   SECTIONS GÉNÉRIQUES
   ============================================ */

.section {
	padding-block: var(--space-3xl);
}

.section--sm { padding-block: var(--space-2xl); }
.section--lg { padding-block: var(--space-4xl); }

.section__title {
	margin-bottom: var(--space-xl);
}

.section__intro {
	font-size: var(--fs-lg);
	color: var(--text-muted);
	max-width: 640px;
	margin-bottom: var(--space-2xl);
}
