/*
Theme Name: Café Social 57
Theme URI: https://cafesocial57.fr/
Author: Café Social 57
Description: Thème WordPress éditorial, accessible et entièrement personnalisé pour le Café Social 57 à Metz.
Version: 2.0.0
Requires at least: 6.3
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: cafe-social-57
*/

:root {
	--turquoise: #73b1ac;
	--turquoise-deep: #3c8d88;
	--turquoise-dark: #236f6a;
	--coral: #ffa58f;
	--coral-warm: #f08a72;
	--brown: #775052;
	--ink: #29242a;
	--ivory: #fbf8f3;
	--beige: #f2ece4;
	--white: #fff;
	--border: rgba(41, 36, 42, 0.13);
	--font-display: Fraunces, Lora, Georgia, 'Times New Roman', serif;
	--font-sans: Manrope, Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--container: 1380px;
	--page-pad: clamp(20px, 4.2vw, 72px);
	--section-space: clamp(88px, 10vw, 168px);
	--radius-sm: 12px;
	--radius-card: 22px;
	--radius-lg: 34px;
	--radius-xl: 44px;
	--ease: cubic-bezier(0.22, 1, 0.36, 1);
}

*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; scroll-padding-top: 110px; }

body {
	margin: 0;
	background: var(--ivory);
	color: var(--ink);
	font-family: var(--font-sans);
	font-size: clamp(16px, 1.2vw, 18px);
	line-height: 1.68;
	-webkit-font-smoothing: antialiased;
	overflow-x: clip;
}

body.menu-open { overflow: hidden; }

img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
button { color: inherit; }
p, h1, h2, h3, h4 { margin-top: 0; }

h1, h2, h3, h4 {
	font-family: var(--font-display);
	font-weight: 600;
	letter-spacing: -0.035em;
	line-height: 1.06;
}

h1 { font-size: clamp(3rem, 5.55vw, 6rem); }
h2 { font-size: clamp(2.15rem, 3.6vw, 4rem); }
h3 { font-size: clamp(1.42rem, 2vw, 2rem); }

::selection { background: var(--coral); color: var(--ink); }

:focus-visible {
	outline: 3px solid var(--coral-warm);
	outline-offset: 4px;
	border-radius: 4px;
}

.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.screen-reader-text:focus {
	top: 12px;
	left: 12px;
	z-index: 10000;
	width: auto;
	height: auto;
	padding: 12px 18px;
	clip: auto;
	background: var(--white);
	color: var(--ink);
}

.cs57-container {
	width: min(100% - (2 * var(--page-pad)), var(--container));
	margin-inline: auto;
}

.section-shell { position: relative; padding-block: var(--section-space); }
.section-shell + .section-shell { padding-top: 0; }

.section-label,
.eyebrow {
	margin-bottom: 22px;
	color: var(--turquoise-dark);
	font-size: 0.74rem;
	font-weight: 800;
	letter-spacing: 0.15em;
	line-height: 1.4;
	text-transform: uppercase;
}

.section-label--light { color: rgba(255, 255, 255, 0.8); }
.eyebrow { display: flex; align-items: center; gap: 12px; }
.eyebrow span { width: 34px; height: 2px; background: var(--coral); }
.rich-text { max-width: 660px; color: rgba(41, 36, 42, 0.75); }

.icon { width: 24px; height: 24px; flex: none; }

.icon-disc {
	display: inline-grid;
	place-items: center;
	width: 60px;
	height: 60px;
	border-radius: 50%;
	background: rgba(115, 177, 172, 0.18);
	color: var(--turquoise-dark);
}

.icon-disc--coral { background: rgba(255, 165, 143, 0.28); color: var(--brown); }

.button-row { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }

.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 54px;
	padding: 0 23px;
	gap: 12px;
	border: 1px solid transparent;
	border-radius: 999px;
	font-size: 0.9rem;
	font-weight: 750;
	line-height: 1.2;
	transition: transform 260ms var(--ease), background 260ms, color 260ms, border-color 260ms;
}

.button:hover { transform: translateY(-2px); }
.button:hover .icon, .text-link:hover .icon { transform: translateX(4px); }
.button .icon, .text-link .icon { width: 20px; transition: transform 240ms var(--ease); }
.button--small { min-height: 46px; padding-inline: 18px; }
.button--primary { background: var(--turquoise-dark); color: var(--white); }
.button--primary:hover { background: var(--brown); }
.button--outline { border-color: rgba(41, 36, 42, 0.25); background: rgba(255, 255, 255, 0.45); }
.button--outline:hover { border-color: var(--coral-warm); background: var(--white); }
.button--dark { background: var(--ink); color: var(--white); }
.button--dark:hover { background: var(--brown); }
.button--ghost { border-color: rgba(41, 36, 42, 0.23); }
.button--light { background: var(--white); color: var(--turquoise-dark); }
.button--ghost-light { border-color: rgba(255, 255, 255, 0.6); color: var(--white); }
.button--full { width: 100%; }

.text-link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding-bottom: 4px;
	border-bottom: 1px solid currentColor;
	color: var(--turquoise-dark);
	font-weight: 800;
	line-height: 1.4;
}

.image-frame { overflow: hidden; background: var(--beige); }
.image-frame img { width: 100%; height: 100%; object-fit: cover; }

.reveal { opacity: 1; transform: none; transition: opacity 560ms var(--ease), transform 560ms var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }

/* Header */
.site-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: rgba(251, 248, 243, 0.84);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	border-bottom: 1px solid transparent;
	transition: border-color 240ms, background 240ms;
}

.site-header.is-scrolled { border-color: var(--border); background: rgba(251, 248, 243, 0.95); }
.site-header__inner { display: flex; align-items: center; min-height: 104px; gap: clamp(18px, 2.6vw, 42px); transition: min-height 240ms; }
.site-header.is-scrolled .site-header__inner { min-height: 82px; }
.brand { display: block; flex: none; align-self: center; }
.brand__logo { width: 82px; height: 84px; object-fit: contain; transition: width 240ms, height 240ms; }
.site-header.is-scrolled .brand__logo { width: 64px; height: 66px; }
.desktop-nav { flex: 1; display: flex; justify-content: center; }
.menu { list-style: none; margin: 0; padding: 0; }
.primary-menu { display: flex; align-items: center; justify-content: center; gap: clamp(14px, 1.5vw, 28px); }
.primary-menu a { position: relative; display: block; padding-block: 14px; font-size: clamp(0.76rem, 0.9vw, 0.91rem); font-weight: 700; white-space: nowrap; }
.primary-menu a::after { content: ''; position: absolute; right: 0; bottom: 8px; left: 0; height: 2px; background: var(--coral); transform: scaleX(0); transform-origin: right; transition: transform 240ms var(--ease); }
.primary-menu a:hover::after, .primary-menu .current-menu-item > a::after { transform: scaleX(1); transform-origin: left; }
.header-actions { display: flex; align-items: center; gap: 12px; flex: none; }
.language { display: grid; place-items: center; min-width: 44px; min-height: 44px; border: 1px solid var(--border); border-radius: 50%; font-size: 0.75rem; font-weight: 800; }
.menu-toggle { display: none; width: 48px; height: 48px; padding: 13px 11px; border: 1px solid var(--border); border-radius: 50%; background: transparent; cursor: pointer; }
.menu-toggle span:not(.screen-reader-text) { display: block; width: 24px; height: 2px; margin: 5px auto; background: var(--ink); transition: transform 220ms, opacity 220ms; }
.menu-toggle[aria-expanded='true'] span:nth-of-type(2) { transform: translateY(7px) rotate(45deg); }
.menu-toggle[aria-expanded='true'] span:nth-of-type(3) { opacity: 0; }
.menu-toggle[aria-expanded='true'] span:nth-of-type(4) { transform: translateY(-7px) rotate(-45deg); }
.mobile-drawer { position: absolute; top: 100%; left: 0; width: 100%; max-height: 0; visibility: hidden; overflow: hidden; background: var(--ivory); border-bottom: 1px solid var(--border); transition: max-height 380ms var(--ease), visibility 380ms; }
.mobile-drawer[aria-hidden='false'] { max-height: calc(100vh - 80px); visibility: visible; overflow-y: auto; }
.mobile-drawer__inner { padding-block: 24px 30px; }
.mobile-menu a { display: block; padding: 13px 4px; border-bottom: 1px solid var(--border); font-family: var(--font-display); font-size: 1.45rem; font-weight: 600; }
.mobile-drawer .button { margin-top: 22px; }

/* Hero */
.hero { padding-top: clamp(42px, 5vw, 80px); overflow: hidden; }
.hero::before { content: ''; position: absolute; top: 8%; left: -10%; width: 36vw; height: 36vw; border-radius: 50%; background: radial-gradient(circle, rgba(255, 165, 143, 0.08), transparent 68%); pointer-events: none; }
.hero__grid { display: grid; grid-template-columns: minmax(0, 0.92fr) minmax(430px, 1.08fr); gap: clamp(34px, 6vw, 96px); align-items: center; }
.hero__content { position: relative; z-index: 2; padding-block: 24px; }
.hero h1 { max-width: 760px; margin-bottom: 28px; }
.hero h1 em { color: var(--coral-warm); font-style: italic; }
.hero__description { max-width: 630px; margin-bottom: 34px; color: rgba(41, 36, 42, 0.74); font-size: clamp(1rem, 1.2vw, 1.18rem); }
.hero__scribble { position: absolute; z-index: -1; width: 160px; right: 7%; top: 54%; fill: none; stroke: var(--turquoise); stroke-width: 3; stroke-linecap: round; }
.hero__visual { position: relative; min-height: min(680px, 48vw); }
.hero__shape { position: absolute; right: -9%; bottom: -5%; width: 74%; height: 58%; border-radius: 46% 54% 34% 66% / 56% 34% 66% 44%; background: linear-gradient(145deg, var(--turquoise), var(--turquoise-deep)); transform: rotate(-8deg); }
.hero__image { position: absolute; inset: 0 3% 3% 0; border-radius: 46% 54% 22% 48% / 32% 35% 65% 68%; box-shadow: 0 28px 75px rgba(35, 111, 106, 0.12); }
.hero__badge { position: absolute; z-index: 3; left: -58px; bottom: 9%; display: grid; place-items: center; width: 160px; aspect-ratio: 1; border-radius: 50%; background: var(--coral); color: var(--brown); transform: rotate(-7deg); }
.hero__badge svg { position: absolute; inset: 6px; width: calc(100% - 12px); fill: none; stroke: var(--brown); stroke-width: 1.5; stroke-dasharray: 5 4; }
.hero__badge span { text-align: center; font-family: var(--font-display); font-size: 1.26rem; font-style: italic; font-weight: 700; line-height: 1.02; }

/* Intro and values */
.intro__grid { display: grid; grid-template-columns: minmax(320px, 0.85fr) minmax(0, 1.15fr); gap: clamp(52px, 8vw, 130px); align-items: start; }
.intro .section-heading { position: sticky; top: 130px; }
.intro .section-heading h2 { max-width: 640px; margin-bottom: 30px; }
.intro .text-link { margin-top: 14px; }
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.value-card { position: relative; min-height: 430px; padding: 40px 28px 34px; border-right: 1px solid var(--border); }
.value-card:last-child { border-right: 0; }
.value-card__number { position: absolute; top: 20px; right: 18px; color: rgba(41, 36, 42, 0.16); font-family: var(--font-display); font-size: 1rem; font-weight: 700; }
.value-card h3 { margin: 72px 0 18px; }
.value-card p { margin: 0; color: rgba(41, 36, 42, 0.68); font-size: 0.95rem; }

/* Activities */
.activities { background: var(--beige); padding-top: var(--section-space) !important; }
.activities__layout { display: grid; grid-template-columns: minmax(260px, 0.34fr) minmax(0, 1fr); gap: clamp(38px, 5vw, 78px); align-items: start; }
.activities__intro { position: sticky; top: 120px; }
.activities__intro h2 { margin-bottom: 24px; }
.activities__intro > p:not(.section-label) { max-width: 460px; margin-bottom: 30px; color: rgba(41, 36, 42, 0.7); }
.activities__arrow { width: 130px; margin: 38px 0 0 42%; fill: none; stroke: var(--coral-warm); stroke-width: 2; stroke-linecap: round; }
.activity-cards { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.activity-card { overflow: hidden; border: 1px solid rgba(41, 36, 42, 0.08); border-radius: var(--radius-card); background: var(--white); transition: transform 280ms var(--ease), box-shadow 280ms; }
.activity-card:hover { transform: translateY(-7px); box-shadow: 0 22px 50px rgba(41, 36, 42, 0.09); }
.activity-card__image { position: relative; display: block; overflow: hidden; aspect-ratio: 1.25; background: #dfeae8; }
.activity-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform 450ms var(--ease); }
.activity-card:hover .activity-card__image img { transform: scale(1.035); }
.category-pill { position: absolute; left: 16px; bottom: 16px; padding: 7px 11px; border-radius: 999px; background: rgba(255, 255, 255, 0.93); color: var(--turquoise-dark); font-size: 0.64rem; font-weight: 850; letter-spacing: 0.11em; }
.activity-card__body { padding: 26px 24px 22px; }
.activity-card h3 { min-height: 2.2em; margin-bottom: 15px; font-size: clamp(1.25rem, 1.55vw, 1.65rem); }
.activity-card__body > p { min-height: 7.5em; color: rgba(41, 36, 42, 0.68); font-size: 0.9rem; }
.activity-card__meta { display: flex; align-items: center; gap: 9px; padding-top: 18px; border-top: 1px solid var(--border); color: var(--turquoise-dark); font-size: 0.76rem; font-weight: 800; }
.activity-card__meta .icon { width: 18px; }
.activity-card__meta a { display: grid; place-items: center; width: 38px; height: 38px; margin-left: auto; border-radius: 50%; background: var(--beige); }

/* Administrative support */
.admin-support { background: var(--beige); }
.admin-support__card { display: grid; grid-template-columns: 0.72fr 1fr 0.55fr; gap: clamp(28px, 4vw, 60px); align-items: center; padding: clamp(24px, 3vw, 42px); border-radius: var(--radius-lg); background: var(--ivory); border: 1px solid var(--border); }
.admin-support__image { overflow: hidden; aspect-ratio: 1.15; border-radius: 26px 26px 50% 26px; }
.admin-support__image img { width: 100%; height: 100%; object-fit: cover; }
.admin-support__copy .icon-disc { margin-bottom: 24px; }
.admin-support__copy .section-label { margin-bottom: 12px; }
.admin-support__copy h2 { margin-bottom: 18px; font-size: clamp(2rem, 2.8vw, 3.2rem); }
.admin-support__copy > p:last-child { margin: 0; color: rgba(41, 36, 42, 0.7); }
.admin-support__schedule { padding-left: clamp(22px, 3vw, 44px); border-left: 1px solid var(--border); }
.admin-support__schedule > span { color: var(--coral-warm); font-size: 0.74rem; font-weight: 850; letter-spacing: 0.12em; text-transform: uppercase; }
.admin-support__schedule p { margin: 14px 0 25px; font-weight: 700; }

/* Impact */
.impact { padding-top: var(--section-space) !important; }
.impact__panel { position: relative; overflow: hidden; padding: clamp(40px, 6vw, 84px); border-radius: var(--radius-xl); background: linear-gradient(135deg, var(--turquoise-dark), var(--turquoise-deep) 68%, #559d98); color: var(--white); }
.impact__panel::before { content: ''; position: absolute; right: -10%; top: -22%; width: 500px; height: 500px; border: 1px solid rgba(255, 255, 255, 0.14); border-radius: 50%; }
.impact__topline { position: relative; z-index: 1; display: grid; grid-template-columns: 0.4fr 1fr; gap: 40px; align-items: end; margin-bottom: 54px; }
.impact__topline h2 { max-width: 760px; margin: 0; }
.impact__content { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1fr) minmax(240px, 0.35fr); gap: 36px; }
.impact__stats { display: grid; grid-template-columns: repeat(5, 1fr); align-items: stretch; }
.impact-item { display: flex; flex-direction: column; min-width: 0; padding: 6px clamp(14px, 2vw, 28px); border-right: 1px solid rgba(255, 255, 255, 0.24); }
.impact-item:first-child { padding-left: 0; }
.impact-item:last-child { border-right: 0; }
.impact-item .icon { margin-bottom: 34px; color: var(--coral); }
.impact-item strong { display: block; font-family: var(--font-display); font-size: clamp(2.1rem, 3.1vw, 3.8rem); font-weight: 600; line-height: 1; letter-spacing: -0.04em; }
.impact-item span { margin-top: 12px; color: rgba(255, 255, 255, 0.78); font-size: 0.8rem; line-height: 1.45; }
.impact__image { min-height: 270px; border-radius: 26px 26px 60% 26px; }

/* Charter */
.charter__heading { display: grid; grid-template-columns: 0.35fr 1fr; gap: 48px; align-items: start; margin-bottom: clamp(48px, 6vw, 88px); }
.charter__heading h2 { max-width: 800px; }
.charter__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-block: 1px solid var(--border); }
.principle { min-height: 320px; padding: 40px clamp(24px, 3vw, 48px); border-right: 1px solid var(--border); }
.principle:first-child { padding-left: 0; }
.principle:last-child { border-right: 0; }
.principle > span { color: var(--coral-warm); font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; }
.principle h3 { margin: 58px 0 18px; }
.principle p { margin: 0; color: rgba(41, 36, 42, 0.68); }
.charter__highlight { display: flex; gap: 18px; align-items: center; max-width: 880px; margin: 54px auto 0; padding: 24px 30px; border: 1px solid rgba(115, 177, 172, 0.35); border-radius: 999px; background: rgba(115, 177, 172, 0.1); }
.charter__highlight span { color: var(--coral-warm); font-size: 1.7rem; }
.charter__highlight p { margin: 0; font-family: var(--font-display); font-size: 1.15rem; font-weight: 600; }

/* Project */
.project { background: var(--white); padding-top: var(--section-space) !important; }
.project__grid { display: grid; grid-template-columns: 1.08fr 0.92fr; gap: clamp(54px, 9vw, 140px); align-items: center; }
.project__visual { position: relative; padding: 0 60px 80px 0; }
.project__image { aspect-ratio: 1.12; border-radius: 35% 26px 34% 26px; }
.testimonial { position: absolute; right: 0; bottom: 0; width: min(440px, 65%); margin: 0; padding: 28px 30px; border-radius: var(--radius-card); background: var(--ivory); box-shadow: 0 20px 60px rgba(41, 36, 42, 0.12); }
.testimonial .icon { color: var(--coral-warm); }
.testimonial p { margin: 16px 0 12px; font-family: var(--font-display); font-size: clamp(1.08rem, 1.5vw, 1.45rem); font-style: italic; line-height: 1.35; }
.testimonial cite { color: var(--turquoise-dark); font-size: 0.74rem; font-style: normal; font-weight: 800; }
.project__copy h2 { margin-bottom: 30px; }
.project__copy > p:not(.section-label) { max-width: 620px; margin-bottom: 30px; color: rgba(41, 36, 42, 0.7); font-size: 1.05rem; }

/* Volunteers */
.volunteers { background: var(--white); }
.volunteers__panel { display: grid; grid-template-columns: 1fr 0.75fr; overflow: hidden; min-height: 570px; border-radius: var(--radius-xl); background: var(--coral); }
.volunteers__copy { display: flex; flex-direction: column; justify-content: center; padding: clamp(42px, 6vw, 90px); }
.volunteers__copy .section-label { color: var(--brown); }
.volunteers__copy h2 { max-width: 760px; margin-bottom: 25px; }
.volunteers__copy > p:not(.section-label) { max-width: 670px; margin-bottom: 32px; color: rgba(41, 36, 42, 0.75); }
.volunteers__image { margin: 22px; border-radius: 28px 28px 28px 45%; }

/* Team */
.section-heading--row { display: flex; justify-content: space-between; gap: 40px; align-items: end; margin-bottom: 54px; }
.section-heading--row h2 { margin-bottom: 0; }
.section-heading--row > p { max-width: 560px; margin: 0; color: rgba(41, 36, 42, 0.68); }
.team-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px; }
.team-card__image { display: grid; place-items: center; overflow: hidden; aspect-ratio: 0.88; border-radius: 90px 90px 24px 24px; background: var(--beige); color: var(--turquoise-deep); font-family: var(--font-display); font-size: 4rem; }
.team-card__image img { width: 100%; height: 100%; object-fit: cover; }
.team-card h3 { margin: 18px 0 5px; font-size: 1.15rem; }
.team-card p { margin: 0; color: var(--turquoise-dark); font-size: 0.74rem; font-weight: 750; }
.role-cloud { display: flex; flex-wrap: wrap; gap: 12px; padding: clamp(28px, 4vw, 52px); border: 1px solid var(--border); border-radius: var(--radius-lg); background: var(--white); }
.role-cloud span { padding: 12px 18px; border-radius: 999px; background: var(--beige); font-size: 0.88rem; font-weight: 750; }
.role-cloud span:nth-child(3n + 1) { background: rgba(115, 177, 172, 0.18); }
.role-cloud span:nth-child(4n) { background: rgba(255, 165, 143, 0.22); }

/* News */
.news { background: var(--beige); padding-top: var(--section-space) !important; }
.news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.news-card { overflow: hidden; border-radius: var(--radius-card); background: var(--white); }
.news-card__image { display: block; overflow: hidden; aspect-ratio: 1.38; }
.news-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform 420ms var(--ease); }
.news-card:hover .news-card__image img { transform: scale(1.035); }
.news-card__body { padding: 26px; }
.post-meta { display: flex; gap: 9px; margin-bottom: 16px; color: var(--turquoise-dark); font-size: 0.68rem; font-weight: 800; letter-spacing: 0.07em; text-transform: uppercase; }
.post-meta > * + *::before { content: '•'; margin-right: 9px; color: var(--coral-warm); }
.news-card h3 { margin-bottom: 14px; }
.news-card__body > p { color: rgba(41, 36, 42, 0.68); font-size: 0.9rem; }
.news-card .text-link { font-size: 0.82rem; }
.empty-state { padding: 32px; border: 1px dashed rgba(41, 36, 42, 0.2); border-radius: var(--radius-card); text-align: center; color: rgba(41, 36, 42, 0.65); }

/* Partners */
.partners { padding-block: clamp(70px, 8vw, 110px); background: var(--beige); border-top: 1px solid var(--border); text-align: center; }
.partners h2 { margin-bottom: 44px; font-size: clamp(2rem, 3vw, 3.3rem); }
.partner-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px; }
.partner-logo { display: grid; place-items: center; min-height: 112px; padding: 20px; border: 1px solid var(--border); border-radius: 18px; background: rgba(255, 255, 255, 0.65); }
.partner-logo img { max-width: 150px; max-height: 66px; width: auto; filter: grayscale(1); opacity: 0.65; transition: filter 260ms, opacity 260ms; }
.partner-logo:hover img { filter: none; opacity: 1; }
.partner-logo span, .partner-placeholder { color: rgba(41, 36, 42, 0.62); font-size: 0.86rem; font-weight: 700; }

/* Visit */
.visit { background: var(--beige); }
.visit__panel { display: grid; grid-template-columns: 1fr 0.88fr; overflow: hidden; min-height: 630px; border-radius: var(--radius-xl); background: var(--turquoise-dark); color: var(--white); }
.visit__copy { padding: clamp(42px, 6vw, 86px); }
.visit__copy h2 { margin-bottom: 36px; }
.visit__details { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; margin-bottom: 36px; }
.visit__details > div { display: flex; gap: 14px; align-items: flex-start; }
.visit__details > div:last-child { grid-column: 1 / -1; }
.visit__details .icon { color: var(--coral); }
.visit__details p, .visit__details address { margin: 0; color: rgba(255, 255, 255, 0.86); font-style: normal; }
.visit__image { margin: 22px; border-radius: 28px 28px 46% 28px; }

/* Footer */
.site-footer { position: relative; overflow: hidden; padding-top: 0; background: var(--ink); color: var(--white); }
.site-footer__pattern { height: 62px; background: var(--ivory) url('brand-pattern.png') center bottom / auto 62px repeat-x; }
.site-footer__grid { display: grid; grid-template-columns: 1.5fr repeat(4, 1fr) 1.25fr; gap: clamp(24px, 3vw, 48px); padding-block: 70px 54px; }
.footer-logo { width: 110px; height: 113px; object-fit: contain; }
.footer-brand p { max-width: 300px; margin: 22px 0; color: rgba(255, 255, 255, 0.65); font-size: 0.85rem; }
.social-links { display: flex; flex-wrap: wrap; gap: 10px; }
.social-links a { padding-bottom: 2px; border-bottom: 1px solid rgba(255, 255, 255, 0.4); font-size: 0.75rem; }
.footer-column h2 { margin-bottom: 20px; color: var(--coral); font-family: var(--font-sans); font-size: 0.78rem; font-weight: 850; letter-spacing: 0.1em; text-transform: uppercase; }
.footer-menu li + li { margin-top: 9px; }
.footer-menu a, .footer-contact, .footer-contact a { color: rgba(255, 255, 255, 0.68); font-size: 0.78rem; }
.footer-menu a:hover, .footer-contact a:hover { color: var(--white); }
.footer-contact { display: flex; flex-direction: column; align-items: flex-start; gap: 10px; }
.footer-contact address { font-style: normal; }
.footer-bottom { display: flex; justify-content: space-between; gap: 20px; padding-block: 24px; border-top: 1px solid rgba(255, 255, 255, 0.12); color: rgba(255, 255, 255, 0.48); font-size: 0.72rem; }
.footer-bottom p { margin: 0; }
.legal-menu { display: flex; flex-wrap: wrap; gap: 18px; }

/* Generic content and archives */
.content-page { min-height: 60vh; padding-block: clamp(60px, 8vw, 120px); }
.content-page__header { max-width: 900px; margin-bottom: 50px; }
.content-page__header p { color: rgba(41, 36, 42, 0.66); }
.entry-content { max-width: 820px; font-size: 1.04rem; }
.entry-content > * + * { margin-top: 1.25em; }
.entry-content a { color: var(--turquoise-dark); text-decoration: underline; text-underline-offset: 3px; }
.single-featured { max-width: 1120px; aspect-ratio: 1.7; margin-bottom: 42px; border-radius: var(--radius-lg); }
.activity-facts { display: flex; flex-wrap: wrap; gap: 14px; max-width: 900px; margin-bottom: 38px; }
.activity-facts > div { display: flex; align-items: center; gap: 10px; padding: 12px 17px; border-radius: 999px; background: var(--beige); color: var(--turquoise-dark); font-size: .86rem; font-weight: 750; }
.archive-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.archive-card { padding: 30px; border: 1px solid var(--border); border-radius: var(--radius-card); background: var(--white); }
.archive-card .category-pill { position: static; display: inline-block; margin-bottom: 18px; background: var(--beige); }
.archive-card p { color: rgba(41, 36, 42, 0.68); }
.pagination { margin-top: 50px; }
.nav-links { display: flex; gap: 8px; }
.page-numbers { display: grid; place-items: center; min-width: 44px; height: 44px; padding: 0 12px; border: 1px solid var(--border); border-radius: 50%; }
.page-numbers.current { background: var(--turquoise-dark); color: var(--white); }

@media (max-width: 1240px) {
	.desktop-nav { display: none; }
	.menu-toggle { display: block; }
	.header-actions { margin-left: auto; }
	.hero__grid { grid-template-columns: minmax(0, 0.95fr) minmax(390px, 1.05fr); gap: 44px; }
	.hero__badge { left: -35px; width: 138px; }
	.values-grid { grid-template-columns: 1fr; }
	.value-card { min-height: auto; padding: 28px; border-right: 0; border-bottom: 1px solid var(--border); }
	.value-card:last-child { border-bottom: 0; }
	.value-card h3 { margin: 30px 0 12px; }
	.activity-cards { grid-template-columns: repeat(2, 1fr); }
	.activity-card:last-child { grid-column: 1 / -1; display: grid; grid-template-columns: 0.75fr 1fr; }
	.activity-card__body > p { min-height: auto; }
	.admin-support__card { grid-template-columns: 0.55fr 1fr; }
	.admin-support__schedule { grid-column: 1 / -1; display: grid; grid-template-columns: 1fr 1fr auto; align-items: center; padding: 24px 0 0; border-left: 0; border-top: 1px solid var(--border); }
	.admin-support__schedule p { margin: 0; }
	.impact__content { grid-template-columns: 1fr; }
	.impact__image { min-height: 360px; }
	.team-grid { grid-template-columns: repeat(3, 1fr); }
	.partner-grid { grid-template-columns: repeat(3, 1fr); }
	.site-footer__grid { grid-template-columns: 1.5fr repeat(3, 1fr); }
	.footer-brand { grid-row: span 2; }
}

@media (max-width: 980px) {
	:root { --page-pad: clamp(20px, 4vw, 36px); --section-space: clamp(76px, 11vw, 118px); }
	.hero__grid { grid-template-columns: 1fr; }
	.hero__content { max-width: 760px; }
	.hero__visual { min-height: min(700px, 92vw); margin-left: 8%; }
	.hero__scribble { right: 3%; }
	.intro__grid { grid-template-columns: 1fr; gap: 52px; }
	.intro .section-heading, .activities__intro { position: static; }
	.values-grid { grid-template-columns: repeat(3, 1fr); }
	.value-card { padding: 28px 22px; border-right: 1px solid var(--border); border-bottom: 0; }
	.value-card:last-child { border-right: 0; }
	.activities__layout { grid-template-columns: 1fr; }
	.activities__intro { display: grid; grid-template-columns: 1fr auto; column-gap: 28px; align-items: end; }
	.activities__intro .section-label, .activities__intro h2, .activities__intro > p { grid-column: 1; }
	.activities__intro .button { grid-column: 2; grid-row: 2 / 4; }
	.activities__arrow { display: none; }
	.impact__topline { grid-template-columns: 1fr; gap: 8px; }
	.impact__stats { grid-template-columns: repeat(3, 1fr); }
	.impact-item { min-height: 190px; border-bottom: 1px solid rgba(255, 255, 255, 0.24); }
	.impact-item:nth-child(3) { border-right: 0; }
	.impact-item:nth-child(4), .impact-item:nth-child(5) { padding-top: 28px; border-bottom: 0; }
	.project__grid { grid-template-columns: 1fr; }
	.project__copy { order: -1; max-width: 720px; }
	.volunteers__panel, .visit__panel { grid-template-columns: 1fr; }
	.volunteers__image, .visit__image { min-height: 450px; }
	.charter__heading { grid-template-columns: 1fr; gap: 10px; }
	.news-grid { grid-template-columns: 1fr 1fr; }
	.news-card:last-child { grid-column: 1 / -1; }
	.site-footer__grid { grid-template-columns: repeat(3, 1fr); }
	.footer-brand { grid-column: 1 / -1; grid-row: auto; }
}

@media (max-width: 720px) {
	.site-header__inner { min-height: 82px; }
	.brand__logo { width: 60px; height: 62px; }
	.site-header .header-actions > .button, .language { display: none; }
	.hero { padding-top: 30px; }
	.hero h1 { font-size: clamp(2.75rem, 13.4vw, 4.3rem); }
	.hero__visual { min-height: 112vw; margin: 0 0 0 6%; }
	.hero__image { inset: 0 0 5% 0; }
	.hero__badge { left: -7%; bottom: 4%; width: 124px; }
	.hero__badge span { font-size: 1rem; }
	.hero__scribble { top: 48%; width: 120px; }
	.button-row { align-items: stretch; }
	.hero .button-row .button, .volunteers .button-row .button, .visit .button-row .button { width: 100%; }
	.values-grid { grid-template-columns: 1fr; }
	.value-card { border-right: 0; border-bottom: 1px solid var(--border); }
	.value-card:last-child { border-bottom: 0; }
	.activities__intro { display: block; }
	.activities__intro .button { margin-top: 6px; }
	.activity-cards { display: grid; grid-template-columns: 1fr; }
	.activity-card:last-child { grid-column: auto; display: block; }
	.admin-support__card { grid-template-columns: 1fr; }
	.admin-support__image { aspect-ratio: 1.3; }
	.admin-support__schedule { grid-column: auto; grid-template-columns: 1fr; gap: 16px; }
	.impact__panel { width: calc(100% - 24px); padding: 36px 24px; border-radius: 34px; }
	.impact__stats { grid-template-columns: 1fr 1fr; }
	.impact-item, .impact-item:nth-child(3), .impact-item:nth-child(4), .impact-item:nth-child(5) { min-height: 170px; padding: 24px 18px; border-right: 1px solid rgba(255, 255, 255, 0.24); border-bottom: 1px solid rgba(255, 255, 255, 0.24); }
	.impact-item:nth-child(2n) { border-right: 0; }
	.impact-item:last-child { grid-column: 1 / -1; border-right: 0; border-bottom: 0; }
	.impact-item .icon { margin-bottom: 24px; }
	.charter__grid { grid-template-columns: 1fr; }
	.principle, .principle:first-child { min-height: auto; padding: 30px 0; border-right: 0; border-bottom: 1px solid var(--border); }
	.principle:last-child { border-bottom: 0; }
	.principle h3 { margin: 28px 0 12px; }
	.charter__highlight { align-items: flex-start; border-radius: var(--radius-card); }
	.project__visual { padding: 0 0 120px; }
	.project__image { aspect-ratio: 0.9; }
	.testimonial { right: -8px; width: 90%; }
	.volunteers__panel { width: calc(100% - 24px); }
	.volunteers__copy { padding: 38px 24px; }
	.volunteers__image, .visit__image { min-height: 360px; }
	.section-heading--row { display: block; }
	.section-heading--row > p, .section-heading--row > .text-link { margin-top: 20px; }
	.team-grid { grid-template-columns: 1fr 1fr; }
	.news-grid { grid-template-columns: 1fr; }
	.news-card:last-child { grid-column: auto; }
	.partner-grid { grid-template-columns: 1fr 1fr; }
	.visit__panel { width: calc(100% - 24px); }
	.visit__copy { padding: 38px 24px; }
	.visit__details { grid-template-columns: 1fr; }
	.visit__details > div:last-child { grid-column: auto; }
	.site-footer__grid { grid-template-columns: 1fr 1fr; }
	.footer-brand { grid-column: 1 / -1; }
	.footer-bottom { flex-direction: column; }
	.archive-grid { grid-template-columns: 1fr; }
}

@media (max-width: 430px) {
	:root { --page-pad: 20px; }
	.hero__description { font-size: 1rem; }
	.hero__visual { min-height: 118vw; }
	.hero__badge { width: 106px; }
	.intro h2 br, .project h2 br { display: none; }
	.activity-card__body { padding: 22px 20px; }
	.activity-card__body > p { min-height: auto; }
	.impact__stats { grid-template-columns: 1fr; }
	.impact-item, .impact-item:nth-child(3), .impact-item:nth-child(4), .impact-item:nth-child(5), .impact-item:last-child { grid-column: auto; min-height: auto; border-right: 0; border-bottom: 1px solid rgba(255, 255, 255, 0.24); }
	.impact-item:last-child { border-bottom: 0; }
	.team-grid, .partner-grid, .site-footer__grid { grid-template-columns: 1fr; }
	.footer-brand { grid-column: auto; }
	.site-footer__pattern { height: 48px; background-size: auto 48px; }
}

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
	.reveal { opacity: 1; transform: none; }
}

@media print {
	.site-header, .site-footer, .button, .hero__badge, .hero__shape, .hero__scribble, .activities__arrow { display: none !important; }
	body { background: #fff; color: #000; }
	.section-shell { padding-block: 30px; }
}
