/*
 * Griffon Movers · Maison
 * Design system v3.0 — Audemars Piguet website doctrine + Griffon gold
 *
 * Bodoni Moda (display caps) + EB Garamond Bold (serif statements) + Inter (UI)
 * Paper white + ink + gold #A88A3F
 * Photography immersive, no decoration, generous space.
 */

/* Fonts loaded via wp_head <link> for parallel download (see functions.php) */

/* =============================================================
 * Tokens
 * ============================================================= */
:root {
	/* Palette — paper / ink / gold */
	--paper:       #FFFFFF;
	--paper-warm:  #FAF8F2;
	--ink:         #0A0A0A;
	--ink-soft:    #1F1F1F;
	--graphite:    #5A5A5A;
	--silver:      #A0A0A0;
	--line:        rgba(10, 10, 10, 0.10);
	--line-soft:   rgba(10, 10, 10, 0.05);

	/* Or Griffon, prélevé du logo */
	--gold:        #A88A3F;
	--gold-soft:   #C7AB66;
	--gold-deep:   #7E6628;
	--gold-tint:   rgba(168, 138, 63, 0.08);
	--gold-line:   rgba(168, 138, 63, 0.30);

	--night:       #0A0A0A;

	/* Aliases sémantiques */
	--bg:          var(--paper);
	--bg-alt:      var(--paper-warm);
	--bg-dark:     var(--night);
	--fg:          var(--ink);
	--fg-soft:     var(--ink-soft);
	--fg-mute:     var(--graphite);
	--fg-faint:    var(--silver);
	--fg-inv:      var(--paper);
	--accent:      var(--gold);

	/* Three families */
	--font-display: "Bodoni Moda", "Didot", "Bodoni 72", "Didot LT STD", serif;
	--font-italic:  "Bodoni Moda", "Didot", "Bodoni 72 Book", serif;
	--font-serif:   "EB Garamond", "Bookmania", "Caslon", "Hoefler Text", "Garamond Premier Pro", serif;
	--font-sans:    "Inter", "Söhne", "Helvetica Neue", -apple-system, system-ui, sans-serif;

	--text-hero:   clamp(3.5rem, 9vw, 9rem);
	--text-h1:     clamp(2.5rem, 6vw, 6rem);
	--text-h2:     clamp(1.75rem, 3.6vw, 3rem);
	--text-h3:     1.375rem;

	--text-italic-hero: clamp(3.75rem, 9.5vw, 9.5rem);
	--text-italic-h1:   clamp(2.75rem, 6.4vw, 6.4rem);
	--text-italic-h2:   clamp(2rem, 4vw, 3.4rem);

	--text-lede:   1.0625rem;
	--text-body:   0.9375rem;
	--text-small:  0.8125rem;
	--text-eyebrow:0.6875rem;

	--tracking-display:  0.02em;
	--tracking-italic:   -0.012em;
	--tracking-eyebrow:  0.18em;
	--tracking-button:   0.04em;

	--lh-display:  1.05;
	--lh-tight:    1.12;
	--lh-snug:     1.4;
	--lh-base:     1.65;
	--lh-relaxed:  1.8;

	--grid-max: 1440px;
	--gutter:   max(32px, 4.5vw);

	--space-1: 4px;
	--space-2: 8px;
	--space-3: 12px;
	--space-4: 16px;
	--space-5: 24px;
	--space-6: 32px;
	--space-7: 48px;
	--space-8: 64px;
	--space-9: 96px;
	--space-10: 144px;
	--space-11: 200px;
	--space-12: 280px;

	--radius-none: 0;

	--dur:      400ms;
	--dur-long: 700ms;
	--dur-xl:   1200ms;
	--ease:     cubic-bezier(.22, .61, .36, 1);

	--shadow-image: 0 60px 120px -50px rgba(10,10,10,0.18);
}

/* =============================================================
 * Base
 * ============================================================= */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
	background: var(--bg);
	color: var(--fg);
	font-family: var(--font-sans);
	font-size: var(--text-body);
	line-height: var(--lh-base);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}
::selection { background: var(--ink); color: var(--paper); }

/* Anchor scroll-margin for fixed nav */
:where([id]) { scroll-margin-top: 96px; }

/* =============================================================
 * Display type — UPPERCASE Bodoni Light
 * ============================================================= */
.h-hero {
	font-family: var(--font-display);
	font-weight: 300;
	font-size: var(--text-hero);
	line-height: var(--lh-display);
	letter-spacing: var(--tracking-display);
	text-transform: uppercase;
	margin: 0;
	color: var(--ink);
}
.h-display {
	font-family: var(--font-display);
	font-weight: 300;
	font-size: var(--text-h1);
	line-height: var(--lh-display);
	letter-spacing: var(--tracking-display);
	text-transform: uppercase;
	margin: 0;
}
.h-section {
	font-family: var(--font-display);
	font-weight: 300;
	font-size: var(--text-h2);
	line-height: var(--lh-tight);
	letter-spacing: var(--tracking-display);
	text-transform: uppercase;
	margin: 0;
}
.h-sub {
	font-family: var(--font-display);
	font-weight: 300;
	font-size: var(--text-h3);
	line-height: var(--lh-snug);
	letter-spacing: var(--tracking-display);
	text-transform: uppercase;
	margin: 0;
}

/* Italic flourish — lowercase, Bodoni italic */
.italic, em.italic, .h-italic {
	font-family: var(--font-italic);
	font-style: italic;
	font-weight: 400;
	text-transform: none;
	letter-spacing: var(--tracking-italic);
}
.h-italic-hero {
	font-family: var(--font-italic);
	font-style: italic;
	font-weight: 400;
	font-size: var(--text-italic-hero);
	line-height: 1.08;
	letter-spacing: var(--tracking-italic);
	text-transform: none;
	margin: 0;
	padding-bottom: 0.08em;
	color: var(--ink);
}
.h-italic-display {
	font-family: var(--font-italic);
	font-style: italic;
	font-weight: 400;
	font-size: var(--text-italic-h1);
	line-height: 1.08;
	letter-spacing: var(--tracking-italic);
	text-transform: none;
	margin: 0;
	padding-bottom: 0.08em;
	color: var(--ink);
}

/* Strong serif — Garamond Bold, matches the wordmark */
.h-serif {
	font-family: var(--font-serif);
	font-weight: 700;
	font-size: var(--text-h1);
	line-height: var(--lh-display);
	letter-spacing: -0.005em;
	text-transform: uppercase;
	margin: 0;
	color: var(--ink);
}
.h-serif--section {
	font-family: var(--font-serif);
	font-weight: 700;
	font-size: var(--text-h2);
	line-height: var(--lh-tight);
	letter-spacing: -0.005em;
	text-transform: uppercase;
	margin: 0;
	color: var(--ink);
}
.h-serif--sub {
	font-family: var(--font-serif);
	font-weight: 600;
	font-size: var(--text-h3);
	line-height: var(--lh-snug);
	letter-spacing: 0;
	text-transform: uppercase;
	margin: 0;
	color: var(--ink);
}
.num-serif {
	font-family: var(--font-serif);
	font-weight: 600;
	font-size: 56px;
	line-height: 1;
	letter-spacing: -0.01em;
	color: var(--ink);
}

/* =============================================================
 * Body / lede / micro
 * ============================================================= */
.lede {
	font-family: var(--font-sans);
	font-weight: 400;
	font-size: var(--text-lede);
	line-height: var(--lh-base);
	letter-spacing: 0;
	color: var(--fg-soft);
}
.body {
	font-family: var(--font-sans);
	font-weight: 400;
	font-size: var(--text-body);
	line-height: var(--lh-relaxed);
	color: var(--fg-soft);
}
.caption {
	font-family: var(--font-sans);
	font-weight: 400;
	font-size: var(--text-small);
	line-height: var(--lh-snug);
	color: var(--fg-mute);
}
.eyebrow {
	display: inline-block;
	font-family: var(--font-sans);
	font-weight: 500;
	font-size: var(--text-eyebrow);
	letter-spacing: var(--tracking-eyebrow);
	text-transform: uppercase;
	color: var(--fg);
}
.eyebrow--mute { color: var(--fg-mute); }
.eyebrow--inv  { color: var(--paper); }
.eyebrow--gold { color: var(--gold); }

.tagline {
	font-family: var(--font-sans);
	font-weight: 500;
	font-size: 11px;
	letter-spacing: 0.32em;
	text-transform: uppercase;
	color: var(--gold);
}

/* =============================================================
 * Hairlines
 * ============================================================= */
.rule, hr.rule { border: 0; border-top: 1px solid var(--line); margin: 0; }
.rule--inv  { border-top-color: rgba(255, 255, 255, 0.18); }
.rule--gold { border-top: 1px solid var(--gold); margin: 0; }
.rule--gold-soft { border-top: 1px solid var(--gold-line); margin: 0; }

/* =============================================================
 * Buttons — rectangle 1px, Inter medium
 * ============================================================= */
.btn,
.wp-block-button__link {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 12px;
	padding: 22px 56px !important;
	background: transparent !important;
	color: var(--ink) !important;
	border: 1px solid var(--ink) !important;
	border-radius: 0 !important;
	font-family: var(--font-sans);
	font-weight: 500 !important;
	font-size: 14px !important;
	line-height: 1 !important;
	letter-spacing: var(--tracking-button) !important;
	text-transform: none !important;
	text-decoration: none !important;
	cursor: pointer;
	transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease) !important;
}
.btn:hover,
.wp-block-button__link:hover {
	background: var(--ink) !important;
	color: var(--paper) !important;
}

.btn--solid {
	background: var(--ink) !important;
	color: var(--paper) !important;
}
.btn--solid:hover {
	background: var(--accent) !important;
	border-color: var(--accent) !important;
	color: var(--paper) !important;
}

.btn--inv {
	border-color: var(--paper) !important;
	color: var(--paper) !important;
}
.btn--inv:hover {
	background: var(--paper) !important;
	color: var(--ink) !important;
}

.btn--ghost {
	background: transparent !important;
	color: var(--ink) !important;
	border: 1px solid var(--ink) !important;
}
.btn--ghost:hover {
	background: var(--ink) !important;
	color: var(--paper) !important;
}

/* Discover link — inter medium, hairline underline */
.discover {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	font-family: var(--font-sans);
	font-weight: 500;
	font-size: 13px;
	letter-spacing: var(--tracking-button);
	color: var(--ink);
	text-decoration: none;
	padding-bottom: 4px;
	border-bottom: 1px solid var(--ink);
	background: transparent;
	cursor: pointer;
	transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease), gap var(--dur) var(--ease);
}
.discover::after { content: "→"; transition: transform var(--dur) var(--ease); }
.discover:hover { color: var(--accent); border-color: var(--accent); gap: 16px; }
.discover:hover::after { transform: translateX(3px); }

.discover--inv { color: var(--paper); border-color: var(--paper); }
.discover--inv:hover { color: var(--accent); border-color: var(--accent); }

/* =============================================================
 * Container
 * ============================================================= */
.container { max-width: var(--grid-max); margin: 0 auto; padding-left: var(--gutter); padding-right: var(--gutter); }
.container--narrow { max-width: 1100px; }
.container--text { max-width: 720px; }

/* =============================================================
 * Logo lockups
 * ============================================================= */
.logo-gm {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	text-decoration: none;
	color: inherit;
}
.logo-gm__icon {
	display: block;
	width: auto;
}
.logo-gm__words {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 2px;
	line-height: 1;
}
.logo-gm__name {
	font-family: var(--font-serif);
	font-weight: 700;
	font-size: 16px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--ink);
	line-height: 1.1;
	white-space: nowrap;
}
.logo-gm__name--inv { color: var(--paper); }
.logo-gm__tag {
	font-family: var(--font-sans);
	font-weight: 500;
	font-size: 9px;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	color: var(--gold);
	white-space: nowrap;
}

/* Stacked layout for footer */
.logo-gm--stacked {
	flex-direction: column;
	align-items: center;
	gap: 16px;
}
.logo-gm--stacked .logo-gm__words {
	align-items: center;
	gap: 6px;
}
.logo-gm--stacked .logo-gm__name {
	font-size: 24px;
}
.logo-gm--stacked .logo-gm__tag {
	font-size: 11px;
	letter-spacing: 0.32em;
}

/* =============================================================
 * Nav
 * ============================================================= */
.griffon-nav {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 50;
	background: var(--paper);
	border-bottom: 1px solid var(--line);
	transition: padding var(--dur) var(--ease);
}
.griffon-nav__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 48px;
	padding: 20px var(--gutter);
	max-width: var(--grid-max);
	margin: 0 auto;
	transition: padding var(--dur) var(--ease);
}
.griffon-nav.is-scrolled .griffon-nav__inner { padding-top: 12px; padding-bottom: 12px; }
.griffon-nav.is-scrolled .logo-gm__icon { height: 36px !important; }

.griffon-nav__links {
	display: flex;
	align-items: center;
	gap: 36px;
	list-style: none;
	padding: 0;
	margin: 0;
}
.griffon-nav__links a {
	font-family: var(--font-sans);
	font-weight: 500;
	font-size: 13px;
	letter-spacing: 0.04em;
	color: var(--ink);
	text-decoration: none;
	transition: color var(--dur) var(--ease);
}
.griffon-nav__links a:hover { color: var(--gold); }

.griffon-nav__divider {
	width: 1px;
	height: 24px;
	background: var(--line);
	margin-left: 8px;
}

.griffon-nav__cta {
	background: var(--ink);
	color: var(--paper);
	border: 0;
	padding: 12px 28px;
	font-family: var(--font-sans);
	font-weight: 500;
	font-size: 12px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	text-decoration: none;
	cursor: pointer;
	transition: background var(--dur) var(--ease);
	display: inline-block;
	white-space: nowrap;
}
.griffon-nav__cta:hover { background: var(--gold); }

.griffon-nav__primary {
	display: flex;
	align-items: center;
	gap: 36px;
}

/* Burger button — hidden on desktop */
.griffon-nav__burger {
	display: none;
	width: 44px;
	height: 44px;
	padding: 0;
	margin: 0;
	background: transparent;
	border: 0;
	cursor: pointer;
	position: relative;
	z-index: 51;
}
.griffon-nav__burger-line {
	position: absolute;
	left: 10px;
	right: 10px;
	height: 1px;
	background: var(--ink);
	transition: transform var(--dur) var(--ease), top var(--dur) var(--ease), opacity var(--dur) var(--ease);
}
.griffon-nav__burger-line:nth-child(1) { top: 16px; }
.griffon-nav__burger-line:nth-child(2) { top: 26px; }
.griffon-nav.is-open .griffon-nav__burger-line:nth-child(1) {
	top: 21px;
	transform: rotate(45deg);
}
.griffon-nav.is-open .griffon-nav__burger-line:nth-child(2) {
	top: 21px;
	transform: rotate(-45deg);
}

/* Mobile drawer — hidden by default. Top offset = header height so burger stays clickable above. */
.griffon-nav__drawer {
	position: fixed;
	top: 68px;
	left: 0;
	right: 0;
	bottom: 0;
	background: var(--paper);
	z-index: 49;
	padding: 32px var(--gutter) 48px;
	opacity: 0;
	pointer-events: none;
	transition: opacity var(--dur) var(--ease);
	overflow-y: auto;
}
.griffon-nav.is-scrolled .griffon-nav__drawer { top: 60px; }
.griffon-nav__drawer[hidden] { display: none; }
.griffon-nav.is-open .griffon-nav__drawer {
	opacity: 1;
	pointer-events: auto;
}
.griffon-nav__drawer nav {
	display: flex;
	flex-direction: column;
	gap: 48px;
	max-width: 480px;
	margin: 24px auto 0;
}
.griffon-nav__drawer-links {
	display: flex;
	flex-direction: column;
	gap: 0;
	list-style: none;
	padding: 0;
	margin: 0;
}
.griffon-nav__drawer-links li {
	border-top: 1px solid var(--line);
}
.griffon-nav__drawer-links li:last-child {
	border-bottom: 1px solid var(--line);
}
.griffon-nav__drawer-links a {
	display: block;
	padding: 24px 0;
	font-family: var(--font-display);
	font-weight: 300;
	font-size: 26px;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: var(--ink);
	text-decoration: none;
	transition: color var(--dur) var(--ease);
}
.griffon-nav__drawer-links a:hover,
.griffon-nav__drawer-links a:focus { color: var(--gold); }
.griffon-nav__drawer-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--ink);
	color: var(--paper);
	padding: 20px 32px;
	font-family: var(--font-sans);
	font-weight: 500;
	font-size: 12px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	text-decoration: none;
	align-self: flex-start;
}
.griffon-nav__drawer-cta:hover { background: var(--gold); }

/* =============================================================
 * Image hover
 * ============================================================= */
.ph-img--hover { transition: transform 1200ms cubic-bezier(.22,.61,.36,1); }
*:hover > .ph-img--hover, a:hover .ph-img--hover, figure:hover .ph-img--hover { transform: scale(1.02); }

/* Photo block */
.griffon-photo {
	margin: 0;
	display: block;
	overflow: hidden;
	position: relative;
}
.griffon-photo > img {
	width: 100%;
	height: auto;
	display: block;
	transition: transform var(--dur-xl) var(--ease);
}
.griffon-photo:hover > img { transform: scale(1.02); }

.magazine-caption,
.caption {
	font-family: var(--font-sans);
	font-weight: 400;
	font-size: var(--text-small);
	line-height: var(--lh-snug);
	color: var(--fg-mute);
	margin-top: 1rem;
}
.magazine-caption strong { color: var(--ink); font-weight: 500; }

/* =============================================================
 * Backwards compat (legacy patterns / inline old styles)
 * ============================================================= */
.griffon-kicker {
	display: inline-block;
	font-family: var(--font-sans);
	font-weight: 500;
	font-size: var(--text-eyebrow);
	letter-spacing: var(--tracking-eyebrow);
	text-transform: uppercase;
	color: var(--graphite);
}
.griffon-kicker--patina,
.griffon-kicker--gold,
.kicker--gold,
.kicker--patina { color: var(--gold); }

.griffon-wordmark {
	display: inline-block;
	font-family: var(--font-serif);
	font-weight: 700;
	font-size: 16px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: inherit;
	text-decoration: none;
}

/* h-editorial → map to AP Bodoni Moda CAPS for legacy pages */
.h-editorial {
	font-family: var(--font-display);
	font-weight: 300;
	line-height: var(--lh-display);
	letter-spacing: var(--tracking-display);
	text-transform: uppercase;
	color: var(--ink);
	margin: 0;
	text-wrap: balance;
}

/* .pull (Fraunces italic) → map to Bodoni italic */
.pull,
.griffon-pull,
blockquote.pull {
	font-family: var(--font-italic);
	font-style: italic;
	font-weight: 400;
	font-size: clamp(1.75rem, 3.6vw, 3rem);
	line-height: 1.25;
	letter-spacing: -0.012em;
	color: var(--ink);
	max-width: 28ch;
	margin: 0 auto;
	text-align: center;
	text-wrap: balance;
}

/* Legacy proof-grid → vertical stack with hairlines */
.griffon-proof-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
}
.griffon-proof-item {
	padding: 32px 24px;
}
.griffon-proof-item + .griffon-proof-item {
	border-left: 1px solid var(--line);
}
.griffon-proof-value {
	font-family: var(--font-serif);
	font-weight: 600;
	font-size: 32px;
	line-height: 1;
	color: var(--ink);
	margin-bottom: 12px;
	letter-spacing: -0.01em;
}
.griffon-proof-label {
	font-family: var(--font-sans);
	font-weight: 500;
	font-size: var(--text-eyebrow);
	letter-spacing: var(--tracking-eyebrow);
	text-transform: uppercase;
	color: var(--graphite);
}

/* Legacy hero-grid (sub pages) */
.griffon-hero-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 96px;
	align-items: end;
}
@media (max-width: 900px) {
	.griffon-hero-grid { grid-template-columns: 1fr; gap: 48px; }
	.griffon-proof-grid { grid-template-columns: 1fr; }
	.griffon-proof-item + .griffon-proof-item { border-left: 0; border-top: 1px solid var(--line); }
}

/* Legacy two-col + projets-* (other pages) */
.griffon-two-col {
	display: grid;
	grid-template-columns: 1fr 1.6fr;
	gap: 96px;
	align-items: start;
}
@media (max-width: 900px) {
	.griffon-two-col { grid-template-columns: 1fr; gap: 48px; }
}

.griffon-projets-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 64px;
	align-items: start;
}
.griffon-projets-grid > article {
	display: flex;
	flex-direction: column;
	gap: 0;
}
@media (max-width: 900px) {
	.griffon-projets-grid { grid-template-columns: 1fr; gap: 48px; }
}

/* Legacy magazine-caption italic for subsidiary pages */
.magazine-caption {
	font-family: var(--font-sans);
	font-weight: 400;
	font-size: var(--text-small);
	line-height: var(--lh-snug);
	color: var(--graphite);
	margin-top: 1rem;
}

/* =============================================================
 * Article body (long-form blog) — softer than display CAPS
 * Wrap blog post bodies in <div class="griffon-article">
 * ============================================================= */
.griffon-article {
	max-width: 720px;
	margin: 0 auto;
}
.griffon-article h2 {
	font-family: var(--font-serif);
	font-weight: 600;
	font-size: clamp(1.5rem, 2.4vw, 2rem);
	line-height: 1.2;
	letter-spacing: -0.005em;
	text-transform: none;
	color: var(--ink);
	margin: 64px 0 24px;
}
.griffon-article h2:first-child { margin-top: 0; }
.griffon-article h3 {
	font-family: var(--font-serif);
	font-weight: 600;
	font-size: 1.25rem;
	line-height: 1.3;
	letter-spacing: 0;
	text-transform: none;
	color: var(--ink);
	margin: 40px 0 16px;
}
.griffon-article p {
	font-family: var(--font-sans);
	font-weight: 400;
	font-size: 1.0625rem;
	line-height: 1.75;
	color: var(--ink-soft);
	margin: 0 0 24px;
}
.griffon-article p strong { color: var(--ink); font-weight: 600; }
.griffon-article p.lede {
	font-size: 1.25rem;
	line-height: 1.55;
	color: var(--ink-soft);
	margin-bottom: 48px;
}
.griffon-article ul,
.griffon-article ol {
	font-family: var(--font-sans);
	font-size: 1.0625rem;
	line-height: 1.75;
	color: var(--ink-soft);
	margin: 0 0 24px;
	padding-left: 24px;
}
.griffon-article li { margin-bottom: 8px; }
.griffon-article a {
	color: var(--gold-deep);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
	transition: color var(--dur) var(--ease);
}
.griffon-article a:hover { color: var(--gold); }
.griffon-article blockquote {
	font-family: var(--font-italic);
	font-style: italic;
	font-weight: 400;
	font-size: 1.5rem;
	line-height: 1.4;
	color: var(--ink);
	margin: 48px 0;
	padding-left: 32px;
	border-left: 1px solid var(--gold);
}
.griffon-article hr {
	border: 0;
	border-top: 1px solid var(--line);
	margin: 64px 0;
}

/* =============================================================
 * Reduce motion
 * ============================================================= */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}

/* =============================================================
 * Mobile
 * ============================================================= */
@media (max-width: 900px) {
	.griffon-nav__inner { gap: 16px; padding: 16px var(--gutter); }
	.griffon-nav__links { gap: 20px; }
	.griffon-nav__links a { font-size: 11px; }
	.griffon-nav__cta { padding: 10px 18px; font-size: 11px; }
}
@media (max-width: 720px) {
	/* Bascule en mode burger : la nav primaire complète disparait */
	.griffon-nav__primary { display: none; }
	.griffon-nav__burger { display: block; }
	.griffon-nav__inner { gap: 12px; padding: 14px var(--gutter); }
	.griffon-nav .logo-gm__icon { height: 36px !important; }
	.griffon-nav .logo-gm__name { font-size: 13px !important; }
	.griffon-nav .logo-gm__tag { display: none; }
}
@media (max-width: 480px) {
	.griffon-nav__inner { gap: 8px; padding: 12px var(--gutter); }
	.griffon-nav .logo-gm { gap: 10px; }
	.griffon-nav .logo-gm__icon { height: 32px !important; }
	.griffon-nav .logo-gm__name { font-size: 12px !important; letter-spacing: 0.06em !important; }
	.griffon-nav__drawer-links a { font-size: 22px; padding: 20px 0; }
}

/* =============================================================
 * Mobile · GLOBAL RESPONSIVE OVERRIDE
 * Force tous les grids inline 2-col/3-col à stacker en colonne
 * sur mobile (les inline styles winner sur les class CSS sans !important)
 * ============================================================= */
@media (max-width: 900px) {
	main section [style*="grid-template-columns"]:not(.wp-block-columns) {
		grid-template-columns: 1fr !important;
		gap: 40px !important;
	}
	main section [style*="grid-template-columns:repeat(3"] {
		grid-template-columns: 1fr 1fr !important;
		gap: 24px !important;
	}
	main section [style*="grid-template-columns:repeat(4"] {
		grid-template-columns: 1fr 1fr !important;
		gap: 24px !important;
	}
	/* Supprimer divisers latéraux quand items stackés */
	main section [style*="border-left:1px solid"] {
		border-left: 0 !important;
		padding-left: 0 !important;
		padding-right: 0 !important;
	}
	/* Ajouter divider horizontal entre stats stackés */
	main section .griffon-maison__stat + .griffon-maison__stat {
		border-top: 1px solid var(--line);
		padding-top: 24px;
	}
	/* Réduire paddings massifs sur mobile */
	main section[style*="padding:200px 0"],
	main section[style*="padding:240px 0"],
	main section[style*="padding:160px 0"] {
		padding: 80px 0 !important;
	}
	main section[style*="padding:200px 0 96px"],
	main section[style*="padding:200px 0 120px"],
	main section[style*="padding-top:200px"] {
		padding: 96px 0 56px !important;
	}
	main section[style*="padding:144px 0"] {
		padding: 64px 0 !important;
	}
	/* Section avec gradient padding 64px reste OK pour proof bar */

	/* Article body padding */
	.griffon-article {
		max-width: 100%;
		padding: 0 var(--gutter);
	}
}

@media (max-width: 720px) {
	main section [style*="grid-template-columns"]:not(.wp-block-columns),
	main section [style*="grid-template-columns:repeat(3"],
	main section [style*="grid-template-columns:repeat(4"] {
		grid-template-columns: 1fr !important;
		gap: 32px !important;
	}
	/* H1 hero plus modeste sur mobile */
	main .h-hero {
		font-size: clamp(2.25rem, 9vw, 4rem) !important;
		line-height: 1.05 !important;
	}
	main .h-italic-hero {
		font-size: clamp(2.5rem, 9.5vw, 4.5rem) !important;
		line-height: 1.05 !important;
	}
	main .h-display {
		font-size: clamp(1.75rem, 7vw, 3rem) !important;
	}
	main .h-italic-display {
		font-size: clamp(2rem, 7.4vw, 3.5rem) !important;
	}
	main h1 .h-display,
	main h1 .h-italic-hero,
	main h1 .h-italic-display {
		font-size: inherit !important;
	}
	/* Hero photo aspect ratio plus haute pour mobile (moins large) */
	main section[style*="padding-top:200px"] figure.griffon-photo {
		display: none;  /* hide hero photo on small screens to gain breathing room */
	}
	/* Padding horizontal */
	.container { padding-left: 24px; padding-right: 24px; }

	/* Hide folio sticky markers on mobile (they conflict avec le contenu) */
	main section [style*="position:absolute"][style*="top:96px"] {
		position: static !important;
		margin-bottom: 32px !important;
	}
	main section [style*="position:absolute"][style*="top:120px"] {
		position: static !important;
		margin-bottom: 32px !important;
	}

	/* Maison stack sticky → static */
	.griffon-maison__copy { position: static !important; }
	.griffon-manifeste__aside { position: static !important; }

	/* Footer cols collapse */
	.griffon-footer__cols { gap: 32px !important; }
}

@media (max-width: 480px) {
	main section[style*="padding:200px 0"],
	main section[style*="padding:240px 0"],
	main section[style*="padding:160px 0"] {
		padding: 64px 0 !important;
	}
	main section[style*="padding:200px 0 96px"],
	main section[style*="padding:200px 0 120px"],
	main section[style*="padding-top:200px"] {
		padding: 80px 0 48px !important;
	}
	.container { padding-left: 20px; padding-right: 20px; }
}
