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

:root {
	--green: #75ac00;
	--green-dark: #5a8600;
	--text-hero: rgba(255, 255, 255, 0.96);
	--text-hero-muted: rgba(255, 255, 255, 0.86);
	--text-hero-soft: rgba(255, 255, 255, 0.72);
	--font-ui:
		system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial,
		sans-serif;
	/* Proche d’IvyMode en largeur de glyphes pour limiter le saut à l’affichage (swap) */
	--font-ivymode-fallback: Georgia, "Times New Roman", Times, serif;
}

/* Même kit Adobe (cwm3axv) : font-display swap pour texte visible immédiatement (FCP / Lighthouse) */
@font-face {
	font-family: ivymode;
	font-style: normal;
	font-weight: 300;
	font-display: swap;
	src:
		url("https://use.typekit.net/af/d15877/00000000000000007735ce78/31/l?subset_id=2&fvd=n3&v=3")
			format("woff2"),
		url("https://use.typekit.net/af/d15877/00000000000000007735ce78/31/d?subset_id=2&fvd=n3&v=3")
			format("woff");
}

@font-face {
	font-family: ivymode;
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src:
		url("https://use.typekit.net/af/c59ffc/00000000000000007735ce7b/31/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3")
			format("woff2"),
		url("https://use.typekit.net/af/c59ffc/00000000000000007735ce7b/31/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3")
			format("woff");
}

html {
	min-height: 100%;
	overflow-x: hidden;
}

body {
	font-family: ivymode, var(--font-ivymode-fallback);
	font-weight: 300;
	font-style: normal;
	background: #111;
	color: #fff;
	min-height: 100vh;
	min-height: 100dvh;
	display: flex;
	flex-direction: column;
	overflow-x: hidden;
	overflow-y: auto;
}

/* ── Hero ───────────────────────────────────────────── */
.hero {
	position: relative;
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	overflow-x: hidden;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	padding: clamp(20px, 4vh, 40px) 24px clamp(28px, 5vh, 48px);
	min-height: calc(100vh - 120px);
	min-height: calc(100dvh - 120px);
}

.hero__bg {
	position: absolute;
	inset: 0;
	background-image: url("../img/hero-background.webp");
	background-size: cover;
	background-position: center;
	filter: grayscale(100%) brightness(0.55);
	z-index: 0;
}

.hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to bottom,
		rgba(0, 0, 0, 0.82) 0%,
		rgba(0, 0, 0, 0.62) 45%,
		rgba(0, 0, 0, 0.88) 100%
	);
	z-index: 1;
}

.hero__content {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0;
	text-align: center;
	width: 100%;
	max-width: 680px;
	text-shadow:
		0 1px 2px rgba(0, 0, 0, 0.85),
		0 2px 20px rgba(0, 0, 0, 0.35);
}

/* ── Logo ───────────────────────────────────────────── */
.logo {
	width: 160px;
	height: 160px;
	margin-bottom: 16px;
}

.logo img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

/* ── Brand name ─────────────────────────────────────── */
.brand {
	font-size: clamp(52px, 8vw, 80px);
	font-weight: 400;
	font-style: normal;
	letter-spacing: 0.08em;
	line-height: 1;
	color: var(--green);
	text-shadow:
		0 0 28px rgba(0, 0, 0, 0.9),
		0 2px 4px rgba(0, 0, 0, 0.95);
	text-transform: uppercase;
	margin-bottom: 32px;
}

/* ── Divider ────────────────────────────────────────── */
.divider {
	width: 60px;
	height: 2px;
	background: var(--green);
	margin: 0 auto 32px;
	opacity: 1;
	box-shadow: 0 0 12px rgba(117, 172, 0, 0.5);
}

/* ── Coming soon ────────────────────────────────────── */
.coming-soon {
	font-size: clamp(14px, 2vw, 17px);
	font-weight: 300;
	letter-spacing: 0.3em;
	text-transform: uppercase;
	color: var(--text-hero-muted);
	margin-bottom: 20px;
}

.tagline {
	font-size: clamp(22px, 3.5vw, 36px);
	font-weight: 300;
	line-height: 1.35;
	color: var(--text-hero);
	margin-bottom: 28px;
	font-style: italic;
}

.hero__infoblock {
	width: 100%;
	max-width: 440px;
	margin-bottom: 28px;
	padding: 18px 20px 20px;
	border-radius: 14px;
	background: rgba(0, 0, 0, 0.32);
	border: 1px solid rgba(255, 255, 255, 0.12);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
}

.hours {
	font-size: clamp(15px, 2vw, 18px);
	font-weight: 300;
	letter-spacing: 0.12em;
	color: var(--text-hero-muted);
	margin-bottom: 14px;
	padding-bottom: 14px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.contact {
	font-style: normal;
	text-align: center;
	margin: 0;
	max-width: none;
}

.contact__address {
	font-size: clamp(14px, 1.9vw, 17px);
	font-weight: 300;
	line-height: 1.55;
	letter-spacing: 0.06em;
	color: var(--text-hero-muted);
	margin-bottom: 12px;
}

.contact__channels {
	font-family: var(--font-ui);
	font-size: clamp(14px, 2vw, 17px);
	font-weight: 400;
	letter-spacing: 0.02em;
	line-height: 1.55;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 8px;
}

.contact__link {
	font-family: inherit;
	color: var(--green);
	text-decoration: none;
	transition: color 0.2s;
}

.contact__link--mail {
	overflow-wrap: anywhere;
	word-break: break-word;
	max-width: 100%;
}

.contact__link:hover {
	color: #8bc420;
}

.social {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	margin-bottom: 32px;
	flex-wrap: wrap;
}

.social__link {
	font-family: var(--font-ui);
	font-size: clamp(13px, 1.8vw, 15px);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--green);
	text-decoration: none;
	transition:
		color 0.2s,
		opacity 0.2s;
}

.social__link:hover {
	color: #8bc420;
}

.social__sep {
	color: var(--text-hero-soft);
	font-size: 14px;
	line-height: 1;
	user-select: none;
}

/* ── Newsletter form ────────────────────────────────── */
.notify {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
	width: 100%;
	text-shadow: none;
}

.notify__label {
	font-size: 13px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--text-hero-soft);
	text-shadow:
		0 1px 2px rgba(0, 0, 0, 0.75),
		0 2px 12px rgba(0, 0, 0, 0.35);
}

.notify__form {
	display: flex;
	gap: 0;
	width: 100%;
	max-width: 420px;
	border: 1px solid rgba(255, 255, 255, 0.42);
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.35);
}

.notify__input {
	flex: 1;
	background: rgba(0, 0, 0, 0.45);
	border: none;
	outline: none;
	color: var(--text-hero);
	font-family: inherit;
	font-size: 15px;
	padding: 14px 18px;
	caret-color: var(--green);
}

.notify__input::placeholder {
	color: rgba(255, 255, 255, 0.52);
}

.notify__btn {
	background: var(--green);
	border: none;
	color: #fff;
	font-family: inherit;
	font-size: 13px;
	font-weight: 400;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	padding: 14px 22px;
	cursor: pointer;
	transition: background 0.2s;
	white-space: nowrap;
}

.notify__btn:hover {
	background: var(--green-dark);
}

.notify__status {
	margin-top: 10px;
	font-size: 12px;
	font-weight: 300;
	letter-spacing: 0.04em;
	color: var(--text-hero-muted);
	max-width: 420px;
	text-align: center;
	line-height: 1.45;
	min-height: 1.45em;
}

.notify__form--error {
	border-color: rgba(255, 120, 120, 0.55);
}

/* ── Footer ─────────────────────────────────────────── */
.footer {
	position: relative;
	z-index: 2;
	text-align: center;
	padding: 20px 24px;
	font-size: 12px;
	letter-spacing: 0.15em;
	color: rgba(255, 255, 255, 0.48);
	text-transform: uppercase;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.8);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
}

.footer__main {
	line-height: 1.4;
}

.footer__credit {
	font-size: 11px;
	font-weight: 300;
	letter-spacing: 0.06em;
	text-transform: none;
	color: rgba(255, 255, 255, 0.42);
	line-height: 1.5;
}

.footer__credit-link {
	color: var(--green);
	text-decoration: none;
	font-weight: 400;
	transition: color 0.2s;
}

.footer__credit-link:hover {
	color: #8bc420;
}

/* ── Responsive ─────────────────────────────────────── */
@media (max-width: 480px) {
	.logo {
		width: 120px;
		height: 120px;
	}

	.notify__form {
		flex-direction: column;
		border: none;
		gap: 10px;
	}

	.notify__input {
		border: 1px solid rgba(255, 255, 255, 0.25);
		width: 100%;
	}

	.notify__btn {
		width: 100%;
		padding: 14px;
	}
}
