﻿:root {
	--mono-gray: #0f0f10;
	--bg: #080809;
	--bg-soft: #121214;
	--surface: #17181b;
	--surface-2: #1d1f23;
	--text: #f3f3f4;
	--text-soft: #adadb3;
	--line: rgba(255, 255, 255, 0.15);
	--line-soft: rgba(255, 255, 255, 0.08);
	--shadow: 0 18px 48px rgba(0, 0, 0, 0.42);
	--box-outline: inset 0 0 0 1px rgba(255, 255, 255, 0.1);
	--site-width: min(1240px, 92vw);
	--site-width-wide: min(1460px, 94vw);
	--header-height: 66px;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: "Archivo", sans-serif;
	background: linear-gradient(165deg, #060607 0%, #0d0d10 46%, #09090b 100%);
	color: var(--text);
	min-height: 100vh;
	overflow-x: hidden;
	overflow-x: clip;
	-webkit-user-select: none;
	user-select: none;
}

body.nav-open {
	overflow: hidden;
}

body.nav-open::before {
	content: "";
	position: fixed;
	inset: var(--header-height) 0 0;
	background: rgba(4, 6, 9, 0.58);
	backdrop-filter: blur(2px);
	z-index: 950;
}

img {
	-webkit-user-drag: none;
}

input,
textarea,
select,
option,
button,
[contenteditable="true"],
[contenteditable="plaintext-only"] {
	-webkit-user-select: text;
	user-select: text;
}

body.intro-lock {
	overflow: hidden;
}

.site-header,
main,
.site-footer {
	position: relative;
	z-index: 3;
}

main {
	isolation: isolate;
	overflow-x: hidden;
	overflow-x: clip;
}

main::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: calc(84vh + 10.4rem);
	background:
		linear-gradient(rgba(6, 8, 11, 0.58), rgba(6, 8, 11, 0.58)),
		url("hero-lawrence.jpeg") center 60% / cover no-repeat;
	pointer-events: none;
	z-index: -1;
}

.intro {
	position: fixed;
	inset: 0;
	width: 100vw;
	height: 100vh;
	min-height: 100dvh;
	background:
		radial-gradient(circle at 50% 28%, rgba(255, 255, 255, 0.11), transparent 24%),
		radial-gradient(circle at 16% 20%, rgba(255, 255, 255, 0.05), transparent 30%),
		radial-gradient(circle at 84% 78%, rgba(255, 255, 255, 0.04), transparent 28%),
		linear-gradient(180deg, #040506 0%, #090a0d 58%, #050507 100%);
	z-index: 2000;
	display: grid;
	place-items: center;
	padding: 4vh 4vw;
	overflow: hidden;
}

.intro::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.035) 50%, transparent 100%),
		radial-gradient(circle at 50% 45%, transparent 34%, rgba(0, 0, 0, 0.62) 100%);
	opacity: 0.9;
	pointer-events: none;
}

.intro::after {
	content: "";
	position: absolute;
	inset: -18%;
	background:
		conic-gradient(
			from 180deg at 50% 50%,
			transparent 0deg,
			rgba(255, 255, 255, 0.03) 60deg,
			transparent 118deg,
			rgba(255, 255, 255, 0.018) 180deg,
			transparent 248deg,
			rgba(255, 255, 255, 0.032) 308deg,
			transparent 360deg
		);
	filter: blur(68px);
	opacity: 0.72;
	transform: rotate(6deg);
	animation: introAuraDrift 7.2s ease-in-out infinite;
	pointer-events: none;
}

.intro-stage {
	position: relative;
	z-index: 1;
	width: min(92vw, 760px);
	display: grid;
	gap: 1.05rem;
	justify-items: center;
	text-align: center;
	animation: introStageIn 1.1s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.intro-stage::before {
	content: "";
	position: absolute;
	left: 10%;
	right: 10%;
	bottom: 16%;
	height: 30%;
	background: radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.05) 34%, transparent 74%);
	filter: blur(54px);
	opacity: 0.58;
	pointer-events: none;
	animation: introAuraPulse 3.1s ease-in-out infinite;
}

.intro-kicker {
	margin: 0;
	padding: 0.42rem 0.92rem;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.04);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.08),
		0 18px 40px rgba(0, 0, 0, 0.32);
	backdrop-filter: blur(16px);
	color: rgba(255, 255, 255, 0.72);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	animation: introTextIn 0.82s ease-out 0.12s both;
}

.intro-logo-shell {
	position: relative;
	width: fit-content;
	max-width: min(78vw, 300px);
	padding: clamp(0.68rem, 1.8vw, 0.88rem);
	border-radius: 1.1rem;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02)),
		linear-gradient(180deg, rgba(10, 11, 14, 0.94), rgba(6, 7, 9, 0.98));
	box-shadow:
		0 44px 110px rgba(0, 0, 0, 0.52),
		inset 0 1px 0 rgba(255, 255, 255, 0.12),
		inset 0 0 0 1px rgba(255, 255, 255, 0.04);
	overflow: hidden;
	isolation: isolate;
	animation: introFrameIn 1.15s cubic-bezier(0.22, 1, 0.36, 1) 0.05s both;
}

.intro-logo-shell::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(115deg, transparent 20%, rgba(255, 255, 255, 0.16) 36%, transparent 54%);
	transform: translateX(-120%);
	animation: introSheen 1.6s ease-out 0.45s both;
	pointer-events: none;
	z-index: 2;
}

.intro-logo-shell::after {
	content: "";
	position: absolute;
	inset: 0.34rem;
	border-radius: 0.8rem;
	border: 1px solid rgba(255, 255, 255, 0.07);
	pointer-events: none;
	z-index: 2;
}

.intro-logo-aura {
	position: absolute;
	inset: 10% 10%;
	background: radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.24), rgba(255, 255, 255, 0.07) 34%, transparent 72%);
	filter: blur(44px);
	opacity: 0.7;
	transform: scale(0.88);
	animation: introAuraPulse 3.1s ease-in-out infinite;
	z-index: 0;
}

.intro-logo-mark {
	width: min(52vw, 210px);
	height: auto;
	display: block;
	filter: grayscale(1) brightness(0) invert(1) contrast(2.1);
	margin: 0 auto;
	position: relative;
	z-index: 1;
	transform: translateY(0) scale(1) rotate(-1deg);
	transform-origin: center;
	clip-path: inset(0 0 0 0);
	animation: introLogoReveal 1.3s cubic-bezier(0.22, 1, 0.36, 1) 0.15s both;
}

.intro-logo-reflection {
	position: absolute;
	left: 12%;
	right: 12%;
	bottom: 0.8rem;
	height: 22px;
	border-radius: 999px;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.22), transparent);
	filter: blur(16px);
	opacity: 0.54;
	z-index: 0;
	animation: introReflection 2.3s ease-in-out infinite;
}

.intro-divider {
	position: relative;
	width: min(52vw, 240px);
	height: 1px;
	margin-top: 0.1rem;
	animation: introTextIn 0.85s ease-out 0.24s both;
}

.intro-divider::before {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(255, 255, 255, 0.1);
}

.intro-divider span {
	display: block;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.9), transparent);
	transform-origin: center;
	transform: scaleX(0.08);
	animation: introLineGrow 1s cubic-bezier(0.22, 1, 0.36, 1) 0.4s both;
}

.intro-signature {
	margin: 0;
	font-family: "Bebas Neue", sans-serif;
	font-size: clamp(1.34rem, 2.8vw, 2rem);
	letter-spacing: 0.22em;
	line-height: 1;
	text-transform: uppercase;
	color: #ffffff;
	text-shadow: 0 0 28px rgba(255, 255, 255, 0.08);
	animation: introTextIn 0.92s ease-out 0.3s both;
}

.intro.is-done {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1), visibility 0.7s ease;
}


@keyframes introStageIn {
	0% {
		opacity: 0;
		transform: translateY(18px);
	}
	100% {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes introFrameIn {
	0% {
		opacity: 0;
		transform: translateY(26px) scale(0.94);
	}
	100% {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

@keyframes introLogoReveal {
	0% {
		opacity: 0;
		transform: translateY(14px) scale(0.84) rotate(-3deg);
		filter: grayscale(1) brightness(0) invert(1) contrast(2.1) blur(6px);
	}
	44% {
		opacity: 1;
		transform: translateY(0) scale(1.04) rotate(-0.7deg);
		filter: grayscale(1) brightness(0) invert(1) contrast(2.22) drop-shadow(0 0 14px rgba(255, 255, 255, 0.18));
	}
	100% {
		opacity: 1;
		transform: translateY(0) scale(1) rotate(-1deg);
		filter: grayscale(1) brightness(0) invert(1) contrast(2.1);
	}
}

@keyframes introTextIn {
	0% {
		opacity: 0;
		transform: translateY(10px);
	}
	100% {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes introLineGrow {
	0% {
		opacity: 0;
		transform: scaleX(0.08);
	}
	100% {
		opacity: 1;
		transform: scaleX(1);
	}
}

@keyframes introSheen {
	0% {
		transform: translateX(-120%);
		opacity: 0;
	}
	18% {
		opacity: 1;
	}
	100% {
		transform: translateX(120%);
		opacity: 0;
	}
}

@keyframes introAuraPulse {
	0%,
	100% {
		opacity: 0.48;
		transform: scale(0.86);
	}
	50% {
		opacity: 0.78;
		transform: scale(1.02);
	}
}

@keyframes introAuraDrift {
	0%,
	100% {
		transform: rotate(6deg) scale(1);
	}
	50% {
		transform: rotate(-5deg) scale(1.04);
	}
}

@keyframes introReflection {
	0%,
	100% {
		opacity: 0.38;
		transform: scaleX(0.88);
	}
	50% {
		opacity: 0.7;
		transform: scaleX(1.02);
	}
}

.noise {
	display: none;
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	isolation: isolate;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.18rem 1.1vw;
	height: var(--header-height);
	background: var(--mono-gray);
	backdrop-filter: none;
	border-bottom: 1px solid var(--line-soft);
}

.header-actions {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.logo {
	text-decoration: none;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	width: 56px;
	height: 50px;
	padding-bottom: 0;
	overflow: hidden;
}

.logo-image {
	display: block;
	height: 50px;
	width: auto;
	max-width: none;
	object-fit: contain;
	clip-path: none;
	filter: grayscale(1) brightness(0) invert(1) contrast(1.9);
}

.main-nav {
	display: flex;
	gap: 1.35rem;
}

.main-nav a {
	color: var(--text);
	text-decoration: none;
	font-weight: 700;
	text-transform: uppercase;
	font-size: 0.76rem;
	letter-spacing: 0.14em;
	opacity: 0.74;
	transition: opacity 0.2s ease;
}

.main-nav a:hover,
.main-nav a:focus-visible {
	opacity: 1;
}

.lang-switch {
	display: inline-flex;
	align-items: center;
	gap: 0.2rem;
	padding: 0.18rem;
	border: 1px solid var(--line);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.04);
}

.lang-btn {
	border: 0;
	background: transparent;
	color: var(--text-soft);
	padding: 0.38rem 0.62rem;
	border-radius: 999px;
	font: inherit;
	font-size: 0.74rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease;
}

.lang-btn.is-active {
	background: #ffffff;
	color: #101012;
}

.menu-btn {
	display: none;
	background: transparent;
	border: 0;
	padding: 0;
}

.menu-btn span {
	display: block;
	width: 24px;
	height: 2px;
	margin: 4px 0;
	background: var(--text);
}

.section {
	width: var(--site-width);
	margin: 0 auto;
	padding: 5.2rem 0;
}

#top,
section[id] {
	scroll-margin-top: calc(var(--header-height) + 14px);
}

.hero {
	min-height: 84vh;
	display: grid;
	grid-template-columns: 1.25fr 0.75fr;
	align-items: center;
	gap: 2.8rem;
	position: relative;
	overflow: hidden;
}

.hero::before {
	display: none;
}

.hero > * {
	position: relative;
	z-index: 1;
}

.hero-glow {
	position: absolute;
	width: min(44vw, 420px);
	aspect-ratio: 1;
	border-radius: 50%;
	right: -90px;
	top: 2%;
	background: radial-gradient(circle, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
	filter: blur(9px);
	pointer-events: none;
}

.eyebrow {
	margin: 0;
	font-size: 0.74rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.66);
	font-weight: 700;
}

h1,
h2,
h3 {
	margin: 0;
	line-height: 0.97;
}

h1 {
	font-family: "Bebas Neue", sans-serif;
	font-size: clamp(2.9rem, 10.3vw, 7rem);
	margin-top: 0.72rem;
	letter-spacing: 0.01em;
	text-wrap: balance;
}

h1 span {
	color: #d0d0d5;
}

.hero-text {
	max-width: 56ch;
	color: var(--text-soft);
	line-height: 1.75;
	font-size: 1.02rem;
	margin: 1.25rem 0 0;
}

.hero-cta {
	margin-top: 1.8rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.8rem;
}

.btn {
	text-decoration: none;
	border: 0;
	cursor: pointer;
	border-radius: 999px;
	padding: 0.82rem 1.28rem;
	font-weight: 700;
	font-size: 0.9rem;
	font-family: inherit;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.btn:hover,
.btn:focus-visible {
	transform: translateY(-2px);
}

.btn-primary {
	background: #f4f4f6;
	color: #101012;
	box-shadow: 0 8px 20px rgba(255, 255, 255, 0.16);
}

.btn-primary:hover,
.btn-primary:focus-visible {
	background: #ffffff;
}

.btn-ghost {
	background: transparent;
	color: var(--text);
	border: 1px solid var(--line);
}

.hero-cta .btn-ghost {
	background: #ffffff;
	color: #101012;
	border-color: #ffffff;
	box-shadow: 0 8px 20px rgba(255, 255, 255, 0.16);
}

.hero-cta .btn-ghost:hover,
.hero-cta .btn-ghost:focus-visible {
	background: #ffffff;
}

.hero-stats {
	display: grid;
	gap: 0.9rem;
}

.hero-stats article {
	border: 1px solid var(--line);
	background: linear-gradient(170deg, rgba(16, 18, 23, 0.76), rgba(10, 12, 16, 0.88));
	border-radius: 16px;
	padding: 1.05rem 1.15rem;
	box-shadow: var(--box-outline), var(--shadow);
}

.hero-stats h2 {
	font-family: "Bebas Neue", sans-serif;
	font-size: 2.2rem;
	color: var(--text);
}

.hero-stats p {
	margin: 0.2rem 0 0;
	color: var(--text-soft);
}

.section-head {
	margin-bottom: 1.2rem;
}

.section-head h2 {
	font-family: "Bebas Neue", sans-serif;
	margin-top: 0.7rem;
	font-size: clamp(2rem, 6vw, 4rem);
}

.members.section {
	padding: 1.4rem 0 4rem;
}

.members .section-head {
	margin-bottom: 0.9rem;
}

.members .section-head h2 {
	margin-top: 0.4rem;
	font-size: clamp(1.8rem, 5.2vw, 3.5rem);
}

.hero-content h1,
.section-head h2,
.contact-intro h2 {
	position: relative;
	display: inline-block;
	transform-origin: left center;
	will-change: transform, filter, letter-spacing, opacity;
}

.hero-content h1 {
	isolation: isolate;
	color: #ffffff;
	background: none;
	-webkit-background-clip: border-box;
	background-clip: border-box;
	-webkit-text-fill-color: #ffffff;
	opacity: 0;
	transform: translateY(6px);
	filter: blur(1px);
	transition: background-position 0.95s cubic-bezier(0.2, 0.8, 0.2, 1), transform 0.26s ease, letter-spacing 0.26s ease, filter 0.26s ease;
}

.hero-content h1::before {
	content: "";
	position: absolute;
	left: 7%;
	right: 7%;
	bottom: -0.08em;
	height: 0.5em;
	border-radius: 999px;
	background: radial-gradient(ellipse at center, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0) 72%);
	opacity: 0;
	pointer-events: none;
	filter: blur(14px);
	transform: translateY(12px) scaleX(0.52);
	transform-origin: center;
	z-index: -1;
}

.hero-content h1::after,
.section-head h2::after,
.contact-intro h2::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -0.18rem;
	width: 0;
	height: 0.16rem;
	border-radius: 999px;
	background: linear-gradient(90deg, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.18));
	opacity: 0;
}

.hero-content h1::after {
	display: none;
}

.section-head.in-view h2,
.section.reveal.in-view .section-head h2,
.contact.reveal.in-view .contact-intro h2 {
	animation: members-title-in 0.82s cubic-bezier(0.2, 0.9, 0.2, 1) both;
}

.section-head.in-view h2::after,
.section.reveal.in-view .section-head h2::after,
.contact.reveal.in-view .contact-intro h2::after {
	animation: members-title-line 0.9s cubic-bezier(0.2, 0.9, 0.2, 1) 0.16s both;
}

.hero-content.in-view.hero-title-ready h1::before {
	animation: none;
}

.hero-content.in-view.hero-title-ready h1::after {
	animation: none;
}

.hero-content.in-view.hero-title-ready h1 {
	animation: hero-title-fade 0.72s ease-out both;
}

@media (hover: hover) and (pointer: fine) {
	.hero-content.hero-title-ready h1:hover {
		background-position: 100% 50%;
		transform: translateY(-1px);
		letter-spacing: 0.02em;
		filter: none;
	}
}

.story {
	position: relative;
	isolation: isolate;
	--story-bg-top: clamp(1.8rem, 2.8vw, 2.5rem);
	min-height: calc(84vh + var(--story-bg-top));
}

.story.section {
	padding-top: 3.9rem;
	padding-bottom: 3.3rem;
}

.story::before {
	content: "";
	position: absolute;
	top: var(--story-bg-top);
	bottom: 0;
	left: 50%;
	width: 100vw;
	transform: translateX(-50%);
	background:
		linear-gradient(rgba(4, 5, 7, 0.62), rgba(4, 5, 7, 0.62)),
		url("story-paris.webp") center bottom / cover no-repeat;
	filter: grayscale(1) contrast(1.06);
	opacity: 1;
	pointer-events: none;
	z-index: 0;
}

.story > * {
	position: relative;
	z-index: 1;
}

.story-copy {
	max-width: 82ch;
	display: grid;
	gap: 1rem;
}

.story-layout {
	display: grid;
	grid-template-columns: minmax(0, 1.25fr) minmax(260px, 0.75fr);
	gap: clamp(1.4rem, 3vw, 2.6rem);
	align-items: start;
}

.story-visual {
	width: min(100%, 390px);
	margin: -4.2rem 0 0;
	align-self: start;
	justify-self: end;
}

.story-stack {
	position: relative;
	display: block;
	width: 100%;
	aspect-ratio: 1 / 1.12;
	padding: 0;
	border: 0;
	background: transparent;
	cursor: pointer;
	appearance: none;
	-webkit-appearance: none;
	-webkit-tap-highlight-color: transparent;
	touch-action: manipulation;
}

.story-stack:focus,
.story-stack:focus-visible {
	outline: none;
}

.story-stack:active {
	background: transparent;
	outline: none;
	box-shadow: none;
}

.story-card {
	position: absolute;
	inset: 0 0 28px 0;
	display: block;
	overflow: hidden;
	border-radius: 1.35rem;
	box-shadow: none;
	transition:
		transform 0.38s cubic-bezier(0.22, 1, 0.36, 1),
		filter 0.3s ease;
	will-change: transform;
}

.story-card img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	pointer-events: none;
	user-select: none;
}

.story-card[data-order="0"] {
	z-index: 4;
	transform: translate(0, 0) rotate(-5deg);
}

.story-card[data-order="1"] {
	z-index: 3;
	transform: translate(18px, 16px) rotate(3deg) scale(0.97);
	filter: brightness(0.92);
}

.story-card[data-order="2"] {
	z-index: 2;
	transform: translate(32px, 32px) rotate(-1.8deg) scale(0.94);
	filter: brightness(0.86);
}

.story-card[data-order="3"] {
	z-index: 1;
	transform: translate(44px, 48px) rotate(4.5deg) scale(0.91);
	filter: brightness(0.8);
}

.story-stack:hover .story-card[data-order="0"],
.story-stack:focus-visible .story-card[data-order="0"] {
	transform: translate(-4px, -6px) rotate(-4deg);
}

.story-copy p {
	margin: 0;
	line-height: 1.82;
	color: var(--text-soft);
	font-size: 1.01rem;
}

.story-copy strong {
	color: var(--text);
	font-weight: 800;
}

.story-copy em {
	color: #d9d9df;
	font-style: italic;
}


.actualite-carousel {
	position: relative;
	padding: 0 0 1.55rem;
}

.actualite-carousel::before,
.actualite-carousel::after {
	display: none;
}

.cards-grid {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: calc((100% - 2rem) / 3);
	gap: 1rem;
	overflow-x: auto;
	overflow-y: hidden;
	padding: 0.2rem 0.15rem 0.8rem;
	scroll-snap-type: x mandatory;
	scroll-padding-left: 0.15rem;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	cursor: grab;
}

.cards-grid.is-dragging {
	cursor: grabbing;
}

.cards-grid::-webkit-scrollbar {
	display: none;
}

.actualite-controls {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0;
	margin-top: 0.35rem;
}

.actualite-buttons {
	display: flex;
	gap: 0.55rem;
}

.actualite-arrow {
	width: 38px;
	height: 38px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.14);
	background: rgba(255, 255, 255, 0.05);
	color: #ffffff;
	font: inherit;
	font-size: 1.25rem;
	line-height: 1;
	cursor: pointer;
	transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.actualite-arrow:hover,
.actualite-arrow:focus-visible {
	transform: translateY(-1px);
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.28);
}

.actualite-progress {
	display: none;
}

.actualite-progress span {
	display: block;
	width: 0%;
	height: 100%;
	border-radius: 999px;
	background: #ffffff;
	transition: width 0.22s ease;
}

.actualite-dots {
	display: none;
}

.actualite-dot {
	width: 5px;
	height: 5px;
	border-radius: 999px;
	border: 0;
	padding: 0;
	background: rgba(255, 255, 255, 0.48);
	cursor: pointer;
	transition: transform 0.22s ease, background 0.22s ease;
}

.actualite-dot:hover,
.actualite-dot:focus-visible {
	background: rgba(255, 255, 255, 0.7);
	transform: scale(1.12);
}

.actualite-dot.is-active {
	background: #ffffff;
	transform: scale(1.35);
}

.insta-live {
	margin-top: 0;
	border: 1px solid var(--line);
	border-radius: 18px;
	padding: 1rem;
	background: linear-gradient(170deg, rgba(14, 16, 21, 0.82), rgba(10, 12, 16, 0.92));
	box-shadow: var(--box-outline), var(--shadow);
}

.insta-live-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 0.8rem;
	margin-bottom: 0.8rem;
}

.insta-live-head h3 {
	margin: 0;
	font-family: "Bebas Neue", sans-serif;
	font-size: 1.7rem;
	letter-spacing: 0.03em;
}

.insta-live-head a {
	text-decoration: none;
	color: var(--text);
	font-size: 0.86rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	opacity: 0.84;
}

.insta-live-head a:hover,
.insta-live-head a:focus-visible {
	opacity: 1;
}

.insta-feed-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.82rem;
}

.insta-feed-card {
	border: 1px solid var(--line-soft);
	border-radius: 14px;
	overflow: hidden;
	background: rgba(8, 10, 14, 0.62);
	box-shadow: var(--box-outline);
}

.insta-feed-card a {
	display: block;
	text-decoration: none;
	color: inherit;
	padding: 0.62rem;
}

.insta-feed-card h4 {
	margin: 0.6rem 0 0;
	font-size: 1rem;
	line-height: 1.25;
}

.insta-feed-card p {
	margin: 0.42rem 0 0;
	color: var(--text-soft);
	font-size: 0.88rem;
	line-height: 1.45;
}

.insta-feed-thumb {
	aspect-ratio: 1 / 0.94;
	border-radius: 10px;
	background:
		radial-gradient(circle at 24% 22%, rgba(255, 255, 255, 0.14), transparent 40%),
		linear-gradient(145deg, #171a22 0%, #10131a 100%);
	border: 1px solid rgba(255, 255, 255, 0.12);
	background-size: cover;
	background-position: center;
	display: grid;
	place-items: center;
	font-family: "Bebas Neue", sans-serif;
	font-size: 1.05rem;
	letter-spacing: 0.08em;
	color: rgba(255, 255, 255, 0.9);
}

.card {
	background: linear-gradient(165deg, rgba(18, 20, 26, 0.78), rgba(10, 12, 16, 0.9));
	border: 1px solid var(--line);
	border-radius: 18px;
	padding: 1.25rem;
	aspect-ratio: 1 / 1;
	min-height: 0;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	box-shadow: var(--box-outline);
	scroll-snap-align: start;
	position: relative;
	overflow: hidden;
	transition: transform 0.22s ease, border-color 0.22s ease;
}

.card-link {
	display: block;
	width: 100%;
	height: 100%;
	color: inherit;
	text-decoration: none;
	position: relative;
	z-index: 1;
}

.card-link-static {
	cursor: default;
}

.card-inner {
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	transform: translateY(var(--parallax, 0px));
	transition: transform 0.24s ease;
}

.card-has-image .card-inner,
.event-panel-image .card-inner {
	position: relative;
	z-index: 1;
}

.card-has-image,
.event-panel-image {
	isolation: isolate;
	padding: 0;
	background-clip: padding-box;
}

.card-has-image .card-link,
.event-panel-image .card-link {
	position: absolute;
	inset: 0;
	display: flex;
	overflow: hidden;
	border-radius: inherit;
	background-color: var(--card-background-color, #090b10);
}

.card-has-image::before,
.event-panel-image::before {
	display: none;
}

.card-has-image .card-link.card-link-textured::before,
.event-panel-image .card-link.card-link-textured::before {
	content: "";
	position: absolute;
	inset: -8%;
	background-image: var(--card-image);
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
	filter: blur(28px) saturate(1.12) brightness(0.72);
	transform: scale(1.08);
	opacity: 0.92;
	pointer-events: none;
	z-index: 0;
}

.card-has-image .card-media,
.event-panel-image .card-media {
	position: absolute;
	inset:
		calc(-1 * var(--card-image-bleed, 0px))
		0
		calc(-1 * var(--card-image-bleed, 0px))
		0;
	background-image: var(--card-image);
	background-position: var(--card-image-position, center center);
	background-size: var(--card-image-size, contain);
	background-repeat: no-repeat;
	transform: translateY(var(--card-image-shift, 0px));
	z-index: 1;
}

.card-has-image .card-link::after,
.event-panel-image .card-link::after {
	display: none;
}

.card-has-image .card-inner,
.event-panel-image .card-inner {
	display: flex;
	align-self: stretch;
	width: 100%;
	height: 100%;
	justify-content: flex-end;
	margin: 0;
	padding: 0 0 1rem;
	border-radius: 0;
	background: transparent;
	backdrop-filter: none;
	position: relative;
	z-index: 3;
	isolation: isolate;
}

.card-has-image .card-inner::before,
.event-panel-image .card-inner::before {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	top: 42%;
	background: linear-gradient(
		180deg,
		rgba(0, 0, 0, 0) 0%,
		rgba(0, 0, 0, 0.14) 18%,
		rgba(0, 0, 0, 0.48) 42%,
		rgba(0, 0, 0, 0.82) 72%,
		rgba(0, 0, 0, 0.96) 100%
	);
	border-radius: 0 0 18px 18px;
	z-index: 0;
	pointer-events: none;
}

.card-has-image .card-inner > *,
.event-panel-image .card-inner > * {
	position: relative;
	z-index: 1;
	padding-left: 1.25rem;
	padding-right: 1.25rem;
}

.card-has-image .card-inner > p:last-child,
.event-panel-image .card-inner > p:last-child {
	padding-bottom: 1rem;
}

.card-has-image .card-tag,
.card-has-image h3,
.card-has-image p,
.event-panel-image .event-tag,
.event-panel-image h3,
.event-panel-image p {
	text-shadow:
		0 2px 10px rgba(0, 0, 0, 0.9),
		0 0 18px rgba(0, 0, 0, 0.65);
}

.card-has-image .card-tag,
.event-panel-image .event-tag {
	color: rgba(255, 255, 255, 0.82);
}

.card-has-image h3,
.event-panel-image h3 {
	color: #ffffff;
	line-height: 1.08;
	max-width: 92%;
}

.card-has-image p,
.event-panel-image p {
	color: rgba(255, 255, 255, 0.86);
	max-width: 88%;
}

.card::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 3px;
	background: linear-gradient(90deg, rgba(255, 255, 255, 0.72), rgba(255, 255, 255, 0));
}

.card:hover {
	transform: translateY(-3px);
	border-color: rgba(255, 255, 255, 0.26);
}

.card-tag {
	margin: 0;
	color: #d8d8dd;
	font-weight: 700;
	font-size: 0.78rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.card h3 {
	font-size: 1.26rem;
	margin-top: 0.6rem;
	line-height: 1.16;
}

.card p {
	margin: 0.5rem 0 0;
	color: var(--text-soft);
}

.classes-layout {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
}

.classes-layout article {
	border: 1px solid var(--line);
	background: linear-gradient(180deg, var(--surface), var(--surface-2));
	border-radius: 14px;
	padding: 1.2rem;
	box-shadow: var(--box-outline);
}

.classes-layout h3 {
	font-size: 1.26rem;
}

.classes-layout p {
	color: var(--text-soft);
	line-height: 1.65;
	margin-top: 0.58rem;
}

.classes-enroll {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1.15fr) minmax(260px, 0.85fr);
	gap: 1.15rem;
	margin-top: 1.25rem;
	padding: clamp(1.2rem, 2vw, 1.65rem);
	border-radius: 24px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background:
		radial-gradient(circle at 16% 18%, rgba(255, 255, 255, 0.16), transparent 28%),
		linear-gradient(140deg, rgba(27, 28, 33, 0.96), rgba(12, 13, 17, 0.98));
	box-shadow:
		0 24px 56px rgba(0, 0, 0, 0.34),
		inset 0 1px 0 rgba(255, 255, 255, 0.09),
		inset 0 0 0 1px rgba(255, 255, 255, 0.03);
	overflow: hidden;
	isolation: isolate;
}

.classes-enroll::before {
	content: "";
	position: absolute;
	inset: auto -12% -35% auto;
	width: 280px;
	aspect-ratio: 1;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0));
	filter: blur(10px);
	opacity: 0.95;
	pointer-events: none;
}

.classes-enroll-copy,
.classes-enroll-link {
	position: relative;
	z-index: 1;
}

.classes-enroll-eyebrow {
	margin: 0;
	font-size: 0.74rem;
	font-weight: 800;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.72);
}

.classes-enroll-title {
	margin: 0.62rem 0 0;
	font-size: clamp(1.55rem, 2vw, 2.2rem);
	line-height: 1.02;
	max-width: 14ch;
}

.classes-enroll-text {
	margin: 0.82rem 0 0;
	max-width: 56ch;
	color: rgba(255, 255, 255, 0.74);
	line-height: 1.7;
}

.classes-enroll-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.55rem;
	margin-top: 1rem;
}

.classes-enroll-tags span {
	display: inline-flex;
	align-items: center;
	padding: 0.46rem 0.74rem;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.11);
	background: rgba(255, 255, 255, 0.05);
	color: rgba(255, 255, 255, 0.82);
	font-size: 0.76rem;
	font-weight: 700;
	letter-spacing: 0.04em;
}

.classes-enroll-link {
	display: grid;
	align-content: end;
	gap: 0.35rem;
	min-height: 100%;
	position: relative;
	padding: 1.15rem 1.2rem;
	border-radius: 20px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background:
		linear-gradient(180deg, rgba(7, 8, 11, 0.44), rgba(7, 8, 11, 0.92)),
		linear-gradient(160deg, rgba(7, 8, 11, 0.38), rgba(7, 8, 11, 0.18));
	text-decoration: none;
	color: #ffffff;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
	transition: transform 0.24s ease, border-color 0.24s ease, background 0.24s ease;
	overflow: hidden;
	isolation: isolate;
}

.classes-enroll-link:hover,
.classes-enroll-link:focus-visible {
	transform: translateY(-2px);
	border-color: rgba(255, 255, 255, 0.24);
	background:
		linear-gradient(180deg, rgba(7, 8, 11, 0.38), rgba(7, 8, 11, 0.88)),
		linear-gradient(160deg, rgba(7, 8, 11, 0.3), rgba(7, 8, 11, 0.16));
}

.classes-enroll-link::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, rgba(5, 6, 9, 0.78) 0%, rgba(5, 6, 9, 0.52) 34%, rgba(5, 6, 9, 0.12) 62%, transparent 82%),
		linear-gradient(0deg, rgba(5, 6, 9, 0.58) 0%, rgba(5, 6, 9, 0.08) 36%, transparent 60%),
		radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.14), transparent 34%);
	pointer-events: none;
	z-index: 1;
}

.classes-enroll-link::after {
	content: "";
	position: absolute;
	inset: 0;
	background: url("classes-signup-bg.jpeg") center center / cover no-repeat;
	transform: scaleX(-1);
	transform-origin: center;
	filter: brightness(0.72) saturate(0.9);
	pointer-events: none;
	z-index: 0;
}

.classes-enroll-link > * {
	position: relative;
	z-index: 2;
}

.classes-enroll-link-head {
	display: flex;
	align-items: center;
	gap: 0.72rem;
	margin-bottom: 0.15rem;
}

.classes-enroll-link-brand {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 50px;
	height: 50px;
	border-radius: 16px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.04)),
		rgba(9, 10, 14, 0.42);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
	flex: 0 0 auto;
}

.classes-enroll-link-logo {
	display: block;
	width: 34px;
	height: auto;
	filter: grayscale(1) brightness(0) invert(1) contrast(1.95);
}

.classes-enroll-link-kicker {
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.84);
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.48);
}

.classes-enroll-link-main {
	font-size: 1.42rem;
	line-height: 1.05;
	text-shadow:
		0 3px 14px rgba(0, 0, 0, 0.72),
		0 0 24px rgba(0, 0, 0, 0.42);
}

.classes-enroll-link-meta {
	color: rgba(255, 255, 255, 0.9);
	font-size: 0.9rem;
	font-weight: 700;
	text-shadow: 0 3px 12px rgba(0, 0, 0, 0.62);
}

.classes-spaces {
	margin-top: 1.15rem;
}

.classes-spaces-label {
	margin: 0 0 0.8rem;
	color: rgba(255, 255, 255, 0.62);
	font-size: 0.76rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.classes-spaces-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
}

.class-space-card {
	position: relative;
	height: 100%;
	perspective: 1600px;
	isolation: isolate;
	background: none;
	border: 0;
	border-radius: 0;
	padding: 0;
	box-shadow: none;
	cursor: pointer;
	outline: none;
}

.class-space-card-shell {
	display: grid;
	height: 100%;
	position: relative;
	transform-style: preserve-3d;
	transition: transform 0.82s cubic-bezier(0.22, 0.61, 0.36, 1);
	transform: translateY(var(--space-card-lift, 0px)) rotateY(var(--space-card-rotation, 0deg));
}

.class-space-card:hover .class-space-card-shell,
.class-space-card:focus-visible .class-space-card-shell {
	--space-card-lift: -3px;
}

.class-space-card.is-flipped .class-space-card-shell {
	--space-card-rotation: 180deg;
}

.class-space-card-face {
	grid-area: 1 / 1;
	border: 1px solid var(--line);
	background: linear-gradient(180deg, rgba(16, 18, 24, 0.82), rgba(10, 12, 16, 0.92));
	border-radius: 14px;
	padding: 0.78rem;
	box-shadow: var(--box-outline);
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
}

.class-space-card-back {
	display: grid;
	align-content: start;
	gap: 0.68rem;
	transform: rotateY(180deg);
	background:
		radial-gradient(circle at top right, rgba(255, 255, 255, 0.08), transparent 34%),
		linear-gradient(160deg, rgba(17, 19, 24, 0.96), rgba(8, 9, 13, 0.98));
}

.class-space-card:focus-visible .class-space-card-face {
	border-color: rgba(255, 255, 255, 0.28);
}

.class-space-photo {
	aspect-ratio: 16 / 10;
	border-radius: 10px;
	border: 1px dashed rgba(255, 255, 255, 0.24);
	background:
		radial-gradient(circle at 24% 22%, rgba(255, 255, 255, 0.08), transparent 42%),
		linear-gradient(160deg, rgba(24, 27, 36, 0.94), rgba(10, 12, 16, 0.98));
}

.class-space-photo-image {
	border: 0;
	background-color: #0d0f14;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
}

.class-space-card h3 {
	margin: 0.68rem 0 0;
	font-size: 1rem;
}

.class-space-meta {
	margin: 0.28rem 0 0;
	color: var(--text-soft);
	font-size: 0.84rem;
	line-height: 1.5;
}

.class-space-link {
	display: inline-block;
	text-decoration: none;
	transition: color 0.2s ease, opacity 0.2s ease;
}

.class-space-link-button {
	display: block;
	width: 100%;
	padding: 0;
	border: 0;
	background: none;
	color: inherit;
	font: inherit;
	text-align: left;
	cursor: pointer;
}

.class-space-link:hover,
.class-space-link:focus-visible {
	color: var(--text);
	opacity: 1;
}

.class-space-map-frame {
	aspect-ratio: 16 / 10;
	border-radius: 10px;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.16);
	background: #0d0f14;
	box-shadow:
		inset 0 0 0 1px rgba(255, 255, 255, 0.04),
		0 12px 28px rgba(0, 0, 0, 0.24);
}

.class-space-map {
	display: block;
	width: 100%;
	height: 100%;
	border: 0;
}

.class-space-back-label {
	margin: 0;
	color: rgba(255, 255, 255, 0.52);
	font-size: 0.58rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.class-space-back-address {
	margin: 0;
	color: rgba(255, 255, 255, 0.8);
	font-size: 0.78rem;
	line-height: 1.55;
}

.class-space-back-actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
	margin-top: auto;
	padding-top: 0.15rem;
}

.class-space-back-open,
.class-space-back-close {
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.05);
	color: #ffffff;
	border-radius: 999px;
	padding: 0.42rem 0.7rem;
	font: inherit;
	font-size: 0.58rem;
	font-weight: 700;
	letter-spacing: 0.13em;
	text-transform: uppercase;
	text-decoration: none;
	transition: background 0.22s ease, border-color 0.22s ease, transform 0.22s ease, color 0.22s ease;
}

.class-space-back-close {
	cursor: pointer;
}

.class-space-back-open:hover,
.class-space-back-open:focus-visible,
.class-space-back-close:hover,
.class-space-back-close:focus-visible {
	background: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.24);
	color: #ffffff;
	transform: translateY(-1px);
}

.class-space-card-empty {
	opacity: 0.44;
}

.events-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
}

.events-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 0.55rem;
	margin: 0 0 1rem;
}

.events-filter {
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.04);
	color: rgba(255, 255, 255, 0.82);
	border-radius: 999px;
	padding: 0.58rem 0.95rem;
	font: inherit;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 0.22s ease, border-color 0.22s ease, color 0.22s ease, transform 0.22s ease;
}

.events-filter:hover,
.events-filter:focus-visible {
	background: rgba(255, 255, 255, 0.09);
	border-color: rgba(255, 255, 255, 0.22);
	color: #ffffff;
	transform: translateY(-1px);
}

.events-filter.is-active {
	background: #f3f3f4;
	color: #0d0f14;
	border-color: #f3f3f4;
}

.events-grid article,
.event-panel {
	border: 1px solid var(--line);
	background: linear-gradient(175deg, rgba(16, 18, 24, 0.78), rgba(10, 12, 16, 0.9));
	border-radius: 16px;
	padding: 1.2rem;
	box-shadow: var(--box-outline);
	scroll-snap-align: start;
}

.event-tag {
	margin: 0 0 0.7rem;
	font-size: 0.74rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.62);
	font-weight: 700;
}

.events-grid h3 {
	font-size: 1.26rem;
}

.events-grid p:last-child,
.event-panel p:last-child {
	margin-top: 0.58rem;
	color: var(--text-soft);
	line-height: 1.68;
}

.events-feed .event-panel {
	min-height: 100%;
}

.event-panel-image {
	background-size: cover;
	background-position: center;
	border-color: rgba(255, 255, 255, 0.18);
	position: relative;
	border-radius: 18px;
}

.event-panel-image::before {
	display: none;
}

.event-panel-image .card-inner {
	position: relative;
	z-index: 1;
}

.card-has-image,
.event-panel-image {
	box-shadow: none;
}

.members-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 0.7rem;
}

.member-card {
	position: relative;
	height: 100%;
	perspective: 1600px;
	isolation: isolate;
	background: none;
	border: 0;
	border-radius: 0;
	padding: 0;
	box-shadow: none;
	cursor: pointer;
	outline: none;
}

.member-card-shell {
	display: grid;
	height: 100%;
	position: relative;
	z-index: 1;
	transform-style: preserve-3d;
	transition: transform 0.82s cubic-bezier(0.22, 0.61, 0.36, 1);
	transform: translateY(var(--member-card-lift, 0px)) rotateY(var(--member-card-rotation, 0deg));
}

.member-card:hover .member-card-shell,
.member-card:focus-visible .member-card-shell {
	--member-card-lift: -4px;
}

.member-card.is-flipped .member-card-shell {
	--member-card-rotation: 180deg;
}

.member-card-face {
	grid-area: 1 / 1;
	position: relative;
	height: 100%;
	border: 1px solid var(--line);
	background: linear-gradient(175deg, rgba(16, 18, 24, 0.78), rgba(10, 12, 16, 0.9));
	border-radius: 14px;
	padding: 0.54rem;
	box-shadow: var(--box-outline), var(--shadow);
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
}

.member-card-front {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	transform-origin: left center;
}

.member-card-back {
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	gap: 0.58rem;
	padding: 0.82rem 0.78rem;
	background:
		radial-gradient(circle at top right, rgba(255, 255, 255, 0.08), transparent 38%),
		linear-gradient(160deg, rgba(17, 19, 24, 0.96), rgba(8, 9, 13, 0.98));
	transform: rotateY(180deg);
}

.member-card-back::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.04), transparent 42%);
	pointer-events: none;
}

.member-card-back > * {
	position: relative;
	z-index: 1;
}

.member-card:focus-visible .member-card-face {
	border-color: rgba(255, 255, 255, 0.28);
}

.member-card-demo {
	z-index: 2;
}

.member-card-demo::before {
	content: "";
	position: absolute;
	inset: -1rem;
	border-radius: 1.5rem;
	background:
		radial-gradient(circle at 50% 44%, rgba(255, 255, 255, 0.58), rgba(255, 255, 255, 0.28) 28%, rgba(255, 255, 255, 0.1) 50%, transparent 74%);
	filter: blur(28px);
	opacity: 0.74;
	transform: scale(0.97);
	pointer-events: none;
	z-index: 0;
	animation: member-card-glow 4.2s ease-in-out 0.6s infinite;
}

.member-card-demo::after {
	content: "";
	position: absolute;
	inset: -0.7rem;
	border-radius: 1.35rem;
	background:
		radial-gradient(circle at 50% 48%, rgba(255, 255, 255, 0.34), rgba(255, 255, 255, 0.16) 32%, rgba(255, 255, 255, 0.06) 52%, transparent 72%);
	filter: blur(20px);
	opacity: 0.46;
	transform: translateX(0) rotateZ(0deg) scale(0.96);
	transform-origin: center;
	pointer-events: none;
	z-index: 0;
	animation: member-card-hint-glow 2.1s ease-in-out 0.9s infinite;
}

.member-card-demo:not(.is-flipped) .member-card-shell {
	will-change: filter;
	animation: member-card-shell-halo 2.1s ease-in-out 0.9s infinite;
}

.member-card-demo:not(.is-flipped) .member-card-front {
	animation: member-card-invite 2.1s ease-in-out 0.9s infinite;
}

.member-photo-slot {
	grid-column: 1 / -1;
	aspect-ratio: 4 / 4.7;
	border-radius: 9px;
	border: 1px dashed rgba(255, 255, 255, 0.3);
	background: linear-gradient(180deg, rgba(20, 22, 28, 0.72), rgba(10, 12, 16, 0.9));
	color: var(--text-soft);
	font-weight: 700;
	font-size: 0.74rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	display: grid;
	place-items: center;
}

.member-photo-slot-image {
	border: 0;
	background-color: #0d0f14;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	color: transparent;
}

.member-card-front h3 {
	grid-column: 1;
	margin-top: 0.42rem;
	font-size: 0.84rem;
	letter-spacing: 0.02em;
}

.member-card-front .member-role {
	grid-column: 1;
	margin: 0.1rem 0 0;
	color: rgba(255, 255, 255, 0.62);
	font-size: 0.62rem;
	font-weight: 700;
	line-height: 1.42;
	min-height: calc(2 * 1.42em);
	max-height: calc(2 * 1.42em);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	overflow: hidden;
}

.member-card-front .member-social {
	grid-column: 2;
	grid-row: 2 / span 2;
	margin-top: 0;
	align-self: end;
	justify-self: end;
	display: inline-flex;
	align-items: center;
	gap: 0;
	text-decoration: none;
	color: var(--text-soft);
	transition: color 0.2s ease, opacity 0.2s ease;
	opacity: 0.86;
}

.member-card-front .member-social:hover,
.member-card-front .member-social:focus-visible {
	color: var(--text);
	opacity: 1;
}

.member-card-front .member-social.is-disabled {
	opacity: 0.38;
	cursor: default;
	pointer-events: auto;
}

.member-card-front .member-social svg {
	width: 15px;
	height: 15px;
	fill: currentColor;
	flex: 0 0 auto;
}

.member-back-label {
	margin: 0;
	color: rgba(255, 255, 255, 0.5);
	font-size: 0.58rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.member-card-back h3 {
	margin: 0;
	font-size: 0.92rem;
	line-height: 1.08;
}

.member-back-role {
	margin: -0.14rem 0 0;
	color: rgba(255, 255, 255, 0.68);
	font-size: 0.6rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.member-bio {
	margin: 0.1rem 0 0;
	color: rgba(255, 255, 255, 0.84);
	font-size: 0.69rem;
	line-height: 1.62;
}

.member-back-actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
	margin-top: auto;
	padding-top: 0.15rem;
}

.member-back-social,
.member-back-close {
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.05);
	color: #ffffff;
	border-radius: 999px;
	padding: 0.42rem 0.7rem;
	font: inherit;
	font-size: 0.58rem;
	font-weight: 700;
	letter-spacing: 0.13em;
	text-transform: uppercase;
	text-decoration: none;
	transition: background 0.22s ease, border-color 0.22s ease, transform 0.22s ease, color 0.22s ease;
}

.member-back-social:hover,
.member-back-social:focus-visible,
.member-back-close:hover,
.member-back-close:focus-visible {
	background: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.24);
	color: #ffffff;
	transform: translateY(-1px);
}

@keyframes member-card-invite {
	0%,
	100% {
		transform: translateX(0) rotateZ(0deg) translateY(0);
	}
	14% {
		transform: translateX(-0.65px) rotateZ(-0.24deg) translateY(0);
	}
	28% {
		transform: translateX(0.9px) rotateZ(0.3deg) translateY(-0.12px);
	}
	42% {
		transform: translateX(-0.52px) rotateZ(-0.18deg) translateY(0);
	}
	56% {
		transform: translateX(0.75px) rotateZ(0.24deg) translateY(0.12px);
	}
	70% {
		transform: translateX(-0.44px) rotateZ(-0.14deg) translateY(0);
	}
	84% {
		transform: translateX(0.34px) rotateZ(0.1deg) translateY(0);
	}
}

@keyframes member-card-glow {
	0%,
	100% {
		opacity: 0.38;
		transform: scale(0.92);
	}
	18% {
		opacity: 0.72;
		transform: scale(1.02);
	}
	36% {
		opacity: 0.46;
		transform: scale(0.96);
	}
	54% {
		opacity: 0.78;
		transform: scale(1.05);
	}
	72% {
		opacity: 0.42;
		transform: scale(0.94);
	}
}

@keyframes member-card-hint-glow {
	0%,
	100% {
		opacity: 0.28;
		transform: translateX(0) rotateZ(0deg) scale(0.95);
	}
	14% {
		opacity: 0.36;
		transform: translateX(-0.7px) rotateZ(-0.22deg) scale(0.97);
	}
	28% {
		opacity: 0.5;
		transform: translateX(0.95px) rotateZ(0.28deg) scale(1);
	}
	42% {
		opacity: 0.34;
		transform: translateX(-0.55px) rotateZ(-0.18deg) scale(0.98);
	}
	56% {
		opacity: 0.46;
		transform: translateX(0.8px) rotateZ(0.22deg) scale(1.01);
	}
	70% {
		opacity: 0.32;
		transform: translateX(-0.46px) rotateZ(-0.14deg) scale(0.98);
	}
	84% {
		opacity: 0.38;
		transform: translateX(0.3px) rotateZ(0.1deg) scale(0.97);
	}
}

@keyframes member-card-shell-halo {
	0%,
	100% {
		filter:
			drop-shadow(0 0 8px rgba(255, 255, 255, 0.06))
			drop-shadow(0 0 16px rgba(255, 255, 255, 0.04));
	}
	14% {
		filter:
			drop-shadow(0 0 10px rgba(255, 255, 255, 0.08))
			drop-shadow(0 0 20px rgba(255, 255, 255, 0.05));
	}
	28% {
		filter:
			drop-shadow(0 0 16px rgba(255, 255, 255, 0.14))
			drop-shadow(0 0 32px rgba(255, 255, 255, 0.08));
	}
	42% {
		filter:
			drop-shadow(0 0 11px rgba(255, 255, 255, 0.09))
			drop-shadow(0 0 22px rgba(255, 255, 255, 0.06));
	}
	56% {
		filter:
			drop-shadow(0 0 15px rgba(255, 255, 255, 0.13))
			drop-shadow(0 0 30px rgba(255, 255, 255, 0.08));
	}
	70% {
		filter:
			drop-shadow(0 0 10px rgba(255, 255, 255, 0.08))
			drop-shadow(0 0 18px rgba(255, 255, 255, 0.05));
	}
	84% {
		filter:
			drop-shadow(0 0 12px rgba(255, 255, 255, 0.1))
			drop-shadow(0 0 24px rgba(255, 255, 255, 0.06));
	}
}

.contact {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.5rem;
	align-items: stretch;
	padding-top: 3.8rem;
}

.contact-intro {
	border: 1px solid var(--line);
	border-radius: 16px;
	padding: 1.2rem;
	background: linear-gradient(170deg, rgba(16, 18, 24, 0.78), rgba(10, 12, 16, 0.9));
	box-shadow: var(--box-outline), var(--shadow);
}

.contact p {
	color: var(--text-soft);
	line-height: 1.72;
}

.contact-highlights {
	display: grid;
	gap: 0.45rem;
	margin-top: 1rem;
	padding-top: 0.9rem;
	border-top: 1px solid var(--line-soft);
}

.contact-highlights p {
	margin: 0;
	font-size: 0.93rem;
}

.contact-highlights strong {
	color: var(--text);
}

.contact-meta {
	list-style: none;
	padding: 0;
	margin: 1rem 0 0;
	display: grid;
	gap: 0.55rem;
}

.contact-meta li {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.6rem 0.75rem;
	border-radius: 10px;
	border: 1px solid var(--line-soft);
	background: rgba(16, 18, 24, 0.72);
	box-shadow: var(--box-outline);
}

.contact-meta span {
	color: var(--text-soft);
	font-size: 0.86rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 700;
}

.contact-meta strong {
	color: var(--text);
	font-size: 0.92rem;
	font-weight: 700;
	overflow-wrap: anywhere;
}

.contact-form {
	display: grid;
	gap: 0.85rem;
	height: 100%;
	padding: 1.1rem;
	border-radius: 14px;
	border: 1px solid var(--line);
	background: linear-gradient(180deg, rgba(18, 20, 26, 0.8), rgba(10, 12, 16, 0.9));
	box-shadow: var(--box-outline);
}

.contact-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.75rem;
}

.contact-form label {
	display: grid;
	gap: 0.35rem;
	font-weight: 600;
	font-size: 0.9rem;
}

.contact-form input,
.contact-form select,
.contact-form textarea {
	width: 100%;
	font: inherit;
	border-radius: 10px;
	border: 1px solid var(--line);
	background: #0f1012;
	color: var(--text);
	padding: 0.65rem 0.75rem;
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
	outline: 2px solid rgba(255, 255, 255, 0.45);
	outline-offset: 1px;
}

.contact-check {
	display: flex !important;
	align-items: center;
	gap: 0.7rem;
	margin-top: 0.35rem;
	font-weight: 500;
	font-size: 0.9rem;
	color: var(--text-soft);
}

.contact-check input {
	width: 18px;
	height: 18px;
	margin: 0;
	accent-color: #ffffff;
}

.contact-check span {
	color: var(--text);
}

#contact-status {
	margin: 0.15rem 0 0;
	min-height: 1.3rem;
	color: var(--text-soft);
	font-size: 0.92rem;
}

#contact-status.is-success {
	color: #d6f5d2;
}

#contact-status.is-error {
	color: #ffb4b4;
}

.site-footer {
	width: var(--site-width);
	margin: 0 auto;
	padding: 0 0 2rem;
}

.site-footer p {
	border-top: 1px solid var(--line-soft);
	margin: 0;
	padding-top: 1.2rem;
	color: var(--text-soft);
	font-size: 0.88rem;
}

.reveal {
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}

.reveal.in-view {
	opacity: 1;
	transform: translateY(0);
}

@keyframes members-title-in {
	0% {
		transform: translateY(20px) scaleX(0.92) scaleY(1.18);
		filter: blur(12px);
		letter-spacing: 0.08em;
	}

	65% {
		transform: translateY(0) scaleX(1.02) scaleY(0.98);
		filter: blur(0);
		letter-spacing: 0.02em;
	}

	100% {
		transform: translateY(0) scaleX(1) scaleY(1);
		filter: blur(0);
		letter-spacing: 0.01em;
	}
}

@keyframes hero-title-fade {
	0% {
		opacity: 0;
		transform: translateY(6px);
		filter: blur(1px);
	}

	100% {
		opacity: 1;
		transform: translateY(0);
		filter: blur(0);
	}
}

@keyframes hero-title-shadow {
	0% {
		opacity: 0;
		transform: translateY(18px) scaleX(0.78);
	}

	100% {
		opacity: 0.12;
		transform: translateY(0) scaleX(1);
	}
}

@keyframes members-title-line {
	0% {
		width: 0;
		opacity: 0;
	}

	100% {
		width: min(9.5rem, 100%);
		opacity: 0.92;
	}
}

@keyframes hero-title-line {
	0% {
		width: 0;
		opacity: 0;
		transform: translate(-50%, 2px);
	}

	100% {
		width: min(6.6rem, 100%);
		opacity: 0.35;
		transform: translate(-50%, 0);
	}
}

@media (prefers-reduced-motion: reduce) {
	.section-head.in-view h2,
	.section.reveal.in-view .section-head h2,
	.contact.reveal.in-view .contact-intro h2,
	.section-head.in-view h2::after,
	.section.reveal.in-view .section-head h2::after,
	.contact.reveal.in-view .contact-intro h2::after {
		animation: none;
	}

	.hero-content.in-view.hero-title-ready h1,
	.hero-content.in-view.hero-title-ready h1::before,
	.hero-content.in-view.hero-title-ready h1::after {
		animation: none;
	}

	.intro::after,
	.intro-stage,
	.intro-stage::before,
	.intro-kicker,
	.intro-logo-shell,
	.intro-logo-shell::before,
	.intro-logo-aura,
	.intro-logo-mark,
	.intro-logo-reflection,
	.intro-divider,
	.intro-divider span,
	.intro-signature {
		animation: none;
	}

	.hero-content h1::before {
		display: none;
	}

	.hero-content.hero-title-ready h1 {
		opacity: 1;
		transform: none;
		filter: none;
	}

	.section-head h2::after,
	.contact-intro h2::after {
		width: min(9.5rem, 100%);
		opacity: 0.92;
	}
}

@media (min-width: 1400px) {
	.site-header {
		padding-left: clamp(1rem, 3vw, 2.8rem);
		padding-right: clamp(1rem, 3vw, 2.8rem);
	}

	.section,
	.site-footer {
		width: var(--site-width-wide);
	}

	main::before {
		height: calc(88vh + 11rem);
		background:
			linear-gradient(rgba(6, 8, 11, 0.54), rgba(6, 8, 11, 0.66)),
			url("hero-lawrence.jpeg") center 60% / cover no-repeat;
	}

	.hero {
		grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
		gap: clamp(3rem, 4vw, 5.2rem);
		min-height: min(88vh, 980px);
	}

	.hero-glow {
		width: min(38vw, 520px);
		right: -70px;
		top: 0;
	}

	h1 {
		font-size: clamp(4.8rem, 6vw, 8.2rem);
	}

	.hero-text {
		max-width: 60ch;
		font-size: 1.08rem;
	}

	.hero-stats article {
		padding: 1.2rem 1.3rem;
	}

	.story-copy {
		max-width: 92ch;
	}

	.story-layout {
		grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
	}

	.story-copy p {
		font-size: 1.05rem;
	}

	.cards-grid {
		grid-auto-columns: calc((100% - 3rem) / 4);
	}

	.classes-layout,
	.classes-spaces-grid,
	.events-grid {
		gap: 1.2rem;
	}

	.members-grid {
		gap: 0.95rem;
	}

	.contact {
		grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
		gap: 1.8rem;
	}

	.contact-intro,
	.contact-form {
		padding: 1.35rem;
	}
}

@media (min-width: 1700px) {
	.section,
	.site-footer {
		width: min(1580px, 95vw);
	}

	.hero {
		grid-template-columns: minmax(0, 1.2fr) minmax(360px, 0.8fr);
		gap: 5.4rem;
	}

	.cards-grid {
		grid-auto-columns: calc((100% - 4rem) / 5);
	}

	.members-grid {
		grid-template-columns: repeat(6, minmax(0, 1fr));
	}
}

@media (max-width: 950px) {
	.hero,
	.contact {
		grid-template-columns: 1fr;
	}

	.contact-row {
		grid-template-columns: 1fr;
	}

	.intro-stage {
		width: min(92vw, 680px);
	}

	.intro-logo-shell {
		max-width: min(82vw, 280px);
	}

	.insta-feed-grid,
	.classes-layout,
	.classes-spaces-grid,
	.events-grid {
		grid-template-columns: 1fr;
	}

	.actualite-carousel {
		padding: 0;
	}

	.cards-grid {
		grid-auto-columns: calc((100% - 1rem) / 2);
	}

	.actualite-dots {
		bottom: 0.1rem;
	}

	.insta-live-head {
		flex-direction: column;
		align-items: flex-start;
	}

	.members-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.hero {
		min-height: auto;
		gap: 1.85rem;
	}

	.hero-text {
		max-width: none;
	}

	.hero-stats {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.story {
		min-height: auto;
	}

	.story.section {
		padding-top: 3.1rem;
		padding-bottom: 2.7rem;
	}

	.classes-enroll {
		grid-template-columns: 1fr;
	}

	.classes-enroll-title {
		max-width: 18ch;
	}

	.classes-enroll-link {
		min-height: 0;
	}

	.story-layout {
		grid-template-columns: 1fr;
	}

	.story-visual {
		width: min(100%, 340px);
		max-width: min(420px, 100%);
		margin-top: 0.35rem;
		justify-self: center;
	}
}

@media (max-width: 760px) {
	.hero.section {
		width: 100%;
		padding-left: 0.75rem;
		padding-right: 0.75rem;
	}

	.actualite-carousel {
		padding: 0;
	}

	.actualite-carousel::before,
	.actualite-carousel::after,
	.actualite-progress,
	.actualite-dots {
		display: none;
	}

	.cards-grid {
		grid-auto-columns: 100%;
		padding-bottom: 0.55rem;
	}

	.classes-enroll {
		padding: 1rem;
		border-radius: 18px;
	}

	.classes-enroll-title {
		font-size: 1.45rem;
		max-width: none;
	}

	.classes-enroll-link {
		padding: 1rem;
		border-radius: 16px;
	}

	.classes-enroll-link-brand {
		width: 44px;
		height: 44px;
		border-radius: 14px;
	}

	.classes-enroll-link-logo {
		width: 30px;
	}

	.classes-enroll-link-main {
		font-size: 1.22rem;
	}
}

@media (max-width: 760px) {
	:root {
		--header-height: 60px;
	}

	.site-header {
		padding: 0.2rem 4vw;
		height: var(--header-height);
	}

	.logo {
		width: 48px;
		height: 42px;
		padding-bottom: 0;
	}

	.logo-image {
		height: 42px;
	}

	.menu-btn {
		display: inline-flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		width: 42px;
		height: 42px;
		border-radius: 12px;
		border: 1px solid var(--line);
		background: rgba(255, 255, 255, 0.04);
		padding: 0;
		touch-action: manipulation;
		-webkit-tap-highlight-color: transparent;
	}

	.menu-btn span {
		width: 20px;
		margin: 3px 0;
	}

	.main-nav {
		position: fixed;
		top: calc(var(--header-height) + 8px);
		left: 4vw;
		right: 4vw;
		display: none;
		flex-direction: column;
		gap: 0;
		background: #121316;
		border: 1px solid var(--line);
		border-radius: 14px;
		padding: 0.7rem 0.95rem;
		max-height: calc(100dvh - var(--header-height) - 1.6rem);
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		box-shadow: 0 22px 46px rgba(0, 0, 0, 0.42);
		z-index: 1200;
	}

	.main-nav a {
		display: block;
		font-size: 0.84rem;
		padding: 0.7rem 0.1rem;
		border-bottom: 1px solid rgba(255, 255, 255, 0.08);
		opacity: 0.9;
	}

	.main-nav a:last-child {
		border-bottom: 0;
	}

	.header-actions {
		gap: 0.5rem;
	}

	.lang-switch {
		padding: 0.12rem;
	}

	.lang-btn {
		padding: 0.3rem 0.48rem;
		font-size: 0.66rem;
	}

	.main-nav.open {
		display: flex;
	}

	.members-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.intro-kicker {
		font-size: 0.64rem;
		letter-spacing: 0.18em;
	}

	.intro-logo-shell {
		max-width: min(84vw, 240px);
		padding: 0.62rem;
	}

	.intro-logo-mark {
		width: min(56vw, 170px);
	}

	.intro-signature {
		letter-spacing: 0.18em;
	}

	.section {
		width: min(100% - 1.5rem, 1240px);
		padding: 4rem 0;
	}

	main::before {
		height: calc(72vh + 7.4rem);
		background-position: center 42%;
	}

	.hero-cta {
		display: grid;
		grid-template-columns: 1fr;
		width: min(100%, 320px);
		gap: 0.55rem;
	}

	.hero-cta .btn {
		width: 100%;
		text-align: center;
		min-height: 44px;
	}

	.events-filters {
		flex-wrap: nowrap;
		overflow-x: auto;
		padding-bottom: 0.28rem;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
	}

	.events-filters::-webkit-scrollbar {
		display: none;
	}

	.events-filter {
		flex: 0 0 auto;
	}

	.contact-meta li {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.32rem;
	}

	.contact-form input,
	.contact-form select,
	.contact-form textarea {
		font-size: 16px;
	}

	h1 {
		font-size: clamp(2.5rem, 16vw, 4.4rem);
	}
}

@media (max-width: 560px) {
	:root {
		--header-height: 58px;
	}

	.hero.section {
		padding-left: 0.55rem;
		padding-right: 0.55rem;
	}

	.section {
		width: min(100% - 1.1rem, 1240px);
		padding: 3.45rem 0;
	}

	.story.section {
		padding-top: 2.45rem;
		padding-bottom: 2.2rem;
	}

	main::before {
		height: calc(67vh + 7rem);
	}

	.hero-stats {
		grid-template-columns: 1fr;
	}

	.hero-stats article {
		padding: 0.95rem 1rem;
	}

	.main-nav {
		left: 3vw;
		right: 3vw;
	}

	.members-grid {
		grid-template-columns: 1fr;
	}

	.member-card-front h3 {
		font-size: 0.96rem;
	}

	.member-card-front .member-role {
		font-size: 0.68rem;
	}

	.member-back-social,
	.member-back-close,
	.class-space-back-open,
	.class-space-back-close {
		font-size: 0.66rem;
		padding: 0.48rem 0.8rem;
	}

	.contact-check {
		align-items: flex-start;
	}
}
