/* ============================================================
   Tania Rousseau — Le Petit Manège de Kingsey
   ============================================================ */

:root {
	--cream: #faf6ef;
	--cream-dark: #f1e9dc;
	--ink: #2b2018;
	--ink-soft: #5c4a3a;
	--cognac: #9a5b2e;
	--cognac-dark: #7c4823;
	--gold: #c19a5b;
	--white: #fffdf9;

	--font-display: "Cormorant Garamond", Georgia, serif;
	--font-body: "Jost", "Segoe UI", sans-serif;

	--max-w: 1120px;
	--radius: 14px;
	--shadow: 0 18px 45px -18px rgba(43, 32, 24, 0.25);
}

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

html { scroll-behavior: smooth; }

body {
	font-family: var(--font-body);
	font-weight: 300;
	color: var(--ink);
	background: var(--cream);
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
}

img { max-width: 100%; display: block; }

h1, h2, h3 { font-family: var(--font-display); font-weight: 600; line-height: 1.1; }

/* ---------- Header ---------- */

.site-header {
	position: fixed;
	inset: 0 0 auto 0;
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.9rem 2rem;
	background: rgba(250, 246, 239, 0.92);
	backdrop-filter: blur(10px);
	transition: box-shadow 0.3s ease;
}
.site-header.scrolled { box-shadow: 0 6px 24px -12px rgba(43, 32, 24, 0.3); }

.brand { text-decoration: none; color: var(--ink); display: flex; flex-direction: column; line-height: 1.15; }
.brand-name { font-family: var(--font-display); font-size: 1.35rem; font-weight: 700; letter-spacing: 0.02em; }
.brand-sub { font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.22em; color: var(--cognac); }

.site-nav { display: flex; align-items: center; gap: 1.8rem; }
.site-nav a {
	text-decoration: none;
	color: var(--ink-soft);
	font-size: 0.9rem;
	font-weight: 400;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	transition: color 0.2s;
}
.site-nav a:hover { color: var(--cognac); }
.site-nav a.nav-cta {
	color: var(--white);
	background: var(--cognac);
	padding: 0.45rem 1.1rem;
	border-radius: 999px;
}
.site-nav a.nav-cta:hover { background: var(--cognac-dark); }

.nav-toggle {
	display: none;
	flex-direction: column;
	gap: 5px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 6px;
}
.nav-toggle span {
	width: 24px; height: 2px;
	background: var(--ink);
	transition: transform 0.25s, opacity 0.25s;
}
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ---------- Hero ---------- */

.hero {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	position: relative;
	padding: 7rem 2rem 4rem;
	background:
		radial-gradient(ellipse at 80% 20%, rgba(193, 154, 91, 0.16), transparent 55%),
		var(--cream);
	overflow: hidden;
}
.hero-inner {
	max-width: var(--max-w);
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 3rem;
	align-items: center;
}
.eyebrow {
	text-transform: uppercase;
	letter-spacing: 0.28em;
	font-size: 0.75rem;
	font-weight: 500;
	color: var(--cognac);
	margin-bottom: 1rem;
}
.hero h1 {
	font-size: clamp(3.2rem, 8vw, 5.6rem);
	font-weight: 700;
	letter-spacing: 0.01em;
}
.hero-role {
	font-family: var(--font-display);
	font-style: italic;
	font-size: 1.4rem;
	color: var(--cognac-dark);
	margin: 0.8rem 0 1.2rem;
}
.hero-lead { max-width: 34rem; font-size: 1.05rem; margin-bottom: 2rem; color: var(--ink-soft); }

.hero-actions, .contact-actions { display: flex; gap: 1rem; flex-wrap: wrap; }

.button {
	display: inline-block;
	padding: 0.8rem 1.8rem;
	background: var(--cognac);
	color: var(--white);
	text-decoration: none;
	font-size: 0.88rem;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	border-radius: 999px;
	transition: background 0.2s, transform 0.2s;
}
.button:hover { background: var(--cognac-dark); transform: translateY(-2px); }
.button.ghost {
	background: transparent;
	color: var(--cognac-dark);
	border: 1.5px solid var(--cognac);
}
.button.ghost:hover { background: rgba(154, 91, 46, 0.08); }

.hero-image img {
	border-radius: 50% 50% var(--radius) var(--radius) / 42% 42% var(--radius) var(--radius);
	box-shadow: var(--shadow);
}
.hero-scroll {
	position: absolute;
	bottom: 1.4rem; left: 50%;
	transform: translateX(-50%);
	color: var(--cognac);
	font-size: 1.4rem;
	animation: bob 2s infinite ease-in-out;
}
@keyframes bob { 0%,100% { transform: translate(-50%,0);} 50% { transform: translate(-50%,8px);} }

/* ---------- Sections ---------- */

.section { padding: 6rem 2rem; }
.section.alt { background: var(--cream-dark); }
.section-inner { max-width: var(--max-w); margin: 0 auto; }
.section-inner.narrow { max-width: 44rem; text-align: center; }

.section-head { max-width: 42rem; margin: 0 auto 3.5rem; text-align: center; }
.section h2 { font-size: clamp(2rem, 4.5vw, 2.9rem); margin-bottom: 1rem; }
.section-head p { color: var(--ink-soft); }

/* Split (à propos) */
.split { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 4rem; align-items: center; }
.split-image img { border-radius: var(--radius); box-shadow: var(--shadow); }
.split-text p { margin-bottom: 1rem; color: var(--ink-soft); }
.split-text .quote {
	font-family: var(--font-display);
	font-style: italic;
	font-size: 1.35rem;
	color: var(--cognac-dark);
	border-left: 3px solid var(--gold);
	padding-left: 1.2rem;
	margin-top: 1.8rem;
}

/* Cards (services) */
.cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1.6rem;
}
.card {
	background: var(--white);
	border-radius: var(--radius);
	padding: 2.2rem 1.8rem;
	box-shadow: 0 10px 30px -18px rgba(43, 32, 24, 0.25);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.card-icon {
	width: 54px; height: 54px;
	border-radius: 50%;
	background: rgba(193, 154, 91, 0.18);
	display: flex; align-items: center; justify-content: center;
	margin-bottom: 1.3rem;
}
.card-icon svg { width: 28px; height: 28px; fill: var(--cognac); }
.card h3 { font-size: 1.45rem; margin-bottom: 0.6rem; }
.card p { font-size: 0.95rem; color: var(--ink-soft); }

/* Pillars (approche) */
.pillars {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 2.5rem;
}
.pillar { border-top: 2px solid var(--gold); padding-top: 1.4rem; }
.pillar-num {
	font-family: var(--font-display);
	font-size: 1.1rem;
	color: var(--gold);
	letter-spacing: 0.15em;
}
.pillar h3 { font-size: 1.5rem; margin: 0.4rem 0 0.6rem; }
.pillar p { font-size: 0.95rem; color: var(--ink-soft); }

/* Facebook embed */
.fb-embed { display: flex; justify-content: center; }
.fb-embed iframe { max-width: 100%; border-radius: var(--radius); box-shadow: var(--shadow); background: var(--white); }
.fb-fallback { text-align: center; margin-top: 2rem; }

/* Contact */
.contact { background: linear-gradient(180deg, var(--cream) 0%, var(--cream-dark) 100%); }
.contact p { color: var(--ink-soft); margin-bottom: 1.6rem; }
.contact-actions { justify-content: center; }
.contact-location { margin-top: 2rem; font-size: 1rem; letter-spacing: 0.05em; }

/* Formulaire de contact */
.contact-form {
	text-align: left;
	background: var(--white);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 2rem 1.8rem;
	margin: 0 auto 2rem;
	max-width: 36rem;
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-field { margin-bottom: 1.1rem; }
.form-field label {
	display: block;
	font-size: 0.78rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--cognac-dark);
	margin-bottom: 0.35rem;
}
.form-field input,
.form-field textarea {
	width: 100%;
	font-family: var(--font-body);
	font-size: 1rem;
	font-weight: 300;
	color: var(--ink);
	background: var(--cream);
	border: 1px solid rgba(154, 91, 46, 0.25);
	border-radius: 8px;
	padding: 0.7rem 0.9rem;
	transition: border-color 0.2s, box-shadow 0.2s;
}
.form-field input:focus,
.form-field textarea:focus {
	outline: none;
	border-color: var(--cognac);
	box-shadow: 0 0 0 3px rgba(193, 154, 91, 0.2);
}
.form-field textarea { resize: vertical; }
.form-submit { width: 100%; border: none; cursor: pointer; font-family: var(--font-body); }
.form-submit:disabled { opacity: 0.6; cursor: wait; transform: none; }
.hp-field { position: absolute; left: -9999px; top: -9999px; }
.form-status { margin: 0.9rem 0 0; font-size: 0.92rem; min-height: 1.4em; }
.form-status.ok { color: #2e7d32; }
.form-status.err { color: #b3402a; }

@media (max-width: 560px) {
	.form-row { grid-template-columns: 1fr; gap: 0; }
}

/* ---------- Footer ---------- */

.site-footer {
	background: var(--ink);
	color: rgba(250, 246, 239, 0.85);
	padding: 3rem 2rem;
	text-align: center;
}
.footer-brand { font-family: var(--font-display); font-size: 1.3rem; color: var(--cream); }
.footer-tag { font-size: 0.85rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gold); margin: 0.5rem 0 1.2rem; }
.footer-copy { font-size: 0.8rem; color: rgba(250, 246, 239, 0.55); }
.footer-credit { font-size: 0.75rem; color: rgba(250, 246, 239, 0.45); margin-top: 0.4rem; }
.footer-credit a { color: var(--gold); text-decoration: none; }
.footer-credit a:hover { text-decoration: underline; }

/* ---------- Reveal animation ---------- */

.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal.visible { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	.reveal { opacity: 1; transform: none; transition: none; }
	.hero-scroll { animation: none; }
}

/* ---------- Responsive ---------- */

@media (max-width: 900px) {
	.hero-inner, .split { grid-template-columns: 1fr; }
	.hero { padding-top: 8rem; }
	.hero-image { order: -1; max-width: 340px; margin: 0 auto; }
	.split-image { max-width: 420px; margin: 0 auto; }
}

@media (max-width: 720px) {
	.site-nav {
		position: absolute;
		top: 100%; left: 0; right: 0;
		flex-direction: column;
		gap: 0;
		background: var(--cream);
		box-shadow: 0 18px 30px -18px rgba(43, 32, 24, 0.35);
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease;
	}
	.site-nav.open { max-height: 22rem; }
	.site-nav a { padding: 1rem 2rem; width: 100%; }
	.site-nav a.nav-cta { border-radius: 0; text-align: center; }
	.nav-toggle { display: flex; }
	.section { padding: 4rem 1.4rem; }
}
