/** Shopify CDN: Minification failed

Line 627:11 Unexpected bad string token
Line 627:63 Unterminated string token
Line 976:1 Expected "}" to go with "{"

**/
/* ============================================================
   Avon Vacuums — Header / Navigation Brand Layer
   avon-nav.css

   PURPOSE
   Bring the header, main nav, dropdowns, mega-menu, and mobile
   drawer into the same brand system used by the rest of the site
   (defined in avon-custom.css). Replaces hardcoded hex values
   with --av-* tokens and overrides off-brand inline styles in
   header.liquid via higher-specificity selectors.

   Brand tokens consumed (from avon-custom.css :root):
   --av-navy, --av-blue, --av-gold, --av-gold-dark,
   --av-cream, --av-warm-gray, --av-text, --av-muted,
   --av-border, --av-serif, --av-shadow-sm, --av-shadow-md
   ============================================================ */


/* ──────────────────────────────────────────────────────────────
   1. TWO-ROW DESKTOP LAYOUT (unchanged from prior version)
   ────────────────────────────────────────────────────────────── */
@media (min-width: 769px) {

  .header__grid {
    flex-wrap: wrap;
    overflow: visible;
  }

  .header__grid .header__logo   { order: 1; }
  .header__grid .header__search { order: 2; }
  .header__grid .header__icons  { order: 3; }

  .header__grid main-menu,
  .header__grid .main-menu {
    order: 99;
    flex: 0 0 100%;
    width: 100%;
    border-top: 1px solid rgba(255, 255, 255, 0.10);
    background: rgba(0, 0, 0, 0.18);
    overflow: visible;
  }

  /* Container width matches .av-container (1200px) for site-wide
     alignment consistency with hero, section blocks, footer. */
  .header__grid .main-menu__content {
    max-width: 1200px;
    margin: 0 auto;
    padding-left:  24px;
    padding-right: 24px;
    box-sizing: border-box;
    width: 100%;
    justify-content: center;
    overflow: visible !important;
  }

  .header__grid .main-menu__content .main-nav {
    justify-content: center;
  }
}


/* ──────────────────────────────────────────────────────────────
   2. DROPDOWN Z-INDEX + OVERFLOW (unchanged)
   ────────────────────────────────────────────────────────────── */
.main-nav__item--dropdown.is-open > .main-nav__child,
.is-open > .main-nav__child {
  z-index: 100;
}

.main-nav__item--dropdown.is-open.is-visible > .main-nav__child,
.is-open.is-visible > .main-nav__child {
  z-index: 100;
  opacity: 1;
}

.cc-header--sticky .main-menu__content,
.cc-header .main-menu__content {
  overflow: visible !important;
}


/* ──────────────────────────────────────────────────────────────
   3. ANNOUNCEMENT BAR — match brand navy + gold link treatment
   Kills the inline <style data-shopify> background hardcode by
   targeting the same wrapper at higher specificity.
   ────────────────────────────────────────────────────────────── */
.cc-announcement,
.cc-announcement .announcement {
  background-color: var(--av-navy) !important;
  color: #fff;
}

.cc-announcement .announcement a {
  color: #fff;
  text-decoration: none;
  transition: color .2s ease;
  position: relative;
}

.cc-announcement .announcement a:hover {
  color: var(--av-gold);
}

.cc-announcement .announcement__text a {
  text-decoration: underline;
  text-underline-offset: 3px;
}

.cc-announcement .announcement__col--right > a:not(.no-spacer)::after {
  opacity: 0.45;
  padding: 0 14px;
}


/* ──────────────────────────────────────────────────────────────
   4. HEADER BAR — token-driven background + search treatment
   Overrides the off-brand --search-bg-color: #223b53 inline.
   ────────────────────────────────────────────────────────────── */
.cc-header,
store-header.header {
  background-color: var(--av-navy) !important;
}

/* Search input: transparent with cream-ish border instead of
   the muted slate currently hardcoded inline. Matches the
   "input on dark background" pattern used in .av-visit-shop. */
.header__search .search__input,
.header__search input[type="search"],
.header .search__form input {
  --search-bg-color: transparent !important;
  background-color: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(201, 169, 97, 0.35) !important;
  color: #fff !important;
  transition: border-color .2s ease, background-color .2s ease;
}

.header__search .search__input:focus,
.header__search input[type="search"]:focus,
.header .search__form input:focus {
  background-color: rgba(255, 255, 255, 0.10) !important;
  border-color: var(--av-gold) !important;
  outline: none;
  box-shadow: 0 0 0 1px var(--av-gold);
}

.header__search input::placeholder {
  color: rgba(255, 255, 255, 0.55) !important;
}

/* Product-type select inside the search bar */
.header__search .product-type-select,
.header__search .custom-select__btn {
  color: rgba(255, 255, 255, 0.85) !important;
  border-color: rgba(201, 169, 97, 0.35) !important;
}


/* ──────────────────────────────────────────────────────────────
   5. MAIN NAV TYPOGRAPHY — matches .av-btn / .av-eyebrow voice
   ────────────────────────────────────────────────────────────── */
@media (min-width: 769px) {
  .main-nav > .main-nav__item > .main-nav__link,
  .main-nav > .main-nav__item > a {
    color: rgba(255, 255, 255, 0.92) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    letter-spacing: 1px;
    text-transform: uppercase;
    padding: 16px 18px;
    position: relative;
    transition: color .2s ease;
  }

  .main-nav > .main-nav__item > .main-nav__link:hover,
  .main-nav > .main-nav__item > a:hover,
  .main-nav > .main-nav__item.is-open > .main-nav__link,
  .main-nav > .main-nav__item.is-open > a {
    color: var(--av-gold) !important;
  }

  /* Gold underline animation on hover/open */
  .main-nav > .main-nav__item > .main-nav__link::after,
  .main-nav > .main-nav__item > a::after {
    content: '';
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: 10px;
    height: 2px;
    background: var(--av-gold);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform .25s ease;
  }

  .main-nav > .main-nav__item:hover > .main-nav__link::after,
  .main-nav > .main-nav__item:hover > a::after,
  .main-nav > .main-nav__item.is-open > .main-nav__link::after,
  .main-nav > .main-nav__item.is-open > a::after {
    transform: scaleX(1);
  }
}


/* ──────────────────────────────────────────────────────────────
   6. PHONE CTA BUTTON — collapse the three-source inline style
   into one .av-btn--primary-shaped treatment.
   ────────────────────────────────────────────────────────────── */
.secondary-nav__cta,
.secondary-nav__cta--button,
.secondary-nav .secondary-nav__link.btn {
  background-color: var(--av-gold) !important;
  color: var(--av-navy) !important;
  border: 2px solid var(--av-gold) !important;
  border-radius: 0 !important;
  padding: 12px 22px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  transition: background-color .2s ease, border-color .2s ease !important;
  --cta-bg-color: 201 169 97;
  --cta-bg-hover-color: 184 151 90;
}

.secondary-nav__cta:hover,
.secondary-nav__cta--button:hover,
.secondary-nav .secondary-nav__link.btn:hover {
  background-color: var(--av-gold-dark) !important;
  border-color: var(--av-gold-dark) !important;
  color: var(--av-navy) !important;
}

.secondary-nav__cta svg,
.secondary-nav__cta--button svg {
  fill: var(--av-navy) !important;
  stroke: var(--av-navy) !important;
}


/* ──────────────────────────────────────────────────────────────
   7. HEADER ICONS — cart, account — unified white with gold hover
   ────────────────────────────────────────────────────────────── */
.header__icons a,
.header__icons button {
  color: #fff;
  transition: color .2s ease;
}

.header__icons a:hover,
.header__icons button:hover {
  color: var(--av-gold);
}

/* Cart badge — gold pill, navy number (matches .av-auth-badge) */
#cart-icon-bubble .cart-count,
.header__icons .cart-count {
  background-color: var(--av-gold) !important;
  color: var(--av-navy) !important;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.5px;
}


/* ──────────────────────────────────────────────────────────────
   8. DROPDOWN PANELS — match the .av-card system
   Cream background, av-border, av-shadow-md, navy text.
   ────────────────────────────────────────────────────────────── */
@media (min-width: 769px) {
  .main-nav__child,
  .mega-nav,
  .main-nav__item--dropdown > .main-nav__child {
    background-color: var(--av-cream) !important;
    border: 1px solid var(--av-border) !important;
    border-top: 3px solid var(--av-gold) !important;
    border-radius: 0 !important;
    box-shadow: var(--av-shadow-md) !important;
    padding: 24px 28px !important;
    color: var(--av-navy);
  }

  /* Dropdown link items */
  .main-nav__child .main-nav__item,
  .main-nav__child .child-nav__item,
  .main-nav__child a {
    color: var(--av-navy);
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.3px;
    text-transform: none;
    transition: color .15s ease;
  }

  .main-nav__child .main-nav__item:hover,
  .main-nav__child .child-nav__item:hover,
  .main-nav__child a:hover {
    color: var(--av-gold-dark) !important;
  }

  /* Grandchild section headings (column titles) */
  .mega-nav__column-title,
  .main-nav__grandchild-title,
  .child-nav__title,
  .main-nav__link--featured {
    color: var(--av-navy) !important;
    font-family: var(--av-serif);
    font-size: 14px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--av-border);
    margin-bottom: 10px;
  }
}


/* ──────────────────────────────────────────────────────────────
   9. MEGA-MENU COLUMNS — image tiles + promo panel
   Promo panel now uses tokens (was hardcoded hex).
   ────────────────────────────────────────────────────────────── */
.mega-nav--columns .child-nav__image-wrap {
  aspect-ratio: 16 / 9;
  border-radius: 0;          /* match flat brand style */
  overflow: hidden;
  border: 1px solid var(--av-border);
}

.mega-nav--columns .child-nav__image-wrap img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: transform 0.3s ease;
}

.mega-nav--columns .child-nav__item:hover .child-nav__image-wrap img {
  transform: scale(1.04);
}

/* Promo panel — token-driven, flat, matches .av-brand-tile */
.mega-nav--columns .child-promos {
  background: var(--av-navy);
  border-radius: 0;           /* was 10px */
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 280px;
  border: 1px solid var(--av-navy);
}

.mega-nav--columns .child-promos .menu-promo__heading {
  color: var(--av-gold);
  font-family: var(--av-serif);
  font-weight: 700;
}

.mega-nav--columns .child-promos .menu-promo__text {
  color: rgba(255, 255, 255, 0.75);
  font-size: 14px;
  line-height: 1.55;
}

/* Promo CTA — matches .av-btn--primary */
.mega-nav--columns .child-promos .menu-promo__btn,
.mega-nav--columns .child-promos .promo a.btn,
.mega-nav--columns .child-promos .promo__content a {
  background: var(--av-gold);
  color: var(--av-navy);
  border: 2px solid var(--av-gold);
  border-radius: 0;           /* was 6px */
  padding: 10px 20px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  transition: background-color .2s ease, border-color .2s ease;
}

.mega-nav--columns .child-promos .menu-promo__btn:hover,
.mega-nav--columns .child-promos .promo a.btn:hover,
.mega-nav--columns .child-promos .promo__content a:hover {
  background: var(--av-gold-dark);
  border-color: var(--av-gold-dark);
  color: var(--av-navy);
}


/* ──────────────────────────────────────────────────────────────
   10. MOBILE DRAWER — cream panel with navy text + gold accents
   Replaces generic theme drawer styling so mobile menu looks
   like the rest of the site, not a default Shopify drawer.
   ────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .menu-drawer,
  .main-menu__content[aria-hidden="false"],
  store-header.header.is-menu-open .main-menu__content {
    background-color: var(--av-cream) !important;
    color: var(--av-navy) !important;
    border-top: 3px solid var(--av-gold) !important;
  }

  /* Mobile nav links */
  .menu-drawer .main-nav__item,
  .menu-drawer .main-nav__link,
  .main-menu__content .main-nav__item,
  .main-menu__content .main-nav__link {
    color: var(--av-navy) !important;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.5px;
    border-bottom: 1px solid var(--av-border);
    padding: 16px 20px;
  }

  .menu-drawer .main-nav__item:hover,
  .menu-drawer .main-nav__link:hover {
    color: var(--av-gold-dark) !important;
    background: rgba(201, 169, 97, 0.06);
  }

  /* Mobile drawer toggle/back buttons */
  .menu-drawer .main-nav__toggle-btn,
  .menu-drawer .main-menu__back {
    color: var(--av-navy) !important;
  }

  /* Mobile drawer close X */
  .menu-drawer__close,
  .main-menu__close {
    color: var(--av-navy) !important;
  }

  /* Mobile announcement links inside the drawer */
  .mob__announcement-links a {
    color: var(--av-navy) !important;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.5px;
  }

  .mob__announcement-links a:hover {
    color: var(--av-gold-dark) !important;
  }

  /* Mobile search bar inside the drawer reverts to a normal
     light-background field (we're now on cream, not navy) */
  .menu-drawer .header__search input,
  .menu-drawer .search__input {
    background-color: #fff !important;
    border-color: var(--av-border) !important;
    color: var(--av-text) !important;
  }

  .menu-drawer .header__search input::placeholder {
    color: var(--av-muted) !important;
  }
}


/* ──────────────────────────────────────────────────────────────
   11. NAV BADGES — token-driven (currently uses inline RGB hex)
   ────────────────────────────────────────────────────────────── */
@media (min-width: 769px) {
  .main-nav__badge--1,
  .main-nav__badge--2,
  .main-nav__badge--3 {
    background-color: var(--av-gold) !important;
    color: var(--av-navy) !important;
    font-size: 10px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 0;
    margin-inline-start: 6px;
  }
}


/* ──────────────────────────────────────────────────────────────
   12. SECOND-ROW STRIP UNDER LOGO — subtle, on-brand divider
   The row-2 background tint changes from generic black/18%
   to a navy-on-navy treatment that reads as one piece.
   ────────────────────────────────────────────────────────────── */
@media (min-width: 769px) {
  .header__grid main-menu,
  .header__grid .main-menu {
    background: rgba(255, 255, 255, 0.03) !important;
    border-top: 1px solid rgba(201, 169, 97, 0.18) !important;
  }
}


/* ============================================================
   13. MOBILE OVERHAUL — Premium Dealer Layer (2026-06)

   PURPOSE
   Full mobile usability pass for screens under 769px. Brings
   the small-screen experience up to the same "clean premium
   dealer" standard as the desktop brand work above: a sticky
   compact header, comfortable 44px+ tap targets, a refined
   drawer menu, calmer section rhythm, and showroom-quality
   product cards and buy buttons.

   All selectors verified against header.liquid, theme.liquid,
   and product-card.liquid in this theme (Enterprise 2.3.0).
   Token fallbacks included so this layer is self-sufficient.
   ============================================================ */

@media (max-width: 768.98px) {

  /* ──────────────────────────────────────────────
     13.1 FOUNDATIONS — touch, type, focus
     ────────────────────────────────────────────── */
  html {
    -webkit-text-size-adjust: 100%;
    scroll-padding-top: 84px; /* clears the sticky header on anchor jumps */
  }

  body {
    -webkit-tap-highlight-color: rgba(201, 169, 97, 0.18);
  }

  /* Inputs at 16px+ prevent iOS auto-zoom on focus */
  input,
  select,
  textarea,
  .search__input {
    font-size: 16px !important;
  }

  /* Every button is a real thumb target */
  .btn {
    min-height: 48px;
    --btn-padding-y: 14px;
  }

  /* Visible, on-brand keyboard/switch focus */
  a:focus-visible,
  button:focus-visible,
  input:focus-visible,
  [tabindex]:focus-visible {
    outline: 2px solid var(--av-gold, #c9a961);
    outline-offset: 2px;
  }

  h1, .h1, h2, .h2 {
    line-height: 1.15;
    overflow-wrap: break-word;
  }

  /* ──────────────────────────────────────────────
     13.2 ANNOUNCEMENT BAR — quiet, single-line
     ────────────────────────────────────────────── */
  .cc-announcement .announcement {
    font-size: 12px;
    letter-spacing: 0.4px;
    text-align: center;
    padding-top: 8px;
    padding-bottom: 8px;
  }

  .cc-announcement .announcement__text {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* The "Our Promise / Visit Us" quick links live in the
     drawer on mobile — hide the cramped top-bar copies */
  .cc-announcement .announcement__col--right {
    display: none;
  }

  /* ──────────────────────────────────────────────
     13.3 STICKY COMPACT HEADER
     The announcement scrolls away; the navy brand bar
     (logo, burger, search, cart) stays with the shopper.
     ────────────────────────────────────────────── */
  .cc-header,
  store-header.header {
    position: sticky;
    top: 0;
    z-index: 60;
    box-shadow: 0 2px 14px rgba(10, 37, 64, 0.28);
  }

  .header__grid {
    align-items: center;
    column-gap: 4px;
    padding-top: 8px;
    padding-bottom: 8px;
  }

  /* Logo: prominent but compact */
  .header__logo {
    max-width: 152px;
  }

  .header__logo img {
    max-width: 100%;
    height: auto;
  }

  /* Burger + header icons: 44px minimum touch area,
     unified white-on-navy with gold feedback */
  [class*="menu__toggle"],
  .header__icons a,
  .header__icons button {
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
  }

\n   dealer" standard as the desktop brand work above: a sticky
   compact header, comfortable 44px+ tap targets, a refined
   drawer menu, calmer section rhythm, and showroom-quality
   product cards and buy buttons.

   All selectors verified against header.liquid, theme.liquid,
   and product-card.liquid in this theme (Enterprise 2.3.0).
   Token fallbacks included so this layer is self-sufficient.
   ============================================================ */

@media (max-width: 768.98px) {

  /* ──────────────────────────────────────────────
     13.1 FOUNDATIONS — touch, type, focus
     ────────────────────────────────────────────── */
  html {
    -webkit-text-size-adjust: 100%;
    scroll-padding-top: 84px; /* clears the sticky header on anchor jumps */
  }

  body {
    -webkit-tap-highlight-color: rgba(201, 169, 97, 0.18);
  }

  /* Inputs at 16px+ prevent iOS auto-zoom on focus */
  input,
  select,
  textarea,
  .search__input {
    font-size: 16px !important;
  }

  /* Every button is a real thumb target */
  .btn {
    min-height: 48px;
    --btn-padding-y: 14px;
  }

  /* Visible, on-brand keyboard/switch focus */
  a:focus-visible,
  button:focus-visible,
  input:focus-visible,
  [tabindex]:focus-visible {
    outline: 2px solid var(--av-gold, #c9a961);
    outline-offset: 2px;
  }

  h1, .h1, h2, .h2 {
    line-height: 1.15;
    overflow-wrap: break-word;
  }

  /* ──────────────────────────────────────────────
     13.2 ANNOUNCEMENT BAR — quiet, single-line
     ────────────────────────────────────────────── */
  .cc-announcement .announcement {
    font-size: 12px;
    letter-spacing: 0.4px;
    text-align: center;
    padding-top: 8px;
    padding-bottom: 8px;
  }

  .cc-announcement .announcement__text {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* The "Our Promise / Visit Us" quick links live in the
     drawer on mobile — hide the cramped top-bar copies */
  .cc-announcement .announcement__col--right {
    display: none;
  }

  /* ──────────────────────────────────────────────
     13.3 STICKY COMPACT HEADER
     The announcement scrolls away; the navy brand bar
     (logo, burger, search, cart) stays with the shopper.
     ────────────────────────────────────────────── */
  .cc-header,
  store-header.header {
    position: sticky;
    top: 0;
    z-index: 60;
    box-shadow: 0 2px 14px rgba(10, 37, 64, 0.28);
  }

  .header__grid {
    align-items: center;
    column-gap: 4px;
    padding-top: 8px;
    padding-bottom: 8px;
  }

  /* Logo: prominent but compact */
  .header__logo {
    max-width: 152px;
  }

  .header__logo img {
    max-width: 100%;
    height: auto;
  }

  /* Burger + header icons: 44px minimum touch area,
     unified white-on-navy with gold feedback */
  [class*="menu__toggle"],
  .header__icons a,
  .header__icons button {
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
  }

  [class*="menu__toggle"]:active,
  .header__icons a:active,
  .header__icons button:active {
    color: var(--av-gold, #c9a961);
  }

  /* ──────────────────────────────────────────────
     13.4 SEARCH — full-width, comfortable field
     ────────────────────────────────────────────── */
  .header__search {
    flex: 0 0 100%;
    width: 100%;
    padding-top: 2px;
    padding-bottom: 10px;
  }

  .header__search .search__input,
  .header__search input[type="search"] {
    min-height: 46px;
    border-radius: 0 !important;
    padding-left: 14px;
  }

  .header__search .search__form button[type="submit"],
  .header__search .search__form button {
    min-width: 44px;
    min-height: 44px;
  }

  /* ──────────────────────────────────────────────
     13.5 TRUST STRIP — compact credentials row
     (icons-with-text directly under the header)
     ────────────────────────────────────────────── */
  .shopify-section[id$="__trust"] {
    font-size: 12px;
    letter-spacing: 0.2px;
  }

  .shopify-section[id$="__trust"] svg {
    width: 18px;
    height: 18px;
  }

  .shopify-section[id$="__trust"] a {
    min-height: 40px;
    display: inline-flex;
    align-items: center;
  }

  /* ──────────────────────────────────────────────
     13.6 MOBILE DRAWER MENU — showroom directory
     Builds on the cream/navy/gold drawer in section 10:
     taller rows, clear chevrons, easy thumb reach.
     ────────────────────────────────────────────── */
  .menu-drawer .main-nav__item,
  .menu-drawer .main-nav__link,
  .main-menu__content .main-nav__item,
  .main-menu__content .main-nav__link {
    min-height: 54px;
    display: flex;
    align-items: center;
    font-size: 16px;
    line-height: 1.3;
  }

  /* Submenu chevron / back / close: full tap targets */
  .menu-drawer .main-nav__toggle-btn,
  .main-menu__content .main-nav__toggle-btn {
    min-width: 54px;
    min-height: 54px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .menu-drawer .main-menu__back,
  .menu-drawer__close,
  .main-menu__close {
    min-height: 48px;
    min-width: 48px;
    font-weight: 600;
  }

  /* Child (sub-menu) links: indented, lighter weight,
     so the hierarchy reads at a glance */
  .menu-drawer .main-nav__child .main-nav__link,
  .main-menu__content .main-nav__child .main-nav__link {
    font-size: 15px;
    font-weight: 500;
    padding-left: 32px;
  }

  /* Phone CTA repeated inside the drawer: full-width,
     unmissable — the number one action for a local service store */
  .menu-drawer .secondary-nav__cta,
  .main-menu__content .secondary-nav__cta,
  .menu-drawer .secondary-nav__cta--button,
  .main-menu__content .secondary-nav__cta--button {
    display: flex !important;
    width: calc(100% - 40px);
    margin: 16px 20px;
    justify-content: center;
    min-height: 50px;
  }

  /* Quick links block inside the drawer */
  .mob__announcement-links a {
    min-height: 46px;
    display: inline-flex;
    align-items: center;
  }

  /* ──────────────────────────────────────────────
     13.7 PAGE RHYTHM — calmer, tighter sections
     ────────────────────────────────────────────── */
  :root {
    --section-gap: 36;
    --heading-gap: 24px;
    --grid-column-gap: 12px;
  }

  /* ──────────────────────────────────────────────
     13.8 PRODUCT CARDS — clean showroom tiles
     ────────────────────────────────────────────── */
  .card--product .card__media .media {
    background-color: #fff;
  }

  .card--product .card__vendor {
    font-size: 11px;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: var(--av-muted, #6b7280);
  }

  .card--product .card__title {
    font-size: 14px;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .card--product .card__subtitle {
    font-size: 12px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .card--product .price {
    font-size: 15px;
    font-weight: 700;
    color: var(--av-navy, #0a2540);
  }

  /* Floating quick-add icon: gold disc, navy mark —
     reads as a deliberate brand accent, not a default */
  .card__quick-add .btn--primary {
    --btn-bg-color: 201 169 97;
    --btn-bg-hover-color: 184 151 90;
    --btn-text-color: 10 37 64;
    box-shadow: 0 2px 10px rgba(10, 37, 64, 0.22);
  }

  /* ──────────────────────────────────────────────
     13.9 PRODUCT PAGE — confident buy area
     ────────────────────────────────────────────── */
  .js-product-form .btn,
  .btn[name="add"],
  form[action*="/cart/add"] .btn {
    width: 100%;
    min-height: 54px;
    font-size: 15px;
    letter-spacing: 0.6px;
  }

  .shopify-payment-button__button {
    min-height: 54px !important;
    border-radius: var(--btn-border-radius, 0) !important;
  }

  input[name="quantity"] {
    min-height: 48px;
  }

  quantity-input button,
  .qty-input button {
    min-width: 44px;
    min-height: 44px;
  }

  /* ──────────────────────────────────────────────
     13.10 IMAGES + OVERFLOW GUARDS
     ────────────────────────────────────────────── */
  img,
  svg,
  video {
    max-width: 100%;
  }

  .rte table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* Extra-small phones: give content room to breathe */
@media (max-width: 400px) {
  .header__logo {
    max-width: 132px;
  }

  .cc-announcement .announcement {
    font-size: 11px;
  }
}

/* Respect reduced-motion preferences site-wide */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}