/** Shopify CDN: Minification failed

Line 4803:2 All "@import" rules must come first

**/
/* SHOPIFY_STYLESHEETS_VERSION: 1.0 */


/* CSS from section stylesheet tags */
/* START_SECTION:announcement-bar (INDEX:0) */
.announcement-bar {
    width: 100%;
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
  }

  .announcement-bar__content {
    width: 100%;
  }

  .announcement-bar__content .splide__arrow {
    background: transparent;
    border: none;

    .icon {
      font-size: 20px !important;
    }
  }
/* END_SECTION:announcement-bar */

/* START_SECTION:blog-featured (INDEX:1) */
.blog-featured {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .blog-featured__inner {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .blog-featured__grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    gap: var(--gap-md);
  }

  @media (width > 750px) {
    .blog-featured__grid {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_SECTION:blog-featured */

/* START_SECTION:breadcrumbs (INDEX:2) */
/* Fix Isoore : le breadcrumb visible (.breadcrumbs) reçoit le padding-top pour passer sous le header fixe 80px.
     IMPORTANT : appliquer sur .breadcrumbs et NON sur .section-breadcrumbs — sinon l'espace s'applique aussi sur les pages où le breadcrumb n'est pas rendu (homepage). */
  .breadcrumbs {
    padding-top: 100px;
    padding-bottom: var(--padding-md);
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }
  @media (max-width: 990px) {
    .breadcrumbs {
      padding-top: 90px;
    }
  }

  .breadcrumbs__list {
    list-style-type: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: row;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--gap-xs);
  }

  .breadcrumbs__item {
    display: flex;
    font-size: var(--font-body--size);
    flex-direction: row;
    align-items: center;
    gap: var(--gap-xs);
  }

  .breadcrumbs__item:not(:last-child):after {
    content: '';
    display: inline-block;
    position: relative;
    vertical-align: middle;
  }

  .breadcrumbs--triangle .breadcrumbs__item:not(:last-child):after {
    border-style: solid;
    border-width: 0.1em 0.1em 0 0;
    height: 0.35em;
    width: 0.35em;
    transform: rotate(45deg);
  }

  .breadcrumbs--slash .breadcrumbs__item:not(:last-child):after {
    content: '/';
  }

  .breadcrumbs__link {
    cursor: pointer;
    display: inline-block;
    border: none;
    box-shadow: none;
    text-decoration: none;
    text-underline-offset: 0.3rem;
    transition: var(--animation-link-hover);
  }

  .breadcrumbs__link:hover {
    opacity: var(--opacity-link-hover);
  }
/* END_SECTION:breadcrumbs */

/* START_SECTION:cart-drawer (INDEX:3) */
:root {
    --cart-item-image-width: 80px;
  }

  cart-drawer {
    position: fixed;
    z-index: 10000;
    left: 0;
    top: 0;
    width: 100vw;
    height: 100%;
    display: flex;
    justify-content: flex-end;
    background: rgba(var(--color-shadow));
    opacity: 0;
    visibility: hidden;
    -webkit-backdrop-filter: brightness(1);
    backdrop-filter: brightness(1);
    transition: opacity var(--animation-speed) var(--animation-easing), visibility var(--animation-speed) var(--animation-easing);
  }

  cart-drawer.is-open {
    opacity: 1;
    visibility: visible;
    -webkit-backdrop-filter: brightness(0.75);
    backdrop-filter: brightness(0.75);
    transition: opacity var(--animation-speed) var(--animation-easing), visibility var(--animation-speed) var(--animation-easing),
      -webkit-backdrop-filter var(--animation-speed) var(--animation-easing), backdrop-filter var(--animation-speed) var(--animation-easing);
  }

  cart-drawer.is-open .cart-drawer__inner {
    animation: modalSlideInRight var(--animation-speed) var(--animation-easing) forwards;
  }

  cart-drawer.is-closing .cart-drawer__inner {
    animation: modalSlideOutRight var(--animation-speed) var(--animation-easing) forwards;
  }

  .cart-drawer__inner {
    height: 100%;
    width: var(--cart-drawer-width);
    max-width: calc(100vw - 30px);
    padding: 0 var(--padding-md);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    background-color: var(--color-background);
    color: var(--color-foreground);
    box-shadow: var(--modal-shadow);
  }

  @media (width <= 750px) {
    .cart-drawer__inner.cart-drawer--full-width-on-mobile {
      width: 100%;
      max-width: 100%;
    }
  }

  @media (width <= 350px) {
    .cart-drawer__inner {
      width: 100%;
    }
  }

  .cart-drawer .splide:not(.is-overflow) .splide__pagination {
    display: flex;
  }

  .cart-drawer .slider-block--with-pagination {
    padding-bottom: var(--margin-md);
  }

  .cart-drawer .splide__pagination {
    bottom: calc(-1 * var(--margin-md));
  }

  .cart-drawer--floating {
    margin: 15px;
    height: calc(100% - 30px);
  }

  .cart-drawer--rounded.card {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
  }

  .cart-drawer__inner-empty {
    height: 100%;
    padding: 0 var(--padding-sm);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: var(--gap-lg);
  }

  .cart-drawer__inner-empty > p {
    text-align: center;
  }

  .cart-drawer__inner-empty .cart-drawer__close {
    right: var(--padding-sm);
    position: absolute;
    top: var(--padding-sm);
  }

  @media screen and (max-width: 350px) {
    .cart-drawer__inner {
      max-width: calc(100vw - 10px);
    }

    .cart-drawer--floating {
      margin: 5px;
      height: calc(100% - 10px);
    }
  }

  /* Cart Drawer Empty State */

  .cart-drawer--empty .cart-drawer__header,
  .cart-drawer--empty .cart-drawer__body,
  .cart-drawer--empty .cart-drawer__footer {
    display: none;
  }

  cart-drawer:not(.cart-drawer--empty) .cart-drawer__inner-empty {
    display: none;
  }

  /* Cart Drawer Header */

  .cart-drawer__header {
    position: relative;
    padding: var(--padding-md);
    border-bottom: var(--separator-border-width) solid var(--color-border);
    margin-left: calc(-1 * var(--padding-md));
    width: calc(100% + (2 * var(--padding-md)));
  }

  .cart-drawer__header_title {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .cart-drawer__header h2 {
    margin: 0;
    display: flex;
    align-items: center;
    gap: 5px;
    color: rgb(var(--color-foreground));
  }

  .cart-drawer__close {
    display: inline-block;
    padding: 0;
    color: rgb(var(--color-foreground));
    background-color: transparent;
    border: none;
    cursor: pointer;
    height: 24px;
  }

  /* Cart Drawer Content */

  .cart-drawer__items {
    display: flex;
    flex-direction: column;
  }

  .cart-drawer__items--disabled {
    pointer-events: none;
  }

  /* Cart Drawer Footer */

  .cart-drawer__footer {
    border-top: var(--separator-border-width) solid var(--color-border);
    padding: var(--padding-md);
    position: sticky;
    bottom: 0;
    background-color: var(--color-background);
    width: calc(100% + (2 * var(--padding-md)));
    margin-left: calc(-1 * var(--padding-md));
  }

  .cart-drawer__footer > *:not(:last-child) {
    margin-bottom: var(--padding-sm);
  }

  .cart-drawer__footer .accordion__header {
    padding: 0;
  }

  .cart-drawer__footer .accordion__content {
    padding: var(--padding-sm) 0;
  }

  /* Totals */

  .cart-drawer__totals,
  .cart-drawer__reductions {
    display: flex;
    justify-content: center;
    align-items: center;
    justify-content: space-between;
  }

  .cart-drawer__totals > * {
    color: rgb(var(--color-foreground));
    margin: 0;
    line-height: 1;
  }

  .cart-drawer__reductions p,
  .cart-drawer__totals p {
    font-weight: 500;
    margin: 0;
    line-height: normal;
  }

  .cart-drawer__reductions p,
  .cart-drawer__totals p,
  .cart-drawer__reductions-value,
  .cart-drawer__totals-value {
    font-size: var(--font-body--size-emphasized);
  }

  /* CTAs */

  .cart-drawer__ctas {
    text-align: center;
    display: flex;
    gap: 10px;
  }

  .cart-drawer__ctas button {
    width: 100%;
  }

  /* Items */

  .cart-drawer__body {
    overflow-y: auto;
    overflow-x: hidden;
    flex: 1;
    padding-right: calc(var(--padding-sm) / 2);
    margin-right: calc(-1 * (var(--padding-sm) / 2));
    padding-top: var(--padding-md);
  }

  .cart-item__error {
    display: flex;
    align-items: flex-start;
    width: min-content;
    min-width: 100%;
  }

  .cart-drawer__body::-webkit-scrollbar {
    width: 3px;
  }

  /* Item */

  .cart-drawer__item {
    background-color: var(--color-background);
    color: var(--color-foreground);
    margin-bottom: var(--margin-lg);
    display: flex;
    gap: var(--gap-sm);
    align-items: flex-start;
    max-width: 100%;
  }

  .cart-drawer__item--loading {
    opacity: 0.5;
    pointer-events: none;
  }

  .cart-drawer__item:last-child {
    margin-bottom: var(--padding-sm);
  }

  .cart-drawer__item > a {
    display: flex;
    align-items: center;
  }

  .cart-drawer__item img {
    width: var(--cart-item-image-width);
    object-fit: cover;
    background-color: white;
    max-width: fit-content;
    border-radius: calc(var(--card-border-radius) - var(--padding-sm));
  }

  .cart-drawer__item.card {
    padding: var(--padding-sm);

    img {
      border-radius: calc(var(--card-border-radius) - var(--padding-sm));
    }
  }

  .cart-drawer__item-options,
  .cart-drawer__item-options p {
    line-height: normal;
    font-size: var(--font-body--size-small);
    word-break: break-word;
    color: rgba(var(--color-foreground), 0.8);
  }

  .cart-drawer__item-options .cart-drawer__item-option:not(:last-child) {
    margin-bottom: var(--padding-xs);
  }

  .cart-drawer__item-option {
    margin: 0;
  }

  .cart-drawer__item-content {
    display: flex;
    flex-direction: column;
    gap: 7px;
    margin-top: 5px;
  }

  .cart-drawer__item-wrapper {
    display: flex;
    justify-content: space-between;
    width: 100%;
    min-height: var(--cart-item-image-width);
    gap: var(--gap-sm);
  }

  .cart-drawer__item-name {
    text-decoration: none;
    display: block;
    width: calc(100% + 60px);
    font-size: var(--font-body--size);
    color: rgb(var(--color-foreground));
    font-weight: 500;
    line-height: normal;
    margin-bottom: 0;
    transition: var(--animation-link-hover);

    &:hover {
      opacity: var(--opacity-link-hover);
    }
  }

  .cart-drawer__item-prices {
    position: relative;
    width: 100%;
  }

  .cart-drawer__item-prices.loading {
    width: max-content;
  }

  .cart-drawer__item-price {
    display: flex;
    align-items: center;
    gap: var(--gap-xs);
    flex-wrap: wrap;
    font-size: var(--font-body--size-small);
    color: rgb(var(--color-foreground));
  }

  .cart-drawer__item-price > * {
    display: block;
    margin: 0;
    padding: 0;
    line-height: normal;
  }

  .cart-drawer__item-discounted-prices {
    display: flex;
    align-self: center;
    gap: 6px;
    line-height: normal;
  }

  .cart-drawer__item-compare-price {
    opacity: 0.7;
  }

  .cart-drawer__item--no-remove-button .cart-drawer__item-actions-wrapper {
    justify-content: flex-end;
  }

  .cart-drawer__item--no-remove-button .cart-drawer__item-name {
    width: calc(100% + var(--cart-item-image-width));
  }

  @media screen and (max-width: 350px) {
    .cart-drawer__item--no-remove-button .cart-drawer__item-name {
      width: calc(100% + 75px);
    }
  }

  @media screen and (max-width: 350px) {
    .cart-drawer__item img {
      width: var(--cart-item-image-width);
      max-height: calc(var(--cart-item-image-width) * 1.2);
    }

    .cart-drawer__item-content {
      gap: 5px;
    }

    .cart-drawer__item-wrapper {
      min-height: calc(var(--cart-item-image-width) * 1.2);
    }
    .cart-drawer__item-name {
      width: calc(100% + 50px);
    }

    .cart-drawer__item-prices {
      width: 100%;
    }
  }

  /* Quantity & Remove Button */

  .cart-drawer__item-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }

  .cart-drawer__item-actions-wrapper {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    flex-direction: column;
    height: 100%;
    gap: 5px;
  }

  @media screen and (max-width: 749px) {
    .cart-drawer__item-actions-wrapper {
      flex-wrap: wrap;
    }
  }

  /* Discounts */

  .cart-drawer__discounts {
    margin-bottom: 0;
  }

  .cart-drawer__discount {
    margin-bottom: var(--padding-sm);
  }

  .cart-drawer__item-discounts,
  .cart-drawer__discounts {
    font-size: 12px;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
  }

  .cart-drawer__item-discount,
  .cart-drawer__discount {
    min-width: max-content;
    gap: var(--gap-xs);
  }

  .cart-drawer__item-discount .icon {
    font-size: 14px !important;
  }

  .icon-discount {
    color: rgb(var(--color-foreground));
    width: 12px;
    height: 12px;
    margin-right: 7px;
  }

  .cart-drawer__item-discount span {
    max-width: 70px;
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
  }

  @media screen and (max-width: 750px) {
    .cart-drawer__discounts {
      overflow: scroll;
      flex-wrap: nowrap;
    }

    .cart-drawer__discounts::-webkit-scrollbar {
      height: 3px;
    }
  }
/* END_SECTION:cart-drawer */

/* START_SECTION:cart (INDEX:4) */
.cart {
    display: block;
  }

  .cart__inner {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  :root {
    --cart-item-image-width: 85px;
  }

  .cart__empty {
    border: var(--container-border-width) solid var(--color-border);
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: var(--gap-sm);
  }

  .cart {
    padding-bottom: 3rem;
  }

  .cart__header {
    padding: var(--gap-md) 0;
  }

  .cart__form {
    display: grid;
    grid-template-columns: 100%;
    gap: var(--gap-md);
  }

  .cart__form--loading {
    opacity: 0.5;
    pointer-events: none;
  }

  @media (width > 750px) {
    .cart__header {
      padding: var(--gap-lg) 0;
    }

    .cart__form {
      grid-template-columns: 60% calc(40% - var(--gap-lg));
      gap: var(--gap-lg);
    }
  }

  .cart__items {
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }

  .cart__footer {
    height: fit-content;
  }

  .cart__footer > *:not(:last-child) {
    margin-bottom: var(--padding-sm);
  }

  .cart__footer .accordion__content,
  .cart__footer .accordion__header {
    padding: var(--padding-xxs) 0;
  }

  /* Totals */

  .cart__totals,
  .cart__reductions {
    display: flex;
    justify-content: center;
    align-items: center;
    justify-content: space-between;
  }

  .cart__totals > * {
    color: rgb(var(--color-foreground));
    margin: 0;
    line-height: 1;
  }

  .cart__reductions p,
  .cart__totals p {
    font-weight: 500;
    margin: 0;
    line-height: normal;
  }

  .cart__reductions p,
  .cart__totals p,
  .cart__reductions-value,
  .cart__totals-value {
    font-size: var(--font-body--size-emphasized);
  }

  /* CTAs */

  .cart__ctas {
    text-align: center;
    display: flex;
    gap: 10px;
    margin-bottom: 0;
  }

  .cart__ctas button {
    width: 100%;
  }

  /* Item */

  .cart__item {
    background-color: var(--color-background);
    color: var(--color-foreground);
    display: flex;
    gap: var(--gap-sm);
    align-items: flex-start;
    max-width: 100%;
  }

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

  .cart__item img {
    width: var(--cart-item-image-width);
    object-fit: cover;
    background-color: white;
    max-width: fit-content;
    border-radius: calc(var(--card-border-radius) - var(--padding-sm));
  }

  .cart__item.card {
    padding: var(--padding-sm);

    img {
      border-radius: calc(var(--card-border-radius) - var(--padding-sm));
    }
  }

  .cart__item-options {
    line-height: normal;
    font-size: var(--font-body--size-small);
    word-break: break-word;
    color: rgba(var(--color-foreground), 0.8);
  }

  .cart__item-options .cart__item-option:not(:last-child) {
    margin-bottom: var(--padding-xs);
  }

  .cart__item-option {
    margin: 0;
  }

  .cart__item-content {
    display: flex;
    flex-direction: column;
    gap: 7px;
    margin-top: 5px;
  }

  .cart__item-wrapper {
    display: flex;
    justify-content: space-between;
    width: 100%;
    min-height: var(--cart-item-image-width);
    gap: var(--gap-sm);
  }

  .cart__item-name {
    text-decoration: none;
    display: block;
    width: calc(100% + 60px);
    font-size: var(--font-body--size);
    color: rgb(var(--color-foreground));
    font-weight: 500;
    line-height: normal;
    margin-bottom: 0;
    transition: var(--animation-link-hover);

    &:hover {
      opacity: var(--opacity-link-hover);
    }
  }

  .cart__item-prices {
    position: relative;
    width: 100%;
  }

  .cart__item-prices.loading {
    width: max-content;
  }

  .cart__item-price {
    display: flex;
    align-items: center;
    gap: var(--gap-xs);
    flex-wrap: wrap;
    font-size: var(--font-body--size-small);
    color: rgb(var(--color-foreground));
  }

  .cart__item-price > * {
    display: block;
    margin: 0;
    padding: 0;
    line-height: normal;
  }

  .cart__item-discounted-prices {
    display: flex;
    align-self: center;
    gap: 6px;
    line-height: normal;
  }

  .cart__item-compare-price {
    opacity: 0.7;
  }

  .cart__item--no-remove-button .cart__item-actions-wrapper {
    justify-content: flex-end;
  }

  .cart__item--no-remove-button .cart__item-name {
    width: calc(100% + var(--cart-item-image-width));
  }

  @media screen and (max-width: 350px) {
    .cart__item--no-remove-button .cart__item-name {
      width: calc(100% + 75px);
    }
  }

  @media screen and (max-width: 350px) {
    .cart__item img {
      width: var(--cart-item-image-width);
      max-height: calc(var(--cart-item-image-width) * 1.2);
    }

    .cart__item-content {
      gap: 5px;
    }

    .cart__item-wrapper {
      min-height: calc(var(--cart-item-image-width) * 1.2);
    }
    .cart__item-name {
      width: calc(100% + 50px);
    }

    .cart__item-prices {
      width: 100%;
    }
  }

  /* Quantity & Remove Button */

  .cart__item-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }

  .cart__item-actions-wrapper {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    flex-direction: column;
    height: 100%;
    gap: 5px;
  }

  .cart__item-actions-wrapper .button,
  .cart__item-actions-wrapper .quantity-selector {
    border: var(--inputs-border-width) solid var(--color-border);
  }

  @media screen and (max-width: 749px) {
    .cart__item-actions-wrapper {
      flex-wrap: wrap;
    }
  }

  /* Discounts */

  .cart__discounts {
    margin-bottom: 0;
  }

  .cart__discount {
    margin-bottom: var(--padding-sm);
  }

  .cart__item-discounts,
  .cart__discounts {
    font-size: 12px;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
  }

  .cart__item-discount,
  .cart__discount {
    min-width: max-content;
    gap: var(--gap-xs);
  }

  .icon-discount {
    color: rgb(var(--color-foreground));
    width: 12px;
    height: 12px;
    margin-right: 7px;
  }

  /* .cart__item-discount span {
  max-width: 70px;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
} */

  @media screen and (max-width: 750px) {
    .cart__discounts {
      overflow: scroll;
      flex-wrap: nowrap;
    }

    .cart__discounts::-webkit-scrollbar {
      height: 3px;
    }
  }
/* END_SECTION:cart */

/* START_SECTION:collection-featured (INDEX:5) */
.collection-featured {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  shopify-visual-preview-block-list .collection-featured .splide__arrow {
    display: none !important;
  }

  .collection-featured__inner {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .collection-featured__grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    gap: var(--gap-md);
  }

  @media (width > 750px) {
    .collection-featured__grid {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_SECTION:collection-featured */

/* START_SECTION:collections-featured (INDEX:6) */
.collections-featured {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .collections-featured__inner {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .collections-featured__grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    gap: var(--gap-md);
  }

  @media (width > 750px) {
    .collections-featured__grid {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_SECTION:collections-featured */

/* START_SECTION:comparison-table (INDEX:7) */
.comparison-table {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .comparison-table__inner {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .comparison-table__table-wrapper {
    overflow-x: auto;
  }

  .comparison-table__table {
    border-collapse: collapse;
    width: 100%;
    background-color: transparent;
    /* table-layout: fixed; */
  }
/* END_SECTION:comparison-table */

/* START_SECTION:custom-code (INDEX:8) */
.custom-code-section {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }
/* END_SECTION:custom-code */

/* START_SECTION:custom-section (INDEX:9) */
.section-custom-section {
    width: 100%;
    max-width: 100%;
    padding: 0;
  }

  .section-custom-section .text-block[data-visual-preview-mode] {
    max-width: 100%;
  }

  .section-custom-section .image-card[data-visual-preview-mode] {
    width: 100%;
  }

  .custom-section {
    width: 100%;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    display: flex;
    justify-content: center;
  }

  .custom-section .custom-section__inner {
    gap: var(--gap-mobile);
    width: 100%;
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .custom-section--flex .custom-section__inner {
    display: flex;
    flex-direction: var(--direction-mobile);
    flex-wrap: var(--wrap-mobile);
    justify-content: var(--justify-mobile);
    align-items: var(--align_items-mobile);
    height: 100%;
  }

  .custom-section:not(.custom-section--row-mobile) > div > .custom-section__inner > .text-block-center-mobile,
  .custom-section:not(.custom-section--row-mobile) > .custom-section__inner > .text-block-center-mobile {
    width: 100%;
  }

  .custom-section--grid .custom-section__inner {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    grid-template-rows: auto;
  }

  @media (width > 750px) {
    .custom-section .custom-section__inner {
      gap: var(--gap);
    }

    .custom-section--flex .custom-section__inner {
      flex-direction: var(--direction);
      flex-wrap: var(--wrap);
      justify-content: var(--justify);
      align-items: var(--align_items);
      height: auto;
    }

    .custom-section:not(.custom-section--row-desktop) > div > .custom-section__inner > .text-block-center-desktop,
    .custom-section:not(.custom-section--row-desktop) > .custom-section__inner > .text-block-center-desktop,
    .custom-section:not(.custom-section--row-desktop) > div > .custom-section__inner > .text-block-right-desktop,
    .custom-section:not(.custom-section--row-desktop) > .custom-section__inner > .text-block-right-desktop {
      width: 100%;
    }

    .custom-section--grid .custom-section__inner {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_SECTION:custom-section */

/* START_SECTION:demo-design-system (INDEX:10) */
.highlights {
    display: grid;
    gap: 1.5rem;
    grid-template-columns: repeat(3, 1fr);
    margin-top: 1.5rem;
  }

  @media (width <= 1000px) {
    .highlights {
      grid-template-columns: 1fr;
    }
  }

  .highlight {
    display: flex;
    flex-direction: column;
  }

  .highlight > * + * {
    margin-top: 1rem;
  }

  .highlight-container {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
  }
/* END_SECTION:demo-design-system */

/* START_SECTION:footer (INDEX:11) */
.footer-section {
    width: 100%;
    max-width: 100%;
    padding: 0;
  }

  .footer {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
    margin-top: var(--margin-top);
  }

  .footer--top-border {
    border-top: var(--separator-border-width) solid var(--color-border);
  }

  .footer__content {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    grid-template-rows: auto;
    gap: var(--gap-mobile);
    width: 100%;
  }

  .footer--flex .footer__content {
    display: flex;
    flex-direction: var(--direction-mobile);
    flex-wrap: var(--wrap-mobile);
    justify-content: var(--justify-mobile);
    align-items: var(--align_items-mobile);
  }

  .footer--grid .footer__content {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    grid-template-rows: auto;
  }

  @media (width > 750px) {
    .footer__content {
      gap: var(--gap);
    }

    .footer--flex .footer__content {
      flex-direction: var(--direction);
      flex-wrap: var(--wrap);
      justify-content: var(--justify);
      align-items: var(--align_items);
    }

    .footer--grid .footer__content {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_SECTION:footer */

/* START_SECTION:header (INDEX:12) */
.shopify-section-group-header-group {
    overflow: visible;
  }

  .section-header {
    position: relative;
  }

  header-component {
    display: flex;
    justify-content: center;
  }

  /* Header transparent */

  .section-header:has(.header--transparent):not(:has(.header--sticky)) {
    z-index: 3;
  }

  .header--transparent {
    margin-bottom: -100%;
  }

  .header--transparent[data-sticky-state='inactive']:not(:has(.header__menu-item--megamenu[data-open='true'])) {
    background-color: transparent;

    .header__layout {
      background-color: transparent;
      color: inherit;
      border-bottom: none;
    }

    .localization-form__language-select {
      background-color: transparent;
      color: inherit;
    }

    .header__logo-image--transparent {
      display: block;
    }

    &:has(.header__logo-image--transparent) .header__logo-image {
      display: none;
    }
  }

  .header__logo {
    display: flex;
    align-items: center;
  }

  .header__logo-image,
  .header__logo-image--transparent {
    height: var(--logo-height-mobile);
    width: var(--logo-width-mobile);
  }

  @media (width > 1000px) {
    .header__logo-image,
    .header__logo-image--transparent {
      height: var(--logo-height);
      width: var(--logo-width);
    }
  }

  .header__logo-image--transparent {
    display: none;
  }

  .header__logo-name {
    text-transform: uppercase;
    font-weight: bold;
  }

  .header__menu {
    display: flex;
    align-items: center;
    gap: 1rem;
  }

  .header__menu-mobile {
    display: flex;
    height: 100%;
    align-items: center;
    justify-content: flex-start;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    color: inherit;
  }

  header-component:not(:has(.header__mobile-menu-overlay)) .header__menu-mobile {
    display: none;
  }

  @media (width > 1000px) {
    .header__menu-mobile {
      display: none;
    }

    .search-popup-mobile {
      display: none;
    }
  }

  .header__menu a,
  .header__menu-mobile {
    transition: var(--animation-link-hover);
  }

  .header__menu a:hover,
  .header__menu-mobile:hover {
    opacity: var(--opacity-link-hover);
  }

  .header__menu a:not(.button) {
    text-decoration: none;
    color: inherit;
  }

  .header__menu a {
    font-size: var(--font-body--size);
  }

  /* Mise en page des headers */

  .header__layout {
    border-bottom: var(--separator-border-width) solid var(--color-border);
  }

  .header__layout-desktop {
    display: none;
  }

  .header__layout-mobile {
    display: flex;
    width: 100%;
    max-width: var(--page-width);
    padding: 0 var(--page-margin-mobile);
  }

  @media (width > 1000px) {
    .header__layout-desktop {
      display: flex;
      width: 100%;
    }

    .header__layout-mobile {
      display: none;
    }
  }

  .header__layout--logo-center,
  .header__layout--logo-left,
  .header__layout--logo-left-menu-left,
  .header__layout--logo-center-with-two-menus,
  .header__layout--logo-center-above-menu__logo-and-icons,
  .header__layout--logo-left-above-menu__logo-and-icons {
    height: var(--header-height);
  }

  .header__layout--logo-center,
  .header__layout--logo-left,
  .header__layout--logo-left-menu-left,
  .header__layout--logo-center-with-two-menus,
  .header__layout--logo-center-above-menu,
  .header__layout--logo-left-above-menu {
    width: 100%;
  }

  .header__layout--logo-center,
  .header__layout--logo-left,
  .header__layout--logo-left-menu-left,
  .header__layout--logo-center-with-two-menus {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 1.5rem;
  }

  .header__layout--logo-left-menu-left {
    grid-template-columns: auto auto 1fr;
  }

  .header__layout--logo-center {
    .header__menu-desktop {
      justify-content: flex-start;
    }

    .header__logo {
      justify-content: center;
    }

    .header__actions {
      justify-content: flex-end;
    }
  }

  .header__layout--logo-left {
    .header__logo {
      justify-content: flex-start;
    }

    .header__menu-desktop {
      justify-content: center;
    }

    .header__actions {
      justify-content: flex-end;
    }
  }

  .header__layout--logo-left-menu-left {
    .header__logo {
      justify-content: flex-start;
    }

    .header__menu-desktop {
      justify-content: flex-start;
    }

    .header__actions {
      justify-content: flex-end;
    }
  }

  .header__layout--logo-center-above-menu {
    .header__layout--logo-center-above-menu__logo-and-icons {
      display: grid;
      grid-template-columns: 1fr auto 1fr;
      gap: 1.5rem;
      align-items: center;

      .header__logo {
        grid-column: 2;
        justify-content: center;
      }

      .header__actions {
        grid-column: 3;
        justify-content: flex-end;
      }
    }

    .header__menu-desktop {
      justify-content: center;
      width: 100%;
    }
  }

  .header__layout--logo-left-above-menu {
    .header__layout--logo-left-above-menu__logo-and-icons {
      display: grid;
      grid-template-columns: auto auto;

      .header__logo {
        grid-column: 1;
        justify-content: flex-start;
      }

      .header__actions {
        grid-column: 2;
        justify-content: flex-end;
      }
    }
  }

  .header__layout--logo-center-above-menu__menu,
  .header__layout--logo-left-above-menu__menu {
    padding-bottom: 1rem;
  }

  .header__layout--logo-center-above-menu__menu,
  .header__layout--logo-left-above-menu__menu:not(:has(.button)) {
    height: 2rem;
  }

  .header__layout--logo-center-with-two-menus {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 1.5rem;

    .header__layout--logo-center-with-two-menus__logo-and-menus {
      grid-column: 2;
      display: grid;
      grid-template-columns: 1fr auto 1fr;
      gap: 2rem;

      & > .header__menu:first-of-type {
        justify-content: flex-end;
      }
    }

    .header__actions {
      grid-column: 3;
      justify-content: flex-end;
    }
  }

  .header__icon-count-bubble {
    position: absolute;
    bottom: -6px;
    right: -6px;
    border-radius: 10px;
    width: 18px;
    height: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: transparent;
  }

  .header__icon-count-bubble-inner {
    background-color: var(--color-primary-button-background);
    color: var(--color-primary-button-text);
    width: 14px;
    height: 14px;
    font-size: 0.6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    font-size: 0.6rem;
  }

  .header__icon-count-bubble--long {
    width: 30px;
    right: -50%;
  }

  header-component:not(.header--transparent) .header__icon-count-bubble,
  .header--transparent[data-sticky-state='active'] .header__icon-count-bubble,
  .header--transparent[data-sticky-state='inactive']:has(.header__menu-item--megamenu[data-open='true']) .header__icon-count-bubble {
    background-color: var(--color-background);
  }
/* END_SECTION:header */

/* START_SECTION:image-banner (INDEX:13) */
.image-banner-wrapper {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .image-banner-wrapper__inner {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .image-banner-wrapper--children-cards .image-banner {
    border-radius: var(--card-border-radius);
  }

  .image-banner-wrapper .splide__arrow {
    background-color: transparent;
    border: none;

    .icon {
      color: white;
    }
  }

  .image-banner-wrapper .splide__pagination {
    bottom: 5px;

    .splide__pagination__page,
    .splide__pagination__page.is-active {
      background: white;
    }
  }
/* END_SECTION:image-banner */

/* START_SECTION:isoore-article-magazine (INDEX:14) */
.isoore-article {
  background: var(--isoore-paper, #FAF7EE);
  color: var(--isoore-ink, #0E0E0C);
  font-family: 'Manrope', system-ui, sans-serif;
  padding-top: 140px;
}

.isoore-article__hero {
  padding: 0 0 48px;
}
.isoore-article__hero-inner {
  max-width: 920px;
}
.isoore-article__breadcrumb {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(14, 14, 12, 0.55);
  margin-bottom: 32px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.isoore-article__breadcrumb a {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s var(--isoore-ease, ease);
}
.isoore-article__breadcrumb a:hover { color: var(--isoore-accent, #2D3E2B); }
.isoore-article__breadcrumb span:not([aria-current]) { opacity: 0.4; }

.isoore-article__category {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  margin: 0 0 20px;
}

.isoore-article__title {
  font-family: 'Manrope', sans-serif;
  font-weight: 500;
  font-size: clamp(2rem, 5vw, 3.6rem);
  line-height: 1.08;
  letter-spacing: -0.015em;
  margin: 0 0 28px;
}
.isoore-article__title em {
  font-style: normal;
  font-weight: 200;
  opacity: 0.7;
}

.isoore-article__chapo {
  font-size: clamp(1.05rem, 1.6vw, 1.25rem);
  line-height: 1.55;
  color: rgba(14, 14, 12, 0.75);
  margin: 0 0 32px;
  max-width: 720px;
}
.isoore-article__chapo p { margin: 0 0 12px; }
.isoore-article__chapo p:last-child { margin-bottom: 0; }

.isoore-article__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(14, 14, 12, 0.6);
  padding-top: 20px;
  border-top: 1px solid rgba(14, 14, 12, 0.1);
}
.isoore-article__meta-label { opacity: 0.55; margin-right: 4px; }
.isoore-article__meta-sep { opacity: 0.3; }

.isoore-article__image {
  margin: 0 0 64px;
  width: 100%;
  max-width: 1640px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 56px;
}
.isoore-article__image img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 21 / 9;
  object-fit: cover;
  border-radius: 4px;
}

.isoore-article__body {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 80px;
  padding-bottom: 80px;
  align-items: start;
}

.isoore-article__toc {
  position: sticky;
  top: 120px;
  padding-top: 8px;
}
.isoore-article__toc-label {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  margin: 0 0 16px;
}
.isoore-article__toc-list {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: toc;
  border-left: 1px solid rgba(14, 14, 12, 0.12);
}
.isoore-article__toc-list li {
  counter-increment: toc;
  margin: 0;
  padding: 8px 0 8px 18px;
  position: relative;
}
.isoore-article__toc-list li::before {
  content: counter(toc, decimal-leading-zero);
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 10px;
  letter-spacing: 0.08em;
  position: absolute;
  left: -22px;
  top: 12px;
  color: rgba(14, 14, 12, 0.35);
  background: var(--isoore-paper, #FAF7EE);
  padding: 0 4px;
}
.isoore-article__toc-list a {
  color: rgba(14, 14, 12, 0.7);
  text-decoration: none;
  font-size: 13px;
  line-height: 1.4;
  display: block;
  transition: color 0.2s var(--isoore-ease, ease);
}
.isoore-article__toc-list a:hover { color: var(--isoore-accent, #2D3E2B); }

.isoore-article__content {
  max-width: 720px;
  font-size: 1.0625rem;
  line-height: 1.75;
  color: rgba(14, 14, 12, 0.88);
}
.isoore-article__content > *:first-child { margin-top: 0; }
.isoore-article__content p { margin: 0 0 1.4em; }
.isoore-article__content strong { font-weight: 600; color: var(--isoore-ink, #0E0E0C); }
.isoore-article__content em { font-style: italic; }
.isoore-article__content a {
  color: var(--isoore-accent, #2D3E2B);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.isoore-article__content a:hover { text-decoration-thickness: 2px; }

.isoore-article__content h2 {
  font-family: 'Manrope', sans-serif;
  font-weight: 500;
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  line-height: 1.2;
  letter-spacing: -0.01em;
  margin: 3em 0 1em;
  scroll-margin-top: 110px;
  color: var(--isoore-ink, #0E0E0C);
}
.isoore-article__content h2::before {
  content: '';
  display: block;
  width: 40px;
  height: 2px;
  background: var(--isoore-accent, #2D3E2B);
  margin-bottom: 16px;
}
.isoore-article__content h3 {
  font-family: 'Manrope', sans-serif;
  font-weight: 600;
  font-size: 1.25rem;
  line-height: 1.3;
  margin: 2em 0 0.7em;
  color: var(--isoore-ink, #0E0E0C);
}
.isoore-article__content h4 {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin: 1.6em 0 0.6em;
  color: var(--isoore-accent, #2D3E2B);
}

.isoore-article__content ul,
.isoore-article__content ol {
  margin: 0 0 1.4em;
  padding-left: 1.2em;
}
.isoore-article__content li { margin: 0 0 0.5em; padding-left: 0.3em; }
.isoore-article__content ul li::marker { color: var(--isoore-accent, #2D3E2B); }

.isoore-article__content blockquote {
  border-left: 3px solid var(--isoore-accent, #2D3E2B);
  padding: 4px 0 4px 24px;
  margin: 2em 0;
  font-size: 1.15rem;
  line-height: 1.55;
  font-style: italic;
  color: rgba(14, 14, 12, 0.78);
}
.isoore-article__content blockquote cite {
  display: block;
  margin-top: 12px;
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-style: normal;
  color: rgba(14, 14, 12, 0.5);
}

.isoore-article__content table {
  width: 100%;
  border-collapse: collapse;
  margin: 2em 0;
  font-size: 0.95rem;
  background: var(--isoore-paper-light, #FAF7EE);
}
.isoore-article__content th,
.isoore-article__content td {
  padding: 14px 16px;
  text-align: left;
  border-bottom: 1px solid rgba(14, 14, 12, 0.1);
}
.isoore-article__content th {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(14, 14, 12, 0.04);
  color: var(--isoore-accent, #2D3E2B);
  font-weight: 500;
}

.isoore-article__content .highlight-box {
  background: rgba(45, 62, 43, 0.06);
  border-left: 3px solid var(--isoore-accent, #2D3E2B);
  padding: 20px 24px;
  margin: 2em 0;
  border-radius: 0 4px 4px 0;
}
.isoore-article__content .highlight-box p:last-child { margin-bottom: 0; }
.isoore-article__content .highlight-box strong:first-child {
  display: block;
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  margin-bottom: 8px;
}

.isoore-article__content figure { margin: 2em 0; }
.isoore-article__content figure img { width: 100%; height: auto; display: block; border-radius: 4px; }
.isoore-article__content figcaption {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(14, 14, 12, 0.5);
  margin-top: 10px;
  text-align: center;
}

.isoore-article__cta {
  padding: 64px 0;
  background: rgba(45, 62, 43, 0.04);
}
.isoore-article__cta-card {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.isoore-article__cta-kicker {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  margin: 0 0 16px;
}
.isoore-article__cta-title {
  font-family: 'Manrope', sans-serif;
  font-weight: 500;
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  line-height: 1.15;
  margin: 0 0 16px;
  letter-spacing: -0.01em;
}
.isoore-article__cta-subtitle {
  color: rgba(14, 14, 12, 0.7);
  font-size: 1.05rem;
  line-height: 1.5;
  margin: 0 0 32px;
}
.isoore-article__cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--isoore-ink, #0E0E0C);
  color: var(--isoore-paper, #FAF7EE);
  padding: 18px 36px;
  border-radius: 999px;
  text-decoration: none;
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition: all 0.3s var(--isoore-ease, ease);
}
.isoore-article__cta-btn:hover {
  background: var(--isoore-accent, #2D3E2B);
  transform: translateY(-2px);
}

.isoore-article__author {
  padding: 64px 0;
  border-top: 1px solid rgba(14, 14, 12, 0.08);
}
.isoore-article__author-card {
  max-width: 720px;
  margin: 0 auto;
}
.isoore-article__author-kicker {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  margin: 0 0 12px;
}
.isoore-article__author-name {
  font-family: 'Manrope', sans-serif;
  font-weight: 500;
  font-size: 1.5rem;
  margin: 0 0 6px;
}
.isoore-article__author-role {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: 0.05em;
  color: rgba(14, 14, 12, 0.6);
  margin: 0 0 20px;
}
.isoore-article__author-bio {
  font-size: 1rem;
  line-height: 1.65;
  color: rgba(14, 14, 12, 0.8);
}
.isoore-article__author-bio p { margin: 0 0 0.8em; }

.isoore-article__related {
  padding: 64px 0 120px;
  background: var(--isoore-paper-deep, #E8E2D3);
}
.isoore-article__related-kicker {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  margin: 0 0 32px;
}
.isoore-article__related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.isoore-article__related-card {
  background: var(--isoore-paper, #FAF7EE);
  padding: 24px;
  border-radius: 4px;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  transition: transform 0.3s var(--isoore-ease, ease);
}
.isoore-article__related-card:hover { transform: translateY(-4px); }
.isoore-article__related-image {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  border-radius: 4px;
  margin: -24px -24px 20px;
}
.isoore-article__related-image img { width: 100%; height: 100%; object-fit: cover; }
.isoore-article__related-category {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  margin: 0 0 8px;
}
.isoore-article__related-title {
  font-family: 'Manrope', sans-serif;
  font-weight: 500;
  font-size: 1.05rem;
  line-height: 1.3;
  margin: 0 0 16px;
  flex: 1;
}
.isoore-article__related-link {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  margin-top: auto;
}

@media (max-width: 990px) {
  .isoore-article { padding-top: 100px; }
  .isoore-article__image { padding: 0 24px; margin-bottom: 40px; }
  .isoore-article__image img { aspect-ratio: 16 / 10; }
  .isoore-article__body {
    grid-template-columns: 1fr;
    gap: 0;
    padding-bottom: 40px;
  }
  .isoore-article__toc {
    position: static;
    padding: 24px;
    background: rgba(14, 14, 12, 0.03);
    border-radius: 4px;
    margin-bottom: 40px;
  }
  .isoore-article__content { font-size: 1rem; }
  .isoore-article__related-grid { grid-template-columns: 1fr; }
  .isoore-article__related-image { margin: -24px -24px 16px; }
}
/* END_SECTION:isoore-article-magazine */

/* START_SECTION:isoore-bioclim (INDEX:15) */
.isoore-bioclim {
    padding: 88px 56px;
    background: var(--color-background);
    color: var(--color-foreground);
  }

  .isoore-bioclim__inner {
    max-width: var(--isoore-container-max, 1300px);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 56px;
    align-items: center;
  }

  .isoore-bioclim__media {
    border-radius: var(--isoore-radius-md, 8px);
    overflow: hidden;
    aspect-ratio: 4 / 3;
    background: linear-gradient(135deg, #E4DCC8, #d8cfb8);
  }

  .isoore-bioclim__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.6s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-bioclim__media:hover .isoore-bioclim__image {
    transform: scale(1.03);
  }

  .isoore-bioclim__image-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--isoore-text, #3A5038);
    opacity: 0.5;
  }

  .isoore-bioclim__heading {
    font-size: clamp(26px, 3vw, 32px);
    font-weight: 500;
    line-height: 1.18;
    letter-spacing: -0.5px;
    margin: 0 0 20px;
    color: var(--isoore-text, #3A5038);
  }

  .isoore-bioclim__body {
    font-size: 14px;
    line-height: 1.75;
    margin-bottom: 24px;
  }

  .isoore-bioclim__features {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin-top: 24px;
  }

  .isoore-bioclim__feature {
    background: var(--isoore-white, #fff);
    padding: 18px;
    border-radius: var(--isoore-radius-md, 8px);
    border: 1px solid var(--isoore-border, #E4DCC8);
    transition: all 0.4s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
    cursor: default;
  }

  .isoore-bioclim__feature:hover {
    transform: translateY(-4px);
    border-color: var(--isoore-cta, #7AAB72);
    box-shadow: 0 12px 28px rgba(58, 80, 56, 0.08);
  }

  .isoore-bioclim__feature-icon {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: rgba(122, 171, 114, 0.15);
    color: var(--isoore-cta, #7AAB72);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 12px;
    transition: all 0.4s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-bioclim__feature:hover .isoore-bioclim__feature-icon {
    background: var(--isoore-cta, #7AAB72);
    color: #fff;
    transform: rotate(8deg) scale(1.1);
  }

  .isoore-bioclim__feature-title {
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 4px;
    color: var(--isoore-text, #3A5038);
  }

  .isoore-bioclim__feature-desc {
    font-size: 12px;
    line-height: 1.5;
    opacity: 0.75;
  }

  @media (max-width: 989px) {
    .isoore-bioclim {
      padding: 56px 24px;
    }

    .isoore-bioclim__inner {
      grid-template-columns: 1fr;
      gap: 32px;
    }

    .isoore-bioclim__features {
      grid-template-columns: 1fr;
    }
  }
/* END_SECTION:isoore-bioclim */

/* START_SECTION:isoore-blog-magazine (INDEX:16) */
body.isoore-template-blog .isoore-top,
body.isoore-template-blog .header,
body.isoore-template-blog .isoore-site-header {
  background: rgba(244, 240, 230, 0.88) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}
body.isoore-template-blog .isoore-top a,
body.isoore-template-blog .isoore-top .brand,
body.isoore-template-blog .isoore-top .isoore-top__brand {
  color: var(--isoore-ink, #0E0E0C) !important;
  text-shadow: none !important;
}

.isoore-blog {
  background: var(--isoore-paper, #FAF7EE);
  color: var(--isoore-ink, #0E0E0C);
  font-family: 'Manrope', system-ui, sans-serif;
  padding-top: 200px;
}

.isoore-blog__hero {
  padding: 0 0 80px;
  border-bottom: 1px solid rgba(14, 14, 12, 0.08);
  margin-bottom: 64px;
}
.isoore-blog__hero-inner { max-width: 920px; }
.isoore-blog__kicker {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  margin: 0 0 28px;
}
.isoore-blog__title {
  font-family: 'Manrope', sans-serif;
  font-weight: 500;
  font-size: clamp(2.2rem, 5.5vw, 4.2rem);
  line-height: 1.04;
  letter-spacing: -0.02em;
  margin: 0 0 32px;
}
.isoore-blog__title em {
  font-style: normal;
  font-weight: 200;
  opacity: 0.65;
}
.isoore-blog__chapo {
  font-size: clamp(1.05rem, 1.5vw, 1.2rem);
  line-height: 1.55;
  color: rgba(14, 14, 12, 0.7);
  margin: 0;
  max-width: 640px;
}

.isoore-blog__filters { margin: 0 0 56px; }
.isoore-blog__filters-inner {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.isoore-blog__filters-label {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(14, 14, 12, 0.5);
  margin-right: 20px;
}
.isoore-blog__filter {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  background: transparent;
  color: rgba(14, 14, 12, 0.6);
  border: 1px solid rgba(14, 14, 12, 0.15);
  padding: 10px 20px;
  border-radius: 999px;
  cursor: pointer;
  transition: all 0.25s var(--isoore-ease, ease);
}
.isoore-blog__filter:hover {
  border-color: var(--isoore-accent, #2D3E2B);
  color: var(--isoore-accent, #2D3E2B);
}
.isoore-blog__filter.is-active {
  background: var(--isoore-ink, #0E0E0C);
  color: var(--isoore-paper, #FAF7EE);
  border-color: var(--isoore-ink, #0E0E0C);
}

.isoore-blog__featured { margin: 0 0 80px; }
.isoore-blog__featured-link { display: block; text-decoration: none; color: inherit; }
.isoore-blog__featured-inner {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 64px;
  align-items: center;
}
.isoore-blog__featured-media {
  aspect-ratio: 5 / 4;
  overflow: hidden;
  border-radius: 4px;
  background: linear-gradient(135deg, #3A4F37 0%, #2D3E2B 50%, #1a2519 100%);
}
.isoore-blog__featured-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.8s var(--isoore-ease, ease);
}
.isoore-blog__featured-link:hover .isoore-blog__featured-media img { transform: scale(1.04); }
.isoore-blog__featured-text { padding: 20px 0; }
.isoore-blog__featured-kicker {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  margin: 0 0 16px;
}
.isoore-blog__featured-category {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(14, 14, 12, 0.5);
  margin: 0 0 20px;
}
.isoore-blog__featured-title {
  font-family: 'Manrope', sans-serif;
  font-weight: 500;
  font-size: clamp(1.6rem, 2.6vw, 2.4rem);
  line-height: 1.15;
  letter-spacing: -0.015em;
  margin: 0 0 24px;
  color: var(--isoore-ink, #0E0E0C);
  transition: color 0.25s var(--isoore-ease, ease);
}
.isoore-blog__featured-link:hover .isoore-blog__featured-title { color: var(--isoore-accent, #2D3E2B); }
.isoore-blog__featured-excerpt {
  font-size: 1.0625rem;
  line-height: 1.65;
  color: rgba(14, 14, 12, 0.7);
  margin: 0 0 28px;
}
.isoore-blog__featured-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(14, 14, 12, 0.55);
  margin: 0 0 28px;
}
.isoore-blog__featured-meta .sep { opacity: 0.4; }
.isoore-blog__featured-cta {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.isoore-blog__grid-wrap { padding: 0 0 80px; }
.isoore-blog__grid-kicker {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(14, 14, 12, 0.5);
  margin: 0 0 32px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(14, 14, 12, 0.08);
}
.isoore-blog__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px 32px;
}
.isoore-blog__card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  transition: transform 0.35s var(--isoore-ease, ease);
}
.isoore-blog__card:hover { transform: translateY(-6px); }
.isoore-blog__card-media {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 4px;
  margin-bottom: 20px;
  position: relative;
}
.isoore-blog__card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.7s var(--isoore-ease, ease);
}
.isoore-blog__card:hover .isoore-blog__card-media img { transform: scale(1.06); }

.isoore-blog__placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.isoore-blog__placeholder::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 30% 40%, rgba(244, 240, 230, 0.08), transparent 55%),
              radial-gradient(circle at 70% 70%, rgba(244, 240, 230, 0.04), transparent 55%);
}
.isoore-blog__placeholder[data-cat="reglementation"] { background: linear-gradient(135deg, #3A4F37 0%, #2D3E2B 60%, #1a2519 100%); }
.isoore-blog__placeholder[data-cat="achat"] { background: linear-gradient(135deg, #5C4A2E 0%, #3D3220 60%, #22180e 100%); }
.isoore-blog__placeholder[data-cat="technique"] { background: linear-gradient(135deg, #2D3540 0%, #1F2630 60%, #0E1418 100%); }
.isoore-blog__placeholder:not([data-cat="reglementation"]):not([data-cat="achat"]):not([data-cat="technique"]) {
  background: linear-gradient(135deg, #3A3F43 0%, #2C2F33 60%, #14171A 100%);
}
.isoore-blog__placeholder-num {
  position: absolute;
  top: 20px;
  left: 24px;
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(244, 240, 230, 0.45);
}
.isoore-blog__placeholder-cat {
  position: relative;
  color: rgba(244, 240, 230, 0.4);
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.isoore-blog__card-body {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.isoore-blog__card-category {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  margin: 0 0 10px;
}
.isoore-blog__card-title {
  font-family: 'Manrope', sans-serif;
  font-weight: 500;
  font-size: 1.2rem;
  line-height: 1.25;
  letter-spacing: -0.005em;
  margin: 0 0 12px;
  color: var(--isoore-ink, #0E0E0C);
  transition: color 0.25s var(--isoore-ease, ease);
}
.isoore-blog__card:hover .isoore-blog__card-title { color: var(--isoore-accent, #2D3E2B); }
.isoore-blog__card-excerpt {
  font-size: 0.95rem;
  line-height: 1.55;
  color: rgba(14, 14, 12, 0.65);
  margin: 0 0 16px;
  flex: 1;
}
.isoore-blog__card-meta {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 10.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(14, 14, 12, 0.45);
  margin-top: auto;
  display: flex;
  gap: 8px;
  align-items: center;
}
.isoore-blog__card-meta .sep { opacity: 0.4; }

.isoore-blog__pagination {
  padding: 0 0 80px;
  display: flex;
  justify-content: center;
  gap: 12px;
}
.isoore-blog__pagination-link {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: transparent;
  color: var(--isoore-ink, #0E0E0C);
  border: 1px solid rgba(14, 14, 12, 0.2);
  padding: 14px 28px;
  border-radius: 999px;
  text-decoration: none;
  transition: all 0.25s var(--isoore-ease, ease);
}
.isoore-blog__pagination-link:hover {
  background: var(--isoore-ink, #0E0E0C);
  color: var(--isoore-paper, #FAF7EE);
}

.isoore-blog__cta {
  padding: 96px 0;
  background: var(--isoore-paper-deep, #E8E2D3);
}
.isoore-blog__cta-card {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.isoore-blog__cta-kicker {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  margin: 0 0 16px;
}
.isoore-blog__cta-title {
  font-family: 'Manrope', sans-serif;
  font-weight: 500;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  line-height: 1.15;
  margin: 0 0 16px;
  letter-spacing: -0.015em;
}
.isoore-blog__cta-subtitle {
  color: rgba(14, 14, 12, 0.7);
  font-size: 1.05rem;
  line-height: 1.5;
  margin: 0 0 32px;
}
.isoore-blog__cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--isoore-ink, #0E0E0C);
  color: var(--isoore-paper, #FAF7EE);
  padding: 18px 36px;
  border-radius: 999px;
  text-decoration: none;
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition: all 0.3s var(--isoore-ease, ease);
}
.isoore-blog__cta-btn:hover {
  background: var(--isoore-accent, #2D3E2B);
  transform: translateY(-2px);
}

@media (max-width: 990px) {
  .isoore-blog { padding-top: 130px; }
  .isoore-blog__hero { padding-bottom: 48px; margin-bottom: 40px; }
  .isoore-blog__filters { margin-bottom: 36px; }
  .isoore-blog__filters-inner { flex-direction: column; align-items: flex-start; gap: 12px; }
  .isoore-blog__filters-label { margin-right: 0; margin-bottom: 0; }
  .isoore-blog__featured { margin-bottom: 48px; }
  .isoore-blog__featured-inner { grid-template-columns: 1fr; gap: 32px; }
  .isoore-blog__featured-text { padding: 0; }
  .isoore-blog__grid { grid-template-columns: 1fr; gap: 40px; }
  .isoore-blog__cta { padding: 64px 0; }
}
@media (min-width: 991px) and (max-width: 1199px) {
  .isoore-blog__grid { grid-template-columns: repeat(2, 1fr); }
}
/* END_SECTION:isoore-blog-magazine */

/* START_SECTION:isoore-blog (INDEX:17) */
.isoore-blog { padding: 88px 56px; background: var(--color-background); color: var(--color-foreground); }
  .isoore-blog__inner { max-width: 1300px; margin: 0 auto; }
  .isoore-blog__header { text-align: center; margin-bottom: 40px; }
  .isoore-blog__heading {
    font-size: clamp(26px, 3vw, 32px);
    font-weight: 500;
    line-height: 1.18;
    margin: 8px 0 12px;
    color: var(--isoore-text, #3A5038);
  }
  .isoore-blog__subheading { font-size: 14px; opacity: 0.75; margin: 0; max-width: 560px; margin: 0 auto; }
  .isoore-blog__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
  .isoore-blog-card { background: #fff; border: 1px solid var(--isoore-border, #E4DCC8); border-radius: 10px; overflow: hidden; transition: all 0.4s var(--isoore-ease, cubic-bezier(0.4,0,0.2,1)); }
  .isoore-blog-card:hover { transform: translateY(-4px); border-color: var(--isoore-cta, #7AAB72); box-shadow: 0 12px 28px rgba(58,80,56,0.10); }
  .isoore-blog-card__link { display: block; color: inherit; text-decoration: none; }
  .isoore-blog-card__media { position: relative; aspect-ratio: 16/9; overflow: hidden; background: linear-gradient(135deg, #E4DCC8, #d8cfb8); }
  .isoore-blog-card__image { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.6s var(--isoore-ease); }
  .isoore-blog-card:hover .isoore-blog-card__image { transform: scale(1.05); }
  .isoore-blog-card__placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: #3A5038; opacity: 0.5; }
  .isoore-blog-card__body { padding: 18px; }
  .isoore-blog-card__date { display: block; font-size: 11px; color: var(--isoore-cta, #7AAB72); letter-spacing: 1px; text-transform: uppercase; font-weight: 600; margin-bottom: 8px; }
  .isoore-blog-card__title { font-size: 16px; font-weight: 600; margin: 0 0 8px; line-height: 1.3; color: var(--isoore-text, #3A5038); }
  .isoore-blog-card__excerpt { font-size: 13px; line-height: 1.5; opacity: 0.75; margin: 0 0 12px; }
  .isoore-blog-card__cta { display: inline-flex; align-items: center; gap: 4px; font-size: 12px; font-weight: 600; color: var(--isoore-cta, #7AAB72); transition: gap 0.3s; }
  .isoore-blog-card:hover .isoore-blog-card__cta { gap: 8px; }
  .isoore-blog__footer { text-align: center; margin-top: 36px; }
  .isoore-blog__cta { display: inline-flex; align-items: center; gap: 8px; padding: 12px 22px; border: 1.5px solid var(--isoore-text, #3A5038); border-radius: 4px; color: var(--isoore-text, #3A5038); text-decoration: none; font-size: 13px; font-weight: 500; transition: all 0.3s; }
  .isoore-blog__cta:hover { background: var(--isoore-text, #3A5038); color: var(--isoore-bg, #F7F3EC); transform: translateY(-2px); }
  .isoore-blog__empty { text-align: center; padding: 40px; opacity: 0.6; font-size: 14px; }
  @media (max-width: 989px) {
    .isoore-blog { padding: 56px 24px; }
    .isoore-blog__grid { grid-template-columns: 1fr; gap: 16px; }
  }
/* END_SECTION:isoore-blog */

/* START_SECTION:isoore-cart (INDEX:18) */
/* Header en mode ink sur fond paper (sinon le bouton panier disparait) */
  body.isoore-cart-page .isoore-top {
    background: rgba(244, 240, 230, 0.88);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }
  body.isoore-cart-page .isoore-top-nav a,
  body.isoore-cart-page .isoore-top-brand,
  body.isoore-cart-page .isoore-top-burger {
    color: #0E0E0C !important;
    text-shadow: none !important;
    filter: none !important;
  }
  body.isoore-cart-page .isoore-top-cart {
    color: #0E0E0C !important;
    border-color: rgba(14, 14, 12, 0.3) !important;
    background: transparent !important;
    filter: none !important;
  }
  body.isoore-cart-page .isoore-top-cart:hover {
    background: #0E0E0C !important;
    color: #F4F0E6 !important;
    border-color: #0E0E0C !important;
  }
  body.isoore-cart-page .isoore-top-cta {
    background: rgba(255, 255, 255, 0.6) !important;
    border-color: rgba(14, 14, 12, 0.4) !important;
    color: #0E0E0C !important;
    text-shadow: none !important;
  }
  body.isoore-cart-page .isoore-top-cta:hover {
    background: #0E0E0C !important;
    color: #F4F0E6 !important;
  }

  .isoore-cart {
    display: block;
    background: var(--isoore-paper, #F4F0E6);
    color: var(--isoore-ink, #0E0E0C);
    font-family: var(--isoore-sans, 'Manrope', sans-serif);
    font-weight: 300;
    line-height: 1.55;
    padding: 120px 0 80px;
    min-height: 60vh;
  }
  @media (max-width: 749px) {
    .isoore-cart { padding: 90px 0 56px; }
  }

  .isoore-cart__inner {
    max-width: 1300px;
    margin: 0 auto;
    padding: 0 56px;
  }
  @media (max-width: 749px) {
    .isoore-cart__inner { padding: 0 20px; }
  }

  /* Header */
  .isoore-cart__header { margin-bottom: 40px; }
  .isoore-cart__eyebrow {
    display: block;
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--isoore-ink-soft, #5C5A55);
    margin-bottom: 12px;
  }
  .isoore-cart__title {
    font-family: var(--isoore-sans, 'Manrope', sans-serif);
    font-size: clamp(32px, 4.5vw, 48px);
    font-weight: 400;
    letter-spacing: -0.02em;
    color: var(--isoore-ink, #0E0E0C);
    line-height: 1.1;
    margin: 0;
  }
  .isoore-cart__count {
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.04em;
    color: var(--isoore-ink-faint, #9A968D);
    margin-left: 12px;
    vertical-align: middle;
  }

  /* État vide */
  .isoore-cart__empty {
    background: var(--isoore-paper-light, #FAF7EE);
    border: 1px solid var(--isoore-line, rgba(14,14,12,0.12));
    padding: 72px 32px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 12px;
  }
  .isoore-cart__empty-eyebrow {
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 10px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--isoore-ink-faint, #9A968D);
    margin-bottom: 4px;
  }
  .isoore-cart__empty-title {
    font-size: 26px;
    font-weight: 400;
    color: var(--isoore-ink, #0E0E0C);
    margin: 0;
    letter-spacing: -0.015em;
  }
  .isoore-cart__empty-desc {
    font-size: 14px;
    color: var(--isoore-ink-soft, #5C5A55);
    line-height: 1.7;
    margin: 0 0 16px;
    max-width: 480px;
  }

  /* Layout 2 colonnes */
  .isoore-cart__form {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
  }
  @media (min-width: 900px) {
    .isoore-cart__form {
      grid-template-columns: minmax(0, 1fr) 400px;
      gap: 40px;
      align-items: start;
    }
  }

  /* Items */
  .isoore-cart__items {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 1px;
    background: var(--isoore-line, rgba(14,14,12,0.12));
    border: 1px solid var(--isoore-line, rgba(14,14,12,0.12));
  }
  .isoore-cart__item {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 20px;
    padding: 20px;
    background: var(--isoore-paper-light, #FAF7EE);
    transition: background 0.25s var(--isoore-ease, cubic-bezier(0.16, 1, 0.3, 1));
  }
  .isoore-cart__item:hover { background: #FCFAF3; }
  @media (max-width: 749px) {
    .isoore-cart__item { grid-template-columns: 90px 1fr; gap: 14px; padding: 16px; }
  }
  .isoore-cart__item-image {
    display: block;
    width: 120px;
    height: 120px;
    background: var(--isoore-paper-deep, #E8E2D3);
    overflow: hidden;
  }
  @media (max-width: 749px) {
    .isoore-cart__item-image { width: 90px; height: 90px; }
  }
  .isoore-cart__item-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .isoore-cart__item-image-fallback {
    display: block; width: 100%; height: 100%;
    background: linear-gradient(135deg, var(--isoore-paper-deep, #E8E2D3) 0%, #DCD4BD 100%);
  }
  .isoore-cart__item-body {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 12px;
    min-width: 0;
  }
  .isoore-cart__item-head { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
  .isoore-cart__item-name {
    font-size: 17px;
    font-weight: 500;
    color: var(--isoore-ink, #0E0E0C);
    text-decoration: none;
    letter-spacing: -0.005em;
    line-height: 1.3;
    transition: color 0.25s var(--isoore-ease, cubic-bezier(0.16, 1, 0.3, 1));
  }
  .isoore-cart__item-name:hover { color: var(--isoore-accent, #2D3E2B); }
  @media (max-width: 749px) {
    .isoore-cart__item-name { font-size: 15px; }
  }
  .isoore-cart__item-variant,
  .isoore-cart__item-prop {
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 10.5px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--isoore-ink-soft, #5C5A55);
    display: block;
  }
  .isoore-cart__item-prop { font-size: 11px; letter-spacing: 0.05em; text-transform: none; }
  .isoore-cart__item-foot {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
  }
  .isoore-cart__item-qty { flex-shrink: 0; }
  .isoore-cart__item-price {
    margin-left: auto;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
    text-align: right;
  }
  .isoore-cart__item-price-now {
    font-family: var(--isoore-sans, 'Manrope', sans-serif);
    font-size: 17px;
    font-weight: 500;
    color: var(--isoore-ink, #0E0E0C);
    letter-spacing: -0.005em;
  }
  .isoore-cart__item-price-was {
    font-size: 12px;
    color: var(--isoore-ink-faint, #9A968D);
    text-decoration: line-through;
  }
  .isoore-cart__item-remove {
    flex-shrink: 0;
    width: 32px; height: 32px;
    display: inline-flex; align-items: center; justify-content: center;
    background: transparent;
    border: 1px solid var(--isoore-line, rgba(14,14,12,0.12));
    border-radius: 999px;
    color: var(--isoore-ink-soft, #5C5A55);
    cursor: pointer;
    transition: all 0.25s var(--isoore-ease, cubic-bezier(0.16, 1, 0.3, 1));
  }
  .isoore-cart__item-remove:hover {
    background: var(--isoore-ink, #0E0E0C);
    color: var(--isoore-paper, #F4F0E6);
    border-color: var(--isoore-ink, #0E0E0C);
  }

  /* Quantity selector override (le composant du thème, on adapte juste les couleurs) */
  .isoore-cart__item .quantity-selector {
    border: 1px solid var(--isoore-line-strong, rgba(14,14,12,0.32)) !important;
    border-radius: 999px !important;
    overflow: hidden;
    background: transparent !important;
    height: 36px !important;
    width: auto !important;
    min-width: 100px !important;
  }
  .isoore-cart__item .quantity-selector button,
  .isoore-cart__item .quantity-selector input {
    background: transparent !important;
    color: var(--isoore-ink, #0E0E0C) !important;
    border: 0 !important;
    font-family: var(--isoore-mono, 'DM Mono', monospace) !important;
    font-size: 13px !important;
    letter-spacing: 0.05em !important;
    font-weight: 400 !important;
  }
  .isoore-cart__item .quantity-selector button:hover { background: var(--isoore-paper-deep, #E8E2D3) !important; }
  .isoore-cart__item .quantity-selector .icon { color: var(--isoore-ink, #0E0E0C); }

  /* === SUMMARY (colonne droite) === */
  .isoore-cart__summary {
    position: sticky;
    top: 120px;
  }
  @media (max-width: 899px) {
    .isoore-cart__summary { position: static; }
  }
  .isoore-cart__summary-inner {
    background: var(--isoore-paper-light, #FAF7EE);
    border: 1px solid var(--isoore-line, rgba(14,14,12,0.12));
    padding: 32px 28px;
    display: flex;
    flex-direction: column;
    gap: 24px;
  }
  @media (max-width: 749px) {
    .isoore-cart__summary-inner { padding: 24px 20px; gap: 20px; }
  }

  .isoore-cart__summary-eyebrow {
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 10px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--isoore-ink-faint, #9A968D);
    margin: 0;
  }

  /* Progress bar livraison */
  .isoore-cart__progress {
    padding-bottom: 22px;
    border-bottom: 1px solid var(--isoore-line, rgba(14,14,12,0.12));
  }
  .isoore-cart__progress-label {
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 10.5px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--isoore-ink-soft, #5C5A55);
    margin: 0 0 12px;
    line-height: 1.5;
  }
  .isoore-cart__progress-label strong {
    font-weight: 500;
    color: var(--isoore-ink, #0E0E0C);
  }
  .isoore-cart__progress-track {
    width: 100%;
    height: 2px;
    background: var(--isoore-paper-deep, #E8E2D3);
    overflow: hidden;
    position: relative;
  }
  .isoore-cart__progress-fill {
    display: block;
    height: 100%;
    background: var(--isoore-accent, #2D3E2B);
    transition: width 0.6s var(--isoore-ease, cubic-bezier(0.16, 1, 0.3, 1));
  }

  /* Totaux */
  .isoore-cart__totals { display: flex; flex-direction: column; gap: 10px; }
  .isoore-cart__total-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 12px;
    font-size: 14px;
    color: var(--isoore-ink-soft, #5C5A55);
    font-weight: 300;
  }
  .isoore-cart__total-row--discount { color: var(--isoore-accent, #2D3E2B); }
  .isoore-cart__total-row--final {
    padding-top: 14px;
    margin-top: 6px;
    border-top: 1px solid var(--isoore-line, rgba(14,14,12,0.12));
    color: var(--isoore-ink, #0E0E0C);
    font-size: 16px;
  }
  .isoore-cart__total-row--final > span:first-child {
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--isoore-ink-soft, #5C5A55);
  }
  .isoore-cart__total-price {
    font-family: var(--isoore-sans, 'Manrope', sans-serif);
    font-size: 24px;
    font-weight: 500;
    color: var(--isoore-ink, #0E0E0C);
    letter-spacing: -0.015em;
  }
  .isoore-cart__total-meta {
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 9.5px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--isoore-ink-faint, #9A968D);
    margin: 4px 0 0;
  }

  /* Code de réduction */
  .isoore-cart__discount { display: block; }
  .isoore-cart__discount-label {
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 10px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--isoore-ink-faint, #9A968D);
    display: block;
    margin-bottom: 8px;
  }
  .isoore-cart__discount-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 0;
  }
  .isoore-cart__discount-input {
    background: #ffffff;
    border: 1px solid var(--isoore-line-strong, rgba(14,14,12,0.32));
    border-right: 0;
    border-radius: 0;
    padding: 0 16px;
    height: 44px;
    font-family: var(--isoore-sans, 'Manrope', sans-serif);
    font-size: 13px;
    font-weight: 300;
    color: var(--isoore-ink, #0E0E0C);
    letter-spacing: 0;
    outline: none;
    transition: border-color 0.2s ease;
  }
  .isoore-cart__discount-input::placeholder {
    color: var(--isoore-ink-faint, #9A968D);
    font-weight: 300;
  }
  .isoore-cart__discount-input:focus {
    border-color: var(--isoore-ink, #0E0E0C);
  }
  .isoore-cart__discount-btn {
    background: var(--isoore-ink, #0E0E0C);
    color: var(--isoore-paper, #F4F0E6);
    border: 1px solid var(--isoore-ink, #0E0E0C);
    border-radius: 0;
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 10.5px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    padding: 0 20px;
    height: 44px;
    cursor: pointer;
    transition: all 0.3s var(--isoore-ease, cubic-bezier(0.16, 1, 0.3, 1));
  }
  .isoore-cart__discount-btn:hover {
    background: var(--isoore-accent, #2D3E2B);
    border-color: var(--isoore-accent, #2D3E2B);
  }
  .isoore-cart__discount-btn .button__content { display: inline; }

  .isoore-cart__discount-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 10px;
  }
  .isoore-cart__discount-badges.hidden { display: none; }
  .isoore-cart__discount-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--isoore-paper-deep, #E8E2D3);
    border: 1px solid var(--isoore-line, rgba(14,14,12,0.12));
    border-radius: 999px;
    padding: 6px 10px 6px 12px;
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 10.5px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--isoore-ink, #0E0E0C);
    margin: 0;
  }
  .isoore-cart__discount-badge .cart-discount__remove-discount {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px; height: 18px;
    cursor: pointer;
    opacity: 0.6;
    transition: opacity 0.2s ease;
  }
  .isoore-cart__discount-badge .cart-discount__remove-discount:hover { opacity: 1; }

  /* Bouton commander (style ATC PDP noir pill) */
  .isoore-cart__checkout,
  .isoore-cart__btn--primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    width: 100%;
    min-height: 56px;
    padding: 18px 32px;
    background: var(--isoore-ink, #0E0E0C);
    color: var(--isoore-paper, #F4F0E6);
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 12px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    font-weight: 400;
    border: 0;
    border-radius: 999px;
    cursor: pointer;
    text-decoration: none;
    transition: all 0.4s var(--isoore-ease, cubic-bezier(0.16, 1, 0.3, 1));
    position: relative;
  }
  .isoore-cart__btn--primary { width: auto; }
  .isoore-cart__checkout:hover:not(:disabled),
  .isoore-cart__btn--primary:hover {
    background: var(--isoore-accent, #2D3E2B);
    gap: 20px;
    transform: translateY(-2px);
  }
  .isoore-cart__checkout svg,
  .isoore-cart__btn--primary svg {
    transition: transform 0.4s var(--isoore-ease, cubic-bezier(0.16, 1, 0.3, 1));
  }
  .isoore-cart__checkout:hover:not(:disabled) svg,
  .isoore-cart__btn--primary:hover svg { transform: translateX(4px); }
  .isoore-cart__checkout:disabled { opacity: 0.5; cursor: not-allowed; }
  .isoore-cart__checkout .loading-spinner { position: absolute; right: 18px; }

  /* Boutons paiement accéléré (Apple Pay, Shop Pay, Google Pay) */
  .isoore-cart__accelerated {
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  .isoore-cart__accelerated .shopify-payment-button__button {
    border-radius: 999px !important;
    min-height: 52px !important;
    font-family: var(--isoore-mono, 'DM Mono', monospace) !important;
    font-size: 12px !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
  }
  .isoore-cart__accelerated .shopify-payment-button__more-options {
    color: var(--isoore-ink-soft, #5C5A55) !important;
    font-family: var(--isoore-mono, 'DM Mono', monospace) !important;
    font-size: 10px !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    text-align: center;
    padding-top: 4px;
  }

  /* Trust paiement */
  .isoore-cart__trust {
    border-top: 1px solid var(--isoore-line, rgba(14,14,12,0.12));
    padding-top: 18px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
  .isoore-cart__trust-label {
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 9.5px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--isoore-ink-faint, #9A968D);
  }
  .isoore-cart__trust-icons {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
  }
  .isoore-cart__trust-icons svg,
  .isoore-cart__trust-icons img {
    height: 22px;
    width: auto;
    filter: grayscale(0.3);
    opacity: 0.85;
  }
/* END_SECTION:isoore-cart */

/* START_SECTION:isoore-faq (INDEX:20) */
.isoore-faq {
    padding: 88px 56px;
    background: var(--color-background);
    color: var(--color-foreground);
  }

  .isoore-faq__inner {
    max-width: 760px;
    margin: 0 auto;
  }

  .isoore-faq__head {
    text-align: center;
    margin-bottom: 36px;
  }

  .isoore-faq__heading {
    font-size: clamp(26px, 3vw, 32px);
    font-weight: 500;
    line-height: 1.18;
    letter-spacing: -0.5px;
    margin: 8px 0 0;
    color: var(--isoore-text, #3A5038);
  }

  .isoore-faq__container {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  .isoore-faq__item {
    background: var(--isoore-white, #fff);
    border: 1px solid var(--isoore-border, #E4DCC8);
    border-radius: var(--isoore-radius-md, 10px);
    overflow: hidden;
    transition: border-color 0.3s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-faq__item.is-open,
  .isoore-faq__item:hover {
    border-color: var(--isoore-cta, #7AAB72);
  }

  .isoore-faq__question {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 22px;
    cursor: pointer;
    user-select: none;
    transition: padding 0.3s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-faq__question:focus-visible {
    outline: 2px solid var(--isoore-cta, #7AAB72);
    outline-offset: -2px;
  }

  .isoore-faq__q-text {
    font-size: 14px;
    font-weight: 600;
    color: var(--isoore-text, #3A5038);
    line-height: 1.4;
    flex: 1;
  }

  .isoore-faq__q-icon {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--isoore-cta, #7AAB72);
    font-size: 22px;
    font-weight: 300;
    flex-shrink: 0;
    transition: transform 0.4s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-faq__item.is-open .isoore-faq__q-icon {
    transform: rotate(45deg);
  }

  .isoore-faq__answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.5s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-faq__answer-inner {
    padding: 0 22px 18px;
    font-size: 13px;
    line-height: 1.7;
    opacity: 0.85;
    border-top: 1px solid var(--isoore-border, #E4DCC8);
    padding-top: 14px;
  }

  .isoore-faq__answer-inner p {
    margin: 0 0 8px;
  }

  .isoore-faq__answer-inner p:last-child { margin-bottom: 0; }

  .isoore-faq__item.is-open .isoore-faq__answer {
    max-height: 600px;
  }

  @media (max-width: 749px) {
    .isoore-faq { padding: 56px 24px; }
    .isoore-faq__question { padding: 16px 18px; }
  }
/* END_SECTION:isoore-faq */

/* START_SECTION:isoore-footer-cta (INDEX:21) */
.isoore-footer-cta {
    padding: 80px 56px;
    text-align: center;
    background:
      radial-gradient(circle at 20% 50%, rgba(122, 171, 114, 0.12), transparent 50%),
      radial-gradient(circle at 80% 50%, rgba(122, 171, 114, 0.08), transparent 50%),
      var(--color-background);
    color: var(--color-foreground);
    position: relative;
    overflow: hidden;
  }

  .isoore-footer-cta__inner {
    max-width: 720px;
    margin: 0 auto;
  }

  .isoore-footer-cta__heading {
    font-size: clamp(28px, 3.5vw, 36px);
    font-weight: 500;
    line-height: 1.15;
    margin: 0 0 16px;
    letter-spacing: -0.5px;
  }

  .isoore-footer-cta__sub {
    font-size: 14px;
    opacity: 0.85;
    line-height: 1.7;
    margin: 0 auto 30px;
    max-width: 520px;
  }

  .isoore-footer-cta__buttons {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
  }

  .isoore-footer-cta__btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 28px;
    border-radius: var(--isoore-radius-sm, 4px);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.3px;
    text-decoration: none;
    position: relative;
    overflow: hidden;
    transition: transform 0.3s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1)),
                box-shadow 0.3s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1)),
                background-color 0.3s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-footer-cta__btn--primary {
    background: var(--isoore-cta, #7AAB72);
    color: #fff;
  }

  .isoore-footer-cta__btn--primary::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.25), transparent);
    transition: left 0.6s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-footer-cta__btn--primary:hover::before { left: 100%; }

  .isoore-footer-cta__btn--primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 25px rgba(122, 171, 114, 0.4);
  }

  .isoore-footer-cta__btn--secondary {
    background: transparent;
    color: inherit;
    border: 1.5px solid rgba(247, 243, 236, 0.7);
  }

  .isoore-footer-cta__btn--secondary:hover {
    background: var(--isoore-bg, #F7F3EC);
    color: var(--isoore-text, #3A5038);
    transform: translateY(-2px);
  }

  .isoore-footer-cta__btn-arrow {
    display: inline-block;
    transition: transform 0.3s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-footer-cta__btn:hover .isoore-footer-cta__btn-arrow {
    transform: translateX(4px);
  }

  @media (max-width: 749px) {
    .isoore-footer-cta { padding: 56px 24px; }
    .isoore-footer-cta__buttons { flex-direction: column; align-items: stretch; }
    .isoore-footer-cta__btn { justify-content: center; }
  }
/* END_SECTION:isoore-footer-cta */

/* START_SECTION:isoore-hero (INDEX:22) */
.isoore-hero {
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: 0 64px;
    color: #F7F3EC;
    isolation: isolate;
  }

  .isoore-hero--h-small  { min-height: 460px; }
  .isoore-hero--h-medium { min-height: 580px; }
  .isoore-hero--h-large  { min-height: 720px; }

  .isoore-hero__media {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
    background:
      linear-gradient(135deg, #6a7b66 0%, #3A5038 50%, #2d3e2b 100%);
    background-size: 200% 200%;
    animation: isoore-bg-shift 18s ease infinite;
  }

  .isoore-hero__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center var(--isoore-hero-focus, 50%);
  }

  .isoore-hero__overlay {
    position: absolute;
    inset: 0;
    background:
      /* Ombre côté gauche : assombrit la zone du H1 sans toucher la pergola à droite */
      linear-gradient(90deg, rgba(0, 0, 0, 0.65) 0%, rgba(0, 0, 0, 0.45) 25%, rgba(0, 0, 0, 0.15) 55%, rgba(0, 0, 0, 0) 75%),
      /* Voile vert subtil pour matcher la charte */
      linear-gradient(135deg, rgba(45, 62, 43, 0.40) 0%, rgba(45, 62, 43, 0.20) 50%, rgba(45, 62, 43, 0.45) 100%),
      /* Légère vignette du bas pour les checkmarks */
      linear-gradient(180deg, rgba(0, 0, 0, 0.08), rgba(0, 0, 0, 0.30));
  }

  .isoore-hero__content {
    position: relative;
    z-index: 1;
    max-width: 620px;
  }

  .isoore-hero__kicker {
    margin: 0 0 18px;
    font-size: 11px;
    letter-spacing: 4px;
    text-transform: uppercase;
    opacity: 0;
    animation: isoore-fade-in-up 1s 0.2s var(--isoore-ease) forwards;
  }

  .isoore-hero__title {
    margin: 0 0 22px;
    font-size: clamp(34px, 5vw, 52px);
    font-weight: 500;
    line-height: 1.08;
    letter-spacing: -0.5px;
    color: #F7F3EC;
    text-shadow: 0 2px 24px rgba(0, 0, 0, 0.35), 0 1px 4px rgba(0, 0, 0, 0.2);
  }

  .isoore-hero__subtitle {
    margin: 0 0 32px;
    font-size: 16px;
    line-height: 1.65;
    max-width: 520px;
    opacity: 0;
    animation: isoore-fade-in-up 1s 0.6s var(--isoore-ease) forwards;
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.3);
  }

  .isoore-hero__buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-bottom: 36px;
    opacity: 0;
    animation: isoore-fade-in-up 1s 0.8s var(--isoore-ease) forwards;
  }

  .isoore-hero__btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 28px;
    border-radius: 4px;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.3px;
    text-decoration: none;
    position: relative;
    overflow: hidden;
    transition: transform 0.3s var(--isoore-ease),
                box-shadow 0.3s var(--isoore-ease),
                background-color 0.3s var(--isoore-ease),
                border-color 0.3s var(--isoore-ease);
  }

  .isoore-hero__btn--primary {
    background: var(--isoore-cta, #7AAB72);
    color: #fff;
  }

  .isoore-hero__btn--primary::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.25), transparent);
    transition: left 0.6s var(--isoore-ease);
  }

  .isoore-hero__btn--primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 25px rgba(122, 171, 114, 0.35);
  }

  .isoore-hero__btn--primary:hover::before { left: 100%; }

  .isoore-hero__btn--secondary {
    background: rgba(0, 0, 0, 0.2);
    color: #F7F3EC;
    border: 1px solid rgba(247, 243, 236, 0.7);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }

  .isoore-hero__btn--secondary:hover {
    background: rgba(247, 243, 236, 0.15);
    border-color: #F7F3EC;
  }

  .isoore-hero__btn-arrow {
    display: inline-block;
    transition: transform 0.3s var(--isoore-ease);
  }

  .isoore-hero__btn:hover .isoore-hero__btn-arrow { transform: translateX(4px); }

  .isoore-hero__checks {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    opacity: 0;
    animation: isoore-fade-in-up 1s 1s var(--isoore-ease) forwards;
  }

  .isoore-hero__check {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
  }

  .isoore-hero__check-icon {
    color: var(--isoore-cta, #7AAB72);
    font-weight: 700;
  }

  .isoore-hero__scroll-indicator {
    position: absolute;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    z-index: 1;
    color: #F7F3EC;
    animation: isoore-float 2.5s ease-in-out infinite;
  }

  .isoore-hero__scroll-label { font-size: 10px; letter-spacing: 4px; }
  .isoore-hero__scroll-arrow { font-size: 14px; }

  @media (max-width: 749px) {
    .isoore-hero {
      /* Textes plus haut sur mobile : center au lieu de flex-end + padding top généreux */
      padding: 80px 24px 40px;
      justify-content: center;
    }
    .isoore-hero--mh-small  { min-height: 460px; }
    .isoore-hero--mh-medium { min-height: 560px; }
    .isoore-hero--mh-large  { min-height: 640px; }

    .isoore-hero__content {
      max-width: 100%;
    }

    .isoore-hero__title    { font-size: clamp(26px, 7vw, 34px); margin-bottom: 14px; }
    .isoore-hero__subtitle { font-size: 14px; margin-bottom: 22px; }
    .isoore-hero__kicker   { font-size: 10px; letter-spacing: 3px; margin-bottom: 12px; }
    .isoore-hero__buttons  { flex-direction: column; align-items: stretch; gap: 10px; margin-bottom: 24px; }
    .isoore-hero__btn      { justify-content: center; padding: 13px 22px; }
    .isoore-hero__checks   { gap: 6px; }
    .isoore-hero__check    { font-size: 13px; }

    /* Overlay plus dense en bas mobile pour que les textes restent lisibles */
    .isoore-hero__overlay {
      background:
        linear-gradient(180deg, rgba(0, 0, 0, 0.45) 0%, rgba(0, 0, 0, 0.30) 40%, rgba(0, 0, 0, 0.55) 100%),
        linear-gradient(135deg, rgba(45, 62, 43, 0.45) 0%, rgba(45, 62, 43, 0.25) 50%, rgba(45, 62, 43, 0.50) 100%);
    }
  }

  @media (prefers-reduced-motion: reduce) {
    .isoore-hero__media,
    .isoore-hero__kicker,
    .isoore-hero__title,
    .isoore-hero__subtitle,
    .isoore-hero__buttons,
    .isoore-hero__checks,
    .isoore-hero__scroll-indicator {
      animation: none !important;
      opacity: 1 !important;
    }
  }
/* END_SECTION:isoore-hero */

/* START_SECTION:isoore-materials (INDEX:33) */
.isoore-materials {
    padding: 88px 56px;
    background: var(--color-background);
    color: var(--color-foreground);
  }

  .isoore-materials__inner {
    max-width: var(--isoore-container-max, 1300px);
    margin: 0 auto;
  }

  .isoore-materials__head {
    text-align: center;
    margin-bottom: 36px;
  }

  .isoore-materials__heading {
    font-size: clamp(26px, 3vw, 32px);
    font-weight: 500;
    line-height: 1.18;
    letter-spacing: -0.5px;
    margin: 8px 0 12px;
    color: var(--isoore-text, #3A5038);
  }

  .isoore-materials__body {
    font-size: 14px;
    line-height: 1.7;
    opacity: 0.8;
    max-width: 640px;
    margin: 0 auto;
  }

  .isoore-materials__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
  }

  .isoore-material {
    background: var(--isoore-bg, #F7F3EC);
    padding: 24px;
    border-radius: var(--isoore-radius-md, 10px);
    border: 1px solid var(--isoore-border, #E4DCC8);
    transition: all 0.5s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
    cursor: default;
  }

  .isoore-material:hover {
    transform: translateY(-6px);
    border-color: var(--isoore-cta, #7AAB72);
    background: var(--isoore-white, #fff);
    box-shadow: 0 16px 36px rgba(58, 80, 56, 0.10);
  }

  .isoore-material__icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: rgba(122, 171, 114, 0.15);
    color: var(--isoore-cta, #7AAB72);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
    transition: all 0.4s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-material:hover .isoore-material__icon {
    background: var(--isoore-cta, #7AAB72);
    color: #fff;
    transform: scale(1.1);
  }

  .isoore-material__title {
    font-size: 15px;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--isoore-text, #3A5038);
  }

  .isoore-material__desc {
    font-size: 13px;
    line-height: 1.6;
    opacity: 0.75;
  }

  @media (max-width: 989px) {
    .isoore-materials { padding: 56px 24px; }
    .isoore-materials__grid { grid-template-columns: repeat(2, 1fr); }
  }

  @media (max-width: 549px) {
    .isoore-materials__grid { grid-template-columns: 1fr; }
  }
/* END_SECTION:isoore-materials */

/* START_SECTION:isoore-page-histoire (INDEX:34) */
body.isoore-template-histoire .isoore-top,
body.isoore-template-histoire .header,
body.isoore-template-histoire .isoore-site-header {
  background: rgba(244, 240, 230, 0.88) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}
body.isoore-template-histoire .isoore-top a,
body.isoore-template-histoire .isoore-top .brand,
body.isoore-template-histoire .isoore-top .isoore-top__brand {
  color: var(--isoore-ink, #0E0E0C) !important;
  text-shadow: none !important;
}

.isoore-histoire {
  background: var(--isoore-paper, #FAF7EE);
  color: var(--isoore-ink, #0E0E0C);
  font-family: 'Manrope', system-ui, sans-serif;
  padding-top: 200px;
}

.isoore-histoire__hero {
  padding: 0 0 80px;
  border-bottom: 1px solid rgba(14, 14, 12, 0.08);
  margin-bottom: 80px;
}
.isoore-histoire__hero-inner { max-width: 920px; }
.isoore-histoire__kicker {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  margin: 0 0 28px;
}
.isoore-histoire__title {
  font-family: 'Manrope', sans-serif;
  font-weight: 500;
  font-size: clamp(2.2rem, 5.5vw, 4.2rem);
  line-height: 1.04;
  letter-spacing: -0.02em;
  margin: 0 0 32px;
  color: var(--isoore-ink, #0E0E0C);
}
.isoore-histoire__title em {
  font-style: normal;
  font-weight: 200;
  opacity: 0.65;
}
.isoore-histoire__chapo {
  font-size: clamp(1.1rem, 1.6vw, 1.3rem);
  line-height: 1.55;
  color: rgba(14, 14, 12, 0.75);
  margin: 0;
  max-width: 680px;
}

.isoore-histoire__chapter {
  padding: 0 0 80px;
  border-bottom: 1px solid rgba(14, 14, 12, 0.08);
  margin-bottom: 80px;
}
.isoore-histoire__chapter:last-of-type { border-bottom: none; }
.isoore-histoire__chapter-inner {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 80px;
  align-items: start;
  max-width: 1200px;
  margin: 0 auto;
}
.isoore-histoire__chapter-num {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--isoore-accent, #2D3E2B);
  position: sticky;
  top: 120px;
  padding-top: 8px;
}
.isoore-histoire__chapter-num strong {
  display: block;
  font-size: 11px;
  color: var(--isoore-accent, #2D3E2B);
  margin-bottom: 6px;
  font-weight: 400;
}
.isoore-histoire__chapter-num span {
  display: block;
  color: rgba(14, 14, 12, 0.45);
  font-size: 10.5px;
}
.isoore-histoire__chapter-body { max-width: 680px; }
.isoore-histoire__chapter-title {
  font-family: 'Manrope', sans-serif;
  font-weight: 500;
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  line-height: 1.15;
  letter-spacing: -0.015em;
  margin: 0 0 28px;
  color: var(--isoore-ink, #0E0E0C);
}
.isoore-histoire__chapter-body p {
  font-size: 1.0625rem;
  line-height: 1.75;
  color: rgba(14, 14, 12, 0.85);
  margin: 0 0 1.4em;
}
.isoore-histoire__chapter-body p:last-child { margin-bottom: 0; }
.isoore-histoire__chapter-body strong {
  font-weight: 600;
  color: var(--isoore-ink, #0E0E0C);
}
.isoore-histoire__chapter-body ul,
.isoore-histoire__chapter-body ol {
  margin: 0 0 1.4em;
  padding-left: 0;
  list-style: none;
}
.isoore-histoire__chapter-body ul li,
.isoore-histoire__chapter-body ol li {
  margin: 0 0 14px;
  padding-left: 24px;
  position: relative;
  font-size: 1.0625rem;
  line-height: 1.65;
  color: rgba(14, 14, 12, 0.85);
}
.isoore-histoire__chapter-body ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 14px;
  height: 1px;
  background: var(--isoore-accent, #2D3E2B);
}
.isoore-histoire__chapter-body ol { counter-reset: steps; }
.isoore-histoire__chapter-body ol li {
  counter-increment: steps;
  padding-left: 36px;
}
.isoore-histoire__chapter-body ol li::before {
  content: counter(steps, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: 0.05em;
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.05em;
  color: var(--isoore-accent, #2D3E2B);
}

.isoore-histoire__quote {
  padding: 80px 0;
  background: var(--isoore-paper-deep, #E8E2D3);
  margin: 0 0 80px;
}
.isoore-histoire__quote-inner {
  max-width: 920px;
  margin: 0 auto;
  text-align: center;
}
.isoore-histoire__quote-mark {
  font-family: 'Manrope', sans-serif;
  font-size: 80px;
  line-height: 1;
  font-weight: 200;
  color: var(--isoore-accent, #2D3E2B);
  margin: 0 0 -20px;
  opacity: 0.55;
}
.isoore-histoire__quote blockquote {
  font-family: 'Manrope', sans-serif;
  font-weight: 300;
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  line-height: 1.35;
  color: var(--isoore-ink, #0E0E0C);
  margin: 0 0 32px;
  font-style: italic;
  letter-spacing: -0.005em;
}
.isoore-histoire__quote cite {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(14, 14, 12, 0.6);
  font-style: normal;
  display: block;
}

.isoore-histoire__signature {
  text-align: center;
  padding: 0 0 80px;
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(14, 14, 12, 0.55);
}
.isoore-histoire__signature strong {
  font-weight: 500;
  color: var(--isoore-ink, #0E0E0C);
  display: block;
  margin-bottom: 6px;
  font-size: 13px;
}

.isoore-histoire__cta {
  padding: 96px 0;
  background: var(--isoore-ink, #0E0E0C);
  color: var(--isoore-paper, #FAF7EE);
}
.isoore-histoire__cta-card {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.isoore-histoire__cta-kicker {
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(244, 240, 230, 0.55);
  margin: 0 0 20px;
}
.isoore-histoire__cta-title {
  font-family: 'Manrope', sans-serif;
  font-weight: 500;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  line-height: 1.15;
  margin: 0 0 16px;
  letter-spacing: -0.015em;
  color: var(--isoore-paper, #FAF7EE);
}
.isoore-histoire__cta-subtitle {
  color: rgba(244, 240, 230, 0.7);
  font-size: 1.05rem;
  line-height: 1.55;
  margin: 0 0 36px;
}
.isoore-histoire__cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--isoore-paper, #FAF7EE);
  color: var(--isoore-ink, #0E0E0C);
  padding: 18px 36px;
  border-radius: 999px;
  text-decoration: none;
  font-family: 'DM Mono', ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition: all 0.3s var(--isoore-ease, ease);
}
.isoore-histoire__cta-btn:hover {
  background: var(--isoore-accent, #2D3E2B);
  color: var(--isoore-paper, #FAF7EE);
  transform: translateY(-2px);
}

@media (max-width: 990px) {
  .isoore-histoire { padding-top: 130px; }
  .isoore-histoire__hero { padding-bottom: 48px; margin-bottom: 48px; }
  .isoore-histoire__chapter { padding-bottom: 48px; margin-bottom: 48px; }
  .isoore-histoire__chapter-inner { grid-template-columns: 1fr; gap: 24px; }
  .isoore-histoire__chapter-num { position: static; padding-top: 0; }
  .isoore-histoire__quote { padding: 56px 0; margin-bottom: 48px; }
  .isoore-histoire__cta { padding: 64px 0; }
}
/* END_SECTION:isoore-page-histoire */

/* START_SECTION:isoore-pdp-hero (INDEX:35) */
.isoore-pdph {
    background: var(--isoore-paper, #F4F0E6);
    color: var(--isoore-ink, #0E0E0C);
    padding: var(--pdph-pad-top, 100px) 0 var(--pdph-pad-bottom, 80px);
    font-family: var(--isoore-sans, 'Manrope', sans-serif);
    font-weight: 300;
    line-height: 1.55;
  }
  @media (max-width: 749px) { .isoore-pdph { padding: var(--pdph-pad-top-mobile, 60px) 0 var(--pdph-pad-bottom-mobile, 40px); } }

  /* Header global plus visible quand on est sur la PDP (fond crème semi-transparent + blur) */
  body.isoore-pdp .isoore-top,
  body.template-product .isoore-top {
    background: rgba(244, 240, 230, 0.88);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }
  body.isoore-pdp .isoore-top a,
  body.isoore-pdp .isoore-top .isoore-top__brand,
  body.template-product .isoore-top a,
  body.template-product .isoore-top .isoore-top__brand {
    color: var(--isoore-ink, #0E0E0C) !important;
    text-shadow: none !important;
  }

  .isoore-pdph__container {
    max-width: 1640px;
    margin: 0 auto;
    padding: 0 56px;
  }
  @media (max-width: 749px) { .isoore-pdph__container { padding: 0 20px; } }

  .isoore-pdph__top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 32px;
    margin-bottom: 48px;
  }
  @media (max-width: 749px) {
    .isoore-pdph__top { flex-direction: column; gap: 6px; margin-bottom: 24px; }
  }
  .isoore-pdph__tag, .isoore-pdph__meta {
    display: flex;
    flex-direction: column;
    gap: 6px;
  }
  .isoore-pdph__meta { text-align: right; }
  @media (max-width: 749px) {
    .isoore-pdph__meta { text-align: left; }
    /* Mobile : micro-textes plus contrastés pour rester lisibles sous le header */
    .isoore-pdph__top .isoore-micro,
    .isoore-pdph__top .isoore-num {
      color: var(--isoore-ink, #0E0E0C);
      opacity: 0.85;
      font-size: 10px;
    }
    /* Et qu'ils ne soient pas tronqués si trop longs */
    .isoore-pdph__tag, .isoore-pdph__meta { max-width: 100%; }
    /* Masquer le breadcrumb + subline sur mobile (garder uniquement sur PC) */
    .isoore-pdph__breadcrumb,
    .isoore-pdph__subline { display: none !important; }
  }

  .isoore-pdph__grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 80px;
    align-items: start;
  }
  @media (max-width: 989px) { .isoore-pdph__grid { grid-template-columns: 1fr; gap: 40px; } }

  .isoore-pdph__gallery {
    display: grid;
    grid-template-columns: 88px 1fr;
    gap: 16px;
    align-items: start;
  }
  .isoore-pdph--no-thumbs .isoore-pdph__gallery { grid-template-columns: 1fr; }
  @media (max-width: 749px) { .isoore-pdph__gallery { grid-template-columns: 1fr; gap: 12px; } }

  .isoore-pdph__thumbs {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  @media (max-width: 749px) {
    .isoore-pdph__gallery {
      display: flex;
      flex-direction: column;
      gap: 12px;
    }
    .isoore-pdph__thumbs-wrap { order: 2; width: 100%; }
    .isoore-pdph__thumbs {
      order: 2;
      flex-direction: row;
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
      gap: 8px;
      scrollbar-width: none;
    }
    .isoore-pdph__thumbs::-webkit-scrollbar { display: none; }
  }
  .isoore-pdph__thumb {
    width: 88px;
    height: 88px;
    padding: 0;
    border: 2px solid transparent;
    background: var(--isoore-paper-deep, #E8E2D3);
    cursor: pointer;
    overflow: hidden;
    transition: border-color 0.25s var(--isoore-ease, cubic-bezier(0.16, 1, 0.3, 1));
    flex-shrink: 0;
  }
  .isoore-pdph__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .isoore-pdph__thumb:hover { border-color: var(--isoore-line-strong, rgba(14,14,12,0.32)); }
  .isoore-pdph__thumb.is-active { border-color: var(--isoore-ink, #0E0E0C); }

  .isoore-pdph__media {
    position: relative;
    background: var(--isoore-paper-deep, #E8E2D3);
    aspect-ratio: 1 / 1;
    overflow: hidden;
  }
  .isoore-pdph__media[data-ratio="square"] { aspect-ratio: 1 / 1; }
  .isoore-pdph__media[data-ratio="portrait"] { aspect-ratio: 4 / 5; }
  .isoore-pdph__media[data-ratio="landscape"] { aspect-ratio: 4 / 3; }
  .isoore-pdph__media[data-ratio="wide"] { aspect-ratio: 16 / 9; }
  @media (max-width: 749px) {
    .isoore-pdph__media { order: 1; aspect-ratio: 1 / 1; }
    .isoore-pdph__media[data-ratio="adapt"] { aspect-ratio: auto; }
  }
  .isoore-pdph__media-item {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 0.4s var(--isoore-ease, cubic-bezier(0.16, 1, 0.3, 1));
    pointer-events: none;
  }
  .isoore-pdph__media-item.is-active { opacity: 1; pointer-events: auto; }
  .isoore-pdph__media-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .isoore-pdph__media-caption {
    position: absolute;
    bottom: 22px;
    left: 22px;
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(244, 240, 230, 0.85);
    pointer-events: none;
  }

  .isoore-pdph__info {
    padding-top: 12px;
    display: flex;
    flex-direction: column;
  }

  .isoore-pdph__title {
    font-family: var(--isoore-sans, 'Manrope', sans-serif);
    font-weight: 500;
    font-size: clamp(2rem, 3.8vw, 3.6rem);
    line-height: 1.04;
    letter-spacing: -0.03em;
    color: var(--isoore-ink, #0E0E0C);
    margin: 0 0 24px;
  }
  .isoore-pdph__title em { font-style: normal; font-weight: 200; opacity: 0.7; }

  .isoore-pdph__lead {
    font-size: 16px;
    line-height: 1.7;
    color: var(--isoore-ink-mid, #1A1A18);
    margin-bottom: 32px;
    max-width: 540px;
  }
  .isoore-pdph__lead p { margin: 0 0 8px; }
  .isoore-pdph__lead p:last-child { margin: 0; }

  .isoore-pdph__price-row {
    display: grid;
    grid-template-columns: auto auto 1fr auto;
    align-items: baseline;
    gap: 20px;
    padding: 24px 0;
    border-top: 1px solid var(--isoore-line, rgba(14,14,12,0.12));
    border-bottom: 1px solid var(--isoore-line, rgba(14,14,12,0.12));
    margin-bottom: 28px;
  }
  @media (max-width: 749px) {
    .isoore-pdph__price-row { grid-template-columns: auto auto auto; gap: 12px; flex-wrap: wrap; }
  }
  .isoore-pdph__price-strike {
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 15px;
    text-decoration: line-through;
    color: var(--isoore-ink-faint, #9A968D);
  }
  .isoore-pdph__price {
    font-family: var(--isoore-sans, 'Manrope', sans-serif);
    font-size: clamp(32px, 3.4vw, 44px);
    font-weight: 500;
    letter-spacing: -0.025em;
    line-height: 1;
    color: var(--isoore-ink, #0E0E0C);
  }
  .isoore-pdph__badge {
    justify-self: end;
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    padding: 7px 14px;
    border-radius: 999px;
    background: var(--isoore-accent, #2D3E2B);
    color: var(--isoore-paper, #F4F0E6);
  }

  .isoore-pdph__form { display: flex; flex-direction: column; }

  .isoore-pdph__variants { border: 0; padding: 0; margin: 0 0 24px; }
  .isoore-pdph__variants-label {
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--isoore-ink-soft, #5C5A55);
    margin-bottom: 12px;
    padding: 0;
  }
  .isoore-pdph__variants-row { display: flex; flex-wrap: wrap; gap: 8px; }
  .isoore-pdph__variant-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
  }
  .isoore-pdph__variant {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    padding: 12px 20px;
    border: 1px solid var(--isoore-line-strong, rgba(14,14,12,0.32));
    border-radius: 999px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.25s var(--isoore-ease, cubic-bezier(0.16, 1, 0.3, 1));
    color: var(--isoore-ink, #0E0E0C);
    background: transparent;
  }
  .isoore-pdph__variant:hover { transform: translateY(-1px); border-color: var(--isoore-ink, #0E0E0C); }
  .isoore-pdph__variant-input:checked + .isoore-pdph__variant {
    background: var(--isoore-ink, #0E0E0C);
    color: var(--isoore-paper, #F4F0E6);
    border-color: var(--isoore-ink, #0E0E0C);
  }
  .isoore-pdph__variant-input:focus-visible + .isoore-pdph__variant {
    outline: 2px solid var(--isoore-accent, #2D3E2B);
    outline-offset: 2px;
  }

  .isoore-pdph__atc {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    width: 100%;
    min-height: 56px;
    padding: 22px 32px;
    background: var(--isoore-ink, #0E0E0C);
    color: var(--isoore-paper, #F4F0E6);
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 12px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    border: 0;
    border-radius: 999px;
    cursor: pointer;
    transition: all 0.4s var(--isoore-ease, cubic-bezier(0.16, 1, 0.3, 1));
    margin: 16px 0 24px;
  }
  .isoore-pdph__atc:hover:not(:disabled) {
    background: var(--isoore-accent, #2D3E2B);
    gap: 20px;
    transform: translateY(-2px);
  }
  .isoore-pdph__atc:disabled { opacity: 0.55; cursor: not-allowed; }
  .isoore-pdph__atc svg { transition: transform 0.4s var(--isoore-ease, cubic-bezier(0.16, 1, 0.3, 1)); }
  .isoore-pdph__atc:hover:not(:disabled) svg { transform: translateX(4px); }

  .isoore-pdph__trust {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    padding-top: 28px;
    border-top: 1px solid var(--isoore-line, rgba(14,14,12,0.12));
  }
  @media (max-width: 749px) {
    .isoore-pdph__trust { grid-template-columns: 1fr; gap: 16px; padding-top: 22px; }
  }
  .isoore-pdph__trust-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
  }
  .isoore-pdph__trust-item .isoore-num {
    color: var(--isoore-accent, #2D3E2B);
    font-weight: 500;
    margin-bottom: 4px;
  }
  .isoore-pdph__trust-label strong {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: var(--isoore-ink, #0E0E0C);
    margin-bottom: 2px;
  }
  .isoore-pdph__trust-label span {
    display: block;
    font-size: 13px;
    color: var(--isoore-ink-mid, #1A1A18);
    line-height: 1.4;
  }

  /* ============================================================
     STICKY ATC BAR (mobile uniquement) — fond anthracite transparent + blur
     Apparaît quand le bouton ATC principal n'est plus dans le viewport
     ============================================================ */
  .isoore-pdph__sticky {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 90;
    transform: translateY(110%);
    transition: transform 0.45s var(--isoore-ease, cubic-bezier(0.16, 1, 0.3, 1));
    background: rgba(244, 240, 230, 0.78);
    backdrop-filter: blur(16px) saturate(160%);
    -webkit-backdrop-filter: blur(16px) saturate(160%);
    border-top: 1px solid rgba(14, 14, 12, 0.08);
    padding: 12px 20px;
    padding-bottom: calc(12px + env(safe-area-inset-bottom));
    pointer-events: none;
  }
  .isoore-pdph__sticky.is-visible {
    transform: translateY(0);
    pointer-events: auto;
  }
  @media (min-width: 750px) {
    .isoore-pdph__sticky { display: none !important; }
  }
  .isoore-pdph__sticky-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    max-width: 600px;
    margin: 0 auto;
  }
  .isoore-pdph__sticky-left {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
    flex: 1;
  }
  .isoore-pdph__sticky-label {
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 10px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--isoore-ink-soft, #5C5A55);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .isoore-pdph__sticky-price {
    font-family: var(--isoore-sans, 'Manrope', sans-serif);
    font-size: 17px;
    font-weight: 500;
    letter-spacing: -0.02em;
    color: var(--isoore-ink, #0E0E0C);
    line-height: 1.1;
  }
  .isoore-pdph__sticky-btn {
    flex-shrink: 0;
    padding: 14px 24px;
    min-height: 48px;
    background: var(--isoore-ink, #0E0E0C);
    color: var(--isoore-paper, #F4F0E6);
    font-family: var(--isoore-mono, 'DM Mono', monospace);
    font-size: 12px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    border: 0;
    border-radius: 999px;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.3s var(--isoore-ease, cubic-bezier(0.16, 1, 0.3, 1));
  }
  .isoore-pdph__sticky-btn:hover,
  .isoore-pdph__sticky-btn:active {
    background: var(--isoore-accent, #2D3E2B);
    color: var(--isoore-paper, #F4F0E6);
  }
  /* Arrondi des médias (toggle Theme Editor) */
  .isoore-pdph--rounded .isoore-pdph__thumb,
  .isoore-pdph--rounded .isoore-pdph__media,
  .isoore-pdph--rounded .isoore-pdph__media-item img {
    border-radius: 12px;
  }
  .isoore-pdph--rounded .isoore-pdph__media { overflow: hidden; }

  /* Carrousel peek mobile : laisse voir un bout de l'image suivante au scroll */
  @media (max-width: 749px) {
    .isoore-pdph--peek-mobile .isoore-pdph__thumbs {
      padding-right: 30%;
      scroll-snap-type: x mandatory;
    }
    .isoore-pdph--peek-mobile .isoore-pdph__thumb {
      scroll-snap-align: start;
    }
  }

  /* === Galerie thumbs — indicateur de scroll === */
  .isoore-pdph__thumbs-wrap {
    position: relative;
  }

  /* Desktop : max 5 thumbs visibles + scroll vertical au-delà + fade bas + chevron */
  @media (min-width: 750px) {
    .isoore-pdph__thumbs-wrap {
      max-height: calc(88px * 5 + 12px * 4); /* 5 thumbs + 4 gaps = 488px */
    }
    .isoore-pdph__thumbs {
      max-height: calc(88px * 5 + 12px * 4);
      overflow-y: auto;
      scrollbar-width: thin;
      scrollbar-color: rgba(14,14,12,0.25) transparent;
      -webkit-mask-image: linear-gradient(to bottom, black 0, black 88%, transparent 100%);
      mask-image: linear-gradient(to bottom, black 0, black 88%, transparent 100%);
      padding-bottom: 12px;
    }
    .isoore-pdph__thumbs::-webkit-scrollbar { width: 4px; }
    .isoore-pdph__thumbs::-webkit-scrollbar-track { background: transparent; }
    .isoore-pdph__thumbs::-webkit-scrollbar-thumb {
      background: rgba(14,14,12,0.25);
      border-radius: 2px;
    }
    .isoore-pdph__thumbs-hint {
      display: flex;
      align-items: center;
      justify-content: center;
      position: absolute;
      bottom: -6px;
      left: 50%;
      transform: translateX(-50%) rotate(90deg);
      width: 24px;
      height: 24px;
      color: var(--isoore-ink-soft, #5C5A55);
      opacity: 0.5;
      pointer-events: none;
      animation: isoore-pdph-hint-pulse 2.2s ease-in-out infinite;
    }
    /* Cacher le hint si moins de 6 thumbs (pas de scroll nécessaire) */
    .isoore-pdph__thumbs:not([data-has-overflow]) ~ .isoore-pdph__thumbs-hint { display: none; }
  }

  /* Mobile : fade droite + chevron pulsé qui indique swipe horizontal */
  @media (max-width: 749px) {
    .isoore-pdph__thumbs-wrap {
      position: relative;
    }
    .isoore-pdph__thumbs {
      -webkit-mask-image: linear-gradient(to right, black 0, black 85%, transparent 100%);
      mask-image: linear-gradient(to right, black 0, black 85%, transparent 100%);
    }
    .isoore-pdph__thumbs-hint {
      display: flex;
      align-items: center;
      justify-content: center;
      position: absolute;
      top: 50%;
      right: 4px;
      transform: translateY(-50%);
      width: 28px;
      height: 28px;
      color: var(--isoore-ink-soft, #5C5A55);
      background: rgba(244,240,230,0.85);
      border-radius: 999px;
      opacity: 0.8;
      pointer-events: none;
      animation: isoore-pdph-hint-pulse-x 1.8s ease-in-out infinite;
      z-index: 2;
    }
  }

  @keyframes isoore-pdph-hint-pulse {
    0%, 100% { transform: translateX(-50%) rotate(90deg) translateY(0); opacity: 0.4; }
    50% { transform: translateX(-50%) rotate(90deg) translateY(3px); opacity: 0.8; }
  }
  @keyframes isoore-pdph-hint-pulse-x {
    0%, 100% { transform: translateY(-50%) translateX(0); opacity: 0.5; }
    50% { transform: translateY(-50%) translateX(4px); opacity: 0.95; }
  }

  /* Ratio adaptatif : container suit la hauteur de l'image active (pas d'absolute stacking) */
  .isoore-pdph__media[data-ratio="adapt"] {
    aspect-ratio: auto;
    position: relative;
    background: var(--isoore-paper-deep, #E8E2D3);
  }
  .isoore-pdph__media[data-ratio="adapt"] .isoore-pdph__media-item {
    position: relative;
    inset: auto;
    opacity: 1;
    display: none;
    pointer-events: auto;
    transition: none;
  }
  .isoore-pdph__media[data-ratio="adapt"] .isoore-pdph__media-item.is-active {
    display: block;
  }
  .isoore-pdph__media[data-ratio="adapt"] .isoore-pdph__media-item img {
    width: 100%;
    height: auto;
    display: block;
  }

  /* ============================================================
     FIX OVERFLOW MOBILE (edit22, 2026-05-23)
     Symptômes (3 PDP) : titre coupé "acier ga...", description tronquée,
     bouton CTA qui déborde à droite, viewport scrollable horizontalement.
     Cause racine : les labels de variants ("Livraison seule | partout en
     France", "Livraison + montage | Île-de-France") sont trop longs et le
     bouton .isoore-pdph__variant n'avait ni max-width ni white-space:normal
     → la pilule s'étire au-delà du viewport mobile et pousse tout le grid.
     ============================================================ */

  /* Safety net : la section ne peut PAS déborder horizontalement */
  .isoore-pdph { overflow-x: clip; }

  /* Le container respecte strictement la largeur du viewport */
  .isoore-pdph__container { max-width: 100%; box-sizing: border-box; }

  /* Bouton ATC principal : box-sizing pour que width:100% + padding ne déborde pas */
  .isoore-pdph__atc { box-sizing: border-box; max-width: 100%; }

  /* Boutons variants (formules) : autorisent le wrap multi-ligne du texte */
  .isoore-pdph__variant {
    box-sizing: border-box;
    max-width: 100%;
    white-space: normal;
    word-break: break-word;
    text-align: center;
    line-height: 1.3;
  }

  /* Mobile : prix-row repasse en flex pour wrap propre (auto auto auto cassait sur 360px) */
  @media (max-width: 749px) {
    .isoore-pdph__price-row {
      display: flex;
      flex-wrap: wrap;
      column-gap: 12px;
      row-gap: 6px;
    }
    .isoore-pdph__price-strike,
    .isoore-pdph__price,
    .isoore-pdph__badge { max-width: 100%; }
    /* Description courte : ne déborde jamais, wrap propre */
    .isoore-pdph__lead { max-width: 100%; word-wrap: break-word; }
    /* Titre : safety wrap si jamais un mot très long arrive */
    .isoore-pdph__title { max-width: 100%; word-wrap: break-word; overflow-wrap: break-word; }
  }

  /* ============================================================
     FIX OVERFLOW MOBILE — PASSE 2 (edit23, 2026-05-23)
     Le 1er patch (overflow-x:clip + max-width:100% sur label) n'a pas
     suffi : le <label> en inline-flex a min-width:auto par défaut qui
     résiste au shrink en flexbox. Solution :
       1. Forcer min-width:0 sur tous les flex/grid children clés
       2. Sur mobile, les boutons formules passent en 1 PAR LIGNE
          (flex-direction:column + width:100%) — plus propre visuellement
          ET élimine tout risque d'overflow
       3. !important pour casser toute règle externe (isoore-home.css)
       4. overflow-x:hidden au lieu de clip (meilleure compat iOS Safari)
     ============================================================ */

  /* Override le clip (moins compatible) par hidden (universellement supporté) */
  .isoore-pdph { overflow-x: hidden !important; width: 100% !important; }

  /* Grid children : autoriser le shrink en dessous de leur min-content */
  .isoore-pdph__grid,
  .isoore-pdph__info,
  .isoore-pdph__gallery,
  .isoore-pdph__form { min-width: 0 !important; }

  @media (max-width: 749px) {
    /* Tout enfant respecte la largeur du viewport — safety net total */
    .isoore-pdph,
    .isoore-pdph * {
      max-width: 100% !important;
      box-sizing: border-box !important;
    }

    /* Boutons formules : 1 par ligne sur mobile (clean + zéro overflow) */
    .isoore-pdph__variants-row {
      flex-direction: column !important;
      align-items: stretch !important;
      gap: 10px !important;
    }
    .isoore-pdph__variant {
      width: 100% !important;
      justify-content: center !important;
      white-space: normal !important;
      word-break: break-word !important;
      text-align: center !important;
      line-height: 1.35 !important;
      padding: 14px 18px !important;
    }

    /* ATC principal : strict viewport-safe */
    .isoore-pdph__atc {
      width: 100% !important;
      max-width: 100% !important;
    }

    /* Container : padding garanti côté visuel */
    .isoore-pdph__container {
      width: 100% !important;
      max-width: 100% !important;
      padding-left: 20px !important;
      padding-right: 20px !important;
    }
  }
/* END_SECTION:isoore-pdp-hero */

/* START_SECTION:isoore-pergolas (INDEX:36) */
.isoore-pergolas { padding: 88px 56px; background: #F7F3EC; color: #3A5038; }
  .isoore-pergolas__inner { max-width: 1300px; margin: 0 auto; }
  .isoore-pergolas__header { text-align: center; margin-bottom: 40px; }
  .isoore-pergolas__heading { font-size: 32px; font-weight: 500; margin: 8px 0 8px; }
  .isoore-pergolas__subheading { font-size: 14px; opacity: 0.75; margin: 0; }
  .isoore-pergolas__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
  .isoore-pergola-card { background: #fff; border: 1.5px solid #E4DCC8; border-radius: 10px; overflow: hidden; transition: all 0.4s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1)); display: flex; flex-direction: column; }
  .isoore-pergola-card:hover { transform: translateY(-6px); box-shadow: 0 16px 36px rgba(58, 80, 56, 0.12); border-color: #7AAB72; }
  .isoore-pergola-card.is-featured { border: 2px solid #7AAB72; box-shadow: 0 12px 32px rgba(122, 171, 114, 0.2); }
  .isoore-pergola-card.is-featured:hover { box-shadow: 0 20px 44px rgba(122, 171, 114, 0.3); }
  .isoore-pergola-card__media { position: relative; aspect-ratio: 4/3; overflow: hidden; background: linear-gradient(135deg, #E4DCC8, #d8cfb8); }
  .isoore-pergola-card__image { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.6s var(--isoore-ease); }
  .isoore-pergola-card:hover .isoore-pergola-card__image { transform: scale(1.06); }
  .isoore-pergola-card__placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: #3A5038; opacity: 0.5; }
  .isoore-pergola-card__badge { position: absolute; top: 12px; right: 12px; padding: 5px 11px; font-size: 10px; font-weight: 600; border-radius: 4px; letter-spacing: 0.5px; text-transform: uppercase; z-index: 1; }
  .isoore-pergola-card__badge--dark { background: #3A5038; color: #F7F3EC; }
  .isoore-pergola-card__badge--green { background: #7AAB72; color: #fff; }
  .isoore-pergola-card__body { padding: 18px; display: flex; flex-direction: column; flex: 1; }
  .isoore-pergola-card__tag { display: inline-block; background: #3A5038; color: #F7F3EC; padding: 4px 9px; font-size: 10px; border-radius: 4px; margin-bottom: 8px; letter-spacing: 0.5px; text-transform: uppercase; font-weight: 600; align-self: flex-start; }
  .isoore-pergola-card__title { font-size: 16px; font-weight: 600; margin: 0 0 6px; }
  .isoore-pergola-card__desc { font-size: 13px; opacity: 0.75; margin: 0 0 14px; line-height: 1.5; }
  .isoore-pergola-card__features { list-style: none; margin: 0 0 16px; padding: 0; display: flex; flex-direction: column; gap: 6px; }
  .isoore-pergola-card__features li { display: flex; align-items: flex-start; gap: 8px; font-size: 12px; line-height: 1.4; opacity: 0.85; }
  .isoore-pergola-card__feature-icon { color: #7AAB72; font-weight: 700; flex-shrink: 0; }
  .isoore-pergola-card__pricing { margin-bottom: 14px; }
  .isoore-pergola-card__price { font-size: 22px; font-weight: 600; line-height: 1.1; }
  .isoore-pergola-card__price small { font-size: 12px; font-weight: 400; opacity: 0.7; }
  .isoore-pergola-card__price-detail { font-size: 12px; opacity: 0.7; margin-top: 3px; }
  .isoore-pergola-card__cta { display: flex; align-items: center; justify-content: center; gap: 6px; padding: 11px 0; background: #7AAB72; color: #fff; border-radius: 6px; font-size: 13px; font-weight: 500; text-decoration: none; margin-top: auto; transition: background 0.3s; }
  .isoore-pergola-card__cta:hover { background: #5d8a55; }
  .isoore-pergola-card__cta-arrow { display: inline-block; transition: transform 0.4s; }
  .isoore-pergola-card:hover .isoore-pergola-card__cta-arrow { transform: translateX(4px); }
  @media (max-width: 989px) {
    .isoore-pergolas { padding: 56px 0; }
    .isoore-pergolas__inner > .isoore-pergolas__header { padding: 0 24px; }
    .isoore-pergolas__grid {
      display: flex;
      grid-template-columns: none;
      overflow-x: auto;
      overflow-y: hidden;
      scroll-snap-type: x mandatory;
      -webkit-overflow-scrolling: touch;
      padding: 8px 24px 16px;
      gap: 14px;
      scrollbar-width: none;
      -ms-overflow-style: none;
    }
    .isoore-pergolas__grid::-webkit-scrollbar { display: none; }
    .isoore-pergola-card {
      flex: 0 0 85%;
      max-width: 320px;
      scroll-snap-align: center;
    }
    .isoore-pergola-card.is-featured {
      flex: 0 0 88%;
      max-width: 340px;
    }
  }
/* END_SECTION:isoore-pergolas */

/* START_SECTION:isoore-pillars (INDEX:37) */
.isoore-pillars {
    padding: 88px 56px;
    background: var(--color-background);
    color: var(--color-foreground);
  }

  .isoore-pillars__inner {
    max-width: var(--isoore-container-max, 1300px);
    margin: 0 auto;
  }

  .isoore-pillars__head {
    text-align: center;
    margin-bottom: 40px;
  }

  .isoore-pillars__heading {
    font-size: clamp(26px, 3vw, 32px);
    font-weight: 500;
    line-height: 1.18;
    letter-spacing: -0.5px;
    margin: 8px 0 0;
    color: var(--isoore-text, #3A5038);
  }

  .isoore-pillars__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
  }

  .isoore-pillar__number {
    font-size: 11px;
    letter-spacing: 2px;
    color: var(--isoore-cta, #7AAB72);
    margin-bottom: 10px;
    font-weight: 600;
  }

  .isoore-pillar__title {
    font-size: 18px;
    font-weight: 600;
    margin: 0 0 12px;
    color: var(--isoore-text, #3A5038);
  }

  .isoore-pillar__desc {
    font-size: 13px;
    line-height: 1.7;
    opacity: 0.85;
  }

  @media (max-width: 989px) {
    .isoore-pillars { padding: 56px 24px; }
    .isoore-pillars__grid { grid-template-columns: 1fr; gap: 28px; }
  }
/* END_SECTION:isoore-pillars */

/* START_SECTION:isoore-policy-page (INDEX:38) */
:root {
    --policy-paper: #F4F0E6;
    --policy-paper-light: #FAF7EE;
    --policy-paper-deep: #E8E2D3;
    --policy-ink: #0E0E0C;
    --policy-ink-soft: #5C5A55;
    --policy-ink-faint: #9A968D;
    --policy-line: rgba(14, 14, 12, 0.12);
    --policy-line-soft: rgba(14, 14, 12, 0.06);
    --policy-accent: #2D3E2B;
    --policy-sans: 'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;
    --policy-mono: 'DM Mono', ui-monospace, monospace;
    --policy-ease: cubic-bezier(0.16, 1, 0.3, 1);
  }

  @import url('https://fonts.googleapis.com/css2?family=Manrope:wght@200;300;400;500;600;700&family=DM+Mono:wght@300;400;500&display=swap');

  /* ============== HIDE FULLSTACK AUTO TITLE + EXTEND PAPER BG ============== */
  /* Cacher tout titre h1 généré automatiquement par le thème Fullstack
     AVANT notre section custom (sur les pages où elle est utilisée). */
  body:has(.isoore-policy-section) main > h1:not(.isoore-policy__title),
  body:has(.isoore-policy-section) main > div > h1:not(.isoore-policy__title):first-child,
  body:has(.isoore-policy-section) main > section:first-child > h1:not(.isoore-policy__title),
  body:has(.isoore-policy-section) .shopify-policy__title,
  body:has(.isoore-policy-section) .policy__title,
  body:has(.isoore-policy-section) .policy-section__title,
  body:has(.isoore-policy-section) .main-page__title,
  body:has(.isoore-policy-section) .page__title,
  body:has(.isoore-policy-section) .main-content > .page-header,
  body:has(.isoore-policy-section) .main-content > h1:first-child,
  body:has(.isoore-policy-section) section.main-page > h1:first-child {
    display: none !important;
  }
  /* Étendre le background paper sur tout le main + retirer le padding par défaut */
  body:has(.isoore-policy-section) main,
  body:has(.isoore-policy-section) .main-content,
  body:has(.isoore-policy-section) main.main-content {
    background: #F4F0E6 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    margin-top: 0 !important;
  }

  .isoore-policy {
    background: var(--policy-paper);
    color: var(--policy-ink);
    font-family: var(--policy-sans);
    font-weight: 300;
    padding: 200px 0 96px;
    min-height: 100vh;
  }
  @media (max-width: 749px) {
    .isoore-policy { padding: 150px 0 64px; }
  }

  .isoore-policy__container {
    max-width: 760px;
    margin: 0 auto;
    padding: 0 24px;
  }
  @media (max-width: 749px) {
    .isoore-policy__container { padding: 0 24px; }
  }

  /* ============== HEADER ============== */
  .isoore-policy__header {
    margin: 0 0 64px;
    text-align: left;
  }
  @media (max-width: 749px) {
    .isoore-policy__header { margin-bottom: 40px; }
  }

  .isoore-policy__breadcrumb {
    display: inline-block;
    font-family: var(--policy-mono);
    font-size: 11px;
    font-weight: 400;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--policy-ink-soft);
    margin-bottom: 20px;
  }

  .isoore-policy__title {
    font-family: var(--policy-sans);
    font-size: clamp(32px, 5vw, 56px);
    font-weight: 500;
    line-height: 1.05;
    letter-spacing: -0.02em;
    margin: 0 0 24px;
    color: var(--policy-ink);
  }

  .isoore-policy__subtitle {
    font-size: clamp(16px, 1.5vw, 18px);
    font-weight: 300;
    line-height: 1.55;
    color: var(--policy-ink-soft);
    margin: 0 0 32px;
    max-width: 640px;
  }

  .isoore-policy__meta {
    font-family: var(--policy-mono);
    font-size: 12px;
    font-weight: 400;
    letter-spacing: 0.04em;
    color: var(--policy-ink-faint);
    margin: 0;
    padding-top: 24px;
    border-top: 1px solid var(--policy-line-soft);
  }
  .isoore-policy__meta-sep { margin: 0 8px; opacity: 0.5; }

  /* ============== ARTICLE CONTENU ============== */
  .isoore-policy__content {
    font-size: 16px;
    line-height: 1.75;
    color: var(--policy-ink);
  }

  /* Rich text styling */
  .isoore-policy__content > * + * { margin-top: 1.2em; }
  .isoore-policy__content h2 {
    font-family: var(--policy-sans);
    font-size: clamp(22px, 2.5vw, 28px);
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: -0.01em;
    color: var(--policy-ink);
    margin: 64px 0 20px;
    padding-top: 32px;
    border-top: 1px solid var(--policy-line-soft);
    scroll-margin-top: 110px;
  }
  .isoore-policy__content > h2:first-child {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
  }
  .isoore-policy__content h3 {
    font-family: var(--policy-sans);
    font-size: clamp(17px, 1.8vw, 20px);
    font-weight: 500;
    line-height: 1.3;
    color: var(--policy-ink);
    margin: 32px 0 12px;
    scroll-margin-top: 110px;
  }
  .isoore-policy__content h4 {
    font-family: var(--policy-mono);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--policy-ink-soft);
    margin: 24px 0 8px;
  }
  .isoore-policy__content p {
    margin: 0;
  }
  .isoore-policy__content a {
    color: var(--policy-accent);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
    transition: opacity 0.2s var(--policy-ease);
  }
  .isoore-policy__content a:hover { opacity: 0.7; }
  .isoore-policy__content strong { font-weight: 600; color: var(--policy-ink); }
  .isoore-policy__content em { font-style: italic; color: var(--policy-ink-soft); }

  .isoore-policy__content ul,
  .isoore-policy__content ol {
    margin: 16px 0;
    padding-left: 24px;
  }
  .isoore-policy__content li {
    margin: 8px 0;
    line-height: 1.7;
  }
  .isoore-policy__content li > ul,
  .isoore-policy__content li > ol {
    margin: 8px 0;
  }

  .isoore-policy__content blockquote {
    margin: 32px 0;
    padding: 20px 28px;
    background: var(--policy-paper-light);
    border-left: 3px solid var(--policy-accent);
    border-radius: 0 6px 6px 0;
    font-style: italic;
    color: var(--policy-ink-soft);
  }
  .isoore-policy__content blockquote p { margin: 0; }

  .isoore-policy__content hr {
    border: none;
    height: 1px;
    background: var(--policy-line);
    margin: 48px 0;
  }

  .isoore-policy__content table {
    width: 100%;
    border-collapse: collapse;
    margin: 24px 0;
    font-size: 14px;
  }
  .isoore-policy__content th,
  .isoore-policy__content td {
    padding: 12px 16px;
    text-align: left;
    border-bottom: 1px solid var(--policy-line-soft);
  }
  .isoore-policy__content th {
    font-family: var(--policy-mono);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--policy-ink-soft);
    border-bottom: 1px solid var(--policy-line);
  }

  .isoore-policy__content code {
    font-family: var(--policy-mono);
    font-size: 13px;
    background: var(--policy-paper-deep);
    padding: 2px 6px;
    border-radius: 3px;
    color: var(--policy-ink);
  }

  /* ============== FOOTER ============== */
  .isoore-policy__footer {
    margin-top: 96px;
    padding-top: 32px;
    border-top: 1px solid var(--policy-line-soft);
    text-align: center;
    color: var(--policy-ink-soft);
    font-size: 14px;
  }
  .isoore-policy__footer p { margin: 8px 0; }
  .isoore-policy__footer a {
    color: var(--policy-accent);
    text-decoration: underline;
    text-underline-offset: 3px;
  }
  .isoore-policy__footer-link a {
    font-family: var(--policy-mono);
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }
/* END_SECTION:isoore-policy-page */

/* START_SECTION:isoore-product-3dview (INDEX:39) */
.isoore-3d {
    background: linear-gradient(180deg, var(--isoore-bg, #F4F0E6) 0%, #F0EBE0 100%);
    color: var(--isoore-text, #0E0E0C);
    padding: var(--isoore-section-pad, 88px) 0;
    overflow: hidden;
  }
  .isoore-3d__container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 56px;
  }
  .isoore-3d__header {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 56px;
  }
  .isoore-3d__title {
    margin: 12px 0 14px;
    font-size: clamp(28px, 3.4vw, 42px);
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -0.5px;
    color: var(--isoore-dark, #0E0E0C);
  }
  .isoore-3d__subtitle {
    margin: 0;
    font-size: 16px;
    line-height: 1.65;
    opacity: 0.85;
  }

  .isoore-3d__stage {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
    gap: 48px;
    align-items: center;
  }

  /* Viewport Three.js */
  .isoore-3d__viewport {
    position: relative;
    aspect-ratio: 5 / 4;
    border-radius: var(--isoore-radius-lg, 12px);
    background: radial-gradient(ellipse at center 70%, #E8E2D3 0%, #D4CFC0 100%);
    overflow: hidden;
    box-shadow: 0 18px 48px rgba(45, 62, 43, 0.15);
    cursor: grab;
    user-select: none;
  }
  .isoore-3d__viewport:active { cursor: grabbing; }
  .isoore-3d__canvas {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
  }

  /* Loading dots */
  .isoore-3d__loading {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    gap: 8px;
    z-index: 4;
  }
  .isoore-3d__loading-dot {
    width: 10px; height: 10px;
    border-radius: 50%;
    background: var(--isoore-cta, #2D3E2B);
    animation: isoore-3d-load 1.2s ease-in-out infinite;
  }
  .isoore-3d__loading-dot:nth-child(2) { animation-delay: 0.15s; }
  .isoore-3d__loading-dot:nth-child(3) { animation-delay: 0.3s; }
  @keyframes isoore-3d-load {
    0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
    40% { transform: scale(1.1); opacity: 1; }
  }
  .isoore-3d__viewport.is-loaded .isoore-3d__loading { opacity: 0; pointer-events: none; transition: opacity 0.3s; }

  /* Hotspots */
  .isoore-3d__hotspot {
    position: absolute;
    left: 0; top: 0;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    z-index: 5;
    transform: translate(-50%, -50%);
    transition: opacity 0.25s var(--isoore-ease);
  }
  .isoore-3d__hotspot.is-occluded {
    opacity: 0.3;
    pointer-events: none;
  }
  .isoore-3d__hotspot-dot {
    display: block;
    width: 20px; height: 20px;
    border-radius: 50%;
    background: var(--isoore-cta, #2D3E2B);
    border: 3px solid #fff;
    box-shadow: 0 0 0 4px rgba(45, 62, 43, 0.3), 0 4px 14px rgba(0, 0, 0, 0.3);
    position: relative;
    transition: transform 0.25s var(--isoore-ease);
  }
  .isoore-3d__hotspot-dot::after {
    content: '';
    position: absolute; inset: -8px;
    border-radius: 50%;
    border: 2px solid rgba(45, 62, 43, 0.5);
    animation: isoore-3d-pulse 2.2s ease-out infinite;
  }
  @keyframes isoore-3d-pulse {
    0% { transform: scale(0.6); opacity: 1; }
    100% { transform: scale(2); opacity: 0; }
  }
  .isoore-3d__hotspot-label {
    position: absolute;
    left: 28px;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(45, 62, 43, 0.95);
    color: #F4F0E6;
    padding: 5px 12px;
    border-radius: 999px;
    font-size: 11.5px;
    font-weight: 500;
    letter-spacing: 0.5px;
    white-space: nowrap;
    opacity: 0;
    transition: opacity 0.2s var(--isoore-ease);
    pointer-events: none;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
  }
  .isoore-3d__hotspot:hover .isoore-3d__hotspot-label,
  .isoore-3d__hotspot.is-active .isoore-3d__hotspot-label { opacity: 1; }
  .isoore-3d__hotspot.is-active .isoore-3d__hotspot-dot {
    background: #fff;
    border-color: var(--isoore-cta, #2D3E2B);
    transform: scale(1.2);
  }
  .isoore-3d__hotspot.is-active .isoore-3d__hotspot-dot::after { animation: none; opacity: 0; }
  .isoore-3d__hotspot:hover .isoore-3d__hotspot-dot { transform: scale(1.15); }

  /* Controles */
  .isoore-3d__controls {
    position: absolute;
    bottom: 18px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 6px;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    padding: 6px;
    border-radius: 999px;
    box-shadow: 0 6px 20px rgba(45, 62, 43, 0.18);
    z-index: 6;
  }
  .isoore-3d__ctrl {
    width: 38px; height: 38px;
    border-radius: 50%;
    border: none;
    background: transparent;
    color: var(--isoore-dark, #0E0E0C);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s, color 0.2s;
  }
  .isoore-3d__ctrl:hover { background: rgba(45, 62, 43, 0.18); }
  .isoore-3d__ctrl svg { width: 18px; height: 18px; }
  .isoore-3d__ctrl.is-primary {
    background: var(--isoore-cta, #2D3E2B);
    color: #fff;
  }
  .isoore-3d__ctrl.is-primary:hover { background: var(--isoore-dark, #0E0E0C); }
  .isoore-3d__ctrl-pause { display: none; }
  .isoore-3d__ctrl.is-playing .isoore-3d__ctrl-play { display: none; }
  .isoore-3d__ctrl.is-playing .isoore-3d__ctrl-pause { display: block; }

  .isoore-3d__drag-hint {
    position: absolute;
    top: 18px; left: 50%;
    transform: translateX(-50%);
    margin: 0;
    background: rgba(255, 255, 255, 0.92);
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 11.5px;
    letter-spacing: 0.3px;
    color: var(--isoore-text);
    pointer-events: none;
    opacity: 0.9;
    z-index: 6;
    box-shadow: 0 2px 8px rgba(45, 62, 43, 0.1);
  }

  /* Panneau details (identique a avant) */
  .isoore-3d__panel { position: relative; min-height: 360px; }
  .isoore-3d__detail {
    display: none;
    animation: isoore-3d-detail-in 0.4s var(--isoore-ease);
  }
  .isoore-3d__detail.is-active { display: block; }
  @keyframes isoore-3d-detail-in {
    from { opacity: 0; transform: translateX(20px); }
    to   { opacity: 1; transform: translateX(0); }
  }
  .isoore-3d__detail-tag {
    display: inline-block;
    font-size: 11px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--isoore-cta, #2D3E2B);
    margin-bottom: 14px;
    font-weight: 500;
  }
  .isoore-3d__detail h3 {
    margin: 0 0 14px;
    font-size: 26px;
    font-weight: 500;
    line-height: 1.2;
    color: var(--isoore-dark);
    letter-spacing: -0.3px;
  }
  .isoore-3d__detail p {
    margin: 0 0 22px;
    font-size: 15px;
    line-height: 1.65;
    color: var(--isoore-text);
    opacity: 0.88;
  }
  .isoore-3d__detail-specs {
    list-style: none;
    margin: 0;
    padding: 0;
    border-top: 1px solid var(--isoore-border, #E8E2D3);
  }
  .isoore-3d__detail-specs li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px solid var(--isoore-border);
    font-size: 13.5px;
  }
  .isoore-3d__detail-specs li span {
    color: var(--isoore-text);
    opacity: 0.7;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    font-size: 11px;
  }
  .isoore-3d__detail-specs li strong {
    color: var(--isoore-dark);
    font-weight: 600;
    text-align: right;
  }

  /* Desktop par défaut : on cache la variante mobile */
  .isoore-3d__drag-hint-mobile { display: none; }

  /* Responsive */
  @media (max-width: 989px) {
    .isoore-3d__container { padding: 0 24px; }
    .isoore-3d__stage { grid-template-columns: 1fr; gap: 32px; }
    .isoore-3d__viewport { aspect-ratio: 1 / 1; }
    .isoore-3d__detail h3 { font-size: 22px; }
    .isoore-3d__hotspot-label { display: none; }
    /* Hint compact mobile : texte court + taille réduite */
    .isoore-3d__drag-hint {
      font-size: 10px;
      padding: 4px 10px;
      top: 10px;
      letter-spacing: 0.2px;
    }
    .isoore-3d__drag-hint-desktop { display: none; }
    .isoore-3d__drag-hint-mobile { display: inline; }
  }
/* END_SECTION:isoore-product-3dview */

/* START_SECTION:isoore-product-ambiances (INDEX:40) */
.isoore-ambiances {
    background: var(--isoore-bg, #F7F3EC);
    color: var(--isoore-text, #3A5038);
    padding: var(--isoore-section-pad, 88px) 0;
  }
  .isoore-ambiances__container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 56px;
  }
  .isoore-ambiances__header {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 48px;
  }
  .isoore-ambiances__title {
    margin: 12px 0 14px;
    font-size: clamp(28px, 3.4vw, 42px);
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -0.5px;
    color: var(--isoore-dark, #3A5038);
  }
  .isoore-ambiances__subtitle {
    margin: 0;
    font-size: 16px;
    line-height: 1.65;
    color: var(--isoore-text, #3A5038);
    opacity: 0.85;
  }

  /* ===== Comparateur ===== */
  .isoore-ambiances__compare-frame {
    position: relative;
    aspect-ratio: 16 / 9;
    border-radius: var(--isoore-radius-lg, 12px);
    overflow: hidden;
    background: #d8d2c0;
    box-shadow: 0 18px 48px rgba(45, 62, 43, 0.18);
    user-select: none;
    touch-action: pan-y pinch-zoom;
  }
  .isoore-ambiances__compare-img {
    position: absolute;
    inset: 0;
  }
  .isoore-ambiances__compare-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .isoore-ambiances__compare-img--after {
    clip-path: inset(0 0 0 var(--compare-pos, 50%));
    transition: clip-path 0.05s linear;
  }
  .isoore-ambiances__compare-tag {
    position: absolute;
    top: 18px;
    padding: 6px 14px;
    background: rgba(247, 243, 236, 0.92);
    color: var(--isoore-dark, #3A5038);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    border-radius: 999px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }
  .isoore-ambiances__compare-tag--before { left: 18px; }
  .isoore-ambiances__compare-tag--after { right: 18px; background: var(--isoore-cta, #7AAB72); color: #fff; }

  /* Placeholders (avant photos reelles) */
  .isoore-ambiances__placeholder {
    width: 100%;
    height: 100%;
  }
  .isoore-ambiances__placeholder--before {
    background:
      linear-gradient(180deg, #b9c5cc 0%, #d4c8a8 60%, #a89a78 100%);
    position: relative;
  }
  .isoore-ambiances__placeholder--before::after {
    content: 'Terrasse nue';
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    color: #fff;
    font-size: 14px;
    letter-spacing: 2px;
    text-transform: uppercase;
    text-shadow: 0 2px 8px rgba(0,0,0,0.3);
    opacity: 0.7;
  }
  .isoore-ambiances__placeholder--after {
    background:
      linear-gradient(180deg, #94b5cc 0%, #b8c5a8 50%, #6d8868 100%);
    position: relative;
  }
  .isoore-ambiances__placeholder--after::before {
    content: '';
    position: absolute;
    left: 18%; right: 18%; top: 30%; height: 18%;
    background:
      repeating-linear-gradient(0deg, #2D3E2B 0 4px, transparent 4px 10px),
      linear-gradient(180deg, #3A5038, #2D3E2B);
    border-radius: 4px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.3);
  }
  .isoore-ambiances__placeholder--after::after {
    content: 'Avec pergola Isoore';
    position: absolute;
    top: 60%; left: 50%;
    transform: translate(-50%, 0);
    color: #fff;
    font-size: 14px;
    letter-spacing: 2px;
    text-transform: uppercase;
    text-shadow: 0 2px 8px rgba(0,0,0,0.3);
    opacity: 0.85;
  }

  /* Poignee */
  .isoore-ambiances__compare-handle {
    position: absolute;
    top: 0; bottom: 0;
    left: var(--compare-pos, 50%);
    width: 4px;
    background: rgba(247, 243, 236, 0.95);
    box-shadow: 0 0 0 1px rgba(45, 62, 43, 0.2), 0 4px 12px rgba(0, 0, 0, 0.18);
    cursor: ew-resize;
    transform: translateX(-50%);
    transition: left 0.05s linear;
  }
  .isoore-ambiances__compare-line {
    position: absolute;
    inset: 0;
  }
  .isoore-ambiances__compare-knob {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: #fff;
    border: 2px solid var(--isoore-cta, #7AAB72);
    color: var(--isoore-dark, #3A5038);
    cursor: ew-resize;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 18px rgba(45, 62, 43, 0.28);
    transition: transform 0.2s var(--isoore-ease), box-shadow 0.2s var(--isoore-ease);
  }
  .isoore-ambiances__compare-knob:hover { transform: translate(-50%, -50%) scale(1.08); box-shadow: 0 10px 24px rgba(45, 62, 43, 0.36); }
  .isoore-ambiances__compare-knob:active { cursor: grabbing; }
  .isoore-ambiances__compare-knob svg { width: 22px; height: 22px; }
  .isoore-ambiances__compare-hint {
    margin: 14px 0 0;
    text-align: center;
    font-size: 12.5px;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--isoore-text, #3A5038);
    opacity: 0.6;
  }

  /* ===== Picker d'ambiances ===== */
  .isoore-ambiances__picker { margin-top: 48px; }
  .isoore-ambiances__picker-label {
    margin: 0 0 16px;
    text-align: center;
    font-size: 12px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--isoore-text);
    opacity: 0.7;
  }
  .isoore-ambiances__picker-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 14px;
    max-width: 720px;
    margin: 0 auto;
  }
  .isoore-ambiances__picker-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 10px 10px 14px;
    border: 1.5px solid var(--isoore-border, #E4DCC8);
    border-radius: var(--isoore-radius-md, 8px);
    background: #fff;
    color: var(--isoore-text);
    cursor: pointer;
    transition: transform 0.25s var(--isoore-ease), border-color 0.25s var(--isoore-ease), box-shadow 0.25s var(--isoore-ease);
  }
  .isoore-ambiances__picker-item:hover {
    transform: translateY(-3px);
    border-color: var(--isoore-cta, #7AAB72);
    box-shadow: 0 8px 20px rgba(45, 62, 43, 0.12);
  }
  .isoore-ambiances__picker-item.is-active {
    border-color: var(--isoore-cta, #7AAB72);
    background: rgba(122, 171, 114, 0.08);
    box-shadow: 0 0 0 3px rgba(122, 171, 114, 0.18);
  }
  .isoore-ambiances__picker-thumb {
    width: 100%;
    aspect-ratio: 4 / 3;
    border-radius: 6px;
    overflow: hidden;
    background: #e4dcc8;
  }
  .isoore-ambiances__picker-thumb img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
  }
  .isoore-ambiances__picker-thumb-placeholder {
    display: block;
    width: 100%; height: 100%;
    background: linear-gradient(135deg, #b8c5a8 0%, #7AAB72 100%);
  }
  .isoore-ambiances__picker-name {
    font-size: 13px;
    font-weight: 500;
    text-align: center;
  }

  /* Fade transition on image swap */
  .isoore-ambiances__compare-frame.is-swapping .isoore-ambiances__compare-img { opacity: 0; transition: opacity 0.25s var(--isoore-ease); }
  .isoore-ambiances__compare-frame.is-swapped .isoore-ambiances__compare-img { opacity: 1; transition: opacity 0.35s var(--isoore-ease); }

  /* Responsive */
  @media (max-width: 989px) {
    .isoore-ambiances__container { padding: 0 24px; }
    .isoore-ambiances__compare-frame { aspect-ratio: 4 / 3; }
    .isoore-ambiances__compare-knob { width: 46px; height: 46px; }
    .isoore-ambiances__picker-grid { grid-template-columns: repeat(2, 1fr); max-width: 360px; }
  }

  @media (prefers-reduced-motion: reduce) {
    .isoore-ambiances__picker-item:hover { transform: none !important; }
    .isoore-ambiances__compare-knob:hover { transform: translate(-50%, -50%) !important; }
  }
/* END_SECTION:isoore-product-ambiances */

/* START_SECTION:isoore-product-blueprint (INDEX:41) */
.isoore-plan {
    background: linear-gradient(180deg, #ffffff 0%, var(--isoore-bg, #F4F0E6) 100%);
    color: var(--isoore-text, #0E0E0C);
    padding: var(--isoore-section-pad, 88px) 0;
  }
  .isoore-plan__container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 56px;
  }
  .isoore-plan__header {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 48px;
  }
  .isoore-plan__title {
    margin: 12px 0 14px;
    font-size: clamp(28px, 3.4vw, 42px);
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -0.5px;
    color: var(--isoore-dark, #0E0E0C);
  }
  .isoore-plan__subtitle {
    margin: 0;
    font-size: 16px;
    line-height: 1.65;
    opacity: 0.85;
  }

  .isoore-plan__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(0, 1fr);
    gap: 56px;
    align-items: start;
    background: #fff;
    border: 1px solid var(--isoore-border, #E8E2D3);
    border-radius: var(--isoore-radius-lg, 12px);
    padding: 36px;
    box-shadow: 0 18px 48px rgba(45, 62, 43, 0.08);
  }

  /* Tabs */
  .isoore-plan__tabs {
    grid-column: 1 / -1;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 8px;
    padding-bottom: 18px;
    border-bottom: 1px solid var(--isoore-border, #E8E2D3);
  }
  .isoore-plan__tab {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: transparent;
    border: 1px solid var(--isoore-border, #E8E2D3);
    color: var(--isoore-text);
    font-size: 13px;
    font-weight: 500;
    padding: 10px 16px;
    border-radius: var(--isoore-radius-md, 8px);
    cursor: pointer;
    transition: all 0.22s var(--isoore-ease);
  }
  .isoore-plan__tab:hover {
    background: rgba(45, 62, 43, 0.06);
    border-color: rgba(45, 62, 43, 0.3);
  }
  .isoore-plan__tab.is-active {
    background: var(--isoore-cta, #2D3E2B);
    color: #fff;
    border-color: var(--isoore-cta, #2D3E2B);
    font-weight: 600;
  }
  .isoore-plan__tab-icon { display: inline-flex; }
  .isoore-plan__tab-icon svg { width: 18px; height: 18px; }

  /* Viewport Three.js + grid blueprint background */
  .isoore-plan__viewport {
    position: relative;
    aspect-ratio: 600 / 460;
    background:
      linear-gradient(rgba(14, 14, 12, 0.04) 1px, transparent 1px),
      linear-gradient(90deg, rgba(14, 14, 12, 0.04) 1px, transparent 1px),
      linear-gradient(180deg, #FAF7EE 0%, #F4F0E6 100%);
    background-size: 20px 20px, 20px 20px, 100% 100%;
    border: 1px solid var(--isoore-border, #E8E2D3);
    border-radius: var(--isoore-radius-md, 8px);
    overflow: hidden;
  }
  .isoore-plan__canvas {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
  }

  /* Loading */
  .isoore-plan__loading {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    gap: 8px;
    z-index: 4;
  }
  .isoore-plan__loading span {
    width: 10px; height: 10px;
    border-radius: 50%;
    background: var(--isoore-cta, #2D3E2B);
    animation: isoore-plan-load 1.2s ease-in-out infinite;
  }
  .isoore-plan__loading span:nth-child(2) { animation-delay: 0.15s; }
  .isoore-plan__loading span:nth-child(3) { animation-delay: 0.3s; }
  @keyframes isoore-plan-load {
    0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
    40% { transform: scale(1.1); opacity: 1; }
  }
  .isoore-plan__viewport.is-loaded .isoore-plan__loading { opacity: 0; pointer-events: none; transition: opacity 0.3s; }

  /* Cotes overlay */
  .isoore-plan__cote {
    position: absolute;
    left: 0; top: 0;
    z-index: 6;
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    border: 1.5px solid var(--isoore-cta, #2D3E2B);
    border-radius: 6px;
    padding: 5px 11px;
    font-size: 12.5px;
    font-weight: 700;
    color: var(--isoore-cta, #2D3E2B);
    letter-spacing: 0.2px;
    white-space: nowrap;
    pointer-events: none;
    transform: translate(-50%, -50%);
    box-shadow: 0 3px 10px rgba(45, 62, 43, 0.08);
    opacity: 0;
    transition: opacity 0.3s var(--isoore-ease);
  }
  .isoore-plan__cote.is-visible { opacity: 1; }
  .isoore-plan__cote--minor {
    border-width: 1px;
    padding: 4px 9px;
    font-size: 11px;
  }
  .isoore-plan__cote--minor .isoore-plan__cote-val { font-weight: 600; }
  .isoore-plan__cote-meta {
    display: block;
    font-size: 9.5px;
    font-weight: 500;
    opacity: 0.7;
    letter-spacing: 0;
    text-transform: uppercase;
    margin-top: 1px;
  }

  /* Indicateur vue active */
  .isoore-plan__view-label {
    position: absolute;
    bottom: 14px;
    right: 18px;
    font-size: 10.5px;
    letter-spacing: 2.5px;
    font-weight: 600;
    color: var(--isoore-dark, #0E0E0C);
    opacity: 0.45;
    z-index: 5;
    pointer-events: none;
  }

  .isoore-plan__hint {
    position: absolute;
    top: 14px;
    left: 50%;
    transform: translateX(-50%);
    margin: 0;
    background: rgba(255, 255, 255, 0.85);
    padding: 5px 13px;
    border-radius: 999px;
    font-size: 11px;
    color: var(--isoore-text);
    opacity: 0.7;
    z-index: 5;
    pointer-events: none;
    white-space: nowrap;
  }

  /* Data table */
  .isoore-plan__data {
    align-self: start;
    position: sticky;
    top: max(90px, 12vh);
  }
  .isoore-plan__data-title {
    margin: 0 0 16px;
    font-size: 12px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--isoore-text);
    opacity: 0.7;
    font-weight: 500;
  }
  .isoore-plan__table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
    margin-bottom: 20px;
  }
  .isoore-plan__table tr {
    border-bottom: 1px solid var(--isoore-border, #E8E2D3);
  }
  .isoore-plan__table th, .isoore-plan__table td {
    padding: 11px 0;
    text-align: left;
    vertical-align: top;
  }
  .isoore-plan__table th {
    font-weight: 500;
    color: var(--isoore-text);
    opacity: 0.85;
    width: 50%;
    padding-right: 10px;
  }
  .isoore-plan__table td {
    color: var(--isoore-dark);
    font-weight: 600;
    text-align: right;
  }
  .isoore-plan__table em {
    font-style: normal;
    font-size: 10.5px;
    color: var(--isoore-text);
    opacity: 0.65;
    font-weight: 400;
    margin-left: 4px;
  }

  /* PDF button */
  .isoore-plan__pdf {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--isoore-dark, #0E0E0C);
    color: #fff;
    padding: 12px 20px;
    border-radius: var(--isoore-radius-md, 8px);
    text-decoration: none;
    font-size: 13px;
    font-weight: 600;
    transition: all 0.22s var(--isoore-ease);
    border: none;
    cursor: pointer;
  }
  .isoore-plan__pdf:hover {
    background: var(--isoore-darker, #2D3E2B);
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(45, 62, 43, 0.3);
  }
  .isoore-plan__pdf svg { width: 18px; height: 18px; }
  .isoore-plan__pdf--ghost {
    background: transparent;
    color: var(--isoore-dark);
    border: 1.5px dashed var(--isoore-border, #E8E2D3);
  }
  .isoore-plan__pdf--ghost:hover {
    background: rgba(45, 62, 43, 0.06);
    border-color: var(--isoore-cta);
    color: var(--isoore-dark);
    box-shadow: none;
  }

  @media (max-width: 989px) {
    .isoore-plan__container { padding: 0 18px; }
    .isoore-plan__layout { grid-template-columns: 1fr; gap: 24px; padding: 20px; }
    .isoore-plan__data { position: relative; top: 0; }
    .isoore-plan__tab { font-size: 11.5px; padding: 8px 10px; gap: 6px; }
    .isoore-plan__tab-icon svg { width: 15px; height: 15px; }
    .isoore-plan__viewport { aspect-ratio: 1 / 1; }
    .isoore-plan__cote { font-size: 10.5px; padding: 4px 8px; }
    .isoore-plan__title { font-size: 24px; }
    .isoore-plan__subtitle { font-size: 14.5px; }
  }
/* END_SECTION:isoore-product-blueprint */

/* START_SECTION:isoore-product-call-before (INDEX:42) */
.isoore-callb {
    background: var(--isoore-bg, #F4F0E6);
    padding: var(--isoore-section-pad, 88px) 0;
  }
  .isoore-callb__container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 56px;
  }
  .isoore-callb__panel {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
    gap: 56px;
    align-items: center;
    background: linear-gradient(135deg, var(--isoore-darker, #2D3E2B) 0%, var(--isoore-dark, #0E0E0C) 100%);
    color: #F4F0E6;
    border-radius: var(--isoore-radius-lg, 12px);
    padding: 56px 56px;
    overflow: hidden;
    position: relative;
  }
  .isoore-callb__panel::before {
    content: '';
    position: absolute;
    top: -50%; right: -20%;
    width: 60%; height: 200%;
    background: radial-gradient(circle, rgba(45, 62, 43, 0.18) 0%, transparent 60%);
    pointer-events: none;
  }

  .isoore-callb__left { position: relative; z-index: 2; }
  .isoore-callb__kicker {
    color: rgba(244, 240, 230, 0.7);
    opacity: 1;
  }
  .isoore-callb__kicker::before { background: #F4F0E6; }
  .isoore-callb__title {
    margin: 12px 0 16px;
    font-size: clamp(28px, 3.4vw, 40px);
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -0.5px;
    color: #F4F0E6;
  }
  .isoore-callb__subtitle {
    margin: 0 0 28px;
    font-size: 16px;
    line-height: 1.65;
    color: rgba(244, 240, 230, 0.88);
  }

  .isoore-callb__benefits {
    list-style: none;
    margin: 0 0 32px;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
  }
  .isoore-callb__benefits li {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    font-size: 14px;
    line-height: 1.55;
    color: rgba(244, 240, 230, 0.92);
  }
  .isoore-callb__benefits strong { color: #fff; }
  .isoore-callb__check {
    flex-shrink: 0;
    width: 24px; height: 24px;
    border-radius: 50%;
    background: var(--isoore-cta, #2D3E2B);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 13px;
    margin-top: 1px;
  }

  .isoore-callb__cta-row {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 16px;
  }
  .isoore-callb__cta {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    background: var(--isoore-cta, #2D3E2B);
    color: #fff;
    padding: 16px 24px;
    border-radius: var(--isoore-radius-md, 8px);
    text-decoration: none;
    font-weight: 600;
    transition: transform 0.22s var(--isoore-ease), box-shadow 0.22s var(--isoore-ease);
  }
  .isoore-callb__cta:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 28px rgba(45, 62, 43, 0.4);
  }
  .isoore-callb__cta svg { width: 26px; height: 26px; }
  .isoore-callb__cta strong { display: block; font-size: 15px; }
  .isoore-callb__cta em { display: block; font-size: 11.5px; font-style: normal; opacity: 0.85; }

  .isoore-callb__cta-info {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: rgba(244, 240, 230, 0.7);
    font-size: 13px;
    line-height: 1.4;
    padding: 8px 4px;
  }
  .isoore-callb__cta-info svg { width: 18px; height: 18px; flex-shrink: 0; opacity: 0.8; }

  .isoore-callb__hours {
    margin: 0;
    font-size: 12px;
    color: rgba(244, 240, 230, 0.6);
    letter-spacing: 0.5px;
  }

  /* Card droite */
  .isoore-callb__right { position: relative; z-index: 2; }
  .isoore-callb__card {
    background: #F4F0E6;
    color: var(--isoore-text);
    padding: 28px 26px;
    border-radius: var(--isoore-radius-md, 8px);
    box-shadow: 0 22px 48px rgba(0, 0, 0, 0.18);
    position: relative;
  }
  .isoore-callb__avatar {
    width: 64px; height: 64px;
    border-radius: 50%;
    overflow: hidden;
    margin-bottom: 14px;
    position: relative;
    box-shadow: 0 4px 14px rgba(45, 62, 43, 0.18);
  }
  .isoore-callb__avatar svg { width: 100%; height: 100%; display: block; }
  .isoore-callb__avatar-status {
    position: absolute;
    bottom: 2px; right: 2px;
    width: 14px; height: 14px;
    border-radius: 50%;
    background: #4ade80;
    border: 2.5px solid #F4F0E6;
    animation: isoore-callb-pulse 2s ease-in-out infinite;
  }
  @keyframes isoore-callb-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(74, 222, 128, 0.6); }
    50% { box-shadow: 0 0 0 6px rgba(74, 222, 128, 0); }
  }
  .isoore-callb__card-name {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: var(--isoore-dark);
  }
  .isoore-callb__card-role {
    margin: 2px 0 0;
    font-size: 12.5px;
    color: var(--isoore-cta);
    font-weight: 500;
  }
  .isoore-callb__quote {
    margin: 18px 0 22px;
    padding: 0;
    font-size: 14.5px;
    line-height: 1.6;
    color: var(--isoore-darker);
    font-style: italic;
    position: relative;
    padding-left: 18px;
    border-left: 3px solid var(--isoore-cta);
  }

  /* Mini calendar */
  .isoore-callb__minicalendar {
    background: #fff;
    border: 1px solid var(--isoore-border, #E8E2D3);
    border-radius: 8px;
    padding: 14px;
  }
  .isoore-callb__mini-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 11px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--isoore-text);
    margin-bottom: 12px;
    font-weight: 500;
  }
  .isoore-callb__mini-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: #4ade80;
    box-shadow: 0 0 0 3px rgba(74, 222, 128, 0.2);
  }
  .isoore-callb__mini-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
  }
  .isoore-callb__mini-slot {
    padding: 8px 10px;
    border-radius: 5px;
    font-size: 12px;
    font-weight: 500;
    text-align: center;
    transition: all 0.2s;
  }
  .isoore-callb__mini-slot.is-available {
    background: rgba(45, 62, 43, 0.12);
    color: var(--isoore-cta);
    border: 1px solid rgba(45, 62, 43, 0.3);
  }
  .isoore-callb__mini-slot.is-taken {
    background: rgba(45, 62, 43, 0.05);
    color: var(--isoore-text);
    opacity: 0.4;
    text-decoration: line-through;
  }
  .isoore-callb__mini-note {
    margin: 12px 0 0;
    font-size: 10.5px;
    color: var(--isoore-text);
    opacity: 0.6;
    text-align: center;
  }

  /* Responsive */
  @media (max-width: 989px) {
    .isoore-callb__container { padding: 0 24px; }
    .isoore-callb__panel { grid-template-columns: 1fr; gap: 36px; padding: 36px 28px; }
    .isoore-callb__title { font-size: clamp(24px, 5vw, 32px); }
  }
/* END_SECTION:isoore-product-call-before */

/* START_SECTION:isoore-product-callback (INDEX:43) */
/* ===== Bloc carte ===== */
  .isoore-callback {
    background: var(--bg, #F7F3EC);
    padding: 32px 0;
  }
  .isoore-callback__container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 56px;
  }
  .isoore-callback__card {
    display: flex;
    align-items: center;
    gap: 24px;
    padding: 28px 32px;
    background: #fff;
    border: 1px solid var(--isoore-border, #E4DCC8);
    border-radius: var(--isoore-radius-lg, 12px);
    box-shadow: 0 8px 24px rgba(58, 80, 56, 0.06);
  }
  .isoore-callback__icon {
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: rgba(122, 171, 114, 0.10);
    color: var(--isoore-cta, #7AAB72);
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .isoore-callback__icon svg { width: 28px; height: 28px; }
  .isoore-callback__copy { flex: 1; min-width: 0; }
  .isoore-callback__title {
    margin: 0 0 4px;
    font-size: 18px;
    font-weight: 600;
    color: var(--isoore-dark, #3A5038);
  }
  .isoore-callback__text {
    margin: 0;
    font-size: 14px;
    color: var(--isoore-text, #3A5038);
    opacity: 0.85;
  }
  .isoore-callback__cta {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 24px;
    border: 1.5px solid var(--isoore-dark, #3A5038);
    border-radius: var(--isoore-radius-md, 8px);
    background: transparent;
    color: var(--isoore-dark, #3A5038);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.3s var(--isoore-ease), color 0.3s var(--isoore-ease), transform 0.3s var(--isoore-ease);
  }
  .isoore-callback__cta:hover {
    background: var(--isoore-dark, #3A5038);
    color: #fff;
    transform: translateY(-2px);
  }
  .isoore-callback__cta-arrow {
    display: inline-block;
    transition: transform 0.3s var(--isoore-ease);
  }
  .isoore-callback__cta:hover .isoore-callback__cta-arrow { transform: translateX(4px); }

  @media (max-width: 749px) {
    .isoore-callback__container { padding: 0 24px; }
    .isoore-callback__card {
      flex-direction: column;
      text-align: center;
      align-items: stretch;
      padding: 24px 22px;
    }
    .isoore-callback__icon { margin: 0 auto; }
    .isoore-callback__cta { justify-content: center; }
  }

  /* ===== Modal ===== */
  .isoore-callback-modal {
    position: fixed;
    inset: 0;
    z-index: 200;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.3s var(--isoore-ease), visibility 0.3s var(--isoore-ease);
  }
  .isoore-callback-modal.is-open {
    visibility: visible;
    opacity: 1;
  }
  .isoore-callback-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(45, 62, 43, 0.55);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
  }
  .isoore-callback-modal__panel {
    position: relative;
    width: 100%;
    max-width: 540px;
    max-height: calc(100vh - 48px);
    overflow-y: auto;
    background: var(--isoore-bg, #F7F3EC);
    border-radius: var(--isoore-radius-lg, 12px);
    box-shadow: 0 30px 80px rgba(45, 62, 43, 0.35);
    transform: translateY(20px) scale(0.97);
    transition: transform 0.4s var(--isoore-ease);
  }
  .isoore-callback-modal.is-open .isoore-callback-modal__panel {
    transform: translateY(0) scale(1);
  }
  .isoore-callback-modal__close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 36px;
    height: 36px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: transparent;
    color: var(--isoore-dark, #3A5038);
    cursor: pointer;
    transition: background 0.2s var(--isoore-ease);
  }
  .isoore-callback-modal__close:hover { background: rgba(58, 80, 56, 0.08); }
  .isoore-callback-modal__close svg { width: 20px; height: 20px; }

  .isoore-callback-modal__header {
    padding: 36px 32px 24px;
  }
  .isoore-callback-modal__kicker { margin-bottom: 10px; }
  .isoore-callback-modal__title {
    margin: 0 0 10px;
    font-size: clamp(22px, 2.6vw, 28px);
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: -0.3px;
    color: var(--isoore-dark, #3A5038);
  }
  .isoore-callback-modal__subtitle {
    margin: 0;
    font-size: 14px;
    line-height: 1.55;
    color: var(--isoore-text, #3A5038);
    opacity: 0.85;
  }

  .isoore-callback-modal__body {
    padding: 0 32px 24px;
  }

  /* ===== Form ===== */
  .isoore-callback-form {
    display: flex;
    flex-direction: column;
    gap: 16px;
  }
  .isoore-callback-form__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
  }
  .isoore-callback-form__field {
    display: flex;
    flex-direction: column;
    gap: 6px;
  }
  .isoore-callback-form__field label {
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.3px;
    color: var(--isoore-text, #3A5038);
    opacity: 0.85;
  }
  .isoore-callback-form__field input,
  .isoore-callback-form__field select,
  .isoore-callback-form__field textarea {
    padding: 12px 14px;
    border: 1.5px solid var(--isoore-border, #E4DCC8);
    border-radius: var(--isoore-radius-md, 8px);
    background: #fff;
    font-family: inherit;
    font-size: 14px;
    color: var(--isoore-dark, #3A5038);
    transition: border-color 0.2s var(--isoore-ease), box-shadow 0.2s var(--isoore-ease);
  }
  .isoore-callback-form__field input:focus,
  .isoore-callback-form__field select:focus,
  .isoore-callback-form__field textarea:focus {
    outline: none;
    border-color: var(--isoore-cta, #7AAB72);
    box-shadow: 0 0 0 3px rgba(122, 171, 114, 0.15);
  }
  .isoore-callback-form__field textarea { resize: vertical; min-height: 70px; }

  .isoore-callback-form__submit {
    margin-top: 4px;
    padding: 15px 20px;
    border: none;
    border-radius: var(--isoore-radius-md, 8px);
    background: var(--isoore-cta, #7AAB72);
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.2px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: background 0.3s var(--isoore-ease), transform 0.3s var(--isoore-ease), box-shadow 0.3s var(--isoore-ease);
  }
  .isoore-callback-form__submit:hover {
    background: var(--isoore-cta-hover, #5d8a55);
    transform: translateY(-1px);
    box-shadow: 0 8px 22px rgba(122, 171, 114, 0.35);
  }

  .isoore-callback-form__legal {
    margin: 0;
    font-size: 11px;
    color: var(--isoore-text, #3A5038);
    opacity: 0.6;
    text-align: center;
  }

  .isoore-callback-form__error {
    padding: 10px 14px;
    background: rgba(220, 80, 80, 0.08);
    border: 1px solid rgba(220, 80, 80, 0.25);
    border-radius: var(--isoore-radius-md, 8px);
    color: #a83030;
    font-size: 13px;
  }
  .isoore-callback-form__error ul { margin: 0; padding-left: 18px; }

  .isoore-callback-form__success {
    text-align: center;
    padding: 20px 0;
  }
  .isoore-callback-form__success svg {
    width: 56px;
    height: 56px;
    color: var(--isoore-cta, #7AAB72);
    margin-bottom: 12px;
  }
  .isoore-callback-form__success h3 {
    margin: 0 0 8px;
    font-size: 20px;
    color: var(--isoore-dark, #3A5038);
  }
  .isoore-callback-form__success p {
    margin: 0;
    font-size: 14px;
    color: var(--isoore-text, #3A5038);
    opacity: 0.85;
  }

  /* ===== Réassurance footer modal ===== */
  .isoore-callback-modal__reassurance {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 18px 32px 30px;
    border-top: 1px solid var(--isoore-border, #E4DCC8);
    margin-top: 4px;
  }
  .isoore-callback-modal__reassurance-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 12px;
    color: var(--isoore-text, #3A5038);
    opacity: 0.85;
  }
  .isoore-callback-modal__reassurance-item svg {
    width: 16px;
    height: 16px;
    color: var(--isoore-cta, #7AAB72);
    flex-shrink: 0;
  }

  @media (max-width: 549px) {
    .isoore-callback-modal { padding: 12px; }
    .isoore-callback-modal__header,
    .isoore-callback-modal__body,
    .isoore-callback-modal__reassurance { padding-left: 22px; padding-right: 22px; }
    .isoore-callback-form__row { grid-template-columns: 1fr; }
  }

  @media (prefers-reduced-motion: reduce) {
    .isoore-callback-modal,
    .isoore-callback-modal__panel { transition: none !important; }
  }
/* END_SECTION:isoore-product-callback */

/* START_SECTION:isoore-product-compare (INDEX:44) */
.isoore-compare {
    background: var(--isoore-bg, #F4F0E6);
    color: var(--isoore-text, #0E0E0C);
    padding: var(--isoore-section-pad, 88px) 0;
  }
  .isoore-compare__container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 56px;
  }
  .isoore-compare__header {
    text-align: center;
    max-width: 720px;
    margin: 0 auto 48px;
  }
  .isoore-compare__title {
    margin: 12px 0 14px;
    font-size: clamp(28px, 3.4vw, 42px);
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -0.5px;
    color: var(--isoore-dark, #0E0E0C);
  }
  .isoore-compare__subtitle {
    margin: 0;
    font-size: 16px;
    line-height: 1.65;
    opacity: 0.85;
  }

  /* Table */
  .isoore-compare__table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: var(--isoore-radius-lg, 12px);
    background: #fff;
    border: 1px solid var(--isoore-border, #E8E2D3);
    box-shadow: 0 18px 48px rgba(45, 62, 43, 0.08);
    padding: 4px;
  }
  .isoore-compare__table {
    width: 100%;
    /* border-collapse: separate permet aux bordures cellule par cellule de
       s'aligner parfaitement avec celles des cellules voisines. */
    border-collapse: separate;
    border-spacing: 0;
    min-width: 720px;
  }
  .isoore-compare__table th,
  .isoore-compare__table td {
    padding: 18px 22px;
    text-align: center;
    vertical-align: middle;
    font-size: 14px;
    line-height: 1.5;
    border-bottom: 1px solid var(--isoore-border, #E8E2D3);
  }
  .isoore-compare__table tbody th {
    text-align: left;
    font-weight: 600;
    color: var(--isoore-dark);
    background: rgba(244, 240, 230, 0.55);
    width: 28%;
    padding-right: 28px;
  }
  .isoore-compare__table tr:last-child th,
  .isoore-compare__table tr:last-child td {
    border-bottom: none;
  }

  /* Headers (colonnes) */
  .isoore-compare__th-empty { background: transparent; border-bottom: 2px solid var(--isoore-border); }
  .isoore-compare__th-col {
    padding: 22px 16px !important;
    border-bottom: 2px solid var(--isoore-border, #E8E2D3);
    vertical-align: bottom;
  }

  /* ===== Colonne Isoore mise en avant - bordures DIRECTEMENT sur les cellules ===== */
  /* Top : header Isoore */
  .isoore-compare__th-col--isoore {
    background: linear-gradient(180deg, rgba(45, 62, 43, 0.14) 0%, rgba(45, 62, 43, 0.06) 100%);
    border-top: 2px solid var(--isoore-cta, #2D3E2B);
    border-left: 2px solid var(--isoore-cta, #2D3E2B);
    border-right: 2px solid var(--isoore-cta, #2D3E2B);
    border-bottom: 2px solid var(--isoore-cta, #2D3E2B);
    border-radius: 10px 10px 0 0;
  }
  /* Milieu : toutes les cellules td de la 3eme colonne */
  .isoore-compare__table tbody tr td:nth-child(3) {
    background: rgba(45, 62, 43, 0.05);
    font-weight: 600;
    color: var(--isoore-dark);
    border-left: 2px solid var(--isoore-cta, #2D3E2B);
    border-right: 2px solid var(--isoore-cta, #2D3E2B);
    /* La border-bottom reste celle naturelle de la cellule (separator clair) */
  }
  /* Bottom : derniere cellule de la colonne Isoore */
  .isoore-compare__table tbody tr:last-child td:nth-child(3) {
    border-bottom: 2px solid var(--isoore-cta, #2D3E2B);
    border-radius: 0 0 10px 10px;
  }
  /* Ombre subtile portee par la colonne Isoore */
  .isoore-compare__th-col--isoore {
    box-shadow: 0 -4px 14px rgba(45, 62, 43, 0.18);
  }

  .isoore-compare__col-badge {
    display: inline-block;
    background: var(--isoore-cta, #2D3E2B);
    color: #fff;
    font-size: 10px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 999px;
    margin-bottom: 8px;
  }
  .isoore-compare__col-label {
    display: block;
    font-size: 16px;
    font-weight: 700;
    color: var(--isoore-dark);
    margin-bottom: 4px;
    letter-spacing: -0.2px;
  }
  .isoore-compare__th-col--isoore .isoore-compare__col-label {
    font-size: 22px;
    color: var(--isoore-darker);
  }
  .isoore-compare__col-meta {
    display: block;
    font-size: 12px;
    color: var(--isoore-text);
    opacity: 0.7;
    font-weight: 500;
  }
  .isoore-compare__th-col--isoore .isoore-compare__col-meta {
    color: var(--isoore-cta);
    opacity: 1;
    font-weight: 600;
  }

  /* Cells colorées */
  .isoore-compare__cell { color: var(--isoore-text); opacity: 0.92; }
  .isoore-compare__cell--no::before {
    content: '✕ ';
    color: #C77F6F;
    font-weight: 700;
    margin-right: 4px;
  }
  .isoore-compare__cell--mid::before {
    content: '∼ ';
    color: #A89368;
    font-weight: 700;
    margin-right: 4px;
  }
  .isoore-compare__cell--yes::before,
  .isoore-compare__cell--yes-strong::before {
    content: '✓ ';
    color: var(--isoore-cta);
    font-weight: 700;
    margin-right: 4px;
  }
  .isoore-compare__cell--yes-strong { color: var(--isoore-darker); font-weight: 600; }

  .isoore-compare__footnote {
    margin: 18px auto 0;
    text-align: center;
    font-size: 12px;
    color: var(--isoore-text);
    opacity: 0.65;
    max-width: 720px;
    line-height: 1.55;
  }

  /* Responsive */
  @media (max-width: 989px) {
    .isoore-compare__container { padding: 0 24px; }
    .isoore-compare__table th,
    .isoore-compare__table td { padding: 14px 12px; font-size: 12.5px; }
    .isoore-compare__col-label { font-size: 13px; }
    .isoore-compare__th-col--isoore .isoore-compare__col-label { font-size: 17px; }
  }
/* END_SECTION:isoore-product-compare */

/* START_SECTION:isoore-product-configurator (INDEX:45) */
.isoore-config {
    background: var(--isoore-bg, #F7F3EC);
    color: var(--isoore-text, #3A5038);
    padding: var(--isoore-section-pad, 88px) 0;
  }
  .isoore-config__container {
    max-width: 880px;
    margin: 0 auto;
    padding: 0 24px;
  }
  .isoore-config__header {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 40px;
  }
  .isoore-config__title {
    margin: 12px 0 14px;
    font-size: clamp(28px, 3.4vw, 42px);
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -0.5px;
    color: var(--isoore-dark, #3A5038);
  }
  .isoore-config__subtitle {
    margin: 0;
    font-size: 16px;
    line-height: 1.65;
    opacity: 0.85;
  }

  .isoore-config__panel {
    position: relative;
    background: #fff;
    border: 1px solid var(--isoore-border, #E4DCC8);
    border-radius: var(--isoore-radius-lg, 12px);
    padding: 36px 32px 24px;
    box-shadow: 0 12px 32px rgba(45, 62, 43, 0.08);
  }

  /* Progress */
  .isoore-config__progress { margin-bottom: 32px; }
  .isoore-config__progress-track {
    height: 4px;
    background: var(--isoore-border, #E4DCC8);
    border-radius: 2px;
    overflow: hidden;
    position: relative;
  }
  .isoore-config__progress-bar {
    height: 100%;
    width: 20%;
    background: var(--isoore-cta, #7AAB72);
    border-radius: 2px;
    transition: width 0.4s var(--isoore-ease);
  }
  .isoore-config__steps {
    display: flex;
    justify-content: space-between;
    margin-top: 14px;
  }
  .isoore-config__step {
    width: 30px; height: 30px;
    border-radius: 50%;
    background: #fff;
    border: 1.5px solid var(--isoore-border, #E4DCC8);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600;
    color: var(--isoore-text);
    opacity: 0.55;
    transition: all 0.3s var(--isoore-ease);
  }
  .isoore-config__step.is-active {
    background: var(--isoore-cta, #7AAB72);
    color: #fff;
    border-color: var(--isoore-cta, #7AAB72);
    opacity: 1;
    transform: scale(1.05);
  }
  .isoore-config__step.is-done {
    background: rgba(122, 171, 114, 0.15);
    color: var(--isoore-cta);
    border-color: var(--isoore-cta);
    opacity: 1;
  }

  /* Step panels */
  .isoore-config__step-panel {
    display: none;
    animation: isoore-config-in 0.4s var(--isoore-ease);
  }
  .isoore-config__step-panel.is-active { display: block; }
  @keyframes isoore-config-in {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  .isoore-config__question {
    margin: 0 0 8px;
    font-size: 22px;
    font-weight: 500;
    color: var(--isoore-dark);
    text-align: center;
  }
  .isoore-config__helper {
    margin: 0 0 28px;
    font-size: 14px;
    line-height: 1.6;
    color: var(--isoore-text);
    opacity: 0.78;
    text-align: center;
  }

  /* Choices */
  .isoore-config__choices {
    display: grid;
    gap: 14px;
  }
  .isoore-config__choices--2 { grid-template-columns: repeat(2, 1fr); }
  .isoore-config__choices--3 { grid-template-columns: repeat(3, 1fr); }
  .isoore-config__choices--4 { grid-template-columns: repeat(4, 1fr); }

  .isoore-config__choice {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 22px 14px 18px;
    border: 1.5px solid var(--isoore-border, #E4DCC8);
    border-radius: var(--isoore-radius-md, 8px);
    background: #fff;
    color: var(--isoore-text);
    cursor: pointer;
    text-align: center;
    transition: transform 0.22s var(--isoore-ease), border-color 0.22s var(--isoore-ease), box-shadow 0.22s var(--isoore-ease), background 0.22s var(--isoore-ease);
  }
  .isoore-config__choice:hover {
    transform: translateY(-3px);
    border-color: var(--isoore-cta, #7AAB72);
    box-shadow: 0 10px 24px rgba(45, 62, 43, 0.14);
  }
  .isoore-config__choice.is-selected {
    border-color: var(--isoore-cta, #7AAB72);
    background: rgba(122, 171, 114, 0.08);
    box-shadow: 0 0 0 3px rgba(122, 171, 114, 0.18);
  }
  .isoore-config__choice-icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: rgba(122, 171, 114, 0.1);
    color: var(--isoore-cta, #7AAB72);
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .isoore-config__choice-icon svg { width: 28px; height: 28px; }
  .isoore-config__choice-title { font-size: 14px; font-weight: 600; color: var(--isoore-dark); }
  .isoore-config__choice-meta { font-size: 12px; opacity: 0.7; }
  .isoore-config__choice-badge {
    position: absolute;
    top: -8px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--isoore-cta, #7AAB72);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    padding: 3px 10px;
    border-radius: 999px;
  }
  .isoore-config__choice.is-recommended {
    border-color: rgba(122, 171, 114, 0.4);
  }

  /* Recap */
  .isoore-config__recap-list {
    list-style: none;
    margin: 0 0 28px;
    padding: 0;
    border-top: 1px solid var(--isoore-border, #E4DCC8);
  }
  .isoore-config__recap-list li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 0;
    border-bottom: 1px solid var(--isoore-border, #E4DCC8);
    font-size: 14px;
  }
  .isoore-config__recap-list li span {
    color: var(--isoore-text);
    opacity: 0.7;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    font-size: 11px;
  }
  .isoore-config__recap-list li strong {
    color: var(--isoore-dark);
    font-weight: 600;
    text-align: right;
    max-width: 65%;
  }

  .isoore-config__recap-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-bottom: 18px;
  }
  .isoore-config__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 16px 22px;
    border-radius: var(--isoore-radius-md, 8px);
    text-decoration: none;
    font-weight: 600;
    font-size: 15px;
    transition: transform 0.22s var(--isoore-ease), box-shadow 0.22s var(--isoore-ease), background 0.22s var(--isoore-ease);
  }
  .isoore-config__cta svg { width: 22px; height: 22px; }
  .isoore-config__cta--whatsapp {
    background: #25D366;
    color: #fff;
  }
  .isoore-config__cta--whatsapp:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 28px rgba(37, 211, 102, 0.36);
    background: #1FB955;
  }
  .isoore-config__cta--calendly {
    background: var(--isoore-darker, #2D3E2B);
    color: #F7F3EC;
  }
  .isoore-config__cta--calendly:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 28px rgba(45, 62, 43, 0.32);
  }
  .isoore-config__recap-note {
    margin: 0;
    text-align: center;
    font-size: 12.5px;
    opacity: 0.65;
  }

  /* Footer nav */
  .isoore-config__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid var(--isoore-border, #E4DCC8);
  }
  .isoore-config__nav {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: transparent;
    border: none;
    color: var(--isoore-text);
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    padding: 8px 12px;
    border-radius: 6px;
    transition: background 0.2s, opacity 0.2s;
  }
  .isoore-config__nav:hover:not(:disabled) { background: rgba(122, 171, 114, 0.1); }
  .isoore-config__nav:disabled { opacity: 0.35; cursor: not-allowed; }
  .isoore-config__nav svg { width: 16px; height: 16px; }
  .isoore-config__step-counter {
    font-size: 12px;
    letter-spacing: 1px;
    text-transform: uppercase;
    opacity: 0.65;
  }
  .isoore-config__step-counter strong { color: var(--isoore-cta); font-size: 13px; }

  /* Responsive */
  @media (max-width: 749px) {
    .isoore-config__panel { padding: 24px 18px 18px; }
    .isoore-config__choices--3, .isoore-config__choices--4 { grid-template-columns: repeat(2, 1fr); }
    .isoore-config__choices--2 { grid-template-columns: 1fr; }
    .isoore-config__recap-actions { grid-template-columns: 1fr; }
    .isoore-config__question { font-size: 19px; }
    .isoore-config__step { width: 26px; height: 26px; font-size: 11px; }
  }

  @media (prefers-reduced-motion: reduce) {
    .isoore-config__choice:hover { transform: none !important; }
    .isoore-config__cta:hover { transform: none !important; }
    .isoore-config__step-panel { animation: none !important; }
  }
/* END_SECTION:isoore-product-configurator */

/* START_SECTION:isoore-product-faq-v2 (INDEX:46) */
.isoore-faqv2 {
    background: var(--isoore-bg, #F4F0E6);
    color: var(--isoore-text, #0E0E0C);
    padding: var(--isoore-section-pad, 88px) 0;
  }
  .isoore-faqv2__container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 56px;
  }
  .isoore-faqv2__header {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 56px;
  }
  .isoore-faqv2__title {
    margin: 12px 0 14px;
    font-size: clamp(28px, 3.4vw, 42px);
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -0.5px;
    color: var(--isoore-dark, #0E0E0C);
  }
  .isoore-faqv2__subtitle {
    margin: 0;
    font-size: 16px;
    line-height: 1.65;
    opacity: 0.85;
  }

  .isoore-faqv2__layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 56px;
    align-items: start;
  }

  /* Sidebar */
  .isoore-faqv2__nav {
    position: sticky;
    top: max(90px, 12vh);
    display: flex;
    flex-direction: column;
    gap: 4px;
  }
  .isoore-faqv2__nav-label {
    margin: 0 0 12px;
    font-size: 11px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--isoore-text);
    opacity: 0.6;
    padding-left: 14px;
  }
  .isoore-faqv2__cat {
    text-align: left;
    background: transparent;
    border: none;
    color: var(--isoore-text);
    font-size: 14px;
    padding: 10px 16px;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.2s var(--isoore-ease);
  }
  .isoore-faqv2__cat:hover { background: rgba(45, 62, 43, 0.08); }
  .isoore-faqv2__cat.is-active {
    background: var(--isoore-cta, #2D3E2B);
    color: #fff;
    font-weight: 600;
  }

  .isoore-faqv2__contact {
    margin-top: 36px;
    padding: 18px;
    background: #fff;
    border-radius: 8px;
    border: 1px solid var(--isoore-border, #E8E2D3);
  }
  .isoore-faqv2__contact p {
    margin: 0 0 8px;
    font-size: 13px;
    color: var(--isoore-dark);
    font-weight: 500;
  }
  .isoore-faqv2__contact a {
    color: var(--isoore-cta, #2D3E2B);
    text-decoration: none;
    font-size: 13px;
    font-weight: 600;
  }

  /* Items */
  .isoore-faqv2__list {
    display: flex;
    flex-direction: column;
    gap: 14px;
  }
  .isoore-faqv2__item {
    background: #fff;
    border: 1px solid var(--isoore-border, #E8E2D3);
    border-radius: var(--isoore-radius-md, 8px);
    overflow: hidden;
    transition: border-color 0.25s var(--isoore-ease), box-shadow 0.25s var(--isoore-ease);
  }
  .isoore-faqv2__item[open] {
    border-color: var(--isoore-cta, #2D3E2B);
    box-shadow: 0 10px 24px rgba(45, 62, 43, 0.08);
  }
  .isoore-faqv2__item.is-hidden { display: none; }

  .isoore-faqv2__item summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 18px;
    padding: 20px 24px;
    cursor: pointer;
    list-style: none;
    user-select: none;
  }
  .isoore-faqv2__item summary::-webkit-details-marker { display: none; }
  .isoore-faqv2__q {
    font-size: 15.5px;
    font-weight: 500;
    color: var(--isoore-dark);
    line-height: 1.4;
  }
  .isoore-faqv2__icon {
    flex-shrink: 0;
    width: 28px; height: 28px;
    border-radius: 50%;
    background: rgba(45, 62, 43, 0.12);
    position: relative;
    transition: all 0.25s var(--isoore-ease);
  }
  .isoore-faqv2__icon::before, .isoore-faqv2__icon::after {
    content: '';
    position: absolute;
    background: var(--isoore-cta, #2D3E2B);
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    transition: all 0.25s var(--isoore-ease);
  }
  .isoore-faqv2__icon::before { width: 12px; height: 2px; border-radius: 2px; }
  .isoore-faqv2__icon::after { width: 2px; height: 12px; border-radius: 2px; }
  .isoore-faqv2__item[open] .isoore-faqv2__icon { background: var(--isoore-cta, #2D3E2B); }
  .isoore-faqv2__item[open] .isoore-faqv2__icon::before,
  .isoore-faqv2__item[open] .isoore-faqv2__icon::after { background: #fff; }
  .isoore-faqv2__item[open] .isoore-faqv2__icon::after { transform: translate(-50%, -50%) rotate(90deg); height: 2px; }

  .isoore-faqv2__a {
    padding: 0 24px 22px 24px;
    color: var(--isoore-text);
    font-size: 14.5px;
    line-height: 1.7;
  }
  .isoore-faqv2__a p { margin: 0 0 12px; }
  .isoore-faqv2__a p:last-child { margin-bottom: 0; }
  .isoore-faqv2__a ul {
    margin: 0 0 12px;
    padding-left: 22px;
  }
  .isoore-faqv2__a ul li { margin-bottom: 8px; }
  .isoore-faqv2__a strong { color: var(--isoore-dark); }

  /* ===== Bouton "Voir plus" ===== */
  .isoore-faqv2__more {
    display: none;
    align-self: center;
    margin-top: 14px;
    padding: 12px 24px;
    background: transparent;
    border: 1.5px solid var(--isoore-cta, #2D3E2B);
    color: var(--isoore-cta, #2D3E2B);
    border-radius: 999px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.22s var(--isoore-ease);
    align-items: center;
    gap: 8px;
  }
  .isoore-faqv2__more:hover {
    background: var(--isoore-cta, #2D3E2B);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(45, 62, 43, 0.3);
  }
  .isoore-faqv2__more svg {
    width: 16px; height: 16px;
    transition: transform 0.3s var(--isoore-ease);
  }
  .isoore-faqv2__more-hide { display: none; }

  /* En mode "all" non-expanded : cache items au-dela du 5e, montre le bouton */
  .isoore-faqv2__list.is-mode-all:not(.is-expanded) .isoore-faqv2__item[data-faq-cat]:nth-of-type(n+6) {
    display: none;
  }
  .isoore-faqv2__list.is-mode-all .isoore-faqv2__more {
    display: inline-flex;
  }
  .isoore-faqv2__list.is-mode-all.is-expanded .isoore-faqv2__more-show { display: none; }
  .isoore-faqv2__list.is-mode-all.is-expanded .isoore-faqv2__more-hide { display: inline; }
  .isoore-faqv2__list.is-mode-all.is-expanded .isoore-faqv2__more svg { transform: rotate(180deg); }

  /* Responsive */
  @media (max-width: 989px) {
    .isoore-faqv2__container { padding: 0 24px; }
    .isoore-faqv2__layout { grid-template-columns: 1fr; gap: 24px; }
    .isoore-faqv2__nav {
      position: relative;
      top: 0;
      flex-direction: row;
      flex-wrap: wrap;
      gap: 8px;
      overflow-x: auto;
    }
    .isoore-faqv2__nav-label { display: none; }
    .isoore-faqv2__cat { padding: 8px 14px; font-size: 12.5px; white-space: nowrap; }
    .isoore-faqv2__contact { width: 100%; margin-top: 0; }
    .isoore-faqv2__q { font-size: 14px; }
  }
/* END_SECTION:isoore-product-faq-v2 */

/* START_SECTION:isoore-product-hero (INDEX:47) */
.isoore-product-hero {
    background: var(--isoore-bg, #F7F3EC);
    color: var(--isoore-text, #3A5038);
    padding: 32px 0 88px;
    overflow: clip;
  }

  .isoore-product-hero__container {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
    gap: 56px;
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 56px;
    align-items: start;
  }

  /* ============ GALERIE ============ */
  .isoore-product-hero__gallery {
    position: relative;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
  }

  /* Badges overlay */
  .isoore-product-hero__badges {
    position: absolute;
    top: 18px;
    left: 18px;
    z-index: 4;
    display: flex;
    flex-direction: column;
    gap: 8px;
    pointer-events: none;
  }

  .isoore-product-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 13px;
    background: rgba(247, 243, 236, 0.92);
    color: var(--isoore-dark, #3A5038);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    border-radius: 999px;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    box-shadow: 0 2px 8px rgba(58, 80, 56, 0.08);
  }
  .isoore-product-hero__badge--bestseller { background: var(--isoore-cta, #7AAB72); color: #fff; }
  .isoore-product-hero__badge--sale { background: var(--isoore-darker, #2D3E2B); color: #fff; }
  .isoore-product-hero__badge-dot {
    width: 6px; height: 6px; border-radius: 50%; background: #fff;
    animation: isoore-pulse 1.8s var(--isoore-ease) infinite;
  }

  /* === Stage (image principale) === */
  .isoore-product-hero__stage {
    position: relative;
    border-radius: var(--isoore-radius-lg, 12px);
    overflow: hidden;
    background: var(--isoore-border, #E4DCC8);
  }

  .isoore-product-hero__stage-track {
    position: relative;
    display: flex;
    width: 100%;
  }

  .isoore-product-hero__slide {
    position: relative;
    flex: 0 0 100%;
    margin: 0;
    width: 100%;
    opacity: 0;
    transition: opacity 0.4s var(--isoore-ease);
    pointer-events: none;
  }

  .isoore-product-hero__slide.is-active {
    opacity: 1;
    pointer-events: auto;
  }

  .isoore-product-hero__slide-img,
  .isoore-product-hero__slide img,
  .isoore-product-hero__slide video,
  .isoore-product-hero__slide model-viewer,
  .isoore-product-hero__placeholder {
    display: block;
    width: 100%;
    height: 100%;
    transition: transform 0.6s var(--isoore-ease);
  }

  /* Ratio control */
  .isoore-product-hero__gallery--ratio-square .isoore-product-hero__slide,
  .isoore-product-hero__gallery--ratio-portrait .isoore-product-hero__slide,
  .isoore-product-hero__gallery--ratio-landscape .isoore-product-hero__slide {
    overflow: hidden;
  }
  .isoore-product-hero__gallery--ratio-square .isoore-product-hero__slide-img,
  .isoore-product-hero__gallery--ratio-portrait .isoore-product-hero__slide-img,
  .isoore-product-hero__gallery--ratio-landscape .isoore-product-hero__slide-img {
    object-fit: cover;
  }

  .isoore-product-hero__gallery--ratio-square .isoore-product-hero__slide   { aspect-ratio: 1 / 1; }
  .isoore-product-hero__gallery--ratio-portrait .isoore-product-hero__slide { aspect-ratio: 3 / 4; }
  .isoore-product-hero__gallery--ratio-landscape .isoore-product-hero__slide { aspect-ratio: 4 / 3; }

  /* Mode "adapt" : laisser l'image à son ratio natif, hauteur du stage suit l'image active */
  .isoore-product-hero__gallery--ratio-adapt .isoore-product-hero__stage-track {
    position: relative;
  }
  .isoore-product-hero__gallery--ratio-adapt .isoore-product-hero__slide {
    position: absolute;
    inset: 0;
  }
  .isoore-product-hero__gallery--ratio-adapt .isoore-product-hero__slide.is-active {
    position: relative;
  }
  .isoore-product-hero__gallery--ratio-adapt .isoore-product-hero__slide-img {
    object-fit: contain;
    width: 100%;
    height: auto;
  }
  .isoore-product-hero__gallery--ratio-adapt .isoore-product-hero__stage {
    background: var(--isoore-bg, #F7F3EC);
  }

  /* Nav arrows */
  .isoore-product-hero__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 3;
    width: 44px;
    height: 44px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: rgba(247, 243, 236, 0.92);
    color: var(--isoore-dark, #3A5038);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 14px rgba(58, 80, 56, 0.12);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: transform 0.2s var(--isoore-ease), background 0.2s var(--isoore-ease);
  }
  .isoore-product-hero__nav svg { width: 20px; height: 20px; }
  .isoore-product-hero__nav:hover { background: #fff; transform: translateY(-50%) scale(1.05); }
  .isoore-product-hero__nav--prev { left: 14px; }
  .isoore-product-hero__nav--next { right: 14px; }

  /* Dots */
  .isoore-product-hero__dots {
    position: absolute;
    bottom: 14px;
    left: 50%;
    transform: translateX(-50%);
    display: none;
    justify-content: center;
    gap: 6px;
    z-index: 3;
  }
  .isoore-product-hero__dot {
    width: 8px;
    height: 8px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: rgba(247, 243, 236, 0.5);
    cursor: pointer;
    transition: all 0.3s var(--isoore-ease);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
  }
  .isoore-product-hero__dot.is-active {
    width: 22px;
    border-radius: 4px;
    background: #fff;
  }

  /* === Thumbnails strip === */
  .isoore-product-hero__thumbs {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--isoore-border, #E4DCC8) transparent;
    padding: 4px 2px;
  }
  .isoore-product-hero__thumbs::-webkit-scrollbar { height: 4px; }
  .isoore-product-hero__thumbs::-webkit-scrollbar-thumb { background: var(--isoore-border, #E4DCC8); border-radius: 2px; }

  .isoore-product-hero__thumb {
    flex: 0 0 84px;
    width: 84px;
    height: 84px;
    padding: 0;
    border: 2px solid transparent;
    border-radius: var(--isoore-radius-sm, 4px);
    background: var(--isoore-border, #E4DCC8);
    overflow: hidden;
    cursor: pointer;
    transition: border-color 0.25s var(--isoore-ease), transform 0.25s var(--isoore-ease);
  }
  .isoore-product-hero__thumb:hover { transform: translateY(-2px); }
  .isoore-product-hero__thumb.is-active {
    border-color: var(--isoore-cta, #7AAB72);
    box-shadow: 0 0 0 2px rgba(122, 171, 114, 0.2);
  }
  .isoore-product-hero__thumb-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  /* ============ Panel achat ============ */
  .isoore-product-hero__panel { min-width: 0; }

  .isoore-product-hero__panel-sticky {
    position: sticky;
    top: 100px;
    display: flex;
    flex-direction: column;
    gap: 22px;
  }

  .isoore-product-hero__kicker { margin: 0; }

  .isoore-product-hero__title {
    margin: 0;
    font-family: inherit;
    font-size: clamp(28px, 3.2vw, 40px);
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -0.5px;
    color: var(--isoore-dark, #3A5038);
  }

  .isoore-product-hero__rating {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: -10px;
  }
  .isoore-product-hero__stars {
    display: inline-flex;
    gap: 1px;
    font-size: 16px;
    line-height: 1;
    color: rgba(58, 80, 56, 0.25);
  }
  .isoore-product-hero__star--filled { color: #E8A93B; }
  .isoore-product-hero__rating-link {
    font-size: 13px;
    color: var(--isoore-text, #3A5038);
    opacity: 0.7;
    text-decoration: underline;
    text-underline-offset: 3px;
  }
  .isoore-product-hero__rating-link:hover { opacity: 1; }

  .isoore-product-hero__price-row {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 12px;
  }
  .isoore-product-hero__price {
    font-size: clamp(28px, 3vw, 36px);
    font-weight: 600;
    color: var(--isoore-dark, #3A5038);
    transition: color 0.3s var(--isoore-ease);
  }
  .isoore-product-hero__price.is-flashing { animation: isoore-price-flash 0.5s var(--isoore-ease); }
  @keyframes isoore-price-flash {
    0%   { color: var(--isoore-cta, #7AAB72); transform: translateY(-2px); }
    100% { color: var(--isoore-dark, #3A5038); transform: translateY(0); }
  }
  .isoore-product-hero__price-compare {
    font-size: 18px;
    color: var(--isoore-text, #3A5038);
    opacity: 0.5;
    text-decoration: line-through;
  }
  .isoore-product-hero__price-suffix {
    font-size: 13px;
    color: var(--isoore-text, #3A5038);
    opacity: 0.65;
  }

  .isoore-product-hero__description {
    font-size: 15px;
    line-height: 1.65;
    color: var(--isoore-text, #3A5038);
    opacity: 0.85;
  }
  .isoore-product-hero__description p { margin: 0 0 8px; }
  .isoore-product-hero__description p:last-child { margin-bottom: 0; }

  /* === Variant picker === */
  .isoore-product-hero__form-wrap { display: contents; }
  .isoore-product-hero__form {
    display: flex;
    flex-direction: column;
    gap: 18px;
  }
  .isoore-product-hero__variants {
    border: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: 10px;
  }
  .isoore-product-hero__variants-legend {
    font-size: 13px; font-weight: 500; letter-spacing: 0.4px;
    text-transform: uppercase;
    color: var(--isoore-text, #3A5038); opacity: 0.75;
    margin-bottom: 4px; padding: 0;
  }
  .isoore-product-hero__variant-card {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 16px 18px;
    border: 1.5px solid var(--isoore-border, #E4DCC8);
    border-radius: var(--isoore-radius-md, 8px);
    background: #fff;
    cursor: pointer;
    transition: border-color 0.25s var(--isoore-ease), background 0.25s var(--isoore-ease), transform 0.25s var(--isoore-ease), box-shadow 0.25s var(--isoore-ease);
  }
  .isoore-product-hero__variant-card:hover:not(.is-unavailable) {
    border-color: var(--isoore-cta, #7AAB72);
    transform: translateY(-1px);
  }
  .isoore-product-hero__variant-card.is-selected {
    border-color: var(--isoore-cta, #7AAB72);
    background: rgba(122, 171, 114, 0.06);
    box-shadow: 0 0 0 3px rgba(122, 171, 114, 0.15);
  }
  .isoore-product-hero__variant-card.is-unavailable { opacity: 0.5; cursor: not-allowed; }
  .isoore-product-hero__variant-card.is-unavailable .isoore-product-hero__variant-price { text-decoration: line-through; }
  .isoore-product-hero__variant-radio { position: absolute; opacity: 0; pointer-events: none; }
  .isoore-product-hero__variant-content { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
  .isoore-product-hero__variant-name { font-size: 14px; font-weight: 500; color: var(--isoore-dark, #3A5038); line-height: 1.3; }
  .isoore-product-hero__variant-price { font-size: 15px; font-weight: 600; color: var(--isoore-cta, #7AAB72); }
  .isoore-product-hero__variant-check {
    flex-shrink: 0; width: 24px; height: 24px; border-radius: 50%;
    background: var(--isoore-cta, #7AAB72); color: #fff;
    display: flex; align-items: center; justify-content: center;
    opacity: 0; transform: scale(0.5);
    transition: opacity 0.25s var(--isoore-ease), transform 0.25s var(--isoore-ease);
  }
  .isoore-product-hero__variant-check svg { width: 14px; height: 14px; }
  .isoore-product-hero__variant-card.is-selected .isoore-product-hero__variant-check { opacity: 1; transform: scale(1); }

  .isoore-product-hero__quantity { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
  .isoore-product-hero__quantity-label { font-size: 13px; font-weight: 500; letter-spacing: 0.4px; text-transform: uppercase; color: var(--isoore-text, #3A5038); opacity: 0.75; }
  .isoore-product-hero__quantity-control { display: inline-flex; align-items: center; border: 1.5px solid var(--isoore-border, #E4DCC8); border-radius: var(--isoore-radius-md, 8px); background: #fff; overflow: hidden; }
  .isoore-product-hero__quantity-btn { width: 38px; height: 38px; border: none; background: transparent; color: var(--isoore-dark, #3A5038); font-size: 18px; cursor: pointer; }
  .isoore-product-hero__quantity-btn:hover { background: rgba(122, 171, 114, 0.1); }
  .isoore-product-hero__quantity-input { width: 44px; height: 38px; border: none; text-align: center; background: transparent; color: var(--isoore-dark, #3A5038); font-size: 14px; font-weight: 500; -moz-appearance: textfield; }
  .isoore-product-hero__quantity-input::-webkit-outer-spin-button,
  .isoore-product-hero__quantity-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

  /* === CTA Acheter maintenant === */
  .isoore-product-hero__cta {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    padding: 18px 24px;
    border: none;
    border-radius: var(--isoore-radius-md, 8px);
    background: var(--isoore-cta, #7AAB72);
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.3px;
    cursor: pointer;
    overflow: hidden;
    transition: transform 0.3s var(--isoore-ease), background 0.3s var(--isoore-ease), box-shadow 0.3s var(--isoore-ease);
  }
  .isoore-product-hero__cta::before {
    content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.25), transparent);
    transition: left 0.65s var(--isoore-ease);
    pointer-events: none;
  }
  .isoore-product-hero__cta:hover:not(:disabled) {
    transform: translateY(-2px);
    background: var(--isoore-cta-hover, #5d8a55);
    box-shadow: var(--isoore-shadow-cta, 0 10px 25px rgba(122, 171, 114, 0.35));
  }
  .isoore-product-hero__cta:hover:not(:disabled)::before { left: 100%; }
  .isoore-product-hero__cta:disabled { background: rgba(58, 80, 56, 0.3); cursor: not-allowed; }
  .isoore-product-hero__cta-arrow { display: inline-block; transition: transform 0.3s var(--isoore-ease); }
  .isoore-product-hero__cta:hover:not(:disabled) .isoore-product-hero__cta-arrow { transform: translateX(4px); }
  .isoore-product-hero__cta-lock { display: inline-flex; }
  .isoore-product-hero__cta-lock svg { width: 16px; height: 16px; }

  .isoore-product-hero__cta-note {
    margin: -6px 0 0;
    font-size: 12px;
    text-align: center;
    color: var(--isoore-text, #3A5038);
    opacity: 0.7;
  }

  /* État loading */
  .isoore-product-hero__cta.is-loading {
    pointer-events: none;
  }
  .isoore-product-hero__cta.is-loading .isoore-product-hero__cta-label::after {
    content: '';
    display: inline-block;
    width: 14px;
    height: 14px;
    margin-left: 10px;
    border: 2px solid rgba(255, 255, 255, 0.4);
    border-top-color: #fff;
    border-radius: 50%;
    animation: isoore-cta-spin 0.7s linear infinite;
    vertical-align: middle;
  }
  @keyframes isoore-cta-spin { to { transform: rotate(360deg); } }

  /* === Réassurances === */
  .isoore-product-hero__reassurances {
    list-style: none;
    padding: 18px 0 0;
    margin: 0;
    border-top: 1px solid var(--isoore-border, #E4DCC8);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px 24px;
  }
  .isoore-product-hero__reassurance { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; line-height: 1.45; color: var(--isoore-text, #3A5038); }
  .isoore-product-hero__reassurance-icon { flex-shrink: 0; width: 22px; height: 22px; display: inline-flex; align-items: center; justify-content: center; color: var(--isoore-cta, #7AAB72); }
  .isoore-product-hero__reassurance-icon svg { width: 100%; height: 100%; }
  .isoore-product-hero__reassurance-text { flex: 1; padding-top: 2px; }

  /* === Estimation livraison === */
  .isoore-product-hero__delivery {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 16px;
    border-radius: var(--isoore-radius-md, 8px);
    background: rgba(122, 171, 114, 0.08);
    border: 1px dashed rgba(122, 171, 114, 0.35);
  }
  .isoore-product-hero__delivery-icon { flex-shrink: 0; width: 24px; height: 24px; color: var(--isoore-cta, #7AAB72); }
  .isoore-product-hero__delivery-text { display: flex; flex-direction: column; gap: 2px; font-size: 13px; line-height: 1.4; color: var(--isoore-text, #3A5038); }
  .isoore-product-hero__delivery-text strong { font-size: 12px; font-weight: 600; letter-spacing: 0.4px; text-transform: uppercase; color: var(--isoore-cta, #7AAB72); }

  /* === Sticky bar mobile === */
  .isoore-product-hero__sticky-bar {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    z-index: 50;
    background: #fff;
    border-top: 1px solid var(--isoore-border, #E4DCC8);
    box-shadow: 0 -8px 24px rgba(58, 80, 56, 0.08);
    transform: translateY(110%);
    transition: transform 0.4s var(--isoore-ease);
    pointer-events: none;
  }
  .isoore-product-hero__sticky-bar.is-visible { transform: translateY(0); pointer-events: auto; }
  .isoore-product-hero__sticky-bar-inner { display: flex; align-items: center; gap: 12px; padding: 12px 18px; padding-bottom: calc(12px + env(safe-area-inset-bottom)); }
  .isoore-product-hero__sticky-bar-info { flex: 1; display: flex; flex-direction: column; gap: 2px; min-width: 0; }
  .isoore-product-hero__sticky-bar-title { font-size: 12px; color: var(--isoore-text, #3A5038); opacity: 0.7; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .isoore-product-hero__sticky-bar-price { font-size: 16px; font-weight: 600; color: var(--isoore-dark, #3A5038); }
  .isoore-product-hero__sticky-bar-cta { padding: 13px 22px; border: none; border-radius: var(--isoore-radius-md, 8px); background: var(--isoore-cta, #7AAB72); color: #fff; font-size: 14px; font-weight: 600; cursor: pointer; white-space: nowrap; }
  .isoore-product-hero__sticky-bar-cta:hover { background: var(--isoore-cta-hover, #5d8a55); }

  /* ============ Responsive ============ */
  @media (max-width: 989px) {
    .isoore-product-hero { padding: 18px 0 64px; }
    .isoore-product-hero__container { grid-template-columns: 1fr; gap: 28px; padding: 0 24px; }
    .isoore-product-hero__panel-sticky { position: static; }
    /* Sur mobile, on cache les thumbs et on affiche dots + flèches */
    .isoore-product-hero__thumbs { display: none; }
    .isoore-product-hero__dots { display: flex; }
    .isoore-product-hero__nav { width: 38px; height: 38px; }
    .isoore-product-hero__reassurances { grid-template-columns: 1fr; gap: 10px; }
  }

  @media (min-width: 990px) {
    /* Sur desktop, les flèches sont cachées par défaut, visibles au hover du stage */
    .isoore-product-hero__nav { opacity: 0; transition: opacity 0.25s var(--isoore-ease), transform 0.2s var(--isoore-ease), background 0.2s var(--isoore-ease); }
    .isoore-product-hero__stage:hover .isoore-product-hero__nav { opacity: 1; }
    .isoore-product-hero__dots { display: none; }
  }

  @media (max-width: 749px) {
    .isoore-product-hero__title { font-size: clamp(24px, 6vw, 30px); }
    .isoore-product-hero__price { font-size: clamp(24px, 6vw, 30px); }
    .isoore-product-hero__variant-card { padding: 14px 16px; }
  }

  @media (prefers-reduced-motion: reduce) {
    .isoore-product-hero__slide { transition: none !important; }
    .isoore-product-hero__slide-img { transition: none !important; }
    .isoore-product-hero__badge-dot { animation: none !important; }
    .isoore-product-hero__price.is-flashing { animation: none !important; }
    .isoore-product-hero__sticky-bar { transition: none !important; }
    .isoore-product-hero__cta.is-loading .isoore-product-hero__cta-label::after { animation: none !important; }
  }
/* END_SECTION:isoore-product-hero */

/* START_SECTION:isoore-product-journey (INDEX:48) */
.isoore-journey {
    background: var(--isoore-bg, #F7F3EC);
    color: var(--isoore-text, #3A5038);
    padding: var(--isoore-section-pad, 88px) 0;
  }
  .isoore-journey__container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 56px;
  }
  .isoore-journey__header {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 56px;
  }
  .isoore-journey__title {
    margin: 12px 0 14px;
    font-size: clamp(28px, 3.4vw, 42px);
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -0.5px;
    color: var(--isoore-dark, #3A5038);
  }
  .isoore-journey__subtitle {
    margin: 0;
    font-size: 16px;
    line-height: 1.65;
    opacity: 0.85;
  }

  /* Stage */
  .isoore-journey__stage {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 80px;
    align-items: flex-start;
  }

  /* ====== Viz sticky a gauche ====== */
  .isoore-journey__viz-wrap {
    position: sticky;
    top: max(80px, 14vh);
  }
  .isoore-journey__viz {
    position: relative;
    aspect-ratio: 1 / 1;
    background: linear-gradient(160deg, #ffffff 0%, #f1ecdc 100%);
    border-radius: var(--isoore-radius-lg, 12px);
    overflow: hidden;
    box-shadow: 0 18px 48px rgba(45, 62, 43, 0.1);
  }

  /* Toutes les scenes empilees, on switch via .is-active */
  .isoore-journey__scene {
    position: absolute;
    inset: 0;
    opacity: 0;
    transform: scale(0.96);
    transition: opacity 0.55s var(--isoore-ease), transform 0.55s var(--isoore-ease);
    pointer-events: none;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .isoore-journey__scene.is-active {
    opacity: 1;
    transform: scale(1);
    pointer-events: auto;
  }

  /* ----- Scene 1 : Device + commande ----- */
  .isoore-journey__device {
    width: 60%;
    aspect-ratio: 3 / 4;
    background: linear-gradient(180deg, #2D3E2B, #3A5038);
    border-radius: 24px;
    padding: 16px;
    box-shadow: 0 20px 40px rgba(45, 62, 43, 0.25);
    animation: isoore-journey-float 4s ease-in-out infinite;
  }
  @keyframes isoore-journey-float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
  }
  .isoore-journey__device-screen {
    width: 100%; height: 100%;
    background: #F7F3EC;
    border-radius: 12px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 10px;
  }
  .isoore-journey__cart-line {
    height: 8px;
    background: rgba(58, 80, 56, 0.15);
    border-radius: 4px;
  }
  .isoore-journey__cart-line--short { width: 60%; }
  .isoore-journey__cart-price {
    font-size: 20px;
    font-weight: 700;
    color: var(--isoore-dark);
    margin-top: 8px;
  }
  .isoore-journey__cart-btn {
    background: var(--isoore-cta);
    color: #fff;
    padding: 10px 14px;
    border-radius: 6px;
    text-align: center;
    font-size: 13px;
    font-weight: 600;
    margin-top: 10px;
  }
  .isoore-journey__check {
    position: absolute;
    top: 16%;
    right: 16%;
    width: 56px; height: 56px;
    color: var(--isoore-cta);
    background: #fff;
    border-radius: 50%;
    padding: 6px;
    box-shadow: 0 10px 20px rgba(122, 171, 114, 0.35);
    animation: isoore-journey-pop 0.6s 0.3s var(--isoore-ease) both;
  }
  @keyframes isoore-journey-pop {
    from { transform: scale(0); }
    50% { transform: scale(1.15); }
    to { transform: scale(1); }
  }

  /* ----- Scene 2 : Carton ----- */
  .isoore-journey__box {
    position: relative;
    width: 55%;
    aspect-ratio: 1 / 1;
    background: linear-gradient(135deg, #d4c2a0 0%, #b8a07d 100%);
    border-radius: 6px;
    box-shadow: 0 16px 32px rgba(45, 62, 43, 0.18);
    transform: rotate(-4deg);
    animation: isoore-journey-rock 3s ease-in-out infinite;
  }
  @keyframes isoore-journey-rock {
    0%, 100% { transform: rotate(-4deg); }
    50% { transform: rotate(2deg); }
  }
  .isoore-journey__box-tape {
    position: absolute;
    left: 0; right: 0; top: 48%;
    height: 14px;
    background: rgba(58, 80, 56, 0.4);
  }
  .isoore-journey__box-label {
    position: absolute;
    top: 24%; left: 50%;
    transform: translateX(-50%);
    color: #fff;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 3px;
  }
  .isoore-journey__box-side {
    position: absolute;
    top: -6px; left: 50%;
    transform: translateX(-50%);
    width: 60%;
    height: 12px;
    background: linear-gradient(180deg, #b08862, transparent);
    border-radius: 6px 6px 0 0;
  }
  .isoore-journey__box--small {
    position: absolute;
    width: 25%;
    bottom: 18%;
    right: 18%;
    transform: rotate(8deg);
    animation-delay: -1.5s;
  }

  /* ===== SVG iso (scenes 3, 4, 5) ===== */
  .isoore-journey__svg-iso {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
  }

  /* Scene 3 : camion qui avance vers la maison */
  .isoore-journey__truck-iso {
    animation: isoore-journey-truck-iso 5s ease-in-out infinite;
  }
  @keyframes isoore-journey-truck-iso {
    0%   { transform: translate(-180px, 340px); }
    55%  { transform: translate(100px, 340px); }
    65%  { transform: translate(100px, 340px); }
    100% { transform: translate(100px, 340px); }
  }
  .isoore-journey__truck-wheels circle:nth-child(3n+1) {
    animation: isoore-journey-spin-iso 0.5s linear infinite;
    transform-origin: 35px 155px;
  }
  .isoore-journey__truck-dust {
    animation: isoore-journey-dust-iso 1.6s ease-in-out infinite;
  }
  @keyframes isoore-journey-dust-iso {
    0%, 100% { opacity: 0.2; transform: translateX(-2px); }
    50%      { opacity: 0.5; transform: translateX(2px); }
  }
  @keyframes isoore-journey-spin-iso {
    to { transform: rotate(360deg); }
  }

  /* Scene 4 : pergola qui se monte */
  .j4-shadow {
    transform-origin: 300px 490px;
    animation: j4-shadow-grow 5s ease-out infinite;
  }
  @keyframes j4-shadow-grow {
    0%, 20%  { opacity: 0; transform: scaleX(0.3); }
    50%      { opacity: 0.2; transform: scaleX(0.6); }
    85%, 100%{ opacity: 0.7; transform: scaleX(1); }
  }
  .j4-pole {
    transform-origin: bottom center;
    animation: j4-pole-build 5s ease-out infinite;
  }
  @keyframes j4-pole-build {
    0%, 10%  { transform: translateY(-180px) scaleY(0.4); opacity: 0; }
    20%      { transform: translateY(-180px) scaleY(0.4); opacity: 1; }
    30%      { transform: translateY(8px) scaleY(1.04); opacity: 1; }
    35%, 100%{ transform: translateY(0) scaleY(1); opacity: 1; }
  }
  .j4-pole.j4-pole--fl { animation-delay: 0s; }
  .j4-pole.j4-pole--fr { animation-delay: 0.15s; }
  .j4-pole.j4-pole--bl { animation-delay: 0.3s; }
  .j4-pole.j4-pole--br { animation-delay: 0.45s; }

  .j4-beam {
    transform-origin: center;
    opacity: 0;
    animation: j4-beam-fade 5s ease-out infinite;
  }
  @keyframes j4-beam-fade {
    0%, 35%  { opacity: 0; transform: scale(0.95); }
    50%, 100%{ opacity: 1; transform: scale(1); }
  }
  .j4-beam--back  { animation-delay: 1.4s; }
  .j4-beam--front { animation-delay: 1.6s; }

  .j4-louvers polygon {
    transform-origin: 296px 230px;
    opacity: 0;
    animation: j4-louver-fade 5s ease-out infinite;
  }
  @keyframes j4-louver-fade {
    0%, 50% { opacity: 0; transform: translateX(-30px) scaleX(0.8); }
    65%, 100% { opacity: 1; transform: translateX(0) scaleX(1); }
  }
  .j4-louvers polygon:nth-child(1)  { animation-delay: 2.00s; }
  .j4-louvers polygon:nth-child(2)  { animation-delay: 2.08s; }
  .j4-louvers polygon:nth-child(3)  { animation-delay: 2.16s; }
  .j4-louvers polygon:nth-child(4)  { animation-delay: 2.24s; }
  .j4-louvers polygon:nth-child(5)  { animation-delay: 2.32s; }
  .j4-louvers polygon:nth-child(6)  { animation-delay: 2.40s; }
  .j4-louvers polygon:nth-child(7)  { animation-delay: 2.48s; }
  .j4-louvers polygon:nth-child(8)  { animation-delay: 2.56s; }
  .j4-louvers polygon:nth-child(9)  { animation-delay: 2.64s; }
  .j4-louvers polygon:nth-child(10) { animation-delay: 2.72s; }

  .j4-worker {
    animation: j4-worker-walk 5s ease-in-out infinite;
  }
  @keyframes j4-worker-walk {
    0%, 5%   { transform: translate(180px, 420px); opacity: 0; }
    15%      { opacity: 1; }
    35%      { transform: translate(220px, 420px); opacity: 1; }
    55%      { transform: translate(290px, 420px); }
    75%      { transform: translate(360px, 420px); }
    95%, 100%{ transform: translate(400px, 420px); opacity: 0; }
  }

  .j4-spark {
    opacity: 0;
    animation: j4-spark-flash 5s linear infinite;
  }
  @keyframes j4-spark-flash {
    0%, 100% { opacity: 0; transform: scale(0.5); }
    5%, 8%   { opacity: 1; transform: scale(1.3); }
    15%      { opacity: 0; transform: scale(0.5); }
  }
  .j4-spark:nth-child(1) { animation-delay: 1.0s; }
  .j4-spark:nth-child(2) { animation-delay: 1.6s; }
  .j4-spark:nth-child(3) { animation-delay: 2.4s; }
  .j4-spark:nth-child(4) { animation-delay: 3.2s; }

  .j4-check {
    opacity: 0;
    transform-origin: center;
    animation: j4-check-pop 5s ease-out infinite;
  }
  @keyframes j4-check-pop {
    0%, 85%  { opacity: 0; transform: scale(0); }
    92%      { opacity: 1; transform: scale(1.2); }
    96%, 100%{ opacity: 1; transform: scale(1); }
  }

  /* Scene 5 : etoiles, lune, ampoules, flamme */
  .j5-stars circle {
    animation: j5-twinkle 3s ease-in-out infinite;
  }
  @keyframes j5-twinkle {
    0%, 100% { opacity: 0.4; }
    50% { opacity: 1; }
  }
  .j5-stars circle:nth-child(2)  { animation-delay: 0.4s; }
  .j5-stars circle:nth-child(3)  { animation-delay: 0.8s; }
  .j5-stars circle:nth-child(4)  { animation-delay: 1.2s; }
  .j5-stars circle:nth-child(5)  { animation-delay: 1.6s; }
  .j5-stars circle:nth-child(6)  { animation-delay: 2.0s; }
  .j5-stars circle:nth-child(7)  { animation-delay: 0.6s; }
  .j5-stars circle:nth-child(8)  { animation-delay: 1.4s; }
  .j5-stars circle:nth-child(9)  { animation-delay: 2.2s; }
  .j5-stars circle:nth-child(10) { animation-delay: 0.2s; }

  /* Guirlande : pas d'animation (statique premium) */
  .j5-bulb { opacity: 1; }

  .j5-flame {
    transform-origin: center bottom;
    animation: j5-flame-flicker 1.4s ease-in-out infinite;
  }
  @keyframes j5-flame-flicker {
    0%, 100% { transform: scale(1) rotate(-2deg); }
    50%      { transform: scale(1.1, 1.18) rotate(3deg); }
  }
  .j5-light-gaps line {
    animation: j5-gap-flicker 4s ease-in-out infinite;
  }
  @keyframes j5-gap-flicker {
    0%, 100% { opacity: 0.7; }
    50%      { opacity: 1; }
  }
  .j5-light-gaps line:nth-child(2n) { animation-delay: 0.5s; }
  .j5-light-gaps line:nth-child(3n) { animation-delay: 1.0s; }

  /* ===== Anciennes scenes 3/4 CSS (preservees pour fallback non utilisees) ===== */
  /* ----- Scene 3 : Camion qui vient vers la maison ----- */
  .isoore-journey__sky-3 {
    position: absolute;
    inset: 0 0 30% 0;
    background: linear-gradient(180deg, #b9d4e8 0%, #e8eef3 70%, #f1ecdc 100%);
  }
  .isoore-journey__sun-3 {
    position: absolute;
    top: 14%; left: 16%;
    width: 38px; height: 38px;
    background: radial-gradient(circle, #fff5cc 30%, #ffd87a 100%);
    border-radius: 50%;
    box-shadow: 0 0 24px rgba(255, 220, 130, 0.55);
  }
  .isoore-journey__hills-3 {
    position: absolute;
    left: -5%; right: -5%;
    bottom: 28%;
    height: 22%;
    background:
      radial-gradient(ellipse 60% 100% at 30% 100%, #8aa285 0%, #8aa285 60%, transparent 65%),
      radial-gradient(ellipse 70% 100% at 75% 100%, #6f8c68 0%, #6f8c68 55%, transparent 60%);
  }
  .isoore-journey__road-3 {
    position: absolute;
    left: -10%; right: -10%;
    bottom: 0;
    height: 30%;
    background: linear-gradient(180deg, #b3a685 0%, #8a7d5f 100%);
  }
  .isoore-journey__road-3::before {
    content: '';
    position: absolute;
    left: 0; right: 0;
    top: 0;
    height: 4px;
    background: var(--isoore-darker);
    opacity: 0.3;
  }

  .isoore-journey__house-3 {
    position: absolute;
    right: 14%;
    bottom: 28%;
    width: 32%;
    z-index: 2;
  }
  .isoore-journey__house-3-roof {
    width: 0; height: 0;
    border-left: 60px solid transparent;
    border-right: 60px solid transparent;
    border-bottom: 42px solid var(--isoore-darker);
    margin: 0 auto;
  }
  .isoore-journey__house-3-body {
    position: relative;
    width: 96%;
    height: 70px;
    background: #fff;
    border: 2px solid var(--isoore-darker);
    margin: 0 auto;
  }
  .isoore-journey__house-3-door {
    position: absolute;
    left: 50%; bottom: 0;
    transform: translateX(-50%);
    width: 18px; height: 32px;
    background: var(--isoore-darker);
    border-radius: 2px 2px 0 0;
  }
  .isoore-journey__house-3-window {
    position: absolute;
    top: 10px;
    width: 16px; height: 16px;
    background: linear-gradient(135deg, #b9d4e8, #e8eef3);
    border: 1.5px solid var(--isoore-darker);
  }
  .isoore-journey__house-3-window--l { left: 12px; }
  .isoore-journey__house-3-window--r { right: 12px; }

  .isoore-journey__truck-3 {
    position: absolute;
    bottom: 16%;
    left: -42%;
    width: 38%;
    height: 26%;
    z-index: 3;
    animation: isoore-journey-arrive 5s ease-out infinite;
  }
  @keyframes isoore-journey-arrive {
    0%   { left: -42%; transform: scale(0.75); }
    55%  { left: 18%;  transform: scale(1); }
    65%  { left: 18%;  transform: scale(1); }
    85%  { left: 18%;  transform: scale(1); }
    100% { left: 18%;  transform: scale(1); opacity: 1; }
  }
  .isoore-journey__truck-3-body {
    position: absolute;
    left: 0;
    bottom: 18%;
    width: 62%;
    height: 78%;
    background: linear-gradient(180deg, #ffffff 0%, #E4DCC8 100%);
    border: 2.5px solid var(--isoore-darker);
    border-radius: 3px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .isoore-journey__truck-3-body span {
    color: var(--isoore-darker);
    font-weight: 800;
    letter-spacing: 4px;
    font-size: 13px;
  }
  .isoore-journey__truck-3-door {
    position: absolute;
    right: 0; top: 0; bottom: 0;
    width: 8px;
    border-left: 2px solid var(--isoore-darker);
  }
  .isoore-journey__truck-3-cab {
    position: absolute;
    right: 0;
    bottom: 18%;
    width: 30%;
    height: 64%;
    background: linear-gradient(180deg, #3A5038, #2D3E2B);
    border-radius: 6px 12px 0 0;
  }
  .isoore-journey__truck-3-window {
    position: absolute;
    top: 14%;
    left: 14%;
    right: 14%;
    height: 50%;
    background: linear-gradient(135deg, #b9d4e8, #6a9cbb);
    border-radius: 3px 8px 0 0;
  }
  .isoore-journey__truck-3-wheel {
    position: absolute;
    bottom: 0;
    width: 18px; height: 18px;
    background: radial-gradient(circle, #888 25%, #222 55%);
    border-radius: 50%;
    border: 2px solid #1a1a1a;
    animation: isoore-journey-spin 0.4s linear infinite;
  }
  @keyframes isoore-journey-spin {
    to { transform: rotate(360deg); }
  }
  .isoore-journey__truck-3-wheel--rear  { left: 12%; }
  .isoore-journey__truck-3-wheel--mid   { left: 36%; }
  .isoore-journey__truck-3-wheel--front { right: 8%; }
  .isoore-journey__truck-3-dust {
    position: absolute;
    left: -10%;
    bottom: 2px;
    height: 18px;
    width: 30%;
    pointer-events: none;
  }
  .isoore-journey__truck-3-dust span {
    position: absolute;
    bottom: 0;
    width: 14px; height: 14px;
    background: radial-gradient(circle, rgba(200, 180, 130, 0.7), transparent 70%);
    border-radius: 50%;
    animation: isoore-journey-dust 1.6s linear infinite;
  }
  .isoore-journey__truck-3-dust span:nth-child(1) { left: 0%; animation-delay: 0s; }
  .isoore-journey__truck-3-dust span:nth-child(2) { left: 25%; animation-delay: -0.5s; }
  .isoore-journey__truck-3-dust span:nth-child(3) { left: 60%; animation-delay: -1.0s; }
  @keyframes isoore-journey-dust {
    0%   { opacity: 0; transform: translateY(0) scale(0.6); }
    50%  { opacity: 0.7; transform: translateY(-12px) scale(1.2); }
    100% { opacity: 0; transform: translateY(-22px) scale(1.6); }
  }

  /* ===== Scene 4 V2 : Pergola se monte solo (premium) ===== */
  .isoore-journey__build-sky {
    position: absolute;
    inset: 0 0 32% 0;
    background:
      radial-gradient(ellipse at 80% 20%, rgba(255, 220, 130, 0.35) 0%, transparent 50%),
      linear-gradient(180deg, #c9dde8 0%, #e8eedb 70%, #f1ecdc 100%);
  }
  .isoore-journey__build-floor-v2 {
    position: absolute;
    left: 0; right: 0;
    bottom: 0;
    height: 32%;
    background:
      repeating-linear-gradient(90deg, transparent 0 38px, rgba(58, 80, 56, 0.05) 38px 40px),
      linear-gradient(180deg, #c5b58e 0%, #a89678 100%);
  }
  .isoore-journey__build-floor-v2::before {
    content: '';
    position: absolute;
    left: 0; right: 0;
    top: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, rgba(45, 62, 43, 0.3), transparent);
  }

  .isoore-journey__pergola-build {
    position: absolute;
    left: 50%;
    bottom: 28%;
    width: 65%;
    height: 52%;
    transform: translateX(-50%);
  }
  .isoore-journey__b-shadow {
    position: absolute;
    left: -8%; right: -8%;
    bottom: -6%;
    height: 14px;
    background: radial-gradient(ellipse at center, rgba(45, 62, 43, 0.42), transparent 70%);
    filter: blur(3px);
    opacity: 0;
    animation: isoore-journey-shadow-grow 6s ease-out infinite;
  }
  @keyframes isoore-journey-shadow-grow {
    0%, 30% { opacity: 0; transform: scaleX(0.4); }
    50% { opacity: 0.5; transform: scaleX(0.7); }
    80%, 100% { opacity: 0.9; transform: scaleX(1); }
  }

  /* 4 poteaux qui descendent du ciel */
  .isoore-journey__b-pole {
    position: absolute;
    width: 10px;
    bottom: 0;
    height: 88%;
    background: linear-gradient(90deg, #4a6048 0%, #2D3E2B 50%, #1f2c1d 100%);
    border-radius: 2px;
    box-shadow: 1px 0 3px rgba(0,0,0,0.25), inset -2px 0 2px rgba(0,0,0,0.2);
    transform: translateY(-220%) scaleY(0.4);
    transform-origin: bottom center;
    opacity: 0;
    animation: isoore-journey-pole-drop-v2 6s ease-out infinite;
  }
  @keyframes isoore-journey-pole-drop-v2 {
    0%, 8%   { transform: translateY(-220%) scaleY(0.4); opacity: 0; }
    18%      { transform: translateY(-220%) scaleY(0.4); opacity: 1; }
    28%      { transform: translateY(2%) scaleY(1.06); opacity: 1; }
    32%      { transform: translateY(-3%) scaleY(0.97); opacity: 1; }
    35%, 100%{ transform: translateY(0) scaleY(1); opacity: 1; }
  }
  .isoore-journey__b-pole--fl { left: 0;        animation-delay: 0s; }
  .isoore-journey__b-pole--fr { right: 0;       animation-delay: 0.15s; }
  .isoore-journey__b-pole--bl { left: 14%;      animation-delay: 0.3s; opacity: 0.55; filter: blur(0.5px); }
  .isoore-journey__b-pole--br { right: 14%;     animation-delay: 0.45s; opacity: 0.55; filter: blur(0.5px); }

  /* Cadre toit qui se trace */
  .isoore-journey__b-beam {
    position: absolute;
    background: linear-gradient(180deg, #4a6048, #2D3E2B);
    border-radius: 2px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.18);
    opacity: 0;
    animation: isoore-journey-beam-build 6s ease-out infinite;
  }
  @keyframes isoore-journey-beam-build {
    0%, 35% { opacity: 0; transform: scaleX(0); }
    45%, 100% { opacity: 1; transform: scaleX(1); }
  }
  .isoore-journey__b-beam--top {
    left: 0; right: 0;
    top: 10%;
    height: 10px;
    transform-origin: left center;
    animation-delay: 1.6s;
  }
  .isoore-journey__b-beam--left, .isoore-journey__b-beam--right {
    width: 10px;
    top: 10%;
    height: 8%;
    transform-origin: top center;
    transform: scaleY(0);
    animation: isoore-journey-beam-side 6s ease-out infinite;
  }
  @keyframes isoore-journey-beam-side {
    0%, 45% { opacity: 0; transform: scaleY(0); }
    55%, 100% { opacity: 1; transform: scaleY(1); }
  }
  .isoore-journey__b-beam--left  { left: 0;  animation-delay: 1.8s; }
  .isoore-journey__b-beam--right { right: 0; animation-delay: 1.95s; }

  /* Lames qui se posent une par une */
  .isoore-journey__b-louvers {
    position: absolute;
    left: 5%; right: 5%;
    top: 15%;
    display: flex;
    flex-direction: column;
    gap: 6px;
  }
  .isoore-journey__b-louvers span {
    display: block;
    height: 5px;
    background: linear-gradient(180deg, #4a6048, #3A5038);
    border-radius: 2px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.16);
    transform: scaleX(0) translateY(-6px);
    transform-origin: left center;
    opacity: 0;
    animation: isoore-journey-louver-place-v2 6s ease-out infinite;
  }
  @keyframes isoore-journey-louver-place-v2 {
    0%, 65% { transform: scaleX(0) translateY(-6px); opacity: 0; }
    78%, 100% { transform: scaleX(1) translateY(0); opacity: 1; }
  }
  .isoore-journey__b-louvers span:nth-child(1)  { animation-delay: 2.50s; }
  .isoore-journey__b-louvers span:nth-child(2)  { animation-delay: 2.58s; }
  .isoore-journey__b-louvers span:nth-child(3)  { animation-delay: 2.66s; }
  .isoore-journey__b-louvers span:nth-child(4)  { animation-delay: 2.74s; }
  .isoore-journey__b-louvers span:nth-child(5)  { animation-delay: 2.82s; }
  .isoore-journey__b-louvers span:nth-child(6)  { animation-delay: 2.90s; }
  .isoore-journey__b-louvers span:nth-child(7)  { animation-delay: 2.98s; }
  .isoore-journey__b-louvers span:nth-child(8)  { animation-delay: 3.06s; }
  .isoore-journey__b-louvers span:nth-child(9)  { animation-delay: 3.14s; }
  .isoore-journey__b-louvers span:nth-child(10) { animation-delay: 3.22s; }

  /* Personnage qui bouge entre les poteaux */
  .isoore-journey__b-worker {
    position: absolute;
    bottom: 28%;
    width: 36px;
    height: 48px;
    animation: isoore-journey-worker 6s ease-in-out infinite;
  }
  .isoore-journey__b-worker svg { width: 100%; height: 100%; }
  @keyframes isoore-journey-worker {
    0%   { left: 10%; opacity: 0; }
    10%  { opacity: 1; }
    25%  { left: 25%; }
    50%  { left: 50%; }
    75%  { left: 75%; }
    90%  { left: 85%; opacity: 1; }
    100% { left: 90%; opacity: 0; }
  }

  /* Etincelles */
  .isoore-journey__b-sparks { position: absolute; inset: 0; pointer-events: none; }
  .isoore-journey__b-sparks span {
    position: absolute;
    width: 10px; height: 10px;
    border-radius: 50%;
    background: radial-gradient(circle, #fff 10%, #ffd87a 40%, transparent 70%);
    box-shadow: 0 0 14px rgba(255, 220, 130, 0.8);
    opacity: 0;
    animation: isoore-journey-spark-v2 6s linear infinite;
  }
  @keyframes isoore-journey-spark-v2 {
    0%, 100% { opacity: 0; transform: scale(0.4); }
    5%       { opacity: 1; transform: scale(1.2); }
    15%      { opacity: 0; transform: scale(0.4) translate(8px, -10px); }
  }
  .isoore-journey__b-sparks span:nth-child(1) { top: 30%; left: 25%; animation-delay: 0.8s; }
  .isoore-journey__b-sparks span:nth-child(2) { top: 35%; right: 30%; animation-delay: 1.6s; }
  .isoore-journey__b-sparks span:nth-child(3) { top: 18%; left: 50%; animation-delay: 2.4s; }
  .isoore-journey__b-sparks span:nth-child(4) { top: 25%; right: 20%; animation-delay: 3.2s; }
  .isoore-journey__b-sparks span:nth-child(5) { top: 32%; left: 65%; animation-delay: 4.0s; }

  /* Outils flottants */
  .isoore-journey__b-tool {
    position: absolute;
    width: 32px; height: 32px;
    background: #fff;
    border-radius: 8px;
    padding: 5px;
    box-shadow: 0 6px 14px rgba(45, 62, 43, 0.18);
  }
  .isoore-journey__b-tool svg { width: 100%; height: 100%; }
  .isoore-journey__b-tool--wrench {
    top: 20%;
    left: 8%;
    animation: isoore-journey-tool-float 3s ease-in-out infinite;
  }
  .isoore-journey__b-tool--drill {
    top: 18%;
    right: 8%;
    animation: isoore-journey-tool-float 3.4s ease-in-out infinite reverse;
    animation-delay: -1.5s;
  }
  @keyframes isoore-journey-tool-float {
    0%, 100% { transform: translateY(0) rotate(-8deg); }
    50%      { transform: translateY(-10px) rotate(6deg); }
  }

  /* Horloge timelapse */
  .isoore-journey__b-clock {
    position: absolute;
    top: 14%;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
  }
  .isoore-journey__b-clock-face {
    width: 32px; height: 32px;
    border-radius: 50%;
    background: #fff;
    border: 2px solid var(--isoore-darker);
    position: relative;
    box-shadow: 0 4px 10px rgba(45, 62, 43, 0.2);
  }
  .isoore-journey__b-clock-hand {
    position: absolute;
    background: var(--isoore-darker);
    border-radius: 2px;
    top: 50%; left: 50%;
    transform-origin: 0 50%;
  }
  .isoore-journey__b-clock-hand--hour {
    width: 8px; height: 2px;
    transform: rotate(0deg);
    animation: isoore-journey-clock-h 6s linear infinite;
  }
  .isoore-journey__b-clock-hand--minute {
    width: 12px; height: 1.5px;
    transform: rotate(0deg);
    animation: isoore-journey-clock-m 6s linear infinite;
  }
  @keyframes isoore-journey-clock-h {
    from { transform: rotate(-90deg); }
    to   { transform: rotate(270deg); }
  }
  @keyframes isoore-journey-clock-m {
    from { transform: rotate(-90deg); }
    to   { transform: rotate(2520deg); }
  }
  .isoore-journey__b-clock-center {
    position: absolute;
    width: 4px; height: 4px;
    border-radius: 50%;
    background: var(--isoore-cta);
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
  }
  .isoore-journey__b-clock-label {
    background: rgba(255, 255, 255, 0.95);
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 10.5px;
    font-weight: 600;
    color: var(--isoore-dark);
    letter-spacing: 0.5px;
    box-shadow: 0 2px 6px rgba(45, 62, 43, 0.12);
  }

  /* === Ancienne scene 4 (preservee pour fallback non utilisee) === */
  .isoore-journey__build-floor {
    position: absolute;
    left: 0; right: 0;
    bottom: 0;
    height: 28%;
    background: linear-gradient(180deg, #e6dcc4 0%, #c5b58e 100%);
  }
  .isoore-journey__build-floor::before {
    content: '';
    position: absolute;
    left: 0; right: 0;
    top: 0;
    height: 3px;
    background: rgba(45, 62, 43, 0.2);
  }
  .isoore-journey__build-stage {
    position: absolute;
    inset: 12% 12% 28% 12%;
  }

  /* Poteaux qui descendent du ciel */
  .isoore-journey__pole-anim {
    position: absolute;
    width: 8px;
    background: linear-gradient(180deg, #4a6048, #2D3E2B);
    border-radius: 2px;
    box-shadow: 1px 0 2px rgba(0,0,0,0.2);
    animation: isoore-journey-pole-drop 5s ease-out infinite;
    transform-origin: bottom center;
  }
  @keyframes isoore-journey-pole-drop {
    0%   { transform: translateY(-220%) scaleY(0.6); opacity: 0; }
    15%  { transform: translateY(-220%) scaleY(0.6); opacity: 0; }
    25%  { transform: translateY(0%) scaleY(1.08); opacity: 1; }
    30%  { transform: translateY(0%) scaleY(0.96); opacity: 1; }
    35%  { transform: translateY(0%) scaleY(1.02); opacity: 1; }
    40%, 100% { transform: translateY(0%) scaleY(1); opacity: 1; }
  }
  .isoore-journey__pole-anim--1 { left: 4%;  bottom: 0; height: 88%; animation-delay: 0s; }
  .isoore-journey__pole-anim--2 { right: 4%; bottom: 0; height: 88%; animation-delay: 0.25s; }
  .isoore-journey__pole-anim--3 { left: 18%; bottom: 0; height: 88%; animation-delay: 0.4s; opacity: 0.7; }
  .isoore-journey__pole-anim--4 { right: 18%; bottom: 0; height: 88%; animation-delay: 0.55s; opacity: 0.7; }

  /* Cadre du toit qui apparait */
  .isoore-journey__frame-anim {
    position: absolute;
    left: 3%; right: 3%;
    top: 12%;
    height: 8px;
    background: var(--isoore-darker);
    border-radius: 2px;
    transform: scaleX(0);
    transform-origin: left center;
    animation: isoore-journey-frame-build 5s ease-out infinite;
  }
  @keyframes isoore-journey-frame-build {
    0%, 40% { transform: scaleX(0); }
    55%, 100% { transform: scaleX(1); }
  }
  .isoore-journey__frame-anim::before, .isoore-journey__frame-anim::after {
    content: '';
    position: absolute;
    top: 6px;
    width: 4px;
    height: 0;
    background: var(--isoore-darker);
    animation: isoore-journey-frame-side 5s ease-out infinite;
  }
  .isoore-journey__frame-anim::before { left: 0; }
  .isoore-journey__frame-anim::after  { right: 0; }
  @keyframes isoore-journey-frame-side {
    0%, 50% { height: 0; }
    65%, 100% { height: 320px; max-height: 80vh; }
  }

  /* Lames qui apparaissent une par une */
  .isoore-journey__louvers-anim {
    position: absolute;
    left: 6%; right: 6%;
    top: 18%;
    height: 6px;
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
  .isoore-journey__louvers-anim span {
    display: block;
    height: 5px;
    background: linear-gradient(180deg, #4a6048, #3A5038);
    border-radius: 2px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.18);
    transform: scaleX(0) translateY(-6px);
    transform-origin: left center;
    animation: isoore-journey-louver-place 5s ease-out infinite;
  }
  @keyframes isoore-journey-louver-place {
    0%, 60% { transform: scaleX(0) translateY(-6px); opacity: 0; }
    75%, 100% { transform: scaleX(1) translateY(0); opacity: 1; }
  }
  .isoore-journey__louvers-anim span:nth-child(1)  { animation-delay: 2.30s; }
  .isoore-journey__louvers-anim span:nth-child(2)  { animation-delay: 2.40s; }
  .isoore-journey__louvers-anim span:nth-child(3)  { animation-delay: 2.50s; }
  .isoore-journey__louvers-anim span:nth-child(4)  { animation-delay: 2.60s; }
  .isoore-journey__louvers-anim span:nth-child(5)  { animation-delay: 2.70s; }
  .isoore-journey__louvers-anim span:nth-child(6)  { animation-delay: 2.80s; }
  .isoore-journey__louvers-anim span:nth-child(7)  { animation-delay: 2.90s; }
  .isoore-journey__louvers-anim span:nth-child(8)  { animation-delay: 3.00s; }
  .isoore-journey__louvers-anim span:nth-child(9)  { animation-delay: 3.10s; }
  .isoore-journey__louvers-anim span:nth-child(10) { animation-delay: 3.20s; }

  /* Etincelle qui suit le montage */
  .isoore-journey__spark {
    position: absolute;
    width: 16px; height: 16px;
    border-radius: 50%;
    background: radial-gradient(circle, #fff 0%, #ffd87a 30%, transparent 70%);
    box-shadow: 0 0 16px rgba(255, 220, 130, 0.9);
    animation: isoore-journey-spark 5s linear infinite;
    pointer-events: none;
  }
  @keyframes isoore-journey-spark {
    0% { top: 100%; left: 4%; opacity: 0; }
    5% { opacity: 1; }
    20% { top: 0%; left: 4%; opacity: 1; }
    40% { top: 0%; left: 96%; opacity: 1; }
    55% { top: 18%; left: 6%; opacity: 1; }
    80% { top: 18%; left: 96%; opacity: 1; }
    85% { opacity: 0; }
    100% { top: 18%; left: 96%; opacity: 0; }
  }

  /* Check vert final */
  .isoore-journey__build-check {
    position: absolute;
    top: 8%; right: -8%;
    width: 52px; height: 52px;
    color: var(--isoore-cta);
    background: #fff;
    border-radius: 50%;
    padding: 6px;
    box-shadow: 0 10px 20px rgba(122, 171, 114, 0.35);
    opacity: 0;
    transform: scale(0);
    animation: isoore-journey-check-pop 5s ease-out infinite;
  }
  @keyframes isoore-journey-check-pop {
    0%, 80% { opacity: 0; transform: scale(0); }
    90% { opacity: 1; transform: scale(1.2); }
    95%, 100% { opacity: 1; transform: scale(1); }
  }

  /* ===== Scene 5 V2 : Premiere soiree (premium) ===== */
  .isoore-journey__evening-v2 {
    position: absolute;
    inset: 0;
    overflow: hidden;
  }
  .isoore-journey__e-sky {
    position: absolute;
    inset: 0 0 28% 0;
    background:
      radial-gradient(ellipse 80% 60% at 80% 30%, rgba(212, 165, 116, 0.65) 0%, transparent 60%),
      linear-gradient(180deg, #1a2548 0%, #3d2e5c 30%, #7e4f6e 55%, #d4926a 80%, #f2c596 100%);
  }
  .isoore-journey__e-stars span {
    position: absolute;
    width: 2px; height: 2px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 0 4px rgba(255, 255, 255, 0.8);
    animation: isoore-journey-twinkle 3s ease-in-out infinite;
  }
  @keyframes isoore-journey-twinkle {
    0%, 100% { opacity: 0.3; transform: scale(0.8); }
    50% { opacity: 1; transform: scale(1.3); }
  }
  .isoore-journey__e-stars span:nth-child(1) { top: 8%;  left: 12%; animation-delay: 0s; }
  .isoore-journey__e-stars span:nth-child(2) { top: 6%;  left: 28%; animation-delay: 0.4s; }
  .isoore-journey__e-stars span:nth-child(3) { top: 12%; left: 40%; animation-delay: 0.8s; }
  .isoore-journey__e-stars span:nth-child(4) { top: 5%;  left: 55%; animation-delay: 1.2s; width: 3px; height: 3px; }
  .isoore-journey__e-stars span:nth-child(5) { top: 10%; left: 68%; animation-delay: 1.6s; }
  .isoore-journey__e-stars span:nth-child(6) { top: 14%; left: 18%; animation-delay: 2.0s; }
  .isoore-journey__e-stars span:nth-child(7) { top: 18%; left: 32%; animation-delay: 0.6s; }
  .isoore-journey__e-stars span:nth-child(8) { top: 8%;  right: 18%; animation-delay: 1.4s; }
  .isoore-journey__e-stars span:nth-child(9) { top: 16%; right: 8%; animation-delay: 2.2s; width: 2.5px; height: 2.5px; }
  .isoore-journey__e-stars span:nth-child(10){ top: 22%; left: 8%; animation-delay: 0.2s; }

  .isoore-journey__e-moon {
    position: absolute;
    top: 12%;
    right: 22%;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: radial-gradient(circle at 35% 35%, #fff8dc 0%, #f5e6a0 60%, #d4b878 100%);
    box-shadow: 0 0 38px rgba(255, 248, 220, 0.55), 0 0 80px rgba(255, 248, 220, 0.25);
  }
  .isoore-journey__e-moon::before, .isoore-journey__e-moon::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    background: rgba(160, 140, 100, 0.18);
  }
  .isoore-journey__e-moon::before { width: 12px; height: 12px; top: 25%; left: 30%; }
  .isoore-journey__e-moon::after { width: 7px; height: 7px; bottom: 25%; right: 25%; }

  /* Pergola elegante */
  .isoore-journey__e-pergola {
    position: absolute;
    left: 12%;
    right: 12%;
    bottom: 24%;
    height: 48%;
  }
  .isoore-journey__e-glow {
    position: absolute;
    inset: 14% 4% 0;
    background:
      radial-gradient(ellipse at center 40%, rgba(255, 200, 130, 0.6) 0%, rgba(255, 200, 130, 0.2) 40%, transparent 70%);
    animation: isoore-journey-glow-pulse 4s ease-in-out infinite;
    z-index: 1;
  }
  @keyframes isoore-journey-glow-pulse {
    0%, 100% { opacity: 0.75; }
    50% { opacity: 1; }
  }

  /* Guirlande lumineuse */
  .isoore-journey__e-garland {
    position: absolute;
    left: 6%; right: 6%;
    top: 24%;
    display: flex;
    justify-content: space-between;
    z-index: 4;
  }
  .isoore-journey__e-garland span {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: radial-gradient(circle, #fff8dc 30%, #ffd87a 100%);
    box-shadow: 0 0 8px rgba(255, 216, 122, 0.95), 0 0 16px rgba(255, 216, 122, 0.5);
    animation: isoore-journey-bulb 2s ease-in-out infinite;
  }
  @keyframes isoore-journey-bulb {
    0%, 100% { opacity: 0.85; }
    50% { opacity: 1; box-shadow: 0 0 12px rgba(255, 216, 122, 1), 0 0 24px rgba(255, 216, 122, 0.7); }
  }
  .isoore-journey__e-garland span:nth-child(1) { animation-delay: 0s; }
  .isoore-journey__e-garland span:nth-child(2) { animation-delay: 0.3s; }
  .isoore-journey__e-garland span:nth-child(3) { animation-delay: 0.6s; }
  .isoore-journey__e-garland span:nth-child(4) { animation-delay: 0.9s; }
  .isoore-journey__e-garland span:nth-child(5) { animation-delay: 1.2s; }
  .isoore-journey__e-garland span:nth-child(6) { animation-delay: 0.5s; }
  .isoore-journey__e-garland span:nth-child(7) { animation-delay: 0.2s; }
  .isoore-journey__e-garland span:nth-child(8) { animation-delay: 0.8s; }

  /* Toit pergola sombre */
  .isoore-journey__e-roof {
    position: absolute;
    left: 0; right: 0;
    top: 14%;
    height: 14%;
    background: linear-gradient(180deg, #1a2418 0%, #0e1810 100%);
    border-radius: 2px;
    box-shadow: 0 4px 14px rgba(0,0,0,0.4);
    z-index: 3;
  }
  .isoore-journey__e-louvers {
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(90deg,
      transparent 0px,
      transparent 4px,
      rgba(255, 200, 130, 0.18) 4px,
      rgba(255, 200, 130, 0.18) 6px,
      transparent 6px,
      transparent 14px);
  }
  .isoore-journey__e-pole {
    position: absolute;
    width: 8px;
    bottom: 0;
    top: 28%;
    background: linear-gradient(90deg, #0e1810 0%, #1a2418 50%, #0e1810 100%);
    z-index: 3;
  }
  .isoore-journey__e-pole--l { left: 4%; }
  .isoore-journey__e-pole--r { right: 4%; }
  .isoore-journey__e-pole--bl { left: 14%; background: linear-gradient(90deg, #0a1108 0%, #14201a 100%); opacity: 0.6; }
  .isoore-journey__e-pole--br { right: 14%; background: linear-gradient(90deg, #0a1108 0%, #14201a 100%); opacity: 0.6; }

  /* Scene au sol : chaises + table */
  .isoore-journey__e-scene {
    position: absolute;
    left: 20%;
    right: 20%;
    bottom: 8%;
    height: 24%;
    z-index: 5;
  }
  .isoore-journey__e-chair {
    position: absolute;
    bottom: 0;
    width: 14%;
    height: 50%;
    background: linear-gradient(180deg, rgba(40, 30, 20, 0.7), rgba(80, 60, 40, 0.7));
    border-radius: 4px 4px 2px 2px;
  }
  .isoore-journey__e-chair::before {
    content: '';
    position: absolute;
    left: 0; right: 0;
    top: -30%;
    height: 60%;
    background: linear-gradient(180deg, rgba(30, 20, 14, 0.7), rgba(60, 45, 30, 0.7));
    border-radius: 3px 3px 0 0;
  }
  .isoore-journey__e-chair--l { left: 8%; }
  .isoore-journey__e-chair--r { right: 8%; }

  .isoore-journey__e-table {
    position: absolute;
    left: 30%;
    right: 30%;
    bottom: 18%;
    height: 8%;
  }
  .isoore-journey__e-table-top {
    position: absolute;
    inset: 0 0 auto 0;
    height: 4px;
    background: linear-gradient(180deg, rgba(212, 165, 116, 0.95), rgba(160, 110, 60, 0.85));
    border-radius: 1px;
    box-shadow: 0 1px 4px rgba(0,0,0,0.35);
  }
  .isoore-journey__e-table-leg {
    position: absolute;
    left: 50%; top: 4px;
    transform: translateX(-50%);
    width: 4px; bottom: -100%;
    background: rgba(80, 50, 30, 0.65);
  }

  .isoore-journey__e-candle {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 28%;
    z-index: 6;
  }
  .isoore-journey__e-candle-body {
    width: 4px; height: 10px;
    background: linear-gradient(180deg, #f5e6a0, #d4b878);
    border-radius: 1px;
    margin: 0 auto;
  }
  .isoore-journey__e-candle-flame {
    width: 5px; height: 10px;
    background: radial-gradient(ellipse at 50% 70%, #fff5cc 10%, #ffd87a 40%, #ff9540 80%, transparent 100%);
    border-radius: 50% 50% 50% 50% / 70% 70% 30% 30%;
    margin: -2px auto 0;
    box-shadow: 0 0 12px rgba(255, 200, 130, 0.9), 0 0 28px rgba(255, 165, 80, 0.5);
    animation: isoore-journey-flame 1.4s ease-in-out infinite;
    transform-origin: 50% 100%;
  }
  @keyframes isoore-journey-flame {
    0%, 100% { transform: scale(1) rotate(-2deg); }
    50%      { transform: scale(1.08, 1.15) rotate(3deg); }
  }

  .isoore-journey__e-glass {
    position: absolute;
    bottom: 30%;
    width: 8px; height: 14px;
    background: linear-gradient(180deg, rgba(255, 245, 200, 0.85), rgba(255, 220, 120, 0.55));
    border-radius: 2px 2px 6px 6px;
    box-shadow: 0 0 6px rgba(255, 220, 130, 0.4);
    z-index: 6;
  }
  .isoore-journey__e-glass-stem {
    position: absolute;
    left: 50%; top: 100%;
    transform: translateX(-50%);
    width: 1.5px; height: 8px;
    background: rgba(80, 50, 30, 0.55);
  }
  .isoore-journey__e-glass--l { left: 30%; }
  .isoore-journey__e-glass--r { right: 30%; }

  .isoore-journey__e-ground {
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 28%;
    background:
      radial-gradient(ellipse at 50% 0%, rgba(255, 200, 130, 0.25) 0%, transparent 50%),
      linear-gradient(180deg, #6b4d34 0%, #3d2c1c 100%);
  }
  .isoore-journey__e-pergola-shadow {
    position: absolute;
    left: 18%; right: 18%;
    bottom: 26%;
    height: 8px;
    background: radial-gradient(ellipse, rgba(0, 0, 0, 0.5), transparent 70%);
    filter: blur(4px);
  }

  /* ===== Ancienne scene 5 (preservee mais inutilisee) ===== */
  .isoore-journey__evening {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, #2c3e6b 0%, #5a4868 50%, #d4a574 100%);
  }
  .isoore-journey__sky-dusk { display: none; }
  .isoore-journey__moon {
    position: absolute;
    top: 14%; right: 18%;
    width: 44px; height: 44px;
    background: radial-gradient(circle, #fffacd 30%, #f5e6a0 100%);
    border-radius: 50%;
    box-shadow: 0 0 28px rgba(255, 250, 205, 0.6);
  }
  .isoore-journey__pergola-night {
    position: absolute;
    left: 18%;
    right: 18%;
    bottom: 22%;
    height: 38%;
  }
  .isoore-journey__pergola-roof {
    position: absolute;
    top: 0;
    left: 0; right: 0;
    height: 12%;
    background:
      repeating-linear-gradient(90deg, #1a2418 0 6%, transparent 6% 11%),
      linear-gradient(180deg, #2D3E2B, #1a2418);
    border-radius: 2px;
  }
  .isoore-journey__pergola-pole {
    position: absolute;
    top: 12%;
    bottom: 0;
    width: 8px;
    background: #1a2418;
  }
  .isoore-journey__pergola-pole--l { left: 0; }
  .isoore-journey__pergola-pole--r { right: 0; }
  .isoore-journey__pergola-glow {
    position: absolute;
    inset: 12% 8% 0;
    background: radial-gradient(ellipse at center top, rgba(255, 200, 130, 0.5), transparent 60%);
    animation: isoore-journey-flicker 3s ease-in-out infinite;
  }
  @keyframes isoore-journey-flicker {
    0%, 100% { opacity: 0.7; }
    50% { opacity: 1; }
  }
  .isoore-journey__table {
    position: absolute;
    left: 30%; right: 30%;
    bottom: 18%;
    height: 18px;
    background: linear-gradient(180deg, rgba(212, 165, 116, 0.85), rgba(160, 110, 60, 0.85));
    border-radius: 2px;
  }
  .isoore-journey__glass {
    position: absolute;
    bottom: 100%;
    width: 12px; height: 22px;
    background: linear-gradient(180deg, rgba(255, 245, 200, 0.85), rgba(255, 220, 120, 0.6));
    border-radius: 2px 2px 6px 6px;
  }
  .isoore-journey__glass--1 { left: 22%; }
  .isoore-journey__glass--2 { right: 22%; }

  /* ----- Scene 6 : Chat SAV ----- */
  .isoore-journey__chat {
    width: 70%;
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .isoore-journey__bubble {
    padding: 12px 18px;
    border-radius: 18px;
    font-size: 14px;
    max-width: 80%;
    animation: isoore-journey-bubble-in 0.4s var(--isoore-ease) both;
  }
  @keyframes isoore-journey-bubble-in {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
  }
  .isoore-journey__bubble--in {
    background: #fff;
    color: var(--isoore-dark);
    align-self: flex-start;
    border-bottom-left-radius: 4px;
    animation-delay: 0s;
  }
  .isoore-journey__bubble--out {
    background: var(--isoore-cta);
    color: #fff;
    align-self: flex-end;
    border-bottom-right-radius: 4px;
    animation-delay: 0.4s;
  }
  .isoore-journey__bubble--typing {
    animation-delay: 0.9s;
    display: inline-flex;
    gap: 4px;
    padding: 16px 18px;
  }
  .isoore-journey__bubble--typing span {
    width: 6px; height: 6px;
    background: var(--isoore-text);
    border-radius: 50%;
    opacity: 0.4;
    animation: isoore-journey-dot 1.2s infinite;
  }
  .isoore-journey__bubble--typing span:nth-child(2) { animation-delay: 0.2s; }
  .isoore-journey__bubble--typing span:nth-child(3) { animation-delay: 0.4s; }
  @keyframes isoore-journey-dot {
    0%, 100% { opacity: 0.3; transform: scale(0.8); }
    50% { opacity: 1; transform: scale(1.1); }
  }
  .isoore-journey__signal {
    position: absolute;
    top: 12%; right: 14%;
    width: 38px; height: 38px;
    color: var(--isoore-cta);
    background: #fff;
    border-radius: 50%;
    padding: 8px;
    box-shadow: 0 8px 20px rgba(122, 171, 114, 0.3);
  }
  .isoore-journey__signal svg { width: 100%; height: 100%; }

  /* ====== Steps a droite ====== */
  .isoore-journey__steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 28px;
    counter-reset: jstep;
  }
  .isoore-journey__step {
    counter-increment: jstep;
    padding: 24px 28px 24px 80px;
    background: #fff;
    border: 1px solid var(--isoore-border, #E4DCC8);
    border-radius: var(--isoore-radius-md, 8px);
    position: relative;
    transition: all 0.45s var(--isoore-ease);
    opacity: 0.45;
    transform: scale(0.985);
  }
  .isoore-journey__step::before {
    content: counter(jstep);
    position: absolute;
    left: 22px;
    top: 28px;
    width: 38px; height: 38px;
    border-radius: 50%;
    background: var(--isoore-border);
    color: var(--isoore-text);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 700;
    transition: all 0.45s var(--isoore-ease);
  }
  .isoore-journey__step::after {
    content: '';
    position: absolute;
    left: 40px;
    top: 70px;
    bottom: -28px;
    width: 2px;
    background: linear-gradient(180deg, var(--isoore-border), transparent);
  }
  .isoore-journey__step:last-child::after { display: none; }

  .isoore-journey__step.is-active {
    opacity: 1;
    transform: scale(1);
    border-color: var(--isoore-cta, #7AAB72);
    background: linear-gradient(135deg, #ffffff 0%, rgba(122, 171, 114, 0.06) 100%);
    box-shadow: 0 12px 32px rgba(45, 62, 43, 0.1);
  }
  .isoore-journey__step.is-active::before {
    background: var(--isoore-cta, #7AAB72);
    color: #fff;
    transform: scale(1.08);
    box-shadow: 0 6px 18px rgba(122, 171, 114, 0.4);
  }
  .isoore-journey__step.is-done {
    opacity: 0.75;
  }
  .isoore-journey__step.is-done::before {
    background: rgba(122, 171, 114, 0.2);
    color: var(--isoore-cta);
  }

  .isoore-journey__step-time {
    display: inline-block;
    font-size: 11px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--isoore-cta, #7AAB72);
    margin-bottom: 6px;
    font-weight: 500;
  }
  .isoore-journey__step-title {
    margin: 0 0 10px;
    font-size: 19px;
    font-weight: 500;
    color: var(--isoore-dark);
    letter-spacing: -0.2px;
  }
  .isoore-journey__step p {
    margin: 0;
    font-size: 14px;
    line-height: 1.6;
    color: var(--isoore-text);
    opacity: 0.85;
  }

  /* ====== Final CTA ====== */
  .isoore-journey__final {
    margin-top: 64px;
    text-align: center;
  }
  .isoore-journey__final-text {
    margin: 0 0 18px;
    font-size: 18px;
    font-weight: 500;
    color: var(--isoore-dark);
  }
  .isoore-journey__final-ctas {
    display: inline-flex;
    gap: 14px;
    flex-wrap: wrap;
    justify-content: center;
  }
  .isoore-journey__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 28px;
    border-radius: var(--isoore-radius-md, 8px);
    text-decoration: none;
    font-size: 15px;
    font-weight: 600;
    transition: transform 0.22s var(--isoore-ease), box-shadow 0.22s var(--isoore-ease);
  }
  .isoore-journey__cta--primary {
    background: var(--isoore-cta);
    color: #fff;
  }
  .isoore-journey__cta--primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 28px rgba(122, 171, 114, 0.36);
  }
  .isoore-journey__cta--ghost {
    background: transparent;
    color: var(--isoore-dark);
    border: 1.5px solid var(--isoore-dark);
  }
  .isoore-journey__cta--ghost:hover {
    background: var(--isoore-dark);
    color: #fff;
    transform: translateY(-2px);
  }

  /* Responsive */
  @media (max-width: 989px) {
    .isoore-journey__container { padding: 0 24px; }
    .isoore-journey__stage { grid-template-columns: 1fr; gap: 28px; }
    .isoore-journey__viz-wrap { position: relative; top: 0; }
    .isoore-journey__viz { aspect-ratio: 16 / 10; }
    .isoore-journey__step { padding: 18px 18px 18px 64px; }
    .isoore-journey__step::before { left: 16px; top: 18px; width: 32px; height: 32px; font-size: 12px; }
    .isoore-journey__step::after { left: 32px; top: 54px; }
  }

  @media (prefers-reduced-motion: reduce) {
    .isoore-journey__scene { transition: opacity 0.2s !important; transform: none !important; }
    .isoore-journey__device, .isoore-journey__box, .isoore-journey__truck,
    .isoore-journey__build-louvers span, .isoore-journey__build-tool,
    .isoore-journey__pergola-glow, .isoore-journey__bubble, .isoore-journey__bubble--typing span {
      animation: none !important;
    }
  }
/* END_SECTION:isoore-product-journey */

/* START_SECTION:isoore-product-louvers (INDEX:49) */
.isoore-product-louvers {
    background: var(--isoore-bg, #F4F0E6);
    color: var(--isoore-text, #0E0E0C);
    padding: var(--isoore-section-pad, 88px) 0;
  }
  .isoore-product-louvers__container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 56px;
  }
  .isoore-product-louvers__header {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 48px;
  }
  .isoore-product-louvers__title {
    margin: 12px 0 14px;
    font-size: clamp(28px, 3.4vw, 42px);
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -0.5px;
    color: var(--isoore-dark, #0E0E0C);
  }
  .isoore-product-louvers__subtitle {
    margin: 0;
    font-size: 16px;
    line-height: 1.65;
    color: var(--isoore-text, #0E0E0C);
    opacity: 0.85;
  }

  /* ===== Scène ===== */
  .isoore-product-louvers__stage {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    gap: 56px;
    align-items: center;
  }

  .isoore-product-louvers__scene {
    position: relative;
    aspect-ratio: 4 / 3;
    border-radius: var(--isoore-radius-lg, 12px);
    overflow: hidden;
    background: linear-gradient(180deg, #b9d4e8 0%, #e4eef3 60%, #F4F0E6 100%);
    transition: background 0.8s var(--isoore-ease);
    box-shadow: 0 18px 48px rgba(45, 62, 43, 0.12);
  }

  .isoore-product-louvers__sky {
    position: absolute;
    inset: 0;
    background:
      radial-gradient(circle at 80% 20%, rgba(255, 220, 130, 0.55), transparent 45%),
      linear-gradient(180deg, rgba(185, 212, 232, 0) 0%, rgba(241, 236, 220, 0.6) 100%);
    transition: opacity 0.6s var(--isoore-ease);
  }

  /* Rayons soleil */
  .isoore-product-louvers__beams {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 70%;
    height: 50%;
    display: flex;
    justify-content: space-around;
    transform-origin: top center;
  }
  .isoore-product-louvers__beams span {
    display: block;
    width: 2px;
    height: 100%;
    background: linear-gradient(180deg, rgba(255, 220, 130, 0.85), rgba(255, 220, 130, 0));
    transition: opacity 0.4s var(--isoore-ease);
  }

  /* Pluie : gouttes CSS qui tombent */
  .isoore-product-louvers__rain {
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.4s var(--isoore-ease);
    overflow: hidden;
  }
  .isoore-product-louvers__rain span {
    position: absolute;
    top: -10%;
    width: 2px;
    height: 14px;
    background: linear-gradient(180deg, rgba(170, 192, 210, 0), rgba(140, 165, 190, 0.85));
    border-radius: 1px;
    animation: isoore-louvers-rain 1s linear infinite;
  }
  /* 40 gouttes placées aléatoirement (positions/délais fixes pour stabilité) */
  .isoore-product-louvers__rain span:nth-child(1)  { left:  3%; animation-delay: -0.10s; animation-duration: 0.95s; }
  .isoore-product-louvers__rain span:nth-child(2)  { left:  8%; animation-delay: -0.55s; animation-duration: 1.05s; }
  .isoore-product-louvers__rain span:nth-child(3)  { left: 13%; animation-delay: -0.20s; animation-duration: 0.85s; }
  .isoore-product-louvers__rain span:nth-child(4)  { left: 18%; animation-delay: -0.75s; animation-duration: 1.10s; }
  .isoore-product-louvers__rain span:nth-child(5)  { left: 22%; animation-delay: -0.35s; animation-duration: 0.90s; }
  .isoore-product-louvers__rain span:nth-child(6)  { left: 27%; animation-delay: -0.85s; animation-duration: 1.00s; }
  .isoore-product-louvers__rain span:nth-child(7)  { left: 32%; animation-delay: -0.15s; animation-duration: 1.05s; }
  .isoore-product-louvers__rain span:nth-child(8)  { left: 37%; animation-delay: -0.60s; animation-duration: 0.95s; }
  .isoore-product-louvers__rain span:nth-child(9)  { left: 42%; animation-delay: -0.30s; animation-duration: 0.85s; }
  .isoore-product-louvers__rain span:nth-child(10) { left: 47%; animation-delay: -0.70s; animation-duration: 1.05s; }
  .isoore-product-louvers__rain span:nth-child(11) { left: 52%; animation-delay: -0.40s; animation-duration: 0.90s; }
  .isoore-product-louvers__rain span:nth-child(12) { left: 57%; animation-delay: -0.80s; animation-duration: 1.10s; }
  .isoore-product-louvers__rain span:nth-child(13) { left: 62%; animation-delay: -0.05s; animation-duration: 0.95s; }
  .isoore-product-louvers__rain span:nth-child(14) { left: 67%; animation-delay: -0.50s; animation-duration: 1.00s; }
  .isoore-product-louvers__rain span:nth-child(15) { left: 72%; animation-delay: -0.25s; animation-duration: 0.85s; }
  .isoore-product-louvers__rain span:nth-child(16) { left: 77%; animation-delay: -0.65s; animation-duration: 1.05s; }
  .isoore-product-louvers__rain span:nth-child(17) { left: 82%; animation-delay: -0.45s; animation-duration: 0.95s; }
  .isoore-product-louvers__rain span:nth-child(18) { left: 87%; animation-delay: -0.90s; animation-duration: 1.10s; }
  .isoore-product-louvers__rain span:nth-child(19) { left: 92%; animation-delay: -0.20s; animation-duration: 0.90s; }
  .isoore-product-louvers__rain span:nth-child(20) { left: 97%; animation-delay: -0.55s; animation-duration: 1.00s; }
  .isoore-product-louvers__rain span:nth-child(21) { left:  5%; animation-delay: -0.35s; animation-duration: 0.95s; }
  .isoore-product-louvers__rain span:nth-child(22) { left: 11%; animation-delay: -0.80s; animation-duration: 1.05s; }
  .isoore-product-louvers__rain span:nth-child(23) { left: 16%; animation-delay: -0.15s; animation-duration: 0.85s; }
  .isoore-product-louvers__rain span:nth-child(24) { left: 21%; animation-delay: -0.60s; animation-duration: 1.10s; }
  .isoore-product-louvers__rain span:nth-child(25) { left: 26%; animation-delay: -0.40s; animation-duration: 0.95s; }
  .isoore-product-louvers__rain span:nth-child(26) { left: 31%; animation-delay: -0.85s; animation-duration: 1.00s; }
  .isoore-product-louvers__rain span:nth-child(27) { left: 36%; animation-delay: -0.10s; animation-duration: 0.85s; }
  .isoore-product-louvers__rain span:nth-child(28) { left: 41%; animation-delay: -0.55s; animation-duration: 1.05s; }
  .isoore-product-louvers__rain span:nth-child(29) { left: 46%; animation-delay: -0.25s; animation-duration: 0.95s; }
  .isoore-product-louvers__rain span:nth-child(30) { left: 51%; animation-delay: -0.70s; animation-duration: 1.10s; }
  .isoore-product-louvers__rain span:nth-child(31) { left: 56%; animation-delay: -0.45s; animation-duration: 0.90s; }
  .isoore-product-louvers__rain span:nth-child(32) { left: 61%; animation-delay: -0.90s; animation-duration: 1.00s; }
  .isoore-product-louvers__rain span:nth-child(33) { left: 66%; animation-delay: -0.20s; animation-duration: 0.85s; }
  .isoore-product-louvers__rain span:nth-child(34) { left: 71%; animation-delay: -0.65s; animation-duration: 1.05s; }
  .isoore-product-louvers__rain span:nth-child(35) { left: 76%; animation-delay: -0.30s; animation-duration: 0.95s; }
  .isoore-product-louvers__rain span:nth-child(36) { left: 81%; animation-delay: -0.75s; animation-duration: 1.10s; }
  .isoore-product-louvers__rain span:nth-child(37) { left: 86%; animation-delay: -0.50s; animation-duration: 0.90s; }
  .isoore-product-louvers__rain span:nth-child(38) { left: 91%; animation-delay: -0.05s; animation-duration: 1.00s; }
  .isoore-product-louvers__rain span:nth-child(39) { left: 96%; animation-delay: -0.40s; animation-duration: 0.85s; }
  .isoore-product-louvers__rain span:nth-child(40) { left:  1%; animation-delay: -0.85s; animation-duration: 1.05s; }
  @keyframes isoore-louvers-rain {
    0%   { transform: translateY(0); opacity: 0; }
    20%  { opacity: 1; }
    80%  { opacity: 1; }
    100% { transform: translateY(120%); opacity: 0; }
  }

  /* Pergola — couleur gris anthracite RAL 7016 */
  .isoore-product-louvers__frame {
    position: absolute;
    left: 8%;
    right: 8%;
    top: 28%;
    bottom: 14%;
    border-left: 5px solid #2C2F33;
    border-right: 5px solid #2C2F33;
    border-radius: 2px;
  }
  .isoore-product-louvers__frame::before,
  .isoore-product-louvers__frame::after {
    content: '';
    position: absolute;
    left: -5px;
    right: -5px;
    height: 7px;
    background: #2C2F33;
    border-radius: 2px;
  }
  .isoore-product-louvers__frame::before { top: -12px; }
  .isoore-product-louvers__frame::after { bottom: -8px; }

  /* Lames */
  .isoore-product-louvers__louvers {
    position: absolute;
    inset: 8px 4px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    perspective: 600px;
  }
  .isoore-product-louvers__louver {
    flex: 1;
    margin: 2px 0;
    background: linear-gradient(180deg, #3A3F43, #2C2F33);
    border-radius: 3px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.25);
    transform-origin: center center;
    transform-style: preserve-3d;
    transition: transform 0.5s var(--isoore-ease);
    will-change: transform;
    --angle: 50deg;
    transform: rotateX(var(--angle));
    position: relative;
  }
  .isoore-product-louvers__louver::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.06), transparent);
    border-radius: inherit;
    pointer-events: none;
  }

  /* Sol */
  .isoore-product-louvers__floor {
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 14%;
    background: linear-gradient(180deg, rgba(197, 181, 142, 0.6), rgba(150, 130, 90, 0.85));
  }

  /* Readout lumière (haut gauche) */
  .isoore-product-louvers__readout {
    position: absolute;
    top: 18px;
    left: 18px;
    padding: 8px 14px;
    background: rgba(244, 240, 230, 0.92);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-radius: 999px;
    box-shadow: 0 2px 8px rgba(14, 14, 12, 0.1);
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--isoore-dark, #0E0E0C);
    z-index: 5;
  }
  .isoore-product-louvers__readout-label {
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 500;
    opacity: 0.7;
  }
  .isoore-product-louvers__readout-value {
    font-weight: 700;
    font-size: 14px;
    color: var(--isoore-cta, #2D3E2B);
    transition: color 0.3s var(--isoore-ease);
    min-width: 38px;
  }

  /* Weather indicator (haut droite) */
  .isoore-product-louvers__weather {
    position: absolute;
    top: 18px;
    right: 18px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    background: rgba(244, 240, 230, 0.95);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-radius: 999px;
    box-shadow: 0 2px 10px rgba(45, 62, 43, 0.12);
    font-size: 12px;
    font-weight: 600;
    color: var(--isoore-dark, #0E0E0C);
    letter-spacing: 0.3px;
    z-index: 5;
  }
  .isoore-product-louvers__weather-sun,
  .isoore-product-louvers__weather-rain {
    width: 16px; height: 16px;
    transition: opacity 0.4s var(--isoore-ease), transform 0.4s var(--isoore-ease);
    position: absolute;
    left: 12px;
  }
  .isoore-product-louvers__weather-sun { color: var(--isoore-cta, #2D3E2B); }
  .isoore-product-louvers__weather-rain {
    color: #6a92b8;
    opacity: 0;
    transform: scale(0.7);
  }
  .isoore-product-louvers__weather.is-rain .isoore-product-louvers__weather-sun {
    opacity: 0; transform: scale(0.7);
  }
  .isoore-product-louvers__weather.is-rain .isoore-product-louvers__weather-rain {
    opacity: 1; transform: scale(1);
  }
  .isoore-product-louvers__weather-label {
    margin-left: 22px;
  }

  /* ===== Contrôles ===== */
  .isoore-product-louvers__controls {
    display: flex;
    flex-direction: column;
    gap: 32px;
  }

  .isoore-product-louvers__presets {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
  }
  .isoore-product-louvers__preset {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 16px 8px;
    border: 1.5px solid var(--isoore-border, #E8E2D3);
    border-radius: var(--isoore-radius-md, 8px);
    background: #fff;
    color: var(--isoore-text, #0E0E0C);
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.25s var(--isoore-ease);
  }
  .isoore-product-louvers__preset svg { width: 22px; height: 22px; color: var(--isoore-cta, #2D3E2B); }
  .isoore-product-louvers__preset:hover { transform: translateY(-2px); border-color: var(--isoore-cta, #2D3E2B); }
  .isoore-product-louvers__preset.is-active {
    border-color: var(--isoore-cta, #2D3E2B);
    background: rgba(45, 62, 43, 0.08);
    box-shadow: 0 0 0 3px rgba(45, 62, 43, 0.15);
  }

  /* Slider */
  .isoore-product-louvers__slider-wrap {
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  .isoore-product-louvers__slider-label {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 13px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--isoore-text, #0E0E0C);
    opacity: 0.85;
  }
  .isoore-product-louvers__angle {
    font-size: 16px;
    font-weight: 700;
    color: var(--isoore-cta, #2D3E2B);
    letter-spacing: 0;
    text-transform: none;
    opacity: 1;
  }
  .isoore-product-louvers__slider {
    appearance: none;
    -webkit-appearance: none;
    width: 100%;
    height: 6px;
    background: linear-gradient(90deg, var(--isoore-cta) 0%, var(--isoore-cta) var(--fill, 55%), var(--isoore-border, #E8E2D3) var(--fill, 55%), var(--isoore-border, #E8E2D3) 100%);
    border-radius: 3px;
    outline: none;
    cursor: pointer;
  }
  .isoore-product-louvers__slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: #fff;
    border: 3px solid var(--isoore-cta, #2D3E2B);
    cursor: grab;
    box-shadow: 0 2px 8px rgba(14, 14, 12, 0.2);
    transition: transform 0.15s var(--isoore-ease);
  }
  .isoore-product-louvers__slider::-webkit-slider-thumb:active { cursor: grabbing; transform: scale(1.15); }
  .isoore-product-louvers__slider::-moz-range-thumb {
    width: 22px; height: 22px; border-radius: 50%;
    background: #fff; border: 3px solid var(--isoore-cta, #2D3E2B);
    cursor: grab;
  }
  .isoore-product-louvers__slider-legend {
    display: flex; justify-content: space-between;
    font-size: 11px; letter-spacing: 1px; text-transform: uppercase;
    color: var(--isoore-text, #0E0E0C); opacity: 0.6;
  }

  /* Bénéfices */
  .isoore-product-louvers__benefits {
    list-style: none;
    margin: 56px 0 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
  }
  .isoore-product-louvers__benefits li {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 22px 24px;
    border-radius: var(--isoore-radius-md, 8px);
    background: #fff;
    border: 1px solid var(--isoore-border, #E8E2D3);
  }
  .isoore-product-louvers__benefits strong {
    font-size: 14px;
    font-weight: 600;
    color: var(--isoore-dark, #0E0E0C);
  }
  .isoore-product-louvers__benefits span {
    font-size: 13px;
    line-height: 1.55;
    color: var(--isoore-text, #0E0E0C);
    opacity: 0.8;
  }

  /* Responsive */
  @media (max-width: 989px) {
    .isoore-product-louvers__container { padding: 0 20px; }
    .isoore-product-louvers__stage { grid-template-columns: 1fr; gap: 28px; }
    .isoore-product-louvers__scene { aspect-ratio: 1 / 1; }
    .isoore-product-louvers__benefits { grid-template-columns: 1fr; gap: 12px; margin-top: 36px; }
    .isoore-product-louvers__title { font-size: 26px; }
    .isoore-product-louvers__subtitle { font-size: 14.5px; }
  }

  @media (prefers-reduced-motion: reduce) {
    .isoore-product-louvers__louver { transition: none !important; }
    .isoore-product-louvers__scene { transition: none !important; }
    .isoore-product-louvers__beams span { transition: none !important; }
    .isoore-product-louvers__rain span { animation: none !important; }
  }
/* END_SECTION:isoore-product-louvers */

/* START_SECTION:isoore-product-multicontact (INDEX:50) */
.isoore-multicontact {
    background: var(--isoore-darker, #2D3E2B);
    color: #F4F0E6;
    padding: 64px 0;
  }
  .isoore-multicontact__container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 56px;
  }
  .isoore-multicontact__inner {
    text-align: center;
  }
  .isoore-multicontact__header {
    max-width: 720px;
    margin: 0 auto 36px;
  }
  .isoore-multicontact__header .isoore-kicker {
    color: rgba(244, 240, 230, 0.8);
    opacity: 1;
  }
  .isoore-multicontact__header .isoore-kicker::before {
    background: #F4F0E6;
  }
  .isoore-multicontact__title {
    margin: 12px 0 14px;
    font-size: clamp(26px, 3.2vw, 38px);
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -0.5px;
    color: #F4F0E6;
  }
  .isoore-multicontact__subtitle {
    margin: 0;
    font-size: 16px;
    line-height: 1.6;
    color: rgba(244, 240, 230, 0.85);
  }

  /* ===== Buttons ===== */
  .isoore-multicontact__buttons {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    max-width: 920px;
    margin: 0 auto;
  }
  /* Adapte la grille au nombre de boutons reellement rendus */
  .isoore-multicontact__buttons:has(.isoore-multicontact__btn:nth-child(2):last-child) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: 640px;
  }
  .isoore-multicontact__buttons:has(.isoore-multicontact__btn:nth-child(1):last-child) {
    grid-template-columns: minmax(0, 360px);
    max-width: 360px;
    justify-content: center;
  }

  .isoore-multicontact__btn {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 18px 22px;
    border-radius: var(--isoore-radius-md, 8px);
    background: rgba(244, 240, 230, 0.08);
    border: 1px solid rgba(244, 240, 230, 0.16);
    color: #F4F0E6;
    text-decoration: none;
    text-align: left;
    cursor: pointer;
    transition:
      transform 0.3s var(--isoore-ease),
      background 0.3s var(--isoore-ease),
      border-color 0.3s var(--isoore-ease),
      box-shadow 0.3s var(--isoore-ease);
  }

  .isoore-multicontact__btn:hover {
    transform: translateY(-3px);
    background: rgba(244, 240, 230, 0.14);
    border-color: rgba(244, 240, 230, 0.3);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.25);
  }

  .isoore-multicontact__btn-icon {
    flex-shrink: 0;
    width: 46px;
    height: 46px;
    border-radius: 50%;
    background: rgba(244, 240, 230, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.3s var(--isoore-ease), transform 0.3s var(--isoore-ease);
  }
  .isoore-multicontact__btn-icon svg {
    width: 22px;
    height: 22px;
  }
  .isoore-multicontact__btn:hover .isoore-multicontact__btn-icon {
    background: rgba(244, 240, 230, 0.2);
    transform: scale(1.05);
  }

  /* Variantes couleur par canal */
  .isoore-multicontact__btn--call:hover {
    border-color: var(--isoore-cta, #2D3E2B);
  }
  .isoore-multicontact__btn--call .isoore-multicontact__btn-icon {
    color: var(--isoore-cta, #2D3E2B);
  }

  .isoore-multicontact__btn--whatsapp:hover {
    border-color: #25D366;
  }
  .isoore-multicontact__btn--whatsapp .isoore-multicontact__btn-icon {
    color: #25D366;
  }

  .isoore-multicontact__btn--calendly:hover {
    border-color: #006bff;
  }
  .isoore-multicontact__btn--calendly .isoore-multicontact__btn-icon {
    color: #6FA9FF;
  }

  .isoore-multicontact__btn-label {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
  }
  .isoore-multicontact__btn-label strong {
    font-size: 15px;
    font-weight: 600;
    color: #F4F0E6;
  }
  .isoore-multicontact__btn-label span {
    font-size: 12.5px;
    color: rgba(244, 240, 230, 0.7);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .isoore-multicontact__footer-note {
    margin: 28px 0 0;
    font-size: 13px;
    color: rgba(244, 240, 230, 0.65);
  }

  /* ===== Mobile ===== */
  @media (max-width: 989px) {
    .isoore-multicontact { padding: 48px 0; }
    .isoore-multicontact__container { padding: 0 24px; }
    .isoore-multicontact__buttons {
      grid-template-columns: 1fr;
      gap: 10px;
    }
  }

  @media (max-width: 549px) {
    .isoore-multicontact__btn {
      padding: 14px 16px;
      gap: 12px;
    }
    .isoore-multicontact__btn-icon {
      width: 40px; height: 40px;
    }
    .isoore-multicontact__btn-label strong { font-size: 14px; }
    .isoore-multicontact__btn-label span { font-size: 12px; }
  }

  /* Reduced motion */
  @media (prefers-reduced-motion: reduce) {
    .isoore-multicontact__btn:hover {
      transform: none !important;
    }
    .isoore-multicontact__btn:hover .isoore-multicontact__btn-icon {
      transform: none !important;
    }
  }
/* END_SECTION:isoore-product-multicontact */

/* START_SECTION:isoore-product-pioneers (INDEX:51) */
.isoore-pio {
    background: var(--isoore-bg, #F4F0E6);
    padding: var(--isoore-section-pad, 88px) 0;
  }
  .isoore-pio__container {
    max-width: 960px;
    margin: 0 auto;
    padding: 0 56px;
  }

  .isoore-pio__panel {
    background: #fff;
    border: 1px solid var(--isoore-border, #E8E2D3);
    border-radius: var(--isoore-radius-lg, 12px);
    padding: 56px 56px;
    position: relative;
    overflow: hidden;
    box-shadow: 0 18px 48px rgba(45, 62, 43, 0.08);
  }
  .isoore-pio__panel::before {
    content: '';
    position: absolute;
    top: -40%; right: -10%;
    width: 60%; height: 200%;
    background: radial-gradient(circle, rgba(45, 62, 43, 0.1) 0%, transparent 60%);
    pointer-events: none;
  }

  .isoore-pio__header {
    text-align: center;
    max-width: 600px;
    margin: 0 auto 36px;
    position: relative;
    z-index: 2;
  }
  .isoore-pio__title {
    margin: 12px 0 14px;
    font-size: clamp(26px, 3.2vw, 36px);
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: -0.3px;
    color: var(--isoore-dark, #0E0E0C);
  }
  .isoore-pio__subtitle {
    margin: 0;
    font-size: 15.5px;
    line-height: 1.6;
    opacity: 0.85;
  }

  /* Compteur */
  .isoore-pio__counter {
    text-align: center;
    margin: 0 0 36px;
    position: relative;
    z-index: 2;
  }
  .isoore-pio__counter-numbers {
    display: inline-flex;
    align-items: baseline;
    gap: 6px;
    line-height: 1;
  }
  .isoore-pio__counter-big {
    font-size: clamp(60px, 9vw, 110px);
    font-weight: 700;
    color: var(--isoore-cta, #2D3E2B);
    letter-spacing: -3px;
    line-height: 1;
  }
  .isoore-pio__counter-over {
    font-size: clamp(22px, 2.8vw, 32px);
    font-weight: 500;
    color: var(--isoore-text);
    opacity: 0.65;
  }
  .isoore-pio__counter-label {
    margin: 6px 0 18px;
    font-size: 12.5px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--isoore-text);
    opacity: 0.75;
  }
  .isoore-pio__progress {
    width: min(360px, 100%);
    height: 6px;
    background: var(--isoore-border, #E8E2D3);
    border-radius: 3px;
    overflow: hidden;
    margin: 0 auto 18px;
  }
  .isoore-pio__progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--isoore-cta, #2D3E2B), #3F5340);
    border-radius: 3px;
    transition: width 0.8s var(--isoore-ease);
  }
  .isoore-pio__dots {
    display: inline-flex;
    gap: 6px;
    margin: 0 auto;
  }
  .isoore-pio__dot {
    width: 14px; height: 14px;
    border-radius: 50%;
    background: rgba(45, 62, 43, 0.18);
    border: 2px solid var(--isoore-cta, #2D3E2B);
  }
  .isoore-pio__dot.is-taken {
    background: var(--isoore-cta, #2D3E2B);
    border-color: var(--isoore-cta, #2D3E2B);
    position: relative;
  }
  .isoore-pio__dot.is-taken::after {
    content: '✓';
    position: absolute;
    inset: 0;
    color: #fff;
    font-size: 9px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  /* Deal */
  .isoore-pio__deal {
    background: linear-gradient(135deg, var(--isoore-cta, #2D3E2B) 0%, #3F5340 100%);
    color: #fff;
    border-radius: var(--isoore-radius-md, 8px);
    padding: 28px 32px;
    text-align: center;
    margin: 0 0 40px;
    box-shadow: 0 12px 28px rgba(45, 62, 43, 0.32);
    position: relative;
    z-index: 2;
  }
  .isoore-pio__deal-amount {
    display: inline-flex;
    align-items: baseline;
    gap: 4px;
    margin-bottom: 6px;
    line-height: 1;
  }
  .isoore-pio__deal-value {
    font-size: clamp(40px, 6vw, 64px);
    font-weight: 700;
    letter-spacing: -1px;
  }
  .isoore-pio__deal-currency {
    font-size: clamp(20px, 3vw, 32px);
    font-weight: 500;
  }
  .isoore-pio__deal-text {
    margin: 0;
    font-size: 14.5px;
    line-height: 1.55;
    opacity: 0.95;
  }

  /* How */
  .isoore-pio__how {
    margin-bottom: 32px;
    position: relative;
    z-index: 2;
  }
  .isoore-pio__how-title {
    margin: 0 0 20px;
    font-size: 13px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--isoore-text);
    opacity: 0.75;
    font-weight: 500;
    text-align: center;
  }
  .isoore-pio__how-steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
  }
  .isoore-pio__how-steps li {
    text-align: center;
    padding: 22px 16px;
    background: rgba(244, 240, 230, 0.6);
    border-radius: 8px;
    border: 1px solid var(--isoore-border, #E8E2D3);
  }
  .isoore-pio__how-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px; height: 32px;
    border-radius: 50%;
    background: var(--isoore-cta, #2D3E2B);
    color: #fff;
    font-weight: 700;
    font-size: 14px;
    margin-bottom: 12px;
  }
  .isoore-pio__how-steps strong {
    display: block;
    font-size: 14.5px;
    color: var(--isoore-dark);
    margin-bottom: 6px;
  }
  .isoore-pio__how-steps p {
    margin: 0;
    font-size: 13px;
    line-height: 1.55;
    color: var(--isoore-text);
    opacity: 0.85;
  }

  /* Transparency */
  .isoore-pio__transparency {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 18px 22px;
    background: rgba(244, 240, 230, 0.7);
    border: 1px dashed var(--isoore-border, #E8E2D3);
    border-radius: 8px;
    position: relative;
    z-index: 2;
  }
  .isoore-pio__transparency-icon {
    flex-shrink: 0;
    width: 22px; height: 22px;
    color: var(--isoore-cta);
    margin-top: 1px;
  }
  .isoore-pio__transparency-icon svg { width: 100%; height: 100%; }
  .isoore-pio__transparency p {
    margin: 0;
    font-size: 13.5px;
    line-height: 1.6;
    color: var(--isoore-text);
  }
  .isoore-pio__transparency strong { color: var(--isoore-dark); }

  /* Responsive */
  @media (max-width: 749px) {
    .isoore-pio__container { padding: 0 16px; }
    .isoore-pio__panel { padding: 32px 22px; }
    .isoore-pio__how-steps { grid-template-columns: 1fr; gap: 12px; }
  }
/* END_SECTION:isoore-product-pioneers */

/* START_SECTION:isoore-product-timeline (INDEX:52) */
.isoore-product-timeline {
    background: var(--isoore-bg, #F7F3EC);
    color: var(--isoore-text, #3A5038);
    padding: var(--isoore-section-pad, 88px) 0;
  }
  .isoore-product-timeline__container {
    max-width: 1280px; margin: 0 auto; padding: 0 56px;
  }
  .isoore-product-timeline__header {
    text-align: center;
    max-width: 720px;
    margin: 0 auto 64px;
  }
  .isoore-product-timeline__title {
    margin: 12px 0 14px;
    font-size: clamp(28px, 3.4vw, 42px);
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: -0.5px;
    color: var(--isoore-dark, #3A5038);
  }
  .isoore-product-timeline__subtitle {
    margin: 0;
    font-size: 16px;
    line-height: 1.65;
    color: var(--isoore-text, #3A5038);
    opacity: 0.85;
  }

  .isoore-product-timeline__steps {
    position: relative;
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
  }

  .isoore-product-timeline__line {
    position: absolute;
    top: 56px;
    left: 12.5%;
    right: 12.5%;
    height: 2px;
    background: var(--isoore-border, #E4DCC8);
    z-index: 0;
  }
  .isoore-product-timeline__line-fill {
    display: block;
    width: 0;
    height: 100%;
    background: linear-gradient(90deg, var(--isoore-cta, #7AAB72), #5d8a55);
    transition: width 1.6s var(--isoore-ease);
  }
  .isoore-product-timeline__steps.is-revealed .isoore-product-timeline__line-fill {
    width: 100%;
  }

  .isoore-product-timeline__step {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    z-index: 1;
  }

  .isoore-product-timeline__day {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--isoore-cta, #7AAB72);
    margin-bottom: 18px;
  }

  .isoore-product-timeline__node {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: #fff;
    border: 2px solid var(--isoore-cta, #7AAB72);
    color: var(--isoore-cta, #7AAB72);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 22px;
    box-shadow: 0 0 0 6px var(--isoore-bg, #F7F3EC);
    transition: background 0.3s var(--isoore-ease), color 0.3s var(--isoore-ease), transform 0.3s var(--isoore-ease);
  }
  .isoore-product-timeline__node svg { width: 24px; height: 24px; }
  .isoore-product-timeline__step:hover .isoore-product-timeline__node {
    background: var(--isoore-cta, #7AAB72);
    color: #fff;
    transform: scale(1.05);
  }

  .isoore-product-timeline__step-title {
    margin: 0 0 8px;
    font-size: 16px;
    font-weight: 600;
    color: var(--isoore-dark, #3A5038);
  }
  .isoore-product-timeline__step-text {
    margin: 0;
    font-size: 13px;
    line-height: 1.55;
    color: var(--isoore-text, #3A5038);
    opacity: 0.85;
    max-width: 220px;
  }

  @media (max-width: 989px) {
    .isoore-product-timeline__container { padding: 0 24px; }
    .isoore-product-timeline__steps { grid-template-columns: 1fr; gap: 32px; }
    .isoore-product-timeline__line {
      top: 0; bottom: 0;
      left: 50%;
      right: auto;
      width: 2px;
      height: auto;
    }
    .isoore-product-timeline__line-fill {
      width: 100%;
      height: 0;
      transition: height 1.6s var(--isoore-ease);
      background: linear-gradient(180deg, var(--isoore-cta, #7AAB72), #5d8a55);
    }
    .isoore-product-timeline__steps.is-revealed .isoore-product-timeline__line-fill {
      width: 100%;
      height: 100%;
    }
  }
/* END_SECTION:isoore-product-timeline */

/* START_SECTION:isoore-product-trust (INDEX:53) */
.isoore-product-trust {
    background: var(--bg, #FFFFFF);
    color: var(--text, #3A5038);
    padding: 22px 0;
    border-top: 1px solid var(--isoore-border, #E4DCC8);
    border-bottom: 1px solid var(--isoore-border, #E4DCC8);
  }
  .isoore-product-trust__container {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 56px;
  }
  .isoore-product-trust__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
  }
  .isoore-product-trust__item {
    display: flex;
    align-items: center;
    gap: 14px;
  }
  .isoore-product-trust__icon {
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--accent, #7AAB72);
    background: rgba(122, 171, 114, 0.08);
    border-radius: 50%;
    transition: transform 0.4s var(--isoore-ease);
  }
  .isoore-product-trust__item:hover .isoore-product-trust__icon {
    transform: rotate(-6deg) scale(1.08);
  }
  .isoore-product-trust__icon svg {
    width: 22px;
    height: 22px;
  }
  .isoore-product-trust__copy {
    display: flex;
    flex-direction: column;
    gap: 2px;
    line-height: 1.35;
  }
  .isoore-product-trust__title {
    font-size: 13px;
    font-weight: 600;
    color: var(--text, #3A5038);
  }
  .isoore-product-trust__sub {
    font-size: 12px;
    color: var(--text, #3A5038);
    opacity: 0.7;
  }
  @media (max-width: 989px) {
    .isoore-product-trust__container { padding: 0 24px; }
    .isoore-product-trust__list { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  }
  @media (max-width: 480px) {
    .isoore-product-trust__list { grid-template-columns: 1fr; }
  }
/* END_SECTION:isoore-product-trust */

/* START_SECTION:isoore-service (INDEX:54) */
.isoore-service {
    padding: 88px 56px;
    background: var(--color-background);
    color: var(--color-foreground);
  }

  .isoore-service__inner {
    max-width: var(--isoore-container-max, 1300px);
    margin: 0 auto;
  }

  .isoore-service__head {
    text-align: center;
    margin-bottom: 36px;
  }

  .isoore-service__heading {
    font-size: clamp(26px, 3vw, 32px);
    font-weight: 500;
    line-height: 1.18;
    letter-spacing: -0.5px;
    margin: 12px 0 0;
    color: inherit;
  }

  .isoore-service__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    margin-bottom: 36px;
  }

  .isoore-service-card {
    background: rgba(247, 243, 236, 0.05);
    border: 1px solid rgba(247, 243, 236, 0.18);
    border-radius: var(--isoore-radius-md, 10px);
    padding: 28px 24px;
    text-align: center;
    transition: all 0.4s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-service-card:hover {
    background: rgba(247, 243, 236, 0.08);
    border-color: var(--isoore-cta, #7AAB72);
    transform: translateY(-4px);
  }

  .isoore-service-card__icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: rgba(122, 171, 114, 0.18);
    color: var(--isoore-cta, #7AAB72);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 18px;
    transition: all 0.4s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-service-card:hover .isoore-service-card__icon {
    background: var(--isoore-cta, #7AAB72);
    color: #fff;
    transform: scale(1.08);
  }

  .isoore-service-card__title {
    font-size: 16px;
    font-weight: 600;
    margin: 0 0 8px;
  }

  .isoore-service-card__desc {
    font-size: 13px;
    line-height: 1.65;
    opacity: 0.8;
  }

  .isoore-service__cta-wrap {
    text-align: center;
  }

  .isoore-service__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 14px 28px;
    background: var(--isoore-cta, #7AAB72);
    color: #fff;
    border-radius: var(--isoore-radius-sm, 4px);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.3px;
    text-decoration: none;
    position: relative;
    overflow: hidden;
    transition: transform 0.3s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1)),
                box-shadow 0.3s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1)),
                background-color 0.3s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-service__cta::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.25), transparent);
    transition: left 0.6s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-service__cta:hover::before { left: 100%; }

  .isoore-service__cta:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 25px rgba(122, 171, 114, 0.4);
  }

  .isoore-service__cta-arrow {
    display: inline-block;
    transition: transform 0.3s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-service__cta:hover .isoore-service__cta-arrow {
    transform: translateX(4px);
  }

  @media (max-width: 749px) {
    .isoore-service { padding: 56px 24px; }
    .isoore-service__grid { grid-template-columns: 1fr; }
  }
/* END_SECTION:isoore-service */

/* START_SECTION:isoore-spirit (INDEX:57) */
.isoore-spirit {
    padding: 88px 56px;
    background: var(--color-background);
    color: var(--color-foreground);
  }

  .isoore-spirit__inner {
    max-width: var(--isoore-container-max, 1300px);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 56px;
    align-items: center;
  }

  .isoore-spirit--right .isoore-spirit__inner {
    grid-template-columns: 1fr 1.2fr;
  }

  .isoore-spirit--right .isoore-spirit__media { order: 2; }
  .isoore-spirit--right .isoore-spirit__content { order: 1; }

  .isoore-spirit__media {
    border-radius: var(--isoore-radius-md, 8px);
    overflow: hidden;
    aspect-ratio: 4 / 3;
    background: linear-gradient(135deg, #E4DCC8, #d8cfb8);
  }

  .isoore-spirit__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.6s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-spirit__media:hover .isoore-spirit__image {
    transform: scale(1.03);
  }

  .isoore-spirit__image-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--isoore-text, #3A5038);
    opacity: 0.5;
  }

  .isoore-spirit__heading {
    font-size: clamp(26px, 3vw, 32px);
    font-weight: 500;
    line-height: 1.18;
    letter-spacing: -0.5px;
    margin: 0 0 20px;
    color: var(--isoore-text, #3A5038);
  }

  .isoore-spirit__body {
    font-size: 14px;
    line-height: 1.75;
    margin-bottom: 24px;
  }

  .isoore-spirit__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    border: 1.5px solid var(--isoore-text, #3A5038);
    background: transparent;
    color: var(--isoore-text, #3A5038);
    font-size: 13px;
    font-weight: 500;
    border-radius: var(--isoore-radius-sm, 4px);
    text-decoration: none;
    transition: all 0.3s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-spirit__cta:hover {
    background: var(--isoore-text, #3A5038);
    color: var(--isoore-bg, #F7F3EC);
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(58, 80, 56, 0.2);
  }

  .isoore-spirit__cta-arrow {
    display: inline-block;
    transition: transform 0.4s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-spirit__cta:hover .isoore-spirit__cta-arrow {
    transform: translateX(4px);
  }

  @media (max-width: 989px) {
    .isoore-spirit { padding: 56px 24px; }

    .isoore-spirit__inner,
    .isoore-spirit--right .isoore-spirit__inner {
      grid-template-columns: 1fr;
      gap: 32px;
    }

    .isoore-spirit--right .isoore-spirit__media { order: 0; }
    .isoore-spirit--right .isoore-spirit__content { order: 0; }
  }
/* END_SECTION:isoore-spirit */

/* START_SECTION:isoore-stats (INDEX:58) */
.isoore-stats {
    background: var(--isoore-dark, #3A5038);
    color: var(--isoore-bg, #F7F3EC);
    padding: 36px 48px;
  }

  .isoore-stats__inner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    max-width: var(--isoore-container-max, 1300px);
    margin: 0 auto;
  }

  .isoore-stat {
    text-align: center;
    position: relative;
    padding: 0 12px;
  }

  .isoore-stat:not(:last-child)::after {
    content: '';
    position: absolute;
    right: 0;
    top: 15%;
    height: 70%;
    width: 1px;
    background: rgba(247, 243, 236, 0.18);
  }

  .isoore-stat__icon {
    color: var(--isoore-cta, #7AAB72);
    margin-bottom: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.5s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-stat:hover .isoore-stat__icon {
    transform: scale(1.2) rotate(-8deg);
  }

  .isoore-stat__number {
    font-size: 34px;
    font-weight: 600;
    line-height: 1;
    margin-bottom: 6px;
    letter-spacing: -1px;
  }

  .isoore-stat__suffix {
    font-size: 18px;
    opacity: 0.7;
    font-weight: 400;
    margin-left: 2px;
  }

  .isoore-stat__label {
    font-size: 12px;
    opacity: 0.75;
    letter-spacing: 0.5px;
  }

  @media (max-width: 749px) {
    .isoore-stats {
      padding: 28px 20px;
    }

    .isoore-stats__inner {
      grid-template-columns: repeat(2, 1fr);
      gap: 24px 12px;
    }

    .isoore-stat:not(:last-child)::after {
      display: none;
    }

    .isoore-stat__number {
      font-size: 28px;
    }
  }
/* END_SECTION:isoore-stats */

/* START_SECTION:isoore-story (INDEX:59) */
.isoore-story {
    padding: 88px 56px;
    background: var(--color-background);
    color: var(--color-foreground);
  }

  .isoore-story__inner {
    max-width: 720px;
    margin: 0 auto;
    text-align: center;
  }

  .isoore-story__heading {
    font-size: clamp(26px, 3vw, 32px);
    font-weight: 500;
    line-height: 1.18;
    letter-spacing: -0.5px;
    margin: 8px 0 24px;
    color: var(--isoore-text, #3A5038);
  }

  .isoore-story__quote-mark {
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 56px;
    font-weight: 600;
    line-height: 1;
    color: var(--isoore-cta, #7AAB72);
    opacity: 0.35;
    margin: 16px 0 8px;
  }

  .isoore-story__body {
    font-size: 15px;
    line-height: 1.85;
    margin-bottom: 28px;
    font-style: italic;
  }

  .isoore-story__body p {
    margin: 0 0 16px;
  }

  .isoore-story__body p:last-child {
    margin-bottom: 0;
  }

  .isoore-story__divider {
    width: 60px;
    height: 2px;
    background: var(--isoore-cta, #7AAB72);
    margin: 0 auto 28px;
    border-radius: 2px;
    opacity: 0.7;
  }

  .isoore-story__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    background: transparent;
    color: var(--isoore-text, #3A5038);
    border: 1.5px solid var(--isoore-text, #3A5038);
    border-radius: var(--isoore-radius-sm, 4px);
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.3s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-story__cta:hover {
    background: var(--isoore-text, #3A5038);
    color: var(--isoore-bg, #F7F3EC);
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(58, 80, 56, 0.2);
  }

  .isoore-story__cta-arrow {
    display: inline-block;
    transition: transform 0.4s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-story__cta:hover .isoore-story__cta-arrow {
    transform: translateX(4px);
  }

  @media (max-width: 749px) {
    .isoore-story { padding: 56px 24px; }
    .isoore-story__quote-mark { font-size: 44px; }
  }
/* END_SECTION:isoore-story */

/* START_SECTION:isoore-summary (INDEX:60) */
.isoore-summary {
    margin: 60px auto 50px;
    padding: 0 24px;
    text-align: center;
    max-width: 1200px;
    position: relative;
  }
  .isoore-summary[open] { padding-bottom: 20px; }

  .isoore-summary__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    background: linear-gradient(135deg, #7AAB72 0%, #5d8a55 100%);
    color: #FFFFFF;
    padding: 14px 32px;
    border-radius: 30px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    border: none;
    appearance: none;
    -webkit-appearance: none;
    list-style: none;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 4px 16px rgba(122, 171, 114, 0.35);
    letter-spacing: 0.04em;
    user-select: none;
    text-transform: uppercase;
  }
  .isoore-summary__btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(122, 171, 114, 0.5);
  }
  .isoore-summary__btn::-webkit-details-marker { display: none; }
  .isoore-summary__btn::marker { display: none; content: ""; }

  .isoore-summary__btn-icon {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  }
  .isoore-summary__btn-icon svg { width: 14px; height: 14px; color: #fff; }
  .isoore-summary[open] .isoore-summary__btn-icon {
    transform: rotate(180deg);
    background: rgba(255, 255, 255, 0.35);
  }

  .isoore-summary__content {
    margin: 36px auto 0;
    text-align: left;
    max-width: 820px;
    padding: 44px 48px;
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-radius: 24px;
    border: 1px solid rgba(228, 220, 200, 0.4);
    box-shadow: 0 8px 32px rgba(58, 80, 56, 0.10), 0 2px 8px rgba(58, 80, 56, 0.04);
    position: relative;
    overflow: hidden;
  }

  .isoore-summary__content::before {
    content: '';
    position: absolute;
    top: -80px; right: -80px;
    width: 240px; height: 240px;
    background: radial-gradient(circle, rgba(122, 171, 114, 0.12) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none; z-index: 0;
  }
  .isoore-summary__content::after {
    content: '';
    position: absolute;
    bottom: -80px; left: -80px;
    width: 240px; height: 240px;
    background: radial-gradient(circle, rgba(58, 80, 56, 0.08) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none; z-index: 0;
  }
  .isoore-summary__content > * { position: relative; z-index: 1; }

  .isoore-summary__header {
    text-align: center;
    margin-bottom: 32px;
    padding-bottom: 24px;
    border-bottom: 1px solid rgba(228, 220, 200, 0.6);
  }
  .isoore-summary__caption {
    color: #7AAB72;
    font-weight: 600;
    font-size: 11px;
    letter-spacing: 0.2rem;
    text-transform: uppercase;
    display: inline-block;
    position: relative;
    padding: 0 36px;
    margin-bottom: 12px;
  }
  .isoore-summary__caption::before,
  .isoore-summary__caption::after {
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 24px; height: 2px;
    background: linear-gradient(90deg, #7AAB72, #5d8a55);
    border-radius: 2px;
  }
  .isoore-summary__caption::before { left: 0; }
  .isoore-summary__caption::after { right: 0; }

  .isoore-summary__main-title {
    font-size: 28px;
    font-weight: 600;
    color: #3A5038;
    margin: 0;
    letter-spacing: -0.02em;
    line-height: 1.25;
  }

  .isoore-summary__h3 {
    font-size: 20px;
    font-weight: 600;
    color: #3A5038;
    margin: 32px 0 14px;
    line-height: 1.3;
    letter-spacing: -0.015em;
    position: relative;
    padding-left: 18px;
  }
  .isoore-summary__h3::before {
    content: '';
    position: absolute;
    left: 0; top: 50%;
    transform: translateY(-50%);
    width: 4px; height: 22px;
    background: linear-gradient(180deg, #7AAB72, #5d8a55);
    border-radius: 4px;
  }
  .isoore-summary__h3:first-of-type { margin-top: 0; }

  .isoore-summary__body { font-size: 15px; line-height: 1.75; color: rgba(58, 80, 56, 0.85); }
  .isoore-summary__body p { margin: 0 0 18px; }
  .isoore-summary__body p:last-of-type { margin-bottom: 0; }
  .isoore-summary__body strong,
  .isoore-summary__body b { color: #3A5038; font-weight: 700; }

  @media screen and (max-width: 749px) {
    .isoore-summary { margin: 40px auto 30px; padding: 0 16px; }
    .isoore-summary__btn { padding: 12px 24px; font-size: 13px; }
    .isoore-summary__content { padding: 28px 22px; margin-top: 28px; border-radius: 18px; }
    .isoore-summary__main-title { font-size: 22px; }
    .isoore-summary__h3 { font-size: 17px; padding-left: 14px; }
    .isoore-summary__body { font-size: 14px; line-height: 1.7; }
  }
/* END_SECTION:isoore-summary */

/* START_SECTION:isoore-testimonials (INDEX:61) */
.isoore-testimonials {
    padding: 88px 56px;
    background: var(--color-background);
    color: var(--color-foreground);
  }

  .isoore-testimonials__inner {
    max-width: var(--isoore-container-max, 1300px);
    margin: 0 auto;
  }

  .isoore-testimonials__head {
    text-align: center;
    margin-bottom: 36px;
  }

  .isoore-testimonials__heading {
    font-size: clamp(26px, 3vw, 32px);
    font-weight: 500;
    line-height: 1.18;
    letter-spacing: -0.5px;
    margin: 8px 0 0;
    color: var(--isoore-text, #3A5038);
  }

  .isoore-testimonials__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }

  .isoore-testimonial {
    background: var(--isoore-bg, #F7F3EC);
    border: 1px solid var(--isoore-border, #E4DCC8);
    border-radius: var(--isoore-radius-md, 10px);
    padding: 24px;
    transition: all 0.4s var(--isoore-ease, cubic-bezier(0.4, 0, 0.2, 1));
  }

  .isoore-testimonial:hover {
    transform: translateY(-4px);
    border-color: var(--isoore-cta, #7AAB72);
    box-shadow: 0 12px 28px rgba(58, 80, 56, 0.08);
  }

  .isoore-testimonial__stars {
    color: var(--isoore-cta, #7AAB72);
    font-size: 16px;
    letter-spacing: 2px;
    margin-bottom: 14px;
  }

  .isoore-testimonial__star { display: inline-block; }
  .isoore-testimonial__star:not(.is-filled) { opacity: 0.35; }

  .isoore-testimonial__quote {
    margin: 0 0 16px;
    padding: 0;
    font-size: 13px;
    line-height: 1.75;
    font-style: italic;
    color: inherit;
  }

  .isoore-testimonial__quote::before { content: '"'; }
  .isoore-testimonial__quote::after  { content: '"'; }

  .isoore-testimonial__footer {
    border-top: 1px solid var(--isoore-border, #E4DCC8);
    padding-top: 12px;
    display: flex;
    flex-direction: column;
    gap: 2px;
  }

  .isoore-testimonial__author {
    font-size: 13px;
    font-weight: 600;
    color: var(--isoore-text, #3A5038);
  }

  .isoore-testimonial__subtitle {
    font-size: 12px;
    opacity: 0.7;
  }

  @media (max-width: 989px) {
    .isoore-testimonials { padding: 56px 0; }
    .isoore-testimonials__inner > .isoore-testimonials__head { padding: 0 24px; }
    .isoore-testimonials__grid {
      display: flex;
      grid-template-columns: none;
      overflow-x: auto;
      overflow-y: hidden;
      scroll-snap-type: x mandatory;
      -webkit-overflow-scrolling: touch;
      padding: 8px 24px 16px;
      gap: 14px;
      scrollbar-width: none;
      -ms-overflow-style: none;
    }
    .isoore-testimonials__grid::-webkit-scrollbar { display: none; }
    .isoore-testimonial {
      flex: 0 0 82%;
      max-width: 320px;
      scroll-snap-align: center;
    }
  }
/* END_SECTION:isoore-testimonials */

/* START_SECTION:main-account (INDEX:62) */
.customer-account {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
    width: 100%;
    padding: 50px 0;
  }

  .customer-account__account {
    max-width: 600px;
    width: 100%;
    margin: 0 auto;
  }

  .customer-account__account > * {
    margin-bottom: var(--margin-md);
  }

  .customer-account__orders,
  .customer-account__addresses {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
  }

  .customer-account__order {
    text-decoration: none;
    color: var(--color-foreground);
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
    transition: var(--animation-link-hover);

    &:hover {
      opacity: var(--opacity-link-hover);
    }

    .customer-account__order-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
    }

    .customer-account__order-header-left {
      display: flex;
      gap: var(--gap-sm);
      flex-wrap: wrap;
    }

    .customer-account__order-number {
      font-weight: 600;
    }

    .customer-account__order-date {
      font-weight: 100;
      opacity: 0.75;
    }
  }

  .customer-account__default-address > * {
    font-style: italic;
  }
/* END_SECTION:main-account */

/* START_SECTION:main-activate-account (INDEX:63) */
.customer-activate {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
    width: 100%;
    padding: 50px 0;
  }

  .customer-activate__activate {
    max-width: 400px;
    width: 100%;
    margin: 0 auto;
  }

  .customer-activate__activate > .h2 {
    margin-bottom: var(--margin-md);
  }

  .customer-activate__form {
    margin-top: var(--margin-lg);
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
  }

  .customer-activate__form-actions {
    margin-top: var(--margin-md);
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }
/* END_SECTION:main-activate-account */

/* START_SECTION:main-addresses (INDEX:64) */
.customer-addresses {
    width: 100%;
    padding: 50px 0;
    display: block;
  }

  .customer-addresses__addresses-container {
    max-width: 600px;
    width: 100%;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
  }

  .customer-addresses__form {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
    margin: var(--margin-md) 0;
  }

  .checkbox-group {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: var(--gap-sm);
  }
/* END_SECTION:main-addresses */

/* START_SECTION:main-article (INDEX:65) */
.article {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .article-content {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  @media (width > 750px) {
    .article-content {
      width: 65vw;
    }
  }
/* END_SECTION:main-article */

/* START_SECTION:main-blog (INDEX:66) */
.main-blog {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .main-blog__articles {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .main-blog__articles-grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    gap: var(--gap-lg);
  }

  @media (width > 750px) {
    .main-blog__articles-grid {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_SECTION:main-blog */

/* START_SECTION:main-collection (INDEX:67) */
.shopify-section-main-collection {
    overflow: visible;
  }

  .main-collection {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .main-collection__inner {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
    display: flex;
    flex-direction: column;
    gap: var(--gap-lg);
  }

  .main-collection__products-grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    gap: var(--gap-md);
  }

  @media (width > 750px) {
    .main-collection:has(.filter-and-sort--inline) .main-collection__inner {
      display: flex;
      flex-direction: column;
      gap: var(--gap-lg);
    }

    .main-collection:has(.filter-and-sort--sidebar) .main-collection__inner {
      display: grid;
      grid-template-columns: 25% calc(75% - var(--gap-lg));
      gap: var(--gap-lg);
    }

    .main-collection__products-grid {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_SECTION:main-collection */

/* START_SECTION:main-collections (INDEX:68) */
.main-collections {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .main-collections__inner {
    display: flex;
    flex-direction: column;
    gap: var(--gap-lg);
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .main-collections__products-grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    gap: var(--gap-md);
  }

  @media (width > 750px) {
    .main-collections__products-grid {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_SECTION:main-collections */

/* START_SECTION:main-login (INDEX:69) */
.customer-login {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
    width: 100%;
    padding: 50px 0;
  }

  .customer-login__login,
  .customer-login__reset-password {
    max-width: 400px;
    width: 100%;
    margin: 0 auto;
  }

  .customer-login__login-form,
  .customer-login__reset-password-form {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
    margin-top: var(--margin-lg);
  }

  .customer-login__form-actions {
    margin-top: var(--margin-md);
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }
/* END_SECTION:main-login */

/* START_SECTION:main-order (INDEX:70) */
.customer-order {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
    width: 100%;
    padding: 50px 0;
  }

  .customer-order__content {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
  }

  .customer-order__content > .card {
    overflow-x: auto;
  }

  .order-details {
    width: 100%;
  }

  .order-details {
    margin-top: var(--margin-md);
    border: 1px solid var(--color-border, #e1e1e1);
    border-collapse: collapse;
  }
  .order-details th,
  .order-details td {
    border: 1px solid var(--color-border, #e1e1e1);
    padding: 10px;
  }

  .customer-order__addresses {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
  }

  .customer-order__addresses > .card {
    width: 100%;
  }

  @media (width > 750px) {
    .customer-order__addresses {
      flex-direction: row;
    }
  }
/* END_SECTION:main-order */

/* START_SECTION:main-page (INDEX:71) */
.section-main-page {
    width: 100%;
    max-width: 100%;
    padding: 0;
  }

  .section-main-page .text-block[data-visual-preview-mode] {
    max-width: 100%;
  }

  .section-main-page .image-card[data-visual-preview-mode] {
    width: 100%;
  }

  .main-page {
    width: 100%;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    display: flex;
    justify-content: center;
  }

  .main-page .main-page__inner {
    gap: var(--gap-mobile);
    width: 100%;
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .main-page--flex .main-page__inner {
    display: flex;
    flex-direction: var(--direction-mobile);
    flex-wrap: var(--wrap-mobile);
    justify-content: var(--justify-mobile);
    align-items: var(--align_items-mobile);
    height: 100%;
  }

  .main-page:not(.main-page--row-mobile) > div > .main-page__inner > .text-block-center-mobile,
  .main-page:not(.main-page--row-mobile) > .main-page__inner > .text-block-center-mobile {
    width: 100%;
  }

  .main-page--grid .main-page__inner {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    grid-template-rows: auto;
  }

  @media (width > 750px) {
    .main-page .main-page__inner {
      gap: var(--gap);
    }

    .main-page--flex .main-page__inner {
      flex-direction: var(--direction);
      flex-wrap: var(--wrap);
      justify-content: var(--justify);
      align-items: var(--align_items);
      height: auto;
    }

    .main-page:not(.main-page--row-desktop) > div > .main-page__inner > .text-block-center-desktop,
    .main-page:not(.main-page--row-desktop) > .main-page__inner > .text-block-center-desktop {
      width: 100%;
    }

    .main-page--grid .main-page__inner {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_SECTION:main-page */

/* START_SECTION:main-register (INDEX:73) */
.customer-register {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
    width: 100%;
    padding: 50px 0;
  }

  .customer-register__register {
    max-width: 400px;
    width: 100%;
    margin: 0 auto;
  }

  .customer-register__form {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
    margin-top: var(--margin-lg);
  }

  .customer-register__form-actions {
    margin-top: var(--margin-md);
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }
/* END_SECTION:main-register */

/* START_SECTION:main-reset-password (INDEX:74) */
.customer-reset-password {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
    width: 100%;
    padding: 50px 0;
  }

  .customer-reset-password__reset-password {
    max-width: 400px;
    width: 100%;
    margin: 0 auto;
  }

  .customer-reset-password__reset-password > .h2 {
    margin-bottom: var(--margin-md);
  }

  .customer-reset-password__form {
    margin-top: var(--margin-lg);
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
  }

  .customer-reset-password__form-actions {
    margin-top: var(--margin-md);
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }
/* END_SECTION:main-reset-password */

/* START_SECTION:main-search (INDEX:75) */
.main-search {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .main-search__inner {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .main-search__form {
    margin: 0;
  }

  .main-search__grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    gap: var(--gap-md);
  }

  .main-search__pages {
    display: flex;
    gap: var(--gap-md);
    flex-wrap: wrap;
    padding-bottom: var(--margin-xl);
  }

  .main-search__page-link {
    color: var(--color-foreground);
  }

  .main-search__results-for {
    margin-top: var(--margin-md);
    margin-bottom: var(--margin-lg);
  }

  @media (width > 750px) {
    .main-search__grid {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_SECTION:main-search */

/* START_SECTION:marquee (INDEX:76) */
.section-marquee {
    padding: 0;
    max-width: 100%;
  }

  .marquee-section {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }
/* END_SECTION:marquee */

/* START_SECTION:navigation (INDEX:77) */
.navigation {
    width: 100%;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .navigation__inner {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .navigation__track {
    display: flex;
    gap: var(--gap-md);
    scrollbar-width: none;
    overflow-x: auto;
    padding-top: 5px;
    align-items: flex-start;
    justify-content: flex-start;
    flex-wrap: var(--wrap);
  }

  @media (width > 750px) {
    .navigation__track {
      justify-content: var(--alignment-desktop);
    }
  }
/* END_SECTION:navigation */

/* START_SECTION:password (INDEX:78) */
.password-page__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100vh;
    text-align: center;
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }
/* END_SECTION:password */

/* START_SECTION:predictive-search (INDEX:79) */
.predictive-search-results-container {
    overflow-y: auto;
    max-height: calc(var(--search-modal-max-height-mobile) - var(--inputs-min-height) - var(--padding-md) * 2);
  }

  @media (width > 750px) {
    .predictive-search-results-container {
      max-height: calc(var(--search-modal-max-height) - var(--inputs-min-height) - var(--padding-md) * 2);
    }
  }

  .predictive-search-results:not(:empty) {
    display: flex;
    flex-direction: column;
    gap: var(--gap-lg);
    padding: var(--padding-xs);
    padding-top: var(--margin-md);
  }

  .predictive-search-results .predictive-search__section:not(:last-child) {
    border-bottom: 1px solid var(--color-input-border-low-opacity);
    padding-bottom: var(--gap-lg);
  }

  .predictive-search__title {
    margin-bottom: var(--margin-md);
  }

  .predictive-search__list,
  .predictive-search__grid {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--gap-xs);
  }

  .predictive-search__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--gap-md);
  }

  @media (width > 750px) {
    .predictive-search__grid {
      grid-template-columns: repeat(4, 1fr);
    }
  }

  .predictive-search__item-product a {
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
    text-decoration: none;
    font-size: var(--font-body--size);
  }

  .predictive-search__item-product a img,
  .predictive-search__item-collection a img {
    border-radius: calc(var(--card-border-radius) - (var(--card-padding) * 0.5));
    aspect-ratio: 1/1;
    object-fit: cover;
  }

  .predictive-search__item-collection a {
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
    text-decoration: none;
    font-size: var(--font-body--size);
  }

  .predictive-search__item-page,
  .predictive-search__item-article {
    padding: var(--padding-xs);
    border-radius: calc(var(--inputs-border-radius) * var(--small-multiplier));
    transition: background-color var(--animation-speed) var(--animation-easing);
    font-size: var(--font-body--size);
    text-decoration: none;
    color: inherit;
    display: block;
  }

  .predictive-search__item-page:hover,
  .predictive-search__item-article:hover {
    background-color: var(--color-input-border-low-opacity);
  }

  .predictive-search__item-article a {
    display: flex;
    justify-content: space-between;
    gap: var(--gap-xs);
    width: 100%;
  }

  .predictive-search__item-article-date {
    opacity: 0.7;
  }
/* END_SECTION:predictive-search */

/* START_SECTION:product-recommendations (INDEX:81) */
.product-recommendations {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    display: block;
  }

  .product-recommendations__inner {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
    background-color: var(--color-background);
  }

  .product-recommendations__title {
    margin-bottom: var(--margin-lg);
  }

  .product-recommendations__grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    gap: var(--gap-md);
  }

  @media (width > 750px) {
    .product-recommendations__grid {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_SECTION:product-recommendations */

/* START_SECTION:reviews (INDEX:82) */
.section-reviews {
    max-width: 100%;
    padding: 0;
  }

  .reviews {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
    width: 100%;
  }

  .reviews__title {
    margin-bottom: var(--gap-lg);
  }

  .reviews__grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    gap: var(--gap-md);
    list-style: none;
    padding: 0;
    margin: 0;
  }

  @media (width > 750px) {
    .reviews__grid {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }

  .reviews .splide {
    padding-bottom: 20px;
  }
/* END_SECTION:reviews */

/* START_SECTION:wishlist-drawer (INDEX:83) */
.wishlist-drawer__overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(var(--color-shadow));
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    -webkit-backdrop-filter: brightness(1);
    backdrop-filter: brightness(1);
    transition:
      opacity var(--animation-speed) var(--animation-easing),
      visibility var(--animation-speed) var(--animation-easing);
  }

  .wishlist-drawer__overlay.is-open {
    opacity: 1;
    visibility: visible;
    -webkit-backdrop-filter: brightness(0.75);
    backdrop-filter: brightness(0.75);
    transition:
      opacity var(--animation-speed) var(--animation-easing),
      visibility var(--animation-speed) var(--animation-easing),
      -webkit-backdrop-filter var(--animation-speed) var(--animation-easing),
      backdrop-filter var(--animation-speed) var(--animation-easing);
  }

  .wishlist-drawer__drawer {
    position: absolute;
    top: 0;
    right: 0;
    width: 90vw;
    max-width: 400px;
    height: 100%;
    background: var(--color-background);
    box-shadow: var(--modal-shadow);
    transform: translateX(100%);
    display: flex;
    flex-direction: column;
  }

  .wishlist-drawer__overlay.is-open .wishlist-drawer__drawer {
    animation: modalSlideInRight var(--animation-speed) var(--animation-easing) forwards;
  }

  .wishlist-drawer__overlay.is-closing .wishlist-drawer__drawer {
    animation: modalSlideOutRight var(--animation-speed) var(--animation-easing) forwards;
  }

  .wishlist-drawer__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--padding-xs);
  }

  .wishlist-drawer__title {
    margin-left: var(--margin-sm);
  }

  .wishlist-drawer__close .icon--close {
    font-size: 22px !important;
  }

  .wishlist-drawer__body {
    flex: 1;
    overflow-y: auto;
    padding: var(--padding-xs);
  }

  .wishlist-drawer__empty {
    text-align: center;
    padding: var(--padding-xl);
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .wishlist-drawer__item {
    display: flex;
    align-items: center;
    gap: var(--padding-xs);
    padding: var(--padding-xs);
    text-decoration: none;
    color: inherit;
    transition: var(--animation-link-hover);
  }

  .wishlist-drawer__item:hover {
    opacity: var(--opacity-link-hover);
  }

  .wishlist-drawer__item-image {
    flex-shrink: 0;
    width: 60px;
    height: 60px;
    object-fit: cover;
    background-color: white;
    border-radius: calc(var(--card-border-radius) - var(--padding-sm));
  }

  .wishlist-drawer__item-info {
    flex: 1;
    min-width: 0; /* Permet au texte de se tronquer si nécessaire */
  }

  .wishlist-drawer__item-title {
    font-size: var(--font-body--size);
    color: rgb(var(--color-foreground));
    font-weight: 500;
    line-height: normal;
    margin-bottom: 0;
  }

  .wishlist-drawer__item-remove {
    flex-shrink: 0;
    margin-left: auto;
    border: var(--inputs-border-width) solid var(--color-border);
  }
/* END_SECTION:wishlist-drawer */

/* CSS from block stylesheet tags */
/* START_BLOCK:_accelerated-checkout (INDEX:84) */
shopify-visual-preview-block-list .accelerated-checkout[data-visual-preview-mode] {
    width: 400px;
  }

  more-payment-options-link {
    font-size: smaller;
  }

  .shopify-payment-button__more-options {
    color: var(--color-foreground);
  }

  more-payment-options-link a {
    --button-color: var(--color-foreground);
  }

  more-payment-options-link a:hover {
    opacity: var(--opacity-link-hover);
  }

  .shopify-payment-button__more-options[aria-hidden='true'] {
    display: none;
  }
/* END_BLOCK:_accelerated-checkout */

/* START_BLOCK:_announcement (INDEX:87) */
.announcement .slide {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    text-align: center;
    gap: var(--gap);
    margin: 0;
    overflow: hidden;
    width: 100%;
    height: 100%;
  }
/* END_BLOCK:_announcement */

/* START_BLOCK:_article-date (INDEX:89) */
.article-date {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }
/* END_BLOCK:_article-date */

/* START_BLOCK:_article-group (INDEX:90) */
.article-card-group {
    display: flex;
    flex-direction: var(--direction-mobile);
    flex-wrap: var(--wrap-mobile);
    justify-content: var(--justify-mobile);
    align-items: var(--align_items-mobile);
    gap: var(--gap-mobile);
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    overflow: hidden;
    width: 100%;
  }

  @media (width > 750px) {
    .article-card-group {
      flex-direction: var(--direction);
      flex-wrap: var(--wrap);
      justify-content: var(--justify);
      align-items: var(--align_items);
      gap: var(--gap);
    }
  }
/* END_BLOCK:_article-group */

/* START_BLOCK:_cart-accelerated-checkout (INDEX:92) */
shopify-visual-preview-block-list .accelerated-checkout[data-visual-preview-mode] {
    width: 400px;
  }

  more-payment-options-link {
    font-size: smaller;
  }

  more-payment-options-link a {
    --button-color: var(--color-foreground);
  }

  more-payment-options-link a:hover {
    opacity: var(--opacity-link-hover);
  }

  .shopify-payment-button__more-options[aria-hidden='true'] {
    display: none;
  }
/* END_BLOCK:_cart-accelerated-checkout */

/* START_BLOCK:_cart-drawer-empty-blocks (INDEX:93) */
.cart-drawer-empty-blocks {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: var(--gap-lg);
    width: 100%;
  }

  @media (width <= 750px) {
    .cart-drawer-empty-blocks .slider-component--65-percent .splide__list {
      width: calc(100vw - 50%);
    }
  }
/* END_BLOCK:_cart-drawer-empty-blocks */

/* START_BLOCK:_cart-drawer-footer-blocks (INDEX:94) */
.cart-footer-blocks {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }
/* END_BLOCK:_cart-drawer-footer-blocks */

/* START_BLOCK:_cart-footer-blocks (INDEX:95) */
.cart-footer-blocks {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }
/* END_BLOCK:_cart-footer-blocks */

/* START_BLOCK:_cart-footer-resume-blocks (INDEX:96) */
.cart-footer-resume-blocks {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }
/* END_BLOCK:_cart-footer-resume-blocks */

/* START_BLOCK:_cart-header-blocks (INDEX:97) */
.cart-header-blocks {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }

  .cart-drawer .cart-header-blocks:not(.card) > div:first-of-type {
    margin-top: var(--padding-md);
  }
/* END_BLOCK:_cart-header-blocks */

/* START_BLOCK:_cart-note (INDEX:98) */
cart-note {
    display: block;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);

    .icon--keyboard_arrow_down {
      display: none;
    }
  }

  cart-note[data-visual-preview-mode] {
    width: 350px;
  }
/* END_BLOCK:_cart-note */

/* START_BLOCK:_cart-progress-bar (INDEX:99) */
.cart-progress-bar {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .cart-progress-bar[data-visual-preview-mode] {
    width: 350px;
  }

  .cart-progress-bar__label {
    margin: 0;
    margin-bottom: var(--margin-md);
    letter-spacing: inherit;
    cursor: default;
    line-height: normal;
    font-weight: 500;
  }

  .cart-progress-bar__bar-container {
    margin-top: 5px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 2px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
  }

  .cart-progress-bar__progress-group {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: -webkit-fill-available;
  }

  .cart-progress-bar__step-label {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 2px;
    font-size: var(--font-body--size-small);
    margin-top: 5px;
  }

  .cart-progress-bar__step-label .icon--check {
    font-size: var(--font-body--size-small) !important;
  }

  .cart-progress-bar__progress {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%;
    height: 5px;
  }

  .cart-progress-bar__progress[value]::-webkit-progress-bar {
    background-color: rgb(from var(--color-primary-button-background) r g b / 15%);
    border-radius: calc(var(--inputs-border-radius) * 20 / 100);
  }

  .cart-progress-bar__progress[value]::-webkit-progress-value {
    -webkit-transition: width 0.5s;
    transition: width 0.5s;
    background-color: var(--color-primary-button-background);
    border-radius: calc(var(--inputs-border-radius) * 20 / 100);
  }

  @-moz-document url-prefix() {
    .cart-progress-bar__bar-container {
      justify-content: center;
    }

    .cart-progress-bar__progress-group {
      width: 100%;
    }

    .cart-progress-bar__progress[value]::-moz-progress-bar {
      background: var(--color-primary-button-background);
      border-radius: calc(var(--inputs-border-radius) * 20 / 100);
    }

    .cart-progress-bar__progress[value],
    .cart-progress-bar__progress[value]::-moz-progress-bar {
      border-radius: calc(var(--inputs-border-radius) * 20 / 100);
    }

    .cart-progress-bar__progress[value] {
      border: none;
      border-radius: calc(var(--inputs-border-radius) * 20 / 100);
    }
  }

  .cart-progress-bar__bar-container:has(.cart-progress-bar__progress_2) {
    .cart-progress-bar__progress_1[value]::-webkit-progress-bar,
    .cart-progress-bar__progress_1[value]::-webkit-progress-value {
      border-top-right-radius: 0;
      border-bottom-right-radius: 0;
    }
  }

  .cart-progress-bar__progress_2[value]::-webkit-progress-bar,
  .cart-progress-bar__progress_2[value]::-webkit-progress-value {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
  }

  .cart-progress-bar__bar-container:has(.cart-progress-bar__progress_3) {
    .cart-progress-bar__progress_2[value]::-webkit-progress-bar,
    .cart-progress-bar__progress_2[value]::-webkit-progress-value {
      border-top-right-radius: 0;
      border-bottom-right-radius: 0;
    }
  }

  .cart-progress-bar__progress_3[value]::-webkit-progress-bar,
  .cart-progress-bar__progress_3[value]::-webkit-progress-value {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
  }
/* END_BLOCK:_cart-progress-bar */

/* START_BLOCK:_comparison-table-data (INDEX:101) */
.comparison-table__cell {
    padding: var(--padding-md);
    text-align: center;
    vertical-align: middle;
  }

  .comparison-table__cell > *:not(.text-block) {
    display: inline-block;
    vertical-align: middle;
  }

  .comparison-table__cell img {
    max-width: 100%;
    height: auto;
    object-fit: contain;
  }

  .comparison-table__cell:empty {
    opacity: 0;
    background-color: transparent;
  }

  @media (width < 750px) {
    .comparison-table__cell {
      padding: var(--padding-sm);
      overflow: hidden;
      min-width: var(--cell-min-width-mobile);
    }
  }

  .highlight-column-1 {
    tr td:nth-child(1):not(:empty) {
      color: var(--color-highlighted-column);
      background-color: var(--color-highlighted-background-column);
    }

    tr:first-child td:nth-child(1):not(:empty) {
      border-top-left-radius: var(--card-border-radius);
      border-top-right-radius: var(--card-border-radius);
    }

    tr:last-child td:nth-child(1):not(:empty) {
      border-bottom-left-radius: var(--card-border-radius);
      border-bottom-right-radius: var(--card-border-radius);
    }
  }

  .highlight-column-2 {
    tr td:nth-child(2):not(:empty) {
      color: var(--color-highlighted-column);
      background-color: var(--color-highlighted-background-column);
    }

    tr:first-child td:nth-child(2):not(:empty) {
      border-top-left-radius: var(--card-border-radius);
      border-top-right-radius: var(--card-border-radius);
    }

    tr:last-child td:nth-child(2):not(:empty) {
      border-bottom-left-radius: var(--card-border-radius);
      border-bottom-right-radius: var(--card-border-radius);
    }
  }

  .highlight-column-3 {
    tr td:nth-child(3):not(:empty) {
      color: var(--color-highlighted-column);
      background-color: var(--color-highlighted-background-column);
    }

    tr:first-child td:nth-child(3):not(:empty) {
      border-top-left-radius: var(--card-border-radius);
      border-top-right-radius: var(--card-border-radius);
    }

    tr:last-child td:nth-child(3):not(:empty) {
      border-bottom-left-radius: var(--card-border-radius);
      border-bottom-right-radius: var(--card-border-radius);
    }
  }

  .highlight-column-4 {
    tr td:nth-child(4):not(:empty) {
      color: var(--color-highlighted-column);
      background-color: var(--color-highlighted-background-column);
    }

    tr:first-child td:nth-child(4):not(:empty) {
      border-top-left-radius: var(--card-border-radius);
      border-top-right-radius: var(--card-border-radius);
    }

    tr:last-child td:nth-child(4):not(:empty) {
      border-bottom-left-radius: var(--card-border-radius);
      border-bottom-right-radius: var(--card-border-radius);
    }
  }

  .highlight-column-5 {
    tr td:nth-child(5):not(:empty) {
      color: var(--color-highlighted-column);
      background-color: var(--color-highlighted-background-column);
    }

    tr:first-child td:nth-child(5):not(:empty) {
      border-top-left-radius: var(--card-border-radius);
      border-top-right-radius: var(--card-border-radius);
    }

    tr:last-child td:nth-child(5):not(:empty) {
      border-bottom-left-radius: var(--card-border-radius);
      border-bottom-right-radius: var(--card-border-radius);
    }
  }

  .highlight-column-6 {
    tr td:nth-child(6):not(:empty) {
      color: var(--color-highlighted-column);
      background-color: var(--color-highlighted-background-column);
    }

    tr:first-child td:nth-child(6):not(:empty) {
      border-top-left-radius: var(--card-border-radius);
      border-top-right-radius: var(--card-border-radius);
    }

    tr:last-child td:nth-child(6):not(:empty) {
      border-bottom-left-radius: var(--card-border-radius);
      border-bottom-right-radius: var(--card-border-radius);
    }
  }

  .highlight-column-7 {
    tr td:nth-child(7):not(:empty) {
      color: var(--color-highlighted-column);
      background-color: var(--color-highlighted-background-column);
    }

    tr:first-child td:nth-child(7):not(:empty) {
      border-top-left-radius: var(--card-border-radius);
      border-top-right-radius: var(--card-border-radius);
    }

    tr:last-child td:nth-child(7):not(:empty) {
      border-bottom-left-radius: var(--card-border-radius);
      border-bottom-right-radius: var(--card-border-radius);
    }
  }

  .highlight-column-8 {
    tr td:nth-child(8):not(:empty) {
      color: var(--color-highlighted-column);
      background-color: var(--color-highlighted-background-column);
    }

    tr:first-child td:nth-child(8):not(:empty) {
      border-top-left-radius: var(--card-border-radius);
      border-top-right-radius: var(--card-border-radius);
    }

    tr:last-child td:nth-child(8):not(:empty) {
      border-bottom-left-radius: var(--card-border-radius);
      border-bottom-right-radius: var(--card-border-radius);
    }
  }
/* END_BLOCK:_comparison-table-data */

/* START_BLOCK:_comparison-table-row (INDEX:102) */
.comparison-table__table tr:not(:last-child) {
    border-bottom: 1px solid var(--color-border);
  }
/* END_BLOCK:_comparison-table-row */

/* START_BLOCK:_custom_product_field (INDEX:103) */
.custom-product-field {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }
/* END_BLOCK:_custom_product_field */

/* START_BLOCK:_discount-code (INDEX:104) */
.cart-discount-block {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);

    .icon--keyboard_arrow_down {
      display: none;
    }
  }

  .cart-discount-block[data-visual-preview-mode] {
    width: 350px;
  }

  cart-discount {
    display: block;
  }

  .cart-discount__container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;

    .textfield {
      width: 100%;
    }

    .textfield input {
      min-width: 100%;
      width: 100%;
    }
  }

  .cart-discount_button {
    min-width: 90px;
  }

  .cart-discount_badge-container {
    margin-top: var(--margin-sm);
  }

  .cart-discount_badge {
    justify-content: center;
    gap: 5px;
    padding-right: 5px !important;
  }

  .cart-discount_badge.loading {
    cursor: default;
    pointer-events: none;

    .cart-discount__discount-text,
    .cart-discount__remove-discount {
      opacity: 0.5;
    }
  }

  .cart-discount__remove-discount {
    cursor: pointer;
    height: 14px;
  }

  .cart-discount_badge .cart-discount__discount-text {
    display: inline-block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
/* END_BLOCK:_discount-code */

/* START_BLOCK:_fake-variant-link (INDEX:105) */
.fake-variant-picker__variant {
    appearance: none;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    min-height: var(--variant-button-min-height);
    min-width: var(--variant-button-min-width);
    max-width: max-content;
    font-size: var(--variant-button-font-size);
    outline: 1px solid transparent;
    transition: all var(--animation-speed-medium) var(--animation-easing);
    padding: var(--variant-button-padding-vertical) var(--variant-button-padding-horizontal);
    color: var(--color-variant-text);
    background-color: var(--color-variant-background);
    border: var(--variant-button-border-width) solid var(--color-variant-border);
    border-radius: var(--inputs-border-radius);
    font-weight: var(--button-primary-font-weight);
    text-transform: var(--button-primary-text-transform);
    letter-spacing: var(--button-letter-spacing);
  }

  .fake-variant-picker__variant--selected {
    background-color: var(--color-selected-variant-background);
    color: var(--color-selected-variant-text);
    border-color: var(--color-selected-variant-border);
  }
/* END_BLOCK:_fake-variant-link */

/* START_BLOCK:_fake-variant-picker (INDEX:106) */
.fake-variant-picker {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .fake-variant-picker__variants {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap-sm);
  }
/* END_BLOCK:_fake-variant-picker */

/* START_BLOCK:_footer-bottom-bar (INDEX:107) */
.footer-bottom-bar {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
    margin-top: var(--margin-top);
  }

  .footer-bottom-bar--top-border {
    border-top: var(--separator-border-width) solid var(--color-border);
  }

  .footer-bottom-bar__content {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    grid-template-rows: auto;
    gap: var(--gap-mobile);
    width: 100%;
  }

  @media (width > 750px) {
    .footer-bottom-bar__content {
      gap: var(--gap);
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_BLOCK:_footer-bottom-bar */

/* START_BLOCK:_footer-policy-list (INDEX:108) */
.policy-list {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .policy-list__links {
    display: flex;
    gap: var(--gap-xs) var(--padding-sm);
    flex-wrap: wrap;
    justify-content: center;
    margin: 0;
    padding: 0;
    list-style: none;

    @media (width >750px) {
      justify-content: flex-start;
    }
  }

  .policy-list__link {
    text-decoration: underline;
    color: var(--color-foreground);
    transition: var(--animation-link-hover);
    font-size: var(--font-body--size-small);

    &:hover {
      opacity: var(--opacity-link-hover);
    }
  }
/* END_BLOCK:_footer-policy-list */

/* START_BLOCK:_header-drawer-menu-header (INDEX:110) */
.header-drawer-menu-header {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
    margin-bottom: var(--margin-sm);
  }
/* END_BLOCK:_header-drawer-menu-header */

/* START_BLOCK:_header-drawer-menu-under-menu (INDEX:111) */
.header-drawer-menu-under-menu {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
    margin-top: var(--margin-sm);
  }
/* END_BLOCK:_header-drawer-menu-under-menu */

/* START_BLOCK:_header-drawer-menu (INDEX:112) */
/* Menu mobile */
  .header__mobile-menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(var(--color-shadow));
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    -webkit-backdrop-filter: brightness(1);
    backdrop-filter: brightness(1);
    transition: opacity var(--animation-speed) var(--animation-easing), visibility var(--animation-speed) var(--animation-easing);
  }

  .header__mobile-menu-overlay.is-open {
    opacity: 1;
    visibility: visible;
    -webkit-backdrop-filter: brightness(0.75);
    backdrop-filter: brightness(0.75);
    transition: opacity var(--animation-speed) var(--animation-easing), visibility var(--animation-speed) var(--animation-easing),
      -webkit-backdrop-filter var(--animation-speed) var(--animation-easing), backdrop-filter var(--animation-speed) var(--animation-easing);
  }

  .header__mobile-menu {
    position: absolute;
    top: 0;
    left: 0;
    width: 90vw;
    max-width: 400px;
    height: 100%;
    background: var(--color-background);
    box-shadow: var(--modal-shadow);
    transform: translateX(-100%);
    display: flex;
    flex-direction: column;
  }

  .header__mobile-menu-overlay.is-open .header__mobile-menu {
    animation: modalSlideInLeft var(--animation-speed) var(--animation-easing) forwards;
  }

  .header__mobile-menu-overlay.is-closing .header__mobile-menu {
    animation: modalSlideOutLeft var(--animation-speed) var(--animation-easing) forwards;
  }

  .header__mobile-menu-header {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: var(--padding-xs);
  }

  .header__mobile-menu-footer {
    padding: var(--padding-sm);
    border-top: var(--separator-border-width) solid var(--color-border);
  }

  .header__mobile-menu-close .icon--close {
    font-size: 22px !important;
  }

  .header__mobile-menu-nav {
    flex: 1;
    padding: var(--padding-md);
    display: flex;
    flex-direction: column;
    gap: var(--gap-xs);
    overflow-y: auto;
  }

  .header__mobile-menu-nav--uppercase .header__mobile-menu-link-text {
    text-transform: uppercase;
  }

  .header__mobile-menu-link-text {
    font-weight: var(--font-weight);
  }

  .header__mobile-menu-link {
    display: block;
    padding: var(--padding-sm);
    text-decoration: none;
    color: inherit;
    font-size: var(--font-h6--size);
    border-radius: var(--inputs-border-radius);
    transition: background-color var(--animation-speed) var(--animation-easing);
  }

  .header__mobile-menu-link:hover {
    background-color: var(--color-input-border-low-opacity);
  }

  /* Accordéons des sous-menus */
  .header__mobile-menu-accordion {
    width: 100%;
  }

  .header__mobile-menu-accordion summary {
    list-style: none;
    cursor: pointer;
  }

  .header__mobile-menu-accordion summary::-webkit-details-marker {
    display: none;
  }

  .header__mobile-menu-link--parent,
  .header__mobile-menu-link--child {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
  }

  .header__mobile-menu-link--parent .icon,
  .header__mobile-menu-link--child .icon {
    transition: transform var(--animation-speed-fast) var(--animation-easing);
    flex-shrink: 0;
  }

  .header__mobile-menu-accordion[open] > summary .icon {
    transform: rotate(180deg);
  }

  .header__mobile-menu-submenu {
    padding-left: var(--padding-sm);
  }

  /* Niveaux d'indentation */
  .header__mobile-menu-link--child {
    font-size: var(--font-body--size-emphasized);
    padding-left: var(--padding-sm);
  }

  .header__mobile-menu-link--grandchild {
    font-size: var(--font-body--size);
    padding-left: var(--padding-sm);
  }

  .header__mobile-menu-submenu--level-2 {
    padding-left: var(--padding-sm);
  }
/* END_BLOCK:_header-drawer-menu */

/* START_BLOCK:_header-megamenu-group (INDEX:113) */
.megamenu-group {
    gap: var(--gap);
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    overflow: hidden;
    width: var(--width);
  }

  .megamenu-group.card {
    padding: var(--padding-vertical) var(--padding-horizontal);
  }

  shopify-visual-preview-block-list .megamenu-group[data-visual-preview-mode] {
    width: 100%;
    max-width: 450px;
  }

  .megamenu-group--flex {
    display: flex;
    flex-direction: var(--direction);
    flex-wrap: var(--wrap);
    justify-content: var(--justify);
    align-items: var(--align_items);
  }

  .megamenu-group--grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns), 1fr);
    grid-template-rows: auto;
  }
/* END_BLOCK:_header-megamenu-group */

/* START_BLOCK:_header-megamenu (INDEX:114) */
.custom-megamenu-content {
    gap: var(--gap);
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    overflow: hidden;
  }

  .custom-megamenu-content--flex {
    display: flex;
    flex-direction: var(--direction);
    flex-wrap: var(--wrap);
    justify-content: var(--justify);
    align-items: var(--align_items);
  }

  .custom-megamenu-content--grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns), 1fr);
    grid-template-rows: auto;
  }
/* END_BLOCK:_header-megamenu */

/* START_BLOCK:_header-notification (INDEX:115) */
.header-notification {
    width: 100%;
    padding: var(--padding-xs);
    background: rgb(var(--color-background));
    border-radius: calc(var(--card-border-radius) - var(--padding-xs));
    transition: background-color var(--animation-speed) var(--animation-easing);
    font-size: var(--font-body--size);
  }

  .header-notification:hover {
    background-color: rgb(from var(--color-foreground) r g b / 5%);
    font-weight: 500;
  }

  .header-notification-link {
    display: flex;
    align-items: center;
    gap: var(--gap-sm);
    text-decoration: none;
    color: rgb(var(--color-foreground));
    width: 100%;
  }

  .header-notification-image {
    width: 50px;
    height: 50px;
    object-fit: cover;
    object-position: center center;
    border-radius: calc(var(--card-border-radius) - (var(--card-padding) * 0.67));
  }

  .header-notification-title {
    font-weight: 500;
  }
/* END_BLOCK:_header-notification */

/* START_BLOCK:_header-notifications (INDEX:116) */
.header-notifications {
    line-height: 0;
    position: relative;
  }

  .header-notifications__icon {
    position: relative;
    display: inline-block;
    cursor: pointer;
  }

  .header-notifications__popup {
    border: var(--container-border-width) solid var(--color-border);
    position: absolute;
    top: 100%;
    right: 0;
    min-width: 240px;
    max-height: 350px;
    overflow-y: auto;
    padding: var(--padding-sm);
  }

  .header-notifications__list {
    display: flex;
    flex-direction: column;
    width: 100%;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: var(--gap-sm);
  }
/* END_BLOCK:_header-notifications */

/* START_BLOCK:_image-banner (INDEX:117) */
.image-banner {
    position: relative;
    overflow: hidden;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    height: 100%;

    &.card {
      padding: 0;
    }
  }

  .image-banner__media-filter {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--color);
    opacity: calc(var(--opacity) / 100);
    z-index: 1;
  }

  .image-banner__media {
    position: absolute;
    width: 100%;
    height: 100%;

    img,
    video,
    deferred-media,
    .placeholder-image {
      height: 100%;
      width: 100%;
      object-fit: cover;
      object-position: center center;
      border-radius: 0;
      overflow: hidden;
      position: relative;
    }

    /* Pour éviter les bandes noires sur desktop */
    .image-banner__external-video .deferred-media__video {
      position: relative;
      padding-bottom: 56.25%;
      height: 0;
      overflow: hidden;
    }

    .image-banner__external-video .deferred-media__video iframe {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
    }

    /* Fix pour éliminer les bandes noires sur mobile */
    @media (width <= 1000px) {
      .image-banner__external-video {
        display: block;
        width: 100%;
        height: 100%;
        border-radius: 0;
      }

      .image-banner__external-video .deferred-media__video {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        padding-bottom: 0;
      }

      .image-banner__external-video .deferred-media__video iframe {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 177.77vh; /* Pour un ratio 16:9 */
        height: 100vh;
        min-width: 100%;
        min-height: 100%;
      }
    }
  }

  .image-banner__content-wrapper {
    position: relative;
    width: 100%;
    z-index: 2;

    .image-banner__content {
      width: 100%;
      min-height: var(--banner-height-mobile);
      display: flex;
      flex-direction: column;
      justify-content: var(--justify-mobile);
      align-items: var(--align-items-mobile);
      padding: var(--padding-vertical) var(--padding-horizontal);
    }
  }

  @media (width > 750px) {
    .image-banner__content-wrapper .image-banner__content {
      min-height: var(--banner-height);
      justify-content: var(--justify);
      align-items: var(--align-items);
    }
  }
/* END_BLOCK:_image-banner */

/* START_BLOCK:_marquee-image (INDEX:118) */
.marquee-image-block {
    width: var(--width-mobile);

    @media (width > 750px) {
      width: var(--width-desktop);
    }
  }

  .marquee-image-block--height-fill .marquee-image-block__image {
    height: 100%;
  }

  .marquee-image-block__image {
    object-fit: cover;
    aspect-ratio: var(--ratio);
    width: 100%;
  }
/* END_BLOCK:_marquee-image */

/* START_BLOCK:_navigation-link (INDEX:119) */
.navigation-item {
    display: flex;
    align-items: center;
    gap: var(--gap-sm);
    justify-content: center;
    text-decoration: none;
    color: var(--color-foreground);
    min-width: fit-content;
    background-color: var(--color-background);
  }

  shopify-visual-preview-block-list .navigation-item[data-visual-preview-mode] {
    width: 150px;
  }

  .navigation__title {
    font-size: var(--font-body--size);
    color: var(--color-foreground);
    line-height: 1;
  }

  .navigation-item img {
    width: var(--image-width-mobile);
    height: var(--image-width-mobile);
    object-fit: cover;
    border-radius: 50px;
    overflow: hidden;
    object-position: center center;
    background-color: #f8f8f8;
  }

  .navigation--row .navigation-item {
    flex-direction: row;
    border-radius: calc(var(--small-multiplier) * var(--button-border-radius));
    border: var(--container-border-width) solid var(--color-border);
    padding: var(--padding-xxs) var(--padding-sm);
    transition: 0.3s;
    min-height: calc(var(--image-width-mobile) + 2 * var(--padding-xxs));

    img {
      border-radius: calc(calc(var(--small-multiplier) * var(--button-border-radius)) - var(--padding-xxs));
    }

    &.navigation-item--with-image {
      padding-left: var(--padding-xxs);
    }

    &.navigation-item--selected,
    &:hover {
      border: var(--container-border-width) solid var(--color-foreground);
    }
  }

  .navigation--column .navigation-item {
    flex-direction: column;

    .navigation__title {
      max-width: 100px;
      text-align: center;
    }

    img,
    .navigation-item__placeholder {
      outline: var(--container-border-width) solid var(--color-border);
      outline-offset: 0.2rem;
      transition: 0.3s;
    }

    &.navigation-item--selected img,
    &.navigation-item--selected .navigation-item__placeholder,
    &:hover img,
    &:hover .navigation-item__placeholder {
      outline: var(--container-border-width) solid var(--color-foreground);
      outline-offset: 0.2rem;
    }
  }

  @media (width > 750px) {
    .navigation-item img {
      width: var(--image-width-desktop);
      height: var(--image-width-desktop);
    }
  }
/* END_BLOCK:_navigation-link */

/* START_BLOCK:_password-form (INDEX:120) */
.password-form-container {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .password-form {
    margin-top: var(--margin-md);
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 300px;
    max-width: 100%;
    gap: var(--gap-md);
  }
/* END_BLOCK:_password-form */

/* START_BLOCK:_product-add-to-cart-button (INDEX:121) */
shopify-visual-preview-block-list .product-add-to-cart-button[data-visual-preview-mode] {
    width: 400px;
  }

  .product-add-to-cart-button {
    display: flex;
    flex-direction: row;
    gap: var(--gap-sm);
    align-items: center;
  }

  .sticky-add-to-cart {
    width: 100%;
  }

  .sticky-add-to-cart[data-active='false'] {
    bottom: -150px;
  }

  .sticky-add-to-cart[data-active='true'] {
    bottom: 0;
    position: fixed;
    left: 0;
    padding: var(--padding-sm) 0;
    z-index: 2;
    border-top: var(--separator-border-width) solid var(--color-border);
    transition: bottom 300ms ease-in-out;

    .sticky-add-to-cart__content {
      width: 100%;
      max-width: var(--page-width);
      margin: 0 auto;
      padding: 0 var(--page-margin-mobile);
    }
  }

  @media (width > 750px) {
    .sticky-add-to-cart[data-active='true'] {
      padding: var(--padding-md) 0;

      .sticky-add-to-cart__content {
        padding: 0 var(--page-margin-desktop);
      }
    }
  }

  .product-add-to-cart-button .button {
    container-type: inline-size;
  }

  #klaviyo-bis-button-container {
    margin-bottom: 0 !important;
  }

  #klaviyo-bis-button-container button {
    appearance: none !important;
    cursor: pointer !important;
    text-decoration: none !important;
    display: inline-flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 10px !important;
    height: calc(var(--inputs-min-height) - (2 * var(--button-padding-vertical))) !important;
    font-size: var(--button-font-size) !important;
    outline: 1px solid transparent !important;
    transition: all var(--animation-speed-medium) var(--animation-easing) !important;
    padding: var(--button-padding-vertical) var(--button-padding-horizontal) !important;
    color: var(--color-primary-button-text) !important;
    background-color: var(--color-primary-button-background) !important;
    border: var(--button-primary-border-width) solid var(--color-primary-button-border) !important;
    border-radius: var(--button-border-radius) !important;
    font-weight: var(--button-primary-font-weight) !important;
    text-transform: var(--button-primary-text-transform) !important;
    width: -webkit-fill-available !important;
    font-family: var(--font-body--family) !important;
    font-weight: 500 !important;
  }

  .product-add-to-cart-button .full-add-to-cart-text {
    display: block;
  }

  .product-add-to-cart-button .small-add-to-cart-text {
    display: none;
  }

  @container (width < 200px) {
    .product-add-to-cart-button .button__separator,
    .product-add-to-cart-button .price-container {
      display: none;
    }

    .product-add-to-cart-button .full-add-to-cart-text {
      display: block;
    }

    .product-add-to-cart-button .small-add-to-cart-text {
      display: none;
    }
  }

  @container (width < 270px) {
    .product-add-to-cart-button .full-add-to-cart-text {
      display: none;
    }

    .product-add-to-cart-button .small-add-to-cart-text {
      display: block;
    }
  }
/* END_BLOCK:_product-add-to-cart-button */

/* START_BLOCK:_product-card-group (INDEX:122) */
.product-card-group-link {
    display: contents;
    color: inherit;
    text-decoration: none;
  }

  .product-card-group {
    display: flex;
    flex-direction: var(--direction-mobile);
    flex-wrap: var(--wrap-mobile);
    justify-content: var(--justify-mobile);
    align-items: var(--align_items-mobile);
    gap: var(--gap-mobile);
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    overflow: hidden;
    width: 100%;
  }

  @media (width > 750px) {
    .product-card-group {
      flex-direction: var(--direction);
      flex-wrap: var(--wrap);
      justify-content: var(--justify);
      align-items: var(--align_items);
      gap: var(--gap);
    }
  }
/* END_BLOCK:_product-card-group */

/* START_BLOCK:_product-card-media-gallery (INDEX:123) */
.product-card-media-gallery-block {
    position: relative;
  }

  .product-card-media-gallery .splide__slide {
    margin-right: var(--card-padding) !important;
  }

  .product-card-media-gallery .splide__arrow {
    background-color: transparent;
    border: none;
  }

  .product-card-media-gallery__media {
    height: 100%;
  }

  .product-card-media-gallery__media--rounded {
    border-radius: var(--card-border-radius);
    overflow: hidden;
  }

  .product-card.card .product-card-media-gallery__media--rounded {
    border-radius: calc(var(--card-border-radius) - (var(--card-padding) * 0.5));
  }

  .slider-component--65-percent product-card-media-gallery .splide__list {
    width: 100%;
  }

  .product-card-media-gallery__add-to-wishlist-button {
    position: absolute;
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap-xs);
    bottom: var(--padding-xs);
    right: var(--padding-xs);
    background-color: transparent;
  }

  .product-card-media-gallery__add-to-wishlist-button .button {
    background-color: transparent;
  }

  @media (width > 750px) {
    product-card-media-gallery .splide__arrow,
    product-card-media-gallery .splide__arrow:disabled {
      opacity: 0;
      transition: opacity 0.2s ease-in-out;
    }

    product-card:hover product-card-media-gallery .splide__arrow {
      opacity: 1;
    }

    product-card:hover product-card-media-gallery .splide__arrow:disabled {
      opacity: 0.5;
    }

    .product-card-media-gallery__add-to-wishlist-button {
      opacity: 0;
      transition: opacity 0.2s ease-in-out;
    }

    .product-card:hover .product-card-media-gallery__add-to-wishlist-button {
      opacity: 1;
    }
  }
/* END_BLOCK:_product-card-media-gallery */

/* START_BLOCK:_product-card-quick-add (INDEX:124) */
.quick-add-component {
    display: block;
    width: 100%;
    cursor: auto;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .quick-add-component--aligned-at-bottom {
    margin-top: auto;
  }

  .quick-add-component .dialog-modal {
    overflow-x: hidden;
  }

  .quick-add-component .button {
    container-type: inline-size;
  }

  .quick-add-button .full-add-to-cart-text {
    display: block;
  }

  .quick-add-button .small-add-to-cart-text {
    display: none;
  }

  @container (width < 200px) {
    .quick-add-button .full-add-to-cart-text {
      display: none;
    }

    .quick-add-button .small-add-to-cart-text {
      display: block;
    }
  }

  .quick-add-component .dialog-modal__content {
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }

  .quick-add-component .dialog-modal__content > * {
    margin-block: 0;
  }

  .quick-add-component .dialog-modal__content .fake-variant-picker,
  .quick-add-component .dialog-modal__content .slider-block,
  .quick-add-component .dialog-modal__content .stories__container {
    display: none;
  }

  .quick-add-component .product-section__medias--sticky,
  .quick-add-component .product-section__product-info--sticky {
    position: relative !important;
  }

  Neutralize sticky add-to-cart inside quick-add dialogs .quick-add-component .sticky-add-to-cart,
  .quick-add-component .sticky-add-to-cart[data-active='true'] {
    position: static !important;
    bottom: auto !important;
    left: auto !important;
    padding: 0 !important;
    border-top: none !important;
    z-index: auto !important;
    transition: none !important;
  }
/* END_BLOCK:_product-card-quick-add */

/* START_BLOCK:_product-form (INDEX:127) */
shopify-visual-preview-block-list product-form[data-visual-preview-mode] {
    width: 400px;
  }

  .product-form__form {
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }
/* END_BLOCK:_product-form */

/* START_BLOCK:_product-media-gallery (INDEX:128) */
@media (width > 750px) {
    .product-media-gallery .splide__arrow,
    .product-media-gallery .splide__arrow:disabled,
    .product-media-gallery .splide__pagination {
      opacity: 0;
      transition: opacity 0.2s ease-in-out;
    }

    .product-media-gallery:hover .splide__arrow,
    .product-media-gallery:hover .splide__pagination {
      opacity: 1;
    }

    .product-media-gallery:hover .splide__arrow:disabled {
      opacity: 0.5;
    }
  }

  @media (width > 750px) {
    .product-media-gallery--grid {
      .splide__list {
        display: grid;
        grid-template-columns: repeat(var(--grid-columns), 1fr);
        gap: var(--grid-gap);

        .product-media-gallery__media--full-width {
          grid-column: span var(--grid-columns);
        }
      }
      .product-media-gallery__thumbnails {
        display: none;
      }
    }
  }

  .product-media-gallery__media {
    height: 100%;
  }

  .product-media-gallery__media--rounded {
    border-radius: var(--card-border-radius);
    overflow: hidden;
  }

  .product-media-gallery .splide__arrow {
    background-color: transparent;
    border: none;
  }

  .product-media-gallery .splide__pagination {
    bottom: 5px;
  }

  .product-media-gallery__thumbnails {
    margin-top: 10px;
  }

  .product-media-gallery__thumbnail {
    position: relative;
    height: auto !important;

    .product-media-gallery__thumbnail-play-button {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-color: rgba(0, 0, 0, 0.1);

      .icon--play_circle {
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);

        position: absolute;
        font-size: 36px !important;
        color: var(--color-primary-button-text);
      }
    }
  }

  .product-media-gallery__thumbnail-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .product-media-gallery__thumbnail--rounded,
  .product-media-gallery__thumbnail--rounded .product-media-gallery__thumbnail-image,
  .product-media-gallery__thumbnail--rounded .product-media-gallery__thumbnail-play-button {
    border-radius: calc(var(--card-border-radius) - (var(--card-padding) * 0.5));
  }
/* END_BLOCK:_product-media-gallery */

/* START_BLOCK:_product-quantity-selector (INDEX:129) */
shopify-visual-preview-block-list .product-quantity-selector-block[data-visual-preview-mode] {
    width: 100px;
  }
/* END_BLOCK:_product-quantity-selector */

/* START_BLOCK:_product-variant-picker (INDEX:130) */
shopify-visual-preview-block-list variant-picker[data-visual-preview-mode] {
    width: 350px;
  }

  variant-picker {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .variant-picker__options {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
  }

  .variant-picker__option {
    border: none;
    padding: 0;
  }

  .variant-picker__option-name {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--gap-sm);
  }

  .variant-picker__option-values {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap-sm);
  }
/* END_BLOCK:_product-variant-picker */

/* START_BLOCK:_quantity-breaks-item (INDEX:132) */
.quantity-break {
    width: 100%;
    padding: var(--padding-md) var(--padding-xs);
    cursor: pointer;
    display: flex;
    flex-direction: column;
    gap: var(--padding-xs);
    justify-content: center;
    align-items: center;
    flex-grow: 1;
    height: 100%;
    overflow: hidden;
    min-width: 0;
    flex: 1 1 0;
    position: relative;
    color: var(--color-input-text);
    background-color: var(--color-input-background);
    border: var(--inputs-border-width) solid var(--color-input-border);

    &.quantity-break--no-overflow {
      overflow: visible;
    }

    &.quantity-break--selected {
      border: var(--inputs-border-width) solid var(--color-selected-input-border);
    }

    &.quantity-break--disabled {
      opacity: 0.5;
      cursor: not-allowed;
    }

    &.quantity-break--with-image {
      padding: var(--padding-xs);
    }

    &:has(.quantity-break__banner--full-width) {
      gap: var(--gap-sm);
    }
  }

  .quantity-break__main-content {
    display: flex;
    flex-direction: column;
    width: 100%;
    align-items: center;
    gap: var(--padding-xs);
  }

  .quantity-break__price-and-title-container {
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
    align-items: center;
  }

  .quantity-break__title-and-badge-container {
    display: flex;
    align-items: center;
    gap: var(--gap-xs);
    flex-wrap: wrap;
    justify-content: center;
  }

  .quantity-break__title {
    font-size: var(--font-body--size);
    font-weight: 500;
    text-align: center;
    line-height: var(--font-body--size);
  }

  .quantity-break__description p,
  .quantity-break__description ul li,
  .quantity-break__description ol li {
    font-size: var(--font-body--size-small);
  }

  .quantity-break__description p {
    margin: 0;
  }

  .quantity-break__description ul {
    margin: 0;
    padding-left: var(--padding-xs);
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--gap-xs);
  }

  .quantity-break__description ol {
    margin: 0;
    padding-left: calc(var(--padding-xs) * 2);
  }

  .quantity-break__description ul li {
    position: relative;
    padding-left: var(--padding-xs);
  }

  .quantity-break__description ul li::before {
    font-family: var(--icon-font);
    content: 'check';
    position: absolute;
    left: calc(-1 * var(--padding-xs));
  }

  .quantity-break__image-container {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;

    img {
      width: 100%;
      height: auto;
      object-fit: contain;
      border-radius: calc(var(--card-border-radius) - var(--padding-xs));
    }
  }

  .quantity-break__image-badge {
    position: absolute;
    background-color: var(--color-background);
    color: var(--color-foreground);
    font-size: var(--font-body--size-small);
    border-radius: calc(var(--card-border-radius) - (2 * var(--padding-xs)));
    z-index: 1;
    display: flex;
    width: 24px;
    height: 24px;
    justify-content: center;
    align-items: center;

    &.quantity-break__image-badge--topright {
      top: var(--padding-xs);
      right: var(--padding-xs);
    }

    &.quantity-break__image-badge--topleft {
      top: var(--padding-xs);
      left: var(--padding-xs);
    }

    &.quantity-break__image-badge--bottomright {
      bottom: var(--padding-xs);
      right: var(--padding-xs);
    }

    &.quantity-break__image-badge--bottomleft {
      bottom: var(--padding-xs);
      left: var(--padding-xs);
    }
  }

  .quantity-break__content {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: var(--gap-sm);
  }

  .quantity-break__price-container {
    display: flex;
    gap: var(--gap-xs);
    flex-wrap: wrap;
    justify-content: center;
    font-size: var(--font-body--size-small);
    color: var(--color-foreground);

    .quantity-break__price-container_unit-price {
      font-size: var(--font-body--size-small);
      opacity: 0.8;
      text-align: center;
    }
  }

  .quantity-break__banner {
    &.quantity-break__banner--full-width {
      width: calc(100% + 2 * var(--padding-xs));
      z-index: 1;
    }

    &.quantity-break__banner--full-width.quantity-break__banner--bottom {
      border-top-right-radius: 0;
      border-top-left-radius: 0;
      margin-bottom: calc(-1 * var(--padding-md));
    }

    &.quantity-break__banner--full-width.quantity-break__banner--top {
      border-bottom-right-radius: 0;
      border-bottom-left-radius: 0;
      margin-top: calc(-1 * var(--padding-md));
    }

    &.quantity-break__banner--overlap {
      max-width: calc(max-content + var(--padding-xs));
      width: max-content;
      z-index: 1;
    }

    &.quantity-break__banner--overlap.quantity-break__banner--bottom {
      position: absolute;
      bottom: 0;
      transform: translateY(65%);
    }

    &.quantity-break__banner--overlap.quantity-break__banner--top {
      position: absolute;
      top: 0;
      transform: translateY(-65%);
    }
  }

  .quantity-break.quantity-break--with-image .quantity-break__banner {
    &.quantity-break__banner--full-width.quantity-break__banner--bottom {
      margin-bottom: calc(-1 * var(--padding-xs));
    }

    &.quantity-break__banner--full-width.quantity-break__banner--top {
      margin-top: calc(-1 * var(--padding-xs));
    }
  }

  .quantity-breaks-container--column {
    .quantity-break__description p,
    .quantity-break__description ul li {
      text-align: center;
    }

    .quantity-break__price-container .price-container .prices {
      align-items: center;
      justify-content: center;
    }

    .quantity-break__banner {
      &.quantity-break__banner--normal.quantity-break__banner--bottom {
        margin-bottom: calc(-1 * var(--padding-xs));
      }

      &.quantity-break__banner--normal.quantity-break__banner--top {
        margin-top: calc(-1 * var(--padding-xs));
      }
    }

    .quantity-break--with-image .quantity-break__banner {
      &.quantity-break__banner--normal.quantity-break__banner--bottom {
        margin-bottom: 0;
      }

      &.quantity-break__banner--normal.quantity-break__banner--top {
        margin-top: 0;
      }
    }

    .quantity-break--with-image {
      &:has(.quantity-break__banner--bottom.quantity-break__banner--overlap) {
        padding-bottom: var(--padding-md);
      }

      &:has(.quantity-break__banner--top.quantity-break__banner--overlap) {
        padding-top: var(--padding-md);
      }
    }
  }

  .quantity-breaks-container--row {
    .quantity-break {
      flex-direction: column;
      justify-content: flex-start;
      position: relative;
      flex: auto;
    }

    .quantity-break:not(.quantity-break--with-image) {
      padding: var(--padding-md);

      .quantity-break__banner--full-width {
        width: calc(100% + 2 * var(--padding-md));
      }
    }

    .quantity-break:has(.quantity-break__banner--overlap.quantity-break__banner--top) {
      margin-top: var(--margin-sm);
    }

    .quantity-break:has(.quantity-break__banner--overlap.quantity-break__banner--bottom) {
      margin-bottom: var(--margin-sm);
    }

    .quantity-break__main-content {
      flex-direction: row;
      gap: var(--gap-sm);
      align-items: flex-start;
    }

    .quantity-break__content {
      align-self: stretch;
      justify-content: center;
      width: 100%;
    }

    .quantity-break__image-container {
      width: auto;

      img {
        width: var(--image-width);
        max-width: var(--image-width);
      }
    }

    .quantity-break__price-and-title-container {
      align-items: flex-start;
    }

    .quantity-break__title-and-badge-container {
      justify-content: flex-start;
      gap: var(--gap-sm);
    }

    .quantity-break__banner {
      &.quantity-break__banner--normal {
        position: absolute;
        right: var(--padding-xs);
      }

      &.quantity-break__banner--normal.quantity-break__banner--top {
        top: var(--padding-xs);
      }

      &.quantity-break__banner--normal.quantity-break__banner--bottom {
        bottom: var(--padding-xs);
      }

      &.quantity-break__banner--overlap {
        right: var(--padding-xs);
      }
    }
  }

  .quantity-breaks-container.quantity-breaks-container--top {
    align-items: flex-end;
  }

  .quantity-breaks-container.quantity-breaks-container--bottom {
    align-items: flex-start;
  }

  /* Sélection de variante */

  .quantity-break__variant-picker-container {
    display: none;
  }

  .quantity-breaks--with-variant-picker .quantity-break--selected .quantity-break__variant-picker-container {
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }

  .quantity-break__variant-picker-row {
    display: flex;
    align-items: center;
    gap: var(--gap-sm);
  }

  .quantity-break__variant-thumbnail {
    width: 40px;
    height: 40px;
    min-width: 40px;
    border-radius: calc(var(--card-border-radius) - var(--padding-md));
    overflow: hidden;
    background-color: var(--color-background);

    img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
  }

  .quantity-break__variant-thumbnail--hidden {
    display: none;
  }

  .quantity-breaks:not([data-show-variant-thumbnail='true']) .quantity-break__variant-thumbnail {
    display: none;
  }

  /* Cross-sell */

  .quantity-break__cross-sells {
    display: none;
    flex-direction: column;
    width: calc(100% + 2 * var(--padding-xs));
    margin-bottom: calc(-1 * var(--padding-xs));
    border-top: var(--separator-border-width) solid var(--color-input-border);
    padding: var(--padding-xs) var(--padding-sm);
    gap: var(--gap-sm);
  }

  .quantity-break:not(.quantity-break--with-image) .quantity-break__cross-sells {
    margin-bottom: calc(-1 * var(--padding-md));
  }

  .quantity-breaks-container--row .quantity-break:not(.quantity-break--with-image) .quantity-break__cross-sells {
    width: calc(100% + 2 * var(--padding-md));
  }

  .quantity-breaks-container--column .quantity-break:not(.quantity-break--with-image) .quantity-break__cross-sells {
    width: calc(100% + 2 * var(--padding-xs));
  }

  .quantity-breaks-container--column {
    .quantity-break__cross-sells {
      padding: var(--padding-xs);
    }

    .quantity-break__cross-sell-image {
      display: none;
    }

    .quantity-break__cross-sell-info {
      flex-direction: column;
      align-items: flex-start;
      justify-content: flex-start;
      gap: var(--gap-xs);
    }

    .quantity-break__cross-sell-title {
      font-size: var(--font-body--size-small);
    }
  }

  .quantity-break--selected .quantity-break__cross-sells {
    display: flex;
  }

  .quantity-break__cross-sell {
    display: flex;
    align-items: center;
    width: 100%;
  }

  .quantity-break__cross-sell-image {
    flex-shrink: 0;
    margin-right: var(--margin-sm);
  }

  .quantity-break__cross-sell-image img {
    display: block;
    width: 34px;
    height: 34px;
    object-fit: cover;
    border-radius: calc(var(--card-border-radius) - var(--padding-sm));
  }

  .quantity-break__cross-sell-info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gap-xs);
    flex-wrap: wrap;
    flex: 1;
  }

  .quantity-break__cross-sell-title {
    font-size: var(--font-body--size);
    font-weight: 500;
  }

  .quantity-break__cross-sell-price {
    font-size: var(--font-body--size-small);
  }

  .quantity-break__cross-sell-price .price-container {
    justify-content: flex-start;
  }

  quantity-break-variant-picker {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;

    &:not(:last-child) {
      margin-bottom: 1rem;
    }

    .form__label {
      margin: 0;
    }

    .quantity-break__variant-picker-container__option--dropdown {
      display: flex;
      align-items: center;
      gap: 0.5rem;
    }
  }
/* END_BLOCK:_quantity-breaks-item */

/* START_BLOCK:_quantity-breaks (INDEX:133) */
.quantity-breaks {
    display: block;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  shopify-visual-preview-block-list .quantity-breaks[data-visual-preview-mode] {
    width: 450px;
  }

  .product-form__form .toggle-cross-sell:not(:first-of-type) {
    display: none;
  }

  .quantity-breaks-container {
    display: flex;
    flex-direction: row;
    gap: 10px;
  }

  .quantity-breaks-container.quantity-breaks-container--row {
    flex-direction: column;
  }

  .product-section__product-info:has(.quantity-breaks) .product-quantity-selector-block,
  .quantity-breaks--hidden {
    display: none;
  }

  .product-section__product-info:has(.quantity-breaks--with-variant-picker) variant-picker,
  .product-section__product-info:has(.quantity-breaks--with-variant-picker) .subscription {
    display: none;
  }
/* END_BLOCK:_quantity-breaks */

/* START_BLOCK:_slide (INDEX:135) */
.slide {
    display: flex;
    flex-direction: var(--direction);
    flex-wrap: var(--wrap);
    justify-content: var(--justify);
    align-items: var(--align_items);
    gap: var(--gap);
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    overflow: hidden;
    width: 100%;
    height: 100%;
  }
/* END_BLOCK:_slide */

/* START_BLOCK:_social-icon (INDEX:136) */
.social-icon__icon {
    transition: var(--animation-link-hover);
  }

  .social-icon__icon:hover {
    opacity: var(--opacity-link-hover);
  }
/* END_BLOCK:_social-icon */

/* START_BLOCK:_story (INDEX:137) */
.story {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    appearance: none;
    border: none;
    background-color: transparent;
    cursor: pointer;
    max-width: 65px;
    padding: 0;
    margin: 0;
  }

  .story__bubble {
    border-radius: 50%;
    position: relative;
    cursor: pointer;
    transition: all 0.2s ease-in-out;
    width: 55px;
    height: 55px;

    .icon {
      font-size: 32px !important;
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      z-index: 2;
      color: white;
    }

    &:hover {
      transform: scale(102%);
    }

    &:before {
      width: 60px;
      height: 60px;
      content: '';
      background-color: #fff;
      border-radius: 50%;
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      z-index: 2;
    }

    &:after {
      content: '';
      width: 65px;
      height: 65px;
      background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
      border-radius: 50%;
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      z-index: 1;
    }

    img {
      z-index: 3;
      width: 55px;
      height: 55px;
      border-radius: 50%;
      position: relative;
      overflow: hidden;
      cursor: pointer;
      z-index: 2;
      object-fit: cover;
    }
  }

  .story__bubble-label {
    font-size: var(--font-body--size-small);
    padding: 0;
    margin: 0;
    color: var(--color-foreground);
  }

  .story-slider__slide {
    /* border-radius: var(--card-border-radius); */
    overflow: hidden;
  }

  .story-slider__slide img,
  .story-slider__slide video {
    aspect-ratio: 3/5;
    object-fit: cover;
    max-width: 100%;
    height: 100%;
  }

  .story__slider {
    height: 100%;

    & > .splide__track {
      height: 100%;
    }

    & > .splide__arrows > .splide__arrow {
      height: 100%;
      width: 50%;
      border: none;
      background-color: transparent;
      color: var(--color-foreground);
    }

    & > .splide__arrows > .splide__arrow--prev {
      left: 0;
      justify-content: flex-start;

      .icon {
        margin-left: 1rem;
      }
    }

    & > .splide__arrows > .splide__arrow--next {
      right: 0;
      justify-content: flex-end;

      .icon {
        margin-right: 1rem;
      }
    }

    .splide__arrow:disabled {
      opacity: 0.5;
    }
  }

  .story__header {
    position: absolute;
    left: 0;
    top: 0;
    padding: var(--padding-md);
    width: 100%;
    z-index: 1;
    background: linear-gradient(0deg, #0000 6.99%, #00000080 163.32%);

    /* Force GPU layer pour iOS */
    transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    will-change: transform;
  }

  .story__progress-bars {
    display: flex;
    flex-direction: row;
    gap: 3px;
  }

  .story__progress-bar {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    flex: 1;
    min-width: 0;
    height: 2.5px;
  }

  .story__progress-bar[value]::-webkit-progress-bar {
    background-color: rgb(from white r g b / 15%);
    border-radius: var(--card-border-radius);
  }

  .story__progress-bar[value]::-webkit-progress-value {
    background-color: white;
    border-radius: var(--card-border-radius);
  }

  .story__heading {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    padding: var(--margin-md) 0;
    gap: var(--gap-sm);
    font-size: var(--font-body--size-small);
    color: white;

    img {
      border-radius: 50%;
      width: 32px;
      height: 32px;
      object-fit: cover;
    }
  }
/* END_BLOCK:_story */

/* START_BLOCK:_subscription (INDEX:138) */
.subscription {
    display: block;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  shopify-visual-preview-block-list .subscription[data-visual-preview-mode] {
    width: 450px;
  }

  /* Par défaut Shopify affiche un message de consentement sous le bouton d'achat rapide, on le cache */
  #shopify-buyer-consent {
    display: none;
  }

  .subscription__options {
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }

  .subscription__option {
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
    padding: var(--padding-md);
    cursor: pointer;
    transition: border-color 0.2s ease;
    color: var(--color-input-text);
    background-color: var(--color-input-background);
    border: var(--inputs-border-width) solid var(--color-input-border);
  }

  .subscription__option.subscription__option--selected {
    border: var(--inputs-border-width) solid var(--color-selected-input-border);
  }

  .subscription__option-radio {
    display: flex;
    align-items: center;
    gap: var(--gap-xs);
  }

  .subscription__option .radio > .radio__label {
    font-size: var(--font-body--size);
    font-weight: 500;
  }

  .subscription__option-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--gap-sm);
    width: 100%;
  }

  .subscription__option-price {
    flex-shrink: 0;
  }

  .subscription__option-price .prices {
    font-size: var(--font-body--size);
  }

  .subscription__frequency {
    width: 100%;
  }

  .subscription__frequency-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap-sm);
    border: none;
    padding: 0;
  }

  .subscription__frequency-button input {
    clip: rect(0, 0, 0, 0);
    overflow: hidden;
    position: absolute;
    height: 1px;
    width: 1px;
  }

  .subscription__frequency-button input + label {
    appearance: none;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    font-size: var(--variant-button-font-size);
    transition: all var(--animation-speed-medium) var(--animation-easing);
    color: var(--color-input-text);
    background-color: var(--color-input-background);
    border: var(--inputs-border-width) solid var(--color-input-border);
    font-weight: var(--button-primary-font-weight);
    text-transform: var(--button-primary-text-transform);
    letter-spacing: var(--button-letter-spacing);
    padding: calc(var(--button-padding-vertical) / 2) calc(var(--button-padding-horizontal) * var(--small-multiplier));
    min-height: calc(var(--small-multiplier) * var(--inputs-min-height));
    min-width: calc(var(--small-multiplier) * var(--inputs-min-width));
    border-radius: calc(var(--small-multiplier) * var(--button-border-radius));
  }

  .subscription__frequency-button input:checked + label {
    background-color: var(--color-selected-input-background);
    color: var(--color-selected-input-text);
    border-color: var(--color-selected-input-border);
  }

  .subscription__option-description p,
  .subscription__option-description ul li,
  .subscription__option-description ol li {
    font-size: var(--font-body--size-small);
  }

  .subscription__option-description p {
    margin: 0;
  }

  .subscription__option-description ul {
    margin: 0;
    padding-left: var(--padding-xs);
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--gap-xs);
  }

  .subscription__option-description ol {
    margin: 0;
    padding-left: calc(var(--padding-xs) * 2);
  }

  .subscription__option-description ul li {
    position: relative;
    padding-left: var(--padding-xs);
  }

  .subscription__option-description ul li::before {
    font-family: var(--icon-font);
    content: 'check';
    position: absolute;
    left: calc(-1 * var(--padding-xs));
  }
/* END_BLOCK:_subscription */

/* START_BLOCK:_tab (INDEX:139) */
.tab__button {
    appearance: none;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    min-height: var(--tab-button-min-height);
    width: max-content;
    font-size: var(--tab-button-font-size);
    outline: 1px solid transparent;
    transition: all var(--animation-speed-medium) var(--animation-easing);
    padding: var(--tab-button-padding-vertical) var(--tab-button-padding-horizontal);
    color: var(--color-tab-text);
    background-color: var(--color-tab-background);
    border: var(--tab-button-border-width) solid var(--color-tab-border);
    border-radius: calc(var(--small-multiplier) * var(--button-border-radius));
    font-weight: var(--button-primary-font-weight);
    text-transform: var(--button-primary-text-transform);
    letter-spacing: var(--button-letter-spacing);
  }

  .tab.active .tab__button {
    background-color: var(--color-selected-tab-background);
    color: var(--color-selected-tab-text);
    border-color: var(--color-selected-tab-border);
  }
/* END_BLOCK:_tab */

/* START_BLOCK:_toggle-cross-sell (INDEX:140) */
.toggle-cross-sell {
    display: block;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  shopify-visual-preview-block-list .toggle-cross-sell[data-visual-preview-mode] {
    width: 400px;
  }

  .product-form__form .toggle-cross-sell:not(:first-of-type) {
    display: none;
  }

  .toggle-cross-sell__content {
    margin-bottom: var(--margin-sm);
  }

  .toggle-cross-sell__description p {
    margin: 0;
    line-height: normal;
    font-size: var(--font-body--size);
  }

  .toggle-cross-sell__products {
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
    width: 100%;
  }

  .toggle-cross-sell__product {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    /* min-height: 50px; */
    gap: var(--gap-md);
    overflow: hidden;
    cursor: pointer;
    border-radius: var(--card-border-radius);
    padding: var(--padding-xs);
    color: var(--color-input-text);
    background-color: var(--color-input-background);
    border: var(--inputs-border-width) solid var(--color-input-border);
  }

  .toggle-cross-sell__product:has(input[type='checkbox']:checked) {
    border-color: var(--color-selected-input-border);
  }

  .toggle-cross-sell__product-image img {
    display: block;
    min-width: 55px;
    width: 55px;
    border-radius: calc(var(--card-border-radius) - var(--margin-sm));
  }

  .toggle-cross-sell__product-image--wide img {
    object-fit: cover;
    min-height: 100%;
    border-radius: 0;
  }

  .toggle-cross-sell__product-container {
    display: flex;
    flex-direction: row;
    cursor: auto;
    gap: var(--gap-sm);
  }

  .toggle-cross-sell__product-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: var(--gap-sm);
  }

  .toggle-cross-sell__product-content--no-image {
    margin-left: var(--margin-sm);
  }

  .toggle-cross-sell__product-header {
    display: flex;
    gap: var(--gap-xs);
    flex-wrap: wrap;
    flex-direction: column;
  }

  .toggle-cross-sell__product-title {
    margin: 0;
    font-size: var(--font-body--size);
    font-weight: 500;
    text-decoration: none;
    color: inherit;
  }

  .toggle-cross-sell__product-price-container {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: var(--gap-sm);
    font-size: var(--font-body--size-small);
  }

  .toggle-cross-sell__product .checkbox,
  .toggle-cross-sell__product .button {
    margin-right: var(--margin-sm);
  }

  .toggle-cross-sell__text-add,
  .toggle-cross-sell__text-added,
  .toggle-cross-sell__text-remove {
    display: none;
  }

  .toggle-cross-sell__product .button.button--secondary .toggle-cross-sell__text-add {
    display: block;
  }

  .toggle-cross-sell__product .button.button--active:not(:hover) .toggle-cross-sell__text-added {
    display: block;
  }

  .toggle-cross-sell__product .button.button--active:hover .toggle-cross-sell__text-remove {
    display: block;
  }
/* END_BLOCK:_toggle-cross-sell */

/* START_BLOCK:accordions (INDEX:141) */
.accordions {
    width: 100%;
  }

  shopify-visual-preview-block-list .accordions[data-visual-preview-mode] {
    width: 450px;
  }

  .accordion-block {
    flex: 1;
    width: 100%;
  }

  .accordions--dividers .accordion-block:not(:last-child) .accordion {
    border-bottom: var(--separator-border-width) solid var(--color-border);
  }

  .accordions--dividers .accordion .details-content {
    padding-block-end: var(--padding-sm);
  }

  .accordions--caret .accordion__icons-add,
  .accordions--add .icon--keyboard_arrow_down {
    display: none;
  }
/* END_BLOCK:accordions */

/* START_BLOCK:badges (INDEX:142) */
.badges {
    justify-content: var(--alignment-mobile);
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  @media (width > 750px) {
    .badges {
      justify-content: var(--alignment);
    }
  }
/* END_BLOCK:badges */

/* START_BLOCK:before-after (INDEX:143) */
.before-after-block {
    width: var(--width-mobile);
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    position: relative;
  }

  .before-after-block__container {
    position: relative;
    width: 100%;
    aspect-ratio: var(--ratio);
    overflow: hidden;
    border-radius: var(--card-border-radius);
  }

  .before-after-block__image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
  }

  .before-after-block__image--before {
    clip-path: inset(0 50% 0 0);
    transition: clip-path 0.1s ease-out;
  }

  .before-after-block__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  .before-after-block__slider {
    position: absolute;
    top: 0;
    left: 50%;
    width: 4px;
    height: 100%;
    background-color: transparent;
    cursor: ew-resize;
    transform: translateX(-50%);
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .before-after-block__slider-line {
    width: 3px;
    height: 100%;
    background-color: var(--color-background);
  }

  .before-after-block__slider-handle {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 40px;
    height: 40px;
    background-color: var(--color-background);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: grab;
    transition: transform 0.1s ease-out;
    border: var(--button-secondary-border-width) solid var(--color-secondary-button-border);
  }

  .before-after-block__slider-handle:active {
    cursor: grabbing;
    transform: translate(-50%, -50%) scale(1.1);
  }

  .before-after-block__slider-icon {
    width: 16px;
    height: 16px;
    color: var(--color-text);
  }

  @media (width > 750px) {
    .before-after-block__slider-handle {
      width: 48px;
      height: 48px;
    }

    .before-after-block__slider-icon {
      width: 20px;
      height: 20px;
    }
  }

  .before-after-block__label {
    position: absolute;
    top: 1rem;
    pointer-events: none;
  }

  .before-after-block__label--before {
    left: 1rem;
  }

  .before-after-block__label--after {
    right: 1rem;
  }

  .before-after-block__label.badge--custom {
    background-color: var(--badge-custom-background);
    color: var(--badge-custom-text);
    border: var(--badge-primary-border-width) solid var(--badge-custom-border);
  }

  @media (width > 750px) {
    .before-after-block {
      width: var(--width-desktop);
    }
  }

  shopify-visual-preview-block-list .before-after-block[data-visual-preview-mode] {
    width: 100%;
    max-width: 600px;
  }
/* END_BLOCK:before-after */

/* START_BLOCK:button (INDEX:144) */
.button-block {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .button-block--full-width {
    width: 100%;
  }
/* END_BLOCK:button */

/* START_BLOCK:collection-featured (INDEX:145) */
.block-collection-featured {
    width: 100%;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  shopify-visual-preview-block-list .block-collection-featured .splide__arrow {
    display: none !important;
  }

  .block-collection-featured__inner {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .block-collection-featured__grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    gap: var(--gap-md);
  }

  @media (width > 750px) {
    .block-collection-featured__grid {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_BLOCK:collection-featured */

/* START_BLOCK:collections-featured (INDEX:146) */
.block-collections-featured {
    width: 100%;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .block-collections-featured__inner {
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .block-collections-featured__grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    gap: var(--gap-md);
  }

  @media (width > 750px) {
    .block-collections-featured__grid {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_BLOCK:collections-featured */

/* START_BLOCK:contact-form (INDEX:147) */
.contact-form {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
    width: 100%;
  }

  shopify-visual-preview-block-list .contact-form[data-visual-preview-mode] {
    max-width: 500px;
  }
/* END_BLOCK:contact-form */

/* START_BLOCK:copyright (INDEX:148) */
.footer-copyright {
    display: flex;
    align-items: center;
    justify-content: var(--alignment-mobile);
  }

  @media (width > 750px) {
    .footer-copyright {
      justify-content: var(--alignment);
    }
  }

  .footer-copyright__text,
  .footer-copyright__text > a {
    color: var(--color-foreground);
    text-decoration: none;
    font-size: var(--font-body--size-small);
  }

  .footer-copyright__text > a {
    transition: var(--animation-link-hover);

    &:hover {
      opacity: var(--opacity-link-hover);
    }
  }
/* END_BLOCK:copyright */

/* START_BLOCK:countdown (INDEX:149) */
.countdown {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    padding: var(--padding-md);
  }

  .countdown:not(.card) {
    padding: 0;
    background-color: inherit;
    color: inherit;
  }

  shopify-visual-preview-block-list .countdown[data-visual-preview-mode] {
    width: 300px;
  }

  date-counter {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--gap-sm);
    margin: 0;
  }

  .countdown__timer {
    display: flex;
    gap: var(--gap-sm);
    width: 100%;
    justify-content: center;
  }

  .countdown__timer-card:not(:last-child)::after {
    content: '';
    position: absolute;
    right: calc(-1 * var(--gap-sm) / 2 - 1px);
    top: calc(50%);
    transform: translateY(-50%);
    width: 1.5px;
    border-radius: 3px;
    height: 60%;
    background-color: var(--color-foreground);
    opacity: 0.2;
  }

  .countdown__timer--background .countdown__timer-card:not(:last-child)::after,
  .countdown__timer--border .countdown__timer-card:not(:last-child)::after {
    display: none;
  }

  .countdown__timer-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: fit-content;
    position: relative;
  }

  .countdown__timer-value {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 var(--padding-md) var(--padding-xxs);
    height: calc(var(--countdown-timer-font-size) + var(--padding-xxs));
    border-radius: 3px;
    line-height: 1;
    font-weight: var(--countdown-timer-font-weight);
    font-size: var(--countdown-timer-font-size);
  }

  .countdown__timer--background .countdown__timer-value {
    background-color: var(--color-foreground);
    color: var(--color-background);
    padding: var(--padding-sm);
    margin-bottom: var(--margin-xs);
  }

  .countdown__timer--border .countdown__timer-value {
    background-color: var(--color-background);
    border: 1px solid var(--color-border);
    padding: var(--padding-sm);
    margin-bottom: var(--margin-xs);
  }

  .countdown__timer-label {
    font-size: 10px;
    text-align: center;
    width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    opacity: 0.8;
  }

  .countdown__timer-ended p {
    font-weight: 500;
  }
/* END_BLOCK:countdown */

/* START_BLOCK:cross-sell (INDEX:150) */
cross-sell-component {
    display: block;
    container-type: inline-size;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    width: 100%;
  }

  shopify-visual-preview-block-list cross-sell-component.cross-sell--row[data-visual-preview-mode] {
    width: 400px;
  }

  shopify-visual-preview-block-list cross-sell-component.cross-sell--column[data-visual-preview-mode] {
    width: 200px;
  }

  .cross-sell {
    display: grid;
    grid-template-columns: auto 1fr 1fr;
    gap: var(--padding-sm);
    grid-template-areas: 'image content content';
    padding: var(--padding-sm);
    border: var(--container-border-width) solid var(--color-border);
  }

  .cart__footer .cross-sell {
    border-radius: calc(var(--card-border-radius) - (var(--card-padding) * 0.5));
  }

  .cross-sell--column .cross-sell {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    .cross-sell__content,
    .cross-sell__actions,
    .cross-sell__heading {
      justify-content: center;
      align-items: center;
      flex-direction: column;
      text-align: center;
    }

    .cross-sell__content,
    .cross-sell__actions,
    .cross-sell__form,
    .cross-sell__form .button {
      min-width: 100%;
    }
  }

  .cross-sell--no-image {
    grid-template-areas: 'content content content';
  }

  .cross-sell__image {
    width: 100%;
    grid-area: image;
    max-width: var(--image-width);
    aspect-ratio: 1/1;
    object-fit: cover;
    border-radius: calc(var(--card-border-radius) - var(--padding-sm));
  }

  .cross-sell__content {
    grid-area: content;
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    gap: var(--padding-xs);
  }

  .cross-sell__heading {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--padding-xs);
    /* flex-wrap: wrap; */
  }

  .cross-sell__heading .prices {
    font-size: var(--font-body--size-small);
  }

  .cross-sell__title-and-description {
    display: flex;
    flex-direction: column;
  }

  .cross-sell__title {
    line-height: normal;
    font-weight: 600;
    font-size: var(--font-body--size);
    margin: 0;
  }

  .cross-sell__description p {
    margin: 0;
    /* line-height: normal; */
    font-size: var(--font-body--size-small);
  }

  .cross-sell__actions {
    display: flex;
    gap: var(--padding-xs);
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-end;
  }

  .cross-sell__selects {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    width: 100%;
    flex: 1;
    gap: var(--gap-xs);
  }

  .cross-sell__select-label {
    font-size: var(--font-body--size-small);
    margin-bottom: var(--padding-xs);
    line-height: normal;
  }

  .cross-sell__select {
    display: flex;
    flex-direction: column;
    width: 100%;
  }

  /* .cross-sell__select:not(.hidden):not(:last-child) {
    margin-right: var(--padding-sm);
  } */

  @container (width < 350px) {
    .cross-sell--row .cross-sell {
      gap: var(--gap-sm);
    }

    .cross-sell__actions .button {
      min-width: 60px;
      padding: calc(var(--button-padding-vertical) / 2) calc(var(--button-padding-horizontal) * var(--small-multiplier) / 2);
    }

    .cross-sell__image {
      max-width: 65px;
    }
  }
/* END_BLOCK:cross-sell */

/* START_BLOCK:custom-code (INDEX:151) */
.custom-code-block {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }
/* END_BLOCK:custom-code */

/* START_BLOCK:delivery-estimation (INDEX:152) */
.delivery-estimation {
    display: block;
    font-size: var(--font-body--size);
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  shopify-visual-preview-block-list .delivery-estimation[data-visual-preview-mode] {
    width: 300px;
  }

  .delivery-estimation__content {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
    align-items: center;
    justify-content: var(--alignment-mobile);

    .icon {
      font-size: 18px !important;
      width: 18px !important;
      height: 18px !important;
      margin-right: var(--margin-xs);
    }
  }

  @media (width > 750px) {
    .delivery-estimation__content {
      justify-content: var(--alignment);
    }
  }
/* END_BLOCK:delivery-estimation */

/* START_BLOCK:filters-and-sort (INDEX:153) */
.filter-and-sort--loading .filter-list,
  .filter-and-sort--loading sort-component,
  .filter-and-sort--loading sort-inline-component,
  .filter-and-sort--loading .filters__clear-all {
    opacity: 0.5;
    pointer-events: none;
  }

  .filter-and-sort__inline,
  .filter-and-sort__sidebar {
    display: none;
  }

  .filter-and-sort__sort-only {
    display: flex;
    justify-content: flex-end;
    width: 100%;
  }

  @media (width > 750px) {
    .filter-and-sort:not(.filter-and-sort--menu) .filter-and-sort__mobile {
      display: none;
    }

    .filter-and-sort--inline .filter-and-sort__inline {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: var(--gap-sm);
    }

    .filter-and-sort--sidebar .filter-and-sort__sidebar {
      display: block;
    }

    .filter-and-sort--sidebar.filter-and-sort--sticky .filter-and-sort__sidebar {
      height: fit-content;
      position: sticky;
      top: calc(var(--header-height, 0px) + var(--padding-md));
    }
  }
/* END_BLOCK:filters-and-sort */

/* START_BLOCK:group (INDEX:154) */
.group {
    gap: var(--gap-mobile);
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    overflow: hidden;
    width: var(--width-mobile);
  }

  .group.card {
    padding: var(--padding-vertical) var(--padding-horizontal);
  }

  shopify-visual-preview-block-list .group[data-visual-preview-mode] {
    width: 100%;
    max-width: 450px;
  }

  .group--flex {
    display: flex;
    flex-direction: var(--direction-mobile);
    flex-wrap: var(--wrap-mobile);
    justify-content: var(--justify-mobile);
    align-items: var(--align_items-mobile);
  }

  .group--grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-columns-mobile), 1fr);
    grid-template-rows: auto;
  }

  @media (width > 750px) {
    .group {
      gap: var(--gap);
      width: var(--width);
    }

    .group--flex {
      flex-direction: var(--direction);
      flex-wrap: var(--wrap);
      justify-content: var(--justify);
      align-items: var(--align_items);
    }

    .group--grid {
      grid-template-columns: repeat(var(--grid-columns), 1fr);
    }
  }
/* END_BLOCK:group */

/* START_BLOCK:icon-with-text (INDEX:155) */
.icon-with-text {
    display: flex;
    gap: var(--gap-mobile);
    overflow: hidden;
    width: 100%;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .icon-with-text .text-block {
    margin-top: 0;
    margin-bottom: 0;
  }

  .icon-with-text--row-mobile {
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
  }

  .icon-with-text--column-mobile {
    flex-direction: column;
    align-items: center;
    justify-content: center;

    .text-block.paragraph p {
      text-align: center;
    }
  }

  shopify-visual-preview-block-list .icon-with-text[data-visual-preview-mode] {
    width: 100%;
    max-width: 350px;
  }

  .text-block.paragraph p {
    font-weight: var(--font-weight);
  }

  .text-block.paragraph a {
    color: inherit;
  }

  @media (width > 750px) {
    .icon-with-text {
      gap: var(--gap);
    }

    .icon-with-text--row-desktop {
      flex-direction: row;
      align-items: center;
      justify-content: flex-start;

      .text-block.paragraph p {
        text-align: left;
      }
    }

    .icon-with-text--column-desktop {
      flex-direction: column;
      align-items: center;
      justify-content: center;

      .text-block.paragraph p {
        text-align: center;
      }
    }
  }
/* END_BLOCK:icon-with-text */

/* START_BLOCK:image-card (INDEX:157) */
.image-card {
    position: relative;
    overflow: hidden;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    text-decoration: none;
    color: var(--color-foreground);
    width: 100%;
    height: 100%;
    display: block;

    &.card {
      padding: 0;
    }
  }

  shopify-visual-preview-block-list .image-card[data-visual-preview-mode] {
    width: 350px;
  }

  .image-card__image-filter {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--color);
    opacity: calc(var(--opacity) / 100);
    z-index: 1;
  }

  .image-card__image {
    position: absolute;
    width: 100%;
    height: 100%;

    img,
    .placeholder-image {
      height: 100%;
      width: 100%;
      object-fit: cover;
      object-position: center center;
      border-radius: 0;
      overflow: hidden;
      position: relative;
    }
  }

  .image-card__content-wrapper {
    position: relative;
    width: 100%;
    z-index: 2;
    padding: var(--card-padding);
    height: 100%;

    .image-card__content {
      width: 100%;
      min-height: var(--image-height);
      height: 100%;
      display: flex;
      flex-direction: column;
      gap: var(--gap-xxs);
      justify-content: var(--justify);
      align-items: var(--align_items);
    }
  }

  /* L'overlay passe au-dessus du filtre */
  .image-card .stretched-link__overlay {
    z-index: 2;
  }
  /* Le content-wrapper reste visuellement au-dessus, 
   mais transparent aux clics */
  .image-card.stretched-link .image-card__content-wrapper {
    z-index: 3;
    pointer-events: none;
  }
  /* Les éléments interactifs récupèrent les clics */
  .image-card.stretched-link .image-card__content-wrapper a,
  .image-card.stretched-link .image-card__content-wrapper button,
  .image-card.stretched-link .image-card__content-wrapper input,
  .image-card.stretched-link .image-card__content-wrapper select,
  .image-card.stretched-link .image-card__content-wrapper summary {
    pointer-events: auto;
  }

  @media (width > 750px) {
    .image-card__content {
      padding: var(--padding-vertical) var(--padding-horizontal);
    }
  }
/* END_BLOCK:image-card */

/* START_BLOCK:image (INDEX:158) */
.image-block {
    width: var(--width-mobile);

    @media (width > 750px) {
      width: var(--width-desktop);
    }
  }

  .image-block__image {
    object-fit: cover;
    aspect-ratio: var(--ratio);
    width: 100%;
  }

  .image-block__image--rounded {
    border-radius: var(--card-border-radius);
  }

  .image-block--height-fill .image-block__image {
    height: 100%;
  }
/* END_BLOCK:image */

/* START_BLOCK:information-slider (INDEX:159) */
.slider-block {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    overflow: hidden;
    width: 100%;
  }

  shopify-visual-preview-block-list .slider-block[data-visual-preview-mode] {
    width: 400px;
  }

  .slider-block--with-pagination {
    padding-bottom: var(--margin-lg);

    &.slider-block--with-pagination-on-left {
      padding-bottom: 0;

      .splide__pagination {
        right: 0;
        left: auto;
        bottom: 50%;
        transform: translateY(50%);
        align-items: center;
        padding: 0;
      }

      .splide__pagination li {
        display: flex;
        align-items: center;
        justify-content: center;
      }
    }
  }
/* END_BLOCK:information-slider */

/* START_BLOCK:logo (INDEX:160) */
.block__logo {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }
/* END_BLOCK:logo */

/* START_BLOCK:marquee (INDEX:161) */
.marquee {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    width: 100%;
  }

  /* Quand la barre est un enfant direct d'une section qui a page-width, on lui fait prendre toute la largeur de la page */
  .page-width > .marquee {
    margin-left: calc(-1 * var(--page-margin-desktop));
    width: calc(100% + 2 * var(--page-margin-desktop));
  }

  marquee-component {
    display: block;
    width: 100%;
    overflow: hidden;
  }

  .marquee__wrapper {
    display: flex;
    gap: var(--marquee-gap);
    width: fit-content;
    white-space: nowrap;
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .marquee__content {
    min-width: max-content;
    display: flex;
    gap: var(--marquee-gap);
  }

  .marquee__content :is(p, h1, h2, h3, h4, h5, h6) {
    white-space: nowrap;
  }

  .marquee__content .marquee__repeated-items * {
    max-width: none;
  }

  .marquee__repeated-items {
    min-width: max-content;
    display: flex;
    gap: var(--marquee-gap);
    align-items: center;
    justify-content: center;
  }

  .marquee__repeated-items > * {
    align-content: center;
  }

  @media (prefers-reduced-motion: no-preference) {
    marquee-component:not([data-disabled]) .marquee__wrapper {
      animation: marquee-motion var(--marquee-speed) linear infinite var(--marquee-direction);
    }
  }

  @keyframes marquee-motion {
    to {
      transform: translate3d(calc(-50% - (var(--marquee-gap) / 2)), 0, 0);
    }
  }
/* END_BLOCK:marquee */

/* START_BLOCK:menu (INDEX:162) */
.menu-block {
    display: flex;
    justify-content: var(--alignment-mobile);
    margin: var(--margin-top) 0 var(--margin-bottom) 0;
  }

  @media (width > 750px) {
    .menu-block {
      justify-content: var(--alignment);
    }
  }

  .menu-block__content {
    display: flex;
    flex-direction: column;
    gap: var(--gap-md);
  }

  .menu-block__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: var(--menu-direction);
    gap: var(--gap-md);
  }

  .menu-block__item {
    margin: 0;
  }

  .menu-block__link {
    text-decoration: none;
    color: var(--color-foreground);
    font-size: var(--font-body--size);
    font-weight: var(--font-body--weight);
    transition: var(--animation-link-hover);

    &:hover {
      opacity: var(--opacity-link-hover);
    }
  }

  .menu-block__link--underlined {
    text-decoration: underline;
  }
/* END_BLOCK:menu */

/* START_BLOCK:newsletter-signup (INDEX:163) */
shopify-visual-preview-block-list .newsletter-signup[data-visual-preview-mode] {
    width: 300px;
    max-width: 100%;
  }

  .newsletter-signup {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    width: 100%;
  }

  .newsletter-signup__form {
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }
/* END_BLOCK:newsletter-signup */

/* START_BLOCK:payment-methods (INDEX:164) */
.payment-methods {
    display: flex;
    flex-direction: row;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--gap-xs);
    margin: var(--margin-top) 0 var(--margin-bottom) 0;
    width: 100%;
    justify-content: var(--alignment-mobile);
  }

  shopify-visual-preview-block-list .payment-methods[data-visual-preview-mode] {
    width: max-content;
  }

  @media (width > 750px) {
    .payment-methods {
      justify-content: var(--alignment);
    }
  }

  .payment-methods svg {
    width: var(--icon-size);
    height: auto;
  }
/* END_BLOCK:payment-methods */

/* START_BLOCK:powered-by-fullstack (INDEX:166) */
.powered-by-fullstack {
    display: flex;
    flex-direction: row;
    align-items: center;
    width: 100%;
    justify-content: var(--alignment-mobile);
  }

  @media (width > 750px) {
    .powered-by-fullstack {
      justify-content: var(--alignment);
    }
  }

  .powered-by-fullstack-minimal {
    color: var(--color-foreground);
    font-size: var(--font-body--size);
    text-decoration: underline;
    transition: var(--animation-link-hover);

    &:hover {
      opacity: var(--opacity-link-hover);
    }
  }

  .powered-by-fullstack-badge {
    border: 1px solid lightgray;
    border-radius: 4px;
    padding: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.5s ease;
    background-color: white;
    position: relative;
    overflow: hidden;
    margin: 2px;
    width: 120px;
  }

  .powered-by-fullstack-badge::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -100%;
    width: 200%;
    height: 200%;
    background: linear-gradient(0deg, transparent, transparent 30%, rgba(255, 255, 255, 0.5));
    transform: rotate(-45deg);
    transition: all 0.5s ease;
    opacity: 0;
  }

  .powered-by-fullstack-badge:hover {
    transform: scale(1.02);
    box-shadow: 0 0 5px rgba(0, 0, 0, 0.1);
  }

  .powered-by-fullstack-badge:hover::before {
    opacity: 1;
    transform: rotate(-45deg) translateY(150%);
  }
/* END_BLOCK:powered-by-fullstack */

/* START_BLOCK:product-inventory (INDEX:168) */
.product-inventory {
    display: block;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  shopify-visual-preview-block-list .product-inventory[data-visual-preview-mode] {
    width: 150px;
  }

  .product-inventory__status {
    display: flex;
    align-items: center;
    gap: var(--gap-sm);
    font-size: var(--font-body--size);
  }

  .product-inventory__status--left {
    justify-content: flex-start;
  }

  .product-inventory__status--right {
    justify-content: flex-end;
  }

  .product-inventory__status--center {
    justify-content: center;
  }

  .product-inventory__icon,
  .product-inventory__icon svg {
    width: 15px;
    height: 15px;
  }

  .product-inventory__icon-low {
    color: orange;
  }

  .product-inventory__icon-in_stock {
    color: green;
  }

  .product-inventory__icon-out_of_stock {
    color: red;
  }

  .product-inventory__icon circle:first-of-type {
    opacity: 0.3;
  }
/* END_BLOCK:product-inventory */

/* START_BLOCK:product-mini-card (INDEX:169) */
.product-mini-card {
    display: flex;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    padding: 0;
    overflow: hidden;
    text-decoration: none;
    color: var(--color-foreground);
    font-size: var(--font-body--size);
    transition: transform 0.2s ease-in-out;
    padding: var(--padding-xs);
  }

  .product-mini-card--column {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--gap-sm);
    max-width: 150px;

    .product-mini-card__content {
      text-align: center;

      .price-container {
        text-align: center;
        justify-content: center;
      }
    }
  }

  .product-mini-card--row {
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    width: max-content;
    max-width: 100%;
  }

  .this-pack-contains_product-list .product-mini-card {
    min-width: max-content;
  }

  a.product-mini-card:hover {
    transform: translateY(-2px);
  }

  shopify-visual-preview-block-list .product-mini-card[data-visual-preview-mode] {
    width: 300px;
  }

  .product-mini-card__image {
    border-radius: calc(var(--card-border-radius) - var(--padding-xs));
    object-fit: cover;
    height: var(--height);
    width: var(--width);
  }

  .product-mini-card__content {
    display: flex;
    flex-direction: column;
    gap: var(--gap-xs);
    padding: 0 var(--padding-xs);
  }

  .product-mini-card__title {
    font-weight: 500;
  }
/* END_BLOCK:product-mini-card */

/* START_BLOCK:product-price (INDEX:170) */
product-price {
    display: flex;
    flex-direction: column;
    min-height: calc(2 * var(--padding-xxs) + var(--font-body--size-small) + var(--badge-primary-border-width) * 2);
    justify-content: center;
  }
/* END_BLOCK:product-price */

/* START_BLOCK:rating-stars (INDEX:171) */
.rating-stars__link {
    text-decoration: none;
    color: inherit;
  }
/* END_BLOCK:rating-stars */

/* START_BLOCK:review (INDEX:172) */
.review {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  shopify-visual-preview-block-list .review[data-visual-preview-mode] {
    width: 400px;
  }
/* END_BLOCK:review */

/* START_BLOCK:reviews-badge (INDEX:173) */
.reviews-badge {
    width: fit-content;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  shopify-visual-preview-block-list .reviews-badge[data-visual-preview-mode] {
    max-width: 400px;
  }

  .reviews-badge a {
    text-decoration: none;
    color: inherit;
  }

  .reviews-badge_badge {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--gap-sm);
    background-color: transparent;
  }

  .reviews-badge_badge--wrapped {
    border-radius: var(--badge-border-radius);
    padding: var(--padding-sm) var(--padding-md);
    background-color: var(--color-background);
    height: 40px;
  }

  .reviews-badge_stars:has(.icon) {
    height: 20px;
  }

  .reviews-badge_stars svg {
    width: 90px;
  }

  .reviews-badge_stars .icon {
    font-size: 20px !important;
    margin: 0 -4px;
    font-variation-settings: 'FILL' 0, 'wght' var(--icon-weight), 'GRAD' 0, 'opsz' 20;
  }

  .reviews-badge_stars .icon--star,
  .reviews-badge_stars .icon--star-filled {
    color: var(--color-stars-icons);
  }

  .reviews-badge_stars .icon--google {
    color: #fbbc05;
  }

  .reviews-badge_stars .icon--star-filled {
    font-variation-settings: 'FILL' 1, 'wght' var(--icon-weight), 'GRAD' 0, 'opsz' 20;
  }

  .reviews-badge_logo img,
  .reviews-badge_logo svg {
    width: 100%;
    max-height: 20px;
  }

  .reviews-badge_logo .trustpilot-logo {
    max-width: 80px;
  }

  .reviews-badge_stars svg,
  .reviews-badge_logo svg {
    display: flex;
  }

  .reviews-badge_logo .trustpilot-logo {
    margin-top: -5px;
  }

  .reviews-badge_text-1,
  .reviews-badge_text-2 {
    font-size: var(--font-body--size);
  }

  .reviews-badge_text-1 p,
  .reviews-badge_text-2 p {
    margin: 0;
  }

  @media screen and (max-width: 768px) {
    .reviews-badge_badge {
      gap: 7px;
    }

    .reviews-badge_badge--wrapped {
      padding: 10px 15px;
    }

    .reviews-badge_text-1,
    .reviews-badge_text-2 {
      font-size: var(--font-body--size-small);
    }

    .reviews-badge_logo img,
    .reviews-badge_logo svg {
      width: 100%;
      max-width: 80px;
    }

    .reviews-badge_stars svg {
      width: 80px;
    }
  }

  @media screen and (max-width: 390px) {
    .reviews-badge_text-1 {
      display: none;
    }
  }
/* END_BLOCK:reviews-badge */

/* START_BLOCK:separator (INDEX:174) */
.separator-block {
    width: 100%;
  }

  shopify-visual-preview-block-list .separator-block[data-visual-preview-mode] {
    width: 150px;
  }
/* END_BLOCK:separator */

/* START_BLOCK:slider (INDEX:175) */
.slider-block {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    overflow: hidden;
    width: 100%;
  }

  shopify-visual-preview-block-list .slider-block[data-visual-preview-mode] {
    width: 400px;
  }

  .slider-block--with-pagination {
    padding-bottom: var(--margin-lg);
  }
/* END_BLOCK:slider */

/* START_BLOCK:social-icons (INDEX:176) */
.social-icons {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    display: flex;
    justify-content: var(--alignment-mobile);
    gap: var(--gap-md);
    align-items: center;
    width: 100%;
  }

  @media (width > 750px) {
    .social-icons {
      justify-content: var(--alignment);
    }
  }

  shopify-visual-preview-block-list .social-icons[data-visual-preview-mode] {
    width: max-content;
  }

  .social-icon__icon {
    width: var(--icon-size);
    height: var(--icon-size);
    fill: var(--icon-color);
    transition: var(--animation-link-hover);
  }

  .social-icon__icon:hover {
    opacity: var(--opacity-link-hover);
  }
/* END_BLOCK:social-icons */

/* START_BLOCK:stories (INDEX:177) */
.stories {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    display: block;
  }

  .stories__container {
    display: flex;
    flex-direction: row;
    justify-content: var(--alignment-mobile);
    gap: 20px;
    overflow-x: auto;
    scrollbar-width: none;
    padding: 6px;
  }

  @media (width > 750px) {
    .stories__container {
      justify-content: var(--alignment);
    }
  }

  .stories__modal {
    padding: 0;
    width: 100%;
    max-width: 100vw;
    height: 100vh;
    background-color: transparent;
    justify-content: center;
    align-items: center;
    overflow: hidden;
  }

  .stories__modal:focus-visible,
  .stories__modal:focus {
    outline: none;
  }

  .stories__modal::backdrop {
    transition: backdrop-filter var(--animation-speed-medium) var(--animation-easing);
    -webkit-backdrop-filter: brightness(1);
    backdrop-filter: brightness(1);
    background: rgba(var(--color-shadow));
  }

  .stories__modal[open]::backdrop {
    animation: backdropFilter var(--animation-speed-medium) var(--animation-easing) forwards;
    transition: opacity var(--animation-speed-medium) var(--animation-easing);
  }

  .stories__modal[open] {
    display: flex;
    animation: modalSlideInTop var(--animation-speed-medium) var(--animation-easing) forwards;
  }

  .stories__modal-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: #0000004d;
    cursor: pointer;
    transition: background-color 0.2s ease-in-out;
    margin-bottom: 1em;
    pointer-events: all;
    backdrop-filter: blur(6.5px);
    z-index: 40;
    position: absolute;
    top: 2rem;
    right: 1rem;

    .icon {
      color: var(--color-background);
    }
  }

  @media (width <= 750px) {
    .stories__modal {
      padding: 40px 20px 0;
    }
  }

  .stories__slider {
    margin: 0 calc(40px + 2rem);
    height: 90vh;
    max-width: 100%;
    aspect-ratio: 3 / 5;

    & > .splide__track > .splide__list > .splide__slide {
      overflow: hidden;
    }

    & > .splide__track {
      overflow: hidden;
      height: 100%;
      border-radius: var(--card-border-radius);
    }

    & .stories__slider-list > .splide__slide:not(.is-active) {
      overflow: hidden;
    }

    & > .splide__arrows > .splide__arrow--prev {
      left: calc(-40px - 1rem);
    }

    & > .splide__arrows > .splide__arrow--next {
      right: calc(-40px - 1rem);
    }

    .splide__arrow:disabled {
      opacity: 0.5;
    }
  }

  @media (width <= 750px) {
    .stories__slider {
      margin: 0;
      height: calc(100vh - 60px);
    }
  }
/* END_BLOCK:stories */

/* START_BLOCK:tabs (INDEX:178) */
.tabs {
    width: 100%;
  }

  shopify-visual-preview-block-list .tabs[data-visual-preview-mode] {
    width: 400px;
  }

  .tabs__navigation {
    display: flex;
    justify-content: var(--alignment-mobile);
    max-width: 100%;
  }

  .tabs--wrapped .tabs__navigation-inner {
    flex-wrap: wrap;
  }

  .tabs__navigation-inner {
    display: flex;
    gap: var(--gap-sm);
    overflow-x: auto;
    scrollbar-width: thin;
    padding-bottom: var(--padding-sm);
  }

  .tabs__panel {
    margin-top: var(--margin-md);
    width: 100%;
  }

  @media (width > 750px) {
    .tabs__navigation {
      justify-content: var(--alignment);
    }

    .tabs__navigation-inner {
      padding-bottom: var(--padding-xxs);
    }
  }
/* END_BLOCK:tabs */

/* START_BLOCK:text (INDEX:179) */
.text-block {
    text-align: var(--text-align-mobile);
    align-content: center;
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  @media (width > 750px) {
    .text-block {
      text-align: var(--text-align);
    }
  }

  shopify-visual-preview-block-list .text-block[data-visual-preview-mode] {
    max-width: 400px;
  }

  .text-block.paragraph > *,
  .see-more__content > * {
    font-weight: var(--font-weight);
    font-size: var(--font-size);
  }

  .text-block a {
    color: inherit;
  }

  see-more-component {
    display: block;
    margin-block: 0 !important;
  }

  .see-more__content {
    position: relative;
  }

  .see-more__content > * {
    margin-block: var(--margin-md) 0;
  }

  .see-more__content {
    /* Solution principale avec mask CSS */
    mask: linear-gradient(to bottom, black calc(100% - 40px), transparent 100%);
    -webkit-mask: linear-gradient(to bottom, black calc(100% - 40px), transparent 100%);
    transition: mask 0.3s ease, -webkit-mask 0.3s ease;
  }

  /* Fallback pour les navigateurs qui ne supportent pas mask */
  @supports not (mask: linear-gradient(black, transparent)) {
    .see-more__content::after {
      content: '';
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      height: 40px;
      background: linear-gradient(transparent, color-mix(in srgb, var(--color-background) 90%, transparent));
      opacity: 1;
      transition: opacity 0.3s ease;
      pointer-events: none;
    }

    .see-more__content--expanded::after,
    .see-more__content--no-overflow::after {
      opacity: 0;
    }
  }

  .see-more__content--expanded,
  .see-more__content--no-overflow {
    mask: none;
    -webkit-mask: none;
  }

  .see-more__toggle {
    background: none;
    border: none;
    color: var(--color-foreground);
    cursor: pointer;
    font-size: 0.9em;
    font-weight: 500;
    margin-top: 0.5rem;
    padding: 0.25rem 0;
    text-decoration: underline;
    transition: var(--animation-link-hover);
  }

  .see-more__toggle:hover {
    opacity: var(--opacity-link-hover);
  }

  .see-more__toggle-text {
    display: inline-block;
    text-decoration: underline;
  }

  .text-block--truncated {
    display: -webkit-box;
    -webkit-line-clamp: var(--truncate-length);
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
  }
/* END_BLOCK:text */

/* START_BLOCK:this-pack-contains (INDEX:180) */
.this-pack-contains {
    display: flex;
    flex-direction: column;
    font-size: var(--font-body--size);
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  shopify-visual-preview-block-list .this-pack-contains[data-visual-preview-mode] {
    width: 450px;
  }

  .this-pack-contains__title {
    font-weight: 500;
  }

  .this-pack-contains_description {
    margin-top: var(--margin-xs);
  }

  .this-pack-contains_product-list {
    display: flex;
    gap: var(--gap-sm);
    width: 100%;
    overflow-y: auto;
    padding: var(--padding-sm) 0;
  }
/* END_BLOCK:this-pack-contains */

/* START_BLOCK:video (INDEX:181) */
deferred-media {
    width: var(--size-style-width-mobile, var(--size-style-width));
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);

    @media screen and (width >750px) {
      width: var(--size-style-width);
    }
  }

  .video-placeholder-wrapper {
    position: relative;
    border-radius: var(--card-border-radius);
    overflow: hidden;
    width: var(--size-style-width-mobile, var(--size-style-width));
    aspect-ratio: var(--ratio);
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);

    @media screen and (width >750px) {
      width: var(--size-style-width);
    }
  }

  .video-placeholder-wrapper__poster-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background-color: transparent;
    border: none;
    transition: var(--animation-link-hover);

    .icon--play_circle {
      font-size: 60px !important;
      color: var(--color-primary-button-text);
    }
  }
/* END_BLOCK:video */

/* CSS from snippet stylesheet tags */
/* START_SNIPPET:accordion (INDEX:182) */
accordion-row:has(.accordion__heading-title:empty),
  accordion-row:has(.accordion__content:empty) {
    display: none;
  }

  .accordion__header {
    display: flex;
    align-items: center;
    cursor: pointer;
    list-style: none;
    transition: margin 150ms ease-out;
    padding: var(--margin-sm) 0;

    /* Masquer la flèche par défaut sur tous les navigateurs */
    &::-webkit-details-marker {
      display: none;
    }

    &::marker {
      display: none;
    }

    /* Fix spécifique pour iOS Safari */
    &::-webkit-details-marker,
    &::before {
      display: none !important;
    }
  }

  .accordion__header .icon,
  .accordion__header .accordion__icons-add {
    margin-inline-start: auto;
    transition: transform var(--animation-speed-fast) var(--animation-easing);
  }

  .accordion[open] .accordion__header .icon--keyboard_arrow_down {
    transform: rotate(180deg);
  }

  .accordion[open] .accordion__header .icon--add {
    transform: rotate(90deg);
  }

  .accordion:not([open]) .accordion__header .icon--remove,
  .accordion[open] .accordion__header .icon--add {
    display: none;
  }

  .accordion[open] .accordion__header .icon--remove,
  .accordion:not([open]) .accordion__header .icon--add {
    display: block;
  }

  .accordion__heading {
    font-size: var(--font-body--size-emphasized);
    display: flex;
    align-items: center;
    gap: var(--gap-sm);
  }

  .accordion__heading .icon {
    font-size: 20px !important;
  }

  .accordion__content {
    padding: 0 0 var(--margin-md);
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }
/* END_SNIPPET:accordion */

/* START_SNIPPET:add-to-wishlist-button (INDEX:183) */
.product-quantity-selector-block[data-visual-preview-mode] {
    width: 100px;
  }

  .add-to-wishlist-button__icon {
    font-variation-settings: 'FILL' 0, 'wght' var(--icon-weight), 'GRAD' 0, 'opsz' 24;
  }

  .add-to-wishlist-button__icon--filled {
    font-variation-settings: 'FILL' 1, 'wght' var(--icon-weight), 'GRAD' 0, 'opsz' 24;
  }
/* END_SNIPPET:add-to-wishlist-button */

/* START_SNIPPET:article-card (INDEX:184) */
.article-card {
    display: flex;
    flex-direction: column;
    gap: var(--gap);
    width: 100%;
    overflow: hidden;
    text-decoration: none;
    transition: transform 0.2s ease-in-out;
    color: var(--color-foreground);
  }

  .article-card[data-visual-preview-mode] {
    max-width: 280px;
  }

  @media (width > 750px) {
    .article-card:hover {
      transform: translateY(-2px);
    }
  }
/* END_SNIPPET:article-card */

/* START_SNIPPET:cart-icon (INDEX:186) */
.header__icon-cart {
    position: relative;
    cursor: pointer;
  }
/* END_SNIPPET:cart-icon */

/* START_SNIPPET:checkbox (INDEX:187) */
.checkbox {
    z-index: 0;
    position: relative;
    display: block;
    line-height: var(--checkbox-size);
  }

  .checkbox > input {
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    z-index: -1;
    position: absolute;
    left: -8px;
    top: -8px;
    display: block;
    margin: 0;
    border-radius: 50%;
    width: 36px;
    height: 36px;
    box-shadow: none;
    outline: none;
    opacity: 0;
    transform: scale(1);
    pointer-events: none;
    transition: opacity 0.3s, transform 0.2s;
  }

  .checkbox > span {
    display: flex;
    align-items: center;
    width: 100%;
    cursor: pointer;
    font-size: var(--font-body--size-emphasized);
  }

  .checkbox__additionnal-label-content {
    margin-right: var(--margin-sm);
  }

  .checkbox > span::before {
    content: '';
    display: inline-block;
    box-sizing: border-box;
    margin-right: var(--margin-sm);
    border: var(--inputs-border-width) solid var(--color-input-text);
    border-radius: var(--checkbox-border-radius);
    min-width: var(--checkbox-size);
    width: var(--checkbox-size);
    height: var(--checkbox-size);
    vertical-align: top;
    transition: border-color 0.2s, background-color 0.2s;
    background-color: var(--color-input-background);
  }

  .checkbox > span:empty::before {
    margin-right: 0;
  }

  .checkbox > span::after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 1px;
    width: 0.6rem;
    height: 0.3rem;
    border: solid 1.5px transparent;
    border-right: none;
    border-top: none;
    transform: translate(0.22rem, 0.32rem) rotate(-45deg);
  }

  .checkbox > input:checked + span::before,
  .checkbox > input:indeterminate + span::before {
    border-color: var(--color-input-text);
    background-color: var(--color-input-text);
  }

  .checkbox > input:checked + span::after,
  .checkbox > input:indeterminate + span::after {
    border-color: var(--color-input-background);
  }

  .checkbox > input:indeterminate + span::after {
    border-left: none;
    transform: translate(0.25rem, 0.1875rem);
  }

  .checkbox > input:focus {
    opacity: 0.12;
  }

  .checkbox > input:disabled {
    opacity: 0;
  }

  .checkbox > input:disabled + span {
    color: var(--color-input-text);
    cursor: initial;
    opacity: 0.5;
  }

  .checkbox > input:disabled + span::before {
    border-color: currentColor;
    cursor: not-allowed;
  }

  .checkbox > input:checked:disabled + span::before,
  .checkbox > input:indeterminate:disabled + span::before {
    border-color: transparent;
    background-color: currentColor;
  }

  .checkbox > input:checked:disabled + span::after {
    border-color: var(--color-input-background);
    cursor: not-allowed;
  }
/* END_SNIPPET:checkbox */

/* START_SNIPPET:collection-card (INDEX:188) */
.collection-card {
    display: flex;
    flex-direction: column;
    gap: var(--gap);
    width: 100%;
    overflow: hidden;
    text-decoration: none;
    transition: transform 0.2s ease-in-out;
    position: relative;
    cursor: pointer;
    color: var(--color-foreground);
  }

  .collection-card[data-visual-preview-mode] {
    max-width: 280px;
  }

  @media (width > 750px) {
    .collection-card:hover {
      transform: translateY(-2px);
    }
  }
/* END_SNIPPET:collection-card */

/* START_SNIPPET:dropdown-localization (INDEX:191) */
dropdown-component .dropdown-localization__toggle {
    gap: 3px;
    font-size: var(--font-body--size-emphasized);

    .icon-flag {
      width: 14px;
      height: 14px;
      clip-path: circle(50%);
      background-position: center;
      background-size: cover;
      margin-inline-end: 4px;
      position: relative;
    }
  }

  dropdown-component .dropdown-localization-content {
    min-width: 240px;
    padding: var(--padding-sm);
  }

  @media (width <= 1000px) {
    dropdown-component .dropdown-localization__toggle {
      width: 100%;
      padding: var(--padding-sm) var(--padding-xs);
    }

    dropdown-component .dropdown-localization-content {
      position: fixed;
      top: auto;
      bottom: 0;
      left: 0;
      width: 100%;
      min-width: 100%;
      border-bottom-left-radius: 0;
      border-bottom-right-radius: 0;
    }
  }
/* END_SNIPPET:dropdown-localization */

/* START_SNIPPET:filter-list (INDEX:193) */
.filter-list {
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
  }

  .filter-list__swatch {
    background: var(--swatch-background);
    width: 16px;
    height: 16px;
    display: block;
    border-radius: 50%;
  }
/* END_SNIPPET:filter-list */

/* START_SNIPPET:filter-price-range (INDEX:194) */
.filter-price-range {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--gap-sm);
  }

  .filter-price-range__field {
    display: flex;
    align-items: center;
    gap: var(--gap-sm);
  }

  .filter-price-range__field .textfield input {
    width: 100px;
    min-width: 100px;
  }
/* END_SNIPPET:filter-price-range */

/* START_SNIPPET:filters-inline (INDEX:195) */
.filters__container {
    display: flex;
    align-items: center;
    gap: var(--gap-sm);
  }

  .filters__list {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--gap-sm);
  }

  .filter-dropdown-toggle {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }

  .filter-dropdown-toggle__label {
    display: flex;
    align-items: center;
    gap: 4px;
  }

  .filter-count {
    background-color: var(--color-primary-button-background);
    color: var(--color-primary-button-text);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    font-size: var(--font-body--size-small);
  }

  dropdown-component .filter-dropdown-content {
    min-width: fit-content;
    padding: var(--padding-md);
  }

  .filter-clear-button {
    margin-top: var(--margin-md);
  }
/* END_SNIPPET:filters-inline */

/* START_SNIPPET:filters-modal (INDEX:196) */
.side-menu__toggle-link {
    display: flex;
    align-items: center;
    gap: var(--gap-sm);
    background-color: transparent;
    color: var(--color-foreground);
    border: none;
    padding: 0;
    margin: 0;
    cursor: pointer;
  }

  .filters-side-panel {
    overflow-y: auto;
    height: 100%;
    padding: 20px;
  }
/* END_SNIPPET:filters-modal */

/* START_SNIPPET:filters-sidebar (INDEX:197) */
.filters-sidebar__list {
    display: flex;
    flex-direction: column;
  }

  .filters-sidebar__filter-label {
    display: block;
    font-size: var(--font-body--size-emphasized);
    font-weight: 600;
    margin-bottom: var(--margin-sm);
  }
/* END_SNIPPET:filters-sidebar */

/* START_SNIPPET:header-actions (INDEX:199) */
.header__actions {
    display: flex;
    align-items: center;
    gap: 1rem;
    height: var(--header-height);
  }

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

  .header__actions .dropdown-toggle:hover {
    opacity: 1;
  }

  .header__icon {
    height: 24px;
  }

  @media (width < 1000px) {
    .header__actions .dropdown-localization,
    .header__actions .search-popup,
    .header__actions .header__icon-account {
      display: none;
    }
  }
/* END_SNIPPET:header-actions */

/* START_SNIPPET:header-menu-desktop (INDEX:200) */
.header__menu-desktop {
    display: none;
  }

  @media (width > 1000px) {
    .header__menu-desktop {
      display: flex;
    }

    .header__menu-desktop-list {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      column-gap: 1rem;
      row-gap: 0.33rem;
      height: 100%;
    }

    .header__menu-mobile {
      display: none;
    }
  }

  .header__menu-desktop-list--uppercase .header__menu-link-text {
    text-transform: uppercase;
  }

  .header__menu-link-text {
    font-weight: var(--font-weight);
  }

  /* Sous-menus */
  .header__submenu-link--parent .icon {
    transition: transform var(--animation-speed) var(--animation-easing);
    font-size: 22px !important;
  }

  .header__submenu-accordion summary {
    transition: var(--animation-link-hover);
  }

  .header__submenu-accordion summary:hover {
    opacity: var(--opacity-link-hover);
  }

  /* Liens dans les sous-menus */
  .header__submenu-link {
    display: block;
    padding: var(--padding-xs) 0;
    font-size: var(--font-body--size);
    text-decoration: none;
    color: inherit;
  }

  .header__menu-item--dropdown .header__submenu-link {
    padding: var(--padding-xs);
    border-radius: calc(var(--inputs-border-radius) * var(--small-multiplier));
    transition: background-color var(--animation-speed) var(--animation-easing);
  }

  .header__menu-item--dropdown .header__submenu-link:hover {
    background-color: var(--color-input-border-low-opacity);
  }

  /* Accordéons dans les sous-menus */
  .header__submenu-accordion {
    width: 100%;
  }

  .header__submenu-accordion summary {
    list-style: none;
    cursor: pointer;
  }

  .header__submenu-accordion summary::-webkit-details-marker {
    display: none;
  }

  .header__submenu-link--parent {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .header__submenu-accordion[open] > summary .icon {
    transform: rotate(180deg);
  }

  .header__subsubmenu {
    padding: 0 var(--padding-sm);
  }

  /* Megamenu */
  .header__menu-item--megamenu {
    position: static;
  }

  dropdown-component .dropdown-content.header__submenu--megamenu {
    width: 100%;
    top: calc(var(--header-offset-height) - var(--separator-border-width));
    left: 0;
    border: 0;
    border-bottom: var(--separator-border-width) solid var(--color-border);
    border-radius: 0;
  }

  .header__submenu--megamenu__content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--gap-md);
    width: 100%;
    max-width: var(--page-width);
    margin: 0 auto;
    padding: var(--padding-sm) var(--page-margin-desktop);
    max-height: 80vh;
    overflow-y: auto;
  }

  .header__submenu--megamenu__item {
    flex: 1;
  }

  .header__submenu--megamenu__item .header__submenu-link {
    font-size: var(--font-body--size);
  }

  .header__submenu--megamenu__item .header__submenu-link--parent {
    font-size: var(--font-body--size-emphasized);
    font-weight: 500;
  }

  .header__submenu-image-link {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--gap-sm);
    transition: var(--animation-link-hover);

    img {
      width: 100%;
      object-fit: cover;
      border-radius: var(--card-border-radius);
      aspect-ratio: var(--image-ratio);
    }

    &:hover {
      opacity: var(--opacity-link-hover);
    }
  }

  .header__submenu-image-title {
    font-size: var(--font-body--size);
    font-weight: 500;
  }
/* END_SNIPPET:header-menu-desktop */

/* START_SNIPPET:loading-spinner (INDEX:205) */
.loading__spinner {
    position: absolute;
    z-index: 1;
    width: 18px;
    display: inline-block;
    color: black;
    left: calc(50% - 9px);
    display: none;
  }

  .is-loading {
    cursor: wait;
    position: relative;
    opacity: 0.7;
    pointer-events: none;
  }

  .is-loading span:not(.loading__spinner) {
    opacity: 0;
  }

  .is-loading .loading__spinner {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    position: absolute;
    display: block;
  }

  .spinner {
    animation: rotator 1.4s linear infinite;

    .path {
      stroke-dasharray: 187;
      stroke-dashoffset: 0;
      transform-origin: center;
      animation: dash 1.4s ease-in-out infinite;
      stroke: var(--color-primary-button-text);
    }
  }

  .button--secondary .spinner .path {
    stroke: var(--color-secondary-button-text);
  }

  @keyframes rotator {
    0% {
      transform: rotate(0deg);
    }
    100% {
      transform: rotate(270deg);
    }
  }

  @keyframes dash {
    0% {
      stroke-dashoffset: 187;
    }
    50% {
      stroke-dashoffset: 46.75;
      transform: rotate(135deg);
    }
    100% {
      stroke-dashoffset: 187;
      transform: rotate(450deg);
    }
  }
/* END_SNIPPET:loading-spinner */

/* START_SNIPPET:localization-form (INDEX:206) */
dropdown-localization-component {
    position: relative;
    color: var(--color-foreground);
  }

  /* Choix de pays */

  .localization-form__country-selector {
    overflow-y: auto;
    max-height: 100%;
    flex-grow: 1;
    max-height: 20.5rem;
  }

  .localization-form__countries {
    display: flex;
    flex-direction: column;
    gap: 3px;
    position: relative;
    width: 100%;
    scroll-padding: var(--padding-xs) 0;
    overflow-y: auto;
    white-space: nowrap;
  }

  .localization-form__country {
    border-radius: calc(var(--card-border-radius) - var(--padding-xs));
    display: flex;
    align-items: center;
    padding: var(--padding-xs);
    font-size: var(--font-body--size);
    gap: 3px;
    cursor: pointer;
    transition: background-color var(--animation-speed) var(--animation-easing);
  }

  .localization-form__country:hover,
  .localization-form__country:focus,
  .localization-form__country--selected {
    background-color: rgb(from var(--color-foreground) r g b / 5%);
    font-weight: 500;
  }

  .localization-form__country .country {
    flex: 1;
  }

  .localization-form__country .icon--check {
    visibility: hidden;
    font-size: 18px !important;
  }

  .localization-form__country--selected .icon--check {
    visibility: visible;
  }

  .localization-form__country-currency {
    width: max-content;
    opacity: 0;
    visibility: hidden;
    transition: none;
  }

  .localization-form__country:hover .localization-form__country-currency,
  .localization-form__country--selected .localization-form__country-currency {
    opacity: 1;
    transition: opacity var(--animation-speed-fast) var(--animation-easing);
    visibility: visible;
  }

  /* Choix de langue */

  .localization-form__language-selector {
    display: flex;
    position: relative;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    font-size: var(--font-body--size);

    &.localization-form__language-selector--with-country {
      border-top: var(--separator-border-width) solid var(--color-border);
      margin-top: var(--padding-xs);
      padding: var(--padding-xs) var(--padding-xs) 0;

      .localization-form__language-select-wrapper {
        width: auto;
      }
    }

    .icon--keyboard_arrow_down {
      font-size: 22px !important;
    }
  }

  .localization-form__language-select-label {
    flex: 1;
  }

  .localization-form__language-select-wrapper {
    position: relative;
    display: inline-block;
    width: 100%;
  }

  .localization-form__language-select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    height: 35px;
    padding: 0 var(--inputs-padding);
    padding-right: calc(var(--inputs-padding) * 2);
    border: none;
    border-radius: var(--inputs-border-radius);
    color: var(--color-input-text);
    background-color: var(--color-input-background);
    cursor: pointer;
    font-size: var(--inputs-font-size);
    font-weight: var(--font-weight);
    width: 100%;
  }

  .localization-form__language-selector--uppercase .localization-form__language-select {
    text-transform: uppercase;
  }

  .localization-form__language-select:not(:disabled):hover,
  .localization-form__language-select:not(:disabled):focus,
  .localization-form__language-select:focus-visible,
  .localization-form__language-select:focus {
    outline: none;
    margin: 0;
    box-shadow: none;
  }

  .localization-form__language-select-wrapper__icon {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    pointer-events: none;
    color: var(--color-input-text);
    height: 20px;
  }

  .localization-form__language-select-wrapper__icon .icon {
    font-size: 20px !important;
  }

  @media (width <= 1000px) {
    .localization-form__country-currency {
      opacity: 1;
      visibility: visible;
    }
  }
/* END_SNIPPET:localization-form */

/* START_SNIPPET:pagination (INDEX:211) */
.pagination-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 30px 0;
  }

  .pagination__list {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    justify-content: center;
  }

  .pagination__item {
    text-decoration: none;
  }

  .pagination__item--current {
    cursor: default;
    pointer-events: none;
  }
/* END_SNIPPET:pagination */

/* START_SNIPPET:price (INDEX:212) */
.badge:has(.badge__savings:empty) {
    display: none;
  }
/* END_SNIPPET:price */

/* START_SNIPPET:product-badges (INDEX:213) */
.product-badges {
    position: absolute;
    display: flex;
    flex-wrap: wrap;
    gap: var(--gap-xs);
  }

  .product-badges--bottom-left {
    bottom: var(--padding-sm);
    left: var(--padding-sm);
    justify-content: flex-start;
  }

  .product-badges--top-left {
    top: var(--padding-sm);
    left: var(--padding-sm);
    justify-content: flex-start;
  }

  .product-badges--top-right {
    top: var(--padding-sm);
    right: var(--padding-sm);
    justify-content: flex-end;
  }
/* END_SNIPPET:product-badges */

/* START_SNIPPET:product-card (INDEX:214) */
.product-card {
    display: flex;
    flex-direction: column;
    gap: var(--gap);
    width: 100%;
    overflow: hidden;
    text-decoration: none;
    transition: transform 0.2s ease-in-out;
    position: relative;
    cursor: pointer;
  }

  .product-card[data-visual-preview-mode] {
    max-width: 280px;
  }

  @media (width > 750px) {
    .product-card:hover {
      transform: translateY(-2px);
    }
  }
/* END_SNIPPET:product-card */

/* START_SNIPPET:product-media (INDEX:215) */
.product-media img {
    aspect-ratio: var(--ratio);
    object-fit: cover;
  }
/* END_SNIPPET:product-media */

/* START_SNIPPET:product-option-value-button (INDEX:216) */
.variant-picker__option-value input {
    clip: rect(0, 0, 0, 0);
    overflow: hidden;
    position: absolute;
    height: 1px;
    width: 1px;
  }

  .variant-picker__option-value input + label {
    appearance: none;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    min-height: var(--variant-button-min-height);
    min-width: var(--variant-button-min-width);
    max-width: max-content;
    font-size: var(--variant-button-font-size);
    outline: 1px solid transparent;
    transition: all var(--animation-speed-medium) var(--animation-easing);
    padding: var(--variant-button-padding-vertical) var(--variant-button-padding-horizontal);
    color: var(--color-variant-text);
    background-color: var(--color-variant-background);
    border: var(--variant-button-border-width) solid var(--color-variant-border);
    border-radius: var(--inputs-border-radius);
    font-weight: var(--button-primary-font-weight);
    text-transform: var(--button-primary-text-transform);
    letter-spacing: var(--button-letter-spacing);
  }

  .variant-picker__option-value input:checked + label {
    background-color: var(--color-selected-variant-background);
    color: var(--color-selected-variant-text);
    border-color: var(--color-selected-variant-border);
  }

  .variant-picker__option-value input[aria-disabled='true'] + label {
    position: relative;
    opacity: 0.5;
    overflow: hidden;

    &::before {
      content: '';
      position: absolute;
      top: 50%;
      left: 0;
      width: 100%;
      height: 1px;
      background-color: var(--color-variant-border);
      rotate: 20deg;
    }
  }

  .variant-picker__option-value input[aria-disabled='true']:checked + label::before {
    background-color: var(--color-selected-variant-text);
  }
/* END_SNIPPET:product-option-value-button */

/* START_SNIPPET:product-section-content (INDEX:217) */
@media (width > 750px) {
    .shopify-section-product-section {
      overflow: visible;
    }
  }

  .product-section {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
  }

  .product-section__content {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
    gap: var(--gap-md);
    padding-top: var(--padding-top);
    padding-bottom: var(--padding-bottom);
  }

  .product-section__product-info {
    display: flex;
    flex-direction: column;
    gap: var(--padding-sm);
  }

  @media (width > 750px) {
    .product-section__content {
      flex-direction: var(--image-position);
      gap: var(--gap);
    }

    .product-section__medias-container {
      overflow: hidden;
    }

    .product-section__medias {
      width: calc(100% - var(--product-info-width));
    }

    .product-section__product-info {
      max-width: calc(var(--product-info-width) - var(--gap));
      width: 100%;
    }

    .product-section__medias--sticky,
    .product-section__product-info--sticky {
      height: fit-content;
      position: sticky;
      top: calc(var(--header-height, 0px) + var(--padding-md));
      z-index: 2;
    }
  }

  @media (width <= 750px) {
    .product-section--carrousel-image-full-width {
      .product-section__content {
        padding-top: 0 !important;
      }

      .product-media-gallery-main-slider {
        width: calc(100% + 2 * (var(--page-margin-mobile)));
        margin-left: calc(var(--page-margin-mobile) * -1);
      }

      .product-media-gallery__media--rounded {
        border-radius: 0;
      }
    }
  }
/* END_SNIPPET:product-section-content */

/* START_SNIPPET:quantity-selector (INDEX:219) */
:root {
    --quantity-selector-button-width: 30px;
  }

  .quantity-selector {
    border: var(--inputs-border-width) solid var(--color-input-border);
    border-radius: var(--inputs-border-radius);
    background-color: var(--color-input-background);
    height: var(--inputs-min-height);
    overflow: hidden;
    display: flex;
    min-width: calc(var(--quantity-selector-button-width) * 3 + var(--inputs-border-width) * 2);
    width: calc(var(--quantity-selector-button-width) * 3 + var(--inputs-border-width) * 2);
  }

  .quantity-selector--disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
  }

  .quantity-selector button,
  .quantity-selector input {
    appearance: textfield;
    background-color: var(--color-input-background);
    border: none;
    transition: 0.2s;
    cursor: pointer;
    min-width: var(--quantity-selector-button-width);
    height: var(--inputs-min-height);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 0;
    color: var(--color-input-text);
  }

  .quantity-selector--small {
    height: calc(var(--small-multiplier) * var(--inputs-min-height));
    border-radius: calc(var(--small-multiplier) * var(--inputs-border-radius));
  }

  .quantity-selector--small button,
  .quantity-selector--small input {
    height: calc(var(--small-multiplier) * var(--inputs-min-height) - 2 * var(--inputs-border-width));
    width: calc(var(--small-multiplier) * var(--inputs-min-height) - 2 * var(--inputs-border-width));
  }

  .quantity-selector button[disabled] {
    opacity: 0.3;
    pointer-events: none;
  }

  .quantity-selector button:not(:disabled):hover svg {
    transform: scale(1.1);
  }

  .quantity-selector .icon {
    pointer-events: none;
    font-size: 20px !important;
    color: var(--color-input-text);
  }

  .quantity-selector input::-webkit-inner-spin-button,
  .quantity-selector input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
  }

  .quantity-selector input:focus-visible {
    outline: none;
    outline-offset: 0;
    box-shadow: none;
    z-index: 1;
  }
/* END_SNIPPET:quantity-selector */

/* START_SNIPPET:radio (INDEX:220) */
.radio {
    z-index: 0;
    position: relative;
    display: inline-block;
    line-height: 1.5;
  }

  .radio > input {
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    z-index: -1;
    position: absolute;
    left: -10px;
    top: -8px;
    display: block;
    margin: 0;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    outline: none;
    opacity: 0;
    transform: scale(1);
    pointer-events: none;
    transition:
      opacity 0.3s,
      transform 0.2s;
  }

  .radio > .radio__label {
    display: inline-block;
    width: 100%;
    cursor: pointer;
    position: relative;
    font-size: var(--font-body--size-emphasized);
  }

  .radio > .radio__label::before {
    content: '';
    display: inline-block;
    box-sizing: border-box;
    margin: 0px 10px 0px 0;
    border: var(--inputs-border-width) solid var(--color-input-text);
    border-radius: 50%;
    width: 20px;
    min-width: 20px;
    height: 20px;
    vertical-align: top;
    transition: border-color 0.2s;
    background-color: var(--color-input-background);
  }

  .radio > .radio__label::after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 50%;
    width: 10px;
    height: 10px;
    background-color: var(--color-input-text);
    transform: translate(5px, 5px) scale(0);
    transition: transform 0.2s;
  }

  .radio > input:checked + .radio__label::before {
    border-color: var(--color-input-text);
  }

  .radio > input:checked + .radio__label::after {
    transform: translate(5px, 5px) scale(1);
  }

  .radio > input:focus {
    opacity: 0.12;
  }

  .radio > input:disabled {
    opacity: 0;
  }

  .radio > input:disabled + .radio__label {
    color: var(--color-input-text);
    opacity: 0.5;
    cursor: not-allowed;
  }

  .radio > input:disabled + .radio__label::before {
    border-color: currentColor;
  }

  .radio > input:disabled + .radio__label::after {
    background-color: currentColor;
  }
/* END_SNIPPET:radio */

/* START_SNIPPET:rating-stars (INDEX:221) */
.rating {
    display: flex;
    align-items: center;
    gap: var(--gap-sm);
    flex-wrap: wrap;
  }

  .rating__stars {
    height: 22px;
  }

  .rating-star {
    font-size: 22px !important;
    margin: 0 -4.5px;
    color: var(--color-stars-icons);
  }

  .rating-star--filled {
    font-variation-settings: 'FILL' 1, 'wght' var(--icon-weight), 'GRAD' 0, 'opsz' 24;
  }

  .rating-star--unfilled {
    font-variation-settings: 'FILL' 0, 'wght' var(--icon-weight), 'GRAD' 0, 'opsz' 24;
  }

  .rating__count {
    line-height: 22px;
  }
/* END_SNIPPET:rating-stars */

/* START_SNIPPET:review (INDEX:222) */
.review {
    display: flex;
    flex-direction: column;
    gap: var(--gap-sm);
    overflow: hidden;
    width: 100%;
  }

  shopify-visual-preview-block-list shopify-visual-preview-block-list .review[data-visual-preview-mode] {
    width: 100%;
    max-width: 400px;
  }

  .review__image {
    object-fit: cover;
    width: 100%;
    overflow: auto;
    border-radius: calc(var(--card-border-radius) - (var(--card-padding) * 0.5));
  }

  .review__image .placeholder-svg {
    width: 100%;
    height: 100%;
    background-color: #f8f8f8;
    border-radius: calc(var(--card-border-radius) - (var(--card-padding) * 0.5));
  }

  .review__title,
  .review__author-name {
    font-weight: 600;
  }

  .review__date {
    font-style: italic;
  }

  .review--2 {
    .review__author-and-date {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: var(--gap-sm);
      width: 100%;
      margin-top: 10px;
    }
  }

  .review--3 {
    .review__image {
      aspect-ratio: var(--image-ratio);
    }

    .review__image .placeholder-svg {
      aspect-ratio: var(--image-ratio);
    }
  }

  .review--4 {
    flex-direction: row;
    align-items: center;

    .review__content {
      width: 100%;
      display: flex;
      flex-direction: column;
      gap: var(--gap-sm);
    }

    .review__image,
    .review__image .placeholder-svg {
      aspect-ratio: 1 / 1;
    }
  }

  @media (width > 750px) {
    .review--4 {
      flex-direction: row;
      align-items: center;
    }
  }

  .review--5 {
    .review__author-and-date-container {
      display: flex;
      flex-direction: row;
      align-items: center;
      gap: var(--gap-sm);
      width: 100%;
      margin-bottom: 10px;

      .review__author-and-date {
        display: flex;
        flex-direction: column;
        gap: var(--gap-xs);
      }

      .review__author-profile,
      .review__author-profile svg {
        width: 50px;
        height: 50px;
        background-color: #f8f8f8;
        border-radius: calc(var(--card-border-radius) - (var(--card-padding) * 0.5));
        object-fit: cover;
      }
    }
  }
/* END_SNIPPET:review */

/* START_SNIPPET:search-popup (INDEX:224) */
.header__icon-search {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    color: inherit;
    display: flex;
  }

  .dialog-modal--search {
    padding: var(--page-margin-mobile);
    flex-direction: row;
    gap: var(--gap-xs);
    align-items: center;
    width: var(--modal-width);
    overflow: hidden !important;
    max-height: var(--search-modal-max-height-mobile);

    @media (width > 750px) {
      max-height: var(--search-modal-max-height);
    }

    &[open] {
      display: flex;
      align-items: flex-start;
    }

    .dialog-modal__content {
      width: 100%;
    }

    .dialog-modal__content .search-form {
      display: flex;
      flex-direction: row;
      gap: var(--gap-xs);
      align-items: center;
      margin: 0;
    }

    .dialog-modal__close {
      position: relative;
      top: auto;
      right: auto;
    }
  }

  @media (width > 750px) {
    .dialog-modal--search {
      padding: var(--padding-md);
    }
  }
/* END_SNIPPET:search-popup */

/* START_SNIPPET:separator (INDEX:226) */
.separator {
    margin-top: var(--margin-top);
    margin-bottom: var(--margin-bottom);
    display: block;
    width: var(--width);
  }

  .separator hr {
    border: none;
    border-top: var(--separator-border-width) var(--separator-style) var(--color-border, #e0e0e0);
  }
/* END_SNIPPET:separator */

/* START_SNIPPET:slider (INDEX:227) */
slider-component {
    position: relative;
  }
/* END_SNIPPET:slider */

/* START_SNIPPET:sort-inline (INDEX:228) */
.sorting-dropdown-toggle {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }

  .sorting__select {
    border-radius: calc(var(--card-border-radius) - var(--padding-xs));
    display: flex;
    align-items: center;
    padding: var(--padding-xs);
    font-size: var(--font-body--size);
    gap: 3px;
    cursor: pointer;
    transition: background-color var(--animation-speed) var(--animation-easing);
  }

  .sorting__list {
    display: flex;
    flex-direction: column;
    gap: 3px;
    position: relative;
    width: 100%;
    scroll-padding: var(--padding-xs) 0;
    overflow-y: auto;
    white-space: nowrap;
    list-style: none;
    padding: 0;
  }

  .sorting__select:hover,
  .sorting__select:focus,
  .sorting__select--selected {
    background-color: rgb(from var(--color-foreground) r g b / 5%);
    font-weight: 500;
  }
/* END_SNIPPET:sort-inline */

/* START_SNIPPET:swatch (INDEX:230) */
.swatch-input {
    clip: rect(0, 0, 0, 0);
    overflow: hidden;
    position: absolute;
    width: 1px;
    height: 1px;
  }

  .swatch-input + .swatch,
  .swatch-link {
    display: block;
    border-radius: calc(var(--swatch-border-radius) - var(--swatch-outline-offset));
    cursor: pointer;
    outline-offset: var(--swatch-outline-offset);
    margin: var(--swatches-border-width);
    width: var(--swatch-size);
    height: var(--swatch-size);
    outline: var(--swatches-border-width) solid transparent;
    transition: outline 0.1s ease-in-out;
    forced-color-adjust: none;
  }

  .swatch-input:active + .swatch,
  .swatch-input:checked + .swatch,
  .swatch-input[aria-checked='true'] + .swatch,
  .swatch-link[aria-checked='true'],
  .swatch-input:focus + .swatch,
  .swatch-input:focus-visible + .swatch {
    outline: var(--swatches-border-width) solid var(--color-selected-input-border);
  }

  .swatch-input:hover:not([aria-checked='true']):not([checked]) + .swatch,
  .swatch-link:hover:not([aria-checked='true']) {
    outline: var(--swatches-border-width) solid var(--color-input-border-low-opacity);
  }

  .swatch span {
    pointer-events: none;
    position: relative;
    overflow: hidden;
    display: block;
    width: var(--swatch-size);
    height: var(--swatch-size);
    background: var(--swatch-background);
    background-size: cover;
    background-origin: border-box;
    border: 0.5px solid var(--color-input-border-low-opacity);
    border-radius: calc(var(--swatch-border-radius) - var(--swatch-outline-offset));
  }

  .swatch--disabled span:after {
    --crossed-line--size: 1px;
    content: '';
    position: absolute;
    bottom: calc(var(--crossed-line--size) * -0.5);
    left: 0;
    width: calc(var(--swatch-size) * 1.414);
    height: var(--crossed-line--size);
    background-color: var(--color-foreground);
    transform: rotate(-45deg);
    transform-origin: left;
  }

  .swatch-input:checked + .swatch {
    outline: var(--swatches-border-width) solid var(--color-selected-input-border);
  }
/* END_SNIPPET:swatch */

/* START_SNIPPET:swatches (INDEX:231) */
.swatches {
    display: flex;
    justify-content: flex-start;
    overflow-x: auto;
    padding: 3px;
    gap: 10px;
    padding-bottom: 10px;
  }

  .swatches {
    --swatch-size: var(--swatches-size);
    --swatch-border-radius: var(--inputs-border-radius);
    --swatch-outline-offset: var(--swatches-outline-offset);
  }

  .swatches--small {
    --swatch-size: calc(var(--swatches-size) * var(--small-multiplier));
    --swatch-border-radius: calc(var(--small-multiplier) * var(--inputs-border-radius));
    --swatch-outline-offset: var(--swatches-small-outline-offset);
  }

  .swatches--big {
    --swatch-size: calc(var(--swatches-size) * var(--big-multiplier));
    --swatch-border-radius: calc(var(--inputs-border-radius) * var(--big-multiplier));
    --swatch-outline-offset: var(--swatches-big-outline-offset);
  }

  .swatches--rounded .swatch,
  .swatches--rounded .swatch-link,
  .swatches--rounded .swatch span {
    --swatch-border-radius: 100%;
  }
/* END_SNIPPET:swatches */

/* START_SNIPPET:textarea (INDEX:233) */
.textarea {
    position: relative;
  }

  .textarea textarea {
    outline: none;
    border: var(--inputs-border-width) solid var(--color-input-border);
    border-radius: var(--inputs-border-radius);
    padding: var(--inputs-padding);
    color: var(--color-input-text);
    background-color: var(--color-input-background);
    transition: 0.1s ease-out;
    height: calc(var(--inputs-min-height) * 2);
    width: 100%;
    font-size: var(--inputs-font-size);
  }

  .textarea--disabled textarea {
    opacity: 0.5;
    cursor: not-allowed;
    background-color: var(--color-input-background);
  }

  .textarea--full-width textarea {
    width: 100%;
  }
/* END_SNIPPET:textarea */

/* START_SNIPPET:textfield (INDEX:234) */
.textfield {
    position: relative;
  }

  .textfield input {
    outline: none;
    border: var(--inputs-border-width) solid var(--color-input-border);
    border-radius: var(--inputs-border-radius);
    padding: 1.25rem var(--inputs-padding) 0.375rem;
    color: var(--color-input-text);
    background-color: var(--color-input-background);
    transition: 0.1s ease-out;
    height: var(--inputs-min-height);
    min-width: var(--inputs-min-width);
    font-size: var(--inputs-font-size);
  }

  .textfield input::placeholder {
    opacity: 0;
  }

  .textfield label {
    position: absolute;
    left: calc(var(--inputs-padding) + var(--inputs-border-width));
    top: 50%;
    transform: translateY(-50%);
    font-size: var(--inputs-font-size);
    color: var(--color-input-text);
    transition: 0.1s ease-out;
    transform-origin: left top;
    pointer-events: none;
  }

  .textfield input:focus + label,
  .textfield input:not(:placeholder-shown) + label {
    top: 0.375rem;
    transform: scale(0.75);
  }

  .textfield--small,
  .textfield--small input {
    height: calc(var(--small-multiplier) * var(--inputs-min-height));
  }

  .textfield--small input {
    padding: 0 var(--inputs-padding);
    border-radius: calc(var(--small-multiplier) * var(--inputs-border-radius));
  }

  .textfield--small label {
    display: none;
  }

  .textfield--small input::placeholder {
    opacity: 1;
  }

  .textfield--disabled input {
    opacity: 0.5;
    cursor: not-allowed;
  }

  .textfield--disabled label {
    opacity: 0.5;
  }

  .textfield--full-width,
  .textfield--full-width input {
    width: 100%;
  }

  .textfield--error input {
    border-color: var(--color-error);
  }

  .textfield--error label {
    color: var(--color-error);
  }

  .input-group {
    display: flex;
    align-items: center;
    border: var(--inputs-border-width) solid var(--color-input-border);
    border-radius: var(--inputs-border-radius);
    background-color: var(--color-input-background);
    transition: border-color 0.1s ease-out;
    width: 100%;

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

    .textfield input {
      border-color: transparent;
      background-color: transparent;
      border-top-right-radius: 0;
      border-bottom-right-radius: 0;
    }
  }

  .input-group:focus-within {
    border-color: var(--color-selected-input-border);
  }

  .input-group__action {
    flex-shrink: 0;
    display: flex;
    align-items: center;

    .button {
      border-color: transparent;
      background-color: transparent;
      color: var(--color-input-text);
      border-top-left-radius: 0;
      border-bottom-left-radius: 0;
    }
  }
/* END_SNIPPET:textfield */

/* START_SNIPPET:video (INDEX:236) */
deferred-media {
    border-radius: var(--card-border-radius);
    overflow: hidden;
    aspect-ratio: var(--ratio);
    position: relative;
    display: block;
  }

  .video-interaction-hint {
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 1;
  }

  .video-interaction-hint:hover {
    opacity: 1;
  }

  .deferred-media__video:empty {
    z-index: -1;
  }

  .deferred-media__video {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
  }

  .deferred-media__video video {
    aspect-ratio: var(--ratio);
    object-fit: cover;
  }

  .deferred-media__poster-button {
    opacity: 0;
    transition: opacity 0.3s ease;
  }

  .deferred-media__poster,
  .deferred-media__poster-button {
    cursor: pointer;
  }

  .deferred-media__poster-icon,
  .deferred-media__poster-button {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background-color: transparent;
    border: none;
    transition: var(--animation-link-hover);

    .icon--play_circle,
    .icon--pause_circle {
      font-size: 60px !important;
      color: var(--color-primary-button-text);
    }
  }

  .deferred-media__poster:hover {
    .deferred-media__poster-button {
      opacity: 1;
    }

    .deferred-media__poster-icon {
      opacity: var(--opacity-link-hover);
    }
  }

  .deferred-media__poster {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: relative;
  }

  .deferred-media__poster.deferred-media__playing {
    opacity: 0;
    transition: opacity 0.3s ease;
  }

  deferred-media img {
    height: 100%;
    transition: opacity 0.3s ease;
  }

  deferred-media iframe {
    width: 100%;
    height: 100%;
    border: none;
    aspect-ratio: var(--ratio);
  }

  deferred-media[data-media-loaded] img {
    opacity: 0;
  }
/* END_SNIPPET:video */

/* START_SNIPPET:wishlist-icon (INDEX:237) */
.header__icon-wishlist {
    position: relative;
    cursor: pointer;
    color: inherit;
  }
/* END_SNIPPET:wishlist-icon */