/* ============================================
   Theme: Clean
   Apple-inspired but NOT boring white.
   Warm grey base (#fafaf8), black accent buttons,
   image-forward, refined typography, visual rhythm
   through alternating section backgrounds.
   The products ARE the design.
   ============================================ */

.sf-theme-clean {
  --sf-radius: 0.5rem;
  --sf-card-radius: 0.625rem;
  --sf-card-shadow-hover: 0 12px 40px rgba(0,0,0,0.08);
  --_warm-bg: #fafaf8;
  --_warm-border: rgba(0,0,0,0.07);
}

/* ---- Global: warm base instead of pure white ---- */
.sf-theme-clean body,
body.sf-theme-clean {
  background-color: var(--_warm-bg);
}

/* ---- Announcement Bar: understated black ---- */
.sf-theme-clean .sf-announcement-bar {
  background: #111;
  color: rgba(255,255,255,0.9);
  font-weight: 500;
  letter-spacing: 0.06em;
  font-size: 0.75rem;
}

/* ---- Header: weightless, refined ---- */
.sf-theme-clean .sf-header {
  background: rgba(250,250,248,0.92);
  backdrop-filter: blur(40px) saturate(180%);
  -webkit-backdrop-filter: blur(40px) saturate(180%);
  border-bottom: 1px solid rgba(0,0,0,0.06);
  box-shadow: none;
}
.sf-theme-clean .sf-header-inner {
  height: 3.75rem;
}
.sf-theme-clean .sf-logo-text {
  font-size: 1.25rem;
  font-weight: 600;
  letter-spacing: -0.03em;
  color: #111;
}

.sf-theme-clean .sf-nav-link {
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  color: rgba(0,0,0,0.65);
  border-radius: 0;
  padding: 0.5rem 0.875rem;
  position: relative;
  transition: color 0.2s ease;
}
.sf-theme-clean .sf-nav-link::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0.875rem;
  right: 0.875rem;
  height: 1.5px;
  background: #111;
  transform: scaleX(0);
  transition: transform 0.25s ease;
}
.sf-theme-clean .sf-nav-link:hover {
  color: rgba(0,0,0,0.8);
  background: transparent;
}
.sf-theme-clean .sf-nav-link:hover::after {
  transform: scaleX(1);
}
.sf-theme-clean .sf-nav-link.active {
  color: #111;
  background: transparent;
  font-weight: 600;
  opacity: 1;
}
.sf-theme-clean .sf-nav-link.active::after {
  transform: scaleX(1);
}

/* ---- Header action icons: dark on light background ---- */
.sf-theme-clean .sf-header-actions i,
.sf-theme-clean .sf-header-actions a,
.sf-theme-clean .sf-header-actions button {
  color: rgba(0, 0, 0, 0.65);
}
.sf-theme-clean .sf-header-actions i:hover,
.sf-theme-clean .sf-header-actions a:hover,
.sf-theme-clean .sf-header-actions button:hover {
  color: rgba(0, 0, 0, 0.8);
}

/* ---- Hero: full-bleed photography, minimal overlay, elegant type ---- */
.sf-theme-clean .sf-hero {
  min-height: 480px;
}

/* No-image: sophisticated dark gradient with subtle depth */
.sf-theme-clean .sf-hero.sf-hero-no-image {
  background:
    radial-gradient(ellipse 80% 50% at 30% 70%, rgba(45,80,22,0.2) 0%, transparent 60%),
    linear-gradient(
      175deg,
      #1a1a1a 0%,
      #2a2a2a 35%,
      #1f1f1f 65%,
      #111 100%
    );
}

/* No-image: subtle diagonal line pattern */
.sf-theme-clean .sf-hero.sf-hero-no-image::before {
  background-image:
    linear-gradient(135deg, rgba(255,255,255,0.02) 25%, transparent 25%),
    linear-gradient(225deg, rgba(255,255,255,0.02) 25%, transparent 25%);
  background-size: 40px 40px;
}

.sf-theme-clean .sf-hero-overlay {
  padding: 6rem 0 5rem;
  display: flex;
  align-items: flex-end;
}

.sf-theme-clean .sf-hero:not(.sf-hero-no-image) .sf-hero-overlay {
  background: linear-gradient(
    180deg,
    rgba(0,0,0,0.15) 0%,
    rgba(0,0,0,0.35) 40%,
    rgba(0,0,0,0.55) 100%
  );
}

.sf-theme-clean .sf-hero.sf-hero-no-image .sf-hero-overlay {
  background: linear-gradient(
    180deg,
    rgba(0,0,0,0.1) 0%,
    rgba(0,0,0,0.02) 40%,
    rgba(0,0,0,0.15) 100%
  );
}
.sf-theme-clean .sf-hero-content h1 {
  font-size: 3.25rem;
  font-weight: 300;
  letter-spacing: -0.04em;
  line-height: 1.08;
  text-shadow: none;
  color: #fff;
}
.sf-theme-clean .sf-hero-content h1 strong,
.sf-theme-clean .sf-hero-content h1 b {
  font-weight: 600;
}
.sf-theme-clean .sf-hero-subtext {
  font-size: 1.0625rem;
  font-weight: 400;
  opacity: 0.8;
  letter-spacing: 0.005em;
  color: rgba(255,255,255,0.85);
  line-height: 1.7;
}
.sf-theme-clean .sf-hero .sf-btn-primary {
  background: #fff;
  color: #111;
  border: none;
  font-weight: 600;
  box-shadow: 0 4px 20px rgba(0,0,0,0.15);
}
.sf-theme-clean .sf-hero .sf-btn-primary:hover {
  background: #f0f0ee;
  box-shadow: 0 6px 28px rgba(0,0,0,0.2);
}
.sf-theme-clean .sf-hero .sf-btn-secondary {
  border-color: rgba(255,255,255,0.5);
  color: #fff;
  font-weight: 500;
}
.sf-theme-clean .sf-hero .sf-btn-secondary:hover {
  background: rgba(255,255,255,0.1);
  border-color: #fff;
}

/* ---- Buttons: solid black Apple-style ---- */
.sf-theme-clean .sf-btn-primary {
  background: #111;
  color: #fff;
  border: none;
  border-radius: var(--sf-radius);
  box-shadow: none;
  font-weight: 500;
  letter-spacing: 0.01em;
  transition: all 0.2s ease;
}
.sf-theme-clean .sf-btn-primary:hover {
  background: #333;
  box-shadow: none;
  transform: none;
}
.sf-theme-clean .sf-btn-secondary {
  background: transparent;
  border: 1.5px solid #111;
  color: #111;
  font-weight: 500;
  transition: all 0.2s ease;
}
.sf-theme-clean .sf-btn-secondary:hover {
  background: #111;
  color: #fff;
}
.sf-theme-clean .sf-btn-lg {
  padding: 0.875rem 2.25rem;
  font-size: 0.9375rem;
  border-radius: var(--sf-radius);
}

/* ---- Sections: alternating warm grey / white rhythm ---- */
.sf-theme-clean .sf-section {
  padding: 4.5rem 0;
}
.sf-theme-clean .sf-section-alt {
  background: #fff;
}
.sf-theme-clean .sf-section-title {
  font-size: 1.625rem;
  font-weight: 600;
  letter-spacing: -0.03em;
  margin-bottom: 2.5rem;
  color: #111;
}
.sf-theme-clean .sf-page-title {
  font-size: 2rem;
  font-weight: 300;
  letter-spacing: -0.03em;
  color: #111;
}
.sf-theme-clean .sf-page-title strong {
  font-weight: 600;
}

/* ---- Product Cards: no borders, shadow on hover, image-forward ---- */
.sf-theme-clean .sf-product-card {
  border: none;
  border-radius: var(--sf-card-radius);
  box-shadow: none;
  background: #fff;
  transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
}
.sf-theme-clean .sf-product-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 30px rgba(0,0,0,0.08), 0 2px 8px rgba(0,0,0,0.04);
}
.sf-theme-clean .sf-product-card:hover .sf-product-image img {
  transform: scale(1.04);
}

.sf-theme-clean .sf-product-image {
  background: #f2f2f0;
  aspect-ratio: 1;
  overflow: hidden;
}
.sf-theme-clean .sf-product-placeholder {
  background: linear-gradient(150deg, #f0f0ee, #e8e8e5);
}

.sf-theme-clean .sf-product-info {
  padding: 1rem 1rem 1.25rem;
}
.sf-theme-clean .sf-product-brand {
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(0,0,0,0.4);
}
.sf-theme-clean .sf-product-name {
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: #111;
  line-height: 1.35;
}
.sf-theme-clean .sf-price {
  font-size: 1rem;
  font-weight: 600;
  color: #111;
}
.sf-theme-clean .sf-price-original {
  color: rgba(0,0,0,0.3);
  font-weight: 400;
}

/* ---- Badges: flat, understated ---- */
.sf-theme-clean .sf-badge {
  border-radius: 0.25rem;
  box-shadow: none;
  font-size: 0.625rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.25rem 0.5rem;
}
.sf-theme-clean .sf-badge-sale {
  background: #111;
  color: #fff;
}
.sf-theme-clean .sf-badge-new {
  background: transparent;
  color: #111;
  border: 1px solid #111;
}

/* ---- Cannabis strain badges: muted, refined ---- */
.sf-theme-clean .sf-strain-indica {
  background: #6d28d9;
  opacity: 0.85;
}
.sf-theme-clean .sf-strain-sativa {
  background: #dc2626;
  opacity: 0.85;
}
.sf-theme-clean .sf-strain-hybrid {
  background: #047857;
  opacity: 0.85;
}
.sf-theme-clean .sf-strain-cbd {
  background: #0369a1;
  opacity: 0.85;
}

/* ---- Cannabinoid badges: subtle type treatment ---- */
.sf-theme-clean .sf-cannabinoid {
  background: transparent;
  border: 1px solid rgba(0,0,0,0.1);
  border-radius: 0.25rem;
  font-weight: 600;
  font-size: 0.6875rem;
  color: rgba(0,0,0,0.5);
  letter-spacing: 0.03em;
}

/* ---- Add to Cart: black, minimal ---- */
.sf-theme-clean .sf-btn-add-to-cart {
  background: #111;
  color: #fff;
  border: none;
  border-radius: var(--sf-radius);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  box-shadow: none;
  padding: 0.625rem;
  transition: background 0.2s ease;
}
.sf-theme-clean .sf-btn-add-to-cart:hover {
  background: #333;
  transform: none;
  box-shadow: none;
}

/* ---- Category Cards: large type, image-forward, minimal decoration ---- */
.sf-theme-clean .sf-category-card {
  border: none;
  border-radius: var(--sf-card-radius);
  box-shadow: none;
  padding: 2rem 1.5rem;
  background: #fff;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}
.sf-theme-clean .sf-category-card:hover {
  transform: none;
  box-shadow: 0 8px 30px rgba(0,0,0,0.06);
}
.sf-theme-clean .sf-category-card h3 {
  font-size: 1.0625rem;
  font-weight: 500;
  letter-spacing: -0.01em;
}
.sf-theme-clean .sf-category-icon-placeholder {
  border-radius: var(--sf-radius);
  background: #f0f0ee;
  color: rgba(0,0,0,0.4);
}
.sf-theme-clean .sf-category-count {
  font-size: 0.75rem;
  color: rgba(0,0,0,0.35);
  font-weight: 400;
}

/* ---- Deal Cards: clean lines, subtle left accent ---- */
.sf-theme-clean .sf-deal-card {
  border: none;
  border-left: 3px solid #111;
  border-radius: 0;
  box-shadow: none;
  padding: 1.5rem 1.5rem 1.5rem 1.75rem;
  background: #fff;
  transition: all 0.2s ease;
}
.sf-theme-clean .sf-deal-card:hover {
  box-shadow: none;
  background: #fff;
  border-left-color: var(--sf-primary);
}
.sf-theme-clean .sf-deal-badge,
.sf-theme-clean .sf-deal-badge-lg {
  background: #111;
  color: #fff;
  border-radius: 0.25rem;
  box-shadow: none;
  text-shadow: none;
  font-weight: 600;
}

/* ---- Tabs: black underline (not pill) ---- */
.sf-theme-clean .sf-tab {
  border: none;
  border-radius: 0;
  border-bottom: 2px solid transparent;
  padding: 0.625rem 1.125rem;
  font-size: 0.8125rem;
  font-weight: 500;
  color: rgba(0,0,0,0.4);
  transition: all 0.2s ease;
  background: transparent;
}
.sf-theme-clean .sf-tab.sf-tab-icon {
  border: none;
  border-bottom: none;
  padding: 0;
  border-radius: 0;
  background: transparent;
  opacity: 1;
}
.sf-theme-clean .sf-tab.sf-tab-icon:hover {
  background: transparent;
  border: none;
  border-bottom: none;
}
.sf-theme-clean .sf-tab:hover {
  color: rgba(0,0,0,0.7);
  border-color: transparent;
}
.sf-theme-clean .sf-tab.active {
  background: transparent;
  color: #111;
  border-bottom-color: #111;
}
.sf-theme-clean .sf-tab.sf-tab-icon.active {
  background: transparent;
  color: #111;
  border: none;
  box-shadow: none;
}
.sf-theme-clean .sf-tab.sf-tab-icon.active .sf-tab-icon-wrap {
  border-color: #111;
  background: #fff;
}
.sf-theme-clean .sf-tab.sf-tab-icon.active .sf-tab-label {
  color: #111;
  font-weight: 600;
}

/* ---- Search: minimal underline style ---- */
.sf-theme-clean .sf-search-input {
  border: none;
  border-bottom: 1.5px solid rgba(0,0,0,0.12);
  border-radius: 0;
  padding: 0.75rem 0;
  font-size: 0.9375rem;
  background: transparent;
  transition: border-color 0.25s ease;
}
.sf-theme-clean .sf-search-input:focus {
  border-bottom-color: #111;
  box-shadow: none;
  outline: none;
}
.sf-theme-clean .sf-search-input::placeholder {
  color: rgba(0,0,0,0.3);
  font-weight: 400;
}
.sf-theme-clean .sf-search-btn {
  border: none;
  border-bottom: 1.5px solid rgba(0,0,0,0.12);
  border-radius: 0;
  background: transparent;
  color: rgba(0,0,0,0.4);
  padding: 0.75rem 1rem;
}

/* ---- Filter Sidebar ---- */
.sf-theme-clean .sf-filter-section h4 {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(0,0,0,0.35);
}
.sf-theme-clean .sf-filter-option {
  color: rgba(0,0,0,0.55);
  font-size: 0.875rem;
  transition: color 0.15s ease;
}
.sf-theme-clean .sf-filter-option:hover {
  color: #111;
}
.sf-theme-clean .sf-filter-active {
  color: #111;
  font-weight: 600;
}

/* ---- Sort Bar ---- */
.sf-theme-clean .sf-sort-select {
  border: none;
  border-bottom: 1px solid rgba(0,0,0,0.1);
  border-radius: 0;
  font-size: 0.8125rem;
  background: transparent;
  color: rgba(0,0,0,0.55);
}
.sf-theme-clean .sf-sort-select:focus {
  border-bottom-color: #111;
  box-shadow: none;
}

/* ---- Info Cards: barely there ---- */
.sf-theme-clean .sf-info-card {
  border: none;
  border-radius: var(--sf-card-radius);
  box-shadow: none;
  padding: 1.75rem;
  background: #fff;
}

/* ---- About: editorial breathing room ---- */
.sf-theme-clean .sf-about-grid {
  gap: 4rem;
}
.sf-theme-clean .sf-about-image img {
  border-radius: var(--sf-card-radius);
  box-shadow: none;
}
.sf-theme-clean .sf-prose {
  font-size: 1rem;
  line-height: 1.9;
  color: rgba(0,0,0,0.5);
  font-weight: 400;
}
.sf-theme-clean .sf-prose strong {
  color: #111;
  font-weight: 600;
}

/* ---- Variation / Weight selectors: minimal ---- */
.sf-theme-clean .sf-variation-btn {
  border-radius: 0.25rem;
  border: 1.5px solid rgba(0,0,0,0.12);
  font-size: 0.8125rem;
  font-weight: 500;
  color: rgba(0,0,0,0.6);
  transition: all 0.2s ease;
}
.sf-theme-clean .sf-variation-btn:hover {
  border-color: #111;
  color: #111;
}
.sf-theme-clean .sf-variation-btn.active {
  border-color: #111;
  background: #111;
  color: #fff;
}

/* ---- Footer: light warm grey, refined ---- */
.sf-theme-clean .sf-footer {
  background: #f3f3f1;
  color: rgba(0,0,0,0.65);
  border-top: 1px solid rgba(0,0,0,0.06);
}
.sf-theme-clean .sf-footer-brand h3 {
  color: #111;
  font-weight: 600;
  letter-spacing: -0.02em;
}
.sf-theme-clean .sf-footer-brand p {
  color: rgba(0,0,0,0.6);
  line-height: 1.7;
}
.sf-theme-clean .sf-footer-links h4,
.sf-theme-clean .sf-footer-hours h4,
.sf-theme-clean .sf-footer-social h4 {
  color: rgba(0,0,0,0.55);
  text-transform: uppercase;
  font-size: 0.6875rem;
  letter-spacing: 0.1em;
  font-weight: 600;
}
.sf-theme-clean .sf-footer-links a {
  color: rgba(0,0,0,0.65);
  opacity: 1;
  font-size: 0.875rem;
  transition: color 0.15s ease;
}
.sf-theme-clean .sf-footer-hours-row {
  color: rgba(0,0,0,0.6);
  opacity: 1;
}
.sf-theme-clean .sf-footer-links a:hover {
  color: #111;
}
.sf-theme-clean .sf-social-links a {
  background: rgba(0,0,0,0.06);
  color: rgba(0,0,0,0.6);
  border-radius: 50%;
  transition: all 0.2s ease;
}
.sf-theme-clean .sf-social-links a:hover {
  background: #111;
  color: #fff;
  transform: none;
}
.sf-theme-clean .sf-footer-bottom {
  border-top-color: rgba(0,0,0,0.06);
}
.sf-theme-clean .sf-powered-by a {
  color: rgba(0,0,0,0.4);
}
.sf-theme-clean .sf-powered-by a:hover {
  color: #111;
}

/* ---- Cart: clean white cards ---- */
.sf-theme-clean .sf-cart-item {
  border: none;
  border-radius: var(--sf-card-radius);
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.sf-theme-clean .sf-cart-summary {
  border: none;
  border-radius: var(--sf-card-radius);
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

/* ---- Checkout: flat, clean ---- */
.sf-theme-clean .sf-checkout-section {
  border: none;
  border-radius: var(--sf-card-radius);
  box-shadow: none;
  background: #fff;
  padding: 2rem;
}
.sf-theme-clean .sf-input {
  border: none;
  border-bottom: 1.5px solid rgba(0,0,0,0.1);
  border-radius: 0;
  padding: 0.75rem 0;
  font-size: 0.9375rem;
  background: transparent;
}
.sf-theme-clean .sf-input:focus {
  border-bottom-color: #111;
  box-shadow: none;
}
.sf-theme-clean .sf-radio-card {
  border: 1.5px solid rgba(0,0,0,0.08);
  border-radius: var(--sf-radius);
  transition: border-color 0.2s ease;
}
.sf-theme-clean .sf-radio-card:hover {
  border-color: rgba(0,0,0,0.2);
}
.sf-theme-clean .sf-radio-card.selected {
  border-color: #111;
}

/* ---- Age Gate: restrained, elegant ---- */
.sf-theme-clean .sf-age-gate {
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(8px);
}
.sf-theme-clean .sf-age-gate-card {
  border-radius: var(--sf-card-radius);
  box-shadow: 0 24px 80px rgba(0,0,0,0.2);
  padding: 3rem 2.5rem;
  background: #fff;
}
.sf-theme-clean .sf-age-gate-card h1 {
  font-size: 1.625rem;
  font-weight: 600;
  letter-spacing: -0.02em;
}
.sf-theme-clean .sf-age-gate-card p {
  color: rgba(0,0,0,0.45);
}

/* ---- Tier Cards: minimal elevation ---- */
.sf-theme-clean .sf-tier-card {
  border: none;
  border-radius: var(--sf-card-radius);
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
  transition: box-shadow 0.3s ease;
}
.sf-theme-clean .sf-tier-card:hover {
  box-shadow: 0 8px 30px rgba(0,0,0,0.08);
}
.sf-theme-clean .sf-tier-featured {
  border: 2px solid #111;
  box-shadow: 0 4px 16px rgba(0,0,0,0.06);
}
.sf-theme-clean .sf-tier-badge {
  background: #111;
  color: #fff;
  border-radius: 0.25rem;
  font-weight: 600;
  font-size: 0.6875rem;
  letter-spacing: 0.04em;
}

/* ---- Pagination: understated ---- */
.sf-theme-clean .sf-pagination a,
.sf-theme-clean .sf-pagination span {
  border: none;
  border-radius: 0.25rem;
  font-size: 0.8125rem;
  font-weight: 500;
}
.sf-theme-clean .sf-pagination a:hover {
  background: rgba(0,0,0,0.04);
}
.sf-theme-clean .sf-pagination .current {
  background: #111;
  color: #fff;
  box-shadow: none;
}

/* ---- Strain Pills (product detail) ---- */
.sf-theme-clean .sf-strain-pill {
  border-radius: 0.25rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.25rem 0.625rem;
}

/* ---- Quantity controls: refined ---- */
.sf-theme-clean .sf-qty-btn {
  border: 1.5px solid rgba(0,0,0,0.12);
  border-radius: 0.25rem;
  background: transparent;
  color: #111;
  transition: all 0.15s ease;
}
.sf-theme-clean .sf-qty-btn:hover {
  background: #111;
  color: #fff;
  border-color: #111;
}
.sf-theme-clean .sf-qty-value {
  border-top: 1.5px solid rgba(0,0,0,0.12);
  border-bottom: 1.5px solid rgba(0,0,0,0.12);
  font-weight: 600;
  font-size: 0.875rem;
}

/* ---- Stock indicator: text-only, clean ---- */
.sf-theme-clean .sf-stock-in {
  color: rgba(0,0,0,0.4);
  font-size: 0.75rem;
  font-weight: 500;
}
.sf-theme-clean .sf-stock-in::before {
  content: '';
  display: inline-block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #059669;
  margin-right: 0.375rem;
}
.sf-theme-clean .sf-stock-low {
  color: rgba(0,0,0,0.4);
}
.sf-theme-clean .sf-stock-low::before {
  content: '';
  display: inline-block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #f59e0b;
  margin-right: 0.375rem;
}

/* ---- Mobile menu: clean slide-in ---- */
.sf-theme-clean .sf-mobile-menu {
  background: #fff;
  color: #111;
}
.sf-theme-clean .sf-mobile-menu a {
  color: rgba(0,0,0,0.6);
  font-weight: 500;
  font-size: 0.9375rem;
  border-bottom: 1px solid rgba(0,0,0,0.04);
}
.sf-theme-clean .sf-mobile-menu a:hover {
  color: #111;
}

/* ---- Subtle entrance for product cards ---- */
.sf-theme-clean .sf-product-card {
  animation: clean-card-in 0.5s ease-out both;
}
@keyframes clean-card-in {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}
.sf-theme-clean .sf-product-grid .sf-product-card:nth-child(1) { animation-delay: 0.03s; }
.sf-theme-clean .sf-product-grid .sf-product-card:nth-child(2) { animation-delay: 0.07s; }
.sf-theme-clean .sf-product-grid .sf-product-card:nth-child(3) { animation-delay: 0.11s; }
.sf-theme-clean .sf-product-grid .sf-product-card:nth-child(4) { animation-delay: 0.15s; }
.sf-theme-clean .sf-product-grid .sf-product-card:nth-child(5) { animation-delay: 0.19s; }
.sf-theme-clean .sf-product-grid .sf-product-card:nth-child(6) { animation-delay: 0.23s; }
.sf-theme-clean .sf-product-grid .sf-product-card:nth-child(7) { animation-delay: 0.27s; }
.sf-theme-clean .sf-product-grid .sf-product-card:nth-child(8) { animation-delay: 0.31s; }
