/*
Theme Name: Kingo Child
Theme URI: https://www.katherinesexcoach.com
Description: Child theme for Kingo — custom styling for Les Clés du Plaisir. All site customizations live here so the parent Kingo theme can be updated safely.
Author: Katherine Sex Coach
Author URI: https://www.katherinesexcoach.com
Template: kingo
Version: 1.7.0
Text Domain: kingo-child
*/

/*@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,500;1,600&display=swap');*/

/* ============================================================
   BRAND TOKENS
   ============================================================ */
:root {
  --kc-purple: #6B2A8A;
  --kc-purple-deep: #4A1A63;
  --kc-purple-rich: #3A1252;
  --kc-purple-soft: #F3EDF7;
  --kc-purple-glow: rgba(107, 42, 138, 0.18);
  --kc-gold: #C9A961;
  --kc-gold-rich: #B89248;
  --kc-gold-deep: #8C6E2E;
  --kc-gold-shimmer: linear-gradient(135deg, #E5C97A 0%, #C9A961 50%, #8C6E2E 100%);
  --kc-ivory: #FAF7F2;
  --kc-ivory-deep: #F1EAD9;
  --kc-cream-grad: linear-gradient(180deg, #FAF7F2 0%, #F5EEDF 60%, #F0E5CC 100%);
  --kc-charcoal: #2A2233;
  --kc-muted: #6E6477;
  --kc-divider: #E8E2E8;
  --kc-card-shadow: 0 4px 24px rgba(42, 34, 51, 0.08);
  --kc-card-shadow-hover: 0 20px 50px rgba(74, 26, 99, 0.25);
  --kc-serif: 'Playfair Display', 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
}

/* ============================================================
   PAGE BACKGROUND — Kingo's `tg_footer_reveal` body class makes
   the body act as a fixed plate behind a scrolling #wrapper.
   So we move our ivory background ONTO #wrapper (which scrolls
   with the content) instead of body. Footer-reveal still works
   visually because the footer sits below #wrapper.
   ============================================================ */
html {
  background: var(--kc-ivory);
}

body.post-type-archive-product,
body.tax-product_cat,
body.tax-product_tag {
  background: var(--kc-ivory) !important;
}

/* The scrolling layer — marble texture with soft ivory veil so products pop */
body.post-type-archive-product #wrapper,
body.tax-product_cat #wrapper,
body.tax-product_tag #wrapper {
  background-color: var(--kc-ivory) !important;
  background-image:
    linear-gradient(rgba(250, 247, 242, 0.62), rgba(250, 247, 242, 0.62)),
    url('images/marble.jpg') !important;
  background-repeat: repeat, repeat !important;
  background-size: auto, 900px auto !important;
  background-position: 0 0, 0 0 !important;
  background-attachment: scroll, scroll !important;
}

/* Inner wrappers stay transparent so #wrapper bg shows through */
body.post-type-archive-product #page_content_wrapper,
body.tax-product_cat #page_content_wrapper,
body.tax-product_tag #page_content_wrapper,
body.post-type-archive-product .inner_wrapper,
body.tax-product_cat .inner_wrapper,
body.post-type-archive-product .sidebar_content,
body.tax-product_cat .sidebar_content {
  background: transparent !important;
}

/* ============================================================
   HERO — eyebrow, title, gold ornament, tagline
   "Beautiful introduction top window"
   ============================================================ */

body.post-type-archive-product #page_caption,
body.tax-product_cat #page_caption {
  /* Lighter veil so marble texture is more visible in the hero (more drama) */
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.5) 0%, rgba(250, 247, 242, 0.2) 100%) !important;
  padding: 90px 20px 70px !important;
  position: relative;
  overflow: visible !important;
}

/* Soft fade from hero ivory into the rest of the page */
body.post-type-archive-product #page_caption + #page_content_wrapper,
body.tax-product_cat #page_caption + #page_content_wrapper {
  background: linear-gradient(180deg, #F1EAD9 0%, var(--kc-ivory) 250px) !important;
}

/* Subtle decorative diamond pattern in the hero background */
body.post-type-archive-product #page_caption::before,
body.tax-product_cat #page_caption::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 20% 50%, var(--kc-purple-glow) 0%, transparent 25%),
    radial-gradient(circle at 80% 50%, rgba(201, 169, 97, 0.12) 0%, transparent 25%);
  pointer-events: none;
  z-index: 0;
}

body.post-type-archive-product .page_title_wrapper,
body.tax-product_cat .page_title_wrapper {
  position: relative;
  z-index: 1;
}

body.post-type-archive-product .page_title_content,
body.tax-product_cat .page_title_content {
  text-align: center !important;
}

/* Eyebrow text above title */
body.post-type-archive-product .page_title_content::before,
body.tax-product_cat .page_title_content::before {
  content: '— Boutique Privée —';
  display: block;
  font-family: var(--kc-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 0.95rem;
  letter-spacing: 0.45em;
  color: var(--kc-gold-deep);
  text-transform: uppercase;
  margin-bottom: 1.4em;
  padding-left: 0.45em; /* compensate for letter-spacing */
}

body.post-type-archive-product #page_caption .page_title_content h1,
body.tax-product_cat #page_caption .page_title_content h1 {
  font-family: var(--kc-serif) !important;
  font-weight: 500 !important;
  font-style: italic !important;
  font-size: clamp(2.6rem, 5.5vw, 4.6rem) !important;
  line-height: 1.05 !important;
  letter-spacing: 0.02em !important;
  color: var(--kc-purple-rich) !important;
  text-transform: none !important;
  position: relative;
  padding-bottom: 0.7em;
  display: inline-block;
  margin: 0 !important;
}

body.post-type-archive-product #page_caption .page_title_content h1::after,
body.tax-product_cat #page_caption .page_title_content h1::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: 140px;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--kc-gold) 50%, transparent 100%);
}

/* Tagline below title */
body.post-type-archive-product .page_title_content::after,
body.tax-product_cat .page_title_content::after {
  content: 'Une sélection sensuelle, pensée pour éveiller vos sens et vous accompagner sur le chemin du plaisir.';
  display: block;
  max-width: 580px;
  margin: 1.5em auto 0;
  font-family: var(--kc-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 1.15rem;
  line-height: 1.6;
  color: var(--kc-muted);
}

/* ============================================================
   SHOP TOOLBAR — search, result count, sort dropdown
   Fix: the "floating in a cream box" look becomes intentional
   container that ties hero to grid.
   ============================================================ */

/* The WooCommerce search BLOCK widget at the top */
.woocommerce .wc-block-product-search,
.woocommerce-page .wc-block-product-search {
  max-width: 640px;
  margin: 2em auto 3em !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
}

.woocommerce .wc-block-product-search__label,
.woocommerce-page .wc-block-product-search__label {
  display: block !important;
  text-align: center;
  font-family: var(--kc-serif) !important;
  font-style: italic;
  font-size: 0.85rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--kc-gold-deep) !important;
  margin-bottom: 1em !important;
  padding-left: 0.35em;
}

.woocommerce .wc-block-product-search__inside-wrapper,
.woocommerce-page .wc-block-product-search__inside-wrapper {
  border: 1px solid var(--kc-divider) !important;
  border-radius: 999px !important;
  background: #fff !important;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(74, 26, 99, 0.06);
  transition: box-shadow 0.3s ease, border-color 0.3s ease;
}

.woocommerce .wc-block-product-search__inside-wrapper:focus-within,
.woocommerce-page .wc-block-product-search__inside-wrapper:focus-within {
  border-color: var(--kc-purple);
  box-shadow: 0 4px 18px var(--kc-purple-glow);
}

.woocommerce .wc-block-product-search__field,
.woocommerce-page .wc-block-product-search__field {
  border: none !important;
  background: transparent !important;
  padding: 1em 1.6em !important;
  font-family: var(--kc-serif) !important;
  font-style: italic;
  font-size: 1.05rem !important;
  color: var(--kc-charcoal) !important;
  outline: none !important;
  box-shadow: none !important;
  flex: 1;
}

.woocommerce .wc-block-product-search__field::placeholder,
.woocommerce-page .wc-block-product-search__field::placeholder {
  color: var(--kc-muted);
  opacity: 0.7;
}

.woocommerce .wc-block-product-search__button,
.woocommerce-page .wc-block-product-search__button {
  background: var(--kc-purple) !important;
  color: #fff !important;
  border: none !important;
  padding: 0 1.6em !important;
  cursor: pointer;
  transition: background 0.25s ease;
}

.woocommerce .wc-block-product-search__button:hover,
.woocommerce-page .wc-block-product-search__button:hover {
  background: var(--kc-gold) !important;
}

.woocommerce .wc-block-product-search__button svg,
.woocommerce-page .wc-block-product-search__button svg {
  fill: #fff !important;
}

/* Result count + sort row */
.woocommerce .woocommerce-result-count,
.woocommerce-page .woocommerce-result-count {
  font-family: var(--kc-serif) !important;
  font-style: italic !important;
  font-size: 1rem !important;
  color: var(--kc-muted) !important;
  letter-spacing: 0.02em !important;
  margin-top: 0.6em !important;
}

.woocommerce .woocommerce-ordering,
.woocommerce-page .woocommerce-ordering {
  margin-bottom: 2em !important;
}

.woocommerce .woocommerce-ordering select,
.woocommerce-page .woocommerce-ordering select {
  border: 1px solid var(--kc-gold) !important;
  background: #fff !important;
  padding: 0.7em 2.4em 0.7em 1.2em !important;
  font-family: var(--kc-serif) !important;
  font-style: italic;
  font-size: 0.95rem !important;
  color: var(--kc-charcoal) !important;
  letter-spacing: 0.03em !important;
  border-radius: 999px !important;
  cursor: pointer;
  transition: all 0.25s ease;
}

.woocommerce .woocommerce-ordering select:hover,
.woocommerce-page .woocommerce-ordering select:hover {
  border-color: var(--kc-purple) !important;
  box-shadow: 0 2px 12px var(--kc-purple-glow);
}

/* ============================================================
   PRODUCT GRID — Heavy luxe cards with corner ornaments,
   dramatic shadow, golden frame on hover, image zoom overlay.
   ============================================================ */

.woocommerce ul.products,
.woocommerce-page ul.products {
  margin-top: 2em !important;
  gap: 2em;
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
}

/* WooCommerce inserts ::before/::after clearfix pseudo-elements on ul.products
   (legacy float layout). When the UL is display:grid, those pseudos become
   grid items and steal slot 1 (and the trailing one), pushing all real
   products down by one. Kill them. */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after {
  display: none !important;
}

@media (min-width: 1200px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  background: #fff !important;
  border: 1px solid var(--kc-divider) !important;
  border-radius: 2px !important;
  padding: 2em 1.8em 2.2em !important;
  box-shadow: var(--kc-card-shadow) !important;
  transition:
    transform 0.45s cubic-bezier(0.2, 0.7, 0.2, 1),
    box-shadow 0.45s cubic-bezier(0.2, 0.7, 0.2, 1),
    border-color 0.45s ease !important;
  display: flex !important;
  flex-direction: column !important;
  position: relative !important;
  overflow: hidden !important;
  margin: 0 !important;
  width: auto !important;
}

.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover {
  transform: translateY(-10px) !important;
  box-shadow: var(--kc-card-shadow-hover) !important;
  border-color: var(--kc-gold) !important;
}

/* Top gold bar that grows on hover */
.woocommerce ul.products li.product::before,
.woocommerce-page ul.products li.product::before {
  content: '';
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 0; height: 3px;
  background: var(--kc-gold-shimmer);
  transition: width 0.5s ease;
  z-index: 2;
}

.woocommerce ul.products li.product:hover::before,
.woocommerce-page ul.products li.product:hover::before { width: 100%; }

/* Gold ornamental corner ticks — top-left + bottom-right */
.woocommerce ul.products li.product::after,
.woocommerce-page ul.products li.product::after {
  content: '';
  position: absolute;
  top: 12px;
  left: 12px;
  width: 18px;
  height: 18px;
  border-top: 1px solid var(--kc-gold);
  border-left: 1px solid var(--kc-gold);
  opacity: 0;
  transition: opacity 0.4s ease 0.1s, top 0.4s ease, left 0.4s ease;
  pointer-events: none;
}

.woocommerce ul.products li.product:hover::after,
.woocommerce-page ul.products li.product:hover::after {
  opacity: 1;
  top: 8px;
  left: 8px;
}

/* Product image — clean, slight zoom on hover */
.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img {
  margin: 0 0 1.4em !important;
  border-radius: 1px !important;
  transition: transform 0.7s cubic-bezier(0.2, 0.7, 0.2, 1) !important;
  width: 100% !important;
  height: auto;
  display: block;
}

.woocommerce ul.products li.product:hover a img,
.woocommerce-page ul.products li.product:hover a img {
  transform: scale(1.05);
}

/* Product title */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2,
.woocommerce-page ul.products li.product h2,
.woocommerce ul.products li.product h3,
.woocommerce-page ul.products li.product h3 {
  font-family: var(--kc-serif) !important;
  font-weight: 600 !important;
  font-style: normal !important;
  font-size: 1.3rem !important;
  line-height: 1.3 !important;
  color: var(--kc-purple-rich) !important;
  letter-spacing: 0.01em !important;
  padding: 0.4em 0 0.6em !important;
  margin: 0 !important;
  min-height: 2.6em;
  text-transform: none !important;
  text-align: center;
}

.woocommerce ul.products li.product a:hover .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product a:hover .woocommerce-loop-product__title {
  color: var(--kc-purple) !important;
}

/* Star ratings — always visible, gold */
.woocommerce ul.products li.product .star-rating,
.woocommerce-page ul.products li.product .star-rating {
  display: block !important;
  margin: 0.5em auto 1em !important;
  font-size: 0.95em !important;
  color: var(--kc-gold) !important;
  letter-spacing: 3px;
  float: none !important;
}

.woocommerce .star-rating::before,
.woocommerce-page .star-rating::before { color: var(--kc-divider) !important; }
.woocommerce .star-rating span::before,
.woocommerce-page .star-rating span::before { color: var(--kc-gold) !important; }

/* Price — bold, large, brand purple, ornamental dividers */
.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price {
  color: var(--kc-purple-rich) !important;
  font-family: var(--kc-serif) !important;
  font-size: 1.55rem !important;
  font-weight: 600 !important;
  margin: 0.5em 0 1.4em !important;
  display: block !important;
  text-align: center;
  letter-spacing: 0.02em !important;
  position: relative;
  padding: 0.5em 0;
}

.woocommerce ul.products li.product .price::before,
.woocommerce ul.products li.product .price::after,
.woocommerce-page ul.products li.product .price::before,
.woocommerce-page ul.products li.product .price::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 30px;
  height: 1px;
  background: var(--kc-gold);
  opacity: 0.5;
}

.woocommerce ul.products li.product .price::before,
.woocommerce-page ul.products li.product .price::before {
  left: 50%;
  transform: translateX(-90px);
}

.woocommerce ul.products li.product .price::after,
.woocommerce-page ul.products li.product .price::after {
  right: 50%;
  transform: translateX(90px);
}

.woocommerce ul.products li.product .price ins,
.woocommerce-page ul.products li.product .price ins {
  text-decoration: none !important;
  font-weight: 700 !important;
}

.woocommerce ul.products li.product .price del,
.woocommerce-page ul.products li.product .price del {
  color: var(--kc-muted) !important;
  font-size: 0.78em !important;
  font-weight: 400 !important;
  margin-right: 0.5em !important;
  opacity: 0.65 !important;
}

/* Sale badge — gold pill */
.woocommerce ul.products li.product .onsale,
.woocommerce-page ul.products li.product .onsale {
  background: var(--kc-gold-shimmer) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 999px !important;
  padding: 0.45em 1.1em !important;
  font-family: var(--kc-serif) !important;
  font-style: italic !important;
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  min-height: auto !important;
  min-width: auto !important;
  line-height: 1.3 !important;
  top: 1.2em !important;
  right: 1.2em !important;
  left: auto !important;
  margin: 0 !important;
  box-shadow: 0 4px 14px rgba(201, 169, 97, 0.35);
  z-index: 3 !important;
}

/* ============================================================
   ADD TO CART / VIEW PRODUCT button — heavy, refined
   ============================================================ */
.woocommerce ul.products li.product .button,
.woocommerce-page ul.products li.product .button,
.woocommerce ul.products li.product a.button.add_to_cart_button,
.woocommerce-page ul.products li.product a.button.add_to_cart_button {
  background: var(--kc-purple-rich) !important;
  color: #fff !important;
  border: 1px solid var(--kc-purple-rich) !important;
  padding: 1em 1.6em !important;
  font-family: var(--kc-serif) !important;
  font-style: italic !important;
  font-size: 0.95rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  transition: all 0.3s ease !important;
  margin-top: auto !important;
  box-shadow: none !important;
  text-shadow: none !important;
  width: 100% !important;
  text-align: center !important;
  position: relative;
  overflow: hidden;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce-page ul.products li.product .button:hover,
.woocommerce ul.products li.product a.button.add_to_cart_button:hover,
.woocommerce-page ul.products li.product a.button.add_to_cart_button:hover {
  background: var(--kc-gold-rich) !important;
  border-color: var(--kc-gold-rich) !important;
  color: #fff !important;
  letter-spacing: 0.22em !important;
}

.woocommerce ul.products li.product .button:active,
.woocommerce-page ul.products li.product .button:active {
  transform: translateY(1px);
}

.woocommerce ul.products li.product .added_to_cart,
.woocommerce-page ul.products li.product .added_to_cart {
  display: block !important;
  text-align: center;
  font-family: var(--kc-serif);
  font-style: italic;
  font-size: 0.85rem;
  letter-spacing: 0.06em;
  color: var(--kc-gold-deep);
  margin-top: 0.8em;
}

/* ============================================================
   PAGINATION
   ============================================================ */
.woocommerce nav.woocommerce-pagination ul,
.woocommerce-page nav.woocommerce-pagination ul {
  border: none !important;
  margin-top: 3em !important;
}

.woocommerce nav.woocommerce-pagination ul li,
.woocommerce-page nav.woocommerce-pagination ul li {
  border: none !important;
  margin: 0 0.3em !important;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span,
.woocommerce-page nav.woocommerce-pagination ul li a,
.woocommerce-page nav.woocommerce-pagination ul li span {
  font-family: var(--kc-serif) !important;
  font-style: italic !important;
  font-size: 1.05rem !important;
  color: var(--kc-charcoal) !important;
  padding: 0.6em 1.05em !important;
  border: 1px solid var(--kc-divider) !important;
  border-radius: 0 !important;
  background: #fff !important;
  transition: all 0.25s ease !important;
  min-width: auto !important;
}

.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce-page nav.woocommerce-pagination ul li a:hover {
  background: var(--kc-purple-rich) !important;
  border-color: var(--kc-purple-rich) !important;
  color: #fff !important;
}

.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce-page nav.woocommerce-pagination ul li span.current {
  background: var(--kc-purple-rich) !important;
  border-color: var(--kc-purple-rich) !important;
  color: #fff !important;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
  body.post-type-archive-product #page_caption,
  body.tax-product_cat #page_caption {
    padding: 60px 16px 30px !important;
  }

  body.post-type-archive-product .page_title_content::before,
  body.tax-product_cat .page_title_content::before {
    font-size: 0.75rem;
    letter-spacing: 0.3em;
    margin-bottom: 1em;
  }

  body.post-type-archive-product #page_caption .page_title_content h1,
  body.tax-product_cat #page_caption .page_title_content h1 {
    font-size: 2.2rem !important;
  }

  body.post-type-archive-product .page_title_content::after,
  body.tax-product_cat .page_title_content::after {
    font-size: 1rem;
    max-width: 90%;
  }

  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: 1fr !important;
    gap: 1.5em;
  }

  .woocommerce ul.products li.product,
  .woocommerce-page ul.products li.product {
    padding: 1.5em 1.2em 1.8em !important;
  }

  .woocommerce ul.products li.product .woocommerce-loop-product__title,
  .woocommerce-page ul.products li.product .woocommerce-loop-product__title {
    min-height: auto;
    font-size: 1.15rem !important;
  }

  .woocommerce ul.products li.product .price,
  .woocommerce-page ul.products li.product .price {
    font-size: 1.35rem !important;
  }
}

/* ============================================================
   LEFT CATEGORY SIDEBAR (added by the kink-atelier-shop plugin)
   Grids the theme's .sidebar_content into [ sidebar | products ]
   only when our sidebar is present, so other pages are untouched.
   ============================================================ */
.woocommerce .sidebar_content.full_width:has(.ka-cat-sidebar),
.woocommerce-page .sidebar_content.full_width:has(.ka-cat-sidebar) {
  display: grid !important;
  grid-template-columns: 260px 1fr !important;
  column-gap: 3em !important;
  align-items: start !important;
}
.sidebar_content.full_width:has(.ka-cat-sidebar) > .ka-cat-sidebar {
  grid-column: 1 !important;
  grid-row: 1 / 999 !important;
}
.sidebar_content.full_width:has(.ka-cat-sidebar) > *:not(.ka-cat-sidebar) {
  grid-column: 2 !important;
}

.ka-cat-sidebar {
  background: #fff;
  border: 1px solid var(--kc-divider);
  border-radius: 2px;
  box-shadow: var(--kc-card-shadow);
  padding: 1.8em 1.6em 2em;
  position: sticky;
  top: 100px;
}
.ka-cat-title {
  font-family: var(--kc-serif);
  font-style: italic;
  font-weight: 600;
  font-size: 1.3rem;
  line-height: 1.2;
  color: var(--kc-purple-rich);
  margin: 0 0 0.9em;
  padding-bottom: 0.6em;
  border-bottom: 1px solid var(--kc-divider);
  text-align: left;
}
.ka-cat-list { list-style: none; margin: 0; padding: 0; }
.ka-cat-list li { margin: 0; }
.ka-cat-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6em;
  padding: 0.62em 0;
  font-family: var(--kc-serif);
  font-style: italic;
  font-size: 1.02rem;
  color: var(--kc-charcoal);
  text-decoration: none;
  border-bottom: 1px solid rgba(232, 226, 232, 0.7);
  transition: color 0.25s ease, padding-left 0.25s ease;
}
.ka-cat-list li:last-child .ka-cat-link { border-bottom: 0; }
.ka-cat-link:hover { color: var(--kc-purple); padding-left: 0.4em; }
.ka-cat-link.is-active { color: var(--kc-gold-deep); font-weight: 600; }
.ka-cat-count {
  color: var(--kc-muted);
  font-size: 0.78rem;
  font-style: normal;
  letter-spacing: 0.04em;
}

@media (max-width: 980px) {
  .woocommerce .sidebar_content.full_width:has(.ka-cat-sidebar),
  .woocommerce-page .sidebar_content.full_width:has(.ka-cat-sidebar) {
    display: block !important;
  }
  .ka-cat-sidebar { position: static; margin-bottom: 2.4em; }
}

/* The floated inner collapses #page_content_wrapper, so its hero→ivory gradient
   only paints a thin ugly band. Drop it and let the #wrapper marble show.
   Must match the original rule's 2-ID specificity (#page_caption + #page_content_wrapper). */
body.post-type-archive-product #page_caption + #page_content_wrapper,
body.tax-product_cat #page_caption + #page_content_wrapper,
body.tax-product_tag #page_caption + #page_content_wrapper {
  background: transparent !important;
  background-image: none !important;
}

/* ============================================================
   TOP TOOLBAR — result count + sort on one line, and the core
   WordPress search block restyled to match the kingo-child pill.
   ============================================================ */
.ka-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5em;
  flex-wrap: wrap;
  margin: 0 0 2em !important;
}
.ka-toolbar .woocommerce-result-count { margin: 0 !important; }
.ka-toolbar .woocommerce-ordering { margin: 0 !important; }
.ka-toolbar .woocommerce-ordering select { margin: 0 !important; }

/* Core WP search block (.wp-block-search) — match kingo-child's product search */
.woocommerce .wp-block-search,
.woocommerce-page .wp-block-search {
  max-width: 640px;
  margin: 0 auto 2.5em !important;
}
.wp-block-search .wp-block-search__label {
  display: block;
  text-align: center;
  font-family: var(--kc-serif);
  font-style: italic;
  font-size: 0.85rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--kc-gold-deep) !important;
  margin-bottom: 1em !important;
  padding-left: 0.35em;
}
.wp-block-search .wp-block-search__inside-wrapper {
  border: 1px solid var(--kc-divider) !important;
  border-radius: 999px !important;
  background: #fff !important;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(74, 26, 99, 0.06);
  transition: box-shadow 0.3s ease, border-color 0.3s ease;
}
.wp-block-search .wp-block-search__inside-wrapper:focus-within {
  border-color: var(--kc-purple) !important;
  box-shadow: 0 4px 18px var(--kc-purple-glow);
}
.wp-block-search .wp-block-search__input {
  border: none !important;
  background: transparent !important;
  padding: 1em 1.6em !important;
  font-family: var(--kc-serif) !important;
  font-style: italic;
  font-size: 1.05rem !important;
  color: var(--kc-charcoal) !important;
  outline: none !important;
  box-shadow: none !important;
}
.wp-block-search .wp-block-search__input::placeholder { color: var(--kc-muted); opacity: 0.7; }
.wp-block-search .wp-block-search__button {
  background: var(--kc-purple) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 1.5em !important;
  margin: 0 !important;
  cursor: pointer;
  transition: background 0.25s ease;
}
.wp-block-search .wp-block-search__button:hover { background: var(--kc-gold) !important; }
.wp-block-search .wp-block-search__button svg { fill: #fff !important; }

/* ---- Toolbar v2: search (left) + sort (right) on one row; result count hidden ---- */
/* The page's own search block is now redundant — the search lives in the toolbar. */
.woocommerce .wp-block-search,
.woocommerce-page .wp-block-search { display: none !important; }

.ka-toolbar { gap: 1.2em; }
.ka-toolbar .woocommerce-result-count { display: none !important; }

.ka-toolbar-search { flex: 1 1 280px; max-width: 360px; }
.ka-toolbar-search .woocommerce-product-search { display: flex; align-items: center; gap: 0.5em; margin: 0; }
.ka-toolbar-search .woocommerce-product-search .search-field {
  flex: 1;
  min-width: 0;
  border: 1px solid var(--kc-divider);
  border-radius: 999px;
  background: #fff;
  padding: 0.55em 1.2em;
  font-family: var(--kc-serif);
  font-style: italic;
  font-size: 0.9rem;
  color: var(--kc-charcoal);
  outline: none;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}
.ka-toolbar-search .woocommerce-product-search .search-field:focus {
  border-color: var(--kc-purple);
  box-shadow: 0 2px 12px var(--kc-purple-glow);
}
.ka-toolbar-search .woocommerce-product-search button {
  flex: 0 0 auto;
  background: var(--kc-purple);
  color: #fff;
  border: none;
  border-radius: 999px;
  padding: 0.55em 1.2em;
  cursor: pointer;
  font-family: var(--kc-serif);
  font-style: italic;
  font-size: 0.82rem;
  letter-spacing: 0.03em;
  transition: background 0.25s ease;
}
.ka-toolbar-search .woocommerce-product-search button:hover { background: var(--kc-gold); }

/* Smaller sort select */
.ka-toolbar .woocommerce-ordering select {
  padding: 0.5em 2.2em 0.5em 1.1em !important;
  font-size: 0.85rem !important;
}

@media (max-width: 600px) {
  .ka-toolbar { flex-direction: column; align-items: stretch; }
  .ka-toolbar-search { max-width: none; }
}

/* ---- Toolbar v3: search pill (magnifier icon) matching the sort select ---- */
/* Same height for both controls */
.ka-search,
.ka-toolbar .woocommerce-ordering select { height: 46px !important; box-sizing: border-box !important; }

/* Sort select: keep its arrow (don't touch background), just match height */
.ka-toolbar .woocommerce-ordering select {
  padding: 0 2.4em 0 1.2em !important;
  font-size: 0.9rem !important;
}

/* Search: same gold border + pill as the sort select, with an inline magnifier */
.ka-search {
  display: flex;
  align-items: center;
  flex: 1 1 260px;
  max-width: 360px;
  margin: 0;
  border: 1px solid var(--kc-gold) !important;
  border-radius: 999px !important;
  background: #fff !important;
  overflow: hidden;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}
.ka-search:focus-within { border-color: var(--kc-purple) !important; box-shadow: 0 2px 12px var(--kc-purple-glow); }
.ka-search__field {
  flex: 1; min-width: 0; height: 100%;
  border: none; background: transparent; box-shadow: none; outline: none;
  padding: 0 0.3em 0 1.3em;
  font-family: var(--kc-serif); font-style: italic; font-size: 0.9rem;
  color: var(--kc-charcoal);
}
.ka-search__field::placeholder { color: var(--kc-muted); opacity: 0.75; }
.ka-search__btn {
  flex: 0 0 auto; height: 100%;
  display: flex; align-items: center; justify-content: center;
  border: none; background: transparent; cursor: pointer;
  padding: 0 1.1em 0 0.5em;
  color: var(--kc-gold-deep);
  transition: color 0.25s ease;
}
.ka-search__btn:hover { color: var(--kc-purple); }
.ka-search__btn svg { display: block; }

/* ============================================================
   PAGINATION FIX — kill list bullets + floats, center the row,
   and make every number/arrow a uniform, vertically-centered box.
   ============================================================ */
.woocommerce nav.woocommerce-pagination,
.woocommerce-page nav.woocommerce-pagination { text-align: center !important; }

.woocommerce nav.woocommerce-pagination ul,
.woocommerce-page nav.woocommerce-pagination ul {
  display: inline-flex !important;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.4em;
  margin: 3em auto 0 !important;
  padding: 0 !important;
  border: 0 !important;
  list-style: none !important;
}
.woocommerce nav.woocommerce-pagination ul li,
.woocommerce-page nav.woocommerce-pagination ul li {
  float: none !important;
  display: inline-flex !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: visible !important;
  list-style: none !important;
}
.woocommerce nav.woocommerce-pagination ul li::marker,
.woocommerce-page nav.woocommerce-pagination ul li::marker { content: none !important; }

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span,
.woocommerce-page nav.woocommerce-pagination ul li a,
.woocommerce-page nav.woocommerce-pagination ul li span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 2.7em;
  height: 2.7em;
  padding: 0 0.7em !important;
  margin: 0 !important;
  line-height: 1 !important;
  border: 1px solid var(--kc-divider) !important;
  border-radius: 0 !important;
  background: #fff !important;
  font-family: var(--kc-serif) !important;
  font-style: italic !important;
  font-size: 1rem !important;
  color: var(--kc-charcoal) !important;
  transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease !important;
}
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce-page nav.woocommerce-pagination ul li a:hover {
  background: var(--kc-purple-rich) !important;
  border-color: var(--kc-purple-rich) !important;
  color: #fff !important;
}
.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce-page nav.woocommerce-pagination ul li span.current {
  background: var(--kc-purple-rich) !important;
  border-color: var(--kc-purple-rich) !important;
  color: #fff !important;
}

/* ============================================================
   COLLAPSIBLE CATEGORIES (mobile) — native <details>/<summary>.
   Desktop: always expanded, title is a plain heading.
   Mobile: collapsed by default, tap the title to expand (chevron).
   ============================================================ */
.ka-cats { margin: 0; }
.ka-cats summary.ka-cat-title {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6em;
}
.ka-cats summary.ka-cat-title::-webkit-details-marker { display: none; }
.ka-cats summary.ka-cat-title::after {
  content: "";
  flex: 0 0 auto;
  width: 0.55em; height: 0.55em;
  margin-bottom: 0.2em;
  border-right: 2px solid var(--kc-gold-deep);
  border-bottom: 2px solid var(--kc-gold-deep);
  transform: rotate(45deg);
  transition: transform 0.25s ease;
  display: none;
}

/* Desktop: force the list open and make the title non-interactive */
@media (min-width: 981px) {
  .ka-cats > .ka-cat-list { display: block !important; }
  .ka-cats summary.ka-cat-title { cursor: default; pointer-events: none; }
}

/* Mobile: collapsed by default; show + rotate the chevron */
@media (max-width: 980px) {
  .ka-cats summary.ka-cat-title { margin-bottom: 0; }
  .ka-cats[open] summary.ka-cat-title { margin-bottom: 0.9em; }
  .ka-cats summary.ka-cat-title::after { display: block; }
  .ka-cats[open] summary.ka-cat-title::after { transform: rotate(-135deg); }
}

/* Explicitly drive the collapse on mobile (don't rely on native <details> hiding,
   which the theme's CSS overrides by keeping the <ul> display:block). */
@media (max-width: 980px) {
  .ka-cats:not([open]) > .ka-cat-list { display: none !important; }
  .ka-cats[open] > .ka-cat-list { display: block !important; }
}

/* On desktop the list is ALWAYS shown, even if it was collapsed on mobile first
   (covers both [open] states + Chrome's newer ::details-content mechanism). */
@media (min-width: 981px) {
  .ka-cats:not([open]) > .ka-cat-list,
  .ka-cats[open] > .ka-cat-list { display: block !important; }
  .ka-cats::details-content { content-visibility: visible !important; display: block !important; }
}

/* #page_caption is content-box with 20px side padding, so width:100% + 40px
   pushes the page 40px off-bounds (horizontal scroll). border-box contains it. */
body.post-type-archive-product #page_caption,
body.tax-product_cat #page_caption,
body.tax-product_tag #page_caption {
  box-sizing: border-box !important;
  max-width: 100% !important;
}

/* ---- Sort select: arrow inside the box, no border ---- */
.woocommerce .woocommerce-ordering::after,
.woocommerce-page .woocommerce-ordering::after { content: none !important; display: none !important; }

.ka-toolbar .woocommerce-ordering select {
  border: 1px solid var(--kc-gold) !important;
  border-radius: 999px !important;
  background-color: #fff !important;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238C6E2E' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 0.9em center !important;
  background-size: 0.8em auto !important;
  padding: 0 2.3em 0 1.2em !important;
}
.ka-toolbar .woocommerce-ordering select:focus { outline: none !important; box-shadow: none !important; }

/* The "grey border that doesn't fit" is on the FORM wrapper, not the select. */
.woocommerce .woocommerce-ordering,
.woocommerce-page form.woocommerce-ordering {
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
}
