/* =========================================================
   CPS eShop — v12.1 — CLEANED & CONSOLIDATED
   ──────────────────────────────────────────────────────
   Modern Sunshine Theme + YELLOW BRAND #FFC107
   - FULL-WIDTH layout with inner content containers
   - Oswald + Inter + Cairo/Tajawal fonts
   - 35+ animation keyframes for rich micro-interactions
   - Premium product cards (v14 — square images, refined)
   - Modern yellow gradient buttons with soft shadows
   - Dark mode support (html[data-theme="dark"]) — OPT-IN
   - Share buttons, mobile filter toggle, scroll progress
   - Search autocomplete, comparison tray
   - Scroll reveal animations with stagger
   - RTL friendly | Bootstrap 4 (Frappe v14)
   - CLEANED: Removed ~2400 lines of duplicate CSS
   ========================================================= */

/* ── Google Fonts ──────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Inter:wght@300;400;500;600;700;800;900&family=Cairo:wght@400;500;600;700;800;900&family=Tajawal:wght@400;500;700;800;900&display=swap');

/* ═══════════════════════════════════════════════════════
   ANIMATION KEYFRAMES — 35+ Animations
   ═══════════════════════════════════════════════════════ */
@keyframes kimoFadeIn { from { opacity: 0 } to { opacity: 1 } }
@keyframes kimoFadeInUp { from { opacity: 0; transform: translateY(40px) } to { opacity: 1; transform: translateY(0) } }
@keyframes kimoFadeInDown { from { opacity: 0; transform: translateY(-24px) } to { opacity: 1; transform: translateY(0) } }
@keyframes kimoFadeInScale { from { opacity: 0; transform: scale(.85) } to { opacity: 1; transform: scale(1) } }
@keyframes kimoSlideInLeft { from { opacity: 0; transform: translateX(-50px) } to { opacity: 1; transform: translateX(0) } }
@keyframes kimoSlideInRight { from { opacity: 0; transform: translateX(50px) } to { opacity: 1; transform: translateX(0) } }
@keyframes kimoPulse { 0%, 100% { transform: scale(1) } 50% { transform: scale(1.06) } }
@keyframes kimoShimmer { 0% { background-position: -200% 0 } 100% { background-position: 200% 0 } }
@keyframes kimoFloat { 0%, 100% { transform: translateY(0) } 50% { transform: translateY(-10px) } }
@keyframes kimoRipple { to { transform: scale(4); opacity: 0 } }
@keyframes kimoSpin { from { transform: rotate(0deg) } to { transform: rotate(360deg) } }
@keyframes kimoHeartbeat { 0%, 100% { transform: scale(1) } 14% { transform: scale(1.25) } 28% { transform: scale(1) } 42% { transform: scale(1.18) } 70% { transform: scale(1) } }
@keyframes kimoBounceIn { 0% { opacity: 0; transform: scale(.3) } 50% { transform: scale(1.08) } 70% { transform: scale(.96) } 100% { opacity: 1; transform: scale(1) } }
@keyframes kimoSlideUp { from { opacity: 0; transform: translateY(60px) } to { opacity: 1; transform: translateY(0) } }
@keyframes kimoToastIn { from { opacity: 0; transform: translateX(100%) } to { opacity: 1; transform: translateX(0) } }
@keyframes kimoToastOut { from { opacity: 1; transform: translateX(0) } to { opacity: 0; transform: translateX(100%) } }
@keyframes kimoDotPulse { 0%, 100% { opacity: .3; transform: scale(.8) } 50% { opacity: 1; transform: scale(1.2) } }
@keyframes kimoShake { 0%, 100% { transform: translateX(0) } 10%, 30%, 50%, 70%, 90% { transform: translateX(-4px) } 20%, 40%, 60%, 80% { transform: translateX(4px) } }
@keyframes kimoGlow { 0%, 100% { box-shadow: 0 0 20px rgba(255, 193, 7, .15) } 50% { box-shadow: 0 0 40px rgba(255, 193, 7, .30) } }
@keyframes kimoTextReveal { from { clip-path: inset(0 100% 0 0) } to { clip-path: inset(0 0 0 0) } }
@keyframes kimoScaleReveal { from { transform: scaleX(0); transform-origin: left } to { transform: scaleX(1); transform-origin: left } }
@keyframes kimoGradient { 0% { background-position: 0% 50% } 50% { background-position: 100% 50% } 100% { background-position: 0% 50% } }
@keyframes kimoOrbFloat1 { 0%, 100% { transform: translate(0, 0) scale(1) } 25% { transform: translate(30px, -20px) scale(1.05) } 50% { transform: translate(-10px, 30px) scale(.95) } 75% { transform: translate(-30px, -10px) scale(1.02) } }
@keyframes kimoOrbFloat2 { 0%, 100% { transform: translate(0, 0) scale(1) } 25% { transform: translate(-20px, 30px) scale(.95) } 50% { transform: translate(30px, -10px) scale(1.05) } 75% { transform: translate(10px, 20px) scale(.98) } }
@keyframes kimoMarquee { from { transform: translateX(0) } to { transform: translateX(-50%) } }
@keyframes kimoBorderGlow { 0%, 100% { border-color: rgba(255, 193, 7, .20); box-shadow: 0 0 10px rgba(255, 193, 7, .03) } 50% { border-color: rgba(255, 193, 7, .40); box-shadow: 0 0 20px rgba(255, 193, 7, .08) } }
@keyframes kimoYellowPulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(255, 193, 7, .3) } 50% { box-shadow: 0 0 0 10px rgba(255, 193, 7, 0) } }
@keyframes kimoScaleIn { from { opacity: 0; transform: scale(.92) } to { opacity: 1; transform: scale(1) } }
@keyframes kimoYellowShine { 0% { left: -100% } 100% { left: 200% } }
@keyframes kimoWipeFill { from { transform: scaleX(0); transform-origin: left } to { transform: scaleX(1); transform-origin: left } }
@keyframes kimoNeonFlicker { 0%, 100% { opacity: 1 } 42% { opacity: .8 } 43% { opacity: 1 } 45% { opacity: .3 } 46% { opacity: 1 } }
@keyframes kimoSlideDown { from { opacity: 0; transform: translateY(-10px) } to { opacity: 1; transform: translateY(0) } }
@keyframes kimoSlideUpStagger { from { opacity: 0; transform: translateY(30px) } to { opacity: 1; transform: translateY(0) } }
@keyframes kimoZoomOut { from { transform: scale(1.15); opacity: 0 } to { transform: scale(1); opacity: 1 } }
@keyframes kimoWiggle { 0%, 100% { transform: rotate(0) } 25% { transform: rotate(-3deg) } 75% { transform: rotate(3deg) } }
@keyframes kimo404Float { 0%, 100% { transform: translateY(0) rotate(0deg) } 25% { transform: translateY(-20px) rotate(2deg) } 50% { transform: translateY(-10px) rotate(-1deg) } 75% { transform: translateY(-25px) rotate(1deg) } }
@keyframes kimo404Pulse { 0%, 100% { text-shadow: 0 0 20px rgba(255, 193, 7, .2) } 50% { text-shadow: 0 0 60px rgba(255, 193, 7, .5), 0 0 100px rgba(255, 193, 7, .2) } }
@keyframes kimoSearchSpinner { to { transform: rotate(360deg) } }
@keyframes kimoSlideOverlay { from { opacity: 0; transform: translateY(100%) } to { opacity: 1; transform: translateY(0) } }
@keyframes kimoStarFill { from { width: 0 } to { width: var(--fill) } }

/* ═══════════════════════════════════════════════════════
   CSS VARIABLES — Design Token System v10.0
   MODERN LIGHT THEME with YELLOW ACCENT
   ═══════════════════════════════════════════════════════ */
:root {
  /* Yellow Accent System — BRAND COLOR DOMINANT */
  --kimo-primary: var(--cps-primary, #FFC107);
  --kimo-primary-dark: var(--cps-primary-dark, #F59E0B);
  --kimo-primary-light: var(--cps-primary-light, #FFD54F);
  --kimo-secondary: var(--cps-secondary, #FFD700);
  --kimo-accent: var(--cps-accent, #FFC107);
  --kimo-accent-light: var(--cps-accent-light, #FFF3CD);
  --kimo-accent-glow: rgba(255, 193, 7, .15);
  --kimo-accent-glow-strong: rgba(255, 193, 7, .30);
  --kimo-gold: #FFD700;
  --kimo-gold-light: #FFEB99;
  --kimo-yellow-soft: rgba(255, 193, 7, .06);
  --kimo-yellow-mid: rgba(255, 193, 7, .10);
  --kimo-yellow-strong: rgba(255, 193, 7, .18);
  --kimo-yellow-intense: rgba(255, 193, 7, .30);

  /* Light Backgrounds — Pure White & Clean */
  --kimo-bg: var(--cps-bg, #FFFFFF);
  --kimo-bg-alt: #FFFFFF;
  --kimo-bg-darker: #FAFAFA;
  --kimo-surface: var(--cps-surface, #FFFFFF);
  --kimo-surface-elevated: #FFFFFF;
  --kimo-surface-card: #FFFFFF;

  /* Text — Deep Navy/Dark for readability */
  --kimo-text: var(--cps-text, #1A1A2E);
  --kimo-text-secondary: #4A4A5A;
  --kimo-muted: var(--cps-muted, #8E8E9A);
  --kimo-muted-gray: #9CA3AF;
  --kimo-text-faint: #B0B0BA;

  /* Borders — Soft and subtle */
  --kimo-border: var(--cps-border, #E8E8E8);
  --kimo-border-strong: #D0D0D0;

  /* Shadows — Soft modern shadows */
  --kimo-shadow: var(--cps-shadow, 0 4px 20px rgba(0, 0, 0, .06));
  --kimo-shadow-deep: 0 12px 40px rgba(0, 0, 0, .10);
  --kimo-shadow-glow: 0 4px 20px rgba(255, 193, 7, .10);
  --kimo-shadow-glow-strong: 0 8px 30px rgba(255, 193, 7, .20);
  --kimo-hard-shadow: 4px 4px 0px 0px rgba(0, 0, 0, .06);
  --kimo-hard-shadow-accent: 4px 4px 0px 0px rgba(255, 193, 7, .25);

  /* Status */
  --kimo-success: var(--cps-success, #22C55E);
  --kimo-danger: var(--cps-danger, #EF4444);
  --kimo-whatsapp: #25D366;

  /* Link/Focus */
  --kimo-link: var(--cps-link, var(--kimo-primary-dark));
  --kimo-focus: var(--cps-focus, var(--kimo-accent));

  /* Header */
  --kimo-header-bg: var(--cps-header-bg, rgba(255, 255, 255, .95));
  --kimo-header-text: var(--cps-header-text, #1A1A2E);
  --kimo-topbar-bg: var(--cps-topbar-bg, var(--kimo-primary));
  --kimo-topbar-text: var(--cps-topbar-text, #1A1A2E);

  /* Footer — Light theme with yellow accent */
  --kimo-footer-bg: var(--cps-footer-bg, #FFFDF5);
  --kimo-footer-surface: var(--cps-footer-surface, #FFF9E6);
  --kimo-footer-text: var(--cps-footer-text, #1A1A2E);
  --kimo-footer-muted: var(--cps-footer-muted, #6B7280);
  --kimo-footer-border: var(--cps-footer-border, rgba(255,193,7,.15));

  /* Radii */
  --kimo-radius: var(--cps-card-radius, 16px);
  --kimo-button-radius: var(--cps-button-radius, 12px);
  --kimo-input-radius: var(--cps-input-radius, 12px);

  /* Typography */
  --kimo-font-heading: 'Oswald', 'Cairo', 'Tajawal', system-ui, sans-serif;
  --kimo-font-body: 'Inter', 'Cairo', 'Tajawal', system-ui, -apple-system, sans-serif;

  /* Animation Tokens */
  --kimo-ease-out-expo: cubic-bezier(.16, 1, .3, 1);
  --kimo-ease-spring: cubic-bezier(.34, 1.56, .64, 1);
  --kimo-ease-smooth: cubic-bezier(.4, 0, .2, 1);
  --kimo-ease-bounce: cubic-bezier(.68, -.55, .27, 1.55);
  --kimo-duration-fast: .15s;
  --kimo-duration-normal: .3s;
  --kimo-duration-slow: .5s;
  --kimo-duration-slower: .7s;
  --kimo-duration-slowest: 1s;
}

/* ═══════════════════════════════════════════════════════
   BASE BODY STYLES
   ═══════════════════════════════════════════════════════ */
html, body {
  background: var(--kimo-bg);
  color: var(--kimo-text);
  scroll-behavior: smooth;
}

body.cps-eshop {
  font-family: var(--kimo-font-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-weight: 600;
  line-height: 1.6;
  overflow-x: hidden;
  position: relative;
}

/* ── Utility Classes ───────────────────────────────────── */
.kimo-muted { color: var(--kimo-muted); }

/* ── Subtle dot pattern overlay (disabled for pure white) ─── */
body.cps-eshop::after {
  display: none;
}

/* ── Headings ─────────────────────────────────────────── */
body.cps-eshop h1, body.cps-eshop h2, body.cps-eshop h3,
body.cps-eshop h4, body.cps-eshop h5, body.cps-eshop h6 {
  font-family: var(--kimo-font-heading);
  text-transform: uppercase;
  letter-spacing: -.02em;
  line-height: 1.1;
}

/* ── Gradient Text Utility ──────────────────────────── */
.kimo-gradient-text {
  background: linear-gradient(135deg, var(--kimo-accent), var(--kimo-primary-dark), var(--kimo-accent-light));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* ── Decorative Blur Orbs ───────────────────────────── */
.kimo-orb { position: absolute; border-radius: 50%; filter: blur(120px); pointer-events: none; z-index: 0; }
.kimo-orb-1 { width: 500px; height: 500px; background: radial-gradient(circle, rgba(255, 193, 7, .06), transparent 70%); animation: kimoOrbFloat1 20s ease-in-out infinite; }
.kimo-orb-2 { width: 400px; height: 400px; background: radial-gradient(circle, rgba(255, 215, 0, .04), transparent 70%); animation: kimoOrbFloat2 25s ease-in-out infinite; }

/* ── RTL ──────────────────────────────────────────────── */
body.cps-eshop.rtl { direction: rtl; }
body.cps-eshop.rtl .kimo-actions-row { flex-direction: row-reverse; }
body.cps-eshop.rtl .kimo-price del { margin-left: 0; margin-right: 10px; }
body.cps-eshop.rtl h1, body.cps-eshop.rtl h2, body.cps-eshop.rtl h3 { font-family: 'Cairo', 'Tajawal', var(--kimo-font-heading); }
body.cps-eshop.rtl .kimo-nav-link::after { left: auto; right: 50%; transform: translateX(50%); }
body.cps-eshop.rtl .kimo-footer a:hover { transform: translateX(-6px); }
body.cps-eshop.rtl .kimo-footer-title::after { left: auto; right: 0; }
body.cps-eshop.rtl .kimo-mitem:hover { transform: translateX(-6px); }

/* ═══════════════════════════════════════════════════════
   LAYOUT SYSTEM — FULL-WIDTH + INNER CONTAINERS
   ═══════════════════════════════════════════════════════ */
.kimo-fullbleed {
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  overflow: hidden;
}

.kimo-inner {
  max-width: 1800px;
  margin: 0 auto;
  padding-left: clamp(16px, 3vw, 48px);
  padding-right: clamp(16px, 3vw, 48px);
  position: relative;
  z-index: 1;
}

.kimo-inner-wide {
  max-width: 1920px;
  margin: 0 auto;
  padding-left: clamp(16px, 3vw, 48px);
  padding-right: clamp(16px, 3vw, 48px);
}

.kimo-wrap {
  max-width: 1800px;
  margin: 0 auto;
  padding-left: clamp(16px, 3vw, 48px);
  padding-right: clamp(16px, 3vw, 48px);
}

/* ═══════════════════════════════════════════════════════
   MARQUEE TICKER — Yellow gradient accent strip
   ═══════════════════════════════════════════════════════ */
.kimo-marquee-strip {
  background: linear-gradient(90deg, var(--kimo-primary-dark), var(--kimo-accent), var(--kimo-gold), var(--kimo-accent), var(--kimo-primary-dark));
  background-size: 200% 100%;
  animation: kimoGradient 4s ease infinite;
  color: #1A1A2E;
  overflow: hidden;
  white-space: nowrap;
  font-family: var(--kimo-font-heading);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 10px 0;
  position: relative;
  border-bottom: 2px solid rgba(255, 193, 7, .2);
}
.kimo-marquee-track {
  display: inline-flex;
  animation: kimoMarquee 25s linear infinite;
}
.kimo-marquee-track span {
  padding: 0 40px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* ═══════════════════════════════════════════════════════
   HEADER — Modern Clean Glass + Yellow Accent
   ═══════════════════════════════════════════════════════ */
.kimo-header {
  position: sticky;
  top: 0;
  z-index: 2000;
  background: var(--kimo-header-bg);
  backdrop-filter: blur(40px) saturate(200%);
  -webkit-backdrop-filter: blur(40px) saturate(200%);
  color: var(--kimo-header-text);
  transition: all var(--kimo-duration-slow) var(--kimo-ease-smooth);
  border-bottom: 1px solid rgba(0, 0, 0, .06);
}
.kimo-header::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--kimo-accent), var(--kimo-gold), var(--kimo-accent), transparent);
  opacity: .4;
  transition: opacity var(--kimo-duration-normal);
}
.kimo-header:hover::after { opacity: .7; }
.kimo-header.kimo-header-scrolled {
  box-shadow: 0 4px 30px rgba(0, 0, 0, .08), 0 0 20px rgba(255, 193, 7, .04);
  background: rgba(255, 255, 255, .98);
  border-bottom-color: rgba(255, 193, 7, .15);
}
.kimo-header.kimo-header-scrolled::after { opacity: .8; }

/* ── Topbar / Announcement bar ──────────────────────── */
.kimo-topbar {
  background: linear-gradient(90deg, var(--kimo-primary-dark), var(--kimo-accent), var(--kimo-gold), var(--kimo-accent), var(--kimo-primary-dark));
  background-size: 200% 100%;
  animation: kimoGradient 6s ease infinite;
  color: #1A1A2E;
  font-family: var(--kimo-font-heading);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  position: relative;
  overflow: hidden;
}
.kimo-topbar .kimo-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-top: 6px;
  padding-bottom: 6px;
}
.kimo-topbar a { color: #1A1A2E; text-decoration: none; font-weight: 800; transition: all var(--kimo-duration-fast); }
.kimo-topbar a:hover { text-decoration: underline; }
.kimo-topbar-left, .kimo-topbar-right { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }

/* ── Pill badge ────────────────────────────────────────── */
.kimo-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: var(--kimo-button-radius);
  background: var(--kimo-accent-light);
  border: 1px solid rgba(255, 193, 7, .20);
  transition: all var(--kimo-duration-fast) var(--kimo-ease-smooth);
  color: var(--kimo-primary-dark);
  font-weight: 700;
  font-size: 13px;
  text-decoration: none;
}
.kimo-pill:hover {
  background: rgba(255, 193, 7, .25);
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(255, 193, 7, .15);
  color: var(--kimo-primary-dark);
}

/* ── Main bar ──────────────────────────────────────────── */
.kimo-mainbar .kimo-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-top: 14px;
  padding-bottom: 14px;
}

/* ── Brand / Logo ─────────────────────────────────────── */
.kimo-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  color: var(--kimo-text);
  min-width: 160px;
  transition: transform var(--kimo-duration-fast) var(--kimo-ease-spring);
}
.kimo-brand:hover { transform: scale(1.02); }
.kimo-brand img {
  height: 52px;
  width: auto;
  object-fit: contain;
  transition: transform var(--kimo-duration-normal) var(--kimo-ease-smooth);
}
.kimo-brand:hover img { transform: rotate(-2deg) scale(1.08); }
.kimo-brand .kimo-brand-text { display: flex; flex-direction: column; line-height: 1.05; }
.kimo-brand .kimo-brand-text strong {
  font-family: var(--kimo-font-heading);
  font-weight: 700;
  font-size: 22px;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--kimo-text);
}
.kimo-brand .kimo-brand-text span {
  font-weight: 700;
  font-size: 11px;
  color: var(--kimo-primary-dark);
  letter-spacing: 1.5px;
  text-transform: uppercase;
}

/* ── Search ────────────────────────────────────────────── */
.kimo-search { flex: 1; max-width: 680px; position: relative; }
.kimo-search input {
  width: 100%;
  height: 48px;
  border-radius: 999px;
  border: 1px solid #E2E2E2;
  padding: 0 52px 0 22px;
  background: #FFFFFF;
  font-weight: 600;
  font-size: 14px;
  color: var(--kimo-text);
  transition: all var(--kimo-duration-normal) var(--kimo-ease-smooth);
  box-shadow: 0 2px 8px rgba(0, 0, 0, .03);
}
.kimo-search input::placeholder { color: #B0B0BA; }
.kimo-search input:focus {
  border-color: var(--kimo-accent);
  box-shadow: 0 0 0 4px rgba(255, 193, 7, .10), 0 4px 16px rgba(0, 0, 0, .06);
  background: #FFFFFF;
}
.kimo-search button {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  border: none;
  background: var(--kimo-accent);
  color: #1A1A2E;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  font-weight: 900;
  font-size: 14px;
  cursor: pointer;
  transition: all var(--kimo-duration-fast) var(--kimo-ease-smooth);
  box-shadow: 0 2px 10px rgba(255, 193, 7, .25);
}
.kimo-search button:hover {
  transform: translateY(-50%) scale(1.12);
  box-shadow: 0 4px 16px rgba(255, 193, 7, .35);
}
.kimo-search button:active { transform: translateY(-50%) scale(.95); }
/* ── Search Autocomplete Dropdown ──────────────────────── */
.kimo-search-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  margin-top: 8px;
  background: rgba(255, 255, 255, .98);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid #EAEAEA;
  border-radius: 16px;
  max-height: 360px;
  overflow-y: auto;
  box-shadow: 0 12px 50px rgba(0, 0, 0, .10), 0 0 20px rgba(255, 193, 7, .04);
  z-index: 100;
  scrollbar-width: thin;
}
.kimo-search-dropdown::-webkit-scrollbar { width: 4px; }
.kimo-search-dropdown::-webkit-scrollbar-thumb { background: rgba(255, 193, 7, .20); border-radius: 999px; }
.kimo-search-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 18px;
  text-decoration: none;
  color: var(--kimo-text);
  transition: all .15s ease;
  border-bottom: 1px solid #F5F5F5;
}
.kimo-search-item:last-child { border-bottom: none; }
.kimo-search-item:hover {
  background: #FFF9E6;
  color: var(--kimo-primary-dark);
}
.kimo-search-item img {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  object-fit: cover;
  flex-shrink: 0;
}
.kimo-search-item-info { min-width: 0; }
.kimo-search-item-name {
  font-weight: 700;
  font-size: 13px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.kimo-search-item-price {
  font-weight: 800;
  font-size: 12px;
  color: var(--kimo-primary-dark);
}
.kimo-search-item-all {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 14px;
  font-weight: 800;
  font-size: 13px;
  color: var(--kimo-primary-dark);
  text-decoration: none;
  border-top: 1px solid #F0F0F0;
  transition: background .15s ease;
}
.kimo-search-item-all:hover {
  background: #FFF9E6;
}
html[dir="rtl"] .kimo-search input { padding: 0 22px 0 52px; }
html[dir="rtl"] .kimo-search button { right: auto; left: 8px; }

/* ── Action buttons ────────────────────────────────────── */
.kimo-actions { display: flex; align-items: center; gap: 6px; }
.kimo-icbtn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid #E8E8E8;
  background: #FFFFFF;
  text-decoration: none;
  color: var(--kimo-text);
  font-size: 18px;
  transition: all var(--kimo-duration-fast) var(--kimo-ease-smooth);
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(0, 0, 0, .04);
}
.kimo-icbtn:hover {
  background: #FFF9E6;
  box-shadow: 0 4px 16px rgba(255, 193, 7, .15);
  transform: translateY(-3px) scale(1.05);
  border-color: var(--kimo-accent);
  color: var(--kimo-primary-dark);
}
.kimo-icbtn:active { transform: translateY(0) scale(.95); }

/* ── Badge ─────────────────────────────────────────────── */
.kimo-badge {
  position: absolute;
  top: -5px;
  right: -5px;
  min-width: 20px;
  height: 20px;
  padding: 0 5px;
  border-radius: 999px;
  background: var(--kimo-accent);
  color: #1A1A2E;
  font-size: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  border: 2px solid #FFFFFF;
  animation: kimoBounceIn .4s var(--kimo-ease-spring);
  transition: transform var(--kimo-duration-fast) var(--kimo-ease-spring);
  box-shadow: 0 2px 8px rgba(255, 193, 7, .35);
}
.kimo-badge:hover { transform: scale(1.2); }

/* ── Nav categories bar ────────────────────────────────── */
.kimo-nav {
  border-top: 1px solid #F0F0F0;
  background: rgba(255, 255, 255, .80);
}
.kimo-nav .kimo-wrap {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 2px;
  width: 100%;
  max-width: none;
}
.kimo-nav-list {
  display: flex;
  align-items: center;
  gap: 2px;
  width: 100%;
  margin: 0;
  padding: 8px 0;
  list-style: none;
  overflow: auto hidden;
  scrollbar-width: thin;
}
.kimo-nav-list::-webkit-scrollbar { height: 2px; }
.kimo-nav-list::-webkit-scrollbar-thumb { background: rgba(255, 193, 7, .2); border-radius: 999px; }

.kimo-nav-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 38px;
  padding: 6px 16px;
  border-radius: 8px;
  text-decoration: none;
  color: #6B7280;
  font-family: var(--kimo-font-heading);
  font-weight: 600;
  font-size: 13px;
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: .8px;
  transition: all var(--kimo-duration-fast) var(--kimo-ease-smooth);
  position: relative;
}
.kimo-nav-link:hover {
  color: var(--kimo-primary-dark);
  background: var(--kimo-yellow-soft);
  transform: translateY(-1px);
}
.kimo-nav-link::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: 50%;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--kimo-accent), var(--kimo-gold));
  border-radius: 999px;
  transition: all var(--kimo-duration-normal) var(--kimo-ease-out-expo);
  transform: translateX(-50%);
}
.kimo-nav-link:hover::after { width: 60%; }
.kimo-nav-link.kimo-hot {
  background: var(--kimo-yellow-mid);
  color: var(--kimo-primary-dark);
  border: 1px solid var(--kimo-yellow-strong);
  animation: kimoYellowPulse 2.5s infinite;
}
.kimo-nav-link.kimo-hot::after { background: var(--kimo-accent); }

/* ── Mega menu ─────────────────────────────────────────── */
.kimo-mega {
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  background: rgba(255, 255, 255, .98);
  backdrop-filter: blur(40px) saturate(200%);
  -webkit-backdrop-filter: blur(40px) saturate(200%);
  border-top: 2px solid var(--kimo-accent);
  box-shadow: 0 20px 60px rgba(0, 0, 0, .10), 0 0 20px rgba(255, 193, 7, .04);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: all var(--kimo-duration-normal) var(--kimo-ease-out-expo);
}
.kimo-nav-item { position: relative; }
.kimo-nav-item:hover .kimo-mega { opacity: 1; visibility: visible; transform: translateY(0); }
.kimo-mega-inner { max-width: 1400px; margin: 0 auto; padding: 28px 48px; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 20px; }
.kimo-mega h6 { margin: 0 0 14px; font-weight: 700; color: var(--kimo-primary-dark); text-transform: uppercase; letter-spacing: 1.5px; font-size: 12px; }
.kimo-mega a { display: block; padding: 10px 14px; border-radius: 10px; text-decoration: none; color: #4A4A5A; font-weight: 600; transition: all var(--kimo-duration-fast); }
.kimo-mega a:hover { background: var(--kimo-yellow-soft); color: var(--kimo-primary-dark); transform: translateX(6px); }

/* ── Mobile menu ───────────────────────────────────────── */
.kimo-mtoggle { display: none; }
.kimo-mobile {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(255, 255, 255, .98);
  backdrop-filter: blur(40px);
  -webkit-backdrop-filter: blur(40px);
  z-index: 3000;
  overflow: auto;
  animation: kimoFadeIn var(--kimo-duration-normal) var(--kimo-ease-smooth);
}
.kimo-mobile.kimo-mobile-open { display: block; }
.kimo-mobile-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid #EAEAEA;
}
.kimo-mobile-close {
  border: 1px solid #E2E2E2;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: #FFFFFF;
  color: var(--kimo-text);
  font-size: 22px;
  cursor: pointer;
  transition: all var(--kimo-duration-fast) var(--kimo-ease-smooth);
}
.kimo-mobile-close:hover {
  background: #FFF9E6;
  transform: rotate(90deg);
  color: var(--kimo-primary-dark);
  border-color: var(--kimo-accent);
}
.kimo-mobile-body { padding: 20px; }
.kimo-mitem {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 14px 16px;
  border-radius: var(--kimo-radius);
  border: 1px solid #EAEAEA;
  background: #FFFFFF;
  font-weight: 700;
  text-decoration: none;
  color: var(--kimo-text);
  margin-bottom: 8px;
  transition: all var(--kimo-duration-fast) var(--kimo-ease-smooth);
}
.kimo-mitem:hover {
  background: #FFF9E6;
  transform: translateX(6px);
  border-color: var(--kimo-accent);
  color: var(--kimo-primary-dark);
}
.kimo-mback { display: none; margin-bottom: 14px; }
.kimo-mback button { border: none; background: transparent; font-weight: 800; color: var(--kimo-primary-dark); cursor: pointer; }

@media (max-width: 992px) {
  .kimo-search { display: none; }
  .kimo-mtoggle { display: inline-flex; }
  .kimo-mega { display: none !important; }
  .kimo-topbar .kimo-topbar-right { display: none; }
}
@media (max-width: 768px) {
  .kimo-topbar { font-size: 10px; letter-spacing: 1px; }
  .kimo-nav-list { gap: 2px; }
  .kimo-mainbar .kimo-wrap { padding-top: 10px; padding-bottom: 10px; }
  .kimo-brand .kimo-brand-text strong { font-size: 16px; }
  .kimo-brand img { height: 40px; }
  .kimo-icbtn { width: 38px; height: 38px; font-size: 16px; }
}

/* ═══════════════════════════════════════════════════════
   HERO CAROUSEL
   ═══════════════════════════════════════════════════════ */
.kimo-hero {
  position: relative;
  overflow: hidden;
  border-bottom: 2px solid rgba(255, 193, 7, .08);
}
.kimo-hero-track {
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.kimo-hero-track::-webkit-scrollbar { display: none; }
.kimo-hero-slide {
  min-width: 100%;
  scroll-snap-align: start;
  position: relative;
  aspect-ratio: 21/9;
  overflow: hidden;
  background: #FFFFFF;
}
@media (max-width: 992px) { .kimo-hero-slide { aspect-ratio: 16/7; } }
@media (max-width: 768px) { .kimo-hero-slide { aspect-ratio: 4/3; } }
.kimo-hero-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 12s ease-out;
  filter: brightness(.90);
}
.kimo-hero-slide.active img { transform: scale(1.08); }
.kimo-hero-caption {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
  padding: 50px;
  background: linear-gradient(0deg, rgba(26, 26, 46, .85) 0%, rgba(26, 26, 46, .40) 40%, rgba(26, 26, 46, .10) 70%, transparent 100%);
  gap: 16px;
}
.kimo-hero-badge {
  display: inline-flex;
  padding: 6px 16px;
  background: var(--kimo-accent);
  color: #1A1A2E;
  font-family: var(--kimo-font-heading);
  font-weight: 900;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  transform: skewX(-12deg);
  border: 2px solid rgba(255, 255, 255, .20);
  box-shadow: 3px 3px 0px 0px rgba(255, 255, 255, .15);
  animation: kimoFadeInUp .6s var(--kimo-ease-out-expo) both;
  animation-delay: .2s;
}
.kimo-hero-badge span { display: inline-block; transform: skewX(12deg); }
.kimo-hero-caption strong {
  font-family: var(--kimo-font-heading);
  font-size: clamp(28px, 5vw, 60px);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -2px;
  color: #fff;
  text-shadow: 0 4px 30px rgba(0, 0, 0, .4);
  line-height: .95;
  animation: kimoFadeInUp .8s var(--kimo-ease-out-expo) both;
  animation-delay: .4s;
}
.kimo-hero-caption .sub {
  font-size: clamp(14px, 1.5vw, 18px);
  color: var(--kimo-accent-light);
  margin-top: 4px;
  font-weight: 700;
  letter-spacing: 1px;
  animation: kimoFadeInUp .8s var(--kimo-ease-out-expo) both;
  animation-delay: .6s;
}
.kimo-hero-cta {
  margin-top: 8px;
  animation: kimoFadeInUp .8s var(--kimo-ease-out-expo) both;
  animation-delay: .8s;
}
.kimo-hero-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, .30);
  background: rgba(255, 255, 255, .15);
  backdrop-filter: blur(16px);
  color: #FFFFFF;
  font-size: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--kimo-duration-fast) var(--kimo-ease-smooth);
  z-index: 5;
}
.kimo-hero-nav:hover {
  background: rgba(255, 193, 7, .25);
  border-color: var(--kimo-accent);
  color: var(--kimo-accent);
  transform: translateY(-50%) scale(1.1);
  box-shadow: 0 0 20px rgba(255, 193, 7, .20);
}
.kimo-hero-nav.prev { left: 20px; }
.kimo-hero-nav.next { right: 20px; }
.kimo-hero-dots {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 5;
}
.kimo-hero-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .30);
  background: transparent;
  cursor: pointer;
  transition: all var(--kimo-duration-fast);
}
.kimo-hero-dot.active {
  background: var(--kimo-accent);
  width: 32px;
  box-shadow: 0 0 12px rgba(255, 193, 7, .5);
}

/* ═══════════════════════════════════════════════════════
   SCROLL REVEAL ANIMATIONS
   ═══════════════════════════════════════════════════════ */
.kimo-reveal { opacity: 0; transform: translateY(40px); transition: opacity var(--kimo-duration-slower) var(--kimo-ease-out-expo), transform var(--kimo-duration-slower) var(--kimo-ease-out-expo); }
.kimo-reveal.kimo-visible { opacity: 1; transform: translateY(0); }
.kimo-reveal-left { opacity: 0; transform: translateX(-40px); transition: opacity var(--kimo-duration-slower) var(--kimo-ease-out-expo), transform var(--kimo-duration-slower) var(--kimo-ease-out-expo); }
.kimo-reveal-left.kimo-visible { opacity: 1; transform: translateX(0); }
.kimo-reveal-right { opacity: 0; transform: translateX(40px); transition: opacity var(--kimo-duration-slower) var(--kimo-ease-out-expo), transform var(--kimo-duration-slower) var(--kimo-ease-out-expo); }
.kimo-reveal-right.kimo-visible { opacity: 1; transform: translateX(0); }
.kimo-reveal-scale { opacity: 0; transform: scale(.85); transition: opacity var(--kimo-duration-slower) var(--kimo-ease-out-expo), transform var(--kimo-duration-slower) var(--kimo-ease-out-expo); }
.kimo-reveal-scale.kimo-visible { opacity: 1; transform: scale(1); }

.kimo-stagger > * { opacity: 0; transform: translateY(30px); transition: opacity var(--kimo-duration-slow) var(--kimo-ease-out-expo), transform var(--kimo-duration-slow) var(--kimo-ease-out-expo); }
.kimo-stagger.kimo-visible > *:nth-child(1) { transition-delay: .05s; opacity: 1; transform: translateY(0); }
.kimo-stagger.kimo-visible > *:nth-child(2) { transition-delay: .1s; opacity: 1; transform: translateY(0); }
.kimo-stagger.kimo-visible > *:nth-child(3) { transition-delay: .15s; opacity: 1; transform: translateY(0); }
.kimo-stagger.kimo-visible > *:nth-child(4) { transition-delay: .2s; opacity: 1; transform: translateY(0); }
.kimo-stagger.kimo-visible > *:nth-child(5) { transition-delay: .25s; opacity: 1; transform: translateY(0); }
.kimo-stagger.kimo-visible > *:nth-child(6) { transition-delay: .3s; opacity: 1; transform: translateY(0); }
.kimo-stagger.kimo-visible > *:nth-child(7) { transition-delay: .35s; opacity: 1; transform: translateY(0); }
.kimo-stagger.kimo-visible > *:nth-child(8) { transition-delay: .4s; opacity: 1; transform: translateY(0); }
.kimo-stagger.kimo-visible > *:nth-child(n+9) { transition-delay: .45s; opacity: 1; transform: translateY(0); }

/* ═══════════════════════════════════════════════════════
   SKELETON LOADING
   ═══════════════════════════════════════════════════════ */
.kimo-skeleton {
  background: linear-gradient(90deg, #F0F0F0 25%, #E8E8E8 50%, #F0F0F0 75%);
  background-size: 200% 100%;
  animation: kimoShimmer 1.5s infinite;
  border-radius: var(--kimo-radius);
}
.kimo-skeleton-card { border: 1px solid #EAEAEA; border-radius: var(--kimo-radius); overflow: hidden; background: var(--kimo-surface); box-shadow: 0 2px 12px rgba(0, 0, 0, .04); }
.kimo-skeleton-img { aspect-ratio: 1/1; background: linear-gradient(90deg, #F0F0F0 25%, #E8E8E8 50%, #F0F0F0 75%); background-size: 200% 100%; animation: kimoShimmer 1.5s infinite; }
.kimo-skeleton-body { padding: 14px; }
.kimo-skeleton-line { height: 14px; border-radius: 6px; margin-bottom: 8px; background: linear-gradient(90deg, #F0F0F0 25%, #E8E8E8 50%, #F0F0F0 75%); background-size: 200% 100%; animation: kimoShimmer 1.5s infinite; }
.kimo-skeleton-line:last-child { width: 60%; margin-bottom: 0; }

/* ═══════════════════════════════════════════════════════
   SECTIONS + GRIDS — Premium Layout
   ═══════════════════════════════════════════════════════ */
.kimo-section { padding: 56px 0; position: relative; }

.kimo-section-accent::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--kimo-accent), var(--kimo-gold), var(--kimo-accent), transparent);
  opacity: .3;
}

.kimo-section h2 {
  font-family: var(--kimo-font-heading);
  font-weight: 900;
  font-size: clamp(28px, 4vw, 48px);
  margin: 0 0 28px;
  text-transform: uppercase;
  letter-spacing: -1.5px;
  position: relative;
  display: inline-block;
  color: var(--kimo-text);
}
.kimo-section h2::after {
  content: '';
  position: absolute;
  bottom: -10px;
  left: 0;
  width: 60px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--kimo-accent), var(--kimo-gold));
  transition: width var(--kimo-duration-slow) var(--kimo-ease-out-expo);
}
.kimo-section:hover h2::after { width: 160px; }

.kimo-section h2 .kimo-accent-word {
  background: linear-gradient(135deg, var(--kimo-accent), var(--kimo-primary-dark));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.kimo-section-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 36px;
}

.kimo-divider {
  width: 80px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--kimo-accent), transparent);
  margin-top: 12px;
}
.kimo-divider-wide {
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 193, 7, .20), transparent);
  margin: 40px 0;
}

.kimo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 20px;
}
@media (max-width: 768px) { .kimo-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px; } }
@media (max-width: 420px) { .kimo-grid { grid-template-columns: 1fr 1fr; gap: 10px; } }

/* ═══════════════════════════════════════════════════════
   ALL PRODUCTS PAGE — Layout, Filters, Controls
   ═══════════════════════════════════════════════════════ */

/* ── Main Layout (sidebar + content) ──────────────────────── */
.kimo-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 24px;
  align-items: start;
}
@media (max-width: 900px) {
  .kimo-layout {
    grid-template-columns: 1fr;
  }
}

/* ── Filters Sidebar — Premium Glass ────────────────────── */
.kimo-filters {
  border: 1px solid rgba(0,0,0,.05);
  border-radius: var(--kimo-radius);
  background: rgba(255,255,255,.90);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 20px;
  position: sticky;
  top: 90px;
  box-shadow: 0 2px 16px rgba(0, 0, 0, .04);
}
.kimo-filters h3 {
  margin: 0;
  font-size: 16px;
  font-weight: 900;
  color: var(--kimo-text);
  font-family: var(--kimo-font-heading);
  text-transform: uppercase;
  letter-spacing: .5px;
}
.kimo-filter-input {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid var(--kimo-border);
  border-radius: var(--kimo-input-radius);
  font-size: 13px;
  font-weight: 600;
  background: var(--kimo-surface);
  color: var(--kimo-text);
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease;
  font-family: var(--kimo-font-body);
}
.kimo-filter-input:focus {
  border-color: var(--kimo-accent);
  box-shadow: 0 0 0 3px rgba(255, 193, 7, .10);
}
.kimo-filter-small {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--kimo-border);
  border-radius: var(--kimo-input-radius);
  font-size: 13px;
  font-weight: 700;
  background: var(--kimo-surface);
  color: var(--kimo-text);
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease;
  font-family: var(--kimo-font-body);
}
.kimo-filter-small:focus {
  border-color: var(--kimo-accent);
  box-shadow: 0 0 0 3px rgba(255, 193, 7, .10);
}
.kimo-filter-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--kimo-text);
  cursor: pointer;
  padding: 6px 0;
}
.kimo-filter-row input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--kimo-accent);
  cursor: pointer;
}
.kimo-filter-actions {
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.kimo-filter-actions .kimo-btn {
  text-align: center;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .3px;
  padding: 10px 16px;
}
/* ── Mobile Filter Toggle ─────────────────────────────── */
.kimo-filter-toggle {
  display: none;
  width: 100%;
  padding: 12px 18px;
  border: 1px solid #E2E2E2;
  border-radius: var(--kimo-button-radius);
  background: #FFFFFF;
  font-weight: 800;
  font-size: 13px;
  color: var(--kimo-text);
  cursor: pointer;
  transition: all .2s ease;
  margin-bottom: 12px;
  text-align: center;
  font-family: var(--kimo-font-body);
}
.kimo-filter-toggle:hover {
  background: #FFF9E6;
  border-color: var(--kimo-accent);
  color: var(--kimo-primary-dark);
}
@media (max-width: 900px) {
  .kimo-filter-toggle { display: block; }
  .kimo-filters { display: none; }
  .kimo-filters.kimo-filters-open {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 9999;
    border-radius: 0;
    overflow-y: auto;
    padding: 20px;
    background: rgba(255, 255, 255, .98);
    backdrop-filter: blur(16px);
  }
}

/* ── Controls Bar — Clean Modern ────────────────────────── */
.kimo-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  padding: 12px 16px;
  border: 1px solid rgba(0,0,0,.05);
  border-radius: var(--kimo-radius);
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  margin-bottom: 4px;
  box-shadow: 0 1px 8px rgba(0, 0, 0, .03);
}
.kimo-controls .kimo-left {
  font-size: 13px;
  font-weight: 700;
  color: var(--kimo-muted);
}
.kimo-controls .kimo-right {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.kimo-select {
  padding: 6px 28px 6px 12px;
  border: 1px solid var(--kimo-border);
  border-radius: var(--kimo-input-radius);
  font-size: 12px;
  font-weight: 700;
  font-family: var(--kimo-font-body);
  background: var(--kimo-surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 5l3 3 3-3' fill='none' stroke='%238E8E9A' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 8px center;
  appearance: none;
  -webkit-appearance: none;
  color: var(--kimo-text);
  cursor: pointer;
  outline: none;
  transition: border-color .2s ease;
}
.kimo-select:focus {
  border-color: var(--kimo-accent);
  box-shadow: 0 0 0 3px rgba(255, 193, 7, .10);
}
html[dir="rtl"] .kimo-select {
  padding: 6px 12px 6px 28px;
  background-position: left 8px center;
}

/* ── RTL adjustments for listing page ──────────────────────── */
html[dir="rtl"] .kimo-layout {
  direction: rtl;
}
html[dir="rtl"] .kimo-filters {
  direction: rtl;
}
html[dir="rtl"] .kimo-controls {
  direction: rtl;
}

/* ── Responsive adjustments for listing page ───────────────── */
@media (max-width: 900px) {
  .kimo-filters {
    position: static;
    padding: 16px;
  }
  .kimo-controls {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }
  .kimo-controls .kimo-right {
    flex-direction: column;
    gap: 8px;
  }
}
@media (max-width: 600px) {
  .kimo-filters {
    padding: 12px;
  }
  .kimo-filters h3 {
    font-size: 14px;
  }
}

/* ── Pager Buttons (see also Pagination section) ─────────── */
.kimo-list-mode-nav {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-bottom: 16px;
}

/* ═══════════════════════════════════════════════════════
   PRODUCT CARDS — v14 Ultra Premium Design
   5:4 image ratio, glass morphism, gold accent,
   hover overlays, rating stars, wishlist & ATC
   ═══════════════════════════════════════════════════════ */

/* ── Card Container — Premium Glass ────────────────────── */
.kimo-card {
  border: 1px solid rgba(0, 0, 0, .05);
  border-radius: var(--kimo-radius);
  background: rgba(255, 255, 255, .92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  overflow: hidden;
  position: relative;
  transition: all .35s cubic-bezier(.25, .46, .45, .94);
  box-shadow: 0 1px 8px rgba(0, 0, 0, .04), 0 0 0 1px rgba(0, 0, 0, .02);
  display: flex;
  flex-direction: column;
}
.kimo-card:hover {
  border-color: rgba(255, 193, 7, .35);
  box-shadow:
    0 20px 50px rgba(0, 0, 0, .08),
    0 0 0 1px rgba(255, 193, 7, .12),
    0 0 30px rgba(255, 193, 7, .06);
  transform: translateY(-8px);
  background: rgba(255, 255, 255, .98);
}

/* ── Gold Accent Top Line (::after) ─────────────────────── */
.kimo-card::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--kimo-accent), rgba(255, 193, 7, .20), transparent);
  z-index: 5;
  opacity: .5;
  transition: opacity .25s ease, height .25s ease;
}
.kimo-card:hover::after { opacity: 1; height: 3px; }
html[dir="rtl"] .kimo-card::after {
  left: auto;
  right: 0;
  background: linear-gradient(270deg, var(--kimo-accent), rgba(255, 193, 7, .30), transparent);
}

/* ── Cursor Glow Effect (::before) ─────────────────────── */
.kimo-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(400px circle at var(--glow-x, 50%) var(--glow-y, 50%), rgba(255, 193, 7, .06), transparent 50%);
  opacity: 0;
  transition: opacity var(--kimo-duration-fast);
  pointer-events: none;
  z-index: 1;
}
.kimo-card:hover::before { opacity: 1; }

/* ── Image Container — UNIFORM 1:1 Square Ratio for Consistency ── */
.kimo-card-img-wrap {
  position: relative;
  overflow: hidden;
  border-radius: var(--kimo-radius) var(--kimo-radius) 0 0;
  /* FIXED height for perfect alignment across all cards */
  height: 220px;
}
.kimo-card-img {
  display: flex;
  align-items: center;
  justify-content: center;
  /* Square ratio ensures consistent card heights */
  aspect-ratio: 1 / 1;
  height: 100%;
  overflow: hidden;
  background: #FFFFFF;
  position: relative;
  border-bottom: 1px solid rgba(0, 0, 0, .04);
  border-radius: var(--kimo-radius) var(--kimo-radius) 0 0;
}
.kimo-card-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,.02) 100%);
  pointer-events: none;
  z-index: 1;
  transition: opacity .3s ease;
}
.kimo-card:hover .kimo-card-img::after {
  opacity: .5;
}
.kimo-card-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  padding: 12px;
  transition: transform .5s cubic-bezier(.25, .46, .45, .94), filter .3s ease;
  /* REMOVED max-height — container height is fixed at 220px for consistency */
}
.kimo-card:hover .kimo-card-img img {
  transform: scale(1.06);
  filter: brightness(1.02);
}
@media (max-width: 768px) {
  .kimo-card-img img { padding: 10px; }
}

/* ── No Image Fallback — Soft Gradient ───────────────── */
.kimo-noimg {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  background: linear-gradient(145deg, #FFFDF5 0%, #FFF9E6 50%, #FFF3CD 100%);
  color: rgba(255, 193, 7, .22);
  font-size: 36px;
  user-select: none;
}

/* ── Card Body — UNIFORM Consistent Spacing & Alignment ──── */
.kimo-card-body {
  padding: 14px 16px 16px;
  position: relative;
  z-index: 2;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
  /* FIXED min-height for perfect row alignment */
  min-height: 120px;
}

/* ── Card Title — UNIFORM Two-Line Clamp ──────── */
.kimo-card-title {
  font-family: var(--kimo-font-body);
  font-weight: 700;
  font-size: 14px;
  line-height: 1.45;
  color: var(--kimo-text);
  /* FIXED height: exactly 2 lines = 14px * 1.45 * 2 ≈ 40.6px */
  min-height: 41px;
  max-height: 41px;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  margin-bottom: 0;
  transition: color .2s ease;
  word-break: break-word;
}
.kimo-card:hover .kimo-card-title { color: var(--kimo-primary-dark); }

/* ── Card Rating (compact inline) ───────────────────────── */
.kimo-card-rating {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-bottom: 2px;
}
.kimo-stars {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-size: 11px;
  color: #D0D0D0;
  line-height: 1;
}
.kimo-stars .kimo-star-filled {
  color: var(--kimo-accent);
}
.kimo-card-rating .kimo-rating-count {
  font-size: 10px;
  font-weight: 600;
  color: var(--kimo-text-faint);
  margin-left: 2px;
}

/* ── Price — Bold & Clear ─────────────────────────────── */
.kimo-price {
  font-weight: 900;
  font-size: 15px;
  color: var(--kimo-text);
  margin-bottom: 2px;
  margin-top: auto;
  line-height: 1.2;
}
.kimo-price strong {
  color: var(--kimo-primary-dark);
  font-size: 16px;
}
.kimo-price del {
  color: var(--kimo-muted);
  font-weight: 600;
  font-size: 12px;
  margin-left: 6px;
  text-decoration-color: var(--kimo-danger);
}
html[dir="rtl"] .kimo-price del { margin-left: 0; margin-right: 6px; }

/* ── Stock Badge (pill style) — HIDDEN per user request ─── */
.kimo-stock {
  display: none !important;
}

/* ── Actions Row — Smooth Reveal ────────────────────────── */
.kimo-actions-row {
  display: flex;
  gap: 4px;
  align-items: center;
  flex-wrap: wrap;
  opacity: 0;
  transform: translateY(6px);
  transition: all .3s var(--kimo-ease-smooth);
  /* CRITICAL FIX: prevent accidental clicks when row is invisible */
  pointer-events: none;
}
.kimo-card:hover .kimo-actions-row {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
@media (max-width: 768px) {
  .kimo-actions-row { opacity: 1; transform: translateY(0); pointer-events: auto; }
}

/* ── Wishlist Heart Button — Premium Glass ───────────── */
.kimo-card-wish-btn {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 10;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, .90);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: var(--kimo-muted);
  font-size: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 2px 10px rgba(0, 0, 0, .10);
  transition: all .25s var(--kimo-ease-smooth);
  opacity: 0;
  transform: scale(.7);
}
.kimo-card:hover .kimo-card-wish-btn,
.kimo-card-wish-btn:focus,
.kimo-card-wish-btn.active { opacity: 1; transform: scale(1); }
.kimo-card-wish-btn:hover {
  background: var(--kimo-accent);
  color: #1A1A2E;
  transform: scale(1.12);
  box-shadow: 0 4px 16px rgba(255, 193, 7, .35);
}
.kimo-card-wish-btn.active {
  background: var(--kimo-danger);
  color: #FFFFFF;
  opacity: 1;
  transform: scale(1);
  animation: kimoHeartbeat .6s var(--kimo-ease-spring);
}
html[dir="rtl"] .kimo-card-wish-btn { right: auto; left: 10px; }
@media (max-width: 768px) {
  .kimo-card-wish-btn { opacity: .85; transform: scale(1); }
}

/* ── Add to Cart Overlay — Premium Slide Up ──────────── */
.kimo-card-atc-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 10;
  padding: 12px 14px 14px;
  background: linear-gradient(0deg, rgba(255, 255, 255, .98) 50%, rgba(255, 255, 255, .90) 75%, transparent 100%);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transform: translateY(100%);
  opacity: 0;
  transition: all .35s var(--kimo-ease-out-expo);
  /* CRITICAL: prevent overlay from intercepting clicks meant for parent <a> navigation */
  pointer-events: none;
}
.kimo-card:hover .kimo-card-atc-overlay {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.kimo-card:hover .kimo-card-atc-overlay .kimo-btn {
  pointer-events: auto;
}
.kimo-card-atc-overlay .kimo-btn {
  width: 100%;
  height: 40px;
  font-size: 12px;
  letter-spacing: .8px;
  border-radius: var(--kimo-button-radius);
  /* CRITICAL FIX: button NOT clickable until overlay is visible via hover */
  pointer-events: none;
  box-shadow: 0 4px 16px rgba(255, 193, 7, .20);
}
@media (max-width: 768px) {
  .kimo-card-atc-overlay {
    opacity: 0;
    transform: translateY(100%);
    pointer-events: none;
  }
  .kimo-card-atc-overlay .kimo-btn {
    pointer-events: none;
  }
  .kimo-card:focus-within .kimo-card-atc-overlay,
  .kimo-card.touched .kimo-card-atc-overlay {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
  .kimo-card:focus-within .kimo-card-atc-overlay .kimo-btn,
  .kimo-card.touched .kimo-card-atc-overlay .kimo-btn {
    pointer-events: auto;
  }
}

/* ── Card Accent Line (explicit element fallback) ───────── */
.kimo-card-accent-line {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--kimo-accent), rgba(255, 193, 7, .30), transparent);
  z-index: 5;
  pointer-events: none;
}
html[dir="rtl"] .kimo-card-accent-line {
  left: auto;
  right: 0;
  background: linear-gradient(270deg, var(--kimo-accent), rgba(255, 193, 7, .30), transparent);
}

/* ── Product Tags — Skewed Badge ──────────────────────── */
.kimo-tag {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 10;
  padding: 4px 12px;
  border-radius: 6px;
  background: var(--kimo-accent);
  color: #1A1A2E;
  font-family: var(--kimo-font-heading);
  font-weight: 900;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .8px;
  transform: skewX(-6deg);
  box-shadow: 1px 2px 8px rgba(0, 0, 0, .10), 0 0 0 1px rgba(255, 193, 7, .20);
  animation: kimoFadeInDown .4s var(--kimo-ease-out-expo) both;
}
.kimo-tag span { display: inline-block; transform: skewX(6deg); }
.kimo-tag.kimo-tag-new { background: var(--kimo-success); color: #FFFFFF; box-shadow: 1px 2px 6px rgba(0, 0, 0, .10), 0 0 0 1px rgba(34, 197, 94, .20); }
.kimo-tag.kimo-tag-sold-out { background: var(--kimo-danger); color: #FFFFFF; box-shadow: 1px 2px 6px rgba(0, 0, 0, .10), 0 0 0 1px rgba(239, 68, 68, .20); }
html[dir="rtl"] .kimo-tag { left: auto; right: 10px; transform: skewX(6deg); }
html[dir="rtl"] .kimo-tag span { transform: skewX(-6deg); }

/* ── Buttons — Premium Interactive ─────────────────────── */
.kimo-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  height: 38px;
  padding: 0 18px;
  border-radius: var(--kimo-button-radius);
  font-weight: 800;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .5px;
  cursor: pointer;
  transition: all .25s cubic-bezier(.25, .46, .45, .94);
  text-decoration: none;
  border: 1px solid transparent;
  position: relative;
  overflow: hidden;
}

.kimo-btn-primary {
  background: linear-gradient(135deg, var(--kimo-accent), var(--kimo-primary-dark));
  color: #1A1A2E;
  border-color: var(--kimo-accent);
  box-shadow: 0 2px 12px rgba(255, 193, 7, .25);
}
.kimo-btn-primary:hover {
  background: linear-gradient(135deg, var(--kimo-primary-light), var(--kimo-accent));
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(255, 193, 7, .35);
}
.kimo-btn-primary:active {
  transform: translateY(0) scale(.97);
  box-shadow: 0 2px 8px rgba(255, 193, 7, .20);
}
/* ── Button Shine Sweep ──────────────────────────────────── */
.kimo-btn-primary::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.25), transparent);
  transition: none;
}
.kimo-btn-primary:hover::after {
  animation: kimoYellowShine .6s ease;
}

.kimo-btn-ghost {
  background: transparent;
  color: var(--kimo-text-secondary);
  border-color: rgba(0,0,0,.08);
}
.kimo-btn-ghost:hover {
  background: rgba(255, 193, 7, .06);
  border-color: rgba(255, 193, 7, .25);
  color: var(--kimo-primary-dark);
  transform: translateY(-1px);
}

.kimo-btn-cta {
  display: inline-flex;
  align-items: center;
  padding: 12px 28px;
  border-radius: var(--kimo-button-radius);
  background: var(--kimo-accent);
  color: #1A1A2E;
  font-family: var(--kimo-font-heading);
  font-weight: 900;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 1px;
  text-decoration: none;
  box-shadow: 0 4px 14px rgba(255, 193, 7, .25);
  transition: all .25s ease;
  position: relative;
  overflow: hidden;
}
.kimo-btn-cta:hover {
  background: var(--kimo-primary-light);
  transform: translateY(-3px);
  box-shadow: 0 6px 24px rgba(255, 193, 7, .35);
}
.kimo-btn-cta:active { transform: translateY(0) scale(.97); }

.kimo-btn-cta-outline {
  display: inline-flex;
  align-items: center;
  padding: 12px 28px;
  border-radius: var(--kimo-button-radius);
  background: transparent;
  color: var(--kimo-accent);
  border: 2px solid var(--kimo-accent);
  font-family: var(--kimo-font-heading);
  font-weight: 900;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 1px;
  text-decoration: none;
  transition: all .25s ease;
}
.kimo-btn-cta-outline:hover {
  background: rgba(255, 193, 7, .08);
  transform: translateY(-3px);
  box-shadow: 0 4px 16px rgba(255, 193, 7, .15);
}
/* ── Share Buttons ──────────────────────────────────────── */
.kimo-share-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  border: 1px solid #E8E8E8;
  background: #FFFFFF;
  color: var(--kimo-text-secondary);
  font-size: 16px;
  text-decoration: none;
  cursor: pointer;
  transition: all .2s ease;
}
.kimo-share-btn:hover {
  background: #FFF9E6;
  border-color: var(--kimo-accent);
  color: var(--kimo-primary-dark);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(255, 193, 7, .15);
}
/* ── Comparison Tray ───────────────────────────────────── */
.kimo-compare-tray {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 8000;
  background: rgba(255, 255, 255, .96);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 2px solid var(--kimo-accent);
  box-shadow: 0 -8px 30px rgba(0, 0, 0, .10), 0 0 20px rgba(255, 193, 7, .04);
  padding: 16px 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  transform: translateY(100%);
  transition: transform .35s var(--kimo-ease-out-expo);
}
.kimo-compare-tray.kimo-compare-tray-visible {
  transform: translateY(0);
}
.kimo-compare-tray-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255, 193, 7, .20);
  background: #FFFDF5;
  font-size: 12px;
  font-weight: 700;
}
.kimo-compare-tray-item img {
  width: 32px;
  height: 32px;
  border-radius: 6px;
  object-fit: cover;
}
.kimo-compare-tray-remove {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: none;
  background: transparent;
  color: var(--kimo-danger);
  font-size: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .15s ease;
}
.kimo-compare-tray-remove:hover {
  background: var(--kimo-danger);
  color: #FFFFFF;
}
/* RTL share buttons */
html[dir="rtl"] .kimo-share-btn {
  transform: scaleX(-1);
}
html[dir="rtl"] .kimo-pdp-quick-actions {
  flex-direction: row-reverse;
}
html[dir="rtl"] .kimo-pdp-quick-actions .kimo-pill {
  margin-left: 0;
  margin-right: auto;
}

/* ── Ripple ─────────────────────────────────────────────── */
.kimo-ripple {
  position: absolute;
  border-radius: 50%;
  background: rgba(255, 193, 7, .25);
  transform: scale(0);
  animation: kimoRipple .6s ease-out;
  pointer-events: none;
}

/* ── Toast — Premium Glass Notification ────────────────── */
.kimo-toast {
  position: fixed;
  top: 24px;
  right: 24px;
  z-index: 99999;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 24px;
  border-radius: 14px;
  background: rgba(255, 255, 255, .96);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  color: var(--kimo-text);
  font-weight: 800;
  font-size: 14px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, .10), 0 0 20px rgba(255, 193, 7, .04);
  animation: kimoToastIn .3s ease;
  border-left: 4px solid var(--kimo-accent);
  border: 1px solid rgba(0, 0, 0, .04);
  border-left: 4px solid var(--kimo-accent);
}
.kimo-toast-success { border-left-color: var(--kimo-success); }
.kimo-toast-error { border-left-color: var(--kimo-danger); }
.kimo-toast-out { animation: kimoToastOut .3s ease forwards; }

/* ── Back to top — Premium Glass ─────────────────────── */
.kimo-back-to-top {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid rgba(255, 193, 7, .15);
  background: rgba(255, 255, 255, .92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: var(--kimo-accent);
  font-size: 20px;
  font-weight: 900;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
  transition: all .3s ease;
  z-index: 5000;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .06);
}
.kimo-back-to-top.kimo-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.kimo-back-to-top:hover {
  background: var(--kimo-accent);
  color: #1A1A2E;
  box-shadow: 0 4px 20px rgba(255, 193, 7, .30);
  transform: translateY(-4px);
}

/* ── WhatsApp button ──────────────────────────────────── */
.kimo-whatsapp {
  position: fixed;
  bottom: 90px;
  right: 30px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--kimo-whatsapp);
  color: #fff;
  font-size: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  z-index: 5000;
  box-shadow: 0 4px 20px rgba(37, 211, 102, .35);
  transition: all .25s ease;
  animation: kimoFloat 3s ease-in-out infinite;
}
.kimo-whatsapp:hover {
  transform: scale(1.12);
  box-shadow: 0 6px 28px rgba(37, 211, 102, .45);
}

/* ── Modal — Premium Glass ─────────────────────────────── */
.kimo-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(26, 26, 46, .12);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  opacity: 0;
  visibility: hidden;
  transition: all .3s ease;
}
.kimo-modal.open { opacity: 1; visibility: visible; }
.kimo-modal-card {
  background: rgba(255, 255, 255, .96);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-radius: 20px;
  max-width: 600px;
  width: 92%;
  max-height: 90vh;
  overflow: auto;
  box-shadow: 0 24px 80px rgba(0, 0, 0, .12), 0 0 40px rgba(255, 193, 7, .04);
  transform: scale(.92) translateY(20px);
  transition: transform .3s var(--kimo-ease-spring);
  border: 1px solid rgba(255, 193, 7, .10);
}
.kimo-modal.open .kimo-modal-card { transform: scale(1) translateY(0); }
.kimo-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 24px;
  border-bottom: 1px solid #EAEAEA;
}
.kimo-modal-head strong { font-family: var(--kimo-font-heading); font-size: 15px; text-transform: uppercase; letter-spacing: .5px; }
.kimo-modal-close {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid #EAEAEA;
  background: #FFFFFF;
  font-size: 18px;
  cursor: pointer;
  transition: all .15s ease;
  color: var(--kimo-text);
  display: flex;
  align-items: center;
  justify-content: center;
}
.kimo-modal-close:hover { background: #FFF3CD; color: var(--kimo-primary-dark); border-color: var(--kimo-accent); }
.kimo-modal-body { padding: 24px; }
.kimo-modal-body .img { margin-bottom: 16px; border-radius: 14px; overflow: hidden; background: #FFFFFF; }
.kimo-modal-body .img img { width: 100%; max-height: 300px; object-fit: contain; }
.kimo-modal-body .info h3 { font-family: var(--kimo-font-heading); font-size: 18px; margin: 0 0 8px; }

/* ── Spinner ────────────────────────────────────────────── */
.kimo-spinner {
  width: 28px;
  height: 28px;
  border: 3px solid #EAEAEA;
  border-top-color: var(--kimo-accent);
  border-radius: 50%;
  animation: kimoSpin .6s linear infinite;
}

/* ── Pagination ────────────────────────────────────────── */
.kimo-pager {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 20px 0;
}
.kimo-pager-btn {
  height: 40px;
  padding: 0 20px;
  border-radius: 10px;
  border: 1px solid #E2E2E2;
  background: #FFFFFF;
  font-weight: 800;
  font-size: 13px;
  cursor: pointer;
  transition: all .2s ease;
  color: var(--kimo-text);
  font-family: var(--kimo-font-heading);
  text-transform: uppercase;
  letter-spacing: .5px;
}
.kimo-pager-btn:hover:not(:disabled) {
  border-color: var(--kimo-accent);
  background: #FFF9E6;
  color: var(--kimo-primary-dark);
}
.kimo-pager-btn:disabled { opacity: .4; cursor: not-allowed; }
.kimo-pager-mid { font-weight: 800; color: var(--kimo-muted); font-size: 13px; }

/* ── Product Gallery ────────────────────────────────────── */
.kimo-gallery { position: relative; }
.kimo-gallery-main { position: relative; border-radius: 14px; overflow: hidden; background: #FFFFFF; border: 1px solid #F0F0F0; box-shadow: 0 2px 12px rgba(0,0,0,.04); }
.kimo-gallery-track {
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}
.kimo-gallery-track::-webkit-scrollbar { display: none; }
.kimo-gallery-slide {
  min-width: 100%;
  scroll-snap-align: start;
  display: none;
}
.kimo-gallery-slide.is-active { display: block; }
/* Gallery slide smooth transition */
.kimo-gallery-slide.is-active {
  animation: kimoFadeIn .3s ease;
}
.kimo-gallery-slide img,
.kimo-pdp-img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: contain;
  border-radius: 10px;
  background: #FFFFFF;
  max-height: 380px;
}
.kimo-gallery-slide-empty { background: linear-gradient(135deg, #FFF9E6, #FFF3CD); }
.kimo-gallery-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid #E2E2E2;
  background: #FFFFFF;
  color: var(--kimo-text);
  font-size: 22px;
  display: none;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 5;
  transition: all .15s ease;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .06);
}
.kimo-gallery.has-many .kimo-gallery-nav { display: flex; }
.kimo-gallery-nav:hover { background: var(--kimo-accent); color: #1A1A2E; border-color: var(--kimo-accent); }
.kimo-gallery-nav.prev { left: 10px; }
.kimo-gallery-nav.next { right: 10px; }

.kimo-gallery-thumbs {
  display: flex;
  gap: 8px;
  margin-top: 10px;
  overflow-x: auto;
  padding-bottom: 4px;
}
.kimo-gallery-thumb {
  flex: 0 0 auto;
  width: 60px;
  height: 60px;
  border-radius: 10px;
  border: 2px solid #EAEAEA;
  overflow: hidden;
  cursor: pointer;
  transition: all .15s ease;
  background: #FFFFFF;
  padding: 0;
}
.kimo-gallery-thumb img { width: 100%; height: 100%; object-fit: cover; }
.kimo-gallery-thumb.is-active { border-color: var(--kimo-accent); box-shadow: 0 0 10px rgba(255, 193, 7, .15); }
.kimo-gallery-thumb:hover { border-color: var(--kimo-accent); }

/* ── Product Detail Page — Compact Premium ───────────── */
.kimo-pdp { background: var(--kimo-bg); }
.kimo-pdp-grid { align-items: start; }
.kimo-pdp-info { position: sticky; top: 90px; }
.kimo-pdp-info h1 { letter-spacing: -.3px; }
.kimo-pdp-info .kimo-stock { margin-top: 12px; padding: 6px 14px; font-size: 11px; }
.kimo-pdp-info .kimo-stock.in { background: rgba(34,197,94,.08); color: #15803D; border-radius: 100px; display: inline-flex; width: fit-content; }
.kimo-pdp-info .kimo-stock.out { background: rgba(239,68,68,.08); color: #B91C1C; border-radius: 100px; display: inline-flex; width: fit-content; }
.kimo-pdp-info .kimo-price del { font-size: 16px; opacity: .7; }
.kimo-pdp-info .kimo-pill { display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px; border-radius: var(--kimo-input-radius); border: 1px solid var(--kimo-border); font-size: 12px; font-weight: 700; cursor: pointer; transition: all .15s ease; text-decoration: none; }
.kimo-pdp-info .kimo-pill:hover { background: #FFF9E6; border-color: var(--kimo-accent); color: var(--kimo-primary-dark); }
/* PDP Gallery - spacious image block */
.kimo-pdp-gallery { max-height: none; overflow: visible; }
.kimo-gallery-main { border: 1px solid rgba(0,0,0,.04); border-radius: 12px; }
.kimo-gallery-nav { width: 32px; height: 32px; font-size: 18px; }
.kimo-gallery-thumbs { margin-top: 8px; gap: 6px; }
.kimo-gallery-thumb { width: 56px; height: 56px; border-radius: 8px; }
/* PDP Reviews Section */
.kimo-reviews-section .kimo-stars { font-size: 14px; gap: 2px; }
.kimo-reviews-section [data-kimo-review-form] input,
.kimo-reviews-section [data-kimo-review-form] textarea { border: 1px solid var(--kimo-border); border-radius: var(--kimo-radius); padding: 12px 16px; font-size: 14px; transition: border-color .2s ease; }
.kimo-reviews-section [data-kimo-review-form] input:focus,
.kimo-reviews-section [data-kimo-review-form] textarea:focus { border-color: var(--kimo-accent); outline: none; box-shadow: 0 0 0 3px rgba(255,193,7,.08); }
@media (max-width: 900px) {
  .kimo-pdp-info { position: static; }
  .kimo-pdp-grid { grid-template-columns: 1fr !important; }
  .kimo-pdp-gallery { max-height: none; }
}
@media (max-width: 600px) {
  .kimo-pdp-info { padding: 18px !important; }
  .kimo-pdp-info h1 { font-size: 20px !important; }
}

/* ── Wishlist heart animation ──────────────────────────── */
.kimo-wish-active { animation: kimoHeartbeat .6s ease; }

/* ── Category Cards ────────────────────────────────────── */
.kimo-cat-card { text-align: center; }
.kimo-cat-card .kimo-card-body { padding: 14px 10px; }
.kimo-cat-card .kimo-card-title { height: auto; text-align: center; font-size: 13px; font-weight: 700; letter-spacing: .5px; }
.kimo-cat-card:hover .kimo-card-title { color: var(--kimo-primary-dark); }
.kimo-cat-card .kimo-card-img img { object-position: center; }

/* ── Carousel listing mode ─────────────────────────────── */
.kimo-grid-carousel {
  display: flex !important;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  gap: 16px;
  padding-bottom: 8px;
}
.kimo-grid-carousel::-webkit-scrollbar { display: none; }
.kimo-grid-carousel > .kimo-card {
  flex: 0 0 260px;
  scroll-snap-align: start;
  max-width: 260px;
}

/* ── Sidebar filters — Premium Glass ──────────────────── */
.kimo-sidebar {
  background: rgba(255, 255, 255, .90);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(0, 0, 0, .05);
  border-radius: var(--kimo-radius);
  padding: 20px;
  box-shadow: 0 2px 16px rgba(0, 0, 0, .04);
}
.kimo-sidebar-title {
  font-family: var(--kimo-font-heading);
  font-weight: 900;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--kimo-text);
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--kimo-accent);
}
.kimo-sidebar .form-control {
  font-size: 13px;
  height: 38px;
}
.kimo-sidebar label {
  font-weight: 700;
  font-size: 13px;
  color: var(--kimo-text-secondary);
  cursor: pointer;
}

/* ═══════════════════════════════════════════════════════
   PRODUCT CARD — QUICK ACTIONS OVERLAY
   ═══════════════════════════════════════════════════════ */
.kimo-quick-actions-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 10px;
  background: linear-gradient(0deg, rgba(255, 255, 255, .92) 0%, rgba(255, 255, 255, .80) 60%, transparent 100%);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  transform: translateY(100%);
  transition: all var(--kimo-duration-normal) var(--kimo-ease-smooth);
  z-index: 10;
}
.kimo-card:hover .kimo-quick-actions-overlay {
  opacity: 1;
  transform: translateY(0);
}
@media (max-width: 768px) {
  .kimo-quick-actions-overlay {
    opacity: 1;
    transform: translateY(0);
  }
}
.kimo-quick-actions-overlay .kimo-qa-btn {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: 1px solid rgba(0, 0, 0, .08);
  background: rgba(255, 255, 255, .90);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: var(--kimo-text);
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--kimo-duration-fast) var(--kimo-ease-smooth);
  box-shadow: 0 1px 4px rgba(0, 0, 0, .06);
}
.kimo-quick-actions-overlay .kimo-qa-btn:hover {
  background: var(--kimo-accent);
  color: #1A1A2E;
  border-color: var(--kimo-accent);
  transform: scale(1.1);
  box-shadow: 0 2px 10px rgba(255, 193, 7, .25);
}

/* ── Rating Stars ──────────────────────────────────────── */
.kimo-rating {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  margin-bottom: 6px;
}
.kimo-rating-stars {
  position: relative;
  display: inline-flex;
  font-size: 14px;
  color: #D0D0D0;
  letter-spacing: 1px;
}
.kimo-rating-fill {
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden;
  white-space: nowrap;
  color: var(--kimo-accent);
  --fill: 80%;
  width: var(--fill);
}
.kimo-rating-count {
  font-size: 11px;
  font-weight: 700;
  color: var(--kimo-muted);
  margin-left: 4px;
}

/* ── "New Arrival" Badge ──────────────────────────────── */
.kimo-badge-new {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 10;
  padding: 4px 10px;
  border-radius: 6px;
  background: linear-gradient(135deg, var(--kimo-accent), var(--kimo-primary-dark));
  color: #FFFFFF;
  font-family: var(--kimo-font-heading);
  font-weight: 900;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  box-shadow: 0 2px 8px rgba(255, 193, 7, .35);
  animation: kimoFadeInDown .4s var(--kimo-ease-out-expo) both;
}

/* ── "Sold Out" Overlay ───────────────────────────────── */
.kimo-sold-out-overlay {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, .70);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 15;
  pointer-events: none;
}
.kimo-sold-out-overlay span {
  display: inline-flex;
  padding: 8px 20px;
  border-radius: 8px;
  background: var(--kimo-danger);
  color: #FFFFFF;
  font-family: var(--kimo-font-heading);
  font-weight: 900;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 2px;
  transform: rotate(-12deg);
  box-shadow: 0 4px 16px rgba(239, 68, 68, .30);
}

/* ═══════════════════════════════════════════════════════
   DARK MODE — Complete Theme Override
   html[data-theme="dark"]
   ═══════════════════════════════════════════════════════ */
html[data-theme="dark"] {
  /* Dark Backgrounds */
  --kimo-bg: #0F0F1A;
  --kimo-bg-alt: #0F0F1A;
  --kimo-bg-darker: #0A0A14;
  --kimo-surface: #1A1A2E;
  --kimo-surface-elevated: #1E1E36;
  --kimo-surface-card: #16162A;

  /* Dark Text */
  --kimo-text: #E4E4F0;
  --kimo-text-secondary: #B0B0C8;
  --kimo-muted: #8E8EA0;
  --kimo-muted-gray: #6E6E82;
  --kimo-text-faint: #5A5A70;

  /* Dark Borders */
  --kimo-border: #2A2A40;
  --kimo-border-strong: #3A3A55;

  /* Dark Shadows */
  --kimo-shadow: 0 4px 20px rgba(0, 0, 0, .30);
  --kimo-shadow-deep: 0 12px 40px rgba(0, 0, 0, .50);
  --kimo-shadow-glow: 0 4px 20px rgba(255, 193, 7, .08);
  --kimo-shadow-glow-strong: 0 8px 30px rgba(255, 193, 7, .15);

  /* Yellow Accent stays the same */
  --kimo-accent-light: #3D3500;

  /* Dark Header */
  --kimo-header-bg: rgba(15, 15, 26, .92);
  --kimo-header-text: #E4E4F0;

  /* Dark Footer */
  --kimo-footer-bg: #0A0A14;
  --kimo-footer-surface: #12122A;
  --kimo-footer-text: #E4E4F0;
  --kimo-footer-muted: #8E8EA0;
  --kimo-footer-border: rgba(255, 193, 7, .10);
}

/* ── Dark mode base ───────────────────────────────────── */
html[data-theme="dark"] body,
html[data-theme="dark"] html {
  background: var(--kimo-bg);
  color: var(--kimo-text);
}

/* ── Dark mode header ─────────────────────────────────── */
html[data-theme="dark"] .kimo-header {
  background: var(--kimo-header-bg);
  border-bottom-color: rgba(255, 255, 255, .06);
}
html[data-theme="dark"] .kimo-header.kimo-header-scrolled {
  background: rgba(15, 15, 26, .98);
  border-bottom-color: rgba(255, 193, 7, .12);
  box-shadow: 0 4px 30px rgba(0, 0, 0, .30), 0 0 20px rgba(255, 193, 7, .03);
}
html[data-theme="dark"] .kimo-header::after {
  opacity: .6;
}

/* ── Dark mode nav ────────────────────────────────────── */
html[data-theme="dark"] .kimo-nav {
  border-top-color: var(--kimo-border);
  background: rgba(15, 15, 26, .80);
}
html[data-theme="dark"] .kimo-nav-link {
  color: var(--kimo-muted);
}
html[data-theme="dark"] .kimo-nav-link:hover {
  color: var(--kimo-accent);
  background: rgba(255, 193, 7, .08);
}

/* ── Dark mode search ─────────────────────────────────── */
html[data-theme="dark"] .kimo-search input {
  background: #1A1A2E;
  border-color: #2A2A40;
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-search input::placeholder { color: #5A5A70; }
html[data-theme="dark"] .kimo-search input:focus {
  background: #1A1A2E;
  border-color: var(--kimo-accent);
  box-shadow: 0 0 0 4px rgba(255, 193, 7, .08), 0 4px 16px rgba(0, 0, 0, .20);
}
/* ── Dark mode search dropdown ────────────────────────── */
html[data-theme="dark"] .kimo-search-dropdown {
  background: rgba(26, 26, 46, .98);
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-search-item {
  color: var(--kimo-text);
  border-bottom-color: #2A2A40;
}
html[data-theme="dark"] .kimo-search-item:hover {
  background: rgba(255, 193, 7, .08);
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-search-item-all {
  color: var(--kimo-accent);
  border-top-color: #2A2A40;
}
html[data-theme="dark"] .kimo-search-item-all:hover {
  background: rgba(255, 193, 7, .08);
}

/* ── Dark mode icon buttons ───────────────────────────── */
html[data-theme="dark"] .kimo-icbtn {
  background: #1A1A2E;
  border-color: #2A2A40;
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-icbtn:hover {
  background: rgba(255, 193, 7, .10);
  border-color: var(--kimo-accent);
  color: var(--kimo-accent);
}

/* ── Dark mode badge ──────────────────────────────────── */
html[data-theme="dark"] .kimo-badge {
  border-color: #16162A;
}

/* ── Dark mode mega menu ──────────────────────────────── */
html[data-theme="dark"] .kimo-mega {
  background: rgba(15, 15, 26, .98);
  box-shadow: 0 20px 60px rgba(0, 0, 0, .40), 0 0 20px rgba(255, 193, 7, .03);
}
html[data-theme="dark"] .kimo-mega a {
  color: var(--kimo-text-secondary);
}
html[data-theme="dark"] .kimo-mega a:hover {
  background: rgba(255, 193, 7, .08);
  color: var(--kimo-accent);
}

/* ── Dark mode mobile menu ────────────────────────────── */
html[data-theme="dark"] .kimo-mobile {
  background: rgba(15, 15, 26, .99);
}
html[data-theme="dark"] .kimo-mobile-head {
  border-bottom-color: var(--kimo-border);
}
html[data-theme="dark"] .kimo-mobile-close {
  background: #1A1A2E;
  border-color: #2A2A40;
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-mobile-close:hover {
  background: rgba(255, 193, 7, .10);
  border-color: var(--kimo-accent);
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-mitem {
  background: #1A1A2E;
  border-color: #2A2A40;
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-mitem:hover {
  background: rgba(255, 193, 7, .10);
  border-color: var(--kimo-accent);
  color: var(--kimo-accent);
}

/* ── Dark mode hero ───────────────────────────────────── */
html[data-theme="dark"] .kimo-hero-slide {
  background: #0F0F1A;
}

/* ── Dark mode product cards ──────────────────────────── */
html[data-theme="dark"] .kimo-card {
  background: var(--kimo-surface-card);
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-card:hover {
  border-color: rgba(255, 193, 7, .30);
  box-shadow: 0 8px 30px rgba(0, 0, 0, .30), 0 0 16px rgba(255, 193, 7, .06);
}
html[data-theme="dark"] .kimo-card::before {
  background: radial-gradient(400px circle at var(--glow-x, 50%) var(--glow-y, 50%), rgba(255, 193, 7, .06), transparent 50%);
}
html[data-theme="dark"] .kimo-card-img {
  background: #1A1A2E;
  border-bottom-color: rgba(255, 255, 255, .04);
}
html[data-theme="dark"] .kimo-card-img img {
  mix-blend-mode: normal;
}
html[data-theme="dark"] .kimo-noimg {
  background: linear-gradient(135deg, #1A1A2E, #16162A);
  color: rgba(255, 193, 7, .20);
}
html[data-theme="dark"] .kimo-card-title {
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-card:hover .kimo-card-title {
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-price {
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-price strong {
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-tag {
  box-shadow: 1px 2px 6px rgba(0, 0, 0, .30), 0 0 0 1px rgba(255, 193, 7, .15);
}

/* ── Dark mode sold out ───────────────────────────────── */
html[data-theme="dark"] .kimo-sold-out-overlay {
  background: rgba(15, 15, 26, .70);
}

/* ── Dark mode buttons ────────────────────────────────── */
html[data-theme="dark"] .kimo-btn-ghost {
  background: transparent;
  color: var(--kimo-text-secondary);
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-btn-ghost:hover {
  background: rgba(255, 193, 7, .10);
  border-color: var(--kimo-accent);
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-btn-cta-outline {
  color: var(--kimo-accent);
  border-color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-btn-cta-outline:hover {
  background: rgba(255, 193, 7, .10);
}

/* ── Dark mode modal ──────────────────────────────────── */
html[data-theme="dark"] .kimo-modal {
  background: rgba(0, 0, 0, .50);
}
html[data-theme="dark"] .kimo-modal-card {
  background: #1A1A2E;
  box-shadow: 0 20px 60px rgba(0, 0, 0, .50);
}
html[data-theme="dark"] .kimo-modal-head {
  border-bottom-color: #2A2A40;
}
html[data-theme="dark"] .kimo-modal-close {
  background: #1A1A2E;
  border-color: #2A2A40;
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-modal-close:hover {
  background: rgba(255, 193, 7, .10);
  color: var(--kimo-accent);
  border-color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-modal-body .img {
  background: #16162A;
}

/* ── Dark mode sidebar / filters ──────────────────────── */
html[data-theme="dark"] .kimo-sidebar {
  background: #1A1A2E;
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-sidebar .form-control {
  background: #16162A;
  border-color: #2A2A40;
  color: var(--kimo-text);
}
/* ── Dark mode filter toggle ──────────────────────────── */
html[data-theme="dark"] .kimo-filter-toggle {
  background: #1A1A2E;
  border-color: #2A2A40;
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-filter-toggle:hover {
  background: rgba(255, 193, 7, .10);
  border-color: var(--kimo-accent);
  color: var(--kimo-accent);
}
/* ── Dark mode controls bar ───────────────────────────── */
html[data-theme="dark"] .kimo-controls {
  background: rgba(26, 26, 46, .85);
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-controls .kimo-left {
  color: var(--kimo-muted);
}
html[data-theme="dark"] .kimo-select {
  background-color: #16162A;
  border-color: #2A2A40;
  color: var(--kimo-text);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 5l3 3 3-3' fill='none' stroke='%238E8EA0' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
}
html[data-theme="dark"] .kimo-select:focus {
  border-color: var(--kimo-accent);
}
/* ── Dark mode comparison tray ────────────────────────── */
html[data-theme="dark"] .kimo-compare-tray {
  background: rgba(15, 15, 26, .96);
  border-top-color: var(--kimo-accent);
  box-shadow: 0 -8px 30px rgba(0, 0, 0, .30), 0 0 20px rgba(255, 193, 7, .03);
}
html[data-theme="dark"] .kimo-compare-tray-item {
  background: rgba(255, 193, 7, .08);
  border-color: rgba(255, 193, 7, .20);
  color: var(--kimo-text);
}
/* ── Dark mode share buttons ──────────────────────────── */
html[data-theme="dark"] .kimo-share-btn {
  background: #1A1A2E;
  border-color: #2A2A40;
  color: var(--kimo-text-secondary);
}
html[data-theme="dark"] .kimo-share-btn:hover {
  background: rgba(255, 193, 7, .10);
  border-color: var(--kimo-accent);
  color: var(--kimo-accent);
}

/* ── Dark mode toast ──────────────────────────────────── */
html[data-theme="dark"] .kimo-toast {
  background: #1A1A2E;
  color: var(--kimo-text);
  box-shadow: 0 8px 30px rgba(0, 0, 0, .40);
}

/* ── Dark mode back-to-top ────────────────────────────── */
html[data-theme="dark"] .kimo-back-to-top {
  background: #1A1A2E;
  border-color: #2A2A40;
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-back-to-top:hover {
  background: var(--kimo-accent);
  color: #1A1A2E;
}

/* ── Dark mode pagination ─────────────────────────────── */
html[data-theme="dark"] .kimo-pager-btn {
  background: #1A1A2E;
  border-color: #2A2A40;
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-pager-btn:hover:not(:disabled) {
  background: rgba(255, 193, 7, .10);
  border-color: var(--kimo-accent);
  color: var(--kimo-accent);
}

/* ── Dark mode gallery ────────────────────────────────── */
html[data-theme="dark"] .kimo-gallery-main {
  background: #1A1A2E;
}
html[data-theme="dark"] .kimo-gallery-slide img,
html[data-theme="dark"] .kimo-pdp-img {
  background: #1A1A2E;
}
html[data-theme="dark"] .kimo-gallery-thumb {
  background: #1A1A2E;
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-gallery-nav {
  background: #1A1A2E;
  border-color: #2A2A40;
  color: var(--kimo-text);
}

/* ── Dark mode skeleton ───────────────────────────────── */
html[data-theme="dark"] .kimo-skeleton {
  background: linear-gradient(90deg, #1A1A2E 25%, #22223A 50%, #1A1A2E 75%);
  background-size: 200% 100%;
}
html[data-theme="dark"] .kimo-skeleton-card {
  background: var(--kimo-surface);
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-skeleton-img,
html[data-theme="dark"] .kimo-skeleton-line {
  background: linear-gradient(90deg, #1A1A2E 25%, #22223A 50%, #1A1A2E 75%);
  background-size: 200% 100%;
}

/* ── Dark mode pill ───────────────────────────────────── */
html[data-theme="dark"] .kimo-pill {
  background: var(--kimo-accent-light);
  border-color: rgba(255, 193, 7, .25);
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-pill:hover {
  background: rgba(255, 193, 7, .15);
  color: var(--kimo-accent);
}

/* ── Dark mode cart ───────────────────────────────────── */
html[data-theme="dark"] .kimo-cart-table,
html[data-theme="dark"] .kimo-cart-item {
  background: #1A1A2E;
  border-color: #2A2A40;
  color: var(--kimo-text);
}

/* ── Dark mode tables ─────────────────────────────────── */
html[data-theme="dark"] table {
  border-color: #2A2A40;
}
html[data-theme="dark"] thead th {
  background: #16162A;
  color: var(--kimo-text);
  border-color: #2A2A40;
}
html[data-theme="dark"] tbody td {
  border-color: #2A2A40;
  color: var(--kimo-text-secondary);
}

/* ── Dark mode inputs ─────────────────────────────────── */
html[data-theme="dark"] .form-control,
html[data-theme="dark"] input[type="text"],
html[data-theme="dark"] input[type="email"],
html[data-theme="dark"] input[type="password"],
html[data-theme="dark"] input[type="number"],
html[data-theme="dark"] input[type="tel"],
html[data-theme="dark"] input[type="url"],
html[data-theme="dark"] textarea,
html[data-theme="dark"] select {
  background: #16162A;
  border-color: #2A2A40;
  color: var(--kimo-text);
}
html[data-theme="dark"] .form-control:focus,
html[data-theme="dark"] input:focus,
html[data-theme="dark"] textarea:focus,
html[data-theme="dark"] select:focus {
  border-color: var(--kimo-accent);
  box-shadow: 0 0 0 3px rgba(255, 193, 7, .08);
  background: #16162A;
  color: var(--kimo-text);
}

/* ── Dark Mode Toggle Button ──────────────────────────── */
.kimo-dark-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid #E8E8E8;
  background: #FFFFFF;
  color: var(--kimo-text);
  font-size: 18px;
  cursor: pointer;
  transition: all var(--kimo-duration-fast) var(--kimo-ease-smooth);
  box-shadow: 0 1px 4px rgba(0, 0, 0, .04);
}
.kimo-dark-toggle:hover {
  background: #FFF9E6;
  border-color: var(--kimo-accent);
  color: var(--kimo-primary-dark);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(255, 193, 7, .15);
}
html[data-theme="dark"] .kimo-dark-toggle {
  background: #1A1A2E;
  border-color: #2A2A40;
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-dark-toggle:hover {
  background: rgba(255, 193, 7, .10);
  border-color: var(--kimo-accent);
  transform: translateY(-2px);
}

/* ── Dark mode PDP ────────────────────────────────────── */
html[data-theme="dark"] .kimo-pdp-info {
  background: rgba(26, 26, 46, .85);
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-pdp-price-block {
  background: linear-gradient(135deg, #1A1A2E 0%, #16162A 60%, #1A1A2E 100%);
  border-color: rgba(255, 193, 7, .12);
}
html[data-theme="dark"] .kimo-pdp-short-desc {
  background: linear-gradient(135deg, #1A1A2E 0%, #16162A 50%, #1A1A2E 100%);
  border-left-color: var(--kimo-accent);
  color: var(--kimo-text-secondary);
}
html[dir="rtl"][data-theme="dark"] .kimo-pdp-short-desc {
  border-right-color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-pdp-trust {
  background: rgba(26, 26, 46, .70);
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-pdp-trust-item {
  background: #16162A;
  border-color: #2A2A40;
  color: var(--kimo-text-secondary);
}
html[data-theme="dark"] .kimo-pdp-tabs {
  background: #1A1A2E;
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-pdp-tab-headers {
  background: linear-gradient(180deg, #16162A, #1A1A2E);
  border-bottom-color: #2A2A40;
}
html[data-theme="dark"] .kimo-pdp-tab-btn {
  color: var(--kimo-muted);
}
html[data-theme="dark"] .kimo-pdp-tab-btn:hover {
  color: var(--kimo-accent);
  background: rgba(255, 193, 7, .08);
}
html[data-theme="dark"] .kimo-pdp-tab-btn.is-active {
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-pdp-tab-panel {
  color: var(--kimo-text-secondary);
}
html[data-theme="dark"] .kimo-spec-row {
  border-bottom-color: #2A2A40;
}
html[data-theme="dark"] .kimo-spec-row:hover {
  background: rgba(255, 193, 7, .04);
}
html[data-theme="dark"] .kimo-spec-label {
  background: #16162A;
  border-right-color: #2A2A40;
  color: var(--kimo-muted);
}
html[dir="rtl"][data-theme="dark"] .kimo-spec-label {
  border-left-color: #2A2A40;
}
html[data-theme="dark"] .kimo-spec-value {
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-pdp-quick-actions .kimo-pill {
  background: #16162A;
  border-color: #2A2A40;
  color: var(--kimo-text-secondary);
}
html[data-theme="dark"] .kimo-pdp-quick-actions .kimo-pill:hover {
  background: rgba(255, 193, 7, .10);
  border-color: var(--kimo-accent);
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-pdp-input,
html[data-theme="dark"] .kimo-pdp-textarea {
  background: #16162A;
  border-color: #2A2A40;
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-pdp-input:focus,
html[data-theme="dark"] .kimo-pdp-textarea:focus {
  border-color: var(--kimo-accent);
  box-shadow: 0 0 0 3px rgba(255, 193, 7, .08);
}

/* ── Dark mode footer ─────────────────────────────────── */
html[data-theme="dark"] .kimo-footer {
  background: var(--kimo-footer-bg) !important;
  color: var(--kimo-footer-text);
}
html[data-theme="dark"] .kimo-footer a {
  color: var(--kimo-text-secondary);
}
html[data-theme="dark"] .kimo-footer a:hover {
  color: var(--kimo-accent);
}


/* ═══════════════════════════════════════════════════════
   DARK MODE — Additional Overrides (from html.kimo-dark consolidation)
   ═══════════════════════════════════════════════════════ */

/* ── Dark mode compare bar ────────────────────────────── */
html[data-theme="dark"] .kimo-compare-bar {
  background: rgba(15, 15, 26, .98);
  border-top-color: var(--kimo-accent);
}

/* ── Dark mode lang menu ──────────────────────────────── */
html[data-theme="dark"] .kimo-lang-menu {
  background: rgba(26, 26, 46, .98);
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-lang-menu a {
  color: var(--kimo-text-secondary);
}
html[data-theme="dark"] .kimo-lang-menu a:hover {
  background: rgba(255, 193, 7, .08);
  color: var(--kimo-accent);
}

/* ── Dark mode newsletter ─────────────────────────────── */
html[data-theme="dark"] .kimo-news-form input {
  background: #16162A;
  border-color: #2A2A40;
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-news-form button {
  background: var(--kimo-accent);
  color: #1A1A2E;
}

/* ── Dark mode footer details ─────────────────────────── */
html[data-theme="dark"] .kimo-footer-trust {
  background: #12122A;
  border-color: rgba(255, 193, 7, .10);
}
html[data-theme="dark"] .kimo-footer-top {
  background: #0A0A14;
}
html[data-theme="dark"] .kimo-footer-cta {
  background: #12122A;
}
html[data-theme="dark"] .kimo-footer-pay {
  background: #0A0A14;
  border-color: rgba(255, 193, 7, .10);
}
html[data-theme="dark"] .kimo-footer-bottom {
  background: #08080F;
  border-color: rgba(255, 193, 7, .08);
}
html[data-theme="dark"] .kimo-footer-title {
  color: var(--kimo-accent);
}

/* ── Dark mode category cards ─────────────────────────── */
html[data-theme="dark"] .kimo-cat-card {
  background: #1A1A2E;
  border-color: #2A2A40;
}

/* ── Dark mode section accent ─────────────────────────── */
html[data-theme="dark"] .kimo-section-accent {
  background: var(--kimo-bg) !important;
}

/* ── Dark mode quantity controls ──────────────────────── */
html[data-theme="dark"] .kimo-qty-group {
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-qty-btn {
  background: #16162A;
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-qty-input {
  background: #1A1A2E;
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-pdp-qty-group {
  border-color: #2A2A40;
}

/* ── Dark mode rich text ──────────────────────────────── */
html[data-theme="dark"] .kimo-richtext {
  color: var(--kimo-text-secondary);
}

/* ── Dark mode card body ──────────────────────────────── */
html[data-theme="dark"] .kimo-card-body {
  background: transparent;
}

/* ── Dark mode card ATC overlay ───────────────────────── */
html[data-theme="dark"] .kimo-card-atc-overlay {
  background: linear-gradient(0deg, rgba(26, 26, 46, .97) 60%, rgba(26, 26, 46, .85) 80%, transparent 100%);
}

/* ── Dark mode card wish button ───────────────────────── */
html[data-theme="dark"] .kimo-card-wish-btn {
  background: rgba(26, 26, 46, .90);
  color: var(--kimo-muted);
  box-shadow: 0 2px 10px rgba(0, 0, 0, .25);
}
html[data-theme="dark"] .kimo-card-wish-btn:hover {
  background: var(--kimo-accent);
  color: #1A1A2E;
}
html[data-theme="dark"] .kimo-card-wish-btn.active {
  background: var(--kimo-danger);
  color: #FFFFFF;
}

/* ── Dark mode card rating ────────────────────────────── */
html[data-theme="dark"] .kimo-card-rating .kimo-rating-num {
  color: var(--kimo-text-secondary);
}
html[data-theme="dark"] .kimo-card-rating .kimo-rating-count {
  color: var(--kimo-text-faint);
}

/* ── Dark mode stock indicators ───────────────────────── */
html[data-theme="dark"] .kimo-stock.in {
  color: #4ADE80 !important;
  background: rgba(74, 222, 128, .10);
}
html[data-theme="dark"] .kimo-stock.out {
  color: #F87171 !important;
  background: rgba(248, 113, 113, .10);
}

/* ── Dark mode card overlay ───────────────────────────── */
html[data-theme="dark"] .kimo-card-overlay {
  background: linear-gradient(0deg, rgba(0, 0, 0, .70) 0%, rgba(0, 0, 0, .20) 50%, transparent 100%);
}

/* ── Dark mode marquee ────────────────────────────────── */
html[data-theme="dark"] .kimo-marquee-strip {
  color: #E4E4F0;
}

/* ── Dark mode topbar ─────────────────────────────────── */
html[data-theme="dark"] .kimo-topbar {
  background: linear-gradient(90deg, #B8860B, var(--kimo-accent), #DAA520, var(--kimo-accent), #B8860B);
  background-size: 200% 100%;
}
html[data-theme="dark"] .kimo-topbar a {
  color: #E4E4F0;
}

/* ── Dark mode search results (alt class names) ───────── */
html[data-theme="dark"] .kimo-search-result {
  border-bottom-color: #2A2A40;
}
html[data-theme="dark"] .kimo-search-result:hover {
  background: rgba(255, 193, 7, .06);
}
html[data-theme="dark"] .kimo-search-result-name {
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-search-result-price {
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-search-result-img {
  background: #16162A;
  border-color: #2A2A40;
}

/* ── Dark mode review cards ───────────────────────────── */
html[data-theme="dark"] .kimo-review-card {
  background: #1A1A2E;
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-review-form {
  background: #1A1A2E;
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-review-form input,
html[data-theme="dark"] .kimo-review-form textarea {
  background: #16162A;
  border-color: #2A2A40;
  color: var(--kimo-text);
}

/* ── Dark mode recent section ─────────────────────────── */
html[data-theme="dark"] .kimo-recent-card {
  background: #16162A;
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-recent-card:hover {
  border-color: rgba(255, 193, 7, .30);
  box-shadow: 0 8px 24px rgba(0, 0, 0, .25);
}
html[data-theme="dark"] .kimo-recent-card-name {
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-recent-card-price {
  color: var(--kimo-accent);
}

/* ── Dark mode search viewall/spinner ─────────────────── */
html[data-theme="dark"] .kimo-search-viewall {
  color: var(--kimo-accent);
  border-top-color: #2A2A40;
}
html[data-theme="dark"] .kimo-search-viewall:hover {
  background: rgba(255, 193, 7, .08);
}
html[data-theme="dark"] .kimo-search-spinner {
  border-color: #2A2A40;
  border-top-color: var(--kimo-accent);
}

/* ── Dark mode WhatsApp float ─────────────────────────── */
html[data-theme="dark"] .kimo-whatsapp-float {
  box-shadow: 0 4px 20px rgba(37, 211, 102, .25);
}

/* ── Dark mode scroll progress ────────────────────────── */
html[data-theme="dark"] .kimo-scroll-progress {
  box-shadow: 0 0 8px rgba(255, 193, 7, .20);
}

/* ── Dark mode card image brightness ──────────────────── */
html[data-theme="dark"] .kimo-card-img img {
  filter: brightness(.95);
}
html[data-theme="dark"] .kimo-card:hover .kimo-card-img img {
  filter: brightness(1.05);
}

/* ── Dark mode PDP short desc ─────────────────────────── */
html[data-theme="dark"] .kimo-pdp-short-desc {
  background: linear-gradient(135deg, #1A1A2E 0%, #1E1E36 50%, #1A1A2E 100%);
  border-left-color: var(--kimo-accent);
}

/* ── Smooth dark mode transition ──────────────────────── */
html[data-theme="dark"] body,
html[data-theme="dark"] .kimo-header,
html[data-theme="dark"] .kimo-card,
html[data-theme="dark"] .kimo-filters,
html[data-theme="dark"] .kimo-controls,
html[data-theme="dark"] .kimo-pdp-info,
html[data-theme="dark"] .kimo-pdp-tabs,
html[data-theme="dark"] .kimo-footer {
  transition: background-color .3s ease, color .3s ease, border-color .3s ease;
}

/* ═══════════════════════════════════════════════════════
   BREADCRUMB NAVIGATION
   ═══════════════════════════════════════════════════════ */
.kimo-breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0;
  padding: 14px 0;
  margin: 0;
  list-style: none;
  font-size: 13px;
  font-weight: 600;
}
.kimo-breadcrumb li {
  display: inline-flex;
  align-items: center;
  gap: 0;
}
.kimo-breadcrumb li + li::before {
  content: '/';
  display: inline-block;
  margin: 0 10px;
  color: var(--kimo-muted-gray);
  font-weight: 400;
}
.kimo-breadcrumb a {
  color: var(--kimo-text-secondary);
  text-decoration: none;
  transition: color var(--kimo-duration-fast);
  padding: 2px 0;
}
.kimo-breadcrumb a:hover {
  color: var(--kimo-accent);
}
.kimo-breadcrumb .kimo-breadcrumb-active {
  color: var(--kimo-accent);
  font-weight: 800;
  cursor: default;
}
/* RTL breadcrumb */
html[dir="rtl"] .kimo-breadcrumb {
  direction: rtl;
}
html[dir="rtl"] .kimo-breadcrumb li + li::before {
  content: '\\';
  margin: 0 10px;
}

/* ═══════════════════════════════════════════════════════
   RECENTLY VIEWED PRODUCTS
   ═══════════════════════════════════════════════════════ */
.kimo-recently-viewed {
  padding: 40px 0;
  position: relative;
}
.kimo-recently-viewed h2 {
  font-family: var(--kimo-font-heading);
  font-weight: 900;
  font-size: clamp(20px, 3vw, 32px);
  text-transform: uppercase;
  letter-spacing: -1px;
  margin-bottom: 20px;
  color: var(--kimo-text);
}
.kimo-recently-viewed-scroll {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-bottom: 8px;
}
.kimo-recently-viewed-scroll::-webkit-scrollbar { display: none; }
.kimo-rv-card {
  flex: 0 0 160px;
  scroll-snap-align: start;
  border-radius: 12px;
  border: 1px solid #EAEAEA;
  background: var(--kimo-surface-card);
  overflow: hidden;
  transition: all var(--kimo-duration-fast) var(--kimo-ease-smooth);
  text-decoration: none;
  color: var(--kimo-text);
}
.kimo-rv-card:hover {
  border-color: rgba(255, 193, 7, .25);
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, .06), 0 0 12px rgba(255, 193, 7, .04);
}
.kimo-rv-card-img {
  aspect-ratio: 1/1;
  overflow: hidden;
  background: #FFFFFF;
}
.kimo-rv-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--kimo-duration-normal) var(--kimo-ease-smooth);
}
.kimo-rv-card:hover .kimo-rv-card-img img {
  transform: scale(1.06);
}
.kimo-rv-card-body {
  padding: 10px;
}
.kimo-rv-card-title {
  font-size: 12px;
  font-weight: 700;
  line-height: 1.3;
  color: var(--kimo-text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-bottom: 4px;
}
.kimo-rv-card:hover .kimo-rv-card-title {
  color: var(--kimo-primary-dark);
}
.kimo-rv-card-price {
  font-weight: 900;
  font-size: 13px;
  color: var(--kimo-primary-dark);
}
/* Dark mode recently viewed */
html[data-theme="dark"] .kimo-rv-card {
  background: #16162A;
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-rv-card:hover {
  border-color: rgba(255, 193, 7, .30);
  box-shadow: 0 8px 24px rgba(0, 0, 0, .25), 0 0 12px rgba(255, 193, 7, .04);
}
html[data-theme="dark"] .kimo-rv-card-title {
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-rv-card:hover .kimo-rv-card-title {
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-rv-card-price {
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-rv-card-img {
  background: #1A1A2E;
}

/* ═══════════════════════════════════════════════════════
   PRODUCT COMPARISON TABLE
   ═══════════════════════════════════════════════════════ */
.kimo-compare-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--kimo-surface);
  border-radius: var(--kimo-radius);
  overflow: hidden;
  border: 1px solid var(--kimo-border);
}
.kimo-compare-header {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--kimo-surface-elevated);
  border-bottom: 2px solid var(--kimo-accent);
}
.kimo-compare-header th {
  padding: 16px 20px;
  font-family: var(--kimo-font-heading);
  font-weight: 900;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: .5px;
  text-align: center;
  color: var(--kimo-text);
}
.kimo-compare-cell {
  padding: 14px 20px;
  border-bottom: 1px solid var(--kimo-border);
  text-align: center;
  font-size: 14px;
  font-weight: 600;
  color: var(--kimo-text-secondary);
  transition: background var(--kimo-duration-fast);
  vertical-align: middle;
}
.kimo-compare-cell:first-child {
  text-align: left;
  font-weight: 800;
  color: var(--kimo-text);
  background: var(--kimo-surface-elevated);
  min-width: 140px;
}
.kimo-compare-table tr:hover .kimo-compare-cell {
  background: rgba(255, 193, 7, .03);
}
/* Highlight differences */
.kimo-compare-cell.kimo-compare-diff {
  background: rgba(255, 193, 7, .06);
  color: var(--kimo-primary-dark);
  font-weight: 800;
}
.kimo-compare-product-img {
  width: 80px;
  height: 80px;
  border-radius: 12px;
  object-fit: cover;
  margin: 0 auto 8px;
  display: block;
}
.kimo-compare-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid #EAEAEA;
  background: #FFFFFF;
  color: var(--kimo-danger);
  font-size: 14px;
  cursor: pointer;
  transition: all var(--kimo-duration-fast);
  margin-top: 4px;
}
.kimo-compare-remove:hover {
  background: var(--kimo-danger);
  color: #FFFFFF;
  border-color: var(--kimo-danger);
}
/* Dark mode comparison */
html[data-theme="dark"] .kimo-compare-table {
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-compare-header {
  background: #16162A;
}
html[data-theme="dark"] .kimo-compare-header th {
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-compare-cell {
  border-bottom-color: #2A2A40;
  color: var(--kimo-text-secondary);
}
html[data-theme="dark"] .kimo-compare-cell:first-child {
  background: #16162A;
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-compare-table tr:hover .kimo-compare-cell {
  background: rgba(255, 193, 7, .04);
}
html[data-theme="dark"] .kimo-compare-cell.kimo-compare-diff {
  background: rgba(255, 193, 7, .08);
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-compare-remove {
  background: #1A1A2E;
  border-color: #2A2A40;
}
/* Responsive comparison */
@media (max-width: 768px) {
  .kimo-compare-table {
    display: block;
    overflow-x: auto;
    scrollbar-width: thin;
  }
}

/* ═══════════════════════════════════════════════════════
   404 PAGE — Creative Design
   ═══════════════════════════════════════════════════════ */
.kimo-404 {
  min-height: 80vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 60px 20px;
  position: relative;
  overflow: hidden;
}
.kimo-404::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(255, 193, 7, .06) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 50%, rgba(255, 215, 0, .04) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 80%, rgba(255, 193, 7, .03) 0%, transparent 50%);
  animation: kimo404Float 8s ease-in-out infinite;
  pointer-events: none;
  z-index: 0;
}
.kimo-404-number {
  font-family: var(--kimo-font-heading);
  font-size: clamp(120px, 25vw, 280px);
  font-weight: 900;
  line-height: .85;
  background: linear-gradient(135deg, var(--kimo-accent), var(--kimo-gold), var(--kimo-primary-dark));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: kimo404Pulse 3s ease-in-out infinite;
  position: relative;
  z-index: 1;
  user-select: none;
}
.kimo-404-title {
  font-family: var(--kimo-font-heading);
  font-size: clamp(24px, 4vw, 48px);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -1px;
  color: var(--kimo-text);
  margin-top: 16px;
  position: relative;
  z-index: 1;
}
.kimo-404-text {
  font-size: 16px;
  font-weight: 600;
  color: var(--kimo-muted);
  max-width: 500px;
  margin: 16px auto 0;
  position: relative;
  z-index: 1;
}
.kimo-404-cta {
  margin-top: 32px;
  position: relative;
  z-index: 1;
}
/* Dark mode 404 */
html[data-theme="dark"] .kimo-404::before {
  background:
    radial-gradient(ellipse at 20% 50%, rgba(255, 193, 7, .04) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 50%, rgba(255, 215, 0, .03) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 80%, rgba(255, 193, 7, .02) 0%, transparent 50%);
}
html[data-theme="dark"] .kimo-404-title {
  color: var(--kimo-text);
}

/* ═══════════════════════════════════════════════════════

.kimo-search-result-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 18px;
  cursor: pointer;
  transition: background var(--kimo-duration-fast);
  text-decoration: none;
  color: var(--kimo-text);
  border-bottom: 1px solid #F0F0F0;
}
.kimo-search-result-item:last-child {
  border-bottom: none;
}
.kimo-search-result-item:hover {
  background: rgba(255, 193, 7, .05);
}
.kimo-search-result-img {
  width: 48px;
  height: 48px;
  border-radius: 10px;
  object-fit: cover;
  flex-shrink: 0;
  background: #FFFFFF;
  border: 1px solid #EAEAEA;
}
.kimo-search-result-info {
  flex: 1;
  min-width: 0;
}
.kimo-search-result-name {
  font-weight: 700;
  font-size: 13px;
  color: var(--kimo-text);
  line-height: 1.3;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.kimo-search-result-name mark {
  background: rgba(255, 193, 7, .20);
  color: var(--kimo-primary-dark);
  font-weight: 800;
  border-radius: 2px;
  padding: 0 2px;
}
.kimo-search-result-price {
  font-weight: 900;
  font-size: 14px;
  color: var(--kimo-primary-dark);
  margin-top: 2px;
}
/* Search loading state */
.kimo-search-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  gap: 8px;
  color: var(--kimo-muted);
  font-weight: 700;
  font-size: 13px;
}
.kimo-search-loading::after {
  content: '';
  width: 18px;
  height: 18px;
  border: 2px solid #EAEAEA;
  border-top-color: var(--kimo-accent);
  border-radius: 50%;
  animation: kimoSearchSpinner .6s linear infinite;
}
.kimo-search-empty {
  padding: 28px;
  text-align: center;
  color: var(--kimo-muted);
  font-weight: 700;
  font-size: 13px;
}
/* Dark mode search dropdown */
html[data-theme="dark"] .kimo-search-dropdown {
  background: #1A1A2E;
  border-color: #2A2A40;
  box-shadow: 0 12px 40px rgba(0, 0, 0, .40);
}
html[data-theme="dark"] .kimo-search-result-item {
  color: var(--kimo-text);
  border-bottom-color: #2A2A40;
}
html[data-theme="dark"] .kimo-search-result-item:hover {
  background: rgba(255, 193, 7, .06);
}
html[data-theme="dark"] .kimo-search-result-name {
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-search-result-name mark {
  background: rgba(255, 193, 7, .20);
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-search-result-img {
  background: #16162A;
  border-color: #2A2A40;
}
html[data-theme="dark"] .kimo-search-result-price {
  color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-search-loading::after {
  border-color: #2A2A40;
  border-top-color: var(--kimo-accent);
}

/* ═══════════════════════════════════════════════════════
   IMPROVED FILTER SIDEBAR
   ═══════════════════════════════════════════════════════ */
.kimo-filter-section {
  margin-bottom: 20px;
  border-bottom: 1px solid #EAEAEA;
  padding-bottom: 16px;
}
.kimo-filter-section:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}
.kimo-filter-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  padding: 8px 0;
  user-select: none;
  transition: color var(--kimo-duration-fast);
}
.kimo-filter-section-header:hover {
  color: var(--kimo-accent);
}
.kimo-filter-section-title {
  font-family: var(--kimo-font-heading);
  font-weight: 900;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--kimo-text);
}
.kimo-filter-section-toggle {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  color: var(--kimo-muted);
  transition: transform var(--kimo-duration-normal) var(--kimo-ease-smooth);
}
.kimo-filter-section.kimo-filter-collapsed .kimo-filter-section-toggle {
  transform: rotate(-90deg);
}
.kimo-filter-section-body {
  padding-top: 10px;
  overflow: hidden;
  transition: max-height var(--kimo-duration-normal) var(--kimo-ease-smooth), opacity var(--kimo-duration-normal);
  max-height: 500px;
  opacity: 1;
}
.kimo-filter-section.kimo-filter-collapsed .kimo-filter-section-body {
  max-height: 0;
  opacity: 0;
  padding-top: 0;
}

/* ── Price Range Slider ───────────────────────────────── */
.kimo-price-range {
  padding: 8px 0;
}
.kimo-price-range-track {
  position: relative;
  height: 6px;
  background: #EAEAEA;
  border-radius: 999px;
  margin: 12px 0;
}
.kimo-price-range-fill {
  position: absolute;
  height: 100%;
  background: linear-gradient(90deg, var(--kimo-accent), var(--kimo-gold));
  border-radius: 999px;
}
.kimo-price-range-thumb {
  position: absolute;
  top: 50%;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #FFFFFF;
  border: 3px solid var(--kimo-accent);
  transform: translate(-50%, -50%);
  cursor: grab;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .10);
  transition: box-shadow var(--kimo-duration-fast), transform var(--kimo-duration-fast);
  z-index: 2;
}
.kimo-price-range-thumb:hover,
.kimo-price-range-thumb:active {
  box-shadow: 0 2px 12px rgba(255, 193, 7, .30);
  transform: translate(-50%, -50%) scale(1.15);
}
.kimo-price-range-thumb:active {
  cursor: grabbing;
}
.kimo-price-range-inputs {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
}
.kimo-price-range-inputs input {
  width: 100%;
  height: 36px;
  border: 1px solid #E2E2E2;
  border-radius: var(--kimo-input-radius);
  padding: 0 10px;
  font-size: 13px;
  font-weight: 700;
  text-align: center;
  background: #FFFFFF;
  color: var(--kimo-text);
  transition: border-color var(--kimo-duration-fast);
}
.kimo-price-range-inputs input:focus {
  border-color: var(--kimo-accent);
  outline: none;
  box-shadow: 0 0 0 3px rgba(255, 193, 7, .08);
}
.kimo-price-range-inputs span {
  color: var(--kimo-muted);
  font-weight: 700;
}

/* ── Color Swatches ───────────────────────────────────── */
.kimo-color-swatches {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 6px 0;
}
.kimo-color-swatch {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 3px solid transparent;
  cursor: pointer;
  transition: all var(--kimo-duration-fast) var(--kimo-ease-smooth);
  position: relative;
  outline-offset: 2px;
}
.kimo-color-swatch:hover {
  transform: scale(1.15);
  box-shadow: 0 2px 10px rgba(0, 0, 0, .15);
}
.kimo-color-swatch.kimo-color-active {
  border-color: var(--kimo-accent);
  box-shadow: 0 0 0 2px var(--kimo-accent-glow);
}
.kimo-color-swatch::after {
  content: '✓';
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 900;
  color: #FFFFFF;
  opacity: 0;
  transition: opacity var(--kimo-duration-fast);
  text-shadow: 0 1px 3px rgba(0, 0, 0, .30);
}
.kimo-color-swatch.kimo-color-active::after {
  opacity: 1;
}

/* ── Better Checkbox / Radio ───────────────────────────── */
.kimo-filter-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 0;
  cursor: pointer;
  font-weight: 600;
  font-size: 13px;
  color: var(--kimo-text-secondary);
  transition: color var(--kimo-duration-fast);
}
.kimo-filter-option:hover {
  color: var(--kimo-accent);
}
.kimo-filter-checkbox {
  position: relative;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}
.kimo-filter-checkbox input {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
  z-index: 1;
}
.kimo-filter-checkbox .kimo-checkmark {
  position: absolute;
  inset: 0;
  border: 2px solid #D0D0D0;
  border-radius: 6px;
  background: #FFFFFF;
  transition: all var(--kimo-duration-fast) var(--kimo-ease-smooth);
}
.kimo-filter-checkbox input:checked + .kimo-checkmark {
  background: var(--kimo-accent);
  border-color: var(--kimo-accent);
}
.kimo-filter-checkbox input:checked + .kimo-checkmark::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 6px;
  width: 5px;
  height: 9px;
  border: solid #1A1A2E;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.kimo-filter-checkbox input:focus + .kimo-checkmark {
  box-shadow: 0 0 0 3px rgba(255, 193, 7, .15);
}
.kimo-filter-radio .kimo-checkmark {
  border-radius: 50%;
}
.kimo-filter-radio input:checked + .kimo-checkmark::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #1A1A2E;
  transform: translate(-50%, -50%);
  border: none;
}
.kimo-filter-count {
  font-size: 11px;
  color: var(--kimo-muted);
  font-weight: 600;
  margin-left: auto;
}

/* Dark mode filters */
html[data-theme="dark"] .kimo-filter-section {
  border-bottom-color: #2A2A40;
}
html[data-theme="dark"] .kimo-filter-section-title {
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-price-range-track {
  background: #2A2A40;
}
html[data-theme="dark"] .kimo-price-range-thumb {
  background: #16162A;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .30);
}
html[data-theme="dark"] .kimo-price-range-inputs input {
  background: #16162A;
  border-color: #2A2A40;
  color: var(--kimo-text);
}
html[data-theme="dark"] .kimo-filter-checkbox .kimo-checkmark {
  background: #16162A;
  border-color: #3A3A55;
}
html[data-theme="dark"] .kimo-filter-checkbox input:checked + .kimo-checkmark {
  background: var(--kimo-accent);
  border-color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-filter-option {
  color: var(--kimo-text-secondary);
}
html[data-theme="dark"] .kimo-filter-option:hover {
  color: var(--kimo-accent);
}

/* ═══════════════════════════════════════════════════════
   GENERAL IMPROVEMENTS
   ═══════════════════════════════════════════════════════ */

/* ── Better Form Controls ─────────────────────────────── */
.form-control,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="url"],
textarea,
select {
  border-radius: var(--kimo-input-radius);
  border: 1px solid #E2E2E2;
  background: #FFFFFF;
  font-weight: 600;
  font-size: 14px;
  color: var(--kimo-text);
  padding: 10px 14px;
  transition: border-color var(--kimo-duration-fast), box-shadow var(--kimo-duration-fast), background var(--kimo-duration-fast);
}
.form-control:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
textarea:focus,
select:focus {
  border-color: var(--kimo-accent);
  box-shadow: 0 0 0 4px rgba(255, 193, 7, .08);
  outline: none;
}
.form-control::placeholder {
  color: var(--kimo-text-faint);
}

/* ── Better Focus States (Accessibility) ──────────────── */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
  outline: 2px solid var(--kimo-accent);
  outline-offset: 2px;
  border-radius: 4px;
}
.kimo-btn:focus-visible,
.kimo-btn-cta:focus-visible,
.kimo-btn-ghost:focus-visible {
  outline: 2px solid var(--kimo-accent);
  outline-offset: 2px;
}
.kimo-icbtn:focus-visible,
.kimo-dark-toggle:focus-visible {
  outline: 2px solid var(--kimo-accent);
  outline-offset: 2px;
}

/* ── Smoother Transitions ─────────────────────────────── */
*,
*::before,
*::after {
  transition-timing-function: var(--kimo-ease-smooth, cubic-bezier(.4, 0, .2, 1));
}

/* ── Improved Mobile Responsiveness ───────────────────── */
@media (max-width: 576px) {
  .kimo-section { padding: 40px 0; }
  .kimo-section-header { margin-bottom: 24px; }
  .kimo-card-body { padding: 12px; }
  .kimo-card-title { font-size: 13px; height: 35px; }
  .kimo-price { font-size: 14px; }
  .kimo-btn-cta { padding: 10px 20px; font-size: 13px; }
  .kimo-modal-card { border-radius: 16px; width: 96%; }
  .kimo-modal-body { padding: 18px; }
  .kimo-breadcrumb { font-size: 12px; }
  .kimo-404-number { font-size: 100px; }
  .kimo-404-title { font-size: 20px; }
  .kimo-404-text { font-size: 14px; }
  .kimo-rv-card { flex: 0 0 130px; }
  .kimo-search-dropdown { border-radius: 12px; }
  .kimo-search-result-item { padding: 10px 14px; }
  .kimo-search-result-img { width: 40px; height: 40px; }
  .kimo-sidebar { padding: 14px; }
}

/* ── Selection color ──────────────────────────────────── */
::selection {
  background: rgba(255, 193, 7, .20);
  color: var(--kimo-text);
}

/* ── Scrollbar styling ────────────────────────────────── */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, .12);
  border-radius: 999px;
}
::-webkit-scrollbar-thumb:hover {
  background: rgba(0, 0, 0, .20);
}
html[data-theme="dark"] ::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, .12);
}
html[data-theme="dark"] ::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, .20);
}

/* ── Skip to content (Accessibility) ──────────────────── */
.kimo-skip-link {
  position: fixed;
  top: -100px;
  left: 16px;
  z-index: 99999;
  padding: 10px 20px;
  background: var(--kimo-accent);
  color: #1A1A2E;
  font-weight: 900;
  font-size: 14px;
  border-radius: 0 0 10px 10px;
  transition: top var(--kimo-duration-fast);
}
.kimo-skip-link:focus {
  top: 0;
}

/* ── Product Comparison ────────────────────────────────── */
.kimo-compare-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 2500;
  background: rgba(255, 255, 255, .98);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-top: 2px solid var(--kimo-accent);
  box-shadow: 0 -4px 30px rgba(0, 0, 0, .10);
  padding: 12px 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  animation: kimoSlideUpStagger .3s var(--kimo-ease-out-expo);
}
/* dark mode: see html[data-theme="dark"] .kimo-compare-bar in dark mode section */
.kimo-compare-items { display: flex; gap: 10px; flex: 1; overflow-x: auto; }
.kimo-compare-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border: 1px solid var(--kimo-border);
  border-radius: 12px;
  background: var(--kimo-surface);
  white-space: nowrap;
  min-width: 0;
}
.kimo-compare-item img {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  object-fit: cover;
}
.kimo-compare-item-name { font-weight: 700; font-size: 12px; max-width: 120px; overflow: hidden; text-overflow: ellipsis; }
.kimo-compare-item-remove {
  width: 24px; height: 24px;
  border-radius: 6px;
  border: none;
  background: rgba(239, 68, 68, .08);
  color: var(--kimo-danger);
  font-size: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .15s ease;
  flex-shrink: 0;
}
.kimo-compare-item-remove:hover { background: rgba(239, 68, 68, .15); transform: scale(1.1); }
.kimo-compare-bar .kimo-btn { flex-shrink: 0; }

/* Comparison Modal */
.kimo-compare-modal-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}
.kimo-compare-modal-table th {
  background: var(--kimo-accent);
  color: #1A1A2E;
  font-family: var(--kimo-font-heading);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .5px;
  font-size: 12px;
  padding: 14px 16px;
  text-align: center;
  position: sticky;
  top: 0;
}
.kimo-compare-modal-table td {
  padding: 16px;
  text-align: center;
  border-bottom: 1px solid var(--kimo-border);
  vertical-align: middle;
}
.kimo-compare-modal-table tr:hover td { background: rgba(255, 193, 7, .03); }
.kimo-compare-modal-img { width: 80px; height: 80px; border-radius: 12px; object-fit: cover; margin: 0 auto; }

/* ── Reviews / Ratings ─────────────────────────────────── */
/* .kimo-stars base is defined in product cards section — Reviews use larger size */
.kimo-stars { font-size: 16px; gap: 2px; }
.kimo-star { color: #D0D0D0; transition: color .15s ease; }
.kimo-star.filled { color: #FFC107; }
.kimo-star.half { position: relative; color: #D0D0D0; }
.kimo-star.half::before {
  content: '\2605';
  position: absolute;
  left: 0;
  top: 0;
  width: 50%;
  overflow: hidden;
  color: #FFC107;
}
.kimo-rating-num {
  font-weight: 900;
  font-size: 14px;
  color: var(--kimo-primary-dark);
  margin-left: 6px;
}
.kimo-review-card {
  padding: 18px;
  border: 1px solid var(--kimo-border);
  border-radius: var(--kimo-radius);
  background: var(--kimo-surface);
  margin-bottom: 12px;
  transition: all .2s ease;
}
.kimo-review-card:hover { border-color: rgba(255, 193, 7, .20); box-shadow: 0 4px 16px rgba(0, 0, 0, .04); }
.kimo-review-header { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 8px; }
.kimo-review-name { font-weight: 800; font-size: 14px; color: var(--kimo-text); }
.kimo-review-date { font-size: 12px; color: var(--kimo-muted); }
.kimo-review-comment { font-size: 14px; line-height: 1.7; color: var(--kimo-text-secondary); }
.kimo-review-form { margin-top: 24px; padding: 20px; border: 1px solid var(--kimo-border); border-radius: var(--kimo-radius); background: var(--kimo-surface); }
.kimo-review-form h4 { margin: 0 0 14px; font-size: 16px; font-weight: 900; }
.kimo-star-input { display: inline-flex; gap: 4px; font-size: 24px; cursor: pointer; margin-bottom: 12px; }
.kimo-star-input .kimo-star { cursor: pointer; transition: all .15s ease; }
.kimo-star-input .kimo-star:hover { transform: scale(1.2); }
.kimo-review-form input,
.kimo-review-form textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid var(--kimo-border);
  border-radius: var(--kimo-input-radius);
  background: var(--kimo-bg);
  color: var(--kimo-text);
  font-family: var(--kimo-font-body);
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 10px;
  transition: border-color .15s ease;
}
.kimo-review-form input:focus,
.kimo-review-form textarea:focus { border-color: var(--kimo-accent); outline: none; box-shadow: 0 0 0 3px rgba(255, 193, 7, .10); }
.kimo-review-form textarea { min-height: 80px; resize: vertical; }
.kimo-reviews-section { margin-top: 28px; }
.kimo-reviews-summary { display: flex; align-items: center; gap: 16px; margin-bottom: 20px; }
.kimo-reviews-avg { font-family: var(--kimo-font-heading); font-weight: 900; font-size: 36px; color: var(--kimo-primary-dark); }
.kimo-reviews-count { font-size: 13px; color: var(--kimo-muted); font-weight: 700; }
.kimo-404-particles {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}
.kimo-404-particle {
  position: absolute;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--kimo-accent);
  opacity: .15;
  animation: kimoFloat 4s ease-in-out infinite;
}

/* ── Recently Viewed Section ───────────────────────────── */
.kimo-recent-section { padding: 40px 0; }
.kimo-recent-scroll {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  padding-bottom: 8px;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 193, 7, .20) transparent;
}
.kimo-recent-scroll::-webkit-scrollbar { height: 4px; }
.kimo-recent-scroll::-webkit-scrollbar-thumb { background: rgba(255, 193, 7, .20); border-radius: 999px; }
.kimo-recent-card {
  min-width: 180px;
  max-width: 200px;
  border: 1px solid var(--kimo-border);
  border-radius: var(--kimo-radius);
  overflow: hidden;
  background: var(--kimo-surface);
  transition: all .2s ease;
  flex-shrink: 0;
}
.kimo-recent-card:hover { border-color: rgba(255, 193, 7, .25); transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0, 0, 0, .06); }
.kimo-recent-card img { width: 100%; aspect-ratio: 1/1; object-fit: cover; }
.kimo-recent-card-body { padding: 10px; }
.kimo-recent-card-name { font-weight: 700; font-size: 12px; line-height: 1.35; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; margin-bottom: 6px; }
.kimo-recent-card-price { font-weight: 800; font-size: 13px; color: var(--kimo-primary-dark); }
.kimo-recent-clear { font-size: 12px; font-weight: 800; color: var(--kimo-muted); background: none; border: none; cursor: pointer; text-decoration: underline; transition: color .15s ease; }
.kimo-recent-clear:hover { color: var(--kimo-danger); }

/* ── Enhanced Product Card Hover Actions ───────────────── */
.kimo-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(0,0,0,.60) 0%, rgba(0,0,0,.10) 50%, transparent 100%);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 14px;
  opacity: 0;
  transition: opacity .3s ease;
  z-index: 2;
  /* Prevent overlay from intercepting clicks meant for parent link */
  pointer-events: none;
}
.kimo-card:hover .kimo-card-overlay { opacity: 1; }
.kimo-card-overlay-actions {
  display: flex;
  gap: 8px;
  animation: kimoSlideOverlay .3s var(--kimo-ease-out-expo);
  /* Only the action buttons inside are clickable */
  pointer-events: auto;
}
.kimo-card-overlay-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, .95);
  color: #1A1A2E;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .15s ease;
  box-shadow: 0 2px 10px rgba(0, 0, 0, .15);
}
.kimo-card-overlay-btn:hover { background: var(--kimo-accent); transform: translateY(-3px) scale(1.1); box-shadow: 0 4px 16px rgba(255, 193, 7, .30); }

/* ── Stock Indicator Dot ────────────────────────────────── */
.kimo-stock-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 6px;
  animation: kimoDotPulse 2s infinite;
}
.kimo-stock-dot.in { background: var(--kimo-success); }
.kimo-stock-dot.out { background: var(--kimo-danger); animation: none; }

/* ── Lazy Load Blur-up ─────────────────────────────────── */
img[data-src] { filter: blur(10px); transition: filter .4s ease; }
img[data-src].kimo-loaded { filter: blur(0); }
.kimo-lazy-animate { opacity: 0; transform: scale(.96); transition: opacity .4s ease, transform .4s ease; }
.kimo-lazy-animate.kimo-loaded { opacity: 1; transform: scale(1); }

/* ── RTL additions for new components ──────────────────── */
html[dir="rtl"] .kimo-compare-items { flex-direction: row-reverse; }
html[dir="rtl"] .kimo-card-overlay-actions { flex-direction: row-reverse; }
html[dir="rtl"] .kimo-rating-num { margin-left: 0; margin-right: 6px; }
html[dir="rtl"] .kimo-card-rating .kimo-rating-count { margin-left: 0; margin-right: 2px; }

/* ── Mobile responsive for new components ──────────────── */
@media (max-width: 992px) {
  .kimo-search-dropdown { min-width: 280px; }
  .kimo-compare-bar { padding: 10px 16px; }
  .kimo-compare-item-name { max-width: 80px; }
}
@media (max-width: 768px) {
  .kimo-compare-bar { flex-wrap: wrap; }
  .kimo-compare-items { width: 100%; }
  .kimo-404-number { font-size: clamp(80px, 18vw, 160px); }
  .kimo-review-form { padding: 14px; }
  .kimo-recent-card { min-width: 150px; max-width: 170px; }
}
@media (max-width: 420px) {
  .kimo-search-dropdown { min-width: 240px; }
  .kimo-recent-card { min-width: 130px; }
}

/* ═══════════════════════════════════════════════════════
   PDP GALLERY — Enhancements (merged into base above)
   ═══════════════════════════════════════════════════════ */
.kimo-gallery {
  border: 1px solid var(--kimo-border);
  border-radius: var(--kimo-radius);
  background: var(--kimo-surface);
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(0, 0, 0, .04);
}
.kimo-gallery-slide:not(.is-active) { display: none; }
.kimo-gallery-thumbs {
  background: var(--kimo-bg-darker);
  border-top: 1px solid var(--kimo-border);
  max-height: 74px;
}
.kimo-gallery-slide-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
}
html[dir="rtl"] .kimo-gallery-nav.prev { left: auto; right: 10px; }
html[dir="rtl"] .kimo-gallery-nav.next { right: auto; left: 10px; }

/* ═══════════════════════════════════════════════════════
   WHATSAPP FLOAT — Yellow accent
   ═══════════════════════════════════════════════════════ */
.kimo-whatsapp-float {
  position: fixed;
  bottom: 28px;
  left: 28px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--kimo-whatsapp, #25D366);
  color: #FFFFFF;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(37, 211, 102, .30);
  z-index: 9998;
  transition: all .25s ease;
  text-decoration: none;
  animation: kimoFloat 3s ease-in-out infinite;
}
.kimo-whatsapp-float:hover {
  transform: scale(1.12);
  box-shadow: 0 6px 28px rgba(37, 211, 102, .40);
}
html[dir="rtl"] .kimo-whatsapp-float { left: auto; right: 28px; }

/* ═══════════════════════════════════════════════════════
   PDP GRID — Better proportions
   ═══════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .kimo-pdp-grid {
    grid-template-columns: 1fr !important;
  }
  .kimo-pdp-img {
    max-height: 280px;
  }
  .kimo-gallery-main {
    max-height: 300px;
  }
}

/* ═══════════════════════════════════════════════════════
   SCROLL PROGRESS BAR — Top of page
   ═══════════════════════════════════════════════════════ */
.kimo-scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--kimo-accent), var(--kimo-gold));
  z-index: 9999;
  transition: width .1s linear;
  box-shadow: 0 0 8px rgba(255, 193, 7, .30);
}

/* ═══════════════════════════════════════════════════════
   CATEGORY CARD HOVER — Yellow border accent
   ═══════════════════════════════════════════════════════ */
.kimo-cat-card:hover {
  border-color: var(--kimo-accent) !important;
  box-shadow: 0 8px 28px rgba(255, 193, 7, .12);
}
.kimo-cat-card .kimo-card-img {
  border-radius: 50%;
  border: 2px solid transparent;
  transition: border-color .3s ease;
  aspect-ratio: 1/1;
}
.kimo-cat-card:hover .kimo-card-img {
  border-color: var(--kimo-accent);
}

/* ═══════════════════════════════════════════════════════
   IMAGE ZOOM — Hover effect on PDP gallery
   ═══════════════════════════════════════════════════════ */
.kimo-gallery-slide img:hover,
.kimo-pdp-img:hover {
  cursor: zoom-in;
  transform: scale(1.05);
  transition: transform .3s ease;
}

/* ═══════════════════════════════════════════════════════
   STICKY CONTROLS BAR — All Products page
   ═══════════════════════════════════════════════════════ */
.kimo-controls-sticky {
  position: sticky;
  top: 80px;
  z-index: 50;
}

/* ═══════════════════════════════════════════════════════
   V14 IMPROVEMENTS — Better Card Consistency & Polish
   ═══════════════════════════════════════════════════════ */

/* ── Consistent Card Heights ─────────────────────────── */
.kimo-card {
  min-height: 0;
}
.kimo-card-body {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}
.kimo-card-body .kimo-price {
  margin-top: auto;
}
.kimo-card-body .kimo-actions-row {
  margin-top: auto;
}

/* ── Better Mobile Card Hover ────────────────────────── */
@media (max-width: 768px) {
  .kimo-card:hover {
    transform: translateY(-3px);
  }
  .kimo-card-wish-btn {
    opacity: .9;
    transform: scale(1);
  }
  .kimo-card-atc-overlay {
    opacity: 0;
    transform: translateY(100%);
    pointer-events: none;
  }
  .kimo-card:focus-within .kimo-card-atc-overlay,
  .kimo-card.touched .kimo-card-atc-overlay {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
  .kimo-card:focus-within .kimo-card-atc-overlay .kimo-btn,
  .kimo-card.touched .kimo-card-atc-overlay .kimo-btn {
    pointer-events: auto;
  }
  .kimo-actions-row {
    opacity: 1;
    transform: translateY(0);
  }
  .kimo-card-title {
    font-size: 12px;
    min-height: 36px;
    max-height: 36px;
  }
  .kimo-price {
    font-size: 14px;
  }
  .kimo-price strong {
    font-size: 15px;
  }
}

/* ── Better Product Listing Grid ─────────────────────── */
@media (min-width: 1200px) {
  .kimo-grid {
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  }
}

/* ── Improved Skeleton Loading ───────────────────────── */
.kimo-skeleton-card {
  min-height: 300px;
}

/* ── Better Dark Mode Cards ──────────────────────────── */
html[data-theme="dark"] .kimo-card-img {
  background: #1A1A2E;
}
html[data-theme="dark"] .kimo-card-img img {
  filter: brightness(.95);
}
html[data-theme="dark"] .kimo-card:hover .kimo-card-img img {
  filter: brightness(1.05);
}

/* ── Better Description Box in Dark Mode ─────────────── */
html[data-theme="dark"] .kimo-pdp-short-desc {
  background: linear-gradient(135deg, #1A1A2E 0%, #1E1E36 50%, #1A1A2E 100%);
  border-left-color: var(--kimo-accent);
}
html[data-theme="dark"] .kimo-richtext {
  color: var(--kimo-text-secondary);
}

/* ── Smoother Card Transitions ───────────────────────── */
.kimo-card {
  will-change: transform, box-shadow;
}
.kimo-card-img img {
  will-change: transform;
}

/* ── Better Trust Features Layout ────────────────────── */
@media (max-width: 768px) {
  .kimo-pdp-trust {
    flex-wrap: wrap;
  }
  .kimo-pdp-trust-item {
    flex: 1 1 auto;
    min-width: calc(50% - 8px);
  }
}

/* ── Price Display Improvements ──────────────────────── */
.kimo-price strong {
  letter-spacing: -.3px;
}
.kimo-price del {
  vertical-align: baseline;
}
