/* ============================================================
   Kinetic Store — main.css
   Design System: Kinetic Typography
   ============================================================ */

/* ── Custom Properties ────────────────────────────────────── */
:root {
  --ks-black:    #0a0a0a;
  --ks-white:    #f5f5f0;
  --ks-accent:   #c9a84c;
  --ks-accent-rgb: 201, 168, 76;
  --ks-accent-dark: #9e7e30;
  --ks-muted:    #6b6b6b;
  --ks-border:   #222222;
  --ks-surface:  #111111;
  --ks-radius:   4px;
  --ks-container: 1280px;
  --ks-gap:      1rem;
  --ks-font-body:    'Space Grotesk', 'Helvetica Neue', Arial, sans-serif;
  --ks-font-display: 'Cinzel', 'Georgia', 'Times New Roman', serif;
  --ks-transition: 300ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ── Reset ────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; overflow-x: hidden; }
body {
  font-family: var(--ks-font-body);
  background: var(--ks-black);
  color: var(--ks-white);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img, video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--ks-accent); }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
ul, ol { list-style: none; }
:focus-visible { outline: 2px solid var(--ks-accent); outline-offset: 3px; }

/* ── Reduced motion ───────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
  .ks-marquee-track { animation: none !important; }
}
body.ks-anim-off *, body.ks-anim-off *::before, body.ks-anim-off *::after {
  animation: none !important; transition: none !important;
}

/* ── Layout helpers ───────────────────────────────────────── */
.ks-container {
  width: 100%;
  max-width: var(--ks-container);
  margin-inline: auto;
  padding-inline: clamp(1rem, 4vw, 2.5rem);
}
.ks-section { padding-block: clamp(3rem, 6vw, 6rem); }
.ks-site    { display: flex; flex-direction: column; min-height: 100vh; }

/* ── Typography ───────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--ks-font-display);
  text-transform: uppercase;
  line-height: 0.95;
  letter-spacing: -0.01em;
}
h1 { font-size: clamp(3.5rem, 9vw, 9rem); }
h2 { font-size: clamp(2rem, 5vw, 4.5rem); }
h3 { font-size: clamp(1.4rem, 3vw, 2.5rem); }
p  { line-height: 1.65; }
.ks-eyebrow {
  font-family: var(--ks-font-body);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--ks-accent);
}

/* ── Marquee Bar ──────────────────────────────────────────── */
.ks-marquee-bar {
  background: var(--ks-accent);
  color: var(--ks-black);
  overflow: hidden;
  white-space: nowrap;
  padding: 0.4rem 0;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.ks-marquee-track {
  display: inline-flex;
  animation: ks-marquee 30s linear infinite;
  width: max-content;
}
.ks-marquee-track--slow { animation-duration: 60s; }
.ks-marquee-item { padding-inline: 2rem; }
@keyframes ks-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ── Header ───────────────────────────────────────────────── */
.ks-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(10,10,10,0.95);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--ks-border);
}
.ks-header-inner {
  display: flex;
  align-items: center;
  gap: 2rem;
  height: 64px;
}
.ks-logo { display: flex; align-items: center; }
.ks-header-inner .custom-logo-link { display: inline-flex; align-items: center; }
.ks-header-inner .custom-logo { max-height: 44px; width: auto; height: auto; max-width: 220px; }
.ks-logo-text {
  font-family: var(--ks-font-display);
  font-size: 1.6rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ks-white);
}
.ks-nav { margin-left: auto; min-width: 0; }
.ks-nav-list { display: flex; gap: 1.2rem; flex-wrap: nowrap; white-space: nowrap; align-items: center; }
.ks-nav-list a {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  transition: color var(--ks-transition);
  position: relative;
}
.ks-nav-list a::after {
  content: '';
  position: absolute;
  left: 0; bottom: -4px;
  width: 0; height: 2px;
  background: var(--ks-accent);
  transition: width var(--ks-transition);
}
.ks-nav-list a:hover::after { width: 100%; }
.ks-header-actions { display: flex; align-items: center; gap: 0.5rem; }
.ks-icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  border-radius: var(--ks-radius);
  transition: background var(--ks-transition), color var(--ks-transition);
  color: var(--ks-white);
  position: relative;
}
.ks-icon-btn:hover { background: var(--ks-surface); color: var(--ks-accent); }
.ks-cart-count {
  position: absolute; top: 4px; right: 4px;
  background: var(--ks-accent); color: var(--ks-black);
  font-size: 0.6rem; font-weight: 700;
  min-width: 16px; height: 16px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.ks-menu-toggle { display: none; }
.ks-hamburger { display: flex; flex-direction: column; gap: 5px; }
.ks-hamburger span { display: block; width: 22px; height: 2px; background: var(--ks-white); transition: var(--ks-transition); }

/* Search bar */
.ks-search-bar {
  border-top: 1px solid var(--ks-border);
  background: var(--ks-surface);
  padding: 1rem 0;
}
.ks-search-bar .ks-container { display: flex; gap: 1rem; align-items: center; }
.ks-search-bar input[type="search"] {
  flex: 1;
  background: transparent;
  border: none;
  border-bottom: 2px solid var(--ks-accent);
  color: var(--ks-white);
  font-family: var(--ks-font-display);
  font-size: 1.8rem;
  text-transform: uppercase;
  padding: 0.5rem 0;
  outline: none;
}
.ks-search-close {
  font-size: 1.2rem;
  color: var(--ks-muted);
  padding: 0.5rem;
  transition: color var(--ks-transition);
}
.ks-search-close:hover { color: var(--ks-accent); }

/* ── Buttons ──────────────────────────────────────────────── */
.ks-btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0.8rem 2rem;
  font-family: var(--ks-font-body);
  font-size: 0.85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  border: 2px solid transparent;
  border-radius: var(--ks-radius);
  transition: background var(--ks-transition), color var(--ks-transition), transform var(--ks-transition), border-color var(--ks-transition);
  cursor: pointer;
}
.ks-btn:active { transform: scale(0.97); }
.ks-btn-accent {
  background: var(--ks-accent);
  color: var(--ks-black);
  border-color: var(--ks-accent);
}
.ks-btn-accent:hover { background: var(--ks-black); color: var(--ks-accent); }
.ks-btn-ghost {
  background: transparent;
  color: var(--ks-white);
  border-color: var(--ks-white);
}
.ks-btn-ghost:hover { background: var(--ks-white); color: var(--ks-black); }
.ks-btn-lg { padding: 1.1rem 2.8rem; font-size: 1rem; }

/* ── Hero ─────────────────────────────────────────────────── */
.ks-hero {
  min-height: clamp(480px, 85vh, 920px);
  display: flex; align-items: center;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--ks-border);
}
.ks-hero-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  align-items: center;
  width: 100%;
  padding-block: 4rem;
}
.ks-hero-headline {
  font-size: clamp(2.5rem, 6vw, 6rem);
  line-height: 0.92;
  margin-bottom: 3rem;
}
.ks-hero-sub {
  color: var(--ks-muted);
  max-width: 40ch;
  margin-bottom: 2rem;
}
.ks-hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 4rem; }
.ks-hero-visual { display: flex; justify-content: center; align-items: center; }
.ks-hero-img {
  width: clamp(240px, 40vw, 560px);
  filter: drop-shadow(0 30px 60px rgba(0,0,0,0.6));
  animation: ks-float 4s ease-in-out infinite;
}
@keyframes ks-float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-18px); }
}
.ks-hero-deco-num {
  position: absolute;
  right: -0.05em; bottom: -0.15em;
  font-family: var(--ks-font-display);
  font-size: clamp(8rem, 25vw, 28rem);
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,0.04);
  pointer-events: none;
  user-select: none;
  z-index: 0;
}

/* ── Product Grid ─────────────────────────────────────────── */
.ks-section-header {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 2rem;
  border-bottom: 2px solid var(--ks-border);
  padding-bottom: 1rem;
}
.ks-section-title { font-size: clamp(1.4rem, 2.8vw, 2.4rem); }
.ks-section-link {
  font-size: 0.8rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--ks-accent);
}

.ks-product-grid {
  display: grid;
  gap: var(--ks-gap);
}
.ks-product-grid--2 { grid-template-columns: repeat(2, 1fr); }
.ks-product-grid--3 { grid-template-columns: repeat(3, 1fr); }
.ks-product-grid--4 { grid-template-columns: repeat(4, 1fr); }
.ks-product-grid--6 { grid-template-columns: repeat(6, 1fr); }

/* Product card */
.ks-product-card {
  border: 1px solid var(--ks-border);
  background: var(--ks-surface);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color var(--ks-transition), transform 0.35s ease, box-shadow 0.35s ease;
}
.ks-product-card:hover {
  border-color: rgba(var(--ks-accent-rgb), 0.45);
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,0.45), 0 0 0 1px rgba(var(--ks-accent-rgb), 0.12);
}
/* invert hover kept for compatibility — now just a subtle tint */
.ks-product-card--invert:hover { background: var(--ks-surface); color: inherit; }
.ks-product-card--invert:hover .ks-product-title a { color: inherit; }
.ks-product-card--invert:hover .ks-product-price { color: var(--ks-accent); }

.ks-product-media {
  display: block;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: #0e0e0e;
  flex-shrink: 0;
  position: relative;
}
.ks-product-media img {
  width: 100%; height: 100%;
  object-fit: contain;
  background: #0e0e0e;
  transition: transform 0.6s ease;
}
.ks-product-card:hover .ks-product-media img { transform: scale(1.06); }
.ks-product-img-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  color: var(--ks-muted); font-size: 0.8rem;
}

/* Price overlay — bottom-left of image */
.ks-product-price-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  padding: 0.3rem 0.65rem;
  background: rgba(0,0,0,0.72);
  backdrop-filter: blur(6px);
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--ks-accent);
  letter-spacing: 0.04em;
  line-height: 1.4;
  z-index: 2;
  border-top-right-radius: 2px;
  pointer-events: none;
}
.ks-product-price-overlay del {
  opacity: 0.45;
  font-size: 0.72em;
  margin-right: 0.3em;
  color: #fff;
}
.ks-product-price-overlay ins {
  text-decoration: none;
}

/* Badge */
.ks-badge {
  position: absolute; top: 0.7rem; left: 0.7rem;
  padding: 0.2rem 0.55rem;
  font-size: 0.6rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.14em;
  border-radius: 2px; z-index: 2;
}
.ks-badge-sale { background: var(--ks-accent); color: var(--ks-black); }
.ks-badge-hot  { background: #e03030; color: #fff; }

/* Product info */
.ks-product-info {
  padding: 1rem 1rem 0.6rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.ks-product-brand {
  font-size: 0.6rem;
  font-family: var(--ks-font-display);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(var(--ks-accent-rgb), 0.55);
  margin: 0;
  min-height: 0.9rem;
}
.ks-product-title {
  font-family: var(--ks-font-display);
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.35;
  margin: 0;
  /* clamp to 3 lines */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.ks-product-title a { color: inherit; }
.ks-product-title a:hover { color: var(--ks-accent); }
.ks-product-price-row {
  margin-top: auto;
  padding-top: 0.4rem;
}
.ks-product-price {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--ks-accent);
  transition: color var(--ks-transition);
}
.ks-product-price del { opacity: 0.4; font-size: 0.75em; margin-right: 0.3em; }

/* Decorative bg number */
.ks-product-deco-num {
  position: absolute; bottom: 3rem; right: 0.5rem;
  font-family: var(--ks-font-display);
  font-size: 3.5rem;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,0.04);
  pointer-events: none;
  user-select: none;
  line-height: 1;
  z-index: 0;
}

/* Add to cart button on card — full-width centered */
.ks-product-cta { display: block; }
.ks-product-cta > *,
.ks-product-cta > form { display: block; }
.ks-product-card .button,
.ks-product-cta .button,
.ks-product-cta a.button,
.ks-product-cta a.add_to_cart_button {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.45em;
  width: 100%;
  padding: 0.7rem 1rem;
  background: transparent;
  border: none;
  border-top: 1px solid var(--ks-border);
  color: rgba(255,255,255,0.45);
  font-family: var(--ks-font-body);
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  text-align: center;
  transition: background var(--ks-transition), color var(--ks-transition), border-color var(--ks-transition);
  position: relative;
  overflow: hidden;
  box-sizing: border-box;
}
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.45em;
  width: 100%;
  padding: 0.7rem 1rem;
  background: transparent;
  border: none;
  border-top: 1px solid var(--ks-border);
  color: rgba(255,255,255,0.55);
  font-family: var(--ks-font-body);
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  text-align: center;
  transition: background var(--ks-transition), color var(--ks-transition), border-color var(--ks-transition);
  position: relative;
  overflow: hidden;
}
/* shimmer line on hover */
.ks-product-card .button::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(var(--ks-accent-rgb), 0.08) 50%, transparent 100%);
  transform: translateX(-100%);
  transition: transform 0.5s ease;
}
.ks-product-card:hover .button::before { transform: translateX(100%); }
.ks-product-card:hover .button {
  border-top-color: rgba(var(--ks-accent-rgb), 0.35);
  color: var(--ks-accent);
}
.ks-product-card .button:hover {
  background: var(--ks-accent);
  color: var(--ks-black);
  border-top-color: var(--ks-accent);
}
.ks-product-card .button:hover::before { display: none; }

/* ── Single Product ───────────────────────────────────────── */

/* Breadcrumb */
.woocommerce-breadcrumb {
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ks-muted);
  margin-bottom: 2.5rem;
  display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap;
}
.woocommerce-breadcrumb a { color: var(--ks-muted); transition: color var(--ks-transition); }
.woocommerce-breadcrumb a:hover { color: var(--ks-accent); }
.woocommerce-breadcrumb .breadcrumb-separator { color: rgba(var(--ks-accent-rgb), 0.3); }

/* Layout */
.ks-single-product {
  display: grid !important;
  grid-template-columns: 55% 1fr;
  gap: 4rem;
  align-items: start;
  padding-block: 2rem 4rem;
  flex-wrap: unset !important;   /* override WC float-based layout */
}
/* Prevent grid blowout from WooCommerce gallery */
.ks-single-gallery,
.ks-single-summary {
  min-width: 0;
  width: 100% !important;
  float: none !important;
  max-width: 100% !important;
}
.ks-single-summary { overflow: visible; }

/* WooCommerce gallery overrides */
#wpgs-gallery.wcgs-woocommerce-product-gallery,
.ks-single-gallery .woocommerce-product-gallery {
  position: sticky !important;
  top: 5rem;
  width: 100% !important;
  max-width: 100% !important;
  min-width: unset !important;
  float: none !important;
  margin: 0 !important;
}
.ks-single-gallery .woocommerce-product-gallery__wrapper {
  border: 1px solid var(--ks-border);
  background: #0a0a0a;
}
.ks-single-gallery .woocommerce-product-gallery__image img {
  width: 100%;
  height: auto;
  display: block;
}
/* Thumbnails row */
.ks-single-gallery .flex-control-thumbs {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.5rem;
  padding: 0;
  list-style: none;
}
.ks-single-gallery .flex-control-thumbs li { flex: 1 1 0; }
.ks-single-gallery .flex-control-thumbs img {
  border: 1px solid var(--ks-border);
  cursor: pointer;
  transition: border-color var(--ks-transition);
  display: block; width: 100%;
}
.ks-single-gallery .flex-control-thumbs img:hover,
.ks-single-gallery .flex-control-thumbs .flex-active { border-color: var(--ks-accent) !important; }
/* Zoom icon */
.ks-single-gallery .woocommerce-product-gallery__trigger {
  position: absolute; top: 0.75rem; right: 0.75rem;
  width: 36px; height: 36px;
  background: rgba(10,10,10,0.75);
  border: 1px solid var(--ks-border);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  z-index: 5;
  backdrop-filter: blur(4px);
}

/* Summary panel */
.ks-single-summary { position: relative; }
.ks-single-deco-num {
  position: absolute; top: -1rem; right: 0;
  font-family: var(--ks-font-display);
  font-size: clamp(4rem, 10vw, 11rem);
  color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,0.04);
  pointer-events: none; user-select: none; line-height: 1; z-index: 0;
}

/* Category eyebrow */
.ks-single-cat {
  font-family: var(--ks-font-display);
  font-size: 0.62rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: rgba(var(--ks-accent-rgb), 0.6);
  margin-bottom: 0.75rem;
}

/* Title */
.ks-single-title {
  font-family: var(--ks-font-display);
  font-size: clamp(1.3rem, 2.2vw, 1.9rem);
  line-height: 1.2;
  letter-spacing: 0.02em;
  margin-bottom: 1.5rem;
  position: relative; z-index: 1;
  text-transform: uppercase;
}

/* Price */
.ks-single-price {
  display: flex; align-items: baseline; gap: 0.75rem;
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--ks-border);
  position: relative; z-index: 1;
}
.ks-single-price .woocommerce-Price-amount {
  font-family: var(--ks-font-display);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 700;
  color: var(--ks-accent);
}
/* Sale price (ins) — green */
.ks-single-price ins {
  text-decoration: none;
}
.ks-single-price ins .woocommerce-Price-amount {
  color: #4caf50 !important;
}
/* Regular / old price (del) — smaller red strikethrough */
.ks-single-price del {
  text-decoration: line-through;
  opacity: 1;
}
.ks-single-price del .woocommerce-Price-amount {
  color: #e05252 !important;
  font-size: 1rem !important;
}

/* Short description */
.ks-single-excerpt {
  color: var(--ks-muted);
  font-size: 0.88rem;
  line-height: 1.7;
  margin-bottom: 2rem;
  max-width: 46ch;
}

/* Trust badges row */
.ks-single-trust {
  display: flex; gap: 1.5rem; flex-wrap: wrap;
  padding: 1rem 0;
  margin-bottom: 1.5rem;
  border-top: 1px solid var(--ks-border);
  border-bottom: 1px solid var(--ks-border);
}
.ks-single-trust-item {
  display: flex; align-items: center; gap: 0.5rem;
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ks-muted);
}
.ks-single-trust-item svg { width: 16px; height: 16px; stroke: rgba(var(--ks-accent-rgb), 0.5); fill: none; flex-shrink: 0; }

/* Cart form */
.ks-single-cart-form { position: relative; z-index: 1; }

/* Outer wrapper: stacks qty row, then button row */
.ks-single-cart-form {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

/* WC form.cart: qty on top, button below */
.ks-single-cart-form form.cart {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.6rem;
}
.ks-single-cart-form form.cart .quantity { width: max-content; }

/* Button row: ATC + WhatsApp side by side */
.ks-single-cart-form form.cart .single_add_to_cart_button,
.ks-single-cart-form form.cart button.single_add_to_cart_button {
  /* full row by default — WA button is a sibling of the form, not inside it */
  width: 100%;
}

/* Row that holds ATC form + WA button */
.ks-single-cart-form {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.ks-single-cart-btn-row {
  display: flex;
  gap: 0.6rem;
  align-items: stretch;
}
.ks-single-cart-btn-row form.cart {
  flex: 1 1 0;
  min-width: 0;
  display: flex !important;
  flex-direction: column !important;
  gap: 0;
}
/* hide WC's own qty inside the button row — our standalone one sits above */
.ks-single-cart-btn-row form.cart .quantity { display: none !important; }
.ks-single-cart-btn-row form.cart .single_add_to_cart_button,
.ks-single-cart-btn-row form.cart button.single_add_to_cart_button { width: 100%; }
.ks-btn-whatsapp { flex-shrink: 0; }
.ks-single-cart-form .single_add_to_cart_button.button,
.ks-single-cart-form button.single_add_to_cart_button,
.ks-single-cart-form .single_add_to_cart_button.button.alt {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  height: 3.4rem;
  background: var(--ks-accent) !important;
  color: var(--ks-black) !important;
  font-family: var(--ks-font-display);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  white-space: nowrap;
  border: none;
  border-radius: 2px;
  cursor: pointer;
  transition: background var(--ks-transition), transform var(--ks-transition), box-shadow var(--ks-transition);
}
.ks-single-cart-form .single_add_to_cart_button.button:hover,
.ks-single-cart-form button.single_add_to_cart_button:hover {
  background: #fff !important;
  color: var(--ks-black) !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(var(--ks-accent-rgb), 0.25);
}

/* WhatsApp button — square icon-only, text visible on wider viewports */
.ks-btn-whatsapp {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  height: 3.4rem;
  width: 3.4rem;          /* square icon at narrow widths */
  padding: 0;
  background: #25d366;
  color: #fff !important;
  font-family: var(--ks-font-display);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border-radius: 2px;
  white-space: nowrap;
  overflow: hidden;
  flex-shrink: 0;
  transition: background var(--ks-transition), transform var(--ks-transition);
  text-decoration: none;
}
.ks-btn-whatsapp:hover {
  background: #128c4e;
  color: #fff !important;
  transform: translateY(-2px);
}
.ks-btn-whatsapp svg { width: 22px; height: 22px; flex-shrink: 0; }
.ks-btn-whatsapp span { display: none; } /* hide text at narrow widths */

/* Show text + widen at larger summary widths */
@media (min-width: 1200px) {
  .ks-btn-whatsapp {
    width: auto;
    padding: 0 1.25rem;
  }
  .ks-btn-whatsapp span { display: inline; }
}

/* Meta */
.ks-single-meta {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--ks-border);
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  color: var(--ks-muted);
  display: flex; flex-direction: column; gap: 0.4rem;
}
.ks-single-meta a { color: var(--ks-muted); transition: color var(--ks-transition); }
.ks-single-meta a:hover { color: var(--ks-accent); }
.ks-single-meta .sku_wrapper,
.ks-single-meta .posted_in,
.ks-single-meta .tagged_as { display: block; }
.ks-single-meta strong { color: rgba(255,255,255,0.5); font-weight: 600; margin-right: 0.3em; }

/* Qty stepper */
.ks-qty-wrap {
  display: flex; align-items: center;
  border: 1px solid var(--ks-border);
  width: max-content;
}
.ks-qty-btn {
  width: 40px; height: 40px;
  font-size: 1.2rem;
  color: var(--ks-muted);
  background: var(--ks-surface);
  transition: color var(--ks-transition), background var(--ks-transition);
}
.ks-qty-btn:hover { background: var(--ks-border); color: var(--ks-white); }
.ks-qty-input {
  width: 52px; height: 40px;
  background: transparent;
  border: none;
  border-left: 1px solid var(--ks-border);
  border-right: 1px solid var(--ks-border);
  color: var(--ks-white);
  font-family: var(--ks-font-display);
  font-size: 1.1rem;
  text-align: center;
  -moz-appearance: textfield;
}
.ks-qty-input::-webkit-outer-spin-button,
.ks-qty-input::-webkit-inner-spin-button { -webkit-appearance: none; }

/* Sticky cart bar */
.ks-sticky-cart {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: rgba(10,10,10,0.97);
  border-top: 1px solid var(--ks-accent);
  backdrop-filter: blur(12px);
  z-index: 999;
  padding: 0.8rem 0;
  transform: translateY(100%);
  transition: transform 0.4s ease;
}
.ks-sticky-cart.is-visible { transform: translateY(0); }
.ks-sticky-cart-inner {
  display: flex; align-items: center;
  gap: 1.5rem; flex-wrap: wrap;
}
.ks-sticky-cart-title {
  font-family: var(--ks-font-display);
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  flex: 1;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ks-sticky-cart-price { color: var(--ks-accent); font-weight: 700; font-size: 1.1rem; white-space: nowrap; }
.ks-sticky-cart-btn { white-space: nowrap; }

/* Product description / reviews tabs */
.ks-single-tabs {
  padding-block: 3rem 3.5rem;
  border-top: 1px solid var(--ks-border);
}

/* Tab nav */
.ks-single-tabs .woocommerce-tabs ul.tabs {
  display: flex;
  gap: 0;
  list-style: none;
  border-bottom: 1px solid var(--ks-border);
  margin-bottom: 2.5rem;
  padding: 0;
}
.ks-single-tabs .woocommerce-tabs ul.tabs li {
  position: relative;
}
.ks-single-tabs .woocommerce-tabs ul.tabs li a {
  display: block;
  padding: 0.75rem 2rem;
  font-family: var(--ks-font-display);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ks-muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color var(--ks-transition), border-color var(--ks-transition);
}
.ks-single-tabs .woocommerce-tabs ul.tabs li.active a,
.ks-single-tabs .woocommerce-tabs ul.tabs li a:hover {
  color: var(--ks-accent);
  border-bottom-color: var(--ks-accent);
}

/* Panel content */
.ks-single-tabs .woocommerce-tabs .woocommerce-Tabs-panel {
  max-width: 860px;
}
/* Hide auto-generated tab panel heading (tab label is already visible) */
.ks-single-tabs .woocommerce-tabs .woocommerce-Tabs-panel > h2:first-child {
  display: none;
}
.ks-single-tabs .woocommerce-tabs .woocommerce-Tabs-panel h2 {
  font-family: var(--ks-font-display);
  font-size: clamp(0.9rem, 1.5vw, 1.1rem);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ks-accent);
  margin-bottom: 1.25rem;
  margin-top: 0;
}
.ks-single-tabs .woocommerce-tabs .woocommerce-Tabs-panel p {
  font-size: 0.92rem;
  line-height: 1.75;
  color: rgba(245,245,240,0.75);
  margin-bottom: 1rem;
}
.ks-single-tabs .woocommerce-tabs .woocommerce-Tabs-panel strong {
  color: var(--ks-white);
}
.ks-single-tabs .woocommerce-tabs .woocommerce-Tabs-panel h3,
.ks-single-tabs .woocommerce-tabs .woocommerce-Tabs-panel h4 {
  font-family: var(--ks-font-display);
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ks-accent);
  margin: 1.5rem 0 0.6rem;
}
.ks-single-tabs .woocommerce-tabs .woocommerce-Tabs-panel ul,
.ks-single-tabs .woocommerce-tabs .woocommerce-Tabs-panel ol {
  padding-left: 1.2rem;
  margin-bottom: 1rem;
}
.ks-single-tabs .woocommerce-tabs .woocommerce-Tabs-panel li {
  font-size: 0.9rem;
  line-height: 1.65;
  color: rgba(245,245,240,0.7);
  margin-bottom: 0.4rem;
}
.ks-single-tabs .woocommerce-tabs .woocommerce-Tabs-panel li strong {
  color: var(--ks-white);
}

/* Reviews panel */
.ks-single-tabs #reviews { color: var(--ks-white); }
.ks-single-tabs #reviews #comments h2 {
  font-family: var(--ks-font-display);
  font-size: 1rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 1rem;
}
.ks-single-tabs #reviews .comment-respond h3 {
  font-family: var(--ks-font-display);
  font-size: 0.9rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ks-accent);
  margin-bottom: 1rem;
}
.ks-single-tabs #reviews .woocommerce-noreviews {
  color: var(--ks-muted);
  font-size: 0.9rem;
}
.ks-single-tabs #reviews .comment-form-rating label {
  font-size: 0.8rem; letter-spacing: 0.1em; text-transform: uppercase;
}
.ks-single-tabs #reviews input[type="text"],
.ks-single-tabs #reviews input[type="email"],
.ks-single-tabs #reviews textarea {
  width: 100%;
  background: var(--ks-surface);
  border: 1px solid var(--ks-border);
  color: var(--ks-white);
  padding: 0.65rem 1rem;
  font-family: var(--ks-font-body);
  font-size: 0.9rem;
  border-radius: 2px;
  margin-bottom: 0.75rem;
}
.ks-single-tabs #reviews input[type="submit"] {
  background: var(--ks-accent);
  color: var(--ks-black);
  font-family: var(--ks-font-display);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 0.75rem 2rem;
  border: none;
  cursor: pointer;
  transition: background var(--ks-transition);
}
.ks-single-tabs #reviews input[type="submit"]:hover { background: #fff; }

/* Related products */
.ks-single-related {
  padding-block: 3rem 4rem;
  border-top: 1px solid var(--ks-border);
}
.ks-single-related .ks-section-header { margin-bottom: 2.5rem; }

/* ── Shop archive ─────────────────────────────────────────── */
.ks-shop-topbar { padding-block: 1.5rem; border-bottom: 1px solid var(--ks-border); }
.ks-shop-topbar-inner { display: flex; align-items: center; justify-content: space-between; }
.ks-shop-title { font-size: clamp(1.1rem, 2.5vw, 1.6rem); text-transform: uppercase; letter-spacing: 0.1em; }

/* ── Category accordion sidebar ──────────────────────── */
.ks-cat-accordion { list-style: none; margin: 0; padding: 0; }
.ks-cat-accordion .ks-cat-parent > .ks-cat-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.55rem 0;
  border-bottom: 1px solid var(--ks-border);
  cursor: pointer;
  user-select: none;
}
.ks-cat-accordion .ks-cat-parent > .ks-cat-row a {
  color: var(--ks-white); font-size: 0.85rem; text-transform: uppercase;
  letter-spacing: 0.08em; text-decoration: none; flex: 1;
  transition: color var(--ks-transition);
}
.ks-cat-accordion .ks-cat-parent > .ks-cat-row a:hover { color: var(--ks-accent); }
.ks-cat-accordion .ks-cat-toggle {
  background: none; border: none; color: var(--ks-muted);
  cursor: pointer; padding: 0 0 0 0.5rem; line-height: 1;
  font-size: 0.7rem; transition: transform 0.25s ease, color 0.2s;
  flex-shrink: 0;
}
.ks-cat-accordion .ks-cat-toggle.is-open { transform: rotate(180deg); color: var(--ks-accent); }
.ks-cat-accordion .ks-cat-children {
  list-style: none; margin: 0; padding: 0 0 0 0.75rem;
  overflow: hidden; max-height: 0; transition: max-height 0.3s ease;
}
.ks-cat-accordion .ks-cat-children.is-open { max-height: 600px; }
.ks-cat-accordion .ks-cat-children li { padding: 0.35rem 0; border-bottom: 1px solid rgba(255,255,255,0.05); }
.ks-cat-accordion .ks-cat-children a {
  color: var(--ks-muted); font-size: 0.8rem; text-decoration: none;
  transition: color var(--ks-transition);
}
.ks-cat-accordion .ks-cat-children a:hover { color: var(--ks-accent); }
.ks-cat-accordion-title {
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.15em;
  color: var(--ks-muted); margin: 0 0 1rem;
}
.ks-shop-layout { display: grid; grid-template-columns: 1fr; gap: 2rem; padding-top: 2rem; }
.ks-shop-layout:has(.ks-shop-sidebar) { grid-template-columns: 240px 1fr; }
/* Mobile filter toggle — hidden on desktop */
.ks-mobile-filter-toggle { display: none; }
.ks-woocommerce-result-count { font-size: 0.8rem; color: var(--ks-muted); }
.woocommerce-ordering select {
  background: var(--ks-surface); color: var(--ks-white);
  border: 1px solid var(--ks-border);
  padding: 0.4rem 0.8rem; font-family: var(--ks-font-body); font-size: 0.8rem;
}
.woocommerce-pagination { margin-top: 3rem; }
.woocommerce-pagination ul { display: flex; gap: 0.5rem; list-style: none; }
.woocommerce-pagination li a,
.woocommerce-pagination li span {
  display: flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  border: 2px solid var(--ks-border);
  font-weight: 600;
  transition: border-color var(--ks-transition), background var(--ks-transition), color var(--ks-transition);
}
.woocommerce-pagination .current,
.woocommerce-pagination li a:hover {
  background: var(--ks-accent); border-color: var(--ks-accent); color: var(--ks-black);
}

/* ── Promo Banner ─────────────────────────────────────────── */
.ks-promo-banner {
  background: var(--ks-surface);
  border-top: 2px solid var(--ks-border);
  border-bottom: 2px solid var(--ks-border);
  text-align: center;
}
.ks-promo-banner--image {
  background-image: var(--ks-promo-bg);
  background-size: cover; background-position: center;
  position: relative;
}
.ks-promo-banner--image::before {
  content: ''; position: absolute; inset: 0;
  background: rgba(10,10,10,0.75);
}
.ks-promo-inner { position: relative; z-index: 1; }
.ks-promo-headline {
  font-size: clamp(2rem, 6vw, 5rem);
  margin-bottom: 0.8rem;
}
.ks-promo-sub {
  color: var(--ks-muted); max-width: 50ch; margin: 0 auto 1.5rem;
}

/* ── Cart page ────────────────────────────────────────────── */
.ks-wc-cart .ks-page-title { margin-bottom: 2rem; }
.ks-cart-table { width: 100%; border-collapse: collapse; }
.ks-cart-table th, .ks-cart-table td {
  padding: 1rem; border-bottom: 1px solid var(--ks-border);
  text-align: left; vertical-align: middle;
}
.ks-cart-table th { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--ks-muted); }
.ks-cart-table .product-thumbnail img { width: 80px; height: 80px; object-fit: cover; }
.ks-cart-remove { font-size: 1.2rem; color: var(--ks-muted); transition: color var(--ks-transition); }
.ks-cart-remove:hover { color: #ff3b3b; }
.ks-cart-form .actions { display: flex; gap: 1rem; align-items: center; }
.ks-input {
  background: var(--ks-surface);
  border: 1px solid var(--ks-border);
  color: var(--ks-white);
  padding: 0.6rem 1rem;
  font-family: var(--ks-font-body);
  border-radius: var(--ks-radius);
}
.cart-collaterals { margin-top: 2rem; display: flex; justify-content: flex-end; }
.cart_totals { min-width: 360px; }
.cart_totals h2 { font-size: clamp(1.4rem, 3vw, 2rem); margin-bottom: 1rem; }
.cart_totals table { width: 100%; border-collapse: collapse; }
.cart_totals td, .cart_totals th { padding: 0.75rem; border-bottom: 1px solid var(--ks-border); text-align: left; }
.wc-proceed-to-checkout .checkout-button {
  display: block; width: 100%;
  background: var(--ks-accent); color: var(--ks-black);
  padding: 1.1rem; margin-top: 1rem;
  font-family: var(--ks-font-display); font-size: 1.5rem;
  text-transform: uppercase; text-align: center;
  border-radius: var(--ks-radius);
  transition: transform var(--ks-transition);
}
.wc-proceed-to-checkout .checkout-button:hover { transform: scale(1.02); }

/* ── Footer ───────────────────────────────────────────────── */
.ks-footer { border-top: 1px solid var(--ks-border); margin-top: auto; }
.ks-footer-marquee { overflow: hidden; border-bottom: 1px solid var(--ks-border); padding: 0.5rem 0; }
.ks-footer-marquee .ks-marquee-item { color: var(--ks-muted); font-size: 0.75rem; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; }
.ks-footer-body {
  display: grid;
  grid-template-columns: 1.4fr repeat(3, minmax(0, 1fr));
  gap: 2.5rem;
  padding-block: 4rem 3rem;
}
.ks-footer-col { min-width: 0; }
.ks-footer-col .ks-widget-title { font-family: var(--ks-font-display); font-size: 0.95rem; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 1rem; color: var(--ks-white); }
.ks-footer-col ul { display: flex; flex-direction: column; gap: 0.55rem; }
.ks-footer-col ul li a { color: var(--ks-muted); font-size: 0.88rem; transition: color var(--ks-transition); white-space: normal; word-break: normal; }
.ks-footer-col ul li a:hover { color: var(--ks-accent); }
.ks-footer-tagline { color: var(--ks-muted); font-size: 0.9rem; margin-top: 0.8rem; max-width: 30ch; }
.ks-footer-brand { min-width: 0; }
.ks-footer-brand .custom-logo,
.ks-footer-brand .ks-logo img,
.ks-footer-brand img { max-width: 200px; height: auto; }
.ks-footer-bottom {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 1rem;
  padding-block: 1.2rem;
  border-top: 1px solid var(--ks-border);
  font-size: 0.78rem; color: var(--ks-muted);
}
.ks-footer-nav { display: flex; gap: 1.2rem; }
.ks-footer-nav a { font-size: 0.78rem; color: var(--ks-muted); transition: color var(--ks-transition); }
.ks-footer-nav a:hover { color: var(--ks-accent); }
.ks-footer-credit a { color: var(--ks-muted); }
.ks-footer-credit a:hover { color: var(--ks-accent); }

/* ── Scroll animation classes ─────────────────────────────── */
.ks-animate { opacity: 0; transform: translateY(24px); transition: opacity 0.6s ease, transform 0.6s ease; }
.ks-animate.is-visible, .ks-animate[data-ks-anim].is-visible { opacity: 1; transform: none; }
.ks-animate[data-ks-anim="fade-in"] { transform: none; }
.ks-animate[data-ks-anim="slide-up"] { transform: translateY(40px); }
.ks-animate[data-ks-anim="split-reveal"] { transform: translateY(60px); }
body.ks-anim-reduced .ks-animate { opacity: 1; transform: none; }

/* ── Notices ──────────────────────────────────────────────── */
.ks-notice {
  padding: 1rem 1.5rem; margin-bottom: 1.5rem;
  border-left: 4px solid var(--ks-border);
  font-size: 0.9rem;
}
.ks-notice-info    { border-color: var(--ks-accent); background: rgba(240,224,64,0.08); }
.ks-notice-warning { border-color: #ff3b3b; background: rgba(255,59,59,0.08); }

/* ── WooCommerce generic overrides ───────────────────────── */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
  border-top-color: var(--ks-accent) !important;
  background: var(--ks-surface) !important;
  color: var(--ks-white) !important;
  padding: 1rem 1.5rem !important;
}
/* breadcrumb styles defined in single product section above */

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 1024px) {
  .ks-product-grid--4 { grid-template-columns: repeat(3, 1fr); }
  .ks-hero-inner { grid-template-columns: 1fr; }
  .ks-hero-visual { display: none; }
  .ks-footer-body { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 680px) {
  .ks-single-product { grid-template-columns: 1fr !important; gap: 2rem; }

  /* Mobile: hide WCGS thumbnail strip — slider handles navigation */
  .gallery-navigation-carousel-wrapper { display: none !important; }
}

@media (max-width: 768px) {
  .ks-product-grid--4,
  .ks-product-grid--3 { grid-template-columns: repeat(2, 1fr); }
  .ks-nav { display: none; }
  .ks-menu-toggle { display: flex; }
  .ks-nav.is-open {
    display: flex;
    position: fixed; inset: 64px 0 0 0;
    background: var(--ks-black);
    z-index: 999;
    flex-direction: column;
    padding: 2rem;
  }
  .ks-nav.is-open .ks-nav-list { flex-direction: column; gap: 1.5rem; }
  .ks-nav.is-open .ks-nav-list a { font-size: 1.5rem; }
  .ks-footer-body { grid-template-columns: 1fr; }
  .ks-shop-layout:has(.ks-shop-sidebar) { grid-template-columns: 1fr; }
  /* Mobile: sidebar collapses, toggle button shown */
  .ks-mobile-filter-toggle {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    width: 100%;
    padding: 0.7rem 1rem;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.12);
    color: var(--ks-text);
    font-size: 0.75rem;
    font-family: inherit;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    cursor: pointer;
    border-radius: 4px;
    margin-bottom: 0;
  }
  .ks-mobile-filter-toggle .ks-mft-arrow {
    margin-left: auto;
    display: inline-block;
    transition: transform 0.25s ease;
  }
  .ks-mobile-filter-toggle[aria-expanded="true"] .ks-mft-arrow { transform: rotate(180deg); }
  .ks-sidebar-inner {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.35s ease;
  }
  .ks-sidebar-inner.is-open { max-height: 3000px; }
  .ks-cat-accordion-title { display: none; }
  /* Loading overlay for product area on category nav */
  .ks-shop-content.ks-loading {
    position: relative;
    min-height: 300px;
  }
  .ks-shop-content.ks-loading::after {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--ks-bg, #0a0a0a);
    z-index: 5;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .ks-shop-content.ks-loading::before {
    content: '';
    position: absolute;
    top: 60px;
    left: 50%;
    transform: translateX(-50%);
    width: 32px;
    height: 32px;
    border: 2px solid rgba(255,255,255,0.1);
    border-top-color: var(--ks-accent);
    border-radius: 50%;
    animation: ks-spin 0.7s linear infinite;
    z-index: 6;
  }
  @keyframes ks-spin { to { transform: translateX(-50%) rotate(360deg); } }
}

@media (max-width: 480px) {
  .ks-product-grid--4,
  .ks-product-grid--3,
  .ks-product-grid--2 { grid-template-columns: 1fr 1fr; }
}

/* ─────────────────────────────────────────
   HOMEPAGE — Shop by Category
   ───────────────────────────────────────── */
.ks-categories .ks-cat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(0.75rem, 1.5vw, 1.5rem);
}

.ks-cat-card {
  position: relative;
  display: block;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: #111;
  border: 1px solid rgba(255, 255, 255, 0.06);
  text-decoration: none;
  isolation: isolate;
  transition: transform 0.5s cubic-bezier(.2,.7,.2,1), border-color 0.3s;
}

.ks-cat-card:hover {
  transform: translateY(-4px);
  border-color: var(--ks-accent, #f5d24a);
}

.ks-cat-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(0.2) contrast(1.05) brightness(0.7);
  transition: transform 0.8s cubic-bezier(.2,.7,.2,1), filter 0.4s;
  z-index: 1;
}
.ks-cat-card:hover .ks-cat-img {
  transform: scale(1.06);
  filter: grayscale(0) contrast(1.1) brightness(0.85);
}

.ks-cat-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 35%, rgba(0,0,0,0.85) 100%);
  z-index: 2;
}

.ks-cat-num {
  position: absolute;
  top: 1rem;
  left: 1.25rem;
  z-index: 3;
  font-family: var(--ks-font-display, 'Archivo Black', sans-serif);
  font-size: clamp(1rem, 1.4vw, 1.25rem);
  letter-spacing: 0.2em;
  color: rgba(255, 255, 255, 0.75);
  mix-blend-mode: difference;
}

.ks-cat-meta {
  position: absolute;
  left: 1.25rem;
  right: 1.25rem;
  bottom: 1rem;
  z-index: 3;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  color: #fff;
}

.ks-cat-count {
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--ks-accent, #f5d24a);
  font-weight: 600;
}

.ks-cat-name {
  font-family: var(--ks-font-display, 'Archivo Black', sans-serif);
  font-size: clamp(1.1rem, 1.6vw, 1.6rem);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  line-height: 1.05;
}

/* Placeholder when no thumbnail set */
.ks-cat-card:not(:has(.ks-cat-img)) {
  background:
    radial-gradient(circle at 20% 20%, rgba(245,210,74,0.18), transparent 55%),
    radial-gradient(circle at 80% 90%, rgba(245,210,74,0.08), transparent 60%),
    #0d0d0d;
}

/* ─────────────────────────────────────────
   HOMEPAGE — Feature Strip
   ───────────────────────────────────────── */
.ks-features {
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  padding-block: clamp(2.5rem, 5vw, 5rem);
}

.ks-feature-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 2.5rem);
}

.ks-feature {
  position: relative;
  padding: clamp(1.25rem, 1.8vw, 2rem) clamp(1rem, 1.5vw, 1.5rem);
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.02);
  transition: border-color 0.3s, transform 0.4s;
}

.ks-feature:hover {
  border-color: var(--ks-accent, #f5d24a);
  transform: translateY(-3px);
}

.ks-feature-num {
  display: inline-block;
  font-family: var(--ks-font-display, 'Archivo Black', sans-serif);
  font-size: 1rem;
  letter-spacing: 0.25em;
  color: var(--ks-accent, #f5d24a);
  margin-bottom: 0.75rem;
}

.ks-feature-title {
  margin: 0 0 0.5rem;
  font-family: var(--ks-font-display, 'Archivo Black', sans-serif);
  font-size: clamp(1rem, 1.3vw, 1.25rem);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #fff;
  line-height: 1.15;
}

.ks-feature-desc {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.65);
}

/* ─────────────────────────────────────────
   HOMEPAGE — responsive overrides
   ───────────────────────────────────────── */
@media (max-width: 1024px) {
  .ks-categories .ks-cat-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ks-feature-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 600px) {
  .ks-categories .ks-cat-grid { grid-template-columns: 1fr 1fr; gap: 0.5rem; }
  .ks-cat-card { aspect-ratio: 3 / 4; }
  .ks-cat-name { font-size: 1rem; }
  .ks-feature-grid { grid-template-columns: 1fr; }
}

/* ─────────────────────────────────────────
   HERO — background image variants
   --ks-hero-overlay set per-site via inline CSS (0..0.95).
   ───────────────────────────────────────── */
.ks-hero--has-bg {
  background-color: var(--ks-black);
}

.ks-hero--has-bg .ks-hero-bg-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}

.ks-hero--has-bg .ks-hero-inner,
.ks-hero--has-bg .ks-hero-deco-num {
  position: relative;
  z-index: 2;
}

/* Cinematic — gradient + accent glow */
.ks-hero--bg-cinematic .ks-hero-bg-overlay {
  background:
    radial-gradient(60% 80% at 80% 20%, var(--ks-accent-soft, rgba(201,164,73,0.18)), transparent 70%),
    linear-gradient(120deg,
      rgba(10,10,10, calc(var(--ks-hero-overlay, 0.65) + 0.15)) 0%,
      rgba(10,10,10, var(--ks-hero-overlay, 0.65)) 50%,
      rgba(10,10,10, calc(var(--ks-hero-overlay, 0.65) - 0.15)) 100%);
}

/* Vignette — dark on edges, lighter in center */
.ks-hero--bg-vignette .ks-hero-bg-overlay {
  background:
    radial-gradient(120% 100% at 50% 50%,
      rgba(10,10,10, calc(var(--ks-hero-overlay, 0.65) - 0.25)) 0%,
      rgba(10,10,10, var(--ks-hero-overlay, 0.65)) 60%,
      rgba(10,10,10, calc(var(--ks-hero-overlay, 0.65) + 0.2)) 100%);
}

/* Accent tint — duotone */
.ks-hero--bg-tint .ks-hero-bg-overlay {
  background:
    linear-gradient(135deg,
      var(--ks-accent-soft, rgba(201,164,73,0.18)) 0%,
      rgba(10,10,10, var(--ks-hero-overlay, 0.65)) 65%,
      rgba(10,10,10, calc(var(--ks-hero-overlay, 0.65) + 0.15)) 100%);
  mix-blend-mode: multiply;
}

/* Flat — straight black overlay */
.ks-hero--bg-flat .ks-hero-bg-overlay {
  background: rgba(10,10,10, var(--ks-hero-overlay, 0.65));
}

/* Subtle parallax-ish movement on supported browsers */
@media (min-width: 768px) {
  .ks-hero--has-bg {
    background-attachment: fixed;
  }
}

/* Make sure decorative number reads on imagery */
.ks-hero--has-bg .ks-hero-deco-num {
  -webkit-text-stroke: 1px rgba(255,255,255,0.18);
}

/* Sub copy stays readable on photo */
.ks-hero--has-bg .ks-hero-sub {
  color: rgba(245,245,240,0.85);
  text-shadow: 0 1px 12px rgba(0,0,0,0.5);
}

/* ── Featured Brands ─────────────────────────────────────── */
.ks-brands { background: linear-gradient(180deg, transparent, rgba(255,255,255,0.02) 50%, transparent); }
.ks-brand-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.25rem;
  margin-top: 2.5rem;
}
.ks-brand-card {
  position: relative;
  display: block;
  aspect-ratio: 3 / 4;
  border-radius: 6px;
  overflow: hidden;
  background: #111;
  border: 1px solid var(--ks-border);
  text-decoration: none;
  isolation: isolate;
  transition: transform var(--ks-transition), border-color var(--ks-transition);
}
.ks-brand-card:hover { transform: translateY(-4px); border-color: var(--ks-accent); }
.ks-brand-card-img {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
  transition: transform 0.6s ease;
  z-index: 0;
  filter: saturate(0.9) brightness(0.85);
}
.ks-brand-card:hover .ks-brand-card-img { transform: scale(1.08); filter: saturate(1) brightness(1); }
.ks-brand-card-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0.55) 60%, rgba(0,0,0,0.92) 100%);
  z-index: 1;
}
.ks-brand-card-body {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 1.25rem 1.4rem 1.4rem;
  display: flex; flex-direction: column; gap: 0.35rem;
  z-index: 2;
  color: var(--ks-white);
}
.ks-brand-card-name {
  font-family: var(--ks-font-display);
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  line-height: 1;
}
.ks-brand-card-tagline { color: var(--ks-muted); font-size: 0.82rem; }
.ks-brand-card-cta {
  margin-top: 0.6rem;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ks-accent);
  opacity: 0; transform: translateY(6px);
  transition: opacity var(--ks-transition), transform var(--ks-transition);
}
.ks-brand-card:hover .ks-brand-card-cta { opacity: 1; transform: translateY(0); }

@media (max-width: 1024px) { .ks-brand-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px)  { .ks-brand-grid { grid-template-columns: 1fr; } }

/* ── Testimonials Page ───────────────────────────────────── */
.ks-page-testimonials .ks-test-hero { padding-block: clamp(3rem, 6vw, 6rem) clamp(1rem, 3vw, 2rem); text-align: center; }
.ks-test-title {
  font-family: var(--ks-font-display);
  font-size: clamp(3rem, 8vw, 7rem);
  line-height: 0.9;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  margin: 0.5rem 0 1.25rem;
}
.ks-test-lede { color: var(--ks-muted); max-width: 56ch; margin: 0 auto; font-size: 1.05rem; }
.ks-test-stats {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem; margin-top: 3rem;
  border-top: 1px solid var(--ks-border);
  border-bottom: 1px solid var(--ks-border);
  padding-block: 1.5rem;
}
.ks-test-stats li { display: flex; flex-direction: column; gap: 0.25rem; align-items: center; text-align: center; }
.ks-test-stat-num { font-family: var(--ks-font-display); font-size: clamp(1.6rem, 3vw, 2.4rem); color: var(--ks-accent); letter-spacing: 0.02em; }
.ks-test-stat-num small { color: var(--ks-muted); font-size: 0.5em; margin-left: 0.1em; }
.ks-test-stat-label { font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ks-muted); }

.ks-test-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
  margin-top: 2rem;
}
.ks-test-card {
  position: relative;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--ks-border);
  border-radius: 6px;
  padding: 2rem 1.6rem 1.6rem;
  display: flex; flex-direction: column; gap: 1rem;
  transition: transform var(--ks-transition), border-color var(--ks-transition), background var(--ks-transition);
  overflow: hidden;
}
.ks-test-card::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(circle at top right, var(--ks-accent-soft), transparent 60%);
  opacity: 0; transition: opacity var(--ks-transition);
  pointer-events: none;
}
.ks-test-card:hover { transform: translateY(-3px); border-color: var(--ks-accent); background: rgba(255,255,255,0.04); }
.ks-test-card:hover::before { opacity: 1; }
.ks-test-quote-mark {
  position: absolute; top: -0.5rem; right: 1.2rem;
  font-family: var(--ks-font-display);
  font-size: 6rem; line-height: 1;
  color: var(--ks-accent); opacity: 0.18;
  pointer-events: none;
}
.ks-test-stars { color: var(--ks-accent); font-size: 1rem; letter-spacing: 0.1em; }
.ks-test-stars .ks-test-star--off { color: var(--ks-border); }
.ks-test-body {
  color: var(--ks-white); font-size: 0.98rem; line-height: 1.6;
  margin: 0; padding: 0;
  font-style: italic;
  flex: 1;
}
.ks-test-foot {
  display: flex; flex-direction: column; gap: 0.15rem;
  border-top: 1px solid var(--ks-border);
  padding-top: 0.85rem; margin-top: 0.5rem;
}
.ks-test-name { font-family: var(--ks-font-display); font-size: 1rem; letter-spacing: 0.04em; text-transform: uppercase; }
.ks-test-meta { font-size: 0.78rem; color: var(--ks-muted); }
.ks-test-product { font-size: 0.74rem; color: var(--ks-accent); letter-spacing: 0.12em; text-transform: uppercase; margin-top: 0.25rem; }

.ks-test-cta { padding-block: clamp(3rem, 6vw, 5rem); }
.ks-test-cta-inner {
  text-align: center;
  border: 1px solid var(--ks-border);
  border-radius: 8px;
  padding: clamp(2rem, 5vw, 4rem);
  background: linear-gradient(135deg, rgba(255,255,255,0.02), transparent);
}
.ks-test-cta-title { font-family: var(--ks-font-display); font-size: clamp(2rem, 5vw, 3.5rem); text-transform: uppercase; line-height: 0.95; margin-bottom: 0.75rem; }
.ks-test-cta-sub { color: var(--ks-muted); max-width: 50ch; margin: 0 auto 1.75rem; }
.ks-test-cta-actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

@media (max-width: 1024px) {
  .ks-test-grid  { grid-template-columns: repeat(2, 1fr); }
  .ks-test-stats { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .ks-test-grid  { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════
   ART DECO LUXURY ELEMENTS  (ported from gatsby-luxe)
══════════════════════════════════════════════════════════════ */

/* ── Gold Divider  ─  line ◆ line  ──────────────────────── */
.ks-divider {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  width: 200px;
  margin: 0 auto;
}
.ks-divider-line {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--ks-accent));
  opacity: 0.7;
}
.ks-divider-line:last-child {
  background: linear-gradient(270deg, transparent, var(--ks-accent));
  opacity: 0.7;
}
.ks-divider-diamond {
  width: 7px;
  height: 7px;
  background: var(--ks-accent);
  transform: rotate(45deg);
  flex-shrink: 0;
}

/* ── Hero — diamond-hatch background pattern ─────────────── */
.ks-hero--artdeco::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(
      45deg,
      rgba(255,255,255,0.018) 0, rgba(255,255,255,0.018) 1px,
      transparent 1px, transparent 36px
    ),
    repeating-linear-gradient(
      -45deg,
      rgba(255,255,255,0.018) 0, rgba(255,255,255,0.018) 1px,
      transparent 1px, transparent 36px
    );
  pointer-events: none;
  z-index: 0;
}

/* ── Hero — radial accent glow (sunburst) ────────────────── */
.ks-hero--artdeco::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 70% 55% at 50% 50%,
    rgba(var(--ks-accent-rgb, 79 124 255),.06) 0%,
    transparent 70%
  );
  pointer-events: none;
  z-index: 0;
}

/* Make hero children sit above patterns */
.ks-hero--artdeco .ks-hero-inner { position: relative; z-index: 1; }

/* ── Section header — centered italic serif style ─────────── */
.ks-section-header--centered {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1rem;
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 3rem;
}
.ks-section-header--centered .ks-section-title {
  font-style: italic;
  font-weight: 400;
  letter-spacing: 0.02em;
  text-transform: none;
  text-align: center;
  width: 100%;
  line-height: 1.2;
  font-size: clamp(1.5rem, 2.5vw, 2.2rem);
  padding-bottom: 0.4rem;
}
.ks-section-header--centered .ks-eyebrow {
  text-align: center;
  width: 100%;
  margin-bottom: 0;
}

/* ── Corner brackets on cards ────────────────────────────── */
.ks-product-card {
  /* ensure relative for corners */
  position: relative;
}
.ks-corner {
  position: absolute;
  width: 12px;
  height: 12px;
  border-color: var(--ks-accent);
  border-style: solid;
  pointer-events: none;
  transition: opacity 0.35s ease, width 0.35s ease, height 0.35s ease;
  opacity: 0;
  z-index: 3;
}
.ks-corner-tl { top: 6px;    left: 6px;   border-width: 1px 0 0 1px; }
.ks-corner-tr { top: 6px;    right: 6px;  border-width: 1px 1px 0 0; }
.ks-corner-bl { bottom: 6px; left: 6px;   border-width: 0 0 1px 1px; }
.ks-corner-br { bottom: 6px; right: 6px;  border-width: 0 1px 1px 0; }

.ks-product-card:hover .ks-corner {
  opacity: 1;
  width: 16px;
  height: 16px;
}

/* Refined card hover — glow instead of full invert ──────── */
.ks-product-card:hover {
  border-color: var(--ks-accent);
  box-shadow: 0 12px 40px rgba(0,0,0,0.55), 0 0 20px rgba(var(--ks-accent-rgb, 79 124 255),.15);
  transform: translateY(-4px);
}

/* ── "Add to Cart" reveal on hover (gatsby style) ────────── */
.ks-product-card .button {
  opacity: 0.6;
  transform: translateY(4px);
  transition: opacity 0.3s ease, transform 0.3s ease, background var(--ks-transition), color var(--ks-transition);
}
.ks-product-card:hover .button {
  opacity: 1;
  transform: translateY(0);
}

/* ── Art Deco diamond background on alternating sections ──── */
.ks-section--pattern {
  position: relative;
}
.ks-section--pattern::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(
      45deg,
      rgba(255,255,255,0.012) 0, rgba(255,255,255,0.012) 1px,
      transparent 1px, transparent 32px
    ),
    repeating-linear-gradient(
      -45deg,
      rgba(255,255,255,0.012) 0, rgba(255,255,255,0.012) 1px,
      transparent 1px, transparent 32px
    );
  pointer-events: none;
}

/* ── Brand Watch Slider ───────────────────────────────────── */
.ks-brand-slider-section {
  padding: 4rem 0;
  overflow: hidden;
}
.ks-brand-slider-section .ks-section-header--centered {
  margin-bottom: 2.5rem;
}
.ks-brand-slider-wrap {
  position: relative;
}
.ks-brand-slider {
  display: flex;
  gap: 1.2rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  padding: 0.5rem 2rem 1.5rem;
  cursor: grab;
}
.ks-brand-slider:active { cursor: grabbing; }
.ks-brand-slider::-webkit-scrollbar { height: 3px; }
.ks-brand-slider::-webkit-scrollbar-track { background: transparent; }
.ks-brand-slider::-webkit-scrollbar-thumb { background: var(--ks-accent); border-radius: 2px; }

/* Card */
.ks-bslide {
  flex: 0 0 260px;
  scroll-snap-align: start;
  aspect-ratio: 1/1;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 2px;
  background: #0d0d0d;
  transition: border-color 0.3s, transform 0.3s;
  text-decoration: none;
  color: inherit;
  display: block;
}
.ks-bslide:hover {
  border-color: var(--ks-accent);
  transform: translateY(-4px);
}
.ks-bslide-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 0.5s ease;
}
.ks-bslide:hover .ks-bslide-img { transform: scale(1.05); }

/* Gradient overlay */
.ks-bslide-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, transparent 35%, rgba(8,12,20,0.75) 100%);
  pointer-events: none;
  z-index: 1;
}
/* Accent glow top-right on hover */
.ks-bslide::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 80% 15%, rgba(var(--ks-accent-rgb),0.15), transparent 60%);
  opacity: 0;
  transition: opacity 0.4s;
  z-index: 2;
  pointer-events: none;
}
.ks-bslide:hover::before { opacity: 1; }

/* Logo badge — actual brand logo */
.ks-bslide-logo {
  position: absolute;
  top: 1rem;
  left: 1rem;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid rgba(255,255,255,0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px;
  z-index: 3;
  box-shadow: 0 2px 12px rgba(0,0,0,0.5);
  overflow: hidden;
  transition: transform 0.3s, box-shadow 0.3s;
}
.ks-bslide:hover .ks-bslide-logo {
  transform: scale(1.08);
  box-shadow: 0 4px 20px rgba(0,0,0,0.6);
}
.ks-bslide-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

/* Brand name label */
.ks-bslide-name {
  position: absolute;
  bottom: 1rem;
  left: 1rem;
  right: 1rem;
  z-index: 3;
  font-family: var(--ks-font-display);
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ks-white);
}
.ks-bslide-tagline {
  display: block;
  font-family: var(--ks-font-body);
  font-size: 0.68rem;
  font-weight: 400;
  letter-spacing: 0.1em;
  color: var(--ks-accent);
  margin-top: 0.2rem;
  text-transform: uppercase;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.3s, transform 0.3s;
}
.ks-bslide:hover .ks-bslide-tagline { opacity: 1; transform: translateY(0); }

/* Arrow buttons */
.ks-bslide-prev,
.ks-bslide-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 40px;
  height: 40px;
  background: rgba(10,10,10,0.85);
  border: 1px solid var(--ks-accent);
  color: var(--ks-accent);
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  transition: background 0.2s, color 0.2s;
  line-height: 1;
  padding: 0;
}
.ks-bslide-prev { left: 0.25rem; }
.ks-bslide-next { right: 0.25rem; }
.ks-bslide-prev:hover,
.ks-bslide-next:hover { background: var(--ks-accent); color: var(--ks-black); }

/* ═══════════════════════════════════════
   SPINNING CIRCULAR BADGE
═══════════════════════════════════════ */
.ks-spin-badge {
  position: relative;
  width: 100px;
  height: 100px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
  flex-shrink: 0;
  margin-left: 0.5rem;
}
.ks-spin-badge-ring {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  animation: ks-spin-badge-rotate 12s linear infinite;
}
@keyframes ks-spin-badge-rotate {
  to { transform: rotate(360deg); }
}
.ks-spin-badge-text {
  font-family: var(--ks-font-display);
  font-size: 8.5px;
  font-weight: 500;
  letter-spacing: 0.18em;
  fill: rgba(var(--ks-accent-rgb), 0.7);
}
.ks-spin-badge-icon {
  position: relative;
  z-index: 1;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ks-accent);
  border: 1px solid rgba(var(--ks-accent-rgb), 0.35);
  border-radius: 50%;
  background: rgba(var(--ks-accent-rgb), 0.05);
  backdrop-filter: blur(4px);
}
.ks-spin-badge-icon svg {
  width: 16px;
  height: 16px;
}
.ks-spin-badge:hover .ks-spin-badge-ring {
  animation-duration: 4s;
}

/* ═══════════════════════════════════════
   HERO MOVEMENT DIAGRAM
═══════════════════════════════════════ */
.ks-movement-diagram {
  position: relative;
  width: clamp(260px, 38vw, 460px);
  aspect-ratio: 1 / 1;
  margin: 0 auto;
}
#ks-movement-svg {
  width: 100%;
  height: 100%;
  overflow: visible;
}
.ks-movement-caption {
  text-align: center;
  font-family: var(--ks-font-display);
  font-size: 0.6rem;
  letter-spacing: 0.24em;
  color: rgba(var(--ks-accent-rgb), 0.35);
  margin-top: 0.6rem;
  text-transform: uppercase;
}

/* ── Bezel & rings ── */
.ks-mv-bezel {
  fill: none;
  stroke: rgba(var(--ks-accent-rgb), 0.3);
  stroke-width: 1.5;
}
.ks-mv-bezel-inner {
  fill: none;
  stroke: rgba(var(--ks-accent-rgb), 0.1);
  stroke-width: 0.7;
}
.ks-mv-guide {
  fill: none;
  stroke: rgba(var(--ks-accent-rgb), 0.07);
  stroke-width: 0.7;
  stroke-dasharray: 3 6;
}
.ks-mv-connector {
  stroke: rgba(var(--ks-accent-rgb), 0.1);
  stroke-width: 0.6;
}
.ks-mv-connector--dash {
  stroke-dasharray: 3 5;
  stroke: rgba(var(--ks-accent-rgb), 0.07);
}

/* ── Gear tooth paths ── */
.ks-mv-gear {
  fill: none;
  stroke: var(--ks-accent);
  stroke-width: 1.1;
  stroke-linejoin: round;
  opacity: 0.75;
}

/* ── Hub elements ── */
.ks-mv-hub-ring {
  fill: none;
  stroke: rgba(var(--ks-accent-rgb), 0.22);
  stroke-width: 0.7;
}
.ks-mv-hub-center {
  fill: rgba(var(--ks-accent-rgb), 0.05);
  stroke: rgba(var(--ks-accent-rgb), 0.35);
  stroke-width: 0.9;
}
.ks-mv-spoke {
  stroke: rgba(var(--ks-accent-rgb), 0.22);
  stroke-width: 0.7;
}
.ks-mv-jewel {
  fill: #c8526a;
  opacity: 0.85;
}

/* ── Balance wheel ── */
.ks-mv-balance-rim {
  fill: none;
  stroke: var(--ks-accent);
  stroke-width: 1.4;
  opacity: 0.65;
}
.ks-mv-balance-rim-inner {
  fill: none;
  stroke: rgba(var(--ks-accent-rgb), 0.22);
  stroke-width: 0.6;
}
.ks-mv-mass {
  fill: var(--ks-accent);
  opacity: 0.65;
}
.ks-mv-hairspring-path {
  fill: none;
  stroke: rgba(var(--ks-accent-rgb), 0.4);
  stroke-width: 0.65;
}

/* ── Seconds hand ── */
.ks-mv-hand-body {
  fill: var(--ks-accent);
  opacity: 0.9;
}
.ks-mv-hand-tail {
  fill: rgba(var(--ks-accent-rgb), 0.45);
}
.ks-mv-hand-cap {
  fill: var(--ks-bg);
  stroke: var(--ks-accent);
  stroke-width: 1.4;
}

/* ── Labels ── */
.ks-mv-lbl {
  font-family: var(--ks-font-display);
  font-size: 7.5px;
  font-weight: 500;
  letter-spacing: 0.14em;
  fill: rgba(var(--ks-accent-rgb), 0.5);
}
.ks-mv-lbl-sm {
  font-family: var(--ks-font-display);
  font-size: 6px;
  letter-spacing: 0.12em;
  fill: rgba(var(--ks-accent-rgb), 0.3);
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .ks-movement-diagram { opacity: 0.6; }
}

@media (max-width: 768px) {
  .ks-bslide { flex: 0 0 200px; }
  .ks-bslide-logo { width: 48px; height: 48px; }
  .ks-bslide-prev, .ks-bslide-next { display: none; }
}
