/*
 * Custom code goes here.
 * Arienne Audio custom theme
 * Accent: #D86018
 * Dark base: #253237
 */

/* =========================================================
   1. Tokens / Bootstrap overrides
   ========================================================= */

:root,
[data-bs-theme="light"],
[data-bs-theme="dark"] {
  /* Brand */
  --aa-accent: #D86018;
  --aa-accent-rgb: 216, 96, 24;
  --aa-accent-soft: rgba(216, 96, 24, 0.08);
  --aa-accent-soft-strong: rgba(216, 96, 24, 0.14);

  --aa-dark: #253237;
  --aa-dark-rgb: 37, 50, 55;
  --aa-dark-950: #0d1214;
  --aa-dark-900: #151d20;
  --aa-dark-850: #1a2428;
  --aa-dark-800: #253237;
  --aa-dark-700: #304148;
  --aa-dark-600: #40565f;

  --aa-cream: #fff8f2;
  --aa-white-soft: rgba(255, 255, 255, 0.82);
  --aa-white-muted: rgba(255, 255, 255, 0.62);
  --aa-white-faint: rgba(255, 255, 255, 0.46);

  /* Bootstrap-friendly support colors */
  --aa-primary-subtle: #F7DFD1;
  --aa-primary-border-subtle: #EFBFA3;
  --aa-primary-active-soft: #F3CFBA;
  --aa-focus-ring: rgba(216, 96, 24, 0.25);
  --aa-input-focus-border: #ECB08C;

  /* Motion */
  --aa-transition-fast: 150ms cubic-bezier(.2, .8, .2, 1);
  --aa-transition: 190ms cubic-bezier(.2, .8, .2, 1);

  /* Radius */
  --aa-radius-sm: 0.35rem;
  --aa-radius: 0.45rem;
  --aa-radius-lg: 0.65rem;

  /* Shadows */
  --aa-shadow-soft: 0 1rem 2.25rem rgba(37, 50, 55, 0.14);
  --aa-shadow-menu: 0 1rem 2.4rem rgba(37, 50, 55, 0.16);

  /* Fonts */
  --aa-font-ui: "DM Sans", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --aa-font-heading: "Fraunces", Georgia, "Times New Roman", serif;

  --bs-font-sans-serif: var(--aa-font-ui);
  --bs-body-font-family: var(--aa-font-ui);
  --ps-ui-font-family: var(--aa-font-ui);
  --ps-heading-font-family: var(--aa-font-heading);

  /* Bootstrap theme colors */
  --bs-primary: var(--aa-accent);
  --bs-primary-rgb: var(--aa-accent-rgb);
  --bs-success: var(--aa-accent);
  --bs-success-rgb: var(--aa-accent-rgb);
  --bs-dark: var(--aa-dark);
  --bs-dark-rgb: var(--aa-dark-rgb);

  --bs-link-color: var(--aa-accent);
  --bs-link-color-rgb: var(--aa-accent-rgb);
  --bs-link-hover-color: var(--aa-accent);
  --bs-link-hover-color-rgb: var(--aa-accent-rgb);

  --bs-primary-text-emphasis: var(--aa-accent);
  --bs-primary-bg-subtle: var(--aa-primary-subtle);
  --bs-primary-border-subtle: var(--aa-primary-border-subtle);
  --bs-success-text-emphasis: var(--aa-accent);
  --bs-success-bg-subtle: var(--aa-primary-subtle);
  --bs-success-border-subtle: var(--aa-primary-border-subtle);
  --bs-form-valid-color: var(--aa-dark);
  --bs-form-valid-border-color: var(--aa-accent);
  --bs-form-valid-icon: none;
  --bs-focus-ring-color: var(--aa-focus-ring);
}

:root,
[data-bs-theme="light"] {
  --bs-body-color: var(--aa-dark);
  --bs-emphasis-color: var(--aa-dark);
  --bs-secondary-color: rgba(var(--aa-dark-rgb), 0.72);
  --bs-tertiary-color: rgba(var(--aa-dark-rgb), 0.56);
}

[data-bs-theme="dark"] {
  --bs-body-bg: var(--aa-dark);
  --bs-body-bg-rgb: var(--aa-dark-rgb);
  --bs-body-color: var(--aa-white-soft);
  --bs-emphasis-color: #fff;
  --bs-secondary-color: var(--aa-white-muted);
  --bs-tertiary-color: var(--aa-white-faint);

  --bs-primary-text-emphasis: #E8A074;
  --bs-primary-bg-subtle: var(--aa-dark);
  --bs-primary-border-subtle: #823A0E;
  --bs-success-text-emphasis: #E8A074;
  --bs-success-bg-subtle: rgba(var(--aa-accent-rgb), 0.18);
  --bs-success-border-subtle: #823A0E;
  --bs-form-valid-color: var(--aa-white-soft);
  --bs-form-valid-border-color: #E8A074;
}


/* =========================================================
   2. Base / Typography
   ========================================================= */

html,
body {
  min-height: 100%;
  font-family: var(--aa-font-ui);
  font-optical-sizing: auto;
}

button,
input,
optgroup,
select,
textarea,
.btn,
.nav,
.nav-link,
.dropdown-menu,
.dropdown-item,
.form-control,
.form-select,
.form-label,
.input-group-text,
.badge,
.breadcrumb,
.pagination,
.page-link,
.accordion-button,
.modal,
.modal-title,
.offcanvas,
.popover,
.tooltip,
.toast,
.table,
.product-miniature,
.product-line,
.cart-summary,
.checkout-steps,
.ps-mainmenu,
.ps-searchbar {
  font-family: var(--aa-font-ui);
  font-optical-sizing: auto;
}

h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6,
.page-title-section,
.section-title,
.left-block__title,
.right-block__title,
.footer-block__title,
.product__name,
.quickview .product__name,
.blockcart-modal__title {
  font-family: var(--aa-font-heading);
  font-optical-sizing: auto;
  font-weight: 600;
  letter-spacing: -0.015em;
}

h1,
.h1,
.page-title-section,
.page-product .product__name,
.page-content--home h1,
.page-content--home h2,
.page-content--home .section-title,
.ps-imageslider__figcaption h1,
.ps-imageslider__figcaption h2,
.ps-imageslider__figcaption .h1,
.ps-imageslider__figcaption .h2 {
  font-family: var(--aa-font-heading);
  font-weight: 650;
  letter-spacing: -0.025em;
}

h2,
.h2,
.section-title {
  font-weight: 600;
  letter-spacing: -0.02em;
}

h3,
h4,
h5,
h6,
.h3,
.h4,
.h5,
.h6,
.left-block__title,
.right-block__title,
.footer-block__title {
  font-weight: 600;
  letter-spacing: -0.01em;
}

.product-miniature__title,
.product-miniature__title a,
.product-miniature__name,
.product-line__title,
.product-pack__name,
.cart-summary-product__title,
.order-confirmation__product-title,
.order-confirmation__product-link,
.ps-searchbar__result-name {
  font-family: var(--aa-font-ui);
  font-weight: 600;
  letter-spacing: 0;
}

.page-product .product__name {
  line-height: 1.1;
}

.btn {
  font-family: var(--aa-font-ui);
  font-weight: 600;
  letter-spacing: 0;
}

.aa-review-audio-embeds {
  display: grid;
  gap: 0.75rem;
  margin: 1rem 0 1.25rem;
}

.aa-review-audio-embed {
  display: block;
  width: 100%;
  max-width: 42rem;
  border: 1px solid rgba(var(--aa-dark-rgb), 0.12);
  border-radius: var(--aa-radius);
  background: #fff;
  box-shadow: 0 0.75rem 1.75rem rgba(var(--aa-dark-rgb), 0.08);
}

.aa-youtube-placeholder {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  padding: 0;
  overflow: hidden;
  border: 0;
  border-radius: var(--aa-radius);
  background:
    radial-gradient(circle at 32% 24%, rgba(var(--aa-accent-rgb), 0.28), transparent 34%),
    linear-gradient(135deg, rgba(var(--aa-dark-rgb), 0.88), rgba(var(--aa-dark-rgb), 0.7));
  cursor: pointer;
}

.aa-youtube-placeholder__play {
  position: absolute;
  inset: 50% auto auto 50%;
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  background: var(--aa-accent);
  box-shadow: 0 1rem 2rem rgba(var(--aa-dark-rgb), 0.22);
  transform: translate(-50%, -50%);
  transition:
    background-color 0.16s ease,
    transform 0.16s ease;
}

.aa-youtube-placeholder__play::before {
  position: absolute;
  inset: 50% auto auto 54%;
  width: 0;
  height: 0;
  border-top: 0.72rem solid transparent;
  border-bottom: 0.72rem solid transparent;
  border-left: 1.05rem solid #fff;
  content: "";
  transform: translate(-50%, -50%);
}

.aa-youtube-placeholder:hover .aa-youtube-placeholder__play,
.aa-youtube-placeholder:focus-visible .aa-youtube-placeholder__play {
  background: var(--aa-accent-dark);
  transform: translate(-50%, -50%) scale(1.05);
}

.aa-youtube-placeholder:focus-visible {
  outline: 3px solid rgba(var(--aa-accent-rgb), 0.38);
  outline-offset: 3px;
}

.ps-mainmenu,
.ps-mainmenu a,
.header-block__action-btn,
.dropdown-item,
.nav-link {
  font-family: var(--aa-font-ui);
  font-weight: 500;
}

.product__price,
.product-miniature__price,
.product-line__price,
.product-line__item-price,
.cart-summary__value,
.order-confirmation__product-total,
.order-confirmation__line-value,
.price,
.current-price,
.regular-price {
  font-family: var(--aa-font-ui);
  font-weight: 700;
  letter-spacing: -0.01em;
}

p,
.rich-text,
.product__description-short,
.category__description,
.product-comment-list-item,
.page-content {
  font-family: var(--aa-font-ui);
  line-height: 1.55;
}


/* =========================================================
   3. Global interactions / focus
   ========================================================= */

a {
  transition:
    color var(--aa-transition-fast),
    background-color var(--aa-transition-fast),
    border-color var(--aa-transition-fast),
    opacity var(--aa-transition-fast);
}

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

.focus-ring-primary {
  --bs-focus-ring-color: rgba(var(--aa-accent-rgb), var(--bs-focus-ring-opacity));
}

.form-control:focus,
.form-select:focus {
  border-color: var(--aa-input-focus-border);
  box-shadow: 0 0 0 .25rem var(--aa-focus-ring);
}

.form-check-input:focus,
.nav-link:focus-visible,
.page-link:focus,
.stars-selector:has(.stars-selector__input:focus-visible),
.search-filters__form-check--color .color:focus-visible {
  box-shadow: 0 0 0 .25rem var(--aa-focus-ring);
}

@keyframes aa-close-button-pulse {
  0% {
    transform: scale(1);
    background-color: transparent;
    filter: none;
  }

  45% {
    transform: scale(1.14);
    background-color: rgba(var(--aa-accent-rgb), 0.14);
    filter:
      invert(45%)
      sepia(81%)
      saturate(1475%)
      hue-rotate(353deg)
      brightness(91%)
      contrast(87%);
  }

  100% {
    transform: scale(1);
    background-color: transparent;
    filter: none;
  }
}

/*
  Close / X buttons:
  - mouse click gets a short orange pulse
  - no orange focus box after click
  - keyboard focus still gets an accessible outline
*/
.btn-close,
.ps-mainmenu--mobile .btn-close {
  transition:
    transform var(--aa-transition-fast),
    background-color var(--aa-transition-fast),
    filter var(--aa-transition-fast);
}

.btn-close:focus,
.btn-close:active,
.ps-mainmenu--mobile .btn-close:focus,
.ps-mainmenu--mobile .btn-close:active {
  box-shadow: none !important;
}

.btn-close:focus:not(:focus-visible),
.ps-mainmenu--mobile .btn-close:focus:not(:focus-visible) {
  outline: 0 !important;
  animation: aa-close-button-pulse 260ms ease-out;
}

.btn-close:active,
.ps-mainmenu--mobile .btn-close:active {
  animation: aa-close-button-pulse 260ms ease-out;
}

.btn-close:focus-visible,
.ps-mainmenu--mobile .btn-close:focus-visible {
  outline: 2px solid rgba(var(--aa-accent-rgb), 0.5);
  outline-offset: 3px;
}

.outline:focus-visible,
.page-product .product__thumbnail.active .product__thumbnail-image,
.stars-selector .stars-selector__input:focus-visible + .stars-selector__input-label,
.ps-mainmenu .ps-mainmenu__tree-link:focus:not(:focus-visible),
.ps-mainmenu .ps-mainmenu__tree-dropdown-toggle:focus:not(:focus-visible),
.ps-mainmenu .submenu__left-item:focus:not(:focus-visible) {
  outline: 0 !important;
  box-shadow: none !important;
}
.ps-searchbar__result-link:focus-visible,
.search-filters .noUi-handle:focus-visible {
  outline-color: var(--aa-accent) !important;
}


/* =========================================================
   4. Bootstrap / component accent overrides
   ========================================================= */

/* Buttons */

.btn-primary {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--aa-accent);
  --bs-btn-border-color: var(--aa-accent);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--aa-accent);
  --bs-btn-hover-border-color: var(--aa-accent);
  --bs-btn-focus-shadow-rgb: var(--aa-accent-rgb);
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: var(--aa-accent);
  --bs-btn-active-border-color: var(--aa-accent);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: var(--aa-accent);
  --bs-btn-disabled-border-color: var(--aa-accent);
}

.btn-outline-primary {
  --bs-btn-color: var(--aa-accent);
  --bs-btn-border-color: var(--aa-accent);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--aa-accent);
  --bs-btn-hover-border-color: var(--aa-accent);
  --bs-btn-focus-shadow-rgb: var(--aa-accent-rgb);
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: var(--aa-accent);
  --bs-btn-active-border-color: var(--aa-accent);
  --bs-btn-disabled-color: var(--aa-accent);
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: var(--aa-accent);
}

.btn-primary,
.btn-primary:is(:hover, :focus, :focus-visible, :active, .active, .show),
.btn-check:checked + .btn-primary,
.btn-check:active + .btn-primary,
:not(.btn-check) + .btn-primary:active,
.btn-outline-primary:is(:hover, :focus, :focus-visible, :active, .active),
.btn-check:checked + .btn-outline-primary {
  color: #fff !important;
  background-color: var(--aa-accent) !important;
  border-color: var(--aa-accent) !important;
}

.btn-tertiary,
.btn-outline-tertiary,
.btn-basic,
.btn-link {
  --bs-btn-hover-color: var(--aa-accent);
  --bs-btn-active-color: var(--aa-accent);
  --bs-btn-focus-shadow-rgb: var(--aa-accent-rgb);
}

.btn-tertiary:is(:hover, :focus, :focus-visible, :active),
.btn-outline-tertiary:is(:hover, :focus, :focus-visible, :active),
.btn-basic:is(:hover, :focus, :focus-visible, :active),
.btn-link:is(:hover, :focus, :focus-visible, :active) {
  color: var(--aa-accent) !important;
}

/* Keep icons inheriting text color */

.btn-primary *,
.btn-outline-primary:is(:hover, :focus, :active) *,
.btn-tertiary:hover *,
.btn-outline-tertiary:hover *,
.btn-basic:hover *,
.btn-link:hover *,
.dropdown-item:is(.active, :active) *,
.bg-primary *,
.text-bg-primary *,
.badge.bg-primary *,
.product-flags .badge:not(.discount) *,
.header-block__badge *,
.quantity-button button:is(:hover, :focus, :active) *,
.wishlist-button-add:hover :is(i, svg, .material-icons) {
  color: inherit !important;
  fill: currentColor !important;
  stroke: currentColor;
}

/* Utilities */

.link-primary,
.link-primary:is(:focus, :hover) {
  color: rgba(var(--aa-accent-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: rgba(var(--aa-accent-rgb), var(--bs-link-underline-opacity, 1)) !important;
}

.text-primary,
.text-primary-emphasis {
  color: rgba(var(--aa-accent-rgb), var(--bs-text-opacity, 1)) !important;
}

.bg-primary,
.text-bg-primary,
.badge.bg-primary {
  color: #fff !important;
  background-color: rgba(var(--aa-accent-rgb), var(--bs-bg-opacity, 1)) !important;
}

.border-primary {
  border-color: rgba(var(--aa-accent-rgb), var(--bs-border-opacity, 1)) !important;
}

.border-primary-subtle {
  border-color: var(--aa-primary-border-subtle) !important;
}

.bg-primary-subtle {
  background-color: var(--aa-primary-subtle) !important;
}

/* Dropdowns / Nav / Pagination / Lists */

.dropdown-menu,
.dropdown-menu-dark {
  --bs-dropdown-link-active-bg: var(--aa-accent);
}

.dropdown-item {
  transition:
    color var(--aa-transition-fast),
    background-color var(--aa-transition-fast);
}

.dropdown-item:is(:hover, :focus) {
  color: var(--aa-accent) !important;
  background-color: var(--aa-accent-soft) !important;
}

.dropdown-item:is(.active, :active) {
  color: #fff !important;
  background-color: var(--aa-accent) !important;
}

.nav {
  --bs-nav-link-color: var(--aa-accent);
  --bs-nav-link-hover-color: var(--aa-accent);
}

.nav-link:is(:hover, :focus, :active),
.nav-tabs .nav-link:is(:hover, :focus),
.nav-underline .nav-link:is(:hover, :focus) {
  color: var(--aa-accent) !important;
}

.nav-pills {
  --bs-nav-pills-link-active-bg: var(--aa-accent);
}

.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
  color: #fff !important;
  background-color: var(--aa-accent) !important;
}

.pagination {
  --bs-pagination-color: var(--aa-accent);
  --bs-pagination-hover-color: var(--aa-accent);
  --bs-pagination-focus-color: var(--aa-accent);
  --bs-pagination-active-color: var(--aa-accent);
  --bs-pagination-focus-box-shadow: 0 0 0 .25rem var(--aa-focus-ring);
}

.page-link:is(:hover, :focus, .active),
.active > .page-link {
  color: var(--aa-accent) !important;
}

.list-group {
  --bs-list-group-active-bg: var(--aa-accent);
  --bs-list-group-active-border-color: var(--aa-accent);
}

.list-group-item.active {
  color: #fff !important;
  background-color: var(--aa-accent) !important;
  border-color: var(--aa-accent) !important;
}

/* Forms */

.form-check-input:checked,
.form-check-input[type="checkbox"]:indeterminate {
  background-color: var(--aa-accent);
  border-color: var(--aa-accent);
}

.form-range:focus::-webkit-slider-thumb {
  box-shadow: 0 0 0 1px #fff, 0 0 0 .25rem var(--aa-focus-ring);
}

.form-range:focus::-moz-range-thumb {
  box-shadow: 0 0 0 1px #fff, 0 0 0 .25rem var(--aa-focus-ring);
}

.form-range::-webkit-slider-thumb {
  background-color: var(--aa-accent);
}

.form-range::-moz-range-thumb {
  background-color: var(--aa-accent);
}

.form-range::-webkit-slider-thumb:active {
  background-color: var(--aa-primary-active-soft);
}

.form-range::-moz-range-thumb:active {
  background-color: var(--aa-primary-active-soft);
}

/* Progress / Tables */

.progress,
.progress-stacked {
  --bs-progress-bar-bg: var(--aa-accent);
}

.progress-bar {
  color: #fff !important;
  background-color: var(--aa-accent) !important;
}

.table-primary {
  --bs-table-color: var(--aa-dark);
  --bs-table-bg: var(--aa-primary-subtle);
  --bs-table-border-color: #C6B2A7;
  --bs-table-striped-bg: #EBD4C7;
  --bs-table-striped-color: var(--aa-dark);
  --bs-table-active-bg: #DEC8BC;
  --bs-table-active-color: var(--aa-dark);
  --bs-table-hover-bg: #E5CEC2;
  --bs-table-hover-color: var(--aa-dark);
}

/* Misc component accents */

.product-flags .badge:not(.discount),
.header-block__badge,
.noUi-connect,
.noUi-active,
.noUi-active:hover,
.noUi-handle:hover {
  color: #fff !important;
  background-color: var(--aa-accent) !important;
  border-color: var(--aa-accent) !important;
}

.carousel-indicators .active {
  background-color: var(--aa-accent) !important;
}

.product-flags .badge.discount {
  color: var(--aa-accent) !important;
  background-color: var(--bs-white);
  border-color: var(--aa-accent) !important;
}

.noUi-handle:hover,
.noUi-active:hover,
.quantity-button button:is(:hover, :focus, :focus-visible, :active) {
  color: var(--aa-accent) !important;
  border-color: var(--aa-accent) !important;
  opacity: 1 !important;
}

.wishlist-button-add:hover {
  color: var(--aa-accent) !important;
  opacity: 1 !important;
}

/* Product/category/account/search link hover consistency */

.left-block__title-link:hover,
.right-block__title-link:hover,
.left-block__link:hover,
.right-block__link:hover,
.category-tree__title-link:hover,
.category-tree__item-link:hover,
.category-tree__item.active > .category-tree__item-header.parent .category-tree__item-link,
.search-filters__link:hover,
.search-filters__color-label:hover,
.sitemap__link:hover,
.account-menu__link:hover,
.account-menu--sidebar .account-menu__link--active,
.product-line__title:hover,
.product-miniature__title a:hover,
.product-miniature__name:hover,
.product-miniature a:hover,
.product-pack__link:hover .product-pack__name,
.attachment__name:hover,
.brand:hover .brand__title,
.supplier:hover .supplier__title,
.ps-searchbar__result-link:active .ps-searchbar__result-name,
#header .ps-contactinfo a:hover,
.ps-sharebuttons__link:hover {
  color: var(--aa-accent) !important;
}

.product-miniature__variants .color:is(.active, :focus-visible, :hover),
.product-variant__colors .color:is(.active, :focus-visible, :hover),
.search-filters__form-check--color .form-check-label .color:is(.active, :focus-visible, :hover),
.input-color__input:focus-visible + .input-color__label .color {
  outline-color: var(--aa-accent) !important;
}

.blockreassurance--dark {
  background-color: var(--aa-dark);
}

.blockreassurance--dark .reassurance--link:hover .reassurance__title {
  color: var(--aa-accent) !important;
}


/* =========================================================
   5. Header
   ========================================================= */

.header,
.header-bottom,
.header-bottom--single,
.header-bottom__container,
.header-bottom__single-row,
.header-single__left {
  overflow: visible;
}

#header,
.header {
  border-bottom: 0;
  box-shadow: none;
}

.header-bottom--single {
  position: relative;
  z-index: 20;
  padding: 0.75rem 0;
  background: var(--bs-body-bg);
  border-bottom: 0;
  box-shadow: none;
}

.header-bottom--single > * {
  position: relative;
  z-index: 2;
}

.header-single__left,
.header-single__right,
.header-single__logo {
  min-width: 0;
}

.header-single__logo .navbar-brand {
  margin: 0;
  padding: 0;
}

.header-single__logo .logo {
  width: auto;
  max-width: 9rem;
  max-height: 3rem;
}

.header-single__left .ps-mainmenu {
  width: auto;
  max-width: 100%;
}

.header-single__right {
  display: flex !important;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
  flex-wrap: nowrap;
}

.header-single__right > *,
.header-single__right .header-block,
.header-single__right [id^="_desktop_ps_"] {
  flex: 0 0 auto;
}

.header-single__right #_desktop_ps_searchbar {
  order: 10 !important;
  margin-left: 0 !important;
  padding-inline: 0;
}

.header-single__right #_desktop_ps_languageselector,
.header-single__right .header-single__language {
  order: 12 !important;
  margin-left: 0 !important;
}

.header-single__right #_desktop_ps_currencyselector,
.header-single__right .header-single__currency {
  order: 14 !important;
  margin-left: 0 !important;
}

.header-single__right #_desktop_ps_customersignin,
.header-single__right .header-single__signin {
  order: 20 !important;
  margin-left: 0 !important;
}

.header-single__right #_desktop_ps_shoppingcart,
.header-single__right .header-single__cart {
  order: 30 !important;
  margin-left: 0 !important;
}

.header-single__right .ps-searchbar {
  width: min(16rem, 32vw);
}

.header-single__right #_desktop_ps_customersignin .header-block__action-btn,
.header-single__right #_desktop_ps_shoppingcart .header-block__action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  padding: 0 !important;
  text-decoration: none;
  cursor: pointer;
}

.header-single__right #_desktop_ps_customersignin .header-block__icon,
.header-single__right #_desktop_ps_shoppingcart .header-block__icon {
  margin: 0;
}

.header-single__right #_desktop_ps_customersignin .dropdown-toggle::after {
  display: none !important;
}

.header-single__right .ps-languageselector,
.header-single__right .ps-currencyselector {
  display: inline-flex;
  align-items: center;
}

.header-single__right .ps-languageselector .form-select,
.header-single__right .ps-currencyselector .form-select {
  width: auto;
  min-width: 4.75rem;
  max-width: 7rem;
  height: 2.5rem;
  padding-block: 0;
  padding-inline: 0.8rem 1.8rem;
  color: var(--aa-dark);
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0;
  text-transform: uppercase;
  cursor: pointer;
  background-color: transparent;
  border: 0;
  border-radius: 999px;
  box-shadow: none;
  transition:
    color var(--aa-transition-fast),
    background-color var(--aa-transition-fast);
}

.header-single__right .ps-currencyselector .form-select {
  color: var(--aa-dark);
  font-family: inherit;
  font-size: 0.95rem;
  background-color: #fff;
}

.ps-currencyselector {
  position: relative;
  border-radius: var(--bs-btn-border-radius, var(--aa-radius-sm));
  transition: background-color var(--aa-transition-fast);
}

.ps-currencyselector:is(:hover, :focus-within) {
  background-color: var(--aa-accent-soft);
}

.ps-currencyselector__toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 4.75rem;
  max-width: 7rem;
  height: 2.5rem;
  padding-block: 0;
  padding-inline: 0.8rem 1.8rem;
  color: var(--aa-dark);
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
  text-transform: uppercase;
  cursor: pointer;
  background-color: #fff;
  border: 0;
  border-radius: var(--bs-btn-border-radius, var(--aa-radius-sm));
  box-shadow: none;
  transition: color var(--aa-transition-fast);
}

.ps-currencyselector__toggle::after {
  position: absolute;
  right: 0.72rem;
}

.ps-currencyselector:hover .ps-currencyselector__toggle {
  color: var(--aa-accent);
  background-color: transparent;
}

.ps-currencyselector__toggle:is(:focus, :focus-visible, .show) {
  color: var(--aa-dark);
  background-color: transparent;
  box-shadow: none;
}

.ps-currencyselector__menu {
  position: absolute;
  top: calc(100% + 0.35rem);
  right: 0;
  z-index: 1000;
  display: block;
  min-width: 100%;
  padding: 0.5rem;
  color: var(--aa-dark);
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(var(--aa-dark-rgb), 0.12);
  border-radius: var(--aa-radius);
  box-shadow: var(--aa-shadow-menu);
  opacity: 0;
  pointer-events: none;
  transform-origin: top right;
  transform: translateY(-0.45rem) scale(0.99);
  visibility: hidden;
  transition:
    opacity var(--aa-transition),
    transform var(--aa-transition),
    visibility 0s linear 190ms;
}

.ps-currencyselector.is-open .ps-currencyselector__menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
  transition-delay: 0s;
  visibility: visible;
}

.ps-currencyselector__menu li + li {
  margin-top: 0.12rem;
}

.ps-currencyselector__item {
  display: flex;
  align-items: center;
  min-height: 2.25rem;
  padding: 0.5rem 0.65rem;
  color: var(--aa-dark) !important;
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: 0;
  text-transform: uppercase;
  text-decoration: none;
  background: transparent !important;
  border-radius: var(--aa-radius-sm);
  transition:
    color var(--aa-transition),
    background-color var(--aa-transition),
    transform var(--aa-transition);
}

.ps-currencyselector__item:is(:hover, :focus, :focus-visible, .active) {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft) !important;
  transform: translateX(2px);
}

.header-single__right .ps-currencyselector .form-select option {
  color: var(--aa-dark);
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: 0;
}

.header-single__right .ps-languageselector .form-select:is(:hover, :focus, :focus-visible),
.header-single__right .ps-currencyselector .form-select:is(:hover, :focus, :focus-visible) {
  color: var(--aa-accent);
  background-color: var(--aa-accent-soft);
  box-shadow: none;
}

.header-single__right .ps-currencyselector .form-select:is(:hover, :focus, :focus-visible) {
  color: var(--aa-dark);
  background-color: transparent;
}

.header-single__right .ps-currencyselector:hover .form-select {
  color: var(--aa-accent);
}

.header-single__right .ps-customersignin .dropdown {
  position: relative;
}

.header-single__right .ps-customersignin .dropdown-toggle:is(:hover, :focus-visible, :active, .show),
.header-single__right .ps-customersignin .dropdown:has(.dropdown-menu.show) .dropdown-toggle {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft) !important;
}

.header-single__right .ps-customersignin .dropdown-menu {
  top: calc(100% + 0.35rem);
  right: auto;
  left: 0;
  display: block;
  min-width: 13rem;
  padding: 0.5rem;
  margin-top: 0 !important;
  color: var(--aa-dark);
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(var(--aa-dark-rgb), 0.12);
  border-radius: var(--aa-radius);
  box-shadow: var(--aa-shadow-menu);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-0.45rem) scale(0.99);
  transform-origin: top left;
  visibility: hidden;
  transition:
    opacity var(--aa-transition),
    transform var(--aa-transition),
    visibility 0s linear 190ms;
}

.header-single__right .ps-customersignin .dropdown-menu.show {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
  transition-delay: 0s;
  visibility: visible;
}

.header-single__right .ps-customersignin .dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 2.25rem;
  padding: 0.5rem 0.65rem;
  color: var(--aa-dark) !important;
  font-weight: 650;
  line-height: 1.2;
  border-radius: var(--aa-radius-sm);
  transition:
    color var(--aa-transition),
    background-color var(--aa-transition),
    transform var(--aa-transition);
}

.header-single__right .ps-customersignin .dropdown-item .material-icons {
  margin-right: 0 !important;
  color: var(--aa-dark);
  font-size: 1.15rem;
  transition: color var(--aa-transition);
}

.header-single__right .ps-customersignin .dropdown-item:is(:hover, :focus, :focus-visible, .active) {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft) !important;
  transform: translateX(2px);
}

.header-single__right .ps-customersignin .dropdown-item:is(:hover, :focus, :focus-visible, .active) .material-icons {
  color: var(--aa-accent);
}

.header-single__right .ps-customersignin .dropdown-divider {
  margin: 0.35rem 0;
  border-top-color: rgba(var(--aa-dark-rgb), 0.1);
}

.header-single__right .ps-searchbar,
.header-single__right .ps-searchbar input,
.header-single__right .ps-searchbar__input {
  user-select: text;
  -webkit-user-select: text;
}

.header-block__action-btn[href]:is(:hover, :focus, :focus-visible, :active),
.header-block--active .header-block,
.header-block--active .header-block__icon {
  color: var(--aa-accent) !important;
}

/* =========================================================
   FIX: Keep desktop header cart icon-only after AJAX refresh
   ========================================================= */

.header-single__right .header-single__cart .header-block__title,
.header-single__right #_desktop_ps_shoppingcart .header-block__title {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
  display: block !important;
}

/* =========================================================
   Header right icons: larger, equal visual size + integrated cart count
   ========================================================= */

.header-single__right {
  --aa-header-action-size: 2.75rem;
  --aa-header-icon-size: 1.68rem;
  --aa-header-cart-badge-size: 1.05rem;
}

/* Equal clickable boxes for right-side header actions */
.header-single__right #_desktop_ps_customersignin .header-block__action-btn,
.header-single__right #_desktop_ps_shoppingcart .header-block__action-btn,
.header-single__right .header-single__signin .header-block__action-btn,
.header-single__right .header-single__cart .header-block__action-btn,
.header-single__right #_mobile_ps_customersignin .header-block__action-btn,
.header-single__right #_mobile_ps_shoppingcart .header-block__action-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--aa-header-action-size);
  height: var(--aa-header-action-size);
  min-width: var(--aa-header-action-size);
  min-height: var(--aa-header-action-size);
  padding: 0 !important;
  color: var(--aa-dark);
  line-height: 1;
  text-decoration: none;
  border-radius: 999px;
}

/* Make sign-in/cart icon glyphs visually equal and slightly larger */
.header-single__right .header-block__icon,
.header-single__right .material-icons,
.header-single__right .material-icons-outlined,
.header-single__right .material-symbols-outlined {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--aa-header-icon-size);
  height: var(--aa-header-icon-size);
  margin: 0 !important;
  font-size: var(--aa-header-icon-size) !important;
  line-height: 1 !important;
}

/* Search icon/button visual size */
.header-single__right .ps-searchbar button,
.header-single__right .ps-searchbar__btn,
.header-single__right .ps-searchbar__submit,
.header-single__right .ps-searchbar__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.header-single__right .ps-searchbar i,
.header-single__right .ps-searchbar .material-icons,
.header-single__right .ps-searchbar .material-icons-outlined,
.header-single__right .ps-searchbar .material-symbols-outlined {
  font-size: var(--aa-header-icon-size) !important;
  line-height: 1 !important;
}

/* Desktop cart badge: integrated into the cart icon, like the mobile one */
.header-single__right #_desktop_ps_shoppingcart .header-block__action-btn,
.header-single__right .header-single__cart .header-block__action-btn,
.header-single__right #_mobile_ps_shoppingcart .header-block__action-btn {
  overflow: visible;
}

/* Cart count pill */
.header-single__right #_desktop_ps_shoppingcart .header-block__badge,
.header-single__right .header-single__cart .header-block__badge,
.header-single__right #_mobile_ps_shoppingcart .header-block__badge {
  position: absolute;
  top: 0.28rem;
  right: 0.28rem;
  z-index: 2;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  min-width: var(--aa-header-cart-badge-size);
  height: var(--aa-header-cart-badge-size);
  padding: 0 0.22rem;

  color: #fff !important;
  background: var(--aa-accent) !important;
  border: 2px solid var(--bs-body-bg);
  border-radius: 999px;

  font-size: 0.62rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.03em;

  transform: translate(12%, -4%);
  box-shadow: 0 0.12rem 0.35rem rgba(var(--aa-dark-rgb), 0.22);
}

/* Keep the cart icon centered even when the badge exists */
.header-single__right #_desktop_ps_shoppingcart .header-block__icon,
.header-single__right .header-single__cart .header-block__icon,
.header-single__right #_mobile_ps_shoppingcart .header-block__icon {
  transform: translate(-0.02rem, 0.04rem);
}

/* Floating cart dropdown */
.header-single__cart,
.header-single__right #_desktop_ps_shoppingcart,
.header-single__right .ps-shoppingcart,
.header-single__right .aa-floating-cart {
  position: relative;
}

.aa-floating-cart__toggle {
  border: 0;
  background: transparent;
}

.aa-floating-cart__panel {
  position: absolute;
  top: calc(100% + 0.65rem);
  right: 0;
  z-index: 1050;
  display: none;
  width: min(24rem, calc(100vw - 2rem));
  max-height: min(70vh, 34rem);
  padding: 0.9rem;
  overflow: hidden;
  color: var(--aa-dark);
  background: var(--bs-body-bg);
  border: 1px solid rgba(var(--aa-dark-rgb), 0.12);
  border-radius: var(--aa-radius-lg);
  box-shadow: var(--aa-shadow-menu);
}

.aa-floating-cart.is-open .aa-floating-cart__panel,
.aa-floating-cart:hover .aa-floating-cart__panel,
.aa-floating-cart:focus-within .aa-floating-cart__panel {
  display: block;
}

.aa-floating-cart__panel::before {
  position: absolute;
  top: -0.45rem;
  right: 1rem;
  width: 0.9rem;
  height: 0.9rem;
  content: "";
  background: var(--bs-body-bg);
  border-top: 1px solid rgba(var(--aa-dark-rgb), 0.12);
  border-left: 1px solid rgba(var(--aa-dark-rgb), 0.12);
  transform: rotate(45deg);
}

.aa-floating-cart__header,
.aa-floating-cart__totals {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.aa-floating-cart__header {
  padding-bottom: 0.75rem;
  border-bottom: 1px solid rgba(var(--aa-dark-rgb), 0.1);
}

.aa-floating-cart__header span {
  font-family: var(--aa-font-heading);
  font-size: 1.05rem;
  font-weight: 650;
}

.aa-floating-cart__header strong {
  color: var(--aa-dark);
  font-size: 0.86rem;
  font-weight: 700;
  white-space: nowrap;
}

.aa-floating-cart__items {
  display: grid;
  max-height: 18.5rem;
  padding: 0.35rem 0;
  margin: 0;
  overflow-y: auto;
  list-style: none;
}

.aa-floating-cart__item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 0.6rem;
  padding: 0.65rem 0;
  border-bottom: 1px solid rgba(var(--aa-dark-rgb), 0.08);
}

.aa-floating-cart__qty {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.7rem;
  height: 1.7rem;
  color: #fff;
  font-size: 0.78rem;
  font-weight: 700;
  background: var(--aa-dark);
  border-radius: 999px;
}

.aa-floating-cart__name {
  min-width: 0;
  overflow: hidden;
  color: var(--aa-dark);
  font-size: 0.9rem;
  font-weight: 650;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.aa-floating-cart__price {
  color: var(--aa-dark);
  font-size: 0.88rem;
  font-weight: 700;
  white-space: nowrap;
}

.aa-floating-cart__remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  color: var(--aa-dark);
  text-decoration: none;
  border-radius: 999px;
}

.aa-floating-cart__remove:is(:hover, :focus-visible) {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft);
}

.aa-floating-cart__remove .material-icons {
  font-size: 1.2rem !important;
}

.aa-floating-cart__totals {
  padding: 0.85rem 0;
  font-size: 0.95rem;
}

.aa-floating-cart__totals strong {
  font-size: 1.05rem;
}

.aa-floating-cart__empty {
  padding: 1.6rem 0 1.2rem;
  color: var(--aa-dark);
  text-align: center;
}

.aa-floating-cart__checkout {
  width: 100%;
}

/* Hover/focus polish */
.header-single__right .header-block__action-btn {
  transition:
    color var(--aa-transition-fast),
    background-color var(--aa-transition-fast),
    transform var(--aa-transition-fast);
}

.header-single__right .header-block__action-btn:is(:hover, :focus-visible, :active) {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft);
}

.header-single__right .header-block__action-btn:is(:hover, :focus-visible, :active) .header-block__icon,
.header-single__right .header-block__action-btn:is(:hover, :focus-visible, :active) .material-icons,
.header-single__right .header-block__action-btn:is(:hover, :focus-visible, :active) .material-icons-outlined,
.header-single__right .header-block__action-btn:is(:hover, :focus-visible, :active) .material-symbols-outlined {
  color: inherit !important;
}

/* Slightly tighter spacing now that the icons are larger */
.header-single__right {
  gap: 0.35rem;
}

@media (max-width: 767.98px) {
  .header-single__right {
    --aa-header-action-size: 2.55rem;
    --aa-header-icon-size: 1.55rem;
    --aa-header-cart-badge-size: 1rem;
  }
}

/* =========================================================
   Header search: desktop icon + dropdown panel
   ========================================================= */

.header-single__right .header-search-dropdown {
  order: 10 !important;
  margin-left: 0 !important;
  padding-inline: 0;
}

.header-single__right .header-search-dropdown__dropdown {
  position: relative;
}

.header-single__right .header-search-dropdown__toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: var(--aa-header-action-size, 2.75rem);
  height: var(--aa-header-action-size, 2.75rem);
  min-width: var(--aa-header-action-size, 2.75rem);
  min-height: var(--aa-header-action-size, 2.75rem);

  padding: 0 !important;
  color: var(--aa-dark);
  line-height: 1;
  text-decoration: none;
  background: transparent;
  border: 0;
  border-radius: 999px;

  transition:
    color var(--aa-transition-fast),
    background-color var(--aa-transition-fast),
    transform var(--aa-transition-fast);
}

.header-single__right .header-search-dropdown__toggle:is(:hover, :focus-visible, :active, .show),
.header-single__right .header-search-dropdown__dropdown:has(.dropdown-menu.show) .header-search-dropdown__toggle {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft);
}

.header-single__right .header-search-dropdown__toggle .header-block__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--aa-header-icon-size, 1.68rem);
  height: var(--aa-header-icon-size, 1.68rem);
  margin: 0 !important;
  font-size: var(--aa-header-icon-size, 1.68rem) !important;
  line-height: 1 !important;
}

/* Dropdown panel */
.header-single__right .header-search-dropdown__menu {
  width: min(24rem, calc(100vw - 2rem));
  padding: 0.65rem;
  margin-top: 0.55rem !important;

  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(var(--aa-dark-rgb), 0.12);
  border-radius: var(--aa-radius-lg);
  box-shadow: var(--aa-shadow-menu);
}

/* Override your earlier inline-header search width */
.header-single__right .header-search-dropdown .ps-searchbar {
  position: relative;
  width: 100%;
}

/* Form layout inside dropdown */
.header-single__right .header-search-dropdown .ps-searchbar__form {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
}

.header-single__right .header-search-dropdown .ps-searchbar__magnifier {
  position: absolute;
  left: 0.8rem;
  z-index: 2;
  color: rgba(var(--aa-dark-rgb), 0.54);
  font-size: 1.25rem !important;
  pointer-events: none;
}

.header-single__right .header-search-dropdown .ps-searchbar__input {
  width: 100%;
  min-height: 2.7rem;
  padding-left: 2.45rem;
  padding-right: 2.35rem;

  color: var(--aa-dark);
  background: #fff;
  border: 1px solid rgba(var(--aa-dark-rgb), 0.16);
  border-radius: 999px;
}

.header-single__right .header-search-dropdown .ps-searchbar__input:focus {
  border-color: var(--aa-input-focus-border);
  box-shadow: 0 0 0 .25rem var(--aa-focus-ring);
}

/* Clear button */
.header-single__right .header-search-dropdown .ps-searchbar__clear {
  position: absolute;
  right: 0.35rem;
  z-index: 3;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: 2rem;
  height: 2rem;
  padding: 0 !important;

  color: rgba(var(--aa-dark-rgb), 0.58);
  border-radius: 999px;
}

.header-single__right .header-search-dropdown .ps-searchbar__clear:hover {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft);
}

/* Autocomplete dropdown inside the search panel */
.header-single__right .header-search-dropdown .ps-searchbar__dropdown {
  position: absolute;
  top: calc(100% + 0.5rem);
  right: 0;
  left: 0;
  z-index: 1100;

  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(var(--aa-dark-rgb), 0.12);
  border-radius: var(--aa-radius-lg);
  box-shadow: var(--aa-shadow-menu);
}

.header-single__right .header-search-dropdown .ps-searchbar__results {
  max-height: min(22rem, calc(100vh - 12rem));
  overflow-y: auto;
}

.header-single__right .header-search-dropdown .ps-searchbar__result-link {
  display: grid;
  grid-template-columns: 3rem 1fr;
  gap: 0.65rem;
  align-items: center;
  padding: 0.6rem;
  color: var(--aa-dark) !important;
  text-decoration: none;
}

.header-single__right .header-search-dropdown .ps-searchbar__result-link:hover,
.header-single__right .header-search-dropdown .ps-searchbar__result-link:focus {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft);
}

.header-single__right .header-search-dropdown .ps-searchbar__result-image {
  width: 3rem;
  height: 3rem;
  object-fit: cover;
  border-radius: var(--aa-radius-sm);
}

.header-single__right .header-search-dropdown .ps-searchbar__result-name {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 600;
  line-height: 1.25;
}

/* Make Bootstrap's active dropdown toggle inherit our color */
.header-single__right .header-search-dropdown__toggle.show,
.header-single__right .header-search-dropdown__toggle.show * {
  color: var(--aa-accent) !important;
}

/* =========================================================
   6. Main menu
   ========================================================= */

.ps-mainmenu--desktop {
  position: relative;
  z-index: 40;

  --aa-menu-panel-width: 28rem;
  --aa-menu-compact-width: 17rem;
  --aa-menu-left-width: 11rem;
}

.ps-mainmenu--desktop .ps-mainmenu__desktop {
  position: relative;
}

.ps-mainmenu--desktop .ps-mainmenu__tree {
  display: flex;
  align-items: center;
  gap: 0.15rem;
  padding: 0;
  margin: 0;
  list-style: none;
}

.ps-mainmenu--desktop .ps-mainmenu__tree-item {
  position: static;
}

.ps-mainmenu--desktop .ps-mainmenu__tree-item-wrapper {
  display: inline-flex;
  align-items: center;
  min-height: 2.25rem;
  border-radius: var(--aa-radius);
  transition:
    background-color var(--aa-transition),
    transform var(--aa-transition);
}

.ps-mainmenu--desktop .ps-mainmenu__tree-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 2.25rem;
  padding: 0.45rem 0.6rem;
  color: var(--aa-dark) !important;
  font-size: 0.94rem;
  font-weight: 600;
  line-height: 1;
  text-decoration: none;
  border-radius: var(--aa-radius);
  transition:
    color var(--aa-transition),
    background-color var(--aa-transition);
}

.ps-mainmenu--desktop .ps-mainmenu__tree-link::after {
  position: absolute;
  right: 0.6rem;
  bottom: 0.32rem;
  left: 0.6rem;
  height: 2px;
  content: "";
  background: var(--aa-accent);
  border-radius: 999px;
  opacity: 0;
  transform: scaleX(0.45);
  transform-origin: center;
  transition:
    opacity var(--aa-transition),
    transform var(--aa-transition);
}

.ps-mainmenu--desktop .ps-mainmenu__tree-dropdown-toggle {
  width: 1.65rem;
  height: 2.25rem;
  padding: 0;
  margin-left: -0.35rem;
  color: rgba(var(--aa-dark-rgb), 0.72);
  background: transparent;
  border: 0;
  border-radius: var(--aa-radius);
  transition:
    color var(--aa-transition),
    transform var(--aa-transition);
}

.ps-mainmenu--desktop .ps-mainmenu__tree-item:is(:hover, :focus-within, .current) .ps-mainmenu__tree-item-wrapper {
  background: var(--aa-accent-soft);
}

.ps-mainmenu--desktop .ps-mainmenu__tree-item:is(:hover, :focus-within, .current) .ps-mainmenu__tree-link,
.ps-mainmenu--desktop .ps-mainmenu__tree-item:is(:hover, :focus-within) .ps-mainmenu__tree-dropdown-toggle {
  color: var(--aa-accent) !important;
}

.ps-mainmenu--desktop .ps-mainmenu__tree-item:is(:hover, :focus-within, .current) .ps-mainmenu__tree-link::after {
  opacity: 1;
  transform: scaleX(1);
}

.ps-mainmenu--desktop .ps-mainmenu__tree-dropdown-toggle::after {
  display: inline-block;
  margin-left: 0;
  vertical-align: middle;

  transform: rotate(0deg) !important;
  transform-origin: 50% 45%;

  opacity: 0.72;

  transition:
    transform 260ms ease-in-out,
    opacity 260ms ease-in-out,
    color 260ms ease-in-out;
}

.ps-mainmenu--desktop .ps-mainmenu__tree-item:is(:hover, :focus-within) .ps-mainmenu__tree-dropdown-toggle::after,
.ps-mainmenu--desktop .ps-mainmenu__tree-dropdown-toggle[aria-expanded="true"]::after {
  transform: rotate(-180deg) !important;
  opacity: 1;
}

.ps-mainmenu--desktop .ps-mainmenu__tree-link:focus-visible,
.ps-mainmenu--desktop .ps-mainmenu__tree-dropdown-toggle:focus-visible,
.ps-mainmenu--desktop .submenu a:focus-visible {
  outline: 2px solid rgba(var(--aa-accent-rgb), 0.5);
  outline-offset: 3px;
}

/* Desktop submenu */

.ps-mainmenu--desktop .ps-mainmenu__tree-item > .submenu {
  display: block !important;
}

.ps-mainmenu--desktop .submenu {
  position: absolute;
  top: calc(100% + 0.6rem);
  left: 0;
  right: auto;
  z-index: 50;
  width: min(var(--aa-menu-panel-width), calc(100vw - 2rem)) !important;
  min-width: 0 !important;
  max-width: calc(100vw - 2rem);
  padding: 0.85rem !important;
  color: var(--aa-dark);
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(var(--aa-dark-rgb), 0.12);
  border-radius: var(--aa-radius);
  box-shadow: var(--aa-shadow-menu);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-0.45rem) scale(0.99);
  transform-origin: top left;
  transition:
    opacity var(--aa-transition),
    transform var(--aa-transition),
    visibility 0s linear 190ms;
}

.ps-mainmenu--desktop .ps-mainmenu__tree-item:is(:hover, :focus-within) > .submenu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
  transition-delay: 0s;
}

.ps-mainmenu--desktop .submenu::before {
  position: absolute;
  right: 0;
  bottom: 100%;
  left: 0;
  height: 0.8rem;
  content: "";
}

.ps-mainmenu--desktop .submenu .container {
  width: 100%;
  max-width: none;
  padding: 0;
}

.ps-mainmenu--desktop .submenu__row {
  --bs-gutter-x: 0;
  min-height: 0 !important;
  align-items: stretch;
}

/* Compact submenu mode */

.ps-mainmenu--desktop .submenu:not(:has(.submenu__right a)) {
  width: min(var(--aa-menu-compact-width), calc(100vw - 2rem)) !important;
  padding: 0.75rem !important;
}

.ps-mainmenu--desktop .submenu:not(:has(.submenu__right a)) .submenu__row {
  display: block;
  margin: 0;
}

.ps-mainmenu--desktop .submenu:not(:has(.submenu__right a)) .submenu__left {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
  border-right: 0;
  flex: 0 0 auto !important;
}

.ps-mainmenu--desktop .submenu:not(:has(.submenu__right a)) .submenu__right {
  display: none !important;
}

/* Submenu columns */

.ps-mainmenu--desktop .submenu__left {
  width: var(--aa-menu-left-width) !important;
  max-width: var(--aa-menu-left-width) !important;
  flex: 0 0 var(--aa-menu-left-width) !important;
  padding: 0.35rem 0.85rem 0.35rem 0.25rem !important;
  border-right: 1px solid rgba(var(--aa-dark-rgb), 0.1);
}

.ps-mainmenu--desktop .submenu__right {
  width: auto !important;
  max-width: none !important;
  flex: 1 1 auto !important;
  padding: 0.35rem 0.25rem 0.35rem 1rem !important;
}

.ps-mainmenu--desktop .submenu__left-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 2.25rem;
  padding: 0.5rem 0.65rem;
  color: var(--aa-dark) !important;
  font-size: 0.92rem;
  font-weight: 600;
  line-height: 1.2;
  text-decoration: none;
  background: transparent;
  border-radius: var(--aa-radius-sm);
  transition:
    color var(--aa-transition),
    background-color var(--aa-transition),
    transform var(--aa-transition);
}

.ps-mainmenu--desktop .submenu__left-item:is(:hover, :focus, :focus-visible, [aria-selected="true"], .active) {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft) !important;
  transform: translateX(2px);
}

/* Prevent stale aria-selected item from looking active while another item is hovered */
.ps-mainmenu--desktop .submenu:has(.submenu__left-item:hover) .submenu__left-item[aria-selected="true"] {
  color: var(--aa-dark) !important;
  background: transparent !important;
}

.ps-mainmenu--desktop .submenu:has(.submenu__left-item[aria-selected="true"]:hover) .submenu__left-item[aria-selected="true"],
.ps-mainmenu--desktop .submenu .submenu__left-item:hover {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft) !important;
}

.ps-mainmenu--desktop .submenu__right .submenu__right-items {
  display: none !important;
  grid-template-columns: 1fr;
  gap: 0.25rem 1rem;
}

/*
 * Maps hovered/focused/selected left menu items to their matching right panels.
 * Extend this pattern if the menu ever has more than 8 top-level submenu groups.
 */

.ps-mainmenu--desktop .submenu:has(.submenu__left-item:nth-of-type(1):is([aria-selected="true"], :hover, :focus)) .submenu__right .submenu__right-items:nth-of-type(1),
.ps-mainmenu--desktop .submenu:has(.submenu__left-item:nth-of-type(2):is([aria-selected="true"], :hover, :focus)) .submenu__right .submenu__right-items:nth-of-type(2),
.ps-mainmenu--desktop .submenu:has(.submenu__left-item:nth-of-type(3):is([aria-selected="true"], :hover, :focus)) .submenu__right .submenu__right-items:nth-of-type(3),
.ps-mainmenu--desktop .submenu:has(.submenu__left-item:nth-of-type(4):is([aria-selected="true"], :hover, :focus)) .submenu__right .submenu__right-items:nth-of-type(4),
.ps-mainmenu--desktop .submenu:has(.submenu__left-item:nth-of-type(5):is([aria-selected="true"], :hover, :focus)) .submenu__right .submenu__right-items:nth-of-type(5),
.ps-mainmenu--desktop .submenu:has(.submenu__left-item:nth-of-type(6):is([aria-selected="true"], :hover, :focus)) .submenu__right .submenu__right-items:nth-of-type(6),
.ps-mainmenu--desktop .submenu:has(.submenu__left-item:nth-of-type(7):is([aria-selected="true"], :hover, :focus)) .submenu__right .submenu__right-items:nth-of-type(7),
.ps-mainmenu--desktop .submenu:has(.submenu__left-item:nth-of-type(8):is([aria-selected="true"], :hover, :focus)) .submenu__right .submenu__right-items:nth-of-type(8) {
  display: grid !important;
}

/* Right-side submenu links */

.ps-mainmenu--desktop .submenu__right-items ul {
  padding-left: 0;
  margin: 0;
  list-style: none;
}

.ps-mainmenu--desktop .submenu__right-items .menu-item,
.ps-mainmenu--desktop .submenu__right-items a {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.55rem;
  color: var(--aa-dark) !important;
  font-size: 0.9rem;
  line-height: 1.35;
  text-decoration: none;
  background: transparent;
  border-radius: var(--aa-radius-sm);
  transition:
    color var(--aa-transition),
    background-color var(--aa-transition),
    transform var(--aa-transition);
}

/* Hover/focus/selected/current right-side submenu items */
.ps-mainmenu--desktop .submenu__right-items .menu-item:is(:hover, :focus, :focus-visible, .active, .current, [aria-selected="true"]),
.ps-mainmenu--desktop .submenu__right-items a:is(:hover, :focus, :focus-visible, .active, .current, [aria-current="page"], [aria-selected="true"]),
.ps-mainmenu--desktop .submenu__right-items .menu-item:is(.active, .current, [aria-selected="true"]) > a,
.ps-mainmenu--desktop .submenu__right-items li:is(.active, .current) > a {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft) !important;
  transform: translateX(2px);
}

.ps-mainmenu--desktop .submenu__right-items .menu-item__group-main-item,
.ps-mainmenu--desktop .submenu__right-items .menu-item.menu-item__group-main-item {
  color: var(--aa-dark) !important;
  font-weight: 700;
}

/* Keep group/main items orange when hovered or active */
.ps-mainmenu--desktop .submenu__right-items .menu-item__group-main-item:is(:hover, :focus, :focus-visible, .active, .current, [aria-selected="true"]),
.ps-mainmenu--desktop .submenu__right-items .menu-item.menu-item__group-main-item:is(:hover, :focus, :focus-visible, .active, .current, [aria-selected="true"]),
.ps-mainmenu--desktop .submenu__right-items .menu-item:is(.active, .current, [aria-selected="true"]) > .menu-item__group-main-item,
.ps-mainmenu--desktop .submenu__right-items li:is(.active, .current) > .menu-item__group-main-item {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft) !important;
}
/* =========================================================
   FIX: Highlight the full current category path in desktop menu
   Example: Shoes -> Male -> Size 6 highlights all three.
   Requires current/aria-current output in ps_mainmenu.tpl.
   ========================================================= */

/* Top-level category: highlight when it or anything inside its submenu is current */
.ps-mainmenu--desktop .ps-mainmenu__tree-item:has(.submenu .current) .ps-mainmenu__tree-item-wrapper,
.ps-mainmenu--desktop .ps-mainmenu__tree-item:has(.submenu [aria-current="page"]) .ps-mainmenu__tree-item-wrapper {
  background: var(--aa-accent-soft);
}

.ps-mainmenu--desktop .ps-mainmenu__tree-item:has(.submenu .current) .ps-mainmenu__tree-link,
.ps-mainmenu--desktop .ps-mainmenu__tree-item:has(.submenu [aria-current="page"]) .ps-mainmenu__tree-link,
.ps-mainmenu--desktop .ps-mainmenu__tree-item:has(.submenu .current) .ps-mainmenu__tree-dropdown-toggle,
.ps-mainmenu--desktop .ps-mainmenu__tree-item:has(.submenu [aria-current="page"]) .ps-mainmenu__tree-dropdown-toggle {
  color: var(--aa-accent) !important;
}

.ps-mainmenu--desktop .ps-mainmenu__tree-item:has(.submenu .current) .ps-mainmenu__tree-link::after,
.ps-mainmenu--desktop .ps-mainmenu__tree-item:has(.submenu [aria-current="page"]) .ps-mainmenu__tree-link::after {
  opacity: 1;
  transform: scaleX(1);
}

/* Right-side current item */
.ps-mainmenu--desktop .submenu__right-items .menu-item.current,
.ps-mainmenu--desktop .submenu__right-items a.current,
.ps-mainmenu--desktop .submenu__right-items a[aria-current="page"] {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft) !important;
  transform: translateX(2px);
}

/* Keep bold group links bold while current */
.ps-mainmenu--desktop .submenu__right-items .menu-item__group-main-item.current,
.ps-mainmenu--desktop .submenu__right-items .menu-item__group-main-item[aria-current="page"] {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft) !important;
  font-weight: 700;
}

/*
  If a current item exists in the right panel, show that panel by default
  instead of the first aria-selected panel.
  Hover/focus on left items still takes over because of the :not(:has(...)) guard.
*/
.ps-mainmenu--desktop
  .submenu:has(.submenu__right .submenu__right-items :is(.current, [aria-current="page"]))
  :not(:has(.submenu__left-item:is(:hover, :focus, :focus-visible)))
  :not(:has(.submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"])))
  .submenu__right
  .submenu__right-items {
  display: none !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__right .submenu__right-items :is(.current, [aria-current="page"]))
  :not(:has(.submenu__left-item:is(:hover, :focus, :focus-visible)))
  :not(:has(.submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"])))
  .submenu__right
  .submenu__right-items:has(:is(.current, [aria-current="page"])) {
  display: grid !important;
}

/* Left-side current item itself */
.ps-mainmenu--desktop .submenu__left-item.current,
.ps-mainmenu--desktop .submenu__left-item[aria-current="page"] {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft) !important;
  transform: translateX(2px);
}

/*
  Map a current right-side panel back to its matching left-side tab.
  This makes "Male" highlight when "Size 6" is current.
  Extend beyond 8 if your menu has more than 8 second-level groups.
*/

.ps-mainmenu--desktop
  .submenu:has(.submenu__right .submenu__right-items:nth-of-type(1) :is(.current, [aria-current="page"]))
  :not(:has(.submenu__left-item:is(:hover, :focus, :focus-visible)))
:not(:has(.submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"])))
  .submenu__left-item:nth-of-type(1),
.ps-mainmenu--desktop
  .submenu:has(.submenu__right .submenu__right-items:nth-of-type(2) :is(.current, [aria-current="page"]))
  :not(:has(.submenu__left-item:is(:hover, :focus, :focus-visible)))
:not(:has(.submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"])))
  .submenu__left-item:nth-of-type(2),
.ps-mainmenu--desktop
  .submenu:has(.submenu__right .submenu__right-items:nth-of-type(3) :is(.current, [aria-current="page"]))
  :not(:has(.submenu__left-item:is(:hover, :focus, :focus-visible)))
:not(:has(.submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"])))
  .submenu__left-item:nth-of-type(3),
.ps-mainmenu--desktop
  .submenu:has(.submenu__right .submenu__right-items:nth-of-type(4) :is(.current, [aria-current="page"]))
  :not(:has(.submenu__left-item:is(:hover, :focus, :focus-visible)))
:not(:has(.submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"])))
  .submenu__left-item:nth-of-type(4),
.ps-mainmenu--desktop
  .submenu:has(.submenu__right .submenu__right-items:nth-of-type(5) :is(.current, [aria-current="page"]))
  :not(:has(.submenu__left-item:is(:hover, :focus, :focus-visible)))
:not(:has(.submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"])))
  .submenu__left-item:nth-of-type(5),
.ps-mainmenu--desktop
  .submenu:has(.submenu__right .submenu__right-items:nth-of-type(6) :is(.current, [aria-current="page"]))
  :not(:has(.submenu__left-item:is(:hover, :focus, :focus-visible)))
:not(:has(.submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"])))
  .submenu__left-item:nth-of-type(6),
.ps-mainmenu--desktop
  .submenu:has(.submenu__right .submenu__right-items:nth-of-type(7) :is(.current, [aria-current="page"]))
  :not(:has(.submenu__left-item:is(:hover, :focus, :focus-visible)))
:not(:has(.submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"])))
  .submenu__left-item:nth-of-type(7),
.ps-mainmenu--desktop
  .submenu:has(.submenu__right .submenu__right-items:nth-of-type(8) :is(.current, [aria-current="page"]))
  :not(:has(.submenu__left-item:is(:hover, :focus, :focus-visible)))
:not(:has(.submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"])))
  .submenu__left-item:nth-of-type(8) {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft) !important;
  transform: translateX(2px);
}

/* Do not let the default first aria-selected item look active when another current path exists */
.ps-mainmenu--desktop
  .submenu:has(.submenu__right .submenu__right-items :is(.current, [aria-current="page"]))
  :not(:has(.submenu__left-item:is(:hover, :focus, :focus-visible)))
  .submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"]) {
  color: var(--aa-dark) !important;
  background: transparent !important;
  transform: none;
}
/* =========================================================
   FIX: Keep the newly selected/hovered left submenu panel open
   while moving from left column to right column.
   Prevents current-path panel from snapping back too early.
   ========================================================= */

/*
  If Hummingbird JS has marked a left item aria-selected="true",
  show its matching right panel even if another right-side item is
  the current page.
*/

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(1)[aria-selected="true"])
  .submenu__right
  .submenu__right-items {
  display: none !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(1)[aria-selected="true"])
  .submenu__right
  .submenu__right-items:nth-of-type(1) {
  display: grid !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(2)[aria-selected="true"])
  .submenu__right
  .submenu__right-items {
  display: none !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(2)[aria-selected="true"])
  .submenu__right
  .submenu__right-items:nth-of-type(2) {
  display: grid !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(3)[aria-selected="true"])
  .submenu__right
  .submenu__right-items {
  display: none !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(3)[aria-selected="true"])
  .submenu__right
  .submenu__right-items:nth-of-type(3) {
  display: grid !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(4)[aria-selected="true"])
  .submenu__right
  .submenu__right-items {
  display: none !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(4)[aria-selected="true"])
  .submenu__right
  .submenu__right-items:nth-of-type(4) {
  display: grid !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(5)[aria-selected="true"])
  .submenu__right
  .submenu__right-items {
  display: none !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(5)[aria-selected="true"])
  .submenu__right
  .submenu__right-items:nth-of-type(5) {
  display: grid !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(6)[aria-selected="true"])
  .submenu__right
  .submenu__right-items {
  display: none !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(6)[aria-selected="true"])
  .submenu__right
  .submenu__right-items:nth-of-type(6) {
  display: grid !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(7)[aria-selected="true"])
  .submenu__right
  .submenu__right-items {
  display: none !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(7)[aria-selected="true"])
  .submenu__right
  .submenu__right-items:nth-of-type(7) {
  display: grid !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(8)[aria-selected="true"])
  .submenu__right
  .submenu__right-items {
  display: none !important;
}

.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item:nth-of-type(8)[aria-selected="true"])
  .submenu__right
  .submenu__right-items:nth-of-type(8) {
  display: grid !important;
}

/* =========================================================
   FIX: Keep visual highlight on the user-selected left item
   while browsing another submenu panel.
   Prevents the current-path item from visually taking back
   the orange highlight.
   ========================================================= */

/* The actively selected left-side item should always look active */
.ps-mainmenu--desktop
  .submenu
  .submenu__left-item[aria-selected="true"] {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft) !important;
  transform: translateX(2px);
}

/*
  If the user has selected a different left item than the real current path,
  suppress the current-path highlight on the old/current left item.
*/
.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"]))
  .submenu__left-item:is(.current, [aria-current="page"]):not([aria-selected="true"]) {
  color: var(--aa-dark) !important;
  background: transparent !important;
  transform: none !important;
}

/*
  Also suppress the nth-of-type current-right-panel mapping from visually
  re-highlighting Item A when Item B is selected.
*/
.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"]))
  .submenu__left-item:not([aria-selected="true"]) {
  background: transparent !important;
}

/* Restore normal text color for non-selected left items in that state */
.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"]))
  .submenu__left-item:not([aria-selected="true"]):not(:hover):not(:focus):not(:focus-visible) {
  color: var(--aa-dark) !important;
  transform: none !important;
}

/* Keep hover/focus working normally */
.ps-mainmenu--desktop
  .submenu:has(.submenu__left-item[aria-selected="true"]:not(.current):not([aria-current="page"]))
  .submenu__left-item:is(:hover, :focus, :focus-visible) {
  color: var(--aa-accent) !important;
  background: var(--aa-accent-soft) !important;
  transform: translateX(2px);
}

/* Mobile menu */

.ps-mainmenu--mobile.offcanvas {
  color: var(--aa-white-soft);
  background: linear-gradient(
    to bottom,
    var(--aa-dark) 0%,
    var(--aa-dark-850) 58%,
    var(--aa-dark-950) 100%
  );
}

.ps-mainmenu--mobile .offcanvas-header,
.ps-mainmenu--mobile .ps-mainmenu__additionnals {
  border-color: rgba(255, 255, 255, 0.1);
}

.ps-mainmenu--mobile .btn-close,
.ps-mainmenu--mobile .btn {
  color: var(--aa-white-soft);
}

.ps-mainmenu--mobile .menu__list {
  padding: 0.75rem 0;
  margin: 0;
  list-style: none;
}

.ps-mainmenu--mobile .menu__title {
  padding: 0.75rem 1rem 0.5rem;
  color: rgba(255, 255, 255, 0.54);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.ps-mainmenu--mobile .menu__link,
.ps-mainmenu--mobile .menu a {
  display: flex;
  align-items: center;
  min-height: 2.75rem;
  padding: 0.6rem 1rem;
  color: var(--aa-white-soft) !important;
  font-weight: 600;
  text-decoration: none;
  border-radius: var(--aa-radius-lg);
  transition:
    color var(--aa-transition),
    background-color var(--aa-transition),
    transform var(--aa-transition);
}

.ps-mainmenu--mobile .menu__link:is(:hover, :focus),
.ps-mainmenu--mobile .menu a:is(:hover, :focus) {
  color: #fff !important;
  background: rgba(var(--aa-accent-rgb), 0.16);
  transform: translateX(2px);
}

.ps-mainmenu--mobile .menu__toggle-child {
  color: rgba(255, 255, 255, 0.68);
  transition:
    color var(--aa-transition),
    transform var(--aa-transition);
}

.ps-mainmenu--mobile .menu__toggle-child:is(:hover, :focus) {
  color: var(--aa-accent);
  transform: translateX(2px);
}

/* =========================================================
   FIX: Extend desktop main-menu clickable/hover hit area downward
   ========================================================= */

.ps-mainmenu--desktop {
  --aa-menu-trigger-extra-hit: 0.8rem;
}

.ps-mainmenu--desktop .ps-mainmenu__tree-item-wrapper,
.ps-mainmenu--desktop .ps-mainmenu__tree-link,
.ps-mainmenu--desktop .ps-mainmenu__tree-dropdown-toggle {
  position: relative;
}

/*
  Extend the actual top-level link/button hit area downward into the
  same space that currently opens the submenu.
*/
.ps-mainmenu--desktop .ps-mainmenu__tree-link::before,
.ps-mainmenu--desktop .ps-mainmenu__tree-dropdown-toggle::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: calc(-1 * var(--aa-menu-trigger-extra-hit));
  left: 0;
  content: "";
  background: transparent;
}

/*
  The submenu bridge can keep the dropdown visually connected,
  but it should not steal the click from the menu link.
*/
.ps-mainmenu--desktop .submenu::before {
  height: var(--aa-menu-trigger-extra-hit);
  pointer-events: none;
}

/* =========================================================
   7. Footer / Sticky footer
   ========================================================= */

/* Sticky footer for short pages */
body > main {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

body > main > #wrapper {
  flex: 1 0 auto;
}

body > main > #footer,
body > main > .footer,
body > main > .footer--arienne {
  flex-shrink: 0;
}

.footer--arienne {
  position: relative;
  isolation: isolate;
  overflow: visible;
  margin-top: 5.5rem;
  padding-block: 3.25rem 1.5rem;
  color: rgba(255, 255, 255, 0.78);
  background: linear-gradient(
    to bottom,
    var(--aa-dark) 0,
    var(--aa-dark) 2.25rem,
    var(--aa-dark-850) 7rem,
    var(--aa-dark-950) 100%
  );
  border-top: 0;
}

.footer--arienne::before {
  position: absolute;
  top: -119px;
  right: 0;
  left: 0;
  z-index: 1;
  height: 121px;
  pointer-events: none;
  content: "";
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 120' preserveAspectRatio='none'%3E%3Cpath fill='%23d7dcde' fill-opacity='.78' d='M0 23C130 72 274 64 430 45C594 26 701 46 865 70C1040 96 1212 58 1440 20L1440 120L0 120Z'/%3E%3Cpath fill='%23798489' fill-opacity='.76' d='M0 50C174 80 307 88 486 67C682 44 758 77 924 56C1073 38 1238 60 1440 47L1440 120L0 120Z'/%3E%3Cpath fill='%23253237' d='M0 68C142 92 289 91 430 77C585 61 666 91 829 84C1017 76 1160 49 1440 66L1440 120L0 120Z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: 100% 100%;
}

.footer--arienne__inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  transform: translateY(-2.5rem);
}

.footer--arienne__logo {
  display: flex;
  justify-content: center;
  margin-bottom: 1.5rem;
  text-align: center;
}

.footer--arienne__logo .navbar-brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
}

.footer--arienne__logo .logo {
  width: auto;
  max-width: 8rem;
  max-height: 3rem;
  filter: brightness(0) invert(1);
}

.footer--arienne__name {
  color: var(--bs-white);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.footer--arienne__nav {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

.footer--arienne__nav .ps-linklist {
  width: auto !important;
  max-width: none !important;
  flex: none !important;
  padding: 0 !important;
  margin: 0 !important;
  text-align: center;
}

.footer--arienne__nav .footer-block__title {
  display: none !important;
}

.footer--arienne__nav .footer-block__content,
.footer--arienne__nav .footer-block__content.collapse {
  display: block !important;
  height: auto !important;
  visibility: visible !important;
}

.footer--arienne__nav .footer-block__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding: 0;
  margin: 0;
  list-style: none;
}

.footer--arienne__nav .footer-block__list li {
  display: inline-flex;
  align-items: center;
  margin: 0;
}

.footer--arienne__nav .footer-block__list li + li::before {
  margin-inline: 0.75rem;
  color: rgba(255, 255, 255, 0.28);
  content: "/";
}

.footer--arienne__nav .footer-block__list a {
  display: inline-block;
  padding: 0;
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.9rem;
  line-height: 1.5;
  text-decoration: none;
  transition: color var(--aa-transition-fast);
}

.footer--arienne__nav .footer-block__list a:hover {
  color: #fff !important;
}

.footer--arienne__nav .ps-linklist + .ps-linklist {
  margin-top: 0.55rem !important;
}

.footer--arienne__nav .ps-linklist + .ps-linklist .footer-block__list a {
  color: rgba(255, 255, 255, 0.56);
  font-size: 0.84rem;
}

.footer--arienne__nav .ps-linklist + .ps-linklist .footer-block__list a:hover {
  color: rgba(255, 255, 255, 0.86) !important;
}

.footer--arienne__copyright {
  margin-top: 0.9rem;
  color: rgba(255, 255, 255, 0.5);
  font-size: 0.82rem;
  text-align: center;
}


/* =========================================================
   8. Page-specific fixes
   ========================================================= */

/* Product page: tighter purchase column rhythm */
.page-product .product__right .product__name {
  margin-bottom: 0.25rem;
}

.page-product .product__manufacturer {
  margin-bottom: 0.55rem;
}

.page-product .product__rating {
  display: flex;
  align-items: center;
  margin: 0.15rem 0 0.5rem;
}

.page-product .product__rating:empty {
  display: none;
}

.page-product .product__rating:not(:has(.grade-stars, .post-product-comment)) {
  display: none;
}

.page-product .product__rating .product-comments-additional-info {
  display: flex;
  align-items: center;
  margin: 0;
}

.page-product .product__rating .product-comments-additional-info > a {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: var(--aa-accent);
  font-weight: 700;
  text-decoration: none;
}

.page-product .product__rating .product-comments-additional-info > a:hover {
  color: var(--aa-dark);
}

.page-product .product__rating .post-product-comment {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  min-width: 0;
  min-height: 1.85rem;
  padding: 0.32rem 0.7rem;
  border-radius: var(--bs-btn-border-radius, var(--aa-radius-sm));
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1.1;
  white-space: nowrap;
}

.page-product .product__rating .comments-note,
.page-product .product__rating .average-grade {
  margin: 0;
}

.page-product .product__prices {
  margin-block: 0.4rem 0.75rem;
}

.page-product .product__prices-block,
.page-product .product__tax-infos {
  margin-bottom: 0;
}

.page-product .product__description-short {
  margin-block: 0.65rem 0.9rem;
  line-height: 1.45;
}

.page-product .product__customization {
  margin-block: 0.8rem 0.55rem;
}

.page-product .product-customization__title {
  margin-bottom: 0.55rem;
}

.page-product .product-customization__item {
  margin-bottom: 0.65rem;
}

.page-product .product-customization__field-footer {
  margin-top: 0.25rem;
}

.page-product .product-customization__action {
  margin-top: 0.65rem;
}

.page-product .product__actions {
  margin-top: 0;
}

.page-product .product__actions .an-pf-fields-wrap {
  margin: 0.15rem 0 0.05rem;
  padding: 0.15rem 0 0;
}

.page-product .product__actions .an-pf-fields-title {
  margin-bottom: 0.75rem;
}

.page-product .product__actions .an-pf-field {
  padding: 0.35rem 0;
}

.page-product .product__actions .an-pf-field .control-label {
  margin-bottom: 0.35rem;
}

.page-product .product__actions .an-pf-fields-total {
  margin-bottom: 0.7rem;
  padding-top: 0.85rem;
}

.page-product .product__variants {
  margin-top: 0;
  margin-bottom: 0.45rem;
}

.page-product .product-variant {
  margin-bottom: 0.5rem;
}

.page-product .product-variant__label {
  margin-bottom: 0.25rem;
}

.page-product .product-add-to-cart {
  margin-top: 0.35rem;
}

.page-product .product__availability {
  margin: 0.35rem 0 0.45rem;
}

.page-product .product__availability-status {
  margin-bottom: 0.15rem;
}

.page-product .product__delivery-infos {
  margin-top: 0.15rem;
}

.page-product .product__actions-qty-add {
  margin-top: 0.55rem;
}

/* Product page: full-width description/bottom sections */
@media (min-width: 992px) {
  .page-product .product__bottom {
    display: block;
    margin-block-start: 2rem;
  }

  .page-product .product__bottom-left,
  .page-product .product__bottom-right {
    width: 100%;
    margin-block-end: 3rem;
  }
}

/* Product page: image zoom modal must fit the visible screen Hummingbird product-images-modal*/

.product-images-modal {
  --aa-product-modal-margin: 0.75rem;
  --aa-product-modal-header-height: 3.25rem;
}

/* Keep the Bootstrap modal dialog inside the viewport */
.product-images-modal .modal-dialog {
  width: calc(100vw - (var(--aa-product-modal-margin) * 2)) !important;
  max-width: min(1140px, calc(100vw - (var(--aa-product-modal-margin) * 2))) !important;

  height: calc(100svh - (var(--aa-product-modal-margin) * 2));
  max-height: calc(100svh - (var(--aa-product-modal-margin) * 2));

  margin: var(--aa-product-modal-margin) auto !important;
}

/* Use dynamic viewport height where supported */
@supports (height: 100dvh) {
  .product-images-modal .modal-dialog {
    height: calc(100dvh - (var(--aa-product-modal-margin) * 2));
    max-height: calc(100dvh - (var(--aa-product-modal-margin) * 2));
  }
}

/* Prevent modal content from becoming taller than the dialog */
.product-images-modal .modal-content {
  display: flex;
  flex-direction: column;
  max-height: 100%;
  overflow: hidden;
}

/* Header stays fixed-height; body gets the remaining space */
.product-images-modal .modal-header {
  flex: 0 0 auto;
}

.product-images-modal .product-images-modal__body,
.product-images-modal .modal-body {
  display: flex;
  flex: 1 1 auto;
  align-items: center;
  justify-content: center;
  min-height: 0;
  padding: 0.75rem;
  overflow: hidden;
}

/* Make the carousel fill only the available modal body */
.product-images-modal__carousel,
.product-images-modal__carousel .carousel-inner,
.product-images-modal__carousel .carousel-item {
  width: 100%;
  height: 100%;
  min-height: 0;
}

/* Center the active/transitioning slide */
.product-images-modal__carousel .carousel-item.active,
.product-images-modal__carousel .carousel-item-next,
.product-images-modal__carousel .carousel-item-prev {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Let <picture> participate in the available-height layout */
.product-images-modal__carousel picture {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  min-height: 0;
}

/* The important part: scale large product images down to the modal body */
.product-images-modal__carousel img,
.product-images-modal__carousel .img-fluid {
  display: block;
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: calc(
    100svh - (var(--aa-product-modal-margin) * 2) - var(--aa-product-modal-header-height) - 1.5rem
  ) !important;
  object-fit: contain;
}

@supports (height: 100dvh) {
  .product-images-modal__carousel img,
  .product-images-modal__carousel .img-fluid {
    max-height: calc(
      100dvh - (var(--aa-product-modal-margin) * 2) - var(--aa-product-modal-header-height) - 1.5rem
    ) !important;
  }
}

@media (max-width: 575.98px) {
  .product-images-modal {
    --aa-product-modal-margin: 0.5rem;
    --aa-product-modal-header-height: 3rem;
  }

  .product-images-modal .product-images-modal__body,
  .product-images-modal .modal-body {
    padding: 0.5rem;
  }
}


/* =========================================================
   9. Safety nets
   ========================================================= */

/* Inline accent-background safety net */
[style*="background-color: #D86018"],
[style*="background-color:#D86018"],
[style*="background: #D86018"],
[style*="background:#D86018"] {
  color: #fff !important;
}

[style*="background-color: #D86018"] *,
[style*="background-color:#D86018"] *,
[style*="background: #D86018"] *,
[style*="background:#D86018"] * {
  color: inherit !important;
  fill: currentColor !important;
  stroke: currentColor;
}


/* =========================================================
   10. About CMS page
   ========================================================= */

body#cms .aa-about {
  --aa-about-ink: #20272b;
  --aa-about-muted: #777a7d;
  --aa-about-rule: #20272b;
  --aa-about-gutter: clamp(22px, 4vw, 64px);
  --aa-about-section-space: clamp(64px, 9vw, 140px);
  --aa-about-column-gap: clamp(36px, 5vw, 84px);
  color: var(--aa-about-ink);
  background: #fff;
  font-family: Arial, Helvetica, sans-serif;
  overflow: visible;
}

body#cms .aa-about * {
  box-sizing: border-box;
}

body#cms .aa-about img {
  display: block;
  max-width: 100%;
  height: auto;
}

body#cms .aa-about__media {
  aspect-ratio: 1;
  width: 100%;
}

body#cms .aa-about__media img {
  aspect-ratio: 1;
  width: 100%;
  height: auto;
  object-fit: contain;
}

body#cms .aa-about__hero,
body#cms .aa-about__principle {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--aa-about-column-gap);
  align-items: center;
}

body#cms .aa-about__hero {
  min-height: clamp(480px, 48vw, 680px);
  padding: clamp(72px, 9vw, 130px) var(--aa-about-gutter) clamp(56px, 7vw, 110px);
}

body#cms .aa-about__intro {
  align-self: center;
  max-width: 720px;
}

body#cms .aa-about__eyebrow {
  margin: 0 0 4px;
  font-size: clamp(15px, 1vw, 20px);
  font-weight: 700;
  line-height: 1;
}

body#cms .aa-about__title {
  margin: 0;
  font-size: clamp(27px, 2.2vw, 42px);
  font-weight: 700;
  line-height: .95;
  letter-spacing: 0;
}

body#cms .aa-about__hero .aa-about__title {
  display: inline-block;
  position: relative;
  padding-bottom: 24px;
}

body#cms .aa-about__hero .aa-about__title::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 122px;
  height: 3px;
  background: var(--aa-about-rule);
}

body#cms .aa-about__copy {
  margin: clamp(18px, 1.6vw, 30px) 0 0;
  max-width: 720px;
  color: var(--aa-about-muted);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(13px, .92vw, 17px);
  line-height: 1.35;
  text-align: justify;
}

body#cms .aa-about__arrow {
  margin: clamp(40px, 5vw, 72px) auto 0;
  width: 42px;
  height: 60px;
  position: relative;
}

body#cms .aa-about__arrow::before,
body#cms .aa-about__arrow::after {
  content: "";
  position: absolute;
  background: var(--aa-about-ink);
}

body#cms .aa-about__arrow::before {
  left: 18px;
  top: 0;
  width: 6px;
  height: 48px;
  border-radius: 999px;
}

body#cms .aa-about__arrow::after {
  left: 9px;
  bottom: 8px;
  width: 24px;
  height: 24px;
  border-right: 6px solid var(--aa-about-ink);
  border-bottom: 6px solid var(--aa-about-ink);
  background: transparent;
  border-radius: 4px;
  transform: rotate(45deg);
}

body#cms .aa-about__logo {
  justify-self: center;
  width: min(640px, 76%);
}

body#cms .aa-about__principle {
  min-height: auto;
  padding: 0 var(--aa-about-gutter) var(--aa-about-section-space);
}

body#cms .aa-about__principle--sound {
  align-items: end;
  padding-top: clamp(20px, 4vw, 80px);
}

body#cms .aa-about__principle--sound .aa-about__media {
  align-self: end;
  margin-left: 0;
  width: 100%;
}

body#cms .aa-about__principle--transparency,
body#cms .aa-about__principle--reliability {
  align-items: center;
}

body#cms .aa-about__principle--transparency .aa-about__text,
body#cms .aa-about__principle--reliability .aa-about__text {
  padding-left: clamp(0px, 2vw, 42px);
}

body#cms .aa-about__principle--courtesy .aa-about__media,
body#cms .aa-about__principle--reliability .aa-about__media {
  align-self: center;
}

body#cms .aa-about__principle--courtesy .aa-about__media img,
body#cms .aa-about__principle--reliability .aa-about__media img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

body#cms .aa-about__principle--transparency .aa-about__media,
body#cms .aa-about__principle--reliability .aa-about__media {
  margin-right: 0;
}

body#cms .aa-about__principle--transparency .aa-about__text,
body#cms .aa-about__principle--courtesy .aa-about__media,
body#cms .aa-about__principle--reliability .aa-about__text {
  justify-self: start;
}

body#cms .aa-about__principle--sound .aa-about__text,
body#cms .aa-about__principle--transparency .aa-about__media,
body#cms .aa-about__principle--courtesy .aa-about__text,
body#cms .aa-about__principle--reliability .aa-about__media {
  justify-self: end;
}

body#cms .aa-about__text {
  max-width: 560px;
}

body#cms .aa-about__text .aa-about__copy {
  margin-top: clamp(20px, 1.8vw, 34px);
}

@media (max-width: 860px) {
  body#cms .aa-about__hero,
  body#cms .aa-about__principle {
    grid-template-columns: 1fr;
  }

  body#cms .aa-about__hero {
    min-height: auto;
    padding-top: 72px;
  }

  body#cms .aa-about__logo {
    width: min(460px, 88%);
    justify-self: start;
  }

  body#cms .aa-about__principle {
    min-height: auto;
    padding-bottom: 88px;
  }

  body#cms .aa-about__principle--sound .aa-about__media,
  body#cms .aa-about__principle--transparency .aa-about__media,
  body#cms .aa-about__principle--reliability .aa-about__media {
    margin-left: 0;
    margin-right: 0;
    width: 100%;
  }

  body#cms .aa-about__principle--transparency .aa-about__text,
  body#cms .aa-about__principle--reliability .aa-about__text {
    padding-left: 0;
  }

  body#cms .aa-about__principle--courtesy .aa-about__media,
  body#cms .aa-about__principle--reliability .aa-about__media {
    min-height: 0;
  }

  body#cms .aa-about__principle--transparency .aa-about__media,
  body#cms .aa-about__principle--reliability .aa-about__media {
    order: -1;
  }

  body#cms .aa-about__copy {
    text-align: left;
  }
}


/* =========================================================
   11. Paged checkout
   ========================================================= */

body#checkout .aa-paged-checkout {
  color: var(--aa-dark);
}

body#checkout .aa-paged-checkout__container,
body#checkout .aa-paged-checkout__notifications {
  width: min(100% - 2rem, 1320px);
  max-width: 1320px;
}

body#checkout .aa-paged-checkout__heading {
  margin: 2rem 0 1.5rem;
}

body#checkout .aa-paged-checkout__eyebrow {
  margin-bottom: 0.35rem;
  color: var(--aa-accent);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

body#checkout .aa-paged-checkout__title {
  margin: 0;
  color: var(--aa-dark);
  font-size: 2.35rem;
  line-height: 1.05;
}

body#checkout .aa-paged-checkout__grid {
  align-items: flex-start;
}

body#checkout .aa-paged-checkout__main {
  padding-right: 1rem;
}

body#checkout .aa-paged-checkout__aside {
  padding-left: 1rem;
}

body#checkout .aa-paged-checkout__summary {
  position: sticky;
  top: 1.25rem;
  padding: 1rem 1.1rem 1.15rem;
  border: 1px solid rgba(var(--aa-dark-rgb), 0.12);
  border-radius: var(--aa-radius-lg);
  background: #ffffff;
}

body#checkout .aa-paged-checkout__summary-header {
  margin-bottom: 0.85rem;
  color: var(--aa-dark);
  font-family: var(--aa-font-heading);
  font-size: 1.25rem;
  font-weight: 650;
  letter-spacing: 0;
}

body#checkout .aa-paged-checkout__summary .accordion-item,
body#checkout .aa-paged-checkout__summary .accordion-button {
  border: 0;
  background: transparent;
  box-shadow: none;
}

body#checkout .aa-paged-checkout__summary .accordion-button {
  padding: 0.85rem 0;
  color: var(--aa-dark);
  font-weight: 800;
}

body#checkout .aa-paged-checkout__summary .cart-summary {
  color: var(--aa-dark);
}

body#checkout .aa-paged-checkout__stage {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(var(--aa-dark-rgb), 0.12);
  border-radius: var(--aa-radius-lg);
  background: #ffffff;
}

body#checkout .aa-paged-checkout-step {
  display: block !important;
  position: absolute;
  inset: 0;
  width: 100%;
  margin: 0;
  padding: 1.3rem 1.35rem 1.4rem 4.2rem;
  opacity: 0;
  pointer-events: none;
  transform: translateX(3rem);
  transition: opacity 220ms ease, transform 260ms ease;
  visibility: hidden;
}

body#checkout .aa-paged-checkout-step.active,
body#checkout .aa-paged-checkout-step.show,
body#checkout .aa-paged-checkout-step.step--current {
  position: relative;
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0);
  visibility: visible;
}

body#checkout .aa-paged-checkout__stage.is-sliding-back .aa-paged-checkout-step {
  transform: translateX(-3rem);
}

body#checkout .aa-paged-checkout__stage.is-sliding-back .aa-paged-checkout-step.active,
body#checkout .aa-paged-checkout__stage.is-sliding-back .aa-paged-checkout-step.show,
body#checkout .aa-paged-checkout__stage.is-sliding-back .aa-paged-checkout-step.step--current {
  transform: translateX(0);
}

body#checkout .aa-paged-checkout-step__number {
  position: absolute;
  top: 1.3rem;
  left: 1.2rem;
  display: inline-flex;
  width: 2rem;
  height: 2rem;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: var(--aa-accent);
  color: #ffffff;
  font-weight: 800;
  line-height: 1;
}

body#checkout .aa-paged-checkout-step__title {
  margin-bottom: 1rem;
  padding-bottom: 0.9rem;
  border-bottom: 1px solid rgba(var(--aa-dark-rgb), 0.12);
}

body#checkout .aa-paged-checkout-step__heading {
  margin: 0;
  color: var(--aa-dark);
  font-family: var(--aa-font-heading);
  font-size: 1.55rem;
  font-weight: 650;
  letter-spacing: 0;
  line-height: 1.12;
}

body#checkout .aa-paged-checkout-step__content {
  color: rgba(var(--aa-dark-rgb), 0.78);
}

body#checkout .aa-paged-checkout .nav-underline {
  gap: 0.65rem;
  margin-bottom: 1.25rem;
}

body#checkout .aa-paged-checkout .nav-underline .nav-link {
  padding-inline: 0;
  color: rgba(var(--aa-dark-rgb), 0.72);
  font-weight: 800;
}

body#checkout .aa-paged-checkout .nav-underline .nav-link.active {
  color: var(--aa-dark);
  border-color: var(--aa-dark);
}

body#checkout .checkout-steps,
body#checkout .aa-paged-checkout .checkout-steps {
  --bs-success: var(--aa-accent);
  --bs-success-rgb: var(--aa-accent-rgb);
}

body#checkout .checkout-steps .text-success,
body#checkout .aa-paged-checkout .text-success {
  color: var(--aa-accent) !important;
}

body#checkout .checkout-steps .progress-ring,
body#checkout .checkout-steps .progress-ring__background-circle,
body#checkout .checkout-steps .progress-ring__circle,
body#checkout .checkout-steps .progress-ring__text {
  color: var(--aa-accent) !important;
}

body#checkout .checkout-steps__step--current::before,
body#checkout .checkout-steps__step--success::before,
body#checkout .checkout-steps__step--success::after,
body#checkout .aa-paged-checkout .checkout-steps__step--current::before,
body#checkout .aa-paged-checkout .checkout-steps__step--success::before,
body#checkout .aa-paged-checkout .checkout-steps__step--success::after {
  background: var(--aa-accent);
}

body#checkout .checkout-steps__step--success .checkout-steps__number,
body#checkout .aa-paged-checkout .checkout-steps__step--success .checkout-steps__number {
  background: var(--aa-accent);
}

body#checkout .checkout-steps__step--success .checkout-steps__btn,
body#checkout .aa-paged-checkout .checkout-steps__step--success .checkout-steps__btn {
  color: var(--aa-dark) !important;
}

body#checkout .aa-paged-checkout .valid-feedback,
body#checkout .aa-paged-checkout .valid-tooltip,
body#checkout .aa-paged-checkout .form-control.is-valid,
body#checkout .aa-paged-checkout .form-select.is-valid,
body#checkout .aa-paged-checkout .was-validated .form-control:valid,
body#checkout .aa-paged-checkout .was-validated .form-select:valid {
  color: var(--aa-dark);
}

body#checkout .aa-paged-checkout .form-control.is-valid,
body#checkout .aa-paged-checkout .form-select.is-valid,
body#checkout .aa-paged-checkout .was-validated .form-control:valid,
body#checkout .aa-paged-checkout .was-validated .form-select:valid {
  border-color: var(--aa-accent);
  background-image: none;
}

body#checkout .aa-paged-checkout .form-control,
body#checkout .aa-paged-checkout .form-select {
  border-color: rgba(var(--aa-dark-rgb), 0.16);
  border-radius: var(--aa-radius-sm);
  color: var(--aa-dark);
}

body#checkout .aa-paged-checkout .form-control:focus,
body#checkout .aa-paged-checkout .form-select:focus {
  border-color: var(--aa-input-focus-border);
  box-shadow: 0 0 0 0.2rem var(--aa-focus-ring);
}

body#checkout .aa-paged-checkout .form-check-input:checked {
  border-color: var(--aa-accent);
  background-color: var(--aa-accent);
}

body#checkout .aa-paged-checkout .address__list,
body#checkout .aa-paged-checkout .delivery-options__list,
body#checkout .aa-paged-checkout .payment-options__list {
  display: grid;
  gap: 0.8rem;
}

body#checkout .aa-paged-checkout .address-item,
body#checkout .aa-paged-checkout .delivery-option__item,
body#checkout .aa-paged-checkout .payment-option {
  border-color: rgba(var(--aa-dark-rgb), 0.12) !important;
  border-radius: var(--aa-radius);
  background: #ffffff;
  transition: border-color var(--aa-transition-fast), background-color var(--aa-transition-fast);
}

body#checkout .aa-paged-checkout .address-item.selected,
body#checkout .aa-paged-checkout .address-item:hover,
body#checkout .aa-paged-checkout .delivery-option__item:hover,
body#checkout .aa-paged-checkout .payment-option:hover {
  border-color: rgba(var(--aa-accent-rgb), 0.42) !important;
  background: var(--aa-cream);
}

body#checkout .aa-paged-checkout .payment-option__additional-information,
body#checkout .aa-paged-checkout .js-payment-option-form,
body#checkout .aa-paged-checkout .delivery-option__extra-content {
  margin-top: 0.75rem;
  padding: 0.85rem 1rem;
  border-radius: var(--aa-radius);
  background: rgba(var(--aa-accent-rgb), 0.07);
}

body#checkout .aa-paged-checkout .buttons-wrapper {
  gap: 0.75rem;
}

body#checkout .aa-paged-checkout .btn-primary {
  border-color: var(--aa-accent);
  background: var(--aa-accent);
  box-shadow: 0 0.65rem 1.35rem rgba(var(--aa-accent-rgb), 0.22);
}

body#checkout .aa-paged-checkout .btn-primary:hover,
body#checkout .aa-paged-checkout .btn-primary:focus {
  border-color: var(--aa-dark);
  background: var(--aa-dark);
}

body#checkout .aa-paged-checkout .btn-outline-primary {
  border-color: rgba(var(--aa-accent-rgb), 0.62);
  color: var(--aa-accent);
}

body#checkout .aa-paged-checkout .btn-outline-primary:hover,
body#checkout .aa-paged-checkout .btn-outline-primary:focus {
  border-color: var(--aa-accent);
  background: var(--aa-accent);
  color: #ffffff;
}

@media (min-width: 992px) {
  body#checkout .aa-paged-checkout__main {
    flex: 0 0 65%;
    max-width: 65%;
  }

  body#checkout .aa-paged-checkout__aside {
    flex: 0 0 35%;
    max-width: 35%;
  }
}

@media (max-width: 991.98px) {
  body#checkout .aa-paged-checkout__heading {
    margin-top: 1.35rem;
  }

  body#checkout .aa-paged-checkout__grid {
    row-gap: 1rem;
  }

  body#checkout .aa-paged-checkout__main,
  body#checkout .aa-paged-checkout__aside {
    padding-inline: 0;
  }

  body#checkout .aa-paged-checkout__summary {
    position: static;
    margin-top: 1rem;
  }
}

@media (max-width: 575.98px) {
  body#checkout .aa-paged-checkout__container,
  body#checkout .aa-paged-checkout__notifications {
    width: min(100% - 0.75rem, 1320px);
  }

  body#checkout .aa-paged-checkout__heading {
    margin: 0.9rem 0 0.8rem;
  }

  body#checkout .aa-paged-checkout__eyebrow {
    margin-bottom: 0.2rem;
    font-size: 0.7rem;
  }

  body#checkout .aa-paged-checkout__title {
    font-size: 1.75rem;
  }

  body#checkout .aa-paged-checkout__stage,
  body#checkout .aa-paged-checkout__summary {
    border-radius: var(--aa-radius);
  }

  body#checkout .aa-paged-checkout-step {
    display: grid !important;
    grid-template-columns: 2rem minmax(0, 1fr);
    gap: 0 0.7rem;
    padding: 0.85rem;
  }

  body#checkout .aa-paged-checkout-step__number {
    position: static;
    margin: 0;
    align-self: start;
  }

  body#checkout .aa-paged-checkout-step__title {
    min-width: 0;
    margin-bottom: 0.75rem;
    padding-bottom: 0.7rem;
  }

  body#checkout .aa-paged-checkout-step__heading {
    font-size: 1.25rem;
    line-height: 1.15;
  }

  body#checkout .aa-paged-checkout-step__content {
    grid-column: 1 / -1;
  }

  body#checkout .aa-paged-checkout .nav-underline {
    gap: 0.5rem;
    margin-bottom: 0.9rem;
  }

  body#checkout .aa-paged-checkout .nav-underline .nav-link {
    font-size: 0.9rem;
  }

  body#checkout .aa-paged-checkout .form-control,
  body#checkout .aa-paged-checkout .form-select {
    min-height: 2.75rem;
  }

  body#checkout .aa-paged-checkout .buttons-wrapper {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
  }

  body#checkout .aa-paged-checkout .buttons-wrapper .btn,
  body#checkout .aa-paged-checkout .btn-primary,
  body#checkout .aa-paged-checkout .btn-outline-primary {
    width: 100%;
  }

  body#checkout .aa-paged-checkout__summary {
    margin-top: 0;
    padding: 0.8rem 0.85rem;
  }

  body#checkout .aa-paged-checkout__summary-header {
    margin-bottom: 0.4rem;
    font-size: 1.1rem;
  }

  body#checkout .aa-paged-checkout__summary .accordion-button {
    padding: 0.65rem 0;
  }
}


/* =========================================================
   12. ETS Blog
   ========================================================= */

:is(body[id^="module-ets_blog-"], body#ets_blog_page) #left-column {
  display: none !important;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) #content-wrapper.left-column,
.aa-ets-blog-page {
  flex: 0 0 100% !important;
  width: 100% !important;
  max-width: 100% !important;
  padding-inline: 1rem;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper,
.aa-ets-blog-page .ets-blog-wrapper {
  max-width: 1060px;
  margin-inline: auto;
  color: var(--aa-dark);
  font-family: var(--aa-font-ui);
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper .page-heading,
.aa-ets-blog-page .ets-blog-wrapper .page-heading {
  margin: 0 0 1.5rem;
  color: var(--aa-dark);
  font-family: var(--aa-font-heading);
  font-size: 2.45rem;
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: 0;
  text-transform: none;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .blog-category,
.aa-ets-blog-page .blog-category {
  margin-bottom: 2rem;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .blog-category.has-blog-image .ets_item_img,
.aa-ets-blog-page .blog-category.has-blog-image .ets_item_img {
  margin-bottom: 1.5rem;
  border-radius: var(--aa-radius-lg);
  overflow: hidden;
  box-shadow: var(--aa-shadow-soft);
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .blog-category-desc,
.aa-ets-blog-page .blog-category-desc {
  max-width: 760px;
  color: rgba(var(--aa-dark-rgb), 0.72);
  font-size: 1rem;
  line-height: 1.75;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-list,
.aa-ets-blog-page .ets-blog-list {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 1.5rem;
  margin: 0 !important;
  padding: 0 !important;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-list > li,
.aa-ets-blog-page .ets-blog-list > li {
  float: none !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-list .post-wrapper,
.aa-ets-blog-page .ets-blog-list .post-wrapper {
  display: grid;
  grid-template-columns: minmax(230px, 0.52fr) minmax(0, 1fr);
  gap: 1.6rem;
  align-items: stretch;
  min-height: 0;
  padding: 1.25rem;
  border: 1px solid rgba(37, 50, 55, 0.12);
  border-radius: var(--aa-radius-lg);
  background: linear-gradient(135deg, #ffffff 0%, #fff8f2 100%);
  box-shadow: 0 18px 42px rgba(37, 50, 55, 0.1);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-list .post-wrapper:hover,
.aa-ets-blog-page .ets-blog-list .post-wrapper:hover {
  border-color: rgba(216, 96, 24, 0.32);
  box-shadow: 0 22px 52px rgba(37, 50, 55, 0.14);
  transform: translateY(-2px);
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-list .ets_item_img,
.aa-ets-blog-page .ets-blog-list .ets_item_img {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  aspect-ratio: 4 / 3;
  border-radius: var(--aa-radius);
  overflow: hidden;
  background: rgba(37, 50, 55, 0.06);
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-list .ets_item_img img,
.aa-ets-blog-page .ets-blog-list .ets_item_img img,
:is(body[id^="module-ets_blog-"], body#ets_blog_page) .blog-category .ets_item_img img,
.aa-ets-blog-page .blog-category .ets_item_img img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  transition: transform 220ms ease;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-list .post-wrapper:hover .ets_item_img img,
.aa-ets-blog-page .ets-blog-list .post-wrapper:hover .ets_item_img img {
  transform: scale(1.03);
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper .ets-blog-wrapper-content,
.aa-ets-blog-page .ets-blog-wrapper .ets-blog-wrapper-content {
  display: flex;
  min-width: 0;
  flex-direction: column;
  justify-content: center;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper .ets-blog-wrapper-content-main,
.aa-ets-blog-page .ets-blog-wrapper .ets-blog-wrapper-content-main {
  min-width: 0;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper .ets_title_block,
.aa-ets-blog-page .ets-blog-wrapper .ets_title_block {
  display: inline;
  color: var(--aa-dark);
  font-family: var(--aa-font-heading);
  font-size: 1.7rem;
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: 0;
  text-transform: none;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper .ets_title_block:hover,
.aa-ets-blog-page .ets-blog-wrapper .ets_title_block:hover,
:is(body[id^="module-ets_blog-"], body#ets_blog_page) .post-author-name:hover,
.aa-ets-blog-page .post-author-name:hover {
  color: var(--aa-accent);
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper .ets-blog-latest-toolbar,
.aa-ets-blog-page .ets-blog-wrapper .ets-blog-latest-toolbar,
:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-sidear-post-meta,
.aa-ets-blog-page .ets-blog-sidear-post-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem 0.85rem;
  margin: 0.75rem 0 0.7rem;
  color: rgba(37, 50, 55, 0.62);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper .ets-blog-latest-toolbar a,
.aa-ets-blog-page .ets-blog-wrapper .ets-blog-latest-toolbar a,
:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-sidear-post-meta a,
.aa-ets-blog-page .ets-blog-sidear-post-meta a,
:is(body[id^="module-ets_blog-"], body#ets_blog_page) .extra_tag_cat a,
.aa-ets-blog-page .extra_tag_cat a {
  color: var(--aa-accent);
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper .blog_description,
.aa-ets-blog-page .ets-blog-wrapper .blog_description {
  color: rgba(var(--aa-dark-rgb), 0.72);
  font-size: 1rem;
  line-height: 1.78;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper .blog_description p,
.aa-ets-blog-page .ets-blog-wrapper .blog_description p {
  margin-bottom: 1rem;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .read_more,
.aa-ets-blog-page .read_more,
:is(body[id^="module-ets_blog-"], body#ets_blog_page) .blog-submit .button,
.aa-ets-blog-page .blog-submit .button {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;
  min-height: 2.65rem;
  margin-top: 0.5rem;
  padding: 0.7rem 1.05rem;
  border: 1px solid var(--aa-accent);
  border-radius: 999rem;
  background: var(--aa-accent);
  color: #ffffff !important;
  font-size: 0.86rem;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
  box-shadow: 0 10px 24px rgba(216, 96, 24, 0.22);
  transition: background-color 160ms ease, border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .read_more:hover,
.aa-ets-blog-page .read_more:hover,
:is(body[id^="module-ets_blog-"], body#ets_blog_page) .blog-submit .button:hover,
.aa-ets-blog-page .blog-submit .button:hover {
  border-color: var(--aa-dark);
  background: var(--aa-dark);
  box-shadow: 0 14px 28px rgba(37, 50, 55, 0.18);
  transform: translateY(-1px);
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .blog-paggination,
.aa-ets-blog-page .blog-paggination {
  margin-top: 2rem;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .blog-paggination ul,
.aa-ets-blog-page .blog-paggination ul {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  justify-content: center;
  padding: 0;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .blog-paggination li,
.aa-ets-blog-page .blog-paggination li {
  list-style: none;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .blog-paggination a,
:is(body[id^="module-ets_blog-"], body#ets_blog_page) .blog-paggination span,
.aa-ets-blog-page .blog-paggination a,
.aa-ets-blog-page .blog-paggination span {
  display: inline-flex;
  min-width: 2.4rem;
  min-height: 2.4rem;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(37, 50, 55, 0.14);
  border-radius: 999rem;
  background: #ffffff;
  color: var(--aa-dark);
  font-weight: 800;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .blog-paggination .active span,
:is(body[id^="module-ets_blog-"], body#ets_blog_page) .blog-paggination a:hover,
.aa-ets-blog-page .blog-paggination .active span,
.aa-ets-blog-page .blog-paggination a:hover {
  border-color: var(--aa-accent);
  background: var(--aa-accent);
  color: #ffffff;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper-detail,
.aa-ets-blog-page .ets-blog-wrapper-detail {
  color: var(--aa-dark);
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper-detail a,
.aa-ets-blog-page .ets-blog-wrapper-detail a {
  color: var(--aa-accent);
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper-detail .blog_description,
.aa-ets-blog-page .ets-blog-wrapper-detail .blog_description {
  color: var(--aa-dark);
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper-detail .ets_comment_form_blog .title_blog,
.aa-ets-blog-page .ets-blog-wrapper-detail .ets_comment_form_blog .title_blog {
  margin-bottom: 1rem;
  color: var(--aa-dark);
  font-family: var(--aa-font-heading);
  font-size: 1.45rem;
  letter-spacing: 0;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper-detail .ets_comment_form_blog label,
.aa-ets-blog-page .ets-blog-wrapper-detail .ets_comment_form_blog label {
  color: var(--aa-dark);
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper-detail .ets_comment_form_blog .form-control,
.aa-ets-blog-page .ets-blog-wrapper-detail .ets_comment_form_blog .form-control {
  border: 1px solid rgba(37, 50, 55, 0.16);
  border-radius: var(--aa-radius-sm);
  color: var(--aa-dark);
}

:is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper-detail .ets_comment_form_blog .form-control:focus,
.aa-ets-blog-page .ets-blog-wrapper-detail .ets_comment_form_blog .form-control:focus {
  border-color: var(--aa-accent);
  box-shadow: 0 0 0 0.18rem rgba(216, 96, 24, 0.16);
}

@media (min-width: 992px) {
  :is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper .page-heading,
  .aa-ets-blog-page .ets-blog-wrapper .page-heading {
    font-size: 3rem;
  }

  :is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-list .post-wrapper,
  .aa-ets-blog-page .ets-blog-list .post-wrapper {
    padding: 1.5rem;
  }
}

@media (max-width: 767.98px) {
  :is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper .page-heading,
  .aa-ets-blog-page .ets-blog-wrapper .page-heading {
    font-size: 2rem;
  }

  :is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-list .post-wrapper,
  .aa-ets-blog-page .ets-blog-list .post-wrapper {
    grid-template-columns: minmax(0, 1fr);
    padding: 1rem;
  }

  :is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-list .ets_item_img,
  .aa-ets-blog-page .ets-blog-list .ets_item_img {
    aspect-ratio: 16 / 10;
  }

  :is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-wrapper .ets_title_block,
  .aa-ets-blog-page .ets-blog-wrapper .ets_title_block {
    font-size: 1.45rem;
  }
}


/* =========================================================
   13. Responsive
   ========================================================= */

@media (max-width: 767.98px) {
  .header-bottom--single {
    padding: 0.5rem 0;
  }

  .header-single__logo .logo {
    max-width: 7rem;
    max-height: 2.5rem;
  }

  .header-single__right .ps-searchbar {
    width: auto;
  }

  .footer--arienne {
    margin-top: 4rem;
    padding-block: 2.5rem 1.25rem;
    background: linear-gradient(
      to bottom,
      var(--aa-dark) 0,
      var(--aa-dark) 1.75rem,
      var(--aa-dark-850) 7.85rem,
      var(--aa-dark-950) 100%
    );
  }

  .footer--arienne::before {
    top: -83px;
    height: 85px;
  }

  .footer--arienne__inner {
    transform: translateY(-1.5rem);
  }
}

@media (max-width: 575.98px) {
  .footer--arienne {
    padding-block: 2rem 1.25rem;
  }

  .footer--arienne__logo {
    margin-bottom: 1.25rem;
  }

  .footer--arienne__logo .logo {
    max-width: 7rem;
    max-height: 2.5rem;
  }

  .footer--arienne__nav .footer-block__list {
    row-gap: 0.25rem;
  }

  .footer--arienne__nav .footer-block__list li + li::before {
    margin-inline: 0.55rem;
  }
}


/* =========================================================
   14. HESK contact form
   ========================================================= */

.hesk-contact {
  width: min(100%, 46rem);
  margin-inline: auto;
  color: var(--aa-dark);
}

.hesk-contact__intro {
  margin-bottom: 1.5rem;
}

.hesk-contact__eyebrow {
  margin-bottom: 0.4rem;
  color: var(--aa-accent);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.hesk-contact__title {
  margin-bottom: 0.55rem;
  font-family: var(--aa-font-heading);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 650;
  line-height: 1.05;
}

.hesk-contact__copy {
  max-width: 38rem;
  margin-bottom: 0;
  color: rgba(var(--aa-dark-rgb), 0.72);
  font-size: 1rem;
  line-height: 1.55;
}

.hesk-contact__form {
  padding: clamp(1.25rem, 3vw, 2rem);
  background: var(--bs-body-bg);
  border: 1px solid rgba(var(--aa-dark-rgb), 0.12);
  border-radius: var(--aa-radius-lg);
  box-shadow: var(--aa-shadow-soft);
}

.hesk-contact__notification {
  margin-bottom: 1.25rem;
}

.hesk-contact__notification ul {
  padding-left: 1.1rem;
  margin-bottom: 0;
}

.hesk-contact__fields {
  display: grid;
  gap: 1rem;
}

.hesk-contact__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.hesk-contact__field {
  min-width: 0;
}

.hesk-contact .form-label {
  margin-bottom: 0.4rem;
  color: var(--aa-dark);
  font-weight: 650;
}

.hesk-contact .form-control,
.hesk-contact .form-select {
  min-height: 2.85rem;
  border-color: rgba(var(--aa-dark-rgb), 0.16);
  border-radius: var(--aa-radius);
  background-color: #fff;
}

.hesk-contact textarea.form-control {
  min-height: 11rem;
  resize: vertical;
}

.hesk-contact__footer {
  display: flex;
  justify-content: flex-end;
  margin-top: 1.25rem;
}

.hesk-contact__submit {
  min-width: 9.5rem;
}

.hesk-contact__trap {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

@media (max-width: 575.98px) {
  .hesk-contact__form {
    padding: 1rem;
  }

  .hesk-contact__grid {
    grid-template-columns: 1fr;
  }

  .hesk-contact__footer,
  .hesk-contact__submit {
    width: 100%;
  }
}


/* =========================================================
   15. Reduced motion
   ========================================================= */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
  }

  a,
  .dropdown-item,
  .btn-close,
  .ps-mainmenu--mobile .btn-close,
  .ps-mainmenu--desktop .ps-mainmenu__tree-item-wrapper,
  .ps-mainmenu--desktop .ps-mainmenu__tree-link,
  .ps-mainmenu--desktop .ps-mainmenu__tree-link::after,
  .ps-mainmenu--desktop .ps-mainmenu__tree-dropdown-toggle,
  .ps-mainmenu--desktop .submenu,
  .ps-mainmenu--desktop .submenu__left-item,
  .ps-mainmenu--desktop .submenu__right-items .menu-item,
  .ps-mainmenu--desktop .submenu__right-items a,
  .ps-mainmenu--mobile .menu__link,
  .ps-mainmenu--mobile .menu a,
  .ps-mainmenu--mobile .menu__toggle-child,
  .header-single__right .ps-customersignin .dropdown-toggle,
  .header-single__right .ps-customersignin .dropdown-menu,
  .header-single__right .ps-customersignin .dropdown-item,
  .header-single__right .ps-customersignin .dropdown-item .material-icons,
  :is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-list .post-wrapper,
  :is(body[id^="module-ets_blog-"], body#ets_blog_page) .ets-blog-list .ets_item_img img,
  :is(body[id^="module-ets_blog-"], body#ets_blog_page) .read_more,
  :is(body[id^="module-ets_blog-"], body#ets_blog_page) .blog-submit .button,
  .aa-ets-blog-page .ets-blog-list .post-wrapper,
  .aa-ets-blog-page .ets-blog-list .ets_item_img img,
  .aa-ets-blog-page .read_more,
  .aa-ets-blog-page .blog-submit .button,
  body#checkout .aa-paged-checkout-step,
  body#checkout .aa-paged-checkout .address-item,
  body#checkout .aa-paged-checkout .delivery-option__item,
  body#checkout .aa-paged-checkout .payment-option {
    transition: none !important;
  }
}
