/*!
Theme Name: Adaliance
Theme URI: http://underscores.me/
Author: Underscores.me
Author URI: http://underscores.me/
Description: Description
Version: 1.1.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: adaliance
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

Adaliance is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Generic
	- Normalize
	- Box sizing
# Base
	- Typography
	- Elements
	- Links
	- Forms
## Layouts
# Components
	- Navigation
	- Posts and pages
	- Comments
	- Widgets
	- Media
	- Captions
	- Galleries
# plugins
	- Jetpack infinite scroll
# Utilities
	- Accessibility
	- Alignments

--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Generic
--------------------------------------------------------------*/

/* Normalize
--------------------------------------------- */

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
	 ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
	line-height: 1.15;
	-webkit-text-size-adjust: 100%;
}

/* Sections
	 ========================================================================== */

/**
 * Remove the margin in all browsers.
 */
body {
	margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
	display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

/* Grouping content
	 ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
	box-sizing: content-box;
	height: 0;
	overflow: visible;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
	font-family: "MuseoSans", monospace, monospace;
	font-size: 1em;
}

/* Text-level semantics
	 ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */
a {
	background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
	border-bottom: none;
	text-decoration: underline;
	text-decoration: underline dotted;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
	font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
	font-family: "MuseoSans", monospace, monospace;
	font-size: 1em;
}

/**
 * Add the correct font size in all browsers.
 */
small {
	font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

/* Embedded content
	 ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */
img {
	border-style: none;
}

/* Forms
	 ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
	font-family: "MuseoSans", inherit;
	font-size: 100%;
	line-height: 1.15;
	margin: 0;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
	overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
	text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
	-webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
	outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
	padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *		`fieldset` elements in all browsers.
 */
legend {
	box-sizing: border-box;
	color: inherit;
	display: table;
	max-width: 100%;
	padding: 0;
	white-space: normal;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
	vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
	overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
	box-sizing: border-box;
	padding: 0;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
	-webkit-appearance: textfield;
	outline-offset: -2px;
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

/* Interactive
	 ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
	display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
	display: list-item;
}

/* Misc
	 ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */
template {
	display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
	display: none;
}

/* Box sizing
--------------------------------------------- */

/* Inherit box-sizing to more easily change it's value on a component level.
@link http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
*,
*::before,
*::after {
	box-sizing: inherit;
}

html {
	box-sizing: border-box;
}

/*--------------------------------------------------------------
# Base
--------------------------------------------------------------*/

/* Typography
--------------------------------------------- */
body,
button,
input,
select,
optgroup,
textarea {
	color: #404040;
	font-family: "MuseoSans", -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: "MuseoSans", "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: "MuseoSans", 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%;
}

/* Elements
--------------------------------------------- */
body {
	background: #fff;
}

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

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

.single-post .container ul,
.single-post .container ol {
	margin: 0 0 2.5em 3em !important;
}

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;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
	max-width: 100%;
}

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

figure {
	margin: 1em 0;
}

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

/* Links
--------------------------------------------- */
a {
	color: #4169e1;
}

a:hover,
a:focus,
a:active {
	color: #191970;
}

a:focus {
	outline: thin dotted;
}

a:hover,
a:active {
	outline: 0;
}

/* Forms
--------------------------------------------- */
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	border: 1px solid;
	border-color: #ccc #ccc #bbb;
	border-radius: 3px;
	background: #e6e6e6;
	color: rgba(0, 0, 0, 0.8);
	line-height: 1;
	padding: 0.6em 1em 0.4em;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	border-color: #ccc #bbb #aaa;
}

button:active,
button:focus,
input[type="button"]:active,
input[type="button"]:focus,
input[type="reset"]:active,
input[type="reset"]:focus,
input[type="submit"]:active,
input[type="submit"]:focus {
	border-color: #aaa #bbb #bbb;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
	color: #666;
	border: 1px solid #ccc;
	border-radius: 3px;
	padding: 3px;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
	color: #111;
}

select {
	border: 1px solid #ccc;
}

textarea {
	width: 100%;
}


/*--------------------------------------------------------------
# Formation catalogue - Formuliare de contact a la place du formulaire DENDREO
--------------------------------------------------------------*/

body.page-id-3407 .catalogue-formation #inscription-anchor{
	display:none;
}

/*
.catalogue-contact-section > .container {
  max-width: 900px;
  padding: 60px 30px;
  margin-left: auto;
  margin-right: auto;
  background-color: #FF4842;
  border-radius: 30px;
  color: #FFF;
margin-bottom: 50px !important;}*/

.catalogue-contact-section > .container {
  max-width: none;
  width: 75%; /* .col-sm-9 = 75% (9/12) */
  padding: 60px 30px;
  margin-left: 0;
  margin-right: auto;
  background-color: #FF4842;
  border-radius: 30px;
  color: #FFF;
  margin-bottom: 50px !important;
}

/* Ajustement pour aligner avec le padding Bootstrap (15px) */
@media (min-width: 1700px) {
  .catalogue-contact-section > .container {
    margin-left: calc((100vw - 1170px) / 2 + 15px);
    width: calc(777px - 30px); /* 75% de 1170px = 877px, moins les paddings */
  }
}


@media (min-width: 992px) and (max-width: 1699px) {
  .catalogue-contact-section > .container {
    margin-left: calc((100vw - 970px) / 2 + 15px);
    width: calc(727px - 30px); /* 75% de 970px = 727px, moins les paddings */
  }
}

@media (max-width: 991px) {
  .catalogue-contact-section > .container {
    margin-left: 15px;
    margin-right: 15px;
    width: auto;
  }
}

.catalogue-contact-section h2{
  margin-bottom: 40px;
	color: #FFF;}

.catalogue-contact-section input[type="submit"]{
  background: #FFF;
  border: 1px solid #fff;
	color: #f75a4e;}

.catalogue-contact-section input[type="submit"]:hover{
color:#fff;
border: 1px solid #fff;}

.catalogue-contact-section form label .asterisk {
	color: #fff !important;}

.catalogue-contact-section a {
  text-decoration: underline;
	color: #FFF;}

.catalogue-container {
	margin-bottom: 25px !important;}

.catalogue-contact-section .form-wrap form input[type="text"], .catalogue-contact-section .form-wrap form input[type="email"], .catalogue-contact-section .form-wrap form input[type="url"], .catalogue-contact-section .form-wrap form input[type="password"], .catalogue-contact-section .form-wrap form input[type="search"], .catalogue-contact-section .form-wrap form input[type="number"], .catalogue-contact-section .form-wrap form input[type="tel"], .catalogue-contact-section .form-wrap form input[type="range"], .catalogue-contact-section .form-wrap form input[type="date"], .catalogue-contact-section .form-wrap form input[type="month"], .catalogue-contact-section .form-wrap form input[type="week"], .catalogue-contact-section .form-wrap form input[type="time"], .catalogue-contact-section .form-wrap form input[type="datetime"], .catalogue-contact-section .form-wrap form input[type="datetime-local"], .catalogue-contact-section .form-wrap form input[type="color"], .catalogue-contact-section .form-wrap form select, .catalogue-contact-section .form-wrap form textarea, .catalogue-contact-section .form-wrap form .custom-file-upload {
	background-color: #FFF;
}

@media screen and (max-width: 1024px) {
	.catalogue-contact-section h2{
		font-size: 1.5rem
 }
	
}

@media screen and (max-width: 600px) {
	.catalogue-contact-section h2{
		font-size: 1.2rem
 }
	
}


/*--------------------------------------------------------------
# Home hero Barbara
--------------------------------------------------------------*/

.home-hero .banner-content .center-content{
	text-align: center;
	padding-top: 150px;
}

.btn-with-arrow {
    display: inline-flex !important;
    align-items: center;
    gap: 8px; /* Espace entre le texte et la flèche */
}

.btn-with-arrow .arrow {
    stroke: #ffffff;
    transition: stroke 0.3s ease;
}

.btn-with-arrow:hover .arrow {
    stroke: #f75a4e;
}

.home-hero .inner .center-content h1 {
	padding-bottom: 3%;}


@media (max-width: 767px) {
    .home-hero .col-sm-6 {
		display: none;}}



.postid-1641 #page-content-5.common-content-wrap .container{
	max-width: 1230px;
}


.postid-1641 #page-content-5.common-content-wrap .half-u-graphic.top,
.postid-1641 #page-content-5.common-content-wrap .abs-circle-graphic.middle{
	display:none;
}

/*--------------------------------------------------------------
# Bouton etre rappele/mobile Barbara
--------------------------------------------------------------*/
 
    /* Bouton flottant stylé */
    #rappel-button { display: none; font-weight:bold; }
    #rappel-button .tel-icon {
  margin-right: 10px;
    vertical-align: middle;
    }
    #rappel-button .rappel-text {
        vertical-align: middle;
        font-size: 18px;
        color: white;
    }

    @media (max-width: 768px) {
        #rappel-button {
            display: flex;
            align-items: center;
            position: fixed;
            bottom: 25px;
            right: 20px;
            background: linear-gradient(135deg,#FF6B6B,#f75a4e);
            padding: 14px 20px;
            border-radius: 50px;
            text-decoration: none;
            font-weight: bold;
            box-shadow: 0 6px 12px rgba(0,0,0,0.3);
            z-index: 9999;
            transition: transform 0.2s, box-shadow 0.2s;
        }
        #rappel-button:hover {
            transform: scale(1.05);
            box-shadow: 0 8px 16px rgba(0,0,0,0.35);
        }
    }

    /* Popup formulaire */
    #popup-rappel {
        display: none;
        position: fixed;
        top: 0; left: 0;
        width: 100%; height: 100%;
        background: rgba(0,0,0,0.6);
        z-index: 10000;
        justify-content: center;
        align-items: center;
    }
    #popup-rappel form {
        background: white;
        padding: 25px;
        border-radius: 15px;
        width: 90%;
        max-width: 400px;
        position: relative;
        box-shadow: 0 6px 16px rgba(0,0,0,0.3);
    }
    #popup-rappel input {
        width: 100%;
        padding: 12px;
        margin: 10px 0;
        border-radius: 8px;
        border: 1px solid #ccc;
    }
    #popup-rappel button {
        background-color: #FF6B6B;
        color: white;
        border: none;
        padding: 12px 18px;
        border-radius: 8px;
        font-weight: bold;
        cursor: pointer;
        width: 100%;
        margin-top: 8px;
        transition: background-color 0.3s;
    }
    #popup-rappel button:hover { background-color: #FF4B4B; }
    #fermer-popup {
        position: absolute;
        top: 10px; right: 15px;
        cursor: pointer;
        font-size: 24px;
        font-weight: bold;
    }


/*--------------------------------------------------------------
# Layouts Barbara
--------------------------------------------------------------*/

.page-template-tpl-contact .wpcf7-list-item-label {
    color: #000 !important;
}

.page-id-3463 .image-content-col {
  padding-top: 120px;
}

.page-id-3407 .common-content-wrap {
  padding: 0px;}

.page-id-3407 .common-content-wrap .abs-circle-graphic.top {
  display: none;
}

.page-id-3407 .title-row-layout .title-row .container {
	max-width: 1200px;
}

.page-id-3407 .title-row-layout .title-row {
	padding-bottom: 0px;
}

.page-id-3407 .banner-content h2 {color:#fff;font-size: 43px;}


.main-navigation ul.menu > li ul.sub-menu > li.menu-item-3506 a{
   padding: 0px 0px 15px 0px;
}

.single-post .btn-wrap-post {
	text-align:center;
	padding: 25px 0px;
}

.btn-wrap-post {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: center;
}

.btn-wrap-post .cta-accent {
    font-size: 1em;
    font-weight: bold;
    color: #f75a4e;
    text-decoration: none !important; /* Pour retirer le soulignement */
    transition: color 0.3s ease;
}

.btn-wrap-post .cta-accent:hover {
    color: #f75a4e; /* Couleur au survol */
    text-decoration: underline; /* Optionnel : souligner au survol */
}

  /*Barbara Google*/

.ti-widget[data-layout-id="4"] {
    width: 80% !important;
	margin: auto !important;}

.home .ti-widget[data-layout-id="4"] {
    width: 90% !important;
	margin: auto !important;}

.ti-widget[data-layout-id="4"] .ti-controls .ti-next:before,.ti-widget[data-layout-id="4"] .ti-controls .ti-prev:before{
	 border-color: #fff !important;
	    border-bottom-width: 1px !important;
    border-left-width: 1px !important;
}

.ti-widget[data-layout-id="4"] .ti-controls .ti-next, .ti-widget[data-layout-id="4"] .ti-controls .ti-prev {
    background-color: #f75a4e !important;
	outline-color: #f75a4e !important;
outline-style: none !important;}

.ti-widget[data-layout-id="4"] .ti-controls .ti-next {
	right: -3% !important;}
.ti-widget[data-layout-id="4"] .ti-controls .ti-prev {
	left: -3% !important;}


.ti-widget[data-layout-id="4"] .ti-controls .ti-next:hover, .ti-widget[data-layout-id="4"] .ti-controls .ti-prev:hover {
  cursor: pointer;
  background-color: #f75a4e !important;
	box-shadow: 0px 5px 25px 0px rgba(0, 0, 0, 0.05);}

.container-goo,
 .page-id-475 #page-content-5 .container{
	max-width: 1230px;
  margin: auto;
}

.home .common-content-wrap {
	padding: 0px 0 84px !important;}

/*--------------------------------------------------------------
# Components
--------------------------------------------------------------*/

/* Navigation
--------------------------------------------- */
.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, 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: 220px;
}

.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;
}

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





@media screen and (min-width: 37.5em) {

	.menu-toggle {
		display: none;
	}

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

.site-main .comment-navigation,
.site-main
.posts-navigation,
.site-main
.post-navigation {
	margin: 0 0 1.5em;
}

.comment-navigation .nav-links,
.posts-navigation .nav-links,
.post-navigation .nav-links {
	display: flex;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
	flex: 1 0 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
	text-align: end;
	flex: 1 0 50%;
}

/* Posts and pages
--------------------------------------------- */
.sticky {
	display: block;
}

.post,
.page {
	margin: 0 0 1.5em;
}

.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;
}

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

.bypostauthor {
	display: block;
}

/* Widgets
--------------------------------------------- */
.widget {
	margin: 0 0 1.5em;
}

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

/* Media
--------------------------------------------- */
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
	border: none;
	margin-bottom: 0;
	margin-top: 0;
	padding: 0;
}

/* Make sure logo link wraps around logo image. */
.custom-logo-link {
	display: inline-block;
}

/* Captions
--------------------------------------------- */
.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;
}

/* Galleries
--------------------------------------------- */
.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;
}

/*--------------------------------------------------------------
# Plugins
--------------------------------------------------------------*/

/* Jetpack infinite scroll
--------------------------------------------- */

/* Hide the Posts Navigation and the Footer when Infinite Scroll is in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
	display: none;
}

/* Re-display the Theme Footer when Infinite Scroll has reached its end. */
.infinity-end.neverending .site-footer {
	display: block;
}

/*--------------------------------------------------------------
# Utilities
--------------------------------------------------------------*/

/* Accessibility
--------------------------------------------- */

/* Text meant only for screen readers. */
.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, 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;
}

/* Do not show the outline on the skip link target. */
#primary[tabindex="-1"]:focus {
	outline: 0;
}

/* Alignments
--------------------------------------------- */
.alignleft {

	/*rtl:ignore*/
	float: left;

	/*rtl:ignore*/
	margin-right: 1.5em;
	margin-bottom: 1.5em;
}

.alignright {

	/*rtl:ignore*/
	float: right;

	/*rtl:ignore*/
	margin-left: 1.5em;
	margin-bottom: 1.5em;
}

.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 1.5em;
}
/* Structure globale encapsulée */
.formation-ux { font-family: "MuseoSans"; line-height: 1.6; color: #333; }
.formation-ux .ux-container { max-width: 1200px; margin: 0 auto; padding: 0 2rem; }
.formation-ux .ux-section-padding { padding: 4rem 0; }
.formation-ux .ux-bg-alt { background-color: #f8f9fa; }

/* Typographie */
.formation-ux h1 { font-size: 2.5rem; margin-bottom: 1rem; color: #111; }
.formation-ux h2 { font-size: 2rem; margin-bottom: 2rem; color: #111; }
.formation-ux h3 { font-size: 1.25rem; margin-bottom: 0.5rem; }
.formation-ux .ux-lead { font-size: 1.25rem; color: #555; margin-bottom: 2rem; }
.formation-ux .ux-lead ul {
    list-style-type: decimal;
    padding-left: 1.5rem;
    margin: 0 auto;
    text-align: left;
    max-width: fit-content;
}

.formation-ux .ux-lead ul li {
    margin-bottom: 0.5rem;
}
/* Boutons isolés */
.formation-ux .ux-btn { display: inline-block; padding: 0.75rem 1.5rem; border-radius: 4px; text-decoration: none; font-weight: bold; text-align: center; }
.formation-ux .ux-btn-primary { background-color: #f75a4e; color: #fff; }
.formation-ux .ux-btn-secondary { background-color: #e9ecef; color: #333; }
.formation-ux .ux-btn-large { width: 100%; padding: 1rem; font-size: 1.1rem; }

/* Hero Section */
/* Hero section avec fond */
.formation-ux .ux-hero { 
    padding-top: 6rem; 
    padding-bottom: 6rem; 
    text-align: center; 
    background-image: linear-gradient(rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.2)), url('https://adaliance.com/wp-content/uploads/2020/11/formation-header.jpg');
    background-size: cover;
    background-position: center;
    background-position: top;
    background-repeat: no-repeat;
}

/* Forçage de la couleur du texte sur le fond sombre */
.formation-ux .ux-hero h1,
.formation-ux .ux-hero .ux-lead {
    color: #ffffff;
}
.formation-ux .ux-hero-actions { display: flex; gap: 1rem; justify-content: center; margin-top: 2rem; }
.formation-ux .ux-hero-meta { display: flex; flex-wrap: wrap; justify-content: center; gap: 2rem; background: #111; color: #fff; padding: 1rem;}
.formation-ux .ux-meta-item { display: flex; align-items: center; gap: 0.5rem; font-size: 0.9rem; }

/* Grilles */
.formation-ux .ux-grid-3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem; }
.formation-ux .ux-grid-4 { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 2rem; }
.formation-ux .ux-conversion-grid, 
.formation-ux .ux-proof-grid, 
.formation-ux .ux-target-section { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }

/* Composants */
.formation-ux .ux-placeholder-box { display: inline-flex; align-items: center; justify-content: center; font-size: 0.8rem; color: #6c757d; }
.formation-ux .ux-icon-placeholder { width: 40px; height: 40px; border-radius: 50%; margin-bottom: 1rem; }
.formation-ux .ux-image-placeholder { width: 100%; height: 350px; border-radius: 8px; }
.formation-ux .ux-qualiopi-logo { width: 120px; height: 60px; }

.formation-ux .ux-benefit-card { padding: 2rem; border: 1px solid #e9ecef; border-radius: 8px; }
.formation-ux .ux-method-step { position: relative; }
.formation-ux .ux-step-num { font-size: 3rem; font-weight: bold; color: #dee2e6; line-height: 1; margin-bottom: 0.5rem; }

.formation-ux .ux-authority-box { background: #fff; padding: 3rem; border-radius: 8px; box-shadow: 0 4px 6px rgba(0,0,0,0.05); text-align: center; }
.formation-ux .ux-testimonial { font-size: 1.25rem; font-style: italic; margin-bottom: 1.5rem; border-left: 4px solid #f75a4e; padding-left: 1rem; }
.formation-ux .ux-logos-row { display: flex; gap: 1rem; margin-top: 2rem; }
.formation-ux .ux-logo-client { width: 150px; height: 40px; }

/* Formulaire */
.formation-ux .ux-form-wrapper { background: #fff; padding: 2.5rem; border-radius: 8px; box-shadow: 0 4px 6px rgba(0,0,0,0.05); }
.formation-ux .ux-form-wrapper form { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.formation-ux .ux-form-group { display: flex; flex-direction: column; gap: 0.5rem; }
.formation-ux .ux-full-width { grid-column: 1 / -1; }
.formation-ux .ux-form-group input, 
.formation-ux .ux-form-group textarea { padding: 0.75rem; border: 1px solid #ced4da; border-radius: 4px; font-family: "MuseoSans", inherit; }
.formation-ux .ux-form-group textarea { min-height: 100px; resize: vertical; }

/* Accordéons / FAQ */
.formation-ux .ux-accordion-wrapper { max-width: 800px; margin: 0 auto; }
.formation-ux details { border-bottom: 1px solid #dee2e6; padding: 1rem 0; }
.formation-ux summary { font-weight: bold; cursor: pointer; font-size: 1.1rem; list-style: none; display: flex; justify-content: space-between; align-items: center; }
.formation-ux summary::-webkit-details-marker { display: none; }
.formation-ux summary::after { content: '+'; font-size: 1.5rem; color: #f75a4e; }
.formation-ux details[open] summary::after { content: '-'; }
.formation-ux .ux-details-content { padding-top: 1rem; color: #555; }

/* Responsive */
@media (max-width: 768px) {
    .formation-ux .ux-conversion-grid, 
    .formation-ux .ux-proof-grid, 
    .formation-ux .ux-target-section, 
    .formation-ux .ux-form-wrapper form { grid-template-columns: 1fr; gap: 2rem; }
    .formation-ux h1 { font-size: 2rem; }
    .formation-ux .ux-hero-actions { flex-direction: column; }
}
.formation-ux .ux-image-visuel { width: 100%; height: 350px; object-fit: cover; border-radius: 8px; display: block; }
/* Surcharge structurelle Contact Form 7 stricte */
.formation-ux .ux-form-wrapper .wpcf7-form {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.formation-ux .ux-form-wrapper .wpcf7-form p,
.formation-ux .ux-form-wrapper .form-group {
    margin: 0 !important;
}

.formation-ux .ux-form-wrapper .wpcf7-form label {
    /*display: flex;*/
    flex-direction: column;
    font-weight: bold;
    color: #333;
    width: 100%;
    gap: 0.25rem;
}

.formation-ux .ux-form-wrapper .wpcf7-form-control-wrap input:not([type="checkbox"]),
.formation-ux .ux-form-wrapper .wpcf7-form-control-wrap textarea {
    width: 100%;
    padding: 0.6rem;
    border: 1px solid #ced4da;
    border-radius: 4px;
    font-family: "MuseoSans", inherit;
    background-color: #fff;
    box-sizing: border-box;
}

.formation-ux .ux-form-wrapper .wpcf7-form-control-wrap textarea {
    max-height: 150px;
    min-height: 100px;
    resize: vertical;
}

/* Formatage du bloc RGPD avec styles en ligne forcés */
.formation-ux .ux-form-wrapper .wpcf7-form > div[style*="background-color: #FF4842"] {
    border-radius: 4px;
    padding: 0.75rem;
    font-size: 0.85rem;
    line-height: 1.3;
}

.formation-ux .ux-form-wrapper .wpcf7-acceptance label {
    flex-direction: row;
    align-items: flex-start;
    font-weight: normal;
    color: #fff;
}

.formation-ux .ux-form-wrapper .wpcf7-acceptance input[type="checkbox"] {
    margin-top: 0.2rem;
}

.formation-ux .ux-form-wrapper .wpcf7-list-item {
    margin: 0;
}

.formation-ux .ux-form-wrapper .wpcf7-list-item-label {
    margin-left: 0.5rem;
}

/* Bouton de soumission */
.formation-ux .ux-form-wrapper .wpcf7-submit {
    /*background-color: #f75a4e;*/
    color: #fff;
    border: none;
    padding: 0.85rem;
    font-size: 1.1rem;
    border-radius: 4px;
    font-weight: bold;
    width: 100%;
    cursor: pointer;
    transition: background-color 0.2s;
    margin-top: 0;
}

.formation-ux .ux-form-wrapper .wpcf7-submit:hover {
    background-color: #004494;
}

.formation-ux .ux-form-wrapper .wpcf7-spinner {
    display: none !important;
}

.formation-ux .ux-form-wrapper .wpcf7-not-valid-tip {
    font-size: 0.85rem;
    color: #dc3545;
    margin-top: 0.25rem;
    font-weight: normal;
}
/* Grille réglementaire Qualiopi */
.formation-ux .ux-reg-grid { 
    display: grid; 
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); 
    gap: 1.5rem; 
}

.formation-ux .ux-reg-card { 
    background: #ffffff; 
    border: 1px solid #e9ecef; 
    border-top: 4px solid #333333; 
    padding: 2rem; 
    border-radius: 4px; 
    box-shadow: 0 4px 6px rgba(0,0,0,0.02); 
    display: flex;
    flex-direction: column;
}

.formation-ux .ux-reg-card-highlight { 
    border-top-color: #f75a4e; 
    background: #f8f9fa; 
}

.formation-ux .ux-reg-title { 
    font-size: 1.1rem; 
    font-weight: bold;
    text-transform: uppercase; 
    letter-spacing: 0.05em; 
    margin-bottom: 1rem; 
    color: #111111; 
    border-bottom: 1px solid #dee2e6; 
    padding-bottom: 0.75rem; 
}

.formation-ux .ux-reg-content { 
    font-size: 0.95rem; 
    color: #555555; 
    flex-grow: 1;
}

.formation-ux .ux-reg-content ul,
.formation-ux .ux-reg-list { 
    padding-left: 1.25rem; 
    margin-top: 0.5rem; 
    list-style-type: disc;
}

.formation-ux .ux-reg-content li { 
    margin-bottom: 0.5rem; 
}
/* Formatage des blocs narratifs Qualiopi */
.formation-ux .ux-riche-text {
    color: #444;
    line-height: 1.7;
}

.formation-ux .ux-riche-text ul {
    padding-left: 1.5rem;
    margin-bottom: 1rem;
    list-style-type: disc;
}

.formation-ux .ux-riche-text p {
    margin-bottom: 1rem;
}

.formation-ux .ux-riche-text strong {
    color: #111;
}
/* Accordéons réglementaires (Interface liste) */
.formation-ux .ux-reg-accordion-wrapper {
    border-top: 1px solid #dee2e6;
}

.formation-ux .ux-reg-accordion-item {
    border-bottom: 1px solid #dee2e6;
}

.formation-ux .ux-reg-accordion-summary {
    padding: 1.25rem 0;
    font-size: 1.1rem;
    font-weight: bold;
    color: #111;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    list-style: none;
    transition: color 0.2s ease;
}

.formation-ux .ux-reg-accordion-summary::-webkit-details-marker {
    display: none;
}

.formation-ux .ux-reg-accordion-summary::after {
    content: '+';
    font-size: 1.5rem;
    font-weight: normal;
    color: #f75a4e;
    transition: transform 0.2s ease;
}

.formation-ux .ux-reg-accordion-item[open] .ux-reg-accordion-summary {
    color: #f75a4e;
}

.formation-ux .ux-reg-accordion-item[open] .ux-reg-accordion-summary::after {
    content: '−';
}

.formation-ux .ux-reg-accordion-content {
    padding: 0 0 1.5rem 0;
    color: #444;
}
/* Bouton secondaire (Outline / Fantôme) */
.formation-ux .ux-btn-programme {
    background-color: transparent;
    color: #ffffff;
    border: 2px solid #ffffff;
    /* Le padding vertical est légèrement réduit pour compenser l'épaisseur de la bordure et s'aligner avec le bouton primary */
    padding: 0.85rem 2rem; 
    transition: all 0.3s ease;
}

.formation-ux .ux-btn-programme:hover {
    background-color: #ffffff;
    color: #111111;
}
.formation-ux .ux-hero-satisfaction {
    font-size: 18px;
    color: rgba(255, 255, 255, 0.8);
    margin-top: 1rem;
}
/* Section Chiffres Clés */
.formation-ux .ux-bg-white { background-color: #ffffff; }
.formation-ux .ux-border-y { border-top: 1px solid #f3f4f6; border-bottom: 1px solid #f3f4f6; }

.formation-ux .ux-stats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
    text-align: center;
}

.formation-ux .ux-stat-item {
    border-right: 1px solid #f3f4f6;
}

.formation-ux .ux-stat-item:nth-child(even),
.formation-ux .ux-stat-item.border-none {
    border-right: none;
}

.formation-ux .ux-stat-number {
    font-size: 2.25rem;
    font-weight: 800;
    color: #f75a4e;
    margin-bottom: 0.5rem;
    line-height: 1.2;
}

.formation-ux .ux-stat-label {
    font-size: 0.75rem;
    font-weight: 700;
    color: #9ca3af;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

@media (min-width: 768px) {
    .formation-ux .ux-stats-grid {
        grid-template-columns: repeat(4, 1fr);
    }
    .formation-ux .ux-stat-item:nth-child(even) {
        border-right: 1px solid #f3f4f6;
    }
}

/* Section Outil ROI */
/* Section Outil ROI - Charte sombre */
.formation-ux .ux-roi-card {
    background-color: #161616;
    border-radius: 1.5rem;
    overflow: hidden;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.4);
    display: grid;
    grid-template-columns: 1fr;
}

@media (min-width: 1024px) {
    .formation-ux .ux-roi-card {
        grid-template-columns: 1fr 1fr;
    }
}

.formation-ux .ux-roi-content {
    padding: 3rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

@media (min-width: 1024px) {
    .formation-ux .ux-roi-content { padding: 4rem; }
}

.formation-ux .ux-roi-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.375rem 1rem;
    border-radius: 9999px;
    background-color: rgba(247, 90, 78, 0.1);
    border: 1px solid rgba(247, 90, 78, 0.25);
    color: #f75a4e;
    font-size: 0.875rem;
    font-weight: 700;
    width: max-content;
    margin-bottom: 2rem;
}

.formation-ux .ux-roi-icon {
    width: 1rem;
    height: 1rem;
    color: #f75a4e;
}

.formation-ux .ux-roi-title {
    font-size: 1.875rem;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 1.5rem;
    line-height: 1.2;
    text-align: left;
}

@media (min-width: 768px) {
    .formation-ux .ux-roi-title { font-size: 2.25rem; }
}

.formation-ux .ux-roi-title span {
    color: #f75a4e;
}

.formation-ux .ux-roi-text {
    color: #a1a1aa;
    font-size: 1.125rem;
    margin-bottom: 2rem;
    line-height: 1.625;
}

.formation-ux .ux-roi-text strong {
    color: #ffffff;
}

.formation-ux .ux-roi-list {
    list-style: none;
    padding: 0;
    margin: 0 0 2.5rem 0;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    color: #ffffff;
}

.formation-ux .ux-roi-list li {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

.formation-ux .ux-roi-check {
    background-color: rgba(247, 90, 78, 0.15);
    padding: 0.375rem;
    border-radius: 9999px;
    margin-top: 0.125rem;
}

.formation-ux .ux-roi-check svg {
    width: 1rem;
    height: 1rem;
    color: #f75a4e;
    flex-shrink: 0;
}

.formation-ux .ux-roi-list span {
    font-size: 1.125rem;
}

.formation-ux .ux-roi-image {
    position: relative;
    background-color: #161616;
    min-height: 300px;
}

@media (min-width: 1024px) {
    .formation-ux .ux-roi-image { min-height: 100%; }
}

.formation-ux .ux-roi-image img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.45;
    mix-blend-mode: luminosity;
}

.formation-ux .ux-roi-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, #161616 0%, transparent 100%);
}

.formation-ux .ux-roi-content {
    padding: 3rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

@media (min-width: 1024px) {
    .formation-ux .ux-roi-content { padding: 4rem; }
}

.formation-ux .ux-roi-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.375rem 1rem;
    border-radius: 9999px;
    background-color: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    color: #ffffff;
    font-size: 0.875rem;
    font-weight: 700;
    width: max-content;
    margin-bottom: 2rem;
}

.formation-ux .ux-roi-icon {
    width: 1rem;
    height: 1rem;
    color: #FF6B00; /* Accent color */
}

.formation-ux .ux-roi-title {
    font-size: 1.875rem;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 1.5rem;
    line-height: 1.2;
    text-align: left;
}

@media (min-width: 768px) {
    .formation-ux .ux-roi-title { font-size: 2.25rem; }
}

.formation-ux .ux-roi-title span {
    color: #FF6B00;
}

.formation-ux .ux-roi-text {
    color: #d1d5db;
    font-size: 1.125rem;
    margin-bottom: 2rem;
    line-height: 1.625;
}

.formation-ux .ux-roi-text strong {
    color: #ffffff;
}

.formation-ux .ux-roi-list {
    list-style: none;
    padding: 0;
    margin: 0 0 2.5rem 0;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    color: #ffffff;
}

.formation-ux .ux-roi-list li {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

.formation-ux .ux-roi-check {
    background-color: rgba(255, 255, 255, 0.1);
    padding: 0.375rem;
    border-radius: 9999px;
    margin-top: 0.125rem;
}

.formation-ux .ux-roi-check svg {
    width: 1rem;
    height: 1rem;
    color: #FF6B00;
    flex-shrink: 0;
}

.formation-ux .ux-roi-list span {
    font-size: 1.125rem;
}

.formation-ux .ux-roi-image {
    position: relative;
    background-color: #f75a4e;
    min-height: 300px;
}

@media (min-width: 1024px) {
    .formation-ux .ux-roi-image { min-height: 100%; }
}

.formation-ux .ux-roi-image img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.6;
    mix-blend-mode: luminosity;
}

.formation-ux .ux-roi-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, #f75a4e, transparent);
}
/* =========================================
   COMPOSANTS PAGE D'ACCUEIL (front-page)
========================================= */

/* Surtitres et liens */
.accueil-ux .ux-surtitre {
    text-transform: uppercase;
    font-size: 0.8rem;
    letter-spacing: 2px;
    color: #f75a4e;
    font-weight: bold;
    margin-bottom: 15px;
    display: block;
}

.accueil-ux .ux-link {
    font-weight: bold;
    color: #f75a4e;
    text-decoration: none;
    font-size: 0.95rem;
    transition: color 0.2s ease;
}

.accueil-ux .ux-link:hover {
    color: #004494;
    text-decoration: underline;
}

/* Grille de Réassurance (Logos & Badges) */
.accueil-ux .ux-trust-badges {
    display: flex;
    justify-content: center;
    align-items: stretch;
    gap: 1.5rem;
    flex-wrap: wrap;
    max-width: 900px;
    margin: 0 auto;
}

/* Cartes classiques (Douleurs) */
.accueil-ux .ux-card {
    padding: 3rem 2rem;
    background: #fff;
    border: 1px solid #f0f0f0;
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.accueil-ux .ux-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 30px 60px rgba(0,0,0,0.08);
}

.accueil-ux .ux-card h3 {
    font-size: 1.25rem;
    margin-bottom: 1rem;
    color: #111;
    line-height: 1.4;
}

.accueil-ux .ux-card p {
    color: #555;
    flex-grow: 1;
    margin-bottom: 1.5rem;
    font-size: 0.95rem;
}

/* Méthodologie : Mise en avant de l'étape ROI */
.accueil-ux .ux-method-highlight {
    background-color: #f8f9fa;
    border-radius: 6px;
    border-left-color: #f75a4e;
}
.accueil-ux .ux-method-highlight .ux-step-num {
    color: #f75a4e;
}

/* Carousel Avis Clients (Scroll-snap natif) */
.accueil-ux .ux-carousel-track {
    display: flex;
    gap: 1.5rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 2rem;
    margin-top: 3rem;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none; /* Firefox */
}

.accueil-ux .ux-carousel-track::-webkit-scrollbar {
    display: none; /* Chrome/Safari */
}

.accueil-ux .ux-carousel-slide {
    flex: 0 0 85%; /* Affichage partiel du suivant sur mobile */
    scroll-snap-align: center;
    background: #ffffff;
    border: 1px solid #e9ecef;
    border-radius: 8px;
    padding: 2.5rem 2rem;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

@media (min-width: 768px) {
    .accueil-ux .ux-carousel-slide { flex: 0 0 45%; }
}

@media (min-width: 1024px) {
    .accueil-ux .ux-carousel-slide { flex: 0 0 31%; }
}

.accueil-ux .ux-quote-mark {
    font-size: 4rem;
    color: #f1f3f5;
    font-family: "MuseoSans", serif;
    line-height: 1;
    position: absolute;
    top: 15px;
    left: 20px;
}

.accueil-ux .ux-review-text {
    font-size: 1rem;
    font-style: italic;
    color: #444;
    margin-top: 1.5rem;
    margin-bottom: 2rem;
    position: relative;
    z-index: 2;
    line-height: 1.6;
}

.accueil-ux .ux-reviewer-info strong {
    display: block;
    font-size: 1.05rem;
    color: #111;
}

.accueil-ux .ux-reviewer-info span {
    display: block;
    font-size: 0.85rem;
    color: #6c757d;
    margin-top: 4px;
}

/* Front-page borders */
.accueil-ux .ux-border-y {
    border-top: 1px solid #e9ecef;
    border-bottom: 1px solid #e9ecef;
}

/* --- ACCUEIL OPTIMISÉE 2026 --- */

.accueil-ux .ux-hero {
    padding: 120px 20px;
    background-attachment: fixed; /* Parallaxe léger pour le dynamisme */
}

/* =========================================
   GRILLE DE LOGOS AVEC ROTATION (SLIDE UP)
========================================= */
.formation-ux .ux-slider-grid,
.accueil-ux .ux-slider-grid {
    display: grid;
    /* 5 colonnes fixes sur desktop */
    grid-template-columns: repeat(5, 1fr);
    gap: 2.5rem;
    align-items: center;
    justify-items: center;
    max-width: 1100px;
    margin: 0 auto;
    /* TRÈS IMPORTANT : Masque les logos quand ils sortent du cadre */
    overflow: hidden; 
}

.formation-ux .ux-slider-slot,
.accueil-ux .ux-slider-slot {
    width: 100%;
    height: 80px; 
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    /* Assure que l'animation se fait bien dans ce cadre */
    overflow: hidden; 
}

.formation-ux .ux-slide-img,
.accueil-ux .ux-slide-img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    display: block;
    position: relative;
    
    /* ÉTAT PAR DÉFAUT : Visible et au centre */
    opacity: 1;
    transform: translateY(0);
    
    /* Transition sur la position et l'opacité */
    /* Temps très court (0.2s) adapté à la vitesse de 600ms */
    transition: transform 0.2s ease-out, opacity 0.2s ease-out;
    
    user-select: none;
    -webkit-user-drag: none;
}

/* ÉTAT 1 : Sortie (L'ancien logo monte et disparaît) */
.formation-ux .ux-slide-img.is-exiting {
    transform: translateY(-100%);
    opacity: 0;
}

/* ÉTAT 2 : Préparation (Le nouveau logo attend invisible en bas) */
/* Transition 'none' gérée par JS pour cet état */
.formation-ux .ux-slide-img.at-bottom {
    transform: translateY(100%);
    opacity: 0;
}

/* --- Responsive : Mobile --- */
@media (max-width: 768px) {
    .formation-ux .ux-slider-grid,
    .accueil-ux .ux-slider-grid {
        /* 3 colonnes sur mobile */
        grid-template-columns: repeat(3, 1fr);
        gap: 1.5rem;
    }
    .formation-ux .ux-slider-slot,
    .accueil-ux .ux-slider-slot {
        height: 50px;
    }
    
    /* Masque les slots 4 et 5 sur mobile */
    .formation-ux .ux-slider-slot:nth-child(n+4),
    .accueil-ux .ux-slider-slot:nth-child(n+4) {
        display: none;
    }
}

/* Barrettes de stats plus compactes et élégantes */
.accueil-ux .ux-stats-grid {
    padding: 20px 0;
}

.accueil-ux .ux-stat-number {
    font-size: 2.8rem;
    font-weight: 900;
}

/* Cartes de problématiques avec plus de contraste ( DNA DNA DNA DNA DNA DNA DNA DNA DNA DNA DNA DNA DNA Sur-mesure) */
.accueil-ux .ux-card {
    padding: 3rem 2rem;
    background: #fff;
    border: 1px solid #f0f0f0;
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.accueil-ux .ux-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 30px 60px rgba(0,0,0,0.08);
}

/* Formulaire CF7 : Nettoyage pour la homepage ( DNA DNA DNA DNA DNA DNA DNA Allié Stratégique) */
.accueil-ux .ux-form-wrapper {
    background: #fff;
    padding: 3rem;
    border-radius: 16px;
}

.accueil-ux .wpcf7-form p {
    margin-bottom: 1.2rem;
}

.accueil-ux .wpcf7-submit {
    background-color: #f75a4e !important;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 800 !important;
    padding: 1.2rem !important;
}

/* Timeline méthodologie */
.accueil-ux .ux-method-step {
    padding: 2rem;
    position: relative;
}

/* Vidéos Témoignages Carrousel (Layout Maquette) */
.accueil-ux .ux-video-carousel-wrapper {
    position: relative;
    overflow: hidden;
}

.accueil-ux .ux-video-carousel-track {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none; /* Firefox */
    -webkit-overflow-scrolling: touch;
    gap: 0;
}

.accueil-ux .ux-video-carousel-track::-webkit-scrollbar {
    display: none; /* Chrome/Safari */
}

.accueil-ux .ux-video-slide {
    flex: 0 0 100%;
    scroll-snap-align: center;
    padding: 0 10px; /* Évite que le contenu touche les bords lors du swipe */
}

/* Grille Interne : 2 colonnes Desktop, 1 colonne Mobile */
.accueil-ux .ux-video-slide-inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
    align-items: center;
}

@media (min-width: 992px) {
    .accueil-ux .ux-video-slide-inner {
        grid-template-columns: 1fr 1fr;
        gap: 5rem;
    }
}

/* Colonne de gauche (Textes) */
.accueil-ux .ux-interview-content {
    display: flex;
    flex-direction: column;
}

.accueil-ux .ux-reviewer-name {
    font-size: 2.5rem;
    font-weight: 900;
    color: #161616;
    margin-bottom: 0.5rem;
    line-height: 1.1;
}

.accueil-ux .ux-reviewer-title {
    font-size: 1.1rem;
    color: #6c757d;
    margin-bottom: 2.5rem;
    display: block;
}

.accueil-ux .ux-interview-quote {
    border-left: 5px solid #f75a4e;
    padding-left: 2rem;
}

.accueil-ux .ux-interview-quote p {
    font-size: 1.25rem;
    font-style: italic;
    color: #444;
    line-height: 1.6;
    margin: 0;
}

/* Colonne de droite (Vidéo) */

/* Container et Iframe Vidéo */
.accueil-ux .ux-video-container {
    position: relative;
    border-radius: 4px;
    overflow: hidden;
    box-shadow: 0 15px 35px rgba(0,0,0,0.1);
    aspect-ratio: 16 / 9;
    width: 100%;
    background-color: #000;
}

.accueil-ux .ux-video-iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: none;
    display: block;
}

/* Façade Image + Play Button */
.accueil-ux .ux-video-facade {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    cursor: pointer;
    z-index: 2;
}

.accueil-ux .ux-video-facade img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}

.accueil-ux .ux-video-facade:hover img {
    transform: scale(1.03);
}

.accueil-ux .ux-play-button {
    width: 70px;
    height: 70px;
    background-color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 10px 20px rgba(0,0,0,0.3);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 10;
    transition: transform 0.2s ease;
}

.accueil-ux .ux-video-facade:hover .ux-play-button {
    transform: translate(-50%, -50%) scale(1.1);
}

/* Flèches de navigation (En bas, centrées) */
.accueil-ux .ux-video-carousel-arrows {
    display: flex;
    justify-content: center;
    gap: 1.5rem;
    margin-top: 2rem;
}

.accueil-ux .ux-arrow-btn {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background-color: #f75a4e;
    color: white;
    border: none;
    outline: none; /* Supprime le contour par défaut */
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

/* Sécurité supplémentaire pour annuler le contour natif au clic */
.accueil-ux .ux-arrow-btn:focus {
    outline: none;
    box-shadow: none;
}

/* Passage en gris foncé au survol et au clic */
.accueil-ux .ux-arrow-btn:hover,
.accueil-ux .ux-arrow-btn:active {
    background-color: #333333; 
    transform: translateY(-2px);
}
.accueil-ux .ux-interview-content {
    display: flex;
    flex-direction: column;
}

.accueil-ux .ux-quote-icon {
    font-size: 5rem;
    color: #f1f3f5;
    font-family: Georgia, serif;
    line-height: 1;
    margin-bottom: -1rem;
}

.accueil-ux .ux-reviewer-info strong {
    display: block;
    font-size: 1.2rem;
    color: #161616;
}

.accueil-ux .ux-reviewer-info span {
    display: block;
    font-size: 0.95rem;
    color: #6c757d;
    margin-top: 5px;
}

.accueil-ux .ux-play-button {
    width: 80px;
    height: 80px;
    background-color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 10px 20px rgba(0,0,0,0.3);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 10;
}

.accueil-ux .ux-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background-color: #dee2e6;
    border: none;
    cursor: pointer;
    padding: 0;
    transition: background-color 0.2s ease;
}

.accueil-ux .ux-dot:hover {
    background-color: #adb5bd;
}

.accueil-ux .ux-dot.active {
    background-color: #f75a4e;
}

/* Tablette & Mobile */
@media (max-width: 768px) {
    @media (max-width: 768px) {
    /* 1. Correction de l'image de fond */
    .accueil-ux .ux-hero {
        background-size: cover !important;
        background-position: center center !important;
        background-repeat: no-repeat !important;
    }

    /* 2. Épuration (masquer le surtitre) */
    .accueil-ux .ux-surtitre {
        display: none !important;
    }

    /* 3. Réduction de la typographie */
    .accueil-ux .ux-hero h1 {
        font-size: 26px !important;
        line-height: 1.2 !important;
        margin-bottom: 15px !important;
    }

    .accueil-ux .ux-hero p {
        font-size: 16px !important;
        margin-bottom: 1.5rem !important;
        padding: 0 10px !important;
    }

    /* 4. Réorganisation des boutons en colonne */
    .accueil-ux .ux-hero-actions {
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
        padding: 0 10px !important;
    }

    .accueil-ux .ux-hero-actions .ux-btn {
        width: 100% !important;
        margin: 0 !important;
    }
}

    /* Empilement propre des boutons d'action */
    .accueil-ux .ux-hero-actions {
        flex-direction: column;
        gap: 0.75rem;
    }

       .accueil-ux .ux-conversion-grid {
        grid-template-columns: 1fr;
        gap: 3rem;
    }

    .accueil-ux .ux-desktop-only {
        display: none !important;
    }
    /* --- CORRECTIONS SECTION CONTACT MOBILE --- */
    
    /* Écrasement de la taille du titre en ligne (2.5rem -> 1.8rem) */
    .accueil-ux #contact h2 {
        font-size: 1.8rem !important;
        line-height: 1.3 !important;
    }

    /* Écrasement de l'espacement vertical (gap) en ligne */
    .accueil-ux .ux-conversion-grid {
        gap: 2.5rem !important;
    }

    /* Réduction du padding du bloc blanc du formulaire pour éviter le débordement */
    .accueil-ux .ux-form-wrapper {
        padding: 1.5rem !important;
        overflow-x: hidden; /* Sécurité contre les débordements des champs CF7 */
    }

    /* Sécurité supplémentaire pour le texte d'acceptation RGPD rouge */
    .accueil-ux .wpcf7-form > div[style*="background-color: #FF4842"] {
        padding: 1rem !important;
        font-size: 0.8rem !important;
    }
    /* Force les marges latérales de toute la section contact sur mobile */
    .accueil-ux #contact {
        padding-left: 20px !important;
        padding-right: 20px !important;
        overflow-x: hidden; /* Sécurité supplémentaire */
    }
    
    /* Ajustement du bloc blanc du formulaire pour qu'il respire mieux */
    .accueil-ux .ux-form-wrapper {
        padding: 1.5rem 1rem !important; 
    }
}


/* Formulaire CF7 : Nettoyage pour la homepage */
.accueil-ux .ux-form-wrapper {
    background: #fff;
    padding: 3rem;
    border-radius: 16px;
}

.accueil-ux .wpcf7-form p {
    margin-bottom: 1.2rem;
}

.accueil-ux .wpcf7-submit {
    background-color: #f75a4e !important;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 800 !important;
    padding: 1.2rem !important;
}

/* Timeline méthodologie */
.accueil-ux .ux-method-step {
    padding: 2rem;
    position: relative;
}

/* Tablette & Mobile */
@media (max-width: 768px) {
    .accueil-ux .ux-hero h1 {
        font-size: 2.2rem;
    }
    .accueil-ux .ux-conversion-grid {
        grid-template-columns: 1fr;
        gap: 3rem;
    }
}
/* --- NEWSROOM SEO --- */
.accueil-ux .ux-news-card {
    background: #fff;
    border: 1px solid #f0f0f0;
    border-radius: 12px;
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
    display: flex;
    flex-direction: column;
}

.accueil-ux .ux-news-card:hover {
    box-shadow: 0 15px 30px rgba(0,0,0,0.05);
    transform: translateY(-5px);
}

.accueil-ux .ux-news-image {
    display: block;
    height: 220px;
    background-size: cover;
    background-position: center;
    transition: opacity 0.2s ease;
}

.accueil-ux .ux-news-image:hover {
    opacity: 0.9;
}

.accueil-ux .ux-news-body {
    padding: 2rem;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

.accueil-ux .ux-news-tag {
    display: inline-block;
    padding: 0.2rem 0.8rem;
    background: rgba(247, 90, 78, 0.08);
    color: #f75a4e;
    font-size: 0.7rem;
    font-weight: 800;
    text-transform: uppercase;
    border-radius: 4px;
    margin-bottom: 1rem;
    width: fit-content;
}

.accueil-ux .ux-news-card h3 {
    font-size: 1.2rem;
    margin-bottom: 1.5rem;
    line-height: 1.4;
    color: #161616;
    flex-grow: 1;
    font-weight: 700;
}
/* Badge Qualiopi Responsive */
.accueil-ux .ux-qualiopi-card {
    display: flex;
    flex-direction: column; /* Empilé sur mobile */
    align-items: center;
    gap: 1.5rem;
    padding: 1.5rem;
    border-radius: 12px;
    text-align: center;
}

.accueil-ux .ux-qualiopi-img {
    height: auto;
    max-height: 100px; /* Plus petit sur mobile pour gagner de la place */
    width: auto;
    max-width: 100%;
    flex-shrink: 0;
}

/* Sur tablette et Desktop : Côte à côte */
@media (min-width: 768px) {
    .accueil-ux .ux-qualiopi-card {
        flex-direction: row;
        text-align: left;
        gap: 2rem;
    }
    .accueil-ux .ux-qualiopi-img {
        max-height: 150px; /* Taille normale sur grand écran */
    }
}
/* -------------------------------------
   PAGE DE FORMATION - OPTIMISATIONS
------------------------------------- */

/* Encadrement de la description ("Plus Carré") */
.formation-ux .ux-programme-box {
    background: #ffffff;
    border: 1px solid #e9ecef;
    border-radius: 12px;
    padding: 3rem;
    box-shadow: 0 15px 40px rgba(0,0,0,0.06);
    max-width: 900px;
    margin: 0 auto;
}

/* Amélioration de la lisibilité des séquences du programme */
.formation-ux .ux-programme-content h2,
.formation-ux .ux-programme-content h3 {
    color: #f75a4e;
    margin-top: 2.5rem;
    margin-bottom: 1rem;
    font-size: 1.35rem;
    border-bottom: 1px solid #f0f0f0;
    padding-bottom: 0.5rem;
    font-weight: 800;
}

.formation-ux .ux-programme-content h2:first-child,
.formation-ux .ux-programme-content h3:first-child {
    margin-top: 0;
}

/* Mise en retrait visuelle des points du programme pour aérer le texte */
.formation-ux .ux-programme-content ul {
    margin-bottom: 1.5rem;
    padding-left: 1.5rem;
    color: #444;
    line-height: 1.7;
}

.formation-ux .ux-programme-content p {
    color: #444;
    line-height: 1.7;
}

@media (max-width: 768px) {
    .formation-ux .ux-programme-box {
        padding: 1.5rem;
    }
}
/* ========================================================
   EXTENSION DES COMPOSANTS PARTAGÉS (PAGE FORMATION)
   (Permet d'utiliser le carrousel et la grille de logos)
======================================================== */

/* Grille de Logos B2B */
.formation-ux .ux-logos-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 3rem 2rem;
    align-items: center;
    justify-items: center;
    margin-bottom: 4rem;
}
.formation-ux .ux-logo-item {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 70px;
}
.formation-ux .ux-logo-item img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    transition: all 0.3s ease;
}

/* Carrousel Vidéo */
.formation-ux .ux-video-carousel-wrapper { position: relative; overflow: hidden; }
.formation-ux .ux-video-carousel-track { display: flex; overflow-x: auto; scroll-snap-type: x mandatory; scrollbar-width: none; -webkit-overflow-scrolling: touch; gap: 0; }
.formation-ux .ux-video-carousel-track::-webkit-scrollbar { display: none; }
.formation-ux .ux-video-slide { flex: 0 0 100%; scroll-snap-align: center; padding: 0 10px; }
.formation-ux .ux-video-slide-inner { display: grid; grid-template-columns: 1fr; gap: 3rem; align-items: center; }
.formation-ux .ux-interview-content { display: flex; flex-direction: column; }
.formation-ux .ux-reviewer-name { font-size: 2.5rem; font-weight: 900; color: #161616; margin-bottom: 0.5rem; line-height: 1.1; }
.formation-ux .ux-reviewer-title { font-size: 1.1rem; color: #6c757d; margin-bottom: 2.5rem; display: block; }
.formation-ux .ux-interview-quote { border-left: 5px solid #f75a4e; padding-left: 2rem; }
.formation-ux .ux-interview-quote p { font-size: 1.25rem; font-style: italic; color: #444; line-height: 1.6; margin: 0; }
.formation-ux .ux-video-container { position: relative; border-radius: 4px; overflow: hidden; box-shadow: 0 15px 35px rgba(0,0,0,0.1); aspect-ratio: 16 / 9; width: 100%; background-color: #000; }
.formation-ux .ux-video-iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none; display: block; }
.formation-ux .ux-video-facade { position: absolute; inset: 0; width: 100%; height: 100%; cursor: pointer; z-index: 2; }
.formation-ux .ux-video-facade img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.3s ease; }
.formation-ux .ux-video-facade:hover img { transform: scale(1.03); }
.formation-ux .ux-play-button { width: 70px; height: 70px; background-color: white; border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 10px 20px rgba(0,0,0,0.3); position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 10; transition: transform 0.2s ease; }
.formation-ux .ux-video-facade:hover .ux-play-button { transform: translate(-50%, -50%) scale(1.1); }
.formation-ux .ux-video-carousel-arrows { display: flex; justify-content: center; gap: 1.5rem; margin-top: 4rem; }
.formation-ux .ux-arrow-btn { width: 50px; height: 50px; border-radius: 50%; background-color: #f75a4e; color: white; border: none; outline: none; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: background-color 0.3s ease, transform 0.2s ease; }
.formation-ux .ux-arrow-btn:focus { outline: none; box-shadow: none; }
.formation-ux .ux-arrow-btn:hover, .formation-ux .ux-arrow-btn:active { background-color: #333333; transform: translateY(-2px); }

/* Adaptations Responsives partagées */
@media (min-width: 992px) {
    .formation-ux .ux-video-slide-inner { grid-template-columns: 1fr 1fr; gap: 5rem; }
}

@media (max-width: 992px) {
    .formation-ux .ux-logos-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
    .formation-ux .ux-logos-grid { grid-template-columns: repeat(2, 1fr); gap: 2rem 1.5rem; }
    .formation-ux .ux-logo-item { height: 50px; }
}
/* =========================================
   TOC FLOTTANT (TABLE DES MATIÈRES) - JAVASCRIPT & DESIGN
========================================= */
.formation-ux .ux-global-toc { display: none; }

@media (min-width: 1200px) {
    .formation-ux .ux-sidebar-wrapper {
        position: relative;
        z-index: 10;
        min-height: 500px;
    }

    /* La piste invisible : Z-index 999 pour passer au-dessus de TOUT */
    .formation-ux .ux-sidebar-track {
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        width: 100%;
        pointer-events: none; 
        z-index: 999; 
    }

    .formation-ux .ux-sidebar-track > .ux-container {
        height: 100%;
        position: relative;
    }

    /* ÉTAT 1 : Initial (Haut du wrapper) - Le sommaire "Widget" */
    .formation-ux .ux-global-toc {
        display: block;
        position: absolute;
        top: 0;
        left: calc(max(20px, calc((100vw - 1300px) / 2)));
        width: 290px;
        pointer-events: auto; 
        max-height: calc(100vh - 150px);
        overflow-y: auto;
        
        /* Design Widget Blanc */
        background-color: #ffffff;
        padding: 1.5rem 1.5rem 1.5rem 0.5rem;
        border-radius: 12px;
        box-shadow: 0 10px 40px rgba(0,0,0,0.08);
        border: 1px solid #f0f0f0;
    }

    /* ÉTAT 2 : Défilement (Piloté par JS - Fixé à l'écran) */
    .formation-ux .ux-global-toc.is-fixed {
        position: fixed;
        top: 150px;
    }

    /* ÉTAT 3 : Fin de section (Piloté par JS - Bloqué en bas) */
    .formation-ux .ux-global-toc.is-bottom {
        position: absolute;
        top: auto;
        bottom: 0;
    }

    .formation-ux .ux-toc-title {
    font-size: 0.85rem;
    text-transform: uppercase;
    color: #999;
    font-weight: 800;
    margin-bottom: 1rem;
    padding-left: 1.5rem;
    cursor: pointer;
    transition: color 0.2s ease;
}

.formation-ux .ux-toc-title:hover {
    color: #f75a4e;
}
    .formation-ux .formation-nav { list-style: none; padding: 0; margin: 0 0 0 1rem; border-left: 2px solid #eee; }
    .formation-ux .formation-nav a { display: block; padding: 0.6rem 1rem; font-size: 0.85rem; color: #6c757d; text-decoration: none; position: relative; }
    
    .formation-ux .formation-nav a::before {
        content: '';
        position: absolute;
        left: -2px;
        top: 0;
        height: 100%;
        width: 2px;
        background-color: #f75a4e;
        transform: scaleY(0);
        transition: transform 0.2s ease;
        transform-origin: left top;
    }
    
    .formation-ux .formation-nav a:hover { color: #111; }
    .formation-ux .formation-nav a:hover::before,
    .formation-ux .formation-nav a.active::before { transform: scaleY(1); }
    .formation-ux .formation-nav a.active { color: #f75a4e; font-weight: 700; }

    /* On repousse les éléments vers la droite pour laisser un large espace au menu */
    .formation-ux .ux-toc-push.ux-container, 
    .formation-ux .ux-toc-push .ux-container {
        max-width: 1300px !important;
        padding-left: 330px !important; 
        margin-left: auto !important;
        margin-right: auto !important;
    }
}

.formation-ux section[id], .formation-ux details[id] { scroll-margin-top: 100px; }

/* Correction de la grille sur une seule ligne (4 colonnes) */
@media (min-width: 992px) {
    .formation-ux .ux-grid-4 {
        display: grid !important;
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 1.5rem !important;
        align-items: stretch;
    }
}
/* =========================================
   CORRECTION DES PADDINGS MOBILE (PAGE FORMATION)
========================================= */

/* On sépare le padding vertical pour ne pas écraser le padding horizontal */
.formation-ux .ux-section-padding { 
    padding-top: 4rem; 
    padding-bottom: 4rem; 
    padding-left: 0; /* Réinitialisation pour éviter les conflits */
    padding-right: 0;
}

@media (max-width: 768px) {
    /* On force des marges de sécurité latérales sur TOUS les conteneurs */
    .formation-ux .ux-container {
        padding-left: 20px !important;
        padding-right: 20px !important;
    }
    
    /* On réduit légèrement l'espacement vertical sur mobile pour ne pas créer de "trous" blancs trop grands */
    .formation-ux .ux-section-padding {
        padding-top: 2.5rem;
        padding-bottom: 2.5rem;
    }
}
@media screen and (max-width: 768px) {
    /* 1. Correction de l'image de fond */
    .ux-hero {
        background-size: cover !important;
        background-position: center top !important;
        background-repeat: no-repeat !important;
    }

    /* 2. Réduction de la typographie */
    .ux-hero h1 {
        font-size: 26px !important;
        line-height: 1.2 !important;
        margin-bottom: 15px !important;
        padding: 0 10px;
    }

    .ux-hero p {
        font-size: 15px !important;
        line-height: 1.4 !important;
        padding: 0 10px;
    }

    /* 3. Suppression de la surcharge cognitive */
    .ux-hero .surtitre { 
        display: none !important;
    }
}