/*!
Theme Name: irap
Theme URI: http://underscores.me/
Author: irap
Description: vERTIge
Version: 1.0.0
Text Domain: irap
*/

/* ============================================================
 * NORMALIZE (Underscores)
 * ============================================================ */
html {
	line-height: 1.15;
	-webkit-text-size-adjust: 100%;
}

body {
	margin: 0;
}

main {
	display: block;
}

h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

hr {
	box-sizing: content-box;
	height: 0;
	overflow: visible;
}

pre {
	font-family: monospace, monospace;
	font-size: 1em;
}

a {
	background-color: transparent;
}

abbr[title] {
	border-bottom: none;
	text-decoration: underline dotted;
}

b,
strong {
	font-weight: bolder;
}

code,
kbd,
samp {
	font-family: monospace, monospace;
	font-size: 1em;
}

small {
	font-size: 80%;
}

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

img {
	border-style: none;
}

button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	font-size: 100%;
	line-height: 1.15;
	margin: 0;
}

button,
input {
	overflow: visible;
}

button,
select {
	text-transform: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
	-webkit-appearance: button;
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
	outline: 1px dotted ButtonText;
}

fieldset {
	padding: 0.35em 0.75em 0.625em;
}

legend {
	box-sizing: border-box;
	color: inherit;
	display: table;
	max-width: 100%;
	padding: 0;
	white-space: normal;
}

progress {
	vertical-align: baseline;
}

textarea {
	overflow: auto;
}

[type="checkbox"],
[type="radio"] {
	box-sizing: border-box;
	padding: 0;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

[type="search"] {
	-webkit-appearance: textfield;
	outline-offset: -2px;
}

[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

details {
	display: block;
}

summary {
	display: list-item;
}

template {
	display: none;
}

[hidden] {
	display: none;
}

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

html {
	box-sizing: border-box;
}

/* Underscores base */
body,
button,
input,
select,
optgroup,
textarea {
	color: #404040;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	font-size: 1rem;
	line-height: 1.5;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	clear: both;
}

p {
	margin-bottom: 1.5em;
}

dfn,
cite,
em,
i {
	font-style: italic;
}

blockquote {
	margin: 0 1.5em;
}

address {
	margin: 0 0 1.5em;
}

pre {
	background: #eee;
	font-family: "Courier 10 Pitch", courier, monospace;
	line-height: 1.6;
	margin-bottom: 1.6em;
	max-width: 100%;
	overflow: auto;
	padding: 1.6em;
}

code,
kbd,
tt,
var {
	font-family: monaco, consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
}

abbr,
acronym {
	border-bottom: 1px dotted #666;
	cursor: help;
}

mark,
ins {
	background: #fff9c0;
	text-decoration: none;
}

big {
	font-size: 125%;
}

body {
	background: #fff;
}

hr {
	background-color: #ccc;
	border: 0;
	height: 1px;
	margin-bottom: 1.5em;
}

ul,
ol {
	margin: 0 0 1.5em 3em;
}

ul {
	list-style: disc;
}

ol {
	list-style: decimal;
}

li>ul,
li>ol {
	margin-bottom: 0;
	margin-left: 1.5em;
}

dt {
	font-weight: 700;
}

dd {
	margin: 0 1.5em 1.5em;
}

embed,
iframe,
object {
	max-width: 100%;
}

img {
	height: auto;
	max-width: 100%;
}

figure {
	margin: 1em 0;
}

table {
	margin: 0 0 1.5em;
	width: 100%;
}

/* Underscores nav */
.main-navigation {
	display: block;
	width: 100%;
}

.main-navigation ul {
	display: none;
	list-style: none;
	margin: 0;
	padding-left: 0;
}

.main-navigation ul ul {
	box-shadow: 0 3px 3px rgba(0, 0, 0, .2);
	float: left;
	position: absolute;
	top: 100%;
	left: -999em;
	z-index: 99999;
}

.main-navigation ul ul ul {
	left: -999em;
	top: 0;
}

.main-navigation ul ul li:hover>ul,
.main-navigation ul ul li.focus>ul {
	display: block;
	left: auto;
}

.main-navigation ul ul a {
	width: 200px;
}

.main-navigation ul li:hover>ul,
.main-navigation ul li.focus>ul {
	left: auto;
}

.main-navigation li {
	position: relative;
}

.main-navigation a {
	display: block;
	text-decoration: none;
}

.menu-toggle,
.main-navigation.toggled ul {
	display: block;
}

@media screen and (min-width: 37.5em) {
	.menu-toggle {
		display: none;
	}

	.main-navigation ul {
		display: flex;
	}
}

.sticky {
	display: block;
}

.post,
.page {
	margin: 0;
}

.updated:not(.published) {
	display: none;
}

.page-content,
.entry-content,
.entry-summary {
	margin: 1.5em 0 0;
}

.page-links {
	clear: both;
	margin: 0 0 1.5em;
}

.comment-content a {
	word-wrap: break-word;
}

.bypostauthor {
	display: block;
}

.widget {
	margin: 0 0 1.5em;
}

.widget select {
	max-width: 100%;
}

.custom-logo-link {
	display: inline-block;
}

.wp-caption {
	margin-bottom: 1.5em;
	max-width: 100%;
}

.wp-caption img[class*="wp-image-"] {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.wp-caption .wp-caption-text {
	margin: 0.8075em 0;
}

.wp-caption-text {
	text-align: center;
}

.gallery {
	margin-bottom: 1.5em;
	display: grid;
	grid-gap: 1.5em;
}

.gallery-item {
	display: inline-block;
	text-align: center;
	width: 100%;
}

.gallery-columns-2 {
	grid-template-columns: repeat(2, 1fr);
}

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

.gallery-columns-4 {
	grid-template-columns: repeat(4, 1fr);
}

.gallery-columns-5 {
	grid-template-columns: repeat(5, 1fr);
}

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

.gallery-columns-7 {
	grid-template-columns: repeat(7, 1fr);
}

.gallery-columns-8 {
	grid-template-columns: repeat(8, 1fr);
}

.gallery-columns-9 {
	grid-template-columns: repeat(9, 1fr);
}

.gallery-caption {
	display: block;
}

.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
	display: none;
}

.infinity-end.neverending .site-footer {
	display: block;
}

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, .6);
	clip: auto !important;
	clip-path: none;
	color: #21759b;
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

#primary[tabindex="-1"]:focus {
	outline: 0;
}

.alignleft {
	float: left;
	margin-right: 24px;
	margin-bottom: 24px;
}

.alignright {
	float: right;
	margin-left: 24px;
	margin-bottom: 24px;
}

.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 24px;
}


/* ============================================================
 * GOOGLE FONTS
 * ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500&display=swap');


/* ============================================================
 * RESET vERTIge
 * ============================================================ */
*,
*::before,
*::after {
	box-sizing: border-box;
}

body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol,
li,
figure,
blockquote {
	margin: 0;
	padding: 0;
}

ul,
ol {
	list-style: none;
}

img,
video {
	display: block;
	max-width: 100%;
	height: auto;
}

button {
	cursor: pointer;
	border: none;
	background: none;
	font: inherit;
	padding: 0;
}

a {
	color: inherit;
	text-decoration: none;
}


a:hover,
a:focus,
a:active {
	color: inherit;
	outline: none;
}

input,
textarea,
select {
	font: inherit;
}


/* ============================================================
 * BASE
 * ============================================================ */
html {
	scroll-behavior: smooth;
}

body {
	font-family: 'DM Sans', sans-serif;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.65;
	color: #382E2B;
	background: #FAFAF9;
	-webkit-font-smoothing: antialiased;
	padding-top: 72px;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: 'DM Sans', sans-serif;
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: -0.02em;
	color: #382E2B;
	margin: 0;
}

h3 {
	font-weight: 500;
	font-size: 28px;
	line-height: 130%;
	margin-bottom: 50px;
}

p {
	line-height: 1.6;
	color: #382E2B;
	font-size: 18px;
	margin-bottom: 15px;
}

a {
	transition: opacity 0.22s ease;
}

a:hover {
	opacity: 0.6;
}

/* Wysiwyg */
.wysiwyg>*+* {
	margin-top: 16px;
}

.wysiwyg h2 {
	font-size: 36px;
	margin-top: 40px;
}

.wysiwyg h3 {
	font-size: 20px;
	margin-top: 24px;
}

.wysiwyg ul {
	list-style: disc;
	padding-left: 24px;
}

.wysiwyg ol {
	list-style: decimal;
	padding-left: 24px;
}

.wysiwyg li {
	margin-bottom: 8px;
	line-height: 1.65;
}

.wysiwyg strong {
	font-weight: 500;
}

.wysiwyg a {
	border-bottom: 1px solid #E8E5E3;
}

.wysiwyg a:hover {
	border-color: #382E2B;
	opacity: 1;
}

.wysiwyg img {
	width: 100%;
	margin-block: 24px;
}

.section__texte img {
	display: inline;
	width: auto;
	max-width: 60px;
	margin: 10px 0;
}


/* ============================================================
 * LAYOUT
 * ============================================================ */
.container {
	width: 100%;
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}

.container--normal {
	max-width: 860px;
}

.container--narrow {
	max-width: 640px;
}

.container--full {
	max-width: 100%;
	padding-left: 0;
	padding-right: 0;
}

.container--flex {
	display: flex;
	align-items: center;
	gap: 120px;
}

/* Bouton */
.button, .submit-wrap input {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: 'DM Sans', sans-serif;
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 0.01em;
	line-height: 1;
	padding: 12px 30px;
	border: 1px solid #382E2B;
		background: #382E2B;
			color: #FAFAF9;
	border-radius: 100px;
	white-space: nowrap;
	transition: background 0.22s ease, color 0.22s ease, border-color 0.22s ease, opacity 0.22s ease;
	cursor: pointer;

}

.button:hover,
.button:focus {
		color: #382E2B;
			background: transparent;
	opacity: 1;
}

.button--primary {
	background: #382E2B;
	color: #FAFAF9;
}

.button--primary:hover {
	background: #6B5B51;
	border-color: #6B5B51;
	color: #FAFAF9;
}

.cky-notice-btn-wrapper .cky-btn {
    border-color: #382e2b !important;
    color: #382e2b !important;
}

button.cky-btn.cky-btn-accept {
    color: white !important;
    background: #382e2b !important;
}

.cky-consent-bar .cky-notice-content-wrapper {
    padding: 24px 24px 12px 24px;
    margin-bottom: -70px;
    background: white;
    z-index: 100000;
    position: relative;
}

.cky-revisit-bottom-left {
display: none !important;
}

/* Section header */
.section__header {
	margin-bottom: 64px;
}

.section__titre {
	font-size: 36px;
	font-weight: 500;
	letter-spacing: -0.025em;
	line-height: 1.1;
	color: #89796C;
	margin-bottom: 80px;
}

.section__chapeau {
	margin-bottom: 0;
}

.section__sous-titre,
.section__intro,
.section__description,
 {
		font-size: 45px;
			color: #382E2B;
			margin-top: 12px;
			line-height: 60px;
			max-width: 800px;
}

.section__description {
    font-size: 18px;
    color: #1E1915;
}

.grille-profils h3.section__intro {
    margin-bottom: 10px;
    font-size: 40px;
}

.section__texte {
	font-size: 18px;
	color: #89796C;
	line-height: 1.7;
	margin-bottom: 40px;
}

.section__footer {
	margin-top: 64px;
	text-align: center;
}

/* Commun */
.section {
	padding-top: 100px;
	padding-bottom: 100px;
}

.post,
.page {
	margin: 0;
}


/* ============================================================
 * HEADER
 * ============================================================ */
.site-header {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	z-index: 900;
	height: 72px;
	background: transparent;
}

.header-inner {
	height: 100%;
	display: flex;
	align-items: center;
	padding-left: 20px;
	padding-right: 20px;
	gap: 40px;
	max-width: 1250px;
	margin: auto;
	padding-top: 60px;
	justify-content: space-between;
}

/* Logo */
.site-branding {
	display: flex;
	align-items: center;
	flex-shrink: 0;
}

.site-branding>a {
	display: flex;
	align-items: center;
}

.site-branding>a>a {
	display: flex;
	align-items: center;
}

.site-branding img,
.site-branding .custom-logo {
	height: 50px;
	width: auto;
	display: block;
}

.site-title {
	font-size: 16px;
	font-weight: 500;
}

.custom-logo-link+.site-title {
	display: none;
}

/* Nav header */
.header-right-container {
	display: flex;
	align-items: center;
	margin-left: auto;
}

ul#menu-header,
.header-nav__list {
	display: flex;
	align-items: center;
	gap: 32px;
	list-style: none;
	margin: 0;
	padding: 0;
	margin-right: 32px;
}

ul#menu-header a,
.header-nav__list a {
	font-size: 18px;
	font-weight: 500;
	color: #382E2B;
	transition: opacity 0.22s ease;
}

ul#menu-header a:hover,
.header-nav__list a:hover {
	opacity: 0.45;
}

ul#menu-header .current-menu-item>a,
ul#menu-header .current_page_item>a {
	opacity: 0.35;
}

#site-navigation {
	display: none;
}

.menu-toggle {
	display: none;
}


.site-header {
	z-index: 10000;
}

.menu-overlay {
	top: 0;
	/* part du haut de la page */
	z-index: 900;
	/* sous le header */
}

.overlay-header {
	display: none;
	/* plus besoin du logo dupliqué */
}

/* ============================================================
 * BURGER — ne pas modifier
 * ============================================================ */
.burger {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 6px;
	width: 60px;
	height: 30px;
	background: #382E2B;
	border-radius: 100px;
	flex-shrink: 0;
	transition: background 0.25s ease;
	z-index: 1100;
	position: relative;
}

.burger:hover {
	background: #6B5B51;
}

.burger span {
	display: block;
	width: 25px;
	height: 2px;
	background: #FAFAF9;
	border-radius: 2px;
	transform-origin: center;
			transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1),
				opacity 0.25s ease;
	
}

.burger.is-active span:nth-child(1) {
	transform: translateY(3.75px);
}

.burger.is-active span:nth-child(2) {
	transform: translateY(-3.75px);
}


/* ============================================================
 * OVERLAY MENU
 * ============================================================ */
.menu-overlay {
	position: fixed;
	inset: 0;
	z-index: 1000;
	background: #FAFAF9;
	display: flex;
	flex-direction: column;
	visibility: hidden;
	pointer-events: none;
			opacity: 0;
				visibility: hidden;
				pointer-events: none;
				transform: translateY(-12px);
				transition: opacity 0.35s ease, transform 0.35s ease, visibility 0s linear 0.35s;
}

.menu-overlay.is-open {
	visibility: visible;
	pointer-events: auto;
	opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transform: translateY(0);
		transition: opacity 0.35s ease, transform 0.35s ease, visibility 0s linear 0s;
}

.overlay-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 72px;
	padding-left: 56px;
	padding-right: 56px;
	flex-shrink: 0;
	border-bottom: 1px solid #E8E5E3;
}

.overlay-header .site-branding>a>a {
	display: flex;
}

.overlay-header .site-branding img,
.overlay-header .custom-logo {
	height: 32px;
	width: auto;
}

.menu-right {
	display: flex;
}

.overlay-nav {
	flex: 1;
	display: flex;
	padding: 80px 20px 0px;
	max-width: 1250px;
	margin: auto;
	width: 100%;
	justify-content: center;
	height: 100vh;
	min-height: 100vh;
	flex-direction: column;
	gap: 30px;
}

.overlay-nav__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.overlay-nav__list li {
	overflow: hidden;
}

.overlay-nav__list a {
	display: block;
	font-size: 40px;
	font-weight: 300;
	line-height: 1.15;
	color: #382E2B;
	padding: 4px 0;
	transform: translateY(110%);
	opacity: 0;
	transition: color 0.2s ease;
}

.overlay-nav__list a:hover {
	color: #B4A79C;
	opacity: 1;
}

.overlay-nav__list .current-menu-item a,
.overlay-nav__list .current_page_item a {
	color: #B4A79C;
}


html.no-scroll {
	overflow: hidden;
}


/* ============================================================
 * HERO
 * ============================================================ */
.hero {
	position: relative;
	display: flex;
	align-items: center;
	overflow: hidden;
	padding: 0;
	background-position: top right;
	background-size: 50% 100%;
	background-repeat: no-repeat;
	margin-top: -80px;
	padding-top: 80px;
}

.hero .container h1, .hero .container p {
    max-width: 540px;
}

.hero--full {
    padding: 150px 0;
}

.hero--compact {
	min-height: 480px;
}

/* Image de fond en balise img */
.hero__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.hero__bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center top;
	display: block;
}

.hero .container {
	position: relative;
	z-index: 2;
	padding-top: 120px;
	padding-bottom: 80px;
	max-width: 1250px;
}

.hero__titre {
	font-size: 44px;
	font-weight: 500;
	line-height: 54px;
	margin-bottom: 22px;
}

.hero__titre br {
	display: block;
	content: '';
}

.hero__sous-titre {
	font-size: 18px;
	font-weight: 400;
	max-width: 500px;
	line-height: 1.65;
	margin-bottom: 48px;
}

.hero__ctas {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	margin-top: 25px;
}

.hero .button {
    border-color: #F5F5F4;
    color: #382E2B;
    background: #F5F5F4;
}

.hero .button:hover {
	background: #382E2B;
	border-color: #382E2B;
	color: #FAFAF9;
	opacity: 1;
}

.hero .button--primary {
	background: #382E2B;
	border-color: #382E2B;
	color: #FAFAF9;
}

.hero .button--primary:hover {
	background: #6B5B51;
	border-color: #6B5B51;
	color: #FAFAF9;
}

.hero__image {
	display: none;
}

/* ============================================================
 * RÉFÉRENCES
 * ============================================================ */
.references {
	padding-top: 56px;
	padding-bottom: 56px;
	background: #fff;
}

.references__titre {
	font-size: 36px;
	font-weight: 500;
	color: #89796C;
	text-align: center;
	margin-bottom: 48px;
}

.references__grille {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 32px 80px;
}

.references__item {
	opacity: 1;
	transition: opacity 0.22s ease;
}

.references__item:hover {
	opacity: 0.7;
	transition: opacity 0.22s ease;
}


.references__item img {
	width: auto;
	max-width: 130px;
	object-fit: contain;
}

.references__item:hover img {
	filter: grayscale(0%);
}

.references__item a {
	display: flex;
	align-items: center;
}

.references a.button {
	color: #F5F5F4;
	border-color: #F5F5F4;
	background: transparent;
}

.references a.button:hover {
	background: #F5F5F4;
	color: #382E2B;
}

/* ============================================================
 * TEXTE + IMAGE (À propos)
 * ============================================================ */
.texte-image {
	background: #FAFAF9;
}

.texte-image .container--flex {
	gap: 120px;
	align-items: flex-start;
	align-items: stretch;
}

.texte-image__image img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
    aspect-ratio: unset;
}

.texte-image--image_gauche .container--flex {
	flex-direction: row-reverse;
}

.texte-image__texte {
    flex: 1;
    min-width: 0;
    padding: 50px 0;
}

.texte-image__texte .section__texte {
	margin-bottom: 40px;
}

.texte-image__image {
	flex: 0 0 42%;
	min-width: 0;
	position: relative;
}

.texte-image__image img {
	width: 100%;
	object-fit: cover;
}


/* ============================================================
 * GRILLE DE CARTES (Offres)
 * Fond chaud, cards avec coins arrondis
 * ============================================================ */
.grille-cartes {
	background: #E8E5E3;
}


.grille-cartes .section__header {
	margin-bottom: 80px;
	max-width: 680px;
}

.cartes-grille {
	display: flex;
	gap: 60px;
	background: none;
	border: none;
	padding: 20px 80px;
}

.carte {
	flex: 1;
	min-width: 220px;
	padding: 48px 40px;
	border: none;
	border-radius: 12px;
	background: #F5F5F4;
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.carte__icone {
	width: 48px;
	height: 48px;
	margin-bottom: 8px;
}

.carte__icone img {
	width: 48px;
	height: 48px;
	object-fit: contain;
}

.carte__titre {
	font-size: 24px;
	font-weight: 500;
	letter-spacing: -0.015em;
	line-height: 1.2;
	margin-bottom: 0;
	margin-top: 60px;
}

.carte__texte {
	font-size: 16px;
	color: #1E1915;
	line-height: 1.65;
	flex: 1;
}

.carte__lien {
    font-size: 14px;
    font-weight: 500;
    display: inline-block;
    border-bottom: 1px solid #D8D3CF;
    padding-bottom: 0px;
    transition: border-color 0.22s ease;
    width: fit-content;
}

.carte__lien:hover {
	border-color: #382E2B;
	opacity: 1;
}


/* ============================================================
 * TEXTE + VISUEL (Matrice)
 * ============================================================ */
.texte-visuel {
	background: #F5F5F4;
}

.texte-visuel__texte h2 {
	color: #382E2B;
	margin-bottom: 30px;
}

.texte-visuel .container--flex {
		align-items: flex-end;
			gap: 0px;
}

.texte-visuel__texte {
	flex: 1;
	min-width: 0;
	background: #FAFAF9;
	padding: 80px;
	margin-left: -300px;
}

.texte-visuel__texte .section__texte {
	margin-bottom: 40px;
}

.texte-visuel__visuel {
	flex: 0 0 70%;
	min-width: 0;
}

.texte-visuel__visuel img {
	width: 100%;
	aspect-ratio: 5/4;
	object-fit: cover;
}


.liste-etapes {
	background: #B4A79C;
}

li.etape {
    max-width: 650px;
}

.liste-etapes .section__titre {
	margin-bottom: 56px;
	color: #FAFAF9;
	text-align: center;
}

.liste-etapes__inner {
	display: flex;
	gap: 100px;
	align-items: flex-start;
}

.liste-etapes__image {
	flex: 0 0 40%;
}

.liste-etapes__image img {
	width: 100%;
}

.etapes-liste {
	flex: 1;
	min-width: 0;
}

.etape__header {
	display: flex;
	align-items: center;
	width: 100%;
	background: none;
	border: none;
	padding: 22px 0;
	cursor: pointer;
	text-align: left;
	gap: 16px;
}

.etape__titre {
	font-size: 16px;
	font-weight: 500;
	color: #382E2B;
	margin: 0;
	font-size: 28px;
}

.etape__header svg path {
	stroke: black;
}

.etape__body {
	overflow: hidden;
	margin-bottom: 20px;
}

.etape__detail {
	font-size: 16px;
	color: #FAFAF9;
	line-height: 1.6;
	padding-bottom: 20px;
	margin: 0;
}

.etape__header svg {
	transition: transform 0.3s ease;
	flex-shrink: 0;
	transform: rotate(-90deg);
	width: 12px;
}

.etape.is-open .etape__header svg {
	transform: rotate(0deg);
}

.is-open h3.etape__titre,
.is-open p {
	color: #FAFAF9;
}

.is-open svg path {
stroke: #FAFAF9;
}
/* ============================================================
 * GRILLE DE PROFILS (Panel d'experts)
 * ============================================================ */
.grille-profils {
	background: #FAFAF9;
}

.grille-profils .section__header {
	max-width: 680px;
	margin-bottom: 80px;
}

.profils-grille {
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
}

.profil-card {
    flex: 1;
    width: 50%;
    border: 1px solid;
    padding: 30px;
    gap: 30px;
    display: flex;
    min-width: 48%;
    margin-top: 0px;
}

.profil-card:nth-child(even) {
    margin-top: -40px;
    margin-bottom: 40px;
}

.profil-card__infos p {
	font-size: 14px;
}

.profil-card__photo {
	flex: 0 0 50%;
}

.profil-card__photo img {
	width: 100%;
	transition: transform 0.5s ease;
	object-fit: cover;
	height: 100%;
}

.profil-card:hover .profil-card__photo img {
	transform: scale(1.04);
}

.profil-card__nom {
	font-size: 18px;
	font-weight: 500;
	margin-bottom: 0;
	border-bottom: 1px solid #c7c7c7;
	padding-bottom: 10px;
}

.profil-card__linkedin {
	position: absolute;
	bottom: -5px;
	right: 10px;
}

.profil-card__infos {
	display: flex;
	flex-direction: column;
	gap: 4px;
	position: relative;
}

.profil-card__nom {
	font-size: 16px;
	font-weight: 500;
}

.profil-card__role {
	font-size: 14px;
	color: #89796C;
}

.profil-card__organisation {
	font-size: 14px;
	color: #89796C;
	font-style: italic;
}

.profil-card__bio {
	font-size: 14px;
	color: #89796C;
	line-height: 1.55;
	margin-top: 8px;
}

.profil-card__linkedin svg {
	width: 45px;
}

.profil-card__linkedin:hover {
	border-color: #382E2B;
	opacity: 1;
}


/* ============================================================
 * CHIFFRES CLÉS
 * Fond chaud, grands chiffres sans bordures
 * ============================================================ */
.chiffres-cles {
	background: #FAFAF9;
}

.chiffres-cles h2.section__titre {
	color: #1E1915;
}

.chiffres-grille {
	display: flex;
	flex-wrap: wrap;
	gap: 56px 80px;
	margin-top: 56px;
}

.chiffre-item {
	flex: 1;
	min-width: 150px;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.chiffre-item__icone {
	margin-bottom: 4px;
}

.chiffre-item__icone img {
	width: 54px;
	height: 54px;
	margin-bottom: 20px;
}

.chiffre-item__valeur {
	font-size: clamp(44px, 5vw, 60px);
	font-weight: 500;
	letter-spacing: -0.04em;
	line-height: 1;
	color: #6B5B51;
}

.chiffre-item__label {
	font-size: 14px;
	color: #89796C;
	line-height: 1.45;
	max-width: 160px;
}


/* ============================================================
 * TÉMOIGNAGES
 * Cards avec coins arrondis
 * ============================================================ */
.temoignages {
	background: #89796C;
}


.temoignage-card__photo-wrap {
    width: 70%;
}

.temoignages h2.section__titre,
.temoignages p.section__sous-titre {
	color: white;
}

.temoignages-liste {
	display: flex;
	flex-wrap: wrap;
	gap: 24px;
	margin-top: 56px;
}

.temoignage-card {
	width: 100%;
	padding: 48px 20px;
	display: flex;
	align-items: center;
	max-width: 1024px;
	margin: auto;
}

.temoignage-card__contenu {
	background: #F5F5F4;
	padding: 60px;
	height: fit-content;
	margin-right: -40px;
	z-index: 1;
}

.temoignage-card__citation {
    font-size: 25px;
    font-weight: 500;
    color: #242321;
    flex: 1;
    line-height: 36px;
    margin-bottom: 20px;
}

.temoignage-card__citation::before {
	content: '\201C ';
}

.temoignage-card__citation::after {
	content: ' \201D';
}


.temoignage-card__nom {
    display: block;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .02em;
}

.temoignage-card__role {
    display: block;
    font-size: 12px;
    color: #1E1915;
    margin-top: 3px;
}

.temoignages h3.section__sous-titre {
    color: #F5F5F4;
    font-size: 40px;
    max-width: 700px;
    font-weight: 400;
}


/* Slider */
.temoignages-slider {
	width: 100%;
	overflow: hidden;
}

.swiper-slide {
	width: 100%;
}

.temoignages-slider {
	position: relative;
}

.temoignages-nav {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	transform: translateY(-50%);
	display: flex;
	align-items: center;
	justify-content: space-between;
	pointer-events: none;
	z-index: 10;
	padding: 0 24px;
	max-width: 1240px;
	margin: auto;
}

.temoignages-prev,
.temoignages-next {
	pointer-events: all;
	/* réactive les clics sur les boutons */
	background: none;
	border: none;
	cursor: pointer;
	padding: 8px 0;
	opacity: 0.55;
	transition: opacity 0.22s ease;
	line-height: 0;
}

.temoignages-prev:hover,
.temoignages-next:hover {
	opacity: 1;
}

.temoignages-next svg {
	transform: scaleX(-1);
}
/* Pagination */
.temoignages-pagination {
	display: flex;
	align-items: center;
	gap: 10px;
	justify-content: center;
}

/* Surcharge les styles Swiper par défaut */
.temoignages-pagination .swiper-pagination-bullet {
	width: 10px;
	height: 10px;
	background: transparent;
	border: 1.5px solid #FAFAF9;
	border-radius: 50%;
	opacity: 0.6;
	transition: all 0.3s ease;
	margin: 0;
	cursor: pointer;
}

.temoignages-pagination .swiper-pagination-bullet-active {
	background: #FAFAF9;
	border-color: #FAFAF9;
	opacity: 1;
	transform: scale(1.15);
}


/* ============================================================
 * SÉLECTION D'ARTICLES (Blog)
 * Fond chaud, cards avec coins arrondis
 * ============================================================ */
.selection-articles {
	background: #E8E5E3;
}

.articles-grille {
	display: flex;
	flex-wrap: wrap;
	gap: 24px;
	margin-top: 56px;
}

.article-card {
	flex: 1;
	min-width: 260px;
	display: flex;
	flex-direction: column;
	background: #F5F5F4;
	border-radius: 12px;
	overflow: hidden;
}

.article-card__image-lien {
	display: block;
	overflow: hidden;
	background: #D8D3CF;
}

.article-card__image-lien img {
	width: 100%;
	aspect-ratio: 16/10;
	object-fit: cover;
	transition: transform 0.5s ease;
}

.article-card:hover .article-card__image-lien img {
	transform: scale(1.04);
}

.article-card__contenu {
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1;
	padding: 32px;
}

.article-card__meta {
	display: flex;
	align-items: center;
	gap: 16px;
}

.article-card__date,
.article-card__lecture {
	font-size: 12px;
	color: #89796C;
	letter-spacing: 0.04em;
}

.article-card__titre {
	font-size: 20px;
	font-weight: 500;
	letter-spacing: -0.01em;
	line-height: 1.3;
	margin-top: 4px;
}

.article-card__titre a:hover {
	opacity: 0.55;
}

.article-card__chapeau {
	font-size: 14px;
	color: #89796C;
	line-height: 1.55;
}


/* ============================================================
 * FORMULAIRE
 * ============================================================ */
.formulaire {
	background: #FAFAF9;
}

.formulaire__inner {
	display: flex;
	gap: 100px;
	align-items: flex-start;
	margin-top: 56px;
}

.formulaire__coordonnees {
	flex: 0 0 40%;
	display: flex;
	flex-direction: column;
}

.formulaire__image {
	margin-top: 50px;
}

.formulaire__image img {
	width: 100%;
	aspect-ratio: 3/4;
	object-fit: cover;
	margin-bottom: 24px;
	object-position: top;
}


.formulaire__email,
.formulaire__telephone {
	border-bottom: 1px solid;
	width: fit-content;
	line-height: 18px;
	margin-bottom: 15px;
}

.formulaire__form {
	flex: 1;
	min-width: 0;
}

/* NinjaForms */
.formulaire .nf-form-content .nf-field-container {
	margin-bottom: 24px;
}

.formulaire .nf-form-content input:not([type=button]):not([type=submit]),
.formulaire .nf-form-content textarea,
.formulaire .nf-form-content select {
border: 1px solid #6b5b5157;
	background: transparent;
	padding: 8px 10px;
	width: 100%;
	font-size: 16px;
	color: #382E2B;
	border-radius: 8px;
	transition: border-color 0.22s ease;
	-webkit-appearance: none;
}

.formulaire .nf-form-content input:focus,
.formulaire .nf-form-content textarea:focus,
.formulaire .nf-form-content select:focus {
	outline: none;
	border-color: #382E2B;
}

.label-above .nf-field-label {
	margin-bottom: 3px;
}

.formulaire .nf-form-content label,
.formulaire .nf-field-label label {
	font-size: 14px;
	color: #242321;
	margin-bottom: 4px;
	display: block;
	font-weight: 500;
}



.formulaire .nf-form-content .submit-container input[type=button],
.formulaire .nf-form-content button[type=submit] {
	display: inline-flex;
	font-family: 'DM Sans', sans-serif;
	font-size: 14px;
	font-weight: 500;
	padding: 14px 28px;
	background: #382E2B;
	color: #FAFAF9;
	border: 1px solid #382E2B;
	border-radius: 100px;
	cursor: pointer;
	transition: background 0.22s ease;
	margin-top: 32px;
	width: auto;
}

.formulaire .nf-form-content .submit-container input[type=button]:hover,
.formulaire .nf-form-content button[type=submit]:hover {
	background: #6B5B51;
	border-color: #6B5B51;
}

.nf-form-fields-required,
.ninja-forms-req-symbol {
	display: none;
}

.nf-error .nf-error-msg {
	font-size: 12px;
	color: #c0392b;
	margin-top: 4px;
}

.nf-after-form-content .nf-form-errors {
	display: none;
}

/* ============================================================
 * CTA
 * ============================================================ */
.cta {
	text-align: center;
}

img.cta__icon {
    width: 70px;
}

.cta .container {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 40px;
}

.cta__accroche {
	font-size: clamp(24px, 3vw, 40px);
	font-weight: 400;
	letter-spacing: -0.025em;
	line-height: 1.2;
	max-width: 600px;
	text-align: left;
}

.cta--dark {
    background: #89796C;
}

.cta--dark .cta__accroche {
	color: #F5F5F4;
}

.cta--dark .button--cta {
    border-color: #FAFAF9;
    color: #FAFAF9;
    background: transparent;
}
.cta--dark .button--cta:hover {
	background: #FAFAF9;
	border-color: #FAFAF9;
	color: #1E1915;
	opacity: 1;
}

.cta--light {
	background: #F5F5F4;
}

.cta--accent {
	background: #382E2B;
}

.cta--accent .cta__accroche {
	color: #F5F5F4;
}

.cta--accent .button--cta {
	border-color: rgba(250, 250, 249, .4);
	color: #FAFAF9;
}

.cta--accent .button--cta:hover {
	background: #FAFAF9;
	border-color: #FAFAF9;
	color: #1E1915;
	opacity: 1;
}


/* ============================================================
 * TEXTE LIBRE
 * ============================================================ */
.texte-libre {
	background: #FAFAF9;
}

.texte-libre__contenu {
	margin-top: 32px;
}


/* ============================================================
 * FOOTER
 * ============================================================ */
.site-footer {
	background: #F5F5F4;
	border-top: 1px solid #E8E5E3;
	padding-top: 80px;
	padding-bottom: 56px;
}

.footer-inner {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 40px;
}

.footer-left {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.footer-logo img,
.footer-logo .custom-logo {
	height: 28px;
	width: auto;
}

.footer-logo>a>a {
	display: flex;
}

.footer-description {
	font-size: 14px;
	color: #89796C;
	max-width: 290px;
	line-height: 1.65;
}

.footer-copyright {
	font-size: 12px;
	color: #89796C;
}

.footer-right {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 12px;
}

.footer-legal {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	justify-content: flex-end;
}

.footer-legal a {
	font-size: 14px;
	color: #382E2B;
	transition: opacity 0.22s ease;
}

.footer-legal a:hover {
	opacity: 0.5;
}

.footer-legal__sep {
	font-size: 14px;
	color: #89796C;
}

.footer-linkedin {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	background: #382E2B;
	color: #FAFAF9;
	font-size: 14px;
	font-weight: 500;
	padding: 9px 16px;
	border-radius: 100px;
	transition: background 0.22s ease;
}

.footer-linkedin:hover {
	background: #6B5B51;
	opacity: 1;
}


/* ============================================================
 * ADMIN BAR
 * ============================================================ */
.admin-bar .site-header {
	top: 32px;
}

@media screen and (max-width: 782px) {
	.admin-bar .site-header {
		top: 46px;
	}
}


/* ============================================================
 * RESPONSIVE — 1000px
 * ============================================================ */
@media (max-width: 1000px) {
	body {
		padding-top: 64px;
	}

	.site-header {
		height: 64px;
	}

	.overlay-header {
		height: 64px;
	}

	.section {
		padding-top: 80px;
		padding-bottom: 80px;
	}

	.container {
		padding-left: 40px;
		padding-right: 40px;
	}

	.header-inner {
		padding-left: 40px;
		padding-right: 40px;
	}

	.container--flex {
		gap: 80px;
	}

	.section__titre {
		font-size: 32px;
	}

	.hero__titre {
		font-size: clamp(40px, 6vw, 52px);
	}

	.profil-card {
		min-width: 180px;
		max-width: calc(50% - 40px);
	}

	.formulaire__inner {
		gap: 64px;
	}

	.footer-inner {
		flex-wrap: wrap;
		gap: 32px;
	}

	.chiffres-grille {
		gap: 48px 56px;
	}

	.liste-etapes__inner {
		gap: 64px;
	}
}


/* ============================================================
 * RESPONSIVE — 800px (mobile)
 * ============================================================ */
@media (max-width: 800px) {
	body {
		padding-top: 60px;
	}

.site-header {
	background: white;
	padding-bottom: 100px;
	margin-top: -10px;
}

	.overlay-header {
		height: 60px;
		padding-left: 24px;
		padding-right: 24px;
	}

	.section {
		padding-top: 60px;
		padding-bottom: 60px;
	}


	.container {
		padding-left: 24px;
		padding-right: 24px;
	}

	.texte-image__image img {
    position: relative;
    margin-left: -30px;
    max-width: calc(100% + 60px);
    width: calc(100% + 54px);
    margin-bottom: -60px;
}

	.header-inner {
		padding-left: 24px;
		padding-right: 24px;
	}

	.texte-image__texte {
    padding: 20px 0;
}

.cartes-grille {
    gap: 40px;
    padding: 0;
}

	/* Nav header cachée */
	ul#menu-header,
	.header-nav {
		display: none;
	}

	/* Typo */
	.hero__titre {
		font-size: clamp(32px, 9vw, 44px);
	}

	.section__titre {
		margin-bottom: 40px;
	}

	.cta__accroche {
		font-size: 24px;
	}

	/* Hero */

	.hero--compact {
		min-height: 320px;
	}

	.hero .container {
		padding-top: 110px;
		padding-bottom: 0px;
	}

	/* Flex → colonne */
	.container--flex,
	.texte-image .container--flex,
	.texte-image--image_gauche .container--flex,
	.texte-visuel .container--flex,
	.liste-etapes__inner {
		flex-direction: column;
		gap: 40px;
	}

	.texte-image__image,
	.texte-visuel__visuel,
	.liste-etapes__image {
		flex: none;
		width: 100%;
	}

	/* Cartes */
	.cartes-grille {
		flex-direction: column;
	}

	.carte {
		min-width: 100%;
	}

	/* Chiffres 2 par ligne */
	.chiffres-grille {
		gap: 40px 32px;
	}

	.chiffre-item {
		min-width: calc(50% - 32px);
	}

	/* Profils */
	.profil-card {
		min-width: 100%;
		max-width: 100%;
	}



	/* Témoignages */
	.temoignages-liste {
		flex-direction: column;
	}

.temoignage-card {
    min-width: 100%;
    flex-direction: column-reverse;
}

.temoignage-card__contenu {
    margin: 0;
}

.temoignage-card__photo-wrap {
    width: 100%;
}

img.temoignage-card__photo {
    width: 100%;
    object-fit: cover;
    aspect-ratio: 16/16;
}

.temoignage-card__contenu {
    padding: 20px;
}

.livre-blanc .container {
    display: flex;
    flex-direction: column;
}

	/* Articles */
	.articles-grille {
		flex-direction: column;
	}

	.article-card {
		min-width: 100%;
	}

	/* Formulaire */
	.formulaire__inner {
		flex-direction: column;
		gap: 40px;
	}

	.formulaire__coordonnees {
		flex: none;
		width: 100%;
	}

	/* Overlay */
.overlay-nav {
    padding: 130px 30px 30px;
    justify-content: flex-start;
}

	.overlay-footer {
		padding: 0 24px 32px;
	}

	.overlay-nav__list a {
		font-size: 36px;
	}

	/* Références */
	.references__item img {
		height: 22px;
	}

	.references__grille {
		gap: 24px 40px;
	}

	/* Footer */
	.footer-inner {
		flex-direction: column;
		align-items: flex-start;
		gap: 32px;
	}

	.footer-right {
		align-items: flex-start;
	}

	.footer-legal {
		justify-content: flex-start;
	}
}

/* ============================================================
 * LIVRE BLANC
 * ============================================================ */
.livre-blanc {
	position: relative;
	overflow: hidden;
	background: #F5F5F4;
	background-position: top right;
	padding-top: 0;
	padding-bottom: 0;
	background-size: 50% 100%;
	background-repeat: no-repeat;
}

.livre-blanc__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.livre-blanc__bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}



.livre-blanc__inner {
	display: flex;
	align-items: stretch;
	min-height: 600px;
}

/* Colonne gauche */
.livre-blanc__texte {
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 32px;
	padding: 80px 80px 80px 0;
	max-width: 520px;
}

/* Logos */
.livre-blanc__logos {
	display: flex;
	align-items: center;
	gap: 16px;
}

.livre-blanc__logo-vertige,
.livre-blanc__logo-client {
	height: 28px;
	width: auto;
	object-fit: contain;
}

.livre-blanc__logo-client {
	max-width: 140px;
}

.livre-blanc__logos-sep {
	font-size: 36px;
	color: #89796C;
	font-weight: 300;
}

.livre-blanc__titre {
	margin-bottom: 0px;
	
}
h3.livre-blanc__form-title {
	color: #89796C;
}

/* Colonne droite */
.livre-blanc__form-wrap {
	position: absolute;
	right: 80px;
	top: 50px;
	width: auto;
	left: calc(50% + 80px);
	bottom: 50px;
	display: flex;
	align-items: center;
}

.livre-blanc__form {
	padding: 60px;
	width: 100%;
}



/* Responsive */
@media (max-width: 1000px) {
	.livre-blanc__texte {
		padding-right: 48px;
	}

	.livre-blanc__form-wrap {
		flex: 0 0 48%;
	}
}

@media (max-width: 800px) {
	.livre-blanc__inner {
		flex-direction: column;
		min-height: auto;
	}

	.livre-blanc__texte {
		padding: 56px 0 40px;
		max-width: 100%;
	}

	.livre-blanc__form-wrap {
		flex: none;
		width: 100%;
		padding: 0 0 56px;
		justify-content: flex-start;
	}

	.hero__image {
		display: block;
	}

		section.section.hero.hero--full {background: none !important;
		padding-bottom: 0px !important;
		}

				.hero__image img {
					margin: 40px 0px -30px -30px;
					width: calc(100% + 60px);
					max-width: calc(100% + 60px);
					object-fit: cover;
					aspect-ratio: 16/9;
				}

				.livre-blanc__form-wrap {
    position: relative;
    left: auto;
    right: auto;
    bottom: auto;
    top: auto;
}

.livre-blanc__form {
    padding: 20px;
    width: 100%;
    background: #e8e5e3;
}

.livre-blanc {
    background: none !important;
}

.overlay-nav__list a {
    font-size: 28px;
}

.texte-visuel__texte {
    padding: 30px;
    margin-left: 0;
    margin-top: -40px;
}

.temoignages-nav {
display: none;
}

.temoignages-pagination {
    margin-top: -60px;
}

	/* Profils */
	.profil-card {
		flex-direction: column;
	}

	.profil-card__photo img {

    aspect-ratio: 16/12;
}

.profil-card:nth-child(even) {
    margin-top: 0;
    margin-bottom: 0px;
}

.profils-grille  {
gap: 0;
}

.profil-card {
margin-bottom: 30px !important;
}



}
