:root { --bp-mobile: 640px;
--bp-tablet: 1024px;
--bp-desktop: 1280px;
--btn-primary-bg: #3C0314;
--btn-primary-bg-hover: #2a020e;
--btn-primary-color: #ffffff;
--btn-secondary-color: currentColor;
--btn-border-radius: 8px;
--btn-font-size: 20px;
--btn-font-weight: 700;
--btn-padding-y: 12px;
--btn-padding-x: 24px;
--btn-gap: 8px;
--btn-transition: all 0.25s ease;
--badge-bg: #fdf2f4;
--badge-color: #3C0314;
--badge-border-radius: 9999px;
--badge-font-size: 0.75rem;
--badge-font-weight: 600;
--badge-padding-y: 4px;
--badge-padding-x: 12px;
--card-bg: #ffffff;
--card-border: 1px solid #e5e7eb;
--card-border-radius: 12px;
--card-padding: 24px;
--card-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
--card-shadow-hover: 0 8px 24px rgba(0, 0, 0, 0.1);
--card-transition: all 0.3s ease;
--section-padding-y: 80px;
--section-padding-x: 64px;
--section-max-width: 1312px;
--container-xl: var(--section-max-width);
--spacing-container-x: var(--section-padding-x);
--focus-ring-color: #3C0314;
} .skip-link {
position: absolute;
left: 16px;
top: -48px;
z-index: 2000;
padding: 10px 14px;
background: #ffffff;
color: #232425;
border: 2px solid var(--focus-ring-color);
border-radius: 8px;
text-decoration: none;
transition: top 0.2s ease;
}
.skip-link:focus,
.skip-link:focus-visible {
top: 16px;
} .btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: var(--btn-gap);
padding: var(--btn-padding-y) var(--btn-padding-x);
border-radius: var(--btn-border-radius);
font-size: var(--btn-font-size);
font-weight: var(--btn-font-weight);
line-height: 1.5;
cursor: pointer;
text-decoration: none;
white-space: nowrap;
border: none;
position: relative;
overflow: hidden;
transition: var(--btn-transition);
box-sizing: border-box;
font-family: "Figtree", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}  .btn-primary {
background-color: var(--btn-primary-bg);
color: var(--btn-primary-color);
border: 1px solid var(--btn-primary-bg);
}
.btn-primary:hover,
.btn-primary:focus {
background-color: var(--btn-primary-bg-hover);
border-color: var(--btn-primary-bg-hover);
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
.btn-primary:active {
transform: translateY(0);
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
} .btn-secondary {
background-color: transparent;
color: var(--btn-secondary-color);
border: 1px solid currentColor;
}
.btn-secondary:hover,
.btn-secondary:focus {
background-color: rgba(0, 0, 0, 0.04);
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}
.btn-secondary:active {
transform: translateY(0);
box-shadow: none;
} .btn.btn-text {
background-color: transparent;
color: var(--btn-secondary-color);
border: none;
padding-left: 0;
padding-right: 0;
}
.btn.btn-text:hover,
.btn.btn-text:focus {
opacity: 0.8;
transform: translateY(-1px);
}
.btn.btn-text:active {
opacity: 1;
transform: translateY(0);
} .btn:focus-visible {
outline: 2px solid currentColor;
outline-offset: 2px;
}
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[role="button"]:focus-visible {
outline: 2px solid var(--focus-ring-color);
outline-offset: 2px;
}
.btn-disabled {
cursor: default;
pointer-events: none;
opacity: 0.72;
} .btn .btn-icon-left,
.btn .btn-icon-right {
width: 20px;
height: 20px;
object-fit: contain;
flex-shrink: 0;
} .btn .btn-text {
display: inline;
font: inherit;
font-weight: inherit;
line-height: inherit;
} .icon,
.icon--fallback {
box-sizing: border-box;
vertical-align: middle;
}
.icon {
display: inline-block;
width: var(--us-icon-size, auto);
height: var(--us-icon-size, auto);
object-fit: contain;
}
.icon--fallback {
display: inline-flex;
align-items: center;
justify-content: center;
width: var(--us-icon-size, auto);
height: var(--us-icon-size, auto);
}
.icon.icon--wrapped,
.icon--fallback.icon--wrapped {
box-sizing: content-box;
padding: var(--us-icon-wrap-padding, 8px);
border-radius: var(--us-icon-wrap-radius, 8px);
} .usine-badge {
display: inline-flex;
align-items: center;
gap: 4px;
padding: var(--badge-padding-y) var(--badge-padding-x);
background-color: var(--badge-bg);
color: var(--badge-color);
font-size: var(--badge-font-size);
font-weight: var(--badge-font-weight);
line-height: 1.4;
border-radius: var(--badge-border-radius);
white-space: nowrap;
text-transform: uppercase;
letter-spacing: 0.025em;
} .usine-badge--solid {
background-color: var(--badge-color);
color: #ffffff;
} .usine-badge--outline {
background-color: transparent;
border: 1px solid currentColor;
} .usine-badge--success {
--badge-bg: #ecfdf5;
--badge-color: #059669;
} .usine-badge--warning {
--badge-bg: #fffbeb;
--badge-color: #d97706;
} .usine-badge--error {
--badge-bg: #fef2f2;
--badge-color: #dc2626;
} .usine-card {
background-color: var(--card-bg);
border: var(--card-border);
border-radius: var(--card-border-radius);
padding: var(--card-padding);
box-shadow: var(--card-shadow);
transition: var(--card-transition);
box-sizing: border-box;
overflow: hidden;
}
.usine-card:hover {
box-shadow: var(--card-shadow-hover);
} a.usine-card,
.usine-card--clickable {
cursor: pointer;
text-decoration: none;
color: inherit;
}
a.usine-card:hover,
.usine-card--clickable:hover {
transform: translateY(-2px);
box-shadow: var(--card-shadow-hover);
} .usine-card__image {
width: 100%;
aspect-ratio: 16 / 9;
overflow: hidden;
border-radius: calc(var(--card-border-radius) - 4px);
margin-bottom: 16px;
}
.usine-card__image img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
} .usine-card__body {
display: flex;
flex-direction: column;
gap: 12px;
} .usine-card__header {
display: flex;
align-items: flex-start;
justify-content: space-between;
gap: 12px;
} .usine-card__footer {
display: flex;
align-items: center;
gap: 12px;
margin-top: auto;
padding-top: 16px;
} .usine-card--highlighted {
border-color: var(--btn-primary-bg);
box-shadow: 0 0 0 1px var(--btn-primary-bg), var(--card-shadow);
} .usine-card--flat {
border: none;
box-shadow: none;
}
.usine-card--flat:hover {
box-shadow: var(--card-shadow);
} .usine-section {
width: 100%;
padding: var(--section-padding-y) var(--section-padding-x);
box-sizing: border-box;
display: flex;
flex-direction: column;
align-items: center;
}
.usine-section__inner {
width: 100%;
max-width: var(--section-max-width);
min-width: 0;
display: flex;
flex-direction: column;
} .usine-section__header {
display: flex;
flex-direction: column;
gap: 16px;
margin-bottom: 48px;
}
.usine-section__header--center {
text-align: center;
align-items: center;
} .icon-text {
display: flex;
align-items: flex-start;
gap: 8px;
}
.icon-text--wrapped {
padding: var(--us-icon-text-wrap-padding, 12px);
box-sizing: border-box;
border-radius: inherit;
}
.icon-text__icon {
width: var(--us-icon-size, 24px);
height: var(--us-icon-size, 24px);
flex-shrink: 0;
display: inline-flex;
align-items: center;
justify-content: center;
box-sizing: border-box;
}
.icon-text__icon.icon--wrapped {
box-sizing: content-box;
}
.icon-text__icon img,
.icon-text__icon svg {
width: 100%;
height: 100%;
object-fit: contain;
}
.icon-text__text {
font-size: 16px;
line-height: 1.5;
min-width: 0;
flex: 1 1 auto;
}   .us-slider {
overflow: hidden;
position: relative;
width: 100%;
--us-slider-visible: 1;
--us-slider-arrow-bg: rgba(255, 255, 255, 0.9);
--us-slider-arrow-bg-hover: #ffffff;
--us-slider-arrow-border-color: transparent;
--us-slider-arrow-border-width: 0px;
--us-slider-arrow-radius: 50%;
--us-slider-arrow-icon-color: #000000;
--us-slider-dot-color: #d1d5db;
--us-slider-dot-hover-color: #9ca3af;
--us-slider-dot-active-color: #374151;
}
.us-slider__track {
display: flex;
transition: transform 0.5s ease; }
.us-slider__track > * {
flex: 0 0 calc(100% / var(--us-slider-visible, 1));
min-width: 0;
box-sizing: border-box;
} .us-slider[data-nbr-visible="2"] { --us-slider-visible: 2; }
.us-slider[data-nbr-visible="3"] { --us-slider-visible: 3; }
.us-slider[data-nbr-visible="4"] { --us-slider-visible: 4; } .us-slider[data-nbr-visible="5"] { --us-slider-visible: 5; }
.us-slider[data-nbr-visible="6"] { --us-slider-visible: 6; } .us-slider__prev,
.us-slider__next {
position: absolute;
top: 50%;
transform: translateY(-50%);
z-index: 2;
width: 48px;
height: 48px;
background: var(--us-slider-arrow-bg);
border: var(--us-slider-arrow-border-width) solid var(--us-slider-arrow-border-color);
border-radius: var(--us-slider-arrow-radius);
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
box-shadow: var(--us-slider-arrow-shadow, 0 2px 8px rgba(0, 0, 0, 0.15));
transition: background 0.2s, box-shadow 0.2s;
}
.us-slider__prev { left: 16px; }
.us-slider__next { right: 16px; }
.us-slider__prev:hover,
.us-slider__next:hover {
background: var(--us-slider-arrow-bg-hover);
box-shadow: var(--us-slider-arrow-shadow-hover, 0 4px 12px rgba(0, 0, 0, 0.2));
}
.us-slider__prev svg,
.us-slider__next svg {
width: 24px;
height: 24px;
color: var(--us-slider-arrow-icon-color);
} .us-slider__dots {
display: flex;
justify-content: center;
gap: 8px;
margin-top: 24px;
}
.us-slider__dot {
width: 10px;
height: 10px;
background: var(--us-slider-dot-color);
border: none;
border-radius: 50%;
cursor: pointer;
padding: 0;
transition: background 0.2s, transform 0.2s;
}
.us-slider__dot:hover {
background: var(--us-slider-dot-hover-color);
}
.us-slider__dot.is-active {
background: var(--us-slider-dot-active-color);
transform: scale(1.2);
} @media (max-width: 1200px) {
:root {
--section-padding-x: 48px;
}
}
@media (max-width: 1024px) {
:root {
--section-padding-y: 48px;
--section-padding-x: 32px;
--card-padding: 20px;
} main#primary > .page-content-wrapper > .entry-content > section,
main#primary > .page-content-wrapper > .entry-content .usine-bloc-stack > section {
padding-top: 48px !important;
padding-bottom: 48px !important;
} .entry-content > * + *,
.site-main > * + * {
margin-top: 12px !important;
} .usine-navbar + main#primary {
margin-top: 12px !important;
} .usine-section__header {
margin-bottom: 24px !important;
} main#primary .entry-content section [class*="bloc-"][class*="__header"]:not([class*="__header-action"]):not([class*="__header-buttons"]) {
gap: 4px !important;
row-gap: 4px !important;
column-gap: 4px !important;
} main#primary .entry-content section [class*="bloc-"][class*="__header-content"] {
gap: 4px !important;
row-gap: 4px !important;
column-gap: 4px !important;
} main#primary > .page-content-wrapper > .entry-content
:is(.usine-card, [class*="__card"]) {
padding: var(--card-padding) !important;
gap: 18px !important;
} main#primary > .page-content-wrapper > .entry-content
:is(.usine-bloc-stack, .usine-bloc-stack--text01-feat02) {
gap: 18px !important;
}
}
@media (max-width: 768px) {
:root {
--section-padding-y: 36px;
--section-padding-x: 16px;
--card-padding: 14px;
} main#primary > .page-content-wrapper > .entry-content > section,
main#primary > .page-content-wrapper > .entry-content .usine-bloc-stack > section {
padding-top: 32px !important;
padding-bottom: 32px !important;
} .entry-content > * + *,
.site-main > * + * {
margin-top: 10px !important;
} .usine-navbar + main#primary {
margin-top: 10px !important;
} .usine-section__header {
margin-bottom: 20px !important;
} main#primary > .page-content-wrapper > .entry-content
:is(.usine-card, [class*="__card"]) {
padding: var(--card-padding) !important;
gap: 16px !important;
} main#primary > .page-content-wrapper > .entry-content
:is(.usine-bloc-stack, .usine-bloc-stack--text01-feat02) {
gap: 16px !important;
} .btn {
max-width: 100%;
white-space: normal;
text-align: center;
justify-content: center;
} .usine-card {
border-radius: 8px;
} .usine-section__header {
gap: 12px;
margin-bottom: 32px;
} .us-slider[data-nbr-visible] .us-slider__track > * {
flex: 0 0 100%;
}
.us-slider__prev,
.us-slider__next {
width: 40px;
height: 40px;
}
.us-slider__prev svg,
.us-slider__next svg {
width: 20px;
height: 20px;
}
}  @media (max-width: 1024px) {
:root {
--typ-h1: 36px;
--typ-h2: 30px;
--typ-h3: 26px;
--typ-h4: 22px;
--typ-h5: 20px;
--typ-h6: 18px;
--typ-body: 15px;
--typ-small: 13px;
--btn-font-size: 18px;
--badge-font-size: 0.72rem;
}
:where(h1) { font-size: var(--typ-h1) !important; line-height: 1.08 !important; }
:where(h2) { font-size: var(--typ-h2) !important; line-height: 1.1 !important; }
:where(h3) { font-size: var(--typ-h3) !important; line-height: 1.12 !important; }
:where(h4) { font-size: var(--typ-h4) !important; line-height: 1.14 !important; }
:where(h5) { font-size: var(--typ-h5) !important; line-height: 1.16 !important; }
:where(h6) { font-size: var(--typ-h6) !important; line-height: 1.18 !important; }
:where(body, p, li, blockquote) {
font-size: var(--typ-body) !important;
line-height: 1.6 !important;
}
:where(small) {
font-size: var(--typ-small) !important;
line-height: 1.4 !important;
}
:where(.btn) {
font-size: var(--btn-font-size) !important;
}
} @media (max-width: 768px) {
:root {
--typ-h1: 32px;
--typ-h2: 28px;
--typ-h3: 22px;
--typ-h4: 20px;
--typ-h5: 18px;
--typ-h6: 16px;
--typ-body: 15px;
--typ-small: 13px;
--btn-font-size: 16px;
--badge-font-size: 0.7rem;
}
:where(h1) { font-size: var(--typ-h1) !important; line-height: 1.08 !important; }
:where(h2) { font-size: var(--typ-h2) !important; line-height: 1.1 !important; }
:where(h3) { font-size: var(--typ-h3) !important; line-height: 1.12 !important; }
:where(h4) { font-size: var(--typ-h4) !important; line-height: 1.14 !important; }
:where(h5) { font-size: var(--typ-h5) !important; line-height: 1.16 !important; }
:where(h6) { font-size: var(--typ-h6) !important; line-height: 1.18 !important; }
:where(body, p, li, blockquote) {
font-size: var(--typ-body) !important;
line-height: 1.6 !important;
}
:where(small) {
font-size: var(--typ-small) !important;
line-height: 1.4 !important;
}
:where(.btn) {
font-size: var(--btn-font-size) !important;
}
}  @media (prefers-reduced-motion: reduce) {
.btn,
.usine-card,
a.usine-card,
.usine-card--clickable,
.us-slider__track {
transition-duration: 0.01ms !important;
animation-duration: 0.01ms !important;
}
.btn:hover,
.btn:focus,
.usine-card:hover,
a.usine-card:hover {
transform: none !important;
}
} @media print {
.btn {
box-shadow: none !important;
border: 1px solid currentColor;
}
.usine-card {
box-shadow: none !important;
border: 1px solid #ccc;
break-inside: avoid;
}
.usine-section {
padding: 24px 0;
}
}