/*
Theme Name: Kicks Laundry
Theme URI: https://kickslaundry.example.com
Author: Lovable
Author URI: https://lovable.dev
Description: A premium WordPress theme for sneaker cleaning & restoration services. Minimalist luxury aesthetic with bold typography, before/after showcases, WooCommerce-ready service packages, multi-step booking, drop-off locations, and an app-like mobile experience with bottom navigation. Inspired by thesneakershack.co.za and walkfresh.co.za.
Version: 1.7.9
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: kicks-laundry
Tags: business, e-commerce, portfolio, custom-logo, custom-menu, featured-images, full-width-template, theme-options, threaded-comments, translation-ready
*/

/* =============================================================
   DESIGN TOKENS — Minimalist luxury, urban-professional
   White / Black with Electric Blue accent
   ============================================================= */
:root {
  --kl-bg: #ffffff;
  --kl-fg: #0a0a0a;
  --kl-muted: #6b6b6b;
  --kl-line: #e8e8e8;
  --kl-surface: #f6f6f6;
  --kl-accent: #2563ff;     /* Electric Blue */
  --kl-accent-2: #3dffb1;   /* Mint pop for hover */
  --kl-black: #0a0a0a;
  --kl-shadow: 0 20px 50px -20px rgba(10,10,10,.18);
  --kl-radius: 14px;
  --kl-radius-sm: 8px;
  --kl-container: 1240px;
  --kl-font-display: "Archivo", "Montserrat", system-ui, -apple-system, sans-serif;
  --kl-font-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --kl-ease: cubic-bezier(.2,.7,.2,1);
}

/* =============================================================
   RESET / BASE
   ============================================================= */
*,*::before,*::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--kl-bg);
  color: var(--kl-fg);
  font-family: var(--kl-font-body);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color .2s var(--kl-ease); }
a:hover { color: var(--kl-accent); }
h1,h2,h3,h4,h5 {
  font-family: var(--kl-font-display);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0 0 .5em;
}
h1 { font-size: clamp(2.4rem, 6vw, 5rem); }
h2 { font-size: clamp(1.9rem, 4vw, 3rem); }
h3 { font-size: 1.4rem; letter-spacing: -0.01em; }
p { margin: 0 0 1em; color: var(--kl-fg); }
.muted { color: var(--kl-muted); }
.eyebrow {
  font-family: var(--kl-font-display);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--kl-accent);
  display: inline-block;
  margin-bottom: 14px;
}

/* =============================================================
   LAYOUT
   ============================================================= */
.kl-container {
  width: 100%;
  max-width: var(--kl-container);
  margin: 0 auto;
  padding: 0 24px;
}
section { padding: 90px 0; }
@media (max-width: 768px) { section { padding: 60px 0; } }

/* =============================================================
   BUTTONS
   ============================================================= */
.kl-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 26px;
  font-family: var(--kl-font-display);
  font-weight: 700;
  font-size: .92rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  border-radius: 999px;
  border: 2px solid var(--kl-black);
  background: var(--kl-black);
  color: #fff;
  cursor: pointer;
  transition: transform .25s var(--kl-ease), background .25s, color .25s, border-color .25s;
  white-space: nowrap;
}
.kl-btn:hover { transform: translateY(-2px); background: var(--kl-accent); border-color: var(--kl-accent); color: #fff; }
.kl-btn--ghost { background: transparent; color: var(--kl-black); }
.kl-btn--ghost:hover { background: var(--kl-black); color: #fff; }
.kl-btn--accent { background: var(--kl-accent); border-color: var(--kl-accent); }
.kl-btn--sm { padding: 10px 18px; font-size: .8rem; }

/* =============================================================
   HEADER — Sticky transparent
   ============================================================= */
.kl-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255,255,255,.78);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color .3s, background .3s;
}
.kl-header.is-scrolled { border-color: var(--kl-line); background: rgba(255,255,255,.92); }
.kl-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 18px 0;
}
.kl-logo {
  font-family: var(--kl-font-display);
  font-weight: 900;
  font-size: 1.25rem;
  letter-spacing: -.02em;
  color: var(--kl-black);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.kl-logo__dot { width: 10px; height: 10px; border-radius: 50%; background: var(--kl-accent); display: inline-block; }
.kl-nav { display: flex; align-items: center; gap: 32px; }
.kl-nav ul { list-style: none; display: flex; gap: 28px; margin: 0; padding: 0; }
.kl-nav a { font-size: .92rem; font-weight: 500; color: var(--kl-fg); }
.kl-nav a:hover { color: var(--kl-accent); }
.kl-header__cta { display: flex; align-items: center; gap: 14px; }
.kl-burger { display: none; background: none; border: 0; padding: 8px; cursor: pointer; }
.kl-burger span { display: block; width: 24px; height: 2px; background: var(--kl-black); margin: 5px 0; transition: transform .25s; }
@media (max-width: 900px) {
  .kl-nav ul { display: none; }
  .kl-burger { display: block; }
  .kl-nav.is-open ul {
    display: flex; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0;
    background: #fff; padding: 24px; border-top: 1px solid var(--kl-line); gap: 18px;
  }
}

/* =============================================================
   HERO
   ============================================================= */
.kl-hero {
  position: relative;
  padding: 56px 0 64px;
  overflow: hidden;
  background:
    radial-gradient(1200px 500px at 80% -10%, rgba(37,99,255,.10), transparent 60%),
    radial-gradient(800px 400px at 0% 100%, rgba(61,255,177,.10), transparent 60%),
    #fff;
}
.kl-hero__grid {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 60px;
  align-items: center;
}
.kl-hero h1 strong { color: var(--kl-accent); font-weight: 900; }
.kl-hero__lead { font-size: 1.15rem; color: var(--kl-muted); max-width: 520px; margin-bottom: 32px; }
.kl-hero__ctas { display: flex; gap: 14px; flex-wrap: wrap; }
.kl-hero__meta {
  margin-top: 40px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 520px;
}
.kl-hero__meta strong { display: block; font-family: var(--kl-font-display); font-size: 1.6rem; font-weight: 800; }
.kl-hero__meta span { font-size: .82rem; color: var(--kl-muted); text-transform: uppercase; letter-spacing: .12em; }

.kl-hero__visual {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: 22px;
  overflow: hidden;
  background: #111;
  box-shadow: var(--kl-shadow);
}
.kl-hero__visual::before {
  content: "BEFORE";
  position: absolute; top: 18px; left: 18px;
  font-family: var(--kl-font-display); font-weight: 800; font-size: .72rem; letter-spacing: .2em;
  background: rgba(255,255,255,.95); color: #000; padding: 6px 12px; border-radius: 999px; z-index: 2;
}
.kl-hero__visual::after {
  content: "AFTER";
  position: absolute; bottom: 18px; right: 18px;
  font-family: var(--kl-font-display); font-weight: 800; font-size: .72rem; letter-spacing: .2em;
  background: var(--kl-accent); color: #fff; padding: 6px 12px; border-radius: 999px; z-index: 2;
}
.kl-hero__split {
  position: absolute; inset: 0;
  background:
    linear-gradient(135deg,
      #1a1a1a 0%, #2a2a2a 49.5%,
      var(--kl-accent) 50%, #4a7eff 100%);
}
.kl-hero__split svg { position: absolute; inset: 0; width: 100%; height: 100%; opacity: .85; }

@media (max-width: 900px) {
  .kl-hero__grid { grid-template-columns: 1fr; }
  .kl-hero__visual { max-width: 480px; margin: 0 auto; }
}

/* =============================================================
   TRUST BAR
   ============================================================= */
.kl-trust {
  padding: 30px 0;
  border-top: 1px solid var(--kl-line);
  border-bottom: 1px solid var(--kl-line);
  background: #fff;
}
.kl-trust__inner {
  display: flex; align-items: center; justify-content: space-between; gap: 40px; flex-wrap: wrap;
}
.kl-trust__label { font-size: .78rem; letter-spacing: .2em; text-transform: uppercase; color: var(--kl-muted); }
.kl-trust__logos { display: flex; gap: 40px; flex-wrap: wrap; align-items: center; opacity: .7; }
.kl-trust__logos span {
  font-family: var(--kl-font-display); font-weight: 800; font-size: 1.1rem; letter-spacing: -.02em; color: var(--kl-black);
}

/* =============================================================
   SECTION HEAD
   ============================================================= */
.kl-section-head { max-width: 720px; margin: 0 auto 56px; text-align: center; }
.kl-section-head--left { margin: 0 0 48px; text-align: left; }

/* =============================================================
   SERVICE / PRICING CARDS
   ============================================================= */
.kl-services { background: var(--kl-surface); }
.kl-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.kl-card {
  background: #fff;
  border: 1px solid var(--kl-line);
  border-radius: var(--kl-radius);
  padding: 36px 32px;
  display: flex; flex-direction: column;
  transition: transform .3s var(--kl-ease), box-shadow .3s, border-color .3s;
  position: relative;
}
.kl-card:hover { transform: translateY(-6px); box-shadow: var(--kl-shadow); border-color: transparent; }
.kl-card--featured { background: var(--kl-black); color: #fff; border-color: var(--kl-black); }
.kl-card--featured h3, .kl-card--featured p, .kl-card--featured li { color: #fff; }
.kl-card--featured .kl-card__price small { color: rgba(255,255,255,.6); }
.kl-card__badge {
  position: absolute; top: -12px; right: 24px;
  background: #000; color: #fff; font-family: var(--kl-font-display);
  font-size: .7rem; font-weight: 700; letter-spacing: .15em; padding: 6px 12px; border-radius: 999px;
}
.kl-card__price { font-family: var(--kl-font-display); font-size: 2.6rem; font-weight: 900; line-height: 1; margin: 14px 0 6px; }
.kl-card__price small { font-size: .9rem; font-weight: 500; color: var(--kl-muted); margin-left: 4px; }
.kl-card ul { list-style: none; padding: 0; margin: 18px 0 28px; flex: 1; }
.kl-card li { padding: 8px 0; font-size: .95rem; display: flex; gap: 10px; }
.kl-card li::before { content: "✓"; color: var(--kl-accent); font-weight: 800; }
.kl-card--featured li::before { color: var(--kl-accent-2); }

@media (max-width: 900px) { .kl-cards { grid-template-columns: 1fr; } }

/* =============================================================
   PROCESS STEPS  (Book → Drop off → Collect)
   ============================================================= */
.kl-process { background: var(--kl-black); color: #fff; }
.kl-process h2, .kl-process p { color: #fff; }
.kl-process .eyebrow { color: var(--kl-accent-2); }
.kl-steps {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px;
  counter-reset: step;
}
.kl-step {
  position: relative; padding: 36px 28px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--kl-radius);
  background: rgba(255,255,255,.03);
  transition: border-color .3s, background .3s;
}
.kl-step:hover { border-color: var(--kl-accent); background: rgba(37,99,255,.08); }
.kl-step__num {
  font-family: var(--kl-font-display); font-weight: 900; font-size: 3.4rem; line-height: 1;
  background: linear-gradient(180deg, var(--kl-accent), var(--kl-accent-2));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  margin-bottom: 16px;
}
.kl-step h3 { color: #fff; margin-bottom: 8px; }
.kl-step p { color: rgba(255,255,255,.7); margin: 0; font-size: .95rem; }
@media (max-width: 900px) { .kl-steps { grid-template-columns: 1fr; } }

/* =============================================================
   BEFORE / AFTER GALLERY
   ============================================================= */
.kl-gallery { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.kl-gallery__item {
  position: relative;
  aspect-ratio: 1;
  border-radius: var(--kl-radius);
  overflow: hidden;
  background: linear-gradient(135deg, #1a1a1a 50%, var(--kl-accent) 50%);
}
.kl-gallery__item span {
  position: absolute; bottom: 12px; left: 12px;
  background: rgba(255,255,255,.95); color: #000;
  font-family: var(--kl-font-display); font-weight: 700; font-size: .7rem; letter-spacing: .14em;
  padding: 5px 10px; border-radius: 999px;
}
@media (max-width: 900px) { .kl-gallery { grid-template-columns: repeat(2, 1fr); } }

/* =============================================================
   LOCATIONS
   ============================================================= */
.kl-locations { background: var(--kl-surface); }
.kl-loc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.kl-loc {
  background: #fff; padding: 24px; border-radius: var(--kl-radius); border: 1px solid var(--kl-line);
  transition: border-color .25s, transform .25s var(--kl-ease);
}
.kl-loc:hover { border-color: var(--kl-accent); transform: translateY(-3px); }
.kl-loc h4 { margin: 0 0 6px; font-family: var(--kl-font-display); font-size: 1.15rem; }
.kl-loc p { font-size: .92rem; color: var(--kl-muted); margin: 0 0 12px; }
.kl-loc__hours { font-size: .82rem; color: var(--kl-fg); display: flex; align-items: center; gap: 6px; }
.kl-loc__pin { display: inline-block; width: 10px; height: 10px; border-radius: 50%; background: var(--kl-accent-2); box-shadow: 0 0 0 4px rgba(61,255,177,.2); }
@media (max-width: 900px) { .kl-loc-grid { grid-template-columns: 1fr; } }

/* =============================================================
   TESTIMONIALS
   ============================================================= */
.kl-testimonials { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.kl-testimonial {
  padding: 32px; border: 1px solid var(--kl-line); border-radius: var(--kl-radius); background: #fff;
}
.kl-testimonial p { font-size: 1.02rem; line-height: 1.6; }
.kl-testimonial__author { display: flex; align-items: center; gap: 12px; margin-top: 18px; }
.kl-testimonial__avatar {
  width: 42px; height: 42px; border-radius: 50%;
  background: linear-gradient(135deg, var(--kl-accent), var(--kl-accent-2));
  color: #fff; display: grid; place-items: center; font-weight: 800; font-family: var(--kl-font-display);
}
.kl-testimonial__name { font-weight: 700; font-size: .92rem; }
.kl-testimonial__loc { font-size: .82rem; color: var(--kl-muted); }
.kl-stars { color: var(--kl-accent); letter-spacing: 2px; margin-bottom: 12px; }
@media (max-width: 900px) { .kl-testimonials { grid-template-columns: 1fr; } }

/* =============================================================
   CTA BAND
   ============================================================= */
.kl-cta {
  background: var(--kl-black);
  color: #fff;
  border-radius: 22px;
  padding: 70px 40px;
  text-align: center;
  margin: 80px auto;
  max-width: var(--kl-container);
  position: relative;
  overflow: hidden;
}
.kl-cta::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(600px 300px at 50% 100%, rgba(37,99,255,.5), transparent 70%);
}
.kl-cta > * { position: relative; }
.kl-cta h2 { color: #fff; }
.kl-cta p { color: rgba(255,255,255,.75); max-width: 540px; margin: 0 auto 28px; }
@media (max-width: 768px) { .kl-cta { margin: 40px 16px; padding: 50px 24px; } }

/* =============================================================
   FOOTER
   ============================================================= */
.kl-footer { background: #0a0a0a; color: rgba(255,255,255,.7); padding: 70px 0 30px; }
.kl-footer h5 { color: #fff; font-family: var(--kl-font-display); font-size: .85rem; letter-spacing: .2em; text-transform: uppercase; margin-bottom: 18px; }
.kl-footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 50px; border-bottom: 1px solid rgba(255,255,255,.1); }
.kl-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; font-size: .92rem; }
.kl-footer a:hover { color: var(--kl-accent-2); }
.kl-footer__bottom { padding-top: 24px; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; font-size: .85rem; }
@media (max-width: 900px) { .kl-footer__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .kl-footer__grid { grid-template-columns: 1fr; } }

/* =============================================================
   MOBILE BOTTOM NAV (app-like)
   ============================================================= */
.kl-bottom-nav {
  display: none;
  position: fixed; bottom: 14px; left: 14px; right: 14px;
  z-index: 90;
  background: rgba(10,10,10,.96);
  backdrop-filter: blur(16px);
  border-radius: 999px;
  padding: 10px 14px;
  box-shadow: 0 18px 40px -10px rgba(0,0,0,.5);
}
.kl-bottom-nav ul { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(4, 1fr); }
.kl-bottom-nav a {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  color: rgba(255,255,255,.7); font-size: .7rem; font-weight: 600; padding: 6px 4px;
}
.kl-bottom-nav a.is-active, .kl-bottom-nav a:hover { color: var(--kl-accent-2); }
.kl-bottom-nav svg { width: 22px; height: 22px; stroke: currentColor; fill: none; stroke-width: 2; }
@media (max-width: 768px) {
  .kl-bottom-nav { display: block; }
  body { padding-bottom: 90px; }
}

/* =============================================================
   PAGE / POST CONTENT (basic prose)
   ============================================================= */
.kl-prose { max-width: 760px; margin: 0 auto; padding: 60px 24px; }
.kl-prose h1 { font-size: clamp(2rem, 5vw, 3.4rem); }
.kl-prose img { border-radius: var(--kl-radius); margin: 24px 0; }
.kl-prose blockquote { border-left: 3px solid var(--kl-accent); padding-left: 20px; font-style: italic; color: var(--kl-muted); }

/* Accessibility */
.screen-reader-text { position: absolute; left: -10000px; top: auto; width: 1px; height: 1px; overflow: hidden; }
:focus-visible { outline: 3px solid var(--kl-accent); outline-offset: 2px; border-radius: 4px; }

/* -----------------------------------------------------------
 * Hero Slider (Swiper)
 * ----------------------------------------------------------- */
.kl-hero--slider { padding: 0; position: relative; overflow: hidden; }
.kl-hero-swiper { width: 100%; }
.kl-hero-swiper .swiper-slide {
  background: linear-gradient(135deg, #e8f2ff 0%, #d6e9ff 55%, #bcdcff 100%);
  color: #0f1b2d;
  padding: 64px 0 72px;
  min-height: 58vh;
  display: flex;
  align-items: center;
}
.kl-hero-swiper .kl-hero__grid {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 60px;
  align-items: center;
  width: 100%;
}
.kl-hero-swiper h1, .kl-hero-swiper h2 {
  font-family: var(--kl-font-display);
  font-weight: 900;
  font-size: clamp(2.4rem, 5.2vw, 4.6rem);
  line-height: 1.02;
  letter-spacing: -0.02em;
  margin: 14px 0 22px;
}
.kl-hero-swiper h1 strong, .kl-hero-swiper h2 strong { color: var(--kl-accent); font-weight: 900; }
.kl-hero-swiper .eyebrow { color: rgba(15,27,45,.65); }
.kl-hero-swiper .kl-hero__lead { color: rgba(15,27,45,.78); max-width: 520px; }
.kl-hero-swiper .kl-hero__visual {
  aspect-ratio: 4/5;
  border-radius: 24px;
  overflow: hidden;
  background: rgba(255,255,255,.04);
  position: relative;
}
.kl-hero-swiper .kl-hero__visual img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Pagination + nav */
.kl-hero__pagination {
  position: absolute;
  bottom: 28px !important;
  left: 0; right: 0;
  text-align: center;
  z-index: 5;
}
.kl-hero__pagination .swiper-pagination-bullet {
  background: rgba(15,27,45,.25);
  opacity: 1;
  width: 28px;
  height: 3px;
  border-radius: 2px;
  transition: background .2s, width .2s;
}
.kl-hero__pagination .swiper-pagination-bullet-active {
  background: var(--kl-accent);
  width: 44px;
}
.kl-hero__nav.swiper-button-prev,
.kl-hero__nav.swiper-button-next {
  color: #0f1b2d;
  width: 48px; height: 48px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.18);
  transition: background .2s;
}
.kl-hero__nav.swiper-button-prev:hover,
.kl-hero__nav.swiper-button-next:hover { background: rgba(255,255,255,.18); }
.kl-hero__nav.swiper-button-prev::after,
.kl-hero__nav.swiper-button-next::after { font-size: 18px; font-weight: 800; }

@media (max-width: 880px) {
  .kl-hero-swiper .kl-hero__grid { grid-template-columns: 1fr; gap: 32px; }
  .kl-hero-swiper .swiper-slide { padding: 90px 0 110px; min-height: auto; }
  .kl-hero-swiper .kl-hero__visual { max-width: 420px; margin: 0 auto; }
  .kl-hero__nav.swiper-button-prev,
  .kl-hero__nav.swiper-button-next { display: none; }
}

/* =============================================================
   ON-SALE SECTION (horizontal scroll carousel)
   ============================================================= */
.kl-sec--sale { padding: 80px 0; background: linear-gradient(180deg, #fafbfc 0%, #ffffff 100%); }
.kl-section-head--row { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; flex-wrap: wrap; margin-bottom: 36px; }
.kl-section-head--row > div { max-width: 640px; }

.kl-sale { position: relative; }
.kl-sale__track {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(260px, 1fr);
  gap: 20px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-padding: 8px;
  padding: 8px 4px 24px;
  scrollbar-width: thin;
}
@media (min-width: 720px)  { .kl-sale__track { grid-auto-columns: minmax(280px, calc((100% - 40px) / 3)); } }
@media (min-width: 1024px) { .kl-sale__track { grid-auto-columns: minmax(280px, calc((100% - 60px) / 4)); } }
.kl-sale__track::-webkit-scrollbar { height: 8px; }
.kl-sale__track::-webkit-scrollbar-thumb { background: rgba(15,27,45,.18); border-radius: 999px; }

.kl-sale-card {
  scroll-snap-align: start;
  background: #fff;
  border: 1px solid rgba(15,27,45,.08);
  border-radius: 18px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.kl-sale-card:hover { transform: translateY(-4px); box-shadow: 0 20px 40px -20px rgba(15,27,45,.25); border-color: rgba(15,27,45,.16); }

.kl-sale-card__media { position: relative; aspect-ratio: 4/3; background: #f3f5f8; overflow: hidden; }
.kl-sale-card__img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; }
.kl-sale-card:hover .kl-sale-card__img { transform: scale(1.05); }
.kl-sale-card__img--placeholder {
  display: flex; align-items: center; justify-content: center;
  font-family: var(--kl-font-display); font-size: 4rem; font-weight: 900; color: #fff;
  background: linear-gradient(135deg, #0f1b2d 0%, #1e3a5f 100%);
}
.kl-sale-card__img--g0 { background: linear-gradient(135deg, #0f1b2d 0%, #1e3a5f 100%); }
.kl-sale-card__img--g1 { background: linear-gradient(135deg, #1e3a5f 0%, #3b6fa0 100%); }
.kl-sale-card__img--g2 { background: linear-gradient(135deg, #0f1b2d 0%, #2d3748 100%); }
.kl-sale-card__img--g3 { background: linear-gradient(135deg, #3b6fa0 0%, #0f1b2d 100%); }

.kl-sale-card__badge {
  position: absolute; top: 12px; left: 12px;
  background: var(--kl-accent, #2d8a9e); color: #fff;
  font-family: var(--kl-font-display); font-weight: 800; font-size: .78rem;
  letter-spacing: .04em; padding: 6px 10px; border-radius: 999px;
}
.kl-sale-card__body { padding: 18px 18px 22px; display: flex; flex-direction: column; gap: 8px; }
.kl-sale-card__title { font-family: var(--kl-font-display); font-weight: 700; font-size: 1.05rem; line-height: 1.25; margin: 0; }
.kl-sale-card__price { font-size: 1rem; display: flex; gap: 10px; align-items: baseline; flex-wrap: wrap; }
.kl-sale-card__price ins, .kl-sale-card__price .price ins { text-decoration: none; font-weight: 800; color: #0f1b2d; }
.kl-sale-card__price del, .kl-sale-card__price .price del { color: rgba(15,27,45,.45); font-size: .9rem; }

/* Carousel arrows */
.kl-sale__nav {
  position: absolute; top: 38%; transform: translateY(-50%);
  width: 44px; height: 44px; border-radius: 999px;
  background: #fff; border: 1px solid rgba(15,27,45,.12);
  font-size: 22px; line-height: 1; color: #0f1b2d;
  cursor: pointer; z-index: 5;
  box-shadow: 0 8px 24px -10px rgba(15,27,45,.25);
  transition: background .2s, transform .2s, opacity .2s;
}
.kl-sale__nav:hover { background: var(--kl-accent, #2d8a9e); color: #fff; border-color: transparent; }
.kl-sale__nav.is-disabled { opacity: 0; pointer-events: none; }
.kl-sale__nav--prev { left: -16px; }
.kl-sale__nav--next { right: -16px; }
@media (max-width: 768px) { .kl-sale__nav { display: none; } }

/* =============================================================
   WOOCOMMERCE — Shop archive + single product
   ============================================================= */
.kl-wc { padding: 60px 0 100px; }

/* Shop hero */
.kl-shop-hero {
  padding: 80px 0 40px;
  background: linear-gradient(180deg, #0f1b2d 0%, #1e3a5f 100%);
  color: #fff;
}
.kl-shop-hero .eyebrow { color: rgba(255,255,255,.7); }
.kl-shop-hero__title {
  font-family: var(--kl-font-display); font-weight: 900;
  font-size: clamp(2.2rem, 5vw, 4rem); line-height: 1.02; letter-spacing: -.02em;
  margin: 10px 0 14px;
}
.kl-shop-hero__lead { color: rgba(255,255,255,.78); max-width: 560px; font-size: 1.05rem; }

/* Shop toolbar */
.kl-shop__toolbar {
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  padding: 22px 0; border-bottom: 1px solid rgba(15,27,45,.08); margin-bottom: 32px; flex-wrap: wrap;
}
.kl-shop .woocommerce-result-count { margin: 0; color: rgba(15,27,45,.6); font-size: .92rem; }
.kl-shop .woocommerce-ordering select {
  border: 1px solid rgba(15,27,45,.15); border-radius: 999px;
  padding: 10px 36px 10px 16px; background: #fff; font-size: .92rem; cursor: pointer;
}

/* Product grid */
.kl-shop ul.products, .woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  list-style: none;
  margin: 0 0 40px !important;
  padding: 0 !important;
}
@media (min-width: 720px)  { .kl-shop ul.products, .woocommerce ul.products { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .kl-shop ul.products, .woocommerce ul.products { grid-template-columns: repeat(4, 1fr); } }

.kl-prod, .woocommerce ul.products li.kl-prod {
  width: auto !important; margin: 0 !important; float: none !important;
  background: #fff; border: 1px solid rgba(15,27,45,.08); border-radius: 18px;
  overflow: hidden; display: flex; flex-direction: column;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.kl-prod:hover { transform: translateY(-4px); box-shadow: 0 20px 40px -20px rgba(15,27,45,.25); border-color: rgba(15,27,45,.16); }
.kl-prod__link { display: flex; flex-direction: column; text-decoration: none; color: inherit; flex: 1; }
.kl-prod__media { position: relative; aspect-ratio: 1/1; background: #f3f5f8; overflow: hidden; }
.kl-prod__img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; }
.kl-prod:hover .kl-prod__img { transform: scale(1.06); }
.kl-prod__img--placeholder {
  display: flex; align-items: center; justify-content: center;
  font-family: var(--kl-font-display); font-size: 4.5rem; font-weight: 900; color: #fff;
  background: linear-gradient(135deg, #0f1b2d 0%, #3b6fa0 100%);
}
.kl-prod__badge {
  position: absolute; top: 12px; left: 12px;
  background: var(--kl-accent, #2d8a9e); color: #fff;
  font-family: var(--kl-font-display); font-weight: 800; font-size: .78rem;
  padding: 6px 10px; border-radius: 999px;
}
.kl-prod__body { padding: 16px 16px 8px; }
.kl-prod__title { font-family: var(--kl-font-display); font-weight: 700; font-size: 1rem; margin: 0 0 6px; line-height: 1.3; }
.kl-prod__price { font-size: 1rem; display: flex; gap: 8px; align-items: baseline; flex-wrap: wrap; }
.kl-prod__price ins { text-decoration: none; font-weight: 800; color: #0f1b2d; }
.kl-prod__price del { color: rgba(15,27,45,.45); font-size: .9rem; }
.kl-prod__cta { padding: 0 16px 16px; }
.kl-prod__cta .button, .kl-prod__cta .added_to_cart {
  display: inline-flex; align-items: center; justify-content: center;
  width: 100%; padding: 11px 16px; border-radius: 999px;
  background: #0f1b2d; color: #fff !important; font-weight: 700; font-size: .9rem;
  letter-spacing: .02em; text-decoration: none; border: 0; cursor: pointer;
  transition: background .2s ease, transform .2s ease;
}
.kl-prod__cta .button:hover { background: var(--kl-accent, #2d8a9e); transform: translateY(-1px); }
.kl-prod__cta .added_to_cart { margin-top: 8px; background: transparent; color: #0f1b2d !important; border: 1px solid rgba(15,27,45,.15); }

/* Pagination */
.woocommerce nav.woocommerce-pagination { text-align: center; margin: 40px 0; }
.woocommerce nav.woocommerce-pagination ul { display: inline-flex; gap: 8px; border: 0; }
.woocommerce nav.woocommerce-pagination ul li { border: 0; margin: 0; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  min-width: 40px; height: 40px; line-height: 40px; padding: 0 14px;
  border-radius: 999px; background: #fff; border: 1px solid rgba(15,27,45,.12);
  font-weight: 600; color: #0f1b2d;
}
.woocommerce nav.woocommerce-pagination ul li span.current { background: #0f1b2d; color: #fff; border-color: #0f1b2d; }

/* Single product */
.kl-single-product div.product { display: grid; grid-template-columns: 1fr; gap: 40px; }
@media (min-width: 900px) { .kl-single-product div.product { grid-template-columns: 1.05fr 1fr; gap: 60px; } }
.kl-single-product .woocommerce-product-gallery {
  width: 100% !important; float: none !important;
  border-radius: 20px; overflow: hidden; background: #f3f5f8;
}
.kl-single-product .woocommerce-product-gallery img { border-radius: 16px; }
.kl-single-product .summary {
  width: 100% !important; float: none !important; padding: 8px 0;
}
.kl-single-product .product_title {
  font-family: var(--kl-font-display); font-weight: 900;
  font-size: clamp(1.8rem, 3.5vw, 2.8rem); line-height: 1.05; letter-spacing: -.01em;
  margin: 0 0 16px;
}
.kl-single-product .price {
  font-size: 1.6rem; font-weight: 800; color: #0f1b2d; margin: 0 0 18px;
  display: flex; gap: 12px; align-items: baseline; flex-wrap: wrap;
}
.kl-single-product .price del { color: rgba(15,27,45,.45); font-size: 1.05rem; font-weight: 500; }
.kl-single-product .price ins { text-decoration: none; color: var(--kl-accent, #2d8a9e); }
.kl-single-product .woocommerce-product-details__short-description { color: rgba(15,27,45,.72); line-height: 1.65; margin: 0 0 24px; }
.kl-single-product .cart { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin: 0 0 24px; }
.kl-single-product .cart .quantity .qty {
  width: 80px; padding: 12px; border-radius: 12px; border: 1px solid rgba(15,27,45,.15);
  text-align: center; font-weight: 700;
}
.kl-single-product .cart .button, .kl-single-product .single_add_to_cart_button {
  padding: 14px 28px !important; border-radius: 999px !important;
  background: #0f1b2d !important; color: #fff !important;
  font-weight: 800 !important; letter-spacing: .03em !important; border: 0 !important;
  transition: background .2s, transform .2s !important;
}
.kl-single-product .cart .button:hover { background: var(--kl-accent, #2d8a9e) !important; transform: translateY(-2px); }
.kl-single-product .product_meta { font-size: .88rem; color: rgba(15,27,45,.55); border-top: 1px solid rgba(15,27,45,.08); padding-top: 16px; }
.kl-single-product .product_meta > span { display: block; margin: 4px 0; }

/* Tabs + related */
.kl-single-product .woocommerce-tabs { grid-column: 1 / -1; margin-top: 30px; }
.kl-single-product .woocommerce-tabs ul.tabs {
  display: flex; gap: 8px; list-style: none; padding: 0 !important;
  border-bottom: 1px solid rgba(15,27,45,.1) !important; margin: 0 0 24px !important;
}
.kl-single-product .woocommerce-tabs ul.tabs::before, .kl-single-product .woocommerce-tabs ul.tabs::after { display: none !important; }
.kl-single-product .woocommerce-tabs ul.tabs li {
  background: transparent !important; border: 0 !important; border-radius: 0 !important;
  margin: 0 !important; padding: 0 !important;
}
.kl-single-product .woocommerce-tabs ul.tabs li::before, .kl-single-product .woocommerce-tabs ul.tabs li::after { display: none !important; }
.kl-single-product .woocommerce-tabs ul.tabs li a {
  padding: 12px 20px !important; font-weight: 700; color: rgba(15,27,45,.6) !important;
  text-decoration: none; border-bottom: 3px solid transparent; transition: color .2s, border-color .2s;
}
.kl-single-product .woocommerce-tabs ul.tabs li.active a { color: #0f1b2d !important; border-bottom-color: var(--kl-accent, #2d8a9e); }
.kl-single-product .related.products, .kl-single-product .upsells.products { grid-column: 1 / -1; }
.kl-single-product .related h2, .kl-single-product .upsells h2 {
  font-family: var(--kl-font-display); font-size: 1.8rem; font-weight: 800; margin: 40px 0 24px;
}

/* WC Notices */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  border-radius: 12px !important; border: 0 !important; padding: 14px 18px !important;
  background: #f3f5f8 !important; border-left: 4px solid var(--kl-accent, #2d8a9e) !important;
}

/* ============================================================
   WOOCOMMERCE — polish: category cards, placeholders, cart, checkout
   ============================================================ */

/* Make placeholder product images look like the sale-card gradients */
.kl-prod__img--placeholder,
.kl-sale-card__img--placeholder {
	display: flex; align-items: center; justify-content: center;
	font-family: var(--kl-font-display, system-ui);
	font-weight: 800; font-size: 4.5rem; color: #fff;
	background: linear-gradient(135deg, #0f1b2d 0%, #1a3a5c 60%, #2d5f8a 100%);
	letter-spacing: -0.02em;
	text-shadow: 0 2px 12px rgba(0,0,0,.25);
}
.kl-sale-card__img--g1, .kl-prod:nth-child(4n+2) .kl-prod__img--placeholder {
	background: linear-gradient(135deg, #1a3a5c 0%, #2d8a9e 100%);
}
.kl-sale-card__img--g2, .kl-prod:nth-child(4n+3) .kl-prod__img--placeholder {
	background: linear-gradient(135deg, #0f1b2d 0%, #3a2d5c 100%);
}
.kl-sale-card__img--g3, .kl-prod:nth-child(4n+4) .kl-prod__img--placeholder {
	background: linear-gradient(135deg, #2d5f8a 0%, #5cbdb9 100%);
}

/* Shop archive — product CATEGORY cards (sub-category tiles) */
.woocommerce ul.products li.product-category {
	background: #fff;
	border: 1px solid rgba(15,27,45,.08);
	border-radius: 18px;
	overflow: hidden;
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
	list-style: none;
}
.woocommerce ul.products li.product-category:hover {
	transform: translateY(-4px);
	box-shadow: 0 20px 40px -20px rgba(15,27,45,.25);
	border-color: rgba(15,27,45,.16);
}
.woocommerce ul.products li.product-category a { text-decoration: none; color: inherit; display: block; }
.woocommerce ul.products li.product-category img {
	width: 100%; aspect-ratio: 1/1; object-fit: cover; display: block; margin: 0 !important;
	background: #f3f5f8;
}
.woocommerce ul.products li.product-category h2.woocommerce-loop-category__title,
.woocommerce ul.products li.product-category h3 {
	font-family: var(--kl-font-display, system-ui);
	font-weight: 700; font-size: 1.05rem;
	margin: 0; padding: 16px 16px 14px;
	color: #0f1b2d; line-height: 1.3;
	display: flex; justify-content: space-between; align-items: center; gap: 8px;
}
.woocommerce ul.products li.product-category mark.count {
	background: #f3f5f8 !important;
	color: rgba(15,27,45,.6) !important;
	font-size: .78rem; font-weight: 600;
	padding: 2px 10px; border-radius: 999px;
}

/* Categories that have no image — show a gradient tile with the initial */
.woocommerce ul.products li.product-category:not(:has(img))::before {
	content: attr(data-initial, "•");
	display: flex; align-items: center; justify-content: center;
	aspect-ratio: 1/1;
	background: linear-gradient(135deg, #0f1b2d 0%, #2d5f8a 100%);
	color: #fff; font-family: var(--kl-font-display, system-ui);
	font-weight: 800; font-size: 4.5rem;
}

/* Single-product gallery placeholder */
.kl-single-product .woocommerce-product-gallery img[src*="placeholder"],
.kl-single-product .wp-post-image[src*="placeholder"] {
	background: linear-gradient(135deg, #0f1b2d 0%, #2d5f8a 100%);
	min-height: 380px;
}

/* Cart page */
.woocommerce-cart .kl-wc, .woocommerce-checkout .kl-wc { padding: 40px 0 100px; }
.woocommerce table.shop_table {
	border: 1px solid rgba(15,27,45,.08) !important;
	border-radius: 16px !important;
	border-collapse: separate !important;
	overflow: hidden;
	background: #fff;
}
.woocommerce table.shop_table th {
	background: #f3f5f8; color: #0f1b2d; font-weight: 700;
	padding: 14px 18px !important;
	font-family: var(--kl-font-display, system-ui);
	text-transform: uppercase; letter-spacing: .04em; font-size: .82rem;
}
.woocommerce table.shop_table td { padding: 16px 18px !important; border-top-color: rgba(15,27,45,.06) !important; }
.woocommerce table.shop_table img { width: 64px !important; height: 64px !important; object-fit: cover; border-radius: 10px; }
.woocommerce .cart_totals h2, .woocommerce-checkout h3 {
	font-family: var(--kl-font-display, system-ui);
	font-size: 1.5rem; font-weight: 800; margin: 0 0 16px;
}
.woocommerce .cart-collaterals .cart_totals {
	background: #fff; padding: 24px;
	border: 1px solid rgba(15,27,45,.08); border-radius: 16px;
}

/* Buttons — unify across all WC contexts */
.woocommerce button.button, .woocommerce a.button, .woocommerce input.button,
.woocommerce #respond input#submit, .woocommerce .checkout-button,
.woocommerce-page button.button, .woocommerce-page a.button {
	background: #0f1b2d !important; color: #fff !important;
	border: 0 !important; border-radius: 999px !important;
	padding: 12px 22px !important; font-weight: 700 !important;
	font-family: var(--kl-font-display, system-ui) !important;
	letter-spacing: .02em; text-transform: none;
	transition: background .2s ease, transform .2s ease;
	box-shadow: 0 6px 16px -6px rgba(15,27,45,.35);
}
.woocommerce button.button:hover, .woocommerce a.button:hover,
.woocommerce #respond input#submit:hover, .woocommerce .checkout-button:hover {
	background: var(--kl-accent, #2d8a9e) !important; transform: translateY(-1px);
}
.woocommerce a.button.alt, .woocommerce .single_add_to_cart_button {
	background: var(--kl-accent, #2d8a9e) !important;
}

/* Form inputs */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	border: 1px solid rgba(15,27,45,.15) !important;
	border-radius: 10px !important;
	padding: 12px 14px !important;
	font-size: .95rem;
	background: #fff;
	transition: border-color .2s ease, box-shadow .2s ease;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
	border-color: var(--kl-accent, #2d8a9e) !important;
	box-shadow: 0 0 0 3px rgba(45,138,158,.15);
	outline: 0;
}
.woocommerce form .form-row label { font-weight: 600; color: #0f1b2d; margin-bottom: 6px; display: block; }

/* Quantity selector */
.woocommerce .quantity .qty {
	border: 1px solid rgba(15,27,45,.15) !important;
	border-radius: 10px !important;
	padding: 10px !important; width: 70px;
}

/* Empty cart message */
.woocommerce .cart-empty {
	text-align: center; padding: 40px 20px; font-size: 1.1rem;
	background: #f3f5f8; border-radius: 16px; color: rgba(15,27,45,.7);
}

/* === Header account & cart icons (v1.5.2) === */
.kl-header__cta { gap: 18px; }
.kl-header__icon {
	position: relative; display: inline-flex; align-items: center; gap: 6px;
	color: var(--kl-ink, #0f1b2d); text-decoration: none; font-size: 0.95rem;
	transition: opacity .2s ease;
}
.kl-header__icon:hover { opacity: 0.65; }
.kl-header__icon svg { display: block; }
.kl-header__icon-label { font-weight: 500; }
.kl-header__cart { padding-right: 4px; }
.kl-header__cart-count {
	position: absolute; bottom: -2px; right: -6px;
	min-width: 18px; height: 18px; padding: 0 5px;
	background: var(--kl-accent, #e85d3a); color: #fff;
	border-radius: 999px; font-size: 11px; font-weight: 700;
	display: inline-flex; align-items: center; justify-content: center; line-height: 1;
}
@media (max-width: 640px) {
	.kl-header__icon-label { display: none; }
	.kl-header__book { display: none; }
}

/* ============================================================
   Shop Enhancements (v1.7.7)
   Sidebar, view toggle, header dropdown, basket label.
   ============================================================ */

/* Header — Shop dropdown */
.kl-nav .kl-has-dropdown { position: relative; }
.kl-nav .kl-caret {
	display: inline-block; font-size: .85em; margin-left: 4px;
	color: var(--kl-accent, #3dffb1); transition: transform .2s ease;
}
.kl-nav .kl-has-dropdown:hover .kl-caret,
.kl-nav .kl-has-dropdown:focus-within .kl-caret { transform: rotate(-180deg); }
.kl-submenu {
	position: absolute; top: 100%; left: 50%; transform: translate(-50%, 8px);
	min-width: 340px; max-width: 380px; padding: 12px;
	background: #0a0a0a; color: #fff;
	border: 1px solid rgba(255,255,255,.08);
	border-radius: 18px;
	box-shadow: 0 28px 60px -20px rgba(0,0,0,.6);
	list-style: none; margin: 0;
	display: flex; flex-direction: column; gap: 4px;
	opacity: 0; visibility: hidden; pointer-events: none;
	transition: opacity .18s ease, transform .18s ease;
	z-index: 200;
}
.kl-nav .kl-has-dropdown:hover .kl-submenu,
.kl-nav .kl-has-dropdown:focus-within .kl-submenu,
.kl-nav .kl-has-dropdown.is-open .kl-submenu {
	opacity: 1; visibility: visible; pointer-events: auto;
	transform: translate(-50%, 0);
}
.kl-nav .kl-has-dropdown.is-open .kl-caret { transform: rotate(-180deg); }
.kl-submenu li { display: block; }
.kl-submenu a {
	display: flex; align-items: center; gap: 14px;
	padding: 12px; border-radius: 14px;
	color: #fff !important; text-decoration: none;
	transition: background .15s ease, color .15s ease;
}
.kl-submenu a:hover,
.kl-submenu a:focus { background: rgba(255,255,255,.06); }
.kl-submenu__thumb {
	flex: 0 0 auto;
	width: 56px; height: 56px;
	border-radius: 14px;
	background: #1a2238;
	display: flex; align-items: center; justify-content: center;
	overflow: hidden;
	font-weight: 800; font-size: 1.4rem; color: var(--kl-accent, #3dffb1);
}
.kl-submenu__thumb img {
	width: 100%; height: 100%; object-fit: cover; display: block;
}
.kl-submenu__text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.kl-submenu__title { font-weight: 800; font-size: 1.02rem; line-height: 1.2; }
.kl-submenu__desc { font-size: .85rem; color: rgba(255,255,255,.6); font-weight: 400; line-height: 1.35; }

/* Header — basket label variant */
.kl-header__cart--labeled {
	background: var(--kl-accent, #3dffb1);
	color: #0a0a0a !important;
	padding: 8px 14px 8px 12px;
	border-radius: 999px;
	font-weight: 700;
}
.kl-header__cart--labeled .kl-header__icon-label { display: inline !important; font-weight: 700; }
.kl-header__cart--labeled .kl-header__cart-count {
	position: static; margin-left: 4px;
}

/* Shop layout — sidebar */
.kl-shop__layout { display: block; }
.kl-shop--has-sidebar .kl-shop__layout {
	display: grid; gap: 36px;
	grid-template-columns: 1fr;
}
@media (min-width: 960px) {
	.kl-shop--has-sidebar .kl-shop__layout {
		grid-template-columns: 260px 1fr;
		align-items: start;
	}
}

.kl-shop__sidebar { display: grid; gap: 20px; position: sticky; top: 96px; }
@media (max-width: 959px) { .kl-shop__sidebar { position: static; } }

.kl-side-card {
	background: #fff;
	border: 1px solid rgba(15,27,45,.08);
	border-radius: 16px;
	padding: 18px 18px 14px;
}
.kl-side-card__title {
	font-family: var(--kl-font-display);
	font-size: .78rem; letter-spacing: .14em; text-transform: uppercase;
	color: rgba(15,27,45,.55);
	margin: 0 0 12px;
}
.kl-side-cats { list-style: none; margin: 0; padding: 0; }
.kl-side-cats li + li { margin-top: 2px; }
.kl-side-cats a {
	display: flex; justify-content: space-between; align-items: center;
	padding: 9px 12px; border-radius: 10px;
	color: var(--kl-ink, #0f1b2d); text-decoration: none;
	font-size: .95rem; font-weight: 500;
	transition: background .15s ease, color .15s ease;
}
.kl-side-cats a:hover { background: rgba(15,27,45,.05); }
.kl-side-cats a.is-active {
	background: #0f1b2d; color: #fff;
}
.kl-side-cats__count {
	font-size: .78rem; color: rgba(15,27,45,.5);
	background: rgba(15,27,45,.06); padding: 2px 8px; border-radius: 999px;
}
.kl-side-cats a.is-active .kl-side-cats__count {
	background: rgba(255,255,255,.18); color: #fff;
}

/* Sidebar special card */
.kl-side-special { padding: 16px; background: linear-gradient(160deg, #0f1b2d, #1a3050); color: #fff; border: 0; }
.kl-side-special__eyebrow {
	display: inline-block; font-size: .68rem; letter-spacing: .18em; text-transform: uppercase;
	background: var(--kl-accent, #3dffb1); color: #0a0a0a;
	padding: 4px 10px; border-radius: 999px; font-weight: 800; margin-bottom: 14px;
}
.kl-side-special__link { display: block; color: #fff; text-decoration: none; }
.kl-side-special__img { width: 100%; height: auto; border-radius: 12px; display: block; margin-bottom: 12px; aspect-ratio: 1/1; object-fit: cover; background: rgba(255,255,255,.06); }
.kl-side-special__title { font-family: var(--kl-font-display); font-size: 1.05rem; font-weight: 700; margin: 0 0 6px; }
.kl-side-special__price { font-size: 1rem; color: rgba(255,255,255,.92); display: flex; gap: 8px; flex-wrap: wrap; align-items: baseline; }
.kl-side-special__price ins { text-decoration: none; color: var(--kl-accent, #3dffb1); font-weight: 800; }
.kl-side-special__price del { color: rgba(255,255,255,.55); font-size: .85rem; }
.kl-side-special__cta { margin-top: 14px; width: 100%; justify-content: center; display: inline-flex; }

/* Shop toolbar */
.kl-shop__toolbar { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; justify-content: space-between; margin-bottom: 22px; }
.kl-shop__toolbar-right { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }

/* View toggle */
.kl-view-toggle {
	display: inline-flex; gap: 0;
	background: #fff; border: 1px solid rgba(15,27,45,.12); border-radius: 10px; overflow: hidden;
}
.kl-view-toggle__btn {
	display: inline-flex; align-items: center; justify-content: center;
	width: 38px; height: 38px;
	background: transparent; border: 0; cursor: pointer;
	color: rgba(15,27,45,.55);
	transition: background .15s ease, color .15s ease;
}
.kl-view-toggle__btn + .kl-view-toggle__btn { border-left: 1px solid rgba(15,27,45,.08); }
.kl-view-toggle__btn:hover { color: var(--kl-ink, #0f1b2d); }
.kl-view-toggle__btn.is-active { background: #0f1b2d; color: #fff; }

/* List view */
.kl-shop__main[data-kl-view="list"] ul.products,
.kl-shop__main[data-kl-view="list"] .woocommerce ul.products {
	grid-template-columns: 1fr !important;
	gap: 14px;
}
.kl-shop__main[data-kl-view="list"] .kl-prod {
	display: grid !important; grid-template-columns: 180px 1fr auto;
	align-items: center; gap: 18px;
	padding: 12px;
}
.kl-shop__main[data-kl-view="list"] .kl-prod__link {
	display: contents;
}
.kl-shop__main[data-kl-view="list"] .kl-prod__media {
	width: 180px; aspect-ratio: 1/1; border-radius: 12px; overflow: hidden;
}
.kl-shop__main[data-kl-view="list"] .kl-prod__body { padding: 0; }
.kl-shop__main[data-kl-view="list"] .kl-prod__title { font-size: 1.15rem; }
.kl-shop__main[data-kl-view="list"] .kl-prod__cta { padding: 0; }
.kl-shop__main[data-kl-view="list"] .kl-prod:hover { transform: none; }
@media (max-width: 600px) {
	.kl-shop__main[data-kl-view="list"] .kl-prod { grid-template-columns: 110px 1fr; }
	.kl-shop__main[data-kl-view="list"] .kl-prod__media { width: 110px; }
	.kl-shop__main[data-kl-view="list"] .kl-prod__cta { grid-column: 1 / -1; }
}

/* Sidebar narrows the grid: drop one column at md */
@media (min-width: 1024px) {
	.kl-shop--has-sidebar .kl-shop__main ul.products,
	.kl-shop--has-sidebar .kl-shop__main .woocommerce ul.products {
		grid-template-columns: repeat(3, 1fr);
	}
}
@media (min-width: 1280px) {
	.kl-shop--has-sidebar .kl-shop__main ul.products,
	.kl-shop--has-sidebar .kl-shop__main .woocommerce ul.products {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* Cart & Checkout polish */
.woocommerce-cart .kl-wc .woocommerce,
.woocommerce-checkout .kl-wc .woocommerce {
	display: grid; gap: 30px;
}
@media (min-width: 960px) {
	.woocommerce-cart .woocommerce .cart-collaterals { float: none; width: 100%; }
	.woocommerce-cart form.woocommerce-cart-form { margin-bottom: 24px; }
}
.woocommerce table.shop_table {
	background: #fff;
	border: 1px solid rgba(15,27,45,.08) !important;
	border-radius: 16px !important;
	overflow: hidden;
	box-shadow: 0 10px 30px -20px rgba(15,27,45,.18);
}
.woocommerce .cart_totals,
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #order_review {
	background: #fff;
	border: 1px solid rgba(15,27,45,.08);
	border-radius: 16px;
	padding: 22px !important;
	box-shadow: 0 10px 30px -20px rgba(15,27,45,.18);
}
.woocommerce-checkout .col2-set { display: grid; gap: 24px; }
@media (min-width: 960px) { .woocommerce-checkout .col2-set { grid-template-columns: 1fr 1fr; } }
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 { width: 100%; float: none; }

/* =============================================================
   MOBILE NAV — Shop submenu (collapsible)
   ============================================================= */
@media (max-width: 900px) {

  /* Shop parent: full-width pill on its own line */
  .kl-nav .kl-has-dropdown { width: 100%;
 	  border-radius: 16px !important;
	}

  /* The "Shop" link/button itself — yellow pill with caret */
  .kl-nav .kl-has-dropdown > a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    width: 100%;
    padding: 12px 18px;
    border-radius: 999px;
    transition: background .2s ease, transform .15s ease;
    color: #0a0a0a !important;
    font-weight: 700;
	
  }

  /* Show caret on mobile and animate it */
  .kl-nav .kl-caret {
    display: inline-block !important;
    margin-left: auto;
    transition: transform .25s var(--kl-ease);
  }
  .kl-nav .kl-has-dropdown.is-open > a .kl-caret {
    transform: rotate(-180deg);
	   
  }

  /* ---- Submenu HIDDEN by default on mobile ---- */
  .kl-nav .kl-submenu,
  .kl-nav .kl-has-dropdown:hover .kl-submenu,
  .kl-nav .kl-has-dropdown:focus-within .kl-submenu {
    position: static;
    transform: none;
    box-shadow: none;
    border: 0;
    min-width: 0;
    max-width: none;

    /* hide */
    display: block;
    max-height: 0;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    padding: 0;
    margin: 0;
    background: transparent;
    pointer-events: none;
    transition:
      max-height .35s var(--kl-ease),
      opacity .25s var(--kl-ease),
      padding .25s var(--kl-ease),
      margin .25s var(--kl-ease);
  }

  /* ---- Submenu OPEN ---- */
  .kl-nav .kl-has-dropdown.is-open .kl-submenu {
    max-height: 800px;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    padding: 8px;
    margin-top: 8px;
    background: #0f1419;
    border-radius: 10px;
  }

  /* Submenu items */
  .kl-nav .kl-submenu a {
    color: #f5d20a !important;
    padding: 10px 12px;
    gap: 12px;
    border-radius: 199px !important;
  }
  .kl-nav .kl-submenu a:hover,
  .kl-nav .kl-submenu a:focus {
    background: rgba(245, 210, 10, 0.08);
  }
	
  .kl-submenu__desc { color: rgba(255,255,255,.6); }
  .kl-submenu__thumb {
    width: 40px; height: 40px;
    border-radius: 10px;
    font-size: 1.1rem;
  }
}




