/** Shopify CDN: Minification failed

Line 2673:18 Unexpected "{"
Line 2673:27 Expected ":"
Line 2673:33 Unexpected ","
Line 2847:31 Unexpected "*"
Line 3265:33 Unexpected "*"

**/
/*
 * FLAIO "Lumina" Design System
 * Custom CSS overrides for Shopify Dawn theme
 * Focus: Light, Movement, Performance, Luxury
 * 
 * NOTE: These styles use !important to ensure they override Dawn's defaults
 */

/* ================================
   0. GLOBAL SMOOTH SCROLL
   ================================ */
html {
  scroll-behavior: smooth !important;
}

/* ================================
   1. CSS CUSTOM PROPERTIES
   ================================ */
:root {
  /* Enable light/dark mode for native UI elements */
  color-scheme: light dark;
  
  /* FLAIO Color Palette */
  --flaio-bg-primary: #faf8f5;
  --flaio-bg-secondary: #f3efe9;
  --flaio-bg-dark: #3d3630;
  --flaio-text-primary: #3d3630;
  --flaio-text-secondary: #8c7e70;
  --flaio-text-inverse: #faf8f5;
  --flaio-accent: #c9a961;
  --flaio-accent-light: #e6dace;
  --flaio-border: rgba(61, 54, 48, 0.1);
  
  /* Override Dawn's color variables */
  --color-background: 250, 248, 245 !important;
  --color-foreground: 61, 54, 48 !important;
  --gradient-background: #faf8f5 !important;
}

/* ================================
   2. TYPOGRAPHY - FORCE GOOGLE FONTS
   ================================ */

/* Override Shopify's font variables to prevent font flash */
/* These ensure serif fallback while Google Fonts load */
:root {
  --font-heading-family: 'Cormorant Garamond', 'Georgia', 'Times New Roman', serif !important;
  --font-body-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
}

/* Force Shopify theme font variables to our fonts */
body {
  --font-heading-family: 'Cormorant Garamond', 'Georgia', 'Times New Roman', serif !important;
  --font-body-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
}

/* Body text - Inter */
body,
.button,
.button-label,
.shopify-challenge__button,
.customer button,
input,
textarea,
select,
.field__input,
.select__select,
.caption,
.caption-large,
.caption-with-letter-spacing {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}

/* Headings - Cormorant Garamond (Quiet Luxury Typography) */
h1, h2, h3, h4, h5, h6,
.h0, .h1, .h2, .h3, .h4, .h5,
.hxl, .hxxl,
.header__heading-link .h2,
.header__heading-link,
.card__heading,
.card__heading a,
.full-unstyled-link,
.title,
.title-wrapper-with-link .title,
.banner__heading,
.image-banner__heading,
.rich-text__heading,
.collection-hero__title,
.product__title,
.featured-collection .title {
  font-family: 'Cormorant Garamond', Georgia, 'Times New Roman', serif !important;
  font-weight: 400 !important;
}

/* Quiet Luxury: Product Title Line Height */
.product__title,
.product__title h1,
.product__title h2,
.card__heading,
h1.h1,
h2.h1 {
  line-height: 1.1 !important;
}

/* Quiet Luxury: 2px Letter Spacing on Add to Cart Button */
.product-form__submit,
.product-form__submit span,
button[name="add"],
.btn--add-to-cart,
#ProductSubmitButton span {
  letter-spacing: 0.2em !important;
}

/* ================================
   3. GLOBAL BACKGROUND & COLORS
   ================================ */

html,
body,
.gradient,
.color-scheme-1 {
  background-color: var(--flaio-bg-primary) !important;
  background: var(--flaio-bg-primary) !important;
}

.color-scheme-2 {
  background-color: var(--flaio-bg-secondary) !important;
  background: var(--flaio-bg-secondary) !important;
}

body {
  color: var(--flaio-text-primary) !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Edge-to-edge sections - remove horizontal padding */
main#MainContent {
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.shopify-section > .gradient,
.shopify-section > .color-scheme-1,
.shopify-section > .color-scheme-2 {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* ================================
   4. HEADER STYLING
   ================================ */

/* Remove announcement bar completely via CSS */
.announcement-bar-section,
.utility-bar,
.shopify-section-announcement-bar {
  display: none !important;
}

/* Header wrapper - smaller height */
.header-wrapper {
  background: rgba(250, 248, 245, 0.92) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.04) !important;
}

.header-wrapper--border-bottom {
  border-bottom: 1px solid rgba(0, 0, 0, 0.04) !important;
}

/* Header wrapper - sticky and above hero */
.section-header,
.header-wrapper {
  position: sticky !important;
  top: 0 !important;
  z-index: 100 !important;
  background-color: rgb(var(--color-background)) !important;
}

/* Header padding - taller bar on desktop */
.header {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
  position: relative !important;
}

@media screen and (min-width: 990px) {
  .header {
    padding-top: 16px !important;
    padding-bottom: 16px !important;
  }
}

/* Header container */
.header.page-width {
  max-width: 1400px !important;
  position: relative !important;
}

/* Logo text styling - matches mobile */
/* Georgia fallback chosen for similar letterforms to Cormorant */
.header__heading-link,
.header__heading-link .h2 {
  font-family: 'Cormorant Garamond', 'Georgia', 'Times New Roman', serif !important;
  font-size: 28px !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  font-weight: 400 !important;
  white-space: nowrap !important;
  color: var(--flaio-text-primary) !important;
}

/* HIDE THE ACCOUNT/PERSON ICON */
.header__icon--account,
a.header__icon[href*="/account"],
.header a[href*="/account/login"],
.header--has-account .header__icon--account {
  display: none !important;
}

/* HIDE HAMBURGER MENU ON ALL DEVICES */
header-drawer,
.header__icon--menu,
.menu-drawer-container,
.header__icon--menu[aria-controls="menu-drawer"] {
  display: none !important;
  visibility: hidden !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
}

/* Reorder header icons - search on far right */
.header__icons {
  display: flex !important;
  flex-direction: row-reverse !important;
  align-items: center !important;
  gap: 4px !important;
}

/* Search icon should be first (rightmost after row-reverse) */
details-modal.header__search,
.header__search {
  order: 0 !important;
}

/* Always show search icon in header icons area (override base.css hiding rules) */
.header:not(.header--has-menu) * > .header__search,
.header__icons .header__search {
  display: inline-flex !important;
}

/* Cart icon second from right */
.header__icon--cart,
#cart-icon-bubble {
  order: -1 !important;
}

/* Cart and search icon sizing - consistent 22px */
.header__icon .svg-wrapper,
.header__icon--cart .svg-wrapper,
#cart-icon-bubble .svg-wrapper,
.header__search .svg-wrapper {
  width: 22px !important;
  height: 22px !important;
}

.header__icon svg,
.header__icon--cart svg,
#cart-icon-bubble svg,
.header__search svg {
  width: 100% !important;
  height: 100% !important;
  stroke-width: 1.5 !important;
}

/* Cart count bubble - gold circle floating on top-right */
.cart-count-bubble {
  position: absolute !important;
  top: 4px !important;
  right: 8px !important;
  left: auto !important;
  bottom: auto !important;
  background-color: var(--flaio-accent, #c9a961) !important;
  color: #ffffff !important;
  height: 16px !important;
  width: 16px !important;
  min-width: 16px !important;
  border-radius: 50% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  font-family: 'Inter', sans-serif !important;
  line-height: 1 !important;
  z-index: 10 !important;
  pointer-events: none !important;
}

.cart-count-bubble:empty {
  display: flex !important;
}

#cart-icon-bubble {
  position: relative !important;
}

/* Desktop navigation - centered and ALWAYS horizontal at 750px+ */
@media screen and (min-width: 750px) {
  .header__inline-menu {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: static !important;
    transform: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
    z-index: 10 !important;
    grid-area: navigation !important;
  }
  
  /* Override header grid to give navigation its own area */
  .header.header--has-menu {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 40px !important;
  }
  
  .header.header--has-menu .header__heading {
    flex-shrink: 0 !important;
  }
  
  .header.header--has-menu .header__inline-menu {
    flex: 1 !important;
    display: flex !important;
    justify-content: center !important;
  }
  
  .header.header--has-menu .header__icons {
    flex-shrink: 0 !important;
  }
  
  .header__inline-menu .list-menu,
  .header__inline-menu .list-menu--inline,
  .header__inline-menu > ul {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 50px !important;
    justify-content: center !important;
    align-items: center !important;
  }
  
  .header__inline-menu .list-menu__item,
  .header__inline-menu > ul > li {
    display: flex !important;
    visibility: visible !important;
    flex-direction: row !important;
    white-space: nowrap !important;
  }
  
  .header__inline-menu .header__menu-item,
  .header__inline-menu a {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    white-space: nowrap !important;
  }
}

/* Navigation menu items */
.header__menu-item,
.header__menu-item span,
.list-menu__item,
.header__inline-menu .list-menu__item {
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.2em !important;
  color: var(--flaio-text-secondary) !important;
  font-weight: 500 !important;
  text-decoration: none !important;
}

.header__inline-menu a,
.header__inline-menu .header__menu-item {
  text-decoration: none !important;
}

.header__menu-item:hover,
.header__menu-item:hover span,
.list-menu__item:hover {
  color: var(--flaio-text-primary) !important;
}

/* Nav link underline on hover */
.header__menu-item span {
  position: relative;
}

.header__menu-item span::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 1px;
  background: var(--flaio-accent);
  transition: width 0.3s ease;
}

.header__menu-item:hover span::after {
  width: 100%;
}

/* Header icons - base styling */
.header__icon,
.header__icon svg,
.header__icon .icon {
  color: var(--flaio-text-primary) !important;
  stroke: var(--flaio-text-primary) !important;
}

.header__icon:hover {
  opacity: 0.7;
}

/* Search icon (viewBox 18x19) */
.header__search .svg-wrapper {
  width: 24px !important;
  height: 24px !important;
}
.header__search .icon-search,
.header__search svg {
  width: 100% !important;
  height: 100% !important;
}

/* ================================
   5. BUTTONS
   ================================ */

.button,
.shopify-challenge__button,
.customer button,
button.shopify-payment-button__button--unbranded {
  border-radius: 40px !important;
  padding: 14px 28px !important;
  font-size: 13px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  font-weight: 500 !important;
  transition: all 0.3s ease !important;
  min-height: 48px !important;
}

/* Primary button */
.button:not(.button--secondary):not(.button--tertiary),
.shopify-payment-button__button--unbranded {
  background-color: var(--flaio-text-primary) !important;
  color: var(--flaio-text-inverse) !important;
  border: none !important;
}

.button:not(.button--secondary):not(.button--tertiary):hover,
.shopify-payment-button__button--unbranded:hover {
  background-color: var(--flaio-accent) !important;
  color: white !important;
  transform: translateY(-2px) !important;
}

/* Secondary button */
.button--secondary {
  background-color: transparent !important;
  border: 1px solid var(--flaio-text-primary) !important;
  color: var(--flaio-text-primary) !important;
}

.button--secondary:hover {
  background-color: var(--flaio-text-primary) !important;
  color: var(--flaio-text-inverse) !important;
}

/* Remove Dawn button pseudo-elements */
.button::before,
.button::after,
.shopify-challenge__button::before,
.shopify-challenge__button::after,
.customer button::before,
.customer button::after {
  display: none !important;
}

/* ================================
   6. PRODUCT CARDS
   ================================ */

/* Card wrapper - enable relative positioning for quick add overlay */
.card-wrapper,
.product-card-wrapper {
  position: relative !important;
}

/* Card styling */
.card,
.card--standard,
.card--card {
  border-radius: 12px !important;
  overflow: visible !important;
  border: none !important;
  box-shadow: none !important;
}

/* Fix ratio container to allow full width images */
.card.ratio,
.card__inner.ratio {
  display: block !important;
}

.card.ratio::before,
.card__inner.ratio::before {
  display: none !important;
}

.card__inner {
  position: relative !important;
  border-radius: 12px !important;
  overflow: visible !important;
  aspect-ratio: 4/5 !important;
}

/* Allow badge to be visible outside the image container */
.card__media {
  overflow: visible !important;
}

/* Fix image container to fill card width - override Dawn's image-padding */
.card__media {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  border-radius: 12px !important;
  overflow: hidden !important;
}

/* Override Dawn's --image-padding margin */
.card--standard .card__media,
.card .card__inner .card__media {
  margin: 0 !important;
  width: 100% !important;
}

/* Product image aspect ratio - portrait */
.card__media .media,
.card__media .media--portrait,
.card__media .media--transparent {
  aspect-ratio: 4/5 !important;
  padding-bottom: 0 !important;
  width: 100% !important;
  height: 100% !important;
  position: relative !important;
}

/* Images fill container */
.card__media img,
.card__media .media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
}

/* Image zoom on hover */
.card__media img,
.media--hover-effect img {
  transition: transform 0.6s cubic-bezier(0.215, 0.61, 0.355, 1) !important;
}

.card-wrapper:hover .card__media img,
.product-card-wrapper:hover .media--hover-effect img {
  transform: scale(1.05) !important;
}

/* Product title */
.card__heading,
.card__heading a,
.card__heading .full-unstyled-link {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  color: var(--flaio-text-primary) !important;
  text-align: center !important;
}

/* Product price */
.price,
.price-item,
.price-item--regular,
.price-item--sale {
  font-family: 'Inter', sans-serif !important;
  font-size: 15px !important;
  color: var(--flaio-text-secondary) !important;
  font-weight: 500 !important;
}

/* Card content alignment */
.card__content,
.card__information,
.card-information {
  text-align: center !important;
  padding: 12px 0 !important;
}

/* Badge styling - positioned at top right of image */
.card__badge {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  bottom: auto !important;
  left: auto !important;
  z-index: 10 !important;
}

/* Ensure card__inner doesn't clip the badge */
.card__inner {
  overflow: visible !important;
}

.card__media {
  overflow: hidden !important;
  border-radius: 12px !important;
}

.badge {
  background: var(--flaio-accent) !important;
  color: white !important;
  font-size: 10px !important;
  text-transform: uppercase !important;
  padding: 6px 12px !important;
  border-radius: 4px !important;
  letter-spacing: 0.06em !important;
  font-weight: 600 !important;
  border: none !important;
}

/* QUICK ADD - Positioned over the product image */

/* 
 * Dawn uses CSS Grid for card layout with .quick-add at grid-row-start: 4
 * We override this to use relative positioning with negative margin
 * to pull the button up into the image area
 */

/* Override Dawn's grid positioning completely */
.quick-add,
.quick-add.no-js-hidden {
  position: relative !important;
  grid-row-start: unset !important;
  grid-row: unset !important;
  grid-column: unset !important;
  grid-area: unset !important;
  margin: 0 !important;
  margin-top: -70px !important;
  margin-left: 12px !important;
  margin-right: 12px !important;
  margin-bottom: 16px !important;
  z-index: 50 !important;
  opacity: 0 !important;
  transform: translateY(8px) !important;
  transition: opacity 0.25s ease, transform 0.25s ease !important;
  visibility: visible !important;
  pointer-events: none !important;
  display: block !important;
}

/* Quick add button styling */
.quick-add__submit,
.quick-add .button,
.quick-add button[type="submit"],
button.quick-add__submit {
  background: white !important;
  color: #3d3630 !important;
  padding: 14px 24px !important;
  border-radius: 50px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.15) !important;
  min-height: auto !important;
  min-width: 100% !important;
  width: 100% !important;
  border: none !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  display: block !important;
  text-align: center !important;
  pointer-events: auto !important;
}

.quick-add__submit:hover,
.quick-add .button:hover,
.quick-add button[type="submit"]:hover {
  background: #3d3630 !important;
  color: white !important;
  box-shadow: 0 6px 28px rgba(0, 0, 0, 0.25) !important;
}

/* Show quick add on hover */
.card-wrapper:hover .quick-add,
.card-wrapper:hover .quick-add.no-js-hidden,
.product-card-wrapper:hover .quick-add,
.product-card-wrapper:hover .quick-add.no-js-hidden {
  opacity: 1 !important;
  transform: translateY(0) !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

/* Always show quick add on mobile (no hover support) */
@media screen and (max-width: 749px) {
  .quick-add,
  .quick-add.no-js-hidden {
    opacity: 1 !important;
    transform: translateY(0) !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }
}

/* Hide the loading spinner in quick add button */
.quick-add .loading__spinner,
.quick-add__submit .loading__spinner {
  display: none !important;
}

/* ================================
   7. SECTIONS
   ================================ */

/* Section spacing */
.section-template,
.shopify-section {
  --spacing-sections-desktop: 80px;
  --spacing-sections-mobile: 60px;
}

/* Section headers / overlines */
.caption-with-letter-spacing,
.subtitle--small,
.collection__title--small {
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.2em !important;
  color: var(--flaio-accent) !important;
  font-weight: 600 !important;
}

/* Section titles */
.title,
.collection-hero__title,
.featured-collection .title {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-weight: 400 !important;
  color: var(--flaio-text-primary) !important;
}

/* ================================
   8. HERO / IMAGE BANNER
   ================================ */

.banner,
.slideshow,
.image-banner {
  min-height: 90vh !important;
}

@media screen and (max-width: 749px) {
  .banner,
  .slideshow,
  .image-banner {
    min-height: 80vh !important;
  }
}

.banner__content,
.slideshow__content,
.image-banner__content {
  max-width: 800px !important;
}

.banner__heading,
.slideshow__heading,
.image-banner__heading {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-weight: 400 !important;
  font-size: clamp(32px, 6vw, 56px) !important;
}

.banner__box,
.slideshow__text-wrapper {
  background: transparent !important;
}

/* ================================
   9. COLLECTION PAGE
   ================================ */

.collection-hero {
  padding: 80px 0 40px !important;
  text-align: center !important;
}

/* Filter pills */
.facet-filters__field,
.facets__disclosure,
.active-facets__button {
  border-radius: 40px !important;
  border: 1px solid var(--flaio-border) !important;
  padding: 10px 20px !important;
  font-size: 13px !important;
  background: white !important;
  transition: all 0.2s ease !important;
}

.facet-filters__field:hover,
.facets__disclosure:hover {
  border-color: var(--flaio-text-primary) !important;
}

/* ================================
   10. PRODUCT PAGE
   ================================ */

/* Gallery - NO ROUNDING, BUTTS AGAINST HEADER */
.product__media-wrapper,
.product-media-container {
  border-radius: 0 !important;
  overflow: hidden !important;
}

/* Remove top padding from product section entirely */
product-info[class*="section-"][class*="-padding"] {
  padding-top: 0 !important;
}

.product__media-wrapper .global-media-settings,
.product__media-wrapper .media,
.product__media-wrapper img {
  border-radius: 0 !important;
}

/* ================================
   DESKTOP PRODUCT PAGE - CAROUSEL + ACCORDION LAYOUT
   ================================ */
@media screen and (min-width: 750px) {
  /* Make product images a horizontal carousel on desktop */
  .product__media-list {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    gap: 0 !important;
  }
  
  .product__media-list::-webkit-scrollbar {
    display: none !important;
  }
  
  .product__media-list > li {
    flex: 0 0 100% !important;
    scroll-snap-align: start !important;
    max-width: 100% !important;
    width: 100% !important;
  }
  
  .product__media-list .product__media-item {
    width: 100% !important;
    max-width: 100% !important;
  }
  
  /* Show thumbnails on desktop for navigation */
  .thumbnail-slider {
    display: flex !important;
    margin-top: 16px !important;
  }
  
  .thumbnail-list {
    display: flex !important;
    gap: 12px !important;
    justify-content: flex-start !important;
  }
  
  .thumbnail-list__item {
    flex: 0 0 80px !important;
    width: 80px !important;
    height: 80px !important;
  }
  
  .thumbnail-list__item button {
    width: 100% !important;
    height: 100% !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    border: 2px solid transparent !important;
    transition: border-color 0.2s ease !important;
  }
  
  .thumbnail-list__item button.is-active,
  .thumbnail-list__item button[aria-current="true"] {
    border-color: var(--flaio-accent, #c9a961) !important;
  }
  
  /* Show slider navigation buttons on desktop */
  .slider-buttons {
    display: flex !important;
  }
  
  /* Hide prev button - only show next */
  .slider-button--prev {
    display: none !important;
  }
  
  .slider-button {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 10 !important;
    width: 48px !important;
    height: 48px !important;
    background: rgba(61, 54, 48, 0.8) !important;
    border: none !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.2s ease !important;
  }
  
  .slider-button .svg-wrapper {
    color: #ffffff !important;
    transform: rotate(180deg) !important;
  }
  
  .slider-button:hover {
    background: rgba(61, 54, 48, 0.95) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
    cursor: pointer !important;
  }
  
  .slider-button--next {
    right: 16px !important;
    left: auto !important;
  }
  
  /* Ensure button is on the right side of the image, not centered */
  .product__media-wrapper .slider-button,
  .product__media-item .slider-button,
  .product slider-component .slider-button {
    right: 16px !important;
    left: auto !important;
  }
  
  .slider-button[disabled] {
    opacity: 0.4 !important;
    cursor: pointer !important;
  }
  
  .slider-button[disabled]:hover {
    cursor: pointer !important;
  }
  
  /* DESKTOP: Details accordion - hidden from right side, will be cloned to left */
  .product__details-accordion {
    display: none !important;
  }
  
  /* Hide duplicate product accordions - we use collapsible_tab blocks now */
  .product-accordions,
  [data-product-accordions],
  .product__fullwidth-accordions {
    display: none !important;
  }
  
  /* DESKTOP: Full-width accordions - Shipping & Care - moved outside container via JS */
  .product__fullwidth-accordions {
    width: 100% !important;
    background-color: #3d3630 !important;
    box-sizing: border-box !important;
  }
  
  .product__fullwidth-accordions.moved-to-root {
    margin-top: 0 !important;
  }
  
  .product__fullwidth-accordions .product-accordion {
    padding: 0 !important;
    border: none !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
  }
  
  .product__fullwidth-accordions .product-accordion:first-child {
    border-top: none !important;
  }
  
  .product__fullwidth-accordions .product-accordion:last-child {
    border-bottom: none !important;
  }
  
  .product__fullwidth-accordions .product-accordion__header {
    font-size: 14px !important;
    font-weight: 500 !important;
    color: #faf8f5 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 24px 40px !important;
  }
  
  .product__fullwidth-accordions .product-accordion__header:hover {
    color: #c9a961 !important;
  }
  
  .product__fullwidth-accordions .product-accordion__icon::before,
  .product__fullwidth-accordions .product-accordion__icon::after {
    background-color: #faf8f5 !important;
  }
  
  .product__fullwidth-accordions .product-accordion__content-inner {
    padding: 0 40px 24px !important;
    color: rgba(250, 248, 245, 0.8) !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
  }
  
  .product__fullwidth-accordions .product-accordion__content-inner p,
  .product__fullwidth-accordions .product-accordion__content-inner li {
    color: rgba(250, 248, 245, 0.8) !important;
  }
  
  .product-accordion__content-inner ul {
    list-style: disc !important;
    padding-left: 20px !important;
  }
  
  .product-accordion__content-inner li {
    margin-bottom: 6px !important;
  }
  
  /* DESKTOP: Product media wrapper needs relative positioning for Details placement */
  .product__media-wrapper {
    position: relative !important;
  }
  
  /* DESKTOP: Details section under photos - not collapsible */
  .product__details-under-photos {
    margin-top: 24px !important;
    padding: 24px !important;
    background-color: #faf8f5 !important;
    border: none !important;
  }
  
  .product__details-under-photos .product-accordion {
    border: none !important;
  }
  
  /* Hide the accordion header/toggle - just show content */
  .product__details-under-photos .product-accordion__header {
    display: none !important;
  }
  
  /* Always show content */
  .product__details-under-photos .product-accordion__content {
    max-height: none !important;
    overflow: visible !important;
  }
  
  .product__details-under-photos .product-accordion__content-inner {
    padding: 0 !important;
  }
  
  .product__details-under-photos .product-accordion__content-inner p,
  .product__details-under-photos .product-accordion__content-inner li {
    color: #5c534a !important;
    font-size: 14px !important;
    line-height: 1.7 !important;
  }
  
  .product__details-under-photos .product-accordion__content-inner ul {
    list-style: disc !important;
    padding-left: 20px !important;
    margin: 0 !important;
  }
  
  .product__details-under-photos .product-accordion__content-inner li {
    margin-bottom: 8px !important;
  }
  
  /* Trust icons when moved to left bar under Details */
  .product__details-under-photos .trust-icons-default {
    margin-top: 20px !important;
    padding-top: 20px !important;
    border-top: 1px solid rgba(61, 54, 48, 0.1) !important;
    grid-template-columns: repeat(4, 1fr) !important;
  }
  
  .product__details-under-photos .trust-icons-default__label {
    font-size: 9px !important;
  }
  
  .product__details-under-photos .trust-icons-default__icon {
    width: 28px !important;
    height: 28px !important;
  }
}

/* MOBILE: Accordion normal flow */
@media screen and (max-width: 749px) {
  .product__details-accordion {
    display: block !important;
    margin: 24px 0 !important;
  }
  
  .product__fullwidth-accordions {
    margin: 0 !important;
    width: auto !important;
    background-color: transparent !important;
  }
  
  .product__fullwidth-accordions .product-accordion {
    border-bottom: 1px solid rgba(61, 54, 48, 0.12) !important;
  }
  
  .product__fullwidth-accordions .product-accordion__header {
    color: #3d3630 !important;
    padding: 18px 0 !important;
    max-width: none !important;
  }
  
  .product__fullwidth-accordions .product-accordion__icon::before,
  .product__fullwidth-accordions .product-accordion__icon::after {
    background-color: #3d3630 !important;
  }
  
  .product__fullwidth-accordions .product-accordion__content-inner {
    padding: 0 0 20px 0 !important;
    color: #5a5149 !important;
    max-width: none !important;
  }
  
  .product__fullwidth-accordions .product-accordion__content-inner p,
  .product__fullwidth-accordions .product-accordion__content-inner li {
    color: #5a5149 !important;
  }
  
  /* Hide the cloned element on mobile */
  .product__details-under-photos {
    display: none !important;
  }
}

/* Product title */
.product__title,
.product__title h1 {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: clamp(28px, 4vw, 40px) !important;
  font-weight: 400 !important;
}

/* ================================
   PRODUCT TITLE + PRICE LAYOUT
   ================================ */

/* Create a header row with title on left, price/shipping on right */
.product__info-container {
  position: relative;
}

/* Crystal subtitle styling - shared */
.product__crystal-subtitle {
  font-family: 'Inter', -apple-system, sans-serif;
  font-size: 16px;
  font-weight: 400;
  color: #8c7e70;
  letter-spacing: 0.02em;
  margin-top: 8px;
  margin-bottom: 0;
  line-height: 1.5;
}

/* DESKTOP: Traditional stacked layout (title on top, price below, shipping below price) */
@media screen and (min-width: 750px) {
  .product__title-price-row {
    display: block !important;
    margin-bottom: 20px !important;
  }

  .product__title-price-row .product__title-column {
    width: 100% !important;
  }

  .product__title-price-row .product__title {
    margin-bottom: 8px !important;
  }
  
  .product__title-price-row .product__title h1 {
    font-size: clamp(32px, 4vw, 44px) !important;
  }

  .product__title-price-row .product__price-shipping {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 6px !important;
    text-align: left !important;
    padding-top: 0 !important;
    margin-top: 12px !important;
  }
  
  /* Share button - position absolutely in title-price area */
  .product__info-container {
    position: relative !important;
  }
  
  .share-button {
    position: absolute !important;
    top: 85px !important;
    right: 0 !important;
  }
  
  /* Price styling on desktop */
  .product__price-shipping .price {
    margin: 0 !important;
  }

  .product__price-shipping .price-item--regular {
    font-family: 'Inter', sans-serif !important;
    font-size: 22px !important;
    font-weight: 600 !important;
    color: #3d3630 !important;
  }
  
  /* Free shipping styling */
  .product__price-shipping .product-free-shipping {
    margin-top: 0 !important;
    font-size: 13px !important;
  }
  
  /* Quantity and Buy 2+ STACKED on desktop */
  .qty-bulk-row {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    align-items: stretch !important;
    max-width: 400px !important;
  }
  
  .qty-bulk-row__qty {
    width: 100% !important;
    justify-content: center !important;
  }
  
  .qty-bulk-row__bulk {
    width: 100% !important;
  }
  
  .qty-bulk-row__bulk-box {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    height: 56px !important;
    padding: 8px 16px !important;
    box-sizing: border-box !important;
  }
  
  .qty-bulk-row__bulk-left {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 10px !important;
  }
  
  .qty-bulk-row__label {
    display: flex !important;
    flex-direction: row !important;
    align-items: baseline !important;
    gap: 6px !important;
  }
  
  .qty-bulk-row__label small {
    display: inline !important;
  }
  
  .qty-bulk-row__price {
    display: flex !important;
    flex-direction: row !important;
    align-items: baseline !important;
    gap: 6px !important;
  }
  
  .qty-bulk-row__price-original {
    display: inline !important;
  }
  
  .qty-bulk-row__price-sale {
    display: inline !important;
  }
  
  .qty-bulk-row__badge {
    position: absolute !important;
    top: -9px !important;
    right: 12px !important;
  }
  
}

/* MOBILE: Keep title and price on same row */
@media screen and (max-width: 749px) {
  .product__title-price-row {
    display: flex !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    gap: 12px !important;
    margin-bottom: 16px !important;
  }
  
  .product__title-price-row .product__title-column {
    flex: 1 !important;
    min-width: 0 !important;
  }
  
  .product__title-price-row .product__title {
    margin-bottom: 0 !important;
  }
  
  .product__title-price-row .product__title h1 {
    font-size: 27px !important;
  }
  
  .product__title-price-row .product__price-shipping {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    gap: 4px !important;
    flex-shrink: 0 !important;
    text-align: right !important;
    padding-top: 4px !important;
  }
  
  .product__price-shipping .price-item--regular {
    font-size: 18px !important;
  }
  
  .product__price-shipping .product-free-shipping {
    margin-top: 2px !important;
    font-size: 12px !important;
  }
  
  .product__crystal-subtitle {
    font-size: 15px;
  }
  
  /* Share button - normal position on mobile */
  .share-button {
    position: static !important;
    top: auto !important;
    right: auto !important;
  }
}

/* Variant selectors */
.product-form__input input[type="radio"] + label,
.variant-input-wrapper label {
  border-radius: 50% !important;
  width: 44px !important;
  height: 44px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid var(--flaio-border) !important;
  font-size: 13px !important;
  transition: all 0.2s ease !important;
}

.product-form__input input[type="radio"]:checked + label,
.variant-input-wrapper input:checked + label {
  background: var(--flaio-text-primary) !important;
  color: white !important;
  border-color: var(--flaio-text-primary) !important;
}

/* ================================
   11. FOOTER - DARK THEME
   ================================ */

/* Force dark background on footer - override Dawn's color scheme */
footer.footer,
.footer,
.section-footer,
.shopify-section-footer footer,
.shopify-section-group-footer-group footer,
.color-scheme-3,
footer.color-scheme-3,
.footer.color-scheme-3 {
  --color-background: 61, 54, 48 !important;
  --color-foreground: 250, 248, 245 !important;
  background: #3d3630 !important;
  background-color: #3d3630 !important;
  color: #faf8f5 !important;
}

/* Override gradient class on footer */
footer.footer.gradient,
.footer.gradient,
.footer.color-scheme-3.gradient {
  --gradient-background: #3d3630 !important;
  background: #3d3630 !important;
  background-color: #3d3630 !important;
  padding-left: 0px !important;
}

/* All text in footer should be light */
.footer,
.footer *,
.footer p,
.footer span,
.footer small,
.footer li,
.footer .copyright__content,
.footer .link,
.footer .list-menu__item,
.footer .list-menu__item--link {
  color: rgba(255, 255, 255, 0.75) !important;
}

/* Footer links */
.footer a,
.footer .link--text,
.footer-block__details-content a {
  color: rgba(255, 255, 255, 0.75) !important;
  text-decoration: none !important;
}

.footer a:hover,
.footer .link--text:hover,
.footer-block__details-content a:hover {
  color: #ffffff !important;
}

/* Footer headings - Gold accent (SHOP, SUPPORT, LEGAL only) */
.footer-block--menu .footer-block__heading,
.footer-block--link_list .footer-block__heading,
.footer-block--menu h2,
.footer-block--link_list h2 {
  font-family: 'Inter', -apple-system, sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  color: #c9a961 !important;
  margin-bottom: 16px !important;
}

/* FLAIO Brand Logo in footer - must override general heading styles */
.footer-block--brand_information .footer-block__heading,
.footer-block--brand_information h2,
.footer-block--brand_information .footer-block__heading.rte,
.footer-block__brand-info .footer-block__heading,
.footer-block__brand-info h2 {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 28px !important;
  font-weight: 400 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  color: #ffffff !important;
  margin-bottom: 16px !important;
}

/* Footer menu items */
.footer .list-menu__item--link,
.footer-block__details-content .list-menu__item--link {
  font-size: 15px !important;
  font-weight: 400 !important;
  padding: 6px 0 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

/* Newsletter section heading */
.footer-block--newsletter .footer-block__heading,
.footer__newsletter .footer-block__heading {
  color: #c9a961 !important;
}

/* Footer newsletter form - input and button separated */
.footer .newsletter-form__field-wrapper,
.footer .newsletter-form,
.footer__newsletter .field {
  display: flex !important;
  gap: 16px !important;
  max-width: 400px !important;
  background: transparent !important;
  border: none !important;
}

/* Input - pill shaped */
.footer .field__input,
.footer .newsletter-form .field__input {
  flex: 1 !important;
  background: transparent !important;
  border: 1px solid rgba(255, 255, 255, 0.3) !important;
  color: #ffffff !important;
  border-radius: 50px !important;
  padding: 14px 24px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  -webkit-appearance: none !important;
}

.footer .field__input::placeholder {
  color: rgba(255, 255, 255, 0.5) !important;
}

.footer .field__input:focus {
  border-color: rgba(255, 255, 255, 0.5) !important;
  outline: none !important;
  box-shadow: none !important;
  padding: 14px 24px !important;
  border-radius: 50px !important;
}

/* Newsletter submit button - TEXT ONLY (no background) - HIGH SPECIFICITY */
.footer .newsletter-form__field-wrapper button.newsletter-form__button,
.footer .newsletter-form__button,
.footer .field__button,
footer.footer .newsletter-form__button,
footer.footer .field__button,
footer .newsletter-form button,
footer .field button {
  all: unset !important;
  display: flex !important;
  align-items: center !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 14px 20px !important;
  color: rgba(255, 255, 255, 0.9) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  cursor: pointer !important;
  flex-shrink: 0 !important;
  box-shadow: none !important;
}

/* Hover state - just brighter text */
.footer .newsletter-form__button:hover,
.footer .field__button:hover,
.footer .newsletter-form__button:focus,
.footer .field__button:focus,
footer.footer .newsletter-form__button:hover,
footer.footer .field__button:hover,
footer .newsletter-form button:hover,
footer .field button:hover {
  all: unset !important;
  display: flex !important;
  align-items: center !important;
  background: transparent !important;
  background-color: transparent !important;
  color: #ffffff !important;
  padding: 14px 20px !important;
  cursor: pointer !important;
}

/* Hide default icon, show JOIN text */
.footer .newsletter-form__button svg,
.footer .field__button svg,
.footer .newsletter-form__button .svg-wrapper,
.footer .field__button .svg-wrapper {
  display: none !important;
}

.footer .newsletter-form__button::after,
.footer .field__button::after {
  content: 'JOIN' !important;
}

/* Social icons in footer */
.footer .list-social,
.footer__list-social {
  margin-top: 16px !important;
  gap: 12px !important;
}

.footer .list-social__link,
.footer__list-social .list-social__link {
  color: rgba(255, 255, 255, 0.7) !important;
}

.footer .list-social__link:hover {
  color: #ffffff !important;
}

.footer .list-social__link svg,
.footer .list-social__link .icon {
  fill: currentColor !important;
  width: 24px !important;
  height: 24px !important;
}

/* Footer bottom section */
.footer__content-bottom,
.footer__content-bottom-wrapper {
  /*border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
  padding-top: 24px !important;
  margin-top: 40px !important;*/
}

.footer__copyright,
.footer .copyright__content {
  font-size: 12px !important;
  color: rgba(255, 255, 255, 0.5) !important;
}

.footer .policies,
.footer .policies a {
  color: rgba(255, 255, 255, 0.5) !important;
}

.footer .policies a:hover {
  color: rgba(255, 255, 255, 0.8) !important;
}

/* Hide "Powered by Shopify" or style it */
.footer .copyright__content a[href*="shopify"] {
  display: none !important;
}

/* ============================================
   FOOTER SPACING OVERRIDES
   Override ALL spacing from section-footer.css
   ============================================ */

/* Desktop Footer Layout */
@media screen and (min-width: 750px) {
  .footer__content-top {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: auto auto !important;
    gap: 24px 60px !important;
    padding-bottom: 40px !important;
    padding-right: 0 !important;
    padding-left: 50px !important;
  }

  /* Footer blocks wrapper - use contents */
  .footer__blocks-wrapper {
    display: contents !important;
  }

  /* Override all footer block margin/padding */
  .footer-block,
  .footer-block.grid__item {
    padding: 0 !important;
    margin: 0 !important;
    width: auto !important;
  }

  /* Brand info - top left */
  .footer-block--brand_information {
    grid-column: 1 !important;
    grid-row: 1 !important;
    max-width: 400px !important;
  }

  /* Newsletter - top right */
  .footer-block--newsletter {
    grid-column: 2 !important;
    grid-row: 1 !important;
    justify-self: end !important;
    align-self: end !important;
  }

  /* Bottom row: SHOP, SUPPORT, LEGAL side by side */
  .footer-block--link_list {
    grid-row: 2 !important;
  }
  
  /* Shop menu - bottom left */
  .footer-block--link_list:nth-of-type(1) {
    grid-column: 1 !important;
  }
  
  /* Support menu - bottom middle-ish */
  .footer-block--link_list:nth-of-type(2) {
    grid-column: 2 !important;
    justify-self: start !important;
  }
  
  /* Legal menu - bottom right */
  .footer-block--link_list:nth-of-type(3) {
    grid-column: 2 !important;
    justify-self: end !important;
  }
}

/* Even better: Make bottom row 3 columns */
@media screen and (min-width: 990px) {
  .footer__content-top {
    display: grid !important;
    grid-template-columns: 350px 1fr !important;
    grid-template-rows: auto auto !important;
    gap: 40px 80px !important;
  }

  /* Brand info - top left */
  .footer-block--brand_information {
    grid-column: 1 !important;
    grid-row: 1 / 3 !important;
  }

  /* Newsletter - top right */
  .footer-block--newsletter {
    grid-column: 2 !important;
    grid-row: 1 !important;
    justify-self: start !important;
  }

  /* Create a flex row for the 3 menus */
  .footer-block--link_list:nth-of-type(1),
  .footer-block--link_list:nth-of-type(2),
  .footer-block--link_list:nth-of-type(3) {
    grid-column: 2 !important;
    grid-row: 2 !important;
  }
}

/* Use a wrapper approach for the menus */
.footer__content-top {
  padding-bottom: 40px !important;
  padding-left: 50px !important;
  padding-right: 0 !important;
}

.footer__blocks-wrapper {
  display: contents !important;
}

.footer-block,
.footer-block.grid__item {
  padding: 0 !important;
  margin: 0 !important;
  width: auto !important;
}

/* Override section-footer.css heading margin */
.footer-block__heading {
  margin-bottom: 16px !important;
  margin-top: 0 !important;
  font-size: inherit !important;
}

/* Override menu list spacing */
.footer-block__details-content {
  margin-bottom: 0 !important;
}

.footer-block__details-content .list-menu__item--link {
  padding-top: 6px !important;
  padding-bottom: 6px !important;
  display: block !important;
}

/* Override newsletter block styling from section-footer.css */
.footer-block--newsletter:only-child,
.footer-block--newsletter {
  margin-top: 0 !important;
}

.footer-block__newsletter {
  text-align: left !important;
  flex-grow: 0 !important;
}

/* Override content bottom from section-footer.css */
.footer__content-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
  padding-top: 24px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.footer__copyright {
  margin-top: 0 !important;
  text-align: left !important;
}

/* Mobile: Stack everything in single column */
@media screen and (max-width: 749px) {
  .footer__content-top {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
    padding-bottom: 32px !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
  
  .footer-block--brand_information,
  .footer-block:first-child,
  .footer-block--newsletter,
  .footer-block--link_list,
  .footer-block--menu,
  .footer-block.grid__item {
    grid-column: 1 !important;
    max-width: 100% !important;
    width: 100% !important;
  }
  
  /* Reset grid row positions for mobile */
  .footer-block--link_list:nth-of-type(2),
  .footer-block--menu:nth-of-type(2),
  .footer-block--link_list:nth-of-type(3),
  .footer-block--menu:nth-of-type(3) {
    grid-row: auto !important;
  }
}

/* ================================
   12. CART DRAWER
   ================================ */

/* Drawer overlay - semi-transparent dark background */
.drawer {
  background: rgba(0, 0, 0, 0.4) !important;
}

/* Drawer panel - white background */
.drawer__inner,
.drawer__inner-empty,
.cart-notification {
  background: #faf8f5 !important;
}

.drawer__header,
.cart-drawer__header {
  border-bottom: 1px solid var(--flaio-border) !important;
}

/* Hide login/account section in cart drawer */
.cart__login-title,
.cart__login-paragraph,
.cart-drawer .cart__login-title,
.cart-drawer .cart__login-paragraph {
  display: none !important;
}

/* ================================
   12.5 QUICK ADD MODAL - REDESIGN
   ================================ */

/* Modal backdrop */
.quick-add-modal {
  background: rgba(0, 0, 0, 0.4) !important;
}

/* Modal content container - Desktop */
.quick-add-modal__content {
  background: #ffffff !important;
  border-radius: 24px !important;
  max-width: 560px !important;
  width: calc(100% - 48px) !important;
  margin: auto !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  padding: 0 !important;
  box-shadow: 0 25px 80px rgba(0, 0, 0, 0.15), 0 10px 30px rgba(0, 0, 0, 0.1) !important;
  overflow: hidden !important;
  max-height: calc(100vh - 100px) !important;
}

/* Close button - Desktop - MUST be inside modal content */
quick-add-modal .quick-add-modal__toggle {
  position: absolute !important;
  top: 24px !important;
  right: 24px !important;
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  background: #f8f6f3 !important;
  border: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  z-index: 100 !important;
  padding: 0 !important;
  transition: background 0.2s ease !important;
}

/* Ensure toggle is hidden when modal is not open */
quick-add-modal:not([open]) .quick-add-modal__toggle {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
}

quick-add-modal .quick-add-modal__toggle:hover {
  background: #eeeae6 !important;
}

quick-add-modal .quick-add-modal__toggle .icon,
quick-add-modal .quick-add-modal__toggle svg {
  width: 16px !important;
  height: 16px !important;
  color: #3d3630 !important;
}

/* Modal content info wrapper */
.quick-add-modal__content-info {
  padding: 32px !important;
  display: block !important;
  overflow-y: auto !important;
  max-height: calc(100vh - 140px) !important;
}

/* Product layout container */
quick-add-modal .product,
quick-add-modal product-info {
  display: block !important;
  padding: 0 !important;
  margin: 0 !important;
}

quick-add-modal .product__info-container {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
}

quick-add-modal .product__info-wrapper {
  padding: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
}

/* ---- HEADER SECTION: Image + Title + Price ---- */
/* This header is created dynamically by quick-add.js */
quick-add-modal .quick-add-modal__product-header {
  display: flex !important;
  gap: 20px !important;
  margin-bottom: 24px !important;
  padding-bottom: 24px !important;
  border-bottom: 1px solid rgba(61, 54, 48, 0.1) !important;
  align-items: flex-start !important;
}

quick-add-modal .quick-add-modal__product-text {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  flex: 1 !important;
  padding-right: 40px !important;
}

/* Product media in header - Show as thumbnail */
quick-add-modal .quick-add-modal__product-header .product__media-wrapper {
  display: block !important;
  width: 140px !important;
  min-width: 140px !important;
  max-width: 140px !important;
  padding: 0 !important;
  margin: 0 !important;
  position: relative !important;
  flex-shrink: 0 !important;
}

quick-add-modal .quick-add-modal__product-header .product__column-sticky {
  position: static !important;
  top: auto !important;
}

quick-add-modal .quick-add-modal__product-header .product-media-container,
quick-add-modal .quick-add-modal__product-header .product__media-list {
  margin: 0 !important;
  padding: 0 !important;
  width: 140px !important;
  height: 140px !important;
  overflow: visible !important;
}

quick-add-modal .quick-add-modal__product-header .product__media-item {
  width: 140px !important;
  height: 140px !important;
  margin: 0 !important;
  padding: 0 !important;
}

quick-add-modal .quick-add-modal__product-header .product__media-item:not(:first-child) {
  display: none !important;
}

quick-add-modal .quick-add-modal__product-header .product__media,
quick-add-modal .quick-add-modal__product-header .media {
  width: 140px !important;
  height: 140px !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  padding: 0 !important;
}

quick-add-modal .quick-add-modal__product-header .product__media img,
quick-add-modal .quick-add-modal__product-header .media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  position: static !important;
}

/* Hide original media wrapper that was cloned */
quick-add-modal .product__info-container > .product__media-wrapper,
quick-add-modal .product > .product__media-wrapper {
  display: none !important;
}

/* Hide thumbnail slider, modals, etc */
quick-add-modal .thumbnail-list,
quick-add-modal .slider-buttons,
quick-add-modal .product__modal-opener,
quick-add-modal .product-modal-opener,
quick-add-modal .media-badge,
quick-add-modal .product__xr-button,
quick-add-modal .slider--mobile-dots {
  display: none !important;
}

/* Hide elements we don't need in quick add */
quick-add-modal .product__description,
quick-add-modal .share-button,
quick-add-modal .product-popup-modal__opener,
quick-add-modal .product__tax,
quick-add-modal quantity-input,
quick-add-modal .quantity,
quick-add-modal .quick-add-hidden,
quick-add-modal .product__view-details,
quick-add-modal .shopify-payment-button,
quick-add-modal .volume-pricing-note,
quick-add-modal .price-per-item,
quick-add-modal .price-per-item__container,
quick-add-modal .product-form__error-message-wrapper,
quick-add-modal [data-dynamic-checkout],
quick-add-modal pickup-availability,
quick-add-modal .product__pickup-availabilities,
quick-add-modal .accordion,
quick-add-modal .icon-with-text,
quick-add-modal product-recommendations {
  display: none !important;
}

/* Product title - in header */
quick-add-modal .quick-add-modal__product-header .product__title,
quick-add-modal .product__title {
  margin: 0 !important;
}

quick-add-modal .product__title h1 {
  display: none !important;
}

quick-add-modal .quick-add-modal__product-header .product__title > a,
quick-add-modal .product__title > a {
  display: block !important;
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 26px !important;
  font-weight: 400 !important;
  color: #3d3630 !important;
  text-decoration: none !important;
  line-height: 1.2 !important;
}

quick-add-modal .product__title > a:hover {
  text-decoration: none !important;
}

/* Price display - in header */
quick-add-modal .quick-add-modal__product-header .no-js-hidden.price,
quick-add-modal .quick-add-modal__product-header .price,
quick-add-modal .no-js-hidden.price {
  margin: 0 !important;
  padding: 0 !important;
}

quick-add-modal .price__container {
  display: flex !important;
  flex-direction: column !important;
}

quick-add-modal .price__regular {
  display: flex !important;
}

quick-add-modal .quick-add-modal__product-header .price-item,
quick-add-modal .quick-add-modal__product-header .price-item--regular,
quick-add-modal .price-item,
quick-add-modal .price-item--regular {
  font-family: 'Inter', sans-serif !important;
  font-size: 20px !important;
  font-weight: 400 !important;
  color: #8c7e70 !important;
}

/* ---- VARIANT PICKER SECTION ---- */
quick-add-modal variant-selects {
  display: block !important;
  margin-top: 24px !important;
  margin-bottom: 24px !important;
}

quick-add-modal .product-form__input,
quick-add-modal .product-form__input--pill {
  margin-bottom: 24px !important;
  border: none !important;
  padding: 0 !important;
}

quick-add-modal .product-form__input--pill legend,
quick-add-modal .product-form__input legend,
quick-add-modal .form__label {
  display: block !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  color: #3d3630 !important;
  margin-bottom: 16px !important;
  padding: 0 !important;
}

/* Size buttons container - HORIZONTAL ROW */
quick-add-modal .product-form__input--pill {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  width: 100% !important;
}

/* Legend takes full width on its own line */
quick-add-modal .product-form__input--pill legend,
quick-add-modal .product-form__input--pill .form__label {
  flex: 0 0 100% !important;
  width: 100% !important;
  margin-bottom: 12px !important;
}

/* Hide radio inputs */
quick-add-modal .product-form__input--pill input[type="radio"] {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
  width: 1px !important;
  height: 1px !important;
}

/* Size button labels - MUST be inline with equal width */
quick-add-modal .product-form__input--pill > label,
quick-add-modal .product-form__input--pill input[type="radio"] + label {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  max-width: none !important;
  width: auto !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 48px !important;
  border-radius: 8px !important;
  border: 1px solid rgba(61, 54, 48, 0.25) !important;
  background: #ffffff !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #3d3630 !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  padding: 0 4px !important;
  margin: 0 !important;
}

quick-add-modal .product-form__input--pill label:hover {
  border-color: #3d3630 !important;
}

quick-add-modal .product-form__input--pill input[type="radio"]:checked + label {
  background: #3d3630 !important;
  color: #ffffff !important;
  border-color: #3d3630 !important;
}

/* Swatch variant support */
quick-add-modal .product-form__input--swatch {
  margin-bottom: 24px !important;
  border: none !important;
  padding: 0 !important;
}

quick-add-modal .product-form__input--swatch legend {
  display: block !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  color: #3d3630 !important;
  margin-bottom: 16px !important;
}

/* ---- ADD TO CART BUTTON ---- */
quick-add-modal product-form,
quick-add-modal .product-form {
  display: block !important;
  margin-top: 0 !important;
}

quick-add-modal .product-form__buttons {
  margin: 0 !important;
  max-width: 100% !important;
}

quick-add-modal .product-form__submit,
quick-add-modal .product-form__submit.button {
  width: 100% !important;
  background: #3d3630 !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 50px !important;
  padding: 18px 32px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  cursor: pointer !important;
  transition: all 0.25s ease !important;
  min-height: 56px !important;
}

quick-add-modal .product-form__submit:hover {
  background: #c9a961 !important;
  transform: translateY(-2px) !important;
}

quick-add-modal .product-form__submit:disabled {
  background: #d4cfc8 !important;
  cursor: not-allowed !important;
  transform: none !important;
}

/* Loading spinner */
quick-add-modal .product-form__submit .loading__spinner {
  display: none !important;
}

quick-add-modal .product-form__submit.loading .loading__spinner {
  display: inline-block !important;
}

/* ================================
   12.6 QUICK ADD MODAL - MOBILE
   ================================ */

@media screen and (max-width: 749px) {
  /* Mobile: Bottom sheet style */
  .quick-add-modal__content {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    top: auto !important;
    transform: none !important;
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 24px 24px 0 0 !important;
    max-height: 85vh !important;
    margin: 0 !important;
  }
  
  .quick-add-modal__content-info {
    padding: 24px !important;
    max-height: calc(85vh - 20px) !important;
  }
  
  /* Close button - Mobile */
  quick-add-modal .quick-add-modal__toggle {
    top: 16px !important;
    right: 16px !important;
    width: 36px !important;
    height: 36px !important;
  }
  
  quick-add-modal .quick-add-modal__toggle .icon,
  quick-add-modal .quick-add-modal__toggle svg {
    width: 14px !important;
    height: 14px !important;
  }
  
  /* Header - Mobile */
  quick-add-modal .quick-add-modal__product-header {
    gap: 16px !important;
    margin-bottom: 20px !important;
    padding-bottom: 20px !important;
  }
  
  quick-add-modal .quick-add-modal__product-text {
    padding-right: 30px !important;
  }
  
  /* Product media thumbnail - Mobile */
  quick-add-modal .quick-add-modal__product-header .product__media-wrapper {
    width: 100px !important;
    min-width: 100px !important;
    max-width: 100px !important;
  }
  
  quick-add-modal .quick-add-modal__product-header .product-media-container,
  quick-add-modal .quick-add-modal__product-header .product__media-list,
  quick-add-modal .quick-add-modal__product-header .product__media-item {
    width: 100px !important;
    height: 100px !important;
  }
  
  quick-add-modal .quick-add-modal__product-header .product__media,
  quick-add-modal .quick-add-modal__product-header .media {
    width: 100px !important;
    height: 100px !important;
    border-radius: 10px !important;
  }
  
  /* Product title - Mobile */
  quick-add-modal .quick-add-modal__product-header .product__title > a,
  quick-add-modal .product__title > a {
    font-size: 22px !important;
  }
  
  /* Price - Mobile */
  quick-add-modal .price-item,
  quick-add-modal .price-item--regular {
    font-size: 18px !important;
  }
  
  /* Size buttons - Mobile */
  quick-add-modal .product-form__input--pill label {
    width: 46px !important;
    height: 46px !important;
    font-size: 13px !important;
  }
  
  /* Add to Cart - Mobile */
  quick-add-modal .product-form__submit {
    padding: 16px 28px !important;
    min-height: 52px !important;
    font-size: 13px !important;
  }
}

/* ================================
   13. MISC OVERRIDES
   ================================ */

/* Page width */
.page-width {
  max-width: 1400px !important;
}

/* Links */
a {
  color: inherit;
  transition: color 0.2s ease;
}

/* Remove default underlines */
.underline-links-hover a {
  text-decoration: none !important;
}

/* Focus states */
*:focus-visible {
  outline: 2px solid var(--flaio-accent) !important;
  outline-offset: 2px !important;
}

/* ================================
   14. ANIMATIONS
   ================================ */

@keyframes flaioFadeUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.scroll-trigger.animate--slide-in {
  animation: flaioFadeUp 0.6s cubic-bezier(0.215, 0.61, 0.355, 1) forwards !important;
}

/* ================================
   15. RESPONSIVE
   ================================ */

@media screen and (max-width: 749px) {
  /* Header - Mobile */
  .header {
    padding-top: 14px !important;
    padding-bottom: 14px !important;
    margin-left: -10px !important;
  }
  
  .header__heading-link,
  .header__heading-link .h2 {
    font-size: 28px !important;
    letter-spacing: 0.2em !important;
  }
  
  /* Hide account icon on mobile too */
  .header__icon--account,
  a.header__icon[href*="/account"] {
    display: none !important;
  }
  
  .header__icons {
    gap: 12px !important;
  }
  
  /* Search icon - mobile */
  .header__search .svg-wrapper {
    width: 22px !important;
    height: 22px !important;
  }
  
  /* Cart icon - mobile - scale up */
  #cart-icon-bubble .svg-wrapper,
  .header__icon--cart .svg-wrapper {
    transform: scale(1) !important;
  }
  
  .header__icons {
    gap: 2px !important;
  }
  
  .button {
    padding: 12px 20px !important;
    font-size: 12px !important;
  }
  
  .card__heading,
  .card__heading a {
    font-size: 16px !important;
  }
  
  .price,
  .price-item {
    font-size: 14px !important;
  }
}

/* ================================
   16. COLLAGE / IMAGE GRID STYLING
   ================================ */

.collage {
  border-radius: 16px !important;
  overflow: hidden !important;
}

.collage__card {
  border-radius: 12px !important;
  overflow: hidden !important;
}

/* Multicolumn/Value Props - NO rounded corners, full bleed */
.multicolumn {
  border-radius: 0 !important;
}

.multicolumn-card {
  border-radius: 0 !important;
}

/* ================================
   17. RICH TEXT SECTIONS
   ================================ */

.rich-text__heading {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
}

.rich-text__text,
.rich-text__caption {
  color: var(--flaio-text-secondary) !important;
}

/* Accent color for captions */
.rich-text__caption,
.image-with-text__text .caption {
  color: var(--flaio-accent) !important;
}

/* ================================
   18. VALUE PROPS / MULTICOLUMN STYLING
   ================================ */

/* Value props section - single sand background for entire section */
.multicolumn.color-scheme-2,
.color-scheme-2.multicolumn {
  background: #f3efe9 !important;
}

/* Remove individual card backgrounds - single section background instead */
.multicolumn.color-scheme-2 .multicolumn-card,
.multicolumn.color-scheme-2 .multicolumn-card.content-container,
.color-scheme-2 .multicolumn-card,
.color-scheme-2 .multicolumn-card.content-container,
.multicolumn.color-scheme-2.background-primary .multicolumn-card,
.color-scheme-2.background-primary .multicolumn-card {
  background: transparent !important;
  border-radius: 0 !important;
  padding: 0 !important;
  padding-left: 10px !important;
  padding-right: 10x !important;
  text-align: left !important;
}

/* Left align the multicolumn list items */
.multicolumn.color-scheme-2 .multicolumn-list__item,
.color-scheme-2 .multicolumn-list__item {
  text-align: left !important;
}

.multicolumn.color-scheme-2 .multicolumn-list__item.center,
.color-scheme-2 .multicolumn-list__item.center {
  text-align: left !important;
}

/* Eyebrow text in multicolumn - value prop labels */
.multicolumn-card .rte strong,
.multicolumn-card__info .rte strong,
.multicolumn-card .rte .value-prop-label,
.multicolumn-card__info .rte .value-prop-label,
.rte .value-prop-label {
  display: block !important;
  font-family: 'Inter', -apple-system, sans-serif !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.25em !important;
  color: #8c7e70 !important;
  margin-bottom: 8px !important;
}

/* First paragraph (value-prop-label) should have proper margin */
.multicolumn-card .rte p:first-child,
.multicolumn-card__info .rte p:first-child {
  margin-bottom: 8px !important;
}

/* h3 headings in multicolumn text */
.multicolumn-card .rte h3,
.multicolumn-card__info .rte h3 {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 24px !important;
  font-weight: 400 !important;
  line-height: 1.3 !important;
  color: var(--flaio-text-primary) !important;
  margin-top: 0 !important;
  margin-bottom: 12px !important;
  text-align: left !important;
}

/* Multicolumn title styling */
.multicolumn-card__info h3,
.multicolumn-card__heading,
.multicolumn-card .h2 {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-size: 24px !important;
  font-weight: 400 !important;
  line-height: 1.3 !important;
  color: var(--flaio-text-primary) !important;
  margin-bottom: 12px !important;
  text-align: left !important;
}

.multicolumn-card__info .rte,
.multicolumn-card__info p,
.multicolumn-card .rte p {
  font-size: 14px !important;
  color: var(--flaio-text-secondary) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
  text-align: left !important;
  font-weight:300;
}

/* ================================
   19. HERO OVERLAY (SCHEME-4)
   ================================ */

/* Dark overlay for hero sections */
.color-scheme-4,
.banner.color-scheme-4,
.slideshow.color-scheme-4 {
  --color-background: 0, 0, 0;
  --color-foreground: 255, 255, 255;
}

/* Hero banner text styling */
.banner__heading,
.slideshow__heading {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-weight: 400 !important;
}

.banner__heading em,
.slideshow__heading em {
  font-style: italic !important;
}

/* ================================
   20. MIXED-MEDIA SWIPEABLE GALLERY (Mobile First)
   ================================ */

/* Mobile swipe gallery with scroll-snap */
@media screen and (max-width: 749px) {
  /* Gallery container */
  #GalleryViewer-{{ section.id }},
  .slider-mobile-gutter {
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch !important;
    scroll-behavior: smooth !important;
  }
  
  /* Each media item snaps to center */
  .product__media-list .product__media-item,
  .slider--mobile .slider__slide {
    scroll-snap-align: center !important;
    scroll-snap-stop: always !important;
  }
  
  /* Force 4:5 aspect ratio for all media */
  .product__media-item .media,
  .product__media-item .product__media,
  .product__media-item .global-media-settings {
    aspect-ratio: 4/5 !important;
    padding-bottom: 0 !important;
    overflow: hidden !important;
  }
  
  .product__media-item .media img,
  .product__media-item video,
  .product__media-item iframe {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }
  
  /* HTML5 video autoplay setup */
  .product__media-item video {
    object-fit: cover !important;
  }
  
  /* Deferred media poster matches aspect ratio */
  .product__media-item .deferred-media {
    aspect-ratio: 4/5 !important;
  }
  
  .product__media-item .deferred-media__poster {
    aspect-ratio: 4/5 !important;
    object-fit: cover !important;
  }
}

/* Dot Pagination for Mobile */
.product-media-dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  padding: 16px 0;
  margin-top: -8px;
}

.product-media-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(61, 54, 48, 0.2);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: all 0.25s ease;
}

.product-media-dot:hover {
  background: rgba(61, 54, 48, 0.4);
}

.product-media-dot--active {
  background: var(--flaio-text-primary, #3d3630);
  width: 10px;
  height: 10px;
}

/* Hide dots on desktop */
@media screen and (min-width: 750px) {
  .product-media-dots {
    display: none !important;
  }
}

/* ================================
   21. MICRO-INTERACTIONS FOR ADD TO CART BUTTON
   ================================ */

/* Add to Cart Button - Luxury Micro-Interactions */
.product-form__submit,
button[name="add"],
.btn--add-to-cart {
  position: relative;
  overflow: hidden;
  transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1), 
              box-shadow 0.25s cubic-bezier(0.4, 0, 0.2, 1),
              background-color 0.25s ease !important;
  box-shadow: 0 4px 12px rgba(61, 54, 48, 0.2) !important;
}

/* Hover: Lift and deepen shadow */
.product-form__submit:not(:disabled):hover,
button[name="add"]:not(:disabled):hover,
.btn--add-to-cart:not(:disabled):hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(61, 54, 48, 0.3) !important;
}

/* Active/Click: Scale down for tactile feedback */
.product-form__submit:not(:disabled):active,
button[name="add"]:not(:disabled):active,
.btn--add-to-cart:not(:disabled):active {
  transform: translateY(0) scale(0.98) !important;
  box-shadow: 0 2px 8px rgba(61, 54, 48, 0.2) !important;
  transition-duration: 0.1s !important;
}

/* Ripple effect container */
.product-form__submit::before,
button[name="add"]::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  background: rgba(255, 255, 255, 0.3);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: width 0.4s ease, height 0.4s ease, opacity 0.4s ease;
  pointer-events: none;
  z-index: 0;
}

/* Ripple on click */
.product-form__submit:active::before,
button[name="add"]:active::before {
  width: 300px;
  height: 300px;
  opacity: 1;
  transition: width 0s, height 0s, opacity 0s;
}

/* Keep button text above ripple */
.product-form__submit span,
button[name="add"] span {
  position: relative;
  z-index: 1;
}

/* Loading State - Spinner */
.product-form__submit.loading,
button[name="add"].loading {
  pointer-events: none;
}

.product-form__submit.loading > span:first-child,
button[name="add"].loading > span:first-child {
  opacity: 0 !important;
  visibility: hidden;
}

/* HIDE ALL SPINNERS by default - very aggressive */
.loading__spinner,
.loading__spinner.hidden,
.product-form__submit .loading__spinner,
.product-form__submit .loading__spinner.hidden,
button[name="add"] .loading__spinner,
button[name="add"] .loading__spinner.hidden,
.product-form__submit > .loading__spinner,
.product-form__submit > div.loading__spinner,
#ProductSubmitButton .loading__spinner,
#ProductSubmitButton-template--* .loading__spinner,
[id^="ProductSubmitButton"] .loading__spinner {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  position: absolute !important;
  pointer-events: none !important;
}

/* Show spinner ONLY when button has loading class AND spinner loses hidden class */
.product-form__submit.loading .loading__spinner:not(.hidden),
button[name="add"].loading .loading__spinner:not(.hidden) {
  display: flex !important;
  opacity: 1 !important;
  visibility: visible !important;
  width: 20px !important;
  height: 20px !important;
}

/* Custom spinning loader - ALWAYS HIDDEN unless loading class is present */
.product-form__submit .loading__spinner,
.product-form__submit .loading-overlay__spinner,
.product-form__submit svg.spinner,
.product-form__submit .spinner,
button[name="add"] .loading__spinner,
button[name="add"] .loading-overlay__spinner,
button[name="add"] svg.spinner,
button[name="add"] .spinner,
.button .loading__spinner,
.button .spinner {
  display: none !important; /* Hidden by default */
  opacity: 0 !important;
  visibility: hidden !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: 20px !important;
  height: 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.product-form__submit .loading__spinner .spinner,
button[name="add"] .loading__spinner .spinner {
  width: 20px !important;
  height: 20px !important;
  animation: atcSpinner 0.8s linear infinite !important;
}

.product-form__submit .loading__spinner .path,
button[name="add"] .loading__spinner .path {
  stroke: currentColor !important;
}

@keyframes atcSpinner {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

/* Success state animation */
@keyframes atcSuccess {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.05);
  }
}

.product-form__submit.success,
button[name="add"].success {
  animation: atcSuccess 0.4s ease;
  background-color: #228b22 !important;
}

/* Focus state for accessibility */
.product-form__submit:focus-visible,
button[name="add"]:focus-visible {
  outline: 2px solid #c9a961 !important;
  outline-offset: 3px !important;
}

/* ================================
   22. SECTION SPACING
   ================================ */

/* Reduce default section gap */
.shopify-section {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

/* Main content area */
main#MainContent {
  background: var(--flaio-bg-primary) !important;
}

/* ================================
   23. TEMU-STYLE SIZE SELECTOR
   ================================ */

/* Size selector container - FLEX container with wrap */
.product-form__input--pill {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  width: 100% !important;
  margin: 16px 0 !important;
  border: none !important;
  padding: 0 !important;
}

/* Legend takes full row */
.product-form__input--pill legend,
.product-form__input--pill .form__label {
  flex: 0 0 100% !important;
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #3d3630 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  margin-bottom: 4px !important;
  padding: 0 !important;
}

/* Size Guide link */
.product-form__input--pill .size-guide-link {
  font-size: 13px;
  font-weight: 500;
  color: #8c7e70;
  text-decoration: underline;
  cursor: pointer;
}

.product-form__input--pill .size-guide-link:hover {
  color: #3d3630;
}

/* Hide radio inputs but keep in flow for accessibility */
.product-form__input--pill input[type="radio"] {
  position: absolute !important;
  opacity: 0 !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
}

/* Size button labels - equal width distribution */
.product-form__input--pill input[type="radio"] + label {
  flex: 1 1 0 !important;
  min-width: 50px !important;
  max-width: 80px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 48px !important;
  padding: 0 8px !important;
  margin: 0 !important;
  background: #ffffff !important;
  border: 1.5px solid #e0dcd6 !important;
  border-radius: 8px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #3d3630 !important;
  cursor: pointer !important;
  transition: all 0.15s ease !important;
  white-space: nowrap !important;
  box-shadow: none !important;
}

.product-form__input--pill input[type="radio"] + label::before {
  display: none !important;
}

.product-form__input--pill input[type="radio"] + label:hover {
  border-color: #3d3630 !important;
  background: #faf8f5 !important;
}

/* Selected state - Temu orange/brand color accent */
.product-form__input--pill input[type="radio"]:checked + label {
  background: #fff5eb !important;
  border-color: #f97316 !important;
  border-width: 2px !important;
  color: #f97316 !important;
  font-weight: 600 !important;
}

/* Disabled/sold out state */
.product-form__input--pill input[type="radio"].disabled + label,
.product-form__input--pill input[type="radio"]:disabled + label {
  background: #f5f5f5 !important;
  border-color: #e5e5e5 !important;
  color: #bcbcbc !important;
  cursor: not-allowed !important;
  position: relative !important;
  text-decoration: none !important;
}

.product-form__input--pill input[type="radio"].disabled + label::after,
.product-form__input--pill input[type="radio"]:disabled + label::after {
  content: '' !important;
  position: absolute !important;
  top: 50% !important;
  left: 5px !important;
  right: 5px !important;
  height: 1px !important;
  background: #d0d0d0 !important;
  transform: rotate(-12deg) !important;
}

/* ================================
   24. FIT SLIDER (TRUE TO SIZE)
   ================================ */

.fit-slider {
  margin: 20px 0 24px 0;
  padding: 16px 16px 12px 16px;
  background: #f8f6f3;
  border-radius: 12px;
}

.fit-slider__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}

.fit-slider__title {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #3d3630;
}

.fit-slider__reviews {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  color: #8c7e70;
}

/* Track container */
.fit-slider__track-container {
  position: relative;
  margin-bottom: 10px;
  padding: 8px 0;
}

/* The track - neutral gray, no color gradient */
.fit-slider__track {
  position: relative;
  height: 6px;
  background: #d4d0c8;
  border-radius: 3px;
  overflow: hidden;
}

/* Fill showing fit position */
.fit-slider__fill {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  background: linear-gradient(90deg, #c9a961 0%, #d4b76a 100%);
  border-radius: 3px 0 0 3px;
  transition: width 0.3s ease;
}

/* Vertical notch at center (TRUE TO SIZE) - VISIBLE BAR */
.fit-slider__notch {
  position: absolute;
  left: 50%;
  top: 2px;
  transform: translateX(-50%);
  width: 1px;
  height: 18px;
  background: rgba(61, 54, 48, 0.4);
  border-radius: 0;
  z-index: 1;
}

/* Marker - vertical bar extending above and below the track */
.fit-slider__marker {
  position: absolute !important;
  top: 0 !important;
  transform: translateX(-50%) !important;
  width: 4px !important;
  height: 22px !important;
  background: #3d3630 !important;
  border-radius: 2px !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.3) !important;
  transition: left 0.3s ease !important;
  z-index: 100 !important;
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Tick marks on track */
.fit-slider__ticks {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 2px;
}

.fit-slider__tick {
  width: 1px;
  height: 10px;
  background: rgba(61, 54, 48, 0.3);
}

.fit-slider__tick--center {
  width: 2px;
  height: 100%;
  background: transparent; /* Hidden, we use the indicator above instead */
}

/* Labels below track */
.fit-slider__labels {
  display: flex;
  justify-content: space-between;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  color: #8c7e70;
  margin-top: 8px;
}

.fit-slider__label {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  flex: 1;
}

.fit-slider__label:first-child {
  align-items: flex-start;
}

.fit-slider__label:last-child {
  align-items: flex-end;
}

.fit-slider__label--center {
  align-items: center !important;
}

.fit-slider__label--active {
  color: #3d3630;
  font-weight: 600;
}

.fit-slider__label-text {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  line-height: 1.2;
}

/* Fit feedback summary */
.fit-slider__feedback {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(61, 54, 48, 0.08);
}

.fit-slider__feedback-icon {
  width: 18px;
  height: 18px;
  color: #3d3630;
  flex-shrink: 0;
}

.fit-slider__feedback-text {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  color: #3d3630;
}

.fit-slider__feedback-text strong {
  font-weight: 600;
}

/* ================================
   25. PRODUCT PAGE MOBILE OPTIMIZATIONS
   ================================ */

@media screen and (max-width: 749px) {
  /* 1. ZERO TOP PADDING - image directly below header */
  .section-main-product,
  .shopify-section--main-product,
  .shopify-section.section-main-product,
  product-info.section-template--*-padding {
    padding-top: 0 !important;
    margin-top: 0 !important;
  }
  
  /* Remove padding from page-width container */
  .section-main-product .page-width,
  .section-main-product .page-width--full-width,
  product-info .page-width {
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-top: 0 !important;
    margin-top: 0 !important;
  }
  
  /* Product grid - no top margin */
  .section-main-product .product,
  .section-main-product .product.grid,
  product-info .product,
  product-info .product.grid {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }
  
  /* Media column - no padding */
  .section-main-product .product__media-wrapper,
  .section-main-product .grid__item:first-child,
  product-info .product__media-wrapper {
    padding-top: 0 !important;
    margin-top: 0 !important;
  }
  
  /* Media wrapper - FULL WIDTH, NO GAPS */
  .product__media-wrapper {
    margin: 0 !important;
    padding: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(-50vw + 50%) !important;
  }
  
  .product-media-container,
  slider-component.slider-mobile-gutter {
    margin: 0 !important;
    padding: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    overflow: hidden !important;
  }
  
  /* Media list - NO GAPS between slides */
  .product__media-list {
    margin: 0 !important;
    padding: 0 !important;
    gap: 0 !important;
    scroll-snap-type: x mandatory !important;
    margin-bottom: 0 !important;
  }
  
  /* Each slide - EXACT 100vw width, no margins */
  .product__media-item {
    width: 100vw !important;
    min-width: 100vw !important;
    max-width: 100vw !important;
    flex: 0 0 100vw !important;
    padding: 0 !important;
    margin: 0 !important;
    scroll-snap-align: start !important;
  }
  
  /* NO ROUNDED CORNERS on media - ANYWHERE */
  .product__media-item .media,
  .product__media-item .media img,
  .product__media-item img,
  .product__media-item video,
  .product__media,
  .media-gallery .media,
  .global-media-settings,
  .global-media-settings--no-shadow,
  .product__media-item .global-media-settings,
  media-gallery .media,
  media-gallery img,
  slider-component img,
  slider-component .media,
  .deferred-media,
  .deferred-media__poster,
  .product-media-container,
  .product__media-wrapper,
  .product-media-container .media {
    border-radius: 0 !important;
  }
  
  /* Remove top margin/padding from product section - DIRECT BELOW HEADER */
  .shopify-section-group-header-group + .shopify-section,
  .shopify-section-group-header-group ~ .shopify-section:first-of-type,
  main#MainContent > .shopify-section:first-child {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }
  
  /* MainContent container - no top spacing */
  main#MainContent {
    padding-top: 0 !important;
    margin-top: 0 !important;
  }
  
  /* product-info element - remove section padding */
  product-info[class*="section-"][class*="-padding"] {
    padding-top: 0 !important;
  }
  
  /* 2. Hide dot pagination - keep only the counter */
  .slider-buttons + .slider-counter {
    display: flex !important;
  }
  
  .product__media-pagination,
  .slider-dots-mobile,
  slider-component .slider-counter ~ *:not(.slider-buttons) {
    display: none !important;
  }
  
  .product slider-component > :last-child:not(.slider-buttons):not(.slider-counter) {
    display: none !important;
  }
  
  /* 3. Slider counter - position over image at bottom right */
  .slider-buttons {
    position: absolute !important;
    bottom: 16px !important;
    right: 16px !important;
    left: auto !important;
    margin: 0 !important;
    padding: 8px 12px !important;
    background: rgba(0, 0, 0, 0.5) !important;
    border-radius: 20px !important;
    z-index: 20 !important;
  }
  
  .slider-buttons .slider-button {
    display: none !important;
  }
  
  .slider-counter {
    color: #ffffff !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 13px !important;
    font-weight: 500 !important;
  }
  
  .slider-counter--current,
  .slider-counter--total {
    color: #ffffff !important;
  }
  
  /* Position the gallery container relative for absolute positioning */
  slider-component.slider-mobile-gutter {
    position: relative !important;
  }
  
  .product__info-wrapper {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
  
  .product__info-container {
    padding-top: 8px !important;
    margin-top: 0 !important;
  }
  
  /* 4. Hide vendor name (FLAIO) */
  .product__text.caption-with-letter-spacing,
  .product .caption-with-letter-spacing:first-child,
  .product__info-container > .caption-with-letter-spacing:first-of-type {
    display: none !important;
  }
  
  [class*="block-vendor"],
  .product__text.inline-richtext[data-block-type="vendor"] {
    display: none !important;
  }
}

/* Hide vendor on all screen sizes on product page */
.product__text.caption-with-letter-spacing,
.product__text.inline-richtext.caption-with-letter-spacing,
.product .caption-with-letter-spacing:first-of-type,
.product__info-container > .caption-with-letter-spacing:first-child,
.product__info-container > p.product__text:first-of-type {
  display: none !important;
}

/* Hide the slider dots below counter */
slider-component .slider-counter + *,
.product slider-component > ul.slider-dots,
.product .slider-counter ~ ul,
.product .slider-buttons ~ ul:not(.slider__slide),
.product-media-dots,
.product__media-pagination {
  display: none !important;
}

/* 5. Always show "Free Shipping" */
.product__tax {
  display: none !important;
}

/* Custom free shipping display */
.product-free-shipping {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  color: #22c55e;
  font-weight: 500;
  margin-top: 4px;
}

.product-free-shipping svg {
  width: 14px;
  height: 14px;
  vertical-align: -2px;
  margin-right: 4px;
}

/* ================================
   26. SWIPE HINT ANIMATION
   ================================ */

/* Swipe hint overlay - covers the entire gallery */
.swipe-hint {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
  overflow: visible !important;
  z-index: 100 !important;
  display: block !important;
}

/* The white circle - positioned relative to gallery */
.swipe-hint__circle {
  position: absolute !important;
  top: 45% !important;
  right: 24px !important;
  width: 56px !important;
  height: 56px !important;
  background: rgba(255, 255, 255, 0.95) !important;
  border-radius: 50% !important;
  opacity: 0 !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3), 0 0 0 3px rgba(255, 255, 255, 0.4) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transform: translateY(-50%) !important;
}

/* Arrow inside the circle pointing left */
.swipe-hint__circle::before {
  content: '' !important;
  width: 12px !important;
  height: 12px !important;
  border-left: 3px solid #3d3630 !important;
  border-bottom: 3px solid #3d3630 !important;
  transform: rotate(45deg) translateX(2px) !important;
  opacity: 0.9 !important;
  display: block !important;
}

/* Animation: circle fades in, slides left with the scroll, fades out */
@keyframes swipeHintCircle {
  0% {
    opacity: 0;
    transform: translateY(-50%) scale(0.7);
  }
  15% {
    opacity: 1;
    transform: translateY(-50%) scale(1);
  }
  85% {
    opacity: 1;
    transform: translateY(-50%) scale(1);
  }
  100% {
    opacity: 0;
    transform: translateY(-50%) scale(0.9);
  }
}

.swipe-hint.active .swipe-hint__circle {
  animation: swipeHintCircle 1.5s ease-in-out forwards !important;
}

/* ================================
   27. DARK MODE - SYSTEM PREFERENCE
   Thoughtfully designed dark palette
   maintaining FLAIO's warm luxury aesthetic
   ================================ */

@media (prefers-color-scheme: dark) {
  
  /* ---- DARK MODE COLOR PALETTE ----
   * Primary BG: #1C1917 (warm dark charcoal)
   * Secondary BG: #252220 (elevated surface)
   * Elevated BG: #302D29 (cards, inputs)
   * Primary Text: #F5F3EF (warm off-white)
   * Secondary Text: #A39C93 (muted cream)
   * Accent Gold: #D4B971 (brighter for contrast)
   * Borders: rgba(255, 255, 255, 0.08)
   */
  
  /* ==== ROOT & GLOBAL OVERRIDES ==== */
  :root {
    /* Override FLAIO custom properties */
    --flaio-bg-primary: #141210;
    --flaio-bg-secondary: #2A2622;
    --flaio-bg-dark: #0F0E0D;
    --flaio-text-primary: #F5F3EF;
    --flaio-text-secondary: #A39C93;
    --flaio-text-inverse: #141210;
    --flaio-accent: #D4B971;
    --flaio-accent-light: #3D3730;
    --flaio-border: rgba(255, 255, 255, 0.08);
    
    /* Override Dawn's core variables */
    --color-background: 20, 18, 16;
    --color-foreground: 245, 243, 239;
    --gradient-background: #141210;
  }
  
  /* ==== SCHEME-1: Primary Light -> Dark Primary ==== */
  /* Used for main content areas - darkest background */
  .color-scheme-1 {
    --color-background: 20, 18, 16;
    --color-foreground: 245, 243, 239;
    --gradient-background: #141210;
    --color-button: 212, 185, 113;
    --color-button-text: 20, 18, 16;
    --color-secondary-button: 20, 18, 16;
    --color-secondary-button-text: 245, 243, 239;
    --color-link: 212, 185, 113;
    --color-badge-foreground: 245, 243, 239;
    --color-badge-background: 48, 45, 41;
    --color-badge-border: 245, 243, 239;
    --color-shadow: 0, 0, 0;
    background-color: #141210 !important;
    background: #141210 !important;
    color: #F5F3EF !important;
  }
  
  /* ==== SCHEME-2: Secondary (Sand) -> Elevated Warm Dark ==== */
  /* Used for value props, cards - warmer, slightly lighter */
  .color-scheme-2 {
    --color-background: 42, 38, 34;
    --color-foreground: 245, 243, 239;
    --gradient-background: #2A2622;
    --color-button: 212, 185, 113;
    --color-button-text: 42, 38, 34;
    --color-secondary-button: 42, 38, 34;
    --color-secondary-button-text: 245, 243, 239;
    --color-link: 212, 185, 113;
    --color-shadow: 0, 0, 0;
    background-color: #2A2622 !important;
    background: #2A2622 !important;
    color: #F5F3EF !important;
  }
  
  /* ==== SCHEME-3: Dark (Footer) -> Slightly Darker ==== */
  .color-scheme-3 {
    --color-background: 15, 14, 13;
    --color-foreground: 245, 243, 239;
    --gradient-background: #0F0E0D;
    --color-button: 245, 243, 239;
    --color-button-text: 15, 14, 13;
    --color-secondary-button: 15, 14, 13;
    --color-secondary-button-text: 245, 243, 239;
    --color-link: 212, 185, 113;
    --color-shadow: 0, 0, 0;
    background-color: #0F0E0D !important;
    background: #0F0E0D !important;
    color: #F5F3EF !important;
  }
  
  /* ==== SCHEME-4: Overlay/Hero -> Same or Darker ==== */
  .color-scheme-4 {
    --color-background: 0, 0, 0;
    --color-foreground: 255, 255, 255;
    --gradient-background: linear-gradient(rgba(0,0,0,0.3), rgba(0,0,0,0.6));
    --color-button: 212, 185, 113;
    --color-button-text: 0, 0, 0;
    --color-secondary-button: 0, 0, 0;
    --color-secondary-button-text: 255, 255, 255;
    --color-link: 212, 185, 113;
  }
  
  /* ==== SCHEME-5: Gold Accent -> Preserved ==== */
  .color-scheme-5 {
    --color-background: 212, 185, 113;
    --color-foreground: 28, 25, 23;
    --gradient-background: #D4B971;
    --color-button: 28, 25, 23;
    --color-button-text: 212, 185, 113;
    --color-secondary-button: 212, 185, 113;
    --color-secondary-button-text: 28, 25, 23;
    background-color: #D4B971 !important;
    background: #D4B971 !important;
    color: #1C1917 !important;
  }
  
  /* ==== HTML, BODY, MAIN ==== */
  html,
  body,
  main#MainContent,
  .gradient {
    background-color: #141210 !important;
    background: #141210 !important;
    color: #F5F3EF !important;
  }
  
  body {
    color: rgba(245, 243, 239, 0.85) !important;
  }
  
  /* Ensure gradient class uses proper dark background */
  .gradient.color-scheme-1 {
    background: #141210 !important;
    background-color: #141210 !important;
  }
  
  .gradient.color-scheme-2 {
    background: #2A2622 !important;
    background-color: #2A2622 !important;
  }
  
  /* ==== HEADER ==== */
  .header-wrapper,
  .header-wrapper.header-wrapper--border-bottom,
  .section-header .header-wrapper,
  .shopify-section-header-sticky .header-wrapper,
  .shopify-section-group-header-group .header-wrapper {
    background: #141210 !important;
    background-color: #141210 !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
  }
  
  .section-header,
  .section-header.shopify-section-header-sticky,
  .shopify-section-group-header-group,
  .shopify-section-header-sticky,
  .section-header.animate {
    background: #141210 !important;
    background-color: #141210 !important;
  }
  
  /* Ensure header stays dark when scrolling - override any inline styles */
  .header-wrapper::before,
  .header-wrapper::after {
    background: #141210 !important;
  }
  
  /* Override header gradient/background that might come from color scheme */
  .header-wrapper .gradient,
  .section-header .gradient {
    background: #141210 !important;
    --gradient-background: #141210 !important;
  }
  
  /* Sticky header states - Dawn uses .animate class when scrolled */
  .shopify-section-header-sticky.animate .header-wrapper,
  .section-header.animate .header-wrapper,
  .shopify-section-header-sticky.shopify-section-header-hidden .header-wrapper {
    background: #141210 !important;
    --color-foreground: 245, 243, 239 !important;
    --color-background: 20, 18, 16 !important;
  }
  
  /* Force override on header that might have inline styles */
  .section-header[style],
  .header-wrapper[style],
  .shopify-section-header-sticky[style] .header-wrapper {
    --color-foreground: 245, 243, 239 !important;
  }
  
  /* ==== SCROLLED HEADER STATES - Override light mode scroll styles ==== */
  /* Mobile scrolled state */
  .header-wrapper.header-wrapper--scrolled {
    background: rgba(20, 18, 16, 0.95) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
  }
  
  .header-wrapper.header-wrapper--scrolled .header__icon,
  .header-wrapper.header-wrapper--scrolled .header__icon svg,
  .header-wrapper.header-wrapper--scrolled .header__heading-link,
  .header-wrapper.header-wrapper--scrolled .header__heading-link .h2,
  .header-wrapper.header-wrapper--scrolled .header__heading-link h2,
  .header-wrapper.header-wrapper--scrolled .header__heading,
  .header-wrapper.header-wrapper--scrolled .h2 {
    color: #FFFFFF !important;
  }
  
  .header-wrapper.header-wrapper--scrolled .header__icon .icon,
  .header-wrapper.header-wrapper--scrolled .header__icon svg,
  .header-wrapper.header-wrapper--scrolled .header__icon svg path,
  .header-wrapper.header-wrapper--scrolled #cart-icon-bubble svg,
  .header-wrapper.header-wrapper--scrolled #cart-icon-bubble svg path {
    stroke: #FFFFFF !important;
    color: #FFFFFF !important;
  }
  
  /* Desktop scrolled-past-header state */
  .scrolled-past-header .header-wrapper,
  .scrolled-past-header.shopify-section-header-sticky .header-wrapper {
    background: rgba(20, 18, 16, 0.95) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
  }
  
  .scrolled-past-header .header__icon,
  .scrolled-past-header .header__icon svg,
  .scrolled-past-header .header__heading-link,
  .scrolled-past-header .header__heading-link .h2,
  .scrolled-past-header .header__heading-link h2,
  .scrolled-past-header .header__heading,
  .scrolled-past-header .h2,
  .scrolled-past-header .header__menu-item,
  .scrolled-past-header .header__menu-item span {
    color: #FFFFFF !important;
  }
  
  .scrolled-past-header .header__icon .icon,
  .scrolled-past-header .header__icon svg,
  .scrolled-past-header .header__icon svg path,
  .scrolled-past-header #cart-icon-bubble svg,
  .scrolled-past-header #cart-icon-bubble svg path {
    stroke: #FFFFFF !important;
    color: #FFFFFF !important;
  }
  
  /* Animate reveal state */
  .shopify-section-header-sticky.animate .header__icon,
  .shopify-section-header-sticky.animate .header__icon svg,
  .shopify-section-header-sticky.animate .header__heading-link,
  .shopify-section-header-sticky.animate .header__heading-link .h2,
  .shopify-section-header-sticky.animate .header__menu-item,
  .shopify-section-header-sticky.animate .header__menu-item span {
    color: #FFFFFF !important;
  }
  
  .shopify-section-header-sticky.animate .header__icon svg,
  .shopify-section-header-sticky.animate .header__icon svg path,
  .shopify-section-header-sticky.animate #cart-icon-bubble svg,
  .shopify-section-header-sticky.animate #cart-icon-bubble svg path {
    stroke: #FFFFFF !important;
    color: #FFFFFF !important;
  }
  
  /* Header logo/title - MUST stay WHITE and visible */
  .header__heading-link,
  .header__heading-link .h2,
  .header__heading,
  .header__heading a,
  .header .header__heading-link,
  .header-wrapper .header__heading-link,
  .section-header .header__heading-link,
  .shopify-section-header-sticky .header__heading-link,
  .header-wrapper .header__heading-link .h2,
  .section-header .header__heading-link .h2,
  [class*="header"] .header__heading-link,
  [class*="header"] .header__heading-link .h2,
  .shopify-section-header-sticky.animate .header__heading-link,
  .shopify-section-header-sticky.animate .header__heading-link .h2,
  .section-header.animate .header__heading-link,
  .section-header.animate .header__heading-link .h2,
  .header__heading-link h2,
  .header__heading-link span,
  h2.header__heading-link,
  a.header__heading-link {
    color: #FFFFFF !important;
    --color-foreground: 255, 255, 255 !important;
    opacity: 1 !important;
  }
  
  /* Override any inline color styles on header - force WHITE foreground */
  .header-wrapper,
  .header-wrapper *,
  .section-header,
  .section-header *,
  .shopify-section-header-sticky .header-wrapper,
  .shopify-section-header-sticky .header-wrapper *,
  .shopify-section-header-sticky.animate .header-wrapper,
  .shopify-section-header-sticky.animate .header-wrapper * {
    --color-foreground: 255, 255, 255 !important;
  }
  
  /* Header icons - MUST stay WHITE and visible */
  .header__icon,
  .header__icon svg,
  .header__icon .icon,
  .header__icons .header__icon,
  .header__icons svg,
  .header-wrapper .header__icon,
  .header-wrapper .header__icon svg,
  .section-header .header__icon,
  .section-header .header__icon svg,
  .header__icon--cart,
  .header__icon--cart svg,
  .header__search svg,
  .header__search .icon,
  #cart-icon-bubble svg,
  .header .svg-wrapper svg,
  [class*="header"] .header__icon svg,
  [class*="header"] .svg-wrapper svg,
  .shopify-section-header-sticky .header__icon svg,
  .shopify-section-header-sticky.animate .header__icon svg,
  .section-header.animate .header__icon svg,
  details-modal .header__icon svg,
  cart-notification .header__icon svg {
    color: #FFFFFF !important;
    stroke: #FFFFFF !important;
    fill: none !important;
    opacity: 1 !important;
  }
  
  /* Icon path strokes must be white */
  .header__icon svg path,
  .header__icons svg path,
  #cart-icon-bubble svg path,
  .header__search svg path {
    stroke: #FFFFFF !important;
    color: #FFFFFF !important;
  }
  
  /* Menu drawer icon */
  .header__icon--menu svg,
  .header__icon--menu .icon,
  .header__icon--menu .icon-hamburger,
  .header__icon--menu .icon-close {
    color: #FFFFFF !important;
    stroke: #FFFFFF !important;
  }
  
  .header__menu-item,
  .header__menu-item span,
  .list-menu__item,
  .header__inline-menu .list-menu__item {
    color: #A39C93 !important;
  }
  
  .header__menu-item:hover,
  .header__menu-item:hover span,
  .list-menu__item:hover {
    color: #F5F3EF !important;
  }
  
  .header__menu-item span::after {
    background: #D4B971 !important;
  }
  
  /* Cart bubble in dark mode - gold with dark text */
  .cart-count-bubble,
  .header .cart-count-bubble,
  .header-wrapper .cart-count-bubble,
  #cart-icon-bubble .cart-count-bubble {
    background-color: #D4B971 !important;
    color: #141210 !important;
  }
  
  /* ==== SEARCH MODAL - Dark Mode ==== */
  
  /* Main search modal container */
  .search-modal,
  .search-modal.gradient {
    background: #141210 !important;
    --gradient-background: #141210 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
  }
  
  /* Modal overlay - dark backdrop */
  .search-modal .modal-overlay {
    background: rgba(0, 0, 0, 0.8) !important;
  }
  
  /* Search modal content area */
  .search-modal__content,
  .search-modal__content-bottom,
  .search-modal__content-top {
    background: #141210 !important;
  }
  
  /* Search form container */
  .search-modal__form,
  .search-modal__form.search,
  predictive-search.search-modal__form {
    background: #141210 !important;
  }
  
  /* Search input field */
  .search-modal .field__input,
  .search-modal input[type="search"],
  .search__input,
  .search-modal .search__input,
  predictive-search .field__input,
  .search .field__input {
    background: #1E1B19 !important;
    border: 1px solid rgba(255, 255, 255, 0.25) !important;
    color: #FFFFFF !important;
  }
  
  .search-modal .field__input::placeholder,
  .search__input::placeholder,
  .search .field__input::placeholder {
    color: rgba(255, 255, 255, 0.5) !important;
  }
  
  .search-modal .field__input:focus,
  .search__input:focus,
  .search .field__input:focus {
    border-color: #D4B971 !important;
    outline: none !important;
    box-shadow: 0 0 0 1px #D4B971 !important;
  }
  
  /* Field label */
  .search-modal .field__label,
  .search .field__label {
    color: rgba(255, 255, 255, 0.6) !important;
  }
  
  /* Search button/icon */
  .search-modal .field__button,
  .search-modal .search__button,
  .search-modal button svg,
  .search .field__button svg,
  .search .search__button svg {
    color: #FFFFFF !important;
  }
  
  .search-modal .field__button svg path,
  .search .field__button svg path,
  .search .search__button svg path {
    stroke: #FFFFFF !important;
  }
  
  /* Close button */
  .search-modal__close-button,
  .search-modal .modal__close-button {
    color: #FFFFFF !important;
  }
  
  .search-modal__close-button svg,
  .search-modal .modal__close-button svg {
    stroke: #FFFFFF !important;
    color: #FFFFFF !important;
  }
  
  /* Reset/clear button */
  .search-modal .reset__button,
  .search .reset__button {
    color: rgba(255, 255, 255, 0.6) !important;
  }
  
  .search-modal .reset__button svg,
  .search .reset__button svg {
    stroke: rgba(255, 255, 255, 0.6) !important;
  }
  
  /* Predictive search results */
  .predictive-search,
  .predictive-search--header,
  .predictive-search__results-groups-wrapper {
    background: #141210 !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
  }
  
  .predictive-search__result-group {
    background: #141210 !important;
  }
  
  .predictive-search__heading {
    color: #D4B971 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
  }
  
  .predictive-search__item {
    color: #F5F3EF !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
  }
  
  .predictive-search__item a,
  .predictive-search__item-heading {
    color: #F5F3EF !important;
  }
  
  .predictive-search__item:hover,
  .predictive-search__item:focus {
    background: rgba(255, 255, 255, 0.05) !important;
  }
  
  .predictive-search__item-content {
    color: rgba(255, 255, 255, 0.7) !important;
  }
  
  /* Loading spinner */
  .predictive-search__loading-state svg {
    stroke: #D4B971 !important;
  }
  
  /* Search modal positioning - make it full-width header bar */
  .header__search {
    position: static !important;
  }
  
  details-modal.header__search {
    position: static !important;
  }
  
  details-modal.header__search details[open] {
    position: static !important;
  }
  
  /* The search modal should cover the entire header when open */
  details-modal.header__search details[open] .search-modal {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 100 !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 2rem !important;
  }
  
  /* Search form should take full width */
  details-modal.header__search details[open] .search-modal__content {
    flex: 1 !important;
    max-width: 100% !important;
  }
  
  details-modal.header__search details[open] .search-modal__form,
  details-modal.header__search details[open] .search-modal__form.search {
    width: 100% !important;
  }
  
  details-modal.header__search details[open] .search .field {
    width: 100% !important;
  }
  
  /* Header submenu / dropdown */
  .header__submenu,
  .header__submenu.list-menu {
    background-color: #252220 !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
  }
  
  .header__submenu .header__submenu {
    background-color: rgba(255, 255, 255, 0.03) !important;
  }
  
  .header__submenu .header__menu-item {
    color: #A39C93 !important;
  }
  
  .header__submenu .header__menu-item:hover {
    color: #F5F3EF !important;
  }
  
  /* Global popup settings */
  .global-settings-popup,
  .header__submenu.global-settings-popup {
    background-color: #252220 !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
  }
  
  /* ==== PRODUCT CARDS ==== */
  /* Cards should be transparent to blend with section background */
  .card,
  .card--standard,
  .card--card,
  .card__inner {
    background-color: transparent !important;
    background: transparent !important;
  }
  
  /* Card media (image container) can have subtle background */
  .card__media,
  .card__media .media {
    background-color: rgba(255, 255, 255, 0.03) !important;
  }
  
  .card__heading,
  .card__heading a,
  .card__heading .full-unstyled-link {
    color: #F5F3EF !important;
  }
  
  .price,
  .price-item,
  .price-item--regular,
  .price-item--sale {
    color: #A39C93 !important;
  }
  
  /* Badge in dark mode */
  .badge {
    background: #D4B971 !important;
    color: #1C1917 !important;
  }
  
  /* Quick add button */
  .quick-add__submit,
  .quick-add .button,
  .quick-add button[type="submit"],
  button.quick-add__submit {
    background: #252220 !important;
    color: #F5F3EF !important;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.4) !important;
  }
  
  .quick-add__submit:hover,
  .quick-add .button:hover,
  .quick-add button[type="submit"]:hover {
    background: #D4B971 !important;
    color: #1C1917 !important;
  }
  
  /* ==== BUTTONS ==== */
  /* Primary button */
  .button:not(.button--secondary):not(.button--tertiary),
  .shopify-payment-button__button--unbranded {
    background-color: #D4B971 !important;
    color: #1C1917 !important;
    border: none !important;
  }
  
  .button:not(.button--secondary):not(.button--tertiary):hover,
  .shopify-payment-button__button--unbranded:hover {
    background-color: #E5CA82 !important;
    color: #1C1917 !important;
  }
  
  /* Secondary button */
  .button--secondary {
    background-color: transparent !important;
    border: 1px solid rgba(245, 243, 239, 0.3) !important;
    color: #F5F3EF !important;
  }
  
  .button--secondary:hover {
    background-color: #F5F3EF !important;
    color: #1C1917 !important;
    border-color: #F5F3EF !important;
  }
  
  /* Add to Cart button */
  .product-form__submit,
  button[name="add"],
  .btn--add-to-cart {
    background-color: #D4B971 !important;
    color: #1C1917 !important;
    box-shadow: 0 4px 12px rgba(212, 185, 113, 0.3) !important;
  }
  
  .product-form__submit:not(:disabled):hover,
  button[name="add"]:not(:disabled):hover {
    background-color: #E5CA82 !important;
    box-shadow: 0 8px 24px rgba(212, 185, 113, 0.4) !important;
  }
  
  /* ==== FORM INPUTS ==== */
  .field__input,
  .select__select,
  .customer .field input,
  .customer select {
    background-color: #302D29 !important;
    color: #F5F3EF !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
  }
  
  .field__input::placeholder,
  .customer .field input::placeholder {
    color: #706B64 !important;
  }
  
  .field__label,
  .customer .field label {
    color: #A39C93 !important;
  }
  
  .field:after,
  .select:after,
  .customer .field:after {
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.1) !important;
  }
  
  /* Quantity input */
  .quantity {
    background-color: #302D29 !important;
    color: #F5F3EF !important;
  }
  
  .quantity:after {
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.1) !important;
  }
  
  .quantity:before {
    background: #302D29 !important;
  }
  
  .quantity__button {
    color: #F5F3EF !important;
  }
  
  .quantity__input {
    color: #F5F3EF !important;
  }
  
  /* ==== SIZE SELECTOR (TEMU STYLE) ==== */
  .product-form__input--pill input[type="radio"] + label {
    background: #302D29 !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
    color: #F5F3EF !important;
  }
  
  .product-form__input--pill input[type="radio"] + label:hover {
    border-color: #D4B971 !important;
    background: #3D3A35 !important;
  }
  
  .product-form__input--pill input[type="radio"]:checked + label {
    background: rgba(212, 185, 113, 0.15) !important;
    border-color: #D4B971 !important;
    color: #D4B971 !important;
  }
  
  .product-form__input--pill legend,
  .product-form__input--pill .form__label {
    color: #F5F3EF !important;
  }
  
  .product-form__input--pill .size-guide-link {
    color: #A39C93 !important;
  }
  
  .product-form__input--pill .size-guide-link:hover {
    color: #D4B971 !important;
  }
  
  /* Disabled sizes */
  .product-form__input--pill input[type="radio"].disabled + label,
  .product-form__input--pill input[type="radio"]:disabled + label {
    background: #252220 !important;
    border-color: rgba(255, 255, 255, 0.05) !important;
    color: #504D48 !important;
  }
  
  .product-form__input--pill input[type="radio"].disabled + label::after,
  .product-form__input--pill input[type="radio"]:disabled + label::after {
    background: #504D48 !important;
  }
  
  /* ==== FIT SLIDER ==== */
  .fit-slider {
    background: #252220 !important;
  }
  
  .fit-slider__title {
    color: #F5F3EF !important;
  }
  
  .fit-slider__reviews {
    color: #A39C93 !important;
  }
  
  .fit-slider__track {
    background: #3D3A35 !important;
  }
  
  .fit-slider__fill {
    background: linear-gradient(90deg, #D4B971 0%, #E5C97A 100%) !important;
  }
  
  .fit-slider__notch {
    background: #F5F3EF !important;
  }
  
  .fit-slider__marker {
    background: #F5F3EF !important;
  }
  
  .fit-slider__label {
    color: #706B64 !important;
  }
  
  .fit-slider__label--active {
    color: #F5F3EF !important;
  }
  
  .fit-slider__feedback {
    border-top-color: rgba(255, 255, 255, 0.08) !important;
  }
  
  .fit-slider__feedback-icon {
    color: #D4B971 !important;
  }
  
  .fit-slider__feedback-text {
    color: #F5F3EF !important;
  }
  
  /* ==== PRODUCT PAGE ==== */
  .product__title,
  .product__title h1 {
    color: #F5F3EF !important;
  }
  
  .product__crystal-subtitle {
    color: #A39C93 !important;
  }
  
  .product__price-shipping .price-item--regular {
    color: #F5F3EF !important;
  }
  
  /* Free shipping text */
  .product-free-shipping {
    color: #6EE7A0 !important;
  }
  
  /* Product accordions */
  .product-accordion {
    border-color: rgba(255, 255, 255, 0.08) !important;
  }
  
  .product-accordion__header {
    color: #F5F3EF !important;
  }
  
  .product-accordion__header:hover {
    color: #D4B971 !important;
  }
  
  .product-accordion__icon::before,
  .product-accordion__icon::after {
    background-color: #F5F3EF !important;
  }
  
  .product-accordion__content-inner {
    color: #A39C93 !important;
  }
  
  .product-accordion__content-inner p,
  .product-accordion__content-inner li {
    color: #A39C93 !important;
  }
  
  /* Details under photos (desktop) */
  .product__details-under-photos {
    background-color: #252220 !important;
  }
  
  .product__details-under-photos .product-accordion__content-inner p,
  .product__details-under-photos .product-accordion__content-inner li {
    color: #A39C93 !important;
  }
  
  .product__details-under-photos .trust-icons-default {
    border-top-color: rgba(255, 255, 255, 0.08) !important;
  }
  
  /* Gallery slider counter */
  .slider-counter {
    background: rgba(0, 0, 0, 0.6) !important;
  }
  
  /* ==== MULTICOLUMN / VALUE PROPS ==== */
  /* Value props section should be scheme-2 (warmer, elevated) */
  /* NO rounded corners - full bleed section */
  .multicolumn.color-scheme-2,
  .color-scheme-2.multicolumn,
  section.color-scheme-2,
  .shopify-section .color-scheme-2 {
    background: #2A2622 !important;
    background-color: #2A2622 !important;
    border-radius: 0 !important;
  }
  
  /* Remove rounded corners from content container in sections */
  .color-scheme-2 .content-container,
  .multicolumn .content-container,
  .multicolumn.color-scheme-2 .section-template,
  .color-scheme-2 .multicolumn-list {
    border-radius: 0 !important;
  }
  
  .multicolumn-card .rte strong,
  .multicolumn-card__info .rte strong,
  .rte .value-prop-label {
    color: #D4B971 !important;
  }
  
  .multicolumn-card .rte h3,
  .multicolumn-card__info .rte h3,
  .multicolumn-card__info h3,
  .multicolumn-card__heading,
  .multicolumn-card .h2 {
    color: #F5F3EF !important;
  }
  
  .multicolumn-card__info .rte,
  .multicolumn-card__info p,
  .multicolumn-card .rte p {
    color: #A39C93 !important;
  }
  
  /* ==== SECTIONS & TITLES ==== */
  .title,
  .collection-hero__title,
  .featured-collection .title {
    color: #F5F3EF !important;
  }
  
  .caption-with-letter-spacing,
  .subtitle--small,
  .collection__title--small {
    color: #D4B971 !important;
  }
  
  .subtitle {
    color: #A39C93 !important;
  }
  
  /* Rich text sections */
  .rich-text__heading {
    color: #F5F3EF !important;
  }
  
  .rich-text__text,
  .rich-text__caption {
    color: #A39C93 !important;
  }
  
  .rich-text__caption,
  .image-with-text__text .caption {
    color: #D4B971 !important;
  }
  
  /* ==== FOOTER (already dark, make slightly darker) ==== */
  footer.footer,
  .footer,
  .section-footer,
  .shopify-section-footer footer,
  .shopify-section-group-footer-group footer,
  footer.color-scheme-3,
  .footer.color-scheme-3 {
    background: #0F0E0D !important;
    background-color: #0F0E0D !important;
    color: #F5F3EF !important;
  }
  
  footer.footer.gradient,
  .footer.gradient,
  .footer.color-scheme-3.gradient {
    background: #0F0E0D !important;
    background-color: #0F0E0D !important;
  }
  
  .footer__content-bottom {
    border-top-color: rgba(255, 255, 255, 0.08) !important;
  }
  
  /* Footer newsletter input */
  .footer .field__input,
  .footer .newsletter-form .field__input {
    background: transparent !important;
    border-color: rgba(255, 255, 255, 0.2) !important;
    color: #F5F3EF !important;
  }
  
  .footer .field__input:focus {
    border-color: rgba(255, 255, 255, 0.4) !important;
  }
  
  /* ==== CART DRAWER ==== */
  .drawer {
    background: rgba(0, 0, 0, 0.6) !important;
  }
  
  .drawer__inner,
  .drawer__inner-empty,
  .cart-notification {
    background: #1C1917 !important;
  }
  
  .drawer__header,
  .cart-drawer__header {
    border-bottom-color: rgba(255, 255, 255, 0.08) !important;
  }
  
  .cart-item {
    border-bottom-color: rgba(255, 255, 255, 0.08) !important;
  }
  
  .cart-item__name,
  .cart-item__details {
    color: #F5F3EF !important;
  }
  
  .cart-item__price-wrapper {
    color: #A39C93 !important;
  }
  
  /* ==== QUICK ADD MODAL ==== */
  .quick-add-modal {
    background: rgba(0, 0, 0, 0.7) !important;
  }
  
  .quick-add-modal__content {
    background: #1C1917 !important;
    box-shadow: 0 25px 80px rgba(0, 0, 0, 0.5) !important;
  }
  
  quick-add-modal .quick-add-modal__toggle {
    background: #302D29 !important;
  }
  
  quick-add-modal .quick-add-modal__toggle:hover {
    background: #3D3A35 !important;
  }
  
  quick-add-modal .quick-add-modal__toggle .icon,
  quick-add-modal .quick-add-modal__toggle svg {
    color: #F5F3EF !important;
  }
  
  quick-add-modal .quick-add-modal__product-header {
    border-bottom-color: rgba(255, 255, 255, 0.08) !important;
  }
  
  quick-add-modal .quick-add-modal__product-header .product__title > a,
  quick-add-modal .product__title > a {
    color: #F5F3EF !important;
  }
  
  quick-add-modal .price-item,
  quick-add-modal .price-item--regular {
    color: #A39C93 !important;
  }
  
  quick-add-modal .product-form__input--pill legend,
  quick-add-modal .product-form__input legend,
  quick-add-modal .form__label {
    color: #F5F3EF !important;
  }
  
  quick-add-modal .product-form__input--pill label {
    background: #302D29 !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
    color: #F5F3EF !important;
  }
  
  quick-add-modal .product-form__input--pill label:hover {
    border-color: #D4B971 !important;
  }
  
  quick-add-modal .product-form__input--pill input[type="radio"]:checked + label {
    background: rgba(212, 185, 113, 0.15) !important;
    border-color: #D4B971 !important;
    color: #D4B971 !important;
  }
  
  quick-add-modal .product-form__submit {
    background: #D4B971 !important;
    color: #1C1917 !important;
  }
  
  quick-add-modal .product-form__submit:hover {
    background: #E5CA82 !important;
  }
  
  /* ==== COLLECTION PAGE ==== */
  .collection-hero {
    background-color: #1C1917 !important;
  }
  
  /* Filter pills */
  .facet-filters__field,
  .facets__disclosure,
  .active-facets__button {
    background: #252220 !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
    color: #F5F3EF !important;
  }
  
  .facet-filters__field:hover,
  .facets__disclosure:hover {
    border-color: rgba(255, 255, 255, 0.3) !important;
  }
  
  /* Facets dropdown */
  .facets__disclosure[open] .facets__summary,
  .facets__summary--active {
    background: #302D29 !important;
  }
  
  .facets__display {
    background: #252220 !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
  }
  
  /* ==== CONTENT CONTAINERS ==== */
  .content-container {
    background-color: #252220 !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
  }
  
  /* ==== MEDIA SETTINGS ==== */
  .media {
    background-color: #302D29 !important;
  }
  
  .media--transparent {
    background-color: transparent !important;
  }
  
  .global-media-settings {
    background-color: #1C1917 !important;
    border-color: rgba(255, 255, 255, 0.05) !important;
  }
  
  /* ==== PLACEHOLDER / EMPTY STATES ==== */
  .placeholder {
    background-color: #252220 !important;
    color: #706B64 !important;
    fill: #706B64 !important;
  }
  
  /* ==== MISC OVERRIDES ==== */
  /* Selection */
  ::selection {
    background-color: rgba(212, 185, 113, 0.3) !important;
  }
  
  /* Horizontal rules */
  hr {
    background-color: rgba(255, 255, 255, 0.1) !important;
  }
  
  /* Tables */
  table:not([class]) {
    box-shadow: 0 0 0 0.1rem rgba(255, 255, 255, 0.1) !important;
  }
  
  table:not([class]) td,
  table:not([class]) th {
    border-color: rgba(255, 255, 255, 0.1) !important;
  }
  
  /* Blockquotes */
  blockquote {
    color: #A39C93 !important;
    border-left-color: rgba(255, 255, 255, 0.15) !important;
  }
  
  /* H6 */
  h6,
  .h6 {
    color: #A39C93 !important;
  }
  
  /* Links */
  .link,
  .customer a {
    color: #D4B971 !important;
  }
  
  .link--text {
    color: #F5F3EF !important;
  }
  
  .link--text:hover {
    color: #A39C93 !important;
  }
  
  .underlined-link,
  .customer a {
    color: #D4B971 !important;
  }
  
  .underlined-link:hover,
  .customer a:hover {
    color: #E5CA82 !important;
  }
  
  /* RTE content */
  .rte a {
    color: #D4B971 !important;
  }
  
  .rte a:hover {
    color: #E5CA82 !important;
  }
  
  /* Focus states */
  *:focus-visible {
    outline-color: #D4B971 !important;
  }
  
  /* Loading spinner */
  .path {
    stroke: #F5F3EF !important;
  }
  
  /* Progress bar */
  .progress-bar-value {
    background-color: #D4B971 !important;
  }
  
  /* Popups and drawers */
  .popup,
  .drawer__inner {
    background-color: #1C1917 !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
  }
  
  /* Localization form */
  .localization-form__select {
    color: #F5F3EF !important;
    background-color: transparent !important;
  }
  
  .disclosure__list-wrapper {
    background-color: #252220 !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
  }
  
  .disclosure__link {
    color: #A39C93 !important;
  }
  
  .disclosure__link:hover {
    color: #F5F3EF !important;
  }
  
  /* Share button fallback */
  .share-button__fallback:before {
    background: #252220 !important;
  }
  
  .share-button__fallback:after {
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.1) !important;
  }
  
  .share-button__copy,
  .share-button__close {
    background-color: transparent !important;
    color: #F5F3EF !important;
  }
  
  /* Swipe hint circle */
  .swipe-hint__circle {
    background: rgba(28, 25, 23, 0.95) !important;
  }
  
  .swipe-hint__circle::before {
    border-left-color: #F5F3EF !important;
    border-bottom-color: #F5F3EF !important;
  }
  
  /* ==== BULK PRICING ROW ==== */
  .qty-bulk-row__bulk-box {
    background-color: #252220 !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
  }
  
  .qty-bulk-row__label {
    color: #F5F3EF !important;
  }
  
  .qty-bulk-row__price-original {
    color: #706B64 !important;
  }
  
  .qty-bulk-row__price-sale {
    color: #6EE7A0 !important;
  }
  
  .qty-bulk-row__badge {
    background-color: #D4B971 !important;
    color: #1C1917 !important;
  }
  
  /* ==== TRUST ICONS ==== */
  .trust-icons-default__icon {
    color: #A39C93 !important;
  }
  
  .trust-icons-default__label {
    color: #A39C93 !important;
  }
  
  /* ==== LOOKBOOK ==== */
  .flaio-lookbook__card-label {
    background: rgba(28, 25, 23, 0.9) !important;
    color: #F5F3EF !important;
  }
  
  .flaio-lookbook-page__card-label {
    background: rgba(28, 25, 23, 0.9) !important;
    color: #F5F3EF !important;
  }
  
  /* ==== CAMPAIGN PAGES DARK MODE ==== */
  
  /* Campaign Collection - How It Works Section */
  .campaign-collection__how-it-works {
    background: #252220 !important;
  }
  
  .campaign-collection__how-title,
  .campaign-collection__how-subtitle {
    color: #F5F3EF !important;
  }
  
  .campaign-step__title {
    color: #F5F3EF !important;
  }
  
  .campaign-step__text {
    color: #A39C93 !important;
  }
  
  .campaign-collection__guarantee {
    background: rgba(45, 106, 79, 0.15) !important;
    border-color: rgba(110, 231, 183, 0.3) !important;
    color: #6EE7B7 !important;
  }
  
  /* Campaign Cards */
  .campaign-card {
    background: #252220 !important;
  }
  
  .campaign-card__title {
    color: #F5F3EF !important;
  }
  
  .campaign-card__price {
    color: #D4B971 !important;
  }
  
  .campaign-card__progress-bar {
    background: rgba(255, 255, 255, 0.1) !important;
  }
  
  .campaign-card__stats {
    color: #A39C93 !important;
  }
  
  .campaign-card__funded-text {
    color: #D4B971 !important;
  }
  
  .campaign-card__remaining {
    color: #A39C93 !important;
  }
  
  .campaign-card__cta {
    background: #302D29 !important;
    color: #F5F3EF !important;
    border-color: rgba(255, 255, 255, 0.2) !important;
  }
  
  .campaign-card__cta:hover {
    background: #D4B971 !important;
    color: #1C1917 !important;
  }
  
  /* Campaign Product Page - Inline Elements */
  .campaign-inline__vote {
    background: linear-gradient(135deg, #302D29 0%, #252220 100%) !important;
    border-color: #D4B971 !important;
  }
  
  .campaign-inline__vote-title {
    color: #F5F3EF !important;
  }
  
  .campaign-inline__vote-text {
    color: #A39C93 !important;
  }
  
  .campaign-inline__progress {
    background: #302D29 !important;
  }
  
  .campaign-inline__progress-label {
    color: #A39C93 !important;
  }
  
  .campaign-inline__progress-status {
    color: #D4B971 !important;
  }
  
  .campaign-inline__bar {
    background: rgba(255, 255, 255, 0.15) !important;
  }
  
  .campaign-inline__stats {
    color: #A39C93 !important;
  }
  
  .campaign-inline__stat-value {
    color: #F5F3EF !important;
  }
  
  .campaign-inline__countdown {
    background: #302D29 !important;
    color: #A39C93 !important;
  }
  
  .campaign-inline__countdown strong {
    color: #F5F3EF !important;
  }
  
  .campaign-inline__guarantee {
    background: rgba(45, 106, 79, 0.15) !important;
    border-color: rgba(110, 231, 183, 0.3) !important;
    color: #6EE7B7 !important;
  }
  
  .campaign-inline__asap {
    background: rgba(212, 185, 113, 0.15) !important;
    border-color: rgba(212, 185, 113, 0.3) !important;
    color: #D4B971 !important;
  }
  
  .campaign-inline__funded {
    background: linear-gradient(135deg, #1e4d3a 0%, #2d6a4f 100%) !important;
  }
  
  /* Gift With Purchase Dark Mode */
  .gift-with-purchase {
    background: linear-gradient(135deg, rgba(45, 106, 79, 0.15) 0%, rgba(45, 106, 79, 0.1) 100%) !important;
    border-color: rgba(110, 231, 183, 0.25) !important;
  }
  
  .gift-with-purchase__thumbnail {
    background: #302D29 !important;
    border-color: rgba(255, 255, 255, 0.1) !important;
  }
  
  .gift-with-purchase__thumbnail svg {
    color: #6EE7B7 !important;
  }
  
  .gift-with-purchase__content strong,
  .gift-with-purchase__title {
    color: #6EE7B7 !important;
  }
  
  .gift-with-purchase__content span,
  .gift-with-purchase__text {
    color: #A39C93 !important;
  }
  
  .gift-with-purchase__icon svg {
    color: #6EE7B7 !important;
  }
  
  /* Quantity Bulk Row (Buy 2+) Dark Mode */
  .qty-bulk-row__qty {
    background: #302D29 !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
  }
  
  .qty-bulk-row__qty-btn {
    color: #F5F3EF !important;
  }
  
  .qty-bulk-row__qty-btn:hover {
    background: rgba(255, 255, 255, 0.1) !important;
  }
  
  .qty-bulk-row__qty-input {
    background: transparent !important;
    color: #F5F3EF !important;
  }
  
  .qty-bulk-row__bulk-box {
    background: #302D29 !important;
    border-color: rgba(255, 255, 255, 0.15) !important;
  }
  
  .qty-bulk-row__bulk:hover .qty-bulk-row__bulk-box {
    border-color: rgba(255, 255, 255, 0.3) !important;
  }
  
  .qty-bulk-row__bulk input[type="radio"]:checked + .qty-bulk-row__bulk-box {
    border-color: #D4B971 !important;
    background: rgba(212, 185, 113, 0.1) !important;
  }
  
  .qty-bulk-row__radio {
    border-color: rgba(255, 255, 255, 0.3) !important;
  }
  
  .qty-bulk-row__bulk input[type="radio"]:checked + .qty-bulk-row__bulk-box .qty-bulk-row__radio {
    border-color: #D4B971 !important;
  }
  
  .qty-bulk-row__radio::after {
    background: #D4B971 !important;
  }
  
  .qty-bulk-row__label {
    color: #F5F3EF !important;
  }
  
  .qty-bulk-row__label small {
    color: #A39C93 !important;
  }
  
  .qty-bulk-row__price-original {
    color: #6B6560 !important;
  }
  
  .qty-bulk-row__price-sale {
    color: #6EE7A0 !important;
  }
  
  .qty-bulk-row__price-total {
    color: #6EE7A0 !important;
  }
  
  .qty-bulk-row__badge {
    background: linear-gradient(135deg, #2d6a4f 0%, #40916c 100%) !important;
    color: #ffffff !important;
  }

  /* Page template - About and other pages */
  .main-page-title,
  .page-title {
    color: #F5F3EF !important;
  }
  
  .main-page-title + .rte h2,
  .main-page-title + .rte h3,
  .main-page-title + .rte h4,
  .rte h2,
  .rte h3,
  .rte h4 {
    color: #A39C93 !important;
  }
  
  .rte p,
  .rte li {
    color: #D4D0C8 !important;
  }
  
  .rte a {
    color: #D4B971 !important;
  }

} /* End of @media (prefers-color-scheme: dark) */

/* ================================
   PAGE TEMPLATE FIXES
   ================================ */

/* Constrain page content width properly */
.page-width--narrow {
  max-width: 800px !important;
  margin: 0 auto !important;
  padding: 0 24px !important;
}

/* Page title styling */
.main-page-title,
.page-title {
  font-family: 'Cormorant Garamond', Georgia, serif !important;
  font-weight: 400 !important;
  font-style: italic !important;
  margin-bottom: 32px !important;
}

/* RTE content styling for pages */
.page-width--narrow .rte h2,
.page-width--narrow .rte h3,
.page-width--narrow .rte h4 {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-weight: 400;
  font-style: italic;
  margin-top: 32px;
  margin-bottom: 16px;
  color: var(--flaio-text-secondary, #6b5e52);
}

.page-width--narrow .rte p {
  font-family: 'Inter', -apple-system, sans-serif;
  font-size: 16px;
  line-height: 1.8;
  margin-bottom: 20px;
}

.page-width--narrow .rte a {
  color: var(--flaio-accent, #c9a961);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.page-width--narrow .rte a:hover {
  color: var(--flaio-text-primary, #3d3630);
}

/* ================================
   QUICK ADD MODAL FIXES
   ================================ */

/* Quick add modal content - full width elements */
quick-add-modal .quick-add-modal__content {
  max-width: 500px;
}

quick-add-modal product-info {
  display: block !important;
  width: 100% !important;
}

quick-add-modal .product__info-wrapper,
quick-add-modal .product__info-container {
  width: 100% !important;
  max-width: 100% !important;
}

/* Hero image at top */
quick-add-modal .quick-add-modal__hero-image {
  width: 100% !important;
  margin: 0 0 20px 0 !important;
  border-radius: 0 !important;
}

/* All form inputs full width */
quick-add-modal .product-form__input,
quick-add-modal variant-selects,
quick-add-modal variant-radios {
  width: 100% !important;
  max-width: 100% !important;
}

/* Size buttons in quick-add modal - consolidated above */

/* Quantity selector full width */
quick-add-modal .product-form__quantity,
quick-add-modal .quantity,
quick-add-modal .qty-bulk-row {
  width: 100% !important;
  max-width: 100% !important;
}

quick-add-modal .quantity__wrapper {
  width: 100% !important;
}

quick-add-modal .quantity__input {
  flex: 1 !important;
}

/* Buy buttons full width */
quick-add-modal .product-form__buttons {
  width: 100% !important;
}

/* Buy 2+ total price styling */
.qty-bulk-row__price-total {
  display: block;
  font-size: 11px;
  font-weight: 500;
  color: #22c55e;
  margin-top: 2px;
}

@media (prefers-color-scheme: dark) {
  .qty-bulk-row__price-total {
    color: #6EE7A0 !important;
  }
}

/* ================================
   ACCORDION / COLLAPSIBLE TAB STYLING
   ================================ */

/* Hide old-style product accordions (with + icon) - we use collapsible_tab instead */
.product-accordions {
  display: none !important;
}

/* Style collapsible tabs uniformly */
.product__accordion .accordion__title,
.accordion .accordion__title {
  font-family: 'Inter', -apple-system, sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  color: var(--flaio-text-primary) !important;
}

@media screen and (min-width: 750px) {
  .product__accordion .accordion__title,
  .accordion .accordion__title {
    font-size: 15px !important;
  }
}

.product__accordion .summary__title,
.accordion .summary__title {
  gap: 12px;
}

.product__accordion .accordion__content,
.accordion .accordion__content {
  font-size: 14px;
  line-height: 1.6;
  color: var(--flaio-text-secondary);
}

/* ================================
   END OF FLAIO CUSTOM STYLES
   ================================ */
