/** Shopify CDN: Minification failed

Line 61:0 All "@import" rules must come first
Line 88:15 Expected identifier but found whitespace
Line 4601:0 Unexpected "<"
Line 5703:0 Unexpected "<"
Line 5799:46 Unexpected "-->"
Line 5801:3 Expected identifier but found "%"
Line 5802:4 Unexpected "{"
Line 5802:5 Expected identifier but found "%"
Line 5803:6 Unexpected "<"
Line 5806:5 Expected identifier but found "%"
... and 19 more hidden warnings

**/
/* ✨ StreamMax Luxury Font Style (Headings + Buttons) */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600&family=Cairo:wght@400;600&family=Playfair+Display:wght@600;700&display=swap');

/* Premium Headings */
h1, h2, h3, .section-title, .hero-title {
  font-family: 'Playfair Display', 'Poppins', 'Cairo', sans-serif;
  font-weight: 700;
  letter-spacing: 0.8px;
  background: linear-gradient(90deg, #00ffc8, #0077ff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 0 10px rgba(0, 255, 200, 0.2);
  transition: all 0.3s ease;
}

h1:hover, h2:hover, h3:hover {
  text-shadow: 0 0 25px rgba(0, 255, 200, 0.4);
}

/* Buttons */
button, .btn, .order-button {
  font-family: 'Poppins', 'Cairo', sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  background: linear-gradient(135deg, #00ff95, #0099ff);
  border: none;
  box-shadow: 0 0 12px rgba(0,255,200,0.35);
  color: #fff;
  transition: all 0.3s ease;
}

button:hover, .btn:hover, .order-button:hover {
  transform: scale(1.05);
  box-shadow: 0 0 22px rgba(0,255,200,0.55);
}

/* Arabic Support */
:lang(ar) h1, :lang(ar) h2, :lang(ar) h3 {
  font-family: 'Cairo', 'Noto Sans Arabic', sans-serif !important;
  font-weight: 700;
  letter-spacing: 0 !important;
}

/* 🌍 StreamMax Global Font Configuration (Multi-language) */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600&family=Cairo:wght@400;500;600&family=Noto+Sans+Arabic:wght@400;500&display=swap');

body, html {
  font-family: 'Poppins', 'Cairo', 'Noto Sans Arabic', 'Segoe UI', 'Roboto', 'Helvetica Neue', sans-serif;
  font-weight: 400;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: #ffffff;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Poppins', 'Cairo', 'Noto Sans Arabic', 'Segoe UI', sans-serif;
  font-weight: 600;
  letter-spacing: 0.5px;
}

button, .btn, .menu, .nav, .faq-title, .pricing-card h3 {
  font-family: 'Poppins', 'Cairo', 'Noto Sans Arabic', sans-serif;
  font-weight: 500;
}

:lang(ar) {
  font-family: 'Cairo', 'Noto Sans Arabic', sans-serif !important;
  letter-spacing: 0 !important;
}

Vous avez dit :
* {
  box-sizing: border-box;
}

body {
  color: var(--color-foreground);
  background: var(--color-background);
  display: flex;
  flex-direction: column;
  margin: 0;
  min-height: 100svh;
  font-variation-settings: 'slnt' 0;
}

:root {
  --hover-lift-amount: 4px;
  --hover-scale-amount: 1.03;
  --hover-subtle-zoom-amount: 1.015;
  --hover-shadow-color: var(--color-shadow);
  --hover-transition-duration: 0.25s;
  --hover-transition-timing: ease-out;
  --surface-transition-duration: 0.3s;
  --surface-transition-timing: var(--ease-out-quad);
}

html {
  /* Firefox */
  scrollbar-width: thin;
  scrollbar-color: rgb(var(--color-foreground-rgb) / var(--opacity-40)) var(--color-background);
  scroll-behavior: smooth;
}

html[scroll-lock] {
  overflow: hidden;
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}

img {
  width: 100%;
  height: auto;
}

input,
textarea,
select {
  font: inherit;
  border-radius: var(--style-border-radius-inputs);
}

input:hover {
  background-color: var(--color-input-hover-background);
}

/** override ios and firefox defaults */
select {
  background-color: var(--color-background);
  color: currentcolor;
}

.product-card,
.collection-card,
.resource-card,
.predictive-search-results__card--product,
.predictive-search-results__card {
  position: relative;
  transition: transform var(--hover-transition-duration) var(--hover-transition-timing),
    box-shadow var(--hover-transition-duration) var(--hover-transition-timing);
  will-change: transform, box-shadow;
  z-index: var(--layer-flat);
}

.product-card__link {
  position: absolute;
  inset: 0;
}

.product-card__content {
  position: relative;
}

.product-card__content {
  cursor: pointer;
}

.product-card__content slideshow-component {
  --cursor: pointer;
}

.predictive-search-results__card .product-card,
.predictive-search-results__card .collection-card,
.predictive-search-results__card .resource-card {
  transition: none;
  will-change: auto;
}

@media (any-pointer: fine) and (prefers-reduced-motion: no-preference) {
  .card-hover-effect-lift .product-card:hover,
  .card-hover-effect-lift .collection-card:hover,
  .card-hover-effect-lift .resource-card:hover,
  .card-hover-effect-lift .predictive-search-results__card:hover {
    transform: translateY(calc(-1 * var(--hover-lift-amount)));
  }

  .card-hover-effect-lift .header .product-card:hover,
  .card-hover-effect-lift .header .collection-card:hover,
  .card-hover-effect-lift .header .resource-card:hover,
  .card-hover-effect-lift .header-drawer .product-card:hover,
  .card-hover-effect-lift .header-drawer .collection-card:hover,
  .card-hover-effect-lift .header-drawer .resource-card:hover {
    transform: none;
  }

  .card-hover-effect-scale .product-card:hover,
  .card-hover-effect-scale .collection-card:hover,
  .card-hover-effect-scale .resource-card:hover,
  .card-hover-effect-scale .predictive-search-results__card:hover {
    transform: scale(var(--hover-scale-amount));
  }

  .card-hover-effect-scale .header .product-card:hover,
  .card-hover-effect-scale .header .collection-card:hover,
  .card-hover-effect-scale .header .resource-card:hover,
  .card-hover-effect-scale .header-drawer .product-card:hover,
  .card-hover-effect-scale .header-drawer .collection-card:hover,
  .card-hover-effect-scale .header-drawer .resource-card:hover {
    transform: none;
  }

  .card-hover-effect-subtle-zoom .card-gallery,
  .card-hover-effect-subtle-zoom .collection-card__image,
  .card-hover-effect-subtle-zoom .product-card__image,
  .card-hover-effect-subtle-zoom .resource-card__image {
    overflow: hidden;
    transition: transform var(--hover-transition-duration) var(--hover-transition-timing);
  }

  .predictive-search-results__card .card-gallery,
  .predictive-search-results__card .collection-card__image,
  .predictive-search-results__card .product-card__image,
  .predictive-search-results__card .resource-card__image {
    transition: none;
  }

  .card-hover-effect-subtle-zoom .product-card:hover .card-gallery,
  .card-hover-effect-subtle-zoom .collection-card:hover .collection-card__image,
  .card-hover-effect-subtle-zoom .product-card:hover .product-card__image,
  .card-hover-effect-subtle-zoom .resource-card:hover .resource-card__image,
  .card-hover-effect-subtle-zoom .predictive-search-results__card:hover {
    transform: scale(var(--hover-subtle-zoom-amount));
  }

  .card-hover-effect-subtle-zoom .header .product-card:hover .card-gallery,
  .card-hover-effect-subtle-zoom .header .collection-card:hover .collection-card__image,
  .card-hover-effect-subtle-zoom .header .product-card:hover .product-card__image,
  .card-hover-effect-subtle-zoom .header .resource-card:hover .resource-card__image,
  .card-hover-effect-subtle-zoom .header-drawer .product-card:hover .card-gallery,
  .card-hover-effect-subtle-zoom .header-drawer .collection-card:hover .collection-card__image,
  .card-hover-effect-subtle-zoom .header-drawer .product-card:hover .product-card__image,
  .card-hover-effect-subtle-zoom .header-drawer .resource-card:hover .resource-card__image {
    transform: none;
  }

  .predictive-search-results__card .product-card:hover,
  .predictive-search-results__card .collection-card:hover,
  .predictive-search-results__card .resource-card:hover,
  .header .product-card:hover,
  .header .collection-card:hover,
  .header .resource-card:hover,
  .header-drawer .product-card:hover,
  .header-drawer .collection-card:hover,
  .header-drawer .resource-card:hover {
    transform: none;
    box-shadow: none;
  }
}

dialog {
  /* the ::backdrop inherits from the originating element, custom properties must be set on the dialog element */
  --backdrop-color-rgb: var(--color-shadow-rgb);

  background-color: var(--color-background);
  color: var(--color-foreground);
}

p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
}

.wrap-text {
  overflow-wrap: break-word;
  word-break: break-word;
  hyphens: auto;
}

p:empty {
  display: none;
}

:first-child:is(p, h1, h2, h3, h4, h5, h6),
:first-child:empty + :where(p, h1, h2, h3, h4, h5, h6) {
  margin-block-start: 0;
}

/* Remove bottom margin from last text item, or previous to last if the last is empty */
:last-child:is(p, h1, h2, h3, h4, h5, h6),
:where(p, h1, h2, h3, h4, h5, h6):nth-child(2):has(+ :last-child:empty) {
  margin-block-end: 0;
}

/* view transitions */
@media (prefers-reduced-motion: no-preference) {
  @view-transition {
    navigation: auto;
  }

  /* Keep page interactive while view transitions are running */
  :root {
    view-transition-name: none;
  }

  /* Have the root transition during page navigation */
  html:active-view-transition-type(page-navigation),
  html:active-view-transition-type(product-image-transition) {
    view-transition-name: root-custom;
  }

  ::view-transition {
    pointer-events: none;
  }

  html:active-view-transition-type(page-navigation) main[data-page-transition-enabled='true'] {
    view-transition-name: main-content;
  }

  html:active-view-transition-type(page-navigation) main[data-product-transition='true'][data-template*='product'] {
    view-transition-name: none;
  }

  ::view-transition-old(main-content) {
    animation: var(--view-transition-old-main-content);
  }

  ::view-transition-new(main-content) {
    animation: var(--view-transition-new-main-content);
  }

  html:active-view-transition-type(product-image-transition) {
    [data-view-transition-type='product-image-transition'] {
      view-transition-name: product-image-transition;
    }

    [data-view-transition-type='product-details'] {
      view-transition-name: product-details;
    }
  }

  ::view-transition-group(product-image-transition) {
    z-index: 1;
  }

  ::view-transition-group(product-image-transition),
  ::view-transition-group(product-details) {
    animation-duration: var(--animation-speed);
    animation-timing-function: var(--animation-easing);
  }

  ::view-transition-old(product-image-transition),
  ::view-transition-new(product-image-transition) {
    block-size: 100%;
    overflow: hidden;
    object-fit: cover;
    animation-duration: 0.25s;
    animation-timing-function: var(--animation-easing);
  }

  ::view-transition-new(product-details) {
    animation: var(--view-transition-new-main-content);
  }
}

/* Focus */
*:focus-visible {
  outline: var(--focus-outline-width) solid currentcolor;
  outline-offset: var(--focus-outline-offset);
}

@supports not selector(:focus-visible) {
  *:focus {
    outline: var(--focus-outline-width) solid currentcolor;
    outline-offset: var(--focus-outline-offset);
  }
}

.focus-inset {
  outline-offset: calc(var(--focus-outline-width) * -1);
}

/* Layout */
.content-for-layout {
  flex: 1;
}

/* Set up page widths & margins */
.page-width-wide,
.page-width-normal,
.page-width-narrow,
.page-width-content {
  --page-margin: 16px;
}

@media screen and (min-width: 750px) {
  .page-width-wide,
  .page-width-normal,
  .page-width-narrow,
  .page-width-content {
    --page-margin: 40px;
  }
}

.page-width-wide {
  /* NOTE: This results in a page width of 2400px because of how we set up margins with grid */
  --page-content-width: var(--wide-page-width);
  --page-width: calc(var(--page-content-width) + (var(--page-margin) * 2));
}

.page-width-normal {
  --page-content-width: var(--normal-page-width);
  --page-width: calc(var(--page-content-width) + (var(--page-margin) * 2));
}

.page-width-narrow,
.page-width-content {
  /* NOTE: This results in a page width of 1400px because of how we set up margins with grid */
  --page-content-width: var(--narrow-page-width);
  --page-width: calc(var(--page-content-width) + (var(--page-margin) * 2));
}

.page-width-content {
  --page-content-width: var(--normal-content-width);
  --page-width: calc(var(--page-content-width) + (var(--page-margin) * 2));
}

/* Section width full vs. page
   The reason we use a grid to contain the section is to allow for the section to have a
   full-width background image even if the section content is constrained by the page width. Do not try
   to rewrite this to max-width: --page-width; margin: 0 auto;, it doesn't work. */
.section {
  --full-page-grid-central-column-width: min(
    var(--page-width) - var(--page-margin) * 2,
    calc(100% - var(--page-margin) * 2)
  );
  --full-page-grid-margin: minmax(var(--page-margin), 1fr);
  --full-page-grid-with-margins: var(--full-page-grid-margin) var(--full-page-grid-central-column-width)
    var(--full-page-grid-margin);

  /* Utility variable gives the grid's first column width. Provides an offset width for components like carousels */
  --util-page-margin-offset: max(
    var(--page-margin),
    calc((100% - min(var(--page-content-width), calc(100% - (var(--page-margin) * 2)))) / 2)
  );

  /* Offset for full-width sections to account for the page margin,
  used for Marquee — note that --util-page-margin-offset doesn't work here */
  --full-page-margin-inline-offset: calc(((100vw - var(--full-page-grid-central-column-width)) / 2) * -1);

  width: 100%;

  /* This is required to make background images work, which are <img> rendered absolutely */
  position: relative;

  /* Set up the grid */
  display: grid;
  grid-template-columns: var(--full-page-grid-with-margins);
  min-height: var(--section-min-height, 'auto');
}

/* Place all direct children in the center column by default */
.section > * {
  grid-column: 2;
}

/* Make the actual section background transparent, and instead apply it to a separate sibling element to enable stacking with hero shadow  */
.shopify-section:not(.header-section) :is(.section, .cart__summary-container) {
  background: transparent;
}

.shopify-section:not(.header-section):has(.section) {
  position: relative;
}

.shopify-section:not(.header-section) .section-background {
  content: '';
  position: absolute;
  inset: 0;
  z-index: var(--layer-section-background);
}

/* For page-width sections, all content goes in the center column */
.section--page-width > * {
  grid-column: 2;
}

/* For full-width sections, content spans all columns */
.section--full-width > * {
  grid-column: 1 / -1;
}

/* Some page-width sections should still extend all the way to the right edge of the page, e.g. collection carousel */
.section--page-width.section--full-width-right > * {
  grid-column: 2 / 4;
}

/* For full-width sections with margin, content still spans full width but with space on the sides */
.section--full-width.section--full-width-margin > * {
  grid-column: 1 / -1;

  @media screen and (min-width: 750px) {
    padding-left: var(--page-margin);
    padding-right: var(--page-margin);
  }
}

/* Some section content break out to full width of the page */
.section > .force-full-width {
  grid-column: 1 / -1;
}

.section--height-small {
  --section-min-height: var(--section-height-small);
}

.section--height-medium {
  --section-min-height: var(--section-height-medium);
}

.section--height-large {
  --section-min-height: var(--section-height-large);
}

.section--height-full-screen {
  --section-min-height: 100svh;
}

.section-content-wrapper.section-content-wrapper {
  min-height: calc(var(--section-min-height, 'auto') - var(--section-height-offset, 0px));
  position: relative;
  width: 100%;
  height: 100%;
}

/* Utility */

.hidden {
  /* stylelint-disable-next-line declaration-no-important */
  display: none !important;
}

@media screen and (max-width: 749px) {
  .hidden--mobile,
  .mobile\:hidden {
    /* stylelint-disable-next-line declaration-no-important */
    display: none !important;
  }
}

@media screen and (min-width: 750px) {
  .hidden--desktop,
  .desktop\:hidden {
    /* stylelint-disable-next-line declaration-no-important */
    display: none !important;
  }
}

.hide-when-empty:empty {
  /* stylelint-disable-next-line declaration-no-important */
  display: none !important;
}

.visually-hidden:not(:focus, :active) {
  /* stylelint-disable-next-line declaration-no-important */
  position: absolute !important;
  overflow: hidden;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  clip: rect(0 0 0 0);
  /* stylelint-disable-next-line declaration-no-important */
  word-wrap: normal !important;
}

@media screen and (max-width: 749px) {
  .is-visually-hidden-mobile:not(:focus, :active) {
    /* stylelint-disable-next-line declaration-no-important */
    position: absolute !important;
    overflow: hidden;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    border: 0;
    clip: rect(0 0 0 0);
    /* stylelint-disable-next-line declaration-no-important */
    word-wrap: normal !important;
  }
}

.contents {
  display: contents;
}

.flex {
  display: flex;
  gap: var(--gap-md);
}

.grid {
  --centered-column-number: 12;
  --full-width-column-number: 14;
  --centered: column-1 / span var(--centered-column-number);
  --full-width: column-0 / span var(--full-width-column-number);

  display: flex;
  flex-direction: column;
}

@media screen and (min-width: 750px) {
  .grid {
    display: grid;
    gap: 0;
    grid-template-columns: var(--margin-4xl) repeat(var(--centered-column-number), minmax(0, 1fr)) var(--margin-4xl);
    grid-template-areas: 'column-0 column-1 column-2 column-3 column-4 column-5 column-6 column-7 column-8 column-9 column-10 column-11 column-12 column-13';
  }
}

@media screen and (min-width: 1400px) {
  .grid {
    grid-template-columns:
      1fr repeat(
        var(--centered-column-number),
        minmax(0, calc((var(--page-width) - var(--page-margin) * 2) / var(--centered-column-number)))
      )
      1fr;
  }
}

.flex {
  display: flex;
  gap: var(--gap-md);
}

.flip-x {
  scale: -1 1;
}

.flip-y {
  scale: 1 -1;
}

.list-unstyled {
  margin: 0;
  padding: 0;
  list-style: none;
}

.skip-to-content-link {
  position: absolute;
  overflow: hidden;
  height: 1px;
  left: -99999px;
  /* stylelint-disable-next-line declaration-no-important */
  word-wrap: normal !important;
}

.skip-to-content-link:focus {
  z-index: var(--layer-temporary);
  overflow: auto;
  width: auto;
  height: auto;
  padding: var(--padding-lg) var(--padding-4xl);
  left: var(--margin-lg);
  top: var(--margin-lg);
  box-shadow: 0 0 0 var(--focus-outline-offset) var(--color-background);
}

.text-left {
  --text-align: left;

  text-align: left;
}

.text-center {
  --text-align: center;

  text-align: center;
}

.text-right {
  --text-align: right;

  text-align: right;
}

.text-inherit {
  color: inherit;
}

.user-select-text {
  user-select: text;
}

.justify-left {
  justify-content: left;
}

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

.justify-right {
  justify-content: right;
}

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

.background-image-container {
  overflow: hidden;
  position: absolute;
  inset: 0;
  opacity: var(--image-opacity);
}

.background-image-container img,
.background-image-container svg {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.background-image-fit img,
.background-image-fit svg {
  object-fit: contain;
}

.svg-wrapper {
  color: currentcolor;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
  pointer-events: none;
}

.svg-wrapper--smaller {
  width: var(--icon-size-2xs);
  height: var(--icon-size-2xs);
}

.svg-wrapper--small {
  width: var(--icon-size-xs);
  height: var(--icon-size-xs);
}

.svg-wrapper > svg {
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
}

.relative {
  position: relative;
}

/* Icons */
.icon-success,
.icon-error {
  width: var(--icon-size-md);
  height: var(--icon-size-md);
  flex-shrink: 0;
}

.icon-success {
  color: var(--color-success);
}

.icon-error {
  fill: var(--color-error);
}

placeholder-image {
  display: block;
  height: 100%;
  aspect-ratio: var(--ratio);
}

placeholder-image[data-type='product'] {
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-15));
  width: 100%;
}

/** Placeholder background for the placeholder image, the dimensions are the same as the product images */
placeholder-image[data-type='product']:not(:has(> img)) {
  aspect-ratio: var(--ratio);
  height: 350px;
}

placeholder-image > img {
  object-fit: cover;
  aspect-ratio: var(--ratio);
  height: 100%;
}

[data-placeholder='true'] * {
  cursor: default;
}

slideshow-component [data-placeholder='true'] * {
  cursor: grab;
}

/* Base text and heading styles */
body,
.paragraph:not(.button),
.paragraph > * {
  font-family: var(--font-paragraph--family);
  font-style: var(--font-paragraph--style);
  font-weight: var(--font-paragraph--weight);
  font-size: var(--font-paragraph--size);
  line-height: var(--font-paragraph--line-height);
  text-transform: var(--font-paragraph--case);
  -webkit-font-smoothing: antialiased;
  color: var(--color, var(--color-foreground));
}

/* Ensure inputs with type presets maintain minimum 16px on mobile to prevent iOS zoom */
@media screen and (max-width: 1200px) {
  input.paragraph.paragraph,
  input.paragraph.paragraph:not([type]),
  textarea.paragraph.paragraph,
  select.paragraph.paragraph {
    font-size: max(1rem, var(--font-paragraph--size));
  }
}

.paragraph > small {
  font-size: smaller;
}

/* Typography presets */

h1,
.h1.h1,
.text-block.h1 > * {
  font-family: var(--font-h1--family);
  font-style: var(--font-h1--style);
  font-weight: var(--font-h1--weight);
  font-size: var(--font-h1--size);
  line-height: var(--font-h1--line-height);
  letter-spacing: var(--font-h1--letter-spacing);
  text-transform: var(--font-h1--case);
  color: var(--color, var(--font-h1-color));
}

@media screen and (max-width: 1200px) {
  input.h1.h1,
  textarea.h1.h1,
  select.h1.h1 {
    font-size: max(1rem, var(--font-h1--size));
  }
}

h2,
.h2.h2,
.text-block.h2 > * {
  font-family: var(--font-h2--family);
  font-style: var(--font-h2--style);
  font-weight: var(--font-h2--weight);
  font-size: var(--font-h2--size);
  line-height: var(--font-h2--line-height);
  letter-spacing: var(--font-h2--letter-spacing);
  text-transform: var(--font-h2--case);
  color: var(--color, var(--font-h2-color));
}

@media screen and (max-width: 1200px) {
  input.h2.h2,
  textarea.h2.h2,
  select.h2.h2 {
    font-size: max(1rem, var(--font-h2--size));
  }
}

h3,
.h3,
.h3.h3,
.text-block.h3 > * {
  font-family: var(--font-h3--family);
  font-style: var(--font-h3--style);
  font-weight: var(--font-h3--weight);
  font-size: var(--font-h3--size);
  line-height: var(--font-h3--line-height);
  letter-spacing: var(--font-h3--letter-spacing);
  text-transform: var(--font-h3--case);
  color: var(--color, var(--font-h3-color));
}

@media screen and (max-width: 1200px) {
  input.h3,
  textarea.h3,
  select.h3 {
    font-size: max(1rem, var(--font-h3--size));
  }
}

h4,
.h4.h4,
.text-block.h4 > * {
  font-family: var(--font-h4--family);
  font-style: var(--font-h4--style);
  font-weight: var(--font-h4--weight);
  font-size: var(--font-h4--size);
  line-height: var(--font-h4--line-height);
  letter-spacing: var(--font-h4--letter-spacing);
  text-transform: var(--font-h4--case);
  color: var(--color, var(--font-h4-color));
}

@media screen and (max-width: 1200px) {
  input.h4.h4,
  textarea.h4.h4,
  select.h4.h4 {
    font-size: max(1rem, var(--font-h4--size));
  }
}

h5,
.h5.h5,
.text-block.h5 > * {
  font-family: var(--font-h5--family);
  font-style: var(--font-h5--style);
  font-weight: var(--font-h5--weight);
  font-size: var(--font-h5--size);
  line-height: var(--font-h5--line-height);
  letter-spacing: var(--font-h5--letter-spacing);
  text-transform: var(--font-h5--case);
  color: var(--color, var(--font-h5-color));
}

@media screen and (max-width: 1200px) {
  input.h5.h5,
  textarea.h5.h5,
  select.h5.h5 {
    font-size: max(1rem, var(--font-h5--size));
  }
}

h6,
.h6.h6,
.text-block.h6 > * {
  font-family: var(--font-h6--family);
  font-style: var(--font-h6--style);
  font-weight: var(--font-h6--weight);
  font-size: var(--font-h6--size);
  line-height: var(--font-h6--line-height);
  letter-spacing: var(--font-h6--letter-spacing);
  text-transform: var(--font-h6--case);
  color: var(--color, var(--font-h6-color));
}

@media screen and (max-width: 1200px) {
  input.h6.h6,
  textarea.h6.h6,
  select.h6.h6 {
    font-size: max(1rem, var(--font-h6--size));
  }
}

:first-child:is(.h1, .h2, .h3, .h4, .h5, .h6) {
  margin-block-start: 0;
}

:last-child:is(.h1, .h2, .h3, .h4, .h5, .h6) {
  margin-block-end: 0;
}

/* Links */
a {
  --button-color: var(--color, var(--color-primary));

  color: var(--button-color);
  text-decoration-color: transparent;
  text-decoration-thickness: 0.075em;
  text-underline-offset: 0.125em;
  transition: text-decoration-color var(--animation-speed) var(--animation-easing),
    color var(--animation-speed) var(--animation-easing);
}

:is(h1, h2, h3, h4, h5, h6, p) > a:hover {
  --button-color: var(--color, var(--color-primary-hover));
}

/* Add underline to text using our paragraph styles only. */
p:not(.h1, .h2, .h3, .h4, .h5, .h6) a:where(:not(.button, .button-primary, .button-secondary)),
.rte
  :is(p, ul, ol, table):not(.h1, .h2, .h3, .h4, .h5, .h6)
  a:where(:not(.button, .button-primary, .button-secondary)) {
  text-decoration-color: currentcolor;

  &:hover {
    text-decoration-color: transparent;
    color: var(--color-primary-hover);
  }
}

.container-background-image {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}

details[open] .summary-closed {
  display: none;
}

details:not([open]) .summary-open {
  display: none;
}

details[open] > summary .icon-animated > svg {
  transform: rotate(180deg);
}

/* iOS fix: hide the default arrow on the summary */
summary::-webkit-details-marker {
  display: none;
}

/* When header is transparent, pull the first main content section up to sit under the floating header */
body:has(.header[transparent]) .content-for-layout > .shopify-section:first-child {
  margin-top: calc(var(--header-group-height) * -1);
}

body:has(.header[transparent]) #header-group > *:not(.header-section) {
  z-index: 1;
}

body:has(.header[transparent]) #header-group > .header-section {
  z-index: var(--layer-sticky);
}

/* Featured collection block */
.featured-collection-block {
  width: 100%;
}

/* Product grid */
.product-grid-container {
  display: block;
  width: 100%;
  padding-block: var(--padding-block-start) var(--padding-block-end);

  @media screen and (min-width: 750px) {
    display: grid;
  }
}

.product-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--product-grid-gap);
  margin: auto;
  padding: 0;
  list-style: none;
}

@media screen and (min-width: 750px) {
  .product-grid {
    grid-template-columns: var(--product-grid-columns-desktop);
  }
}

.product-grid :is(h3, p) {
  margin: 0;
}

.product-grid__item {
  border: var(--product-card-border-width) solid rgb(var(--color-border-rgb) / var(--product-card-border-opacity));
}

.product-grid--organic[product-grid-view='default'] .product-grid__item {
  height: fit-content;
}

.product-grid__card.product-grid__card {
  display: flex;
  flex-flow: column nowrap;
  gap: var(--product-card-gap);
  align-items: var(--product-card-alignment);
  text-decoration: none;
  color: var(--color, var(--color-foreground));
  padding-block: var(--padding-block-start) var(--padding-block-end);
  padding-inline: var(--padding-inline-start) var(--padding-inline-end);
  overflow: hidden;
}

[product-grid-view='zoom-out'] .product-grid__card {
  row-gap: var(--padding-xs);
}

[product-grid-view='default'] {
  --product-grid-gap: 16px;
  --padding-block-start: 24px;
  --padding-block-end: 24px;
  --padding-inline-start: 0px;
  --padding-inline-end: 0px;
}

[product-grid-view='default'] .product-grid__item {
  padding-block: 0;
}

[product-grid-view='mobile-single'],
.product-grid-mobile--large {
  @media screen and (max-width: 749px) {
    grid-template-columns: 1fr;
  }
}

.product-grid__card .group-block > * {
  @media screen and (max-width: 749px) {
    flex-direction: column;
  }
}

ul[product-grid-view='zoom-out'] .product-grid__card > * {
  display: none;
}

ul[product-grid-view='zoom-out'] .product-grid__card .card-gallery {
  display: block;
}

[product-grid-view='zoom-out']
  .card-gallery
  > :is(quick-add-component, .product-badges, slideshow-component > slideshow-controls) {
  display: none;
}

ul[product-grid-view='zoom-out'] .card-gallery > img {
  display: block;
}

[product-grid-view='zoom-out'] {
  --product-grid-columns-desktop: repeat(
    10,
    minmax(clamp(50px, calc(100% - 9 * var(--product-grid-gap)) / 10, 80px), 1fr)
  );
}

.product-grid-view-zoom-out--details {
  display: none;
}

.product-grid-view-zoom-out--details .h4,
.product-grid-view-zoom-out--details span,
.product-grid-view-zoom-out--details s {
  font-size: var(--font-size--xs);
  font-family: var(--font-paragraph--family);
}

.product-grid-view-zoom-out--details span {
  font-weight: 500;
}

.product-grid-view-zoom-out--details .h4 {
  line-height: 1.3;
  font-weight: 400;
}

.product-grid-view-zoom-out--details > span.h6,
.product-grid-view-zoom-out--details > div.h6 > product-price {
  display: inline-block;
  line-height: 0;
  margin-top: var(--margin-2xs);
}

.product-grid-view-zoom-out--details > span.h6 > *,
.product-grid-view-zoom-out--details > div.h6 > * > * {
  line-height: 1.2;
}

@media (prefers-reduced-motion: no-preference) {
  :root:active-view-transition-type(product-grid) {
    details[open] floating-panel-component {
      view-transition-name: panel-content;

      .checkbox *,
      .facets__pill-label {
        transition: none;
      }

      .facets--vertical & {
        view-transition-name: none;
      }
    }

    .product-grid {
      view-transition-name: product-grid;
    }

    footer {
      view-transition-name: footer;
    }

    .product-grid__item,
    floating-panel-component {
      transition: none;
    }
  }
}

::view-transition-group(panel-content) {
  z-index: 1;
}

::view-transition-new(product-grid) {
  animation-delay: 150ms;
  animation-name: fadeInUp;
  animation-duration: var(--animation-speed);
  animation-timing-function: var(--animation-easing);
}

results-list[initialized] {
  .product-grid__item {
    transition: opacity var(--animation-speed) var(--animation-easing),
      transform var(--animation-speed) var(--animation-easing);

    @starting-style {
      opacity: 0;
      transform: translateY(10px);
    }
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Collection and product list cards have equal heights */
:is(.product-grid__item, .resource-list__item) .product-card {
  display: grid;
  height: 100%;
}

/* Video background */
.video-background,
.video-background * {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.video-background--cover * {
  object-fit: cover;
}

.video-background--contain * {
  object-fit: contain;
}

.text-block {
  width: 100%;
}

.text-block > *:first-child,
.text-block > *:first-child:empty + * {
  margin-block-start: 0;
}

.text-block > *:last-child,
.text-block > *:has(+ *:last-child:empty) {
  margin-block-end: 0;
}

/* This is to deal with the margin applied to the p when custom styles are enabled. The p isn't the first child anymore due to the style tag */
.text-block > style + * {
  margin-block-start: 0;
}

/* Dialog */
.dialog-modal {
  border: none;
  box-shadow: var(--shadow-popover);

  @media screen and (min-width: 750px) {
    border-radius: var(--style-border-radius-popover);
    max-width: var(--normal-content-width);
  }

  @media screen and (max-width: 749px) {
    max-width: 100%;
    max-height: 100%;
    height: 100dvh;
    width: 100dvw;
    padding: var(--padding-md);
  }
}

.dialog-modal::backdrop {
  transition: backdrop-filter var(--animation-speed) var(--animation-easing);
  backdrop-filter: brightness(1);
  background: rgb(var(--backdrop-color-rgb) / var(--backdrop-opacity));
}

.dialog-modal[open] {
  animation: elementSlideInTop var(--animation-speed) var(--animation-easing) forwards;

  &::backdrop {
    animation: backdropFilter var(--animation-speed) var(--animation-easing) forwards;
    transition: opacity var(--animation-speed) var(--animation-easing);
  }
}

.dialog-modal.dialog-closing {
  animation: elementSlideOutTop var(--animation-speed) var(--animation-easing) forwards;

  &::backdrop {
    opacity: 0;
  }
}

/* stylelint-disable value-keyword-case */
.dialog-drawer {
  --dialog-drawer-opening-animation: slideInLeft;
  --dialog-drawer-closing-animation: slideOutLeft;
}

.dialog-drawer--right {
  --dialog-drawer-opening-animation: slideInRight;
  --dialog-drawer-closing-animation: slideOutRight;
}
/* stylelint-enable value-keyword-case */

.dialog-drawer[open] {
  animation: var(--dialog-drawer-opening-animation) var(--animation-speed) var(--animation-easing) forwards;
}

.dialog-drawer.dialog-closing {
  animation: var(--dialog-drawer-closing-animation) var(--animation-speed) var(--animation-easing);
}

/* Buttons */
.button,
.button-secondary,
button.shopify-payment-button__button--unbranded {
  --text-align: center;

  display: grid;
  align-content: center;
  text-decoration: none;
  text-align: var(--text-align);
  color: var(--button-color);
  appearance: none;
  background-color: var(--button-background-color);
  border: none;
  font-family: var(--font-paragraph--family);
  font-style: var(--font-paragraph--style);
  font-size: var(--font-paragraph--size);
  line-height: var(--font-paragraph--line-height);
  margin-block: 0;
  transition: color var(--animation-speed) var(--animation-easing),
    box-shadow var(--animation-speed) var(--animation-easing),
    background-color var(--animation-speed) var(--animation-easing);
  cursor: pointer;
  width: fit-content;
  box-shadow: inset 0 0 0 var(--button-border-width) var(--button-border-color);
  padding-block: var(--button-padding-block);
  padding-inline: var(--button-padding-inline);
}

.button {
  font-family: var(--button-font-family-primary);
  text-transform: var(--button-text-case-primary);
  border-radius: var(--style-border-radius-buttons-primary);
}

.button:not(.button-secondary, .button-unstyled) {
  outline-color: var(--button-background-color);
}

.button-secondary {
  font-family: var(--button-font-family-secondary);
  text-transform: var(--button-text-case-secondary);
  border-radius: var(--style-border-radius-buttons-secondary);
}

button.shopify-payment-button__button--unbranded {
  font-family: var(--button-font-family-primary);
  text-transform: var(--button-text-case-primary);
}

textarea,
input {
  background-color: var(--color-input-background);
  border-color: var(--color-input-border);
}

textarea::placeholder,
input::placeholder {
  color: var(--color-input-text);
}

textarea:not(:placeholder-shown)::placeholder,
input:not(:placeholder-shown)::placeholder {
  opacity: 0;
}

/* The declaration above is messing with buttons that have an attribute of hidden as it overwrites the display value */
.button[hidden] {
  display: none;
}

.button[aria-disabled='true'],
.button-secondary[aria-disabled='true'],
.button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.button,
button.shopify-payment-button__button--unbranded {
  --button-color: var(--color-primary-button-text);
  --button-background-color: var(--color-primary-button-background);
  --button-border-color: var(--color-primary-button-border);
  --button-border-width: var(--style-border-width-primary);
}

.button:hover,
button.shopify-payment-button__button--unbranded:hover:not([disabled]) {
  --button-color: var(--color-primary-button-hover-text);
  --button-background-color: var(--color-primary-button-hover-background);
  --button-border-color: var(--color-primary-button-hover-border);
}

.button-secondary {
  --button-color: var(--color-secondary-button-text);
  --button-background-color: var(--color-secondary-button-background);
  --button-border-color: var(--color-secondary-button-border);
  --button-border-width: var(--style-border-width-secondary);
}

.button-secondary:hover {
  --button-color: var(--color-secondary-button-hover-text);
  --button-background-color: var(--color-secondary-button-hover-background);
  --button-border-color: var(--color-secondary-button-hover-border);
}

/* Needed to override the default Shopify styles */
button.shopify-payment-button__button--unbranded:hover:not([disabled]) {
  background-color: var(--button-background-color);
}

.button-unstyled {
  display: block;
  padding: 0;
  background-color: inherit;
  color: inherit;
  border: 0;
  border-radius: 0;
  overflow: hidden;
  box-shadow: none;
  font-family: var(--font-paragraph--family);
  font-style: var(--font-paragraph--style);
  font-size: var(--font-paragraph--size);
}

.button-unstyled:hover {
  background-color: inherit;
}

.button-unstyled--with-icon {
  color: var(--color-foreground);
  display: flex;
  gap: var(--gap-2xs);
  align-items: center;
}

.button-unstyled--transparent {
  background-color: transparent;
  box-shadow: none;
}

/* Show more */

.show-more__button {
  color: var(--color-primary);
  cursor: pointer;
}

.show-more__button:hover {
  @media screen and (min-width: 750px) {
    color: var(--color-primary-hover);
  }
}

.show-more__label {
  text-align: start;
  font-size: var(--font-size--body-md);
  font-family: var(--font-paragraph--family);
}

.show-more__button .svg-wrapper {
  width: var(--icon-size-xs);
  height: var(--icon-size-xs);
}

.show-more[data-expanded='true'] .show-more__label--more,
.show-more[data-expanded='false'] .show-more__label--less {
  display: none;
}

.link {
  display: inline-block;
  text-align: center;
}

shopify-accelerated-checkout,
shopify-accelerated-checkout-cart {
  --shopify-accelerated-checkout-button-border-radius: var(--style-border-radius-buttons-primary);
  --shopify-accelerated-checkout-button-block-size: var(--height-buy-buttons);
}

.product-form-buttons:has(.add-to-cart-button.button-secondary)
  :is(shopify-accelerated-checkout, shopify-accelerated-checkout-cart) {
  --shopify-accelerated-checkout-button-border-radius: var(--style-border-radius-buttons-secondary);
  --shopify-accelerated-checkout-button-block-size: var(--height-buy-buttons);
}

/* Collapsible row */

.icon-caret svg {
  transition: transform var(--animation-speed) var(--animation-easing);
}

.icon-caret--forward svg {
  transform: rotate(-90deg);
}

.icon-caret--backward svg {
  transform: rotate(90deg);
}

summary {
  display: flex;
  align-items: center;
  cursor: pointer;
  list-style: none;
  padding-block: var(--padding-sm);
}

summary:hover {
  color: var(--color-primary-hover);
}

summary .svg-wrapper {
  margin-inline-start: auto;
  height: var(--icon-size-xs);
  width: var(--icon-size-xs);
  transition: transform var(--animation-speed) var(--animation-easing);
}

/* Shared plus/minus icon animations */
summary .icon-plus :is(.horizontal, .vertical),
.show-more__button .icon-plus :is(.horizontal, .vertical) {
  transition: transform var(--animation-speed) var(--animation-easing);
  transform: rotate(0deg);
  transform-origin: 50% 50%;
  opacity: 1;
}

details[open] > summary .icon-plus .horizontal,
.details-open > summary .icon-plus .horizontal,
.show-more:where([data-expanded='true']) .show-more__button .icon-plus .horizontal {
  transform: rotate(90deg);
}

details[open] > summary .icon-plus .vertical,
.details-open > summary .icon-plus .vertical,
.show-more:where([data-expanded='true']) .show-more__button .icon-plus .vertical {
  transform: rotate(90deg);
  opacity: 0;
}

/* Product Media */
media-gallery {
  display: block;
  width: 100%;
}

:where(media-gallery, .product-grid__item) {
  .media-gallery__grid {
    grid-template-columns: 1fr;
    gap: var(--image-gap);
  }
}

.product-media-gallery__slideshow--single-media slideshow-container {
  @media screen and (max-width: 749px) {
    grid-area: unset;
  }
}

:not(.dialog-zoomed-gallery) > .product-media-container {
  /* width and overflow forces children to shrink to parent width */
  --slide-width: round(up, 100%, 1px);

  display: flex;
  aspect-ratio: var(--gallery-aspect-ratio, var(--media-preview-ratio));
  max-height: var(--constrained-height);
  width: 100%;

  /* Relative position needed for video and 3d models */
  position: relative;
  overflow: hidden;

  &:where(.constrain-height) {
    /* arbitrary offset value based on average theme spacing and header height */
    --viewport-offset: 400px;
    --constrained-min-height: 300px;
    --constrained-height: max(var(--constrained-min-height), calc(100vh - var(--viewport-offset)));

    margin-right: auto;
    margin-left: auto;
  }
}

media-gallery:where(.media-gallery--grid) .media-gallery__grid {
  display: none;
}

media-gallery.media-gallery--grid .media-gallery__grid .product-media-container {
  /* Needed for safari to stretch to full grid height */
  height: 100%;
}

.product-media :is(deferred-media, product-model) {
  position: absolute;
}

@media screen and (max-width: 749px) {
  .product-media-container.constrain-height {
    max-height: none;
  }
}

@media screen and (min-width: 750px) {
  .product-media-container.constrain-height {
    --viewport-offset: var(--header-height, 100px);
    --constrained-min-height: 500px;
  }

  .media-gallery--two-column .media-gallery__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .media-gallery--large-first-image .product-media-container:first-child,
  .media-gallery--two-column .product-media-container:only-child {
    /* First child spans 2 columns */
    grid-column: span 2;
  }

  /* Display grid view as a carousel on mobile, grid on desktop */
  media-gallery:is(.media-gallery--grid) slideshow-component {
    display: none;
  }

  media-gallery:where(.media-gallery--grid) .media-gallery__grid {
    display: grid;
  }
}

.product-media-container--model {
  /* Usefull when view in your space is shown */
  flex-direction: column;
}

.shopify-model-viewer-ui__controls-area {
  bottom: calc(var(--minimum-touch-target) + var(--padding-sm));
}

.product-media-container img {
  aspect-ratio: inherit;
  object-fit: contain;
}

.product-media-container.media-fit-contain img {
  object-position: center center;
}

.product-media-container.media-fit {
  --product-media-fit: cover;

  img {
    object-fit: var(--product-media-fit);
  }
}

/* Media gallery zoom dialog */
.product-media-container__zoom-button {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: var(--layer-flat);
  cursor: zoom-in;
  background-color: transparent;

  &:hover {
    background-color: transparent;
  }
}

zoom-dialog dialog {
  width: 100vw;
  height: 100vh;
  border: none;
  margin: 0;
  padding: 0;
  max-width: 100%;
  max-height: 100%;
  background: #fff;
  opacity: 0;
  transition: opacity var(--animation-speed) var(--animation-easing);
  scrollbar-width: none;

  &[open] {
    opacity: 1;
  }

  @media (prefers-reduced-motion: no-preference) {
    scroll-behavior: smooth;
  }

  &::backdrop {
    background: transparent;
  }
}

/* Animate the UI elements in only after the view transition is complete */
.close-button {
  position: fixed;
  top: var(--margin-lg);
  right: var(--margin-lg);
  width: var(--minimum-touch-target);
  height: var(--minimum-touch-target);
  z-index: var(--layer-flat);
  background-color: transparent;
  display: flex;
  align-items: center;
  justify-content: center;

  /* For the outline radius */
  border-radius: 50%;
}

/* This triggers iOS < 16.4. The outline bug is not recognized as a lack of @supports */

@supports not (background-color: rgb(from red 150 g b / alpha)) {
  /**
    There is a bug in safari < 16.4 that causes the outline to not follow the elements border radius. This is a workaround.
    Using element selector to increase specificity.
  **/

  .close-button:focus-visible {
    outline: none;
    overflow: visible;
  }

  .close-button:focus-visible::after {
    content: '';
    position: absolute;
    inset: calc(-1 * var(--focus-outline-offset));
    border: var(--focus-outline-width) solid currentColor;
    border-radius: 50%;
    display: inherit;
  }
}

.dialog--closed .close-button {
  animation: elementSlideOutBottom calc(var(--animation-speed) * 0.5) var(--animation-easing) forwards;
}

.dialog-thumbnails-list-container {
  position: fixed;
  width: 100%;
  bottom: 0;
  display: flex;
  z-index: var(--layer-raised);
}

.dialog-thumbnails-list {
  position: relative;
  display: inline-flex;
  flex-direction: row;
  gap: 8px;
  bottom: 0;
  overflow-x: auto;
  opacity: 0;
  padding: var(--padding-lg);
  margin-inline: auto;
  scrollbar-width: none;
  animation: thumbnailsSlideInBottom calc(var(--animation-speed) * 0.75) var(--animation-easing) forwards;
  animation-delay: calc(var(--animation-speed) * 1.5);
}

.dialog--closed .dialog-thumbnails-list {
  animation: thumbnailsSlideOutBottom var(--animation-speed) var(--animation-easing) forwards;
}

@media screen and (min-width: 750px) {
  .dialog-thumbnails-list {
    position: fixed;
    flex-direction: column;
    inset: 50% var(--margin-lg) auto auto;
    right: 0;
    max-height: calc(100vh - 200px);
    overflow-y: auto;
    animation: thumbnailsSlideInTop calc(var(--animation-speed) * 0.5) var(--animation-easing) forwards;
    animation-delay: calc(var(--animation-speed) * 2);
  }

  .dialog--closed .dialog-thumbnails-list {
    animation: thumbnailsSlideOutTop var(--animation-speed) var(--animation-easing) forwards;
  }
}

.dialog-thumbnails-list__thumbnail {
  width: var(--thumbnail-width);
  height: auto;
  transition: transform var(--animation-speed) var(--animation-easing);
  flex-shrink: 0;
  border-radius: var(--media-radius);

  img {
    height: 100%;
    object-fit: cover;
    border-radius: var(--media-radius);
    aspect-ratio: var(--aspect-ratio);
  }

  &:is([aria-selected='true']) {
    outline: var(--focus-outline-width) solid currentcolor;
    outline-offset: calc(var(--focus-outline-offset) / 2);
    border: var(--style-border-width) solid rgb(var(--color-border-rgb) / var(--media-border-opacity));
  }
}

.close-button:hover {
  background-color: transparent;
  opacity: 0.8;
}

.close-button svg {
  width: var(--icon-size-xs);
  height: var(--icon-size-xs);
}

/* Product media */
.product-media {
  display: flex;
  flex: 1;
}

/* If the product media is already providing an image cover, hide images provided by sibling deferred-media */
.product-media__image ~ * .deferred-media__poster-image {
  display: none;
}

/* If the product media is playing, hide the preview image */
.product-media-container:has(.deferred-media__playing) .product-media__image {
  opacity: 0;
  transition: opacity var(--animation-speed) var(--animation-easing);
}

/* Deferred media & Product model  */
:is(product-model, deferred-media) {
  /* Height needed to make sure when it's set to be stretched, it takes the full height */
  height: 100%;
  width: 100%;
  position: relative;
}

product-model model-viewer,
/* Media that have a poster button sibling providing the size should be absolute-positioned.
Otherwise, it should be a block to rely on its own size */
:is(deferred-media, product-model) > .deferred-media__poster-button ~ *:not(template) {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;

  /* Required to make sure the absolute position respects the padding of the wrapper: */
  padding: inherit;
}

slideshow-slide .shopify-model-viewer-ui__controls-area.shopify-model-viewer-ui__controls-area {
  bottom: var(--padding-sm);
  right: var(--padding-sm);
}

.dialog-zoomed-gallery .shopify-model-viewer-ui__controls-area.shopify-model-viewer-ui__controls-area {
  /* Move the controls above the thumbnails. Need to calculate the height of the thumbnails list */
  bottom: calc(var(--thumbnail-width) / calc(var(--media-preview-ratio)) + var(--padding-lg) * 2);
  right: var(--padding-lg);
}

@media screen and (max-width: 749px) {
  slideshow-component:has(:not(.mobile\:hidden) :is(.slideshow-controls__dots, .slideshow-controls__counter))
    .shopify-model-viewer-ui__controls-area {
    /* Position the controls just above the counter */
    bottom: calc(var(--minimum-touch-target) + var(--padding-sm));
  }
}

@media screen and (min-width: 750px) {
  slideshow-component:has(:not(.desktop\:hidden) :is(.slideshow-controls__dots, .slideshow-controls__counter))
    .shopify-model-viewer-ui__controls-area {
    /* Position the controls just above the counter */
    bottom: calc(var(--minimum-touch-target) + var(--padding-sm));
  }

  .dialog-zoomed-gallery .shopify-model-viewer-ui__controls-area.shopify-model-viewer-ui__controls-area {
    /* Move the controls up to match the padding on the thumbnails */
    bottom: var(--padding-lg);

    /* Move the controls to the left of the thumbnails list on the right */
    right: calc(var(--thumbnail-width) + var(--padding-lg) * 2);
  }
}

:is(deferred-media, .video-placeholder-wrapper).border-style {
  /* Apply the border radius to the video */
  overflow: hidden;
}

deferred-media {
  /* The overflow hidden in the deferred-media won't let the button show the focus ring */
  &:has(:focus-visible) {
    outline: var(--focus-outline-width) solid currentcolor;
    outline-offset: var(--focus-outline-offset);
  }

  @supports not selector(:focus-visible) {
    &:has(:focus) {
      outline: var(--focus-outline-width) solid currentcolor;
      outline-offset: var(--focus-outline-offset);
    }
  }
}

.deferred-media__poster-button {
  width: 100%;
  height: 100%;
  aspect-ratio: var(--video-aspect-ratio, auto);
}

.deferred-media__poster-button.deferred-media__playing {
  opacity: 0;
  transition: opacity 0.3s ease;
}

deferred-media img {
  height: 100%;
  object-fit: cover;
  transition: opacity 0.3s ease;
}

deferred-media iframe {
  width: 100%;
  height: 100%;
  border: none;
  aspect-ratio: var(--size-style-aspect-ratio, auto);
}

deferred-media[data-media-loaded] img {
  opacity: 0;
}

.deferred-media__poster-icon,
.video-placeholder-wrapper__poster-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.deferred-media__poster-icon svg,
.video-placeholder-wrapper__poster-icon svg {
  width: var(--button-size);
  height: var(--button-size);
  color: var(--color-white);
  filter: drop-shadow(var(--shadow-button));

  &:hover {
    color: rgb(var(--color-white-rgb) / var(--opacity-80));
  }

  @media screen and (min-width: 750px) {
    width: 4rem;
    height: 4rem;
  }
}

deferred-media[class] :is(.deferred-media__poster-button img, .deferred-media__poster-button ~ video) {
  /* only apply this on the video block not product media */
  object-fit: cover;
  height: 100%;
  aspect-ratio: var(--size-style-aspect-ratio, auto);
}

.button-shopify-xr {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: var(--padding-md);
}

.button-shopify-xr > svg {
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
  fill: currentcolor;
  margin-inline-end: var(--margin-md);
}

.button-shopify-xr[data-shopify-xr-hidden] {
  display: none;
}

/* Swatches */
.swatch {
  --color-border: rgb(var(--color-foreground-rgb) / var(--style-border-swatch-opacity));
  --min-width-unitless: 15.9999; /* want to avoid division by 0 */
  --min-height-unitless: 15.9999; /* want to avoid division by 0 */
  --min-height: 16px;
  --min-width: 16px;

  /* mobile values */
  --scaling-factor: 0.5;
  --max-swatch-size: 28px;
  --max-pill-size: 20px;
  --max-filter-size: 32px;

  /* From the settings */
  --offset-swatch-width: calc(var(--variant-picker-swatch-width-unitless) - var(--min-width-unitless));
  --offset-swatch-height: calc(var(--variant-picker-swatch-height-unitless) - var(--min-height-unitless));

  /**
    Offset values are obtained from the following formulas:
      offset-width = width - min-width
      offset-height = height - min-height

    The offset-scaled-width and heigth are obtained by extending the line from
    [min,min] to [W,H] and taking the intersection with a square that starts at
    [min,min] and ends at [max,max].

    The extending line forms right angle triangles with the [min,min]->[max,max]
    box that enable us to derive the following formulas

    We also want the result to always be smaller than the input (pdp > everywhere else)
    by some scaling factor.
  */
  --offset-scaled-width: calc(
    var(--scaling-factor) * var(--offset-swatch-width) / var(--offset-swatch-height) * var(--offset-max-swatch-size)
  );
  --offset-scaled-height: calc(
    var(--scaling-factor) * var(--offset-swatch-height) / var(--offset-swatch-width) * var(--offset-max-swatch-size)
  );
  --offset-max-swatch-size: calc(var(--max-swatch-size) - var(--min-width));

  /* width = min(m + sU, (m + s * W'/H' * M'), M) */
  --swatch-width: min(
    calc(var(--min-width) + calc(var(--scaling-factor) * var(--offset-swatch-width) * 1px)),
    calc(var(--min-width) + var(--offset-scaled-width)),
    var(--max-swatch-size)
  );

  /* height = min(m + sV, (m + s * H'/W' * M'), M) */
  --swatch-height: min(
    calc(var(--min-height) + calc(var(--scaling-factor) * var(--offset-swatch-height) * 1px)),
    calc(var(--min-height) + var(--offset-scaled-height)),
    var(--max-swatch-size)
  );

  display: block;
  background: var(--swatch-background);
  background-position: var(--swatch-focal-point, center);
  border-radius: var(--variant-picker-swatch-radius);
  border: var(--style-border-swatch-width) var(--style-border-swatch-style) var(--color-border);
  width: var(--swatch-width);
  height: var(--swatch-height);

  /* This is different than background-size: cover because we use box-sizing: border-box,
   * doing it like makes the background clip under the border without repeating.
   */
  background-size: var(--swatch-width) var(--swatch-height);

  &.swatch--unavailable {
    border-style: dashed;
  }

  &.swatch--unscaled {
    /* for when you want fixed sizing (e.g. pdp) */
    --swatch-width: var(--variant-picker-swatch-width);
    --swatch-height: var(--variant-picker-swatch-height);
  }

  &.swatch--filter {
    --swatch-width: var(--max-filter-size);
    --swatch-height: var(--max-filter-size);

    border-radius: var(--variant-picker-swatch-radius);
  }

  &.swatch--pill {
    --swatch-width: var(--max-pill-size);
    --swatch-height: var(--max-pill-size);

    border-radius: var(--variant-picker-swatch-radius);
  }

  /* swatches in filters and pills always have a border  */
  &.swatch--filter,
  &.swatch--pill {
    --style-border-swatch-width: var(--variant-picker-border-width);
    --style-border-swatch-style: var(--variant-picker-border-style);
    --color-border: rgb(var(--color-foreground-rgb) / var(--variant-picker-border-opacity));
  }

  @media screen and (min-width: 750px) {
    /* desktop values */
    --max-swatch-size: 32px;
    --max-pill-size: 16px;
    --max-filter-size: 28px;
    --scaling-factor: 0.65;
  }
}

.variant-picker .variant-option--buttons label:has(.swatch) {
  border-radius: var(--variant-picker-swatch-radius);
}

.sticky-content {
  position: sticky;
  top: var(--sticky-header-offset, 0);
  z-index: var(--layer-flat);
}

@media screen and (min-width: 750px) {
  .sticky-content--desktop,
  .sticky-content--desktop.full-height--desktop > .group-block {
    position: sticky;
    top: var(--sticky-header-offset, 0);
    z-index: var(--layer-flat);
  }
}

.price,
.compare-at-price,
.unit-price {
  white-space: nowrap;
}

.unit-price {
  display: block;
  font-size: min(0.85em, var(--font-paragraph--size));
  color: rgb(var(--color-foreground-rgb) / var(--opacity-subdued-text));
}

.tax-note.tax-note.tax-note {
  font-size: min(0.85em, var(--font-paragraph--size));
  color: rgb(var(--color-foreground-rgb) / var(--opacity-subdued-text));
}

product-price.text-block:is(.h1, .h2, .h3, .h4, .h5, .h6) > *:not(.tax-note) {
  margin-block: 0;
}

.compare-at-price {
  opacity: 0.4;
  text-decoration-line: line-through;
  text-decoration-thickness: 1.5px;
}

.card-gallery {
  position: relative;
}

@media screen and (min-width: 750px) {
  product-card:focus-within .quick-add__button,
  .card-gallery:hover .quick-add__button {
    display: grid;
    will-change: margin, opacity;
    animation: elementSlideInTop var(--animation-speed) var(--animation-easing);
  }
}

@container (max-width: 70px) {
  .card-gallery:hover .quick-add__button {
    display: none;
  }
}

/* Drawer */
.drawer {
  background-color: var(--color-background);
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: var(--sidebar-width);
  z-index: var(--layer-raised);
  transform: translateX(-120%);
  transition: transform var(--animation-speed) var(--animation-easing);
}

.drawer[data-open='true'] {
  transform: translateX(0);
}

.drawer-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}

.drawer__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--drawer-header-block-padding) var(--drawer-inline-padding);
}

.drawer__title {
  font-size: var(--font-h2--size);
  margin: 0;
}

.drawer__close {
  width: var(--minimum-touch-target);
  height: var(--minimum-touch-target);
}

.drawer__content {
  display: block;
  padding: var(--drawer-content-block-padding) var(--drawer-inline-padding);
  width: 100%;
}

/* Background overlay */
.background-overlay {
  position: relative;

  &::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--background-overlay-color, rgb(0 0 0 / 15%));
  }
}

/* Spacing style */
.spacing-style {
  --spacing-scale: var(--spacing-scale-md);

  @media screen and (min-width: 990px) {
    --spacing-scale: var(--spacing-scale-default);
  }

  /* Must disable this, when you use these with calc and another unit type, things break — see logo.liquid */
  /* stylelint-disable length-zero-no-unit */
  --padding-block: 0px;
  --padding-block-start: var(--padding-block, 0px);
  --padding-block-end: var(--padding-block, 0px);
  --padding-inline: 0px;
  --padding-inline-start: var(--padding-inline, 0px);
  --padding-inline-end: var(--padding-inline, 0px);
  --margin-block: 0px;
  --margin-block-start: var(--margin-block, 0px);
  --margin-block-end: var(--margin-block, 0px);
  --margin-inline: 0px;
  --margin-inline-start: var(--margin-inline, 0px);
  --margin-inline-end: var(--margin-inline, 0px);
}

.spacing-style,
.inherit-spacing {
  padding-block: calc(var(--padding-block-start) + var(--section-top-offset, 0px)) var(--padding-block-end);
  padding-inline: var(--padding-inline-start) var(--padding-inline-end);
  margin-block: var(--margin-block-start) var(--margin-block-end);
  margin-inline: var(--margin-inline-start) var(--margin-inline-end);
}

/* Size style */
.size-style {
  width: var(--size-style-width-mobile, var(--size-style-width));
  height: var(--size-style-height-mobile, var(--size-style-height));

  @media screen and (min-width: 750px) {
    width: var(--size-style-width);
    height: var(--size-style-height);
  }
}

/* Custom Typography style */
.custom-typography,
.custom-typography > * {
  font-family: var(--font-family);
  font-weight: var(--font-weight);
  text-transform: var(--text-transform);
  text-wrap: var(--text-wrap);
  line-height: var(--line-height);
  letter-spacing: var(--letter-spacing);
}

.custom-typography {
  h1 {
    line-height: var(--line-height--display, var(--line-height));
  }

  h2,
  h3,
  h4 {
    line-height: var(--line-height--heading, var(--line-height));
  }

  p {
    line-height: var(--line-height--body, var(--line-height));
  }
}

.custom-font-size,
.custom-font-size > * {
  font-size: var(--font-size);
}

.custom-font-weight,
.custom-font-weight > * {
  font-weight: var(--weight);
}

/* Border override style */
.border-style {
  border-width: var(--border-width);
  border-style: var(--border-style);
  border-color: var(--border-color);
  border-radius: var(--border-radius);
}

/* Gap scaling style */
.gap-style,
.layout-panel-flex {
  --gap-scale: var(--spacing-scale-md);

  @media screen and (min-width: 990px) {
    --gap-scale: var(--spacing-scale-default);
  }
}

.layout-panel-flex {
  display: flex;
  gap: var(--gap);
  height: 100%;
}

.layout-panel-flex--row {
  flex-flow: row var(--flex-wrap);
  justify-content: var(--horizontal-alignment);
  align-items: var(--vertical-alignment);
}

.layout-panel-flex--column {
  flex-flow: column var(--flex-wrap);
  align-items: var(--horizontal-alignment);
  justify-content: var(--vertical-alignment);
}

@media screen and (max-width: 749px) {
  .mobile-column {
    flex-flow: column nowrap;
    align-items: var(--horizontal-alignment);
    justify-content: var(--vertical-alignment-mobile);
  }

  .layout-panel-flex--row:not(.mobile-column) {
    flex-wrap: var(--flex-wrap-mobile);

    > .text-block {
      flex: 1 1 var(--max-width--display-tight);
    }

    > .image-block {
      flex: 1 1 var(--size-style-width-mobile-min);
    }

    > .button {
      flex: 0 0 fit-content;
    }
  }
}

@media (min-width: 750px) {
  .layout-panel-flex {
    flex-direction: var(--flex-direction);
  }
}

/* Form fields */
.field {
  position: relative;
  width: 100%;
  display: flex;
  transition: box-shadow var(--animation-speed) ease;
}

.field__input {
  flex-grow: 1;
  text-align: left;
  border-radius: var(--style-border-radius-inputs);
  transition: box-shadow var(--animation-speed) ease, background-color var(--animation-speed) ease;
  padding: var(--input-padding);
  box-shadow: var(--input-box-shadow);
  background-color: var(--color-input-background);
  color: var(--color-input-text);
  border: none;
  outline: none;
  font-size: var(--font-paragraph--size);

  &:autofill {
    background-color: var(--color-input-background);
    color: var(--color-input-text);
  }
}

.field__input:is(:focus, :hover) {
  box-shadow: var(--input-box-shadow-focus);
  background-color: var(--color-input-hover-background);
}

.field__input--button-radius {
  border-radius: var(--style-border-radius-buttons-primary);
}

.field__input--button-padding {
  padding-inline: var(--padding-3xl);
}

.field__label {
  color: rgb(var(--color-input-text-rgb) / var(--opacity-80));
  font-size: var(--font-paragraph--size);
  left: var(--input-padding-x);
  top: 50%;
  transform: translateY(-50%);
  margin-bottom: 0;
  pointer-events: none;
  position: absolute;
  transition: top var(--animation-speed) ease, font-size var(--animation-speed) ease;
}

/* RTE styles */
.rte,
.shopify-policy__title {
  :is(h1, h2, h3, h4, h5, h6) {
    margin-block: clamp(1.5rem, 1em * 3.3, 2.5rem) clamp(1rem, 1em * 0.25, 2rem);
  }

  :first-child:is(p, h1, h2, h3, h4, h5, h6),
  :first-child:empty + :is(p, h1, h2, h3, h4, h5, h6) {
    margin-block-start: 0;
  }

  ul,
  ol {
    margin-block-start: 0;
    padding-inline-start: 1.5em;
  }

  /* Only apply margin-block-end to the higher level list, not nested lists */
  :is(ul, ol):not(:is(ul, ol) :is(ul, ol)) {
    margin-block-end: 1em;
  }

  blockquote {
    margin-inline: 1.5em 2.3em;
    margin-block: 3.8em;
    padding-inline-start: 0.8em;
    border-inline-start: 1.5px solid rgb(var(--color-foreground-rgb) / var(--opacity-25));
    font-style: italic;
    font-weight: 500;
  }

  .rte-table-wrapper {
    overflow-x: auto;
  }

  table {
    /* stylelint-disable-next-line declaration-no-important */
    width: 100% !important;
    border-collapse: collapse;
  }

  tr:not(:has(td)),
  thead {
    background-color: rgb(var(--color-foreground-rgb) / var(--opacity-5));
    font-weight: bold;
    text-transform: uppercase;
  }

  tr:has(td) {
    border-bottom: 1px solid rgb(var(--color-foreground-rgb) / var(--opacity-10));
  }

  th,
  td {
    text-align: start;
    padding-inline: var(--padding-md);
    padding-block: var(--padding-sm);
  }
}

.shopify-policy__container {
  padding-block: var(--padding-xl);
}

.checkbox {
  --checkbox-size: 22px;
  --checkbox-top: 50%;
  --checkbox-left: 1.5px;
  --checkbox-offset: 3px;
  --checkbox-border-radius: 7px;
  --checkbox-label-padding: 8px;
  --checkbox-path-opacity: 0;
  --checkbox-cursor: pointer;
  --checkbox-border: 1px solid rgb(var(--color-foreground-rgb) / var(--opacity-35-55));

  position: relative;
  display: flex;
  align-items: center;

  @media screen and (min-width: 750px) {
    --checkbox-size: 16px;
    --checkbox-border-radius: 5px;
    --checkbox-label-padding: 6px;
  }

  &:has(.checkbox__input:checked) {
    --checkbox-path-opacity: 1;
  }

  &:has(.checkbox__input:disabled) {
    --checkbox-cursor: not-allowed;
  }
}

.checkbox__input {
  position: absolute;
  opacity: 0;
  margin: 0;
  width: var(--checkbox-size);
  height: var(--checkbox-size);

  /* Outline is on the SVG instead, to allow it to have border-radius */
  &:focus-visible {
    outline: none;
  }

  &:focus-visible + .checkbox__label .icon-checkmark {
    outline: var(--focus-outline-width) solid currentcolor;
    outline-offset: var(--focus-outline-offset);
  }

  &:checked + .checkbox__label .icon-checkmark {
    background-color: var(--color-foreground);
    border-color: var(--color-foreground);
  }

  &:disabled + .checkbox__label .icon-checkmark {
    background-color: var(--input-disabled-background-color);
    border-color: var(--input-disabled-border-color);
  }
}

.checkbox__label {
  position: relative;
  display: inline-flex;
  cursor: var(--checkbox-cursor);
  line-height: var(--checkbox-size);
  min-width: var(--minimum-touch-target);
}

.checkbox .icon-checkmark {
  height: var(--checkbox-size);
  width: var(--checkbox-size);
  flex-shrink: 0;
  border: var(--checkbox-border);
  border-radius: var(--checkbox-border-radius);
  background-color: var(--color-background);
}

.checkbox__label-text {
  padding-inline-start: var(--checkbox-label-padding);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.checkbox .icon-checkmark path {
  stroke: var(--color-background);
  opacity: var(--checkbox-path-opacity);
  transition: opacity var(--animation-speed) var(--animation-easing);
}

.checkbox__input:disabled + .checkbox__label {
  color: var(--input-disabled-text-color);
}

/* Add to cart button */
.button[id^='BuyButtons-ProductSubmitButton-'] {
  position: relative;
  overflow: hidden;
}

/* Cart bubble */
.cart-bubble {
  --cart-padding: 0.2em;

  position: relative;
  width: 20px;
  aspect-ratio: 1;
  border-radius: 50%;
  border-width: 0;
  display: flex;
  line-height: normal;
  align-items: center;
  justify-content: center;
  color: var(--color-primary-button-text);
  padding-inline: var(--cart-padding);
}

.cart-bubble__background {
  position: absolute;
  inset: 0;
  background-color: var(--color-primary-button-background);
  border-radius: var(--style-border-radius-lg);
}

.cart-bubble__text {
  font-size: var(--font-size--2xs);
  z-index: var(--layer-flat);
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Quantity selector */
.quantity-selector {
  --quantity-selector-width: 124px;

  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--color-input-text);
  background-color: var(--color-input-background);
  border: var(--style-border-width-inputs) solid var(--color-input-border);
  border-radius: var(--style-border-radius-inputs);
  flex: 1 1 var(--quantity-selector-width);
  align-self: stretch;
  transition: background-color var(--animation-speed) var(--animation-easing);

  &:hover {
    background-color: var(--color-input-hover-background);
  }
}

.product-form-buttons:has(.add-to-cart-button.button-secondary) .quantity-selector {
  border-radius: var(--style-border-radius-buttons-secondary);
}

.quantity-selector :is(.quantity-minus, .quantity-plus) {
  /* Unset button styles */
  padding: 0;
  background: transparent;
  box-shadow: none;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  width: var(--minimum-touch-target);
  height: var(--minimum-touch-target);
  flex-shrink: 0;
  color: var(--color-input-text);
}

.quantity-selector .quantity-minus {
  border-start-start-radius: var(--style-border-radius-inputs);
  border-end-start-radius: var(--style-border-radius-inputs);
}

.quantity-selector .quantity-plus {
  border-start-end-radius: var(--style-border-radius-inputs);
  border-end-end-radius: var(--style-border-radius-inputs);
}

.product-details .quantity-selector {
  border-radius: var(--style-border-radius-buttons-primary);
}

.product-details .quantity-selector .quantity-minus {
  border-start-start-radius: var(--style-border-radius-buttons-primary);
  border-end-start-radius: var(--style-border-radius-buttons-primary);
}

.product-details .quantity-selector .quantity-plus {
  border-start-end-radius: var(--style-border-radius-buttons-primary);
  border-end-end-radius: var(--style-border-radius-buttons-primary);
}

.quantity-selector .svg-wrapper {
  transition: transform var(--animation-speed) var(--animation-easing);
}

.quantity-selector svg {
  width: var(--icon-size-xs);
  height: var(--icon-size-xs);
}

:is(.quantity-minus, .quantity-plus):active .svg-wrapper {
  transform: scale(0.9);
}

.quantity-selector input[type='number'] {
  margin: 0;
  text-align: center;
  border: none;
  appearance: none;
  max-width: calc(var(--quantity-selector-width) - var(--minimum-touch-target) * 2);
  border-radius: var(--style-border-radius-buttons);
  color: var(--color-input-text);
  background-color: transparent;
}

/* Chrome, Safari, Edge, Opera */
.quantity-selector input[type='number']::-webkit-inner-spin-button,
.quantity-selector input[type='number']::-webkit-outer-spin-button {
  appearance: none;
}

/* Firefox */
.quantity-selector input[type='number'] {
  appearance: textfield;
}

/* Pills (used in facets and predictive search) */

.pills__pill {
  --pills-pill-background-color: rgb(var(--color-foreground-rgb) / var(--opacity-5-15));

  color: var(--color-foreground);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--gap-sm);
  min-width: 48px;
  padding: 6px 12px;
  border-radius: var(--style-border-radius-pills);
  cursor: pointer;
  background-color: var(--pills-pill-background-color);
  transition: background-color var(--animation-speed) var(--animation-easing);

  &:hover {
    --pills-pill-background-color: rgb(var(--color-foreground-rgb) / var(--opacity-10-25));
  }

  @media screen and (max-width: 749px) {
    padding: var(--padding-xs) var(--padding-md);
  }
}

.pills__pill > .svg-wrapper {
  --close-icon-opacity: 0.4;
  --icon-stroke-width: 1px;

  color: var(--color-foreground);
}

.pills__pill--swatch {
  @media screen and (max-width: 749px) {
    padding-inline-start: var(--padding-sm);
  }
}

.pills__pill--swatch .swatch {
  margin-right: -4px;
}

.pills__pill--desktop-small {
  @media screen and (min-width: 750px) {
    font-size: var(--font-size--xs);
  }
}

/* Fly to cart animation */
fly-to-cart {
  position: fixed;
  width: 40px;
  height: 40px;
  left: 0;
  top: 0;
  border-radius: 50%;
  z-index: calc(infinity);
  pointer-events: none;
  opacity: 0;
  overflow: hidden;
  box-shadow: 0 4px 8px rgb(0 0 0 / 20%);
  transition: opacity 0.3s ease;
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  background-color: var(--color-foreground);
  transform: translate(var(--x, 0), var(--y, 0)) scale(var(--scale, 1));
}

/* ------------------------------------------------------------------------------ */

/* ------------------------------------------------------------------------------ */

/* ------------------------------------------------------------------------------ */

/* Animation declarations - to be kept at the bottom of the file for ease of find */
@keyframes grow {
  0% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.2);
  }

  100% {
    transform: scale(1);
  }
}

@keyframes slideInLeft {
  from {
    transform: translateX(var(--custom-transform-from, 100%));
  }

  to {
    transform: translateX(var(--custom-transform-to, 0));
  }
}

@keyframes slideInLeftViewTransition {
  from {
    transform: translateX(100px);
  }
}

@keyframes slideOutRight {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(var(--custom-transform-to, -100%));
  }
}

@keyframes slideInRight {
  from {
    transform: translateX(-100%);
  }

  to {
    transform: translateX(0);
  }
}

@keyframes slideOutLeft {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(100%);
  }
}

@keyframes slideInTop {
  from {
    transform: translateY(100%);
  }

  to {
    transform: translateY(0);
  }
}

@keyframes slideInTopViewTransition {
  from {
    transform: translateY(100px);
  }
}

@keyframes slideOutBottom {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(100%);
  }
}

@keyframes slideInBottom {
  from {
    transform: translateY(-100%);
  }

  to {
    transform: translateY(0);
  }
}

@keyframes slideOutTop {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(-100%);
  }
}

@keyframes cartBubbleSlideIn {
  from {
    transform: translateY(-1em);
  }

  to {
    transform: translateY(0);
  }
}

@keyframes elementSlideInTop {
  from {
    margin-top: var(--padding-sm);
    opacity: 0;
  }

  to {
    margin-top: 0;
    opacity: 1;
  }
}

@keyframes elementSlideOutTop {
  from {
    transform: translateY(0);
    opacity: 1;
  }

  to {
    transform: translateY(var(--padding-sm));
    opacity: 0;
  }
}

@keyframes elementSlideInBottom {
  from {
    transform: translateY(calc(-1 * var(--padding-sm)));
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes elementSlideOutBottom {
  from {
    transform: translateY(0);
    opacity: 1;
  }

  to {
    transform: translateY(calc(-1 * var(--padding-sm)));
    opacity: 0;
  }
}

@keyframes thumbnailsSlideInTop {
  from {
    transform: translateY(calc(-50% + var(--margin-lg)));
    opacity: 0;
  }

  to {
    transform: translateY(-50%);
    opacity: 1;
  }
}

@keyframes thumbnailsSlideOutTop {
  from {
    transform: translateY(-50%);
    opacity: 1;
  }

  to {
    transform: translateY(calc(-50% + var(--margin-lg)));
    opacity: 0;
  }
}

@keyframes thumbnailsSlideInBottom {
  from {
    transform: translateY(100%);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes thumbnailsSlideOutBottom {
  from {
    transform: translateY(0);
    opacity: 1;
  }

  to {
    transform: translateY(100%);
    opacity: 0;
  }
}

@keyframes search-element-slide-in-bottom {
  0% {
    transform: translateY(20px);
    opacity: 0;
  }

  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes search-element-slide-out-bottom {
  0% {
    transform: translateY(0);
    opacity: 1;
  }

  100% {
    transform: translateY(20px);
    opacity: 0;
  }
}

@keyframes dialogZoom {
  from {
    opacity: 1;
    transform: scale(1) translateY(0);
  }

  to {
    opacity: 0;
    transform: scale(0.95) translateY(1em);
  }
}

@keyframes thumbnail-selected {
  0%,
  100% {
    box-shadow: 0 0 0 2px transparent;
    scale: 0.9;
  }

  50% {
    box-shadow: 0 0 0 2px #000;
    scale: 1;
  }
}

@keyframes backdropFilter {
  from {
    backdrop-filter: brightness(1);
  }

  to {
    backdrop-filter: brightness(0.75);
  }
}

@keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes modalSlideInTop {
  from {
    transform: translateY(var(--padding-sm));
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes modalSlideOutTop {
  from {
    transform: translateY(0);
    opacity: 1;
  }

  to {
    transform: translateY(var(--padding-sm));
    opacity: 0;
  }
}

.bubble {
  display: inline-flex;
  height: calc(var(--variant-picker-swatch-height) / 1.5);
  font-size: var(--font-size--xs);
  border-radius: 20px;
  min-width: 20px;
  padding: 0 6px;
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-10-25));
  color: var(--color-foreground);
  align-items: center;
  justify-content: center;
}

.bubble svg {
  width: 12px;
  height: 12px;
}

.top-shadow::before {
  content: '';
  box-shadow: 0 0 10px var(--color-shadow);
  position: absolute;
  z-index: var(--layer-lowest);
  inset: 0;
  clip-path: inset(-50px 0 0 0); /* stylelint-disable-line */
}

@media (min-width: 750px) {
  .top-shadow--mobile::before {
    display: none;
  }
}

.bottom-shadow::before {
  content: '';
  box-shadow: 0 0 10px var(--color-shadow);
  position: absolute;
  z-index: var(--layer-lowest);
  inset: 0;
  clip-path: inset(0 0 -50px 0); /* stylelint-disable-line */
}

@media (min-width: 750px) {
  .bottom-shadow--mobile::before {
    display: none;
  }
}

.video-placeholder-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  aspect-ratio: var(--size-style-aspect-ratio, auto);
}

:not(deferred-media) > .video-placeholder-wrapper {
  width: var(--video-placeholder-width);
}

.video-placeholder-wrapper > * {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/*
 * Slideshow Component
 */
slideshow-component {
  --cursor: grab;

  position: relative;
  display: flex;
  flex-direction: column;
  timeline-scope: var(--slideshow-timeline);
}

.slideshow--single-media {
  --cursor: default;
}

a slideshow-component {
  --cursor: pointer;
}

/*
 * Slideshow Slides
 */
slideshow-slides {
  width: 100%;
  position: relative;
  display: flex;
  overflow-x: scroll;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-color: transparent transparent;
  scrollbar-width: none;
  gap: var(--slideshow-gap, 0);
  cursor: var(--cursor);

  @media (prefers-reduced-motion) {
    scroll-behavior: auto;
  }

  &::-webkit-scrollbar {
    width: 0;
  }

  &::-webkit-scrollbar-track {
    background: transparent;
  }

  &::-webkit-scrollbar-thumb {
    background: transparent;
    border: none;
  }

  &[size='small'] {
    min-height: 17.5rem;
  }

  &[size='medium'] {
    min-height: 21.25rem;
  }

  &[size='large'] {
    min-height: 25rem;
  }

  @media screen and (min-width: 750px) {
    &[size='small'] {
      min-height: 26.25rem;
    }

    &[size='medium'] {
      min-height: 35rem;
    }

    &[size='large'] {
      min-height: 45rem;
    }
  }
}

slideshow-component[disabled='true'] slideshow-slides {
  overflow: hidden;
}

slideshow-component[mobile-disabled] slideshow-slides {
  @media screen and (max-width: 749px) {
    overflow: hidden;
  }
}

slideshow-slide {
  position: relative;
  scroll-snap-align: start;
  width: var(--slide-width, 100%);
  max-height: 100%;
  flex-shrink: 0;
  view-timeline-axis: inline;
  content-visibility: auto;
  contain-intrinsic-size: auto none;

  slideshow-component[actioned] &,
  &[aria-hidden='false'] {
    content-visibility: visible;
  }

  slideshow-component slideshow-slide:not([aria-hidden='false']) {
    content-visibility: hidden;
  }

  &[hidden]:not([reveal]) {
    display: none;
  }
}

slideshow-slide.product-media-container--tallest {
  content-visibility: visible;
}

@media screen and (max-width: 749px) {
  /* Media gallery has a peeking slide on the right side always, and on the left side when the current slide is the last one */
  .media-gallery--hint
    :is(
      slideshow-slide:has(+ slideshow-slide[aria-hidden='false']:last-of-type),
      slideshow-slide[aria-hidden='false'] + slideshow-slide
    ) {
    content-visibility: auto;

    slideshow-component[actioned] & {
      content-visibility: visible;
    }
  }
}

/*
 * Collection and Resource list carousels have peeking slides on both sides.
 * Card galleries preview the next or previous images on 'pointerenter', so we
 * try to kick load them beforehand (they are lazy loaded otherwise).
 */
:is(.resource-list__carousel, .card-gallery)
  :is(
    slideshow-slide:has(+ slideshow-slide[aria-hidden='false']),
    slideshow-slide[aria-hidden='false'] + slideshow-slide
  ) {
  content-visibility: auto;

  slideshow-component[actioned] & {
    content-visibility: visible;
  }
}

/*
 * Be specific about HTML children structure to avoid targeting nested slideshows.
 * Ensure that the content is 'visible' while scrolling instead of 'auto' to avoid issues in Safari.
 */
slideshow-component:is([dragging], [transitioning], :hover) > slideshow-container > slideshow-slides > slideshow-slide {
  content-visibility: visible;
}

slideshow-slides[gutters*='start'] {
  padding-inline-start: var(--gutter-slide-width, 0);
  scroll-padding-inline-start: var(--gutter-slide-width, 0);
}

slideshow-slides[gutters*='end'] {
  padding-inline-end: var(--gutter-slide-width, 0);
}

slideshow-component[dragging] {
  --cursor: grabbing;

  * {
    pointer-events: none;
  }
}

slideshow-component[dragging] slideshow-arrows {
  display: none;
}

slideshow-container {
  width: 100%;
  display: block;
  position: relative;
  grid-area: container;
  container-type: inline-size;
}

/*
 * Slideshow Controls
 */
slideshow-controls {
  flex-shrink: 0;
  display: flex;
  justify-content: space-between;
  scrollbar-width: none;
  min-height: var(--minimum-touch-target);
  grid-area: controls;

  &[controls-on-media] {
    position: absolute;
    bottom: 0;
  }
}

slideshow-controls::-webkit-scrollbar {
  display: none;
}

slideshow-controls button {
  --color: rgb(var(--color-foreground-rgb) / var(--opacity-30));
  --color-active: var(--color-foreground);
  --color-hover: rgb(var(--color-foreground-rgb) / var(--opacity-50));

  display: inline-block;
  height: var(--minimum-touch-target);
  width: var(--minimum-touch-target);
  cursor: pointer;
}

slideshow-controls .icon {
  width: var(--icon-size-sm);
  height: var(--icon-size-xs);
}

slideshow-controls[pagination-position='center'] {
  align-items: center;
  justify-content: center;
}

slideshow-controls[pagination-position='center'][thumbnails] {
  width: 100%;
}

slideshow-controls[pagination-position='center']:not([controls-on-media], [thumbnails], [icons-on-media]) {
  justify-content: space-between;
}

slideshow-component:has(slideshow-controls[thumbnails]) {
  &:has(slideshow-controls[pagination-position='right']) {
    display: grid;
    grid-template:
      'container controls' auto
      'arrows controls' min-content
      / 1fr auto;
  }

  &:has(slideshow-controls[pagination-position='left']) {
    display: grid;
    grid-template:
      'controls container' auto
      'controls arrows' min-content
      / auto 1fr;
  }

  slideshow-controls[pagination-position='left'] {
    order: -1;
  }
}

slideshow-controls[thumbnails]:is([pagination-position='right'], [pagination-position='left']) {
  display: flex;
  flex-direction: column;
  height: 0;
  min-height: 100%;

  .slideshow-controls__thumbnails-container {
    overflow: hidden auto;
  }

  &:not([controls-on-media]) {
    .slideshow-controls__thumbnails-container {
      position: sticky;
      top: var(--sticky-header-offset, 0);
    }

    .slideshow-controls__thumbnails {
      padding-block-start: var(--focus-outline-offset);
    }
  }
}

slideshow-controls:not([controls-on-media])[icons-on-media] {
  &[pagination-position='right'] {
    justify-content: flex-end;
  }

  &[pagination-position='left'] {
    justify-content: flex-start;
  }
}

slideshow-controls:not([controls-on-media]):is([pagination-position='left'], [pagination-position='right'])
  .slideshow-controls__thumbnails {
  padding-block: var(--padding-2xs);
}

slideshow-controls:not([controls-on-media]) {
  &:is([pagination-position='right']) {
    .slideshow-controls__thumbnails {
      padding-inline-end: var(--slideshow-thumbnails-padding-inline, var(--focus-outline-offset));
    }
  }

  &:is([pagination-position='left']) {
    .slideshow-controls__thumbnails {
      padding-inline-start: var(--slideshow-thumbnails-padding-inline, var(--focus-outline-offset));
    }
  }
}

slideshow-controls[controls-on-media] {
  z-index: var(--layer-raised);

  &:has(.slideshow-controls__dots, .slideshow-controls__counter) {
    --color-foreground: #fff;
    --color-foreground-rgb: var(--color-white-rgb);
  }

  &[pagination-position='right'] {
    right: 0;
  }

  &[pagination-position='left'] {
    left: 0;
  }

  &[pagination-position='center'] {
    width: 100%;
  }

  &:not([thumbnails])[pagination-position='left'] {
    width: fit-content;
    align-self: flex-start;
  }

  &:not([thumbnails])[pagination-position='right'] {
    width: fit-content;
    align-self: flex-end;
  }
}

slideshow-controls:is([pagination-position='right'], [pagination-position='left']) {
  .slideshow-controls__thumbnails {
    flex-direction: column;
  }
}

.slideshow-controls__arrows {
  display: flex;
  justify-content: space-between;
  height: var(--minimum-touch-target);
  grid-area: arrows;

  button {
    padding: 0 var(--padding-xs);
  }
}

.slideshow-controls__dots,
.slideshow-controls__counter {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  list-style: none;

  button {
    --color: rgb(var(--color-foreground-rgb) / var(--opacity-30));
    --color-active: var(--color-foreground);
    --color-hover: rgb(var(--color-foreground-rgb) / var(--opacity-50));
  }
}

slideshow-controls:has(.slideshow-controls__dots),
slideshow-component[autoplay] slideshow-controls {
  mix-blend-mode: difference;
}

.slideshow-controls__dots {
  gap: 0.6rem;
  padding: var(--padding-sm) var(--padding-lg);
  border-radius: 3rem;
  overflow: hidden;

  button {
    --size: 0.5rem;

    display: flex;
    align-items: center;
    justify-content: center;
    width: calc(var(--size) * 2);
    height: calc(var(--size) * 2);
    margin: calc(var(--size) / -2);
    font-size: 0;
    border-radius: calc(var(--size));

    &::after {
      content: '';
      display: block;
      background-color: var(--color);
      height: var(--size);
      width: var(--size);

      /* This is at --size / 2 to remove a visual regression on subpixel rendering displays */
      border-radius: calc(var(--size) / 2);

      @supports not (view-timeline-axis: inline) {
        &[aria-selected='true'] {
          --color: var(--color-active);
        }
      }

      &:hover {
        --color: var(--color-hover);
      }
    }

    &[aria-selected='true'] {
      --color: var(--color-active);
    }
  }
}

.slideshow-controls__dots,
.slideshow-controls__counter {
  &:only-child {
    margin-inline: auto;
  }
}

.slideshow-controls__counter {
  color: var(--color-foreground);
  background-color: rgb(0 0 0 / 40%);
  width: auto;
  border-radius: 2rem;
  padding: 0.3rem var(--padding-sm);
  margin-inline: var(--margin-sm);
  backdrop-filter: blur(10px);
  font-variant-numeric: tabular-nums;
  font-size: var(--font-size--xs);

  .slash {
    color: rgb(var(--color-foreground-rgb) / var(--opacity-40));
    padding-inline: var(--padding-2xs);
    margin-block-start: -0.1rem;
  }
}

.slideshow-control[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

.slideshow-control--large {
  .icon-caret {
    --icon-stroke-width: 1px;
  }

  .icon-caret {
    --icon-stroke-width: 1px;
  }

  .svg-wrapper,
  svg {
    width: var(--slideshow-controls-icon);
    height: var(--slideshow-controls-icon);
  }
}

/* Slideshow control shape styles */
.button-unstyled.slideshow-control.slideshow-control--shape-square,
.button-unstyled.slideshow-control.slideshow-control--shape-circle {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1 / 1;
  background-color: var(--color-primary-button-background);
  color: var(--color-primary-button-text);
}

.button-unstyled.slideshow-control.slideshow-control--shape-circle {
  border-radius: 50%;
}

.button-unstyled.slideshow-control.slideshow-control--shape-square {
  border-radius: 0;
}

.slideshow-control .icon-caret {
  rotate: -90deg;
}

/* Slideshow Thumbnails */
.slideshow-controls__thumbnails-container {
  display: flex;
  width: 100%;
  max-height: 100%;
  overflow-x: scroll;
  scrollbar-width: none;
}

.slideshow-controls__thumbnails {
  display: inline-flex;
  padding-inline: var(--slideshow-thumbnails-padding-inline, var(--padding-sm));
  padding-block: var(--slideshow-thumbnails-padding-block, var(--padding-sm));
  gap: var(--gap-xs);
  margin-inline: auto;
  height: fit-content;

  .slideshow-control {
    border-radius: var(--media-radius);
    width: clamp(44px, 7vw, var(--thumbnail-width));
    height: auto;
    aspect-ratio: var(--aspect-ratio);

    img {
      height: 100%;
      object-fit: cover;
      border-radius: var(--media-radius);
    }

    &:is([aria-selected='true']) {
      outline: var(--focus-outline-width) solid currentcolor;
      outline-offset: calc(var(--focus-outline-offset) / 2);
      border: var(--style-border-width) solid rgb(var(--color-border-rgb) / var(--media-border-opacity));
    }
  }
}

.slideshow-controls__thumbnail {
  position: relative;
}

.slideshow-controls__thumbnail-badge {
  position: absolute;
  top: var(--padding-2xs);
  right: var(--padding-2xs);
  width: clamp(16px, 10%, 20px);
  height: clamp(16px, 10%, 20px);
  background-color: var(--color-background);
  border-radius: var(--style-border-radius-xs);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 0 1px rgb(var(--color-foreground-rgb) / var(--opacity-5));
}

.slideshow-controls__thumbnail-badge svg {
  width: 60%;
  height: 60%;
  fill: var(--color-foreground);
  opacity: 0.6;
}

/* Slideshow Play/Pause */
.slideshow-control:is(.icon-pause, .icon-play) {
  color: var(--color-active);

  &:hover {
    color: var(--color-hover);
  }

  svg {
    display: none;
  }
}

slideshow-component:is([autoplay]) {
  &:is([paused]) {
    .icon-play > svg {
      display: block;
    }
  }

  &:not([paused]) {
    .icon-pause > svg {
      display: block;
    }
  }
}

/* Slideshow Arrows */
slideshow-arrows {
  --cursor-previous: w-resize;
  --cursor-next: e-resize;

  position: absolute;
  inset: 0;
  display: flex;
  z-index: var(--layer-heightened);
  pointer-events: none;
  mix-blend-mode: difference;
  align-items: flex-end;

  &[position='left'] {
    justify-content: flex-start;
    padding-inline: var(--padding-xs);
  }

  &[position='right'] {
    justify-content: flex-end;
    padding-inline: var(--padding-xs);
  }

  &[position='center'] {
    justify-content: space-between;
    align-items: center;
  }
}

slideshow-arrows:has(.slideshow-control--shape-square),
slideshow-arrows:has(.slideshow-control--shape-circle) {
  mix-blend-mode: normal;
}

slideshow-component[disabled='true'] slideshow-arrows {
  display: none;
}

slideshow-arrows .slideshow-control {
  pointer-events: auto;
  opacity: 0;
  min-height: var(--minimum-touch-target);
  padding: 0 var(--padding-xs);
  color: var(--color-white);
}

slideshow-arrows .slideshow-control.slideshow-control--style-none {
  display: none;
}

.media-gallery--carousel slideshow-arrows .slideshow-control {
  padding-inline: 0 var(--padding-md);
}

.card-gallery slideshow-arrows .slideshow-control {
  /* Align icons with quick-add button */
  padding-inline: var(--padding-xl);

  @container (max-width: 249px) {
    padding-inline: 0 var(--padding-sm);
  }
}

.media-gallery--carousel slideshow-arrows .slideshow-control {
  opacity: 1;
}

:not(.media-gallery--carousel)
  > :is(slideshow-component:hover, slideshow-component:focus-within):not(:has(slideshow-controls:hover))
  > slideshow-container
  > slideshow-arrows
  .slideshow-control {
  animation: arrowsSlideIn var(--animation-speed) var(--animation-easing) forwards;
}

@keyframes arrowsSlideIn {
  from {
    transform: translate(var(--padding-sm), 0);
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.block-resource-list {
  display: flex;
  flex-direction: column;
  row-gap: var(--gap);
  min-width: 0;
  min-height: 0;
  container-type: inline-size;
  container-name: resource-list;
}

.section-resource-list {
  row-gap: var(--gap);
}

.section-resource-list__content {
  display: flex;
  flex-direction: column;
  align-items: var(--horizontal-alignment);
  gap: var(--gap);
  width: 100%;
}

.section-resource-list__content:empty {
  display: none;
}

.section-resource-list__header:is(:empty, :has(.group-block-content:empty)),
.section-resource-list__content:empty {
  display: none;
}

.section-resource-list.section--full-width product-card-link > .group-block {
  @media screen and (max-width: 749px) {
    padding-inline: max(var(--padding-xs), var(--padding-inline-start))
      max(var(--padding-xs), var(--padding-inline-end));
  }
}

.resource-list--carousel-mobile {
  display: block;

  @media screen and (min-width: 750px) {
    display: none;
  }
}

.resource-list {
  --resource-list-mobile-gap-max: 9999px;
  --resource-list-column-gap: min(var(--resource-list-column-gap-desktop), var(--resource-list-mobile-gap-max));
  --resource-list-row-gap: min(var(--resource-list-row-gap-desktop), var(--resource-list-mobile-gap-max));

  width: 100%;

  @media screen and (max-width: 749px) {
    --resource-list-mobile-gap-max: 12px;
  }

  @container resource-list (max-width: 749px) {
    --resource-list-mobile-gap-max: 12px;
  }
}

.resource-list--grid {
  display: grid;
  gap: var(--resource-list-row-gap) var(--resource-list-column-gap);
  grid-template-columns: var(--resource-list-columns-mobile);

  @media screen and (min-width: 750px) {
    grid-template-columns: var(--resource-list-columns);
  }

  @container resource-list (max-width: 449px) {
    grid-template-columns: var(--resource-list-columns-mobile);
  }

  @container resource-list(min-width: 450px) and (max-width: 749px) {
    --resource-list-columns-per-row: 3;

    grid-template-columns: repeat(var(--resource-list-columns-per-row), 1fr);

    /* Avoid orphan in last row when there are 4, 7, or 10 items */
    &:has(.resource-list__item:first-child:nth-last-child(3n + 1)),
    /* Clean two full rows when there are 8 items */
    &:has(.resource-list__item:first-child:nth-last-child(8n)) {
      --resource-list-columns-per-row: 4;
    }
  }

  @container resource-list (min-width: 750px) {
    grid-template-columns: repeat(var(--resource-list-columns-per-row), 1fr);

    &:has(.resource-list__item:first-child:nth-last-child(n + 9)) {
      --resource-list-columns-per-row: 5;
    }

    &:has(.resource-list__item:first-child:nth-last-child(n + 7):nth-last-child(-n + 8)) {
      --resource-list-columns-per-row: 4;
    }

    &:has(.resource-list__item:first-child:nth-last-child(6)) {
      --resource-list-columns-per-row: 3;
    }

    &:has(.resource-list__item:first-child:nth-last-child(5)) {
      --resource-list-columns-per-row: 5;
    }

    &:has(.resource-list__item:first-child:nth-last-child(-n + 4)) {
      --resource-list-columns-per-row: 4;
    }
  }

  @container resource-list (min-width: 1200px) {
    &:has(.resource-list__item:first-child:nth-last-child(6)) {
      --resource-list-columns-per-row: 6;
    }
  }
}

.resource-list__item {
  height: 100%;
  color: var(--color-foreground);
  text-decoration: none;
}

.resource-list__carousel {
  --slide-width: 60vw;

  width: 100%;
  position: relative;
  container-type: inline-size;
  container-name: resource-list-carousel;

  .slideshow-control[disabled] {
    display: none;
  }

  .slideshow-control--next {
    margin-inline-start: auto;
  }
}

@container resource-list-carousel (max-width: 749px) {
  .resource-list__carousel .resource-list__slide {
    --slide-width: clamp(150px, var(--mobile-card-size, 60cqw), var(--slide-width-max));
  }
}

@container resource-list-carousel (min-width: 750px) {
  .resource-list__carousel .resource-list__slide {
    --section-slide-width: calc(
      (100% - (var(--resource-list-column-gap) * (var(--column-count) - 1)) - var(--peek-next-slide-size)) /
        var(--column-count)
    );
    --fallback-slide-width: clamp(150px, var(--mobile-card-size, 60cqw), var(--slide-width-max));
    --slide-width: var(--section-slide-width, var(--fallback-slide-width));
  }
}

.resource-list__carousel slideshow-slides {
  gap: var(--resource-list-column-gap);

  /* Add padding to prevent hover animations from being clipped in slideshow
     15px accommodates:
     - Scale effect (9px on each side from 1.03 scale)
     - Lift effect (4px upward movement)
     - Shadow (15px spread with -5px offset)
     Using 16px for better alignment with our spacing scale */

  margin-block: -16px;
  padding-block: 16px;
}

.resource-list__carousel slideshow-arrows {
  padding-inline: var(--util-page-margin-offset);
}

.resource-list__carousel .resource-list__slide {
  width: var(--slide-width);
  flex: 0 0 auto;
  scroll-snap-align: start;
  min-width: 0;
}

/* Base styles */
.group-block,
.group-block-content {
  position: relative;
}

.group-block:has(> video-background-component),
.group-block:has(> .background-image-container) {
  overflow: hidden;
}

.group-block-content {
  height: 100%;
  width: 100%;
}

/* Container styles */
.section-content-wrapper.section-content-wrapper:where(.layout-panel-flex) .group-block--fill {
  flex: 1;
}

/* Flex behavior for width variants */
.layout-panel-flex--row > .group-block--width-fit {
  flex: 0;
}

.layout-panel-flex--row > .group-block--width-fill {
  flex: 1;
}

.layout-panel-flex--row > .group-block--width-custom {
  flex-basis: var(--size-style-width);
}

/* Dimension utilities - Height */
.group-block--height-fit {
  height: auto;
}

.group-block--height-custom,
.group-block--height-fill {
  height: var(--size-style-height);
}

/* Flex behavior for height variants */
.layout-panel-flex--column > .group-block--height-fit {
  flex: 0 1 auto;
}

.layout-panel-flex--column > .group-block--height-fill {
  flex: 1;
}

.layout-panel-flex--column > .group-block--height-custom {
  flex-basis: var(--size-style-height);
}

accordion-custom {
  details {
    &::details-content,
    .details-content {
      block-size: 0;
      overflow-y: clip;
      opacity: 0;
      interpolate-size: allow-keywords;
      transition: content-visibility var(--animation-speed-slow) allow-discrete,
        padding-block var(--animation-speed-slow) var(--animation-easing),
        opacity var(--animation-speed-slow) var(--animation-easing),
        block-size var(--animation-speed-slow) var(--animation-easing);
    }

    &:not([open]) {
      &::details-content,
      .details-content {
        padding-block: 0;
      }
    }

    &[open] {
      &::details-content,
      .details-content {
        opacity: 1;
        block-size: auto;

        @starting-style {
          block-size: 0;
          opacity: 0;
          overflow-y: clip;
        }

        &:focus-within {
          overflow-y: visible;
        }
      }
    }
  }
}

accordion-custom[data-disable-on-mobile='true'] summary {
  @media screen and (max-width: 749px) {
    cursor: auto;
  }
}

accordion-custom[data-disable-on-desktop='true'] summary {
  @media screen and (min-width: 750px) {
    cursor: auto;
  }
}

text-component {
  --shimmer-text-color: rgb(var(--color-foreground-rgb) / var(--opacity-50));
  --shimmer-color-light: rgb(var(--color-foreground-rgb) / var(--opacity-10));
  --shimmer-speed: 1.25s;

  display: inline-block;
  position: relative;
  transition: color var(--animation-speed-slow) ease;
  line-height: 1;

  &::after {
    content: attr(value);
    position: absolute;
    inset: 0;
    color: transparent;
    opacity: 0;
    transition: opacity var(--animation-speed-slow) var(--animation-easing);
    pointer-events: none;
    background-image: linear-gradient(
      -85deg,
      var(--shimmer-text-color) 10%,
      var(--shimmer-color-light) 50%,
      var(--shimmer-text-color) 90%
    );
    background-clip: text;
    background-size: 200% 100%;
    background-position: 100% 0;
    place-content: center;
  }

  &[shimmer] {
    color: transparent;

    &::after {
      opacity: 1;
      animation: text-shimmer var(--shimmer-speed) infinite linear;
    }
  }
}

@keyframes text-shimmer {
  0% {
    background-position: 100% 0;
  }

  100% {
    background-position: -100% 0;
  }
}

/* Animation transitions */
.transition-background-color {
  transition: background-color var(--animation-speed-medium) ease-in-out;
}

.transition-transform {
  transition: transform var(--animation-speed-medium) var(--animation-timing-bounce);
}

.transition-border-color {
  transition: border-color var(--animation-speed-medium) var(--animation-timing-hover);
}

/* Global scrollbar styles */

/* Webkit browsers */
::-webkit-scrollbar {
  width: 20px;
}

::-webkit-scrollbar-track {
  background-color: transparent;
}

::-webkit-scrollbar-thumb {
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-40));
  border-radius: 20px;
  border: 6px solid transparent;
  background-clip: content-box;
  transition: background-color 0.2s;
}

::-webkit-scrollbar-thumb:hover {
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-60));
}

@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: smooth;
  }
}

/* Product card title truncation - applied only to zoom-out view */
[product-grid-view='zoom-out'] :is(.product-card, .product-grid__card) :is(h4, .h4) {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 3;
}

/* Product card title truncation - applied on mobile regardless of view */
@media screen and (max-width: 749px) {
  :is(.product-card, .product-grid__card) :is(h4, .h4) {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 3;
  }
}

.product-card:hover,
.collection-card:hover,
.resource-card:hover,
.predictive-search-results__card--product:hover,
.predictive-search-results__card:hover {
  position: relative;
  z-index: var(--layer-raised);
  transition: transform var(--hover-transition-duration) var(--hover-transition-timing),
    box-shadow var(--hover-transition-duration) var(--hover-transition-timing);
}

.header .product-card:hover,
.header .collection-card:hover,
.header .resource-card:hover,
.header-drawer .product-card:hover,
.header-drawer .collection-card:hover,
.header-drawer .resource-card:hover {
  z-index: auto;
  transform: none;
  box-shadow: none;
}

/* Prevent iOS zoom on input focus by ensuring minimum 16px font size on mobile */
@media screen and (max-width: 1200px) {
  input,
  textarea,
  select,
  /* Higher specificity to override type preset classes like .paragraph, .h1, etc. */
  .paragraph.paragraph input,
  .paragraph.paragraph textarea,
  .paragraph.paragraph select,
  .h1.h1 input,
  .h1.h1 textarea,
  .h1.h1 select,
  .h2.h2 input,
  .h2.h2 textarea,
  .h2.h2 select,
  .h3.h3 input,
  .h3.h3 textarea,
  .h3.h3 select,
  .h4.h4 input,
  .h4.h4 textarea,
  .h4.h4 select,
  .h5.h5 input,
  .h5.h5 textarea,
  .h5.h5 select,
  .h6.h6 input,
  .h6.h6 textarea,
  .h6.h6 select {
    font-size: max(1rem, 100%);
  }
}/* StreamMax Unified Style (Menu + WhatsApp Button) */
.whatsapp-float{position:fixed;bottom:calc(env(safe-area-inset-bottom)+22px);right:22px;width:58px;height:58px;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 30% 30%,#0fb,#086);border-radius:50%;box-shadow:0 0 25px rgba(0,255,180,.5);text-decoration:none;color:#fff;z-index:9999;animation:wf 2s ease-in-out infinite;transition:.3s}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 0 35px rgba(0,255,180,.8)}
@keyframes wf{0%{box-shadow:0 0 10px rgba(0,255,180,.3)}50%{box-shadow:0 0 25px rgba(0,255,180,.8);transform:translateY(-4px)}100%{box-shadow:0 0 10px rgba(0,255,180,.3);transform:translateY(0)}}
.drawer[data-drawer=menu]{background:rgba(10,10,20,.92)!important;backdrop-filter:blur(12px)}
.drawer[data-drawer=menu] .drawer__menu-item{color:#fff!important;font-weight:700;text-transform:uppercase;letter-spacing:.5px;transition:.3s}
.drawer[data-drawer=menu] .drawer__menu-item:hover{color:#0fb!important;text-shadow:0 0 10px rgba(0,255,176,.6)}
.drawer[data-drawer=menu] .drawer__close-button{filter:brightness(1.8)}
/* STREAMMAX – Premium Buttons & Text Enhancements */
/* ---------------------------------------------- */

/* ✅ تحسين قراءة النصوص العامة */
.product__description,
.product__info,
.product__title,
.product__price {
  line-height: 1.65;
  letter-spacing: 0.2px;
  color: #e9e9ff;
}

/* ✅ زر "Add to Cart" – تأثير Glow متوهج */
.product-form__buttons .button--primary {
  background: linear-gradient(135deg, #7a3cff, #9f68ff);
  box-shadow: 0 0 20px rgba(160, 120, 255, 0.5);
  border-radius: 8px;
  font-weight: 700;
  transition: all 0.35s ease;
  animation: btnGlow 2.5s infinite ease-in-out;
}

.product-form__buttons .button--primary:hover {
  transform: scale(1.05);
  box-shadow: 0 0 30px rgba(180, 140, 255, 0.8);
}

/* Animation Glow effect */
@keyframes btnGlow {
  0% {
    box-shadow: 0 0 15px rgba(180, 140, 255, 0.4);
  }
  50% {
    box-shadow: 0 0 35px rgba(180, 140, 255, 0.8);
  }
  100% {
    box-shadow: 0 0 15px rgba(180, 140, 255, 0.4);
  }
}

/* ✅ زر "Buy It Now" – ذهبي متوهج فاخر */
.shopify-payment-button .shopify-payment-button__button {
  background: linear-gradient(135deg, #f6d365, #fda085);
  border: none;
  border-radius: 8px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #3c1b00 !important;
  box-shadow: 0 0 25px rgba(255, 200, 90, 0.6);
  transition: all 0.3s ease;
}

.shopify-payment-button .shopify-payment-button__button:hover {
  background: linear-gradient(135deg, #ffeb9a, #ffb774);
  transform: scale(1.05);
  box-shadow: 0 0 40px rgba(255, 215, 130, 0.9);
}

/* ✅ تحسين العناوين والأوصاف */
.product__title {
  color: #fff;
  font-weight: 800;
  text-shadow: 0 0 8px rgba(150, 90, 255, 0.4);
}

.product__description ul li {
  margin-bottom: 6px;
}

/* ✅ تباعد بين الأقسام */
.product__description {
  margin-top: 10px;
}

/* ✅ تحسين الأزرار الصغيرة / الثانويّة */
.button--secondary {
  background: rgba(255, 255, 255, 0.05);
  color: #ccc;
  border: 1px solid rgba(255, 255, 255, 0.15);
  transition: all 0.3s ease;
}

.button--secondary:hover {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
}.language-switcher {
  position: fixed;
  top: 18px;
  right: 16px;
  z-index: 9999;
  background: rgba(40, 0, 80, 0.85);
  border: 1px solid rgba(255, 215, 0, 0.3);
  border-radius: 6px;
  padding: 6px 10px;
  box-shadow: 0 0 10px rgba(255, 215, 0, 0.25);
}

.language-switcher select {
  background: transparent;
  color: #ffd86b;
  border: none;
  font-weight: 600;
  outline: none;
  font-size: 14px;
  cursor: pointer;
}

.language-switcher select option {
  background: #1b1029;
  color: white;
}
@keyframes pulseGlow{
  0%{box-shadow:0 0 18px rgba(46,143,255,.25);border-color:rgba(46,143,255,.4)}
  50%{box-shadow:0 0 45px rgba(46,143,255,.75);border-color:rgba(46,143,255,.9)}
  100%{box-shadow:0 0 18px rgba(46,143,255,.25);border-color:rgba(46,143,255,.4)}
}@keyframes pulseGlow{
  0%{box-shadow:0 0 18px rgba(46,143,255,.25);border-color:rgba(46,143,255,.4)}
  50%{box-shadow:0 0 45px rgba(46,143,255,.75);border-color:rgba(46,143,255,.9)}
  100%{box-shadow:0 0 18px rgba(46,143,255,.25);border-color:rgba(46,143,255,.4)}
}
/* STREAMMAX IPTV – Pricing Enhancements */

/* ==== GENERAL LAYOUT ==== */
.pricing-section {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 25px;
  padding: 40px 10px;
}

/* ==== PRICING CARD ==== */
.pricing-card {
  background: rgba(10, 20, 45, 0.85);
  border: 1px solid rgba(46, 143, 255, 0.25);
  border-radius: 20px;
  width: 270px;
  transition: all 0.4s ease;
  position: relative;
  overflow: hidden;
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.4);
}

.pricing-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 0 30px rgba(46, 143, 255, 0.45);
  border-color: rgba(46, 143, 255, 0.6);
}

/* ==== PREMIUM CARD GLOW ==== */
.pricing-card.premium {
  border: 1px solid rgba(255, 215, 0, 0.6);
  box-shadow: 0 0 25px rgba(255, 215, 0, 0.2);
  animation: goldGlow 5s infinite alternate ease-in-out;
}

@keyframes goldGlow {
  0% {
    box-shadow: 0 0 15px rgba(255, 215, 0, 0.2);
  }
  50% {
    box-shadow: 0 0 35px rgba(255, 215, 0, 0.5);
  }
  100% {
    box-shadow: 0 0 15px rgba(255, 215, 0, 0.2);
  }
}

/* ==== ORDER BUTTON ==== */
.pricing-card .order-btn {
  display: block;
  background: linear-gradient(90deg, #ff3030, #ff5050);
  color: white;
  font-weight: 700;
  padding: 12px 0;
  border-radius: 8px;
  margin: 15px auto;
  text-align: center;
  transition: 0.3s;
  animation: pulseBtn 2s infinite;
}

@keyframes pulseBtn {
  0% { transform: scale(1); box-shadow: 0 0 0 rgba(255, 0, 0, 0.3); }
  50% { transform: scale(1.05); box-shadow: 0 0 15px rgba(255, 0, 0, 0.5); }
  100% { transform: scale(1); box-shadow: 0 0 0 rgba(255, 0, 0, 0.3); }
}

.pricing-card .order-btn:hover {
  background: linear-gradient(90deg, #ff5050, #ff2020);
}

/* ==== TEXT STYLES ==== */
.pricing-card h3 {
  font-size: 18px;
  color: #fff;
  text-align: center;
  margin-bottom: 10px;
}

.pricing-card .price {
  color: #ff5050;
  font-size: 28px;
  font-weight: 700;
  text-align: center;
}

/* ==== RESPONSIVE ==== */
@media (max-width: 900px) {
  .pricing-section {
    flex-direction: column;
    align-items: center;
  }
  .pricing-card {
    width: 90%;
    max-width: 380px;
  }
}
<div class="pricing-section">

  <!-- 3 MONTHS PLAN -->
  <div class="pricing-card">
    <h3>3 MONTHS 🎯 STARTER PLAN</h3>
    <p class="price">$25.99 🚀</p>
    <a href="#" class="order-btn">Order Now</a>
  </div>

  <!-- 6 MONTHS PLAN -->
  <div class="pricing-card">
    <h3>6 MONTHS ⭐ STANDARD PLAN</h3>
    <p class="price">$49.99 🌍</p>
    <a href="#" class="order-btn">Order Now</a>
  </div>

  <!-- 12 MONTHS PLAN (PREMIUM + GLOW EFFECT) -->
  <div class="pricing-card premium">
    <h3>12 MONTHS 👑 PREMIUM PLAN</h3>
    <p class="price">$69.99 🏆</p>
    <a href="#" class="order-btn">Order Now</a>
  </div>

  <!-- 24 MONTHS PLAN -->
  <div class="pricing-card">
    <h3>24 MONTHS 💼 ULTIMATE PLAN</h3>
    <p class="price">$119.99 👜</p>
    <a href="#" class="order-btn">Order Now</a>
  </div>

</div>
/* 🔷 STREAMMAX Pricing Glow Effects */
.pricing-card {
  background: rgba(8, 61, 123, 0.95);
  border-radius: 20px;
  border: 1px solid rgba(255, 242, 46, 0.15);
  transition: all 0.5s ease;
  position: relative;
  overflow: hidden;
  box-shadow: 0 0 10px rgba(0,0,0,0.4);
}

/* Hover Animation */
.pricing-card:hover {
  transform: scale(1.04);
  box-shadow: 0 0 35px rgba(255, 242, 46, 0.4);
  border-color: rgba(255, 242, 46, 0.6);
}

/* Premium Plan (3rd card) Golden Glow */
.pricing-card:nth-child(3) {
  animation: premiumPulse 6s infinite;
  border-color: rgba(255, 242, 46, 0.4);
  box-shadow: 0 0 20px rgba(255, 242, 46, 0.2);
}

/* Button Styling */
.pricing-card button,
.pricing-card .button {
  background: linear-gradient(135deg, #ff2e2e, #ff6a00);
  color: #fff;
  border-radius: 12px;
  padding: 10px 25px;
  font-weight: 600;
  transition: all 0.3s ease-in-out;
}

/* Button Hover */
.pricing-card button:hover,
.pricing-card .button:hover {
  transform: scale(1.08);
  box-shadow: 0 0 20px rgba(255, 242, 46, 0.6);
}

/* 🔆 Premium Glow Pulse Animation */
@keyframes premiumPulse {
  0%, 100% {
    box-shadow: 0 0 0 rgba(255, 242, 46, 0);
    transform: scale(1);
  }
  50% {
    box-shadow: 0 0 35px rgba(255, 242, 46, 0.6);
    transform: scale(1.03);
  }
}

/* Button Pulse Animation */
@keyframes pulseBtn {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.07);
  }
}

/* Responsive Tweaks */
@media (max-width: 768px) {
  .pricing-card {
    margin-bottom: 20px;
  }
  .pricing-card:hover {
    transform: scale(1.02);
  }
}
/* 🔷 STREAMMAX PRICING – Multi-Color Glow Edition */
.pricing-card {
  border-radius: 20px;
  background: rgba(8, 61, 123, 0.95);
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: 0 0 12px rgba(0,0,0,0.4);
  transition: all 0.4s ease;
  overflow: hidden;
}

/* Hover Scaling */
.pricing-card:hover {
  transform: scale(1.04);
}

/* === INDIVIDUAL COLORS === */

/* 3-Month Starter (Red Energy) */
.pricing-card:nth-child(1) {
  border-color: rgba(255,46,46,0.4);
  animation: starterPulse 6s infinite;
}
@keyframes starterPulse {
  0%,100% { box-shadow:0 0 0 rgba(255,46,46,0); }
  50% { box-shadow:0 0 30px rgba(255,46,46,0.6); }
}

/* 6-Month Standard (Sky Blue Glow) */
.pricing-card:nth-child(2) {
  border-color: rgba(0,180,255,0.4);
  animation: standardPulse 6s infinite;
}
@keyframes standardPulse {
  0%,100% { box-shadow:0 0 0 rgba(0,180,255,0); }
  50% { box-shadow:0 0 35px rgba(0,180,255,0.6); }
}

/* 12-Month Premium (Gold Glow) */
.pricing-card:nth-child(3) {
  border-color: rgba(255,215,0,0.5);
  animation: premiumPulse 6s infinite;
}
@keyframes premiumPulse {
  0%,100% { box-shadow:0 0 0 rgba(255,215,0,0); }
  50% { box-shadow:0 0 40px rgba(255,215,0,0.7); }
}

/* 24-Month Ultimate (Metal Gray) */
.pricing-card:nth-child(4) {
  border-color: rgba(180,180,180,0.4);
  animation: ultimatePulse 7s infinite;
}
@keyframes ultimatePulse {
  0%,100% { box-shadow:0 0 0 rgba(180,180,180,0); }
  50% { box-shadow:0 0 35px rgba(180,180,180,0.6); }
}

/* === BUTTON STYLES === */
.pricing-card button,
.pricing-card .button {
  background: linear-gradient(135deg, #ff2e2e, #ff6a00);
  color: #fff;
  font-weight: 600;
  border-radius: 12px;
  padding: 10px 24px;
  transition: all 0.3s ease;
}

.pricing-card button:hover,
.pricing-card .button:hover {
  transform: scale(1.08);
  box-shadow: 0 0 20px rgba(255,215,0,0.6);
}

/* === RESPONSIVE === */
@media (max-width:768px){
  .pricing-card{margin-bottom:20px;transform:none!important;}
}
/* === STREAMMAX HEADER STYLE === */
.header {
  background: linear-gradient(135deg, #06191f, #0e3a40, #1a5a55);
  background-size: 200% 200%;
  animation: headerGlow 10s ease infinite;
  border-bottom: 1px solid rgba(0, 255, 180, 0.15);
  box-shadow: 0 0 25px rgba(0, 255, 150, 0.15);
  backdrop-filter: blur(8px);
  transition: all 0.4s ease;
}

/* تأثير الإضاءة الناعمة */
@keyframes headerGlow {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* عند المرور بالماوس */
.header:hover {
  box-shadow: 0 0 35px rgba(0, 255, 150, 0.25);
  border-bottom: 1px solid rgba(0, 255, 180, 0.35);
}

/* توحيد النصوص داخل الهيدر */
.header a,
.header .header__menu-item,
.header .localization-selector,
.header .header__icon {
  color: #e0fdf8 !important;
  transition: color 0.3s ease;
}

/* عند المرور على الروابط */
.header a:hover,
.header .header__menu-item:hover {
  color: #00ffcc !important;
}
/* === STREAMMAX HEADER - CINEMATIC GREEN TECH + LASER LINE === */
.header {
  position: relative;
  background: linear-gradient(135deg, #06191f, #0e3a40, #1a5a55);
  background-size: 200% 200%;
  animation: headerGlow 10s ease infinite;
  border-bottom: 1px solid rgba(0, 255, 180, 0.15);
  box-shadow: 0 0 25px rgba(0, 255, 150, 0.15);
  backdrop-filter: blur(8px);
  transition: all 0.4s ease;
  overflow: hidden;
}

/* تأثير الإضاءة الخلفية المتحركة */
@keyframes headerGlow {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* === خط الليزر المتحرك === */
.header::before {
  content: "";
  position: absolute;
  top: 0;
  left: -15%;
  width: 30%;
  height: 3px;
  background: linear-gradient(90deg, transparent, #00ffcc, transparent);
  animation: laserMove 4s linear infinite;
  opacity: 0.6;
}

/* حركة الوميض الليزري */
@keyframes laserMove {
  0% { left: -30%; opacity: 0; }
  20% { opacity: 0.8; }
  50% { left: 100%; opacity: 1; }
  80% { opacity: 0.8; }
  100% { left: 130%; opacity: 0; }
}

/* تأثير عند المرور */
.header:hover {
  box-shadow: 0 0 35px rgba(0, 255, 150, 0.25);
  border-bottom: 1px solid rgba(0, 255, 180, 0.35);
}

/* ألوان النصوص داخل الهيدر */
.header a,
.header .header__menu-item,
.header .localization-selector,
.header .header__icon {
  color: #e0fdf8 !important;
  transition: color 0.3s ease;
}

/* عند المرور */
.header a:hover,
.header .header__menu-item:hover {
  color: #00ffcc !important;
}
/* === STREAMMAX HEADER - GREEN TECH + LASER SPARK EFFECT === */
.header {
  position: relative;
  background: linear-gradient(135deg, #06191f, #0e3a40, #1a5a55);
  background-size: 200% 200%;
  animation: headerGlow 10s ease infinite;
  border-bottom: 1px solid rgba(0, 255, 180, 0.15);
  box-shadow: 0 0 25px rgba(0, 255, 150, 0.15);
  backdrop-filter: blur(8px);
  transition: all 0.4s ease;
  overflow: hidden;
}

/* توهج الخلفية المتحرك */
@keyframes headerGlow {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* === خط الليزر المتحرك === */
.header::before {
  content: "";
  position: absolute;
  top: 0;
  left: -30%;
  width: 35%;
  height: 3px;
  background: linear-gradient(90deg, transparent, #00ffcc, transparent);
  animation: laserMove 4s linear infinite;
  opacity: 0.6;
}

/* === الشرارة (Spark) اللي تمشي مع الليزر === */
.header::after {
  content: "";
  position: absolute;
  top: -2px;
  left: -30%;
  width: 10px;
  height: 10px;
  background: radial-gradient(circle, #00ffcc 0%, transparent 70%);
  border-radius: 50%;
  animation: sparkMove 4s linear infinite;
  filter: blur(1px);
  opacity: 0.8;
}

/* حركة الليزر */
@keyframes laserMove {
  0% { left: -30%; opacity: 0; }
  20% { opacity: 0.8; }
  50% { left: 100%; opacity: 1; }
  80% { opacity: 0.8; }
  100% { left: 130%; opacity: 0; }
}

/* حركة الشرارة */
@keyframes sparkMove {
  0% { left: -30%; opacity: 0; transform: scale(0.6); }
  25% { opacity: 1; transform: scale(1); }
  50% { left: 100%; opacity: 1; transform: scale(1.2); }
  80% { opacity: 0.7; transform: scale(0.9); }
  100% { left: 130%; opacity: 0; transform: scale(0.6); }
}

/* تأثير عند المرور */
.header:hover {
  box-shadow: 0 0 35px rgba(0, 255, 150, 0.25);
  border-bottom: 1px solid rgba(0, 255, 180, 0.35);
}

/* ألوان النصوص داخل الهيدر */
.header a,
.header .header__menu-item,
.header .localization-selector,
.header .header__icon {
  color: #e0fdf8 !important;
  transition: color 0.3s ease;
}

/* عند المرور على الروابط */
.header a:hover,
.header .header__menu-item:hover {
  color: #00ffcc !important;
}
/* === STREAMMAX LOGO GLOW EFFECT === */
.header__heading-logo img {
  animation: logoPulse 5s ease-in-out infinite;
  transition: all 0.3s ease;
  filter: drop-shadow(0 0 4px rgba(0, 255, 180, 0.35));
}

/* نبضة ضوئية خفيفة */
@keyframes logoPulse {
  0% {
    filter: drop-shadow(0 0 4px rgba(0, 255, 180, 0.35));
    transform: scale(1);
  }
  50% {
    filter: drop-shadow(0 0 14px rgba(0, 255, 180, 0.7));
    transform: scale(1.03);
  }
  100% {
    filter: drop-shadow(0 0 4px rgba(0, 255, 180, 0.35));
    transform: scale(1);
  }
}

/* عند المرور بالماوس - وميض إضافي */
.header__heading-logo img:hover {
  filter: drop-shadow(0 0 18px rgba(0, 255, 200, 0.9));
  transform: scale(1.06);
}
/* === STREAMMAX LOGO - SOFT GLOW PULSE === */
.header__heading-logo img {
  animation: logoPulseSoft 5s ease-in-out infinite;
  transition: all 0.4s ease;
  filter: drop-shadow(0 0 3px rgba(0, 255, 180, 0.25));
}

/* نبضة ضوئية ناعمة كل 5 ثواني */
@keyframes logoPulseSoft {
  0% {
    filter: drop-shadow(0 0 3px rgba(0, 255, 180, 0.25));
    transform: scale(1);
  }
  50% {
    filter: drop-shadow(0 0 10px rgba(0, 255, 180, 0.45));
    transform: scale(1.02);
  }
  100% {
    filter: drop-shadow(0 0 3px rgba(0, 255, 180, 0.25));
    transform: scale(1);
  }
}

/* عند المرور على اللوجو */
.header__heading-logo img:hover {
  filter: drop-shadow(0 0 12px rgba(0, 255, 200, 0.7));
  transform: scale(1.05);
}
/* 🎬 StreamMax Cinematic Gradient Background */
body {
  background: linear-gradient(135deg, #2b0a59 0%, #6c1bf0 40%, #40c9ff 100%);
  background-attachment: fixed;
  background-size: cover;
  position: relative;
  overflow-x: hidden;
}

/* 🌌 Subtle Glow Center */
body::before {
  content: "";
  position: fixed;
  top: 50%;
  left: 50%;
  width: 1800px;
  height: 1800px;
  background: radial-gradient(circle, rgba(108,27,240,0.25) 0%, rgba(0,0,0,0) 70%);
  transform: translate(-50%, -50%);
  z-index: 0;
  pointer-events: none;
  animation: glowPulse 6s ease-in-out infinite;
}

/* ✨ Glow Animation */
@keyframes glowPulse {
  0%, 100% {
    opacity: 0.6;
  }
  50% {
    opacity: 1;
  }
}

/* 🧱 Sections Content Above Background */
.section, .main-content, .page-width {
  position: relative;
  z-index: 2;
}

/* StreamMax - How It Works (Glow Sync + VIP Gold Pulse) */
#shopify-section-how-it-works-steps {
  background: radial-gradient(circle at top right, #0a0a18 0%, #02030a 100%);
  border-top: 1px solid rgba(46,143,255,0.15);
  border-bottom: 1px solid rgba(46,143,255,0.15);
  position: relative;
  overflow: hidden;
  animation: syncGlow 6s ease-in-out infinite alternate;
}

/* Glow sync overlay */
#shopify-section-how-it-works-steps::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(46,143,255,0.12), rgba(255,215,0,0.04));
  z-index: 0;
  animation: syncGlow 6s ease-in-out infinite alternate;
}

/* Layer fix */
#shopify-section-how-it-works-steps * {
  position: relative;
  z-index: 1;
}

/* Title glow with gold pulse */
#shopify-section-how-it-works-steps h1,
#shopify-section-how-it-works-steps h2,
#shopify-section-how-it-works-steps h3 {
  color: #fff;
  text-shadow: 0 0 20px rgba(46,143,255,0.6);
  animation: syncGlow 6s ease-in-out infinite alternate, goldPulse 12s infinite;
}

/* Step cards */
#shopify-section-how-it-works-steps .step {
  background: rgba(15,20,35,0.8);
  border: 1px solid rgba(46,143,255,0.25);
  border-radius: 18px;
  box-shadow: 0 0 15px rgba(46,143,255,0.15);
  transition: 0.4s ease;
  animation: syncGlow 6s ease-in-out infinite alternate, goldPulse 12s infinite;
}

#shopify-section-how-it-works-steps .step:hover {
  transform: scale(1.03);
  border-color: rgba(255,215,0,0.6);
  box-shadow: 0 0 25px rgba(255,215,0,0.5);
}

/* Unified Glow (blue sync) */
@keyframes syncGlow {
  0% {
    filter: brightness(1);
    box-shadow: 0 0 10px rgba(46,143,255,0.25);
  }
  50% {
    filter: brightness(1.15);
    box-shadow: 0 0 30px rgba(46,143,255,0.45);
  }
  100% {
    filter: brightness(1);
    box-shadow: 0 0 10px rgba(46,143,255,0.25);
  }
}

/* Gold pulse - VIP shimmer */
@keyframes goldPulse {
  0%, 90% {
    filter: hue-rotate(0deg);
  }
  95% {
    filter: hue-rotate(35deg) brightness(1.3);
    box-shadow: 0 0 35px rgba(255,215,0,0.5);
  }
  100% {
    filter: hue-rotate(0deg);
  }
}
/* 🌙 إصلاح تراكب عناصر المينيو في نسخة الموبايل */
@media (max-width: 768px) {
  .header__menu-item {
    position: relative;
    z-index: 2;
  }

  .header__menu-item a {
    background: transparent !important;
    padding: 10px 0;
    display: block;
    font-size: 15px;
    color: #ffffff !important;
  }

  .header__menu-item a:hover {
    color: #00ffcc !important;
  }

  /* إزالة أي خلفية متدرجة تغطي النص */
  .header__menu-item::before,
  .header__menu-item::after {
    display: none !important;
  }

  /* تباعد إضافي بين العناصر */
  .header__menu {
    gap: 10px !important;
  }
}/* ✅ إصلاح تراكب العناصر + تأثير زجاجي متناسق مع StreamMax */
@media (max-width: 768px) {
  .header__menu {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 10px 0 !important;
  }

  .header__menu-item {
    position: relative !important;
    background: none !important;
    z-index: 2 !important;
  }

  .header__menu-item a {
    display: inline-block !important;
    padding: 8px 12px !important;
    background: transparent !important;
    border-radius: 6px !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    color: #ffffff !important;
    text-transform: uppercase !important;
    transition: 0.3s ease;
  }

  .header__menu-item a:hover {
    color: #00ffc8 !important;
    text-shadow: 0 0 8px rgba(0, 255, 200, 0.8);
  }

  .header__menu-item::before,
  .header__menu-item::after {
    display: none !important;
  }

  .header__icons,
  .header__actions {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
  }
}

/* 🌫️ تأثير زجاجي متدرّج على الهيدر أثناء السحب */
.header--sticky,
.shopify-section-header-sticky {
  backdrop-filter: blur(12px) saturate(150%) !important;
  -webkit-backdrop-filter: blur(12px) saturate(150%) !important;
  background: rgba(10, 15, 25, 0.65) !important;
  box-shadow: 0 0 20px rgba(0, 255, 200, 0.2);
  transition: background 0.4s ease, box-shadow 0.4s ease;
}

/* 🌈 عند تمرير الصفحة للأسفل، الإضاءة تزداد قليلاً */
.header--scrolled {
  background: rgba(15, 20, 35, 0.8) !important;
  box-shadow: 0 0 30px rgba(0, 255, 200, 0.3);
}/* ✅ إصلاح تراكب المينيو في اللغة الفرنسية والعربية فقط */
html[lang="fr"], 
html[lang="ar"] {
  /* نضبط المينيو باش العناصر ما يتراكبوش */
  .header__menu {
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 10px !important;
  }

  .header__menu-item {
    position: relative !important;
    z-index: 2 !important;
  }

  .header__menu-item a {
    display: inline-block !important;
    padding: 8px 10px !important;
    font-size: 15px !important;
    background: transparent !important;
    color: #ffffff !important;
  }

  /* نحيد الخلفيات المتدرجة اللي كتغطي النص */
  .header__menu-item::before,
  .header__menu-item::after {
    display: none !important;
  }

  /* نصوص الفرنسية والعربية كتكون وسطية أكثر */
  .header__menu-item a {
    text-align: center !important;
  }
}

/* 📱 نزيد ضبط للموبايل فقط */
@media (max-width: 768px) {
  html[lang="fr"] .header__menu,
  html[lang="ar"] .header__menu {
    flex-direction: row !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 12px !important;
  }
}/* 🌍 إصلاح الاتجاه RTL للقائمة في اللغة العربية فقط */
html[lang="ar"] .header__menu {
  direction: rtl !important;
  flex-direction: row-reverse !important;
  justify-content: center !important;
  gap: 12px !important;
}

html[lang="ar"] .header__menu-item a {
  text-align: right !important;
}

/* نحافظ على توازن الأيقونات مع اللوجو */
html[lang="ar"] .header__actions {
  flex-direction: row !important;
  justify-content: flex-start !important;
}

html[lang="ar"] .header__icons {
  flex/* 🌍 إصلاح اتجاه المينيو إلى اليمين تلقائياً إذا كانت اللغة العربية ظاهرة */
.header__menu:has(a:contains("العربية")),
.header__menu:has(a[lang="ar"]) {
  direction: rtl !important;
  flex-direction: row-reverse !important;
  justify-content: center !important;
  gap: 12px !important;
}

.header__menu:has(a:contains("العربية")) .header__menu-item a,
.header__menu:has(a[lang="ar"]) .header__menu-item a {
  text-align: right !important;
}

.header__actions:has(a:contains("العربية")),
.header__icons:has(a:contains("العربية")) {
  flex-direction: row-reverse !important;
}-direction: row-reverse !important;
}/* ✅ إصلاح الاتجاه RTL للمينيو في اللغة العربية (كل الحالات الممكنة) */

/* 1️⃣ إذا كان العنصر الرئيسي معرف بـ lang="ar" */
html[lang="ar"] .header__menu,
body[lang="ar"] .header__menu,
header[lang="ar"] .header__menu,
[data-lang="ar"] .header__menu {
  direction: rtl !important;
  flex-direction: row-reverse !important;
  justify-content: center !important;
  gap: 12px !important;
}

/* 2️⃣ تنسيق النصوص */
html[lang="ar"] .header__menu-item a,
body[lang="ar"] .header__menu-item a,
header[lang="ar"] .header__menu-item a,
[data-lang="ar"] .header__menu-item a {
  text-align: right !important;
  direction: rtl !important;
}

/* 3️⃣ توازن الأيقونات مع اللوجو */
html[lang="ar"] .header__actions,
body[lang="ar"] .header__actions,
[data-lang="ar"] .header__actions {
  flex-direction: row !important;
  justify-content: flex-start !important;
}

html[lang="ar"] .header__icons,
body[lang="ar"] .header__icons,
[data-lang="ar"] .header__icons {
  flex-direction: row-reverse !important;
}

/* 📱 في الموبايل */
@media (max-width: 768px) {
  html[lang="ar"] .header__menu,
  body[lang="ar"] .header__menu,
  header[lang="ar"] .header__menu,
  [data-lang="ar"] .header__menu {
    flex-direction: row-reverse !important;
    justify-content: center !important;
    gap: 10px !important;
  }
}/* 🔄 تحويل الاتجاه إلى RTL عندما تكون اللغة العربية مفعّلة */
.header__menu:has(a[href*="ar"]),
.header__menu:has(span:contains("العربية")),
.header__menu:has(button:contains("العربية")) {
  direction: rtl !important;
  flex-direction: row-reverse !important;
  justify-content: center !important;
  gap: 12px !important;
}

/* نصوص منسقة من اليمين */
.header__menu:has(a[href*="ar"]) .header__menu-item a,
.header__menu:has(span:contains("العربية")) .header__menu-item a {
  text-align: right !important;
  direction: rtl !important;
}

/* الأيقونات تبقى متوازنة */
.header__icons,
.header__actions {
  flex-direction: row-reverse !important;
  justify-content: flex-start !important;
}

/* 📱 في الموبايل */
@media (max-width: 768px) {
  .header__menu:has(a[href*="ar"]),
  .header__menu:has(span:contains("العربية")),
  .header__menu:has(button:contains("العربية")) {
    flex-direction: row-reverse !important;
    justify-content: center !important;
  }
}.bottom-icons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
}

.bottom-icons button {
  width: 42px;
  height: 42px;
  border: none;
  outline: none;
  border-radius: 8px;
  background: rgba(0, 255, 200, 0.15);
  backdrop-filter: blur(10px);
  box-shadow: 0 0 8px rgba(0, 255, 255, 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: 0.35s ease;
  cursor: pointer;
  animation: glowPulse 5s infinite ease-in-out;
}

.bottom-icons button:hover {
  transform: scale(1.08);
  background: rgba(0, 255, 255, 0.25);
  box-shadow: 0 0 15px rgba(0, 255, 255, 0.6);
}

.bottom-icons button.active {
  background: rgba(0, 255, 255, 0.35);
  box-shadow: 0 0 25px rgba(0, 255, 255, 0.8);
}

.bottom-icons svg {
  width: 18px;
  height: 18px;
  stroke: #fff;
  opacity: 0.9;
  transition: opacity 0.3s;
}

.bottom-icons button:hover svg {
  opacity: 1;
}

/* ⚡ أنميشن النبضة الضوئية */
@keyframes glowPulse {
  0%, 100% {
    box-shadow: 0 0 8px rgba(0, 255, 255, 0.25);
  }
  50% {
    box-shadow: 0 0 25px rgba(0, 255, 255, 0.7);
  }
}.bottom-icons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
}

.bottom-icons button {
  width: 42px;
  height: 42px;
  border: none;
  outline: none;
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(0,255,200,0.2), rgba(0,180,255,0.25));
  backdrop-filter: blur(10px);
  box-shadow: 0 0 10px rgba(0,255,255,0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  animation: glowPulse 5s infinite ease-in-out;
  transition: all 0.35s ease;
}

/* تأخير بسيط باش النبضات تكون بتناوب */
.bottom-icons button:nth-child(1) {
  animation-delay: 0s;
}
.bottom-icons button:nth-child(2) {
  animation-delay: 1s;
}
.bottom-icons button:nth-child(3) {
  animation-delay: 2s;
}

.bottom-icons button:hover {
  transform: scale(1.08);
  box-shadow: 0 0 18px rgba(0,255,255,0.6);
}

.bottom-icons button.active {
  background: rgba(0, 255, 255, 0.35);
  box-shadow: 0 0 25px rgba(0, 255, 255, 0.8);
}

.bottom-icons svg {
  width: 18px;
  height: 18px;
  stroke: #fff;
  opacity: 0.9;
  transition: opacity 0.3s;
}

.bottom-icons button:hover svg {
  opacity: 1;
}

@keyframes glowPulse {
  0%, 100% {
    box-shadow: 0 0 10px rgba(0,255,255,0.25);
  }
  50% {
    box-shadow: 0 0 25px rgba(0,255,255,0.8);
  }
}.bottom-icons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
}

.bottom-icons button {
  width: 42px;
  height: 42px;
  border: none;
  outline: none;
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(0,255,200,0.2), rgba(0,180,255,0.25));
  backdrop-filter: blur(10px);
  box-shadow: 0 0 10px rgba(0,255,255,0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  animation: glowPulse 5s infinite ease-in-out;
  transition: all 0.35s ease;
}

/* تأخير بسيط باش النبضات تكون بتناوب */
.bottom-icons button:nth-child(1) {
  animation-delay: 0s;
}
.bottom-icons button:nth-child(2) {
  animation-delay: 1s;
}
.bottom-icons button:nth-child(3) {
  animation-delay: 2s;
}

.bottom-icons button:hover {
  transform: scale(1.08);
  box-shadow: 0 0 18px rgba(0,255,255,0.6);
}

.bottom-icons button.active {
  background: rgba(0, 255, 255, 0.35);
  box-shadow: 0 0 25px rgba(0, 255, 255, 0.8);
}

.bottom-icons svg {
  width: 18px;
  height: 18px;
  stroke: #fff;
  opacity: 0.9;
  transition: opacity 0.3s;
}

.bottom-icons button:hover svg {
  opacity: 1;
}

@keyframes glowPulse {
  0%, 100% {
    box-shadow: 0 0 10px rgba(0,255,255,0.25);
  }
  50% {
    box-shadow: 0 0 25px rgba(0,255,255,0.8);
  }
}/* 🔹 تصحيح اتجاه النص للسعر بالعربية */
.pricing-card .price {
  direction: ltr !important;
  unicode-bidi: plaintext !important;
  font-weight: 700;
  font-size: 28px;
  color: #ff4040;
  text-align: center;
  margin: 0 auto 10px auto;
  display: block;
}

/* 🔹 زر "اطلب الآن" يبقى بنفس التناسق */
.pricing-card .btn-order {
  background: linear-gradient(90deg, #ff6600, #ff3c00);
  border-radius: 10px;
  color: #fff;
  font-weight: bold;
  padding: 10px 25px;
  text-align: center;
  transition: 0.3s ease;
}
.pricing-card .btn-order:hover {
  transform: scale(1.05);
  box-shadow: 0 0 15px rgba(255, 80, 0, 0.5);
}

/* 🔹 تحسين طفيف لتباعد العناصر */
.pricing-card ul {
  padding: 0 20px;
  list-style: none;
  text-align: right;
}/* 🔹 تصغير حجم الكتابة للسعر */
.pricing-card .price {
  direction: ltr !important;
  unicode-bidi: plaintext !important;
  font-weight: 600;
  font-size: 22px; /* 👈 هنا صغّرت الحجم */
  color: #ff4040;
  text-align: center;
  margin: 0 auto 8px auto;
  display: block;
  letter-spacing: 0.5px;
}/* 🔹 تنسيق السعر مع علامة الدولار فقط */
.pricing-card .price {
  direction: ltr !important;
  unicode-bidi: plaintext !important;
  font-weight: 700;
  font-size: 24px;
  color: #ff4040;
  text-align: center;
  margin: 0 auto 10px auto;
  display: flex;
  justify-content: center;
  align-items: baseline;
  gap: 4px;
}

/* 🔹 تصميم علامة الدولار بشكل أنيق */
.pricing-card .price::after {
  content: " $";
  font-size: 18px;
  color: #ff6b3d;
  font-weight: 600;
  opacity: 0.9;
}/* حذف كلمة دولارًا أمريكيًا والإبقاء على الرقم فقط */
.pricing-card .price {
  direction: ltr !important;
  unicode-bidi: plaintext !important;
  font-weight: 700;
  font-size: 26px;
  color: #ff4040;
  text-align: center;
}

/* إخفاء النص العربي "دولار" أو "أمريكي" إن وجد */
.pricing-card .price:lang(ar) {
  visibility: visible;
}
.pricing-card .price::after {
  content: "";
}
/* FAQ Accordion تحسين الألوان والتباعد */
.faq-accordion {
  background: rgba(10, 10, 35, 0.9);
  border-radius: 16px;
  padding: 10px 20px;
  backdrop-filter: blur(6px);
}

/* العناوين */
.faq-accordion summary {
  font-size: 1.1rem;
  font-weight: 600;
  color: #00d4ff;
  text-shadow: 0 0 8px rgba(0, 212, 255, 0.3);
  transition: color 0.3s ease;
}

.faq-accordion summary:hover {
  color: #6df3ff;
}

/* المحتوى */
.faq-accordion p {
  color: #d0eaff;
  font-size: 0.95rem;
  line-height: 1.6;
  padding-top: 8px;
}

/* رموز + و - */
.faq-accordion summary::marker {
  content: '';
}
.faq-accordion summary::after {
  content: '+';
  float: right;
  color: #00e0ff;
  transition: transform 0.3s ease;
}
.faq-accordion[open] summary::after {
  content: '−';
  transform: rotate(180deg);
}
<section class="faq-accordion">
  <h2 class="faq-title">Frequently Asked Questions</h2>

  <details>
    <summary>What types of devices are supported?</summary>
    <p>Our IPTV service works perfectly on Smart TVs, Android & iOS devices, Fire Stick, MAG, Enigma, DreamBox, Kodi, VLC, and all Android Boxes.</p>
  </details>

  <details>
    <summary>How long will it take to receive my IPTV login info?</summary>
    <p>You’ll receive your IPTV credentials instantly via email after your payment is confirmed. If you don’t see it, check your spam or promotions folder.</p>
  </details>

  <details>
    <summary>If my current subscription ends?</summary>
    <p>You can renew directly from your customer dashboard, or simply contact us via WhatsApp for a fast renewal process.</p>
  </details>

  <details>
    <summary>Is the content displayed in high quality?</summary>
    <p>Yes! All our streams are provided in HD, Full HD, and 4K where available — optimized for smooth performance on all supported devices.</p>
  </details>
</section>
.faq-accordion {
  max-width:800px;margin:40px auto;
  background:rgba(10,10,35,.9);
  border:1px solid rgba(0,212,255,.2);
  border-radius:16px;padding:25px;
  backdrop-filter:blur(8px);
}
.faq-title {
  text-align:center;color:#00e0ff;
  font-size:1.8rem;margin-bottom:20px;
  text-shadow:0 0 8px rgba(0,255,255,.3);
}
.faq-accordion details {
  background:rgba(15,20,60,.6);
  border-radius:10px;margin-bottom:10px;
  padding:15px;transition:.3s;
}
.faq-accordion details:hover {
  border-color:rgba(0,255,255,.3);
  box-shadow:0 0 12px rgba(0,255,255,.2);
}
.faq-accordion summary {
  color:#00d4ff;font-weight:600;
  cursor:pointer;position:relative;
  padding-right:20px;list-style:none;
}
.faq-accordion summary::after {
  content:'+';position:absolute;right:0;
  color:#00e0ff;transition:.3s;
}
.faq-accordion details[open] summary::after {
  content:'−';color:#00ffff;
}
.faq-accordion p {
  color:#d4f6ff;font-size:.95rem;
  line-height:1.6;margin-top:6px;
}
.stats-section {
  background: linear-gradient(135deg, #1b1a55, #2a1a8d);
  display: flex;
  justify-content: space-around;
  align-items: center;
  padding: 60px 0;
  color: white;
  text-align: center;
}

.stat-item i {
  font-size: 42px;
  color: #00ff9c;
  filter: drop-shadow(0 0 6px #00ff9c);
  margin-bottom: 10px;
  transition: transform 0.3s ease, filter 0.3s ease;
}

.stat-item:hover i {
  transform: scale(1.1);
  filter: drop-shadow(0 0 12px #00ff9c);
}

.stat-number {
  font-size: 2.5rem;
  font-weight: 800;
  background: linear-gradient(90deg, #00ff9c, #00d4ff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.stat-label {
  font-size: 1rem;
  color: rgba(255,255,255,0.8);
  margin-top: 4px;
}
<!-- 🌐 الشريط العلوي StreamMax -->
<div class="top-marquee glass-bar fade-in">
  {% case localization.language.iso_code %}
    {% when 'ar' %}
      <div class="marquee-content">
        🎬 استمتع بأفضل القنوات العالمية 🇲🇦📺 | ⚡ اشتراك <b>STREAMMAX</b> يمنحك تجربة مشاهدة بلا حدود | 🎁 عروض حصرية هذا الأسبوع فقط!
      </div>
    {% when 'fr' %}
      <div class="marquee-content">
        🎬 Profitez des meilleures chaînes internationales 🇫🇷📺 | ⚡ L’abonnement <b>STREAMMAX</b> vous offre un divertissement illimité | 🎁 Offres spéciales cette semaine !
      </div>
    {% else %}
      <div class="marquee-content">
        🎬 Enjoy the best international channels 🇺🇸📺 | ⚡ <b>STREAMMAX</b> subscription gives you unlimited entertainment | 🎁 Exclusive deals this week only!
      </div>
  {% endcase %}
</div>

<!-- 🌐 الشريط السفلي للأخبار أو التحديثات -->
<div class="bottom-marquee glass-bar-alt fade-in">
  {% case localization.language.iso_code %}
    {% when 'ar' %}
      <div class="marquee-content">
        📰 جديد هذا الأسبوع: تحديثات في سيرفرات القنوات الرياضية ⚽ | بث مباشر بجودة 4K 📡 | دعم فني 24/7 عبر واتساب 💬
      </div>
    {% when 'fr' %}
      <div class="marquee-content">
        📰 Nouveautés de la semaine : serveurs sportifs améliorés ⚽ | Diffusion en 4K 📡 | Support technique 24/7 sur WhatsApp 💬
      </div>
    {% else %}
      <div class="marquee-content">
        📰 This week’s updates: new sports servers ⚽ | 4K live streaming 📡 | 24/7 WhatsApp Support 💬
      </div>
  {% endcase %}
</div>

<style>
/* إعدادات عامة */
.top-marquee, .bottom-marquee {
  overflow: hidden;
  text-align: center;
  padding: 10px 0;
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  letter-spacing: 0.4px;
  position: relative;
  z-index: 9999;
}

/* ✨ الشريط العلوي */
.glass-bar {
  background: linear-gradient(120deg, rgba(0,255,255,0.25), rgba(0,80,255,0.25), rgba(0,255,150,0.25));
  background-size: 300% 300%;
  animation: gradientFlow 12s ease infinite, pulseGlow 5s ease-in-out infinite;
  backdrop-filter: blur(10px) saturate(180%);
  border-bottom: 1px solid rgba(0,255,255,0.15);
  box-shadow: 0 0 20px rgba(0,255,255,0.25);
}

/* 🟣 الشريط السفلي (لون بنفسجي غامق متدرج) */
.glass-bar-alt {
  background: linear-gradient(120deg, rgba(150,0,255,0.25), rgba(0,0,150,0.25), rgba(255,0,255,0.25));
  background-size: 300% 300%;
  animation: gradientFlowAlt 14s ease infinite, pulseGlowAlt 5s ease-in-out infinite;
  backdrop-filter: blur(10px) saturate(180%);
  border-top: 1px solid rgba(255,0,255,0.2);
  box-shadow: 0 0 20px rgba(180,0,255,0.25);
}

/* 💡 حركات التدرج والوميض */
@keyframes gradientFlow {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
@keyframes gradientFlowAlt {
  0% { background-position: 100% 50%; }
  50% { background-position: 0% 50%; }
  100% { background-position: 100% 50%; }
}
@keyframes pulseGlow {
  0%, 100% { box-shadow: 0 0 20px rgba(0,255,255,0.25); }
  50% { box-shadow: 0 0 45px rgba(0,255,255,0.6); }
}
@keyframes pulseGlowAlt {
  0%, 100% { box-shadow: 0 0 20px rgba(180,0,255,0.25); }
  50% { box-shadow: 0 0 45px rgba(255,0,255,0.6); }
}

/* 🔄 النصوص المتحركة */
.marquee-content {
  color: #e8faff;
  display: inline-block;
  white-space: nowrap;
  animation: scrollText 18s linear infinite;
  font-size: 15px;
  text-shadow: 0 0 8px rgba(255,255,255,0.25);
}
@keyframes scrollText {
  0% { transform: translateX(100%); }
  100% { transform: translateX(-100%); }
}

/* ⏸️ توقف عند المرور */
.top-marquee:hover .marquee-content,
.bottom-marquee:hover .marquee-content {
  animation-play-state: paused;
}

/* 🌫️ تأثير الظهور */
.fade-in {
  opacity: 0;
  transform: translateY(-12px);
  animation: fadeInSmooth 1.8s ease forwards;
}
@keyframes fadeInSmooth {
  to { opacity: 1; transform: translateY(0); }
}

/* 📱 متجاوب */
@media (max-width: 768px) {
  .marquee-content { font-size: 13px; }
}
</style>
<section class="setup-guide">
  <h2 class="setup-title">Setup Guide</h2>
  <p class="setup-desc">
    If you can't find your device, don't worry. We support all devices and all apps. 
    We will give you help. Simply contact us.
  </p>

  <div class="setup-tabs">
    <button class="tab active">WINDOWS / MACBOOK</button>
    <button class="tab">FIRE TV STICK</button>
    <button class="tab">ANDROID</button>
    <button class="tab">APPLE / IOS</button>
    <button class="tab">SMART TV</button>
    <button class="tab">APPLE TV</button>
    <button class="tab">MAG BOX</button>
  </div>

  <div class="setup-content">
    <h3 class="highlight-pulse">Windows method:</h3>
    <p>
      Download the IPTV Smarters app via this URL: 
      <a href="https://www.iptvsmarters.com/download?download=windows" target="_blank">
        https://www.iptvsmarters.com/download?download=windows
      </a>
    </p>

    <h3 class="highlight-pulse">MAC method:</h3>
    <p>
      Download the IPTV Smarters app via this URL: 
      <a href="https://www.iptvsmarters.com/download?download=mac" target="_blank">
        https://www.iptvsmarters.com/download?download=mac
      </a>
    </p>
  </div>

  <a href="https://wa.me/212600000000" class="whatsapp-icon" target="_blank">
    <img src="https://upload.wikimedia.org/wikipedia/commons/6/6b/WhatsApp.svg" alt="WhatsApp">
  </a>
</section>

<style>
/* ===== خلفية عامة ===== */
.setup-guide {
  background: radial-gradient(circle at center, #0a0a0f 0%, #000 100%);
  color: #e6fff9;
  text-align: center;
  padding: 60px 20px;
  font-family: 'Poppins', sans-serif;
  position: relative;
  overflow: hidden;
}

/* ===== العنوان ===== */
.setup-title {
  font-size: 42px;
  color: #00ffc6;
  text-shadow: 0 0 15px rgba(0,255,200,0.6);
  margin-bottom: 10px;
  animation: softPulse 6s infinite ease-in-out;
}

/* ===== الوصف ===== */
.setup-desc {
  font-size: 16px;
  color: #c8d5d0;
  margin-bottom: 35px;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

/* ===== الأزرار ===== */
.setup-tabs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  background: rgba(0,255,200,0.07);
  border-radius: 18px;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(0,255,200,0.25);
  box-shadow: 0 0 25px rgba(0,255,200,0.25);
  padding: 15px 10px;
  margin-bottom: 40px;
}

.setup-tabs .tab {
  background: linear-gradient(90deg, #00ffc6, #00aaff);
  border: none;
  color: #001010;
  font-weight: 600;
  border-radius: 10px;
  padding: 12px 25px;
  cursor: pointer;
  transition: all 0.3s ease;
  text-transform: uppercase;
}

.setup-tabs .tab:hover,
.setup-tabs .tab.active {
  background: linear-gradient(90deg, #00ffcc, #00ff88);
  box-shadow: 0 0 15px rgba(0,255,200,0.7);
  transform: translateY(-2px);
}

/* ===== المحتوى ===== */
.setup-content {
  background: rgba(0, 20, 20, 0.85);
  border: 1px solid rgba(0,255,200,0.25);
  border-radius: 20px;
  box-shadow: 0 0 30px rgba(0,255,200,0.2);
  padding: 35px;
  text-align: left;
  max-width: 900px;
  margin: auto;
  color: #dffef5;
  backdrop-filter: blur(8px);
}

.setup-content h3 {
  color: #00ffc6;
  font-size: 24px;
  margin-top: 20px;
  text-shadow: 0 0 10px rgba(0,255,200,0.6);
}

/* ===== الروابط ===== */
.setup-content a {
  color: #00ffcc;
  text-decoration: none;
  font-weight: 500;
}
.setup-content a:hover {
  text-decoration: underline dotted;
  text-shadow: 0 0 8px #00ffcc;
}

/* ===== أيقونة واتساب ===== */
.whatsapp-icon {
  position: fixed;
  bottom: 25px;
  left: 25px;
  width: 64px;
  height: 64px;
  z-index: 999;
  animation: glowPulse 5s infinite ease-in-out;
}
.whatsapp-icon img {
  width: 100%;
  height: 100%;
}

/* ===== تأثيرات أنيميشن ===== */
@keyframes glowPulse {
  0%, 100% { filter: drop-shadow(0 0 5px #00ffcc); }
  50% { filter: drop-shadow(0 0 15px #00ffcc); }
}

@keyframes softPulse {
  0%, 100% { text-shadow: 0 0 12px rgba(0,255,200,0.4); }
  50% { text-shadow: 0 0 22px rgba(0,255,200,0.8); }
}
</style>
.stream-topbar {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 38px;
  background: rgba(10, 20, 30, 0.45);
  backdrop-filter: blur(14px) saturate(180%);
  -webkit-backdrop-filter: blur(14px) saturate(180%);
  border-bottom: 1px solid rgba(0, 255, 150, 0.25);
  overflow: hidden;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 15px rgba(0, 255, 120, 0.15);
  animation: glowSync 10s infinite ease-in-out;
  transition: box-shadow 0.3s ease;
}

.scrolling-text {
  white-space: nowrap;
  color: #00ffae;
  font-size: 15px;
  font-weight: 500;
  animation: scrollLeft 25s linear infinite;
  padding-left: 100%;
  text-shadow: 0 0 10px rgba(0, 255, 170, 0.9);
}

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

@keyframes glowSync {
  0%, 100% {
    box-shadow: 0 0 15px rgba(0, 255, 120, 0.15);
    border-bottom-color: rgba(0, 255, 150, 0.25);
    filter: drop-shadow(0 0 0px rgba(0,255,150,0));
  }
  50% {
    box-shadow: 0 0 35px rgba(0, 255, 150, 0.75);
    border-bottom-color: rgba(0, 255, 170, 0.6);
    filter: drop-shadow(0 0 8px rgba(0,255,150,0.8));
  }
}

header .header__heading img,
.header__logo img,
.site-header__logo img {
  animation: glowSync 10s infinite ease-in-out !important;
  transition: filter 0.4s ease;
}.stream-topbar {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 38px;
  background: rgba(10, 20, 30, 0.45);
  backdrop-filter: blur(14px) saturate(180%);
  -webkit-backdrop-filter: blur(14px) saturate(180%);
  border-bottom: 1px solid rgba(0, 255, 150, 0.25);
  overflow: hidden;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 15px rgba(0, 255, 120, 0.15);
  animation: glowSync 10s infinite ease-in-out;
}

.scrolling-text {
  white-space: nowrap;
  color: #00ffae;
  font-size: 15px;
  font-weight: 500;
  animation: scrollLeft 25s linear infinite;
  padding-left: 100%;
  text-shadow: 0 0 10px rgba(0, 255, 170, 0.9);
}

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

@keyframes glowSync {
  0%, 100% {
    box-shadow: 0 0 15px rgba(0, 255, 120, 0.15);
    border-bottom-color: rgba(0, 255, 150, 0.25);
  }
  50% {
    box-shadow: 0 0 35px rgba(0, 255, 150, 0.75);
    border-bottom-color: rgba(0, 255, 170, 0.6);
  }
}

header .header__heading img,
.header__logo img,
.site-header__logo img {
  animation: glowSync 10s infinite ease-in-out !important;
  transition: filter 0.4s ease;
}
.header {
  background: linear-gradient(90deg, #001122 0%, #00d17d 50%, #001122 100%) !important;
  backdrop-filter: blur(8px) !important;
  border-bottom: 1px solid rgba(0,255,200,0.25) !important;
}

.header a,
.header .header__menu-item,
.header .localization-selector__item,
.header .icon {
  color: #e9fff9 !important;
  text-shadow: 0 0 8px rgba(0,255,200,0.4) !important;
  transition: color 0.3s ease;
}

.header a:hover,
.header .header__menu-item:hover {
  color: #00ffc8 !important;
}

.header .icon:hover {
  filter: drop-shadow(0 0 8px rgba(0,255,200,0.6)) !important;
}

.localization-selector__item {
  font-weight: 500 !important;
}
/* تحسين الخلفية العامة للهيدر */
.header {
  background: linear-gradient(90deg, #001122 0%, #00d17d 50%, #001122 100%) !important;
  backdrop-filter: blur(8px) !important;
  border-bottom: 1px solid rgba(0,255,200,0.25) !important;
  transition: background 0.5s ease, box-shadow 0.5s ease;
  box-shadow: 0 0 15px rgba(0,255,200,0.1);
}

/* النصوص والقوائم */
.header a,
.header .header__menu-item,
.header .localization-selector__item,
.header .icon {
  color: #e9fff9 !important;
  text-shadow: 0 0 8px rgba(0,255,200,0.3) !important;
  transition: color 0.3s ease, text-shadow 0.3s ease;
}

/* التأثير عند المرور */
.header a:hover,
.header .header__menu-item:hover {
  color: #00ffc8 !important;
  text-shadow: 0 0 12px rgba(0,255,200,0.6) !important;
}

/* الأيقونات */
.header .icon:hover {
  filter: drop-shadow(0 0 8px rgba(0,255,200,0.6)) !important;
}

/* اللغة */
.localization-selector__item {
  font-weight: 500 !important;
  color: #ccfff5 !important;
}

.localization-selector__item:hover {
  color: #00ffc8 !important;
}
/* ==== StreamMax Header Neon Glass Style ==== */
header-component .header__row--top {
  background: linear-gradient(90deg, #001122 0%, #00d17d 50%, #001122 100%) !important;
  backdrop-filter: blur(10px) !important;
  border-bottom: 1px solid rgba(0,255,200,0.25) !important;
  box-shadow: 0 0 15px rgba(0,255,200,0.2);
  transition: all 0.5s ease-in-out;
  z-index: 1000;
}

/* النصوص والقوائم */
header-component .header__row--top a,
header-component .header__row--top .header__menu-item,
header-component .header__row--top .localization-selector__item,
header-component .header__row--top .icon {
  color: #e9fff9 !important;
  text-shadow: 0 0 8px rgba(0,255,200,0.3) !important;
  transition: color 0.3s ease, text-shadow 0.3s ease;
}

/* تأثير عند المرور */
header-component .header__row--top a:hover,
header-component .header__row--top .header__menu-item:hover {
  color: #00ffc8 !important;
  text-shadow: 0 0 12px rgba(0,255,200,0.6) !important;
}

/* الأيقونات */
header-component .header__row--top .icon:hover {
  filter: drop-shadow(0 0 8px rgba(0,255,200,0.6)) !important;
}

/* اللغة */
header-component .header__row--top .localization-selector__item {
  font-weight: 500 !important;
  color: #ccfff5 !important;
}

header-component .header__row--top .localization-selector__item:hover {
  color: #00ffc8 !important;
}

/* تعديل على الشريط المتحرك باش يندمج مع الهيدر */
.stream-topbar {
  background: rgba(0, 255, 200, 0.08);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(0, 255, 200, 0.2);
  color: #bafff0;
  font-weight: 500;
  text-align: center;
  padding: 4px 0;
  animation: glowPulse 8s infinite ease-in-out;
}

@keyframes glowPulse {
  0%, 100% { box-shadow: 0 0 12px rgba(0,255,200,0.15); }
  50% { box-shadow: 0 0 25px rgba(0,255,200,0.4); }
}/* ===== StreamMax Header Fix - Text Visibility Override ===== */
header-component .header__row--top,
header-component .header__row--top .header__columns,
header-component .header__row--top .header__menu-item,
header-component .header__row--top .menu-list__link,
header-component .header__row--top .localization-selector__item,
header-component .header__row--top .icon {
  color: #eaffff !important;
  --color-foreground: #eaffff !important;
  --color-foreground-rgb: 234, 255, 255 !important;
  text-shadow: 0 0 8px rgba(0, 255, 200, 0.3) !important;
  transition: color 0.3s ease, text-shadow 0.3s ease;
}

header-component .header__row--top a:hover,
header-component .header__row--top .menu-list__link:hover {
  color: #00ffc8 !important;
  text-shadow: 0 0 12px rgba(0,255,200,0.6) !important;
}

header-component .header__row--top .header__menu-item:visited {
  color: #d0ffef !important;
}

/* ====== إعلان بنفسجي زجاجي متحرك ====== */
.announcement-bar {
  background: linear-gradient(90deg, rgba(140, 0, 255, 0.25), rgba(255, 0, 200, 0.25)) !important;
  backdrop-filter: blur(8px) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
  box-shadow: 0 2px 8px rgba(180, 0, 255, 0.25) !important;
  position: relative !important;
  z-index: 10 !important;
  animation: purplePulse 8s infinite ease-in-out !important;
}

@keyframes purplePulse {
  0%, 100% {
    background: linear-gradient(90deg, rgba(140, 0, 255, 0.25), rgba(255, 0, 200, 0.25));
    box-shadow: 0 2px 8px rgba(180, 0, 255, 0.25);
  }
  50% {
    background: linear-gradient(90deg, rgba(180, 0, 255, 0.35), rgba(255, 0, 220, 0.35));
    box-shadow: 0 0 15px rgba(200, 0, 255, 0.35);
  }
}

/* خلفية الهيدر الجديدة */
.header {
  background: linear-gradient(180deg, #001a33, #002b55); /* تدرّج أزرق تكنولوجي */
  box-shadow: 0 0 15px rgba(0, 255, 200, 0.2);
  height: 78px;
}
/* خلفية الهيدر بتدرج زجاجي ناعم */
.header {
  background: linear-gradient(120deg, rgba(0,255,180,0.15), rgba(0,120,255,0.15));
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(0,255,200,0.25);
  box-shadow: 0 0 20px rgba(0,255,200,0.15);
  transition: background 0.6s ease, box-shadow 0.6s ease;
}

/* نبضة ضوء متزامنة (glow pulse) كل 10 ثواني */
@keyframes headerGlow {
  0%, 100% { box-shadow: 0 0 15px rgba(0,255,200,0.15); }
  50% { box-shadow: 0 0 25px rgba(0,255,200,0.4); }
}
.header {
  animation: headerGlow 10s infinite ease-in-out;
}
/* 🔷 خلفية الهيدر بتدرج أزرق بنفسجي Cyber */
.header {
  background: linear-gradient(120deg, rgba(20, 15, 40, 0.9), rgba(0, 30, 80, 0.9));
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(120, 60, 255, 0.25);
  box-shadow: 0 0 25px rgba(100, 80, 255, 0.15);
  transition: background 0.6s ease, box-shadow 0.6s ease;
}

/* 💫 تأثير نبضة ضوء بنفسجي متناسق مع اللوجو */
@keyframes cyberGlow {
  0%, 100% { box-shadow: 0 0 15px rgba(120, 60, 255, 0.25); }
  50% { box-shadow: 0 0 30px rgba(0, 200, 255, 0.5); }
}
.header {
  animation: cyberGlow 10s infinite ease-in-out;
}

/* ✨ تلوين الروابط والنصوص داخل الهيدر */
.header__menu-item a {
  color: #d8e2ff !important;
  transition: 0.3s;
}
.header__menu-item a:hover {
  color: #00ccff !important;
  text-shadow: 0 0 10px rgba(0, 200, 255, 0.8);
}

/* 🧊 تأثير خفيف على اللوجو */
.header__heading-link img {
  transition: 0.4s ease;
  opacity: 0.95;
}
.header__heading-link:hover img {
  opacity: 1;
  filter: drop-shadow(0 0 10px rgba(0, 150, 255, 0.7));
}
