/** Shopify CDN: Minification failed

Line 7006:0 All "@import" rules must come first
Line 7474:0 All "@import" rules must come first
Line 8994:0 All "@import" rules must come first
Line 9261:0 All "@import" rules must come first
Line 9599:0 All "@import" rules must come first
Line 10423:8 Expected identifier but found whitespace
Line 10423:9 Unexpected "48px"
Line 10587:0 "@import" is only valid at the top level
Line 10856:0 "@import" is only valid at the top level
Line 10927:0 "@import" is only valid at the top level
... and 3 more hidden warnings

**/
@charset "UTF-8";
/* Color custom properties */
:root {
  --color-error: 238, 88, 79;
  --color-error-border: 238, 88, 79;
  --color-error-background: 255, 245, 245;
  --duration-short: 100ms;
  --duration-default: 250ms;
  --duration-long: 500ms;
  --alpha-link: 0.5;
  --alpha-button-background: 1;
  --alpha-button-border: 1;
  --color-placeholder-input: 0, 0, 0;
  --alpha-placeholder-input: 0.5;
}

[data-scheme=dark] .subtitle .icon {
  --color-accent: #fff;
}
[data-scheme=dark] .multirow-card__image-wrapper--icon.multirow-card__image-wrapper--shadow,
[data-scheme=dark] .multicolumn-card__image-wrapper--icon.multicolumn-card__image-wrapper--shadow,
[data-scheme=dark] .aic__icon--shadow,
[data-scheme=dark] .image-banner__icon--shadow,
[data-scheme=dark] .image-with-text__column-icon--shadow,
[data-scheme=dark] .multirow-card__image-wrapper--icon--shadow,
[data-scheme=dark] .product__text-icon--shadow,
[data-scheme=dark] .cart__warnings .cart__empty-icon--shadow {
  background-color: #343435;
}
[data-scheme=dark] .contact-form__wrapper {
  background-color: #343435;
}
[data-scheme=dark] .placeholder-svg {
  filter: brightness(0.5) grayscale(1);
}
[data-scheme=dark] .compare {
  color: #e5e5e5;
}
[data-scheme=dark] .swiper-buttons.swiper-buttons--secondary .icon {
  color: rgb(var(--color-background));
}
[data-scheme=dark] .featured-products__products-item .card__inner,
[data-scheme=dark] .card__link::after,
[data-scheme=dark] .card-horizontal__link,
[data-scheme=dark] .card-horizontal__link::after,
[data-scheme=dark] .collection-product-list .collection-product-card--extended .card__link::after {
  background-color: rgb(33, 33, 33);
}
[data-scheme=dark] .collection-results--products .card-wrapper,
[data-scheme=dark] .product-recommendations__product .card-wrapper,
[data-scheme=dark] .search-modal .search__items-item,
[data-scheme=dark] .search-modal .card-horizontal-wrapper {
  background-color: rgb(28, 28, 28);
}
[data-scheme=dark] .featured-products__products-list--horizontal.featured-products__products-list--placeholder .card-wrapper,
[data-scheme=dark] .featured-products__products-list .featured-products__products-item--horizontal .card-horizontal-wrapper {
  border-color: rgb(223, 223, 223);
}
[data-scheme=dark] .filters__item:not(.filters__item_active) {
  opacity: 0.5;
}
[data-scheme=dark] .filters__item:not(.filters__item_active) span {
  color: #000;
}
[data-scheme=dark] .logo-list__image--dark:not(:only-child) {
  display: block;
}
[data-scheme=dark] .logo-list__image--dark:not(:only-child) + .logo-list__image--light {
  display: none;
}
[data-scheme=dark] .card--product-placeholder .placeholder-svg {
  background-color: rgb(var(--color-background));
}
[data-scheme=dark] .product .advantage img:first-child:nth-last-child(2),
[data-scheme=dark] .product .advantage svg:first-child:nth-last-child(2) {
  display: none;
}
[data-scheme=dark] .product .advantage img:first-child:nth-last-child(2) ~ svg, [data-scheme=dark] .product .advantage img:first-child:nth-last-child(2) ~ img,
[data-scheme=dark] .product .advantage svg:first-child:nth-last-child(2) ~ svg,
[data-scheme=dark] .product .advantage svg:first-child:nth-last-child(2) ~ img {
  display: block;
}
[data-scheme=dark] .mega-menu__item--dark .mega-menu__item-heading,
[data-scheme=dark] .mega-menu__item--dark .mega-menu__item-description,
[data-scheme=dark] .mega-menu__item--dark .mega-menu__item-text,
[data-scheme=dark] .mega-menu__item--dark .mega-menu__item-text--accent {
  color: #282828;
}
[data-scheme=dark] .search__block--dark .search__heading,
[data-scheme=dark] .search__block--dark .search__text,
[data-scheme=dark] .search__block--dark .search__text--accent {
  color: #282828;
}

@media (prefers-color-scheme: dark) {
  [data-scheme=auto] .subtitle .icon {
    --color-accent: #fff;
  }
  [data-scheme=auto] .multirow-card__image-wrapper--icon.multirow-card__image-wrapper--shadow,
  [data-scheme=auto] .multicolumn-card__image-wrapper--icon.multicolumn-card__image-wrapper--shadow,
  [data-scheme=auto] .aic__icon--shadow,
  [data-scheme=auto] .image-banner__icon--shadow,
  [data-scheme=auto] .image-with-text__column-icon--shadow,
  [data-scheme=auto] .multirow-card__image-wrapper--icon--shadow,
  [data-scheme=auto] .product__text-icon--shadow,
  [data-scheme=auto] .cart__warnings .cart__empty-icon--shadow {
    background-color: #343435;
  }
  [data-scheme=auto] .contact-form__wrapper {
    background-color: #343435;
  }
  [data-scheme=auto] .placeholder-svg {
    filter: brightness(0.5) grayscale(1);
  }
  [data-scheme=auto] .compare {
    color: #e5e5e5;
  }
  [data-scheme=auto] .swiper-buttons.swiper-buttons--secondary .icon {
    color: rgb(var(--color-background));
  }
  [data-scheme=auto] .featured-products__products-item .card__inner,
  [data-scheme=auto] .card__link::after,
  [data-scheme=auto] .card-horizontal__link,
  [data-scheme=auto] .card-horizontal__link::after,
  [data-scheme=auto] .collection-product-list .collection-product-card--extended .card__link::after {
    background-color: rgb(var(--color-background));
  }
  [data-scheme=auto] .collection-results--products .card-wrapper,
  [data-scheme=auto] .product-recommendations__product .card-wrapper,
  [data-scheme=auto] .search-modal .search__items-item,
  [data-scheme=auto] .search-modal .card-horizontal-wrapper {
    background-color: rgb(33, 33, 33);
  }
  [data-scheme=auto] .featured-products__products-list--horizontal.featured-products__products-list--placeholder .card-wrapper,
  [data-scheme=auto] .featured-products__products-list .featured-products__products-item--horizontal .card-horizontal-wrapper {
    border-color: rgb(223, 223, 223);
  }
  [data-scheme=auto] .filters__item:not(.filters__item_active) {
    opacity: 0.5;
  }
  [data-scheme=auto] .filters__item:not(.filters__item_active) span {
    color: #000;
  }
  [data-scheme=auto] .logo-list__image--dark:not(:only-child) {
    display: block;
  }
  [data-scheme=auto] .logo-list__image--dark:not(:only-child) + .logo-list__image--light {
    display: none;
  }
  [data-scheme=auto] .product .advantage img:first-child:nth-last-child(2),
  [data-scheme=auto] .product .advantage svg:first-child:nth-last-child(2) {
    display: none;
  }
  [data-scheme=auto] .product .advantage img:first-child:nth-last-child(2) ~ svg, [data-scheme=auto] .product .advantage img:first-child:nth-last-child(2) ~ img,
  [data-scheme=auto] .product .advantage svg:first-child:nth-last-child(2) ~ svg,
  [data-scheme=auto] .product .advantage svg:first-child:nth-last-child(2) ~ img {
    display: block;
  }
  [data-scheme=auto] .mega-menu__item--dark .mega-menu__item-heading,
  [data-scheme=auto] .mega-menu__item--dark .mega-menu__item-description,
  [data-scheme=auto] .mega-menu__item--dark .mega-menu__item-text,
  [data-scheme=auto] .mega-menu__item--dark .mega-menu__item-text--accent {
    color: #282828;
  }
  [data-scheme=auto] .search__block--dark .search__heading,
  [data-scheme=auto] .search__block--dark .search__text,
  [data-scheme=auto] .search__block--dark .search__text--accent {
    color: #282828;
  }
  .swiper-buttons.swiper-buttons--secondary .icon {
    color: rgb(var(--color-background));
  }
  .card--product-placeholder .placeholder-svg {
    background-color: rgb(var(--color-background));
  }
}
.container,
.container-fluid,
.container-xxl,
.shopify-policy__container-xxl,
.container-xl,
.shopify-policy__container-xl,
.container-lg,
.shopify-policy__container-lg,
.container-md,
.shopify-policy__container-md,
.container-sm,
.shopify-policy__container-sm,
.shopify-policy__container {
  width: 100%;
  padding-right: 2rem;
  padding-left: 2rem;
  margin-right: auto;
  margin-left: auto;
}
@media screen and (min-width: 1200px) {
  .container,
  .container-fluid,
  .container-xxl,
  .shopify-policy__container-xxl,
  .container-xl,
  .shopify-policy__container-xl,
  .container-lg,
  .shopify-policy__container-lg,
  .container-md,
  .shopify-policy__container-md,
  .container-sm,
  .shopify-policy__container-sm,
  .shopify-policy__container {
    padding-right: 6.4rem;
    padding-left: 6.4rem;
  }
}

@media (min-width: 576px) {
  .container-sm,
  .shopify-policy__container-sm, .container,
  .shopify-policy__container {
    max-width: 100%;
  }
}
@media (min-width: 750px) {
  .container-md,
  .shopify-policy__container-md, .container-sm,
  .shopify-policy__container-sm, .container,
  .shopify-policy__container {
    max-width: 100%;
  }
}
@media (min-width: 990px) {
  .container-lg,
  .shopify-policy__container-lg, .container-md,
  .shopify-policy__container-md, .container-sm,
  .shopify-policy__container-sm, .container,
  .shopify-policy__container {
    max-width: 100%;
  }
}
@media (min-width: 1200px) {
  .container-xl,
  .shopify-policy__container-xl, .container-lg,
  .shopify-policy__container-lg, .container-md,
  .shopify-policy__container-md, .container-sm,
  .shopify-policy__container-sm, .container,
  .shopify-policy__container {
    max-width: 100%;
  }
}
@media (min-width: 1360px) {
  .container-xxl,
  .shopify-policy__container-xxl, .container-xl,
  .shopify-policy__container-xl, .container-lg,
  .shopify-policy__container-lg, .container-md,
  .shopify-policy__container-md, .container-sm,
  .shopify-policy__container-sm, .container,
  .shopify-policy__container {
    max-width: 1760px;
  }
}
@font-face {
  font-family: "icon-custom";
  src: url("./custom-font.eot?54195873");
  src: url("./custom-font.eot?54195873#iefix") format("embedded-opentype"), url("./custom-font.woff2?54195873") format("woff2"), url("./custom-font.woff?54195873") format("woff"), url("./custom-font.ttf?54195873") format("truetype");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
i[class^=icon-],
i[class*=" icon-"] {
  font-family: "icon-custom";
  line-height: 1;
}

i[class^=icon-]:before,
i[class*=" icon-"]:before {
  font-family: "icon-custom";
  font-style: normal;
  font-weight: normal;
  speak: never;
  display: inline-block;
  text-decoration: inherit;
  text-align: center;
  /* For safety - reset parent styles, that can break glyph codes*/
  font-variant: normal;
  text-transform: none;
  /* Font smoothing. That was taken from TWBS */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-video:before {
  content: "\e800";
} /* '' */
.icon-vimeo:before {
  content: "\e801";
} /* '' */
.icon-wallet:before {
  content: "\e802";
} /* '' */
.icon-watch:before {
  content: "\e803";
} /* '' */
.icon-water-1:before {
  content: "\e804";
} /* '' */
.icon-water-2:before {
  content: "\e805";
} /* '' */
.icon-water-3:before {
  content: "\e806";
} /* '' */
.icon-wave-1:before {
  content: "\e807";
} /* '' */
.icon-wifi-1:before {
  content: "\e808";
} /* '' */
.icon-wave-2:before {
  content: "\e809";
} /* '' */
.icon-wifi-2:before {
  content: "\e80a";
} /* '' */
.icon-window:before {
  content: "\e80b";
} /* '' */
.icon-youtube:before {
  content: "\e80c";
} /* '' */
.icon-arrow-bar:before {
  content: "\e80d";
} /* '' */
.icon-bag-1:before {
  content: "\e80e";
} /* '' */
.icon-bag-2:before {
  content: "\e80f";
} /* '' */
.icon-bar-chart:before {
  content: "\e810";
} /* '' */
.icon-bars-upward:before {
  content: "\e811";
} /* '' */
.icon-baseball:before {
  content: "\e812";
} /* '' */
.icon-battery-1:before {
  content: "\e813";
} /* '' */
.icon-battery-2:before {
  content: "\e814";
} /* '' */
.icon-battery-3:before {
  content: "\e815";
} /* '' */
.icon-book:before {
  content: "\e816";
} /* '' */
.icon-card:before {
  content: "\e817";
} /* '' */
.icon-card-holder:before {
  content: "\e818";
} /* '' */
.icon-chart:before {
  content: "\e819";
} /* '' */
.icon-chats:before {
  content: "\e81a";
} /* '' */
.icon-check-1:before {
  content: "\e81b";
} /* '' */
.icon-check-2:before {
  content: "\e81c";
} /* '' */
.icon-check-3:before {
  content: "\e81d";
} /* '' */
.icon-check-4:before {
  content: "\e81e";
} /* '' */
.icon-circles:before {
  content: "\e81f";
} /* '' */
.icon-circle:before {
  content: "\e820";
} /* '' */
.icon-close:before {
  content: "\e821";
} /* '' */
.icon-cloud-server:before {
  content: "\e822";
} /* '' */
.icon-computer:before {
  content: "\e823";
} /* '' */
.icon-confetti:before {
  content: "\e824";
} /* '' */
.icon-delivery:before {
  content: "\e825";
} /* '' */
.icon-delivery-box:before {
  content: "\e826";
} /* '' */
.icon-devices:before {
  content: "\e827";
} /* '' */
.icon-directions:before {
  content: "\e828";
} /* '' */
.icon-dumbbell:before {
  content: "\e829";
} /* '' */
.icon-eye:before {
  content: "\e82a";
} /* '' */
.icon-facebook:before {
  content: "\e82b";
} /* '' */
.icon-file-1:before {
  content: "\e82c";
} /* '' */
.icon-file-2:before {
  content: "\e82d";
} /* '' */
.icon-flag:before {
  content: "\e82e";
} /* '' */
.icon-folder-1:before {
  content: "\e82f";
} /* '' */
.icon-folder-2:before {
  content: "\e830";
} /* '' */
.icon-food:before {
  content: "\e831";
} /* '' */
.icon-hand-1:before {
  content: "\e832";
} /* '' */
.icon-hand-2:before {
  content: "\e833";
} /* '' */
.icon-hand-3:before {
  content: "\e834";
} /* '' */
.icon-headphones:before {
  content: "\e835";
} /* '' */
.icon-instagram:before {
  content: "\e836";
} /* '' */
.icon-laptop-1:before {
  content: "\e837";
} /* '' */
.icon-laptop-2:before {
  content: "\e838";
} /* '' */
.icon-leaf:before {
  content: "\e839";
} /* '' */
.icon-lightning-bolt-1:before {
  content: "\e83a";
} /* '' */
.icon-lightning-bolt-2:before {
  content: "\e83b";
} /* '' */
.icon-like:before {
  content: "\e83c";
} /* '' */
.icon-link:before {
  content: "\e83d";
} /* '' */
.icon-lock-1:before {
  content: "\e83e";
} /* '' */
.icon-lock-2:before {
  content: "\e83f";
} /* '' */
.icon-logout:before {
  content: "\e840";
} /* '' */
.icon-luggage:before {
  content: "\e841";
} /* '' */
.icon-mark:before {
  content: "\e842";
} /* '' */
.icon-medicine:before {
  content: "\e843";
} /* '' */
.icon-microphone:before {
  content: "\e844";
} /* '' */
.icon-moon:before {
  content: "\e845";
} /* '' */
.icon-pencil:before {
  content: "\e846";
} /* '' */
.icon-phone-4:before {
  content: "\e847";
} /* '' */
.icon-phone-1:before {
  content: "\e848";
} /* '' */
.icon-phone-2:before {
  content: "\e849";
} /* '' */
.icon-phone-3:before {
  content: "\e84a";
} /* '' */
.icon-pinterest:before {
  content: "\e84b";
} /* '' */
.icon-plug:before {
  content: "\e84c";
} /* '' */
.icon-presentation-1:before {
  content: "\e84d";
} /* '' */
.icon-presentation-2:before {
  content: "\e84e";
} /* '' */
.icon-pulse:before {
  content: "\e84f";
} /* '' */
.icon-recycle:before {
  content: "\e850";
} /* '' */
.icon-rocket:before {
  content: "\e851";
} /* '' */
.icon-search:before {
  content: "\e852";
} /* '' */
.icon-server-1:before {
  content: "\e853";
} /* '' */
.icon-server-2:before {
  content: "\e854";
} /* '' */
.icon-settings:before {
  content: "\e855";
} /* '' */
.icon-shield:before {
  content: "\e856";
} /* '' */
.icon-shopping-basket:before {
  content: "\e857";
} /* '' */
.icon-shuffle:before {
  content: "\e858";
} /* '' */
.icon-snapchat:before {
  content: "\e859";
} /* '' */
.icon-sound-waves:before {
  content: "\e85a";
} /* '' */
.icon-speaker:before {
  content: "\e85b";
} /* '' */
.icon-squares-1:before {
  content: "\e85c";
} /* '' */
.icon-squares-2:before {
  content: "\e85d";
} /* '' */
.icon-stack:before {
  content: "\e85e";
} /* '' */
.icon-star:before {
  content: "\e85f";
} /* '' */
.icon-stopwatch:before {
  content: "\e860";
} /* '' */
.icon-sun:before {
  content: "\e861";
} /* '' */
.icon-tag:before {
  content: "\e862";
} /* '' */
.icon-telephone-tower:before {
  content: "\e863";
} /* '' */
.icon-tik-tok:before {
  content: "\e864";
} /* '' */
.icon-tree:before {
  content: "\e865";
} /* '' */
.icon-trend:before {
  content: "\e866";
} /* '' */
.icon-tumblr:before {
  content: "\e868";
} /* '' */
.icon-tv:before {
  content: "\e869";
} /* '' */
.icon-twitter:before {
  content: "\e86a";
} /* '' */
.icon-user-1:before {
  content: "\e86b";
} /* '' */
.icon-user-2:before {
  content: "\e86c";
} /* '' */
.icon-user-3:before {
  content: "\e86d";
} /* '' */
.icon-user-4:before {
  content: "\e86e";
} /* '' */
.icon-trophy:before {
  content: "\e86f";
} /* '' */
.icon-clock-1:before {
  content: "\e870";
} /* '' */
.icon-clock-2:before {
  content: "\e871";
} /* '' */
.icon-sending:before {
  content: "\e872";
} /* '' */
.icon-chart-2:before {
  content: "\e873";
} /* '' */
.icon-user-5:before {
  content: "\e874";
} /* '' */
.icon-chart-3:before {
  content: "\e875";
} /* '' */
.icon-bag-3:before {
  content: "\e876";
} /* '' */
.icon-computer-mouse:before {
  content: "\e877";
} /* '' */
/* Base */
.text-gradient {
  background: var(--gradient-accent);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  display: inline-block;
}

.no-js:not(html) {
  display: none !important;
}

html, body {
  scrollbar-gutter: stable;
}

html.no-js .no-js:not(html) {
  display: block !important;
}

.no-js-inline {
  display: none !important;
}

html.no-js .no-js-inline {
  display: inline-block !important;
}

.no-js-flex {
  display: none !important;
}

html.no-js .no-js-flex {
  display: flex !important;
}

html.js .js-hidden {
  display: none !important;
}

html.no-js .no-js-block {
  display: block !important;
}

html.no-js .no-js-hidden {
  display: none !important;
}

.page-width {
  max-width: 139.6rem;
  margin: 0 auto;
  padding: 0 2.5rem;
}

@media screen and (min-width: 750px) {
  .page-width {
    padding: 0 5rem;
  }
  .page-width--narrow {
    padding: 0 9rem;
  }
}
@media screen and (min-width: 990px) {
  .page-width--narrow {
    max-width: 72.6rem;
    padding: 0;
  }
}
.spaced-section {
  position: relative;
}

.section-border-top {
  padding-top: 5rem;
}
.section-border-top__inner {
  position: relative;
}
.section-border-top__inner:before {
  content: "";
  position: absolute;
  width: calc(100% - 12.8rem);
  height: 1px;
  left: 50%;
  transform: translateX(-50%);
  top: -5rem;
  background-color: rgba(var(--color-foreground), 0.2);
}

body,
.color-background-1,
.color-background-2,
.color-background-3 {
  line-height: var(--font-body-line-height);
  letter-spacing: calc(var(--font-body-letter-spacing) * 0.1);
}

.background-secondary {
  background-color: rgba(var(--color-background-secondary));
  padding: 4rem 0 5rem;
}

@media screen and (min-width: 750px) {
  .background-secondary {
    padding: 6rem 0 5rem;
  }
}
.page-margin,
.shopify-challenge__container {
  margin: 7rem auto;
}

.shopify-challenge__error {
  padding-left: 0;
}
.shopify-challenge__button {
  font-family: var(--font-button-family);
  font-weight: var(--font-button-weight);
  font-style: var(--font-button-style);
  text-transform: var(--font-button-text-transform);
  letter-spacing: var(--font-button-letter-spacing);
  position: relative;
  box-sizing: border-box;
  text-decoration: none;
  border: 0;
  border-radius: var(--border-radius-button);
  font-size: 1.6rem;
  line-height: var(--font-body-line-height);
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
  overflow: hidden;
  z-index: 1;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-width: 10rem;
  min-height: 5.6rem;
  padding: 0 3.2rem;
  transition: background-color var(--duration-default), color var(--duration-default);
  background-color: rgba(var(--color-button), var(--alpha-button-background));
  color: rgb(var(--color-button-text));
  margin-top: 2.4rem !important;
}
@media screen and (min-width: 576px) {
  .shopify-challenge__button {
    padding: 0 5.6rem;
  }
}
.shopify-challenge__button:hover {
  background-color: rgb(var(--color-button-hover));
  color: rgb(var(--color-button-text-hover));
}
.shopify-challenge__button:focus {
  background-color: rgba(var(--color-button), var(--alpha-button-background));
}

.rte-width {
  max-width: 82rem;
  margin: 0 auto 2rem;
}

.list-unstyled {
  margin: 0;
  padding: 0;
  list-style: none;
}

.hidden {
  display: none !important;
}

.visually-hidden {
  position: absolute !important;
  overflow: hidden;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  clip: rect(0 0 0 0);
  word-wrap: normal !important;
}

.visually-hidden--inline {
  margin: 0;
  height: 1em;
}

.visibility-hidden {
  visibility: hidden;
}

.skip-to-content-link:focus {
  z-index: 9999;
  position: inherit;
  overflow: auto;
  width: auto;
  height: auto;
  clip: auto;
  mix-blend-mode: exclusion;
}

.overflow-hidden,
.overflow-hidden-drawer {
  overflow: hidden;
}

body.scroll-locked {
  position: fixed;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

/* base-details-summary */
summary {
  cursor: pointer;
  list-style: none;
  position: relative;
}

summary .icon-caret {
  position: absolute;
  width: 2.4rem;
  height: 2.4rem;
  right: 0;
  top: calc(50% - 1rem);
}

summary::-webkit-details-marker {
  display: none;
}

.disclosure-has-popup {
  position: relative;
}

.disclosure-has-popup[open] > summary::before {
  position: fixed;
  inset: 0;
  z-index: 2;
  display: block;
  cursor: default;
  content: " ";
  background: transparent;
}

.disclosure-has-popup > summary::before {
  display: none;
}

.disclosure-has-popup[open] > summary + * {
  z-index: 100;
}

/* Animation */
@keyframes translate {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(-40rem, 0, 0);
  }
}
@keyframes fade {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes link-hover {
  0% {
    width: 100%;
  }
  50% {
    width: 0;
  }
  100% {
    width: 100%;
  }
}
/* Light header on dark bg */
.header-wrapper--overlay .header__menu-item:not(.mega-menu__link):not(.list-menu__item) {
  transition: none;
}

body:not(.body--hidden) #shopify-section-header:not(.shopify-section-header-sticky.animate) .header-wrapper--overlay .header__offcanvas-toggle .header__offcanvas-toggle-link {
  color: var(--color-light-text-hex);
}
body:not(.body--hidden) #shopify-section-header:not(.shopify-section-header-sticky.animate) .header-wrapper--overlay .header__heading-link > * {
  color: var(--color-light-text-hex);
}

@media (prefers-color-scheme: light) {
  .header__heading-logo:not(.header__heading-logo--overlay) {
    display: block;
  }
  .header__heading .header__heading-logo--overlay,
  .header__heading-link .header__heading-logo--overlay {
    display: none;
  }
  .header__heading .header__heading-logo:not(.header__heading-logo--overlay),
  .header__heading-link .header__heading-logo:not(.header__heading-logo--overlay) {
    display: block;
  }
  .header__heading .header__heading-logo:only-child,
  .header__heading-link .header__heading-logo:only-child {
    display: block !important;
  }
  .search__form-inner .field.color-background-2 {
    background: none;
  }
  .search__form-inner .field.color-background-3 {
    background: none;
  }
}
[data-scheme=light] .header__heading-logo:not(.header__heading-logo--overlay) {
  display: block;
}
[data-scheme=light] .header__heading .header__heading-logo--overlay,
[data-scheme=light] .header__heading-link .header__heading-logo--overlay {
  display: none;
}
[data-scheme=light] .header__heading .header__heading-logo:not(.header__heading-logo--overlay),
[data-scheme=light] .header__heading-link .header__heading-logo:not(.header__heading-logo--overlay) {
  display: block;
}
[data-scheme=light] .header__heading .header__heading-logo:only-child,
[data-scheme=light] .header__heading-link .header__heading-logo:only-child {
  display: block !important;
}

@media (prefers-color-scheme: dark) {
  .header__heading-logo:not(.header__heading-logo--overlay) {
    display: none;
  }
  .header__heading-logo.header__heading-logo--overlay {
    display: block;
  }
  .header__heading-logo:only-child {
    display: block !important;
  }
  .search__form-inner .field.color-background-2 {
    background: none;
  }
  .search__form-inner .field.color-background-3 {
    background: none;
  }
}
[data-scheme=dark] .header__heading-logo:not(.header__heading-logo--overlay) {
  display: none;
}
[data-scheme=dark] .header__heading-logo.header__heading-logo--overlay {
  display: block;
}
[data-scheme=dark] .header__heading-logo:only-child {
  display: block !important;
}

main .shopify-section:first-child:not(.not-margin) .section--has-overlay:not(.article-template__header) {
  margin-top: calc(-1 * (var(--header-height) + var(--breadcrumbs-height)));
}

main .shopify-section:first-child.not-margin .section--has-overlay:not(.article-template__header) {
  margin-top: calc(-1 * var(--breadcrumbs-height));
}

.placeholder-svg {
  filter: grayscale(1);
}
.placeholder-svg.placeholder-svg--no-transition {
  transition: none;
}

.placeholder-svg—lined {
  fill: rgb(var(--color-foreground));
  background-color: rgba(var(--color-background-secondary));
}

.background {
  background: rgb(var(--color-background));
  background: var(--gradient-background, rgb(var(--color-background)));
  background-attachment: fixed;
}

p {
  color: rgb(var(--color-foreground));
}

.shopify-policy__title {
  text-align: left;
}

.shopify-policy__body {
  padding-bottom: 4.8rem;
}
@media screen and (min-width: 1200px) {
  .shopify-policy__body {
    padding-bottom: 8.8rem;
  }
}

.section-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 2.4rem 2rem;
}
@media screen and (min-width: 750px) {
  .section-grid {
    gap: 3.2rem 2rem;
  }
}
@media screen and (min-width: 1200px) {
  .section-grid {
    gap: 5.6rem 2rem;
  }
}
.section-grid .description {
  margin-bottom: 0;
}
.section-grid .section-top + .button {
  grid-row: 3;
  grid-column: span 2;
  align-self: end;
  width: 100%;
}
@media screen and (min-width: 576px) {
  .section-grid .section-top + .button {
    grid-row: unset;
    grid-column: unset;
    width: auto;
  }
}
.section-grid_no-text {
  display: flex;
  flex-direction: column-reverse;
}
@media screen and (min-width: 576px) {
  .section-grid_no-text {
    flex-direction: column;
  }
  .section-grid_no-text > .button {
    align-self: flex-end;
  }
}

.section-top {
  align-self: center;
}

.section-border {
  position: relative;
}
.section-border .container::before {
  content: "";
  position: absolute;
  top: 0;
  display: block;
  width: 100%;
  height: 0.1rem;
  background-color: rgb(var(--color-border));
  max-width: calc(100% - 4rem);
}
@media screen and (min-width: 1200px) {
  .section-border .container::before {
    max-width: calc(100% - 12.8rem);
  }
}
@media screen and (min-width: 1760px) {
  .section-border .container::before {
    max-width: calc(1760px - 12.8rem);
  }
}
.section-border-full .container::before {
  left: 0;
  max-width: 100%;
}

/*Section rte */
.section-rte a {
  color: rgb(var(--color-accent));
  text-decoration: none;
  transition: opacity var(--duration-default) ease;
}
.section-rte a:hover {
  opacity: 0.8;
}
.section-rte ol,
.section-rte ul {
  padding-left: 2.4rem;
  margin: 0 0 1.6rem 0;
}
@media screen and (min-width: 576px) {
  .section-rte ol,
  .section-rte ul {
    margin: 0 0 1.6rem 0.8rem;
  }
}
.section-rte li {
  list-style: inherit;
  padding-left: 0.4rem;
  margin: 1.6rem 0rem;
}
.section-rte h1,
.section-rte h2,
.section-rte h3,
.section-rte h4 {
  margin-top: 2.4rem;
  margin-bottom: 1.6rem;
  line-height: var(--font-heading-line-height);
}
@media screen and (min-width: 576px) {
  .section-rte h1,
  .section-rte h2,
  .section-rte h3,
  .section-rte h4 {
    margin-top: 3.2rem;
  }
}
.section-rte h1 + p,
.section-rte h2 + p,
.section-rte h3 + p,
.section-rte h4 + p {
  margin-top: 0;
}
.section-rte p {
  margin: 1.6rem 0;
}
.section-rte *:first-child {
  margin-top: 0;
}
.section-rte *:last-child {
  margin-bottom: 0;
}

[dir=rtl] input[dir=ltr],
[dir=rtl] textarea[dir=ltr] {
  text-align: right !important;
}
[dir=rtl] .header__submenu li a span svg {
  transform: rotate(90deg);
}
[dir=rtl] .blog__button-next .icon-caret-right {
  transform: rotate(180deg) !important;
}
[dir=rtl] .swiper-navigation .swiper-button-next {
  transform: translateX(-50%) !important;
}
[dir=rtl] .swiper-navigation .swiper-button-prev {
  transform: translateX(50%) !important;
}
[dir=rtl] .swiper-button-prev .icon {
  transform: rotate(180deg) !important;
}
[dir=rtl] .swiper-button-next .icon {
  transform: rotate(180deg) !important;
}
@media screen and (min-width: 1200px) {
  [dir=rtl] .swiper-button-next:hover .icon {
    transform: rotate(180deg) translateX(0.3rem) !important;
  }
  [dir=rtl] .swiper-button-prev:hover .icon {
    transform: rotate(180deg) translateX(-0.3rem) !important;
  }
}
[dir=rtl] .article-card__tags {
  right: 2.4rem;
}
[dir=rtl] .list-menu--disclosure .list-menu--disclosure {
  left: 0;
  right: 100%;
}
[dir=rtl] * + .header__cart::before {
  display: none;
}
[dir=rtl] * + .header__cart:after {
  content: "";
  position: absolute;
  left: 0;
  width: 0.2rem;
  height: 1.6rem;
  background-color: rgb(var(--color-border));
  border-radius: 0.2rem;
}
[dir=rtl] .shopify-section-header:not(.color-background-overlay) * + .header__cart:after {
  background-color: rgb(var(--color-foreground), 0.2);
}
[dir=rtl] * + .header__cart {
  margin-right: 0.2rem;
  padding-right: 1.6rem;
  padding-left: 0;
  margin-left: 0;
}
[dir=rtl] .header__icons .header__cart:after {
  right: 0.1rem;
}
[dir=rtl] .header__column {
  margin-right: auto;
  margin-left: 0;
}
[dir=rtl] .header--left-logo .header__heading-link {
  margin-left: 2rem;
  margin-right: -0.8rem;
}
@media screen and (min-width: 1360px) {
  [dir=rtl] .header--left-logo .header__heading-link {
    margin-left: 2.4rem;
    margin-right: 0;
  }
}
@media screen and (min-width: 1100px) {
  [dir=rtl] .header--left-logo .header__heading-link {
    margin-right: 0;
  }
}
[dir=rtl] .header__icon--menu {
  margin-right: -1.2rem;
  margin-left: 0;
}
[dir=rtl] .menu-drawer-container .header__modal-close-button {
  margin-left: 0;
  margin-right: -1.2rem;
}
[dir=rtl] .product-markers__item:before {
  left: 22.5%;
  right: -22.5%;
}
[dir=rtl] .product-markers__item-title span {
  text-align: right;
}
[dir=rtl] .multicolumn-card__text {
  margin-left: 1.6rem;
  margin-right: 0;
}
@media (min-width: 1200px) {
  [dir=rtl] .multicolumn-card__text {
    margin-right: 0;
    margin-left: 3.4rem;
  }
}
[dir=rtl] .icon-button-arrow {
  transform: rotate(-90deg);
}
@media screen and (min-width: 1200px) {
  [dir=rtl] .button--arrow:hover .icon-button-arrow,
  [dir=rtl] .customer .button--arrow:hover .icon-button-arrow {
    transform: rotate(-135deg);
  }
}
[dir=rtl] .drawer__close {
  left: 2rem !important;
  right: auto !important;
}
[dir=rtl] .drawer__header .drawer__heading {
  padding-right: 0;
  padding-left: 5rem;
}
[dir=rtl] .page-title {
  text-align: right;
}
[dir=rtl] .image-with-text__top {
  top: 4rem;
  left: auto;
  right: 4rem;
  gap: 3.2rem;
}
[dir=rtl] .article-card__info {
  text-align: right;
}
[dir=rtl] .odometer-inside {
  direction: ltr !important;
}
[dir=rtl] .newsletter__text {
  direction: ltr !important;
  text-align: end;
}
[dir=rtl] .pricing-table__badge {
  right: auto;
  left: 2.4rem;
}
@media screen and (min-width: 1200px) {
  [dir=rtl] .product__slider-nav:not(.product-media-modal__slider-nav) .swiper-button-next {
    transform: translate(-50%);
  }
}
@media screen and (min-width: 1200px) {
  [dir=rtl] .product__slider-nav:not(.product-media-modal__slider-nav) .swiper-button-prev {
    transform: translate(50%);
  }
}
@media screen and (min-width: 576px) {
  [dir=rtl] .template-search__search .search__form-inner .button,
  [dir=rtl] .template-404__page .search__form-inner .button {
    right: auto;
    left: 0.6rem;
  }
}
@media screen and (min-width: 576px) {
  [dir=rtl] .template-search__search .search__form-inner .field .field__input,
  [dir=rtl] .template-404__page .search__form-inner .field .field__input {
    padding-left: 10.2rem;
  }
}
@media screen and (min-width: 576px) {
  [dir=rtl] .template-search__search .search__form-inner .field .field__input,
  [dir=rtl] .template-404__page .search__form-inner .field .field__input {
    padding-right: 2.4rem !important;
  }
}
[dir=rtl] .pagination__item-arrow {
  transform: rotate(180deg) !important;
}
[dir=rtl] .collections-list__description {
  text-align: right;
}
[dir=rtl] .header .search__input {
  padding-right: 2.4rem !important;
}
[dir=rtl] .header .search__button {
  left: 0.6rem;
  right: auto;
}
[dir=rtl] .field label {
  direction: ltr !important;
}
[dir=rtl] .search__form-text {
  text-align: right !important;
}
@media screen and (min-width: 750px) {
  [dir=rtl] .footer .newsletter__form .newsletter__button {
    right: auto;
    left: 0.6rem;
  }
}
@media screen and (min-width: 750px) {
  [dir=rtl] .footer .newsletter__form .field input {
    padding: 1.6rem 2.4rem 1.6rem 13.4rem;
  }
}
[dir=rtl] .header__account-modal {
  left: 0;
  right: auto !important;
}
[dir=rtl] .header__search-inner {
  left: 0;
}
@media screen and (min-width: 990px) {
  [dir=rtl] .header__search-inner {
    right: unset !important;
    top: calc(100% + 1.6rem);
    padding: 3.2rem;
    width: 53.2rem;
  }
}
[dir=rtl] .multicolumn-card--hor-align-left .multicolumn-card__image-wrapper {
  margin-left: auto;
  margin-right: 0;
}
[dir=rtl] .product .price-wrapper .price dd:not(:last-child) {
  margin: 0 0 0 0.6rem;
}

/* Typography */
h1,
h2,
h3,
h4,
h5,
h6,
.h0,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
  font-family: var(--font-heading-family);
  font-style: var(--font-heading-style);
  font-weight: var(--font-heading-weight);
  letter-spacing: calc(var(--font-heading-letter-spacing) * 0.1);
  color: rgb(var(--color-foreground-title));
  line-height: var(--font-heading-line-height);
  text-transform: var(--font-heading-text-transform);
  word-wrap: break-word;
  max-width: 100%;
}

.h0 {
  font-size: 5rem;
}
@media screen and (min-width: 990px) {
  .h0 {
    font-size: 10rem;
  }
}
@media screen and (min-width: 1360px) {
  .h0 {
    font-size: 14.4rem;
  }
}

h1,
.h1 {
  font-size: calc(var(--font-heading-h1-scale) * 3.2rem);
}
@media only screen and (min-width: 750px) {
  h1,
  .h1 {
    font-size: calc(var(--font-heading-h1-scale) * 4.2rem);
  }
}
@media only screen and (min-width: 1360px) {
  h1,
  .h1 {
    font-size: calc(var(--font-heading-h1-scale) * 4.8rem);
  }
}
@media only screen and (min-width: 1536px) {
  h1,
  .h1 {
    font-size: calc(var(--font-heading-h1-scale) * 5.6rem);
  }
}

h2,
.h2 {
  font-size: calc(var(--font-heading-h2-scale) * 2.5rem);
}
@media only screen and (min-width: 750px) {
  h2,
  .h2 {
    font-size: calc(var(--font-heading-h2-scale) * 3.2rem);
  }
}
@media only screen and (min-width: 1360px) {
  h2,
  .h2 {
    font-size: calc(var(--font-heading-h2-scale) * 3.7rem);
  }
}
@media only screen and (min-width: 1536px) {
  h2,
  .h2 {
    font-size: calc(var(--font-heading-h2-scale) * 4.2rem);
  }
}

h3,
.h3 {
  font-size: calc(var(--font-heading-h3-scale) * 2.6rem);
}
@media only screen and (min-width: 750px) {
  h3,
  .h3 {
    font-size: calc(var(--font-heading-h3-scale) * 3rem);
  }
}
@media only screen and (min-width: 1360px) {
  h3,
  .h3 {
    font-size: calc(var(--font-heading-h3-scale) * 3.6rem);
  }
}
@media only screen and (min-width: 1536px) {
  h3,
  .h3 {
    font-size: calc(var(--font-heading-h3-scale) * 4rem);
  }
}

h4,
.h4 {
  font-size: calc(var(--font-heading-h4-scale) * 2.1rem);
}
@media only screen and (min-width: 750px) {
  h4,
  .h4 {
    font-size: calc(var(--font-heading-h4-scale) * 2.3rem);
  }
}
@media only screen and (min-width: 1360px) {
  h4,
  .h4 {
    font-size: calc(var(--font-heading-h4-scale) * 2.5rem);
  }
}
@media only screen and (min-width: 1536px) {
  h4,
  .h4 {
    font-size: calc(var(--font-heading-h4-scale) * 2.8rem);
  }
}

h5,
.h5 {
  font-size: calc(var(--font-heading-h5-scale) * 2rem);
}
@media only screen and (min-width: 750px) {
  h5,
  .h5 {
    font-size: calc(var(--font-heading-h5-scale) * 2.4rem);
  }
}

h6,
.h6 {
  font-size: 1.8rem;
  line-height: var(--font-body-line-height);
}
@media only screen and (min-width: 750px) {
  h6,
  .h6 {
    font-size: 2rem;
  }
}

a {
  color: rgba(var(--color-foreground));
  text-decoration-color: rgb(var(--color-foreground));
  transition: color var(--duration-default), text-decoration var(--duration-default);
}
@media only screen and (min-width: 1200px) {
  a:hover {
    color: rgba(var(--color-foreground));
    text-decoration-color: rgb(var(--color-foreground));
  }
}

blockquote {
  padding: 2rem 3rem;
  font-size: 1.6rem;
  color: rgba(var(--color-foreground));
  line-height: 1.3;
  border-top: 0.3rem solid rgba(var(--color-foreground));
  border-bottom: 0.1rem solid rgba(var(--color-foreground), 0.3);
}

@media screen and (min-width: 750px) {
  blockquote {
    padding: 2.4rem 10rem;
    font-size: 2rem;
  }
}
table:not([class]) {
  table-layout: fixed;
  border-collapse: collapse;
  font-size: 1.4rem;
  border-style: hidden;
  box-shadow: 0 0 0 0.1rem rgba(var(--color-foreground), 0.2);
  /* draws the table border  */
}

table:not([class]) td,
table:not([class]) th {
  padding: 1em;
  border: 0.1rem solid rgba(var(--color-foreground), 0.2);
}

a:empty,
ul:empty,
dl:empty,
section:empty,
article:empty,
p:empty,
h1:empty,
h2:empty,
h3:empty,
h4:empty,
h5:empty,
h6:empty {
  display: none;
}

hr {
  display: block;
  width: 100%;
  height: 0.1rem;
  background-color: rgb(var(--color-border));
  border: none;
}

.caption {
  font-size: 1rem;
  color: rgb(var(--color-foreground-secondary));
  line-height: 1.7;
}

@media screen and (min-width: 750px) {
  .caption {
    font-size: 1.2rem;
  }
}
.caption-with-letter-spacing {
  margin-top: 1rem;
  font-size: 1.2rem;
}

.caption-large,
.form__label {
  text-transform: uppercase;
  font-weight: 500;
  color: rgba(var(--color-foreground));
}

@media screen and (max-width: 749px) {
  .small-hide {
    display: none;
  }
}
@media screen and (max-width: 749px) {
  .small-hide {
    display: none !important;
  }
}
@media screen and (min-width: 750px) and (max-width: 989px) {
  .medium-hide {
    display: none !important;
  }
}
@media screen and (min-width: 990px) {
  .large-up-hide {
    display: none !important;
  }
}
.center {
  text-align: center;
}

.right {
  text-align: right;
}

.uppercase {
  text-transform: uppercase;
}

.light {
  opacity: 0.7;
}

.link {
  cursor: pointer;
  display: inline-block;
  border: none;
  box-shadow: none;
  text-decoration: underline;
  text-underline-offset: 0.3rem;
  color: rgb(var(--color-link));
  background-color: transparent;
  font-size: calc(var(--font-body-scale) * 1.4rem);
  transition: var(--duration-default);
}

.header__localization-button.disclosure__button.localization-form__select.localization-selector.link.link--text.caption-large.focus-inset {
  text-decoration: none;
}

.link--text {
  color: rgb(var(--color-foreground));
  transition: var(--duration-default);
}

.circle-divider::after {
  content: "•";
  margin: 0 8px 0 8px;
}

.circle-divider:last-of-type::after {
  display: none;
}

.line-divider {
  align-items: center;
  justify-content: center;
}

.line-divider::after {
  content: "";
  display: inline-flex;
  width: 16px;
  height: 1px;
  margin: 0 8px 0 8px;
  background: rgba(var(--color-foreground), 0.6);
}

.line-divider_vertical::after {
  width: 1px;
  height: 13px;
}

.line-divider:last-of-type::after {
  display: none;
}

.full-unstyled-link {
  text-decoration: none;
  color: currentColor;
  display: block;
}

.placeholder {
  background-color: rgba(var(--color-foreground), 0.04);
  color: rgba(var(--color-foreground), 0.55);
  fill: rgba(var(--color-foreground), 0.55);
}

details > * {
  box-sizing: border-box;
}

.break {
  word-break: break-word;
}

@media (prefers-reduced-motion) {
  .motion-reduce {
    transition: none !important;
  }
}
.underlined-link {
  color: rgb(var(--color-foreground));
  text-underline-offset: 0.3rem;
  text-decoration-thickness: 0.1rem;
  transition: opacity var(--duration-default);
}

.underlined-link:hover {
  opacity: 0.7;
}

.link-hover-line {
  position: relative;
}
.link-hover-line::after {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  content: "";
  width: 0;
  height: 0.1rem;
  background-color: currentColor;
  transition: width var(--duration-default);
}
.link-hover-line:hover::after {
  width: 100%;
}

.link-hover-line-outer > span {
  position: relative;
}
.link-hover-line-outer > span::after {
  position: absolute;
  bottom: 0.2rem;
  left: 0;
  right: 0;
  content: "";
  width: 0;
  height: 0.1rem;
  background-color: rgb(var(--color-button));
  transition: width var(--duration-default);
}
.link-hover-line-outer:hover > span::after {
  width: 100%;
}

.link-hover-arrow svg {
  opacity: 0;
  transition: opacity var(--duration-default);
}
.link-hover-arrow:hover svg {
  opacity: 1;
}

.body-large {
  font-size: calc(var(--font-body-scale) * 1.2rem + 0.2rem);
}
@media only screen and (min-width: 750px) {
  .body-large {
    font-size: calc(var(--font-body-scale) * 1.3rem + 0.3rem);
  }
}
@media only screen and (min-width: 1536px) {
  .body-large {
    font-size: calc(var(--font-body-scale) * 1.4rem + 0.4rem);
  }
}

.body-normal {
  font-size: calc(var(--font-body-scale) * 1.2rem);
}
@media screen and (min-width: 750px) {
  .body-normal {
    font-size: calc(var(--font-body-scale) * 1.3rem);
  }
}
@media only screen and (min-width: 1536px) {
  .body-normal {
    font-size: calc(var(--font-body-scale) * 1.4rem);
  }
}

.body-small {
  font-size: calc(var(--font-body-scale) * 1.2rem - 0.1rem);
}
@media only screen and (min-width: 750px) {
  .body-small {
    font-size: calc(var(--font-body-scale) * 1.4rem - 0.2rem);
  }
}

.body-xs {
  font-size: calc(var(--font-body-scale) * 1.2rem - 0.3rem);
}
@media only screen and (min-width: 750px) {
  .body-xs {
    font-size: calc(var(--font-body-scale) * 1.4rem - 0.4rem);
  }
}

.bold {
  font-family: var(--font-additional-family);
  font-style: var(--font-additional-style);
  font-weight: var(--font-additional-weight);
}

/* Component-title */
.title {
  margin: 3rem 0 2rem;
}

.title-wrapper {
  margin-bottom: 3rem;
}

.title--primary {
  margin: 4rem 0;
}

.title--page {
  text-align: left;
}

.title--section > * {
  margin: 0;
}

.title--section-mt-none {
  margin: 0 0 3rem 0;
}

.title--section-m-none {
  margin: 0;
}

@media screen and (min-width: 990px) {
  .title {
    margin: 5rem 0 3rem;
  }
  .title--primary {
    margin: 2rem 0;
  }
}
.page-header {
  margin-top: 1.6rem;
  margin-bottom: 1.6rem;
  text-align: center;
}
@media screen and (min-width: 750px) {
  .page-header {
    margin-top: 3.2rem;
    margin-bottom: 2.4rem;
  }
}
@media screen and (min-width: 1200px) {
  .page-header {
    margin-top: 4.8rem;
  }
}

.page-header .title--page {
  margin-bottom: 0;
  margin-top: 0;
}

.page-header .title--page:not(:first-child) {
  margin-bottom: 1.5rem;
}

.subtitle {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin: 0;
  font-family: var(--font-subtitle-family);
  font-weight: var(--font-subtitle-weight);
  font-style: var(--font-subtitle-style);
  letter-spacing: var(--font-subtitle-letter-spacing);
  text-transform: var(--font-subtitle-text-transform);
  color: rgba(var(--color-foreground-secondary));
  font-size: calc(var(--font-subtitle-scale) * 1rem - 0.1rem);
}
@media only screen and (min-width: 1360px) {
  .subtitle {
    font-size: calc(var(--font-subtitle-scale) * 1rem);
  }
}
.subtitle .icon {
  font-family: "icon-custom";
  font-size: 1.4rem;
  line-height: 1;
  color: rgba(var(--color-accent));
}
@media only screen and (min-width: 1360px) {
  .subtitle .icon {
    font-size: 1.5rem;
  }
}

.subtitle--secondary {
  padding: 0.5rem 1rem;
  font-family: var(--font-subtitle-secondary-family);
  font-weight: var(--font-subtitle-secondary-weight);
  font-style: var(--font-subtitle-secondary-style);
  font-size: calc(var(--font-subtitle-secondary-scale) * 1rem - 0.1rem);
  letter-spacing: var(--font-subtitle-secondary-letter-spacing);
  text-transform: var(--font-subtitle-secondary-text-transform);
  color: rgba(var(--color-foreground-title));
  border-radius: 10rem;
  background-color: rgb(var(--color-background-secondary));
}
@media only screen and (min-width: 1360px) {
  .subtitle--secondary {
    font-size: calc(var(--font-subtitle-secondary-scale) * 1rem);
  }
}

.card__subtitle {
  position: relative;
  margin: 0;
  font-size: 1.1rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
  font-family: var(--font-subtitle-family);
  font-weight: var(--font-subtitle-weight);
  font-style: var(--font-subtitle-style);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgb(var(--color-foreground-secondary));
}

.titles {
  max-width: 86rem;
}
.titles--center {
  text-align: center;
  max-width: 86rem;
  margin-left: auto;
  margin-right: auto;
}
.titles--center .title--word_break_an.js-anim-rolling .js-anim-title,
.titles--center .title--word_break_an.js-anim-appearing .js-anim-title {
  display: flex;
  margin-left: auto;
  margin-right: auto;
}
.titles--center .title--word_break_an.js-anim-rolling .js-anim-title span,
.titles--center .title--word_break_an.js-anim-appearing .js-anim-title span {
  justify-content: center;
}
.titles--right {
  margin-left: auto;
}
.titles--right .title--word_break_an.js-anim-rolling .js-anim-title,
.titles--right .title--word_break_an.js-anim-appearing .js-anim-title {
  display: flex;
  margin-left: auto;
}
.titles--right .title--word_break_an.js-anim-rolling .js-anim-title span,
.titles--right .title--word_break_an.js-anim-appearing .js-anim-title span {
  justify-content: right;
}
.titles .title a {
  text-decoration: none;
  transition: color var(--duration-default);
}
.titles .title a:hover {
  color: rgb(var(--color-accent));
}
.titles .title--simple span[style*="text-decoration:underline"] {
  display: inline-block;
  text-decoration-color: var(--color-line) !important;
  text-underline-offset: 6%;
}
.titles .title--rounded span[style*="text-decoration:underline"] {
  display: inline-block;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: bottom;
  text-decoration: none !important;
  padding-bottom: 0.5rem;
}
@media screen and (min-width: 576px) {
  .titles .title--rounded span[style*="text-decoration:underline"] {
    padding-bottom: 0.7rem;
  }
}
.titles .title--rounded span[style*="text-decoration:underline"].title--rounded-xs {
  padding-bottom: 0.5rem;
}
.titles .title--background {
  position: relative;
  z-index: 1;
}
.titles .title--background span[style*="text-decoration:underline"] {
  position: relative;
  display: inline-block;
  text-decoration: none !important;
  padding: 0 0.8rem;
  background-color: var(--color-line);
  border-radius: 0.6rem;
  z-index: -1;
}
.titles .title--word_break span[style*="text-decoration:underline"] {
  display: inline;
}
.titles .title--word_break_an .js-anim-title {
  display: block;
}
.titles + .content {
  margin-top: 2.4rem;
}
@media screen and (min-width: 750px) {
  .titles + .content {
    margin-top: 3.2rem;
  }
}
@media screen and (min-width: 1200px) {
  .titles + .content {
    margin-top: 5.6rem;
  }
}
@media screen and (min-width: 1200px) {
  .titles.titles_margin-medium + .content {
    margin-top: 4rem;
  }
}
.titles + .description {
  margin-top: 0.8rem;
}
@media screen and (min-width: 750px) {
  .titles + .description {
    margin-top: 1.6rem;
  }
}
.titles + .description--center {
  text-align: center;
  max-width: 86rem;
  margin-left: auto;
  margin-right: auto;
}

.subtitle + .title {
  margin-top: 0.8rem;
}
@media screen and (min-width: 750px) {
  .subtitle + .title {
    margin-top: 1.4rem;
  }
}

.title {
  margin: 0;
}

.description {
  margin-top: 0;
  margin-bottom: 2.4rem;
  max-width: 86rem;
  white-space: pre-wrap;
  word-wrap: break-word;
}
.description--center {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 750px) {
  .description {
    margin-bottom: 3.2rem;
  }
}
@media screen and (min-width: 1200px) {
  .description {
    margin-bottom: 5.6rem;
  }
}

/* Title animation */
.js-anim-typewriter,
.js-anim-rolling,
.js-anim-appearing {
  opacity: 0;
}

.js-anim-rolling .js-anim-title {
  display: inline-block;
  position: relative;
  overflow: hidden;
  vertical-align: bottom;
}
.js-anim-rolling .js-anim-title > span {
  width: 100%;
  display: flex;
  position: relative;
  top: 0;
  left: 0;
}
.js-anim-rolling .js-anim-title:not(:only-of-type):first-of-type > span {
  align-items: flex-end;
}

.js-anim-appearing .js-anim-title {
  display: inline-block;
  position: relative;
  overflow: hidden;
  vertical-align: bottom;
}
.js-anim-appearing .js-anim-title > span {
  display: flex;
  opacity: 1;
  width: 100%;
  left: 0;
  top: 0;
}
.js-anim-appearing .js-anim-title:not(:only-of-type):first-of-type > span {
  align-items: flex-end;
}

[data-scheme=dark] .title--simple span[style*="text-decoration:underline"] {
  text-decoration-color: #4A4A4C !important;
}
[data-scheme=dark] .title--background span[style*="text-decoration:underline"] {
  background-color: #4A4A4C;
}

@media (prefers-color-scheme: dark) {
  [data-scheme=auto] .title--simple span[style*="text-decoration:underline"] {
    text-decoration-color: #4A4A4C !important;
  }
  [data-scheme=auto] .title--background span[style*="text-decoration:underline"] {
    background-color: #4A4A4C;
  }
}
@media screen and (min-width: 750px) and (max-width: 989px) {
  .slider--tablet.grid--peek .grid__item {
    width: calc(25% - 3rem);
  }
  .slider--tablet.grid--peek.grid--3-col-tablet .grid__item {
    width: calc(33.33% - 2.6666666667rem);
  }
  .slider--tablet.grid--peek.grid--2-col-tablet .grid__item {
    width: calc(50% - 2rem);
  }
  .slider--tablet.grid--peek .grid__item:first-of-type {
    padding-left: 1.5rem;
  }
  .slider--tablet.grid--peek .grid__item:last-of-type {
    padding-right: 1.5rem;
  }
}
@media screen and (max-width: 989px) {
  .slider--tablet.grid--peek {
    margin: 0;
    width: 100%;
  }
  .slider--tablet.grid--peek .grid__item {
    box-sizing: content-box;
    margin: 0;
  }
}
@keyframes progress {
  0% {
    stroke-dashoffset: 75;
    opacity: 1;
  }
  100% {
    stroke-dashoffset: 0;
    opacity: 1;
  }
}
.swiper-pagination .swiper-bullet {
  width: 3rem;
  height: 3rem;
  position: relative;
  cursor: pointer;
}
.swiper-pagination .swiper-bullet:hover::after {
  width: 1rem;
  height: 1rem;
  background-color: rgba(var(--color-button), var(--alpha-button-background));
}
.swiper-pagination .swiper-bullet::before, .swiper-pagination .swiper-bullet:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.swiper-pagination .swiper-bullet::after {
  width: 0.6rem;
  height: 0.6rem;
  background-color: rgb(var(--color-border));
  border-radius: 50%;
  transition: var(--duration-default);
}
.swiper-pagination .swiper-bullet svg {
  position: relative;
  z-index: 4;
}
.swiper-pagination .swiper-bullet--svg-animation svg {
  transform: rotate(-90deg);
}
.swiper-pagination .swiper-bullet--svg-animation .svg__circle-inner {
  stroke: red;
  fill: transparent;
  transition: all 0.7s ease;
}
.swiper-pagination .swiper-bullet-active .svg__circle {
  stroke: rgba(var(--color-button), var(--alpha-button-background));
  stroke-dasharray: 75;
  stroke-dashoffset: 0;
  animation-name: progress;
  animation-fill-mode: backwards;
  animation-timing-function: linear;
}
.swiper-pagination .swiper-bullet-active::after {
  width: 1rem;
  height: 1rem;
  background-color: rgba(var(--color-button), var(--alpha-button-background));
}
.swiper-pagination .swiper-bullet-active::before {
  width: 2.8rem;
  height: 2.8rem;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg width='28' height='28' viewBox='0 0 30 30' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle opacity='1' cx='15' cy='15' r='14' stroke='%23E0E3EE' stroke-width='2'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
}

.swiper-navigation {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.8rem;
  margin-top: 2.4rem;
}
@media screen and (min-width: 1200px) {
  .swiper-navigation {
    position: absolute;
    right: 0;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    z-index: 3;
    justify-content: space-between;
    width: 100%;
    margin-top: 0;
  }
  .swiper-navigation .swiper-button-next {
    transform: translateX(50%);
  }
  .swiper-navigation .swiper-button-prev {
    transform: translateX(-50%);
  }
}

.swiper-button-next,
.swiper-button-prev,
.swiper-pagination {
  position: static;
  margin: 0;
  padding: 0;
  background-color: transparent;
  border: none;
}

.swiper-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.1rem;
}

.swiper-button-next,
.swiper-button-prev {
  position: static;
  flex: none;
  width: 4.4rem;
  height: 4.4rem;
  background-color: rgb(var(--color-background));
  border-radius: 100%;
  transition: var(--duration-default);
  box-shadow: 0px 8px 30px 0px rgba(var(--color-foreground), 0.08);
}
@media screen and (min-width: 576px) {
  .swiper-button-next,
  .swiper-button-prev {
    width: 4.6rem;
    height: 4.6rem;
  }
}
@media screen and (min-width: 990px) {
  .swiper-button-next,
  .swiper-button-prev {
    width: 5.6rem;
    height: 5.6rem;
  }
}
.swiper-button-next.swiper-button-disabled,
.swiper-button-prev.swiper-button-disabled {
  opacity: 0;
  pointer-events: none;
  box-shadow: none;
}
.swiper-button-next::after,
.swiper-button-prev::after {
  display: none;
}
.swiper-button-next svg,
.swiper-button-prev svg {
  width: 2rem;
  height: 2rem;
  color: rgb(var(--color-foreground));
  transition: transform var(--duration-default);
}
@media screen and (min-width: 990px) {
  .swiper-button-next svg,
  .swiper-button-prev svg {
    width: 2.4rem;
    height: 2.4rem;
  }
}

@media screen and (min-width: 1200px) {
  .swiper-button-prev:hover .icon {
    transform: translateX(-0.3rem);
  }
}

@media screen and (min-width: 1200px) {
  .swiper-button-next:hover .icon {
    transform: translateX(0.3rem);
  }
}

.swiper-horizontal > .swiper-pagination-bullets {
  margin-top: 1.6rem;
}
@media screen and (min-width: 1200px) {
  .swiper-horizontal > .swiper-pagination-bullets {
    margin-top: 3.2rem;
  }
}

.swiper-pagination-bullet {
  flex: none;
  width: 0.8rem;
  height: 0.8rem;
  background-color: rgb(var(--color-foreground));
  opacity: 0.3;
  transition: opacity var(--duration-default), margin var(--duration-default);
}
.swiper-pagination-bullet:not(.swiper-pagination-bullet-active):hover {
  opacity: 0.4;
}

.swiper-pagination-bullet-active {
  width: 1.2rem;
  height: 1.2rem;
  background-color: rgb(var(--color-foreground));
  opacity: 1;
}

.swiper-buttons {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 2.4rem;
  padding-inline: 1rem;
  min-width: 15rem;
  height: 6rem;
  font-size: 1.3rem;
  font-family: var(--font-button-family);
  font-weight: var(--font-button-weight);
  font-style: var(--font-button-style);
  text-transform: var(--font-button-text-transform);
  letter-spacing: var(--font-button-letter-spacing);
  line-height: 1;
  color: rgb(var(--color-button-text));
  text-decoration: none;
  background-color: rgba(var(--color-button));
  border-radius: 6rem;
  border: 0;
  z-index: 1;
}
.swiper-buttons .swiper-pagination {
  color: rgb(var(--color-button-text));
}
.swiper-buttons.swiper-buttons--secondary {
  background-color: rgb(var(--color-background));
}
.swiper-buttons.swiper-buttons--secondary .swiper-pagination,
.swiper-buttons.swiper-buttons--secondary .icon {
  color: rgb(var(--color-foreground-title));
}

.button-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 6.4rem;
}
.button-wrapper .button svg {
  width: 2rem;
  height: 2rem;
}

@media (prefers-color-scheme: light) {
  .swiper-button-next,
  .swiper-button-prev {
    background-color: rgb(var(--color-background));
  }
  .swiper-button-next svg,
  .swiper-button-prev svg {
    color: rgb(var(--color-foreground));
  }
}
@media (prefers-color-scheme: dark) {
  .swiper-button-next,
  .swiper-button-prev {
    background-color: #fff;
  }
  .swiper-button-next svg,
  .swiper-button-prev svg {
    color: #000;
  }
}
[data-scheme=light] .swiper-button-next,
[data-scheme=light] .swiper-button-prev {
  background-color: rgb(var(--color-background));
}
[data-scheme=light] .swiper-button-next svg,
[data-scheme=light] .swiper-button-prev svg {
  color: rgb(var(--color-foreground));
}

[data-scheme=dark] .swiper-button-next,
[data-scheme=dark] .swiper-button-prev {
  background-color: #fff;
}
[data-scheme=dark] .swiper-button-next svg,
[data-scheme=dark] .swiper-button-prev svg {
  color: #000;
}

/* Media */
.media {
  width: 100%;
  height: 100%;
  display: block;
  background-color: rgba(var(--color-foreground), 0.3);
  position: relative;
  overflow: hidden;
}

.media--transparent {
  background-color: transparent;
}

.media > *:not(.zoom, .deferred-media__poster-button, .card__link),
.media model-viewer,
.card-wrapper__link--overlay:empty {
  display: block;
  max-width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
}

.media > img {
  object-fit: cover;
  object-position: center center;
  transition: opacity var(--duration-long), transform var(--duration-long);
}

.media--square {
  padding-bottom: 100%;
}

.media--portrait {
  padding-bottom: 114.2%;
}

.media--landscape {
  padding-bottom: 66.6%;
}

.media--cropped {
  padding-bottom: 56%;
}

.media--16-9 {
  padding-bottom: 56.25%;
}

.media--circle {
  padding-bottom: 100%;
  border-radius: 12px;
}

.media.media--hover-effect > img + img {
  opacity: 0;
}

@media screen and (min-width: 990px) {
  .media--cropped {
    padding-bottom: 63%;
  }
}
deferred-media {
  display: block;
}

/* Button */
/* Button - default */
.button,
.customer .button {
  font-family: var(--font-button-family);
  font-weight: var(--font-button-weight);
  font-style: var(--font-button-style);
  text-transform: var(--font-button-text-transform);
  letter-spacing: var(--font-button-letter-spacing);
  position: relative;
  box-sizing: border-box;
  text-decoration: none;
  border: 0;
  border-radius: var(--border-radius-button);
  transition: var(--duration-default);
  font-size: 1.4rem;
  line-height: var(--font-body-line-height);
  vertical-align: middle;
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
  overflow: hidden;
  z-index: 1;
}
@media screen and (min-width: 750px) {
  .button,
  .customer .button {
    font-size: 1.6rem;
  }
}
.button--primary, .button--secondary, .button--tertiary,
.customer .button--primary,
.customer .button--secondary,
.customer .button--tertiary {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-width: 10rem;
  min-height: 4.8rem;
  padding: 0 2.4rem;
  transition: background-color var(--duration-default), color var(--duration-default);
}
.button--primary,
.customer .button--primary {
  background-color: rgba(var(--color-button));
  color: rgb(var(--color-button-text));
}
@media screen and (min-width: 1100px) {
  .button--primary:hover,
  .customer .button--primary:hover {
    background-color: rgb(var(--color-button-hover));
    color: rgb(var(--color-button-text-hover));
  }
  .button--primary:hover .icon-pack,
  .customer .button--primary:hover .icon-pack {
    color: rgb(var(--color-button-text-hover));
  }
}
.button--primary:focus,
.customer .button--primary:focus {
  background-color: rgba(var(--color-button));
}
.button--primary .icon-pack,
.customer .button--primary .icon-pack {
  color: rgb(var(--color-button-text));
}
.button--secondary,
.customer .button--secondary {
  background-color: rgba(var(--color-button-secondary));
  color: rgb(var(--color-button-secondary-text));
}
@media screen and (min-width: 1100px) {
  .button--secondary:hover,
  .customer .button--secondary:hover {
    color: rgb(var(--color-button-secondary-text-hover));
    background-color: rgb(var(--color-button-secondary-hover));
  }
  .button--secondary:hover .icon-pack,
  .customer .button--secondary:hover .icon-pack {
    color: rgb(var(--color-button-secondary-text-hover));
  }
}
.button--secondary:focus,
.customer .button--secondary:focus {
  background-color: rgba(var(--color-button-secondary));
}
.button--secondary .icon-pack,
.customer .button--secondary .icon-pack {
  color: rgb(var(--color-button-secondary-text));
}
.button--tertiary,
.customer .button--tertiary {
  color: rgba(var(--color-button-tertiary-text));
  background-color: rgb(var(--color-button-tertiary));
}
@media screen and (min-width: 1100px) {
  .button--tertiary:hover,
  .customer .button--tertiary:hover {
    color: rgb(var(--color-button-tertiary-text-hover));
    background-color: rgb(var(--color-button-tertiary-hover));
  }
  .button--tertiary:hover .icon-pack,
  .customer .button--tertiary:hover .icon-pack {
    color: rgb(var(--color-button-tertiary-text-hover));
  }
}
.button--tertiary .icon-pack,
.customer .button--tertiary .icon-pack {
  color: rgba(var(--color-button-tertiary-text));
}
.button .icon-button-arrow,
.customer .button .icon-button-arrow {
  width: 2rem;
  height: 2rem;
}
.button--simple-move,
.customer .button--simple-move {
  --alpha-button-background: 0;
  display: inline-flex;
  align-items: center;
  row-gap: 0.2rem;
  padding: 0;
  min-width: auto;
  min-height: auto;
  background: none;
  box-shadow: none;
  text-decoration: none;
  color: rgb(var(--color-button));
  overflow: visible;
}
.button--simple-move .icon-button-arrow,
.customer .button--simple-move .icon-button-arrow {
  color: rgba(var(--color-button));
  transition: transform var(--duration-default);
}
@media screen and (min-width: 1100px) {
  .button--simple-move:hover .icon-button-arrow,
  .customer .button--simple-move:hover .icon-button-arrow {
    transform: translateX(0.4rem);
  }
}
.button--simple-move:focus .icon-button-arrow,
.customer .button--simple-move:focus .icon-button-arrow {
  transform: translateX(0);
}
.button--unstyled,
.customer .button--unstyled {
  cursor: pointer;
  background: none;
  box-shadow: none;
  border: none;
}
.button--play > span,
.customer .button--play > span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.3rem;
  height: 1.6rem;
}
.button--play > span .button-icon,
.customer .button--play > span .button-icon {
  position: absolute;
  transition: opacity var(--duration-default);
}
.button--play > span .icon-hidden,
.customer .button--play > span .icon-hidden {
  opacity: 0;
}
.button--play.active .button-icon:not(.icon-hidden),
.customer .button--play.active .button-icon:not(.icon-hidden) {
  opacity: 0;
}
.button--play.active .icon-hidden,
.customer .button--play.active .icon-hidden {
  opacity: 1;
}
.button--sound > span,
.customer .button--sound > span {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 2.4rem;
  height: 2.4rem;
}
.button--sound .button-icon,
.customer .button--sound .button-icon {
  position: absolute;
  transition: opacity var(--duration-default);
}
.button--sound .icon-hidden,
.customer .button--sound .icon-hidden {
  opacity: 0;
}
.button--sound.active .button-icon:not(.icon-hidden),
.customer .button--sound.active .button-icon:not(.icon-hidden) {
  opacity: 0;
}
.button--sound.active .icon-hidden,
.customer .button--sound.active .icon-hidden {
  opacity: 1;
}
.button--simple, .button--simple_secondary, .button--simple_link,
.customer .button--simple,
.customer .button--simple_secondary,
.customer .button--simple_link {
  display: block;
  align-items: center;
  padding: 0;
  min-width: auto;
  min-height: auto;
  background: none;
  box-shadow: none;
  color: rgba(var(--color-button));
  overflow: visible;
}
@media screen and (min-width: 1100px) {
  .button--simple:hover, .button--simple_secondary:hover, .button--simple_link:hover,
  .customer .button--simple:hover,
  .customer .button--simple_secondary:hover,
  .customer .button--simple_link:hover {
    color: rgba(var(--color-button-hover));
  }
}
.button--simple_secondary,
.customer .button--simple_secondary {
  color: rgba(var(--color-button-secondary));
}
@media screen and (min-width: 1100px) {
  .button--simple_secondary:hover,
  .customer .button--simple_secondary:hover {
    color: rgba(var(--color-button-secondary-hover));
  }
}
.button--simple_link,
.customer .button--simple_link {
  color: rgba(var(--color-foreground));
}
.button--arrow,
.customer .button--arrow {
  position: relative;
  display: inline-flex;
  align-items: center;
  overflow: hidden;
}
.button--arrow .icon-button-arrow,
.customer .button--arrow .icon-button-arrow {
  transition-property: transform;
  transition-duration: var(--duration-default);
}
@media screen and (min-width: 1100px) {
  .button--arrow:hover .icon-button-arrow,
  .customer .button--arrow:hover .icon-button-arrow {
    transform: rotate(45deg);
  }
}
.button--full-link,
.customer .button--full-link {
  position: static;
}
.button--full-link:after,
.customer .button--full-link:after {
  content: "";
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
}
.button--primary-size,
.customer .button--primary-size {
  min-height: 5.8rem;
  min-width: 20rem;
  padding: 0 4rem;
}
.button--small,
.customer .button--small {
  padding: 1rem 2.6rem;
  min-height: 4rem;
  min-width: 13rem;
}
.button--full-width,
.customer .button--full-width {
  display: flex;
  width: 100%;
}
.button .spinner,
.customer .button .spinner {
  display: none;
}
.button.loading span,
.customer .button.loading span {
  opacity: 0;
}
.button.loading .spinner,
.customer .button.loading .spinner {
  position: absolute;
  display: inline-block;
}
.button.loading .spinner .path,
.customer .button.loading .spinner .path {
  stroke: currentColor;
}

/* Button - other */
.button:disabled,
.button[aria-disabled=true],
.button.disabled,
.customer button:disabled,
.customer button[aria-disabled=true],
.customer button.disabled {
  cursor: not-allowed;
  opacity: 0.5;
}

@keyframes loading {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
/* Button - social share */
.share-button {
  display: block;
  position: relative;
  margin-top: 1rem;
}

.share-button__button {
  padding: 0;
  box-shadow: none;
  background: none;
  text-transform: none;
  font-weight: 500;
  justify-content: flex-start;
}

.share-button .share-button__button:hover {
  box-shadow: none;
}

.share-button .share-button__button:focus {
  box-shadow: none;
  border: none;
}

.share-button__button .icon-share {
  margin-right: 1rem;
}

.share-button__fallback {
  border: 0.1rem solid rgba(var(--color-foreground), 0.1);
  background: rgb(var(--color-background));
  padding: 2rem;
  position: absolute;
  top: 4rem;
  left: -0.1rem;
  z-index: 3;
  width: 100%;
  display: flex;
  flex-direction: column;
}

.share-button__fallback .button {
  margin-top: 1rem;
}

.share-button__fallback .icon-clipboard {
  height: 1.4rem;
  width: 1.8rem;
}

.share-button__message:not(:empty) {
  font-size: 1.2rem;
  text-align: right;
  display: block;
  margin-top: 0.5rem;
}

/* Button - social share new */
.share-buttons {
  position: relative;
}

.share-buttons__label-name {
  color: rgb(var(--color-foreground-secondary));
}

.share-buttons__label .icon-share {
  width: 1.2rem;
  margin-right: 1rem;
}

.share-buttons__label .icon-share path {
  fill: rgba(var(--color-foreground));
}

.share-buttons__list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1.2rem;
  width: 100%;
}

.share-buttons__item a {
  color: rgb(var(--color-foreground));
  transition: var(--duration-default);
}

.share-buttons__item .icon {
  width: 2.4rem;
  height: 2.4rem;
}

.share-buttons__button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.4rem;
  height: 2.4rem;
  text-decoration: none;
  transition: opacity var(--duration-default);
}
.share-buttons__button:hover .icon {
  opacity: 0.7;
}

.share-button__name {
  font-size: 1.4rem;
}

.share-button__icon {
  display: flex;
  align-items: center;
  gap: 0.2rem;
  color: rgb(var(--color-foreground));
  padding: 0.8rem;
  background-color: rgb(var(--color-scondary-element-background));
  border-radius: 100%;
  transition: var(--duration-default);
}

.share-buttons__button:hover .share-button__icon {
  background-color: rgb(var(--color-foreground));
}

.share-buttons-simple {
  display: flex;
  margin: 0;
  padding: 0;
  list-style: none;
}

.share-buttons-simple__button {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0.8rem;
  transition: opacity var(--duration-default);
}
.share-buttons-simple__button:hover .icon {
  opacity: 0.6;
}

.share-buttons-simple .icon {
  width: 2.8rem;
  height: 2.8rem;
  transition: opacity var(--duration-default);
}

@keyframes fadeInToUp {
  0% {
    opacity: 0;
    transform: translate3d(0, -4px, 0);
  }
  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
@keyframes fadeInScale {
  0% {
    opacity: 0;
    transform: scale(0) translateX(-50%);
  }
  100% {
    opacity: 1;
    transform: scale(1) translateX(-50%);
  }
}
.copy-btn {
  position: relative;
  overflow: visible;
}
.copy-btn .copy-success,
.copy-btn .copy-error {
  position: absolute;
  top: calc(100% + 0.6rem);
  left: 50%;
  min-width: max-content;
  transform: scale(0) translateX(-50%);
  opacity: 0;
  z-index: 2;
  animation-delay: 0.2s;
}
.copy-btn.copied {
  pointer-events: none;
}
.copy-btn.copied .copy-success {
  animation: fadeInScale 0.3s ease;
  transform: scale(1) translateX(-50%);
  opacity: 1;
}
.copy-btn.copied .copy-btn__success {
  display: block;
}
.copy-btn.notCopied {
  pointer-events: none;
}
.copy-btn.notCopied .copy-error {
  animation: fadeInScale 0.3s ease;
  transform: scale(1) translateX(-50%);
  opacity: 1;
}
.copy-btn.notCopied .copy-btn__error {
  display: block;
}

.modal-close-button {
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  width: 4.4rem;
  height: 4.4rem;
  border-radius: 0.6rem;
  border: none;
  box-shadow: 0px 8px 40px 0px rgba(var(--color-shadow), 0.08);
  overflow: hidden;
  color: rgb(var(--color-foreground));
  background-color: rgb(var(--color-background));
  cursor: pointer;
  transition: opacity var(--duration-default);
}
.modal-close-button svg {
  width: 1.8rem;
  height: 1.8rem;
}
.modal-close-button:hover {
  opacity: 0.7;
}

.header__offcanvas-toggle-link .icon-close {
  color: rgb(var(--color-foreground));
}

.infinite-scroll__loading {
  display: flex;
  justify-content: center;
  margin-top: 4rem;
  color: rgba(var(--color-button-tertiary-text));
}
.infinite-scroll__loading .spinner {
  display: none;
  width: 2rem;
  height: 2rem;
}
.infinite-scroll__loading.loading .spinner {
  display: block;
}

.scroll-top {
  cursor: pointer;
  position: fixed;
  bottom: 0.8rem;
  right: 0.8rem;
  width: 3.2rem;
  height: 3.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgb(var(--color-button));
  color: rgb(var(--color-button-text));
  border: none;
  border-radius: var(--border-radius-button);
  opacity: 0;
  z-index: 999;
  transition: background-color var(--duration-default);
}
.scroll-top svg {
  flex: none;
  width: 2rem;
  height: 2rem;
}
.scroll-top.show {
  opacity: 1;
}
.scroll-top:hover {
  background-color: rgb(var(--color-button-hover));
}

@media (prefers-color-scheme: dark) {
  [data-scheme=auto] .button--simple,
  [data-scheme=auto] .button--simple_link,
  [data-scheme=auto] .button--simple_secondary {
    color: rgb(var(--color-foreground));
  }
  [data-scheme=auto] .button--simple:hover,
  [data-scheme=auto] .button--simple_link:hover,
  [data-scheme=auto] .button--simple_secondary:hover {
    color: #e3e4e5;
  }
}
[data-scheme=dark] .button--simple,
[data-scheme=dark] .button--simple_link,
[data-scheme=dark] .button--simple_secondary {
  color: rgb(var(--color-foreground));
}
[data-scheme=dark] .button--simple:hover,
[data-scheme=dark] .button--simple_link:hover,
[data-scheme=dark] .button--simple_secondary:hover {
  color: #e3e4e5;
}

/* Form */
.field {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.field label {
  position: relative;
  transition: var(--duration-short);
  order: -1;
}
.field input[type=text],
.field input[type=email],
.field input[type=tel],
.field input[type=search],
.field input[type=password],
.field select,
.field .field__input {
  width: 100%;
  min-height: 4.8rem;
  font-family: var(--font-body-family);
  font-style: var(--font-body-style);
  font-size: 1.6rem;
  -webkit-appearance: none;
  appearance: none;
  color: rgb(var(--color-foreground));
  background-color: rgb(var(--color-background-input));
  border: 0.1rem solid rgb(var(--color-border-input));
  border-radius: var(--border-radius-button);
  box-sizing: border-box;
  transition: border var(--duration-default), background-color var(--duration-default);
  overflow: hidden;
}
.field input[type=text]::placeholder,
.field input[type=email]::placeholder,
.field input[type=tel]::placeholder,
.field input[type=search]::placeholder,
.field input[type=password]::placeholder,
.field select::placeholder,
.field .field__input::placeholder {
  transition: color var(--duration-default);
  letter-spacing: -0.03em;
  color: rgba(var(--color-foreground), 0.4);
}
.field input[type=text]:hover:not(:focus)::placeholder,
.field input[type=email]:hover:not(:focus)::placeholder,
.field input[type=tel]:hover:not(:focus)::placeholder,
.field input[type=search]:hover:not(:focus)::placeholder,
.field input[type=password]:hover:not(:focus)::placeholder,
.field select:hover:not(:focus)::placeholder,
.field .field__input:hover:not(:focus)::placeholder {
  color: rgba(var(--color-foreground), 0.3);
}
.field input[type=text]:focus-visible, .field input[type=text]:focus,
.field input[type=email]:focus-visible,
.field input[type=email]:focus,
.field input[type=tel]:focus-visible,
.field input[type=tel]:focus,
.field input[type=search]:focus-visible,
.field input[type=search]:focus,
.field input[type=password]:focus-visible,
.field input[type=password]:focus,
.field select:focus-visible,
.field select:focus,
.field .field__input:focus-visible,
.field .field__input:focus {
  outline: none;
}
.field textarea.field__input,
.field .textarea {
  border-radius: 0.6rem;
}
.field input[type=search]::-webkit-search-cancel-button {
  display: none;
}
.field input[type=search]::placeholder {
  color: rgba(var(--color-foreground), 0.4);
}
.field input[type=text],
.field input[type=email],
.field input[type=tel],
.field input[type=password],
.field .field__input {
  flex-grow: 1;
  padding: 1.2rem 2.4rem;
  text-align: left;
}
.field input[type=text]::-webkit-search-cancel-button,
.field input[type=email]::-webkit-search-cancel-button,
.field input[type=tel]::-webkit-search-cancel-button,
.field input[type=password]::-webkit-search-cancel-button,
.field .field__input::-webkit-search-cancel-button {
  display: none;
}
.field input[type=text]::placeholder,
.field input[type=email]::placeholder,
.field input[type=tel]::placeholder,
.field input[type=password]::placeholder,
.field .field__input::placeholder {
  font-size: 1.6rem;
}
.field input[type=text]:focus::placeholder,
.field input[type=email]:focus::placeholder,
.field input[type=tel]:focus::placeholder,
.field input[type=password]:focus::placeholder,
.field .field__input:focus::placeholder {
  opacity: 0;
}
.field input[type=text][required] + label::after,
.field input[type=email][required] + label::after,
.field input[type=tel][required] + label::after,
.field input[type=password][required] + label::after,
.field .field__input[required] + label::after {
  content: "*";
  position: relative;
  top: 0;
  left: 0.5rem;
  color: rgb(var(--color-error));
}
.field input[type=text] + label,
.field input[type=email] + label,
.field input[type=tel] + label,
.field input[type=password] + label,
.field .field__input + label {
  text-transform: none;
  color: rgb(var(--color-foreground));
  padding-bottom: 1rem;
}
.field textarea.field__input {
  padding: 1.8rem 2rem;
}
.field .select {
  width: 100%;
}
.field .select .placeholder-select {
  font-size: 1.6rem;
  font-weight: 500;
  text-transform: none;
  color: rgba(var(--color-foreground-secondary));
  position: absolute;
  top: 50%;
  left: 1.8rem;
  transform: translateY(-50%);
  pointer-events: none;
}
.field .select .placeholder-select span {
  color: rgb(var(--color-error));
}
.field select {
  cursor: pointer;
  padding: 0.8rem 3.6rem 0.8rem 1.6rem;
  min-height: 4.8rem;
  line-height: 1.4;
  background-color: rgb(var(--color-background-input));
  letter-spacing: calc(var(--font-body-letter-spacing) * 0.1);
  transition: color var(--duration-default);
}
.field select:focus {
  border-color: rgb(var(--color-border-input));
}
.field select:hover, .field select:focus-visible {
  color: rgb(var(--color-foreground), 0.7);
}
.field select + svg {
  width: 2rem;
  height: 2rem;
  pointer-events: none;
  position: absolute;
  top: calc(50% - 1rem);
  right: 1.4rem;
  color: rgb(var(--color-foreground));
}
.field select option {
  background-color: rgb(var(--color-background-input));
}
.field select[required] + label::after {
  content: "*";
  position: relative;
  top: 0;
  left: 0.5rem;
  color: rgb(var(--color-error));
}
.field--checkbox input[type=checkbox] {
  position: absolute;
  opacity: 1;
  width: 1.6rem;
  height: 1.6rem;
  top: 0;
  left: 0;
  z-index: -1;
  appearance: none;
}
.field--checkbox input[type=checkbox]:checked + label::before {
  border-color: rgb(var(--color-button));
  background-color: rgb(var(--color-button));
}
.field--checkbox input[type=checkbox]:checked + label .icon-checkmark {
  visibility: visible;
}
.field--checkbox input[type=checkbox] + label {
  display: inline-flex;
  align-items: center;
  gap: 1.6rem;
  font-size: 1.4rem;
  color: rgb(var(--color-foreground));
  position: relative;
  cursor: pointer;
}
.field--checkbox input[type=checkbox] + label::before {
  content: "";
  display: block;
  flex-shrink: 0;
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 0.2rem;
  border: 0.1rem solid rgb(var(--color-border));
  background-color: rgb(var(--color-background));
  transition: border-color var(--duration-default);
}
.field--checkbox input[type=checkbox] + label .icon-checkmark {
  position: absolute;
  left: 0.4rem;
  top: calc(50% - 0.4rem);
  z-index: 5;
  visibility: hidden;
  color: rgb(var(--color-button-text));
}
.field--checkbox input[type=checkbox] + label a {
  text-decoration: none;
  transition: var(--duration-default);
}
.field--checkbox input[type=checkbox] + label a:hover {
  opacity: 0.8;
}
.field--checkbox input[type=checkbox][required] + label span::after {
  content: "*";
  position: relative;
  top: 0;
  left: 0;
  color: rgb(var(--color-error));
}
.field--pass {
  position: relative;
}
.field--pass .button-pass-visibility {
  display: none;
  width: 2.4rem;
  height: 2.4rem;
  position: absolute;
  bottom: 1.2rem;
  right: 2.4rem;
  cursor: pointer;
}
.field--pass .button-pass-visibility svg {
  color: rgba(var(--color-foreground), 0.5);
}
.field--pass .button-pass-visibility svg.icon-eye {
  display: none;
}
.field--dark input[type=text],
.field--dark input[type=email],
.field--dark input[type=tel],
.field--dark input[type=password],
.field--dark input[type=search] {
  border-color: rgba(255, 255, 255, 0.4);
  color: rgb(255, 255, 255);
  background-color: transparent;
}
.field--dark input[type=text] + label::before,
.field--dark input[type=email] + label::before,
.field--dark input[type=tel] + label::before,
.field--dark input[type=password] + label::before,
.field--dark input[type=search] + label::before {
  color: rgba(255, 255, 255, 0.5);
}

/* Text area */
.text-area {
  font-family: var(--font-body-family);
  font-style: var(--font-body-style);
  font-weight: var(--font-body-weight);
  padding: 1.2rem;
  min-height: 10rem;
  resize: none;
}

.text-area--resize-vertical {
  resize: vertical;
}

/* Form global */
.form--shadow input[type=text],
.form--shadow input[type=email],
.form--shadow input[type=tel],
.form--shadow input[type=search],
.form--shadow input[type=password],
.form--shadow select,
.form--shadow .field__input {
  border: none;
  box-shadow: 0px 8px 40px 0px rgba(1, 22, 36, 0.08);
}

.form__label {
  display: block;
}

.form__message {
  align-items: center;
  display: flex;
  font-size: 1.4rem;
  line-height: 1;
  margin-top: 1rem;
}

.form__message--large {
  font-size: 1.4rem;
}

.form__message .icon {
  flex-shrink: 0;
  height: 1.3rem;
  margin-right: 0.5rem;
  width: 1.3rem;
}

.form__message--large .icon {
  height: 1.5rem;
  width: 1.5rem;
  margin-right: 1rem;
}

.form-status {
  margin: 0;
  font-size: 1.4rem;
}

.form-status-list {
  padding: 0;
  margin: 2rem 0 4rem;
}

.form-status-list li {
  list-style-position: inside;
}

.form-status-list .link::first-letter {
  text-transform: capitalize;
}

/* Quantity */
.quantity {
  position: relative;
  width: 12.4rem;
  min-height: 4.8rem;
  display: flex;
  border: 0.1rem solid rgb(var(--color-border-input));
  background-color: rgb(var(--color-background-input));
  border-radius: var(--border-radius-button);
}

.quantity__input {
  font-family: var(--font-body-family);
  font-size: inherit;
  color: rgb(var(--color-foreground));
  text-align: center;
  background-color: transparent;
  border: 0;
  width: 100%;
  flex-grow: 1;
  -webkit-appearance: none;
  appearance: none;
}

.quantity__button {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 0;
  width: 4rem;
  background-color: transparent;
  color: rgb(var(--color-foreground));
  border: 0;
  transition: opacity var(--duration-default);
  cursor: pointer;
}
@media screen and (min-width: 576px) {
  .quantity__button {
    width: 4.8rem;
  }
}
.quantity__button:hover {
  opacity: 0.7;
}
.quantity__button.disabled {
  pointer-events: none;
  opacity: 0.2;
}
.quantity__button svg {
  width: 2rem;
  pointer-events: none;
}

.quantity__input:-webkit-autofill,
.quantity__input:-webkit-autofill:hover,
.quantity__input:-webkit-autofill:active {
  box-shadow: 0 0 0 10rem rgb(var(--color-background)) inset !important;
  -webkit-box-shadow: 0 0 0 10rem rgb(var(--color-background)) inset !important;
}

.quantity__input::-webkit-outer-spin-button,
.quantity__input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.quantity__input[type=number] {
  -moz-appearance: textfield;
}

/* Negate the fallback side-effect for browsers that support :focus-visible */
*:focus:not(:focus-visible) {
  outline: 0;
}

/*
  Focus ring - inset
*/
.focus-inset:focus-visible {
  outline: 0.1rem solid rgba(var(--color-foreground), 0.5);
  outline-offset: 0.2rem;
  box-shadow: 0 0 0.2rem 0 rgba(var(--color-foreground), 0.3);
}

/* Fallback */
.focus-inset:focus {
  outline: 0.1rem solid rgba(var(--color-foreground), 0.5);
  outline-offset: 0.2rem;
}

.focus-inset:focus:not(:focus-visible) {
  outline: 0;
}

/*
  Focus ring - none
*/
/* Dangerous for a11y - Use with care */
.focus-none {
  box-shadow: none !important;
  outline: 0 !important;
}

/* Modal */
.modal__toggle {
  list-style-type: none;
}

.no-js details[open] .modal__toggle {
  z-index: 2;
}

.modal__toggle-close {
  display: none;
}

.no-js details[open] svg.modal__toggle-close {
  display: flex;
  z-index: 1;
  height: 1.4rem;
  width: 1.4rem;
}

.modal__toggle-open {
  display: flex;
}

.no-js details[open] .modal__toggle-open {
  display: none;
}

.no-js .modal__close-button.link {
  display: none;
}

.modal__close-button.link {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0rem;
  background-color: transparent;
}

.modal__close-button .icon {
  width: 1.4rem;
  height: 1.4rem;
}

.modal__content {
  position: absolute;
  inset: 0;
  background: rgb(var(--color-background));
  z-index: 1;
  display: flex;
  justify-content: center;
  align-items: center;
}

.fancybox-skin {
  padding: 0 !important;
}

/* Announcement-bar */
.section-announcement {
  height: var(--announcement-height);
  transition: transform var(--duration-default);
  z-index: 4;
}
.section-announcement.section-announcement-overlay {
  z-index: 12;
}

.body--hidden .section-announcement {
  transform: translateY(-100%);
}

.announcement-bar {
  display: flex;
  justify-content: center;
  overflow: hidden;
  height: var(--announcement-height);
  font-size: 1.2rem;
}
@media screen and (min-width: 1200px) {
  .announcement-bar {
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 1536px) {
  .announcement-bar {
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 764px) {
  .announcement-bar.swiper:not(.swiper-initialized) .announcement-bar__wrapper--2-mobile {
    display: grid;
    grid-template-rows: 1fr 1fr;
  }
}
@media screen and (min-width: 765px) {
  .announcement-bar.swiper:not(.swiper-initialized) .announcement-bar__wrapper--2 {
    display: grid;
    grid-template-rows: 1fr 1fr;
  }
}
.announcement-bar:not(.swiper) .announcement-bar__message {
  height: 100%;
}
.announcement-bar__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
}
.announcement-bar__icon .icon {
  font-size: 1.6rem;
}
@media screen and (min-width: 576px) {
  .announcement-bar__icon .icon {
    font-size: 2rem;
  }
}
.announcement-bar__icon--subtle {
  color: rgba(var(--color-foreground), 0.14);
}
.announcement-bar__icon--contrast {
  color: rgba(var(--color-foreground));
}
.announcement-bar__icon--colored {
  color: rgba(var(--color-accent));
}
.announcement-bar__icon--colored.announcement-bar__icon--gradient {
  color: var(--gradient-accent);
}
.announcement-bar__wrapper {
  width: 100%;
}
.announcement-bar__message {
  color: rgb(var(--color-foreground));
  min-height: 4rem;
  width: 100%;
  box-sizing: border-box;
  overflow-y: auto;
}
.announcement-bar__message::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
.announcement-bar__message::-webkit-scrollbar-thumb {
  background-color: rgba(var(--color-border));
  border-radius: 100px;
}
.announcement-bar__message-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  text-align: center;
  padding: 0 2rem;
  height: 100%;
}
.announcement-bar__text {
  font-weight: var(--font-heading-weight);
  line-height: 145%;
  word-break: break-word;
}
.announcement-bar__text p {
  margin: 0;
}
.announcement-bar__text a {
  position: relative;
  color: inherit;
  text-underline-offset: 0.2rem;
  text-decoration-color: inherit;
  z-index: 2;
  transition: opacity var(--duration-default);
}
.announcement-bar__text a:hover {
  opacity: 0.7;
}

body.body--hidden {
  overflow-y: hidden;
}

.shopify-section-header {
  position: relative;
  z-index: 12;
  will-change: transform;
  transition: background var(--duration-default) linear;
}
.shopify-section-header.overlay::before {
  content: "";
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100vw;
  height: 120vh;
  background-color: rgb(var(--color-overlay), 0.01);
  backdrop-filter: blur(0.6rem);
  z-index: 1;
}
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) {
  --color-background: 255, 255, 255;
  --color-foreground: 255, 255, 255;
  --color-background-secondary: 255, 255, 255, 0.2;
  --color-background-input: 255, 255, 255, 0.2;
  --color-border-input: 255, 255, 255, 0.2;
  --color-border: 255, 255, 255, 0.12;
}
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header--border {
  background-color: transparent;
}
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header-wrapper.container .header,
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header-wrapper:not(.container) {
  background-color: transparent;
}
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header-wrapper.container .header::before,
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header-wrapper:not(.container)::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(var(--color-background), 0.12);
  backdrop-filter: blur(15px);
  border-radius: inherit;
}
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__heading,
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__inline-menu,
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__column {
  z-index: 1;
}
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .cart-count-bubble {
  background-color: rgb(var(--color-background));
}
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .cart-count-bubble span {
  color: #000;
}
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__heading-logo {
  display: none;
}
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__heading-logo:only-child {
  display: block;
  z-index: 1;
}
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__heading-logo--overlay {
  display: block;
  z-index: 1;
}
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .menu-drawer-container.menu-opening .header__heading-logo {
  display: block;
}
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .menu-drawer-container.menu-opening .header__heading-logo--overlay {
  display: none;
}
.shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .menu-drawer-container.menu-opening .header__heading-logo--overlay:only-child {
  display: block;
}
@media (prefers-color-scheme: dark) {
  .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .menu-drawer-container.menu-opening .header__heading-logo:not(.header__heading-logo--overlay) {
    display: none;
  }
  .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .menu-drawer-container.menu-opening .header__heading-logo.header__heading-logo--overlay {
    display: block;
  }
  .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .menu-drawer-container.menu-opening .header__heading-logo:only-child {
    display: block !important;
  }
}
[data-scheme=dark] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .menu-drawer-container.menu-opening .header__heading-logo:not(.header__heading-logo--overlay) {
  display: none;
}
[data-scheme=dark] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .menu-drawer-container.menu-opening .header__heading-logo.header__heading-logo--overlay {
  display: block;
}
[data-scheme=dark] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .menu-drawer-container.menu-opening .header__heading-logo:only-child {
  display: block !important;
}
.shopify-section-header.color-background-1 {
  background-color: rgb(var(--color-background));
}
.shopify-section-header.color-background-3 {
  background-color: transparent;
}
.shopify-section-header.color-background-3 .header--border::before {
  background-color: rgba(249, 249, 249, 0.12);
}
.shopify-section-header.color-background-3 .header__account summary::before {
  background-color: rgba(249, 249, 249, 0.12);
}
.shopify-section-header.color-background-3 .menu-drawer-container.menu-opening .header__modal-close-button {
  border-color: rgba(249, 249, 249, 0.12);
}
.shopify-section-header.color-background-3 .header__heading-logo {
  display: none;
}
.shopify-section-header.color-background-3 .header__heading-logo:only-child {
  display: block;
}
.shopify-section-header.color-background-3 .header__heading-logo--overlay {
  display: block;
}
.shopify-section-header:not(.animate):not(.shopify-section-header-sticky) .header-wrapper.container {
  transition: all var(--duration-default);
  border-radius: 0.6rem;
}
@media screen and (min-width: 1200px) {
  .shopify-section-header:not(.animate):not(.shopify-section-header-sticky) .header-wrapper.container {
    border-radius: 1.2rem;
  }
}

.shopify-section-header-sticky {
  position: sticky;
  top: 0;
  z-index: 12;
}
.shopify-section-header-sticky .header-wrapper {
  max-width: 100%;
  padding: 0;
}
.shopify-section-header-sticky .header-wrapper.container {
  background-color: rgb(var(--color-background));
  box-shadow: 0px 8px 30px 0px rgba(var(--color-shadow), 0.08);
}
.shopify-section-header-sticky .header-wrapper.container .header {
  position: relative;
  padding-inline: 2rem;
  max-width: 163.2rem;
  border-radius: 0;
  box-shadow: none;
}
@media screen and (min-width: 1200px) {
  .shopify-section-header-sticky .header-wrapper.container .header {
    padding-inline: 6.4rem;
    max-width: 176rem;
  }
}
@media screen and (min-width: 990px) {
  .shopify-section-header-sticky .header-wrapper.container .header .mega-menu--columns-3,
  .shopify-section-header-sticky .header-wrapper.container .header .mega-menu--columns-4 {
    left: 6.4rem;
    right: 6.4rem;
  }
}
@media screen and (min-width: 1360px) {
  .shopify-section-header-sticky .header-wrapper.container .header .mega-menu--columns-3,
  .shopify-section-header-sticky .header-wrapper.container .header .mega-menu--columns-4 {
    right: unset;
  }
}
.shopify-section-header-sticky .header-wrapper.container .header__search-inner {
  right: 2rem;
  left: 2rem;
}
@media screen and (min-width: 750px) {
  .shopify-section-header-sticky .header-wrapper.container .header__search-inner {
    left: auto;
  }
}
@media screen and (min-width: 1200px) {
  .shopify-section-header-sticky .header-wrapper.container .header__search-inner {
    right: 6.4rem;
  }
}
.shopify-section-header-sticky .header-wrapper.container .menu-drawer {
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  box-shadow: none;
  border-radius: 0;
}
.shopify-section-header-sticky .menu-drawer {
  height: calc(100vh - (var(--header-bottom-position, 100%)));
  height: calc(var(--vh, 1vh) * 100 - (var(--header-bottom-position, 100%)));
}

.shopify-section-header-hidden {
  transform: translateY(-100%);
}

.shopify-section-header.animate {
  transition: transform 0.15s ease-out;
}

.header-wrapper {
  display: block;
  position: relative;
  transition: all var(--duration-default);
  z-index: 2;
}
.header-wrapper[data-sticky-type=on-scroll-up] {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
.header-wrapper.container {
  transition: all var(--duration-default);
}
.header-wrapper.container .header {
  margin-top: 1.6rem;
  padding-inline: 2rem;
  background: rgb(var(--color-background));
  border-radius: 0.6rem;
  box-shadow: 0px 8px 30px 0px rgba(var(--color-shadow), 0.08);
  transition: all var(--duration-default), border-radius var(--duration-short);
}
@media screen and (min-width: 1200px) {
  .header-wrapper.container .header {
    padding-inline: 3.2rem;
    margin-top: 3.2rem;
    box-shadow: 0px 8px 40px 0px rgba(var(--color-shadow), 0.08);
    border-radius: 1.2rem;
  }
}
@media screen and (min-width: 1536px) {
  .header-wrapper.container .header {
    padding-inline: 6.4rem;
  }
}
.header-wrapper.container .menu-drawer {
  left: 2rem;
  right: 2rem;
  width: auto;
  box-shadow: 0px 8px 40px 0px rgba(var(--color-shadow), 0.08);
  border-radius: 0.6rem;
}

.container--header {
  margin: 0 auto;
  padding-inline: 2rem;
}
@media screen and (min-width: 1360px) {
  .container--header {
    max-width: 174rem;
  }
}

.header {
  position: relative;
  display: block;
  align-items: center;
  justify-content: space-between;
  padding-block: 0.8rem;
  font-family: var(--font-header-menu-family);
  font-style: var(--font-header-menu-style);
  font-weight: var(--font-header-menu-weight);
  text-transform: var(--font-header-menu-text-transform);
  z-index: 4;
}
@media screen and (min-width: 1200px) {
  .header {
    display: flex;
    padding-block: 1.8rem;
  }
}
.header > .header__heading, .header > .header__heading-link {
  display: flex;
  align-items: center;
  z-index: 1;
}
.header__localization {
  position: relative;
  display: none;
  align-items: center;
}
@media screen and (min-width: 750px) {
  .header__localization {
    display: flex;
  }
}
.header__localization localization-form {
  display: flex;
  align-items: center;
  justify-content: center;
}
.header__localization .disclosure {
  position: static;
}
.header__localization .disclosure__button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  min-width: 4.4rem;
  min-height: 4.4rem;
  padding-inline: 0.4rem;
}
.header__localization .disclosure__button:hover, .header__localization .disclosure__button:focus {
  box-shadow: none;
}
.header__localization .localization-selector.link {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.header__localization .localization-selector.link::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 3.6rem;
  background-color: rgb(var(--color-background-input));
  border: 0.1rem solid rgb(var(--color-border-input));
  border-radius: var(--border-radius-button);
}
.header__localization .localization-selector.link .icon-caret {
  position: static;
  margin: 0;
  flex: none;
  z-index: 1;
}
.header__localization .localization-selector.link .currency-country {
  flex: none;
  z-index: 1;
}
.header__localization .localization-selector + .disclosure__list {
  right: 0;
  top: calc(100% + 1rem);
  bottom: auto;
  margin-top: 0;
  padding: 1.2rem;
  max-width: 25rem;
  border-radius: 1.2rem;
  animation: animateMenuOpen var(--duration-default) ease;
  box-shadow: 0px 8px 40px 0px rgba(var(--color-shadow), 0.08);
  transform: translateY(0rem);
}
.header--border {
  background-color: rgb(var(--color-background));
}
.header--border::before {
  position: absolute;
  content: "";
  bottom: 0;
  display: block;
  height: 0.1rem;
  width: 100%;
  background-color: rgb(var(--color-border));
  transition: background-color var(--duration-short);
  pointer-events: none;
  z-index: 3;
}
.header--border .menu-drawer {
  top: 0;
  bottom: 0;
}
.header--border .header__account-modal,
.header--border .header__search-inner {
  right: 0;
}
@media screen and (min-width: 990px) {
  .header--border .header__account-modal,
  .header--border .header__search-inner {
    right: 2rem;
  }
}
@media screen and (min-width: 1200px) {
  .header--border .header__account-modal,
  .header--border .header__search-inner {
    right: 6.4rem;
  }
}
.header--border .mega-menu--columns-3,
.header--border .mega-menu--columns-4 {
  left: 0;
}
@media screen and (min-width: 990px) {
  .header--border .mega-menu--columns-3,
  .header--border .mega-menu--columns-4 {
    width: calc(100% - 4rem);
    left: 2rem;
  }
}
@media screen and (min-width: 1200px) {
  .header--border .mega-menu--columns-3,
  .header--border .mega-menu--columns-4 {
    left: 6.4rem;
    width: calc(100% - 12.8rem);
  }
}
.header--left-logo {
  display: flex;
  align-items: center;
  gap: 0.8rem;
}
.header--left-logo .header__heading-link {
  margin-right: 1.2rem;
  margin-left: -0.8rem;
}
@media screen and (min-width: 1100px) {
  .header--left-logo .header__heading-link {
    margin-left: 0;
    margin-right: 1.6rem;
  }
}
@media screen and (min-width: 1360px) {
  .header--left-logo .header__heading-link {
    margin-right: 2.4rem;
  }
}
.header--left-logo .header__contact {
  padding: 0;
}
.header--left-logo .header__shop {
  margin-left: 0;
}
.header--left-logo .mega-menu {
  top: auto;
}
.header--center-logo {
  display: grid;
  align-items: center;
  grid-template-columns: 1fr auto 1fr;
  gap: 0.8rem;
}
@media screen and (min-width: 1200px) {
  .header--center-logo {
    display: grid;
    grid-template-columns: 5fr auto 5fr;
    gap: 0.8rem;
    align-items: center;
  }
}
@media screen and (min-width: 1100px) {
  .header--center-logo .list-menu--inline {
    gap: 0 0.2rem;
  }
}
@media screen and (min-width: 1360px) {
  .header--center-logo .list-menu--inline {
    gap: 0 1.2rem;
  }
}
.header--center-logo .header__contact {
  padding: 0;
}
.header--center-logo .header__shop {
  margin-left: 0;
}
.header--center-logo .mega-menu {
  top: auto;
}
@media screen and (max-width: 1100px) {
  .header--center-logo .header__localization {
    display: none;
  }
}
@media screen and (max-width: 1100px) {
  .header--center-logo .header__localization + .header__scheme::before {
    display: none;
  }
}
.header__heading-logo {
  display: block;
  height: auto;
  object-fit: contain;
}
@media screen and (max-width: 576px) {
  .header__heading-logo {
    max-width: 25rem;
  }
}
@media screen and (max-width: 450px) {
  .header__heading-logo {
    max-width: 15rem;
  }
}
@media screen and (max-width: 370px) {
  .header__heading-logo {
    max-width: 10rem;
  }
}
.header__heading {
  display: inline-flex;
  align-items: center;
  margin: 0;
  line-height: 0;
}
.header__heading span {
  line-height: 1;
  text-transform: var(--font-header-menu-text-transform);
}
.header__heading-link {
  display: inline-flex;
  padding: 0;
  text-decoration: none;
  word-break: break-word;
}
.header__heading-link span {
  display: flex;
  align-items: center;
  max-width: 25rem;
  line-height: 1;
  letter-spacing: -0.05em;
  text-transform: var(--font-header-menu-text-transform);
}
.header__heading-logo--overlay {
  display: none;
}
.header *[tabindex="-1"]:focus {
  outline: none;
}

.header__column {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex: none;
  margin-left: auto;
  width: auto;
}

.header__icons {
  display: flex;
  align-items: center;
  grid-area: icons;
  justify-self: end;
}
@media screen and (min-width: 750px) {
  .header__icons .header__scheme,
  .header__icons .header__localization {
    padding-inline: 0.8rem;
  }
}
@media screen and (min-width: 1360px) {
  .header__icons .header__scheme,
  .header__icons .header__localization {
    padding-inline: 1.2rem;
  }
}
@media screen and (min-width: 1100px) {
  .header__icons .header__search {
    padding-inline: 0.8rem;
  }
}
@media screen and (min-width: 1360px) {
  .header__icons .header__search {
    padding-inline: 1.2rem;
  }
}
.header__icons .header__localization::after {
  left: 0;
  right: 0;
  width: auto;
}
.header__icons .header__cart::after {
  right: 1.1rem;
}

.header__icon {
  display: flex;
  align-items: center;
  justify-content: center;
}
.header__icon--summary {
  justify-content: flex-start;
}

.header__icon .icon {
  width: 1.4rem;
  height: 1.4rem;
  transition: var(--duration-default);
  color: rgba(var(--color-foreground));
}
.header__icon .icon-hamburger {
  width: 1.8rem;
  height: 1.8rem;
}

.header__icon--account {
  position: relative;
  transition: opacity var(--duration-default);
}
.header__icon--account:hover {
  opacity: 0.6;
}
.header__icon--account .icon {
  width: 2rem;
  height: 2rem;
}

.header__icon--menu {
  margin-left: -1.2rem;
  justify-content: center;
  width: 4.4rem;
  height: 4.4rem;
}
@media screen and (min-width: 1100px) {
  .header__icon--menu {
    margin: 0;
  }
}
.header__icon--menu span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.6rem;
}
.header__icon--menu .header__modal-close-button {
  opacity: 0;
}

.header__icon::after {
  content: none;
}

.header__icon .icon {
  fill: none;
  vertical-align: middle;
}

.header__icon--search {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  min-width: 4.4rem;
  height: 4.4rem;
  transition: opacity var(--duration-default);
}
.header__icon--search:hover {
  opacity: 0.6;
}
.header__icon--search .icon {
  width: 2rem;
  height: 2rem;
}

.header__icon--search,
.header__icon--cart {
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  min-height: 4.4rem;
}

.header__icon .header__icon-name {
  display: none;
  margin-left: 0.7rem;
}

.header__icon--search .header__icon-name {
  position: relative;
}

.header__account {
  display: none;
  align-items: center;
}

.header__account-modal {
  position: absolute;
  top: calc(100% - 1rem);
  right: 0;
  display: flex;
  flex-direction: column;
  padding: 1.6rem 2.4rem;
  min-width: 19.8rem;
  max-width: 30rem;
  height: auto;
  margin: 0;
  text-transform: none;
  background-color: rgba(var(--color-background));
  box-shadow: 0px 8px 40px 0px rgba(var(--color-shadow), 0.08);
  border-radius: 1.2rem;
  transition: opacity var(--duration-default), transform var(--duration-default);
  z-index: 10;
}

.header__account details[open] .header__account-modal {
  animation: animateMenuOpen var(--duration-default) ease;
}

.header__account-login {
  min-width: max-content;
  width: 100%;
}

.header__account-login .icon {
  flex: none;
  margin-right: 1rem;
  margin-left: 0;
  width: 2rem;
  height: 2rem;
}

.header__account-register {
  align-self: center;
  margin-top: 1.2rem;
  line-height: var(--font-body-line-height);
  font-weight: var(--font-body-weight);
}

.header__account-name {
  position: relative;
  margin-bottom: 1.6rem;
  padding-bottom: 1.6rem;
  font-family: var(--font-heading-family);
  font-style: var(--font-heading-style);
  font-size: inherit;
  letter-spacing: calc(var(--font-heading-letter-spacing) * 0.1);
  color: rgba(var(--color-foreground));
  line-height: var(--font-heading-line-height);
}
.header__account-name::after {
  position: absolute;
  content: "";
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 0.1rem;
  background-color: rgb(var(--color-border));
}

.header__account-address {
  margin-top: 1.6rem;
}

.header__account-body {
  margin: 0;
  padding: 0;
  list-style: none;
}
.header__account-body a {
  display: block;
  text-decoration: none;
  transition: var(--duration-default);
}
.header__account-body a:hover {
  color: rgb(var(--color-foreground));
}
.header__account-body a + a {
  margin-top: 0.8rem;
}

.header__account-logout {
  margin-top: 1.6rem;
  min-width: max-content;
  width: 100%;
}

@keyframes animateSearchOpen {
  0% {
    opacity: 0;
    transform: translateY(-1.5rem);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@media screen and (min-width: 990px) {
  .header__icon .header__icon-name {
    display: flex;
  }
  .header__icons > .header__account {
    padding: 0;
  }
}
@media screen and (min-width: 990px) and (min-width: 990px) {
  .header__account summary {
    position: relative;
    width: 4.4rem;
    height: 4.4rem;
  }
}
@media screen and (min-width: 990px) {
  .header__account {
    display: inline-flex;
  }
}
@media screen and (max-width: 989px) {
  menu-drawer ~ .header__icons .header__icon--account {
    display: none;
  }
}
menu-drawer + .header__search {
  display: none;
}

.shopify-section-header-sticky .header__search-inner {
  max-height: 100vh;
}

.header__details {
  width: 100%;
}
.header__details .search__input {
  font-size: 1.3rem;
  color: rgba(var(--color-foreground-secondary));
}
.header__search {
  display: flex;
  align-items: center;
}
.header__search > details {
  position: static;
}
.header__search > details[open] .header__search-inner {
  animation: animateSearchOpen var(--duration-default) ease;
}
.header__search-heading {
  display: none;
}
@media screen and (min-width: 1200px) {
  .header__search-heading {
    display: flex;
    align-items: center;
  }
}
.header__search-inner {
  position: absolute;
  top: calc(100% + 0.8rem);
  right: 0;
  left: 0;
  padding: 2rem;
  border-radius: 1.2rem;
  box-shadow: 0px 8px 40px 0px rgba(var(--color-shadow), 0.08);
}
@media screen and (min-width: 990px) {
  .header__search-inner {
    top: calc(100% + 1.6rem);
    left: unset;
    width: 53.2rem;
  }
}
@media screen and (min-width: 1200px) {
  .header__search-inner {
    padding: 3.2rem;
  }
}
.header .search {
  z-index: 4;
}
.header .search__content {
  height: 100%;
}
.header .search__form {
  width: 100%;
}
.header .search .field {
  position: relative;
  height: 6rem;
  border-radius: var(--border-radius-button);
}
.header .search__input {
  padding-right: 10.2rem;
  width: 100%;
  height: 100%;
}
.header .search__button {
  position: absolute;
  right: 0.6rem;
  top: 0.6rem;
  bottom: 0.6rem;
  min-width: 4.8rem;
  padding: 0;
}
.header .search__button .icon {
  width: 2.4rem;
  height: 2.4rem;
}
.header .search__modal {
  margin-top: 2.4rem;
  z-index: 2;
}
.header .search__modal--hidden {
  display: none;
}
.header .search__products {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2.4rem 1.6rem;
  margin-top: 1.6rem;
}
.header .search__products-title {
  margin-top: 3.2rem;
  margin-bottom: 0;
}
.header .search__products .card__title {
  margin-bottom: 0.6rem;
  font-size: 1.6rem;
  line-height: 1.4;
  letter-spacing: -0.03em;
}
.header .search__products .card-information {
  padding-top: 1.4rem;
}
.header .search__products .price {
  font-size: 1.4rem;
}
.header .search__products .card-wrapper .button--link {
  padding: 0;
  width: 4.4rem;
  height: 4.4rem;
  min-height: 4.4rem;
}
.header .search__products .card-wrapper .button--link .icon {
  width: 2rem;
  height: 2rem;
}

.header__icon--menu .icon {
  display: block;
  position: absolute;
  opacity: 1;
  transform: scale(1);
  transition: transform 150ms ease, opacity 150ms ease;
}

details:not([open]) > .header__icon--menu .icon-close {
  visibility: hidden;
  opacity: 0;
}

details[open] > .header__icon--menu .icon-hamburger {
  visibility: hidden;
  opacity: 0;
}

.js details[open]:not(.menu-opening) > .header__icon--menu .icon-close {
  visibility: hidden;
}

.js details[open]:not(.menu-opening) > .header__icon--menu .icon-hamburger {
  visibility: visible;
  opacity: 1;
}

.header__inline-menu details:hover > .header__submenu {
  opacity: 1;
  transform: translateY(0rem);
  animation: animateMenuOpen var(--duration-default) ease;
}

.menu-drawer__submenu--hidden {
  display: none;
}

.menu-drawer-container .header__modal-close-button {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: none;
  margin-left: -1.2rem;
  height: 4.4rem;
  width: 4.4rem;
  color: rgb(var(--color-foreground));
  background-color: transparent;
  cursor: pointer;
}
.menu-drawer-container .header__modal-close-button .icon-close {
  width: 1.8rem;
  height: 1.8rem;
  transition: var(--duration-default) ease;
}
.menu-drawer-container .header__modal-close-button:hover .icon-close {
  transform: rotate(90deg);
}
.menu-drawer-container .mega-menu {
  box-shadow: none;
}

.menu-opening .header__modal-close-button {
  opacity: 1;
}
.menu-opening .header__scheme {
  display: flex;
  margin-left: -1.2rem;
}
.menu-opening .header__toggle-scheme {
  display: inline-flex;
  justify-content: flex-start;
  width: max-content;
}
.menu-opening .menu-drawer__localization {
  display: flex;
}
.menu-opening .menu-drawer__localization-wrapper {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 2.4rem;
}
.menu-opening .header__localization--language {
  margin-left: 0;
}

.header__articles {
  width: 38.4rem;
  max-width: 100%;
  grid-row-start: 1;
  grid-row-end: 3;
  grid-column-start: 3;
  grid-column-end: 4;
}
@media screen and (min-width: 1440px) {
  .header__articles {
    width: 41.4rem;
  }
}
@media screen and (max-height: 680px) {
  .header__articles {
    height: 65vh;
  }
}
.header__articles .header__article:not(:first-child) {
  margin-top: -0.1rem;
}
@media screen and (max-height: 680px) {
  .header__articles .article-card-small {
    padding-block: 0.8rem;
  }
}
.header__articles .header__subtitle {
  margin-bottom: 2.4rem;
}
.header__articles .header__article-button {
  margin-top: 2.4rem;
}

.header__inline-menu {
  display: none;
}

.header--center .header__heading-link {
  margin-left: 0;
}

@media screen and (min-width: 1100px) {
  .header__inline-menu {
    display: block;
  }
  .header--center .header__inline-menu {
    display: flex;
  }
}
.header__menu {
  padding: 0 1rem;
}

.header__menu-item {
  text-decoration: none;
  color: rgb(var(--color-foreground));
  transition: color var(--duration-default);
  overflow: hidden;
}

.list-menu--inline {
  align-items: center;
  gap: 0 0.4rem;
}
@media screen and (min-width: 1360px) {
  .list-menu--inline {
    gap: 0 1.2rem;
  }
}
.list-menu--inline li:not(.list-menu--megamenu) {
  position: relative;
}
.list-menu--inline .list-menu-item:hover > .header__submenu,
.list-menu--inline .list-menu-item:focus-within > .header__submenu,
.list-menu--inline .list-menu-item:focus > .header__submenu,
.list-menu--inline .list-menu-item:active > .header__submenu {
  opacity: 1;
  pointer-events: all;
}
.list-menu--inline .list-menu-item:not(.list-menu--submenu) > .header__menu-item {
  position: relative;
  display: flex;
  align-items: center;
  overflow: visible;
}
.list-menu--inline .list-menu-item > .header__menu-item {
  min-height: 4.4rem;
}
.list-menu--inline .header__menu-item span {
  display: flex;
  align-items: center;
  padding: 0.4rem 1rem;
  border-radius: 0.4rem;
  transition: background var(--duration-default);
}
.list-menu--inline .header__menu-item span .icon-caret {
  position: static;
  margin-left: 0.4rem;
}
.list-menu--inline .header__menu-item + .header__submenu {
  opacity: 0;
  pointer-events: none;
}
.list-menu--inline .header__menu-item + .header__submenu:hover, .list-menu--inline .header__menu-item + .header__submenu:focus-within, .list-menu--inline .header__menu-item + .header__submenu:focus, .list-menu--inline .header__menu-item + .header__submenu:active {
  opacity: 1;
  pointer-events: all;
}
.list-menu--inline .header__menu-item--active > span {
  background-color: rgb(var(--color-background-secondary));
}
.list-menu--inline .header__menu-item:hover > span, .list-menu--inline .header__menu-item:focus-within > span, .list-menu--inline .header__menu-item:focus > span, .list-menu--inline .header__menu-item:active > span {
  background-color: rgb(var(--color-background-secondary));
}
.list-menu--inline .header__menu-item:hover + .header__submenu, .list-menu--inline .header__menu-item:focus-within + .header__submenu, .list-menu--inline .header__menu-item:focus + .header__submenu, .list-menu--inline .header__menu-item:active + .header__submenu {
  opacity: 1;
  pointer-events: all;
}

.header__inline-menu .header__menu-item {
  align-items: center;
}

.header__menu-item > span {
  position: relative;
}

.header__icon .header__icon-name {
  text-decoration: none;
  line-height: var(--font-body-line-height);
  color: rgb(var(--color-foreground));
}

.header__submenu {
  text-transform: none;
  border-radius: 1.2rem;
  box-shadow: 0px 8px 40px 0px rgba(var(--color-shadow), 0.08);
  transition: opacity var(--duration-default);
  z-index: 15;
}
.header__submenu.list-menu {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  padding: 1.2rem;
}
.header__submenu .header__menu-item {
  justify-content: space-between;
  height: auto;
  padding: 0;
  text-transform: none;
}
.header__submenu .header__menu-item span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 1rem 2rem;
  border-radius: 0.6rem;
}
.header__submenu .header__menu-item:hover span {
  background-color: rgb(var(--color-background-secondary));
}
.header__submenu .icon-caret {
  right: 1.6rem;
}
@media screen and (min-width: 1100px) {
  .header__submenu .header__submenu {
    --clientY: var(--header-height);
    max-height: calc(100vh - var(--clientY) - 2rem);
    overflow: auto;
  }
  .header__submenu .header__submenu::-webkit-scrollbar {
    width: 0.4rem;
  }
  .header__submenu .header__submenu::-webkit-scrollbar-thumb {
    background-color: rgba(var(--color-border));
    border-radius: 2rem;
  }
}

.header__menu-item .icon-caret {
  flex: none;
  width: 2rem;
  height: 2rem;
  transform: rotate(-90deg);
  z-index: 0;
}

.header__inline-menu .list-menu--disclosure {
  width: 20rem;
  min-width: auto;
  left: auto;
}
.header__inline-menu li:hover > .header__submenu {
  opacity: 1;
  pointer-events: all;
}
.header__inline-menu span.header__menu-item {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.header__menu-item > span {
  position: relative;
}

.header__icon .header__icon-name {
  text-decoration: none;
  line-height: var(--font-body-line-height);
  color: rgb(var(--color-foreground));
}

@keyframes animateMenuOpen {
  0% {
    opacity: 0;
    transform: translateY(-1rem);
  }
  100% {
    opacity: 1;
    transform: translateY(0rem);
  }
}
@keyframes animateLocalOpen {
  0% {
    opacity: 0;
    transform: translateY(-1rem);
  }
  100% {
    opacity: 1;
    transform: translateY(0rem);
  }
}
.overflow-hidden-mobile,
.overflow-hidden-tablet {
  overflow: hidden;
}

@media screen and (min-width: 750px) {
  .overflow-hidden-mobile {
    overflow: auto;
  }
}
@media screen and (min-width: 990px) {
  .overflow-hidden-tablet {
    overflow: auto;
  }
}
.header__icon--cart {
  position: relative;
  gap: 0.4rem;
  padding-right: 0;
  min-width: 4.4rem;
  width: auto;
  height: 4.4rem;
  transition: opacity var(--duration-default);
}
.header__icon--cart:hover {
  opacity: 0.6;
}
.header__icon--cart .icon {
  width: 2rem;
  height: 2rem;
}

* + .header__cart {
  position: relative;
  margin-left: 0.2rem;
  padding-left: 1.6rem;
}
* + .header__cart::before {
  content: "";
  position: absolute;
  left: 0;
  width: 0.2rem;
  height: 1.6rem;
  background-color: rgb(var(--color-border));
  border-radius: 0.2rem;
}

.header__cart {
  display: flex;
  align-items: center;
}

.cart-count-bubble:empty {
  display: none;
}

.cart-count-bubble {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: none;
  padding: 0.2rem;
  min-width: 2.4rem;
  height: 2.4rem;
  font-size: 1.1rem;
  font-weight: 600;
  line-height: 1;
  background-color: rgb(var(--color-background-secondary));
  border-radius: 2rem;
}
@media screen and (max-width: 1200px) {
  .cart-count-bubble {
    margin-right: 0;
  }
}

.scheme-toggled[data-scheme] *:not(.swiper-wrapper),
.scheme-toggled[data-scheme] *::after,
.scheme-toggled[data-scheme] *::before {
  transition: none !important;
}

.header__scheme {
  position: relative;
  display: none;
  align-items: center;
  min-width: 4.4rem;
}
@media screen and (min-width: 750px) {
  .header__scheme {
    display: flex;
  }
}

.header__toggle-scheme {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1rem;
  flex: none;
  min-width: 4.4rem;
  padding: 0.4rem;
  background-color: rgb(var(--color-background-secondary));
  border: none;
  border-radius: 2rem;
  transition: opacity var(--duration-default);
  cursor: pointer;
}
.header__toggle-scheme:hover {
  opacity: 0.6;
}
.header__toggle-scheme::before {
  content: "";
  position: absolute;
  display: flex;
  width: 2.8rem;
  height: 2.8rem;
  left: 0;
  background-color: rgb(var(--color-background));
  border-radius: 50%;
  transition: transform var(--duration-default) !important;
  transform: translateX(0.4rem);
}
.header__toggle-scheme-item {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  width: 2.8rem;
  height: 2.8rem;
  color: rgb(var(--color-foreground));
  z-index: 1;
}
.header__toggle-scheme-item .icon {
  flex: none;
  width: 1.8rem;
  height: 1.8rem;
  transition: var(--duration-default);
}

@media (prefers-color-scheme: light) {
  [data-scheme=auto] .header__toggle-scheme-item--dark .icon {
    color: rgb(var(--color-foreground));
  }
  [data-scheme=auto] .header__toggle-scheme::before {
    transform: translateX(0.4rem);
    transition: transform var(--duration-default) !important;
  }
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) {
    --color-background-secondary: 255, 255, 255, 0.2;
  }
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__toggle-scheme-item--light .icon {
    color: #000;
  }
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__toggle-scheme-item--dark .icon {
    color: var(--color-foreground);
  }
  .header__submenu,
  .header .disclosure__list,
  .header__account-modal {
    background-color: rgb(var(--color-background));
    box-shadow: 0 8px 40px 0 rgba(var(--color-shadow), 0.08);
  }
  .header__search-inner,
  .drawer__inner {
    background-color: rgb(var(--color-background));
  }
}
[data-scheme=light] .header__toggle-scheme-item--dark .icon {
  color: rgb(var(--color-foreground));
}
[data-scheme=light] .header__toggle-scheme::before {
  transform: translateX(0.4rem);
  transition: transform var(--duration-default) !important;
}
[data-scheme=light] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) {
  --color-background-secondary: 255, 255, 255, 0.2;
}
[data-scheme=light] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__toggle-scheme-item--light .icon {
  color: #000;
}
[data-scheme=light] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__toggle-scheme-item--dark .icon {
  color: var(--color-foreground);
}
[data-scheme=light] .header__submenu,
[data-scheme=light] .header .disclosure__list,
[data-scheme=light] .header__account-modal {
  background-color: rgb(var(--color-background));
  box-shadow: 0 8px 40px 0 rgba(var(--color-shadow), 0.08);
}
[data-scheme=light] .header__search-inner,
[data-scheme=light] .drawer__inner {
  background-color: rgb(var(--color-background));
}

@media (prefers-color-scheme: dark) {
  [data-scheme=auto] .header__toggle-scheme {
    background-color: #4a4a4c;
  }
  [data-scheme=auto] .header__toggle-scheme-item--dark .icon {
    color: rgb(var(--color-foreground));
  }
  [data-scheme=auto] .header__toggle-scheme::before {
    transform: translateX(4.2rem);
    transition: transform var(--duration-default) !important;
  }
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__submenu.list-menu {
    --color-background-secondary: 24, 24, 24;
  }
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__toggle-scheme-item--light .icon {
    color: var(--color-foreground);
  }
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__toggle-scheme-item--dark .icon {
    color: #000;
  }
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__submenu,
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header .disclosure__list,
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__account-modal,
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .list-menu--megamenu .mega-menu {
    background-color: #343435;
    box-shadow: 0 -8px 40px 0 rgba(0, 0, 0, 0.2);
  }
}
@media screen and (prefers-color-scheme: dark) and (min-width: 1100px) {
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .mega-menu__columns {
    background-color: #343435;
    box-shadow: 0 -8px 40px 0 rgba(0, 0, 0, 0.2);
  }
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .mega-menu__column-list,
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .mega-menu__tab-list {
    background-color: #343435;
  }
}
@media (prefers-color-scheme: dark) {
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__search-inner,
  [data-scheme=auto] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .drawer__inner {
    background-color: #343435;
  }
}
[data-scheme=dark] .header__toggle-scheme {
  background-color: #4a4a4c;
}
[data-scheme=dark] .header__toggle-scheme-item--dark .icon {
  color: rgb(var(--color-foreground));
}
[data-scheme=dark] .header__toggle-scheme::before {
  transform: translateX(4.2rem);
  transition: transform var(--duration-default) !important;
}
[data-scheme=dark] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__submenu.list-menu {
  --color-background-secondary: 24, 24, 24;
}
[data-scheme=dark] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__toggle-scheme-item--light .icon {
  color: var(--color-foreground);
}
[data-scheme=dark] .shopify-section-header.color-background-overlay:not(.shopify-section-header-sticky) .header__toggle-scheme-item--dark .icon {
  color: #000;
}
[data-scheme=dark] .header__submenu,
[data-scheme=dark] .header .disclosure__list,
[data-scheme=dark] .header__account-modal,
[data-scheme=dark] .list-menu--megamenu .mega-menu {
  background-color: #343435;
  box-shadow: 0 -8px 40px 0 rgba(0, 0, 0, 0.2);
}
@media screen and (min-width: 1100px) {
  [data-scheme=dark] .mega-menu__columns {
    background-color: #343435;
    box-shadow: 0 -8px 40px 0 rgba(0, 0, 0, 0.2);
  }
  [data-scheme=dark] .mega-menu__column-list,
  [data-scheme=dark] .mega-menu__tab-list {
    background-color: #343435;
  }
}
[data-scheme=dark] .header__search-inner,
[data-scheme=dark] .drawer__inner {
  background-color: #343435;
}

.mega-menu {
  position: absolute;
  top: auto;
  display: none;
  max-height: calc(100vh - var(--header-height) - var(--announcement-height) - var(--logo-bar-height) - 3.2rem);
  opacity: 0;
  pointer-events: none;
  overflow-y: auto;
  box-shadow: 0px 8px 40px 0px rgba(var(--color-shadow), 0.08);
  border-radius: 1.2rem;
  transition: opacity var(--duration-short) linear, max-height var(--duration-short) linear, padding var(--duration-short) linear, width var(--duration-short);
  z-index: 4;
}
@media screen and (min-width: 1536px) {
  .mega-menu {
    max-height: 820px;
  }
}
.mega-menu:hover, .mega-menu:focus, .mega-menu:focus-visible, .mega-menu:focus-within {
  opacity: 1;
  pointer-events: all;
}
.mega-menu::-webkit-scrollbar {
  width: 0.4rem;
  height: 0.4rem;
}
.mega-menu::-webkit-scrollbar-thumb {
  background-color: rgba(var(--color-border));
  border-radius: 2rem;
}
.mega-menu--columns {
  width: 100%;
  max-width: 129.6rem;
  container-name: columns;
  container-type: inline-size;
}
.mega-menu--columns-1 {
  max-width: 37rem;
}
.mega-menu--columns-2 {
  max-width: 66.4rem;
}
@media screen and (min-width: 1536px) {
  .mega-menu--columns-2 {
    max-width: 70.4rem;
  }
}
.mega-menu--columns-3 {
  right: 0;
  left: 0;
  max-width: 100rem;
}
@media screen and (min-width: 1360px) {
  .mega-menu--columns-3 {
    right: unset;
  }
}
.mega-menu--columns-4 {
  right: 0;
  left: 0;
}
@media screen and (min-width: 1360px) {
  .mega-menu--columns-4 {
    right: unset;
  }
}
.mega-menu--tabs {
  display: grid;
  grid-template-columns: 1fr 2.2fr;
  max-width: 72rem;
}
.mega-menu--tabs .mega-menu__promo {
  grid-column: 1/3;
}
.mega-menu__columns {
  display: grid;
  grid-template-columns: 1fr;
  align-items: flex-start;
  gap: 4rem 3.2rem;
  grid-template-columns: repeat(var(--column-count), 1fr);
  padding: 3.2rem;
}
@media screen and (min-width: 1360px) {
  .mega-menu__columns {
    padding: 4rem;
  }
}
.mega-menu__columns--1 {
  --column-count: 1;
}
.mega-menu__columns--2 {
  --column-count: 2;
}
.mega-menu__columns--3 {
  --column-count: 3;
}
.mega-menu__columns--4 {
  --column-count: 4;
}
.mega-menu__column, .mega-menu__tab {
  display: flex;
  align-items: flex-start;
  gap: 1.6rem;
}
.mega-menu__column-info, .mega-menu__tab-info {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.4rem;
  min-width: 20rem;
  max-width: 25.2rem;
}
.mega-menu__column-heading, .mega-menu__tab-heading {
  font-family: var(--font-heading-family);
  font-style: var(--font-heading-style);
  font-weight: var(--font-heading-weight);
  letter-spacing: calc(var(--font-heading-letter-spacing) * 0.1);
  line-height: var(--font-heading-line-height);
  text-transform: var(--font-heading-text-transform);
}
.mega-menu__column-text, .mega-menu__tab-text {
  margin: 0;
  font-family: var(--font-body-family);
  font-style: var(--font-body-style);
  font-weight: var(--font-body-weight);
  letter-spacing: calc(var(--font-body-letter-spacing) * 0.1);
  line-height: var(--font-body-line-height);
  color: rgb(var(--color-foreground-secondary));
}
.mega-menu__column-list, .mega-menu__tab-list {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1.2rem;
  margin-top: 0.8rem;
  background-color: rgb(var(--color-background));
}
.mega-menu__column-list-item, .mega-menu__tab-list-item {
  line-height: 1.4;
}
.mega-menu__column-list-link, .mega-menu__tab-list-link {
  line-height: 1.4;
  text-decoration: none;
  color: rgb(var(--color-foreground));
}
.mega-menu__column-list-link:hover, .mega-menu__tab-list-link:hover {
  color: rgb(var(--color-foreground-secondary));
}
.mega-menu__column-link, .mega-menu__tab-link {
  flex: none;
}
.mega-menu__column {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr;
  flex-direction: column;
  gap: 1.6rem 1rem;
}
.mega-menu__column--overlay .mega-menu__column-text {
  transition: color var(--duration-default);
}
.mega-menu__column--overlay:hover .mega-menu__column-text {
  color: rgb(var(--color-foreground));
}
.mega-menu__column-top {
  display: flex;
  gap: 1.2rem;
  align-items: flex-start;
}
.mega-menu__column-link-overlay:empty {
  position: absolute;
  inset: 0;
  display: block;
}
.mega-menu__column-link-overlay:empty + .mega-menu__column-heading {
  pointer-events: none;
  transition: opacity var(--duration-default);
}
.mega-menu__column-link-overlay:empty:hover + .mega-menu__column-heading {
  opacity: 0.7;
}
.mega-menu__column-info {
  grid-column: 2/3;
}
.mega-menu__column-info--only-heading {
  align-self: center;
}
.mega-menu__column-list {
  margin: 0;
  grid-column: 2/3;
}
.mega-menu__tabs {
  position: relative;
  padding: 2rem;
  padding-right: 0;
  min-height: 25rem;
}
.mega-menu__tab {
  grid-column: 1/2;
  width: 100%;
}
@media screen and (min-width: 1100px) {
  .mega-menu__tab {
    max-width: 36.6rem;
  }
}
.mega-menu__tab-wrapper {
  display: flex;
  align-items: flex-start;
  gap: 1.6rem;
  padding: 2rem;
  width: 100%;
  border-radius: 0.8rem;
  transition: background var(--duration-default);
}
@media screen and (min-width: 1100px) {
  .mega-menu__tab-wrapper:hover {
    background-color: rgb(var(--color-background-secondary));
  }
}
.mega-menu__tab-wrapper:hover .mega-menu__tab-list {
  opacity: 1;
  pointer-events: all;
}
@media screen and (min-width: 1100px) {
  .mega-menu__tab-wrapper--active {
    background-color: rgb(var(--color-background-secondary));
  }
}
.mega-menu__tab-wrapper--active .mega-menu__tab-list {
  opacity: 1;
}
.mega-menu__tab-info {
  flex-direction: row;
  gap: 1.6rem;
  max-width: 29.3rem;
  cursor: default;
}
.mega-menu__tab-inner {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.mega-menu__tab-inner--only-heading {
  align-self: center;
}
.mega-menu__tab-list {
  gap: 0;
}
@media screen and (min-width: 1100px) {
  .mega-menu__tab-list {
    position: absolute;
    inset: 0;
    left: 100%;
    display: inline-flex;
    flex-direction: row;
    writing-mode: vertical-lr;
    flex-wrap: wrap;
    align-items: stretch;
    gap: 3.2rem 0;
    margin-top: 3.4rem;
    padding-block: 3.2rem;
    width: max-content;
    transition: opacity var(--duration-default);
    opacity: 0;
    pointer-events: none;
  }
}
@media screen and (min-width: 1536px) {
  .mega-menu__tab-list {
    gap: 4rem 0;
  }
}
.mega-menu__tab-list-item {
  writing-mode: horizontal-tb;
  line-height: var(--font-heading-line-height);
}
.mega-menu__tab-list-link {
  display: block;
  padding-block: 0.8rem;
  color: rgb(var(--color-foreground));
}
.mega-menu__tab-list-link:hover {
  color: rgb(var(--color-foreground-secondary));
}
.mega-menu__promo {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 3.2rem;
  padding-inline: 3.2rem;
  padding-block: 2.4rem;
  background-color: rgb(var(--color-background-secondary));
}
@media screen and (min-width: 1360px) {
  .mega-menu__promo {
    padding-inline: 4rem;
  }
}
.mega-menu__promo-info {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.mega-menu__promo-heading {
  font-family: var(--font-heading-family);
  font-style: var(--font-heading-style);
  font-weight: var(--font-heading-weight);
  letter-spacing: calc(var(--font-heading-letter-spacing) * 0.1);
  line-height: var(--font-heading-line-height);
  text-transform: var(--font-heading-text-transform);
}
.mega-menu__promo-text {
  margin: 0;
  color: rgb(var(--color-foreground-secondary));
  white-space: pre-wrap;
}
.mega-menu__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  width: max-content;
  background: transparent;
}
.mega-menu__icon--normal .icon {
  font-size: 2.8rem;
}
@media screen and (min-width: 750px) {
  .mega-menu__icon--normal .icon {
    font-size: 3.2rem;
  }
}
@media screen and (min-width: 1200px) {
  .mega-menu__icon--normal .icon {
    font-size: 4rem;
  }
}
.mega-menu__icon--small .icon {
  font-size: 2rem;
}
@media screen and (min-width: 1200px) {
  .mega-menu__icon--small .icon {
    font-size: 2.4rem;
  }
}
.mega-menu__icon--large .icon {
  font-size: 3.2rem;
}
@media screen and (min-width: 750px) {
  .mega-menu__icon--large .icon {
    font-size: 4rem;
  }
}
@media screen and (min-width: 1200px) {
  .mega-menu__icon--large .icon {
    font-size: 4.8rem;
  }
}
.mega-menu__icon--recommended .icon {
  font-size: 2.4rem;
}
@media screen and (min-width: 1200px) {
  .mega-menu__icon--recommended .icon {
    font-size: 2.8rem;
  }
}
.mega-menu__icon--shadow {
  padding: 0.8rem;
  background-color: rgba(var(--color-background));
  border-radius: 0.6rem;
  box-shadow: 0px 8px 40px 0px rgba(var(--color-shadow), 0.08);
}
@media screen and (min-width: 1200px) {
  .mega-menu__icon--shadow {
    padding: 1rem;
    border-radius: 0.8rem;
  }
}
.mega-menu__icon--shadow.mega-menu__icon--recommended .icon {
  font-size: 2rem;
}
@media screen and (min-width: 1200px) {
  .mega-menu__icon--shadow.mega-menu__icon--recommended .icon {
    font-size: 2.4rem;
  }
}
.mega-menu__icon--subtle {
  color: rgba(var(--color-foreground), 0.14);
}
.mega-menu__icon--contrast {
  color: rgba(var(--color-foreground));
}
.mega-menu__icon--colored {
  color: rgba(var(--color-accent));
}
.mega-menu__icon--colored.mega-menu__icon--gradient {
  color: var(--gradient-accent);
}
.mega-menu__wrapper {
  grid-column-start: 1;
  grid-column-end: 13;
  width: 100%;
  transition: opacity var(--duration-default), transform var(--duration-default);
}

.list-menu--megamenu .mega-menu__wrapper {
  opacity: 0;
}
.list-menu--megamenu .mega-menu {
  opacity: 0;
  pointer-events: none;
}
.list-menu--megamenu:focus > .mega-menu,
.list-menu--megamenu:focus .mega-menu__list-item--visible .mega-menu__submenu,
.list-menu--megamenu:focus .mega-menu__wrapper, .list-menu--megamenu:focus-visible > .mega-menu,
.list-menu--megamenu:focus-visible .mega-menu__list-item--visible .mega-menu__submenu,
.list-menu--megamenu:focus-visible .mega-menu__wrapper, .list-menu--megamenu:focus-within > .mega-menu,
.list-menu--megamenu:focus-within .mega-menu__list-item--visible .mega-menu__submenu,
.list-menu--megamenu:focus-within .mega-menu__wrapper {
  opacity: 1;
  pointer-events: all;
}

.list-menu--megamenu-visible .mega-menu,
.list-menu--megamenu-visible .mega-menu__list-item--visible .mega-menu__submenu,
.list-menu--megamenu-visible .mega-menu__wrapper,
.list-menu--megamenu-visible .mega-menu__tab-wrapper--active .mega-menu__tab-list {
  opacity: 1;
  pointer-events: all;
}

.header__menu-item:focus + .mega-menu,
.header__menu-item:focus-visible + .mega-menu,
.header__menu-item:focus-within + .mega-menu,
.header__menu-item:hover + .mega-menu {
  pointer-events: all;
}
.header__menu-item:focus + .mega-menu:hover,
.header__menu-item:focus-visible + .mega-menu:hover,
.header__menu-item:focus-within + .mega-menu:hover,
.header__menu-item:hover + .mega-menu:hover {
  opacity: 1;
  pointer-events: all;
}

.menu-drawer__mega-menu {
  position: static;
  padding: 0;
  max-height: unset;
  pointer-events: all;
  opacity: 1;
}
.menu-drawer .mega-menu__columns {
  padding: 0;
  padding-bottom: 2.4rem;
  grid-template-columns: 1fr;
  gap: 2.4rem;
}
.menu-drawer .mega-menu__column, .menu-drawer .mega-menu__tab {
  gap: 1.2rem;
}
.menu-drawer .mega-menu__column-info, .menu-drawer .mega-menu__tab-info {
  min-width: unset;
  max-width: 35rem;
}
.menu-drawer .mega-menu__column {
  gap: 1rem 1.2rem;
}
.menu-drawer .mega-menu__column:not(:first-child) {
  padding-top: 2rem;
  border-top: 0.1rem solid rgb(var(--color-border));
}
.menu-drawer .mega-menu__column-list {
  z-index: 3;
}
.menu-drawer .mega-menu__promo {
  flex-direction: column;
  align-items: flex-start;
  gap: 1.2rem;
  margin-bottom: 2.4rem;
  padding: 2.4rem;
  border-radius: 1.2rem;
}
.menu-drawer .mega-menu__tabs {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  width: auto;
  padding: 0;
  padding-bottom: 2.4rem;
}
.menu-drawer .mega-menu__tab:not(:first-child) {
  padding-top: 2rem;
  border-top: 0.1rem solid rgb(var(--color-border));
}
.menu-drawer .mega-menu__tab-wrapper {
  flex-direction: column;
  padding: 0;
}
.menu-drawer .mega-menu__tab-list {
  margin-top: 1rem;
}
.menu-drawer .mega-menu__tab-list-item:first-child .mega-menu__tab-list-link {
  padding-top: 0;
}
.menu-drawer .mega-menu__tab-list-item:last-child .mega-menu__tab-list-link {
  padding-bottom: 0;
}

@container columns (max-width: 1200px) {
  .mega-menu__columns {
    --column-count: 3;
  }
}
@container columns (max-width: 900px) {
  .mega-menu__columns {
    --column-count: 2;
  }
}
@container columns (max-width: 658px) {
  .mega-menu__columns {
    --column-count: 1;
  }
}
@media (prefers-color-scheme: dark) {
  [data-scheme=auto] .shopify-section-header:not(.color-background-overlay) .header,
  [data-scheme=auto] .shopify-section-header:not(.color-background-overlay) .header-wrapper:not(.container) {
    background-color: #343435;
  }
  [data-scheme=auto] .shopify-section-header:not(.color-background-overlay) .header__toggle-scheme:before {
    background-color: #343435;
  }
  [data-scheme=auto] .shopify-section-header:not(.color-background-overlay) .header--border.header-wrapper:not(.container) {
    background-color: rgb(var(--color-background));
  }
  [data-scheme=auto] .shopify-section-header:not(.color-background-overlay) .header--border .header {
    background-color: rgb(var(--color-background));
  }
  [data-scheme=auto] .shopify-section-header:not(.color-background-overlay) .header--border::before {
    background-color: rgb(var(--color-foreground), 0.2);
    bottom: -0.1rem;
  }
  [data-scheme=auto] .shopify-section-header:not(.color-background-overlay) .cart-count-bubble {
    background-color: #4a4a4c;
  }
  [data-scheme=auto] .shopify-section-header:not(.color-background-overlay) * + .header__cart:before {
    background-color: rgb(var(--color-foreground), 0.2);
  }
  [data-scheme=auto] .shopify-section-header-sticky .header-wrapper.container,
  [data-scheme=auto] .shopify-section-header-sticky .header--border {
    background-color: #343435;
  }
  [data-scheme=auto] .shopify-section-header-sticky .header-wrapper.container .header,
  [data-scheme=auto] .shopify-section-header-sticky .header--border .header {
    background-color: #343435;
  }
  [data-scheme=auto] .shopify-section-header-sticky .header-wrapper.container .header__toggle-scheme:before,
  [data-scheme=auto] .shopify-section-header-sticky .header--border .header__toggle-scheme:before {
    background-color: #343435;
  }
  [data-scheme=auto] .shopify-section-header-sticky .header-wrapper.container .cart-count-bubble,
  [data-scheme=auto] .shopify-section-header-sticky .header--border .cart-count-bubble {
    background-color: #4a4a4c;
  }
  [data-scheme=auto] .shopify-section-header-sticky .header-wrapper.container * + .header__cart:before,
  [data-scheme=auto] .shopify-section-header-sticky .header--border * + .header__cart:before {
    background-color: rgb(var(--color-foreground), 0.2);
  }
  [data-scheme=auto] .header .card-wrapper {
    background-color: #343435;
  }
}
[data-scheme=dark] .shopify-section-header:not(.color-background-overlay) .header,
[data-scheme=dark] .shopify-section-header:not(.color-background-overlay) .header-wrapper:not(.container) {
  background-color: #343435;
}
[data-scheme=dark] .shopify-section-header:not(.color-background-overlay) .header__toggle-scheme:before {
  background-color: #343435;
}
[data-scheme=dark] .shopify-section-header:not(.color-background-overlay) .header--border.header-wrapper:not(.container) {
  background-color: rgb(var(--color-background));
}
[data-scheme=dark] .shopify-section-header:not(.color-background-overlay) .header--border .header {
  background-color: rgb(var(--color-background));
}
[data-scheme=dark] .shopify-section-header:not(.color-background-overlay) .header--border::before {
  background-color: rgb(var(--color-foreground), 0.2);
  bottom: -0.1rem;
}
[data-scheme=dark] .shopify-section-header:not(.color-background-overlay) .cart-count-bubble {
  background-color: #4a4a4c;
}
[data-scheme=dark] .shopify-section-header:not(.color-background-overlay) * + .header__cart:before {
  background-color: rgb(var(--color-foreground), 0.2);
}
[data-scheme=dark] .shopify-section-header-sticky .header-wrapper.container,
[data-scheme=dark] .shopify-section-header-sticky .header--border {
  background-color: #343435;
}
[data-scheme=dark] .shopify-section-header-sticky .header-wrapper.container .header,
[data-scheme=dark] .shopify-section-header-sticky .header--border .header {
  background-color: #343435;
}
[data-scheme=dark] .shopify-section-header-sticky .header-wrapper.container .header__toggle-scheme:before,
[data-scheme=dark] .shopify-section-header-sticky .header--border .header__toggle-scheme:before {
  background-color: #343435;
}
[data-scheme=dark] .shopify-section-header-sticky .header-wrapper.container .cart-count-bubble,
[data-scheme=dark] .shopify-section-header-sticky .header--border .cart-count-bubble {
  background-color: #4a4a4c;
}
[data-scheme=dark] .shopify-section-header-sticky .header-wrapper.container * + .header__cart:before,
[data-scheme=dark] .shopify-section-header-sticky .header--border * + .header__cart:before {
  background-color: rgb(var(--color-foreground), 0.2);
}
[data-scheme=dark] .header .card-wrapper {
  background-color: #343435;
}

noscript .localization-form__select {
  position: relative;
  display: flex;
  align-items: center;
}
noscript .localization-form__select svg {
  position: absolute;
  right: 1.2rem;
}

@media screen and (max-width: 989px) {
  .logo-disable-on-mobile {
    display: none !important;
  }
}

@media screen and (min-width: 990px) {
  .logo-disable-on-desktop {
    display: none !important;
  }
}

@media screen and (max-width: 989px) {
  .header--center-logo.header--without-logo-mobile {
    grid-template-columns: 1fr 1fr;
  }
}

@media screen and (min-width: 990px) {
  .header--center-logo.header--without-logo-desktop {
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (min-width: 1100px) {
  .header--center-logo.header--without-logo-desktop {
    grid-template-columns: 1fr 1fr;
  }
}

/* Breadcrumb  */
.breadcrumb {
  position: relative;
  z-index: 4;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  row-gap: 0.6rem;
  margin: 2.4rem 0 0 0;
  font-family: var(--font-body-family);
  font-weight: var(--font-heading-weight);
  color: rgba(var(--color-foreground), 0.3);
  background-color: transparent;
}
.breadcrumb__delimiter {
  width: 0.4rem;
  height: 0.4rem;
  border-radius: 50%;
  background-color: rgba(var(--color-foreground), 0.3);
  margin-inline: 0.8rem;
}
.breadcrumb--center {
  justify-content: center;
}
.breadcrumb a {
  position: relative;
  color: inherit;
  text-decoration: none;
  transition: color var(--duration-default);
}
.breadcrumb a:hover {
  color: rgba(var(--color-foreground), 0.5);
}
.breadcrumb span {
  color: rgba(var(--color-foreground), 0.5);
}

/* Popup */
.popup-scroll-hidden {
  overflow: hidden;
  width: 100%;
}

.popup-animated {
  animation-duration: 0.5s;
  animation-fill-mode: both;
  overflow: hidden !important;
}

@keyframes popupOpenFade {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes popupExitFade {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes popupOpenSlide {
  from {
    transform: translate3d(0, 100vh, 0);
    visibility: visible;
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes popupExitSlide {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    visibility: hidden;
    transform: translate3d(0, 100vh, 0);
  }
}
@keyframes popupOpenZoom {
  from {
    opacity: 0;
    transform: scale(1.1);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes popupExitZoom {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(1.1);
  }
}
@keyframes popupOpenSlideFade {
  from {
    opacity: 0;
    transform: translate3d(0, 4rem, 0);
    visibility: visible;
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
@keyframes popupExitSlideFade {
  from {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
  to {
    opacity: 0;
    visibility: hidden;
    transform: translate3d(0, 4rem, 0);
  }
}
.popupOpenFade {
  animation-name: popupOpenFade;
}

.popupExitFade {
  animation-name: popupExitFade;
}

.popupOpenSlide {
  animation-name: popupOpenSlide;
}

.popupExitSlide {
  animation-name: popupExitSlide;
}

.popupOpenZoom {
  animation-name: popupOpenZoom;
}

.popupExitZoom {
  animation-name: popupExitZoom;
}

.popupOpenSlideFade {
  animation-name: popupOpenSlideFade;
}

.popupExitSlideFade {
  animation-name: popupExitSlideFade;
}

.popup {
  display: none;
  position: fixed;
  z-index: 999999;
  max-width: calc(100vw - 4rem);
  max-height: calc(100vh - 4rem);
  -webkit-backface-visibility: hidden;
  transition: var(--duration-default);
}
@media screen and (min-width: 1200px) {
  .popup {
    max-width: calc(100vw - 6.4rem);
    max-height: calc(100vh - 6.4rem);
  }
}
.popup--top {
  top: 2rem;
  left: 50%;
  transform: translate3d(-50%, 0, 0);
}
@media screen and (min-width: 750px) {
  .popup--top {
    top: 3.2rem;
  }
}
.popup--top-left {
  top: 2rem;
  left: 2rem;
}
@media screen and (min-width: 750px) {
  .popup--top-left {
    top: 3.2rem;
    left: 3.2rem;
  }
}
.popup--top-right {
  top: 2rem;
  right: 2rem;
}
@media screen and (min-width: 750px) {
  .popup--top-right {
    top: 3.2rem;
    right: 3.2rem;
  }
}
.popup--bottom {
  bottom: 2rem;
  left: 50%;
  transform: translate3d(-50%, 0, 0);
}
@media screen and (min-width: 750px) {
  .popup--bottom {
    bottom: 3.2rem;
  }
}
.popup--bottom-left {
  left: 2rem;
  bottom: 2rem;
}
@media screen and (min-width: 750px) {
  .popup--bottom-left {
    left: 3.2rem;
    bottom: 3.2rem;
  }
}
.popup--bottom-right {
  right: 2rem;
  bottom: 2rem;
}
@media screen and (min-width: 750px) {
  .popup--bottom-right {
    right: 3.2rem;
    bottom: 3.2rem;
  }
}
.popup--left {
  left: 2rem;
  top: 50%;
  transform: translate3d(0, -50%, 0);
}
@media screen and (min-width: 750px) {
  .popup--left {
    left: 3.2rem;
  }
}
.popup--right {
  top: 50%;
  right: 2rem;
  transform: translate3d(0, -50%, 0);
}
@media screen and (min-width: 750px) {
  .popup--right {
    right: 3.2rem;
  }
}
.popup--center {
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
}
.popup-wrap {
  position: relative;
  overflow-x: hidden;
  overflow-y: auto;
  width: 100%;
  border-radius: 1.2rem;
}
.popup-wrap::-webkit-scrollbar {
  width: 0.4rem;
  height: 0.4rem;
}
.popup-wrap::-webkit-scrollbar-track {
  background: rgb(var(--color-background));
}
.popup-wrap::-webkit-scrollbar-thumb {
  background: rgb(var(--color-foreground), 0.3);
}
.popup-container {
  width: 100%;
}
.popup-outer {
  position: relative;
  display: flex;
  flex-direction: column;
  --background: rgb(var(--color-background));
  background: var(--background);
  border-radius: 1.2rem;
}
.popup-text {
  color: rgb(var(--color-foreground-secondary));
}
.popup-text a {
  text-decoration: underline;
  transition: color var(--duration-default);
}
.popup-text p {
  margin: 0;
}
.popup .popup-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 2;
}
.popup-open {
  display: flex;
}
@media (max-width: 576px) {
  .popup-open[data-mobile-disable=true] {
    display: none;
  }
  .popup-open[data-mobile-disable=true] + .popup-overlay {
    display: none;
  }
}
.popup-open + .popup-overlay {
  display: block;
}
.popup-overlay {
  background-color: rgba(var(--color-overlay), 0.3);
  position: fixed;
  display: none;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 999998;
}
.popup-overlay .popup-wrap {
  box-shadow: none;
}
.popup-thumbnail img {
  width: 100%;
}
.popup-trigger {
  cursor: pointer;
}

.popup-heading {
  font-family: var(--font-popups-heading-family);
  font-style: var(--font-popups-heading-style);
  font-weight: var(--font-popups-heading-weight);
}

.popup-text, .popup-description {
  font-family: var(--font-popups-text-family);
  font-style: var(--font-popups-text-style);
  font-weight: var(--font-popups-text-weight);
}

.popup-main {
  border-radius: 1.2rem;
  max-width: calc(100vw - 4rem);
  max-height: calc(100vh - 4rem);
}
@media (min-width: 1200px) {
  .popup-main {
    max-width: calc(100vw - 12.8rem);
    max-height: calc(100vh - 6.4rem);
  }
}
.popup-main-image--left .popup-outer_image::before, .popup-main-image--right .popup-outer_image::before {
  content: "";
  display: none;
  height: 100%;
  width: 0;
  padding-bottom: 25%;
}
@media (min-width: 750px) {
  .popup-main-image--left .popup-outer_image::before, .popup-main-image--right .popup-outer_image::before {
    display: block;
  }
}
.popup-main-image--left .popup-outer_image .popup-content, .popup-main-image--right .popup-outer_image .popup-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.popup-main .popup-wraper-text {
  position: relative;
  z-index: 1;
}
.popup-main .popup-wraper-text--columns {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
@media screen and (min-width: 990px) {
  .popup-main .popup-wraper-text--columns {
    flex-direction: row;
    align-items: center;
    gap: 48px;
  }
}
.popup-main .popup-column {
  flex: 1;
}
@media screen and (min-width: 990px) {
  .popup-main .popup-column:first-child {
    max-width: 49%;
  }
  .popup-main .popup-column:last-child {
    max-width: 44%;
  }
}
@media screen and (max-width: 989px) {
  .popup-main .popup-column:first-child *:first-child {
    margin-right: 4rem;
  }
}
@media screen and (max-width: 989px) {
  .popup-main .popup-wraper-text:not(.popup-wraper-text--columns) > *:first-child {
    margin-right: 4rem;
  }
}
.popup-main .popup-heading {
  max-width: 53rem;
  margin-top: 0;
  margin-bottom: 0.8rem;
  font-size: calc(var(--font-popup-heading-scale) * 2rem);
}
@media screen and (min-width: 750px) {
  .popup-main .popup-heading {
    margin-bottom: 1.2rem;
    font-size: calc(var(--font-popup-heading-scale) * 2.6rem);
  }
}
@media screen and (min-width: 990px) {
  .popup-main .popup-heading:last-child {
    margin-bottom: 0;
  }
}
.popup-main .popup-description {
  max-width: 44rem;
  margin-top: 0;
  margin-bottom: 1.6rem;
  font-size: calc(var(--font-popup-desc-scale) * 1.3rem);
  color: rgb(var(--color-foreground), 0.6);
}
@media screen and (min-width: 750px) {
  .popup-main .popup-description {
    margin-bottom: 2.4rem;
    font-size: calc(var(--font-popup-desc-scale) * 1.6rem);
  }
}
@media screen and (min-width: 990px) {
  .popup-main .popup-description:last-child {
    margin-bottom: 0;
  }
}
.popup-main .popup-text {
  margin-top: 0.8rem;
  font-size: calc(var(--font-popup-text-scale) * 1rem);
  color: rgb(var(--color-foreground-secondary));
}
@media screen and (min-width: 750px) {
  .popup-main .popup-text {
    margin-top: 1.6rem;
    font-size: calc(var(--font-popup-text-scale) * 1.3rem);
  }
}
.popup-main .popup-text p {
  color: inherit;
}
.popup-main .popup__button {
  margin-bottom: 1.6rem;
}
@media screen and (min-width: 750px) {
  .popup-main .popup__button {
    margin-bottom: 2.4rem;
  }
}
.popup-main .popup__button:last-child {
  margin-bottom: 0;
}
.popup-main .list-social__item {
  transition: opacity var(--duration-default);
}
.popup-main .list-social__item:hover {
  opacity: 0.7;
}
@media (min-width: 750px) {
  .popup-main .popup-outer {
    flex-direction: row;
  }
}
.popup-main .popup-thumbnail {
  flex: 1 0 47%;
  display: flex;
  overflow: hidden;
  z-index: 1;
}
.popup-main .popup-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.popup-main .popup-content {
  padding: 28px;
  flex: 1 0 53%;
  order: 2;
}
@media screen and (min-width: 576px) {
  .popup-main .popup-content {
    padding: 56px;
  }
}
.popup-main .popup-content:first-child:last-child {
  flex: 1 0 100%;
}
.popup-main .popup-content::before {
  content: "";
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(var(--color-overlay), var(--opacity));
  border-radius: 1.2rem;
}
.popup-main .popup-content .modal-close-button {
  background-color: rgb(var(--color-background-secondary));
}
.popup-main .popup-content_bg .modal-close-button {
  background-color: rgb(var(--color-foreground), 0.12);
  box-shadow: none;
}
.popup-main .popup-content--center {
  text-align: center;
}
.popup-main .popup-content--center .list-social {
  justify-content: center;
}
.popup-main .popup-content--center .popup-description {
  margin-left: auto;
  margin-right: auto;
}
.popup-main .popup-content--right {
  text-align: right;
}
.popup-main .popup-content--right .list-social {
  justify-content: flex-end;
}
.popup-main .popup-content--right .popup-description {
  margin-left: auto;
}
.popup-main .popup-wrap.color-background-3 .popup-content .modal-close-button {
  background-color: rgb(var(--color-foreground), 0.12);
  box-shadow: none;
}
.popup-main--no-image .popup-content {
  padding: 28px;
}
@media screen and (min-width: 990px) {
  .popup-main--no-image .popup-content {
    padding: 56px;
  }
}
@media (min-width: 576px) {
  .popup-main-image--right .popup-outer {
    flex-direction: row-reverse;
  }
}
.popup-main-image--top .popup-outer {
  flex-direction: column;
}
.popup-main-image--top .popup-thumbnail {
  position: relative;
  padding-bottom: 43%;
}
.popup-main-image--top .popup-thumbnail img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.popup-main-image--bottom .popup-outer {
  flex-direction: column-reverse;
}
.popup-main-image--bottom .popup-content {
  padding-top: 6.4rem;
}
.popup-main-image--bottom .popup-thumbnail {
  position: relative;
  padding-bottom: 43%;
}
.popup-main-image--bottom .popup-thumbnail img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.popup-main .newsletter-form .newsletter-form__inner {
  background-color: transparent;
}
.popup-main .newsletter-form .field,
.popup-main .newsletter-form .button {
  min-height: 4.8rem;
}
.popup-main .newsletter-form .button {
  max-width: 100%;
  width: 100%;
}
@media screen and (min-width: 576px) {
  .popup-main .newsletter-form .newsletter-form__inner {
    position: relative;
  }
  .popup-main .newsletter-form .button {
    position: absolute;
    top: 50%;
    right: 0.6rem;
    min-height: 4.8rem;
    transform: translateY(-50%);
    width: auto;
  }
  .popup-main .newsletter-form .field__input {
    min-height: 6rem;
    padding-right: 15rem;
  }
}
.popup-main .newsletter-form__inner {
  display: flex;
  gap: 0.8rem;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
}
@media screen and (min-width: 576px) {
  .popup-main .newsletter-form__inner:not(.newsletter-form__inner_column) {
    flex-direction: row;
  }
}
.popup-main .newsletter-form__field-wrapper {
  flex: 1;
  width: 100%;
}
.popup-main .list-social {
  margin-left: -0.6rem;
  margin-bottom: 0.8rem;
  /*@media screen and (max-width: 989px) {
  	&:first-child {
  		margin-right: 4rem;
  	}
  }*/
}
.popup-main .list-social:last-child {
  margin-bottom: 0;
}
.popup-main .list-social:empty {
  display: none;
}

.notification-banner {
  border-radius: 1.2rem;
}
.notification-banner .popup-outer {
  padding: 28px;
  background-color: rgb(var(--color-background));
}
.notification-banner .popup-outer_bg .modal-close-button {
  background-color: rgb(var(--color-foreground), 0.12);
  box-shadow: none;
}
.notification-banner .popup-heading {
  margin: 0;
  font-size: calc(var(--font-notification-heading-scale) * 2rem);
}
.notification-banner .popup-heading + .popup-text {
  margin-top: 0.8rem;
}
.notification-banner .popup-text {
  padding-right: 1rem;
  font-size: calc(var(--font-notification-text-scale) * 1.3rem);
}
.notification-banner .popup-button {
  width: 100%;
  margin-top: 1.6rem;
}
.notification-banner--box .popup-close {
  top: 1rem;
  right: 1rem;
}
.notification-banner--bar.popup--top {
  width: 100%;
  max-width: 100%;
  top: 0;
  left: 0;
  bottom: auto;
  transform: none;
}
.notification-banner--bar.popup--top .popup-wrap {
  border-radius: 0;
}
.notification-banner--bar.popup--bottom {
  width: 100%;
  max-width: 100%;
  top: auto;
  left: 0;
  bottom: 0;
  transform: none;
}
.notification-banner--bar.popup--bottom .popup-wrap {
  border-radius: 0;
}
.notification-banner--bar .popup-outer {
  padding-top: 28px;
  padding-bottom: 28px;
  padding-left: 37.3333333333px;
  padding-right: 37.3333333333px;
}
.notification-banner--bar .popup-close {
  top: 1rem;
  right: 1rem;
}
@media (min-width: 750px) {
  .notification-banner--bar .popup-outer {
    justify-content: center;
    align-items: center;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 1.6rem 2.4rem;
    margin: 0 auto;
  }
  .notification-banner--bar .popup-close {
    top: 50%;
    transform: translateY(-50%);
    right: 1rem;
  }
  .notification-banner--bar .button {
    margin-top: 0;
    width: auto;
  }
}
.notification-banner--banner .popup-outer {
  flex-direction: row;
  align-items: center;
  flex-wrap: wrap;
  padding: 0.2rem;
}
.notification-banner--banner .popup-outer-image--right {
  flex-direction: row-reverse;
}
.notification-banner--banner .popup-outer-image--top {
  flex-direction: column;
}
.notification-banner--banner .popup-outer-image--bottom {
  flex-direction: column-reverse;
}
.notification-banner--banner .popup-outer-image--top .notification-banner__image, .notification-banner--banner .popup-outer-image--bottom .notification-banner__image {
  position: relative;
  padding-bottom: 55%;
}
.notification-banner--banner .popup-outer-image--top .notification-banner__image img, .notification-banner--banner .popup-outer-image--bottom .notification-banner__image img {
  position: absolute;
  inset: 0;
}
.notification-banner--banner .popup-button {
  width: auto;
  width: 100%;
  max-width: 18rem;
  padding-left: 1rem;
  padding-right: 1rem;
}
.notification-banner--banner .notification-banner__image {
  flex: 1 35%;
  min-width: 7.6rem;
  align-self: stretch;
  display: flex;
  border-radius: 1.2rem;
  overflow: hidden;
}
.notification-banner--banner .notification-banner__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.notification-banner--banner .notification-banner__content {
  flex: 1 65%;
  padding: 2.4rem 3.2rem 2.4rem 2.4rem;
}
.notification-banner--banner .popup-close,
.notification-banner--banner .popup-outer_bg .modal-close-button {
  top: 0;
  right: 0;
  box-shadow: none;
  background-color: transparent;
}

.age-verification {
  position: fixed;
  inset: 0;
  -webkit-backface-visibility: hidden;
  width: 100vw;
  height: 100vh;
  max-width: unset;
  max-height: unset;
  padding: 2.4rem;
  background-color: rgb(var(--color-background));
}
@media screen and (min-width: 750px) {
  .age-verification {
    padding: 6.4rem;
  }
}
.age-verification .popup-text p {
  text-align: center;
  font-size: 1.6rem;
}
@media screen and (min-width: 576px) {
  .age-verification .popup-text p {
    font-size: 1.8rem;
  }
}
.age-verification__wrapper {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 100%;
  box-shadow: none;
}
.age-verification__content {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.age-verification__question {
  display: none;
}
.age-verification__question.show {
  display: block;
}
.age-verification__heading {
  margin-top: 0;
  margin-bottom: 1.6rem;
  text-align: center;
}
.age-verification__buttons {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.8rem;
  margin-top: 3.2rem;
}
@media screen and (min-width: 576px) {
  .age-verification__buttons {
    flex-direction: row;
  }
}
@media screen and (min-width: 750px) {
  .age-verification__buttons {
    margin-top: 4rem;
  }
}
.age-verification__buttons .button {
  min-width: 12rem;
}
.age-verification__declined {
  display: none;
}
.age-verification__declined.show {
  display: block;
}

@media (prefers-color-scheme: light) {
  .popup .popup-outer {
    background: var(--background);
  }
}
[data-scheme=light] .popup .popup-outer {
  background: var(--background);
}

@media (prefers-color-scheme: dark) {
  .popup .popup-outer {
    background: #353535;
  }
}
[data-scheme=dark] .popup .popup-outer {
  background: #353535;
}
/* HARD OVERRIDE — Animated Image Collage: make images NOT round */
.aic .aic__slide,
.aic .aic__slide::before,
.aic .aic__slide::after,
.aic .aic__image,
.aic .aic__image::before,
.aic .aic__image::after,
.aic .aic__image img,
.aic .aic__image source,
.aic picture.aic__image {
  border-radius: 12px !important;
  clip-path: none !important;
  -webkit-clip-path: none !important;
  mask-image: none !important;
  overflow: visible !important;
}
/* Masquer la recherche dans le header */
.header__search,
predictive-search,
.header__icon--search {
  display: none !important;
}
/* Masquer l’icône panier */
.header__icon--cart,
a[href="/cart"] {
  display: none !important;
}

/* Masquer le drawer panier (sécurité) */
cart-drawer {
  display: none !important;
}



/* =================== AJOURS DEV ======================== */
@media(min-width:750px){
  .header-nav-center{
    margin-left:auto;
  }
  .header-nav-btn-style ul:not(.header__submenu) > li > a.list-menu__item {
    border: 1px solid;
    border-radius: 20px;
    min-height: 3.5rem !important;
  }
  .header-nav-btn-style ul:not(.header__submenu) > li > a.list-menu__item:hover {
    background:#ff0541;
  }
  .header-nav-btn-style ul:not(.header__submenu) > li > a.list-menu__item:hover span {
    background: transparent;
    color:white;
  }
  .menu-nav-btn{
    min-height: 3.5rem !important;
  }
  .steps__content--scroll .step__info, .steps__content--collapsible .step__toggle-content{
    max-width:none !important;
  }
}
@media(min-width:1100px){
  .menu-nav-btn{
    margin-left:auto;
  }
}
@media(max-width:750px){
  .menu-nav-btn{
    display:none;
  }
}

/* ===========================================
   ABOUT SECTION
   =========================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

.about-section {
  --about-bg: hsl(0 0% 99%);
  --about-bg-end: hsl(0 0% 100%);
  --about-charcoal: hsl(0 0% 8%);
  --about-gold: hsl(38 35% 55%);
  --about-gold-40: hsl(38 35% 55% / 0.4);
  --about-muted: hsl(0 0% 45%);
  --about-border: hsl(0 0% 90%);
  --about-border-30: hsl(0 0% 90% / 0.3);
  --about-cream-50: hsl(45 30% 97% / 0.5);
  --about-mint: hsl(160 60% 45%);
  --about-mint-40: hsl(160 60% 45% / 0.4);
  --about-navy: hsl(220 30% 18%);
  --about-navy-20: hsl(220 30% 18% / 0.2);
}

.about-section {
  position: relative;
  padding: 96px 0;
  background: linear-gradient(to bottom, var(--about-bg), var(--about-bg-end));
  overflow: hidden;
}

/* ===========================================
   BRANDING VERTICAL TEXT - LEFT (RYSE)
   =========================================== */
.about-brand-left {
  position: absolute;
  left: -30px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
}

.about-brand-text-left {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 28vw;
  font-weight: 700;
  color: var(--about-charcoal);
  opacity: 0.03;
  line-height: 0.85;
  letter-spacing: -0.05em;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  user-select: none;
}

@media (min-width: 768px) {
  .about-brand-left {
    left: -20px;
  }
  
  .about-brand-text-left {
    font-size: 22vw;
  }
}

@media (min-width: 1024px) {
  .about-brand-left {
    left: -10px;
  }
  
  .about-brand-text-left {
    font-size: 18vw;
  }
}

@media (min-width: 1400px) {
  .about-brand-text-left {
    font-size: 250px;
  }
}

/* ===========================================
   BRANDING VERTICAL TEXT - RIGHT (AGENCY)
   =========================================== */
.about-brand-right {
  position: absolute;
  right: -30px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
}

.about-brand-text-right {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 28vw;
  font-weight: 700;
  color: var(--about-charcoal);
  opacity: 0.03;
  line-height: 0.85;
  letter-spacing: -0.05em;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transform: rotate(180deg);
  user-select: none;
}

@media (min-width: 768px) {
  .about-brand-right {
    right: -20px;
  }
  
  .about-brand-text-right {
    font-size: 22vw;
  }
}

@media (min-width: 1024px) {
  .about-brand-right {
    right: -10px;
  }
  
  .about-brand-text-right {
    font-size: 18vw;
  }
}

@media (min-width: 1400px) {
  .about-brand-text-right {
    font-size: 250px;
  }
}

/* ===========================================
   DECORATIVE DOTS
   =========================================== */
.about-dots {
  position: absolute;
  display: flex;
  flex-direction: column;
  gap: 8px;
  z-index: 5;
}

.about-dots--top-left {
  left: 16px;
  top: 40px;
}

.about-dots--bottom-right {
  right: 16px;
  bottom: 40px;
}

@media (min-width: 1024px) {
  .about-dots--top-left {
    left: 32px;
    top: 80px;
  }
  
  .about-dots--bottom-right {
    right: 32px;
    bottom: 80px;
  }
}

.about-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
}

@media (min-width: 1024px) {
  .about-dot {
    width: 8px;
    height: 8px;
  }
}

.about-dot--gold {
  background-color: var(--about-gold-40);
}

.about-dot--mint {
  background-color: var(--about-mint-40);
}

.about-dot--navy {
  background-color: var(--about-navy-20);
}

/* ===========================================
   CONTAINER
   =========================================== */
.about-container {
  position: relative;
  z-index: 10;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}

@media (min-width: 1024px) {
  .about-container {
    padding: 0 48px;
  }
}

/* ===========================================
   HEADER
   =========================================== */
.about-header {
  margin-bottom: 48px;
  opacity: 0;
  transform: translateY(20px);
  animation: aboutFadeIn 0.6s ease forwards;
}

@keyframes aboutFadeIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.about-label {
  display: block;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--about-gold);
  margin-bottom: 16px;
}

.about-main-title {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 32px;
  font-weight: 600;
  color: var(--about-charcoal);
  line-height: 1.2;
  letter-spacing: -0.02em;
}

@media (min-width: 768px) {
  .about-main-title {
    font-size: 42px;
  }
}

@media (min-width: 1024px) {
  .about-main-title {
    font-size: 48px;
  }
}

/* ===========================================
   TABS LAYOUT
   =========================================== */
.about-tabs-wrapper {
  display: flex;
  flex-direction: column;
  gap: 32px;
  opacity: 0;
  transform: translateY(20px);
  animation: aboutFadeIn 0.6s ease forwards;
  animation-delay: 0.2s;
}

@media (min-width: 768px) {
  .about-tabs-wrapper {
    flex-direction: row;
    gap: 32px;
  }
}

/* ===========================================
   TABS NAV
   =========================================== */
.about-tabs-nav {
  display: flex;
  flex-direction: row;
  gap: 8px;
  flex-shrink: 0;
}

@media (min-width: 768px) {
  .about-tabs-nav {
    flex-direction: column;
    width: 208px;
  }
}

.about-tab-btn {
  position: relative;
  padding: 12px 16px;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 14px;
  font-weight: 500;
  text-align: left;
  color: var(--about-muted);
  background: transparent;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.3s ease;
  white-space: nowrap;
}

.about-tab-btn:hover {
  color: var(--about-charcoal);
  background-color: hsl(0 0% 100% / 0.5);
}

.about-tab-btn.is-active {
  color: var(--about-charcoal);
  background-color: hsl(0 0% 100%);
  box-shadow: 0 4px 12px -2px hsl(0 0% 0% / 0.08);
  border: 1px solid var(--about-border-30);
}

.about-tab-indicator {
  display: none;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 24px;
  background: linear-gradient(to bottom, var(--about-navy), var(--about-gold));
  border-radius: 4px;
}

@media (min-width: 768px) {
  .about-tab-btn.is-active .about-tab-indicator {
    display: block;
  }
}

/* ===========================================
   TAB CONTENT
   =========================================== */
.about-tab-content {
  flex: 1;
  background-color: hsl(0 0% 100%);
  border-radius: 16px;
  padding: 32px;
  box-shadow: 0 2px 8px -2px hsl(0 0% 0% / 0.05);
  border: 1px solid var(--about-border-30);
}

.about-content-title {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 24px;
  font-weight: 500;
  color: var(--about-charcoal);
  margin-bottom: 24px;
  line-height: 1.3;
}

@media (min-width: 768px) {
  .about-content-title {
    font-size: 28px;
  }
}

@media (min-width: 1024px) {
  .about-content-title {
    font-size: 30px;
  }
}

.about-content-text {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.7;
  color: var(--about-muted);
  margin-bottom: 32px;
}

@media (min-width: 768px) {
  .about-content-text {
    font-size: 18px;
  }
}

/* ===========================================
   BADGES
   =========================================== */
.about-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.about-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background-color: var(--about-cream-50);
  border: 1px solid var(--about-border-30);
  border-radius: 9999px;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 12px;
  font-weight: 500;
  color: var(--about-charcoal);
  transition: box-shadow 0.3s ease;
}

.about-badge:hover {
  box-shadow: 0 2px 8px -2px hsl(0 0% 0% / 0.1);
}

.about-badge-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.about-badge-dot--mint {
  background-color: var(--about-mint);
}

.about-badge-dot--gold {
  background-color: var(--about-gold);
}

.about-badge-dot--navy {
  background-color: var(--about-navy);
}

/* ===========================================
   MOBILE ADJUSTMENTS
   =========================================== */
@media (max-width: 767px) {
  .about-section {
    padding: 64px 0;
  }
  
  .about-header {
    margin-bottom: 32px;
  }
  
  .about-main-title {
    font-size: 28px;
  }
  
  .about-tabs-nav {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 8px;
  }
  
  .about-tab-content {
    padding: 24px;
  }
  
  .about-content-title {
    font-size: 22px;
  }
  
  .about-content-text {
    font-size: 15px;
  }
}

/* ============================================
   AGENCE SHOPIFY LOCALE PAGE - CSS
   Design System RYSE Agency
   Fichier: assets/agence-shopify-locale.css
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  --agl-charcoal: hsl(0, 0%, 8%);
  --agl-charcoal-light: hsl(220, 15%, 20%);
  --agl-gold: hsl(43, 50%, 60%);
  --agl-gold-65: hsl(43, 50%, 65%);
  --agl-gold-light: hsl(38, 35%, 55%);
  --agl-mint: hsl(160, 60%, 45%);
  --agl-mint-text: hsl(160, 60%, 35%);
  --agl-cream: hsl(40, 33%, 98%);
  --agl-cream-dark: hsl(38, 25%, 92%);
  --agl-navy: hsl(220, 15%, 8%);
  --agl-navy-gradient: hsl(220, 20%, 18%);
  --agl-text-dark: hsl(220, 15%, 12%);
  --agl-text-muted: hsl(220, 10%, 45%);
  --agl-bg-light: #fcfcfc;
  --agl-bg-white: #ffffff;
  --agl-border-light: hsl(0, 0%, 90%);
  --agl-font: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
}

@keyframes aglFadeIn {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
.animate-fade-in { animation: aglFadeIn 0.6s ease forwards; }
.animation-delay-100 { animation-delay: 0.1s; opacity: 0; }
.animation-delay-200 { animation-delay: 0.2s; opacity: 0; }

/* HERO */
.agl-hero {
  position: relative;
  padding: 96px 0;
  background-color: var(--agl-navy);
  overflow: hidden;
}
@media (min-width: 1024px) { .agl-hero { padding: 128px 0; } }
.agl-hero__noise {
  position: absolute;
  inset: 0;
  opacity: 0.04;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
}
.agl-hero__glow {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.agl-hero__glow--gold {
  top: 0;
  left: 25%;
  width: 500px;
  height: 500px;
  background: var(--agl-gold);
  filter: blur(200px);
  opacity: 0.1;
}
.agl-hero__glow--blue {
  bottom: 0;
  right: 25%;
  width: 400px;
  height: 400px;
  background: hsl(220, 60%, 50%);
  filter: blur(180px);
  opacity: 0.06;
}
.agl-hero__container {
  position: relative;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
  text-align: center;
}
@media (min-width: 1024px) { .agl-hero__container { padding: 0 48px; } }
.agl-hero__label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 9999px;
  background-color: hsla(43, 50%, 60%, 0.15);
  color: var(--agl-gold-65);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: 24px;
  font-family: var(--agl-font);
}
.agl-hero__label-icon { width: 14px; height: 14px; }
.agl-hero__title {
  font-family: var(--agl-font);
  font-size: 32px;
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1.15;
  color: var(--agl-cream);
  margin: 0 0 16px 0;
}
@media (min-width: 640px) { .agl-hero__title { font-size: 38px; } }
@media (min-width: 768px) { .agl-hero__title { font-size: 46px; } }
@media (min-width: 1024px) { .agl-hero__title { font-size: 52px; } }
.agl-hero__subtitle {
  display: block;
  color: hsla(40, 33%, 98%, 0.6);
  font-weight: 300;
  font-style: italic;
  font-size: 0.5em;
  margin-top: 12px;
}
.agl-hero__description {
  font-family: var(--agl-font);
  font-size: 15px;
  line-height: 1.7;
  color: hsla(40, 33%, 98%, 0.7);
  max-width: 680px;
  margin: 0 auto 48px;
}
@media (min-width: 768px) { .agl-hero__description { font-size: 17px; } }
.agl-hero__description strong { color: var(--agl-cream); }
.agl-hero__stats {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 32px;
}
@media (min-width: 768px) { .agl-hero__stats { gap: 48px; } }
.agl-hero__stat {
  display: flex;
  align-items: center;
  gap: 12px;
}
.agl-hero__stat-icon {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  background-color: hsla(43, 50%, 60%, 0.15);
  display: flex;
  align-items: center;
  justify-content: center;
}
.agl-hero__stat-icon svg {
  width: 20px;
  height: 20px;
  color: var(--agl-gold);
}
.agl-hero__stat-content { text-align: left; }
.agl-hero__stat-value {
  display: block;
  font-size: 20px;
  font-weight: 600;
  color: var(--agl-cream);
  letter-spacing: -0.02em;
  font-family: var(--agl-font);
}
@media (min-width: 768px) { .agl-hero__stat-value { font-size: 24px; } }
.agl-hero__stat-label {
  font-size: 12px;
  color: hsla(40, 33%, 98%, 0.6);
  font-family: var(--agl-font);
}

/* TRUST */
.agl-trust {
  position: relative;
  padding: 40px 0;
  background-color: var(--agl-bg-white);
  border-bottom: 1px solid hsla(220, 15%, 12%, 0.1);
}
.agl-trust__noise {
  position: absolute;
  inset: 0;
  opacity: 0.03;
  pointer-events: none;
  z-index: 1;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
}
.agl-trust__container {
  position: relative;
  z-index: 2;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (min-width: 1024px) { .agl-trust__container { padding: 0 48px; } }
.agl-trust__badges {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 32px;
}
@media (min-width: 640px) { .agl-trust__badges { flex-direction: row; } }
.agl-trust__badge {
  display: flex;
  align-items: center;
  gap: 12px;
}
.agl-trust__badge-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.agl-trust__badge-icon--dark {
  background-color: var(--agl-text-dark);
}
.agl-trust__badge-icon--dark span {
  color: var(--agl-cream);
  font-weight: 700;
  font-size: 14px;
  font-family: var(--agl-font);
}
.agl-trust__badge-icon--gold {
  background-color: var(--agl-gold);
}
.agl-trust__badge-icon--gold svg {
  width: 24px;
  height: 24px;
  color: var(--agl-text-dark);
}
.agl-trust__badge-icon--mint {
  background-color: var(--agl-mint);
}
.agl-trust__badge-icon--mint svg {
  width: 24px;
  height: 24px;
  color: white;
}
.agl-trust__badge-text {
  font-size: 14px;
  font-weight: 500;
  color: var(--agl-text-muted);
  font-family: var(--agl-font);
}

/* AEO */
.agl-aeo {
  padding: 80px 0;
  background-color: var(--agl-bg-light);
}
@media (min-width: 1024px) { .agl-aeo { padding: 112px 0; } }
.agl-aeo__container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (min-width: 1024px) { .agl-aeo__container { padding: 0 48px; } }
.agl-aeo__header {
  text-align: center;
  margin-bottom: 64px;
}
.agl-aeo__label {
  display: block;
  font-family: var(--agl-font);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--agl-gold-light);
  margin-bottom: 16px;
}
.agl-aeo__title {
  font-family: var(--agl-font);
  font-size: 32px;
  font-weight: 600;
  color: var(--agl-text-dark);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0 0 24px 0;
}
@media (min-width: 768px) { .agl-aeo__title { font-size: 48px; } }
.agl-aeo__description {
  color: var(--agl-text-muted);
  font-size: 18px;
  max-width: 900px;
  margin: 0 auto;
  font-family: var(--agl-font);
  line-height: 1.6;
}
.agl-aeo__grid {
  display: grid;
  gap: 24px;
}
@media (min-width: 768px) { .agl-aeo__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .agl-aeo__grid { grid-template-columns: repeat(3, 1fr); } }
.agl-aeo__card {
  padding: 24px;
  border-radius: 16px;
  background-color: var(--agl-bg-white);
  border: 1px solid var(--agl-border-light);
  box-shadow: 0 4px 24px -4px hsla(220, 15%, 12%, 0.04);
  transition: all 0.3s ease;
}
.agl-aeo__card:hover {
  box-shadow: 0 8px 32px -4px hsla(220, 15%, 12%, 0.08);
  border-color: hsla(38, 35%, 55%, 0.2);
}
.agl-aeo__card-icon {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  background-color: var(--agl-cream-dark);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
}
.agl-aeo__card-icon svg {
  width: 20px;
  height: 20px;
  color: var(--agl-gold-light);
}
.agl-aeo__card-title {
  font-family: var(--agl-font);
  font-size: 18px;
  font-weight: 600;
  color: var(--agl-text-dark);
  margin: 0 0 12px 0;
  line-height: 1.3;
}
.agl-aeo__card-text {
  color: var(--agl-text-muted);
  font-size: 14px;
  line-height: 1.7;
  font-family: var(--agl-font);
  margin: 0;
}

/* SERVICES */
.agl-services {
  padding: 80px 0;
  background-color: var(--agl-bg-white);
}
@media (min-width: 1024px) { .agl-services { padding: 112px 0; } }
.agl-services__container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (min-width: 1024px) { .agl-services__container { padding: 0 48px; } }
.agl-services__header {
  text-align: center;
  margin-bottom: 64px;
}
.agl-services__label {
  display: block;
  font-family: var(--agl-font);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--agl-gold-light);
  margin-bottom: 16px;
}
.agl-services__title {
  font-family: var(--agl-font);
  font-size: 32px;
  font-weight: 600;
  color: var(--agl-text-dark);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0 0 24px 0;
}
@media (min-width: 768px) { .agl-services__title { font-size: 48px; } }
.agl-services__description {
  color: var(--agl-text-muted);
  font-size: 18px;
  max-width: 900px;
  margin: 0 auto;
  font-family: var(--agl-font);
  line-height: 1.6;
}
.agl-services__grid {
  display: grid;
  gap: 24px;
}
@media (min-width: 768px) { .agl-services__grid { grid-template-columns: repeat(2, 1fr); gap: 32px; } }
.agl-services__card {
  position: relative;
  padding: 32px;
  border-radius: 16px;
  background-color: var(--agl-bg-light);
  border: 1px solid var(--agl-border-light);
  box-shadow: 0 4px 24px -4px hsla(220, 15%, 12%, 0.06);
  transition: all 0.3s ease;
  text-decoration: none;
  display: block;
}
.agl-services__card:hover {
  box-shadow: 0 12px 40px -8px hsla(220, 15%, 12%, 0.12);
  border-color: hsla(38, 35%, 55%, 0.3);
  transform: translateY(-4px);
}
.agl-services__card-icon {
  width: 56px;
  height: 56px;
  border-radius: 12px;
  background-color: var(--agl-cream-dark);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24px;
  transition: background-color 0.3s ease;
}
.agl-services__card:hover .agl-services__card-icon {
  background-color: hsla(38, 35%, 55%, 0.15);
}
.agl-services__card-icon svg {
  width: 28px;
  height: 28px;
  color: var(--agl-gold-light);
}
.agl-services__card-title {
  font-family: var(--agl-font);
  font-size: 20px;
  font-weight: 600;
  color: var(--agl-text-dark);
  margin: 0 0 12px 0;
}
.agl-services__card-description {
  color: var(--agl-text-muted);
  font-size: 15px;
  line-height: 1.7;
  margin: 0 0 24px 0;
  font-family: var(--agl-font);
}
.agl-services__card-features {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}
.agl-services__card-feature {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 9999px;
  background-color: hsla(160, 60%, 45%, 0.08);
  color: var(--agl-mint-text);
  font-size: 12px;
  font-weight: 500;
  font-family: var(--agl-font);
}
.agl-services__card-feature svg { width: 12px; height: 12px; }
.agl-services__card-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--agl-gold-light);
  font-weight: 500;
  font-size: 14px;
  font-family: var(--agl-font);
  transition: gap 0.3s ease;
}
.agl-services__card:hover .agl-services__card-cta { gap: 10px; }
.agl-services__card-cta svg { width: 16px; height: 16px; }
.agl-services__cta {
  text-align: center;
  margin-top: 48px;
}
.agl-services__cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  border-radius: 9999px;
  background-color: var(--agl-text-dark);
  color: white;
  font-weight: 500;
  font-size: 14px;
  font-family: var(--agl-font);
  text-decoration: none;
  transition: all 0.3s ease;
}
.agl-services__cta-btn:hover {
  background-color: var(--agl-charcoal-light);
  transform: translateY(-2px);
}
.agl-services__cta-btn svg { width: 16px; height: 16px; }

/* WHY */
.agl-why {
  padding: 80px 0;
  background-color: var(--agl-bg-light);
}
@media (min-width: 1024px) { .agl-why { padding: 112px 0; } }
.agl-why__container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (min-width: 1024px) { .agl-why__container { padding: 0 48px; } }
.agl-why__grid {
  display: grid;
  gap: 64px;
  align-items: center;
}
@media (min-width: 1024px) { .agl-why__grid { grid-template-columns: 1fr 1fr; } }
.agl-why__label {
  display: block;
  font-family: var(--agl-font);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--agl-gold-light);
  margin-bottom: 16px;
}
.agl-why__title {
  font-family: var(--agl-font);
  font-size: 32px;
  font-weight: 600;
  color: var(--agl-text-dark);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0 0 24px 0;
}
@media (min-width: 768px) { .agl-why__title { font-size: 48px; } }
.agl-why__description {
  color: var(--agl-text-muted);
  font-size: 18px;
  line-height: 1.6;
  margin: 0 0 32px 0;
  font-family: var(--agl-font);
}
.agl-why__reasons {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.agl-why__reason {
  display: flex;
  gap: 16px;
}
.agl-why__reason-icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background-color: hsla(160, 60%, 45%, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 4px;
}
.agl-why__reason-icon svg {
  width: 16px;
  height: 16px;
  color: var(--agl-mint);
}
.agl-why__reason-title {
  font-family: var(--agl-font);
  font-size: 18px;
  font-weight: 600;
  color: var(--agl-text-dark);
  margin: 0 0 4px 0;
}
.agl-why__reason-description {
  color: var(--agl-text-muted);
  font-size: 15px;
  line-height: 1.6;
  font-family: var(--agl-font);
  margin: 0;
}
.agl-why__visual { position: relative; }
.agl-why__card {
  position: relative;
  background: linear-gradient(to bottom right, var(--agl-text-dark), var(--agl-navy-gradient));
  border-radius: 24px;
  padding: 32px;
  overflow: hidden;
}
@media (min-width: 768px) { .agl-why__card { padding: 48px; } }
.agl-why__card-glow {
  position: absolute;
  top: 0;
  right: 0;
  width: 256px;
  height: 256px;
  background-color: var(--agl-gold-light);
  border-radius: 50%;
  filter: blur(100px);
  opacity: 0.1;
}
.agl-why__card-content { position: relative; z-index: 10; }
.agl-why__card-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 32px;
}
.agl-why__card-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background-color: hsla(38, 35%, 55%, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
}
.agl-why__card-icon svg {
  width: 24px;
  height: 24px;
  color: var(--agl-gold-light);
}
.agl-why__card-city {
  color: hsla(45, 20%, 96%, 1);
  font-weight: 600;
  font-family: var(--agl-font);
}
.agl-why__card-region {
  color: hsla(45, 20%, 96%, 0.6);
  font-size: 14px;
  font-family: var(--agl-font);
}
.agl-why__card-rows {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.agl-why__card-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 16px;
  border-bottom: 1px solid hsla(45, 20%, 96%, 0.1);
}
.agl-why__card-row--last { border-bottom: none; padding-bottom: 0; }
.agl-why__card-row-label {
  color: hsla(45, 20%, 96%, 0.7);
  font-family: var(--agl-font);
}
.agl-why__card-row-value {
  color: hsla(45, 20%, 96%, 1);
  font-weight: 500;
  font-family: var(--agl-font);
}
.agl-why__card-row-value--mint { color: var(--agl-mint); }
.agl-why__card-row-value--gold { color: var(--agl-gold-light); }
.agl-why__card-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  margin-top: 32px;
  padding: 14px 24px;
  border-radius: 8px;
  background-color: var(--agl-gold-light);
  color: var(--agl-text-dark);
  font-weight: 600;
  font-size: 14px;
  font-family: var(--agl-font);
  text-decoration: none;
  transition: all 0.3s ease;
}
.agl-why__card-btn:hover { background-color: hsl(38, 45%, 60%); }
.agl-why__card-btn svg { width: 16px; height: 16px; }

/* PROJECTS */
.agl-projects {
  padding: 80px 0;
  background-color: var(--agl-bg-white);
}
@media (min-width: 1024px) { .agl-projects { padding: 112px 0; } }
.agl-projects__container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (min-width: 1024px) { .agl-projects__container { padding: 0 48px; } }
.agl-projects__header {
  text-align: center;
  margin-bottom: 64px;
}
.agl-projects__label {
  display: block;
  font-family: var(--agl-font);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--agl-gold-light);
  margin-bottom: 16px;
}
.agl-projects__title {
  font-family: var(--agl-font);
  font-size: 32px;
  font-weight: 600;
  color: var(--agl-text-dark);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0 0 24px 0;
}
@media (min-width: 768px) { .agl-projects__title { font-size: 48px; } }
.agl-projects__description {
  color: var(--agl-text-muted);
  font-size: 18px;
  max-width: 672px;
  margin: 0 auto;
  font-family: var(--agl-font);
  line-height: 1.6;
}
.agl-projects__grid {
  display: grid;
  gap: 24px;
}
@media (min-width: 768px) { .agl-projects__grid { grid-template-columns: repeat(3, 1fr); gap: 32px; } }
.agl-projects__card {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: 16px;
  overflow: hidden;
  background-color: var(--agl-bg-white);
  box-shadow: 0 4px 24px -4px hsla(220, 15%, 12%, 0.08);
  transition: all 0.5s ease;
}
.agl-projects__card:hover {
  box-shadow: 0 12px 40px -8px hsla(220, 15%, 12%, 0.15);
  transform: translateY(-4px);
}
.agl-projects__card-image {
  position: absolute;
  inset: 0;
}
.agl-projects__card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.7s ease;
}
.agl-projects__card:hover .agl-projects__card-image img { transform: scale(1.05); }
.agl-projects__card-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, var(--agl-cream-dark), var(--agl-bg-light));
}
.agl-projects__card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, var(--agl-text-dark), hsla(220, 15%, 12%, 0.4) 50%, transparent);
  opacity: 0.9;
}
.agl-projects__card-badge {
  position: absolute;
  top: 16px;
  left: 16px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 9999px;
  background-color: var(--agl-bg-white);
  font-size: 12px;
  font-weight: 500;
  color: var(--agl-text-dark);
  font-family: var(--agl-font);
}
.agl-projects__card-badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
}
.agl-projects__card-badge-dot--gold { background-color: var(--agl-gold); }
.agl-projects__card-badge-dot--green { background-color: #10b981; }
.agl-projects__card-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 24px;
}
.agl-projects__card-industry {
  color: var(--agl-gold-light);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-family: var(--agl-font);
}
.agl-projects__card-name {
  color: white;
  font-size: 20px;
  font-weight: 600;
  margin: 4px 0 8px 0;
  font-family: var(--agl-font);
}
.agl-projects__card-description {
  color: hsla(45, 20%, 96%, 0.7);
  font-size: 14px;
  line-height: 1.5;
  margin: 0 0 12px 0;
  font-family: var(--agl-font);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.agl-projects__card-results {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--agl-mint);
  font-size: 14px;
  font-weight: 500;
  font-family: var(--agl-font);
}
.agl-projects__card-results svg { width: 16px; height: 16px; }
.agl-projects__cta {
  text-align: center;
  margin-top: 48px;
}
.agl-projects__cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  border-radius: 9999px;
  background-color: var(--agl-text-dark);
  color: white;
  font-weight: 500;
  font-size: 14px;
  font-family: var(--agl-font);
  text-decoration: none;
  transition: all 0.3s ease;
}
.agl-projects__cta-btn:hover {
  background-color: var(--agl-charcoal-light);
  transform: translateY(-2px);
}
.agl-projects__cta-btn svg { width: 16px; height: 16px; }

/* MIGRATION */
.agl-migration {
  padding: 80px 0;
  background-color: var(--agl-bg-light);
}
@media (min-width: 1024px) { .agl-migration { padding: 112px 0; } }
.agl-migration__container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (min-width: 1024px) { .agl-migration__container { padding: 0 48px; } }
.agl-migration__grid {
  display: grid;
  gap: 48px;
  align-items: center;
}
@media (min-width: 1024px) { .agl-migration__grid { grid-template-columns: 1fr 1fr; } }
.agl-migration__label {
  display: block;
  font-family: var(--agl-font);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--agl-gold-light);
  margin-bottom: 16px;
}
.agl-migration__title {
  font-family: var(--agl-font);
  font-size: 32px;
  font-weight: 600;
  color: var(--agl-text-dark);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0 0 24px 0;
}
@media (min-width: 768px) { .agl-migration__title { font-size: 42px; } }
.agl-migration__description {
  color: var(--agl-text-muted);
  font-size: 18px;
  line-height: 1.6;
  margin: 0 0 24px 0;
  font-family: var(--agl-font);
}
.agl-migration__description strong { color: var(--agl-text-dark); }
.agl-migration__text {
  color: var(--agl-text-muted);
  font-size: 15px;
  line-height: 1.6;
  margin: 0 0 32px 0;
  font-family: var(--agl-font);
}
.agl-migration__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 32px;
}
.agl-migration__tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 9999px;
  background-color: var(--agl-bg-white);
  border: 1px solid var(--agl-border-light);
  color: var(--agl-text-dark);
  font-size: 14px;
  font-weight: 500;
  font-family: var(--agl-font);
}
.agl-migration__tag svg {
  width: 16px;
  height: 16px;
  color: var(--agl-mint);
}
.agl-migration__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--agl-gold-light);
  font-weight: 500;
  font-family: var(--agl-font);
  text-decoration: none;
  transition: gap 0.3s ease;
}
.agl-migration__link:hover { gap: 12px; }
.agl-migration__link svg { width: 16px; height: 16px; }
.agl-migration__stats-card {
  position: relative;
  background: linear-gradient(to bottom right, var(--agl-text-dark), var(--agl-navy-gradient));
  border-radius: 24px;
  padding: 32px;
  overflow: hidden;
}
@media (min-width: 768px) { .agl-migration__stats-card { padding: 48px; } }
.agl-migration__stats-glow {
  position: absolute;
  top: 0;
  right: 0;
  width: 256px;
  height: 256px;
  background-color: var(--agl-mint);
  border-radius: 50%;
  filter: blur(100px);
  opacity: 0.1;
}
.agl-migration__stats-content {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.agl-migration__stat-value {
  font-size: 48px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.02em;
  font-family: var(--agl-font);
  margin: 0;
}
@media (min-width: 768px) { .agl-migration__stat-value { font-size: 56px; } }
.agl-migration__stat-value--white { color: hsla(45, 20%, 96%, 1); }
.agl-migration__stat-value--mint { color: var(--agl-mint); }
.agl-migration__stat-value--gold { color: var(--agl-gold-light); }
.agl-migration__stat-label {
  color: hsla(45, 20%, 96%, 0.6);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-top: 8px;
  font-family: var(--agl-font);
}
.agl-migration__stat-divider {
  height: 1px;
  background-color: hsla(45, 20%, 96%, 0.1);
}

/* PROCESS */
.agl-process {
  position: relative;
  padding: 80px 0;
  background-color: var(--agl-navy);
  overflow: hidden;
}
@media (min-width: 1024px) { .agl-process { padding: 112px 0; } }
.agl-process__noise {
  position: absolute;
  inset: 0;
  opacity: 0.03;
  pointer-events: none;
  z-index: 1;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
}
.agl-process__container {
  position: relative;
  z-index: 10;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (min-width: 1024px) { .agl-process__container { padding: 0 48px; } }
.agl-process__header {
  text-align: center;
  margin-bottom: 64px;
}
.agl-process__label {
  display: block;
  font-family: var(--agl-font);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--agl-gold-light);
  margin-bottom: 16px;
}
.agl-process__title {
  font-family: var(--agl-font);
  font-size: 32px;
  font-weight: 600;
  color: hsla(45, 20%, 96%, 1);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0;
}
@media (min-width: 768px) { .agl-process__title { font-size: 48px; } }
.agl-process__grid {
  display: grid;
  gap: 32px;
}
@media (min-width: 768px) { .agl-process__grid { grid-template-columns: repeat(4, 1fr); } }
.agl-process__step { position: relative; }
.agl-process__step-connector {
  display: none;
}
@media (min-width: 768px) {
  .agl-process__step-connector {
    display: block;
    position: absolute;
    top: 32px;
    left: 60%;
    width: 100%;
    height: 1px;
    background: linear-gradient(to right, hsla(38, 35%, 55%, 0.5), transparent);
  }
}
.agl-process__step-number {
  font-size: 56px;
  font-weight: 700;
  color: hsla(38, 35%, 55%, 0.3);
  line-height: 1;
  margin-bottom: 16px;
  font-family: var(--agl-font);
}
.agl-process__step-title {
  font-size: 20px;
  font-weight: 600;
  color: hsla(45, 20%, 96%, 1);
  margin: 0 0 8px 0;
  font-family: var(--agl-font);
}
.agl-process__step-description {
  color: hsla(45, 20%, 96%, 0.6);
  font-size: 15px;
  line-height: 1.6;
  margin: 0;
  font-family: var(--agl-font);
}

/* TESTIMONIALS */
.agl-testimonials {
  padding: 80px 0;
  background-color: var(--agl-bg-white);
}
@media (min-width: 1024px) { .agl-testimonials { padding: 112px 0; } }
.agl-testimonials__container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (min-width: 1024px) { .agl-testimonials__container { padding: 0 48px; } }
.agl-testimonials__header {
  text-align: center;
  margin-bottom: 64px;
}
.agl-testimonials__label {
  display: block;
  font-family: var(--agl-font);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--agl-gold-light);
  margin-bottom: 16px;
}
.agl-testimonials__title {
  font-family: var(--agl-font);
  font-size: 32px;
  font-weight: 600;
  color: var(--agl-text-dark);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0;
}
@media (min-width: 768px) { .agl-testimonials__title { font-size: 48px; } }
.agl-testimonials__grid {
  display: grid;
  gap: 32px;
}
@media (min-width: 768px) { .agl-testimonials__grid { grid-template-columns: repeat(2, 1fr); } }
.agl-testimonials__card {
  position: relative;
  padding: 32px;
  border-radius: 16px;
  background-color: var(--agl-bg-light);
  border: 1px solid var(--agl-border-light);
}
.agl-testimonials__stars {
  display: flex;
  gap: 4px;
  margin-bottom: 24px;
}
.agl-testimonials__stars svg {
  width: 20px;
  height: 20px;
  color: var(--agl-gold);
  fill: var(--agl-gold);
}
.agl-testimonials__quote {
  font-family: var(--agl-font);
  font-size: 18px;
  line-height: 1.7;
  color: var(--agl-text-dark);
  margin: 0 0 24px 0;
}
.agl-testimonials__author-name {
  font-weight: 600;
  color: var(--agl-text-dark);
  font-family: var(--agl-font);
}
.agl-testimonials__author-company {
  color: var(--agl-text-muted);
  font-size: 14px;
  font-family: var(--agl-font);
}
.agl-testimonials__trust {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin-top: 64px;
  padding-top: 48px;
  border-top: 1px solid hsla(220, 15%, 12%, 0.08);
}
@media (min-width: 768px) { .agl-testimonials__trust { gap: 40px; } }
.agl-testimonials__trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
}
.agl-testimonials__trust-stars {
  display: flex;
  gap: 2px;
}
.agl-testimonials__trust-stars svg {
  width: 14px;
  height: 14px;
  color: var(--agl-gold);
  fill: var(--agl-gold);
}
.agl-testimonials__trust-score {
  font-size: 13px;
  font-weight: 600;
  color: var(--agl-text-dark);
  font-family: var(--agl-font);
}
.agl-testimonials__trust-platform {
  font-size: 13px;
  color: var(--agl-text-muted);
  font-family: var(--agl-font);
}
.agl-testimonials__trust-reviews {
  font-size: 11px;
  color: hsla(220, 10%, 45%, 0.6);
  font-family: var(--agl-font);
}

/* LOCAL */
.agl-local {
  padding: 80px 0;
  background-color: var(--agl-bg-light);
}
@media (min-width: 1024px) { .agl-local { padding: 112px 0; } }
.agl-local__container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (min-width: 1024px) { .agl-local__container { padding: 0 48px; } }
.agl-local__grid {
  display: grid;
  gap: 48px;
  align-items: center;
}
@media (min-width: 1024px) { .agl-local__grid { grid-template-columns: 1fr 1fr; } }
.agl-local__label {
  display: block;
  font-family: var(--agl-font);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--agl-gold-light);
  margin-bottom: 16px;
}
.agl-local__title {
  font-family: var(--agl-font);
  font-size: 32px;
  font-weight: 600;
  color: var(--agl-text-dark);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0 0 24px 0;
}
@media (min-width: 768px) { .agl-local__title { font-size: 42px; } }
.agl-local__description {
  color: var(--agl-text-muted);
  font-size: 18px;
  line-height: 1.6;
  margin: 0 0 24px 0;
  font-family: var(--agl-font);
}
.agl-local__text {
  color: var(--agl-text-muted);
  font-size: 15px;
  line-height: 1.6;
  margin: 0 0 32px 0;
  font-family: var(--agl-font);
}
.agl-local__cities {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.agl-local__city {
  display: flex;
  align-items: center;
  gap: 8px;
}
.agl-local__city svg {
  width: 16px;
  height: 16px;
  color: var(--agl-gold-light);
}
.agl-local__city span {
  color: var(--agl-text-dark);
  font-size: 14px;
  font-family: var(--agl-font);
}
.agl-local__card {
  position: relative;
  background: linear-gradient(to bottom right, var(--agl-cream-dark), hsl(38, 20%, 95%));
  border-radius: 24px;
  padding: 32px;
}
@media (min-width: 768px) { .agl-local__card { padding: 48px; } }
.agl-local__card-icon {
  width: 64px;
  height: 64px;
  color: var(--agl-gold-light);
  margin-bottom: 24px;
}
.agl-local__card-title {
  font-size: 24px;
  font-weight: 600;
  color: var(--agl-text-dark);
  margin: 0 0 16px 0;
  font-family: var(--agl-font);
}
.agl-local__card-text {
  color: var(--agl-text-muted);
  font-size: 15px;
  line-height: 1.6;
  margin: 0 0 16px 0;
  font-family: var(--agl-font);
}
.agl-local__card-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  padding: 12px 24px;
  border-radius: 8px;
  background-color: var(--agl-text-dark);
  color: white;
  font-weight: 500;
  font-size: 14px;
  font-family: var(--agl-font);
  text-decoration: none;
  transition: all 0.3s ease;
}
.agl-local__card-btn:hover { background-color: var(--agl-charcoal-light); }
.agl-local__card-btn svg { width: 16px; height: 16px; }

/* FAQ */
.agl-faq {
  padding: 80px 0;
  background-color: var(--agl-bg-white);
}
@media (min-width: 1024px) { .agl-faq { padding: 112px 0; } }
.agl-faq__container {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 24px;
}
@media (min-width: 1024px) { .agl-faq__container { padding: 0 48px; } }
.agl-faq__header {
  text-align: center;
  margin-bottom: 64px;
}
.agl-faq__label {
  display: block;
  font-family: var(--agl-font);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--agl-gold-light);
  margin-bottom: 16px;
}
.agl-faq__title {
  font-family: var(--agl-font);
  font-size: 32px;
  font-weight: 600;
  color: var(--agl-text-dark);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0;
}
@media (min-width: 768px) { .agl-faq__title { font-size: 48px; } }
.agl-faq__items {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.agl-faq__item {
  border: 1px solid var(--agl-border-light);
  border-radius: 12px;
  overflow: hidden;
}
.agl-faq__question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 24px;
  background-color: var(--agl-bg-white);
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: var(--agl-font);
  font-size: 18px;
  font-weight: 500;
  color: var(--agl-text-dark);
  transition: background-color 0.3s ease;
}
.agl-faq__question:hover { background-color: hsl(0, 0%, 99%); }
.agl-faq__question-icon {
  width: 20px;
  height: 20px;
  color: var(--agl-gold-light);
  flex-shrink: 0;
  transition: transform 0.3s ease;
}
.agl-faq__item.is-open .agl-faq__question-icon { transform: rotate(90deg); }
.agl-faq__answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}
.agl-faq__answer p {
  padding: 0 24px 24px;
  margin: 0;
  color: var(--agl-text-muted);
  font-size: 15px;
  line-height: 1.7;
  font-family: var(--agl-font);
}

/* CTA */
.agl-cta {
  position: relative;
  padding: 96px 0;
  background-color: var(--agl-bg-light);
  overflow: hidden;
}
@media (min-width: 1024px) { .agl-cta { padding: 112px 0; } }
.agl-cta__noise {
  position: absolute;
  inset: 0;
  opacity: 0.03;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
}
.agl-cta__container {
  position: relative;
  max-width: 900px;
  margin: 0 auto;
  padding: 0 24px;
  text-align: center;
}
@media (min-width: 1024px) { .agl-cta__container { padding: 0 48px; } }
.agl-cta__label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 9999px;
  background-color: hsla(220, 15%, 12%, 0.05);
  color: var(--agl-text-muted);
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: 24px;
  font-family: var(--agl-font);
}
.agl-cta__title {
  font-family: var(--agl-font);
  font-size: 32px;
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1.1;
  color: var(--agl-text-dark);
  margin: 0 0 16px 0;
}
@media (min-width: 768px) { .agl-cta__title { font-size: 42px; } }
@media (min-width: 1024px) { .agl-cta__title { font-size: 50px; } }
.agl-cta__description {
  font-family: var(--agl-font);
  font-size: 15px;
  line-height: 1.6;
  color: var(--agl-text-muted);
  max-width: 560px;
  margin: 0 auto 40px;
}
@media (min-width: 768px) { .agl-cta__description { font-size: 17px; } }
.agl-cta__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 16px 32px;
  background-color: var(--agl-text-dark);
  color: white;
  font-family: var(--agl-font);
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  border-radius: 6px;
  text-decoration: none;
  transition: all 0.3s ease;
}
.agl-cta__button:hover {
  background-color: var(--agl-charcoal-light);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px -4px hsla(220, 15%, 12%, 0.3);
}
.agl-cta__button svg { width: 16px; height: 16px; transition: transform 0.3s ease; }
.agl-cta__button:hover svg { transform: translate(2px, -2px); }
.agl-cta__trust {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin-top: 48px;
  padding-top: 40px;
  border-top: 1px solid hsla(220, 15%, 12%, 0.08);
}
.agl-cta__trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
}
.agl-cta__trust-stars {
  display: flex;
  gap: 2px;
}
.agl-cta__trust-stars svg {
  width: 12px;
  height: 12px;
  color: var(--agl-gold);
  fill: var(--agl-gold);
}
.agl-cta__trust-score {
  font-size: 12px;
  font-weight: 500;
  color: var(--agl-text-dark);
  font-family: var(--agl-font);
}
.agl-cta__trust-platform {
  font-size: 12px;
  color: var(--agl-text-muted);
  font-family: var(--agl-font);
}
.agl-faq__question h3 {
  font-size: inherit;
  font-weight: inherit;
  margin: 0;
  padding: 0;
}
/* ===========================================
   BLOG / INSIGHTS SECTION
   =========================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

.blog-section {
  --blog-bg: hsl(0 0% 100%);
  --blog-charcoal: hsl(0 0% 8%);
  --blog-gold: hsl(38 35% 55%);
  --blog-muted: hsl(0 0% 40%);
  --blog-border: hsl(0 0% 90%);
}

.blog-section {
  padding: 48px 0;
  background-color: var(--blog-bg);
}

@media (min-width: 1024px) {
  .blog-section {
    padding: 64px 0;
  }
}

/* ===========================================
   CONTAINER
   =========================================== */
.blog-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
}

@media (min-width: 1024px) {
  .blog-container {
    padding: 0 48px;
  }
}

/* ===========================================
   HEADER
   =========================================== */
.blog-header {
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin-bottom: 24px;
  opacity: 0;
  transform: translateY(30px);
  animation: blogFadeIn 0.6s ease forwards;
}

@media (min-width: 768px) {
  .blog-header {
    flex-direction: row;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 32px;
  }
}

@keyframes blogFadeIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.blog-header-content {
  max-width: 600px;
}

.blog-label {
  display: inline-flex;
  align-items: center;
  padding: 0 0 6px 0;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--blog-muted);
  border-bottom: 1px solid currentColor;
  margin-bottom: 8px;
}

.blog-title {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 36px;
  font-weight: 500;
  color: var(--blog-charcoal);
  letter-spacing: -0.02em;
}

@media (min-width: 768px) {
  .blog-title {
    font-size: 48px;
  }
}

.blog-view-all {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: var(--blog-charcoal);
  text-decoration: none;
  position: relative;
}

.blog-view-all::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: currentColor;
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

.blog-view-all:hover::after {
  transform: scaleX(1);
  transform-origin: left;
}

.blog-view-all svg {
  width: 16px;
  height: 16px;
}

/* ===========================================
   ARTICLES GRID
   =========================================== */
.blog-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
}

@media (min-width: 768px) {
  .blog-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
  }
}

/* ===========================================
   ARTICLE CARD
   =========================================== */
.blog-card {
  display: block;
  text-decoration: none;
  opacity: 0;
  transform: translateY(30px);
  animation: blogFadeIn 0.6s ease forwards;
}

.blog-card:nth-child(1) { animation-delay: 0.1s; }
.blog-card:nth-child(2) { animation-delay: 0.2s; }
.blog-card:nth-child(3) { animation-delay: 0.3s; }

/* Image Container */
.blog-card-image {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  margin-bottom: 20px;
  background-color: var(--blog-border);
}

.blog-card-image::before {
  content: '';
  position: absolute;
  inset: 0;
  border: 1px solid rgba(0, 0, 0, 0.05);
  pointer-events: none;
  z-index: 2;
}

.blog-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1s ease-out;
}

.blog-card:hover .blog-card-image img {
  transform: scale(1.05);
}

/* Meta */
.blog-card-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 13px;
  color: var(--blog-muted);
}

.blog-card-category {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 11px;
  font-weight: 500;
}

.blog-card-meta-separator {
  color: var(--blog-border);
}

.blog-card-readtime {
  display: flex;
  align-items: center;
  gap: 4px;
}

.blog-card-readtime svg {
  width: 14px;
  height: 14px;
}

/* Title */
.blog-card-title {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 20px;
  font-weight: 400;
  color: var(--blog-charcoal);
  line-height: 1.4;
  transition: color 0.3s ease;
}

.blog-card:hover .blog-card-title {
  color: var(--blog-gold);
}

/* ===========================================
   MOBILE ADJUSTMENTS
   =========================================== */
@media (max-width: 767px) {
  .blog-section {
    padding: 40px 0;
  }
  
  .blog-header {
    margin-bottom: 20px;
  }
  
  .blog-label {
    margin-bottom: 8px;
  }
  
  .blog-title {
    font-size: 32px;
  }
  
  .blog-card-title {
    font-size: 18px;
  }
}
/* ===========================================
   BOOKING SECTION
   =========================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

.booking-section {
  --booking-bg: hsl(0 0% 8%);
  --booking-cream: hsl(45 20% 96%);
  --booking-cream-70: hsl(45 20% 96% / 0.7);
  --booking-cream-80: hsl(45 20% 96% / 0.8);
  --booking-cream-10: hsl(45 20% 96% / 0.1);
  --booking-gold: hsl(38 35% 55%);
  --booking-gold-10: hsl(38 35% 55% / 0.1);
}

.booking-section {
  position: relative;
  padding: 96px 0;
  background-color: var(--booking-bg);
  overflow: hidden;
}

@media (min-width: 1024px) {
  .booking-section {
    padding: 128px 0;
  }
}

/* ===========================================
   CONTAINER
   =========================================== */
.booking-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
}

@media (min-width: 1024px) {
  .booking-container {
    padding: 0 48px;
  }
}

/* ===========================================
   GRID LAYOUT
   =========================================== */
.booking-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
  align-items: center;
}

@media (min-width: 1024px) {
  .booking-grid {
    grid-template-columns: 1fr 1fr;
    gap: 64px;
  }
}

@media (min-width: 1200px) {
  .booking-grid {
    gap: 96px;
  }
}

/* ===========================================
   LEFT COLUMN - CONTENT
   =========================================== */
.booking-content {
  opacity: 0;
  transform: translateY(30px);
  animation: bookingFadeIn 0.6s ease forwards;
}

@keyframes bookingFadeIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.booking-label {
  display: block;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--booking-gold);
  margin-bottom: 16px;
}

.booking-title {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 36px;
  font-weight: 500;
  color: var(--booking-cream);
  margin-bottom: 24px;
  line-height: 1.2;
  letter-spacing: -0.02em;
}

@media (min-width: 768px) {
  .booking-title {
    font-size: 48px;
  }
}

.booking-description {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 18px;
  line-height: 1.7;
  color: var(--booking-cream-70);
  margin-bottom: 40px;
}

/* ===========================================
   FEATURES LIST
   =========================================== */
.booking-features {
  display: flex;
  flex-direction: column;
  gap: 24px;
  margin-bottom: 40px;
}

.booking-feature {
  display: flex;
  align-items: center;
  gap: 16px;
}

.booking-feature-icon {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  background-color: var(--booking-gold-10);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.booking-feature-icon svg {
  width: 20px;
  height: 20px;
  color: var(--booking-gold);
}

.booking-feature-text {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 16px;
  color: var(--booking-cream-80);
}

/* ===========================================
   CTA BUTTON
   =========================================== */
.booking-cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 16px 32px;
  background-color: var(--booking-gold);
  color: var(--booking-bg);
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  text-decoration: none;
  border-radius: 6px;
  transition: all 0.3s ease;
  border: none;
  cursor: pointer;
}

.booking-cta:hover {
  background-color: hsl(38 45% 65%);
  transform: translateY(-2px);
}

.booking-cta svg {
  width: 16px;
  height: 16px;
  transition: transform 0.3s ease;
}

.booking-cta:hover svg {
  transform: translateX(4px);
}

/* ===========================================
   RIGHT COLUMN - CALENDLY
   =========================================== */
.booking-calendly-wrapper {
  position: relative;
  opacity: 0;
  transform: translateY(30px);
  animation: bookingFadeIn 0.6s ease forwards;
  animation-delay: 0.2s;
}

.booking-calendly-container {
  position: relative;
  background: hsl(0 0% 5%);
  border: 1px solid var(--booking-cream-10);
  border-radius: 16px;
  overflow: hidden;
  min-height: 650px;
}

/* Calendly iframe styling */
.booking-calendly-container .calendly-inline-widget {
  min-width: 100% !important;
  height: 650px !important;
}

/* ===========================================
   DECORATIVE GLOWS
   =========================================== */
.booking-glow {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(60px);
}

.booking-glow--top {
  top: -24px;
  right: -24px;
  width: 96px;
  height: 96px;
  background: var(--booking-gold);
  opacity: 0.2;
}

.booking-glow--bottom {
  bottom: -24px;
  left: -24px;
  width: 128px;
  height: 128px;
  background: var(--booking-gold);
  opacity: 0.1;
}

/* ===========================================
   MOBILE ADJUSTMENTS
   =========================================== */
@media (max-width: 767px) {
  .booking-section {
    padding: 64px 0;
  }
  
  .booking-title {
    font-size: 32px;
  }
  
  .booking-description {
    font-size: 16px;
  }
  
  .booking-calendly-container {
    min-height: 700px;
  }
  
  .booking-calendly-container .calendly-inline-widget {
    height: 700px !important;
  }
}
/* Masquer visuellement le titre Calendly */
.booking-calendly-wrapper iframe {
  border: none;
}

/* Option : réduire l'impact visuel */
.booking-calendly-wrapper {
  --calendly-title-scale: 0.85;
}
.accordion summary {
  display: flex;
  position: relative;
  line-height: 1;
  padding: 1.5rem 0;
}

.accordion .summary__title {
  display: flex;
  flex: 1;
}

.accordion + .accordion {
  margin-top: 0;
  border-top: none;
}

.accordion {
  margin-top: 2.5rem;
  margin-bottom: 0;
  border-top: 0.1rem solid rgba(var(--color-foreground), 0.2);
  border-bottom: 0.1rem solid rgba(var(--color-foreground), 0.2);
}

.accordion__title {
  display: inline-block;
  max-width: calc(100% - 6rem);
  min-height: 1.6rem;
  margin: 0;
  word-break: break-word;
}

.accordion .icon-accordion {
  align-self: center;
  min-width: 1.6rem;
  margin-right: 1rem;
  fill: rgb(var(--color-foreground));
}

.accordion details[open] > summary .icon-caret {
  transform: rotate(-180deg);
}

.accordion__content {
  margin-bottom: 1.5rem;
  word-break: break-word;
}

.accordion__content img {
  max-width: 100%;
}

.footer .accordion__title {
  text-transform: var(--font-header-menu-text-transform);
}/* =============================================================================
   SHOPIFY RENTAL GUIDE - EDITORIAL THEME CSS
   Fichier : Assets > editorial-custom.css
   VERSION CORRIGÉE - Valeurs en PX pour override le font-size: 10px du thème
   ============================================================================= */

/* --- GOOGLE FONTS IMPORT --- */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Inter:wght@300;400;500;600&display=swap');

/* --- CSS VARIABLES (Design System) --- */
:root {
  /* Palette Premium Editorial */
  --clr-background: hsl(45, 20%, 98%);
  --clr-foreground: hsl(0, 0%, 4%);
  
  --clr-card: hsl(45, 20%, 99%);
  --clr-card-foreground: hsl(0, 0%, 4%);
  
  --clr-primary: hsl(0, 0%, 8%);
  --clr-primary-foreground: hsl(45, 20%, 98%);
  
  --clr-secondary: hsl(45, 15%, 95%);
  --clr-secondary-foreground: hsl(0, 0%, 8%);
  
  --clr-muted: hsl(45, 10%, 92%);
  --clr-muted-foreground: hsl(0, 0%, 40%);
  
  --clr-accent: hsl(38, 35%, 70%);
  --clr-accent-foreground: hsl(0, 0%, 4%);
  
  --clr-gold: hsl(38, 50%, 55%);
  --clr-gold-light: hsl(38, 45%, 85%);
  
  --clr-border: hsl(45, 15%, 88%);
  
  /* Spécifiques Editorial */
  --clr-editorial-cream: hsl(45, 30%, 96%);
  --clr-editorial-warm-gray: hsl(30, 10%, 50%);
  --clr-editorial-charcoal: hsl(0, 0%, 12%);
  --clr-editorial-black: hsl(0, 0%, 4%);
  
  /* Typography */
  --font-serif: 'Playfair Display', Georgia, serif;
  --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
  
  /* Shadows */
  --shadow-editorial: 0 4px 40px -12px rgba(0, 0, 0, 0.08);
  --shadow-card: 0 2px 20px -8px rgba(0, 0, 0, 0.06);
  --shadow-hover: 0 8px 50px -15px rgba(0, 0, 0, 0.12);
  
  /* Border radius */
  --radius: 4px;
}

/* =============================================================================
   CONTAINERS - VALEURS EN PX
   ============================================================================= */

.editorial-container {
  max-width: 1280px !important; /* 80rem */
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 24px !important; /* 1.5rem = 24px */
  padding-right: 24px !important;
}

@media (min-width: 1024px) {
  .editorial-container {
    padding-left: 48px !important; /* 3rem = 48px */
    padding-right: 48px !important;
  }
}

/* Max-width utilities */
.max-w-5xl {
  max-width: 1024px !important; /* 64rem */
}

.max-w-4xl {
  max-width: 896px !important; /* 56rem */
}

.max-w-3xl {
  max-width: 768px !important; /* 48rem */
}

.max-w-2xl {
  max-width: 672px !important; /* 42rem */
}

.max-w-xl {
  max-width: 576px !important; /* 36rem */
}

/* =============================================================================
   TYPOGRAPHY CLASSES - VALEURS EN PX
   ============================================================================= */

/* text-4xl md:text-5xl lg:text-6xl = 36px / 48px / 60px */
.editorial-heading-xl {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 36px !important;
  font-weight: 500 !important;
  line-height: 1.25 !important;
  letter-spacing: -0.025em !important;
  margin: 0 !important;
}

@media (min-width: 768px) {
  .editorial-heading-xl {
    font-size: 48px !important;
  }
}

@media (min-width: 1024px) {
  .editorial-heading-xl {
    font-size: 60px !important;
  }
}

/* text-3xl md:text-4xl = 30px / 36px */
.editorial-heading-lg {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 30px !important;
  font-weight: 500 !important;
  line-height: 1.25 !important;
  letter-spacing: -0.025em !important;
  margin: 0 !important;
}

@media (min-width: 768px) {
  .editorial-heading-lg {
    font-size: 36px !important;
  }
}

/* text-2xl md:text-3xl = 24px / 30px */
.editorial-heading-md {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 24px !important;
  font-weight: 500 !important;
  line-height: 1.375 !important;
  letter-spacing: -0.025em !important;
  margin: 0 !important;
}

@media (min-width: 768px) {
  .editorial-heading-md {
    font-size: 30px !important;
  }
}

/* text-xl md:text-2xl = 20px / 24px */
.editorial-heading-sm {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 20px !important;
  font-weight: 500 !important;
  line-height: 1.25 !important;
  margin: 0 !important;
}

@media (min-width: 768px) {
  .editorial-heading-sm {
    font-size: 24px !important;
  }
}

/* text-base md:text-lg = 16px / 18px */
.editorial-body {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 16px !important;
  line-height: 1.625 !important;
  font-weight: 300 !important;
  margin: 0 !important;
}

@media (min-width: 768px) {
  .editorial-body {
    font-size: 18px !important;
  }
}

/* text-sm md:text-base = 14px / 16px */
.editorial-body-sm {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 14px !important;
  line-height: 1.625 !important;
  font-weight: 300 !important;
  margin: 0 !important;
}

@media (min-width: 768px) {
  .editorial-body-sm {
    font-size: 16px !important;
  }
}

/* text-xs = 12px */
.editorial-caption {
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  font-weight: 500 !important;
  margin: 0 !important;
}

/* =============================================================================
   CARD STYLES
   ============================================================================= */

.editorial-card {
  background-color: var(--clr-card) !important;
  border: 1px solid hsla(45, 15%, 88%, 0.5) !important;
  border-radius: 4px !important;
  box-shadow: var(--shadow-card) !important;
  transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.editorial-card:hover {
  box-shadow: var(--shadow-hover) !important;
  border-color: hsla(38, 35%, 70%, 0.3) !important;
}

/* =============================================================================
   DIVIDER
   ============================================================================= */

.editorial-divider {
  width: 64px !important;
  height: 1px !important;
  background-color: var(--clr-accent) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* =============================================================================
   COLOR UTILITIES
   ============================================================================= */

.text-gold {
  color: var(--clr-gold) !important;
}

.text-foreground {
  color: var(--clr-foreground) !important;
}

.text-muted-foreground {
  color: var(--clr-muted-foreground) !important;
}

.text-editorial-black {
  color: var(--clr-editorial-black) !important;
}

.text-editorial-warm-gray {
  color: var(--clr-editorial-warm-gray) !important;
}

.bg-background {
  background-color: var(--clr-background) !important;
}

.bg-secondary {
  background-color: var(--clr-secondary) !important;
}

.bg-primary {
  background-color: var(--clr-primary) !important;
}

.bg-gold-light {
  background-color: var(--clr-gold-light) !important;
}

.bg-editorial-cream {
  background-color: var(--clr-editorial-cream) !important;
}

.text-primary-foreground {
  color: var(--clr-primary-foreground) !important;
}

.text-secondary-foreground {
  color: var(--clr-secondary-foreground) !important;
}

/* =============================================================================
   BORDER UTILITIES
   ============================================================================= */

.border-border {
  border-color: var(--clr-border) !important;
}

.border-gold {
  border-color: var(--clr-gold) !important;
}

.border-l-2 {
  border-left-width: 2px !important;
  border-left-style: solid !important;
}

.border-l-gold {
  border-left-color: var(--clr-gold) !important;
}

/* =============================================================================
   SPACING UTILITIES - VALEURS EN PX
   ============================================================================= */

/* Padding Y */
.py-8 { padding-top: 32px !important; padding-bottom: 32px !important; }
.py-12 { padding-top: 48px !important; padding-bottom: 48px !important; }
.py-16 { padding-top: 64px !important; padding-bottom: 64px !important; }
.py-24 { padding-top: 96px !important; padding-bottom: 96px !important; }
.py-32 { padding-top: 128px !important; padding-bottom: 128px !important; }

/* Padding X */
.px-4 { padding-left: 16px !important; padding-right: 16px !important; }
.px-6 { padding-left: 24px !important; padding-right: 24px !important; }
.px-8 { padding-left: 32px !important; padding-right: 32px !important; }

/* Padding all */
.p-4 { padding: 16px !important; }
.p-6 { padding: 24px !important; }
.p-8 { padding: 32px !important; }
.p-10 { padding: 40px !important; }

/* Margin bottom */
.mb-2 { margin-bottom: 8px !important; }
.mb-3 { margin-bottom: 12px !important; }
.mb-4 { margin-bottom: 16px !important; }
.mb-6 { margin-bottom: 24px !important; }
.mb-8 { margin-bottom: 32px !important; }
.mb-12 { margin-bottom: 48px !important; }
.mb-16 { margin-bottom: 64px !important; }

/* Margin top */
.mt-4 { margin-top: 16px !important; }
.mt-8 { margin-top: 32px !important; }
.mt-16 { margin-top: 64px !important; }

/* Gap */
.gap-2 { gap: 8px !important; }
.gap-3 { gap: 12px !important; }
.gap-4 { gap: 16px !important; }
.gap-6 { gap: 24px !important; }
.gap-8 { gap: 32px !important; }

/* =============================================================================
   LAYOUT UTILITIES
   ============================================================================= */

.flex { display: flex !important; }
.inline-flex { display: inline-flex !important; }
.block { display: block !important; }
.grid { display: grid !important; }

.flex-col { flex-direction: column !important; }
.flex-row { flex-direction: row !important; }
.flex-wrap { flex-wrap: wrap !important; }

.items-start { align-items: flex-start !important; }
.items-center { align-items: center !important; }
.items-end { align-items: flex-end !important; }

.justify-start { justify-content: flex-start !important; }
.justify-center { justify-content: center !important; }
.justify-between { justify-content: space-between !important; }

.text-left { text-align: left !important; }
.text-center { text-align: center !important; }
.text-right { text-align: right !important; }

.mx-auto { margin-left: auto !important; margin-right: auto !important; }

/* =============================================================================
   BORDER RADIUS
   ============================================================================= */

.rounded-none { border-radius: 0 !important; }
.rounded-sm { border-radius: 2px !important; }
.rounded { border-radius: 4px !important; }
.rounded-md { border-radius: 6px !important; }
.rounded-lg { border-radius: 8px !important; }
.rounded-full { border-radius: 9999px !important; }

/* =============================================================================
   FONT UTILITIES
   ============================================================================= */

.font-serif { font-family: 'Playfair Display', Georgia, serif !important; }
.font-sans { font-family: 'Inter', system-ui, sans-serif !important; }

.font-light { font-weight: 300 !important; }
.font-normal { font-weight: 400 !important; }
.font-medium { font-weight: 500 !important; }
.font-semibold { font-weight: 600 !important; }
.font-bold { font-weight: 700 !important; }

.italic { font-style: italic !important; }

.uppercase { text-transform: uppercase !important; }
.lowercase { text-transform: lowercase !important; }
.capitalize { text-transform: capitalize !important; }

.tracking-tight { letter-spacing: -0.025em !important; }
.tracking-normal { letter-spacing: 0 !important; }
.tracking-wide { letter-spacing: 0.025em !important; }
.tracking-wider { letter-spacing: 0.05em !important; }
.tracking-widest { letter-spacing: 0.1em !important; }

.leading-none { line-height: 1 !important; }
.leading-tight { line-height: 1.25 !important; }
.leading-snug { line-height: 1.375 !important; }
.leading-normal { line-height: 1.5 !important; }
.leading-relaxed { line-height: 1.625 !important; }
.leading-loose { line-height: 2 !important; }

.whitespace-nowrap { white-space: nowrap !important; }

/* =============================================================================
   TEXT SIZES - VALEURS EN PX
   ============================================================================= */

.text-xs { font-size: 12px !important; }
.text-sm { font-size: 14px !important; }
.text-base { font-size: 16px !important; }
.text-lg { font-size: 18px !important; }
.text-xl { font-size: 20px !important; }
.text-2xl { font-size: 24px !important; }
.text-3xl { font-size: 30px !important; }
.text-4xl { font-size: 36px !important; }
.text-5xl { font-size: 48px !important; }
.text-6xl { font-size: 60px !important; }

/* =============================================================================
   TRANSITION
   ============================================================================= */

.transition-all {
  transition-property: all !important;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !important;
  transition-duration: 150ms !important;
}

.transition-colors {
  transition-property: color, background-color, border-color !important;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !important;
  transition-duration: 150ms !important;
}

.duration-300 { transition-duration: 300ms !important; }
.duration-500 { transition-duration: 500ms !important; }

/* =============================================================================
   WIDTH/HEIGHT - VALEURS EN PX
   ============================================================================= */

.w-8 { width: 32px !important; }
.w-10 { width: 40px !important; }
.w-16 { width: 64px !important; }
.w-full { width: 100% !important; }

.h-px { height: 1px !important; }
.h-4 { height: 16px !important; }
.h-5 { height: 20px !important; }
.h-10 { height: 40px !important; }

.min-h-screen { min-height: 100vh !important; }

.flex-shrink-0 { flex-shrink: 0 !important; }

/* =============================================================================
   POSITION
   ============================================================================= */

.relative { position: relative !important; }
.absolute { position: absolute !important; }
.inset-0 { top: 0 !important; right: 0 !important; bottom: 0 !important; left: 0 !important; }

.z-10 { z-index: 10 !important; }
.z-20 { z-index: 20 !important; }

/* =============================================================================
   OVERFLOW
   ============================================================================= */

.overflow-hidden { overflow: hidden !important; }

/* =============================================================================
   RESPONSIVE PREFIXES
   ============================================================================= */

@media (min-width: 640px) {
  .sm\:flex-row { flex-direction: row !important; }
  .sm\:text-left { text-align: left !important; }
}

@media (min-width: 768px) {
  .md\:py-32 { padding-top: 128px !important; padding-bottom: 128px !important; }
  .md\:p-10 { padding: 40px !important; }
  .md\:text-lg { font-size: 18px !important; }
  .md\:text-base { font-size: 16px !important; }
  .md\:text-2xl { font-size: 24px !important; }
  .md\:text-3xl { font-size: 30px !important; }
  .md\:text-4xl { font-size: 36px !important; }
  .md\:text-5xl { font-size: 48px !important; }
  .md\:flex-row { flex-direction: row !important; }
}

@media (min-width: 1024px) {
  .lg\:px-12 { padding-left: 48px !important; padding-right: 48px !important; }
  .lg\:text-6xl { font-size: 60px !important; }
}

/* =============================================================================
   CUSTOM COMPONENTS
   ============================================================================= */

.criteria-pill {
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 12px 20px !important;
  background-color: var(--clr-secondary) !important;
  border: 1px solid var(--clr-border) !important;
  border-radius: 9999px !important;
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 14px !important;
  font-weight: 300 !important;
  transition: border-color 0.2s ease !important;
}

.criteria-pill:hover {
  border-color: hsla(38, 50%, 55%, 0.3) !important;
}

.gold-accent {
  color: var(--clr-gold) !important;
}

.gold-gradient {
  background: linear-gradient(135deg, var(--clr-gold) 0%, var(--clr-gold-light) 100%) !important;
}

.icon-sm { width: 16px !important; height: 16px !important; }
.icon-md { width: 20px !important; height: 20px !important; }
.icon-lg { width: 24px !important; height: 24px !important; }

.hover-lift {
  transition: transform 0.3s ease !important;
}

.hover-lift:hover {
  transform: translateY(-2px) !important;
}

/* =============================================================================
   ANIMATIONS
   ============================================================================= */

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes bounce {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(5px);
  }
}

.animate-fade-in {
  opacity: 0;
  animation: fadeIn 0.8s ease-out forwards !important;
}

.animate-bounce {
  animation: bounce 1.5s infinite !important;
}

.animate-delay-1 { animation-delay: 0.1s !important; }
.animate-delay-2 { animation-delay: 0.2s !important; }
.animate-delay-3 { animation-delay: 0.3s !important; }
.animate-delay-4 { animation-delay: 0.4s !important; }
.animate-delay-5 { animation-delay: 0.8s !important; }
/* =============================================================================
   BOUTONS HERO - FIX
   ============================================================================= */

.hero-editorial__btn,
a.hero-editorial__btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 20px 32px !important;
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  letter-spacing: 0.025em !important;
  text-decoration: none !important;
  border-radius: 0 !important;
  transition: all 0.3s ease !important;
  cursor: pointer !important;
}

.hero-editorial__btn--primary,
a.hero-editorial__btn--primary {
  background-color: hsl(0, 0%, 8%) !important;
  color: hsl(45, 20%, 98%) !important;
  border: 1px solid hsl(0, 0%, 8%) !important;
}

.hero-editorial__btn--primary:hover,
a.hero-editorial__btn--primary:hover {
  background-color: hsl(0, 0%, 15%) !important;
}

.hero-editorial__btn--secondary,
a.hero-editorial__btn--secondary {
  background-color: transparent !important;
  color: hsl(0, 0%, 4%) !important;
  border: 1px solid hsla(0, 0%, 8%, 0.2) !important;
}

.hero-editorial__btn--secondary:hover,
a.hero-editorial__btn--secondary:hover {
  background-color: hsla(0, 0%, 8%, 0.05) !important;
}/* =============================================================================
   BOUTONS EDITORIAL
   ============================================================================= */

.btn-editorial-primary,
a.btn-editorial-primary {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 18px 32px !important;
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  letter-spacing: 0.025em !important;
  text-decoration: none !important;
  border-radius: 0 !important;
  transition: all 0.3s ease !important;
  cursor: pointer !important;
  background-color: hsl(0, 0%, 8%) !important;
  color: hsl(45, 20%, 98%) !important;
  border: 1px solid hsl(0, 0%, 8%) !important;
}

.btn-editorial-primary:hover,
a.btn-editorial-primary:hover {
  background-color: hsl(0, 0%, 15%) !important;
  color: hsl(45, 20%, 98%) !important;
  text-decoration: none !important;
}

.btn-editorial-secondary,
a.btn-editorial-secondary {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 18px 32px !important;
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  letter-spacing: 0.025em !important;
  text-decoration: none !important;
  border-radius: 0 !important;
  transition: all 0.3s ease !important;
  cursor: pointer !important;
  background-color: transparent !important;
  color: hsl(0, 0%, 4%) !important;
  border: 1px solid hsla(0, 0%, 8%, 0.2) !important;
}

.btn-editorial-secondary:hover,
a.btn-editorial-secondary:hover {
  background-color: hsla(0, 0%, 8%, 0.05) !important;
  color: hsl(0, 0%, 4%) !important;
  text-decoration: none !important;
}
/* =============================================================================
   SCROLL INDICATOR
   ============================================================================= */

.scroll-indicator {
  position: absolute !important;
  bottom: 32px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 100% !important;
  text-align: center !important;
}

.scroll-indicator__link {
  display: inline-flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 8px !important;
  color: var(--clr-editorial-warm-gray) !important;
  text-decoration: none !important;
  transition: color 0.3s ease !important;
}

.scroll-indicator__link:hover {
  color: var(--clr-gold) !important;
  text-decoration: none !important;
}

.scroll-indicator__link .editorial-caption {
  font-size: 10px !important;
}
/* =============================================================================
   SOMMAIRE EDITORIAL
   ============================================================================= */

.sommaire-editorial {
  background-color: var(--clr-background) !important;
}

.sommaire-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 16px !important;
}

@media (min-width: 768px) {
  .sommaire-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 24px !important;
  }
}

@media (min-width: 1024px) {
  .sommaire-grid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

.sommaire-card {
  display: block !important;
  padding: 24px !important;
  background-color: var(--clr-card) !important;
  border: 1px solid var(--clr-border) !important;
  border-radius: 2px !important;
  box-shadow: var(--shadow-card) !important;
  text-decoration: none !important;
  transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

@media (min-width: 768px) {
  .sommaire-card {
    padding: 32px !important;
  }
}

.sommaire-card:hover {
  border-color: hsla(38, 50%, 55%, 0.5) !important;
  box-shadow: var(--shadow-hover) !important;
  text-decoration: none !important;
}

.sommaire-card__header {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  margin-bottom: 16px !important;
}

.sommaire-card__icon {
  width: 48px !important;
  height: 48px !important;
  border-radius: 50% !important;
  background-color: var(--clr-secondary) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.3s ease !important;
  color: var(--clr-muted-foreground) !important;
}

.sommaire-card:hover .sommaire-card__icon {
  background-color: hsla(38, 50%, 55%, 0.1) !important;
  color: var(--clr-gold) !important;
}

.sommaire-card__icon svg {
  width: 20px !important;
  height: 20px !important;
}

.sommaire-card__title {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 18px !important;
  font-weight: 500 !important;
  color: var(--clr-foreground) !important;
  margin: 0 !important;
  transition: color 0.3s ease !important;
}

.sommaire-card:hover .sommaire-card__title {
  color: var(--clr-gold) !important;
}

.sommaire-card__line {
  margin-top: 16px !important;
  width: 0 !important;
  height: 1px !important;
  background-color: var(--clr-gold) !important;
  transition: width 0.5s ease !important;
}

.sommaire-card:hover .sommaire-card__line {
  width: 48px !im/* =============================================================================
   CAN YOU RENT EDITORIAL
   ============================================================================= */

.can-you-rent-editorial {
  background-color: var(--clr-editorial-cream) !important;
}

.can-you-rent-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 32px !important;
  width: 100% !important;
}

@media screen and (min-width: 768px) {
  .can-you-rent-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 32px !important;
  }
}

.can-you-rent-editorial .editorial-card,
.can-you-rent-card {
  display: block !important;
  width: 100% !important;
  padding: 32px !important;
  background-color: var(--clr-card) !important;
  border: 1px solid var(--clr-border) !important;
  border-radius: 2px !important;
  box-shadow: var(--shadow-card) !important;
}

@media screen and (min-width: 768px) {
  .can-you-rent-editorial .editorial-card,
  .can-you-rent-card {
    padding: 40px !important;
  }
}

.can-you-rent-card--negative {
  border-left: 2px solid hsl(0, 84%, 60%) !important;
}

.can-you-rent-card__header {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 12px !important;
  margin-bottom: 24px !important;
  width: 100% !important;
}

.can-you-rent-card__icon {
  width: 40px !important;
  height: 40px !important;
  min-width: 40px !important;
  max-width: 40px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}

.can-you-rent-card__icon--green {
  background-color: hsl(142, 76%, 96%) !important;
  color: hsl(142, 71%, 45%) !important;
}

.can-you-rent-card__icon--red {
  background-color: hsl(0, 86%, 97%) !important;
  color: hsl(0, 84%, 60%) !important;
}

.can-you-rent-card__icon svg {
  width: 20px !important;
  height: 20px !important;
}

.can-you-rent-card__header h3,
.can-you-rent-card__header .editorial-heading-sm {
  margin: 0 !important;
  flex: 1 !important;
}

.can-you-rent-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: block !important;
}

.can-you-rent-list__item {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 12px !important;
  margin-bottom: 12px !important;
}

.can-you-rent-list__item:last-child {
  margin-bottom: 0 !important;
}

.can-you-rent-list__icon {
  flex-shrink: 0 !important;
  width: 16px !important;
  height: 16px !important;
  min-width: 16px !important;
}

.can-you-rent-list__icon--green {
  color: hsl(142, 71%, 45%) !important;
}

.can-you-rent-list__icon--red {
  color: hsl(0, 84%, 60%) !important;
}

/* Info Box */
.can-you-rent-info-box {
  background-color: hsla(38, 50%, 55%, 0.05) !important;
  border: 1px solid hsla(38, 50%, 55%, 0.2) !important;
  border-radius: 2px !important;
  padding: 24px !important;
}

@media screen and (min-width: 768px) {
  .can-you-rent-info-box {
    padding: 32px !important;
  }
}

.can-you-rent-info-box__content {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: flex-start !important;
  gap: 16px !important;
}

.can-you-rent-info-box__icon {
  flex-shrink: 0 !important;
  color: var(--clr-gold) !important;
  margin-top: 2px !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
}

.can-you-rent-info-box__title {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  color: var(--clr-foreground) !important;
  margin: 0 0 8px 0 !important;
/* ===========================================
   FAQ SECTION
   =========================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

.faq-section {
  --faq-bg: hsl(0 0% 100%);
  --faq-charcoal: hsl(0 0% 8%);
  --faq-gold: hsl(38 35% 55%);
  --faq-gold-30: hsl(38 35% 55% / 0.3);
  --faq-warm-gray: hsl(30 5% 45%);
  --faq-border: hsl(0 0% 90%);
  --faq-border-50: hsl(0 0% 90% / 0.5);
}

.faq-section {
  padding: 96px 0;
  background-color: var(--faq-bg);
}

@media (min-width: 1024px) {
  .faq-section {
    padding: 128px 0;
  }
}

/* ===========================================
   CONTAINER
   =========================================== */
.faq-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
}

@media (min-width: 1024px) {
  .faq-container {
    padding: 0 48px;
  }
}

/* ===========================================
   GRID LAYOUT
   =========================================== */
.faq-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
}

@media (min-width: 1024px) {
  .faq-grid {
    grid-template-columns: 1fr 1fr;
    gap: 64px;
  }
}

@media (min-width: 1200px) {
  .faq-grid {
    gap: 96px;
  }
}

/* ===========================================
   LEFT COLUMN - HEADER
   =========================================== */
.faq-header {
  opacity: 0;
  transform: translateY(30px);
  animation: faqFadeIn 0.6s ease forwards;
}

@media (min-width: 1024px) {
  .faq-header {
    position: sticky;
    top: 128px;
    align-self: start;
  }
}

@keyframes faqFadeIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.faq-label {
  display: block;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--faq-gold);
  margin-bottom: 16px;
}

.faq-title {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 36px;
  font-weight: 500;
  color: var(--faq-charcoal);
  margin-bottom: 24px;
  line-height: 1.2;
  letter-spacing: -0.02em;
}

@media (min-width: 768px) {
  .faq-title {
    font-size: 48px;
  }
}

.faq-description {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 18px;
  line-height: 1.7;
  color: var(--faq-warm-gray);
}

/* ===========================================
   RIGHT COLUMN - ACCORDION
   =========================================== */
.faq-accordion {
  display: flex;
  flex-direction: column;
  gap: 16px;
  opacity: 0;
  transform: translateY(30px);
  animation: faqFadeIn 0.6s ease forwards;
  animation-delay: 0.2s;
}

/* ===========================================
   ACCORDION ITEM
   =========================================== */
.faq-item {
  border: 1px solid var(--faq-border-50);
  border-radius: 12px;
  overflow: hidden;
  transition: border-color 0.3s ease;
}

.faq-item.is-open {
  border-color: var(--faq-gold-30);
}

/* ===========================================
   ACCORDION TRIGGER
   =========================================== */
.faq-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 24px;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 18px;
  font-weight: 500;
  color: var(--faq-charcoal);
  transition: color 0.3s ease;
}

.faq-trigger:hover {
  color: var(--faq-gold);
}

.faq-trigger-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  position: relative;
}

.faq-trigger-icon::before,
.faq-trigger-icon::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  background-color: var(--faq-charcoal);
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.faq-trigger-icon::before {
  width: 12px;
  height: 2px;
  transform: translate(-50%, -50%);
}

.faq-trigger-icon::after {
  width: 2px;
  height: 12px;
  transform: translate(-50%, -50%);
}

.faq-item.is-open .faq-trigger-icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
  opacity: 0;
}

/* ===========================================
   ACCORDION CONTENT
   =========================================== */
.faq-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.faq-content-inner {
  padding: 0 24px 24px 24px;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.7;
  color: var(--faq-warm-gray);
}

/* ===========================================
   MOBILE ADJUSTMENTS
   =========================================== */
@media (max-width: 767px) {
  .faq-section {
    padding: 64px 0;
  }
  
  .faq-title {
    font-size: 32px;
  }
  
  .faq-description {
    font-size: 16px;
  }
  
  .faq-trigger {
    font-size: 16px;
    padding: 20px;
  }
  
  .faq-content-inner {
    padding: 0 20px 20px 20px;
    font-size: 15px;
  }
}
/* ===========================================
   FAQ QUESTION (H3 RESET) — FORCE ABSOLUE
   =========================================== */
.faq-trigger .faq-question {
  all: unset !important;
  display: block !important;

  font-family: inherit !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  line-height: inherit !important;
  letter-spacing: inherit !important;
  color: inherit !important;
  text-transform: inherit !important;

  margin: 0 !important;
  padding: 0 !important;
}
/* ===========================================
   GEO SECTION
   =========================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

.geo-section {
  --geo-bg: hsl(40 33% 98%);

  --geo-text: hsl(0 0% 40%);
  --geo-text-strong: hsl(0 0% 8%);
}

.geo-section {
  padding: 64px 0;
  background-color: var(--geo-bg);
}

/* ===========================================
   CONTAINER
   =========================================== */
.geo-container {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 24px;
}

/* ===========================================
   CONTENT
   =========================================== */
.geo-content {
  text-align: center;
  opacity: 0;
  transform: translateY(20px);
  animation: geoFadeIn 0.6s ease forwards;
}

@keyframes geoFadeIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.geo-text {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 18px;
  line-height: 1.8;
  color: var(--geo-text);
  margin: 0;
}

.geo-text strong {
  color: var(--geo-text-strong);
  font-weight: 600;
}

/* ===========================================
   MOBILE ADJUSTMENTS
   =========================================== */
@media (max-width: 767px) {
  .geo-section {
    padding: 48px 0;
  }
  
  .geo-text {
    font-size: 16px;
    line-height: 1.7;
  }
}

/* ===========================================
   REALISATIONS PORTFOLIO SECTION
   =========================================== */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Inter:wght@300;400;500;600;700&display=swap');

.realisations-section {
--rp-background: hsl(0 0% 100%);
 --rp-foreground: hsl(220 15% 12%);
  --rp-card: hsl(0 0% 100%);
  --rp-gold: hsl(43 50% 60%);
  --rp-gold-foreground: hsl(220 15% 12%);
  --rp-muted-foreground: hsl(220 10% 45%);
  --rp-primary-foreground: hsl(40 33% 98%);
  --rp-card-shadow: 0 4px 24px -4px hsla(220, 15%, 12%, 0.08);
  --rp-card-shadow-hover: 0 12px 40px -8px hsla(220, 15%, 12%, 0.15);
  --rp-noise-opacity: 0.03;
}

.realisations-section {
  position: relative;
  padding-top: 24px;   /* ↓ réduit fortement l’espace au-dessus */
  padding-bottom: 60px;
  background-color: var(--rp-background);
  overflow: hidden;
}

@media (min-width: 768px) {
  .realisations-section {
    padding-top: 48px;
    padding-bottom: 112px;
  }
}

@media (min-width: 1024px) {
  .realisations-section {
    padding-top: 40px;
    padding-bottom: 128px;
  }
}


.realisations-section.noise-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  opacity: var(--rp-noise-opacity);
  pointer-events: none;
  z-index: 1;
}

.realisations-section > * {
  position: relative;
  z-index: 2;
}

/* CONTAINER */
.realisations-container {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: border-box;
}

@media (min-width: 768px) {
  .realisations-container { padding: 0 60px; }
}

@media (min-width: 1200px) {
  .realisations-container { padding: 0 80px; }
}

/* HEADER */
.realisations-header {
  text-align: center;
  margin-bottom: 40px;
}

@media (min-width: 768px) {
  .realisations-header { margin-bottom: 64px; }
}

.realisations-section .section-label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--rp-gold);
  margin-bottom: 16px;
  font-family: 'Inter', system-ui, sans-serif;
}

.realisations-section .section-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 32px;
  font-weight: 500;
  letter-spacing: -0.025em;
  line-height: 1.2;
  color: var(--rp-foreground);
  margin-bottom: 16px;
}

@media (min-width: 768px) {
  .realisations-section .section-title { font-size: 48px; }
}

@media (min-width: 1024px) {
  .realisations-section .section-title { font-size: 60px; }
}

.realisations-section .section-description {
  color: var(--rp-muted-foreground);
  font-size: 16px;
  max-width: 672px;
  margin: 0 auto;
  font-family: 'Inter', system-ui, sans-serif;
  line-height: 1.6;
}

@media (min-width: 768px) {
  .realisations-section .section-description { font-size: 18px; }
}

/* ===========================================
   DESKTOP GRID
   =========================================== */
.desktop-only {
  display: none;
}

@media (min-width: 768px) {
  .desktop-only { display: grid; }
}

.projects-grid {
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
  width: 100%;
  box-sizing: border-box;
}

@media (min-width: 1024px) {
  .projects-grid { 
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
  }
}

.project-card-wrapper {
  width: 100%;
  box-sizing: border-box;
  animation: rpFadeUp 0.6s ease forwards;
  opacity: 0;
}

.project-card-wrapper:nth-child(1) { animation-delay: 0.1s; }
.project-card-wrapper:nth-child(2) { animation-delay: 0.2s; }
.project-card-wrapper:nth-child(3) { animation-delay: 0.3s; }
.project-card-wrapper:nth-child(4) { animation-delay: 0.4s; }
.project-card-wrapper:nth-child(5) { animation-delay: 0.5s; }
.project-card-wrapper:nth-child(6) { animation-delay: 0.6s; }

/* ===========================================
   MOBILE CAROUSEL
   =========================================== */
.mobile-only {
  display: block;
}

@media (min-width: 768px) {
  .mobile-only { display: none; }
}

.projects-carousel {
  width: 100%;
  overflow: hidden;
  position: relative;
}

.carousel-track {
  display: flex;
  gap: 16px;
  transition: transform 0.3s ease;
  touch-action: pan-y pinch-zoom;
}

.carousel-slide {
  flex: 0 0 calc(100% - 40px);
  min-width: calc(100% - 40px);
  box-sizing: border-box;
}

/* Carousel Dots */
.carousel-dots {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 24px;
}

.carousel-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: none;
  background-color: rgba(0, 0, 0, 0.2);
  cursor: pointer;
  padding: 0;
  transition: all 0.3s ease;
}

.carousel-dot.active {
  background-color: var(--rp-gold);
  transform: scale(1.2);
}

.carousel-dot:hover {
  background-color: var(--rp-gold);
}

/* ===========================================
   PROJECT CARD
   =========================================== */
.project-card {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  cursor: pointer;
  background-color: var(--rp-card);
  aspect-ratio: 4 / 5;
  width: 100%;
  box-sizing: border-box;
  box-shadow: var(--rp-card-shadow);
  transition: all 0.5s ease;
}

.project-card:hover {
  box-shadow: var(--rp-card-shadow-hover);
  transform: translateY(-4px);
}

.project-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.7s ease;
}

.project-card:hover .project-image {
  transform: scale(1.05);
}

.project-image-placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, #f5f5f5 0%, #e0e0e0 100%);
}

.project-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.2) 40%, transparent 100%);
  pointer-events: none;
}

.badge-wrapper {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 3;
}

.badge-platform {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 9999px;
  font-size: 13px;
  font-weight: 500;
  backdrop-filter: blur(8px);
  background: hsla(38, 30%, 90%, 0.9);
  color: var(--rp-foreground);
  font-family: 'Inter', system-ui, sans-serif;
  white-space: nowrap;
}

.badge-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.dot-gold { background-color: var(--rp-gold); }
.dot-green { background-color: #10b981; }

.project-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 20px;
  z-index: 2;
}

@media (min-width: 768px) {
  .project-content { padding: 24px; }
}

.project-category {
  display: block;
  font-size: 11px;
  color: rgba(255, 255, 255, 0.7);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  margin-bottom: 8px;
  font-family: 'Inter', system-ui, sans-serif;
}

.project-name {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 20px;
  font-weight: 500;
  color: var(--rp-primary-foreground);
  margin-bottom: 16px;
  margin-top: 0;
}

@media (min-width: 768px) {
  .project-name { font-size: 24px; }
}

@media (min-width: 1200px) {
  .project-name { font-size: 26px; }
}

.project-badges {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.badge-highlight {
  padding: 8px 14px;
  border-radius: 9999px;
  font-size: 12px;
  font-weight: 500;
  background-color: var(--rp-gold);
  color: var(--rp-gold-foreground);
  font-family: 'Inter', system-ui, sans-serif;
  white-space: nowrap;
}

.badge-service {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 9999px;
  font-size: 12px;
  font-weight: 500;
  background: rgba(0, 0, 0, 0.9);
  color: var(--rp-primary-foreground);
  backdrop-filter: blur(8px);
  font-family: 'Inter', system-ui, sans-serif;
  white-space: nowrap;
}

.project-arrow {
  margin-left: auto;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: var(--rp-card);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s ease;
  text-decoration: none;
  color: var(--rp-foreground);
  flex-shrink: 0;
}

.project-card:hover .project-arrow { opacity: 1; }

.project-arrow svg {
  width: 16px;
  height: 16px;
}

/* Animation */
@keyframes rpFadeUp {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}/* ===========================================
   RYSE AGENCY - SECTION PROJETS PORTFOLIO V2
   Reproduction pixel-perfect de Lovable
   Toutes les valeurs en px, jamais en rem
   =========================================== */

/* === FONT IMPORTS === */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&display=swap");

/* === CSS VARIABLES === */
.ryse-projets {
  --ryse-background: #fcfcfc;
  --ryse-foreground: hsl(220, 15%, 12%);
  --ryse-white: #ffffff;
  --ryse-primary: hsl(220, 15%, 12%);
  --ryse-primary-foreground: hsl(40, 33%, 98%);
  --ryse-gold: hsl(43, 50%, 60%);
  --ryse-gold-light: hsl(43, 50%, 65%);
  --ryse-cream: hsl(45, 20%, 96%);
  --ryse-cream-dark: hsl(38, 25%, 92%);
  --ryse-cream-98: hsl(40, 33%, 98%);
  --ryse-charcoal: hsl(0, 0%, 8%);
  --ryse-charcoal-light: hsl(220, 15%, 20%);
  --ryse-text-primary: hsl(220, 15%, 12%);
  --ryse-text-secondary: hsl(220, 10%, 45%);
  --ryse-text-muted: hsl(220, 10%, 55%);
  --ryse-border: hsl(40, 15%, 88%);
  --ryse-border-light: hsla(220, 15%, 12%, 0.1);
  --ryse-shadow-md: 0 4px 24px -4px hsla(220, 15%, 12%, 0.08);
  --ryse-shadow-xl: 0 12px 40px -8px hsla(220, 15%, 12%, 0.15);
  --ryse-shadow-hover: 0 8px 24px -4px hsla(220, 15%, 12%, 0.3);
  font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* === RESET === */
.ryse-projets *, .ryse-projets *::before, .ryse-projets *::after { box-sizing: border-box; margin: 0; padding: 0; }
.ryse-projets a { text-decoration: none; color: inherit; }
.ryse-projets img { max-width: 100%; height: auto; display: block; }
.ryse-projets button { font-family: inherit; cursor: pointer; border: none; background: none; }

/* === NOISE TEXTURE === */
.ryse-hero__noise, .ryse-filters__noise, .ryse-grid-section__noise, .ryse-partners__noise, .ryse-cta__noise {
  position: absolute; inset: 0; opacity: 0.04; pointer-events: none; z-index: 1;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
}
.ryse-filters__noise, .ryse-grid-section__noise, .ryse-partners__noise, .ryse-cta__noise { opacity: 0.03; }

/* ===========================================
   HERO SECTION
   =========================================== */
.ryse-hero {
  position: relative;
  padding-top: 96px;
  padding-bottom: 96px;
  background-color: hsl(220, 15%, 8%);
  overflow: hidden;
}
@media (min-width: 1024px) { .ryse-hero { padding-top: 128px; padding-bottom: 128px; } }

.ryse-hero__glow { position: absolute; border-radius: 9999px; pointer-events: none; }
.ryse-hero__glow--gold { top: 0; left: 25%; width: 500px; height: 500px; background: hsl(43, 50%, 60%); filter: blur(200px); opacity: 0.1; }
.ryse-hero__glow--blue { bottom: 0; right: 25%; width: 400px; height: 400px; background: hsl(220, 60%, 50%); filter: blur(180px); opacity: 0.06; }

.ryse-hero__container {
  position: relative; z-index: 2; max-width: 1400px; margin: 0 auto;
  padding-left: 24px; padding-right: 24px; text-align: center;
}
@media (min-width: 1024px) { .ryse-hero__container { padding-left: 48px; padding-right: 48px; } }

.ryse-hero__label {
  display: inline-flex; align-items: center; gap: 8px; padding: 8px 16px; border-radius: 9999px;
  background-color: hsla(43, 50%, 60%, 0.15); color: hsl(43, 50%, 65%);
  font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: 2.4px; margin-bottom: 24px;
}

.ryse-hero__title {
  font-family: 'Inter', sans-serif; font-size: 36px; font-weight: 600;
  letter-spacing: -1.08px; line-height: 1.1; color: hsl(40, 33%, 98%); margin-bottom: 16px;
}
@media (min-width: 640px) { .ryse-hero__title { font-size: 42px; letter-spacing: -1.26px; } }
@media (min-width: 768px) { .ryse-hero__title { font-size: 50px; letter-spacing: -1.5px; } }
@media (min-width: 1024px) { .ryse-hero__title { font-size: 56px; letter-spacing: -1.68px; } }

.ryse-hero__title-sub { display: block; color: hsla(40, 33%, 98%, 0.6); font-weight: 300; font-style: italic; font-size: 0.45em; margin-top: 8px; }

.ryse-hero__description {
  font-family: 'Inter', sans-serif; font-size: 15px; line-height: 1.6;
  color: hsla(40, 33%, 98%, 0.7); max-width: 600px; margin: 0 auto 48px auto;
}
@media (min-width: 768px) { .ryse-hero__description { font-size: 17px; } }

.ryse-hero__stats { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 32px; }
@media (min-width: 768px) { .ryse-hero__stats { gap: 48px; } }

.ryse-hero__stat { display: flex; align-items: center; gap: 12px; }
.ryse-hero__stat-icon {
  width: 40px; height: 40px; border-radius: 8px;
  background-color: hsla(43, 50%, 60%, 0.15);
  display: flex; align-items: center; justify-content: center; color: hsl(43, 50%, 60%);
}
.ryse-hero__stat-content { text-align: left; }
.ryse-hero__stat-value { display: block; font-size: 20px; font-weight: 600; color: hsl(40, 33%, 98%); letter-spacing: -0.5px; }
@media (min-width: 768px) { .ryse-hero__stat-value { font-size: 24px; } }
.ryse-hero__stat-label { font-size: 12px; color: hsla(40, 33%, 98%, 0.6); }

/* ===========================================
   FILTERS SECTION
   =========================================== */
.ryse-filters {
  position: relative; padding-top: 32px; padding-bottom: 32px;
  background-color: white; border-bottom: 1px solid hsla(220, 15%, 12%, 0.1);
}
.ryse-filters__container {
  position: relative; z-index: 2; max-width: 1400px; margin: 0 auto;
  padding-left: 20px; padding-right: 20px;
}
@media (min-width: 768px) { .ryse-filters__container { padding-left: 60px; padding-right: 60px; } }
@media (min-width: 1024px) { .ryse-filters__container { padding-left: 80px; padding-right: 80px; } }

.ryse-filters__wrap { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; }

/* FILTRES - Couleurs exactes Lovable */
.ryse-filters__btn {
  padding: 10px 20px !important; 
  border-radius: 9999px !important; 
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important; 
  font-weight: 500 !important; 
  transition: all 0.3s ease !important;
  background-color: hsla(220, 15%, 12%, 0.05) !important; 
  color: hsl(220, 15%, 12%) !important;
  border: none !important;
  cursor: pointer !important;
  outline: none !important;
}
.ryse-filters__btn:hover { 
  background-color: hsla(220, 15%, 12%, 0.1) !important; 
}
.ryse-filters__btn--active,
.ryse-filters__btn--active:hover,
.ryse-filters__btn--active:focus { 
  background-color: hsl(220, 15%, 12%) !important; 
  color: hsl(40, 33%, 98%) !important; 
}

/* ===========================================
   GRID SECTION
   =========================================== */
.ryse-grid-section {
  position: relative; padding-top: 64px; padding-bottom: 64px;
  background-color: white; overflow: hidden;
}
@media (min-width: 768px) { .ryse-grid-section { padding-top: 96px; padding-bottom: 96px; } }
@media (min-width: 1024px) { .ryse-grid-section { padding-top: 112px; padding-bottom: 112px; } }

.ryse-grid-section__container {
  position: relative; z-index: 2; max-width: 1400px; margin: 0 auto;
  padding-left: 20px; padding-right: 20px;
}
@media (min-width: 768px) { .ryse-grid-section__container { padding-left: 60px; padding-right: 60px; } }
@media (min-width: 1024px) { .ryse-grid-section__container { padding-left: 80px; padding-right: 80px; } }

.ryse-grid--desktop { display: none; }
@media (min-width: 768px) { .ryse-grid--desktop { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; } }
@media (min-width: 1024px) { .ryse-grid--desktop { grid-template-columns: repeat(3, 1fr); gap: 32px; } }

.ryse-carousel--mobile { display: block; overflow: hidden; }
@media (min-width: 768px) { .ryse-carousel--mobile { display: none; } }

.ryse-carousel__track { display: flex; gap: 16px; transition: transform 0.3s ease-out; }
.ryse-carousel__slide { flex-shrink: 0; width: calc(100% - 40px); }
.ryse-carousel__dots { display: flex; justify-content: center; gap: 10px; margin-top: 32px; }
.ryse-carousel__dot {
  width: 10px; height: 10px; border-radius: 9999px;
  background-color: hsla(0, 0%, 0%, 0.2); border: none; padding: 0; cursor: pointer; transition: all 0.3s ease;
}
.ryse-carousel__dot:hover { background-color: hsl(43, 50%, 60%); }
.ryse-carousel__dot--active { background-color: hsl(43, 50%, 60%); transform: scale(1.2); }

.ryse-grid__empty { text-align: center; padding-top: 64px; padding-bottom: 64px; }
.ryse-grid__empty p { font-size: 18px; color: hsl(220, 10%, 45%); }

/* ===========================================
   PROJECT CARD
   =========================================== */
.ryse-card {
  position: relative; display: block; border-radius: 16px; overflow: hidden;
  background-color: white; aspect-ratio: 4 / 5; width: 100%;
  box-shadow: 0 4px 24px -4px hsla(220, 15%, 12%, 0.08); 
  transition: all 0.5s ease; 
  cursor: pointer;
}
.ryse-card:hover { 
  box-shadow: 0 12px 40px -8px hsla(220, 15%, 12%, 0.15); 
  transform: translateY(-4px); 
}

.ryse-card__image { width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s ease; }
.ryse-card:hover .ryse-card__image { transform: scale(1.05); }

.ryse-card__placeholder { width: 100%; height: 100%; background-color: hsl(38, 25%, 92%); display: flex; align-items: center; justify-content: center; }
.ryse-card__placeholder-svg { width: 50%; height: 50%; opacity: 0.3; }

/* Overlay gradient - exact Lovable */
.ryse-card__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, hsla(0, 0%, 0%, 0.7), hsla(0, 0%, 0%, 0.2) 50%, transparent);
  pointer-events: none;
}

/* Badge top right */
.ryse-card__badge-top { position: absolute; top: 16px; right: 16px; z-index: 3; }
.ryse-card__badge-platform {
  display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; border-radius: 9999px;
  font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 500;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  background-color: hsla(38, 30%, 90%, 0.9); color: hsl(220, 15%, 12%); white-space: nowrap;
}
.ryse-card__badge-dot { width: 8px; height: 8px; border-radius: 9999px; flex-shrink: 0; }
.ryse-card__badge-dot--gold { background-color: hsl(43, 50%, 60%); }
.ryse-card__badge-dot--green { background-color: #10b981; }

/* Content bottom */
.ryse-card__content { position: absolute; bottom: 0; left: 0; right: 0; padding: 20px; z-index: 2; }
@media (min-width: 768px) { .ryse-card__content { padding: 24px; } }

.ryse-card__category {
  display: block; font-family: 'Inter', sans-serif; font-size: 11px;
  color: hsla(0, 0%, 100%, 0.7); letter-spacing: 2.4px; text-transform: uppercase; margin-bottom: 8px;
}

.ryse-card__title {
  font-family: 'Playfair Display', Georgia, serif; font-size: 20px; font-weight: 500;
  color: hsl(40, 33%, 98%); margin: 0 0 16px 0;
}
@media (min-width: 768px) { .ryse-card__title { font-size: 24px; } }
@media (min-width: 1024px) { .ryse-card__title { font-size: 26px; } }

.ryse-card__badges { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

.ryse-card__badge-highlight {
  padding: 8px 14px; border-radius: 9999px; font-family: 'Inter', sans-serif;
  font-size: 12px; font-weight: 500; background-color: hsl(43, 50%, 60%); color: hsl(220, 15%, 12%); white-space: nowrap;
}

.ryse-card__badge-service {
  display: inline-flex; align-items: center; gap: 6px; padding: 8px 14px; border-radius: 9999px;
  font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 500;
  background-color: hsla(0, 0%, 0%, 0.9); color: hsl(40, 33%, 98%);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); white-space: nowrap;
}

.ryse-card__arrow {
  margin-left: auto; width: 40px; height: 40px; border-radius: 9999px;
  background-color: white; display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 0.3s ease; flex-shrink: 0; color: hsl(220, 15%, 12%);
}
.ryse-card:hover .ryse-card__arrow { opacity: 1; }

/* ===========================================
   PARTNERS SECTION
   =========================================== */
.ryse-partners {
  position: relative; padding-top: 48px; padding-bottom: 48px;
  background-color: white; border-top: 1px solid hsla(220, 15%, 12%, 0.1);
}
.ryse-partners__container {
  position: relative; z-index: 2; max-width: 1400px; margin: 0 auto;
  padding-left: 20px; padding-right: 20px;
}
@media (min-width: 768px) { .ryse-partners__container { padding-left: 60px; padding-right: 60px; } }
@media (min-width: 1024px) { .ryse-partners__container { padding-left: 80px; padding-right: 80px; } }

.ryse-partners__wrap {
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 32px;
}
@media (min-width: 640px) { .ryse-partners__wrap { flex-direction: row; } }

.ryse-partners__item { display: flex; align-items: center; gap: 12px; }

.ryse-partners__icon {
  width: 48px; height: 48px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Inter', sans-serif; font-size: 14px; font-weight: 700;
}
.ryse-partners__icon--dark { background-color: hsl(220, 15%, 12%); color: hsl(40, 33%, 98%); }
.ryse-partners__icon--gold { background-color: hsl(43, 50%, 60%); color: hsl(220, 15%, 12%); }

.ryse-partners__text { font-family: 'Inter', sans-serif; font-size: 14px; font-weight: 500; color: hsl(220, 10%, 45%); }

/* ===========================================
   CTA SECTION
   =========================================== */
.ryse-cta {
  position: relative; padding-top: 96px; padding-bottom: 96px;
  background-color: #fcfcfc; overflow: hidden;
}
@media (min-width: 1024px) { .ryse-cta { padding-top: 112px; padding-bottom: 112px; } }

.ryse-cta__container {
  position: relative; z-index: 2; max-width: 900px; margin: 0 auto;
  padding-left: 24px; padding-right: 24px; text-align: center;
}
@media (min-width: 1024px) { .ryse-cta__container { padding-left: 48px; padding-right: 48px; } }

.ryse-cta__label {
  display: inline-flex; align-items: center; gap: 8px; padding: 8px 16px; border-radius: 9999px;
  background-color: hsla(220, 15%, 12%, 0.05); color: hsl(220, 10%, 45%);
  font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: 2.4px; margin-bottom: 24px;
}

.ryse-cta__title {
  font-family: 'Inter', sans-serif; font-size: 32px; font-weight: 600;
  letter-spacing: -0.96px; line-height: 1.1; color: hsl(220, 15%, 12%); margin-bottom: 16px;
}
@media (min-width: 768px) { .ryse-cta__title { font-size: 42px; letter-spacing: -1.26px; } }
@media (min-width: 1024px) { .ryse-cta__title { font-size: 50px; letter-spacing: -1.5px; } }

.ryse-cta__description {
  font-family: 'Inter', sans-serif; font-size: 15px; line-height: 1.6;
  color: hsl(220, 10%, 45%); max-width: 576px; margin: 0 auto 40px auto;
}
@media (min-width: 768px) { .ryse-cta__description { font-size: 17px; } }

.ryse-cta__button {
  display: inline-flex; align-items: center; justify-content: center; gap: 12px;
  padding: 16px 32px; background-color: hsl(220, 15%, 12%); color: white;
  font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 1.6px; border-radius: 6px;
  transition: all 0.3s ease;
}
.ryse-cta__button:hover {
  background-color: hsl(220, 15%, 20%);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px -4px hsla(220, 15%, 12%, 0.3);
}
.ryse-cta__button svg { transition: transform 0.3s ease; }
.ryse-cta__button:hover svg { transform: translate(2px, -2px); }

/* Trust badges */
.ryse-cta__trust {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 24px;
  margin-top: 48px; padding-top: 40px; border-top: 1px solid hsla(220, 15%, 12%, 0.08);
}

.ryse-cta__trust-item { display: flex; align-items: center; gap: 8px; }
.ryse-cta__stars { display: flex; gap: 2px; color: hsl(43, 50%, 60%); }
.ryse-cta__trust-score { font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 500; color: hsl(220, 15%, 12%); }
.ryse-cta__trust-platform { font-family: 'Inter', sans-serif; font-size: 12px; color: hsl(220, 10%, 45%); }

/* ===========================================
   ANIMATIONS - Exactes comme Lovable
   =========================================== */
@keyframes ryse-fadeUp {
  from { 
    opacity: 0; 
    transform: translateY(30px); 
  }
  to { 
    opacity: 1; 
    transform: translateY(0); 
  }
}

@keyframes ryse-fadeIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Animation des cartes - fadeUp avec delay */
.ryse-animate-fade-up {
  opacity: 0;
  animation: ryse-fadeUp 0.6s ease forwards;
}

/* Animation hero - fadeIn */
.ryse-animate-fade-in { 
  animation: ryse-fadeIn 0.6s ease forwards; 
}

/* Delays pour animations */
.ryse-animate-delay-100 { 
  animation-delay: 0.1s; 
  opacity: 0; 
}
.ryse-animate-delay-200 { 
  animation-delay: 0.2s; 
  opacity: 0; 
}.ryse-partners__img {
  height: 40px;
  width: auto;
  object-fit: contain;
}
/* RYSE AGENCY - REFONTE E-COMMERCE - ryse-refonte.css */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap");

:root {
  --ryse-background: #fcfcfc;
  --ryse-foreground: #1a1d23;
  --ryse-card: #ffffff;
  --ryse-border: #e8e4dd;
  --ryse-gold: #c9a227;
  --ryse-gold-light: #d4b84a;
  --ryse-charcoal: #141414;
  --ryse-charcoal-light: #2d3139;
  --ryse-muted: #64696f;
  --ryse-cream: #f5f3ef;
  --ryse-cream-dark: #ebe7df;
  --ryse-shadow-md: 0 4px 24px -4px rgba(26, 29, 35, 0.08);
  --ryse-shadow-xl: 0 12px 40px -8px rgba(26, 29, 35, 0.15);
}

.ryse-page { font-family: 'Inter', system-ui, sans-serif; -webkit-font-smoothing: antialiased; color: var(--ryse-foreground); line-height: 1.5; }
.ryse-page * { box-sizing: border-box; margin: 0; padding: 0; }

.ryse-container { max-width: 1280px; margin: 0 auto; padding: 0 24px; }
.ryse-container-wide { max-width: 1400px; margin: 0 auto; padding: 0 24px; }
@media (min-width: 1024px) { .ryse-container-wide { padding: 0 48px; } }

.ryse-section { padding: 64px 0; }
@media (min-width: 768px) { .ryse-section { padding: 96px 0; } }
@media (min-width: 1024px) { .ryse-section { padding: 128px 0; } }
.ryse-section-sm { padding: 48px 0; }

.ryse-label { font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.2em; color: var(--ryse-gold); margin-bottom: 16px; display: block; }
.ryse-heading-display { font-size: 32px; font-weight: 600; letter-spacing: -0.03em; line-height: 1.1; color: var(--ryse-foreground); margin-bottom: 16px; }
@media (min-width: 640px) { .ryse-heading-display { font-size: 40px; } }
@media (min-width: 768px) { .ryse-heading-display { font-size: 48px; } }
@media (min-width: 1024px) { .ryse-heading-display { font-size: 54px; } }
.ryse-heading-section { font-size: 32px; font-weight: 500; letter-spacing: -0.02em; line-height: 1.2; color: var(--ryse-foreground); margin-bottom: 24px; }
@media (min-width: 768px) { .ryse-heading-section { font-size: 48px; } }
.ryse-heading-subsection { font-size: 18px; font-weight: 600; letter-spacing: -0.02em; color: var(--ryse-foreground); margin-bottom: 8px; }
.ryse-text-editorial { font-size: 15px; line-height: 1.7; color: var(--ryse-muted); }
@media (min-width: 768px) { .ryse-text-editorial { font-size: 17px; } }
.ryse-text-body { font-size: 16px; line-height: 1.7; color: var(--ryse-muted); }
.ryse-subtitle { display: block; color: var(--ryse-muted); font-weight: 300; font-style: italic; font-size: 0.48em; margin-top: 12px; }
.ryse-text-white { color: #ffffff; }

.ryse-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 16px 32px; font-size: 14px; font-weight: 500; border-radius: 12px; text-decoration: none; transition: all 0.3s ease; cursor: pointer; border: none; font-family: inherit; }
.ryse-btn-primary { background-color: var(--ryse-charcoal); color: #ffffff; }
.ryse-btn-primary:hover { background-color: var(--ryse-charcoal-light); transform: translateY(-2px); }
.ryse-btn-secondary { background-color: transparent; color: var(--ryse-charcoal); border: 1px solid rgba(26, 29, 35, 0.2); }
.ryse-btn-secondary:hover { background-color: rgba(26, 29, 35, 0.05); }
.ryse-btn-gold { background-color: var(--ryse-gold); color: var(--ryse-charcoal); font-weight: 600; }
.ryse-btn-gold:hover { background-color: var(--ryse-gold-light); transform: translateY(-2px); }
.ryse-btn-white-outline { background-color: rgba(255, 255, 255, 0.1); color: #ffffff; border: 1px solid rgba(255, 255, 255, 0.2); }
.ryse-btn-white-outline:hover { background-color: rgba(255, 255, 255, 0.2); }
.ryse-btn svg { width: 20px; height: 20px; transition: transform 0.3s ease; flex-shrink: 0; }
.ryse-btn:hover svg { transform: translateX(4px); }

.ryse-card { background-color: var(--ryse-card); border-radius: 16px; border: 1px solid rgba(232, 228, 221, 0.5); box-shadow: var(--ryse-shadow-md); padding: 24px; transition: all 0.5s ease; }
.ryse-card-hover:hover { box-shadow: var(--ryse-shadow-xl); transform: translateY(-4px); }
.ryse-dark-card { padding: 24px; border-radius: 16px; background-color: rgba(255, 255, 255, 0.05); border: 1px solid rgba(255, 255, 255, 0.1); transition: border-color 0.3s ease; }
.ryse-dark-card:hover { border-color: rgba(201, 162, 39, 0.3); }
.ryse-plus-card { padding: 32px; border-radius: 16px; background-color: rgba(255, 255, 255, 0.05); border: 1px solid rgba(255, 255, 255, 0.1); }

.ryse-badge { display: inline-flex; align-items: center; gap: 8px; padding: 8px 16px; border-radius: 9999px; font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.15em; }
.ryse-badge-light { background-color: rgba(26, 29, 35, 0.05); color: var(--ryse-muted); }
.ryse-badge-dot { width: 8px; height: 8px; border-radius: 50%; background-color: var(--ryse-gold); }
.ryse-tag { display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px; border-radius: 9999px; font-size: 12px; font-weight: 500; background-color: var(--ryse-cream-dark); color: var(--ryse-charcoal); }
.ryse-tag-dark { background-color: rgba(255, 255, 255, 0.1); color: rgba(255, 255, 255, 0.8); }
.ryse-result-badge { display: inline-flex; align-items: center; gap: 4px; padding: 4px 8px; border-radius: 4px; background-color: rgba(201, 162, 39, 0.2); color: var(--ryse-gold); font-size: 12px; font-weight: 500; }
.ryse-impact-badge { display: inline-flex; align-items: center; gap: 8px; padding: 4px 12px; border-radius: 9999px; background-color: rgba(239, 68, 68, 0.1); color: #fca5a5; font-size: 12px; }

.ryse-grid { display: grid; gap: 24px; }
.ryse-grid-2 { grid-template-columns: 1fr; }
@media (min-width: 768px) { .ryse-grid-2 { grid-template-columns: repeat(2, 1fr); } }
.ryse-grid-3 { grid-template-columns: 1fr; }
@media (min-width: 768px) { .ryse-grid-3 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .ryse-grid-3 { grid-template-columns: repeat(3, 1fr); } }
.ryse-grid-4 { grid-template-columns: 1fr; }
@media (min-width: 640px) { .ryse-grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .ryse-grid-4 { grid-template-columns: repeat(4, 1fr); } }

.ryse-flex { display: flex; }
.ryse-flex-col { flex-direction: column; }
.ryse-flex-wrap { flex-wrap: wrap; }
.ryse-items-center { align-items: center; }
.ryse-items-start { align-items: flex-start; }
.ryse-justify-center { justify-content: center; }
.ryse-gap-2 { gap: 8px; }
.ryse-gap-3 { gap: 12px; }
.ryse-gap-4 { gap: 16px; }
.ryse-gap-6 { gap: 24px; }
@media (max-width: 639px) { .ryse-flex-col-sm { flex-direction: column; } }

.ryse-text-center { text-align: center; }
.ryse-max-w-3xl { max-width: 768px; }
.ryse-max-w-4xl { max-width: 896px; }
.ryse-max-w-5xl { max-width: 1024px; }
.ryse-mx-auto { margin-left: auto; margin-right: auto; }
.ryse-z-10 { position: relative; z-index: 10; }

.ryse-bg-light { background-color: var(--ryse-background); }
.ryse-bg-subtle { background-color: #fcfcfc; }
.ryse-bg-dark { background-color: var(--ryse-charcoal); color: #ffffff; }

.ryse-noise { position: relative; overflow: hidden; }
.ryse-noise::before { content: ""; position: absolute; inset: 0; opacity: 0.03; pointer-events: none; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E"); }

.ryse-glow { position: absolute; border-radius: 50%; pointer-events: none; filter: blur(80px); }
.ryse-glow-gold { background-color: rgba(201, 162, 39, 0.1); }

.ryse-icon { width: 24px; height: 24px; flex-shrink: 0; }
.ryse-icon-sm { width: 16px; height: 16px; flex-shrink: 0; }
.ryse-icon-box { width: 48px; height: 48px; border-radius: 12px; display: flex; align-items: center; justify-content: center; background-color: var(--ryse-cream-dark); flex-shrink: 0; }
.ryse-icon-box-sm { width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center; justify-content: center; background-color: rgba(201, 162, 39, 0.2); flex-shrink: 0; }
.ryse-icon-box-sm svg { width: 16px; height: 16px; color: var(--ryse-gold); }
.ryse-mistake-icon { width: 40px; height: 40px; border-radius: 12px; background-color: rgba(239, 68, 68, 0.2); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ryse-mistake-icon svg { width: 20px; height: 20px; color: #f87171; }
.ryse-icon-red { color: #f87171; }
.ryse-icon-green { color: #34d399; }
.ryse-icon-gold { color: var(--ryse-gold); }
.ryse-check-icon { width: 20px; height: 20px; color: #10b981; flex-shrink: 0; }
.ryse-geo-icon { width: 20px; height: 20px; color: var(--ryse-gold); }

.ryse-list { list-style: none; padding: 0; margin: 0; }
.ryse-list-item { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 12px; }
.ryse-list-item:last-child { margin-bottom: 0; }
.ryse-list-item-sm { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.ryse-list-item-sm:last-child { margin-bottom: 0; }

.ryse-link { color: var(--ryse-foreground); font-weight: 500; font-size: 14px; text-decoration: none; display: inline-flex; align-items: center; gap: 4px; transition: color 0.3s ease; }
.ryse-link:hover { color: var(--ryse-gold); }

.ryse-hero { padding: 80px 0; background-color: var(--ryse-background); }
@media (min-width: 1024px) { .ryse-hero { padding: 112px 0; } }

.ryse-stats { padding: 48px 0; background-color: #fcfcfc; }
.ryse-stat { text-align: center; }
.ryse-stat-value { font-size: 30px; font-weight: 700; color: var(--ryse-foreground); }
@media (min-width: 768px) { .ryse-stat-value { font-size: 36px; } }
.ryse-stat-label { font-size: 14px; color: var(--ryse-muted); margin-top: 4px; }

.ryse-reponse-rapide { max-width: 768px; margin: 0 auto; padding: 24px; background-color: rgba(201, 162, 39, 0.1); border: 1px solid rgba(201, 162, 39, 0.3); border-radius: 16px; }
.ryse-reponse-rapide-label { font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.1em; color: #9a7d1e; margin-bottom: 8px; }

.ryse-process-step { display: flex; gap: 24px; margin-bottom: 32px; }
.ryse-process-step:last-child { margin-bottom: 0; }
.ryse-process-left { display: flex; flex-direction: column; align-items: center; }
.ryse-process-number { width: 56px; height: 56px; border-radius: 16px; background-color: var(--ryse-charcoal); color: #ffffff; font-size: 18px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ryse-process-line { width: 2px; flex-grow: 1; background-color: var(--ryse-border); margin-top: 16px; }
.ryse-process-content { padding-bottom: 32px; }
.ryse-process-duration { display: inline-flex; padding: 4px 12px; border-radius: 9999px; background-color: var(--ryse-cream-dark); font-size: 12px; font-weight: 500; color: var(--ryse-foreground); margin-left: 12px; }

.ryse-comparison-note { padding-top: 16px; border-top: 1px solid var(--ryse-border); margin-top: 24px; }

.ryse-accordion { display: flex; flex-direction: column; gap: 16px; }
.ryse-accordion-item { background-color: #ffffff; border: 1px solid var(--ryse-border); border-radius: 12px; overflow: hidden; }
.ryse-accordion-item.is-open { border-color: rgba(201, 162, 39, 0.3); }
.ryse-accordion-trigger { width: 100%; padding: 20px 24px; background: none; border: none; text-align: left; font-size: 16px; font-weight: 600; color: var(--ryse-foreground); cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 16px; font-family: inherit; }
.ryse-accordion-trigger:hover { background-color: rgba(0, 0, 0, 0.02); }
.ryse-accordion-icon { width: 20px; height: 20px; transition: transform 0.3s ease; flex-shrink: 0; }
.ryse-accordion-item.is-open .ryse-accordion-icon { transform: rotate(180deg); }
.ryse-accordion-content { display: none; padding: 0 24px 20px; color: var(--ryse-muted); line-height: 1.7; font-size: 15px; }
.ryse-accordion-item.is-open .ryse-accordion-content { display: block; }

.ryse-cta { padding: 80px 0; background-color: var(--ryse-charcoal); color: #ffffff; position: relative; overflow: hidden; }
.ryse-cta-glow-1 { position: absolute; top: 0; left: 33%; width: 384px; height: 384px; background-color: rgba(201, 162, 39, 0.1); border-radius: 50%; filter: blur(80px); pointer-events: none; }
.ryse-cta-glow-2 { position: absolute; bottom: 0; right: 33%; width: 320px; height: 320px; background-color: rgba(201, 162, 39, 0.05); border-radius: 50%; filter: blur(80px); pointer-events: none; }

.ryse-trust-item { display: flex; align-items: center; gap: 8px; color: rgba(255, 255, 255, 0.5); font-size: 14px; }
.ryse-trust-item svg { width: 16px; height: 16px; }

@keyframes ryse-fade-in { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.ryse-animate { animation: ryse-fade-in 0.6s ease forwards; }
.ryse-delay-1 { animation-delay: 0.1s; opacity: 0; }
.ryse-delay-2 { animation-delay: 0.2s; opacity: 0; }
.ryse-delay-3 { animation-delay: 0.3s; opacity: 0; }

/* ===========================================
   MIGRATION HERO SECTION
   Design System RYSE Agency
   À ajouter dans assets/base.css
   =========================================== */

/* === MIGRATION HERO BASE === */
.migration-hero-section .mig-hero {
  position: relative;
  background-color: #141414;
  overflow: hidden;
  display: flex;
  align-items: center;
}

/* Hauteurs */
.migration-hero-section .mig-hero--full {
  min-height: 85vh;
}

.migration-hero-section .mig-hero--large {
  min-height: 70vh;
}

.migration-hero-section .mig-hero--medium {
  min-height: 60vh;
}

/* === GLOWS (Effets de fond) === */
.migration-hero-section .mig-hero__glow {
  position: absolute;
  border-radius: 9999px;
  pointer-events: none;
}

.migration-hero-section .mig-hero__glow--top {
  width: 600px;
  height: 600px;
  background: #C9A962;
  top: -20%;
  left: 50%;
  transform: translateX(-50%);
  opacity: 0.08;
  filter: blur(200px);
}

.migration-hero-section .mig-hero__glow--bottom {
  width: 400px;
  height: 400px;
  background: #3DB88B;
  bottom: 10%;
  right: 10%;
  opacity: 0.05;
  filter: blur(150px);
}

/* === NOISE TEXTURE === */
.migration-hero-section .mig-hero__noise {
  position: absolute;
  inset: 0;
  opacity: 0.03;
  pointer-events: none;
  z-index: 1;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
}

/* === CONTAINER === */
.migration-hero-section .mig-hero__container {
  position: relative;
  z-index: 10;
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
  padding: 80px 24px;
  width: 100%;
}

@media (min-width: 1024px) {
  .migration-hero-section .mig-hero__container {
    padding: 112px 48px;
  }
}

/* === CONTENT === */
.migration-hero-section .mig-hero__content {
  max-width: 896px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

/* === BADGE === */
.migration-hero-section .mig-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 9999px;
  background-color: rgba(201, 169, 98, 0.1);
  border: 1px solid rgba(201, 169, 98, 0.2);
  margin-bottom: 32px;
}

.migration-hero-section .mig-hero__badge-dot {
  width: 8px;
  height: 8px;
  border-radius: 9999px;
  flex-shrink: 0;
}

.migration-hero-section .mig-hero__badge-dot--mint {
  background-color: #3DB88B;
}

.migration-hero-section .mig-hero__badge-dot--gold {
  background-color: #C9A962;
}

.migration-hero-section .mig-hero__badge-text {
  color: #C9A962;
  font-size: 14px;
  font-weight: 500;
  font-family: 'Inter', system-ui, sans-serif;
}

/* === TITRE H1 === */
.migration-hero-section .mig-hero__title {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 28px;
  font-weight: 600;
  color: #F7F6F3;
  line-height: 1.1;
  letter-spacing: -0.03em;
  margin: 0 0 20px 0;
}

@media (min-width: 768px) {
  .migration-hero-section .mig-hero__title {
    font-size: 36px;
  }
}

@media (min-width: 1024px) {
  .migration-hero-section .mig-hero__title {
    font-size: 44px;
  }
}

/* === SOUS-TITRE H2 === */
.migration-hero-section .mig-hero__subtitle {
  color: #B49764;
  font-size: 20px;
  font-weight: 500;
  margin: 0 0 24px 0;
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  line-height: 1.3;
}

@media (min-width: 768px) {
  .migration-hero-section .mig-hero__subtitle {
    font-size: 28px;
  }
}

@media (min-width: 1024px) {
  .migration-hero-section .mig-hero__subtitle {
    font-size: 36px;
  }
}

/* === DESCRIPTION === */
.migration-hero-section .mig-hero__description {
  max-width: 800px;
  margin: 0 auto 40px auto;
}

.migration-hero-section .mig-hero__description-main,
.migration-hero-section .mig-hero__description-main p {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 16px;
  color: #F7F6F3;
  line-height: 1.7;
  margin: 0 0 20px 0;
}

.migration-hero-section .mig-hero__description-main strong {
  color: #C9A962;
  font-weight: 600;
}

@media (min-width: 768px) {
  .migration-hero-section .mig-hero__description-main,
  .migration-hero-section .mig-hero__description-main p {
    font-size: 20px;
  }
}

.migration-hero-section .mig-hero__description-secondary,
.migration-hero-section .mig-hero__description-secondary p {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 16px;
  color: #F7F6F3;
  line-height: 1.7;
  margin: 0;
}

.migration-hero-section .mig-hero__description-secondary strong {
  color: #FFFFFF;
  font-weight: 700;
}

@media (min-width: 768px) {
  .migration-hero-section .mig-hero__description-secondary,
  .migration-hero-section .mig-hero__description-secondary p {
    font-size: 20px;
  }
}

/* === CTAs === */
.migration-hero-section .mig-hero__ctas {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-bottom: 48px;
}

.migration-hero-section .mig-hero__cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 24px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  transition: all 0.3s ease;
  font-family: 'Inter', system-ui, sans-serif;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
}

.migration-hero-section .mig-hero__cta--primary {
  background-color: #C9A962;
  color: #141414;
  border: none;
}

.migration-hero-section .mig-hero__cta--primary:hover {
  background-color: #D4B872;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px -4px rgba(201, 169, 98, 0.4);
  color: #141414;
  text-decoration: none;
}

.migration-hero-section .mig-hero__cta--secondary {
  background-color: #1F1F1F;
  color: #F7F6F3;
  border: 1px solid rgba(247, 246, 243, 0.15);
}

.migration-hero-section .mig-hero__cta--secondary:hover {
  background-color: #262626;
  border-color: rgba(247, 246, 243, 0.3);
  color: #F7F6F3;
  text-decoration: none;
}

.migration-hero-section .mig-hero__cta-icon {
  width: 16px;
  height: 16px;
  transition: transform 0.3s ease;
}

.migration-hero-section .mig-hero__cta--primary:hover .mig-hero__cta-icon {
  transform: translateX(4px);
}

/* === TRUST BADGES === */
.migration-hero-section .mig-hero__trust {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 32px;
  padding-top: 32px;
  border-top: 1px solid rgba(247, 246, 243, 0.1);
}

.migration-hero-section .mig-hero__trust-item {
  display: flex;
  align-items: center;
  gap: 8px;
}

.migration-hero-section .mig-hero__trust-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.migration-hero-section .mig-hero__trust-icon--mint {
  color: #3DB88B;
}

.migration-hero-section .mig-hero__trust-icon--gold {
  color: #C9A962;
}

.migration-hero-section .mig-hero__trust-text {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 14px;
  color: rgba(247, 246, 243, 0.7);
}

/* === ANIMATIONS === */
@keyframes migFadeIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.migration-hero-section .animate-fade-in {
  animation: migFadeIn 0.6s ease forwards;
}

.migration-hero-section .animation-delay-100 {
  animation-delay: 0.1s;
  opacity: 0;
}

.migration-hero-section .animation-delay-200 {
  animation-delay: 0.2s;
  opacity: 0;
}

.migration-hero-section .animation-delay-300 {
  animation-delay: 0.3s;
  opacity: 0;
}

.migration-hero-section .animation-delay-400 {
  animation-delay: 0.4s;
  opacity: 0;
}

/* === RESPONSIVE === */
@media (max-width: 767px) {
  .migration-hero-section .mig-hero__trust {
    flex-direction: column;
    gap: 16px;
  }
  
  .migration-hero-section .mig-hero__ctas {
    flex-direction: column;
    width: 100%;
  }
  
  .migration-hero-section .mig-hero__cta {
    width: 100%;
    justify-content: center;
  }
  
  .migration-hero-section .mig-hero__glow--top {
    width: 300px;
    height: 300px;
    filter: blur(100px);
  }
  
  .migration-hero-section .mig-hero__glow--bottom {
    width: 200px;
    height: 200px;
    filter: blur(80px);
  }
}/* ===========================================
   BLOG SOMMAIRE - TABLE DES MATIÈRES
   Design System RYSE Agency
   À COPIER DANS: assets/base.css
   =========================================== */

/* === BASE === */
.section-blog-sommaire {
  background-color: #FCFCFC !important;
}

.section-blog-sommaire .blog-sommaire {
  padding-top: 48px;
  padding-bottom: 48px;
}

@media (min-width: 768px) {
  .section-blog-sommaire .blog-sommaire {
    padding-top: 64px;
    padding-bottom: 64px;
  }
}

/* === CONTAINER === */
.section-blog-sommaire .blog-sommaire__container {
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
}

@media (min-width: 768px) {
  .section-blog-sommaire .blog-sommaire__container {
    padding-left: 32px;
    padding-right: 32px;
  }
}

@media (min-width: 1024px) {
  .section-blog-sommaire .blog-sommaire__container {
    padding-left: 48px;
    padding-right: 48px;
  }
}

/* === NAV === */
.section-blog-sommaire .blog-sommaire__nav {
  max-width: 896px;
  margin-left: auto;
  margin-right: auto;
  background-color: #FFFFFF;
  border-radius: 20px;
  padding: 32px;
  border: 1px solid hsl(40, 15%, 88%);
  box-shadow: 0 4px 24px -4px hsla(220, 15%, 12%, 0.08);
}

@media (min-width: 768px) {
  .section-blog-sommaire .blog-sommaire__nav {
    padding: 40px 48px;
  }
}

/* === LABEL === */
.section-blog-sommaire .blog-sommaire__label {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: hsl(220, 15%, 12%);
  margin: 0 0 24px 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* === GRID === */
.section-blog-sommaire .blog-sommaire__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

@media (min-width: 768px) {
  .section-blog-sommaire .blog-sommaire__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
}

/* === LINK === */
.section-blog-sommaire .blog-sommaire__link {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 20px;
  background-color: hsl(45, 20%, 96%);
  border-radius: 12px;
  border: 1px solid transparent;
  text-decoration: none;
  transition: all 0.3s ease;
}

.section-blog-sommaire .blog-sommaire__link:hover {
  background-color: #FFFFFF;
  border-color: hsl(43, 50%, 60%);
  box-shadow: 0 4px 16px -4px hsla(43, 50%, 60%, 0.2);
  transform: translateY(-2px);
}

/* === LINK NUMBER === */
.section-blog-sommaire .blog-sommaire__link-number {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: hsl(38, 35%, 55%);
  flex-shrink: 0;
  min-width: 28px;
}

/* === LINK TEXT === */
.section-blog-sommaire .blog-sommaire__link-text {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: hsl(220, 15%, 12%);
  line-height: 1.5;
  transition: color 0.3s ease;
}

.section-blog-sommaire .blog-sommaire__link:hover .blog-sommaire__link-text {
  color: hsl(38, 35%, 55%);
}

/* === RESPONSIVE MOBILE === */
@media (max-width: 767px) {
  .section-blog-sommaire .blog-sommaire__nav {
    padding: 24px;
    border-radius: 16px;
  }
  
  .section-blog-sommaire .blog-sommaire__label {
    font-size: 13px;
    margin-bottom: 20px;
  }
  
  .section-blog-sommaire .blog-sommaire__link {
    padding: 14px 16px;
  }
  
  .section-blog-sommaire .blog-sommaire__link-text {
    font-size: 13px;
  }
}
/* ===========================================
   DEFINITION - SECTION ENCYCLOPÉDIQUE
   Design System RYSE Agency
   À COPIER DANS: assets/base.css
   =========================================== */

/* === BASE === */
.section-definition {
  background-color: hsla(160, 60%, 45%, 0.05);
  border-bottom: 1px solid hsla(160, 60%, 45%, 0.15);
}

.section-definition .definition {
  padding-top: 40px;
  padding-bottom: 40px;
}

/* === CONTAINER === */
.section-definition .definition__container {
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 24px;
  padding-right: 24px;
}

@media (min-width: 1024px) {
  .section-definition .definition__container {
    padding-left: 48px;
    padding-right: 48px;
  }
}

/* === CARD === */
.section-definition .definition__card {
  max-width: 1024px;
  margin-left: auto;
  margin-right: auto;
  padding: 24px;
  background-color: #FFFFFF;
  border-radius: 16px;
  border: 2px solid hsla(160, 60%, 45%, 0.3);
  box-shadow: 0 4px 24px -4px hsla(160, 60%, 45%, 0.1);
}

@media (min-width: 768px) {
  .section-definition .definition__card {
    padding: 32px;
    border-radius: 20px;
  }
}

/* === CONTENT LAYOUT === */
.section-definition .definition__content {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}

@media (min-width: 768px) {
  .section-definition .definition__content {
    gap: 20px;
  }
}

/* === ICON === */
.section-definition .definition__icon-wrapper {
  width: 48px;
  height: 48px;
  min-width: 48px;
  border-radius: 12px;
  background-color: hsla(160, 60%, 45%, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.section-definition .definition__icon {
  width: 24px;
  height: 24px;
  color: hsl(160, 60%, 45%);
}

/* === TEXT CONTENT === */
.section-definition .definition__text {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* === TITLE === */
.section-definition .definition__title {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: hsl(220, 15%, 12%);
  margin: 0;
  line-height: 1.4;
}

@media (min-width: 768px) {
  .section-definition .definition__title {
    font-size: 18px;
  }
}

/* === DESCRIPTION === */
.section-definition .definition__description {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 15px;
  font-weight: 400;
  color: hsl(220, 15%, 12%);
  margin: 0;
  line-height: 1.7;
}

@media (min-width: 768px) {
  .section-definition .definition__description {
    font-size: 17px;
  }
}

.section-definition .definition__description strong {
  font-weight: 600;
  color: hsl(220, 15%, 12%);
}

/* === NOTE === */
.section-definition .definition__note {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 14px;
  font-weight: 400;
  color: hsl(220, 10%, 45%);
  margin: 0;
  line-height: 1.7;
}

@media (min-width: 768px) {
  .section-definition .definition__note {
    font-size: 15px;
  }
}

/* === RESPONSIVE MOBILE === */
@media (max-width: 480px) {
  .section-definition .definition__content {
    flex-direction: column;
    gap: 12px;
  }
  
  .section-definition .definition__icon-wrapper {
    width: 40px;
    height: 40px;
    min-width: 40px;
    border-radius: 10px;
  }
  
  .section-definition .definition__icon {
    width: 20px;
    height: 20px;
  }
}