@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:ital,wght@0,100..700;1,100..700&display=swap');


/* ===== LOADING SCREEN ===== */
#loadingScreen {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    background-image: linear-gradient(120deg, rgb(255, 247, 230) 0%, rgb(239, 245, 255) 100%);
    transition: transform .4s cubic-bezier(0.83, 0, 0.17, 1);
    transform: translateX(0%);
}

#loadingScreen.hidden {
    transform: translateX(-100%);
    pointer-events: none;
}

#loadingScreen.initial {
    transform: translateX(100%);
    transition: none;
}

.loading-navbar .nav-logo img {
    height: 32px;
    opacity: .6;
    
}


#loadingScreen .bar {
    width: calc(100% + 20px);
    height: 2px;
    background-color: rgba(0, 0, 0, .05);
    border-radius: 10px;
    overflow: hidden;
    margin-top: 10px;
}

#loadingScreen .bar > div {
    width: 30%; /* On fixe une largeur pour l'élément qui bouge */
    height: 100%;
    background-color: var(--color-accent);
    border-radius: 10px;
    position: relative;
    /* On remplace le transition par une animation infinie */
    animation: infiniteScan 1s infinite ease-in-out;
    transition: .1s ease;
}

#loadingScreen.error .bar {
    background-color: #ffd6d4;
}

#loadingScreen.error .bar > div {
    background-color: #FF4136;
    width: 100%;
    animation: none;
}

@keyframes infiniteScan {
    0% {
        left: -30%;
        width: 10%;
    }
    50% {
        width: 30%;
    }
    100% {
        left: 100%;
        width: 10%;
    }
}


#loadingScreen > div > p {
    text-align: left;
    font-size: calc(var(--subparagraph) * .8);
    color: var(--color-grey);
    margin-top: 5px;
    opacity: .8;
}

#loadingScreen.error > div > p {
    color: #FF4136;
}








/* ===== RESET & BASE STYLES ===== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    --color-background: #FAFAFA;

    /* Colors */
    --color-black: #0F0F10;
    --color-white: #FAFAFA;
    --color-grey: #6B6B6B;
    --color-accent-dim: #DAE5FB;
    --color-accent: #2563eb;
    --color-accent-hover: #1147BB;


    --title: clamp(12px, 2vw, 32px);
    --subtitle: clamp(12px, 1.6vw, 24px);
    --paragraph: clamp(12px, 1.2vw, 24px);
    --subparagraph: clamp(12px, 1vw, 18px);
    
    /* Typography */
    --font-primary: 'IBM Plex Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    
    /* Grid System */
    --grid-columns: 5;
    --container-margin: 50px;
    
    /* Spacing */
    --spacing-md: 24px;
    --spacing-xl: 48px;
    --spacing-xxl: 64px;
}

body {
    font-family: var(--font-primary);
    font-weight: 400;
    line-height: 1.6;
    color: var(--color-grey-900);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    background-color: var(--color-background);
    user-select: none;
    overflow: hidden;
}

h1, h2, h3, h4, h5, h6 {
    letter-spacing: 0.01em;
}

section:not(.hero-section) {
    padding: var(--spacing-xxl) var(--container-margin);
    border-top: 1px solid var(--color-grey-200);
    background-color: var(--color-background);
}

section h2 {
    font-size: 2.5rem;
    margin-bottom: var(--spacing-xl);
    text-align: center;
}

a {
    color: var(--color-accent);
    text-decoration: none;
}

a:hover {
    color: var(--color-accent-hover);
}








/* 1. Largeur de la barre */
*::-webkit-scrollbar {
    width: 12px;
}

/* 2. Le fond (Track) */
*::-webkit-scrollbar-track {
    background: var(--color-white); /* Couleur de fond (gris très clair) */
    margin: 10px 0;
}

/* 3. La partie qui bouge (Thumb) */
*::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, .2); /* Couleur du curseur */
    border-radius: 10px;
    border: 4px solid var(--color-white);
    background-clip: padding-box;
}

/* 4. Effet au survol */
*::-webkit-scrollbar-thumb:hover {
    background: var(--color-grey); /* Devient un peu plus foncé au survol */
    border-radius: 6px;
    border: 3px solid var(--color-white);
}

/* 4. Effet au survol */
*::-webkit-scrollbar-thumb:active {
    background: var(--color-accent); /* Devient un peu plus foncé au survol */
}

/* ===== GRID OVERLAY (for development) ===== 
body::before {
    content: '';
    position: fixed;
    top: 0;
    left: var(--container-margin);
    right: var(--container-margin);
    bottom: 0;
    background-image: repeating-linear-gradient(to right, transparent, transparent calc(100% / var(--grid-columns) - 1px), rgba(0,0,0,.1) calc(100% / var(--grid-columns) - 1px), rgba(0,0,0,.1) calc(100% / var(--grid-columns)));
    pointer-events: none;
    z-index: 1000;
    opacity: .8;
}*/
    

/* DRIVER.jS styles
======================== */

.driver-popover {
	border-radius: 12px;
	padding: 6px;
    max-width: 400px;
    min-width: 300px;
}

.driver-popover * {
  	font-family: "IBM Plex Sans", sans-serif;
}

.driver-popover.driverjs-theme {
  background-color: var(--color-accent);
  color: var(--color-black);
}

.driver-popover-title {
	font-size: var(--paragraph) !important;
	font: inherit;
	font-weight: 500 !important;
	color: var(--color-accent-hover) !important;
	padding: 5px !important;
}

.driver-popover-description {
	font-weight: 500;
	font-size: var(--subparagraph) !important;
	padding: 5px 5px !important;
}

.driver-popover.driverjs-theme .driver-popover-title,
.driver-popover.driverjs-theme .driver-popover-description,
.driver-popover.driverjs-theme .driver-popover-progress-text {
  color: var(--color-black);
  font: inherit;
  font-family: "IBM Plex Sans", sans-serif;
}

.driver-popover button {
  font-family: "IBM Plex Sans", sans-serif;
  flex: 1;
  text-align: center;
  background-color: transparent;
  color: var(--color-grey);
  border: 1px solid rgba(0, 0, 0, .2);
  text-shadow: none !important;
  font-size: var(--subparagraph);
  padding: 10px 5px;
  border-radius: 6px;
  transition: .1s ease;
}

.driver-popover button:hover {
	box-shadow: 0 5px 10px rgba(0, 0, 0, .2);
  	color: var(--color-black);
}

.driver-popover-next-btn {
	background-color: var(--color-accent) !important;
	color: var(--color-white) !important;
  	text-shadow: none !important;
	border: none !important;
}

.driver-popover-next-btn:hover {
	background-color: var(--color-accent-hover) !important;
	color: var(--color-white) !important;
  	text-shadow: none !important;
	border: none !important;
}

.driver-popover-navigation-btns {
  justify-content: space-between;
  gap: 3px;
  width: calc(100% - 80px);
  flex-grow: 0;
}

.driver-popover-close-btn {
	font-weight: 400 !important;
	font-size: 24px !important;
	color: var(--color-grey) !important;
	background-color: transparent;
	box-shadow: none !important;
	border: none !important;
	padding: 5px !important;
}

.driver-popover-close-btn:hover {
	color: var(--color-accent-hover) !important;
	box-shadow: none;
  	border: none !important;
}



.driver-popover-progress-text {
	margin-left: 5px;
}

.driver-popover.driverjs-theme .driver-popover-arrow-side-left.driver-popover-arrow {
  border-left-color: var(--color-accent);
}

.driver-popover.driverjs-theme .driver-popover-arrow-side-right.driver-popover-arrow {
  border-right-color: var(--color-accent);
}

.driver-popover.driverjs-theme .driver-popover-arrow-side-top.driver-popover-arrow {
  border-top-color: var(--color-accent);
}

.driver-popover.driverjs-theme .driver-popover-arrow-side-bottom.driver-popover-arrow {
  border-bottom-color: var(--color-accent);
}












.main-nav {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 998;
    width: 100vw;
    height: 70px;
    padding: 5px 0 10px 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    transition: .2s ease;
}

.main-nav.solid {
    background-color: var(--color-background);
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.2);
}

.nav-container {
    width: 100%;
    height: 100%;
    padding: 0 var(--container-margin);
    display: flex;
    align-items: center;
}

.nav-logo {
    width: 260px;
}

.nav-logo a {
    text-decoration: none;
    color: black;
    cursor: pointer;
}

.nav-logo img {
    height: 24px;
    margin-top: 28px;
    margin-right: 10px;
    opacity: .4;
    mix-blend-mode: multiply;
    transition: .1s ease;
}

.nav-logo img:hover {
    opacity: .8;
}

.nav-logo img.mobile {
    height: 16px;
    margin-top: 5px;
}

.main-nav.solid .nav-logo img {
    opacity: 1;
}

.nav-logo h2 {
    font-size: 1.5rem;
    font-weight: 500;
    letter-spacing: -0.03rem;
    color: inherit;
    margin: 0;
}

.nav-logo h2 span {
    font-weight: 300;
}

.nav-item {
    padding: 0;
}

.nav-item > b {
    font-weight: 500;
    font-size: 10px;
    margin: 0;
    text-transform: uppercase;
    color: rgba(0, 0, 0, 0.6);
}


.nav-item p {
    font-weight: 400;
    font-size: 14px;
    margin: 0;
}

.nav-item.step p {
    font-weight: 500;
}

.nav-item.step[data-status] p::before {
    content: "";
    width: 8px;
    height: 8px;
    position: absolute;
    border-radius: 50px;
    margin-top: 8px;
    margin-left: -15px;
}

.nav-item.step[data-status="ready"] p::before {
    background-color: orange;
}

.nav-item.step[data-status="waiting"] p::before {
    background-color: green;
}

.nav-item.step[data-status="error"] p::before {
    background-color: red;
}

.nav-item.id p {
    font-family: monospace;
}



.nav-item.button {
    position: absolute;
    right: 20px;
    background: var(--color-accent-dim);
    color: var(--color-accent-hover);
    border-radius: 6px;
    padding: 20px 30px;
    box-sizing: border-box;
    transform: translateY(2px);
    border: 1px solid rgba(0, 0, 0, .1);
    transition: background-color .1s ease;
    cursor: pointer;
    display: flex;
    justify-content: left;
}

.nav-item.button:hover {
    background: rgba(0, 51, 255, 0.3);
}

.nav-item.button p {
    font-weight: 500;
}

.nav-item.button svg {
    width: 18px;
    margin-right: 10px;
}

.nav-item.revision {
    background: rgba(255, 140, 0, 0.2);
}

.nav-item.revision:hover {
    background: rgba(255, 140, 0, 0.4);
}




.side {
    background-color: rgba(0, 0, 0, 0.05);
    width: 260px;
    height: 100%;
    box-sizing: border-box;
    padding: 30px;
    padding-top: 80px;
    position: fixed;
    mix-blend-mode: luminosity;


    
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.side > .steps {
    margin-top: 20px;
}

.side > .steps div {
    padding-bottom: 50px;
    padding-left: 20px;
    border-left: 3px solid rgba(0, 0, 0, 0.8);
    transition: .1s ease;
}

.side > .steps div.hidden {
    display: none;
}

.side > .steps div.anim-hidden {
    opacity: 0;
    transform: translateX(-20px);
    pointer-events: none;
}



.side > .steps div h4::before {
    content: "";
    width: 11px;
    height: 11px;
    background-color: black;
    box-sizing: border-box;
    position: absolute;
    border-radius: 8px;
    margin-left: -26px;
    margin-top: 10px;
}

.side > .steps div.done h4::before {
    background-color: black;
}

.side > .steps div h4 {
    font-size: 16px;
    font-weight: 500;
    transform: translateY(-10px);
    color: rgba(0, 0, 0, 0.4);
}

.side > .steps div p {
    font-size: 12px;
    font-weight: 400;
    transform: translateY(-10px);
    color: black;
    opacity: .5;
}


.side > .steps div.ready {
    border-left: 2px dashed rgba(0, 0, 0, 0.4);
}
.side > .steps div.ready h4 {
    color: black;
}

.side > .steps div.ready h4::before {
    background-color: black;
}

.side > .steps div.ready ~ div h4::before {
    background-color: var(--color-background);
    border: 2px solid rgba(0, 0, 0, 0.4);
}

.side > .steps div.ready ~ div {
    border-left: 2px dashed rgba(0, 0, 0, 0.4);
}

.side > .steps div.ready p {
    opacity: 1;
}

.side > .steps div.done {
    border-left: 2px solid rgba(0, 0, 0, 0.8);
}

.side > .steps div.done:last-of-type {
    display: block;
}

.side > .steps div.ready ~ div:last-of-type,
.side > .steps div.ready:last-of-type {
    border-left: 3px solid transparent;
}









.wrapper {
    width: calc(100% - 260px);
    height: calc(100% - 80px - 30px);
    left: 260px;
    top: 70px;
    position: absolute;
    overflow: hidden;
    background-color: var(--color-background);
}

.wrapper > div {
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.wrapper > div .main {
    width: 100%;
    height: calc(100% - 150px);
}

.wrapper > div .main > .text {
    width: 100%;
    height: 100%;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
}

.wrapper > div .main .text img {
    height: 80%;
    mix-blend-mode: normal;
}

.wrapper > div .action {
    width: 100%;
    height: 130px;
    box-sizing: border-box;
    border-top: 1px solid rgba(0,0,0,.1);
}

.wrapper > div .action .bar {
    height: 3px;
    width: 100%;
    background-color: var(--color-accent-dim);
}

.wrapper > div .action .bar > div {
    background: var(--color-accent);
    height: 100%;
    width: 0;
    transition: .1s ease;
}


.wrapper > div .action .text {
    width: 100%;
    height: 130px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    opacity: .8;
}

.wrapper > div .action .text h4 {
    font-weight: 500;
    font-size: 20px;
    margin-bottom: 10px;
}

.wrapper > div .action .text p {
    font-size: 16px;
}





/* L'élément qui sert de base au skeleton */
.wrapper > div .main iframe {
    height: 100%;
    width: 100%;
    position: relative;
    overflow: hidden;
    border: none;
}

.wrapper > div .main.loading {
    background-color: rgba(0, 0, 0, .1); 
}

/* L'animation de balayage (shimmer) */
.wrapper > div .main.loading::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(
        90deg,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, 0.4) 50%,
        rgba(255, 255, 255, 0) 100%
    );
    animation: skeleton-shimmer 1.5s infinite;
}

@keyframes skeleton-shimmer {
    0% {
        transform: translateX(-100%);
    }
    100% {
        transform: translateX(100%);
    }
}

.wrapper > div .action .sign {
    display: flex;
    flex-direction: row;
}

.wrapper > div .action .sign .left {
    display: flex;
    flex-direction: column;
    padding: 10px;
}

.wrapper > div .action .sign .left a {
    background: rgba(0, 0, 0, 0.05);
    margin: 5px;
    padding: 15px;
    color: black;
    font-size: 14px;
    font-weight: 500;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: .1s ease;
}

.wrapper > div .action .sign .left a:hover {
    background-color: rgba(0, 0, 0, 0.1);
}

.wrapper > div .action .sign .left a svg {
    width: 18px;
    margin-right: 20px;
}

.wrapper > div .action .sign canvas {
    border-right: 1px solid rgba(0, 0, 0, 0.1);
    border-left: 1px solid rgba(0, 0, 0, 0.1);
    height: 100%;
    box-sizing: border-box;
    background-color: var(--color-accent-dim)
}

.wrapper > div .action .sign .info {
    position: absolute;
    margin-left: 330px;
    margin-top: 60px;
    opacity: .4;
    z-index: -1;
    background: red;
}

.wrapper > div .action .sign .clear svg {
    border-radius: 50px;
    background: rgba(0, 0, 0, 0.05);
    width: 20px;
    height: 20px;
    padding: 8px;
    box-sizing: content-box;
    margin-top: 10px;
    margin-left: -50px;
    cursor: pointer;
    transition: .1s ease;
}

.wrapper > div .action .sign .clear svg:hover {
    background-color: rgba(0, 0, 0, 0.2);
}

.wrapper > div .action .sign .clear svg.hidden {
    display: none;
}

.wrapper > div .action .sign .send {
    margin: 15px;
    height: 120px;
    border-radius: 10px;
    background: rgba(0, 0, 0, 0.05);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: .1s ease;
    overflow: hidden;
}

.wrapper > div .action .sign .send.hidden {
    height: 0;
    opacity: .8;
}

.wrapper > div .action .sign .send:hover {
    background: rgba(0, 0, 0, 0.1);
}

.wrapper > div .action .sign .send svg {
    margin-right: 20px;
    margin-left: 20px;
}

.wrapper > div .action .sign .send h4 {
    font-size: 14px;
    font-weight: 500;
}

.wrapper > div .action .sign .send p {
    font-size: 14px;
    font-weight: 400;
    width: 250px;
    padding-right: 30px;
    margin-top: 5px;
}




.wrapper .step.quote-request .main > div {
    transition: opacity .1s ease, max-height .2s ease, padding .2s ease;
    max-height: 100%;
    opacity: 1;
    overflow: hidden;
}

.wrapper .step.quote-request .main > div.hidden {
    max-height: 0;
    opacity: 0;
    padding-top: 0;
    padding-bottom: 0;
}


.wrapper .step.quote-request .main .fixed {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: flex-start;
    padding-top: 30px;
    justify-content: center;
}


.wrapper .step.quote-request .main .fixed > div {
    background-color: white;
    margin-right: 20px;
    width: calc(50% - 200px);
    border: 1px solid rgba(0, 0, 0, .2);
    border-radius: 6px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    cursor: pointer;
    transition: .1s ease;
}

.wrapper .step.quote-request .main .fixed > div.selected {
    border: 1px solid var(--color-accent);
    box-shadow: 0 5px 10px rgba(0, 0, 0, .1);
}

.wrapper .step.quote-request .main .fixed > div:hover,
.wrapper .step.quote-request .main .modules > div:hover {
    box-shadow: 0 10px 20px rgba(0, 0, 0, .1);
    border: 1px solid var(--color-accent);
}


.wrapper > .step.quote-request > .main > .fixed > div .text,
.wrapper .step.quote-request .main .modules > div .text {
    display: flex;
    flex-direction: column;
    justify-content: left;
    align-items: left !important;
    text-align: left;
    height: 150px;
}

.wrapper .step.quote-request .main .fixed > div .text h4,
.wrapper .step.quote-request .main .modules > div .text h4 {
    font-size: var(--paragraph);
    font-weight: 500;
}

.wrapper .step.quote-request .main .fixed > div:hover .text h4,
.wrapper .step.quote-request .main .modules > div:hover .text h4 {
    color: var(--color-accent-hover);
}

.wrapper .step.quote-request .main .fixed > div.selected .text h4,
.wrapper .step.quote-request .main .modules > div.selected .text h4 {
    color: var(--color-accent-hover);
}


.wrapper .step.quote-request .main .fixed > div .text span,
.wrapper .step.quote-request .main .modules > div .text span {
    font-size: var(--subparagraph);
    font-weight: 400;
    display: block;
}

.wrapper .step.quote-request .main .fixed > div:hover .text span,
.wrapper .step.quote-request .main .modules > div:hover .text span {
    color: var(--color-accent);
}

.wrapper .step.quote-request .main .fixed > div.selected .text span,
.wrapper .step.quote-request .main .modules > div.selected .text span {
    color: var(--color-accent);
}

.wrapper .step.quote-request .main .fixed > div .text p,
.wrapper .step.quote-request .main .modules > div .text p {
    font-size: var(--subparagraph);
    font-weight: 400;
    color: gray;
}


.wrapper .step.quote-request .main .fixed > div .image,
.wrapper .step.quote-request .main .modules > div .image {
    background: rgba(0, 0, 0, .05);
    width: 100%;
    height: calc(100vh - 600px);
    border-radius: 3px;
    margin: 10px 0;
    background-size: cover;
    background-position: center;
}

.wrapper .step.quote-request .main .fixed > div .price,
.wrapper .step.quote-request .main .modules > div .price {
    text-align: right;
}

.wrapper .step.quote-request .main .fixed > div .price span,
.wrapper .step.quote-request .main .modules > div .price span {
    font-size: calc(var(--subparagraph) * .8);
    text-transform: uppercase;
    color: var(--color-grey);
}

.wrapper .step.quote-request .main .fixed > div .price h4,
.wrapper .step.quote-request .main .modules > div .price h4 {
    font-size: var(--paragraph);
    color: var(--color-black);
    font-weight: 500;
}

.wrapper .step.quote-request .main .fixed > div.selected .price h4 {
    color: var(--color-accent);
}





.wrapper .step.quote-request .main .modules {
    height: 100%;
    padding: 20px;
    padding-top: 0;
    transform: translateY(-10px);
    display: block;
    overflow: scroll;
    /* Le masque de transparence */
    -webkit-mask-image: linear-gradient(to bottom, black calc(100% - 100px), transparent 100%);
    mask-image: linear-gradient(to bottom, black calc(100% - 100px), transparent 100%);
}


.wrapper .step.quote-request .main .modules > div {
    width: calc(33vw - 120px);
    max-width: 600px;
    display: inline-block;
    background-color: white;
    margin: 10px;
    border: 1px solid rgba(0, 0, 0, .2);
    border-radius: 6px;
    padding: 20px;
    cursor: default;
    transition: .1s ease;
}

.wrapper .step.quote-request .main .modules > div.selected {
    border: 1px solid var(--color-accent);
}

.wrapper .step.quote-request .main .modules > div.selected:hover {
    border: 1px solid var(--color-accent);
}

.wrapper .step.quote-request .main .modules > div:hover {
    border: 1px solid rgba(0, 0, 0, .1);
}


.wrapper .step.quote-request .main .modules > div .stepper {
    border: 1px solid rgba(0, 0, 0, .2);
    border-radius: 6px;
    width: 170px;
    float: left;
    margin-top: 25px;
    padding: 3px;
    display: flex;
    flex-direction: row;
}

.wrapper .step.quote-request .main .modules > div:hover .stepper {
    border: 1px solid var(--color-accent);
}

.wrapper .step.quote-request .main .modules > div .stepper input {
    font-size: var(--subparagraph);
    font-weight: 500;
    width: 100%;
    text-align: center;
    padding: 5px 0;
    outline: none;
    border: none;
    display: flex;
    justify-content: center;
    align-items: center;
    appearance: none;
    user-select: none;
    cursor: default;
}


.wrapper .step.quote-request .main .modules > div .stepper button {
    font-size: var(--subparagraph);
    border: none;
    outline: none;
    background-color: var(--color-white);
    padding: 0 20px;
    cursor: pointer;
    border-radius: 3px;
}

.wrapper .step.quote-request .main .modules > div .stepper button.disabled {
    color: var(--color-grey);
    cursor: default;
    opacity: .5;
}

.wrapper .step.quote-request .main .modules > div .stepper button.disabled:hover {
    color: var(--color-grey);
    background-color: var(--color-white);
    cursor: default;
}

.wrapper .step.quote-request .main .modules > div:hover .stepper input {
    color: var(--color-accent-hover);
}

.wrapper .step.quote-request .main .modules > div:hover .stepper button {
    color: var(--color-accent);
}

.wrapper .step.quote-request .main .modules > div .stepper button:hover {
    background-color: var(--color-accent);
    color: var(--color-white);
}

.wrapper .step.quote-request .main .modules > div .stepper button:active {
    background-color: var(--color-accent-hover);
    color: var(--color-white);
}


.wrapper .step.quote-request .main .details {
    display: flex;
    flex-direction: row;
    width: 100%;
    height: 100%;
}

.wrapper .step.quote-request .main .details > .summary {
    width: 300px;
    height: 100%;
    box-sizing: border-box;
    padding: 0;
    border-right: 1px solid rgba(0, 0, 0, .1);
    overflow: hidden;
}

.wrapper .step.quote-request .main .details > .summary > h4 {
    font-size: var(--paragraph);
    font-weight: 500;
    color: var(--color-black);
    padding: 0 10px;
    margin-top: 20px;
}

.wrapper .step.quote-request .main .details > .summary > p {
    font-size: var(--subparagraph);
    font-weight: 400;
    width: 100%;
    color: var(--color-grey);
    padding: 0 10px;
}


.wrapper .step.quote-request .main .details > .summary .list {
    overflow-y: scroll;
    height: calc(100% - 90px);
    padding-left: 10px;
    padding-right: 5px;
    position: relative; /* Indispensable pour caler le dégradé */
}

.wrapper .step.quote-request .main .details > .summary .list > div {
    border-radius: 6px;
    border: 1px solid rgba(0, 0, 0, .1);
    margin: 10px 0;
    box-sizing: border-box;
    padding: 5px;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
    cursor: pointer;
    transition: .1s ease;
}

.wrapper .step.quote-request .main .details > .summary .list > div:last-of-type {
    margin-bottom: 50px;
}

.wrapper .step.quote-request .main .details > .summary .list > div:hover {
    box-shadow: 0 10px 20px rgba(0, 0, 0, .1);
    color: var(--color-accent);
}

.wrapper .step.quote-request .main .details > .summary .list > div.selected {
    box-shadow: 0 10px 20px rgba(0, 0, 0, .1);
    border: 1px solid var(--color-accent);
    cursor: default;
}

.wrapper .step.quote-request .main .details > .summary .list > div .text {
    margin-left: 5px;
}

.wrapper .step.quote-request .main .details > .summary .list > div .image {
    width: 60px;
    border-radius: 3px;
    height: 60px;
    clip-path: inset(0 0 0 0);
    overflow: hidden; /* C'est souvent ICI que ça se joue */
    position: relative;
    contain: paint;              /* Optimisation navigateur : ne dessine rien hors cadre */
}

.wrapper .step.quote-request .main .details > .summary .list > div .image g {
    overflow: hidden;
}


.wrapper .step.quote-request .main .details > .summary .list > div.selected .image {
    opacity: 1;
}

.wrapper .step.quote-request .main .details > .summary .list > div span {
    font-size: var(--subparagraph);
    color: var(--color-grey);
    text-transform: uppercase;
}

.wrapper .step.quote-request .main .details > .summary .list > div h4 {
    font-size: var(--subparagraph);
    color: var(--color-black);
    font-weight: 500;
}

.wrapper .step.quote-request .main .details > .summary .list > div:hover h4 {
    color: var(--color-accent);
}

.wrapper .step.quote-request .main .details > .summary .list > div.selected h4 {
    color: var(--color-accent-hover);
}


.wrapper .step.quote-request .main .details > div:not(.summary) > h4 {
    font-size: var(--paragraph);
    font-weight: 500;
    color: var(--color-black);
    margin-left: 10px;
    margin-top: 10px;
}

.wrapper .step.quote-request .main .details > div:not(.summary) > p {
    font-size: var(--subparagraph);
    font-weight: 400;
    width: 100%;
    color: var(--color-grey);
    margin-left: 10px;
    margin-bottom: 20px;
}



.wrapper .step.quote-request .main .details > .options .controls-top {
    width: 100%;
    display: flex;
    flex-direction: row;
}

.wrapper .step.quote-request .main .details > .options .control-group {
    width: 100%;
    margin-right: 20px;
}

.wrapper .step.quote-request .main .details > .options .control-group p {
    margin-left: 10px;
    font-size: calc(var(--subparagraph) * .8);
    text-transform: uppercase;
    color: var(--color-grey);
    margin-bottom: 10px;
}

.wrapper .step.quote-request .main .details > .options .control {
    border: 1px solid rgba(0, 0, 0, .1);
    border-radius: 6px;
    padding: 10px;
    box-sizing: border-box;
    margin-bottom: 10px;
}

.wrapper .step.quote-request .main .details > .options .control svg {
    float: left;
    margin: 15px;
    margin-left: 5px;
}

.wrapper .step.quote-request .main .details > .options .control h4 {
    font-size: var(--subparagraph);
    font-weight: 500;
}


.wrapper .step.quote-request .main .details > .options .control .badge-selector {
    background: rgba(0, 0, 0, .05);
    border-radius: 6px;
    display: inline-block;
    padding: 5px;
}

.wrapper .step.quote-request .main .details > .options .control .badge-selector button {
    height: 100%;
    border: none;
    outline: none;
    background-color: transparent;
    padding: 10px;
    font-family: "IBM Plex Sans", sans-serif;
    font-weight: 500;
    padding-bottom: 8px;
    justify-content: left;
    align-items: left;
    text-align: left;
    cursor: pointer;
}

.wrapper .step.quote-request .main .details > .options .control .badge-selector button.active {
    box-shadow: 0 10px 20px rgba(0, 0, 0, .1);
    color: var(--color-accent);
    background-color: var(--color-white);
    border-radius: 3px;
    cursor: default;
    text-align: left;
}



.wrapper .step.quote-request .main .details > .options .control .badge-selector button span {
    display: block;
    text-align: left;
    font-size: calc(var(--subparagraph) * .8);
    font-weight: 400;
    color: var(--color-grey);
}

.wrapper .step.quote-request .main .details > .options .control textarea {
    font-family: "IBM Plex Sans", sans-serif;
    font-size: calc(var(--subparagraph) * .8);
    width: calc(100% - 50px);
    outline: none;
    appearance: none;
    background: var(--color-white);
    box-shadow: 0 5px 50px rgba(0, 0, 0, .1);
    box-sizing: border-box;
    padding: 10px;
    height: calc(100vh - 450px);
    border: none;
    border-radius: 6px;
    resize: none;
}



.wrapper .step.quote-request .main .details > div:not(.summary) {
    width: calc(100% - 300px);
    transition: .2s ease;
    overflow: hidden;
    padding: 10px;
    white-space: nowrap;
}



.wrapper .step.quote-request .main .details > div.hidden {
    width: 0;
    padding: 10px 0;
    opacity: .5;
}




.wrapper .step.quote-request .main .details > .contact:not(.summary) {
    white-space: normal;
}

.wrapper .step.quote-request .main .details > .contact input {
    padding: 10px;
    font-family: "IBM Plex Sans", sans-serif;
    font-weight: 400;
    font-size: var(--subparagraph);
    color: var(--color-black);
    border-radius: 3px;
    width: 40%;
    margin: 5px;
    outline: none;
    border: 1px solid rgba(0, 0, 0, .2);
}

.wrapper .step.quote-request .main .details > .contact input:focus {
    color: var(--color-black);
    border: 1px solid var(--color-accent-hover);
}


.wrapper .step.quote-request .main .details > .contact input.invalid {
    color: #FF4136;
    border-color: red;
}

.wrapper .step.quote-request .main .details > .contact input.invalid::placeholder {
    color: #FF4136;
}

.wrapper .step.quote-request .main .details > .contact:not(.summary) > p {
    margin-bottom: 10px;
}

.wrapper .step.quote-request .main .details > .contact:not(.summary) > p:last-of-type {
    margin-top: 30px;
}



.wrapper .step.quote-request .main .upload {
    padding: 20px;
    height: 100%;
    display: flex;
    flex-direction: row;
}

.wrapper .step.quote-request .main .upload .file-list {
    border: 1px solid rgba(0, 0, 0, .2);
    border-radius: 16px;
    padding: 10px;
    width: 450px;
    box-sizing: border-box;
    height: 100%;
    overflow-y: auto;
}

.wrapper .step.quote-request .main .upload .file-list > div,
.wrapper .step.meeting .main > div > .files > .list > div {
    display: flex;
    flex-direction: row;
    box-shadow: 0 5px 15px rgba(0, 0, 0, .2);
    padding: 10px;
    border-radius: 6px;
    margin-bottom: 10px;
    transition: .1s ease;
    border: 1px solid transparent;
}

.wrapper .step.quote-request .main .upload .file-list > div.success,
.wrapper .step.meeting .main > div > .files > .list > div.success {
    box-shadow: 0 0px 0px rgba(0, 0, 0, .1);
    border: 1px solid #3D9970;
}

.wrapper .step.quote-request .main .upload .file-list > div.existing,
.wrapper .step.meeting .main > div > .files > .list > div.existing {
    box-shadow: 0 0px 0px rgba(0, 0, 0, .1);
    border: 1px solid rgba(0, 0, 0, .2);
}

.wrapper .step.quote-request .main .upload .file-list > div.error,
.wrapper .step.meeting .main > div > .files > .list > div.error {
    box-shadow: 0 0px 0px rgba(0, 0, 0, .1);
    border: 1px solid #FF4136;
}


.wrapper .step.quote-request .main .upload .file-list > div .file-icon,
.wrapper .step.meeting .main > div > .files > .list > div .file-icon {
    height: auto;
    width: auto;
    padding: 10px;
    margin-right: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}


/* L'animation de pulsation */
@keyframes iconPulse {
    0% { opacity: 1;}
    50% { opacity: 0.6; }
    100% { opacity: 1; }
}

/* Application à l'icône pendant l'upload (quand pas encore .success ou .error) */
.wrapper .step.quote-request .main .upload .file-list > div:not(.success, .error) .file-icon,
.wrapper .step.meeting .main > div > .files > .list > div:not(.success, .error) .file-icon {
    animation: iconPulse 1.5s infinite ease-in-out;
    color: var(--color-accent); /* Optionnel : force la couleur sur ton bleu/couleur principale */
}

.wrapper .step.quote-request .main .upload .file-list > div.success .file-icon svg,
.wrapper .step.meeting .main > div > .files > .list > div.success .file-icon svg {
    color: #3D9970;
}

.wrapper .step.quote-request .main .upload .file-list > div.error .file-icon svg,
.wrapper .step.meeting .main > div > .files > .list > div.error .file-icon svg {
    color: #FF4136;
}

.wrapper .step.quote-request .main .upload .file-list > div.existing .file-icon svg,
.wrapper .step.meeting .main > div > .files > .list > div.existing .file-icon svg {
    color: var(--color-grey);
}

.wrapper .step.quote-request .main .upload .file-list > div .file-details,
.wrapper .step.meeting .main > div > .files > .list > div .file-details {
    display: flex;
    flex-direction: column;
    justify-content: left;
    width: calc(100% - 50px);
}

.wrapper .step.quote-request .main .upload .file-list > div .file-details .file-info,
.wrapper .step.meeting .main > div > .files > .list > div  .file-details .file-info {
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
/* Le conteneur qui masque ce qui dépasse */
.wrapper .step.quote-request .main .upload .file-list > div .file-details .file-info,
.wrapper .step.meeting .main > div > .files > .list > div .file-details .file-info {
    overflow: hidden;
    width: 100%; /* Ou une largeur fixe */
}

.wrapper .step.quote-request .main .upload .file-list > div .file-details .file-info .marquee-shadow.is-scrolling,
.wrapper .step.meeting .main > div > .files > .list > div .file-details .file-info .marquee-shadow.is-scrolling {
    mask-image: linear-gradient(to right, black 90%, transparent);
    transition: .1s ease;
}

.wrapper .step.quote-request .main .upload .file-list > div:hover .file-details .file-info .marquee-shadow.is-scrolling,
.wrapper .step.meeting .main > div > .files > .list > div:hover .file-details .file-info .marquee-shadow.is-scrolling {
    mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
}

/* Le conteneur qui anime */
.wrapper .step.quote-request .main .upload .file-list > div .file-details .file-info .marquee-wrapper,
.wrapper .step.meeting .main > div > .files > .list > div  .file-details .file-info .marquee-wrapper {
    display: flex;
    width: max-content; 
}

/* État normal : Pas d'animation, l'élément reste au début */
.wrapper .step.quote-request .main .upload .file-list > div .file-details .file-info .marquee-shadow.is-scrolling .marquee-wrapper,
.wrapper .step.meeting .main > div > .files > .list > div .file-details .file-info .marquee-shadow.is-scrolling .marquee-wrapper {
    animation: none; /* L'animation n'existe pas par défaut */
    transform: translateX(0); /* On s'assure qu'il est au début */
    transition: .1s ease;
}

/* État Hover : On injecte l'animation */
.wrapper .step.quote-request .main .upload .file-list > div:hover .file-details .file-info .marquee-shadow.is-scrolling .marquee-wrapper,
.wrapper .step.meeting .main > div > .files > .list > div:hover .file-details .file-info .marquee-shadow.is-scrolling .marquee-wrapper {
    animation: marquee-pro 6s linear infinite;
    animation-play-state: running;
}

.wrapper .step.quote-request .main .upload .file-list > div .file-details .file-info .file-name,
.wrapper .step.meeting .main > div > .files > .list > div  .file-details .file-info .file-name {
    font-size: var(--subparagraph);
    font-weight: 500;
    color: var(--color-black);
    white-space: nowrap;
    padding-right: 20px; /* Espace entre la fin et le début du clone */
    transition: .1s ease;
}

/* L'animation qui boucle sur 50% car on a doublé le texte */
@keyframes marquee-pro {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}



.wrapper .step.quote-request .main .upload .file-list > div .file-details .file-info .file-name[href],
.wrapper .step.meeting .main > div > .files > .list > div .file-details .file-info .file-name[href] {
    text-decoration: underline;
}

.wrapper .step.quote-request .main .upload .file-list > div .file-details .file-info .file-name[href]:hover,
.wrapper .step.meeting .main > div > .files > .list > div .file-details .file-info .file-name[href]:hover  {
    color: var(--color-grey);
}

.wrapper .step.quote-request .main .upload .file-list > div .file-details .file-info span.file-type,
.wrapper .step.meeting .main > div > .files > .list > div .file-details .file-info span.file-type {
    font-family: "IBM Plex Sans", sans-serif;
    font-size: calc(var(--subparagraph) * .8);
    font-weight: 500;
    color: var(--color-accent);
    display: flex;
    align-items: center;
}

.wrapper .step.quote-request .main .upload .file-list > div.success .file-details .file-info span.file-type,
.wrapper .step.meeting .main > div > .files > .list > div.success .file-details .file-info span.file-type {
    color: #3D9970;
}

.wrapper .step.quote-request .main .upload .file-list > div.error .file-details .file-info span.file-type,
.wrapper .step.meeting .main > div > .files > .list > div  .file-details .file-info span.file-type {
    color: #FF4136;
}

.wrapper .step.quote-request .main .upload .file-list > div.existing .file-details .file-info span.file-type,
.wrapper .step.meeting .main > div > .files > .list > div.existing .file-details .file-info span.file-type {
    color: var(--color-grey);
}


.wrapper .step.quote-request .main .upload .file-list > div .file-details .file-info span.file-type svg,
.wrapper .step.meeting .main > div > .files > .list > div .file-details .file-info span.file-type svg {
    display: inline-block;
    margin-right: 6px;
    height: 18px;
    width: 18px;
    fill: currentColor;
}

.wrapper .step.quote-request .main .upload .file-list > div .progress-wrapper {
    width: 100%;
    height: 2px;
    background-color: var(--color-accent-dim);
    border-radius: 50px;
}

.wrapper .step.quote-request .main .upload .file-list > div .progress-wrapper div {
    width: 30%;
    height: 100%;
    border-radius: 50px;
    background: var(--color-accent);
    transition: .1s ease;
}

.wrapper .step.quote-request .main .upload .file-list > div.success .progress-wrapper {
    display: none;
}


.wrapper .step.quote-request .main .upload .file-list > div .file-remove {
    width: 60px;
    margin-left: 20px;
    border: 1px solid transparent;
    border-radius: 3px;
    background-color: var(--color-white);
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: .1s ease;
}

.wrapper .step.quote-request .main .upload .file-list > div .file-remove:hover {
    border: 1px solid var(--color-accent);
}

.wrapper .step.quote-request .main .upload .file-list > div .file-remove svg {
    width: 18px;
    fill: var(--color-grey);
    transition: .1s ease;
}

.wrapper .step.quote-request .main .upload .file-list > div .file-remove:hover svg {
    fill: var(--color-accent);
}


.wrapper .step.quote-request .main .upload .drop-zone {
    height: 100%;
    width: 100%;
    margin-right: 20px;
    border: 2px dashed var(--color-accent);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    cursor: pointer;
}

.wrapper .step.quote-request .main .upload .drop-zone:not(.disabled):hover {
    border: 2px dashed var(--color-accent-hover);
}

.wrapper .step.quote-request .main .upload .drop-zone.disabled {
    border: 2px dashed var(--color-grey);
    opacity: .4;
}

.wrapper .step.quote-request .main .upload .drop-zone.drag-over {
    border: 2px solid var(--color-accent-hover);
}

.wrapper .step.quote-request .main .upload .drop-zone svg {
    width: 48px;
    height: 48px;
    fill: var(--color-accent-dim);
    animation: iconPulse 2s linear infinite;
}

.wrapper .step.quote-request .main .upload .drop-zone.disabled svg {
    fill: rgba(0, 0, 0, .2);
}

.wrapper .step.quote-request .main .upload .drop-zone h4 {
    font-size: var(--subtitle);
    color: var(--color-accent);
    font-weight: 500;
    transition: .1s ease;
}

.wrapper .step.quote-request .main .upload .drop-zone:not(.disabled):hover h4 {
    color: var(--color-accent-hover);
}

.wrapper .step.quote-request .main .upload .drop-zone.disabled h4 {
    color: var(--color-black);
}


.wrapper .step.quote-request .main .upload .drop-zone.drag-over h4 {
    color: var(--color-accent-hover);
}



.wrapper .step.quote-request .main .upload .drop-zone.disabled h4 {
    fill: var(--color-accent-gray);
    animation: iconPulse 2s linear infinite;
}


.wrapper .step.quote-request .main .upload .drop-zone p {
    color: var(--color-grey);
    font-weight: 400;
}

.wrapper .step.quote-request .main .upload .drop-zone.disabled p {
    fill: var(--color-accent-gray);
    animation: iconPulse 2s linear infinite;
}



.wrapper .step.quote-request .main .upload p.info-note {
    position: relative;
    background-color: rgba(0, 0, 0, .05);
    right: 0;
    padding: 10px;
    border-radius: 6px;
    width: 100%;
    color: var(--color-grey);
}

.wrapper .step.quote-request .main .upload p.info-note b {
    display: block;
    font-weight: 500;
    margin-bottom: 10px;
    color: var(--color-black);
}


.wrapper .step.quote-request .main .upload p.info-note button {
    border: none;
    border-radius: 6px;
    display: block;
    padding: 10px;
    width: 100%;
    box-shadow: 0 5px 15px rgba(0, 0, 0, .1);
    margin-top: 10px;
    text-align: center;
    background-color: var(--color-accent);
    color: var(--color-white);
    font-weight: 500;
    font-size: var(--subparagraph);
    cursor: pointer;
    transition: .1s ease;
}


.wrapper .step.quote-request .main .upload p.info-note button:hover {
    background-color: var(--color-accent-hover);
}



.wrapper .step.quote-request .main .upload p.info-note button.second {
    background-color: white;
    border: 1px solid rgba(0, 0, 0, .2);
    color: var(--color-black);
    box-shadow: 0 0 0 rgba(0, 0, 0, .1);
}

.wrapper .step.quote-request .main .upload p.info-note button.second:hover {
    box-shadow: 0 5px 15px rgba(0, 0, 0, .1);
    color: var(--color-grey);
}


.wrapper .step.quote-request .main .submit {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

.wrapper .step.quote-request .main .submit h1 {
    font-size: var(--title);
    color: var(--color-black);
    font-weight: 500;
    margin: 2vh 0;
}

.wrapper .step.quote-request .main .submit h1 p {
    font-weight: var(--paragraph);
    font-weight: 400;
    color: var(--color-grey);
    margin: 2vh 0;
}

.wrapper .step.quote-request .main .submit .timeline {
    box-shadow: 0 10px 20px rgba(0, 0, 0, .2);
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-radius: 6px;
    padding: 20px;
    width: 60vw;
    min-width: 600px;
    margin: 5vh 0;
}

.wrapper .step.quote-request .main .submit .timeline .text {
    display: flex;
    flex-direction: column;
    width: auto;
    margin: 0 10px;
}


.wrapper .step.quote-request .main .submit .timeline .text h4 {
    font-weight: 500;
    font-size: var(--paragraph);
}

.wrapper .step.quote-request .main .submit .timeline .text p {
    font-size: var(--subparagraph);
    font-weight: 500;
    color: var(--color-grey);
}

.wrapper .step.quote-request .main .submit .timeline .text:first-of-type p {
    color: var(--color-accent);
}

.wrapper .step.quote-request .main .submit .timeline .text p svg {
    height: 18px;
    width: 18px;
    margin-right: 3px;
    transform: translateY(5px);
    fill: currentColor;
}

.wrapper .step.quote-request .main .submit .timeline .text span {
    color: var(--color-grey);
    font-size: calc(var(--subparagraph) * .8);
    font-weight: 400;
}

.wrapper .step.quote-request .main .submit .timeline .bar {
    width: 200px;
    height: 2px;
    background: rgba(0, 0, 0, .1);
    border-radius: 50px;
    transform: translateY(-22px);
}

.wrapper .step.quote-request .main .submit .timeline .bar .inside {
    height: 100%;
    width: 0;
    background-color: var(--color-accent);
    animation: timeline-bar 1.2s ease infinite;
    border-radius: 50px;
}

@keyframes timeline-bar {
    0% {
        width: 0;
        opacity: 1;
    }

    100% {
        width: 100%;
        opacity: 0;
    }
}




.wrapper .step.quote-request .main .submit .buttons {
    display: flex;
    flex-direction: row;
    margin: 2vh;
}

.wrapper .step.quote-request .main .submit .buttons > a {
    font-size: var(--subparagraph);
    font-weight: 400;
    text-decoration: none;
    padding: 10px 20px;
    border-radius: 6px;
    cursor: pointer;
    margin-right: 20px;
}

.wrapper .step.quote-request .main .submit .buttons > a.second {
    border: 1px solid rgba(0, 0, 0, .2);
    color: var(--color-grey);
}

.wrapper .step.quote-request .main .submit .buttons > a.second:hover {
    border: 1px solid rgba(0, 0, 0, .2);
    box-shadow: 0 5px 15px rgba(0, 0, 0, .1);
    color: var(--color-black);
}

.wrapper .step.quote-request .main .submit .buttons > a.dashboard {
    background-color: var(--color-accent);
    color: var(--color-white);
}



.wrapper .step.quote-request .main .submit .buttons > a.dashboard:hover {
    background-color: var(--color-accent-hover);
}











.wrapper .step.meeting .main {
    display: flex;
    flex-direction: row;
    height: 100%;
}

.wrapper .step.meeting .main > div {
    width: calc(33% - 20px);
    height: calc(100% - 20px);
    box-sizing: border-box;
    margin: 10px;
    max-width: 500px;
}


.wrapper .step.meeting .main > div > div {
    box-shadow: 0 5px 20px rgba(0, 0, 0, .1);
    border-radius: 6px;
    overflow: hidden;
}

.wrapper .step.meeting .main > div > div > h4 {
    font-weight: 500;
    font-size: var(--subparagraph);
    margin-left: 10px;
}

.wrapper .step.meeting .main > div > div > p {
    font-weight: 400;
    font-size: calc(var(--subparagraph) * .8);
    color: var(--color-grey);
    margin-bottom: 10px;
    margin-left: 10px;
}

.wrapper .step.meeting .main > div > div {
    padding: 10px;
}





.wrapper .step.meeting .main > .left .modules {
    height: calc(100% - 260px);
}

.wrapper .step.meeting .main > .left .modules .list {
    overflow-y: scroll;
    height: calc(100% - 50px);
    padding-left: 10px;

    /* On définit le dégradé du plein vers le transparent */
    -webkit-mask-image: linear-gradient(to bottom, black 60%, transparent 100%);
    mask-image: linear-gradient(to bottom, black 60%, transparent 100%);
}


.wrapper .step.meeting .main > .left .modules .list > div {
    display: flex;
    flex-direction: row;
    margin-bottom: 30px;
}

.wrapper .step.meeting .main > .left .modules .list > div:last-of-type {
    margin-bottom: 50px;
}

.wrapper .step.meeting .main > .left .modules .list > div > div h4 {
    font-weight: 500;
    font-size: var(--subparagraph);
    margin-bottom: 0;
}

.wrapper .step.meeting .main > .left .modules .list > div > div span {
    font-weight: 400;
    font-size: calc(var(--subparagraph) * .8);
    color: var(--color-black);
    display: block;
}

.wrapper .step.meeting .main > .left .modules .list > div > div p {
    font-size: calc(var(--subparagraph) * .8);
    color: var(--color-grey);
}


.wrapper .step.meeting .main > .left .modules .list > div .img {
    background-color: rgba(0, 0, 0, .05);
    width: 80px;
    height: 60px;
    margin-right: 10px;
    border-radius: 3px;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
}

.wrapper .step.meeting .main > .left .modules .list > div .text {
    width: calc(100% - 70px);
}





.wrapper .step.meeting .main > .left .actions {
    margin-top: 20px;
    padding: 10px;
    height: 240px;
}

.wrapper .step.meeting .main > .left .actions > p {
    margin-bottom: 10px;
} 

.wrapper .step.meeting .main > .left .actions .list > a {
    font-size: var(--subparagraph);
    font-weight: 500;
    cursor: pointer;
    color: var(--color-grey);
    padding: 10px;
    transition: .1s ease;
    border-radius: 6px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: left;
}

.wrapper .step.meeting .main > .left .actions .list > a h4 {
    font-weight: 500;
}

.wrapper .step.meeting .main > .left .actions .list > a p {
    font-weight: 400;
}

.wrapper .step.meeting .main > .left .actions .list > a:hover {
    color: var(--color-black);
    background-color: rgba(0, 0, 0, .05);
}

.wrapper .step.meeting .main > .left .actions .list > a svg {
    float: left;
    margin-right: 20px;
    margin-left: 5px;
    width: 18px;
    fill: currentColor;
}


.wrapper .step.meeting .main > div > .files {
    height: 100%;

}

.wrapper .step.meeting .main > div > .files .list {
    overflow-y: scroll;
    height: calc(100% - 200px);

    /* On définit le dégradé du plein vers le transparent */
    -webkit-mask-image: linear-gradient(to bottom, black 60%, transparent 100%);
    mask-image: linear-gradient(to bottom, black 60%, transparent 100%);
}

.wrapper .step.meeting .main > div > .files .list .info {
    height: calc(100% - 50px);
    display: flex;
    align-items: left;
    justify-content: center;
    flex-direction: column;
    box-sizing: border-box;
    padding: 20px;
    color: var(--color-grey);
    box-shadow: none;
}

.wrapper .step.meeting .main > div > .files .list .info h4 {
    font-size: var(--subparagraph);
    font-weight: 500;
}

.wrapper .step.meeting .main > div > .files .list .info p {
    font-size: var(--subparagraph);
    font-weight: 400;
}

.wrapper .step.meeting .main > .middle > .files > .list > div.file-item {
    border: none;
    padding: none;
    border-radius: 0;
    padding: 5px 10px;
    transition: .1s ease;
    max-height: 200px;
}


.wrapper .step.meeting .main > .middle > .files > .list > div.file-item:last-of-type {
    margin-bottom: 50px;
}

.wrapper .step.meeting .main > .middle > .files > .list > div.file-item.hidden {
    max-height: 0;
    padding: 5px 0;
    opacity: 0;
}

.wrapper .step.meeting .main > .middle > .files > .list > div.file-item .file-icon {
    padding: 0;
    margin-right: 10px;
}



.wrapper .step.meeting .main > div > .files .upload {
    border-top: 1px solid rgba(0, 0, 0, .1);
    margin-top: 20px;
    box-sizing: border-box;
    height: 100px;
    display: flex;
    flex-direction: column;
    align-items: left;
    justify-content: flex-end;
}

.wrapper .step.meeting .main > div > .files .upload > p {
    font-size: var(--subparagraph);
    font-weight: 400;
    color: var(--color-grey);
}

.wrapper .step.meeting .main > div > .files .upload a {
    text-align: center;
    width: 100%;
    padding: 10px;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    background-color: rgba(0, 0, 0, .05);
    border-radius: 6px;
    color: var(--color-black);
    margin-top: 10px;
    transition: .1s ease;
}

.wrapper .step.meeting .main > div > .files .upload a:hover {
    box-shadow: 0 5px 15px rgba(0, 0, 0, .2);
    background-color: var(--color-white);
}


.wrapper .step.meeting .main > div > .files .upload a svg {
    margin-right: 10px;
    width: 18px;
    fill: currentColor;
}









.wrapper .step.meeting .main > div > .info {
    height: 180px;
}

.wrapper .step.meeting .main > div > .info h4 {
    color: var(--color-accent-hover);
}

.wrapper .step.meeting .main > div > .info p {
    font-size: var(--subparagraph);
    color: var(--color-accent);
    overflow: hidden;
    height: calc(100% - 80px);
}

.wrapper .step.meeting .main > div > .info a {
    text-align: center;
    font-size: var(--subparagraph);
    padding: 5px 10px;
    margin: 0 10px;
    border-radius: 3px;
    display: block;
    width: calc(100% - 20px);
    color: var(--color-black);
    background-color: var(--color-white);
    border: 1px solid rgba(0, 0, 0, .2);
    transition: .1s ease;
    cursor: pointer;
}

.wrapper .step.meeting .main > div > .info a:hover {
    color: var(--color-accent-hover);
    box-shadow: 0 5px 10px rgba(0, 0, 0, .1);
}

.wrapper .step.meeting .main > div > .info a:active {
    opacity: .8;
}

.wrapper .step.meeting .main > div > .info a.primary {
    background-color: var(--color-accent);
    color: var(--color-white);
}

.wrapper .step.meeting .main > div > .info a.primary:hover {
    background-color: var(--color-accent-hover);
}





.wrapper .step.meeting .main > div > .admin {
    height: calc(100% - 90px - 200px);
    margin-top: 20px;
}


.wrapper .step.meeting .main > div > .admin .list {
    padding: 0;
    margin: 0;
    padding-left: 10px;
    height: calc(100% - 30px);
    width: 100%;
    overflow-y: scroll;
}

.wrapper .step.meeting .main > div > .admin .list > div {
    margin-bottom: 0px;
}

.wrapper .step.meeting .main > div > .admin .list > div:last-of-type {
    margin-bottom: 30px;
}

.wrapper .step.meeting .main > div > .admin .list div > svg {
    float: left;
    margin-bottom: 20px;
    margin-right: 20px;
    transform: translateY(0px);
}

.wrapper .step.meeting .main > div > .admin .list div h4 {
    font-weight: 500;
    font-size: var(--subparagraph);
    display: inline-block;
}

.wrapper .step.meeting .main > div > .admin .list div span {
    text-transform: uppercase;
    font-weight: 500;
    font-size: calc(var(--subparagraph) * .8);
    color: var(--color-grey);
    margin-right: 25px;
    float: right;
    transform: translateY(3px);
}
.wrapper .step.meeting .main > div > .admin .list div.disabled.future span {
    color: var(--color-black);
}


.wrapper .step.meeting .main > div > .admin .list div .buttons {
    transform: translateX(-10px);
    margin-left: 0;
    margin-top: 0;
    max-height: 300px;
    width: calc(100% - 50px);
    padding: 5px 0 15px 10px;
    transition: .1s ease;
    overflow: hidden;
    display: block;
}

.wrapper .step.meeting .main > div > .admin .list div.disabled.future {
    opacity: .3;
}

.wrapper .step.meeting .main > div > .admin .list div.disabled .buttons {
    max-height: 0;
    padding: 5px 0 15px 10px;
}

.wrapper .step.meeting .main > div > .admin .list div .buttons a {
    font-size: var(--subparagraph);
    margin-right: 10px;
    padding: 5px 10px;
    transition: .1s ease;
    border-radius: 3px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.wrapper .step.meeting .main > div > .admin .list div.disabled .buttons a {
    display: none;
}

.wrapper .step.meeting .main > div > .admin .list div .buttons a svg {
    width: 18px;
    margin-right: 6px;
    fill: currentColor;
}

.wrapper .step.meeting .main > div > .admin .list div .buttons a.loading {
    animation: iconPulse 1s linear infinite;
}

.wrapper .step.meeting .main > div > .admin .list div .buttons a.loading svg {
    animation: spin-infinite 1s linear infinite;
    /* On s'assure que le SVG tourne sur son propre centre */
    transform-origin: center;
}

@keyframes spin-infinite {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

.wrapper .step.meeting .main > div > .admin .list div .buttons a.primary {
    background-color: var(--color-accent);
    color: var(--color-white);
}

.wrapper .step.meeting .main > div > .admin .list div .buttons a.primary:hover {
    background-color: var(--color-accent-hover);
    color: var(--color-white);
}

.wrapper .step.meeting .main > div > .admin .list div .buttons a.secondary {
    background-color: var(--color-white);
    border: 1px solid rgba(0, 0, 0, .2);
    color: var(--color-black);
}

.wrapper .step.meeting .main > div > .admin .list div .buttons a.secondary:hover {
    border: 1px solid rgba(0, 0, 0, .2);
    box-shadow: 0 2px 10px rgba(0, 0, 0, .1);
    color: var(--color-accent-hover);
}

.wrapper .step.meeting .main > div.right > .card {
    width: 100%;
    max-width: auto;
    padding: 10px;
    height: 70px;
    margin: 0;
    box-sizing: border-box;
    margin-top: 20px;
}

.wrapper .step.meeting .main > div.right > .card .avatar {
    margin-left: 10px;
    width: 50px;
    height: 50px;
}
















.wrapper .step.quote-request .action .card,
.wrapper .step.meeting .main > div > .card {
    box-sizing: border-box;
    border-radius: 6px;
    height: 100px;
    margin: 10px;
    margin-top: 25px;
    margin-right: 80px;
    padding: 10px;
    float: right;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: left;
    transition: .2s ease;
    max-width: 650px;
    overflow: hidden;
}

.wrapper .step.quote-request .action .card {
    margin: 10px;
}

.wrapper .step.quote-request .action .next:not(.hidden) + .card {
    margin-right: 10px;
}

.wrapper .step.quote-request .action .card.hidden,
.wrapper .step.meeting .main > div > .card.hidden {
    max-width: 0;
    padding: 10px 0;
    border-color: transparent;
}

.wrapper .step.quote-request .action .card .avatar,
.wrapper .step.meeting .main > div > .card .avatar {
    width: 64px;
    height: 64px;
    background: rgba(0, 0, 0, .05);
    border-radius: 80px;
    background-position: center;
    background-size: cover;
}

.wrapper .step.quote-request .action .info,
.wrapper .step.meeting .main > div > .card .info {
    margin-left: 20px;
}

.wrapper .step.quote-request .action .info p,
.wrapper .step.meeting .main > div > .card .info p {
    font-size: calc(var(--subparagraph) * .7);
    font-weight: 500;
    text-transform: uppercase;
    color: var(--color-grey);
}

.wrapper .step.quote-request .action .info h4,
.wrapper .step.meeting .main > div > .card .info h4 {
    font-size: var(--paragraph);
    font-weight: 500;
    color: var(--color-black);
}

.wrapper .step.quote-request .action .info h4 span,
.wrapper .step.meeting .main > div > .card .info h4 span {
    color: var(--color-grey);
    font-size: var(--subparagraph);
    font-weight: 400;
}

.wrapper .step.quote-request .action .info .contact-links,
.wrapper .step.meeting .main > div > .card .info .contact-links {
    display: flex;
    flex-direction: row;
    justify-content: left;
    margin-left: -10px;
}

.wrapper .step.quote-request .action .info .contact-links a,
.wrapper .step.meeting .main > div > .card .info .contact-links a {
    padding: 2px 10px;
    transition: .1s ease;
    border-radius: 3px;
}

.wrapper .step.quote-request .action .info .contact-links a:hover,
.wrapper .step.meeting .main > div > .card .info .contact-links a:hover {
    background-color: rgba(0, 0, 0, .05);
}


.wrapper .step.quote-request .action .left {
    height: 130px;
    width: calc(100% - 800px);
    min-width: 350px;
    margin-left: 30px;
    padding: 0;
    float: left;
}

.wrapper .step.quote-request .action .left .prev {
    display: inline-block;
    width: auto;
    font-size: 12px;
    padding: 0 10px;
    padding-bottom: 3px;
    border-radius: 5px;
    color: rgba(0, 0, 0, .8);
    margin-top: 5px;
    cursor: pointer;
    border: 1px solid rgba(0, 0, 0, .2);
    max-height: 50px;
    max-width: 300px;
    overflow: hidden;
    transition: .1s ease;
    white-space: nowrap;
}

.wrapper .step.quote-request .action .left .prev:hover {
    background-color: rgba(0, 0, 0, .05);
    border: 1px solid rgba(0, 0, 0, .1);
}

.wrapper .step.quote-request .action .left .prev.hidden {
    max-width: 0;
    max-height: 0;
    padding: 0;
    padding-bottom: 3px;
    margin: 0;
    border: 1px solid transparent;
}

.wrapper .step.quote-request .action .left .prev svg {
    width: 18px;
    height: 18px;
    transform: translateY(4px);
    margin-right: 5px;
    fill: rgba(0, 0, 0, .6);
}

.wrapper .step.quote-request .action .left h4 {
    font-weight: 500;
    margin-top: 0;
    font-size: 16px;
}

.wrapper .step.quote-request .action .left h4 span {
    padding-right: 10px;
}

.wrapper .step.quote-request .action .left p {
    font-size: 14px;
}




.wrapper .step.quote-request .action .inputs {
    padding: 10px;
    width: 0;
    display: none;
    height: 150px;
    display: flex;
    flex-direction: column;
    float: left;
}

.wrapper .step.quote-request .action .inputs div {
    height: 100%;
    overflow: hidden;
    transition: .2s ease;
}

.wrapper .step.quote-request .action .inputs div.hidden {
    height: 0;
    opacity: 0;
}

.wrapper .step.quote-request .action .inputs input {
    width: 100%;
    outline: none;
    border: 1px solid rgba(0, 0, 0, .2);
    background-color: rgba(0, 0, 0, .03);
    padding: 10px;
    margin: 3px 0;
    border-radius: 5px;
}

.wrapper .step.quote-request .action .inputs input:focus {
    border: 1px solid var(--color-accent-hover);
    background-color: rgba(0, 0, 0, 0);
}





.wrapper .step.quote-request .action .inputs .model, 
.wrapper .step.quote-request .action .inputs .options, 
.wrapper .step.quote-request .action .inputs .deadline {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 120px;
}

.wrapper .step.quote-request .action .inputs input[type="radio"] {
    display: none;
}

.wrapper .step.quote-request .action .inputs label {
    padding: 10px;
    border: 1px solid rgba(0, 0, 0, .1);
    border-right: 0;
    margin: 0;

    float: left;
    cursor: pointer;
}

.wrapper .step.quote-request .action .inputs div label svg {
    width: 18px;
    height: 18px;
    transform: translateY(3px);
    margin-right: 10px;
}

.wrapper .step.quote-request .action .inputs div label span {
    margin-right: 10px;
}

.wrapper .step.quote-request .action .inputs div label b {
    font-size: 12px;
    font-weight: 400;
    margin-left: 10px;
    color: rgba(0, 0, 0, .6);
}

.wrapper .step.quote-request .action .inputs div label:first-of-type {
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
    border-right: 0;
}

.wrapper .step.quote-request .action .inputs div label:last-of-type {
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
    border-right: 1px solid rgba(0, 0, 0, .1);
}

.wrapper .step.quote-request .action .inputs input[type="radio"]:checked + label {
    background-color: var(--color-accent-dim);
    color: var(--color-accent-hover);
}

.wrapper .step.quote-request .action .inputs input[type="radio"]:checked + label b {
    color: var(--color-accent-hover);
}



.wrapper .step.quote-request .action .inputs .options input[type="checkbox"] {
    display: none;
}

.wrapper .step.quote-request .action .inputs .options {
    display: block;
    height: 150px;
}

.wrapper .step.quote-request .action .inputs .options label {
    display: flex;
    justify-content: space-between;
    width: 100%;
    border-radius: 5px;
    margin-bottom: 5px;
    padding: 5px 10px;
    border: 1px solid rgba(0, 0, 0, .1);
}

.wrapper .step.quote-request .action .inputs .options input[type="checkbox"]:checked + label{
    background-color: var(--color-accent-dim);
    border: 1px solid var(--color-accent);
    color: var(--color-accent-hover);
}

.wrapper .step.quote-request .action .inputs .options input[type="checkbox"]:checked + label b {
    color: var(--color-accent-hover);
}

.wrapper .step.quote-request .action .inputs .options label:first-of-type {
    border-right: 1px solid rgba(0, 0, 0, .1);
}


.wrapper .step.quote-request .action .inputs .options label span {
    font-size: 14px;
}




.wrapper .step.quote-request .action .inputs .quantity {
    height: 120px;
    align-items: center;
    justify-content: center;
    display: flex;
}

.wrapper .step.quote-request .action .inputs .quantity input {
    width: 50%;
}




.wrapper .step.quote-request .action .inputs .format {
    height: 100%;
}

.wrapper .step.quote-request .action .inputs .format .list {
    display: flex;
    flex-direction: row;
    justify-content: space-evenly;
    height: 100%;
}

.wrapper .step.quote-request .action .inputs .format .list > div {
    display: flex;
    flex-direction: column;
    border-radius: 6px;
    height: 100%;
    padding: 0 10px;
    padding-left: 0px;
    text-align: left;
    cursor: pointer;
    transition: .1s ease;
}

.wrapper .step.quote-request .action .inputs .format .list > div:hover {
    background-color: var(--color-accent-dim);
}

.wrapper .step.quote-request .action .inputs .format .list > div .img-wrapper {
    width: 90px;
    height: 90px;
    padding-left: 10px;
    display: flex;
    align-items: center;
    justify-content: left;
}

.wrapper .step.quote-request .action .inputs .format .list > div .img-wrapper div {
    width: 62.5px;
    height: 62.5px;
    border-radius: 3px;
    background: var(--color-accent-dim);
    box-shadow: 0 0 0 rgba(0, 0, 0, .1);
    transition: .1s ease;
}

.wrapper .step.quote-request .action .inputs .format .list > div:hover .img-wrapper div {
    background: var(--color-white);
    box-shadow: 0 6px 10px rgba(0, 0, 0, .2);
}

.wrapper .step.quote-request .action .inputs .format .list > div h4 {
    margin-left: 10px;
    font-size: 12px;
    font-weight: 500;
}

.wrapper .step.quote-request .action .inputs .format .list > div:hover h4 {
    color: var(--color-accent-hover);
}

.wrapper .step.quote-request .action .inputs .format .list > div p {
    font-size: 10px;
    margin: 0;
    margin-left: 10px;
    font-weight: 400;
}

.wrapper .step.quote-request .action .inputs .format .list > div:hover p {
    color: var(--color-accent);
}












.wrapper .step.quote-request .action .inputs .send {
    height: 120px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.wrapper .step.quote-request .action .inputs .send p {
    margin-top: 10px;
    font-size: 14px;
    color: rgba(0, 0, 0, .6);
}













.wrapper .step.quote-request .action .next {
    margin: 10px;
    max-width: 500px;
    overflow: hidden;
    transition: .2s ease-out;
    cursor: pointer;
    white-space: nowrap;
    float: right;
}

.wrapper .step.quote-request .action .next.hidden {
    max-width: 0;
    opacity: 0;
}

.wrapper .step.quote-request .action .next a {
    color: black;
    display: inline-block;
    border: 1px solid rgba(0, 0, 0, .2);
    padding: 20px;
    border-radius: 5px;
    margin-left: 10px;
    margin-bottom: 20px;
    margin-right: 90px;
    transition: .4s ease;
}

.wrapper .step.quote-request .action .next a:hover {
    border: 1px solid var(--color-accent);
    color: var(--color-accent-hover);
    box-shadow: 0 10px 20px rgba(0, 0, 0, .1);
}

.wrapper .step.quote-request .action .next a .col {
    display: flex;
    flex-direction: column;
    float: left;
}

.wrapper .step.quote-request .action .next a span {
    font-size: var(--subparagraph);
    color: rgba(0, 0, 0, .6);
}


.wrapper .step.quote-request .action .next a:hover span {
    color: var(--color-accent-hover);
}

.wrapper .step.quote-request .action .next a h5 {
    font-size: var(--paragraph);
    font-weight: 500;
    color: var(--color-accent);
}

.wrapper .step.quote-request .action .next a:hover h5 {
    color: var(--color-accent-hover);
}

.wrapper .step.quote-request .action .next a svg {
    margin-top: calc(var(--paragraph) + 10px);
    margin-left: 15px;
    fill: var(--color-accent);
    transition: .1s ease;
}

.wrapper .step.quote-request .action .next a:hover svg {
    transform: translateX(5px);
    fill: var(--color-accent-hover);
}

















.wrapper > div .action .invoice {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: row;
}

.wrapper > div .action .invoice .left {
    width: 40%;
    height: 100%;
    box-sizing: border-box;
    padding: 15px;
    padding-left: 50px;
    border-right: 1px solid rgba(0, 0, 0, 0.1);
}

.wrapper > div .action .invoice .left h4 {
    font-size: 20px;
    font-weight: 500;
    margin-bottom: 10px;
}

.wrapper > div .action .invoice .left p {
    font-size: 14px;
    opacity: .8;
}

.wrapper > div .action .invoice .buttons {
    display: flex;
    flex-direction: column;
    width: 50%;
}

.wrapper > div .action .invoice .buttons a {
    background-color: rgba(0, 0, 0, 0.05);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: left;
    color: black;
    transition: .1s ease;
}

.wrapper > div .action .invoice .buttons a:hover {
    background-color: rgba(0, 0, 0, 0.1);
}

.wrapper > div .action .invoice .buttons a svg {
    height: 18px;
    margin: 0 10px;
}

.wrapper > div .action .invoice .buttons a span {
    font-size: var(--subparagraph);
    font-weight: 500;
}

.wrapper > div .action .invoice .buttons .top {
    width: 100%;
    height: 75px;
    box-sizing: border-box;
    display: flex;
    flex-direction: row;
}

.wrapper > div .action .invoice .buttons .top a {
    width: 50%;
    margin: 10px;
    cursor: pointer;
}

.wrapper > div .action .invoice .buttons .top a.download {
    margin-right: 0;
}


.wrapper > div .action .invoice .buttons .bottom {
    width: 100%;
}

.wrapper > div .action .invoice .buttons .bottom a {
    margin: 10px;
    margin-top: 0;
    height: 60px;
    cursor: pointer;
    background-color: var(--color-accent-dim);
    color: var(--color-accent-hover);
}


.wrapper > div .action .invoice .buttons .bottom a svg {
    fill: currentColor;
}

.wrapper > div .action .invoice .buttons .bottom a span {
    margin-right: 10px;
}

.wrapper > div .action .invoice .buttons .bottom a b {
    font-weight: 400;
    font-size: var(--subparagraph);
}

.wrapper > div .action .invoice .buttons .bottom a:hover {
    background-color: var(--color-accent);
    color: var(--color-white);
}

.wrapper > div .action .invoice .right {
    border-left: 1px solid rgba(0,0,0,.1);
    width: 20%;
}

.wrapper > div .action .invoice .right img {
    height: 100px;
    margin: 0 0;
    box-sizing: border-box;
    padding: 5px;
}










.wrapper > .angles-selection .main .list {
    width: calc(100% - 20px);
    box-sizing: border-box;
    height: 100%;
    padding: 10px;
    overflow-y: scroll;
    overflow-x: hidden;
}

.droppable-angle-selection {
    width: 400px;
    height: auto;
    display: inline-block;
    border-radius: 10px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    margin: 5px;
    cursor: pointer;
    transition: box-shadow .1s ease;
    background: var(--color-background);
    box-sizing: border-box;
}

.droppable-angle-selection:hover {
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
}

.droppable-angle-selection.dragging {
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
}

.droppable-angle-selection.moving:not(.dragging) {
    border: 1px dashed rgba(0, 0, 0, 0.2);
}

.droppable-angle-selection.moving:not(.dragging) .img {
    opacity: 0;
}

.droppable-angle-selection.moving:not(.dragging):hover {
    box-shadow: none;
}

.droppable-angle-selection.moving:not(.dragging) h4,
.droppable-angle-selection.moving:not(.dragging) span {
    opacity: .4;
}

.droppable-angle-selection .img {
    width: 100%;
    height: 200px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: 10px 10px 0 0;
    background-color: rgba(0, 0, 0, 0.1);
}

.droppable-angle-selection h4 {
    font-size: 12px;
    font-weight: 500;
    padding: 10px;
    position: relative;
    float: left;
}

.droppable-angle-selection span {
    float: right;
    padding: 10px;
    font-size: 12px;
}

.droppable-angle-selection:not(.fixed) .comment {
    display: none;
}

.wrapper .step.angles-selection .action {
    overflow-y: hidden;
    overflow-x: scroll;
    white-space: nowrap;
    height: 150px;
    box-shadow: 0 0px 100px rgba(0, 0, 0, .2);
}

.wrapper .step.angles-selection .action .info {
    margin: 10px;
    width: calc(100% - 20px);
    box-sizing: border-box;
    padding: 10px;
    padding-left: 40px;
    height: 100px;
    border-radius: 10px;
    border: 2px dashed rgba(0, 0, 0, 0.1);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.wrapper .step.angles-selection .action .info h4 {
    font-size: 20px;
    font-weight: 500;
    opacity: .4;

}

.wrapper .step.angles-selection .action .info p {
    font-size: 14px;
    opacity: .4;
}

.wrapper .step.angles-selection .action .droppable-angle-selection {
    height: 110px;
    width: 200px;
    border-radius: 10px;
    overflow: hidden;
}

.wrapper .step.angles-selection .action .droppable-angle-selection:hover {
    opacity: .8;
    box-shadow: none;
}

.wrapper .step.angles-selection .action .droppable-angle-selection .img {
    height: 120px;
    width: 100%;
}

.wrapper .step.angles-selection .action .droppable-angle-selection h4 {
    margin-top: -120px;
    width: calc(100% - 50px);
    overflow: hidden;
    color: var(--color-white);
    mix-blend-mode: luminosity;
    opacity: .8;
    text-shadow: 0 2px 6px rgba(0, 0, 0, .8);
    /* On définit le dégradé du plein vers le transparent */
  -webkit-mask-image: linear-gradient(to right, black 80%, transparent 100%);
  mask-image: linear-gradient(to right, black 80%, transparent 100%);
}

.wrapper .step.angles-selection .action .droppable-angle-selection.moving h4,
.wrapper .step.angles-selection .action .droppable-angle-selection.moving > span,
.wrapper .step.angles-selection .action .droppable-angle-selection.moving .comment {
    display: none;
}

.wrapper .step.angles-selection .action .droppable-angle-selection > span {
    margin-top: -120px;
    color: var(--color-white);
    mix-blend-mode: luminosity;
    opacity: .8;
    text-shadow: 0 2px 6px rgba(0, 0, 0, .8);
}

.wrapper > .step.angles-selection .droppable-angle-selection .comment {
    display: block;
    flex-direction: row;
    justify-content: left;
    align-items: center;
    background: rgba(255, 255, 255, 0.4);
    backdrop-filter: blur(6px) saturate(180%);
    border-radius: 16px;
    padding: 6px;
    margin: 4px;
    max-width: 36px;
    box-sizing: border-box;
    margin-top: -48px;
    height: 32px;
    transition: .1s ease;
    overflow: hidden;
    color: var(--color-black);
}

.wrapper > .step.angles-selection .main .droppable-angle-selection:not(.fixed) .comment {
    display: none;
}

.wrapper > .step.angles-selection .droppable-angle-selection.fixed .comment {
    display: block;
    margin-top: -40px;
    margin-left: 5px;
}

.wrapper > .step.angles-selection .droppable-angle-selection:hover .comment {
    background: rgba(255, 255, 255, 0.8);
}

.wrapper > .step.angles-selection .droppable-angle-selection .comment:hover {
    max-width: 200px;
    background: rgba(255, 255, 255, 0.8);
    border-radius: 6px;
}

.wrapper > .step.angles-selection .droppable-angle-selection .comment:active {
    background-color: var(--color-accent-dim);
    color: var(--color-accent-hover);
    fill: var(--color-accent-hover);
}

.wrapper > .step.angles-selection .droppable-angle-selection .comment svg {
    height: 18px;
    width: 18px;
    margin-right: 12px;
    margin-top: 2px;
    margin-left: 2px;
    float: left;
}

.wrapper > .step.angles-selection .droppable-angle-selection .comment span {
    font-size: 12px;
    margin-top: 2px;
    display: block;
    float: none;
    width: auto;
    padding: 0;
}


.wrapper > .comment_modal {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    backdrop-filter: blur(6px);
    background-color: rgba(0, 0, 0, .4);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 999;
}

.wrapper > .comment_modal > div {
    background-color: var(--color-white);
    width: 600px;
    height: auto;
    padding: 10px;
    border-radius: 16px;
    display: flex;
    flex-direction: row;
    box-shadow: 0 12px 48px rgba(0, 0, 0, .2);
}

.wrapper > .comment_modal > div .image-wrapper {
    width: 300px;
    height: 300px;
    background-color: rgba(0, 0, 0, .1);
    border-radius: 6px;
    margin-right: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.wrapper > .comment_modal > div .image-wrapper div {
    width: 250px;
    height: 187.5px;
    background: var(--color-white);
    border-radius: 6px;
    filter: drop-shadow(0 12px 24px rgba(0, 0, 0, .1));
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    transition: .1s ease;
}

.wrapper > .comment_modal > div .image-wrapper div.contain {
    background-color: transparent;
    transition: none;
}

.wrapper > .comment_modal > div .text {
    width: calc(100% - 300px);
}

.wrapper > .comment_modal > div .text h2 {
    font-size: 14px;
    font-weight: 500;
    margin: 5px 10px;
    height: 50px;
}

.wrapper > .comment_modal > div .text h4 {
    font-size: 12px;
    font-weight: 500;
    margin-left: 10px;
}

.wrapper > .comment_modal > div .text textarea {
    font-family: "IBM Plex Sans";
    font-weight: 400;
    width: 100%;
    height: calc(100% - 222px);
    resize: none;
    outline: none;
    border: 1px solid rgba(0, 0, 0, .1);
    box-sizing: border-box;
    padding: 10px;
    border-radius: 6px;
    margin-bottom: 5px;
}

.wrapper > .comment_modal > div .text textarea:focus {
    border: 1px solid var(--color-accent);
}

.wrapper > .comment_modal > div .text .format-list {
    display: flex;
    width: 100%;
    margin-top: 5px;
    white-space: wrap;
    word-break: normal;
    word-wrap: normal;
    flex-direction: row;
    align-items: center;
    justify-content: space-evenly;
}

.wrapper > .comment_modal > div .text .format-list div {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-evenly;
    border: 2px solid rgba(0, 0, 0, 0);
    padding: 10px;
    border-radius: 13px;
    cursor: pointer;
}

.wrapper > .comment_modal > div .text .format-list div.disabled {
    cursor: default;
}

.wrapper > .comment_modal > div .text .format-list div.disabled .shape {
    background-color: rgba(0, 0, 0, .2);
}

.wrapper > .comment_modal > div .text .format-list div.selected {
    border: 2px solid rgba(0, 0, 0, .1);
    cursor: default;
}

.wrapper > .comment_modal > div .text .format-list div:not(.disabled):hover {
    background-color: rgba(0, 0, 0, .1);
}


.wrapper > .comment_modal > div .text .format-list div .shape {
    display: block;
    width: 10px;
    height: 10px;
    background: var(--color-black);
    border-radius: 3px;
}

.wrapper > .comment_modal > div .text .format-list div .text {
    font-size: 12px;
    display: none;
    width: 0;
    height: 0;
    transform: translateY(20px) translateX(-17px);
    opacity: .8;
    text-align: left;
}

.wrapper > .comment_modal > div .text .format-list div.selected .text,
.wrapper > .comment_modal > div .text .format-list div:not(.disabled):hover .text {
    display: block;
}

.wrapper > .comment_modal > div .text .format-list div[data-format="none"] {
    border-radius: 50px;
}

.wrapper > .comment_modal > div .text .format-list div[data-format="none"] .shape {width: 12px; height: 12px; background-color: rgba(0, 0, 0, .2); border-radius: 20px;}
.wrapper > .comment_modal > div .text .format-list div[data-format="16:9"] .shape {width: 16px; height: 9px;}
.wrapper > .comment_modal > div .text .format-list div[data-format="9:16"] .shape {width: 9px; height: 16px;}
.wrapper > .comment_modal > div .text .format-list div[data-format="4:3"] .shape {width: 16px; height: 12px;}
.wrapper > .comment_modal > div .text .format-list div[data-format="3:4"] .shape {width: 12px; height: 16px;}
.wrapper > .comment_modal > div .text .format-list div[data-format="3:2"] .shape {width: 15px; height: 10px;}
.wrapper > .comment_modal > div .text .format-list div[data-format="2:3"] .shape {width: 10px; height: 15px;}
.wrapper > .comment_modal > div .text .format-list div[data-format="1:1"] .shape {width: 12px; height: 12px;}

.wrapper > .comment_modal > div .text .format-list div.selected:not([data-format="none"]) .shape {
    background-color: var(--color-black);
}

.wrapper > .comment_modal > div .text .format-list div.selected:hover {
    background-color: transparent;
}

.wrapper > .comment_modal > div .text .buttons {
    height: 48px;
    margin-top: 20px;
    border-top: 1px solid rgba(0, 0, 0, .1);
    display: flex;
    flex-direction: row;
    align-items: end;
    justify-content: space-evenly;
}



.wrapper > .comment_modal > div .text .buttons a {
    background: rgba(0, 0, 0, .1);
    text-align: left;
    box-sizing: border-box;
    width: 100%;
    height: 40px;
    text-indent: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    color: var(--color-black);
    cursor: pointer;
}


.wrapper > .comment_modal > div .text .buttons a.cancel {
    background: none;
}
.wrapper > .comment_modal > div .text .buttons a.cancel:hover {
    color: var(--color-accent-hover);
    text-decoration: underline;
}



.wrapper > .comment_modal > div .text .buttons a.save {
    background-color: rgba(0, 0, 0, .1);
    color: var(--color-black);
}

.wrapper > .comment_modal > div .text .buttons a.save:hover {
    background-color: var(--color-accent-dim);
    color: var(--color-accent-hover);
}







.wrapper .step.revision .main {
    position:relative;
    overflow:hidden;
    background:rgba(38, 23, 0, 0.15);
    height: calc(100% - 160px);
}

.wrapper .step.revision .main h4 {
    width: 100%;
    height: 100%;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 500;
    font-size: var(--subtitle);
    color: var(--color-grey);
}

.wrapper .step.revision .main img {
    position:absolute;
    -webkit-user-drag: none;
    transform-origin: top left;
    cursor: grab;
    box-shadow: 0 10px 30px rgba(0, 0, 0, .3);
}

.wrapper .step.revision .main > div {
    position: absolute;
    background: orange;
    border-radius: 30px;
    padding: 0 4px;
    height: 25px;
    transform: translate(-12px, -12px);
    z-index: 5;
}

.wrapper .step.revision .main > div::after {
    width: 0;
    height: 0;
    margin-top: 11px;
    margin-left: 6px;
    border-top: 3px dashed orange;
    position: absolute;
    content: "";
    cursor: default;
}

.wrapper .step.revision .main > div.read-only::after {
    border-top: 3px dashed rgba(255, 255, 255, 0.4);
}

.wrapper .step.revision .main > div.read-only {
    background: rgba(255, 255, 255, 0.4);
    backdrop-filter: blur(20px) saturate(180%);
}

.wrapper .step.revision .main > div.line::after {
    width: 100vw;
}

.wrapper .step.revision .main > div svg {
    width: 18px;
    display: inline-block;
}

.wrapper .step.revision .main > div h4 {
    display: inline-block;
    font-weight: 500;
    font-size: 14px;
    transform: translateY(-6px);
    margin-right: 5px;
    width: auto;
    height: auto;
    color: var(--color-black);
}

.wrapper .step.revision .main > div .details {
    display: none;
}




/* ===== ANNOTATION STYLES ===== */
/* iPad specific: larger tap target */
.wrapper .step.revision .main > div.ipad-annotation {
    padding: 8px 12px;
    box-sizing: content-box;
}



.wrapper .step.validation .panel,
.wrapper .step.revision .panel {
    height: calc(100% - 280px);
    width: 300px;
    background-color: var(--color-background);
    border-radius: 10px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4);
    position: fixed;
    right: 10px;
    top: 80px;
    z-index: 10;
    box-sizing: border-box;
    padding: 10px;
    transition: .2s ease;
}

.wrapper .step.validation .panel.hidden,
.wrapper .step.revision .panel.hidden {
    right: -350px;
}

.wrapper .step.validation .panel > p,
.wrapper .step.revision .panel > p {
    text-transform: uppercase;
    font-size: 10px;
    font-weight: 500;
    color: rgba(0, 0, 0, 0.4);
}

.wrapper .step.validation .panel > h4,
.wrapper .step.revision .panel > h4 {
    font-size: 14px;
    font-weight: 500;
}

.wrapper .step.validation .panel .select,
.wrapper .step.revision .panel .select {
    padding-top: 5px;
    display: block;
    float: right;
    margin-top: -45px;
    margin-bottom: 5px;
}

.wrapper .step.validation .panel .select > svg,
.wrapper .step.revision .panel .select > svg {
    opacity: 1;
    fill: rgba(0, 0, 0, 0.6);
    padding: 10px;
    height: 18px;
    width: 18px;
    margin-right: 5px;
    box-sizing: content-box;
    border-radius: 50px;
    border: 1px solid rgba(0, 0, 0, 0.1);
    cursor: pointer;
}

.wrapper .step.validation .panel .select > svg:hover,
.wrapper .step.revision .panel .select > svg:hover {
    border: 1px solid rgba(0, 0, 0, .6);
    fill: rgba(0, 0, 0, 0.8);
    background-color: rgba(0, 0, 0, 0.02);
}

.wrapper .step.validation .panel .select > svg.delete:hover,
.wrapper .step.revision .panel .select > svg.delete:hover {
    background: rgba(255, 0, 0, 0.1);
    fill: rgb(220, 0, 0);
    border: 1px solid rgba(255, 0, 0, 0.6);
}

.wrapper .step.validation .panel .select .text,
.wrapper .step.revision .panel .select .text {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    margin-right: 0;
}

.wrapper .step.validation .panel .select .color,
.wrapper .step.revision .panel .select .color {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    margin-left: -5px;
}

.wrapper .step.validation .panel .select > svg.active,
.wrapper .step.revision .panel .select > svg.active {
    fill: orange;
    border: 1px solid rgba(255, 140, 0, 0.6);
    background: rgba(255, 115, 0, 0.05);
    cursor: default;
}

.wrapper .step.validation .panel .tabs,
.wrapper .step.revision .panel .tabs {
    height: calc(100% - 100px);
}

.wrapper .step.validation .panel .tabs > div,
.wrapper .step.revision .panel .tabs > div {
    height: 100%;
}

.wrapper .step.validation .panel .tabs .text textarea,
.wrapper .step.revision .panel .tabs .text textarea {
    font-family: var(--font-primary);
    font-size: 18px;
    line-height: 25px;
    outline: none;
    resize: none;
    width: 100%;
    height: 100%;
    border: 2px solid rgba(0, 0, 0, 0.1);
    border-radius: 5px;
    box-sizing: border-box;
    padding: 10px;
}

.wrapper .step.validation .panel .tabs .hidden,
.wrapper .step.revision .panel .tabs .hidden {
    display: none;
}

.wrapper .step.validation .panel .tabs .text textarea:focus-within,
.wrapper .step.revision .panel .tabs .text textarea:focus-within {
    border-color: orange;
}


.wrapper .step.validation .panel .tabs .color > div,
.wrapper .step.revision .panel .tabs .color > div {
    width: 100%;
    height: 100px;
    padding: 0;
}

.wrapper .step.validation .panel .tabs .color input,
.wrapper .step.revision .panel .tabs .color input {
    font-family: var(--font-primary);
    font-size: 18px;
    line-height: 25px;
    outline: none;
    resize: none;
    width: 100%;
    height: 100%;
    border: 2px solid rgba(0, 0, 0, 0.1);
    border-radius: 5px;
    box-sizing: border-box;
    padding: 10px;
}

.clr-field.clr-rtl button {
    display: block;
    height: 100%;
    width: 50%;
    cursor: pointer;
    border-radius: 5px 0 0 5px;
    outline: none;
    border: 2px solid rgb(225, 225, 225);
    border-right: 0;
}




.wrapper .step.validation .panel .navigation,
.wrapper .step.revision .panel .navigation {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    margin-top: 10px;
    padding: 10px 0;
}

.wrapper .step.validation .panel .navigation > div,
.wrapper .step.revision .panel .navigation > div {
    border: 1px solid rgba(0, 0, 0, 0.1);
    width: 50%;
    height: 40px;
    display: flex;
    align-items: center;
    box-sizing: border-box;
    padding: 0 10px;
    cursor: pointer;
}

.wrapper .step.validation .panel .navigation > div:hover,
.wrapper .step.revision .panel .navigation > div:hover {
    border: 1px solid rgba(0, 0, 0, 0.4);
    background-color: rgba(0, 0, 0, 0.02);
}

.wrapper .step.validation .panel .navigation > div svg,
.wrapper .step.revision .panel .navigation > div svg {
    fill: rgba(0, 0, 0, .6);
}

.wrapper .step.validation .panel .navigation > div:hover svg,
.wrapper .step.revision .panel .navigation > div:hover svg {
    fill: rgba(0, 0, 0, .8);
}

.wrapper .step.validation .panel .navigation > div.right,
.wrapper .step.revision .panel .navigation > div.right {
    border-radius: 0 5px 5px 0;
    justify-content: right;
}

.wrapper .step.validation .panel .navigation > div.left,
.wrapper .step.revision .panel .navigation > div.left {
    border-radius: 5px 0 0 5px;
    border-right: none;
}

.wrapper .step.validation .panel .navigation > div.left:hover,
.wrapper .step.revision .panel .navigation > div.left:hover {
    border-right: 1px solid rgba(0, 0, 0, .6);
}

.wrapper .step.revision .panel .navigation > div.left:hover+ {
    border-left: none;
}






.wrapper .step.revision .action {
    display: block;
    overflow-y: hidden;
    overflow-x: scroll;
    white-space: nowrap;
    height: 160px;
}

.wrapper .step.revision .action > div {
    display: inline-block;
    height: 150px;
    width: 250px;
    margin: 10px;
    margin-right: 5px;
    cursor: pointer;
}

.wrapper .step.revision .action > div:hover {
    opacity: .8;
}


.wrapper .step.revision .action > div.forbidden {
    opacity: .3;
    cursor: default;
}

.wrapper .step.revision .action > div.selected .img {
    border: 3px solid orange;
}

@keyframes shake {
    0% { transform: translate(1px, 0) }
    20% { transform: translate(-1px, 0) }
    40% { transform: translate(-3px, 0) }
    60% { transform: translate(3px, 0)}
    80% { transform: translate(1px, 0) }
    100% { transform: translate(-1px, 0)}
}

.wrapper .step.revision .action > div.limit-reached .img {
    border: 3px solid red;
    animation: shake 0.3s;
}

.wrapper .step.revision .action > div .img {
    height: 110px;
    width: 100%;
    background-size: cover;
    background-position: center center;
    border-radius: 10px;
    background-color: rgba(0, 0, 0, .1);
}

.wrapper .step.revision .action > div h4 {
    font-weight: 500;
    font-size: 12px;
    margin-top: 5px;
    margin-left: 5px;
    float: left;
}

.wrapper .step.revision .action > div.selected h4 {
    color: rgb(219, 143, 0);
}

.wrapper .step.revision .action > div.limit-reached h4 {
    color: rgb(214, 0, 0);
}

.wrapper .step.revision .action > div span {
    float: right;
    font-weight: 500;
    font-size: 12px;
    margin-top: 5px;
    margin-right: 5px;
    padding: 0px 5px;
    padding-left: 10px;
    background: rgba(0, 0, 0, 0.05);
    border-radius: 20px;
}

.wrapper .step.revision .action > div.selected span {
    background-color: rgba(255, 166, 0, 0.2);
}

.wrapper .step.revision .action > div.selected.limit-reached span {
    background-color: rgba(214, 0, 0, 0.2);
}

.wrapper .step.revision .action > div span b {
    font-weight: 500;
}

.wrapper .step.revision .action > div span svg {
    width: 14px;
    height: 14px;
    transform: translateY(2px);
    margin-left: 2px;
}








.wrapper .step.validation .slider-wrapper,
.wrapper .step.angles-validation .slider-wrapper {
    height: 100%;
    width: calc(100% - 320px);
    display: grid;
    /* Définit trois colonnes de largeur égale */
    grid-template-columns: 100px 1fr 100px;
    /* Optionnel mais souvent utile pour l'alignement */
}

.wrapper .step.validation .slider-wrapper .arrow, 
.wrapper .step.angles-validation .slider-wrapper .arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    width: auto;
    border: none;
}

.wrapper .step.validation .slider-wrapper .arrow svg, 
.wrapper .step.angles-validation .slider-wrapper .arrow svg {
    border-radius: 50px;
    border: 1px solid rgba(0, 0, 0, .1);
    padding: 16px;
    box-sizing: content-box;
    cursor: pointer;
    overflow: visible;
}


.wrapper .step.validation .slider-wrapper .arrow svg:hover,
.wrapper .step.angles-validation .slider-wrapper .arrow svg:hover {
    background-color: rgba(0, 0, 0, .05);
}

.wrapper .step.validation .slider-wrapper .img-wrapper, 
.wrapper .step.angles-validation .slider-wrapper .img-wrapper {
    margin: 10px 0;
    display: block;
}

.wrapper .step.validation .slider-wrapper .img,
.wrapper .step.angles-validation .slider-wrapper .img {
    height: 100%;
    width: 100%;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    border: 1px solid rgba(0, 0, 0, .1);
    border-radius: 16px;
    transition: .1s ease;
}

.wrapper .step.validation .slider-wrapper .img.left,
.wrapper .step.angles-validation .slider-wrapper .img.left {
    transform: translateX(-10px);
    opacity: 0;
}

.wrapper .step.validation .slider-wrapper .img.right,
.wrapper .step.angles-validation .slider-wrapper .img.right {
    transform: translateX(10px);
    opacity: 0;
}



.wrapper .step.validation .slider-wrapper .img .flag,
.wrapper .step.angles-validation .slider-wrapper .img .flag {
    background: var(--color-accent-dim);
    padding: 6px;
    width: 300px;
    margin: 10px;
    color: var(--color-black);

    border-radius: 6px;
    cursor: pointer;
    transition: .1s ease;
}

.wrapper .step.angles-validation .slider-wrapper .img .flag.hidden,
.wrapper .step.validation .slider-wrapper .img .flag.hidden {
    opacity: 0;
}

.wrapper .step.angles-validation .slider-wrapper .img .flag:hover,
.wrapper .step.validation .slider-wrapper .img .flag:hover {
    color: var(--color-accent-hover);
    opacity: .8;
}

.wrapper .step.angles-validation .slider-wrapper .img .flag.active,
.wrapper .step.validation .slider-wrapper .img .flag.active {
    background-color: orange;
    color: var(--color-black);
}

.wrapper .step.validation .slider-wrapper .img .flag svg,
.wrapper .step.angles-validation .slider-wrapper .img .flag svg {
    float: left;
    margin: 6px 15px 30px 10px;
    fill: currentColor;
    transition: .1s ease;
}

.wrapper .step.validation .slider-wrapper .img .flag p,
.wrapper .step.angles-validation .slider-wrapper .img .flag p {
    font-size: calc(var(--subparagraph) * .8);
    font-weight: 500;
    margin: 0;
    transition: .1s ease;
}

.wrapper .step.validation .slider-wrapper .img .flag span,
.wrapper .step.angles-validation .slider-wrapper .img .flag span {
    font-size: calc(var(--subparagraph) * .8);
    font-weight: 400;
    margin: 0;
    margin-top: -3px;
    display: block;
    transition: .1s ease;
}

.wrapper .step.validation .slider-wrapper .img .flag span b,
.wrapper .step.angles-validation .slider-wrapper .img .flag span b {
    font-weight: 500;
}


.wrapper .step.validation .action .left,
.wrapper .step.angles-validation .action .left {
    width: 400px;
    box-sizing: border-box;
    padding: 20px 50px;
    border-right: 1px solid rgba(0, 0, 0, .1);
}

.wrapper .step.angles-validation .action .left h4,
.wrapper .step.validation .action .left h4 {
    font-size: 30px;
    font-weight: 500;
}





.wrapper > .step.validation .action,
.wrapper > .step.angles-validation .action {
    display: flex;
    flex-direction: row;
}


.wrapper > .step.angles-validation .buttons,
.wrapper > .step.validation .buttons {
    display: flex;
    flex-direction: column;
    width: 50%;
}

.wrapper > .step.validation .buttons a,
.wrapper > .step.angles-validation .buttons a {
    background-color: rgba(0, 0, 0, 0.05);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: left;
    color: black;
    transition: .1s ease;
}

.wrapper > .step.validation .buttons a:hover,
.wrapper > .step.angles-validation .buttons a:hover {
    background-color: rgba(0, 0, 0, 0.1);
}

.wrapper > .step.validation .buttons a svg,
.wrapper > .step.angles-validation .buttons a svg {
    height: 18px;
    margin: 0 10px;
    fill: currentColor;
}

.wrapper > .step.validation .buttons a span,
.wrapper > .step.angles-validation .buttons a span {
    font-size: 14px;
    font-weight: 500;
}

.wrapper > .step.angles-validation .buttons .top a span b,
.wrapper > .step.validation .buttons .top a span b {
    font-weight: 400;
    font-size: calc(var(--subparagraph) * .8);
    display: block;
}


.wrapper > .step.validation .buttons .top,
.wrapper > .step.angles-validation .buttons .top {
    width: 100%;
    height: 75px;
    box-sizing: border-box;
    display: flex;
    flex-direction: row;
}

.wrapper > .step.validation .buttons .top a,
.wrapper > .step.angles-validation .buttons .top a {
    width: 50%;
    margin: 10px;
    cursor: pointer;
}

.wrapper > .step.validation .buttons .top a.email,
.wrapper > .step.angles-validation .buttons .top a.email {
    margin-right: 0;
}

.wrapper > .step.validation .buttons .bottom,
.wrapper > .step.angles-validation .buttons .bottom {
    width: calc(100% - 20px);
}

.wrapper > .step.validation .buttons .bottom a,
.wrapper > .step.angles-validation .buttons .bottom a {
    margin: 10px;
    margin-top: 0;
    height: 60px;
    cursor: pointer;
    background-color: var(--color-accent-dim);
    color: var(--color-accent-hover);
    transition: .1s ease;
}

.wrapper > .step.validation .buttons .bottom a:hover,
.wrapper > .step.angles-validation .buttons .bottom a:hover {
    background-color: var(--color-accent);
    color: var(--color-white);
}

.wrapper > .step.validation .buttons .bottom a svg,
.wrapper > .step.angles-validation .buttons .bottom a svg {
    color: currentColor;
}

.wrapper > .step.validation .buttons .bottom a.loading,
.wrapper > .step.angles-validation .buttons .bottom a.loading {
    animation: iconPulse 1s linear infinite;
}

.wrapper > .step.validation .buttons .bottom a.loading svg,
.wrapper > .step.angles-validation .buttons .bottom a.loading svg {
    animation: spin-infinite 1s linear infinite;
    /* On s'assure que le SVG tourne sur son propre centre */
    transform-origin: center;
}

.wrapper > .step.validation .buttons .bottom a span,
.wrapper > .step.angles-validation .buttons .bottom a span {
    margin-right: 0;
}

.wrapper > .step.validation .buttons .bottom a b,
.wrapper > .step.angles-validation .buttons .bottom a b {
    font-weight: 400;
    margin-left: 5px;
    font-size: 14px;
}

.wrapper > .step.validation .right,
.wrapper > .step.angles-validation .right {
    border-left: 1px solid rgba(0,0,0,.1);
    width: 20%;
}

.wrapper > .step.validation .right img,
.wrapper > .step.angles-validation .right img {
    height: 150px;
    margin: 0 20px;
    box-sizing: border-box;
    padding: 5px;
}

.wrapper .step.delivery .action {
    display: flex;
}

.wrapper .step.delivery .action .left {
    width: 400px;
    box-sizing: border-box;
    padding: 20px 50px;
    border-right: 1px solid rgba(0, 0, 0, .1);
}

.wrapper .step.delivery .action .left h4 {
    font-size: var(--subtitle);
    font-weight: 500;
}

.wrapper .step.delivery .action .left p {
    font-size: var(--subparagraph);
}

.wrapper .step.delivery .action .download {
    padding: 20px 30px;
}

.wrapper .step.delivery .action .download .button {
    color: black;
    background: var(--color-background);
    border-radius: 10px;
    padding: 20px;
    width: 300px;
    display: flex;
    height: 110px;
    align-items: center;
    box-shadow: 0px 5px 20px rgba(0, 0, 0, .2);
    transition: .2s ease;
    box-sizing: border-box;
    border: 1px solid rgba(0, 0, 0, .1);
    cursor: pointer;
}

.wrapper .step.delivery .action .download .button:hover {
    box-shadow: 0px 0px 0px rgba(0, 0, 0, .2);
    background: rgba(0, 0, 0, .05);
}

.wrapper .step.delivery .action .download .button svg {
    margin-right: 20px;
}










/* styles minimaux pour confettis */
.confetti-container { position: fixed; left: 0; top: 0; width: 100%; height: 100%; pointer-events: none; overflow: visible; z-index: 9999; }
.confetti {
  position: absolute;
  will-change: transform, opacity;
  pointer-events: none;
  border-radius: 2px;
  transform-origin: center center;
  box-shadow: 0 1px 0 rgba(0,0,0,0.15);
}






/* ===== FOOTER ===== */
.footer {
    background-color: var(--color-background);
    color: black;
    position: absolute;
    bottom: 0;
    width: calc(100% - 260px);
    left: 260px;
}

.footer-bottom {
    position: absolute;
    bottom: 0;
    left: 0;
    justify-content: space-between;
    display: flex;
    height: 40px;
    box-sizing: border-box;
    padding: 10px 50px;
    font-size: 12px;
    font-weight: 500;
    width: 100%;
    cursor: default;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.footer-bottom img {
    height: clamp(9px, .6vw, 10px);
    opacity: .4;
}

.footer-bottom p {
    color: rgba(0, 0, 0, 0.4);
}

.footer-bottom p a {
    color: rgba(0, 0, 0, 0.4);
    transition: .1s ease;
}

.footer-bottom p a:hover {
    color: rgba(0, 0, 0, 0.8);
}













/* ===== CATEGORIES ===== */

.wrapper .step.quote-request .main .modules > .category {
	width: 100%;
	margin-bottom: 40px;
	display: block;
}

.wrapper .step.quote-request .main .modules > .category .category-header {
	margin-bottom: 20px;
	padding-bottom: 15px;
	border-bottom: 2px solid rgba(0, 0, 0, .1);
}

.wrapper .step.quote-request .main .modules > .category .category-header h3 {
	font-size: var(--h4);
	font-weight: 600;
	margin-bottom: 5px;
	color: var(--color-dark);
}

.wrapper .step.quote-request .main .modules > .category .category-header p {
	font-size: var(--paragraph);
	color: var(--color-grey);
	line-height: 1.5;
}

.wrapper .step.quote-request .main .modules > .category .category-content {
	display: block;
}

.wrapper .step.quote-request .main .modules > .category .modules-list,
.wrapper .step.quote-request .main .modules > .category .options-list,
.wrapper .step.quote-request .main .modules > .category .packs-list {
	display: block;
	margin-bottom: 30px;
}

.wrapper .step.quote-request .main .modules > .category .packs-header {
	margin-bottom: 15px;
	margin-top: 20px;
}

.wrapper .step.quote-request .main .modules > .category .packs-header h4 {
	font-size: var(--h5);
	font-weight: 600;
	color: var(--color-dark);
	opacity: .7;
}

/* Offer items (modules, options, packs) */
.wrapper .step.quote-request .main .modules > .category .offer-item {
	width: calc(33vw - 120px);
	max-width: 600px;
	display: inline-block;
	background-color: white;
	margin: 10px;
	border: 1px solid rgba(0, 0, 0, .2);
	border-radius: 6px;
	padding: 20px;
	cursor: default;
	transition: .1s ease;
	vertical-align: top;
}

.wrapper .step.quote-request .main .modules > .category .offer-item.selected {
	border: 1px solid var(--color-accent);
}

.wrapper .step.quote-request .main .modules > .category .offer-item:hover {
	border: 1px solid rgba(0, 0, 0, .1);
}

.wrapper .step.quote-request .main .modules > .category .offer-item.selected:hover {
	border: 1px solid var(--color-accent);
}

/* Option items specifics */
.wrapper .step.quote-request .main .modules > .category .offer-item.option-item {
	position: relative;
	padding-right: 100px;
}

.wrapper .step.quote-request .main .modules > .category .offer-item.option-item .checkbox {
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
}

.wrapper .step.quote-request .main .modules > .category .offer-item.option-item .checkbox input[type="checkbox"] {
	width: 20px;
	height: 20px;
	cursor: pointer;
	accent-color: var(--color-accent);
}

/* Pack items specifics */
.wrapper .step.quote-request .main .modules > .category .offer-item.pack-item {
	background-color: rgba(var(--color-accent-rgb), .05);
	border: 1px solid var(--color-accent);
	cursor: pointer;
}

.wrapper .step.quote-request .main .modules > .category .offer-item.pack-item:hover {
	background-color: rgba(var(--color-accent-rgb), .1);
	border: 1px solid var(--color-accent);
}

.wrapper .step.quote-request .main .modules > .category .offer-item.pack-item .content {
	display: block;
	font-size: var(--subparagraph);
	color: var(--color-grey);
	margin-top: 10px;
	font-style: italic;
}

/* Text styles within offer items */
.wrapper .step.quote-request .main .modules > .category .offer-item .text {
	margin-bottom: 15px;
}

.wrapper .step.quote-request .main .modules > .category .offer-item .text span {
	font-size: var(--subparagraph);
	color: var(--color-grey);
	font-weight: 500;
	display: block;
	margin-bottom: 5px;
}

.wrapper .step.quote-request .main .modules > .category .offer-item .text h4 {
	font-size: var(--h5);
	font-weight: 600;
	color: var(--color-dark);
	margin-bottom: 8px;
	transition: .1s ease;
}

.wrapper .step.quote-request .main .modules > .category .offer-item:hover .text h4 {
	color: var(--color-accent);
}

.wrapper .step.quote-request .main .modules > .category .offer-item.selected .text h4 {
	color: var(--color-accent);
}

.wrapper .step.quote-request .main .modules > .category .offer-item .text p {
	font-size: var(--subparagraph);
	color: var(--color-grey);
	line-height: 1.5;
	margin: 0;
}

/* Price styling */
.wrapper .step.quote-request .main .modules > .category .offer-item .price {
	float: right;
	text-align: right;
	margin-top: 0;
}

.wrapper .step.quote-request .main .modules > .category .offer-item .price span {
	font-size: var(--subparagraph);
	color: var(--color-grey);
	display: block;
}

.wrapper .step.quote-request .main .modules > .category .offer-item .price h4 {
	font-size: var(--h5);
	font-weight: 600;
	color: var(--color-accent);
	margin: 0;
}

/* Stepper styling */
.wrapper .step.quote-request .main .modules > .category .offer-item .stepper {
	border: 1px solid rgba(0, 0, 0, .2);
	border-radius: 6px;
	width: 170px;
	float: left;
	margin-top: 25px;
	padding: 3px;
	display: flex;
	flex-direction: row;
	clear: left;
}

.wrapper .step.quote-request .main .modules > .category .offer-item:hover .stepper {
	border: 1px solid var(--color-accent);
}

.wrapper .step.quote-request .main .modules > .category .offer-item .stepper input {
	font-size: var(--subparagraph);
	font-weight: 500;
	width: 100%;
	text-align: center;
	padding: 5px 0;
	outline: none;
	border: none;
	display: flex;
	justify-content: center;
	align-items: center;
	appearance: none;
	user-select: none;
	cursor: default;
}

.wrapper .step.quote-request .main .modules > .category .offer-item .stepper button {
	font-size: var(--subparagraph);
	border: none;
	outline: none;
	background-color: var(--color-white);
	padding: 0 20px;
	cursor: pointer;
	border-radius: 3px;
	transition: .1s ease;
}

.wrapper .step.quote-request .main .modules > .category .offer-item .stepper button:hover {
	background-color: var(--color-accent);
	color: white;
}

.wrapper .step.quote-request .main .modules > .category .offer-item .stepper button.disabled {
	color: var(--color-grey);
	cursor: default;
	opacity: .5;
}

.wrapper .step.quote-request .main .modules > .category .offer-item .stepper button.disabled:hover {
	color: var(--color-grey);
	background-color: var(--color-white);
	cursor: default;
	opacity: .5;
}




@media (max-width: 600px) {

    .nav-container {
        padding: 0 20px;
    }

    .nav-container .nav-logo {
        margin-top: -8px;
    }

    .nav-container .nav-item {
        overflow: hidden;
        width: 0;
        margin-top: -200px;
    }

    .side {
        width: 100%;
        height: 40px;
        padding: 0;
        margin: 0;
        position: fixed;
        z-index: 1;
        top: 70px;
        left: 0;
        overflow: hidden;
        border-bottom: 1px solid rgba(0, 0, 0, .1);
    }

    .side .steps {
        padding: 0;
        margin: 0;
    }

    .side .steps div:not(.ready) {
        display: none;
    }

    .side > .steps div.ready,
    .side > .steps div.hidden.ready,
    .side > .steps div.ready:last-of-type {
        margin: 0;
        padding: 20px 0;
        margin-left: 30px;
        padding-left: 20px;
        border-left: 2px dashed rgba(0, 0, 0, .2);
        transition: .1s ease;
        display: block;
    }

    .side .steps div.ready h4,
    .side .steps div.ready p {
        transform: none;
    }

    .side .steps div.ready::before {
        height: 50px;
        width: 2px;
        margin-left: -22px;
        margin-top: -30px;
        background: var(--color-black);
        position: absolute;
        content: "";
    }

    .side > .steps div.anim-hidden {
        opacity: 0;
        transform: translateY(20px);
        pointer-events: none;
    }




    .wrapper > div .main {
        width: 100%;
        height: calc(100% - 340px);
        top: 110px;
        padding: 0;
        margin: 0;
        position: fixed;
        left: 0;
    }








    .wrapper .step.meeting .main {
        flex-direction: column;
        overflow-y: scroll;
        overflow-x: hidden;
        height: calc(100% - 200px);
        width: 100%;
    }

    .wrapper .step.meeting .main > div {
        width: calc(100% - 20px);
        height: auto;
        margin-left: 10px;
        margin-right: 10px;
    }

    .wrapper .step.meeting .main > .left .modules {
        height: auto;
    }

    .wrapper .step.meeting .main > .left .modules .list {
        height: auto;
        mask-image: none;
    }

    .wrapper .step.meeting .main > .left .modules .list div:last-of-type {
        margin-bottom: 10px;
    }

    .wrapper .step.meeting .main > .left .actions {
        height: auto;
    }

    .wrapper .step.meeting .main > div > .files {
        height: auto;
    }


    .wrapper .step.meeting .main > .right .admin .list {
        height: auto;
    }

    .wrapper .step.meeting .main > .right .admin .list div:last-of-type {
        margin-bottom: 0;
    }

    


    .wrapper > div .action {
        position: fixed;
        width: 100%;
        height: 200px;
        bottom: 30px;
        left: 0;
        box-shadow: 0 5px 48px rgba(0, 0, 0, .5);

        display: flex;
        flex-direction: column;
        background: var(--color-white);
        transition: .2s ease;
    }

    .wrapper > div .action.small,
    .wrapper .step.angles-selection .action.small {
        height: 120px;
    }

    .wrapper .step.quote-request .action .left {
        width: 100%;
        height: auto;
        padding: 10px 0;
        padding-bottom: 0;
        margin: 0 25px;
    }

    .wrapper > .step.quote-request .action .left h4 {
        font-size: var(--title);
        color: var(--color-grey);
        width: 60%;
        margin-top: 10px;
    }

    .wrapper > .step.quote-request .action .left p {
        font-size: calc(var(--title) * 1);
        font-weight: 500;
        width: calc(100% - 50px);
    }

    .wrapper .step.quote-request .action .card {
        display: none;
    }

    .wrapper > .step .action .text {
        text-align: left;
        padding: 0 20px;
        height: 100px;
    }

    .wrapper > .step .action .text h4 {
        font-size: var(--title);
        opacity: .8;
        width: 50%;
        margin-bottom: 5px;
    }

    .wrapper > .step .action .text p {
        font-weight: 400;
        width: 100%;
        white-space: normal;
        overflow-x: inherit;
        overflow-wrap: normal; /* Recommandé : coupe le mot si nécessaire */
        word-break: normal;     /* Coupe partout, même au milieu d'un mot */
    }

    .wrapper > .step .main > .text {
        height: calc(100vh - 300px);
    }

    .wrapper > .step .main > .text img {
        width: calc(100% - 40px);
        height: auto;
        border-radius: 6px;
        border: 1px solid rgba(0, 0, 0, .2);
    }





    .wrapper .step.quote-request .main .fixed {
        flex-direction: column;
        padding: 20px;
        box-sizing: border-box;
        overflow-y: scroll;
        overflow-x: hidden;
        height: 100%;
        align-items: flex-start;
        justify-content: start;
    }

    .wrapper .step.quote-request .main .fixed > div {
        width: 100%;
        height: auto;
        margin: 0;
        margin-bottom: 20px;
    }

    .wrapper .step.quote-request .main .fixed > div:hover:not(.selected) {
        border: 1px solid rgba(0, 0, 0, .2);
    }

    .wrapper .step.quote-request .main .fixed > div.selected {
        border: 1px solid var(--color-accent);
        background-color: rgba(0, 68, 255, 0.05);
    }

    .wrapper .step.quote-request .main .fixed > div:last-of-type {
        margin-bottom: 20px;
    }


    .wrapper .step.quote-request .main .fixed > div .text {
        height: auto;
    }

    .wrapper .step.quote-request .main .fixed > div .text p {
        margin-bottom: 10px;
    }


    .wrapper .step.quote-request .main .modules {
        height: 100%;
        display: flex;
        flex-direction: column;
        overflow-x: hidden;
        mask-image: linear-gradient(to bottom, black calc(100% - 10px), transparent 100%);
        -webkit-mask-image: linear-gradient(to bottom, black calc(100% - 10px), transparent 100%);
    }

    .wrapper .step.quote-request .main .modules > div {
        width: 100%;
    }

    .wrapper .step.quote-request .main .modules > div.selected {
        background-color: rgba(0, 68, 255, 0.05);
    }

    .wrapper .step.quote-request .main .modules > div.selected .stepper {
        background-color: rgba(0, 68, 255, 0.05);
        color: var(--color-accent-hover);
    }

    .wrapper .step.quote-request .main .modules > div.selected .stepper input {
        background-color: rgba(0, 68, 255, 0.05);
    }





    .wrapper .step.quote-request .main .details {
        flex-direction: column;
        height: 100%;
        overflow-y: scroll;
        overflow-x: hidden;
    }

    .wrapper .step.quote-request .main .details > div.summary {
        width: 100%;
        height: auto;
        overflow: visible;
        border-bottom: 1px solid rgba(0, 0, 0, .2);
        position: fixed;
        background: var(--color-white);
    }

    .wrapper .step.quote-request .main .details.hidden > div.summary,
    .wrapper .step.quote-request .main .details > div.hidden.summary {
        display: none;
    }

    .wrapper .step.quote-request .main .details > .summary > h4 {
        margin-top: 10px;
        margin-bottom: -5px;
    }
    

    .wrapper .step.quote-request .main .details > .summary > h4,
    .wrapper .step.quote-request .main .details > .summary > p {
        margin-left: 10px;
    }

    .wrapper .step.quote-request .main .details > .summary > p {
        display: none;
    }

    .wrapper .step.quote-request .main .details > .summary .list {
        height: 90px;
        display: flex;
        flex-direction: row;
        justify-content: left;
        align-items: left;
        overflow-y: hidden;

        /* Le masque de transparence */
        -webkit-mask-image: linear-gradient(to right, black calc(100% - 100px), transparent 100%);
        mask-image: linear-gradient(to right, black calc(100% - 100px), transparent 100%);
    }

    .wrapper .step.quote-request .main .details > .summary .list > div {
        width: auto;
        height: 70px;
        padding: 0;
        margin: 10px 0;
        margin-right: 10px;
        align-items: center;
    }

    .wrapper .step.quote-request .main .details > .summary .list > div:last-of-type {
        margin-right: 30px;
    }

    .wrapper .step.quote-request .main .details > .summary .list > div .text {
        margin: 0 5px;
    }

    .wrapper .step.quote-request .main .details > .summary .list > div .image {
        width:  80px;
        height: 100%;
        float: right;
        border-radius: 0 6px 6px 0;
    }

    .wrapper .step.quote-request .main .details > .summary .list > div:last-of-type {
        margin-bottom: 20px;
    }


    .wrapper .step.quote-request .main .details > div.options {
        width: 100%;
        height: auto;
        overflow: visible;
        margin-top: 100px;
    }

    .wrapper .step.quote-request .main .details > div.options h4,
    .wrapper .step.quote-request .main .details > div.options p:nth-child(2) {
        display: none;
    }

    .wrapper .step.quote-request .main .details > .options .control {
        margin: 0;
        padding: 5px;
        border: none;
    }

    .wrapper .step.quote-request .main .details > .options .control-group p {
        margin-bottom: 0;
        margin-top: 20px;
    }

    .wrapper .step.quote-request .main .details > .options .control svg {
        display: none;
    }

    .wrapper .step.quote-request .main .details > .options .controls-top {
        flex-direction: column;
    }

    .wrapper .step.quote-request .main .details > .options .control textarea {
        width: 100%;
        height: 500px;
        font-size: 16px;
    }

    .wrapper .step.quote-request .main .details > div.contact.hidden,
    .wrapper .step.quote-request .main .details > div.hidden {
        width: 0;
        height: 0;
        overflow: hidden;
    }

    .wrapper .step.quote-request .main .details > div.contact {
        width: 100%;
        height: auto;
        overflow: visible;
        margin-bottom: 50px;
        margin-top: -120px;
    }

    .wrapper .step.quote-request .main .details > div.contact input {
        font-size: 16px;
        width: calc(100% - 20px);
    }





    




    .wrapper .step.quote-request .main .upload {
        flex-direction: column;
        overflow-y: scroll;
        height: calc(100% + 80px);
    }

    .wrapper .step.quote-request .main .upload > .drop-zone {
        width: 100%;
        height: 200px;
        margin-bottom: 20px;
        margin-right: 0;
    }

    
    .wrapper .step.quote-request .main .upload > .file-list {
        width: 100%;
        height: auto;
    }



    .wrapper .step.quote-request .main .submit {
        align-items: center;
        justify-content: start;
        height: calc(100% + 80px);
        overflow-y: scroll;
    }


    .wrapper .step.quote-request .main .submit > h1 {
        width: 80%;
        font-size: var(--title);
    }

    .wrapper .step.quote-request .main .submit > p {
        width: 80%;
        font-size: var(--subtitle);
    }

    .wrapper .step.quote-request .main .submit .timeline {
        flex-direction: column;
        align-items: flex-start;
        justify-content: start;
        width: 80%;
        min-width: auto;
        margin: 10px 0;
        padding: 5px;
    }

    .wrapper .step.quote-request .main .submit .timeline .bar {
        display: none;
    }

    .wrapper .step.quote-request .main .submit .timeline .text {
        margin-bottom: 20px;
        border-bottom: 1px solid rgba(0, 0, 0, .1);
        width: 100%;
        margin: 0;
        padding: 5px 10px;
    }

    .wrapper .step.quote-request .main .submit .timeline .text:last-of-type {
        margin-bottom: 0;
        border-bottom: none;
    }


    .wrapper .step.quote-request .main .submit .timeline .text span {
        margin-left: 25px;
    }

    .wrapper .step.quote-request .main .submit .buttons {
        flex-direction: column;
        width: 80vw;
    }


    .wrapper .step.quote-request .main .submit .buttons a {
        width: 100%;
        font-size: var(--title);
        margin-bottom: 10px;
        text-align: center;
        padding: 20px;
    }






    

    

    .wrapper .step.quote-request .action.small .left h4, 
    .wrapper .step.quote-request .action.small .left p {
        width: 100%;
    }

    .wrapper .step.quote-request .action .left h4 span.number {
        display: none;
    }



    .wrapper .step.quote-request .action .left .prev {
        position: fixed;
        right: 10px;
        bottom: 190px;
        z-index: 999;
    }

    .wrapper .step.quote-request .action.small .left .prev {
        bottom: 110px;
    }

    .wrapper .step.quote-request .action .next {
        max-height: 150px;
        margin: 0 10px;
        box-sizing: border-box;
        overflow: visible;
    }

     .wrapper .step.quote-request .action .next.hidden,
     .wrapper .step.quote-request .action .next.hidden:hover {
        cursor: default;
        opacity: .5;
        box-shadow: none;
     }


     .wrapper .step.quote-request .action .next a {
        display: block;
        margin: 0;
        padding: 10px 15px;
        height: 65px;
        width: calc(100vw - 20px);
        bottom: 60px;
        justify-content: space-between;
        position: fixed;
     }

     .wrapper .step.quote-request .action .next.hidden:hover a {
        box-shadow: none;
        border: 1px solid rgba(0, 0, 0, .1);
     }

     .wrapper .step.quote-request .action .next a svg {
        margin-top: 10px;
        float: right;
     }

    .wrapper .step.quote-request .action .next.hidden a div h5,
    .wrapper .step.quote-request .action .next.hidden:hover a div h5,
    .wrapper .step.quote-request .action .next.hidden a div span,
    .wrapper .step.quote-request .action .next.hidden:hover a div span {
        color: var(--color-black);
    }

    .wrapper .step.quote-request .action .next.hidden a svg,
    .wrapper .step.quote-request .action .next.hidden:hover a svg {
        fill: var(--color-grey);
    }

    .wrapper > .step.quote-request .inputs .send {
        transform: translateY(20px);
        width: calc(100vw - 40px);
        margin-left: 10px;
    }











    /* QUOTE SIGNATURE
    ==================== */

    .wrapper > .step .action .sign {
        flex-direction: column;
        padding: 0;
    }

    .wrapper .step.quote-signature .action .left {
        width: 100%;
        flex-direction: row;
        padding: 0px;
    }

    .wrapper > .step .action .sign .left a {
        font-size: var(--title);
        padding: 10px;
        width: 50%;
    }

    .wrapper > .step .action .sign canvas {
        height: auto;
    }

    .wrapper > .step .action .sign .clear {
        position: absolute;
        top: 90px;
        right: 0px;
        z-index: 10;
    }

    .wrapper > .step .action .sign .send {
        position: absolute;
        background: var(--color-white);
        border: 1px solid rgba(0, 0, 0, .2);
        padding: 5px 0;
        height: auto;
        display: flex;
        top: 0;
        width: calc(100% - 6px);
        margin: 3px;
    }

    .wrapper > .step .action .sign .send.hidden {
        display: none;
    }
    
    .wrapper > .step .action .sign .send div {
        display: flex;
        align-items: flex-start;
        justify-content: center;
    }

    .wrapper > .step .action .sign .send p {
        margin-top: 0;
        font-size: var(--paragraph);
        margin-right: 0;
        display: inline-block;
    }

    .wrapper > .step .action .sign .send h4 {
        display: inline-block;
        margin-right: 20px;
    }

    .wrapper > .step.angles-selection {
        overflow-x: hidden;
        width: 100%;
    }

    .wrapper > .step.angles-selection .main {
        overflow-x: hidden;
        overflow: hidden;
        width: 100%;
    }

    .wrapper > .step.angles-selection .list {
        height: calc(100vh - 300px);
        width: 100%;
        margin: 0;
        text-align: center;
        overflow-x: hidden;
    }

    .wrapper > .step.angles-selection .list > div {
        width: 100%;
    }

    .wrapper > .step.angles-selection .list > div:last-of-type {
        margin-bottom: 100px;
    }

    .wrapper > .step.angles-selection .action {
        flex-direction: row;
        overflow-x: auto;
        white-space: wrap;
        width: 100vw;
        height: 200px;
    }

    .wrapper > .step.angles-selection .action .left {
        padding: 20px;
        width: 100vw;
        white-space: normal;
        overflow-x: inherit;
    }

    .wrapper > .step.angles-selection .action .left p {
        width: calc(100vw - 40px);
        white-space: normal;
        overflow-x: inherit;
        overflow-wrap: normal; /* Recommandé : coupe le mot si nécessaire */
        word-break: normal;     /* Coupe partout, même au milieu d'un mot */
        
    }

    .wrapper > .step.angles-selection .list .droppable-angle-selection {
        border: 2px solid transparent;
        background-color: white;
        box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
    }

    .wrapper > .step.angles-selection .list .droppable-angle-selection .img {
        height: calc(60vw);
    }

    .wrapper > .step.angles-selection .list .droppable-angle-selection.selected {
        border: 2px solid var(--color-accent);
        background-color: var(--color-accent-dim);
        color: var(--color-accent-hover);
        box-sizing: none;
    }

    
.wrapper > .step.angles-selection .main .droppable-angle-selection .comment {
    display: block;
    flex-direction: row;
    justify-content: left;
    align-items: center;
    background: rgba(255, 255, 255, 0.6);
    backdrop-filter: blur(6px) saturate(180%);
    border-radius: 80px;
    padding: 14px;
    width: 48px;
    height: 48px;
    max-width: 48px;
    box-sizing: border-box;
    transform: translateY(-20px) translateX(30px);
    transition: .1s ease;
    float: right;
    overflow: hidden;
    color: var(--color-black);
}

.wrapper > .step.angles-selection .main .droppable-angle-selection:not(.fixed) .comment {
    display: block;
}

.wrapper > .step.angles-selection .main .droppable-angle-selection:hover .comment {
    background: rgba(255, 255, 255, 0.4);
}

.wrapper > .step.angles-selection .main .droppable-angle-selection .comment:hover {
    background: rgba(255, 255, 255, 0.4);
}

.wrapper > .step.angles-selection .main .droppable-angle-selection .comment:active {
    background-color: var(--color-accent-dim);
    color: var(--color-accent-hover);
    fill: var(--color-accent-hover);
}

.wrapper > .step.angles-selection .main .droppable-angle-selection .comment svg {
    height: 18px;
    width: 18px;
}

.wrapper > .step.angles-selection .main .droppable-angle-selection .comment span {
    display: none;
}

    .wrapper > .comment_modal > div {
        flex-direction: column;
        width: calc(100vw - 40px);
    }

    .wrapper > .comment_modal > div > .image-wrapper {
        width: 100%;
        height: 270px;
    }

    .wrapper > .comment_modal > div > .text {
        width: 100%;
    }

    .wrapper > .comment_modal > div > .text h2 {
        height: auto;
    }

    .wrapper > .comment_modal > div > .text textarea {
        font-size: 16px;
    }
    


    .nav-item.button.angles-selection {
        font-size: var(--title);
        position: fixed;
        bottom: 60px;
        left: 10px;
        z-index: 10;
        width: calc(100vw - 20px);
    }

    .nav-item.button.angles-selection.hidden {
        background-color: rgba(0, 0, 0, .05);
        color: var(--color-grey);
        border: 1px solid rgba(0, 0, 0, .2);
    }






    .wrapper > div.deposit-invoice .main,
    .wrapper > div.final-invoice .main {
        height: calc(100% - 440px);
    }

    .wrapper > div.deposit-invoice .action,
    .wrapper > div.final-invoice .action {
        height: 300px;
    }


    .wrapper > .step .action .invoice {
        flex-direction: column;
    }

    .wrapper > .step .action .invoice .left {
        width: 100%;
        padding: 20px;
        height: auto;
        padding-bottom: 0;
    }

    .wrapper > .step .action .invoice .left h4 {
        width: 100%;
    }

    .wrapper > .step .action .invoice .left p {
        width: 100%;
    }

    .wrapper > .step .action .invoice .buttons {
        width: 100%;
    }

    .wrapper > .step .action .invoice .buttons a.pay {
        height: 70px;
    }

    .wrapper > .step .action .invoice .buttons a.pay span {
        width: 140px;
        line-height: 16px;
    }

    .wrapper > .step .action .invoice .right {
        display: none;
    }

    .wrapper > .step.revision .main,
    .wrapper > .step.revision .action,
    .wrapper > .step.validation .main,
    .wrapper > .step.validation .action {
        display: none;
    }

    .wrapper > .mobile-declined {
        position: fixed;
        top: 0;
        left: 0;
        width: 100vw;
        height: 100vh;
        box-sizing: border-box;
        padding: 20px;
        background-color: var(--color-white);
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column;
        text-align: center;
    }

     .wrapper > .mobile-declined h4 {
        font-size: calc(var(--title) * 1.5);
        margin-bottom: 10px;
        font-weight: 500;
    }

    .wrapper > .mobile-declined p {
        font-size: calc(var(--title) * 1.2);
    }

    .wrapper > .mobile-declined a {
        width: 100%;
        padding: 10px;
        border-radius: 6px;
        border: 1px solid rgba(0, 0, 0, .2);
        font-weight: 500;
        font-size: var(--paragraph);
        color: var(--color-grey);
        margin-top: 20px;
    }

    .wrapper > .mobile-declined a:active {
        background-color: var(--color-grey);
        color: var(--color-black);
    }

    .wrapper > .step.delivery .action {
        flex-direction: column;
        height: 240px;
    }


    .wrapper > .step.delivery .action .left {
        width: 100%;
        padding: 20px;
        height: auto;
        padding-bottom: 0;
    }

    .wrapper > .step.delivery .action .left h4 {
        width: 100%;
        font-size: var(--subtitle);
    }

    .wrapper > .step.delivery .action .left p {
        width: 100%;
        font-size: calc(var(--title) * 1.5);
    }

    .wrapper > .step.delivery .action .download {
        width: 100%;
        padding: 0 20px;
    }

    .wrapper > .step.delivery .action .download .button {
        width: 100%;
        height: auto;
        margin-top: 10px;
    }

    .wrapper > .step.delivery .main .text {
        height: calc(100vh - 400px);
    }








    footer.footer {
        width: 100%;
        left: 0;
        position: fixed;
        bottom: 0;
        height: 50px;
        padding: 0;
    }

    footer .footer-bottom {
        font-size: 10px;
        padding: 10px 20px;
        padding-right: 20px;
        height: 50px;
        flex-direction: column;
        justify-content: center;
        align-items: left;
        text-align: left;
    }

}
/* ===== STYLES POUR LES APPAREILS TACTILES (CLASSE .mobile) ===== */
html.mobile .wrapper > .step.angles-selection {
    overflow-x: hidden;
    width: 100%;
}

html.mobile .wrapper > .step.angles-selection .main {
    overflow-x: hidden;
    overflow: hidden;
    width: 100%;
}

html.mobile .wrapper > .step.angles-selection .list {
    height: calc(100vh - 300px);
    width: 100%;
    margin: 0;
    text-align: center;
    overflow-x: hidden;
}

html.mobile .wrapper > .step.angles-selection .list > div {
    width: 100%;
}

html.mobile .wrapper > .step.angles-selection .list > div:last-of-type {
    margin-bottom: 100px;
}

html.mobile .wrapper > .step.angles-selection .action {
    flex-direction: row;
    overflow-x: auto;
    white-space: wrap;
    width: 100vw;
    height: 200px;
}

html.mobile .wrapper > .step.angles-selection .action .left {
    padding: 20px;
    width: 100vw;
    white-space: normal;
    overflow-x: inherit;
}

html.mobile .wrapper > .step.angles-selection .action .left p {
    width: calc(100vw - 40px);
    white-space: normal;
    overflow-x: inherit;
    overflow-wrap: normal;
    word-break: normal;
}

html.mobile .wrapper > .step.angles-selection .list .droppable-angle-selection {
    border: 2px solid transparent;
    background-color: white;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
}

html.mobile .wrapper > .step.angles-selection .list .droppable-angle-selection .img {
    height: calc(60vw);
}

html.mobile .wrapper > .step.angles-selection .list .droppable-angle-selection.selected {
    border: 2px solid var(--color-accent);
    background-color: var(--color-accent-dim);
    color: var(--color-accent-hover);
    box-sizing: none;
}

html.mobile .wrapper > .step.angles-selection .main .droppable-angle-selection .comment {
    display: block;
    flex-direction: row;
    justify-content: left;
    align-items: center;
    background: rgba(255, 255, 255, 0.6);
    backdrop-filter: blur(6px) saturate(180%);
    border-radius: 80px;
    padding: 14px;
    width: 48px;
    height: 48px;
    max-width: 48px;
    box-sizing: border-box;
    transform: translateY(-20px) translateX(30px);
    transition: .1s ease;
    float: right;
    overflow: hidden;
    color: var(--color-black);
}

html.mobile .wrapper > .step.angles-selection .main .droppable-angle-selection:not(.fixed) .comment {
    display: block;
}

html.mobile .wrapper > .step.angles-selection .main .droppable-angle-selection:hover .comment {
    background: rgba(255, 255, 255, 0.4);
}

html.mobile .wrapper > .step.angles-selection .main .droppable-angle-selection .comment:hover {
    background: rgba(255, 255, 255, 0.4);
}

html.mobile .wrapper > .step.angles-selection .main .droppable-angle-selection .comment:active {
    background-color: var(--color-accent-dim);
    color: var(--color-accent-hover);
    fill: var(--color-accent-hover);
}

html.mobile .wrapper > .step.angles-selection .main .droppable-angle-selection .comment svg {
    height: 18px;
    width: 18px;
}

html.mobile .wrapper > .step.angles-selection .main .droppable-angle-selection .comment span {
    display: none;
}