/*
Theme Name:        Clarisse Lagarde Child
Theme URI:         https://clarisselagarde.fr
Description:       Theme enfant Astra — Voyante indépendante solo. Design Editorial Premium (Playfair Display + Inter, violet prune + or + ivoire). v2 refactor UI/UX Pro Max.
Author:            Wyp Agency
Author URI:        https://wyp.agency
Template:          astra
Version:           2.0.0
Text Domain:       clarisse-lagarde-child
License:           GPL-2.0-or-later
*/

/* ==========================================================================
   1. DESIGN TOKENS — v2 (scale a11y-compliant)
   ========================================================================== */

:root {
	/* Couleurs — Editorial Premium (violet mystique + or Tiffany + noir velours) */
	--cl-plum:           #5B2A86;
	--cl-plum-deep:      #3D1A5E;
	--cl-plum-light:     #7A4BA3;
	--cl-plum-blur:      #2A1545;
	--cl-rose-gold:      #E8B4B8;
	--cl-gold:           #C9A961;
	--cl-gold-deep:      #A88843;
	--cl-gold-bright:    #E4C988;
	--cl-ivory:          #FAF6F0;
	--cl-ivory-warm:     #F3EBDD;
	--cl-paper:          #F7F0E4;
	--cl-velvet:         #1A0F1F;
	--cl-text:           #1A0F1F;
	--cl-text-soft:      #3A2D40;
	--cl-muted:          #6B5E75;
	--cl-white:          #FFFFFF;
	--cl-border:         rgba(91, 42, 134, 0.12);
	--cl-border-gold:    rgba(201, 169, 97, 0.35);

	/* Typographies — Playfair Display (editorial luxe) + Inter */
	--cl-font-display:   'Playfair Display', 'Times New Roman', serif;
	--cl-font-sans:      'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

	/* Type scale a11y-compliant (16px base minimum, WCAG + iOS) */
	--cl-fs-xs:          0.8125rem;    /* 13px — meta, stat-label */
	--cl-fs-sm:          0.9375rem;    /* 15px — small text */
	--cl-fs-body:        1.0625rem;    /* 17px — body default */
	--cl-fs-lg:          1.1875rem;    /* 19px — lead */
	--cl-fs-xl:          1.375rem;     /* 22px */
	--cl-fs-2xl:         1.75rem;      /* 28px — h3 */
	--cl-fs-3xl:         clamp(1.875rem, 2vw + 1rem, 2.625rem);    /* 42px — h2 */
	--cl-fs-display:     clamp(2.5rem, 4vw + 1rem, 4.25rem);        /* 68px — h1 hero */

	/* Spacing — 8pt grid */
	--cl-gap-xs:         0.5rem;
	--cl-gap-sm:         1rem;
	--cl-gap-md:         1.5rem;
	--cl-gap-lg:         2.5rem;
	--cl-gap-xl:         4rem;
	--cl-gap-2xl:        5.5rem;

	/* Layout */
	--cl-container:      1200px;
	--cl-radius-sm:      6px;
	--cl-radius-md:      14px;
	--cl-radius-lg:      22px;
	--cl-radius-round:   999px;

	/* Ombres */
	--cl-shadow-xs:      0 1px 2px rgba(26, 15, 31, 0.04);
	--cl-shadow-sm:      0 2px 10px rgba(26, 15, 31, 0.06);
	--cl-shadow-md:      0 8px 28px rgba(26, 15, 31, 0.08);
	--cl-shadow-lg:      0 20px 48px rgba(61, 26, 94, 0.18);
	--cl-shadow-gold:    0 8px 24px rgba(201, 169, 97, 0.35);
	--cl-shadow-inner:   inset 0 1px 0 rgba(255, 255, 255, 0.1);

	/* Easings — premium */
	--cl-ease-out:       cubic-bezier(0.22, 1, 0.36, 1);
	--cl-ease-in-out:    cubic-bezier(0.65, 0, 0.35, 1);
	--cl-ease-spring:    cubic-bezier(0.34, 1.56, 0.64, 1);

	--cl-dur-fast:       160ms;
	--cl-dur-mid:        250ms;
	--cl-dur-slow:       420ms;

	--cl-header-height:  76px;
	--cl-topbar-height:  40px;
	--cl-sticky-height:  76px;
}

/* ==========================================================================
   2. RESET & BASE
   ========================================================================== */

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

html {
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}

body {
	font-family: var(--cl-font-sans);
	font-size: var(--cl-fs-body);
	line-height: 1.7;
	color: var(--cl-text);
	background: var(--cl-ivory);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-feature-settings: "kern" 1, "liga" 1, "calt" 1;
}

/* Astra overrides sur la home */
body.home .site-header,
body.home .ast-site-header-cart,
body.home .main-header-bar-wrap,
body.home .site-footer,
body.home #colophon { display: none !important; }

body.home .site-content > .ast-container,
body.home .ast-container {
	display: block !important;
	padding: 0 !important;
	max-width: 100% !important;
	width: 100% !important;
}
body.home .site-content { padding: 0 !important; max-width: 100% !important; }
body.home #primary, body.home .site-main, body.home main#primary {
	width: 100% !important; max-width: 100% !important;
	margin: 0 !important; padding: 0 !important;
	float: none !important; display: block !important;
}
body.home article.page, body.home .entry-content, body.home article {
	width: 100% !important; max-width: 100% !important;
	margin: 0 !important; padding: 0 !important;
}
body.home .entry-header, body.home .entry-content > h1, body.home .entry-title { display: none !important; }

/* Typos */
h1, h2, h3, h4 {
	font-family: var(--cl-font-display);
	color: var(--cl-plum-deep);
	font-weight: 500;
	line-height: 1.15;
	letter-spacing: -0.02em;
	margin: 0;
}
h1 { font-size: var(--cl-fs-display); font-weight: 400; }
h2 { font-size: var(--cl-fs-3xl); }
h3 { font-size: var(--cl-fs-2xl); font-weight: 500; }
h4 { font-size: var(--cl-fs-xl); }

p { margin: 0 0 var(--cl-gap-sm); }

a {
	color: var(--cl-plum);
	text-decoration: none;
	transition: color var(--cl-dur-fast) var(--cl-ease-out);
}
a:hover { color: var(--cl-plum-deep); }

/* Focus visible custom — ring or with offset */
a:focus-visible,
button:focus-visible,
[tabindex="0"]:focus-visible,
.cl-btn:focus-visible,
.cl-faq-summary:focus-visible,
details:focus-visible {
	outline: 3px solid var(--cl-gold);
	outline-offset: 3px;
	border-radius: 4px;
}

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

/* Selection */
::selection {
	background: var(--cl-gold);
	color: var(--cl-velvet);
}

/* ==========================================================================
   3. LAYOUT UTILS
   ========================================================================== */

.cl-container {
	max-width: var(--cl-container);
	margin: 0 auto;
	padding: 0 1.5rem;
}
.cl-section { padding: var(--cl-gap-2xl) 0; }

.cl-eyebrow {
	display: inline-block;
	font-family: var(--cl-font-sans);
	font-size: var(--cl-fs-xs);
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--cl-gold-deep);
	margin-bottom: 0.875rem;
}

.cl-section-title {
	margin-bottom: var(--cl-gap-md);
	font-weight: 500;
}

.cl-section-lead {
	font-size: var(--cl-fs-lg);
	color: var(--cl-text-soft);
	max-width: 680px;
	margin-bottom: var(--cl-gap-lg);
	line-height: 1.55;
}

/* Ornement entre sections — constellation dorée */
.cl-ornament {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	margin: 0 auto var(--cl-gap-lg);
	max-width: 240px;
	color: var(--cl-gold);
}
.cl-ornament::before,
.cl-ornament::after {
	content: '';
	flex: 1;
	height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--cl-gold) 40%, var(--cl-gold) 60%, transparent 100%);
	opacity: 0.6;
}
.cl-ornament svg { width: 18px; height: 18px; }

.cl-text-center { text-align: center; }
.cl-mx-auto { margin-left: auto; margin-right: auto; }

/* ==========================================================================
   4. BOUTONS — touch-target ≥ 44px, press feedback
   ========================================================================== */

.cl-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.875rem 1.75rem;
	font-family: var(--cl-font-sans);
	font-size: var(--cl-fs-body);
	font-weight: 600;
	line-height: 1;
	text-decoration: none;
	border: 2px solid transparent;
	border-radius: var(--cl-radius-round);
	cursor: pointer;
	transition: transform var(--cl-dur-fast) var(--cl-ease-spring),
	            box-shadow var(--cl-dur-mid) var(--cl-ease-out),
	            background-color var(--cl-dur-fast) var(--cl-ease-out),
	            color var(--cl-dur-fast) var(--cl-ease-out);
	white-space: nowrap;
	min-height: 48px;
	letter-spacing: 0.01em;
}
.cl-btn:active { transform: scale(0.97); }

.cl-btn-gold {
	background: var(--cl-gold);
	color: var(--cl-velvet);
	box-shadow: var(--cl-shadow-gold), var(--cl-shadow-inner);
}
.cl-btn-gold:hover {
	background: var(--cl-gold-bright);
	color: var(--cl-velvet);
	transform: translateY(-2px);
	box-shadow: 0 16px 40px rgba(201, 169, 97, 0.45), var(--cl-shadow-inner);
}

.cl-btn-ghost-gold {
	background: transparent;
	color: var(--cl-gold);
	border-color: var(--cl-gold);
}
.cl-btn-ghost-gold:hover {
	background: var(--cl-gold);
	color: var(--cl-velvet);
	transform: translateY(-2px);
}

.cl-btn-ghost-plum {
	background: transparent;
	color: var(--cl-plum);
	border-color: var(--cl-plum);
}
.cl-btn-ghost-plum:hover {
	background: var(--cl-plum);
	color: var(--cl-white);
	transform: translateY(-2px);
}

.cl-btn-lg {
	padding: 1.125rem 2.5rem;
	font-size: 1.0625rem;
	min-height: 56px;
}
.cl-btn svg { width: 20px; height: 20px; }

/* ==========================================================================
   5. CTA GROUP (règle CRO)
   ========================================================================== */

.cl-cta-group {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	gap: 0.625rem;
	text-align: center;
}
.cl-cta-group--left { align-items: flex-start; text-align: left; }

.cl-cta-offer {
	font-family: var(--cl-font-display);
	font-size: 1.375rem;
	font-weight: 500;
	font-style: italic;
	color: var(--cl-gold);
	line-height: 1.2;
	margin-top: 0.25rem;
}
.cl-cta-offer strong {
	color: var(--cl-gold-bright);
	font-weight: 600;
	font-style: normal;
}
.cl-cta-price {
	font-size: var(--cl-fs-xs);
	color: rgba(250, 246, 240, 0.7);
	font-weight: 400;
	letter-spacing: 0.02em;
}

.cl-light .cl-cta-offer { color: var(--cl-plum-deep); }
.cl-light .cl-cta-offer strong { color: var(--cl-gold-deep); }
.cl-light .cl-cta-price { color: var(--cl-muted); }

/* ==========================================================================
   6. TOPBAR
   ========================================================================== */

.cl-topbar {
	background: var(--cl-velvet);
	color: var(--cl-ivory);
	font-size: var(--cl-fs-sm);
	padding: 0.625rem 1.5rem;
	text-align: center;
	height: var(--cl-topbar-height);
	display: flex;
	align-items: center;
	justify-content: center;
	letter-spacing: 0.01em;
}
.cl-topbar strong { color: var(--cl-gold); font-weight: 600; }

/* ==========================================================================
   7. HEADER
   ========================================================================== */

.cl-header {
	position: absolute;
	top: var(--cl-topbar-height);
	left: 0;
	right: 0;
	z-index: 20;
	padding: 1.125rem 0;
	background: transparent;
	height: var(--cl-header-height);
}
.cl-header-inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: var(--cl-gap-md);
}
.cl-logo {
	font-family: var(--cl-font-display);
	font-size: 1.5rem;
	font-weight: 500;
	color: var(--cl-white);
	letter-spacing: 0;
	line-height: 1;
	display: inline-flex;
	align-items: center;
	gap: 0.3125rem;
	transition: opacity var(--cl-dur-fast) var(--cl-ease-out);
}
.cl-logo:hover { opacity: 0.85; color: var(--cl-white); }
.cl-logo-last {
	color: var(--cl-gold);
	font-style: italic;
}

.cl-header-nav {
	display: none;
	justify-content: center;
}
.cl-header-nav-list {
	display: flex;
	gap: 2rem;
	list-style: none;
	padding: 0;
	margin: 0;
}
.cl-header-nav-list a {
	color: rgba(255, 255, 255, 0.82);
	font-size: var(--cl-fs-sm);
	font-weight: 500;
	position: relative;
	padding-bottom: 4px;
	letter-spacing: 0.02em;
}
.cl-header-nav-list a::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 1px;
	background: var(--cl-gold);
	transform: scaleX(0);
	transform-origin: right;
	transition: transform var(--cl-dur-mid) var(--cl-ease-out);
}
.cl-header-nav-list a:hover { color: var(--cl-gold); }
.cl-header-nav-list a:hover::after { transform: scaleX(1); transform-origin: left; }

.cl-header-cta {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	justify-self: end;
}
.cl-header-cta .cl-btn {
	padding: 0.75rem 1.375rem;
	font-size: var(--cl-fs-sm);
	min-height: 44px;
}
.cl-header-cta .cl-btn svg {
	width: 16px;
	height: 16px;
}

@media (min-width: 1024px) {
	.cl-header-nav { display: flex; }
}

/* ==========================================================================
   8. HERO
   ========================================================================== */

.cl-hero {
	position: relative;
	background:
		radial-gradient(ellipse at top right, rgba(201, 169, 97, 0.15) 0%, transparent 50%),
		radial-gradient(ellipse at bottom left, rgba(232, 180, 184, 0.1) 0%, transparent 50%),
		linear-gradient(135deg, var(--cl-plum-blur) 0%, var(--cl-plum-deep) 45%, var(--cl-plum) 100%);
	color: var(--cl-ivory);
	overflow: hidden;
	padding: calc(var(--cl-topbar-height) + var(--cl-header-height) + 2.5rem) 0 3.5rem;
}

/* Texture grain SVG subtile (élément anti-IA) */
.cl-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
	opacity: 0.35;
	pointer-events: none;
	mix-blend-mode: overlay;
}

/* Constellations décoratives en background */
.cl-hero-decor {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 1;
	opacity: 0.25;
}
.cl-hero-decor svg {
	position: absolute;
	color: var(--cl-gold);
}
.cl-hero-decor-top { top: 15%; left: 8%; width: 60px; }
.cl-hero-decor-bottom { bottom: 10%; right: 12%; width: 80px; }

.cl-hero-inner {
	position: relative;
	z-index: 2;
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: var(--cl-gap-lg);
	align-items: center;
}

.cl-hero-content .cl-eyebrow { color: var(--cl-gold); }

.cl-hero h1 {
	color: var(--cl-white);
	font-weight: 400;
	line-height: 1.02;
	margin-bottom: 1.125rem;
	letter-spacing: -0.03em;
}
.cl-hero h1 em {
	font-weight: 500;
	color: var(--cl-gold);
	font-style: italic;
	display: block;
}

.cl-hero-lead {
	font-size: var(--cl-fs-lg);
	color: rgba(250, 246, 240, 0.92);
	max-width: 520px;
	line-height: 1.55;
	margin-bottom: 1.75rem;
}

.cl-hero-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 2rem;
}
.cl-hero-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 1rem;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(232, 180, 184, 0.22);
	border-radius: var(--cl-radius-round);
	font-size: var(--cl-fs-xs);
	color: var(--cl-ivory);
	backdrop-filter: blur(8px);
	letter-spacing: 0.01em;
}
.cl-hero-badge svg {
	width: 14px;
	height: 14px;
	color: var(--cl-gold);
	flex-shrink: 0;
}

/* Portrait */
.cl-hero-portrait {
	position: relative;
	justify-self: center;
}
.cl-hero-portrait-frame {
	position: relative;
	width: 400px;
	max-width: 100%;
	aspect-ratio: 4 / 5;
	border-radius: var(--cl-radius-lg);
	overflow: hidden;
	box-shadow: 0 30px 80px rgba(0, 0, 0, 0.45), 0 0 0 1px rgba(232, 180, 184, 0.18);
}
.cl-hero-portrait-frame img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform var(--cl-dur-slow) var(--cl-ease-out);
}
.cl-hero-portrait:hover .cl-hero-portrait-frame img { transform: scale(1.03); }
.cl-hero-portrait::before {
	content: '';
	position: absolute;
	inset: -18px;
	border: 1px solid var(--cl-gold);
	border-radius: calc(var(--cl-radius-lg) + 18px);
	opacity: 0.45;
	pointer-events: none;
}

/* Stats 4-ways — a11y-compliant */
.cl-hero-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1px;
	background: rgba(232, 180, 184, 0.2);
	border: 1px solid rgba(232, 180, 184, 0.25);
	border-radius: var(--cl-radius-md);
	overflow: hidden;
	backdrop-filter: blur(16px);
	margin-top: 1.5rem;
}
.cl-hero-stat {
	padding: 1rem 0.625rem;
	background: rgba(26, 15, 31, 0.55);
	text-align: center;
	transition: background var(--cl-dur-fast) var(--cl-ease-out);
}
.cl-hero-stat:hover { background: rgba(26, 15, 31, 0.75); }
.cl-hero-stat-num {
	font-family: var(--cl-font-display);
	font-size: 1.5rem;
	font-weight: 500;
	color: var(--cl-gold);
	line-height: 1;
	display: block;
	margin-bottom: 0.3125rem;
	letter-spacing: -0.01em;
}
.cl-hero-stat-num--stars {
	font-size: 1.0625rem;
	letter-spacing: 0.1em;
}
.cl-hero-stat-label {
	font-size: 0.75rem;
	color: rgba(250, 246, 240, 0.9);
	line-height: 1.25;
	display: block;
	letter-spacing: 0.02em;
}

/* ==========================================================================
   9. TRUSTBAR — SVG icons + slider infini mobile
   ========================================================================== */

.cl-trustbar {
	background: var(--cl-velvet);
	color: var(--cl-ivory);
	padding: 1.25rem 0;
	border-top: 1px solid rgba(232, 180, 184, 0.15);
	overflow: hidden;
	position: relative;
}
.cl-trustbar-track {
	display: flex;
	flex-wrap: nowrap;
	gap: 2.5rem;
	justify-content: center;
	list-style: none;
	padding: 0;
	margin: 0;
	align-items: center;
}
.cl-trustbar-item {
	display: inline-flex;
	align-items: center;
	gap: 0.625rem;
	font-size: var(--cl-fs-sm);
	color: rgba(250, 246, 240, 0.92);
	white-space: nowrap;
	letter-spacing: 0.01em;
}
.cl-trustbar-item svg {
	width: 20px;
	height: 20px;
	flex-shrink: 0;
	color: var(--cl-gold);
}

@media (max-width: 900px) {
	.cl-trustbar { padding: 1rem 0; }
	.cl-trustbar-track {
		flex-wrap: nowrap;
		justify-content: flex-start;
		overflow: hidden;
		padding: 0;
		gap: 2rem;
		animation: cl-trust-scroll 36s linear infinite;
		width: max-content;
	}
	.cl-trustbar:hover .cl-trustbar-track { animation-play-state: paused; }
}

@keyframes cl-trust-scroll {
	0%   { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}

/* ==========================================================================
   10. SECTION WHY
   ========================================================================== */

.cl-why { background: var(--cl-ivory); }
.cl-why-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--cl-gap-md);
	margin-top: var(--cl-gap-lg);
}
.cl-why-card {
	background: var(--cl-white);
	padding: 2.5rem 2rem;
	border-radius: var(--cl-radius-md);
	border: 1px solid var(--cl-border);
	box-shadow: var(--cl-shadow-sm);
	transition: transform var(--cl-dur-mid) var(--cl-ease-out),
	            box-shadow var(--cl-dur-mid) var(--cl-ease-out),
	            border-color var(--cl-dur-mid) var(--cl-ease-out);
	position: relative;
}
.cl-why-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--cl-shadow-md);
	border-color: var(--cl-border-gold);
}
.cl-why-icon {
	width: 56px;
	height: 56px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--cl-plum) 0%, var(--cl-plum-deep) 100%);
	color: var(--cl-gold);
	border-radius: 14px;
	margin-bottom: 1.25rem;
	box-shadow: 0 6px 18px rgba(61, 26, 94, 0.25);
}
.cl-why-icon svg {
	width: 28px;
	height: 28px;
}
.cl-why-card h3 {
	font-size: 1.375rem;
	margin-bottom: 0.75rem;
	color: var(--cl-plum-deep);
}
.cl-why-card p {
	color: var(--cl-text-soft);
	font-size: var(--cl-fs-body);
	line-height: 1.7;
	margin: 0;
}

/* ==========================================================================
   11. SPÉCIALITÉS
   ========================================================================== */

.cl-specialties { background: var(--cl-ivory-warm); }
.cl-specialties-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--cl-gap-md);
	margin-top: var(--cl-gap-lg);
}
.cl-specialty {
	background: var(--cl-white);
	padding: 2.5rem;
	border-radius: var(--cl-radius-md);
	border-left: 3px solid var(--cl-gold);
	box-shadow: var(--cl-shadow-sm);
	display: grid;
	grid-template-columns: 64px 1fr;
	gap: 1.5rem;
	align-items: start;
	transition: transform var(--cl-dur-mid) var(--cl-ease-out),
	            box-shadow var(--cl-dur-mid) var(--cl-ease-out);
}
.cl-specialty:hover {
	transform: translateY(-3px);
	box-shadow: var(--cl-shadow-md);
}
.cl-specialty-symbol {
	width: 64px;
	height: 64px;
	background: linear-gradient(135deg, var(--cl-plum) 0%, var(--cl-plum-deep) 100%);
	color: var(--cl-gold);
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	box-shadow: 0 6px 18px rgba(61, 26, 94, 0.3);
}
.cl-specialty-symbol svg { width: 30px; height: 30px; }
.cl-specialty h3 {
	font-size: 1.5rem;
	margin-bottom: 0.625rem;
	color: var(--cl-plum-deep);
}
.cl-specialty p {
	color: var(--cl-text-soft);
	margin: 0;
	font-size: var(--cl-fs-body);
	line-height: 1.65;
}

/* ==========================================================================
   12. STORY — avec lettrine éditoriale
   ========================================================================== */

.cl-story { background: var(--cl-ivory); }
.cl-story-grid {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: var(--cl-gap-xl);
	align-items: center;
}
.cl-story-visual {
	position: relative;
	aspect-ratio: 3 / 4;
	border-radius: var(--cl-radius-lg);
	overflow: hidden;
	box-shadow: var(--cl-shadow-lg);
	max-width: 460px;
	margin: 0 auto;
}
.cl-story-visual img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform var(--cl-dur-slow) var(--cl-ease-out);
}
.cl-story-visual:hover img { transform: scale(1.04); }
.cl-story-visual::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 50%, rgba(26, 15, 31, 0.7) 100%);
	pointer-events: none;
}
.cl-story-quote {
	position: absolute;
	bottom: 1.75rem;
	left: 1.75rem;
	right: 1.75rem;
	color: var(--cl-ivory);
	font-family: var(--cl-font-display);
	font-style: italic;
	font-size: 1.0625rem;
	line-height: 1.4;
	z-index: 2;
	margin: 0;
	font-weight: 400;
}
.cl-story-quote::before {
	content: '';
	display: block;
	width: 32px;
	height: 2px;
	background: var(--cl-gold);
	margin-bottom: 0.875rem;
}

.cl-story-content h2 { margin-bottom: 1.25rem; }
.cl-story-content p {
	color: var(--cl-text-soft);
	font-size: var(--cl-fs-body);
	line-height: 1.75;
	margin-bottom: 1rem;
}
.cl-story-content p:first-of-type::first-letter {
	font-family: var(--cl-font-display);
	font-size: 3.5rem;
	font-weight: 500;
	float: left;
	line-height: 0.9;
	margin: 0.35rem 0.75rem 0 0;
	color: var(--cl-gold-deep);
	font-style: italic;
}
.cl-story-signature {
	margin-top: 1.75rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--cl-border);
}
.cl-story-signature-name {
	font-family: var(--cl-font-display);
	font-style: italic;
	font-size: 1.375rem;
	color: var(--cl-plum-deep);
	font-weight: 500;
}
.cl-story-signature-role {
	font-size: var(--cl-fs-xs);
	color: var(--cl-muted);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	margin-top: 0.25rem;
	display: block;
}

/* ==========================================================================
   13. TÉMOIGNAGES — avatars SVG élégants
   ========================================================================== */

.cl-testimonials { background: var(--cl-ivory-warm); }
.cl-testimonials-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--cl-gap-md);
	margin-top: var(--cl-gap-lg);
}
.cl-testimonial {
	background: var(--cl-white);
	padding: 2.5rem 2.25rem;
	border-radius: var(--cl-radius-md);
	box-shadow: var(--cl-shadow-sm);
	display: flex;
	flex-direction: column;
	gap: 1rem;
	transition: transform var(--cl-dur-mid) var(--cl-ease-out),
	            box-shadow var(--cl-dur-mid) var(--cl-ease-out);
	position: relative;
}
.cl-testimonial:hover {
	transform: translateY(-3px);
	box-shadow: var(--cl-shadow-md);
}
.cl-testimonial-stars {
	display: inline-flex;
	gap: 2px;
	color: var(--cl-gold);
}
.cl-testimonial-stars svg { width: 18px; height: 18px; }
.cl-testimonial-text {
	color: var(--cl-text);
	font-family: var(--cl-font-display);
	font-size: 1.0625rem;
	font-style: italic;
	line-height: 1.55;
	flex: 1;
	margin: 0;
	font-weight: 400;
}
.cl-testimonial-author {
	display: flex;
	align-items: center;
	gap: 0.875rem;
	margin-top: auto;
	padding-top: 1rem;
	border-top: 1px solid var(--cl-border);
}
.cl-testimonial-avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--cl-ivory-warm) 0%, var(--cl-paper) 100%);
	border: 1px solid var(--cl-border-gold);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--cl-plum);
	flex-shrink: 0;
}
.cl-testimonial-avatar svg { width: 24px; height: 24px; }
.cl-testimonial-name {
	font-weight: 600;
	color: var(--cl-text);
	font-size: var(--cl-fs-sm);
	margin: 0;
}
.cl-testimonial-meta {
	font-size: var(--cl-fs-xs);
	color: var(--cl-muted);
	margin: 0;
}

/* ==========================================================================
   14. ÉTHIQUE
   ========================================================================== */

.cl-ethics {
	background: var(--cl-velvet);
	color: var(--cl-ivory);
}
.cl-ethics h2 { color: var(--cl-ivory); text-align: center; }
.cl-ethics .cl-section-lead {
	color: rgba(250, 246, 240, 0.85);
	text-align: center;
	margin: 0 auto var(--cl-gap-lg);
}
.cl-ethics-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
	margin-top: var(--cl-gap-lg);
}
.cl-ethics-item {
	display: flex;
	gap: 1rem;
	align-items: flex-start;
	padding: 1.5rem;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(232, 180, 184, 0.12);
	border-radius: var(--cl-radius-md);
	transition: background var(--cl-dur-mid) var(--cl-ease-out);
}
.cl-ethics-item:hover { background: rgba(255, 255, 255, 0.06); }
.cl-ethics-icon {
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	background: var(--cl-gold);
	color: var(--cl-velvet);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}
.cl-ethics-icon svg { width: 18px; height: 18px; }
.cl-ethics-item p {
	margin: 0;
	color: rgba(250, 246, 240, 0.92);
	font-size: var(--cl-fs-body);
	line-height: 1.6;
}
.cl-ethics-item strong {
	color: var(--cl-gold);
	font-weight: 600;
}

/* ==========================================================================
   15. FAQ
   ========================================================================== */

.cl-faq { background: var(--cl-ivory); }
.cl-faq-list {
	max-width: 820px;
	margin: var(--cl-gap-lg) auto 0;
}
.cl-faq-item {
	background: var(--cl-white);
	border: 1px solid var(--cl-border);
	border-radius: var(--cl-radius-md);
	margin-bottom: 0.75rem;
	overflow: hidden;
	transition: border-color var(--cl-dur-fast) var(--cl-ease-out);
}
.cl-faq-item[open] { border-color: var(--cl-border-gold); }
.cl-faq-summary {
	padding: 1.375rem 1.75rem;
	font-family: var(--cl-font-sans);
	font-weight: 600;
	font-size: var(--cl-fs-body);
	color: var(--cl-plum-deep);
	cursor: pointer;
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	transition: background var(--cl-dur-fast) var(--cl-ease-out);
	min-height: 44px;
}
.cl-faq-summary::-webkit-details-marker { display: none; }
.cl-faq-summary-icon {
	flex-shrink: 0;
	width: 24px;
	height: 24px;
	color: var(--cl-gold);
	transition: transform var(--cl-dur-mid) var(--cl-ease-out);
}
.cl-faq-item[open] .cl-faq-summary { background: var(--cl-ivory-warm); }
.cl-faq-item[open] .cl-faq-summary-icon { transform: rotate(45deg); }
.cl-faq-answer {
	padding: 0 1.75rem 1.5rem;
	color: var(--cl-text-soft);
	line-height: 1.7;
	font-size: var(--cl-fs-body);
}
.cl-faq-answer p { margin: 0.75rem 0 0; }
.cl-faq-answer p:first-child { margin-top: 0; }

/* ==========================================================================
   16. PRICING / CTA FINAL
   ========================================================================== */

.cl-pricing {
	background:
		radial-gradient(ellipse at top right, rgba(201, 169, 97, 0.18) 0%, transparent 50%),
		linear-gradient(135deg, var(--cl-plum-deep) 0%, var(--cl-plum) 100%);
	color: var(--cl-ivory);
	position: relative;
	overflow: hidden;
	padding: 4rem 0;
}
.cl-pricing::after {
	content: '';
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.06 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
	opacity: 0.4;
	pointer-events: none;
	mix-blend-mode: overlay;
}
.cl-pricing-inner {
	position: relative;
	z-index: 2;
	max-width: 680px;
	margin: 0 auto;
	text-align: center;
}
.cl-pricing h2 {
	color: var(--cl-white);
	margin-bottom: 0.875rem;
	font-size: clamp(1.75rem, 2vw + 1rem, 2.375rem);
}
.cl-pricing-subtitle {
	font-size: var(--cl-fs-body);
	color: rgba(250, 246, 240, 0.8);
	max-width: 520px;
	margin: 0 auto 1.75rem;
	line-height: 1.55;
}
.cl-pricing-phone {
	font-family: var(--cl-font-display);
	font-size: clamp(2rem, 3vw + 0.75rem, 2.75rem);
	color: var(--cl-gold);
	letter-spacing: 0.04em;
	display: block;
	text-decoration: none;
	margin: 0.625rem 0 0.5rem;
	font-weight: 500;
	transition: color var(--cl-dur-fast) var(--cl-ease-out);
}
.cl-pricing-phone:hover { color: var(--cl-gold-bright); }

/* ==========================================================================
   17. FOOTER — 3 colonnes éditoriales
   ========================================================================== */

.cl-footer {
	background: var(--cl-velvet);
	color: rgba(250, 246, 240, 0.78);
	padding: 4rem 0 1.75rem;
	font-size: var(--cl-fs-sm);
}
.cl-footer-grid {
	display: grid;
	grid-template-columns: 1.5fr 1fr 1fr;
	gap: var(--cl-gap-lg);
	margin-bottom: var(--cl-gap-lg);
}
.cl-footer h4 {
	font-family: var(--cl-font-display);
	color: var(--cl-gold);
	font-size: 1.25rem;
	margin-bottom: 1rem;
	font-weight: 500;
}
.cl-footer ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
.cl-footer li {
	margin-bottom: 0.625rem;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.cl-footer li svg {
	width: 14px;
	height: 14px;
	color: var(--cl-gold);
	flex-shrink: 0;
}
.cl-footer a {
	color: rgba(250, 246, 240, 0.78);
	transition: color var(--cl-dur-fast) var(--cl-ease-out);
}
.cl-footer a:hover { color: var(--cl-gold); }
.cl-footer-brand p {
	margin: 0.75rem 0 0;
	line-height: 1.65;
	max-width: 380px;
}
.cl-footer-bottom {
	padding-top: 1.5rem;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
	font-size: var(--cl-fs-xs);
	color: rgba(250, 246, 240, 0.5);
}
.cl-disclaimer {
	background: rgba(0, 0, 0, 0.3);
	padding: 1.125rem 1.375rem;
	margin-bottom: var(--cl-gap-lg);
	border-radius: var(--cl-radius-sm);
	border-left: 2px solid var(--cl-gold);
	font-size: var(--cl-fs-xs);
	color: rgba(250, 246, 240, 0.75);
	line-height: 1.65;
}

/* ==========================================================================
   18. STICKY CTA MOBILE
   ========================================================================== */

.cl-sticky-cta { display: none; }
@media (max-width: 900px) {
	.cl-sticky-cta {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 0.75rem;
		position: fixed;
		left: 0; right: 0; bottom: 0;
		z-index: 100;
		background: linear-gradient(135deg, var(--cl-plum-deep) 0%, var(--cl-plum) 100%);
		padding: 0.75rem 1rem calc(0.75rem + env(safe-area-inset-bottom));
		box-shadow: 0 -10px 28px rgba(0, 0, 0, 0.3);
		border-top: 1px solid rgba(201, 169, 97, 0.35);
		transform: translateY(110%);
		transition: transform var(--cl-dur-slow) var(--cl-ease-out);
	}
	.cl-sticky-cta.is-visible { transform: translateY(0); }
	.cl-sticky-offer {
		flex: 1; color: var(--cl-ivory); line-height: 1.2; min-width: 0;
	}
	.cl-sticky-offer-big {
		display: block;
		font-family: var(--cl-font-display);
		font-size: 1.0625rem;
		font-style: italic;
		color: var(--cl-gold);
		font-weight: 500;
	}
	.cl-sticky-offer-small {
		display: block;
		font-size: 0.75rem;
		color: rgba(250, 246, 240, 0.75);
		margin-top: 0.125rem;
	}
	.cl-sticky-btn {
		flex-shrink: 0;
		padding: 0.75rem 1.25rem;
		background: var(--cl-gold);
		color: var(--cl-velvet);
		font-weight: 700;
		font-size: var(--cl-fs-sm);
		border-radius: var(--cl-radius-round);
		display: inline-flex;
		align-items: center;
		gap: 0.375rem;
		text-decoration: none;
		white-space: nowrap;
		min-height: 46px;
		box-shadow: 0 4px 12px rgba(201, 169, 97, 0.35);
		transition: transform var(--cl-dur-fast) var(--cl-ease-spring);
	}
	.cl-sticky-btn svg { width: 18px; height: 18px; }
	.cl-sticky-btn:active { transform: scale(0.96); }
	.cl-sticky-btn:hover {
		background: var(--cl-gold-bright);
		color: var(--cl-velvet);
	}
	body.has-sticky-cta { padding-bottom: var(--cl-sticky-height); }
}

/* ==========================================================================
   19. RESPONSIVE
   ========================================================================== */

@media (max-width: 1100px) {
	.cl-hero {
		padding-top: calc(var(--cl-topbar-height) + var(--cl-header-height) + 1.75rem);
		padding-bottom: 2.5rem;
	}
	.cl-hero-inner {
		grid-template-columns: 1fr;
		gap: 2rem;
		text-align: center;
	}
	.cl-hero-content .cl-eyebrow,
	.cl-hero-lead { margin-left: auto; margin-right: auto; }
	.cl-hero-badges { justify-content: center; }
	.cl-cta-group { align-items: center; text-align: center; }
	.cl-hero-portrait { order: -1; }
	.cl-hero-portrait-frame { width: 260px; }
	.cl-hero-portrait::before { inset: -12px; }
	.cl-hero-stats {
		max-width: 440px;
		margin-left: auto;
		margin-right: auto;
	}
	.cl-story-grid { grid-template-columns: 1fr; gap: 2rem; }
	.cl-footer-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 780px) {
	:root {
		--cl-gap-2xl: 3.75rem;
		--cl-header-height: 64px;
	}
	.cl-container { padding: 0 1.25rem; }
	.cl-section { padding: 3.25rem 0; }
	.cl-hero-inner { gap: 1.5rem; }
	.cl-hero h1 { font-size: clamp(2rem, 8vw, 3rem); }
	.cl-hero-lead { font-size: var(--cl-fs-body); margin-bottom: 1.5rem; }
	.cl-hero-portrait-frame { width: 220px; }
	.cl-hero-stat-num { font-size: 1.25rem; }
	.cl-hero-stat-label { font-size: 0.6875rem; }

	.cl-why-grid,
	.cl-specialties-grid,
	.cl-testimonials-grid,
	.cl-ethics-grid { grid-template-columns: 1fr; }
	.cl-why-card { padding: 2rem 1.75rem; }
	.cl-specialty {
		grid-template-columns: 56px 1fr;
		padding: 1.75rem;
		gap: 1rem;
	}
	.cl-specialty-symbol { width: 56px; height: 56px; }
	.cl-specialty-symbol svg { width: 26px; height: 26px; }
	.cl-testimonial { padding: 2rem 1.75rem; }
	.cl-ethics-item { padding: 1.375rem; }
	.cl-faq-summary {
		padding: 1.125rem 1.375rem;
		font-size: var(--cl-fs-body);
	}
	.cl-faq-answer { padding: 0 1.375rem 1.375rem; }

	.cl-pricing { padding: 3rem 0; }
	.cl-footer-grid { grid-template-columns: 1fr; gap: 2rem; }
	.cl-footer-bottom { flex-direction: column; gap: 0.5rem; }

	.cl-topbar { font-size: 0.8125rem; padding: 0.5rem 1rem; }
	.cl-logo-full { display: none; }
	.cl-logo-short { display: inline; }
	.cl-header-cta .cl-btn {
		padding: 0.5625rem 1rem;
		font-size: 0.8125rem;
	}
}

@media (min-width: 781px) {
	.cl-logo-short { display: none; }
	.cl-logo-full { display: inline; }
}

@media (max-width: 480px) {
	.cl-hero-badges { gap: 0.375rem; }
	.cl-hero-badge {
		padding: 0.375rem 0.75rem;
		font-size: 0.75rem;
	}
	.cl-hero-stats { grid-template-columns: repeat(2, 1fr); }
	.cl-btn-lg { padding: 0.9375rem 1.875rem; font-size: var(--cl-fs-body); }
}
