/* ==========================================================================
   simulant.css — design-system overrides for the Hummingbird base theme.
   Loaded AFTER theme.css so these rules win on conflicts.

   Goals:
   - Polished, modern e-commerce visual.
   - CRO-focused: prominent primary CTA (single per fold), strong price
     hierarchy, visible trust signals, sticky add-to-cart on mobile,
     skeleton loaders for perceived speed, generous tap targets.
   - One-token system via :root vars — every colour, radius, spacing,
     font is declared once. Per-shop rebrand by overriding tokens only.
   ========================================================================== */

/* ---------------------------------------------------------------- 1. tokens */

:root {
  /* Brand */
  --s-primary: #1f1f1f;
  --s-primary-ink: #ffffff;
  --s-accent: #25e07a;
  --s-accent-ink: #062215;
  --s-accent-strong: #1bbf66;

  /* Surface */
  --s-bg: #fafaf7;
  --s-surface: #ffffff;
  --s-surface-2: #f4f4ef;

  /* Ink */
  --s-ink-1: #111111;
  --s-ink-2: #4a4a4a;
  --s-ink-3: #767676;
  --s-ink-4: #a8a8a8;

  /* Lines */
  --s-border: #e5e3dd;
  --s-border-strong: #d0cdc6;

  /* Status */
  --s-success: #1bbf66;
  --s-warning: #f5a623;
  --s-danger: #d6473b;
  --s-info: #2c6dd6;
  --s-trust-bg: #f0fdf4;
  --s-trust-ink: #15803d;

  /* Radius */
  --s-r-sm: 4px;
  --s-r: 8px;
  --s-r-lg: 12px;
  --s-r-xl: 20px;
  --s-r-pill: 999px;

  /* Shadow */
  --s-shadow-1: 0 1px 2px rgba(15,15,15,.04), 0 1px 3px rgba(15,15,15,.06);
  --s-shadow-2: 0 4px 12px rgba(15,15,15,.08), 0 2px 4px rgba(15,15,15,.04);
  --s-shadow-3: 0 12px 32px rgba(15,15,15,.12), 0 4px 8px rgba(15,15,15,.06);

  /* Spacing */
  --s-1: 4px;  --s-2: 8px;  --s-3: 12px; --s-4: 16px;
  --s-5: 20px; --s-6: 24px; --s-8: 32px; --s-10: 40px;
  --s-12: 48px; --s-16: 64px; --s-20: 80px;

  /* Layout */
  --s-container-max: 1280px;
  --s-header-height: 72px;

  /* Motion */
  --s-ease: cubic-bezier(.4,0,.2,1);
  --s-fast: 150ms;
  --s-base: 250ms;
  --s-slow: 400ms;

  /* Bootstrap re-binds */
  --bs-primary: var(--s-primary);
  --bs-primary-rgb: 31,31,31;
  --bs-body-color: var(--s-ink-1);
  --bs-body-bg: var(--s-bg);
  --bs-border-color: var(--s-border);
  --bs-border-radius: var(--s-r);
  --bs-link-color: var(--s-ink-1);
  --bs-link-hover-color: var(--s-accent-strong);
}

/* ---------------------------------------------------------------- 2. base */

html { scroll-behavior: smooth; }

body {
  background: var(--s-bg) !important;
  color: var(--s-ink-1) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "ss01","ss02","cv05","cv11";
  text-rendering: optimizeLegibility;
}

a { transition: color var(--s-fast) var(--s-ease); }
a:hover { color: var(--s-accent-strong); }
::selection { background: var(--s-accent); color: var(--s-accent-ink); }

:focus-visible {
  outline: 2px solid var(--s-accent);
  outline-offset: 2px;
  border-radius: var(--s-r-sm);
}

/* ---------------------------------------------------------------- 3. type */

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  color: var(--s-ink-1);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.15;
}
h1, .h1 { font-size: clamp(2rem, 4vw, 3.25rem); letter-spacing: -0.03em; }
h2, .h2 { font-size: clamp(1.5rem, 2.5vw, 2.25rem); }
h3, .h3 { font-size: clamp(1.25rem, 1.8vw, 1.625rem); }

p { color: var(--s-ink-2); }
.lead { color: var(--s-ink-2); line-height: 1.6; }
small, .small { color: var(--s-ink-3); }

.s-overline {
  font-size: .6875rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--s-ink-3);
}

/* ---------------------------------------------------------------- 4. buttons */

.btn,
button.btn,
a.btn {
  font-weight: 600 !important;
  font-size: .9375rem !important;
  line-height: 1 !important;
  letter-spacing: -.005em;
  padding: 14px 24px !important;
  border-radius: var(--s-r) !important;
  border: 1.5px solid transparent !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  transition: all var(--s-fast) var(--s-ease);
  white-space: nowrap;
  position: relative;
}

.btn-primary,
.btn.btn-primary {
  background: var(--s-accent) !important;
  color: var(--s-accent-ink) !important;
  border-color: var(--s-accent) !important;
}
.btn-primary:hover,
.btn.btn-primary:hover {
  background: var(--s-accent-strong) !important;
  border-color: var(--s-accent-strong) !important;
  transform: translateY(-1px);
  box-shadow: var(--s-shadow-2);
  color: var(--s-accent-ink) !important;
}

.btn-dark, .btn.btn-dark {
  background: var(--s-primary) !important;
  color: var(--s-primary-ink) !important;
  border-color: var(--s-primary) !important;
}
.btn-dark:hover { background: #000 !important; border-color: #000 !important; color: white !important; }

.btn-outline-primary, .btn-outline-dark, .btn-secondary {
  background: transparent !important;
  color: var(--s-ink-1) !important;
  border-color: var(--s-border-strong) !important;
}
.btn-outline-primary:hover, .btn-outline-dark:hover, .btn-secondary:hover {
  background: var(--s-ink-1) !important;
  color: white !important;
  border-color: var(--s-ink-1) !important;
}

.btn-link, .btn.btn-link {
  background: transparent !important;
  color: var(--s-ink-1) !important;
  border: none !important;
  padding: var(--s-2) var(--s-3) !important;
  font-weight: 500 !important;
}

.btn-sm, .btn.btn-sm { padding: 8px 16px !important; font-size: .8125rem !important; }
.btn-lg, .btn.btn-lg { padding: 18px 32px !important; font-size: 1rem !important; }

/* ---------------------------------------------------------------- 5. forms */

.form-control, .form-select,
input[type="text"], input[type="email"], input[type="password"],
input[type="search"], input[type="tel"], input[type="number"],
textarea, select {
  font-size: .9375rem;
  padding: 12px 16px;
  border-radius: var(--s-r);
  border: 1.5px solid var(--s-border) !important;
  background: var(--s-surface);
  color: var(--s-ink-1);
  transition: border-color var(--s-fast) var(--s-ease), box-shadow var(--s-fast) var(--s-ease);
}
.form-control:focus,
input:focus, textarea:focus, select:focus {
  border-color: var(--s-ink-1) !important;
  box-shadow: 0 0 0 3px rgba(31,31,31,.08) !important;
  outline: none;
}
.form-control::placeholder { color: var(--s-ink-4); }
label, .form-label { font-weight: 500; font-size: .875rem; color: var(--s-ink-2); margin-bottom: var(--s-2); }

/* Search bar — heroic */
form.search-form input[type="text"],
#search_widget input[type="text"],
.search-widget input.ui-autocomplete-input {
  border-radius: var(--s-r-pill) !important;
  padding: 12px 20px 12px 44px !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23767676' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><path d='m21 21-4.3-4.3'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: 16px center !important;
  background-size: 18px !important;
}

/* ---------------------------------------------------------------- 6. layout */

.container, .container-fluid, .container-lg, .container-xl {
  max-width: var(--s-container-max);
}

main, #main, .page-wrapper { background: var(--s-bg); min-height: 60vh; }

#wrapper { padding-block: var(--s-8); }

/* ---------------------------------------------------------------- 7. header */

#header, header.header {
  background: var(--s-surface) !important;
  border-bottom: 1px solid var(--s-border);
  position: sticky;
  top: 0;
  z-index: 1030;
  backdrop-filter: saturate(1.4) blur(8px);
  background-color: rgba(255,255,255,.92) !important;
}

.header-top, .header-nav {
  min-height: var(--s-header-height);
  display: flex;
  align-items: center;
  gap: var(--s-6);
}

#_desktop_logo a, .logo, .header_logo {
  font-weight: 700 !important;
  font-size: 1.375rem !important;
  letter-spacing: -.03em !important;
  color: var(--s-ink-1) !important;
}
#_desktop_logo img, .logo img { max-height: 36px !important; width: auto !important; }

#top-menu .menu-item a, .menu-item a,
.header-nav .top-menu li a {
  font-weight: 500;
  font-size: .9375rem;
  padding: 10px 14px;
  color: var(--s-ink-2);
  border-radius: var(--s-r-sm);
  transition: all var(--s-fast) var(--s-ease);
}
#top-menu .menu-item a:hover, .menu-item a:hover {
  color: var(--s-ink-1);
  background: var(--s-surface-2);
}

.header-nav .blockcart, .header-nav .user-info, .cart-preview {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 8px 14px 8px 12px;
  background: var(--s-surface-2);
  border-radius: var(--s-r-pill);
  font-size: .875rem;
  font-weight: 500;
  color: var(--s-ink-1);
  transition: all var(--s-fast) var(--s-ease);
}
.header-nav .blockcart:hover, .cart-preview:hover {
  background: var(--s-ink-1);
  color: white;
}

.cart-preview .cart-products-count, .blockcart .cart-products-count {
  background: var(--s-accent);
  color: var(--s-accent-ink);
  font-size: .6875rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: var(--s-r-pill);
  margin-left: var(--s-1);
}

/* ---------------------------------------------------------------- 8. hero / homepage */

#ps_imageslider, .slick-slider {
  border-radius: var(--s-r-xl);
  overflow: hidden;
  margin-bottom: var(--s-12);
}

.s-home-hero {
  position: relative;
  border-radius: var(--s-r-xl);
  overflow: hidden;
  background: linear-gradient(135deg, #1a1a1a, #2a2a2a);
  color: white;
  padding: clamp(48px, 8vw, 96px) clamp(24px, 5vw, 64px);
  margin-bottom: var(--s-12);
}
.s-home-hero::after {
  content: "";
  position: absolute;
  inset: -40% -40% auto auto;
  width: 600px; height: 600px;
  background: radial-gradient(circle, var(--s-accent), transparent 70%);
  opacity: .18;
  pointer-events: none;
  filter: blur(40px);
}
.s-home-hero h1 { color: white; max-width: 18ch; }
.s-home-hero p { color: rgba(255,255,255,.78); max-width: 50ch; font-size: 1.125rem; }
.s-home-hero .btn-primary { margin-top: var(--s-6); }

/* ---------------------------------------------------------------- 9. trust signals */

.block-reassurance {
  background: var(--s-surface) !important;
  border: 1px solid var(--s-border);
  border-radius: var(--s-r-lg) !important;
  padding: var(--s-5) !important;
  margin-block: var(--s-8) !important;
}
.block-reassurance ul {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
  gap: var(--s-4) !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.block-reassurance li {
  display: flex !important;
  align-items: center !important;
  gap: var(--s-3) !important;
  padding: var(--s-2) !important;
  margin: 0 !important;
  border: none !important;
}
.block-reassurance img, .block-reassurance svg {
  width: 40px !important;
  height: 40px !important;
  flex-shrink: 0;
  border-radius: var(--s-r);
  background: var(--s-trust-bg);
  padding: 8px;
}
.block-reassurance h3, .block-reassurance .h6, .block-reassurance p {
  margin: 0;
  font-size: .8125rem;
  font-weight: 500;
  color: var(--s-ink-1) !important;
  text-transform: none;
  letter-spacing: 0;
}

/* ---------------------------------------------------------------- 10. product cards */

.products, .product_list {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
  gap: var(--s-6) !important;
  list-style: none;
  padding: 0;
  margin: 0;
}

article.product-miniature, .product-miniature, .js-product-miniature {
  background: var(--s-surface) !important;
  border-radius: var(--s-r-lg) !important;
  overflow: hidden !important;
  border: 1px solid transparent;
  transition: transform var(--s-base) var(--s-ease), box-shadow var(--s-base) var(--s-ease), border-color var(--s-base);
  position: relative;
  display: flex !important;
  flex-direction: column !important;
}
.product-miniature:hover {
  transform: translateY(-2px);
  box-shadow: var(--s-shadow-2);
  border-color: var(--s-border);
}

.product-miniature .thumbnail-container,
.product-miniature .product-thumbnail {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: var(--s-surface-2);
  display: block;
}
.product-miniature .thumbnail-container img,
.product-miniature .product-thumbnail img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform var(--s-slow) var(--s-ease);
}
.product-miniature:hover .product-thumbnail img,
.product-miniature:hover .thumbnail-container img {
  transform: scale(1.05);
}

/* Flags (sale, new) */
ul.product-flags {
  position: absolute;
  top: var(--s-3);
  left: var(--s-3);
  display: flex !important;
  flex-direction: column;
  gap: var(--s-1);
  list-style: none;
  margin: 0;
  padding: 0;
  z-index: 2;
}
.product-flag, ul.product-flags li {
  font-size: .6875rem !important;
  font-weight: 700 !important;
  padding: 4px 10px !important;
  border-radius: var(--s-r-pill) !important;
  text-transform: uppercase;
  letter-spacing: .04em;
  background: var(--s-ink-1) !important;
  color: white !important;
  display: inline-block;
}
.product-flag.discount, .product-flag.discount-percentage,
.product-flag.on-sale, li.discount {
  background: var(--s-danger) !important;
}
.product-flag.new, li.new { background: var(--s-info) !important; }

/* Wishlist / quick-view actions */
.product-miniature .product-actions, .highlighted-informations {
  position: absolute;
  top: var(--s-3);
  right: var(--s-3);
  display: flex;
  flex-direction: column;
  gap: var(--s-1);
  z-index: 2;
}
.product-miniature .product-actions button,
.highlighted-informations a, .highlighted-informations button {
  width: 36px !important;
  height: 36px !important;
  border-radius: var(--s-r-pill) !important;
  background: rgba(255,255,255,.95);
  border: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--s-shadow-1);
  transition: transform var(--s-fast) var(--s-ease);
  cursor: pointer;
}
.product-miniature .product-actions button:hover,
.highlighted-informations a:hover { transform: scale(1.08); }

/* Info area */
.product-miniature .product-description,
.product-miniature .product-info {
  padding: var(--s-4) !important;
  display: flex !important;
  flex-direction: column !important;
  gap: var(--s-2) !important;
  flex: 1;
}
.product-miniature .product-title,
.product-miniature .product-title a,
.product-miniature h2, .product-miniature h3 {
  font-size: .9375rem !important;
  font-weight: 500 !important;
  margin: 0 !important;
  letter-spacing: -.005em;
  line-height: 1.4;
  color: var(--s-ink-1) !important;
  text-transform: none !important;
}
.product-miniature .product-title a:hover { color: var(--s-accent-strong) !important; }

.product-miniature .product-price-and-shipping,
.product-miniature .product-price {
  display: flex !important;
  align-items: baseline !important;
  gap: var(--s-2) !important;
  margin-top: auto !important;
  flex-wrap: wrap;
}
.product-miniature span.price, .product-miniature .price {
  font-size: 1.0625rem !important;
  font-weight: 700 !important;
  color: var(--s-ink-1) !important;
  letter-spacing: -.01em;
}
.product-miniature .regular-price {
  text-decoration: line-through !important;
  color: var(--s-ink-3) !important;
  font-size: .875rem !important;
  font-weight: 500 !important;
}
.product-miniature .discount-percentage,
.product-miniature .discount-amount {
  font-size: .75rem !important;
  font-weight: 700 !important;
  color: var(--s-danger) !important;
  background: rgba(214,71,59,.08) !important;
  padding: 2px 8px !important;
  border-radius: var(--s-r-sm) !important;
}

/* ---------------------------------------------------------------- 11. product page */

.product-cover, #content.product-container .images-container .product-cover {
  border-radius: var(--s-r-lg) !important;
  overflow: hidden;
  background: var(--s-surface);
  border: 1px solid var(--s-border);
}

ul.product-thumbnails, .product-thumbs {
  display: flex !important;
  gap: var(--s-2) !important;
  list-style: none;
  padding: 0;
  margin: 0;
  overflow-x: auto;
}
.product-thumbs li, ul.product-thumbnails li {
  width: 80px !important;
  height: 80px !important;
  flex-shrink: 0;
  border-radius: var(--s-r) !important;
  overflow: hidden;
  border: 2px solid transparent !important;
  cursor: pointer;
  transition: border-color var(--s-fast) var(--s-ease);
}
.product-thumbs li.selected, .product-thumbs li:hover,
ul.product-thumbnails li.selected, ul.product-thumbnails li:hover {
  border-color: var(--s-ink-1) !important;
}

#product h1.h1, .product-detail-name, .product-information h1 {
  font-size: clamp(1.5rem, 2.4vw, 2rem) !important;
  letter-spacing: -.02em;
  margin-bottom: var(--s-3);
}

.product-prices, .product-information .product-prices {
  display: flex !important;
  align-items: baseline !important;
  gap: var(--s-3) !important;
  margin-block: var(--s-4) var(--s-6) !important;
  flex-wrap: wrap;
}
.product-prices .current-price .price,
.product-prices .price.current-price {
  font-size: 2rem !important;
  font-weight: 700 !important;
  color: var(--s-ink-1) !important;
  letter-spacing: -.02em;
}
.product-prices .regular-price {
  font-size: 1.125rem !important;
  text-decoration: line-through !important;
  color: var(--s-ink-3) !important;
}
.product-discount {
  font-size: .875rem !important;
  font-weight: 700 !important;
  color: white !important;
  background: var(--s-danger) !important;
  padding: 4px 10px !important;
  border-radius: var(--s-r-sm) !important;
}

.product-description-short, .product_short_description {
  color: var(--s-ink-2) !important;
  line-height: 1.6 !important;
  margin-bottom: var(--s-6);
}

/* Variants */
.product-variants > .product-variants-item {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--s-2) !important;
  margin-bottom: var(--s-4) !important;
}
.product-variants .control-label {
  font-weight: 600 !important;
  font-size: .875rem !important;
  color: var(--s-ink-1) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}
.product-variants ul.color, .input-color-pick {
  display: flex !important;
  gap: var(--s-2) !important;
  list-style: none;
  padding: 0;
  margin: 0;
}
.product-variants ul.color li label,
.input-color {
  width: 36px !important;
  height: 36px !important;
  border-radius: var(--s-r-pill) !important;
  border: 2px solid var(--s-border) !important;
  cursor: pointer;
  transition: transform var(--s-fast) var(--s-ease), border-color var(--s-fast) var(--s-ease);
}
.product-variants ul.color li label:hover { transform: scale(1.08); }
.product-variants ul.color li input:checked + label {
  border-color: var(--s-ink-1) !important;
  transform: scale(1.05);
}

/* Quantity stepper */
.product-quantity, .qty {
  display: inline-flex !important;
  align-items: center !important;
  border: 1.5px solid var(--s-border) !important;
  border-radius: var(--s-r) !important;
  overflow: hidden;
  background: var(--s-surface);
}
.product-quantity .btn-touchspin, .qty button,
.input-group-btn-vertical button {
  width: 44px !important;
  height: 48px !important;
  border: none !important;
  background: transparent !important;
  font-size: 1.125rem !important;
  cursor: pointer;
  color: var(--s-ink-1) !important;
}
.product-quantity input[type="number"], .qty input {
  width: 56px !important;
  height: 48px !important;
  border: none !important;
  text-align: center !important;
  font-weight: 600 !important;
  font-size: 1rem !important;
  background: transparent !important;
}

/* Add-to-cart hero CTA */
.product-add-to-cart .add-to-cart,
button.add-to-cart,
button[data-button-action="add-to-cart"],
.add[data-button-action="add-to-cart"] {
  width: 100% !important;
  font-size: 1rem !important;
  padding: 18px 32px !important;
  border-radius: var(--s-r) !important;
  background: var(--s-accent) !important;
  color: var(--s-accent-ink) !important;
  font-weight: 700 !important;
  border: none !important;
  cursor: pointer;
  transition: all var(--s-fast) var(--s-ease);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
}
.product-add-to-cart .add-to-cart:hover,
button.add-to-cart:hover {
  background: var(--s-accent-strong) !important;
  transform: translateY(-1px);
  box-shadow: var(--s-shadow-2);
}

/* Sticky add-to-cart on mobile */
@media (max-width: 768px) {
  .product-actions-sticky, .sticky-mobile-cart {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    background: var(--s-surface);
    border-top: 1px solid var(--s-border);
    padding: var(--s-3) var(--s-4);
    z-index: 1020;
    box-shadow: 0 -4px 16px rgba(0,0,0,.08);
    display: flex;
    align-items: center;
    gap: var(--s-3);
  }
  body.has-sticky-cart { padding-bottom: 80px; }
}

/* Trust badges row */
.product-trust-badges {
  display: flex;
  gap: var(--s-4);
  flex-wrap: wrap;
  margin-top: var(--s-6);
  padding-top: var(--s-6);
  border-top: 1px solid var(--s-border);
}
.product-trust-badges > div {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  font-size: .8125rem;
  color: var(--s-ink-2);
}

/* Tabs */
.nav-tabs {
  border: none !important;
  margin-bottom: var(--s-6) !important;
  gap: var(--s-1);
  flex-wrap: wrap;
}
.nav-tabs .nav-link {
  border: none !important;
  border-bottom: 2px solid transparent !important;
  padding: var(--s-3) var(--s-4) !important;
  font-weight: 600 !important;
  font-size: .9375rem !important;
  color: var(--s-ink-3) !important;
  background: transparent !important;
  border-radius: 0 !important;
}
.nav-tabs .nav-link:hover { color: var(--s-ink-1) !important; }
.nav-tabs .nav-link.active {
  color: var(--s-ink-1) !important;
  border-bottom-color: var(--s-ink-1) !important;
}

/* ---------------------------------------------------------------- 12. category / listing */

#category-description, .category-cover {
  margin-bottom: var(--s-8);
  padding: var(--s-8);
  background: var(--s-surface);
  border-radius: var(--s-r-lg);
  border: 1px solid var(--s-border);
}

#search_filters, .block-categories,
aside.column, #left-column, #right-column {
  background: var(--s-surface) !important;
  border: 1px solid var(--s-border) !important;
  border-radius: var(--s-r-lg) !important;
  padding: var(--s-5) !important;
}
#search_filters h2, #search_filters h3, .block-categories h2 {
  font-size: .75rem !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: var(--s-ink-3) !important;
  font-weight: 700 !important;
  margin-bottom: var(--s-3) !important;
}
#search_filters .facet {
  margin-bottom: var(--s-5) !important;
  padding-bottom: var(--s-5) !important;
  border-bottom: 1px solid var(--s-border) !important;
}
#search_filters .facet:last-child { border-bottom: none !important; }

.products-selection, .product-list-toolbar {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: var(--s-4) !important;
  flex-wrap: wrap;
  margin-bottom: var(--s-6);
}
.total-products, .count-products {
  font-size: .875rem;
  color: var(--s-ink-3);
}

/* ---------------------------------------------------------------- 13. cart */

#cart .cart-grid, #checkout .cart-grid {
  display: grid !important;
  grid-template-columns: 1.5fr 1fr;
  gap: var(--s-8);
}
@media (max-width: 992px) {
  #cart .cart-grid, #checkout .cart-grid {
    grid-template-columns: 1fr;
  }
}

.cart-overview, .cart-grid-body {
  background: var(--s-surface) !important;
  border-radius: var(--s-r-lg) !important;
  border: 1px solid var(--s-border) !important;
  padding: var(--s-6) !important;
}

.cart-item, li.cart-item {
  display: grid !important;
  grid-template-columns: 88px 1fr auto !important;
  gap: var(--s-4) !important;
  padding: var(--s-4) 0 !important;
  border-bottom: 1px solid var(--s-border) !important;
  align-items: center;
}
.cart-item:last-child { border-bottom: none !important; }
.cart-item .product-image {
  width: 88px;
  height: 88px;
  border-radius: var(--s-r);
  overflow: hidden;
  background: var(--s-surface-2);
}
.cart-item .product-name {
  font-weight: 500 !important;
  font-size: .9375rem !important;
  color: var(--s-ink-1) !important;
}
.cart-item .product-price { font-weight: 700 !important; }

/* Sticky summary */
.cart-summary, .cart-grid-right {
  background: var(--s-surface) !important;
  border-radius: var(--s-r-lg) !important;
  border: 1px solid var(--s-border) !important;
  padding: var(--s-6) !important;
  position: sticky;
  top: calc(var(--s-header-height) + var(--s-4));
  align-self: start;
}
.cart-summary h3 { font-size: 1.0625rem; margin-bottom: var(--s-4); }
.cart-summary-line {
  display: flex !important;
  justify-content: space-between !important;
  align-items: baseline !important;
  padding: var(--s-2) 0 !important;
  font-size: .9375rem;
  color: var(--s-ink-2);
}
.cart-summary-totals {
  border-top: 1px solid var(--s-border);
  margin-top: var(--s-3);
  padding-top: var(--s-4);
}
.cart-summary-totals .label, .cart-summary-totals .value {
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  color: var(--s-ink-1) !important;
}
.cart-detailed-actions .btn { width: 100%; margin-top: var(--s-4); }

/* ---------------------------------------------------------------- 14. checkout */

#checkout .checkout-form, #checkout-form {
  display: grid !important;
  grid-template-columns: 1fr 380px;
  gap: var(--s-8);
}
@media (max-width: 992px) {
  #checkout .checkout-form, #checkout-form { grid-template-columns: 1fr; }
}

.checkout-step, section.checkout-step, .js-checkout-step {
  background: var(--s-surface) !important;
  border: 1px solid var(--s-border) !important;
  border-radius: var(--s-r-lg) !important;
  margin-bottom: var(--s-4) !important;
  padding: var(--s-6) !important;
  transition: box-shadow var(--s-base) var(--s-ease);
}
.checkout-step.-current, .checkout-step.js-current-step {
  box-shadow: var(--s-shadow-2) !important;
  border-color: var(--s-ink-1) !important;
}
.checkout-step h2, .checkout-step h1 {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  font-size: 1.125rem !important;
  margin-bottom: var(--s-4);
}

/* Step number badge */
.checkout-step .step-number, .step-number {
  width: 28px;
  height: 28px;
  border-radius: var(--s-r-pill);
  background: var(--s-ink-1);
  color: white;
  font-size: .875rem;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* ---------------------------------------------------------------- 15. footer */

#footer, footer.footer-container {
  background: var(--s-primary) !important;
  color: rgba(255,255,255,.78) !important;
  padding: var(--s-16) 0 var(--s-6) 0 !important;
  margin-top: var(--s-20);
}
#footer h3, #footer h4, footer h3, footer h4 {
  color: white !important;
  font-size: .875rem !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  font-weight: 600 !important;
  margin-bottom: var(--s-4) !important;
}
#footer a, footer a {
  color: rgba(255,255,255,.65) !important;
  font-size: .9375rem;
}
#footer a:hover, footer a:hover { color: white !important; }
#footer ul { list-style: none; padding: 0; margin: 0; }
#footer ul li { padding: 4px 0; }

#footer .container {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) !important;
  gap: var(--s-8) !important;
}

.block_newsletter, #ps_emailsubscription {
  background: rgba(255,255,255,.06) !important;
  border-radius: var(--s-r-lg) !important;
  padding: var(--s-6) !important;
  margin-bottom: var(--s-8) !important;
}
.block_newsletter form, #ps_emailsubscription form {
  display: flex !important;
  gap: var(--s-2) !important;
  flex-wrap: wrap;
}
.block_newsletter input[type="email"],
#ps_emailsubscription input[type="email"] {
  flex: 1;
  min-width: 240px;
  background: rgba(255,255,255,.1) !important;
  border-color: rgba(255,255,255,.2) !important;
  color: white !important;
}
.block_newsletter input[type="email"]::placeholder,
#ps_emailsubscription input[type="email"]::placeholder {
  color: rgba(255,255,255,.5) !important;
}

#copyright, .copyright {
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: var(--s-5);
  margin-top: var(--s-12);
  font-size: .8125rem;
  color: rgba(255,255,255,.5) !important;
  text-align: center;
}

/* ---------------------------------------------------------------- 16. modals + alerts */

.modal-content {
  border: none !important;
  border-radius: var(--s-r-lg) !important;
  box-shadow: var(--s-shadow-3);
}
.modal-header { border-bottom: 1px solid var(--s-border) !important; padding: var(--s-5) var(--s-6) !important; }
.modal-body { padding: var(--s-6) !important; }
.modal-footer { border-top: 1px solid var(--s-border) !important; padding: var(--s-4) var(--s-6) !important; }

.alert {
  border-radius: var(--s-r) !important;
  border: 1px solid var(--s-border);
  padding: var(--s-3) var(--s-4) !important;
  background: var(--s-surface);
  font-size: .9375rem;
}
.alert-success {
  background: var(--s-trust-bg) !important;
  border-color: rgba(27,191,102,.2) !important;
  color: var(--s-trust-ink) !important;
}
.alert-warning {
  background: rgba(245,166,35,.08) !important;
  border-color: rgba(245,166,35,.25) !important;
  color: #92590a !important;
}
.alert-danger {
  background: rgba(214,71,59,.06) !important;
  border-color: rgba(214,71,59,.2) !important;
  color: #842823 !important;
}
.alert-info {
  background: rgba(44,109,214,.06) !important;
  border-color: rgba(44,109,214,.2) !important;
  color: #1d4994 !important;
}

/* ---------------------------------------------------------------- 17. utils + skeletons */

.skeleton {
  background: linear-gradient(90deg, var(--s-surface-2) 25%, #ebebe5 50%, var(--s-surface-2) 75%);
  background-size: 200% 100%;
  animation: s-pulse 1.4s linear infinite;
  border-radius: var(--s-r);
}
@keyframes s-pulse {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.section-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--s-4);
  margin-bottom: var(--s-6);
  flex-wrap: wrap;
}
.section-heading h2 { margin: 0; }
.section-heading .section-link {
  font-size: .9375rem;
  color: var(--s-ink-2);
  font-weight: 500;
}
.section-heading .section-link:hover { color: var(--s-accent-strong); }

/* Pagination */
.pagination {
  display: flex !important;
  gap: var(--s-1) !important;
  list-style: none;
  padding: 0;
  margin: var(--s-8) 0 var(--s-4) !important;
  justify-content: center;
}
.pagination li a, .pagination li.current span,
.pagination .page-link, .page-list li {
  width: 40px !important;
  height: 40px !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border-radius: var(--s-r) !important;
  border: 1px solid var(--s-border) !important;
  background: var(--s-surface) !important;
  color: var(--s-ink-1) !important;
  font-size: .875rem !important;
  font-weight: 500 !important;
  transition: all var(--s-fast) var(--s-ease);
  padding: 0 !important;
}
.pagination li a:hover { border-color: var(--s-ink-1) !important; }
.pagination li.current span,
.pagination .page-item.active .page-link {
  background: var(--s-ink-1) !important;
  color: white !important;
  border-color: var(--s-ink-1) !important;
}

/* Breadcrumb */
.breadcrumb, nav.breadcrumb {
  background: transparent !important;
  padding: var(--s-3) 0 !important;
  font-size: .8125rem !important;
  margin-bottom: var(--s-4) !important;
  list-style: none !important;
  display: flex !important;
  flex-wrap: wrap;
  gap: var(--s-1) !important;
  align-items: center;
}
.breadcrumb li { color: var(--s-ink-3); }
.breadcrumb li::after {
  content: "/";
  margin: 0 var(--s-2);
  color: var(--s-ink-4);
}
.breadcrumb li:last-child::after { content: ""; }
.breadcrumb a { color: var(--s-ink-3) !important; }
.breadcrumb a:hover { color: var(--s-ink-1) !important; }
.breadcrumb li:last-child {
  color: var(--s-ink-1) !important;
  font-weight: 500;
}

/* Stock indicator */
.product-availability {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--s-2) !important;
  font-size: .875rem !important;
  color: var(--s-ink-2) !important;
  font-weight: 500;
}
.product-availability::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--s-success);
  flex-shrink: 0;
  display: inline-block;
}
.product-availability.out-of-stock::before { background: var(--s-danger); }

/* Print: hide non-essential UI */
@media print {
  #header, #footer, .product-actions, .breadcrumb, .reassurance,
  .block-reassurance { display: none !important; }
  body { background: white; }
}

/* ---------------------------------------------------------------- 18. responsive */

@media (max-width: 768px) {
  :root {
    --s-12: 32px;
    --s-16: 48px;
    --s-20: 56px;
  }
  .container, .container-fluid { padding-inline: var(--s-4); }
  .s-home-hero { padding: 48px 24px; }
  .products, .product_list { grid-template-columns: repeat(2, 1fr) !important; gap: var(--s-3) !important; }
  .product-miniature .product-description { padding: var(--s-3) !important; }
  .section-heading { margin-bottom: var(--s-4); }
}

@media (max-width: 480px) {
  body { font-size: 15px; }
  .products, .product_list { grid-template-columns: 1fr !important; }
}

/* ---------------------------------------------------------------- 19. login */

#authentication, #password, #identity, #my-account {
  max-width: 480px !important;
  margin: var(--s-12) auto !important;
  padding: var(--s-8) !important;
  background: var(--s-surface);
  border-radius: var(--s-r-lg);
  border: 1px solid var(--s-border);
  box-shadow: var(--s-shadow-2);
}
#authentication h1, #password h1 {
  font-size: 1.5rem !important;
  text-align: center;
  margin-bottom: var(--s-2);
}
#authentication p, #password p {
  text-align: center;
  color: var(--s-ink-3) !important;
  margin-bottom: var(--s-6);
}

/* Better-Auth SSO button */
.stackauth-login-button, button[name="stackauthadmin_signin"] {
  width: 100%;
  padding: 14px 24px;
  font-size: .9375rem;
  font-weight: 600;
  background: var(--s-ink-1);
  color: white;
  border-radius: var(--s-r);
  border: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  margin-bottom: var(--s-4);
  cursor: pointer;
  transition: all var(--s-fast) var(--s-ease);
}
.stackauth-login-button:hover {
  background: #000;
  transform: translateY(-1px);
  box-shadow: var(--s-shadow-2);
}

.auth-divider {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin: var(--s-5) 0;
  font-size: .8125rem;
  color: var(--s-ink-3);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.auth-divider::before, .auth-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--s-border);
}
