/*
Theme Name: KeyGif Final Theme
Theme URI: https://example.com/
Author: Shehzad
Description: WooCommerce gift card storefront theme with configurable homepage sections.
Version: 1.0.0
Text Domain: keygif-final-theme
*/

:root {
  --kg-bg: #F1F5F9;
  --kg-card: #ffffff;
  --kg-text: #111827;
  --kg-muted: #6b7280;
  --kg-primary: #10b981;
  --kg-primary-hover: #059669;
  --kg-primary-text: #ffffff;
  --kg-accent: #ffd400;
  --kg-accent-hover: #f2c800;
  --kg-accent-text: #111827;
  --kg-border: #e2e8f0;
  --kg-soft: #f1f5f9;
  --kg-header-bg: #181834;
  --kg-header-hero-glow: rgba(53, 185, 255, 0.78);
  --kg-header-text: #f8fafc;
  --kg-header-border: rgba(132, 167, 214, 0.24);
  --kg-search-bg: #10102a;
  --kg-search-text: #f8fafc;
  --kg-search-placeholder: #b7c9e8;
  --kg-header-menu-hover: #BDE715;
  --kg-header-register-bg: #90d610;
  --kg-header-register-hover: #a6e024;
  --kg-header-register-text: #000000;
  --kg-btn-gradient: linear-gradient(48deg, #90d610 -13.21%, #ddf218 51.2%);
  --kg-btn-gradient-hover: linear-gradient(48deg, #a6e024 -13.21%, #e9f84a 51.2%);
  --kg-btn-gradient-text: #000000;
  --kg-home-trust-star: #ffd400;
  --kg-footer-bg: #dde3e8;
  --kg-footer-surface: #ffffff;
  --kg-footer-text: #1f2937;
  --kg-footer-heading: #111827;
  --kg-footer-border: #cfd8df;
  --kg-footer-link: #111827;
  --kg-primary-ring: rgba(16, 185, 129, 0.14);
  --kg-primary-ring-strong: rgba(16, 185, 129, 0.3);
  --kg-primary-border-soft: rgba(16, 185, 129, 0.3);
  --kg-primary-border-strong: rgba(16, 185, 129, 0.5);
  --kg-primary-tint: rgba(16, 185, 129, 0.12);
  --kg-primary-tint-soft: rgba(16, 185, 129, 0.08);
  --kg-primary-tint-strong: rgba(16, 185, 129, 0.18);
  --kg-accent-ring: rgba(255, 212, 0, 0.14);
  --kg-home-header-bg: var(--kg-header-bg);
  --kg-home-header-bg-strong: var(--kg-header-bg);
  --kg-home-header-main-bg: var(--kg-home-header-bg);
  --kg-home-header-surface: var(--kg-search-bg);
  --kg-home-header-border: rgba(248, 250, 252, 0.14);
  --kg-home-header-border-strong: rgba(248, 250, 252, 0.24);
  --kg-home-header-accent: var(--kg-header-text);
  --kg-home-header-accent-strong: var(--kg-header-text);
  --kg-home-header-text: var(--kg-header-text);
  --kg-home-header-muted: rgba(248, 250, 252, 0.66);
  --kg-mobile-header-bg: var(--kg-header-bg);
  --kg-mobile-header-border: var(--kg-header-border);
  --kg-mobile-header-surface: var(--kg-search-bg);
  --kg-mobile-header-surface-strong: color-mix(in srgb, var(--kg-search-bg) 84%, var(--kg-header-text));
  --kg-mobile-header-text: var(--kg-header-text);
  --kg-mobile-header-muted: var(--kg-search-placeholder);
  --kg-mobile-header-count: var(--kg-accent);
  --kg-mobile-header-count-text: var(--kg-accent-text);
  --kg-radius: 14px;
  --kg-site-header-height: clamp(74px, 8vw, 88px);
  --kg-layout-max: 1280px;
  --kg-layout-gutter: 32px;
  --kg-layout-side-gutter: 16px;
}

@media (min-width: 992px) {
  :root {
    --kg-layout-max: 1400px;
    --kg-layout-gutter: 48px;
    --kg-layout-side-gutter: 24px;
  }
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--kg-text);
  background: var(--kg-bg);
}
a { color: inherit; text-decoration: none; }

.container {
  width: min(var(--kg-layout-max), calc(100% - var(--kg-layout-gutter)));
  margin: 0 auto;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 60;
  background: var(--kg-header-bg);
  border-bottom: 1px solid var(--kg-header-border);
  color: var(--kg-header-text);
  transition: background 0.24s ease, color 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}
body.admin-bar .site-header {
  top: 32px;
}
.site-header.is-stuck {
  box-shadow: 0 18px 42px rgba(2, 6, 12, 0.32);
}
@media (max-width: 782px) {
  body.admin-bar .site-header {
    top: 0;
  }
}
.site-header .container {
  width: min(var(--kg-layout-max), calc(100% - var(--kg-layout-gutter)));
}
.header-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 28px;
  align-items: center;
  min-height: 72px;
}
.branding {
  justify-self: start;
}
.branding img {
  display: block;
  max-height: 44px;
  max-width: 220px;
  width: auto;
}
.site-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--kg-header-text);
}

.kg-search {
  position: relative;
  width: 100%;
}
.kg-search input {
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--kg-header-border);
  border-radius: 14px;
  padding: 0 54px 0 18px;
  background: var(--kg-search-bg);
  color: var(--kg-search-text);
  font-size: 0.96rem;
  transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease;
}
.kg-search input[type="search"]::-webkit-search-cancel-button,
.kg-search input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
  appearance: none;
  display: none;
}
.kg-search input[type="search"]::-ms-clear,
.kg-search input[type="search"]::-ms-reveal {
  display: none;
  width: 0;
  height: 0;
}
.kg-search input::placeholder {
  color: var(--kg-search-placeholder);
}
.kg-search input:focus {
  outline: 2px solid var(--kg-primary-ring);
  box-shadow: 0 0 0 1px var(--kg-primary-ring-strong);
  background: var(--kg-search-bg);
}
.kg-search button {
  position: absolute;
  right: 7px;
  top: 50%;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: var(--kg-search-text);
  cursor: pointer;
}
.kg-search button svg {
  width: 19px;
  height: 19px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.kg-search--mobile button {
  display: none;
}

.kg-search--mobile input {
  padding-right: 18px;
}

.kg-search--desktop button {
  display: inline-flex;
  width: 48px;
  height: 48px;
}

.kg-search--desktop input {
  min-height: 52px;
  padding-right: 68px;
}

.kg-theme-search-results {
  padding: 30px 0 18px;
}
.kg-theme-search-results__header {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 24px;
}
.kg-theme-search-results__eyebrow {
  margin: 0;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--kg-primary);
}
.kg-theme-search-results__title {
  margin: 0;
  font-size: clamp(28px, 4vw, 40px);
  line-height: 1.08;
}
.kg-theme-search-results__summary {
  margin: 0;
  color: var(--kg-muted);
  font-size: 0.98rem;
}
.kg-theme-search-results__body {
  min-height: 120px;
}
.kg-theme-search-empty {
  background: var(--kg-card);
  border: 1px solid var(--kg-border);
  border-radius: 16px;
  padding: 28px;
  color: var(--kg-muted);
  font-size: 1rem;
}
body.kg-theme-search-active .site-main > :not(.kg-theme-search-results) {
  display: none;
}
body.kg-theme-search-active .site-main > .kg-theme-search-results {
  display: block;
}
body.kg-theme-search-active .site-header__hero-shell {
  min-height: 0;
  padding-bottom: 18px;
}
body.kg-theme-search-active .site-header__hero-body {
  display: none;
}

.header-actions {
  display: flex;
  align-items: center;
  justify-self: end;
  gap: 12px;
  position: relative;
}

.header-search {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.header-search__toggle {
  order: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 36px;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: #2c2c2c;
  color: #f8fafc;
  cursor: pointer;
  transition: background 0.18s ease, transform 0.18s ease;
}

.header-search__toggle:hover,
.header-search__toggle:focus-visible,
.header-search.is-open .header-search__toggle {
  background: #363636;
  color: #f8fafc;
  transform: translateY(-1px);
}

.header-search__toggle svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.kg-search--desktop {
  order: 1;
  position: relative;
  top: auto;
  right: auto;
  width: clamp(220px, 26vw, 360px);
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  z-index: auto;
}

.kg-search--desktop[hidden] {
  display: none !important;
}

.site-header .header-login {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 22px;
  border: 1px solid var(--kg-header-register-bg);
  border-radius: 999px;
  background: var(--kg-header-register-bg);
  background-color: var(--kg-header-register-bg);
  color: var(--kg-header-register-text);
  font-family: Inter, Arial, sans-serif;
  font-size: 0.99rem;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1;
  white-space: nowrap;
  transition: border-color 0.18s ease, background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}
.site-header .header-login:hover {
  border-color: var(--kg-header-register-hover);
  background: var(--kg-header-register-hover);
  background-color: var(--kg-header-register-hover);
  color: var(--kg-header-register-text);
  transform: translateY(-1px);
}

.site-header .header-cart {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 40px;
  height: 36px;
  border: 0;
  border-radius: 999px;
  background: rgba(12, 28, 56, 0.88);
  background-color: rgba(12, 28, 56, 0.88);
  color: #f8fafc;
  transition: background 0.18s ease, transform 0.18s ease;
}
.site-header .header-cart:hover {
  background: rgba(17, 40, 79, 0.96);
  background-color: rgba(17, 40, 79, 0.96);
  color: #f8fafc;
  transform: translateY(-1px);
}
.site-header .header-cart svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
  stroke-width: 1.9;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.header-cart__count {
  position: absolute;
  top: -4px;
  right: -2px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  border: 2px solid var(--kg-header-bg);
  border-radius: 999px;
  background: var(--kg-accent);
  color: var(--kg-accent-text);
  font-size: 0.68rem;
  font-weight: 700;
  line-height: 1;
}

.kg-trustpilot-stars {
  --kg-trustpilot-rating-percent: 0%;
  position: relative;
  display: inline-block;
  line-height: 1;
  white-space: nowrap;
  color: rgba(148, 163, 184, 0.38);
}

.kg-trustpilot-stars::before,
.kg-trustpilot-stars::after {
  content: "★★★★★";
  display: block;
  letter-spacing: 0.18em;
}

.kg-trustpilot-stars::after {
  position: absolute;
  left: 0;
  top: 0;
  width: var(--kg-trustpilot-rating-percent);
  overflow: hidden;
  color: var(--kg-accent);
}

.kg-home-header {
  display: none;
}

.site-header__desktop-menu-bar {
  display: none;
}

@media (min-width: 992px) {
  .header-row--site {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .header-row--site .branding {
    margin-left: 0;
  }

  .site-header--homepage {
    background: linear-gradient(180deg, var(--kg-home-header-bg) 0%, var(--kg-home-header-bg-strong) 100%);
    border-bottom-color: var(--kg-home-header-border);
    color: var(--kg-home-header-text);
  }

  .site-header--homepage.is-stuck {
    box-shadow: 0 20px 42px rgba(2, 10, 24, 0.34);
  }

  .site-header--homepage .container {
    width: min(var(--kg-layout-max), calc(100% - var(--kg-layout-gutter)));
  }

  .site-header--homepage .kg-home-header {
    display: flex;
    align-items: center;
    gap: 12px;
    width: min(calc(var(--kg-layout-max) + (var(--kg-layout-side-gutter) * 2)), 100%);
    padding: 12px var(--kg-layout-side-gutter);
    transition: padding 0.24s ease, gap 0.24s ease;
  }

  .site-header--homepage .kg-home-header__top {
    display: contents;
  }

  .site-header--homepage .branding--homepage img {
    max-width: min(100%, 170px);
    max-height: 34px;
  }

  .branding img {
    max-width: 170px;
    max-height: 34px;
  }

  .site-header .branding:not(.branding--mobile) .custom-logo-link {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    width: 170px;
    height: 34px;
    max-width: 170px;
  }

  .site-header .branding:not(.branding--mobile) img.custom-logo {
    width: 100%;
    height: 100%;
    max-width: none;
    max-height: none;
    object-fit: contain;
    object-position: left center;
  }

  .site-header--homepage .branding--homepage .site-title {
    font-size: clamp(1.8rem, 2.7vw, 2.4rem);
    letter-spacing: -0.04em;
  }

  .site-header--homepage .kg-home-header__utility {
    order: 3;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    white-space: nowrap;
    margin-left: auto;
  }

  .site-header--homepage .kg-home-header__locale {
    --kg-home-header-pill-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    height: var(--kg-home-header-pill-height);
    min-height: var(--kg-home-header-pill-height);
    min-width: 132px;
    padding: 0 11px;
    border: 1px solid rgba(115, 147, 191, 0.44);
    border-radius: 999px;
    background: var(--kg-home-header-surface);
  }

  .site-header--homepage .kg-home-header__locale::after {
    content: "";
    width: 6px;
    height: 6px;
    margin-top: -2px;
    border-right: 1.6px solid currentColor;
    border-bottom: 1.6px solid currentColor;
    transform: rotate(45deg);
    opacity: 0.82;
  }

  .site-header--homepage .kg-home-header__utility-item {
    color: var(--kg-home-header-text);
    font-size: 0.9rem;
    font-weight: 600;
  }

  .site-header--homepage .kg-home-header__utility-divider {
    width: 1px;
    height: 12px;
    background: var(--kg-home-header-border-strong);
  }

  .site-header--homepage .header-login--homepage {
    height: var(--kg-home-header-pill-height, 40px);
    min-height: var(--kg-home-header-pill-height, 40px);
    min-width: 132px;
    padding: 0 11px;
  }

  .site-header--homepage .header-login--homepage:hover {
    transform: translateY(-1px);
  }

  .site-header--homepage .kg-home-header__main {
    order: 2;
    display: flex;
    align-items: center;
    gap: clamp(14px, 1.5vw, 22px);
    flex: 1 1 0;
    max-width: none;
    min-width: 0;
    margin: 0;
    padding: 0;
    border-top: 0;
    background: transparent;
    width: auto;
  }

  .site-header--homepage .header-nav-row--homepage {
    flex: 0 0 auto;
    min-width: 0;
    margin-left: clamp(22px, 2.2vw, 34px);
    overflow: visible;
    scrollbar-width: none;
  }

  .site-header--homepage .header-nav-row--homepage::-webkit-scrollbar {
    display: none;
  }

  .site-header--homepage .branding--homepage {
    order: 1;
    flex: 0 0 auto;
    min-width: max-content;
    margin-left: 0;
  }

  .site-header--homepage .kg-home-header__search-form {
    flex: 1 1 auto;
    min-width: clamp(180px, 22vw, 340px);
    max-width: none;
    width: 100%;
  }

  .site-header--homepage .kg-home-header__search-form input {
    height: 40px;
    min-height: 40px;
    padding: 0 16px 0 52px;
    border: 1px solid rgba(110, 147, 198, 0.34);
    border-radius: 999px;
    background: var(--kg-search-bg);
    color: var(--kg-search-text);
    font-size: 0.95rem;
    font-weight: 500;
    box-shadow: none;
  }

  .site-header--homepage .kg-home-header__search-form input::placeholder {
    color: var(--kg-search-placeholder);
  }

  .site-header--homepage #kg-header-search-field-home {
    height: 40px;
    min-height: 40px;
  }

  .site-header--homepage .kg-home-header__search-form input:focus {
    outline: 2px solid rgba(121, 255, 94, 0.16);
    border-color: rgba(121, 255, 94, 0.46);
    box-shadow: 0 0 0 1px rgba(121, 255, 94, 0.24);
    background: var(--kg-search-bg);
  }

  .site-header--homepage .kg-home-header__search-form button {
    left: 12px;
    right: auto;
    display: inline-flex;
    width: 32px;
    height: 32px;
    color: var(--kg-search-placeholder);
  }

  .site-header--homepage .kg-home-header__search-form button svg {
    width: 28px;
    height: 28px;
    stroke-width: 1.8;
  }

  .site-header--homepage .header-nav-row--homepage {
    min-width: 0;
  }

  .site-header--homepage .primary-nav {
    display: flex;
    justify-content: flex-start;
    width: 100%;
  }

  .site-header--homepage .primary-menu {
    min-height: 40px;
    gap: clamp(16px, 1.6vw, 26px);
    justify-content: flex-start;
    flex-wrap: nowrap;
  }

  .site-header--homepage .primary-menu > li > a {
    min-height: 40px;
    color: var(--kg-home-header-text);
    font-family: Inter, "Segoe UI", sans-serif;
    font-size: 1.03rem;
    font-weight: 500;
    letter-spacing: 0;
    text-transform: none;
  }

  .site-header--homepage .primary-menu > li:nth-child(n+5) {
    display: none;
  }

  .site-header--homepage .primary-menu > li > a:hover,
  .site-header--homepage .primary-menu > li.current-menu-item > a,
  .site-header--homepage .primary-menu > li.current-menu-ancestor > a,
  .site-header--homepage .primary-menu > li.current_page_parent > a,
  .site-header--homepage .primary-menu > li.current_page_item > a {
    color: #BDE715;
  }

  .site-header--homepage .primary-menu > li.current-menu-item > a::before,
  .site-header--homepage .primary-menu > li.current-menu-ancestor > a::before,
  .site-header--homepage .primary-menu > li.current_page_parent > a::before,
  .site-header--homepage .primary-menu > li.current_page_item > a::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: auto;
    height: 3px;
    border-radius: 999px;
    transform: none;
    background: var(--kg-header-register-bg);
  }

  .site-header--homepage .primary-menu > .menu-item-has-children > a::after {
    color: var(--kg-home-header-muted);
    margin-left: 6px;
  }

  .site-header--homepage .primary-menu .sub-menu {
    top: calc(100% + 12px);
    background: var(--kg-home-header-main-bg);
    border: 1px solid var(--kg-home-header-border);
    box-shadow: 0 18px 40px rgba(2, 10, 24, 0.34);
  }

  .site-header--homepage .primary-menu .sub-menu a {
    color: var(--kg-home-header-text);
    font-family: Inter, "Segoe UI", sans-serif;
    font-size: 0.93rem;
    font-weight: 500;
    letter-spacing: 0;
    text-transform: none;
  }

  .site-header--homepage .primary-menu .sub-menu a:hover {
    background: color-mix(in srgb, var(--kg-home-header-main-bg) 90%, #ffffff);
    color: #79ff5e;
  }

  .site-header--homepage .primary-menu .sub-menu .menu-item-has-children > a::after {
    color: currentColor;
  }

  .site-header__desktop-menu-bar {
    display: grid;
    grid-template-columns: max-content minmax(260px, 1fr);
    align-items: center;
    width: 100vw;
    gap: clamp(16px, 1.8vw, 26px);
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    background: #172439;
    padding: 10px max(var(--kg-layout-side-gutter), calc((100vw - var(--kg-layout-max)) / 2)) 12px;
    border-top: 1px solid var(--kg-home-header-border);
    transition: padding 0.24s ease, gap 0.24s ease;
  }

  .site-header__desktop-menu-bar .kg-home-header__search-form {
    min-width: 0;
    max-width: none;
    justify-self: stretch;
    width: 100%;
  }

  .site-header__desktop-menu-bar .kg-home-header__search-form input {
    min-height: 40px;
    padding: 0 16px 0 46px;
    border: 1px solid rgba(110, 147, 198, 0.34);
    border-radius: 999px;
    background: var(--kg-search-bg);
    color: var(--kg-search-text);
    font-size: 0.95rem;
    font-weight: 500;
    box-shadow: none;
  }

  .site-header__desktop-menu-bar .kg-home-header__search-form input::placeholder {
    color: var(--kg-search-placeholder);
  }

  .site-header__desktop-menu-bar .kg-home-header__search-form input:focus {
    outline: 2px solid rgba(121, 255, 94, 0.16);
    border-color: rgba(121, 255, 94, 0.46);
    box-shadow: 0 0 0 1px rgba(121, 255, 94, 0.24);
    background: var(--kg-search-bg);
  }

  .site-header__desktop-menu-bar .kg-home-header__search-form button {
    left: 14px;
    right: auto;
    display: inline-flex;
    width: 24px;
    height: 24px;
    color: var(--kg-search-placeholder);
  }

  .site-header__desktop-menu-bar .kg-home-header__search-form button svg {
    width: 20px;
    height: 20px;
    stroke-width: 1.8;
  }

  .site-header__desktop-menu-bar .header-nav-row--homepage {
    min-width: 0;
  }

  .site-header__desktop-menu-bar .primary-nav {
    display: flex;
    justify-content: flex-start;
    width: 100%;
  }

  .site-header__desktop-menu-bar .primary-menu {
    min-height: 40px;
    gap: clamp(16px, 1.6vw, 26px);
    justify-content: flex-start;
    flex-wrap: nowrap;
  }

  .site-header__desktop-menu-bar .primary-menu > li > a {
    min-height: 40px;
    color: var(--kg-home-header-text);
    font-family: Inter, "Segoe UI", sans-serif;
    font-size: 1.03rem;
    font-weight: 500;
    letter-spacing: 0;
    text-transform: none;
  }

  .site-header__desktop-menu-bar .primary-menu > li:nth-child(n+5) {
    display: none;
  }

  .site-header__desktop-menu-bar .primary-menu > li > a:hover,
  .site-header__desktop-menu-bar .primary-menu > li.current-menu-item > a,
  .site-header__desktop-menu-bar .primary-menu > li.current-menu-ancestor > a,
  .site-header__desktop-menu-bar .primary-menu > li.current_page_parent > a,
  .site-header__desktop-menu-bar .primary-menu > li.current_page_item > a {
    color: #BDE715;
  }

  .site-header__desktop-menu-bar .primary-menu > li.current-menu-item > a::before,
  .site-header__desktop-menu-bar .primary-menu > li.current-menu-ancestor > a::before,
  .site-header__desktop-menu-bar .primary-menu > li.current_page_parent > a::before,
  .site-header__desktop-menu-bar .primary-menu > li.current_page_item > a::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: auto;
    height: 3px;
    border-radius: 999px;
    transform: none;
    background: var(--kg-header-register-bg);
  }

  .site-header__desktop-menu-bar .primary-menu > .menu-item-has-children > a::after {
    color: var(--kg-home-header-muted);
    margin-left: 6px;
  }

  .site-header__desktop-menu-bar .primary-menu .sub-menu {
    top: calc(100% + 12px);
    background: var(--kg-home-header-main-bg);
    border: 1px solid var(--kg-home-header-border);
    box-shadow: 0 18px 40px rgba(2, 10, 24, 0.34);
  }

  .site-header__desktop-menu-bar .primary-menu .sub-menu a {
    color: var(--kg-home-header-text);
    font-family: Inter, "Segoe UI", sans-serif;
    font-size: 0.93rem;
    font-weight: 500;
    letter-spacing: 0;
    text-transform: none;
  }

  .site-header__desktop-menu-bar .primary-menu .sub-menu a:hover {
    background: color-mix(in srgb, var(--kg-home-header-main-bg) 90%, #ffffff);
    color: #79ff5e;
  }

  .site-header__desktop-menu-bar .primary-menu .sub-menu .menu-item-has-children > a::after {
    color: currentColor;
  }

  .site-header.is-stuck .site-header__desktop-menu-bar {
    padding: 10px max(var(--kg-layout-side-gutter), calc((100vw - var(--kg-layout-max)) / 2)) 12px;
  }
}

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

@media (min-width: 992px) and (max-width: 1199px) {
  .site-header--homepage .container {
    width: min(var(--kg-layout-max), calc(100% - var(--kg-layout-gutter)));
  }

  .site-header--homepage .kg-home-header {
    flex-wrap: wrap;
    row-gap: 10px;
  }

  .site-header--homepage .kg-home-header__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex: 0 0 100%;
    gap: 16px;
  }

  .site-header--homepage .kg-home-header__main {
    display: grid;
    grid-template-columns: max-content minmax(190px, 1fr);
    flex: 0 0 100%;
    gap: clamp(12px, 1.4vw, 18px);
    width: 100%;
  }

  .site-header--homepage .kg-home-header__search-form {
    min-width: clamp(170px, 20vw, 300px);
    max-width: none;
    width: 100%;
    justify-self: stretch;
  }

  .site-header--homepage .header-nav-row--homepage {
    margin-left: 0;
  }

  .site-header__desktop-menu-bar {
    grid-template-columns: max-content minmax(230px, 1fr);
    gap: 18px;
  }

  .site-header--homepage .primary-menu {
    gap: clamp(14px, 1.4vw, 20px);
  }

  .site-header__desktop-menu-bar .primary-menu {
    gap: clamp(14px, 1.4vw, 20px);
  }
}

@media (min-width: 992px) and (max-width: 1080px) {
  .site-header--homepage .header-nav-row--homepage {
    overflow-x: auto;
    padding-bottom: 4px;
  }

  .site-header__desktop-menu-bar .header-nav-row--homepage {
    overflow-x: auto;
    padding-bottom: 4px;
  }

  .site-header--homepage .primary-menu {
    flex-wrap: nowrap;
    min-width: max-content;
  }

  .site-header__desktop-menu-bar .primary-menu {
    flex-wrap: nowrap;
    min-width: max-content;
  }

  .site-header--homepage .kg-home-header__main {
    gap: 18px;
  }

  .site-header__desktop-menu-bar {
    gap: 18px;
  }
}

@media (min-width: 1200px) {
  .site-header--homepage .branding--homepage {
    margin-left: 0;
  }
}

@media (min-width: 992px) {
  .site-header--homepage .container.kg-home-header {
    width: min(calc(var(--kg-layout-max) + (var(--kg-layout-side-gutter) * 2)), 100%);
  }
}

.site-header .header-login span {
  font: inherit;
}
.header-nav-row {
  min-width: 0;
}
.header-nav-row--desktop {
  padding-inline: 4px 18px;
}
.primary-nav { width: 100%; }
.primary-menu {
  margin: 0;
  padding: 0;
  list-style: none;
  min-height: 72px;
  display: flex;
  align-items: center;
  gap: clamp(18px, 2vw, 34px);
}
.primary-menu li {
  list-style: none;
  position: relative;
}
.primary-menu > li > a {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 72px;
  font-size: 1.04rem;
  font-weight: 400;
  color: var(--kg-header-text);
  transition: color 0.18s ease;
}
.primary-menu > li > a:hover {
  color: var(--kg-header-menu-hover);
}
.primary-menu > li.current-menu-item > a,
.primary-menu > li.current-menu-ancestor > a,
.primary-menu > li.current_page_parent > a,
.primary-menu > li.current_page_item > a {
  color: var(--kg-header-menu-hover);
}
.primary-menu > li.current-menu-item > a::before,
.primary-menu > li.current-menu-ancestor > a::before,
.primary-menu > li.current_page_parent > a::before,
.primary-menu > li.current_page_item > a::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: auto;
  height: 3px;
  border-radius: 999px;
  transform: none;
  background: var(--kg-header-register-bg);
}
.primary-menu > .menu-item-has-children::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  height: 12px;
}
.primary-menu > .menu-item-has-children > a::after {
  content: "▾";
  font-size: 0.68em;
  margin-left: 8px;
  color: var(--kg-search-placeholder);
}
.primary-menu .sub-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  display: none;
  margin: 0;
  padding: 8px 0;
  min-width: 220px;
  background: var(--kg-header-bg);
  border: 1px solid var(--kg-header-border);
  border-radius: 16px;
  box-shadow: 0 24px 52px rgba(2, 6, 12, 0.28);
  z-index: 15;
}
.primary-menu .sub-menu .sub-menu {
  top: -8px;
  left: calc(100% + 8px);
}
.primary-menu .sub-menu .menu-item-has-children::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 100%;
  width: 12px;
}
.primary-menu .sub-menu a {
  display: block;
  padding: 10px 16px;
  font-size: 13px;
  color: var(--kg-header-text);
  transition: background 0.18s ease, color 0.18s ease;
}
.primary-menu .sub-menu .menu-item-has-children > a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.primary-menu .sub-menu .menu-item-has-children > a::after {
  content: "▾";
  flex: 0 0 auto;
  margin-left: 12px;
  font-size: 0.78em;
  line-height: 1;
  color: var(--kg-search-placeholder);
}
.primary-menu .sub-menu a:hover {
  background: var(--kg-search-bg);
  color: var(--kg-header-menu-hover);
}
.primary-menu li:hover > .sub-menu,
.primary-menu li:focus-within > .sub-menu { display: block; }
.kg-desktop-brand-menu-item > .sub-menu {
  min-width: 260px;
}
.primary-menu .sub-menu--product-brands a {
  font-family: inherit;
  font-size: 1.04rem;
  font-weight: 400;
}
.primary-menu .sub-menu--product-brands a:hover {
  color: var(--kg-header-menu-hover);
}
.site-header--homepage .primary-menu .sub-menu--product-brands a {
  font-family: Inter, "Segoe UI", sans-serif;
  font-size: 0.93rem;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
}
.site-header--homepage .primary-menu .sub-menu--product-brands a:hover {
  color: var(--kg-header-menu-hover);
}

.site-header--hero {
  overflow: hidden;
  border-bottom: 0 !important;
  color: var(--kg-header-text);
  background: var(--kg-header-bg);
}

.site-header--hero::before,
.site-header--hero::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.24s ease;
}

.site-header--hero::before {
  inset: -14% 42% 8% -14%;
  background: radial-gradient(circle at 22% 48%, var(--kg-header-hero-glow) 0%, rgba(53, 185, 255, 0.48) 28%, rgba(53, 185, 255, 0.14) 52%, rgba(53, 185, 255, 0) 72%);
  filter: blur(10px);
}

.site-header--hero::after {
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0) 18%, rgba(7, 21, 33, 0.12) 54%, rgba(7, 21, 33, 0.36) 100%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.04) 0%, rgba(255, 255, 255, 0) 20%);
}

.site-header--hero .container {
  position: relative;
  z-index: 1;
}

.site-header__hero-shell {
  min-height: 0;
  padding: 18px 0 0;
  border-bottom: 0;
  transition: padding 0.24s ease;
}

.site-header__hero-top {
  position: relative;
  min-height: 0;
}

.branding--hero {
  position: absolute;
  top: 2px;
  left: 0;
  z-index: 2;
  padding-top: 2px;
}

.branding--hero img {
  max-height: 48px;
}

.site-header--hero .site-title {
  color: var(--kg-header-text);
  font-size: 2rem;
}

.site-header__hero-controls {
  min-width: 0;
  width: 100%;
}

.site-header__hero-mainline {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  min-height: 54px;
  padding: 8px 0 12px;
  padding-left: 220px;
  border-bottom: 0;
  transition: padding 0.24s ease, min-height 0.24s ease;
}

.site-header__hero-mainline::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  background: rgba(148, 163, 184, 0.72);
}

.header-nav-row--hero {
  flex: 0 1 auto;
  min-width: 0;
  margin-left: auto;
  margin-right: clamp(18px, 2vw, 30px);
  padding: 0;
  border-bottom: 0;
}

.site-header--hero .primary-nav {
  display: flex;
  width: auto;
  justify-content: flex-end;
}

.site-header--hero .primary-menu {
  justify-content: flex-start;
  gap: 18px;
  min-height: 42px;
}

.site-header--hero .primary-menu > li > a {
  position: relative;
  min-height: 42px;
  color: var(--kg-header-text);
  font-size: 0.94rem;
  font-weight: 400;
  letter-spacing: -0.01em;
}

.site-header--hero .primary-menu > li > a:hover {
  color: var(--kg-primary);
}

.site-header--hero .primary-menu > li.current-menu-item > a::before,
.site-header--hero .primary-menu > li.current-menu-ancestor > a::before,
.site-header--hero .primary-menu > li.current_page_parent > a::before {
  content: none;
}

.site-header--hero .primary-menu > .menu-item-has-children > a::after {
  color: var(--kg-muted);
}

.site-header--hero .primary-menu .sub-menu {
  top: calc(100% + 12px);
  background: var(--kg-card);
  border: 1px solid var(--kg-header-border);
  box-shadow: 0 18px 34px rgba(15, 23, 42, 0.1);
  backdrop-filter: none;
}

.site-header--hero .primary-menu .sub-menu a {
  color: var(--kg-header-text);
}

.site-header__hero-tools {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
  flex: 0 0 auto;
  flex-wrap: nowrap;
  min-width: 0;
}

.site-header--hero .kg-search {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(clamp(360px, 32vw, 520px), calc(100% - 560px));
  max-width: 100%;
  flex: none;
  transform: translate(-50%, -50%);
}

.site-header--hero .kg-search input {
  min-height: 50px;
  padding-right: 20px;
  border: 1px solid var(--kg-header-border);
  background: var(--kg-search-bg);
  color: var(--kg-search-text);
  box-shadow: none;
  backdrop-filter: none;
}

.site-header--hero .kg-search input::placeholder {
  color: var(--kg-search-placeholder);
}

.site-header--hero .kg-search input:focus {
  outline: 2px solid var(--kg-primary-ring);
  box-shadow: 0 0 0 1px var(--kg-primary-ring-strong);
  background: var(--kg-card);
}

.site-header--hero .kg-search button {
  display: none;
}

.site-header--hero .header-actions {
  justify-self: auto;
  gap: 8px;
  flex: 0 0 auto;
}

.site-header--hero .header-login {
  min-height: 46px;
  padding: 0 16px;
  border-color: var(--kg-primary);
  background: var(--kg-primary);
  background-color: var(--kg-primary);
  color: var(--kg-primary-text);
  box-shadow: none;
  backdrop-filter: none;
}

.site-header--hero .header-login:hover {
  border-color: var(--kg-primary-hover);
  background: var(--kg-primary-hover);
  background-color: var(--kg-primary-hover);
  color: var(--kg-primary-text);
}

.site-header--hero .header-cart {
  width: 46px;
  height: 46px;
  border-color: var(--kg-primary-border-soft);
  background: var(--kg-header-bg);
  background-color: var(--kg-header-bg);
  color: var(--kg-primary);
  box-shadow: none;
  backdrop-filter: none;
}

.site-header--hero .header-cart:hover {
  border-color: var(--kg-primary-border-strong);
  background: var(--kg-header-bg);
  background-color: var(--kg-header-bg);
  color: var(--kg-primary-hover);
}

.site-header--hero .header-cart__count {
  border-color: var(--kg-header-bg);
  background: var(--kg-primary);
  color: var(--kg-primary-text);
}

.site-header--hero:not(.is-stuck) {
  color: #fff;
  background: transparent;
  border-bottom: 0;
  box-shadow: none;
}

.site-header--hero:not(.is-stuck)::before,
.site-header--hero:not(.is-stuck)::after {
  opacity: 0;
}

.site-header--hero.is-stuck .site-header__hero-shell {
  padding-bottom: 0;
}

.site-header--hero:not(.is-stuck) .site-title,
.site-header--hero:not(.is-stuck) .primary-menu > li > a {
  color: #fff;
}

.site-header--hero:not(.is-stuck) .primary-menu > li > a:hover {
  color: rgba(255, 255, 255, 0.82);
}

.site-header--hero:not(.is-stuck) .primary-menu > li.current-menu-item > a::before,
.site-header--hero:not(.is-stuck) .primary-menu > li.current-menu-ancestor > a::before,
.site-header--hero:not(.is-stuck) .primary-menu > li.current_page_parent > a::before {
  content: none;
  background: none;
}

.site-header--hero:not(.is-stuck) .primary-menu > .menu-item-has-children > a::after {
  color: rgba(255, 255, 255, 0.54);
}

.site-header--hero:not(.is-stuck) .primary-menu .sub-menu {
  background: rgba(7, 21, 33, 0.92);
  border-color: rgba(255, 255, 255, 0.12);
  box-shadow: 0 24px 50px rgba(2, 10, 18, 0.32);
  backdrop-filter: blur(16px);
}

.site-header--hero:not(.is-stuck) .primary-menu .sub-menu a {
  color: #fff;
}

.site-header--hero.is-stuck .site-header__hero-mainline {
  min-height: 50px;
  padding-bottom: 8px;
}

.site-header--hero:not(.is-stuck) .site-header__hero-mainline::after {
  background: rgba(255, 255, 255, 0.22);
}

.site-header--hero:not(.is-stuck) .branding--hero img {
  filter: drop-shadow(0 12px 28px rgba(2, 10, 18, 0.24));
}

.site-header--hero:not(.is-stuck) .kg-search input {
  border-color: rgba(255, 255, 255, 0.15);
  background: rgba(7, 21, 33, 0.34);
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 16px 36px rgba(2, 10, 18, 0.16);
  backdrop-filter: blur(14px);
}

.site-header--hero:not(.is-stuck) .kg-search input::placeholder {
  color: rgba(255, 255, 255, 0.68);
}

.site-header--hero:not(.is-stuck) .kg-search input:focus {
  outline: 2px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.18), 0 16px 36px rgba(2, 10, 18, 0.18);
  background: rgba(7, 21, 33, 0.46);
}

.site-header--hero:not(.is-stuck) .header-login {
  border-color: rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.11);
  background-color: rgba(255, 255, 255, 0.11);
  color: #fff;
  box-shadow: 0 16px 36px rgba(2, 10, 18, 0.14);
  backdrop-filter: blur(14px);
}

.site-header--hero:not(.is-stuck) .header-login:hover {
  border-color: rgba(255, 255, 255, 0.28);
  background: rgba(255, 255, 255, 0.18);
  background-color: rgba(255, 255, 255, 0.18);
  color: #fff;
}

.site-header--hero:not(.is-stuck) .header-cart {
  border-color: rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.11);
  background-color: rgba(255, 255, 255, 0.11);
  color: #fff;
  box-shadow: 0 16px 36px rgba(2, 10, 18, 0.14);
  backdrop-filter: blur(14px);
}

.site-header--hero:not(.is-stuck) .header-cart:hover {
  border-color: rgba(255, 255, 255, 0.28);
  background: rgba(255, 255, 255, 0.18);
  background-color: rgba(255, 255, 255, 0.18);
  color: #fff;
}

.site-header--hero:not(.is-stuck) .header-cart__count {
  border-color: rgba(7, 21, 33, 0.9);
  background: #fff;
  color: #081a2a;
}

.site-header__hero-body {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: 22px;
  align-items: center;
  padding-top: 26px;
}

.site-header__hero-copy {
  position: relative;
  z-index: 2;
  max-width: 620px;
  padding-top: 34px;
}

.site-header__hero-title {
  margin: 0;
  display: grid;
  gap: 8px;
  font-family: "Barlow Condensed", sans-serif;
  font-size: clamp(3.35rem, 6.2vw, 5.7rem);
  font-weight: 700;
  line-height: 1.01;
  letter-spacing: 0.01em;
  color: rgba(255, 255, 255, 0.92);
  text-shadow: 0 16px 38px rgba(2, 10, 18, 0.18);
}

.site-header__hero-title span {
  display: block;
}

.site-header__hero-summary {
  max-width: 760px;
  margin: 30px 0 0;
  color: rgba(255, 255, 255, 0.9);
  font-size: clamp(1rem, 1.5vw, 1.22rem);
  line-height: 1.6;
}

.site-header__hero-visual {
  position: relative;
  min-height: 590px;
  isolation: isolate;
}

.site-header__hero-top-dots {
  position: absolute;
  top: 8px;
  right: 18px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.34);
  box-shadow: -20px 0 0 rgba(255, 255, 255, 0.34), -40px 0 0 rgba(255, 255, 255, 0.34);
}

.site-header__hero-dot-grid {
  position: absolute;
  display: block;
  background-image: radial-gradient(rgba(255, 255, 255, 0.3) 1.5px, rgba(255, 255, 255, 0) 1.5px);
  background-size: 22px 22px;
  opacity: 0.7;
}

.site-header__hero-dot-grid--left {
  left: -40px;
  top: 178px;
  width: 290px;
  height: 206px;
}

.site-header__hero-dot-grid--right {
  right: -4px;
  top: 22px;
  width: 116px;
  height: 96px;
  opacity: 0.46;
}

.site-header__hero-float,
.site-header__hero-card {
  position: absolute;
  display: block;
  transform-origin: center;
}

.site-header__hero-float {
  z-index: 1;
  pointer-events: none;
  opacity: 0.46;
  filter: saturate(0.92) brightness(0.86);
}

.site-header__hero-float img,
.site-header__hero-card img {
  display: block;
  width: 100%;
  height: auto;
}

.site-header__hero-float img {
  border-radius: 18px;
  box-shadow: 0 22px 54px rgba(2, 10, 18, 0.34);
}

.site-header__hero-float--logo,
.site-header__hero-float--logo-edge-1,
.site-header__hero-float--logo-edge-2 {
  aspect-ratio: 5 / 8.4;
  overflow: hidden;
  border-radius: 18px;
}

.site-header__hero-float--logo {
  left: 10px;
  top: 34px;
  width: clamp(84px, 8.6vw, 108px);
  opacity: 0.42;
  filter: saturate(0.98) brightness(0.94);
  transform: rotate(-24deg);
  z-index: 1;
}

.site-header__hero-float--logo-edge-1 {
  left: -54px;
  top: 18px;
  width: clamp(54px, 5.6vw, 70px);
  opacity: 0.3;
  transform: rotate(-24deg);
}

.site-header__hero-float--logo-edge-2 {
  left: -34px;
  top: 144px;
  width: clamp(46px, 4.8vw, 60px);
  opacity: 0.24;
  transform: rotate(-24deg);
}

.site-header__hero-float--logo img,
.site-header__hero-float--logo-edge-1 img,
.site-header__hero-float--logo-edge-2 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.site-header__hero-float--support-1 {
  left: 126px;
  right: auto;
  top: auto;
  bottom: 14px;
  width: clamp(82px, 8.4vw, 102px);
  opacity: 0.56;
  transform: rotate(-18deg);
}

.site-header__hero-float--support-2 {
  left: 244px;
  bottom: 14px;
  width: clamp(88px, 8.9vw, 108px);
  opacity: 0.54;
  transform: rotate(-18deg);
}

.site-header__hero-float--support-3 {
  left: 368px;
  right: auto;
  bottom: 14px;
  width: clamp(94px, 9.4vw, 114px);
  opacity: 0.44;
  transform: rotate(-18deg);
}

.site-header__hero-card {
  --kg-hero-card-rotate: 0deg;
  --kg-hero-card-scale: 1;
  --kg-hero-card-shift-y: 0px;
  overflow: hidden;
  border-radius: 14px;
  box-shadow:
    0 28px 64px rgba(2, 10, 18, 0.42),
    0 0 18px rgba(76, 197, 255, 0.16);
  border: 1px solid rgba(255, 255, 255, 0.12);
  pointer-events: auto;
  transform: translateY(var(--kg-hero-card-shift-y)) rotate(var(--kg-hero-card-rotate)) scale(var(--kg-hero-card-scale));
  transition: transform 220ms ease, box-shadow 220ms ease, filter 220ms ease;
  filter: drop-shadow(0 0 10px rgba(91, 208, 255, 0.12));
}

.site-header__hero-card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    radial-gradient(circle at 18% 16%, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0) 34%),
    linear-gradient(135deg, rgba(95, 220, 255, 0.14) 0%, rgba(95, 220, 255, 0) 52%);
  opacity: 0.7;
  pointer-events: none;
}

.site-header__hero-card img {
  border-radius: inherit;
  box-shadow: none;
  transform-origin: center center;
}

.site-header__hero-card--left {
  left: 74px;
  right: auto;
  top: -34px;
  width: clamp(188px, 20vw, 228px);
  z-index: 3;
  --kg-hero-card-rotate: -10deg;
}

.site-header__hero-card--right {
  left: auto;
  right: 6px;
  top: -12px;
  width: clamp(246px, 26vw, 296px);
  z-index: 4;
  --kg-hero-card-rotate: 9deg;
}

.site-header__hero-card:hover {
  --kg-hero-card-scale: 1.06;
  --kg-hero-card-shift-y: -12px;
  z-index: 6;
  box-shadow:
    0 34px 78px rgba(2, 10, 18, 0.5),
    0 0 24px rgba(76, 197, 255, 0.24);
  filter: drop-shadow(0 0 14px rgba(91, 208, 255, 0.22));
}

.kg-blog-archive,
.kg-page-content {
  padding: 32px 0 48px;
}

.kg-blog-archive__header,
.kg-page-content__header {
  max-width: 760px;
  margin-bottom: 24px;
}

.kg-blog-archive__eyebrow {
  margin: 0 0 10px;
  color: var(--kg-primary);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.kg-blog-archive__title,
.kg-page-content__header h1 {
  margin: 0;
  font-size: clamp(2rem, 3vw, 3rem);
  line-height: 1.08;
}

.kg-blog-archive__description {
  margin-top: 14px;
  color: var(--kg-muted);
  line-height: 1.75;
}

.kg-blog-archive__description > *:first-child {
  margin-top: 0;
}

.kg-blog-archive__description > *:last-child {
  margin-bottom: 0;
}

.kg-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.kg-post-card {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  overflow: hidden;
  border: 1px solid var(--kg-border);
  border-radius: 20px;
  background: var(--kg-card);
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.06);
}

.kg-post-card__image-link {
  display: block;
  background: linear-gradient(135deg, var(--kg-primary-ring), rgba(14, 165, 233, 0.16));
}

.kg-post-card__image {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

.kg-post-card__image--placeholder {
  background: linear-gradient(135deg, var(--kg-primary-tint-strong), rgba(148, 163, 184, 0.26));
}

.kg-post-card__body {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
  padding: 24px;
}

.kg-post-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  color: var(--kg-muted);
  font-size: 0.88rem;
}

.kg-post-card__meta a {
  color: inherit;
}

.kg-post-card__title {
  margin: 0;
  font-size: 1.35rem;
  line-height: 1.3;
}

.kg-post-card__excerpt {
  color: var(--kg-muted);
  line-height: 1.75;
}

.kg-post-card__excerpt p {
  margin: 0;
}

.kg-post-card__link {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  background: var(--kg-primary);
  color: var(--kg-primary-text);
  font-size: 0.94rem;
  font-weight: 600;
}

.kg-post-card__link:hover {
  background: var(--kg-primary-hover);
}

.navigation.pagination {
  margin-top: 32px;
}

.navigation.pagination .nav-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.navigation.pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  padding: 0 16px;
  border: 1px solid var(--kg-border);
  border-radius: 50%;
  background: var(--kg-card);
  color: var(--kg-text);
  font-weight: 600;
  text-decoration: none;
  transition: all 0.2s ease;
}

.navigation.pagination .page-numbers.current,
.navigation.pagination .page-numbers:hover {
  border-color: transparent;
  background: var(--kg-primary);
  color: var(--kg-primary-text);
}

.navigation.pagination .page-numbers .page-navigator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.kg-empty-state,
.kg-blog-archive__empty,
.kg-page-content__body {
  padding: 28px 30px;
  border: 1px solid var(--kg-border);
  border-radius: 20px;
  background: var(--kg-card);
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.05);
  overflow: auto;
}

.kg-blog-archive__empty h2,
.kg-empty-state h2 {
  margin: 0 0 8px;
  font-size: 1.25rem;
}

.kg-blog-archive__empty p,
.kg-empty-state p {
  margin: 0;
  color: var(--kg-muted);
}

.kg-page-content__body {
  line-height: 1.8;
}

.kg-page-content__body > *:first-child {
  margin-top: 0;
}

.kg-page-content__body > *:last-child {
  margin-bottom: 0;
}

.kg-single-post__featured {
  display: none;
  margin: 0 auto 24px;
  max-width: 760px;
  overflow: hidden;
  border: 1px solid var(--kg-border);
  border-radius: 20px;
  background: var(--kg-card);
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.05);
}

.kg-single-post__featured-image {
  display: block;
  width: 100%;
  height: auto;
}

.kg-single-post__inline-featured {
  float: left;
  width: 280px;
  margin: 0 28px 20px 0;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--kg-border);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.07);
}

.kg-single-post__inline-featured img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}

.kg-blog-index {
  padding: 32px 16px 48px;
}

.kg-blog-index__header {
  display: none;
  align-items: center;
  gap: 10px;
  margin-bottom: 32px;
}

.kg-blog-index__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 30px;
  height: 30px;
  color: #ff8a1d;
}

.kg-blog-index__icon svg {
  display: block;
  width: 100%;
  height: 100%;
  fill: currentColor;
}

.kg-blog-index__icon svg path + path {
  fill: #ffffff;
}

.kg-blog-index__header h1 {
  margin: 0;
  color: #020617;
  font-size: clamp(25px, 2.1vw, 32px);
  font-weight: 800;
  line-height: 1.16;
  letter-spacing: 0;
}

.kg-blog-index__intro {
  display: block;
  max-width: 720px;
  margin: 0 0 28px;
}

.kg-blog-index__desktop-title {
  margin: 0;
  color: #030712;
  font-size: clamp(28px, 7vw, 38px);
  font-weight: 800;
  line-height: 1.16;
  letter-spacing: 0;
}

.kg-blog-index__desktop-title-accent {
  color: var(--kg-header-register-bg);
}

.kg-blog-index__description {
  max-width: 44rem;
  margin: 12px 0 0;
  color: #667085;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.62;
}

.kg-blog-index__search {
  position: relative;
  display: flex;
  align-items: center;
  width: min(100%, 390px);
  height: 50px;
  margin-top: 18px;
}

.kg-blog-index__search-icon {
  position: absolute;
  left: 18px;
  top: 50%;
  display: inline-flex;
  width: 19px;
  height: 19px;
  color: #8c98a5;
  pointer-events: none;
  transform: translateY(-50%);
}

.kg-blog-index__search-icon svg {
  display: block;
  width: 100%;
  height: 100%;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}

.kg-blog-index__search input[type="search"] {
  width: 100%;
  height: 100%;
  border: 0;
  border-radius: 999px;
  padding: 0 18px 0 48px;
  background: #effff0;
  color: #111827;
  font: inherit;
  font-size: 15px;
  font-weight: 600;
  line-height: 1;
  outline: 0;
  transition: box-shadow 0.18s ease, background-color 0.18s ease;
}

.kg-blog-index__search input[type="search"]::-webkit-search-cancel-button,
.kg-blog-index__search input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
  appearance: none;
  display: none;
}

.kg-blog-index__search input[type="search"]::placeholder {
  color: #7e8996;
  opacity: 1;
}

.kg-blog-index__search input[type="search"]:focus {
  background: #ecffed;
  box-shadow: 0 0 0 3px var(--kg-primary-ring);
}

.kg-blog-index__empty--search {
  margin: 0;
}

.kg-blog-index__empty--search h2 {
  margin: 0;
  font-size: 1rem;
}

.kg-blog-index .navigation.pagination {
  margin-top: 42px;
}

.kg-blog-index .navigation.pagination .nav-links {
  justify-content: center;
  gap: 8px;
}

.kg-blog-index .navigation.pagination .page-numbers {
  min-width: 32px;
  min-height: 32px;
  padding: 0 9px;
  border: 0;
  border-radius: 7px;
  background: transparent;
  color: #5f6875;
  font-size: 14px;
  font-weight: 500;
}

.kg-blog-index .navigation.pagination .page-numbers.current,
.kg-blog-index .navigation.pagination .page-numbers:hover {
  background: var(--kg-accent);
  color: var(--kg-accent-text);
}

.kg-blog-index .navigation.pagination .page-numbers.dots,
.kg-blog-index .navigation.pagination .page-numbers.dots:hover {
  background: transparent;
  color: #5f6875;
}

.kg-blog-index .navigation.pagination .page-numbers.prev,
.kg-blog-index .navigation.pagination .page-numbers.next {
  color: #9aa3af;
  font-size: 22px;
  line-height: 1;
}

.kg-blog-index .screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.kg-blog-index__breadcrumbs {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 7px;
  margin-bottom: 16px;
  color: #6b7280;
  font-size: 14px;
  line-height: 1.4;
}

.kg-blog-index__breadcrumbs a {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: inherit;
}

.kg-blog-index__breadcrumbs svg {
  width: 15px;
  height: 15px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.8;
}

.kg-blog-index__breadcrumbs strong {
  color: #020617;
  font-weight: 700;
}

.kg-blog-index__empty {
  padding: 28px 30px;
  border: 1px solid var(--kg-border);
  border-radius: 8px;
  background: #ffffff;
}

.kg-blog-index__empty h2 {
  margin: 0 0 8px;
}

.kg-blog-index__empty p {
  margin: 0;
  color: var(--kg-muted);
}

.kg-blog-list-card__comments {
  display: none;
}

.kg-blog-list-card__comments .kg-blog-list-card__comments-icon--desktop {
  display: none;
}

.kg-blog-index__pagination--desktop {
  display: none;
}

.kg-blog-index__pagination[hidden] {
  display: none !important;
}

@media (max-width: 980px) {
  .kg-blog-index__grid {
    grid-template-columns: 1fr;
  }

  .kg-blog-list-card__link {
    min-height: 90px;
  }

  .kg-blog-list-card__media {
    aspect-ratio: 1.4 / 1;
  }
}

@media (max-width: 560px) {
  .kg-blog-index {
    padding: 20px 0 36px;
  }

  .kg-blog-index__breadcrumbs {
    margin-bottom: 14px;
  }

  .kg-blog-index__header {
    margin-bottom: 18px;
  }

  .kg-blog-index__intro {
    margin-bottom: 22px;
  }

  .kg-blog-index__desktop-title {
    font-size: 26px;
    line-height: 1.18;
  }

  .kg-blog-index__description {
    font-size: 14px;
    line-height: 1.58;
  }

  .kg-blog-index__search {
    height: 48px;
    margin-top: 16px;
  }

  .kg-blog-index__icon {
    display: none;
  }

  .kg-blog-index__header h1 {
    font-size: 20px;
    font-weight: 500;
    line-height: 1.2;
  }

  .kg-blog-index__grid {
    display: block;
  }

  .kg-blog-list-card {
    overflow: visible;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
  }

  .kg-blog-list-card:not(:last-child) {
    padding-bottom: 20px;
    margin-bottom: 19px;
    border-bottom: 1px solid var(--kg-border);
  }

  .kg-blog-list-card__link {
    --kg-blog-thumb-width: clamp(116px, 38vw, 140px);
    display: grid;
    grid-template-columns: var(--kg-blog-thumb-width) minmax(0, 1fr);
    column-gap: 15px;
    align-items: start;
    min-height: 79px;
    color: inherit;
  }

  .kg-blog-list-card__media {
    display: block;
    width: var(--kg-blog-thumb-width);
    aspect-ratio: 16 / 9;
    min-width: 0;
    max-height: none;
    overflow: hidden;
    border-radius: 5px;
    background: var(--kg-soft);
  }

  .kg-blog-list-card__image {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 0;
    border-radius: inherit;
    object-fit: cover;
  }

  .kg-blog-list-card__body {
    display: flex;
    min-width: 0;
    flex-direction: column;
    align-items: flex-start;
    padding: 0;
  }

  .kg-blog-list-card__title {
    order: 2;
    display: -webkit-box;
    overflow: hidden;
    max-width: 100%;
    color: var(--kg-text);
    font-size: 15px;
    font-weight: 500;
    line-height: 1.45;
    letter-spacing: 0;
    overflow-wrap: anywhere;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }

  .kg-blog-list-card__excerpt {
    display: none;
  }

  .kg-blog-list-card__date {
    order: 1;
    display: block;
    margin: 0 0 6px;
    color: var(--kg-muted);
    font-size: 14px;
    line-height: 1.3;
  }

  .kg-blog-list-card__comments {
    order: 3;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin-top: 8px;
    color: var(--kg-muted);
    font-size: 13px;
    line-height: 1;
  }

  .kg-blog-list-card__comments svg {
    display: block;
    width: 16px;
    height: 16px;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.7;
  }

  .kg-blog-index .navigation.pagination .nav-links {
    gap: 4px;
  }

  .kg-blog-index .navigation.pagination .page-numbers {
    min-width: 30px;
    min-height: 30px;
    padding: 0 8px;
    font-size: 13px;
  }
}

@media (min-width: 981px) {
  .kg-blog-index {
    --kg-blog-desktop-side-pad: clamp(18px, 1.55vw, 22px);
    padding: clamp(86px, 7.25vw, 104px) var(--kg-blog-desktop-side-pad) 78px;
    background: #ffffff;
    box-shadow: 0 0 0 100vmax #ffffff;
    clip-path: inset(0 -100vmax);
  }

  .kg-blog-index__breadcrumbs {
    display: none;
  }

  .kg-blog-index__header {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    border: 0;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
  }

  .kg-blog-index__intro {
    display: block;
    max-width: 980px;
    margin-bottom: 0;
  }

  .kg-blog-index__desktop-title {
    max-width: 1050px;
    margin: 0;
    color: #030712;
    font-size: clamp(38px, 3.2vw, 48px);
    font-weight: 800;
    line-height: 1.14;
    letter-spacing: 0;
  }

  .kg-blog-index__desktop-title-accent {
    color: var(--kg-header-register-bg);
  }

  .kg-blog-index__description {
    max-width: 880px;
    min-height: 3.3em;
    margin: 22px 0 0;
    color: #667085;
    font-size: clamp(18px, 1.45vw, 21px);
    font-weight: 500;
    line-height: 1.65;
  }

  .kg-blog-index__search {
    position: relative;
    display: flex;
    align-items: center;
    width: clamp(330px, 28vw, 378px);
    height: 58px;
    margin-top: 40px;
  }

  .kg-blog-index__search-icon {
    position: absolute;
    left: 23px;
    top: 50%;
    display: inline-flex;
    width: 21px;
    height: 21px;
    color: #8c98a5;
    pointer-events: none;
    transform: translateY(-50%);
  }

  .kg-blog-index__search-icon svg {
    display: block;
    width: 100%;
    height: 100%;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2.1;
  }

  .kg-blog-index__search input[type="search"] {
    width: 100%;
    height: 100%;
    border: 0;
    border-radius: 999px;
    padding: 0 24px 0 60px;
    background: #effff0;
    color: #111827;
    font: inherit;
    font-size: 18px;
    font-weight: 600;
    line-height: 1;
    outline: 0;
    transition: box-shadow 0.18s ease, background-color 0.18s ease;
  }

  .kg-blog-index__search input[type="search"]::-webkit-search-cancel-button,
  .kg-blog-index__search input[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
    appearance: none;
    display: none;
  }

  .kg-blog-index__search input[type="search"]::placeholder {
    color: #7e8996;
    opacity: 1;
  }

  .kg-blog-index__search input[type="search"]:focus {
    background: #ecffed;
    box-shadow: 0 0 0 3px var(--kg-primary-ring);
  }

  .kg-blog-index__grid {
    display: block;
    width: min(100%, 1160px);
    max-width: none;
    margin: 52px 0 0;
  }

  .kg-blog-index__pagination--mobile {
    display: none;
  }

  .kg-blog-index__pagination--desktop {
    display: block;
  }

  .kg-blog-list-card {
    overflow: visible;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
  }

  .kg-blog-list-card:not(:last-child) {
    padding-bottom: 0;
    margin-bottom: clamp(56px, 4.8vw, 68px);
    border-bottom: 0;
  }

  .kg-blog-list-card__link {
    display: grid;
    grid-template-columns: clamp(318px, 26.5vw, 368px) minmax(0, 1fr);
    column-gap: clamp(32px, 3vw, 42px);
    align-items: start;
    min-height: clamp(211px, 17.6vw, 244px);
    color: inherit;
  }

  .kg-blog-list-card__media {
    display: block;
    width: 100%;
    aspect-ratio: 386 / 256;
    height: auto;
    min-width: 0;
    overflow: hidden;
    border-radius: 7px;
    background: var(--kg-soft);
  }

  .kg-blog-list-card__image {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 0;
    border-radius: inherit;
    object-fit: cover;
  }

  .kg-blog-list-card__image--placeholder {
    background:
      linear-gradient(135deg, rgba(255, 138, 29, 0.82), rgba(37, 99, 235, 0.78)),
      var(--kg-soft);
  }

  .kg-blog-list-card__body {
    display: flex;
    min-width: 0;
    flex-direction: column;
    align-items: flex-start;
    padding: 12px 0 0;
  }

  .kg-blog-list-card__title {
    order: 2;
    display: -webkit-box;
    overflow: hidden;
    max-width: 100%;
    color: var(--kg-text);
    font-size: clamp(21px, 1.65vw, 24px);
    font-weight: 800;
    line-height: 1.25;
    letter-spacing: 0;
    overflow-wrap: anywhere;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }

  .kg-blog-list-card__excerpt {
    order: 3;
    display: -webkit-box;
    overflow: hidden;
    max-width: 720px;
    margin-top: 16px;
    color: var(--kg-muted);
    font-size: clamp(16px, 1.25vw, 18px);
    font-weight: 500;
    line-height: 1.72;
    overflow-wrap: anywhere;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }

  .kg-blog-list-card__date {
    order: 1;
    margin: 0 0 13px;
    color: #7a8491;
    font-size: clamp(17px, 1.25vw, 19px);
    font-weight: 500;
    line-height: 1.4;
  }

  .kg-blog-list-card__comments {
    order: 4;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 16px;
    color: #7a8491;
    font-size: 17px;
    font-weight: 500;
    line-height: 1;
  }

  .kg-blog-list-card__comments svg {
    display: block;
    width: 22px;
    height: 22px;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.9;
  }

  .kg-blog-list-card__comments .kg-blog-list-card__comments-icon--mobile {
    display: none;
  }

  .kg-blog-list-card__comments .kg-blog-list-card__comments-icon--desktop {
    display: block;
  }

  .kg-blog-index .navigation.pagination {
    margin-top: 80px;
  }

  .kg-blog-index .navigation.pagination .nav-links {
    align-items: center;
    justify-content: center;
    gap: 18px;
  }

  .kg-blog-index .navigation.pagination .page-numbers {
    width: auto;
    min-width: 24px;
    min-height: 50px;
    padding: 0 4px;
    border: 1px solid transparent;
    border-radius: 999px;
    background: transparent;
    color: var(--kg-muted);
    font-size: 18px;
    font-weight: 400;
  }

  .kg-blog-index .navigation.pagination .page-numbers.current,
  .kg-blog-index .navigation.pagination .page-numbers.current:hover {
    width: 50px;
    min-width: 50px;
    padding: 0;
    border-color: transparent;
    background: var(--kg-accent);
    color: var(--kg-accent-text);
  }

  .kg-blog-index .navigation.pagination .page-numbers.dots,
  .kg-blog-index .navigation.pagination .page-numbers.dots:hover {
    min-width: 24px;
    padding: 0;
    border-color: transparent;
    background: transparent;
    color: var(--kg-muted);
  }

  .kg-blog-index .navigation.pagination .page-numbers.prev,
  .kg-blog-index .navigation.pagination .page-numbers.next,
  .kg-blog-index .navigation.pagination .page-numbers.prev:hover,
  .kg-blog-index .navigation.pagination .page-numbers.next:hover {
    width: 50px;
    min-width: 50px;
    padding: 0;
    border-color: var(--kg-border);
    background: var(--kg-card);
    color: var(--kg-text);
    font-size: 34px;
    line-height: 1;
  }
}

.home-section {
  margin: 34px 0 42px;
}

.home-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.section-title {
  margin: 0;
  color: var(--kg-text);
  font-size: clamp(24px, 2.8vw, 30px);
  font-weight: 800;
  letter-spacing: -0.04em;
}

.home-section__viewall {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: 999px;
  background: #DEE9F9;
  color: #2563EB;
  font-size: 0.96rem;
  font-weight: 700;
  white-space: nowrap;
}

.home-section__viewall::after {
  content: "›";
  font-size: 1.25em;
  line-height: 1;
}

.kg-home-articles {
  margin: clamp(54px, 5.4vw, 86px) 0 clamp(52px, 5.2vw, 82px);
}

.kg-home-articles__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.kg-home-articles__title {
  margin: 0;
  color: var(--kg-text);
  font-size: clamp(24px, 2.8vw, 30px);
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: -0.04em;
}

.kg-home-articles__view-all {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border: 0;
  border-radius: 999px;
  background: #DEE9F9;
  color: #2563EB;
  font-size: 0.96rem;
  font-weight: 700;
  line-height: 1.2;
  white-space: nowrap;
  box-shadow: none;
}

.kg-home-articles__view-all::after {
  content: "›";
  font-size: 1.25em;
  font-weight: 400;
  line-height: 1;
}

.kg-home-articles__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(24px, 2.6vw, 34px);
}

.kg-home-article-card {
  container-type: inline-size;
  min-width: 0;
}

.kg-home-article-card__media {
  display: block;
  overflow: hidden;
  width: 100%;
  height: calc(54cqw + 16px);
  aspect-ratio: 1.75 / 1;
  border-radius: 14px;
  background: var(--kg-soft);
  position: relative;
}

.kg-home-article-card__media::after {
  content: '';
  position: absolute;
  inset: -130%;
  pointer-events: none;
  z-index: 1;
  opacity: 0;
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0) 42%,
    rgba(255, 255, 255, 0.62) 50%,
    rgba(255, 255, 255, 0) 58%
  );
  transform: translate(-58%, -58%);
}

.kg-home-article-card__media:hover::after,
.kg-home-article-card__media:focus-visible::after {
  opacity: 1;
  animation: kg-product-card-shine 0.72s ease-out;
}

.kg-home-article-card__image {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  object-fit: cover;
}

.kg-home-article-card__image--placeholder {
  background:
    linear-gradient(135deg, rgba(16, 185, 129, 0.72), rgba(37, 99, 235, 0.72)),
    var(--kg-soft);
}

.kg-home-article-card__body {
  padding-top: clamp(14px, 1.4vw, 20px);
}

.kg-home-article-card__date {
  display: block;
  margin: 0 0 clamp(10px, 1vw, 14px);
  color: #737c89;
  font-size: clamp(13px, 0.92vw, 16px);
  font-weight: 600;
  line-height: 1.35;
}

.kg-home-article-card__title {
  margin: 0;
  color: #101420;
  font-size: clamp(17px, 1.15vw, 20px);
  font-weight: 800;
  line-height: 1.25;
  letter-spacing: 0;
  display: -webkit-box;
  overflow-wrap: anywhere;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.kg-home-article-card__title a {
  display: inline;
}

.kg-home-article-card__excerpt {
  display: -webkit-box;
  overflow: hidden;
  margin: clamp(10px, 1vw, 14px) 0 0;
  color: #5f6673;
  font-size: clamp(14px, 0.95vw, 16px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0;
  overflow-wrap: anywhere;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

@media (max-width: 991px) {
  .kg-home-articles__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .kg-home-article-card__media {
    height: calc(58cqw + 10px);
    aspect-ratio: 1.65 / 1;
  }
}

@media (min-width: 1440px) {
  .kg-home-articles__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .kg-home-articles-carousel {
    overflow: hidden;
    background: transparent;
  }

  .kg-home-articles-carousel__track.kg-home-articles__grid {
    display: flex;
    grid-template-columns: none;
    overflow-x: auto;
    overflow-y: visible;
    padding: 0 0 12px;
    background: transparent;
    scroll-behavior: smooth;
    scroll-padding-inline: 0;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
  }

  .kg-home-articles-carousel__track.kg-home-articles__grid {
    gap: 18px;
  }

  .kg-home-articles-carousel__track::-webkit-scrollbar {
    display: none;
  }

  .kg-home-articles-carousel__slide {
    flex: 0 0 calc((100% - 18px) / 2);
    max-width: calc((100% - 18px) / 2);
    scroll-snap-align: start;
    scroll-snap-stop: always;
  }
}

@media (max-width: 640px) {
  .kg-home-articles {
    margin: 42px 0 50px;
  }

  .kg-home-articles__header {
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 14px;
    margin-bottom: 24px;
  }

  .kg-home-articles__title {
    flex: 1 1 180px;
    font-size: 24px;
  }

  .kg-home-articles__view-all {
    padding: 10px 16px;
    border-radius: 999px;
    font-size: 14px;
  }

  .kg-home-articles__grid {
    gap: 18px;
  }

  .kg-home-article-card__body {
    padding-top: 10px;
  }

  .kg-home-article-card__date {
    margin-bottom: 8px;
    font-size: 12px;
  }

  .kg-home-article-card__title {
    font-size: 15px;
  }

  .kg-home-article-card__excerpt {
    margin-top: 8px;
    font-size: 13px;
    line-height: 1.45;
  }
}

.hero-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.hero-card {
  border-radius: var(--kg-radius);
  overflow: hidden;
  background: #111;
  color: #fff;
  aspect-ratio: 1 / 1;
  position: relative;
  box-shadow: 0 12px 24px rgba(0, 0, 0, .15);
}
.hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
}
.hero-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.88), rgba(0,0,0,.22) 46%, rgba(0,0,0,.10));
}
.hero-product-frame {
  position: absolute;
  top: 28px;
  left: 50%;
  width: calc(100% - 52px);
  aspect-ratio: 1.75 / 1;
  transform: translateX(-50%);
  background: #f1f5f9;
  border-radius: 12px;
  padding: 0;
  overflow: hidden;
  z-index: 2;
  box-shadow: 0 8px 20px rgba(17, 24, 39, .25);
}
.hero-product-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero-card-content {
  position: absolute;
  inset: 0;
  padding: 18px;
  z-index: 3;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.hero-chip {
  display: inline-block;
  position: absolute;
  left: 18px;
  top: 18px;
  border-radius: 999px;
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  background: linear-gradient(90deg, #6d5ef8, #3ba8ff);
  margin-bottom: 0;
}
.hero-card-content strong {
  display: block;
  font-size: clamp(20px, 1.35vw, 31px);
  line-height: 1.2;
  padding-right: 60px;
}
.hero-summary {
  margin-top: 8px;
  display: block;
  font-size: clamp(16px, 1vw, 23px);
  line-height: 1.25;
  max-width: 88%;
}
.hero-cta {
  position: absolute;
  right: 18px;
  bottom: 18px;
  width: 48px;
  height: 48px;
  border-radius: 12px;
  color: #111;
  background: #fff;
  display: grid;
  place-items: center;
  font-size: 22px;
}

.category-icons {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 16px;
}
.category-tile {
  overflow: hidden;
  background: var(--kg-card);
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 16px;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  box-shadow: 0 14px 26px rgba(15, 23, 42, 0.06);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.category-tile:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 36px rgba(15, 23, 42, 0.1);
}

.category-tile__top {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 136px;
  padding: 14px;
  background: linear-gradient(135deg, #16233f 0%, #1e3a8a 48%, #1d4ed8 100%);
}

.category-tile--image .category-tile__top {
  padding: 0;
  background: #15233a;
}

.category-tile__media {
  width: 100%;
  min-height: 136px;
  height: 136px;
  object-fit: contain;
  display: block;
}

.category-tile__media--icon {
  width: 70px;
  min-height: 70px;
  height: 70px;
}

.category-tile--image .category-tile__media {
  object-fit: cover;
  background: transparent;
}

.category-tile__mark {
  color: #fff;
  font-size: clamp(38px, 4.2vw, 52px);
  font-weight: 800;
  line-height: 0.9;
  text-transform: uppercase;
}

.category-tile__name {
  display: block;
  color: #fff;
  font-size: 1.08rem;
  font-weight: 700;
  line-height: 1.15;
  text-align: center;
}

.category-tile__range {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  min-height: 50px;
  padding: 11px 14px 13px;
  color: var(--kg-text);
  font-size: 1.08rem;
  font-weight: 800;
  letter-spacing: -0.03em;
}

.category-tile__range > .woocommerce-Price-amount:first-child {
  color: #f59e0b;
}

.category-tile__range > .woocommerce-Price-amount:last-child {
  color: #64748b;
}

.category-tile__range-separator {
  color: #f59e0b;
  font-size: 0.82rem;
}

.category-tile__range--fallback {
  font-size: 0.86rem;
  font-weight: 700;
  color: var(--kg-text);
}

.products-grid {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}
.products-grid > li {
  margin: 0;
  padding: 0;
  list-style: none;
}

@media (min-width: 992px) {
  .home-products-static.products-grid,
  .kg-theme-search-results__body .products-grid,
  body.post-type-archive-product ul.products {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 14px;
  }

  .home-products-carousel {
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}

@media (min-width: 1200px) {
  .products-grid,
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 14px;
  }
}

@media (min-width: 1440px) {
  .products-grid,
  .kg-category-products {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }

  .home-products-static.products-grid,
  .kg-theme-search-results__body .products-grid,
  body.post-type-archive-product ul.products {
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  }
}

.home-products-carousel {
  --kg-home-carousel-gap: 14px;
  --kg-home-carousel-visible-slides: 5;
  --kg-home-carousel-shadow-bleed-left: 4px;
  --kg-home-carousel-shadow-bleed-right: 4px;
  --kg-home-carousel-shadow-bleed-y: 32px;
  position: relative;
}

.home-products-carousel__viewport {
  position: relative;
  overflow-x: auto;
  overflow-y: visible;
  margin-left: calc(0px - var(--kg-home-carousel-shadow-bleed-left));
  margin-right: calc(0px - var(--kg-home-carousel-shadow-bleed-right));
  padding: 4px var(--kg-home-carousel-shadow-bleed-right) var(--kg-home-carousel-shadow-bleed-y) var(--kg-home-carousel-shadow-bleed-left);
  background: transparent;
  scroll-behavior: smooth;
  scroll-padding-inline: 0;
  scroll-snap-type: x mandatory;
  scrollbar-color: rgba(15, 23, 42, 0.24) transparent;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
}

.home-products-carousel__viewport::-webkit-scrollbar {
  height: 6px;
  display: none;
}

.home-products-carousel__viewport::-webkit-scrollbar-track {
  background: transparent;
}

.home-products-carousel__viewport::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.24);
}

.home-products-carousel__viewport:focus {
  outline: none;
}

.home-products-carousel__track.products-grid {
  display: flex;
  grid-template-columns: none;
  flex-wrap: nowrap;
  gap: var(--kg-home-carousel-gap);
  overflow: visible;
  position: relative;
  z-index: 1;
  background: transparent;
}

.home-products-carousel__slide {
  flex: 0 0 calc((100% - (var(--kg-home-carousel-visible-slides) - 1) * var(--kg-home-carousel-gap)) / var(--kg-home-carousel-visible-slides));
  max-width: calc((100% - (var(--kg-home-carousel-visible-slides) - 1) * var(--kg-home-carousel-gap)) / var(--kg-home-carousel-visible-slides));
  position: relative;
  z-index: 1;
  scroll-snap-align: start;
  scroll-snap-stop: always;
}

.home-products-carousel .product-card,
.home-products-static .product-card,
.kg-theme-search-results__body .product-card,
body.post-type-archive-product ul.products li.product .product-card {
  --kg-product-card-radius: 0;
  height: 100%;
  border-bottom-left-radius: 16px;
  border-bottom-right-radius: 16px;
}

.home-products-carousel .product-card {
  z-index: 1;
}

@media (hover: hover) and (pointer: fine) {
  .home-products-carousel__viewport {
    cursor: grab;
  }

  .home-products-carousel.is-dragging .home-products-carousel__viewport {
    cursor: grabbing;
    scroll-snap-type: none;
    scroll-behavior: auto;
  }

  .home-products-carousel.is-dragging .home-products-carousel__slide a,
  .home-products-carousel.is-dragging .home-products-carousel__slide img,
  .home-products-carousel.is-dragging .home-products-carousel__slide button {
    pointer-events: none;
  }
}

@media (max-width: 991px) {
  .home-products-carousel {
    --kg-home-carousel-gap: 8px;
    --kg-home-carousel-visible-slides: 2;
    padding-bottom: 16px;
  }

  body.home .home-products-carousel__viewport:focus {
    outline: none;
  }

  body.home .home-products-carousel__viewport:focus-visible {
    outline: none;
  }

  .home-products-carousel::before {
    content: none;
    display: none;
  }

  .home-products-carousel::after {
    content: "";
    display: block;
    width: 86px;
    height: 4px;
    margin: 10px auto 0;
    border-radius: 999px;
    background: linear-gradient(90deg, #ff9e05 0 32px, rgba(15, 23, 42, 0.18) 32px 100%);
  }

  .home-products-carousel__viewport:focus {
    outline: 2px solid rgba(255, 158, 5, 0.42);
    outline-offset: 4px;
  }
}

@media (min-width: 1440px) {
  .home-products-carousel {
    --kg-home-carousel-visible-slides: 6;
  }
}

.product-card {
  --kg-product-card-radius: 12px;
  --kg-product-card-media-radius: var(--kg-product-card-radius);
  --kg-product-card-button-radius: 10px;
  --kg-product-card-content-x: 16px;
  --kg-product-card-button-inset: var(--kg-product-card-content-x);
  position: relative;
  overflow: hidden;
  overflow: clip;
  isolation: isolate;
  background: var(--kg-card);
  border-radius: var(--kg-product-card-radius);
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: 0 0 16px;
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.06);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.product-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 34px rgba(15, 23, 42, 0.1);
}

.product-card__media {
  position: relative;
  display: block;
  overflow: hidden;
  aspect-ratio: 1.2 / 1;
  min-height: 0;
  border-radius: var(--kg-product-card-media-radius) var(--kg-product-card-media-radius) 0 0;
  background: var(--kg-soft);
  clip-path: inset(0 round var(--kg-product-card-media-radius) var(--kg-product-card-media-radius) 0 0);
  transform: translateZ(0);
}

.product-card__picture {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
}

.kg-product-featured-picture {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
}

.home-products-carousel .product-card__media,
.home-products-static .product-card__media,
.kg-theme-search-results__body .product-card__media,
body.post-type-archive-product ul.products li.product .product-card__media {
  aspect-ratio: 9 / 10;
  border-radius: 8px;
  clip-path: inset(0 round 8px);
}

.home-products-carousel .product-card__media::after,
.home-products-static .product-card__media::after,
.kg-theme-search-results__body .product-card__media::after,
body.post-type-archive-product ul.products li.product .product-card__media::after,
.kg-pdp-related-shell .product-card__media::after {
  content: "";
  position: absolute;
  inset: -130%;
  pointer-events: none;
  z-index: 1;
  opacity: 0;
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0) 42%,
    rgba(255, 255, 255, 0.62) 50%,
    rgba(255, 255, 255, 0) 58%
  );
  transform: translate(-58%, -58%);
}

.home-products-carousel .product-card:hover .product-card__media::after,
.home-products-static .product-card:hover .product-card__media::after,
.kg-theme-search-results__body .product-card:hover .product-card__media::after,
body.post-type-archive-product ul.products li.product .product-card:hover .product-card__media::after,
.kg-pdp-related-shell .product-card:hover .product-card__media::after,
.home-products-carousel .product-card__media:focus-visible::after,
.home-products-static .product-card__media:focus-visible::after,
.kg-theme-search-results__body .product-card__media:focus-visible::after,
body.post-type-archive-product ul.products li.product .product-card__media:focus-visible::after,
.kg-pdp-related-shell .product-card__media:focus-visible::after {
  opacity: 1;
  animation: kg-product-card-shine 0.72s ease-out;
}

@media (max-width: 767px) {
  .home-products-carousel .product-card__media,
  .home-products-static .product-card__media,
  .kg-theme-search-results__body .product-card__media,
  body.post-type-archive-product ul.products li.product .product-card__media {
    width: 100%;
    height: auto;
    max-width: none;
    margin: 0;
  }

  .home-products-carousel .product-card__media,
  .home-products-static .product-card__media,
  .kg-theme-search-results__body .product-card__media,
  body.post-type-archive-product ul.products li.product .product-card__media {
    aspect-ratio: 9 / 10;
  }

  /* Keep the mobile scroll area invisible while preserving card shadow bleed. */
  body.home .home-section .home-products-carousel__viewport,
  body.home .home-section .home-products-carousel__track.products-grid {
    background: transparent;
    background-color: transparent;
  }

  body.home .home-section .home-products-carousel__viewport {
    scrollbar-width: none;
  }

  body.home .home-section .home-products-carousel__viewport::-webkit-scrollbar {
    display: none;
  }
}

.product-card__media img {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  min-height: 100%;
  margin: 0;
  border-radius: inherit;
  object-fit: cover;
  object-position: center top;
  backface-visibility: hidden;
  transform: translateZ(0);
}

.product-card__badge {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  padding: 6px 12px;
  border-radius: 12px 0 12px 0;
  background: linear-gradient(135deg, #2953dc, #3b82f6);
  color: #fff;
  font-size: 0.9rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.02em;
}

@keyframes kg-product-card-shine {
  0% {
    transform: translate(-58%, -58%);
  }
  100% {
    transform: translate(58%, 58%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .home-products-carousel .product-card__media::after,
  .home-products-static .product-card__media::after,
  .kg-theme-search-results__body .product-card__media::after,
  body.post-type-archive-product ul.products li.product .product-card__media::after,
  .kg-pdp-related-shell .product-card__media::after {
    animation: none !important;
    opacity: 0 !important;
  }
}

.product-card__body {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  padding: 14px var(--kg-product-card-content-x) 0;
}

.product-card__meta {
  display: flex;
  align-items: center;
  min-height: 1.2em;
  margin: 8px 0 0;
  font-size: 0.9rem;
  font-weight: 400;
  line-height: 1.2;
}

.product-card__amount {
  margin: 12px 0 0;
  color: #030712;
  font-size: 18px;
  font-family: Inter, Arial, sans-serif;
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: 0;
}

.product-card__category {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  min-height: 18px;
  line-height: 1;
  color: var(--kg-muted);
  text-decoration: none;
  transition: color 0.2s ease;
}

.product-card__category-link {
  --kg-product-card-category-hover-color: var(--kg-primary);
}

.product-card__category-icon {
  display: inline-block;
  flex: 0 0 18px;
  width: 18px;
  height: 18px;
  background-color: currentColor;
  -webkit-mask-image: var(--kg-category-icon-image);
  mask-image: var(--kg-category-icon-image);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
}

.product-card__category-link:hover,
.product-card__category-link:focus {
  color: var(--kg-product-card-category-hover-color);
  text-decoration: none;
}

body.home .home-section .product-card__category-link:hover,
body.home .home-section .product-card__category-link:focus,
body.front-page .home-section .product-card__category-link:hover,
body.front-page .home-section .product-card__category-link:focus {
  color: var(--kg-product-card-category-hover-color) !important;
  text-decoration: none;
}

.product-card__title {
  margin: 0;
  font-size: 16px;
  line-height: 1.3;
  letter-spacing: 0;
  font-family: Inter, Arial, sans-serif;
  font-weight: 600;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  min-height: calc(1.3em * 2);
}

.home-products-carousel .product-card__title,
.home-products-static .product-card__title,
.kg-theme-search-results__body .product-card__title,
body.post-type-archive-product ul.products li.product .product-card__title {
  text-align: center;
}

@media (min-width: 992px) {
  .home-products-carousel .product-card__title,
  .home-products-static .product-card__title,
  .kg-theme-search-results__body .product-card__title,
  body.post-type-archive-product ul.products li.product .product-card__title {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .home-products-carousel .product-card__title a,
  .home-products-static .product-card__title a,
  .kg-theme-search-results__body .product-card__title a,
  body.post-type-archive-product ul.products li.product .product-card__title a {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    width: 100%;
  }
}

.product-card__title a {
  color: inherit;
}

.product-card__divider {
  width: 100%;
  height: 1px;
  margin: 12px 0 0;
  background: #d8dde3;
}

.products-grid .product-card__button,
.woocommerce ul.products li.product .product-card__button,
.woocommerce-page ul.products li.product .product-card__button {
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  width: auto;
  max-width: none;
  margin: 16px var(--kg-product-card-button-inset) 0;
  background: linear-gradient(90deg, #ffd44d 0%, #ffbf1f 52%, #ff9e05 100%);
  border: 1px solid rgba(214, 140, 0, 0.4);
  border-radius: var(--kg-product-card-button-radius);
  min-height: 50px;
  text-align: center;
  padding: 0 20px;
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.2;
  color: #172554;
  text-decoration: none;
  box-shadow: none;
  overflow: hidden;
  background-clip: padding-box;
  clip-path: inset(0 round var(--kg-product-card-button-radius));
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}
.product-card__button-label {
  display: inline-block;
  transform: none;
  letter-spacing: -0.02em;
}
.products-grid .product-card__button--buy-now,
.woocommerce ul.products li.product .product-card__button--buy-now,
.woocommerce-page ul.products li.product .product-card__button--buy-now {
  background: linear-gradient(180deg, #ffdf2e 0%, #ffd21d 56%, #ffc70f 100%);
  border-color: #efbf0c;
  border-bottom-color: #efbf0c;
  border-radius: 8px;
  min-height: 50px;
  clip-path: inset(0 round 8px);
  padding: 0 20px;
  font-size: 1.12rem;
  font-weight: 900;
  color: #fff;
  box-shadow: none;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.products-grid .product-card__button--shop-now,
.woocommerce ul.products li.product .product-card__button--shop-now,
.woocommerce-page ul.products li.product .product-card__button--shop-now {
  background: linear-gradient(90deg, #ffab1f 0%, #ff8608 52%, #ff5b00 100%);
  border-color: #ff8a12;
  border-radius: 8px;
  min-height: 42px;
  clip-path: inset(0 round 8px);
  color: var(--kg-shop-now-text, #ffffff);
  font-family: Inter, Arial, sans-serif;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0;
}

.products-grid .product-card__button--shop-now .product-card__button-label,
.woocommerce ul.products li.product .product-card__button--shop-now .product-card__button-label,
.woocommerce-page ul.products li.product .product-card__button--shop-now .product-card__button-label {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
}

.products-grid .product-card__button--buy-now .product-card__button-label,
.woocommerce ul.products li.product .product-card__button--buy-now .product-card__button-label,
.woocommerce-page ul.products li.product .product-card__button--buy-now .product-card__button-label {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-shadow: 0 2px 6px rgba(120, 88, 0, 0.28);
}

.products-grid .product-card__button--buy-now .product-card__button-label::after,
.woocommerce ul.products li.product .product-card__button--buy-now .product-card__button-label::after,
.woocommerce-page ul.products li.product .product-card__button--buy-now .product-card__button-label::after {
  content: "\2197";
  display: inline-block;
  font-size: 1.12em;
  font-weight: 900;
  line-height: 1;
  color: #fff;
  text-shadow: 0 2px 6px rgba(120, 88, 0, 0.28);
}

.products-grid .product-card__button:hover,
.products-grid .product-card__button:focus,
.woocommerce ul.products li.product .product-card__button:hover,
.woocommerce ul.products li.product .product-card__button:focus,
.woocommerce-page ul.products li.product .product-card__button:hover,
.woocommerce-page ul.products li.product .product-card__button:focus {
  background: linear-gradient(90deg, #ffd957 0%, #ffc52b 52%, #ffa20a 100%);
  border-color: rgba(214, 140, 0, 0.55);
  color: #172554;
}
.products-grid .product-card__button--buy-now:hover,
.products-grid .product-card__button--buy-now:focus,
.woocommerce ul.products li.product .product-card__button--buy-now:hover,
.woocommerce ul.products li.product .product-card__button--buy-now:focus,
.woocommerce-page ul.products li.product .product-card__button--buy-now:hover,
.woocommerce-page ul.products li.product .product-card__button--buy-now:focus {
  background: linear-gradient(180deg, #ffe43f 0%, #ffd629 56%, #ffcb19 100%);
  border-color: #efbf0c;
  border-bottom-color: #efbf0c;
  color: #fff;
  box-shadow: none;
  transform: none;
}

.products-grid .product-card__button--shop-now:hover,
.products-grid .product-card__button--shop-now:focus,
.woocommerce ul.products li.product .product-card__button--shop-now:hover,
.woocommerce ul.products li.product .product-card__button--shop-now:focus,
.woocommerce-page ul.products li.product .product-card__button--shop-now:hover,
.woocommerce-page ul.products li.product .product-card__button--shop-now:focus {
  background: linear-gradient(90deg, #ffb734 0%, #ff930f 52%, #ff6a0a 100%);
  border-color: #ff941f;
  color: var(--kg-shop-now-text, #ffffff);
}

.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after {
  content: none;
}
.woocommerce ul.products li.product,
.woocommerce ul.products[class*="columns-"] li.product,
.woocommerce-page ul.products li.product,
.woocommerce-page ul.products[class*="columns-"] li.product {
  float: none;
  width: auto;
  clear: none;
  margin: 0;
  padding: 0;
}
.woocommerce ul.products li.product .product-card,
.woocommerce-page ul.products li.product .product-card,
.products-grid .product-card {
  height: 100%;
}

@media (min-width: 1200px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 14px;
  }
}

@media (min-width: 1440px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}

.site-footer {
  background: var(--kg-footer-bg);
  margin-top: 46px;
  padding: 58px 0 36px;
  color: var(--kg-footer-text);
}
.site-footer .container {
  width: min(1188px, calc(100% - 112px));
}
.site-footer a {
  color: var(--kg-footer-link);
}
.site-footer p {
  color: var(--kg-footer-text);
}
.kg-site-footer {
  display: grid;
  gap: 44px;
}
.kg-site-footer__top {
  display: grid;
  grid-template-columns: minmax(320px, 1.35fr) minmax(180px, 0.7fr) minmax(180px, 0.7fr);
  gap: clamp(36px, 5.2vw, 88px);
  align-items: start;
}
.kg-site-footer__brand {
  justify-self: center;
  max-width: 520px;
  text-align: center;
}
.kg-site-footer__brand-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 22px;
  max-width: 220px;
}
.kg-site-footer__brand-image {
  display: block;
  max-width: 100%;
  width: auto;
  height: auto;
  max-height: 58px;
  object-fit: contain;
}
.kg-site-footer__brand-wordmark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 58px;
  color: var(--kg-footer-heading);
  font-family: 'Barlow Condensed', Inter, sans-serif;
  font-size: clamp(3rem, 4.6vw, 4.55rem);
  font-weight: 800;
  letter-spacing: -0.06em;
  line-height: 0.9;
  white-space: nowrap;
}
.kg-site-footer__brand-copy {
  margin: 0 auto;
  max-width: 470px;
  font-size: 1rem;
  line-height: 1.55;
}
.kg-site-footer__column {
  min-width: 0;
}
.kg-site-footer__heading {
  margin: 0 0 22px;
  font-size: 1.18rem;
  font-weight: 700;
  line-height: 1.1;
  color: var(--kg-footer-heading);
}
.kg-site-footer__links {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 16px;
}
.kg-site-footer__links a {
  display: inline-flex;
  font-size: 1rem;
  line-height: 1.5;
}
.kg-site-footer__bottom {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 18px;
  padding-top: 26px;
  border-top: 1px solid var(--kg-footer-border);
}
.kg-site-footer__copyright {
  margin: 0;
  font-size: 0.96rem;
  line-height: 1.5;
  white-space: normal;
}
.kg-site-footer__socials {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.kg-site-footer__social {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  background: var(--kg-footer-heading);
  color: var(--kg-footer-surface);
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.1);
}
.site-footer .kg-site-footer__social {
  color: var(--kg-footer-surface);
  text-decoration: none;
}
.kg-site-footer__social svg {
  display: block;
  width: 18px;
  height: 18px;
  fill: currentColor;
  stroke: currentColor;
}

@media (max-width: 1200px) {
  .site-header__hero-body {
    grid-template-columns: minmax(0, 1fr) minmax(0, 0.92fr);
  }

  .site-header__hero-title {
    font-size: clamp(3rem, 5.8vw, 4.9rem);
  }

  .site-header__hero-card--left {
    left: 58px;
  }

  .site-header__hero-card--right {
    left: auto;
    right: 4px;
  }
}

@media (max-width: 991px) {
  .site-header__hero-shell {
    min-height: 0;
    padding: 16px 0 0;
  }
  .site-header__hero-top {
    min-height: 0;
  }
  .branding--hero {
    position: static;
  }
  .site-header__hero-mainline {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    min-height: 0;
    padding-top: 0;
    padding-left: 0;
  }
  .site-header--hero .primary-nav {
    width: 100%;
    justify-content: flex-start;
  }
  .header-nav-row--hero {
    margin-left: 0;
    margin-right: 0;
  }
  .site-header--hero .primary-menu {
    justify-content: flex-start;
    gap: 20px;
    overflow-x: auto;
    padding-bottom: 6px;
  }
  .site-header__hero-tools {
    justify-content: flex-start;
    flex-wrap: wrap;
  }
  .site-header--hero .kg-search {
    position: relative;
    left: auto;
    top: auto;
    width: min(100%, 420px);
    flex: 1 1 360px;
    justify-self: stretch;
    transform: none;
  }
  .site-header__hero-body {
    grid-template-columns: 1fr;
    gap: 18px;
    padding-top: 22px;
  }
  .site-header__hero-copy {
    max-width: 100%;
    padding-top: 0;
  }
  .site-header__hero-title {
    font-size: clamp(2.85rem, 10vw, 4.5rem);
  }
  .site-header__hero-summary {
    max-width: 620px;
    margin-top: 24px;
  }
  .site-header__hero-visual {
    min-height: 490px;
    width: min(100%, 620px);
    margin-left: auto;
  }
  .site-header__hero-card--left {
    left: 56px;
    top: -18px;
    width: min(32vw, 188px);
  }
  .site-header__hero-card--right {
    right: 6px;
    top: 8px;
    width: min(42vw, 246px);
  }
  .site-header__hero-float--logo {
    left: 8px;
    top: 30px;
    width: min(12vw, 86px);
  }
  .site-header__hero-float--logo-edge-1 {
    left: -42px;
    top: 20px;
    width: min(7vw, 58px);
  }
  .site-header__hero-float--logo-edge-2 {
    left: -28px;
    top: 128px;
    width: min(6vw, 48px);
  }
  .site-header__hero-float--support-1 {
    left: 102px;
    right: auto;
    top: auto;
    bottom: 16px;
    width: min(13vw, 92px);
  }
  .site-header__hero-float--support-2 {
    left: 204px;
    bottom: 16px;
    width: min(14vw, 98px);
  }
  .site-header__hero-float--support-3 {
    left: 312px;
    right: auto;
    bottom: 16px;
    width: min(15vw, 104px);
  }
  .kg-blog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .hero-grid,
  .products-grid,
  .woocommerce ul.products,
  .woocommerce-page ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  body.home .home-section .products-grid,
  body.front-page .home-section .products-grid {
    gap: 8px;
  }
  .category-icons { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .header-row { grid-template-columns: 1fr; gap: 14px; padding: 14px 0; }
  .kg-search { justify-self: stretch; }
  .kg-theme-search-results { padding-top: 22px; }
  .header-actions { justify-self: start; }
  .primary-menu { gap: 18px; min-height: 44px; overflow-x: auto; flex-wrap: nowrap; padding-bottom: 6px; }
  .primary-menu > li > a { min-height: 44px; white-space: nowrap; }
  .primary-menu .sub-menu { position: static; display: block; border: 0; box-shadow: none; padding: 0; min-width: 0; }
  .home-section__header {
    align-items: center;
    justify-content: space-between;
    flex-direction: row;
    width: 100%;
  }
  .hero-card { aspect-ratio: 1 / 1; }
  .hero-product-frame { top: 16px; width: calc(100% - 30px); }
  .hero-product-frame img { height: 100%; }
  .hero-summary { font-size: 14px; }
  .product-card__meta { font-size: 0.9rem; }
  .product-card__title { font-size: 16px; }
  .product-card__amount { font-size: 18px; }
  .kg-site-footer {
    gap: 32px;
  }
  .site-footer {
    padding: 40px 0 28px;
  }
  .site-footer .container {
    width: min(100%, calc(100% - 24px));
  }
  .kg-site-footer__top {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .kg-site-footer__brand {
    justify-self: start;
    max-width: none;
    text-align: left;
  }
  .kg-site-footer__brand-link {
    margin-inline: 0;
    margin-bottom: 18px;
  }
  .kg-site-footer__brand-copy {
    margin-inline: 0;
    max-width: 100%;
  }
}

@media (max-width: 640px) {
  .site-header--hero .container {
    width: min(100%, calc(100% - 24px));
  }
  .branding--hero img {
    max-height: 42px;
  }
  .header-nav-row--hero {
    padding-top: 0;
    padding-bottom: 0;
  }
  .site-header--hero .primary-menu {
    gap: 16px;
    min-height: 40px;
  }
  .site-header--hero .primary-menu > li > a {
    min-height: 40px;
    font-size: 0.95rem;
  }
  .site-header__hero-tools {
    gap: 10px;
    flex-wrap: wrap;
  }
  .site-header--hero .kg-search {
    width: 100%;
  }
  .site-header--hero .header-actions {
    width: auto;
  }
  .site-header--hero .header-login {
    min-height: 46px;
  }
  .site-header--hero .header-cart {
    width: 46px;
    height: 46px;
  }
  .site-header__hero-title {
    font-size: clamp(2.35rem, 12vw, 3.65rem);
  }
  .site-header__hero-summary {
    margin-top: 18px;
    font-size: 0.98rem;
  }
  .site-header__hero-visual {
    min-height: 340px;
  }
  .site-header__hero-card {
    border-radius: 12px;
  }
  .site-header__hero-card--left {
    left: 12%;
    top: -10px;
    width: 34%;
  }
  .site-header__hero-card--right {
    right: 1%;
    top: 12px;
    width: 45%;
  }
  .site-header__hero-dot-grid {
    background-size: 18px 18px;
  }
  .site-header__hero-dot-grid--left {
    left: -6px;
    top: 108px;
    width: 184px;
    height: 140px;
  }
  .site-header__hero-dot-grid--right {
    right: 4px;
    top: 8px;
    width: 86px;
    height: 72px;
  }
  .site-header__hero-top-dots {
    top: 2px;
    right: 8px;
  }
  .site-header__hero-float--logo {
    left: 10px;
    top: 50px;
    width: 58px;
  }
  .site-header__hero-float--logo-edge-1 {
    left: -28px;
    top: 40px;
    width: 42px;
  }
  .site-header__hero-float--logo-edge-2 {
    left: -18px;
    top: 122px;
    width: 34px;
  }
  .site-header__hero-float--support-1 {
    left: 54px;
    right: auto;
    top: auto;
    bottom: 12px;
    width: 64px;
  }
  .site-header__hero-float--support-2 {
    left: 116px;
    bottom: 12px;
    width: 68px;
  }
  .site-header__hero-float--support-3 {
    left: 186px;
    right: auto;
    bottom: 12px;
    width: 72px;
  }
  .kg-theme-search-results__title {
    font-size: 26px;
  }
  .products-grid,
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .category-icons {
    grid-template-columns: minmax(0, 1fr);
  }
  .category-tile__top,
  .category-tile__media {
    min-height: 120px;
    height: 120px;
  }
  .product-card__media img {
    min-height: 100%;
    height: 100%;
  }
  .product-card__meta {
    font-size: 0.88rem;
  }
  .product-card__title {
    font-size: 16px;
  }
  .product-card__amount {
    font-size: 18px;
  }
}

/* Single product redesign */
.single-product .site-main,
.single-product main {
  padding: 24px 0 0;
}
.single-product .kg-single-product {
  width: min(1420px, calc(100% - 80px));
  margin: 0 auto;
  float: none;
}
.kg-product-content-wrap {
  width: 100%;
  margin: 0 auto;
  padding-bottom: 40px;
}
.kg-breadcrumb {
  font-size: 13px;
  color: var(--kg-muted);
  margin-bottom: 22px;
}
.kg-product-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 34px;
  align-items: start;
  margin-bottom: 30px;
}
.kg-product-gallery {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 18px;
  padding: 22px;
  min-height: 330px;
}
.kg-product-gallery .woocommerce-product-gallery,
.kg-product-gallery .images {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin: 0 auto !important;
  max-width: 360px;
}
.kg-product-gallery .woocommerce-product-gallery__wrapper,
.kg-product-gallery .woocommerce-product-gallery__image {
  width: 100%;
}
.kg-product-gallery .woocommerce-product-gallery__image {
  display: flex;
  justify-content: center;
}
.kg-product-gallery .woocommerce-product-gallery__image img,
.kg-product-gallery .woocommerce-product-gallery__wrapper img {
  max-height: 260px;
  object-fit: contain;
  display: block;
  margin: 0 auto;
  width: 100%;
}
.kg-popular-badge {
  position: absolute;
  top: 22px;
  left: 0;
  background: #7c5cff;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  padding: 8px 14px;
  border-radius: 0 8px 8px 0;
  z-index: 2;
  text-transform: uppercase;
}
.kg-product-info .product_title {
  font-size: clamp(28px, 2.4vw, 38px);
  margin: 0 0 10px;
}
.kg-product-info .price {
  font-size: clamp(24px, 2vw, 34px);
  font-weight: 700;
  color: #111827;
}
.kg-product-info {
  height: 360px;
}
.kg-product-info form.cart {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin: 18px 0 16px;
  align-items: center;
}
.kg-product-info form.cart.kg-simple-product-cart {
  display: block;
}
.kg-product-info form.variations_form.cart {
  display: block;
  margin: 18px 0 16px;
}
.kg-product-info .kg-product-variation-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 16px;
  margin: 0 0 16px;
}
.kg-product-info .kg-variation-option-field {
  display: grid;
  gap: 8px;
}
.kg-product-info .kg-variation-option-label {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  color: #111827;
  line-height: 1.2;
}
.kg-product-info .kg-variation-option-control {
  display: grid;
  gap: 8px;
}
.kg-product-info .kg-variation-option-control .kg-variation-select,
.kg-product-info .kg-variation-option-control select {
  width: 100%;
  height: 44px;
  border: 1px solid #c5ccd6;
  border-radius: 8px;
  background-color: #fff;
  color: #111827;
  font-size: 16px;
  font-weight: 500;
  padding: 0 36px 0 12px;
  appearance: none;
  -webkit-appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, #6b7280 50%), linear-gradient(135deg, #6b7280 50%, transparent 50%);
  background-position: calc(100% - 16px) calc(50% - 2px), calc(100% - 11px) calc(50% - 2px);
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
}
.kg-product-info .kg-variation-option-control .reset_variations {
  display: none;
}
.kg-product-info .single_variation_wrap {
  margin: 0;
}
.kg-product-info .single_variation_wrap .woocommerce-variation {
  margin: 0 0 12px;
}
.kg-product-info .kg-product-purchase-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(170px, 260px);
  gap: 14px 16px;
  align-items: center;
  margin: 0 0 18px;
}
.kg-product-info form.variations_form.cart .woocommerce-variation-add-to-cart.variations_button {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(170px, 260px);
  gap: 14px 16px;
  align-items: center;
}
.kg-product-info .kg-product-purchase-grid .kg-quantity-label {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  color: #111827;
  line-height: 1.35;
}
.kg-product-info form.variations_form.cart .variations_button .kg-quantity-label {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  color: #111827;
  line-height: 1.35;
}
.kg-product-info .kg-product-purchase-grid .quantity {
  grid-column: 2;
  justify-self: stretch;
  width: 100%;
  margin: 0;
}
.kg-product-info form.variations_form.cart .variations_button .quantity {
  grid-column: 2;
  justify-self: stretch;
  width: 100%;
  margin: 0;
}
.kg-product-info .kg-product-purchase-grid .quantity::before {
  content: none;
}
.kg-product-info form.variations_form.cart .variations_button .quantity::before {
  content: none;
}
.kg-product-info .kg-product-purchase-grid .quantity .qty {
  width: 100%;
  min-width: 0;
}
.kg-product-info form.variations_form.cart .variations_button .quantity .qty {
  width: 100%;
  min-width: 0;
}
.kg-product-info .kg-quantity-stepper {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr) 54px;
  align-items: stretch;
  gap: 0;
  border: 1px solid #c5ccd6;
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
}
.kg-product-info .kg-quantity-stepper .qty {
  width: 100%;
  height: 42px;
  border: 0;
  border-left: 1px solid #c5ccd6;
  border-right: 1px solid #c5ccd6;
  border-radius: 0;
  box-shadow: none;
  font-size: 24px;
  font-weight: 600;
  line-height: 1;
  padding: 0 8px;
  appearance: textfield;
  -moz-appearance: textfield;
}
.kg-product-info .kg-quantity-stepper .qty::-webkit-outer-spin-button,
.kg-product-info .kg-quantity-stepper .qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.kg-product-info .kg-quantity-stepper__button {
  height: 42px;
  border: 0;
  background: #fff;
  color: #4b5563;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
}
.kg-product-info .kg-quantity-stepper__button:hover {
  background: #f8fafc;
}
.kg-product-info form.variations_form.cart .variations_button .single_add_to_cart_button.button.alt {
  grid-column: 1 / -1;
  margin-top: 0;
}
.kg-product-info form.variations_form.cart .variations_button input[type="hidden"] {
  display: none;
}
.woocommerce div.product form.cart {
  margin-bottom: 0.75em;
}
.kg-product-info form.cart .quantity {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.kg-product-info form.cart .quantity::before {
  content: "Quantity:";
  font-size: 14px;
  font-weight: 600;
  color: #111827;
  line-height: 1;
}
.kg-product-info form.cart.kg-simple-product-cart .quantity::before,
.kg-product-info .kg-product-purchase-grid .quantity::before,
.kg-product-info .kg-quantity-stepper::before {
  content: none;
}
.kg-product-info form.cart .quantity .qty {
  width: 52px;
  height: 46px;
  border-radius: 10px;
  border: 1px solid #c5ccd6;
  background: #fff;
  font-size: 18px;
  font-weight: 500;
  color: #111827;
  text-align: center;
  padding: 0 6px;
}
.kg-product-info form.cart .kg-quantity-stepper {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr) 54px;
  gap: 0;
}
.kg-product-info form.cart .kg-quantity-stepper .qty {
  width: 100%;
  height: 42px;
  border: 0;
  border-left: 1px solid #c5ccd6;
  border-right: 1px solid #c5ccd6;
  border-radius: 0;
  padding: 0 8px;
}
.kg-product-info .single_add_to_cart_button.button.alt {
  background: var(--kg-accent);
  border: 1px solid var(--kg-accent);
  border-radius: 10px;
  color: var(--kg-accent-text);
  font-weight: 700;
  padding: 16px 24px;
  flex-basis: 100%;
  width: 100%;
  text-align: center;
  margin-top: 6px;
}
.kg-product-info .kg-product-activation-notice {
  margin: -2px 0 14px;
  color: #f05a4f;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.45;
}
.kg-product-info form.variations_form.cart .variations_button .kg-product-activation-notice {
  grid-column: 1 / -1;
  margin: -4px 0 0;
}
.kg-product-info .single_add_to_cart_button.button.alt:hover {
  background: var(--kg-accent-hover);
  border-color: var(--kg-accent-hover);
}
.woocommerce-cart .wc-proceed-to-checkout .checkout-button.button.alt,
.woocommerce-cart .wc-proceed-to-checkout .checkout-button.button.alt.wc-forward {
  background: var(--kg-accent);
  border: 1px solid var(--kg-accent);
  border-radius: 10px;
  color: var(--kg-accent-text);
  font-weight: 700;
}
.woocommerce-cart .wc-proceed-to-checkout .checkout-button.button.alt:hover,
.woocommerce-cart .wc-proceed-to-checkout .checkout-button.button.alt.wc-forward:hover {
  background: var(--kg-accent-hover);
  border-color: var(--kg-accent-hover);
  color: var(--kg-accent-text);
}
.woocommerce-cart .wc-block-cart .wc-block-cart__submit-container .wc-block-components-button,
.woocommerce-cart .wc-block-cart .wc-block-cart__submit-container .wc-block-components-button:not(.is-link),
.woocommerce-cart .wc-block-cart .wc-block-cart__submit-container .wc-block-components-button:not(.is-link) .wc-block-components-button__text {
  background: var(--kg-accent) !important;
  background-color: var(--kg-accent) !important;
  color: var(--kg-accent-text) !important;
}
.woocommerce-cart .wc-block-cart .wc-block-cart__submit-container .wc-block-components-button,
.woocommerce-cart .wc-block-cart .wc-block-cart__submit-container .wc-block-components-button:not(.is-link) {
  border: 1px solid var(--kg-accent) !important;
  border-radius: 10px;
  font-weight: 700;
}
.woocommerce-cart .wc-block-cart .wc-block-cart__submit-container .wc-block-components-button:hover,
.woocommerce-cart .wc-block-cart .wc-block-cart__submit-container .wc-block-components-button:focus,
.woocommerce-cart .wc-block-cart .wc-block-cart__submit-container .wc-block-components-button:not(.is-link):hover,
.woocommerce-cart .wc-block-cart .wc-block-cart__submit-container .wc-block-components-button:not(.is-link):focus,
.woocommerce-cart .wc-block-cart .wc-block-cart__submit-container .wc-block-components-button:not(.is-link):hover .wc-block-components-button__text,
.woocommerce-cart .wc-block-cart .wc-block-cart__submit-container .wc-block-components-button:not(.is-link):focus .wc-block-components-button__text {
  background: var(--kg-accent-hover) !important;
  background-color: var(--kg-accent-hover) !important;
  border-color: var(--kg-accent-hover) !important;
  color: var(--kg-accent-text) !important;
}
.kg-product-info .kg-product-delivery-note {
  font-size: 16px;
  line-height: 1.45;
  color: #1f2937;
  margin-top: 2px;
}
.kg-partner-badge {
  display: inline-block;
  font-size: 12px;
  color: #4b5563;
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  padding: 6px 12px;
  margin-bottom: 14px;
}
.kg-feature-list {
  display: grid;
  gap: 18px;
  margin: 0 0 18px;
  padding-bottom: 14px;
}
.kg-feature-item {
  display: flex;
  gap: 10px;
  font-size: 14px;
  color: #374151;
  align-items: center;
}
.kg-feature-icon {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #e0ecff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
}
.kg-product-info-box {
  margin-top: 18px;
  padding-top: 20px;
}
.kg-product-info-box.section-box {
  max-width: 760px;
}
.kg-product-details-row {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  column-gap: clamp(24px, 22vw, 315px);
  row-gap: 24px;
  align-items: start;
  margin-top: 18px;
}
.kg-product-details-row .kg-product-info-box {
  margin-top: 0;
  order: 2;
}
.kg-product-details-row .kg-related-box {
  order: 1;
}
.kg-product-info-title {
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 12px;
  padding-top: 14px;
  border-top: 1.5px solid #d1d5db;
}
.kg-product-info-description p {
  margin: 0 0 10px;
  font-size: 14px;
  line-height: 1.7;
  color: #1f2937;
}
.kg-product-review-slot.has-product-copy {
  margin-top: 28px;
  padding-top: 28px;
  border-top: 1.5px solid #d1d5db;
}
.kg-product-reviews {
  margin-top: 0;
}
.kg-product-reviews__title {
  padding-top: 0;
  border-top: 0;
  margin-bottom: 18px;
}
.kg-product-reviews__summary {
  display: grid;
  grid-template-columns: minmax(180px, 220px) minmax(0, 1fr);
  gap: 24px 34px;
  align-items: start;
}
.kg-product-reviews__score {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-size: clamp(42px, 5vw, 54px);
  line-height: 1;
  font-weight: 700;
  color: #111827;
}
.kg-product-reviews__score span {
  font-size: 20px;
  color: #4b5563;
}
.kg-product-reviews__stars-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
  margin-top: 12px;
}
.kg-product-reviews__stars-row .star-rating {
  margin: 0;
}
.kg-product-reviews__count {
  font-size: 16px;
  font-weight: 600;
  color: #1f2937;
}
.kg-product-reviews__empty {
  margin: 12px 0 0;
  font-size: 15px;
  line-height: 1.6;
  color: #4b5563;
}
.kg-product-reviews__bars {
  display: grid;
  gap: 10px;
}
.kg-product-reviews__bar {
  display: grid;
  grid-template-columns: 90px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
}
.kg-product-reviews__bar-label {
  color: #f3c243;
  font-size: 17px;
  letter-spacing: 1px;
}
.kg-product-reviews__bar-track {
  position: relative;
  height: 10px;
  border-radius: 999px;
  background: #e5e7eb;
  overflow: hidden;
}
.kg-product-reviews__bar-fill {
  position: absolute;
  inset: 0 auto 0 0;
  border-radius: 999px;
  background: var(--kg-accent);
}
.kg-product-reviews__bar-count {
  min-width: 48px;
  text-align: right;
  font-size: 15px;
  color: #111827;
}
.kg-product-reviews__details {
  margin-top: 26px;
}
.kg-product-reviews__details > summary {
  list-style: none;
  position: relative;
  cursor: pointer;
  padding: 16px 48px 16px 20px;
  border: 1px solid #2f6fd7;
  border-radius: 12px;
  text-align: center;
  font-size: 17px;
  font-weight: 600;
  color: #2f6fd7;
  transition: background-color 0.2s ease, color 0.2s ease;
}
.kg-product-reviews__toggle-text--open {
  display: none;
}
.kg-product-reviews__details[open] .kg-product-reviews__toggle-text--closed {
  display: none;
}
.kg-product-reviews__details[open] .kg-product-reviews__toggle-text--open {
  display: inline;
}
.kg-product-reviews__details > summary::-webkit-details-marker {
  display: none;
}
.kg-product-reviews__details > summary::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 22px;
  width: 9px;
  height: 9px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: translateY(-70%) rotate(45deg);
  transition: transform 0.2s ease;
}
.kg-product-reviews__details[open] > summary::after {
  transform: translateY(-25%) rotate(-135deg);
}
.kg-product-reviews__details-inner {
  display: grid;
  gap: 22px;
  margin-top: 22px;
}
.kg-product-reviews .commentlist {
  list-style: none;
  margin: 0;
  padding: 0;
}
.kg-product-reviews .commentlist > .review {
  margin: 0;
  padding: 24px 0;
}
.kg-product-reviews .commentlist > .review.byuser {
  padding: 20px 18px;
  border: 1px solid #cbd5e1;
  border-radius: 16px;
  background: #fff;
}
.kg-product-reviews .commentlist > .review:first-child {
  padding-top: 0;
}
.kg-product-reviews .commentlist > .review.byuser:first-child {
  padding-top: 20px;
}
.kg-product-reviews .commentlist > .review + .review {
  border-top: 1px solid #cbd5e1;
}
.kg-product-reviews .commentlist > .review.byuser + .review {
  border-top: 1px solid #cbd5e1;
}
.kg-product-reviews .comment_container {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  column-gap: 8px;
  row-gap: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  align-items: start;
}
.kg-product-reviews .kg-product-review__avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: #3d7cdd;
  color: #fff;
  font-size: 18px;
  font-weight: 600;
}
.kg-product-reviews .comment_container > .comment-text {
  min-width: 0;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
}
.kg-product-reviews .kg-product-review__meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px 16px;
  margin: 0;
}
.kg-product-reviews .woocommerce-review__published-date {
  font-size: 14px;
  font-weight: 500;
  color: #334155;
}
.kg-product-reviews .kg-product-review__rating {
  margin-top: 10px;
}
.kg-product-reviews .kg-product-review__rating:empty {
  display: none;
}
.kg-product-reviews .kg-product-review__rating .star-rating {
  margin: 0;
}
.kg-product-reviews .meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin: 0 0 10px;
  font-size: 14px;
  color: #4b5563;
}
.kg-product-reviews .woocommerce-review__author {
  color: #111827;
  font-size: 16px;
  line-height: 1.4;
}
.kg-product-reviews .kg-product-review__product {
  margin: 14px 0 6px;
  font-size: 18px;
  line-height: 1.4;
  font-weight: 700;
  color: #111827;
}
.kg-product-reviews .description {
  margin-top: 0;
}
.kg-product-reviews .description p {
  margin: 0;
  font-size: 15px;
  line-height: 1.7;
  color: #1f2937;
}
.kg-product-reviews .woocommerce-pagination ul {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.kg-product-reviews .woocommerce-pagination a,
.kg-product-reviews .woocommerce-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  height: 42px;
  padding: 0 14px;
  border-radius: 10px;
  border: 1px solid #d1d5db;
  color: #111827;
}
.kg-product-reviews #review_form_wrapper,
.kg-product-reviews .woocommerce-noreviews,
.kg-product-reviews .woocommerce-review-already-submitted,
.kg-product-reviews .woocommerce-verification-required,
.kg-product-reviews .must-log-in {
  padding: 22px;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  background: #f9fafb;
}
.kg-product-reviews #reply-title {
  display: block;
  margin: 0 0 18px;
  font-size: 20px;
  line-height: 1.3;
  font-weight: 700;
  color: #111827;
}
.kg-product-reviews .comment-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 18px;
}
.kg-product-reviews .comment-form p {
  margin: 0;
}
.kg-product-reviews .comment-form-comment,
.kg-product-reviews .comment-form-rating,
.kg-product-reviews .form-submit,
.kg-product-reviews .logged-in-as,
.kg-product-reviews .must-log-in {
  grid-column: 1 / -1;
}
.kg-product-reviews .comment-form label {
  display: block;
  margin-bottom: 8px;
  font-size: 14px;
  font-weight: 600;
  color: #111827;
}
.kg-product-reviews .comment-form input[type="text"],
.kg-product-reviews .comment-form input[type="email"],
.kg-product-reviews .comment-form select,
.kg-product-reviews .comment-form textarea {
  width: 100%;
  border: 1px solid #cbd5e1;
  border-radius: 12px;
  background: #fff;
  padding: 14px 16px;
  color: #111827;
}
.kg-product-reviews .comment-form textarea {
  min-height: 170px;
  resize: vertical;
}
.kg-product-reviews .form-submit .submit {
  min-width: 190px;
  border: 1px solid var(--kg-accent);
  border-radius: 10px;
  background: var(--kg-accent);
  color: var(--kg-accent-text);
  font-weight: 700;
  padding: 14px 24px;
}
.kg-product-reviews .form-submit .submit:hover,
.kg-product-reviews .form-submit .submit:focus {
  background: var(--kg-accent-hover);
  border-color: var(--kg-accent-hover);
  color: var(--kg-accent-text);
}
.kg-product-reviews .required {
  color: #dc2626;
}
.kg-related-heading {
  font-size: 20px;
  margin-top: 2rem;
  margin-bottom: 0.75rem;
  padding-left: 8px;
  font-weight: 600;
}
.kg-related-box .related.products ul.products {
  margin: 0;
  padding: 0;
  width: min(100%, 320px);
  grid-template-columns: minmax(0, 1fr);
}
.kg-related-box .related.products ul.products li.product {
  width: auto;
}
.kg-related-box .related.products ul.products li.product .product-card {
  min-height: 0;
}

@media (max-width: 991px) {
  .kg-product-layout {
    grid-template-columns: 1fr;
    gap: 22px;
  }
  .kg-product-details-row {
    grid-template-columns: 1fr;
  }
  .kg-product-details-row .kg-product-info-box {
    order: 1;
  }
  .kg-product-details-row .kg-related-box {
    order: 2;
  }
  .single-product .kg-single-product {
    width: min(100%, calc(100% - 28px));
  }
  .kg-product-gallery {
    min-height: auto;
  }
  .kg-product-info {
    height: auto;
  }
  .kg-product-info form.cart .quantity::before {
    font-size: 13px;
  }
  .kg-product-info form.cart .quantity .qty {
    width: 48px;
    height: 42px;
    font-size: 16px;
  }
  .kg-product-info form.cart .kg-quantity-stepper {
    grid-template-columns: 48px minmax(0, 1fr) 48px;
  }
  .kg-product-info form.cart .kg-quantity-stepper .qty {
    width: 100%;
    height: 42px;
  }
  .kg-product-info .kg-product-variation-fields {
    grid-template-columns: 1fr;
  }
  .kg-product-info .kg-product-purchase-grid {
    grid-template-columns: 1fr;
  }
  .kg-product-info form.variations_form.cart .woocommerce-variation-add-to-cart.variations_button {
    grid-template-columns: 1fr;
  }
  .kg-product-info .kg-product-purchase-grid .kg-quantity-label {
    font-size: 15px;
  }
  .kg-product-info form.variations_form.cart .variations_button .kg-quantity-label {
    font-size: 15px;
  }
  .kg-product-info .kg-product-purchase-grid .quantity {
    grid-column: 1;
  }
  .kg-product-info form.variations_form.cart .variations_button .quantity {
    grid-column: 1;
  }
  .kg-product-info .kg-product-purchase-grid .quantity .qty {
    width: 100%;
  }
  .kg-product-info form.variations_form.cart .variations_button .quantity .qty {
    width: 100%;
  }
  .kg-product-info .kg-quantity-stepper {
    grid-template-columns: 48px minmax(0, 1fr) 48px;
  }
  .kg-product-reviews__summary {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .kg-product-reviews__bar {
    grid-template-columns: 72px minmax(0, 1fr) auto;
    gap: 10px;
  }
  .kg-product-reviews .comment-form {
    grid-template-columns: 1fr;
  }
  .kg-related-box .related.products ul.products {
    width: 100%;
    max-width: 320px;
  }
}

/* Single product reference refresh */
.single-product .kg-single-product {
  width: min(1128px, calc(100% - 72px));
}

.kg-product-content-wrap {
  padding-bottom: 56px;
}

.kg-breadcrumb {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 26px;
  font-size: 13px;
  color: #8f98a8;
}

.kg-breadcrumb a {
  color: #15803D;
  text-decoration: none;
}

.kg-breadcrumb a:hover,
.kg-breadcrumb a:focus-visible {
  color: #0F5F2D;
}

.kg-breadcrumb span:last-child {
  color: #b59263;
}

.kg-product-layout {
  grid-template-columns: minmax(0, 530px) minmax(0, 1fr);
  gap: 48px;
  align-items: start;
  margin-bottom: 0;
}

.kg-product-gallery {
  min-height: 324px;
  padding: 54px 46px;
  border: 0;
  border-radius: 0;
  background: #f6f6f4;
  box-shadow: none;
}

.kg-product-gallery .woocommerce-product-gallery,
.kg-product-gallery .images {
  max-width: 350px;
}

.kg-product-gallery .woocommerce-product-gallery__wrapper,
.kg-product-gallery .woocommerce-product-gallery__image {
  width: 100%;
}

.kg-product-gallery .woocommerce-product-gallery__image img,
.kg-product-gallery .woocommerce-product-gallery__wrapper img {
  max-height: 250px;
  border-radius: 18px;
}

.kg-product-gallery .flex-control-thumbs,
.kg-product-gallery .woocommerce-product-gallery__trigger,
.kg-product-gallery .zoomImg {
  display: none !important;
}

.kg-product-sidebar {
  display: grid;
  gap: 30px;
  align-content: start;
}

.kg-product-info {
  height: auto;
  display: grid;
  gap: 16px;
}

.kg-product-info .product_title {
  margin: 0;
  color: #24324b;
  font-size: clamp(28px, 2.4vw, 34px);
  line-height: 1.25;
  letter-spacing: 0;
  font-family: Inter, Arial, sans-serif;
  font-weight: 600;
}

.kg-product-info .price,
.kg-product-info .woocommerce-product-rating,
.kg-product-info .stock.in-stock,
.kg-product-info .kg-product-delivery-note,
.kg-product-info .product_meta,
.kg-product-info .woocommerce-product-details__short-description,
.kg-product-info .woocommerce-variation-price,
.kg-product-info .woocommerce-variation-availability,
.kg-product-info .woocommerce-variation-description {
  display: none !important;
}

.kg-product-info form.cart,
.kg-product-info form.variations_form.cart {
  margin: 0;
}

.kg-product-info .kg-product-variation-fields {
  grid-template-columns: minmax(0, 1fr) minmax(0, 258px);
  gap: 16px 18px;
  margin: 0 0 24px;
}

.kg-product-info .kg-variation-option-field {
  gap: 10px;
}

.kg-product-info .kg-variation-option-label {
  font-size: 16px;
  font-weight: 600;
  color: #111827;
}

.kg-product-info .kg-variation-option-control .kg-variation-select,
.kg-product-info .kg-variation-option-control select {
  height: 44px;
  border: 1px solid #d7dce2;
  border-radius: 6px;
  background-color: #fff;
  color: #111827;
  font-size: 16px;
  font-weight: 500;
  padding: 0 36px 0 14px;
  background-image: linear-gradient(45deg, transparent 50%, #9aa1ad 50%), linear-gradient(135deg, #9aa1ad 50%, transparent 50%);
  background-position: calc(100% - 18px) calc(50% - 2px), calc(100% - 13px) calc(50% - 2px);
  background-size: 5px 5px, 5px 5px;
}

.kg-product-info .kg-product-purchase-grid,
.kg-product-info form.variations_form.cart .woocommerce-variation-add-to-cart.variations_button {
  grid-template-columns: minmax(0, 1fr) minmax(0, 258px);
  gap: 16px 18px;
}

.kg-product-info .kg-product-purchase-grid .kg-quantity-label,
.kg-product-info form.variations_form.cart .variations_button .kg-quantity-label {
  font-size: 16px;
  font-weight: 600;
  color: #111827;
}

.kg-product-info .kg-quantity-stepper {
  grid-template-columns: 52px minmax(0, 1fr) 52px;
  border: 1px solid #d7dce2;
  border-radius: 6px;
  background: #fff;
}

.kg-product-info .kg-quantity-stepper .qty {
  height: 40px;
  font-size: 22px;
  font-weight: 500;
  color: #111827;
}

.kg-product-info .kg-quantity-stepper__button {
  height: 40px;
  color: #4b5563;
  font-size: 25px;
  font-weight: 500;
}

.kg-product-info .kg-product-activation-notice {
  margin: -4px 0 0;
  color: #ff5a4f;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
}

.kg-product-info .single_add_to_cart_button.button.alt {
  width: 100%;
  margin-top: 6px;
  padding: 16px 24px;
  border: 1px solid var(--kg-accent);
  border-radius: 10px;
  background: var(--kg-accent);
  color: var(--kg-accent-text);
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  box-shadow: none;
}

.kg-product-info .single_add_to_cart_button.button.alt:hover,
.kg-product-info .single_add_to_cart_button.button.alt:focus-visible {
  background: var(--kg-accent-hover);
  border-color: var(--kg-accent-hover);
  color: var(--kg-accent-text);
}

.kg-product-benefits-card {
  display: grid;
  gap: 20px;
  padding: 24px;
  border-radius: 14px;
  background: #f7f7f5;
}

.kg-product-benefits-list {
  display: grid;
  gap: 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid #e1e5e8;
}

.kg-product-benefits-item {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.kg-product-benefits-item__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  color: #00bb72;
}

.kg-product-benefits-item__icon svg {
  width: 24px;
  height: 24px;
  fill: currentColor;
}

.kg-product-benefits-item__copy strong {
  display: block;
  margin-bottom: 3px;
  color: #00b66f;
  font-size: 16px;
  font-weight: 700;
}

.kg-product-benefits-item__copy span {
  color: #7a8392;
  font-size: 14px;
  line-height: 1.45;
}

.kg-product-payments {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.kg-product-payments__label {
  color: #5d6674;
  font-size: 14px;
  font-weight: 500;
}

.kg-product-payments__list {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.kg-payment-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 64px;
  height: 40px;
  padding: 0 14px;
  border: 1px solid #d1d7e0;
  border-radius: 10px;
  background: #fff;
  color: #111827;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.kg-payment-pill--mastercard {
  min-width: 58px;
  padding: 0 10px;
}

.kg-payment-pill__mastercard {
  display: inline-flex;
  align-items: center;
}

.kg-payment-pill__mastercard span {
  display: block;
  width: 18px;
  height: 18px;
  border-radius: 50%;
}

.kg-payment-pill__mastercard span:first-child {
  background: #ef3d2f;
}

.kg-payment-pill__mastercard span:last-child {
  background: #ffb300;
  margin-left: -5px;
}

.kg-payment-pill--visa {
  color: #1f49b6;
  font-size: 18px;
  letter-spacing: 0;
}

.kg-payment-pill--blik {
  position: relative;
  color: #ffffff;
  background: #232323;
  text-transform: lowercase;
}

.kg-payment-pill--blik::before {
  content: "";
  width: 7px;
  height: 7px;
  margin-right: 6px;
  border-radius: 50%;
  background: #ff4b45;
}

.kg-product-information {
  display: grid;
  gap: 16px;
}

.kg-product-information__title {
  margin: 0;
  color: #24324b;
  font-size: clamp(28px, 2.7vw, 44px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  font-weight: 500;
}

.kg-product-information__content p {
  margin: 0 0 16px;
  color: #404958;
  font-size: 16px;
  line-height: 1.72;
}

.kg-product-information__content p:last-child {
  margin-bottom: 0;
}

.kg-product-information__content strong {
  color: #101828;
  font-weight: 700;
}

.kg-product-faq {
  margin-top: 4px;
}

.kg-product-faq__items {
  display: grid;
  gap: 10px;
}

.kg-product-faq__item {
  overflow: hidden;
  border-radius: 8px;
  background: #f6f6f4;
}

.kg-product-faq__item summary {
  position: relative;
  padding: 17px 48px 17px 18px;
  cursor: pointer;
  list-style: none;
  color: #1f2937;
  font-size: 18px;
  line-height: 1.35;
  font-weight: 500;
}

.kg-product-faq__item summary::-webkit-details-marker {
  display: none;
}

.kg-product-faq__item summary::after {
  content: "";
  position: absolute;
  right: 20px;
  top: 50%;
  width: 9px;
  height: 9px;
  border-right: 2px solid #00bb72;
  border-bottom: 2px solid #00bb72;
  transform: translateY(-60%) rotate(45deg);
  transition: transform 0.2s ease;
}

.kg-product-faq__item[open] summary {
  color: #6a5ac9;
}

.kg-product-faq__item[open] summary::after {
  transform: translateY(-35%) rotate(-135deg);
}

.kg-product-faq__answer {
  padding: 0 18px 18px;
}

.kg-product-faq__answer p {
  margin: 0 0 14px;
  color: #4b5563;
  font-size: 16px;
  line-height: 1.68;
}

.kg-product-faq__answer p:last-child {
  margin-bottom: 0;
}

@media (max-width: 991px) {
  .single-product .kg-single-product {
    width: min(100%, calc(100% - 28px));
  }

  .kg-product-layout {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .kg-product-gallery {
    min-height: 0;
  }

  .kg-product-sidebar {
    gap: 24px;
  }
}

@media (max-width: 640px) {
  .single-product .kg-single-product {
    width: calc(100% - 22px);
  }

  .kg-breadcrumb {
    margin-bottom: 18px;
    font-size: 12px;
  }

  .kg-product-gallery {
    padding: 30px 22px;
  }

  .kg-product-info .product_title {
    font-size: clamp(24px, 8vw, 30px);
  }

  .kg-product-info .kg-product-variation-fields,
  .kg-product-info .kg-product-purchase-grid,
  .kg-product-info form.variations_form.cart .woocommerce-variation-add-to-cart.variations_button {
    grid-template-columns: 1fr;
  }

  .kg-product-info .kg-product-purchase-grid .quantity,
  .kg-product-info form.variations_form.cart .variations_button .quantity {
    grid-column: 1;
  }

  .kg-product-info .kg-quantity-stepper {
    grid-template-columns: 48px minmax(0, 1fr) 48px;
  }

  .kg-product-benefits-card {
    padding: 20px 18px;
  }

  .kg-product-benefits-item {
    gap: 12px;
  }

  .kg-product-information__content p,
  .kg-product-faq__answer p {
    font-size: 15px;
  }

  .kg-product-faq__item summary {
    padding: 15px 44px 15px 16px;
    font-size: 16px;
  }
}

/* Category archive redesign */
body.tax-product_cat {
  background: #fff;
  color: #0f2138;
}
.kg-category-page {
  position: relative;
  min-height: 100vh;
  background: #fff;
  color: #0f2138;
}
.kg-category-loading {
  position: absolute;
  inset: 0;
  z-index: 20;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 28px 20px 20px;
  background: rgba(255, 255, 255, 0.72);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.18s ease, visibility 0.18s ease;
}
.kg-category-products-shell.is-loading .kg-category-loading {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.kg-category-loading__inner {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px;
  border: 1px solid rgba(42, 119, 255, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 12px 28px rgba(15, 33, 56, 0.08);
}
.kg-category-loading__spinner {
  width: 16px;
  height: 16px;
  border: 2px solid #b9cdf7;
  border-right-color: #2a77ff;
  border-radius: 50%;
  animation: kg-category-spin 0.7s linear infinite;
}
.kg-category-loading__text {
  font-size: 0.86rem;
  font-weight: 700;
  color: #1f4fa3;
}
.kg-category-page .screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.kg-category-container,
.kg-category-header__inner,
.kg-category-header__nav-inner,
.kg-category-footer__trust-inner,
.kg-category-footer__help-inner,
.kg-category-footer__legal-inner {
  width: min(1240px, calc(100% - 48px));
  margin: 0 auto;
}
.kg-category-header {
  position: static;
  background: #fff;
  border-bottom: 1px solid #e7edf3;
}
.kg-category-header__inner {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) auto;
  gap: 22px;
  align-items: center;
  padding: 14px 0 12px;
}
.kg-category-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 800;
  font-size: 1rem;
  color: #14263d;
}
.kg-category-brand__mark,
.kg-category-hero__brand-mark,
.kg-category-divider__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.kg-category-brand__mark {
  width: 38px;
  height: 38px;
}
.kg-category-brand__logo {
  display: block;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
}
.kg-category-brand__textmark {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #2f8bff, #44efc5);
  color: #fff;
  font-size: 0.86rem;
  font-weight: 800;
}
.kg-category-search {
  position: relative;
}
.kg-category-search input {
  width: 100%;
  min-height: 42px;
  padding: 0 48px 0 18px;
  border: 0;
  border-radius: 999px;
  background: var(--kg-soft);
  box-shadow: inset 0 0 0 1px var(--kg-border);
  font-size: 0.92rem;
  color: var(--kg-text);
}
.kg-category-search input::placeholder,
.kg-category-footer__search input::placeholder {
  color: var(--kg-search-placeholder);
}
.kg-category-search__button,
.kg-category-tools__cart {
  position: relative;
  border: 0;
  background: transparent;
  cursor: pointer;
}
.kg-category-search__button {
  position: absolute;
  top: 50%;
  right: 14px;
  width: 20px;
  height: 20px;
  transform: translateY(-50%);
}
.kg-category-search__button::before,
.kg-category-tools__cart::before {
  content: "";
  position: absolute;
}
.kg-category-search__button::before {
  inset: 1px 1px auto auto;
  width: 12px;
  height: 12px;
  border: 2px solid var(--kg-text);
  border-radius: 50%;
}
.kg-category-search__button::after {
  content: "";
  position: absolute;
  right: 2px;
  bottom: 4px;
  width: 7px;
  height: 2px;
  background: var(--kg-text);
  border-radius: 999px;
  transform: rotate(45deg);
}
.kg-category-tools {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.kg-category-tools__locale {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--kg-border);
  background: var(--kg-card);
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--kg-text);
}
.kg-category-tools__cart {
  width: 28px;
  height: 28px;
}
.kg-category-tools__cart::before {
  left: 2px;
  top: 5px;
  width: 16px;
  height: 11px;
  border: 2px solid var(--kg-text);
  border-top: 0;
  border-radius: 0 0 4px 4px;
}
.kg-category-tools__cart::after {
  content: "";
  position: absolute;
  left: 7px;
  top: 1px;
  width: 10px;
  height: 8px;
  border: 2px solid var(--kg-text);
  border-bottom: 0;
  border-radius: 8px 8px 0 0;
}
.kg-category-tools__login,
.kg-category-footer__search button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 16px;
  border-radius: 999px;
  background: var(--kg-primary);
  color: var(--kg-primary-text);
  font-size: 0.82rem;
  font-weight: 800;
  box-shadow: none;
}
.kg-category-tools__login:hover,
.kg-category-tools__login:focus {
  background: var(--kg-primary-hover);
  color: var(--kg-primary-text);
}
.kg-category-header__nav {
  border-top: 1px solid var(--kg-border);
}
.kg-category-topnav {
  display: flex;
  gap: 20px;
  align-items: center;
  min-height: 38px;
  overflow-x: auto;
}
.kg-category-topnav__link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  white-space: nowrap;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--kg-muted);
}
.kg-category-topnav__link:not(.kg-category-topnav__link--plain)::after,
.kg-category-faq__item summary::after {
  content: "";
  width: 7px;
  height: 7px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg);
  transition: transform 0.2s ease;
}
.kg-category-content {
  padding: 14px 0 0;
}
.kg-category-breadcrumbs {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--kg-muted);
  font-size: 0.76rem;
}
.kg-category-breadcrumbs strong {
  color: var(--kg-text);
}
.kg-category-hero {
  position: relative;
  margin: 18px 0 18px;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(240px, 0.8fr);
  gap: 18px;
  align-items: center;
  min-height: 210px;
  padding: 24px 34px;
  border-radius: 10px;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0) 30%),
    linear-gradient(90deg, #24262d 0%, #202229 58%, #2fd6e6 58%, #66e9c7 100%);
}
.kg-category-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.02), transparent 55%);
  pointer-events: none;
}
.kg-category-hero__copy {
  position: relative;
  z-index: 1;
  color: #fff;
}
.kg-category-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: #d7e3f5;
  font-size: 0.74rem;
  font-weight: 700;
  margin-bottom: 14px;
}
.kg-category-hero__brandlockup {
  display: flex;
  align-items: center;
  gap: 14px;
}
.kg-category-hero__brand-mark {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  padding: 12px;
}
.kg-category-hero__brand-name {
  font-size: clamp(2rem, 4.5vw, 3rem);
  line-height: 1;
  font-weight: 800;
  letter-spacing: -0.03em;
}
.kg-category-hero__subtitle {
  margin: 14px 0 0;
  max-width: 480px;
  font-size: 0.92rem;
  line-height: 1.5;
  color: #d8e3f4;
}
.kg-category-hero__visual {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: flex-end;
}
.kg-category-hero__orb {
  position: relative;
  width: min(340px, 100%);
  aspect-ratio: 1 / 1;
  border-radius: 999px 0 0 999px;
  overflow: hidden;
  background: linear-gradient(135deg, #46a4ff, #2ae6c5);
  display: flex;
  align-items: center;
  justify-content: center;
}
.kg-category-hero__orb img {
  width: 64%;
  height: 64%;
  object-fit: contain;
  filter: drop-shadow(0 12px 24px rgba(0, 0, 0, 0.12));
}
.kg-category-hero__orb span {
  font-size: clamp(2.6rem, 5vw, 4rem);
  font-weight: 800;
  color: rgba(255, 255, 255, 0.96);
  letter-spacing: 0.08em;
}
.kg-category-benefits {
  width: fit-content;
  max-width: 100%;
  margin: 0 auto 26px;
  padding: 9px 16px;
  border-radius: 999px;
  border: 1px solid #e2e8f0;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  flex-wrap: wrap;
  box-shadow: 0 3px 14px rgba(15, 33, 56, 0.05);
}
.kg-category-benefits__item {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.78rem;
  font-weight: 700;
  color: #24374e;
}
.kg-category-benefits__item::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(135deg, #398cff, #42eac1);
  box-shadow: 0 0 0 4px rgba(63, 172, 240, 0.08);
}
.kg-category-overview {
  margin-bottom: 22px;
}
.kg-category-overview__title,
.kg-category-copy h2,
.kg-category-faq h2,
.kg-category-footer__help h2,
.kg-category-grid-section__heading h2 {
  margin: 0;
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  line-height: 1.25;
  letter-spacing: -0.02em;
  color: #0f2138;
}
.kg-category-overview__intro,
.kg-category-copy p,
.kg-category-copy li,
.kg-category-faq__lead,
.kg-category-faq__answer p,
.kg-category-footer__help p,
.kg-category-footer__column li {
  font-size: 0.84rem;
  line-height: 1.6;
  color: #314359;
}
.kg-category-overview__intro {
  max-width: 760px;
  margin: 10px 0 16px;
}
.kg-category-pills-wrap {
  display: grid;
  gap: 8px;
}
.kg-category-pills__label {
  font-size: 0.72rem;
  font-weight: 700;
  color: #6d7b8c;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.kg-category-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.kg-category-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid #dbe4ee;
  background: #fff;
  color: #5d7084;
  font-size: calc(0.74rem + 2px);
  font-weight: 700;
}
.kg-category-pill.is-pending {
  background: #eef4ff;
  border-color: #8fb4ff;
  color: #2a77ff;
}
.kg-category-pill.is-pending::after {
  content: "";
  width: 12px;
  height: 12px;
  margin-left: 8px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: kg-category-spin 0.7s linear infinite;
}
.kg-category-pill.is-active {
  background: #2a77ff;
  border-color: #2a77ff;
  color: #fff;
}
@keyframes kg-category-spin {
  to {
    transform: rotate(360deg);
  }
}
.kg-category-grid-section {
  margin-bottom: 44px;
}
.kg-category-grid-section__heading {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 14px;
}
.kg-category-grid-section__heading span {
  color: #6f7f92;
  font-size: 0.8rem;
  font-weight: 600;
}
.kg-category-products {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}
.kg-category-products-shell {
  position: relative;
  min-height: 160px;
}
.kg-category-products-content {
  transition: opacity 0.18s ease;
}
.kg-category-products-shell.is-loading .kg-category-products-content {
  opacity: 0.42;
  pointer-events: none;
}
.kg-category-card {
  background: #fff;
  border: 1px solid #dfe6ee;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(15, 33, 56, 0.04);
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.kg-category-card:hover {
  transform: translateY(-2px);
  border-color: #c7d5e5;
  box-shadow: 0 8px 20px rgba(15, 33, 56, 0.08);
}
.kg-category-card__link {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.kg-category-card__media {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 118px;
  padding: 14px;
  background: #f5f7fa;
}
.kg-category-card__media img {
  width: 100%;
  max-height: 86px;
  object-fit: contain;
}
.kg-category-card__body {
  display: grid;
  gap: 6px;
  padding: 10px 12px 12px;
}
.kg-category-card__title {
  min-height: 34px;
  font-size: 0.84rem;
  line-height: 1.3;
  font-weight: 700;
  color: #10233a;
}
.kg-category-card__price {
  font-size: 0.78rem;
  font-weight: 800;
  color: #10233a;
}
.kg-category-card__price .amount {
  color: inherit;
}
.kg-category-empty {
  margin: 0;
  padding: 18px 20px;
  border-radius: 12px;
  background: #eef3f7;
  color: #314359;
}
.kg-category-divider {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 44px 0 30px;
}
.kg-category-divider__line {
  flex: 1;
  height: 1px;
  background: #dae4ee;
}
.kg-category-divider__badge {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  padding: 6px;
  background: #fff;
  border: 1px solid #d9e4ef;
}
.kg-category-copy {
  display: grid;
  gap: 26px;
}
.kg-category-copy__section {
  max-width: 1180px;
}
.kg-category-copy h2,
.kg-category-faq h2,
.kg-category-grid-section__heading h2 {
  font-size: 1rem;
  margin-bottom: 10px;
}
.kg-category-copy p {
  max-width: 1220px;
  margin: 0 0 12px;
}
.kg-category-copy ol,
.kg-category-copy ul {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 4px;
}
.kg-category-copy li::marker {
  color: #3d7feb;
  font-weight: 700;
}
.kg-category-faq {
  margin-bottom: 48px;
}
.kg-category-faq__lead {
  margin: 8px 0 18px;
  max-width: 840px;
}
.kg-category-faq__items {
  display: grid;
  gap: 10px;
}
.kg-category-faq__item {
  border-radius: 18px;
  border: 1px solid #dde5ee;
  background: #f2f5f8;
  overflow: hidden;
}
.kg-category-faq__item summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 12px 18px;
  cursor: pointer;
  font-size: 0.84rem;
  font-weight: 700;
  color: #10233a;
}
.kg-category-faq__item summary::-webkit-details-marker {
  display: none;
}
.kg-category-faq__item[open] summary::after {
  transform: rotate(225deg);
}
.kg-category-faq__answer {
  padding: 0 18px 14px;
}
.kg-category-faq__answer p {
  margin: 0;
}
.kg-category-footer {
  background: var(--kg-footer-bg);
  border-top: 1px solid var(--kg-footer-border);
}
.kg-category-footer__trust {
  border-bottom: 1px solid var(--kg-footer-border);
}
.kg-category-footer__trust-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 12px 0;
}
.kg-category-footer__payments,
.kg-category-footer__rating,
.kg-category-footer__stores,
.kg-category-footer__socials,
.kg-category-footer__legal-links {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.kg-category-footer__payments span,
.kg-category-footer__stores span,
.kg-category-footer__socials span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 12px;
  background: var(--kg-footer-surface);
  border: 1px solid var(--kg-footer-border);
  font-size: 0.76rem;
  font-weight: 700;
  color: var(--kg-footer-heading);
}
.kg-category-footer__rating {
  font-size: 0.82rem;
  color: var(--kg-footer-heading);
}
.kg-category-footer__stars {
  color: #00b67a;
  letter-spacing: 0.1em;
}
.kg-category-footer__help {
  padding: 42px 0 36px;
}
.kg-category-footer__help-inner {
  text-align: center;
}
.kg-category-footer__help h2 {
  margin-bottom: 12px;
}
.kg-category-footer__avatars {
  display: flex;
  justify-content: center;
  gap: 0;
  margin-bottom: 10px;
}
.kg-category-footer__avatars span {
  width: 42px;
  height: 42px;
  margin-left: -6px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #ffffff, #edf2f7);
  border: 3px solid var(--kg-footer-bg);
  box-shadow: 0 8px 18px rgba(15, 33, 56, 0.06);
  font-size: 0.8rem;
  font-weight: 800;
  color: var(--kg-footer-heading);
}
.kg-category-footer__avatars span:first-child {
  margin-left: 0;
}
.kg-category-footer__help p {
  margin: 0 auto 18px;
  max-width: 680px;
}
.kg-category-footer__search {
  width: min(520px, 100%);
  margin: 0 auto 34px;
  display: grid;
  grid-template-columns: 1fr auto;
  border-radius: 6px;
  overflow: hidden;
  background: var(--kg-footer-surface);
  border: 1px solid var(--kg-footer-border);
  box-shadow: 0 8px 20px rgba(15, 33, 56, 0.05);
}
.kg-category-footer__search input {
  min-height: 38px;
  border: 0;
  padding: 0 14px;
  background: transparent;
  font-size: 0.82rem;
  color: var(--kg-footer-heading);
}
.kg-category-footer__search button {
  min-height: 38px;
  border: 1px solid var(--kg-accent);
  border-radius: 0;
  padding: 0 18px;
  background: var(--kg-accent);
  color: var(--kg-accent-text);
  box-shadow: none;
}
.kg-category-footer__search button:hover,
.kg-category-footer__search button:focus {
  background: var(--kg-accent-hover);
  border-color: var(--kg-accent-hover);
  color: var(--kg-accent-text);
}
.kg-category-footer__columns {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  text-align: left;
}
.kg-category-footer__column h3 {
  margin: 0 0 12px;
  font-size: 1rem;
  line-height: 1.1;
  color: var(--kg-footer-heading);
}
.kg-category-footer__column ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}
.kg-category-footer__column li,
.kg-category-footer__column p,
.kg-category-footer__copyright,
.kg-category-footer__legal-links span {
  color: var(--kg-footer-text);
  font-size: 0.8rem;
}
.kg-category-footer__column p {
  margin: 0 0 14px;
}
.kg-category-footer__legal {
  border-top: 1px solid var(--kg-footer-border);
}
.kg-category-footer__legal-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 12px 0 18px;
}
.kg-category-footer a {
  color: var(--kg-footer-link);
}

@media (max-width: 1300px) {
  .kg-category-products {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .kg-category-footer__columns {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1080px) {
  .kg-category-header__inner {
    grid-template-columns: 1fr;
  }
  .kg-category-tools {
    justify-content: flex-start;
  }
  .kg-category-hero {
    grid-template-columns: 1fr;
    padding: 24px;
  }
  .kg-category-hero__visual {
    justify-content: center;
  }
  .kg-category-products {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .kg-category-footer__trust-inner,
  .kg-category-footer__legal-inner {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 780px) {
  .kg-category-container,
  .kg-category-header__inner,
  .kg-category-header__nav-inner,
  .kg-category-footer__trust-inner,
  .kg-category-footer__help-inner,
  .kg-category-footer__legal-inner {
    width: min(100%, calc(100% - 24px));
  }
  .kg-category-topnav {
    gap: 18px;
    min-height: 46px;
  }
  .kg-category-hero {
    border-radius: 18px;
    margin-top: 20px;
    min-height: auto;
    gap: 18px;
  }
  .kg-category-hero__brandlockup {
    align-items: flex-start;
  }
  .kg-category-hero__brand-name {
    font-size: clamp(2.2rem, 12vw, 3.6rem);
  }
  .kg-category-hero__orb {
    border-radius: 28px;
    aspect-ratio: 4 / 3;
  }
  .kg-category-benefits {
    width: 100%;
    justify-content: flex-start;
    border-radius: 24px;
    padding: 14px;
  }
  .kg-category-products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .kg-category-card__media {
    min-height: 140px;
    padding: 16px;
  }
  .kg-category-card__title {
    min-height: 0;
    font-size: 0.9rem;
  }
  .kg-category-divider {
    margin: 38px 0 24px;
    gap: 12px;
  }
  .kg-category-divider__badge {
    width: 32px;
    height: 32px;
    padding: 6px;
  }
  .kg-category-footer__search {
    grid-template-columns: 1fr;
  }
  .kg-category-footer__search button {
    width: 100%;
  }
  .kg-category-footer__columns {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .kg-category-search input {
    min-height: 52px;
    padding-left: 18px;
  }
  .kg-category-tools {
    gap: 12px;
  }
  .kg-category-tools__login {
    min-height: 42px;
    padding: 0 18px;
  }
  .kg-category-overview__intro,
  .kg-category-copy p,
  .kg-category-copy li,
  .kg-category-faq__lead,
  .kg-category-faq__answer p,
  .kg-category-footer__help p,
  .kg-category-footer__column li {
    font-size: 0.88rem;
  }
  .kg-category-products {
    grid-template-columns: 1fr;
  }
  .kg-category-grid-section__heading {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
  .kg-category-faq__item summary {
    padding: 18px 20px;
    font-size: 1rem;
  }
  .kg-category-faq__answer {
    padding: 0 20px 18px;
  }
}

@media (max-width: 560px) {
  .site-header .container {
    width: min(100%, calc(100% - 24px));
  }
  .header-row {
    gap: 12px;
  }
  .header-actions {
    width: 100%;
  }
  .header-login {
    padding: 0 16px;
  }
}

.woocommerce-account .container {
  width: min(1320px, calc(100% - 40px));
}
.woocommerce-account main {
  padding-top: 24px;
}
.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content {
  float: none;
  width: 100%;
}
.kg-account-page {
  display: grid;
  gap: 18px;
  padding-bottom: 32px;
}
.kg-account-breadcrumbs {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--kg-muted);
}
.kg-account-breadcrumbs strong {
  color: var(--kg-text);
}
.kg-account-banner {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border-radius: 14px;
  border: 1px solid transparent;
  font-size: 14px;
  line-height: 1.5;
}
.kg-account-banner p {
  margin: 0;
}
.kg-account-banner__dot {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  flex: 0 0 auto;
}
.kg-account-banner--pending {
  background: var(--kg-primary-tint);
  border-color: var(--kg-primary-border-soft);
  color: var(--kg-primary);
}
.kg-account-banner--pending .kg-account-banner__dot {
  background: var(--kg-primary);
}
.kg-account-banner--verified {
  background: #e4f8ee;
  border-color: #b7e7ce;
  color: #165d38;
}
.kg-account-banner--verified .kg-account-banner__dot {
  background: #1fa561;
}
.kg-account-layout {
  display: grid;
  grid-template-columns: 270px minmax(0, 1fr);
  gap: 28px;
  align-items: start;
}
.kg-account-layout > .woocommerce-MyAccount-navigation,
.kg-account-layout > .woocommerce-MyAccount-content {
  min-width: 0;
}
.kg-account-navigation {
  width: 100%;
  background: var(--kg-card);
  border: 1px solid var(--kg-border);
  border-radius: 20px;
  padding: 22px 18px;
  position: sticky;
  top: 24px;
}
.kg-account-navigation__title {
  margin: 0 0 18px;
  font-size: 26px;
  color: var(--kg-text);
}
.kg-account-navigation ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}
.kg-account-navigation li {
  list-style: none;
}
.kg-account-navigation a {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 46px;
  padding: 0 14px;
  border-radius: 12px;
  color: var(--kg-muted);
  font-weight: 600;
  transition: background .2s ease, color .2s ease;
}
.kg-account-navigation a:hover,
.kg-account-navigation .is-active a {
  background: var(--kg-primary);
  color: var(--kg-primary-text);
}
.kg-account-navigation .woocommerce-MyAccount-navigation-link--customer-logout {
  margin-top: 10px;
  padding-top: 14px;
  border-top: 1px solid var(--kg-border);
}
.kg-account-navigation__icon {
  display: inline-flex;
  width: 18px;
  height: 18px;
}
.kg-account-navigation__icon svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 1.9;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.kg-account-content {
  display: grid;
  gap: 18px;
}
.kg-account-panel {
  background: var(--kg-card);
  border: 1px solid var(--kg-border);
  border-radius: 20px;
  padding: 24px 28px;
}
.kg-account-panel__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 20px;
}
.kg-account-panel__eyebrow {
  margin: 0 0 6px;
  font-size: 13px;
  font-weight: 700;
  color: var(--kg-primary);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.kg-account-panel__title,
.kg-account-panel__header h2 {
  margin: 0;
  font-size: 30px;
  line-height: 1.15;
  color: var(--kg-text);
}
.kg-account-panel__description {
  margin: 10px 0 0;
  color: var(--kg-muted);
  line-height: 1.6;
}
.kg-account-panel__link,
.kg-account-panel .button,
.kg-account-inline-form .button,
.woocommerce-account .woocommerce-orders-table .button,
.kg-account-form button.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  border-radius: 12px;
  border: 1px solid var(--kg-primary);
  background: var(--kg-primary);
  color: var(--kg-primary-text);
  font-weight: 700;
  padding: 0 18px;
  cursor: pointer;
}
.kg-account-panel__link.is-secondary,
.kg-account-inline-form .button,
.woocommerce-account .woocommerce-orders-table .button.view,
.kg-account-form button.button.is-secondary {
  background: var(--kg-card);
  color: var(--kg-primary);
}
.kg-account-panel__link:hover,
.kg-account-panel .button:hover,
.kg-account-inline-form .button:hover,
.woocommerce-account .woocommerce-orders-table .button:hover,
.kg-account-form button.button:hover {
  background: var(--kg-primary-hover);
  border-color: var(--kg-primary-hover);
  color: var(--kg-primary-text);
}
.kg-account-panel__link.is-secondary:hover,
.kg-account-inline-form .button:hover,
.woocommerce-account .woocommerce-orders-table .button.view:hover,
.kg-account-form button.button.is-secondary:hover {
  background: var(--kg-primary-tint-soft);
  border-color: var(--kg-primary);
  color: var(--kg-primary);
}
.kg-account-profile-card {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 18px 20px;
  border-radius: 18px;
  background: var(--kg-soft);
  border: 1px solid var(--kg-primary-tint);
}
.kg-account-profile-card__avatar {
  flex: 0 0 auto;
}
.kg-account-profile-card__avatar img,
.kg-account-profile-card__avatar .avatar {
  width: 72px;
  height: 72px;
  border-radius: 999px;
}
.kg-account-profile-card__label {
  display: block;
  margin-bottom: 4px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--kg-muted);
}
.kg-account-profile-card h3 {
  margin: 0;
  font-size: 24px;
}
.kg-account-profile-card p {
  margin: 4px 0 0;
  color: var(--kg-muted);
}
.kg-account-status-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
}
.kg-account-status-pill::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: currentColor;
}
.kg-account-status-pill--verified {
  background: #e7f8ef;
  color: #127947;
}
.kg-account-status-pill--pending {
  background: var(--kg-primary-tint);
  color: var(--kg-primary);
}
.kg-account-stack {
  display: grid;
  gap: 16px;
}
.kg-account-copy,
.kg-account-panel p,
.kg-account-panel li,
.kg-account-order-card__meta {
  color: var(--kg-muted);
  line-height: 1.6;
}
.kg-account-order-card {
  display: grid;
  gap: 16px;
  padding: 20px;
  border: 1px solid var(--kg-border);
  border-radius: 18px;
  background: var(--kg-soft);
}
.kg-account-order-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}
.kg-account-order-card__header h3,
.kg-account-section-title {
  margin: 0;
  font-size: 22px;
  color: var(--kg-text);
}
.kg-account-order-card__number {
  font-weight: 700;
  color: var(--kg-text);
}
.kg-account-order-card__status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--kg-primary-tint);
  color: var(--kg-primary);
  font-weight: 700;
}
.kg-account-order-card__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.kg-account-order-card__meta strong {
  display: block;
  margin-bottom: 4px;
  color: var(--kg-text);
}
.kg-account-empty-state {
  display: grid;
  gap: 14px;
  padding: 20px;
  border-radius: 18px;
  background: #f8fafc;
  border: 1px dashed #cbd5e1;
}
.kg-account-empty-state p {
  margin: 0;
}
.kg-account-inline-form {
  margin: 0;
}
.kg-account-help-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  color: var(--kg-primary);
}
.kg-account-help-link::after {
  content: ">";
  font-size: 20px;
  line-height: 1;
}
.kg-account-form {
  display: grid;
  gap: 20px;
}
.kg-account-form__section--profile {
  gap: 22px;
  background:
    radial-gradient(circle at top right, var(--kg-primary-tint), transparent 24%),
    linear-gradient(180deg, var(--kg-card) 0%, var(--kg-soft) 100%);
}
.kg-account-form__section-header--profile {
  margin-bottom: 2px;
}
.kg-account-form__hero-title {
  margin: 0;
  font-size: 32px;
  line-height: 1.1;
  color: #111827;
}
.kg-account-form__summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.kg-account-form__summary-item {
  padding: 16px 18px;
  border-radius: 16px;
  border: 1px solid var(--kg-primary-tint);
  background: rgba(255, 255, 255, .92);
}
.kg-account-form__summary-item span {
  display: block;
  margin-bottom: 6px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--kg-muted);
}
.kg-account-form__summary-item strong {
  display: block;
  color: var(--kg-text);
  line-height: 1.5;
  word-break: break-word;
}
.kg-account-verify-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 24px;
  border-radius: 18px;
  border: 1px solid #fed7aa;
  background: linear-gradient(180deg, #fff7ed 0%, #fffbf5 100%);
}
.kg-account-verify-card__copy {
  display: grid;
  gap: 8px;
}
.kg-account-verify-card__copy h3 {
  margin: 0;
  font-size: 24px;
  line-height: 1.2;
  color: #111827;
}
.kg-account-verify-card__copy p {
  margin: 0;
}
.kg-account-form__section {
  display: grid;
  gap: 18px;
  padding: 22px;
  border: 1px solid var(--kg-border);
  border-radius: 18px;
  background: var(--kg-card);
}
.kg-account-form__section-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}
.kg-account-form__grid--profile {
  gap: 16px;
}
.kg-account-form__field {
  padding: 18px;
  border: 1px solid var(--kg-border);
  border-radius: 16px;
  background: var(--kg-card);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .65);
}
.kg-account-form__field:focus-within {
  border-color: var(--kg-primary);
  box-shadow: 0 0 0 3px var(--kg-primary-tint-soft);
}
.kg-account-form__section-title {
  margin: 0;
  font-size: 20px;
  color: var(--kg-text);
}
.kg-account-form__section-description {
  margin: 8px 0 0;
  color: var(--kg-muted);
  line-height: 1.6;
}
.kg-account-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.kg-account-form .form-row {
  width: 100%;
  margin: 0;
}
.kg-account-form .form-row-wide,
.kg-account-form__grid .kg-account-form__full {
  grid-column: 1 / -1;
}
.kg-account-form label,
.kg-account-form legend {
  display: block;
  margin-bottom: 8px;
  font-weight: 700;
  color: var(--kg-text);
}
.kg-account-form .required {
  color: #d92d20;
}
.kg-account-form input[type="text"],
.kg-account-form input[type="email"],
.kg-account-form input[type="password"] {
  width: 100%;
  min-height: 50px;
  border: 1px solid var(--kg-border);
  border-radius: 14px;
  padding: 0 16px;
  font-size: 15px;
  background: var(--kg-card);
}
.kg-account-form input:focus {
  outline: none;
  border-color: var(--kg-primary);
  box-shadow: 0 0 0 3px var(--kg-primary-ring);
}
.kg-account-form__help,
.kg-account-form em,
.kg-account-form small {
  display: block;
  margin-top: 8px;
  color: var(--kg-muted);
  font-size: 14px;
  line-height: 1.5;
}
.kg-account-form__choices {
  display: grid;
  gap: 14px;
}
.kg-account-choice {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 18px;
  border: 1px solid var(--kg-border);
  border-radius: 16px;
  background: var(--kg-card);
}
.kg-account-choice input {
  margin-top: 3px;
}
.kg-account-choice strong {
  display: block;
  margin-bottom: 4px;
  color: var(--kg-text);
}
.kg-account-form__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.kg-account-form__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 22px;
  border-radius: 18px;
  background: #101828;
}
.kg-account-form__footer-copy {
  margin: 0;
  max-width: 560px;
  color: rgba(255, 255, 255, .78);
}
.kg-account-form__footer--profile {
  margin-top: 2px;
}
.kg-account-form__footer .kg-account-form__actions {
  justify-content: flex-end;
}
.kg-account-page--guest .kg-account-panel__eyebrow {
  color: var(--kg-primary);
}
.kg-auth-shell {
  display: grid;
  gap: 22px;
  max-width: 1080px;
  width: 100%;
  margin: 0 auto;
}
.kg-auth-shell__header {
  margin-bottom: 0;
}
.kg-auth-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, .82fr);
  gap: 20px;
  align-items: stretch;
}
.kg-auth-grid--single {
  grid-template-columns: minmax(0, 1fr);
}
#customer_login.kg-auth-grid::before,
#customer_login.kg-auth-grid::after {
  display: none;
}
#customer_login.kg-auth-grid > * {
  float: none;
  width: 100%;
  margin: 0;
  min-width: 0;
}
.kg-auth-card {
  border: 1px solid var(--kg-border);
  border-radius: 22px;
  background: var(--kg-card);
  overflow: hidden;
  min-height: 100%;
  box-shadow: 0 20px 44px rgba(15, 23, 42, 0.06);
  display: flex;
  flex-direction: column;
}
.kg-auth-card--promo {
  border-color: var(--kg-border);
  background: var(--kg-card);
}
.kg-auth-card--form .kg-auth-card__header {
  padding: 18px 20px 8px;
  border-bottom: 0;
  background: var(--kg-card);
  text-align: center;
}
.kg-auth-card__header {
  padding: 24px 24px 14px;
  border-bottom: 1px solid var(--kg-border);
  background: linear-gradient(180deg, var(--kg-card) 0%, var(--kg-soft) 100%);
}
.kg-auth-card__header--promo {
  background: linear-gradient(180deg, var(--kg-card) 0%, var(--kg-soft) 100%);
  border-bottom: 1px solid var(--kg-border);
  padding-bottom: 14px;
  text-align: center;
}
.kg-auth-card__eyebrow {
  margin: 0 0 6px;
  font-size: 13px;
  font-weight: 700;
  color: var(--kg-primary);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.kg-auth-card__title {
  margin: 0;
  font-size: 26px;
  line-height: 1.15;
  color: var(--kg-text);
}
.kg-auth-card__description {
  margin: 10px 0 0;
  font-size: 0.98rem;
  color: var(--kg-muted);
  line-height: 1.5;
}
.kg-auth-card--promo .kg-auth-card__description {
  max-width: 30ch;
  margin-left: auto;
  margin-right: auto;
}
.kg-auth-card--login-form + .kg-auth-card--promo .kg-auth-card__description {
  max-width: 39ch;
}
.kg-auth-promo {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  gap: 18px;
  padding: 24px;
}
.kg-auth-promo__features {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  align-content: start;
}
.kg-auth-card--login-form + .kg-auth-card--promo .kg-auth-promo__features {
  gap: 10px;
}
.kg-auth-feature {
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 14px 12px;
  border: 1px solid var(--kg-primary-tint-strong);
  border-radius: 18px;
  background: var(--kg-card);
  color: var(--kg-primary);
  font-size: 0.96rem;
  font-weight: 600;
  line-height: 1.5;
  text-align: center;
}
.kg-auth-card--login-form + .kg-auth-card--promo .kg-auth-feature {
  gap: 8px;
  padding: 11px 10px;
  border-radius: 14px;
  font-size: 0.9rem;
}
.kg-auth-feature__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 16px;
  background: var(--kg-card);
  color: var(--kg-primary);
  box-shadow: inset 0 0 0 1px var(--kg-primary-ring);
}
.kg-auth-card--login-form + .kg-auth-card--promo .kg-auth-feature__icon {
  width: 42px;
  height: 42px;
  border-radius: 14px;
}
.kg-auth-feature__icon svg {
  width: 24px;
  height: 24px;
  stroke: currentColor;
  stroke-width: 1.8;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.kg-auth-card--login-form + .kg-auth-card--promo .kg-auth-feature__icon svg {
  width: 20px;
  height: 20px;
}
.kg-auth-form {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  gap: 12px;
  padding: 24px;
}
.kg-auth-form .woocommerce-form-row,
.kg-auth-form .form-row {
  margin: 0;
  padding: 0;
}
.kg-auth-form label {
  margin-bottom: 6px;
  font-size: 0.92rem;
}
.kg-auth-form .screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  border: 0;
  white-space: nowrap;
}
.kg-auth-form__field-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  align-items: start;
}
.kg-auth-form__field-row > .woocommerce-form-row,
.kg-auth-form__field-row > .form-row,
.kg-auth-form__field-row > .form-row-wide {
  grid-column: auto;
  width: 100%;
  min-width: 0;
}
.kg-auth-form--login {
  gap: 10px;
  padding-top: 8px;
}
.kg-auth-form--login .kg-auth-form__field-row {
  gap: 10px;
}
.kg-auth-form--login .woocommerce-form-row,
.kg-auth-form--login .form-row {
  margin-bottom: 0;
}
.kg-auth-form input[type="text"],
.kg-auth-form input[type="email"],
.kg-auth-form input[type="password"] {
  min-height: 38px;
  border-color: var(--kg-border);
  border-radius: 12px;
  padding: 0 10px;
  font-size: 14px;
  background: var(--kg-card);
  color: var(--kg-text);
}
.kg-auth-form input::placeholder {
  color: var(--kg-search-placeholder);
}
.kg-auth-form input:focus {
  border-color: var(--kg-primary);
  box-shadow: 0 0 0 3px var(--kg-primary-ring);
}
.kg-auth-form__links {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.kg-auth-form__links a {
  color: var(--kg-primary);
  font-weight: 700;
}
.kg-auth-form__links a:hover {
  color: var(--kg-primary-hover);
  text-decoration: underline;
}
.kg-auth-form__links--login {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
}
.kg-auth-form__links--login a:last-child {
  justify-self: end;
  text-align: right;
}
.kg-auth-form__links--single {
  grid-template-columns: 1fr;
}
.kg-auth-form__links--single a:last-child {
  justify-self: start;
  text-align: left;
}
.kg-auth-form__copy,
.kg-auth-form .woocommerce-privacy-policy-text,
.kg-auth-form .woocommerce-privacy-policy-text p {
  margin: 0;
  font-size: 0.92rem;
  color: var(--kg-muted);
  line-height: 1.7;
}
.kg-auth-form .woocommerce-privacy-policy-text a,
.kg-auth-form .lost_password a {
  color: var(--kg-primary);
  font-weight: 700;
}
.kg-auth-form__remember {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--kg-muted);
  font-size: 0.95rem;
  font-weight: 600;
}
.kg-auth-form--login .kg-auth-form__links {
  margin-top: 2px;
}
.kg-auth-form__remember input {
  width: 18px;
  height: 18px;
  margin: 0;
  accent-color: var(--kg-primary);
}
.kg-auth-form__submit {
  display: flex;
  width: 100%;
  margin-top: auto;
}
.kg-auth-form .button,
.kg-auth-form button.button,
.kg-auth-form .woocommerce-button,
.kg-auth-card__action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 42px;
  padding: 0 16px;
  border: 1px solid var(--kg-primary);
  border-radius: 12px;
  background: var(--kg-primary);
  color: var(--kg-primary-text);
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  transition: border-color 0.18s ease, background 0.18s ease, color 0.18s ease;
}
.kg-auth-form .button:hover,
.kg-auth-form button.button:hover,
.kg-auth-form .woocommerce-button:hover,
.kg-auth-card__action:hover {
  border-color: var(--kg-primary-hover);
  background: var(--kg-primary-hover);
  color: var(--kg-primary-text);
}
@media (min-width: 992px) {
  .woocommerce form.checkout_coupon,
  .woocommerce form.login,
  .woocommerce form.register {
    margin-top: 10px;
  }
}
.woocommerce-account .woocommerce-notices-wrapper {
  display: grid;
  gap: 12px;
}
.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-info,
.woocommerce-account .woocommerce-error {
  margin: 0;
  padding: 16px 18px 16px 54px;
  border-radius: 16px;
  border-top: 0;
  background: #fff;
  border: 1px solid #dbe4f0;
}
.woocommerce-account .woocommerce-message {
  background: #eefbf4;
  border-color: #bde5cb;
}
.woocommerce-account .woocommerce-error {
  background: #fff2f2;
  border-color: #f2b8b5;
}
.woocommerce-account .woocommerce-info {
  background: #eef5ff;
  border-color: #cbdaf7;
}
.woocommerce-account .woocommerce-orders-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  border: 1px solid #e4e7ec;
  border-radius: 18px;
}
.woocommerce-account .woocommerce-orders-table th,
.woocommerce-account .woocommerce-orders-table td {
  padding: 16px 18px;
  border-bottom: 1px solid #e4e7ec;
  text-align: left;
}
.woocommerce-account .woocommerce-orders-table thead {
  background: #f8fafc;
}
.woocommerce-account .woocommerce-orders-table tr:last-child td,
.woocommerce-account .woocommerce-orders-table tr:last-child th {
  border-bottom: 0;
}
.woocommerce-account .woocommerce-pagination {
  margin-top: 18px;
  display: flex;
  justify-content: flex-end;
  gap: 12px;
}

@media (max-width: 991px) {
  .kg-account-layout {
    grid-template-columns: 1fr;
  }
  .kg-account-navigation {
    position: static;
  }
  .kg-account-form__summary {
    grid-template-columns: 1fr;
  }
  .kg-auth-grid {
    grid-template-columns: 1fr;
  }
  .kg-auth-promo__features {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .kg-account-navigation__title {
    font-size: 24px;
  }
  .kg-account-order-card__grid,
  .kg-account-form__grid {
    grid-template-columns: 1fr;
  }
  .kg-account-form__footer {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 640px) {
  .kg-blog-archive,
  .kg-page-content {
    padding: 24px 0 36px;
  }
  .kg-single-post__featured {
    display: block;
    margin-bottom: 18px;
    border-radius: 18px;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
    height: 260px;
  }
  .kg-single-post__featured-image {
    height: 100%;
    object-fit: cover;
  }
  .kg-single-post__inline-featured {
    display: none;
  }
  .kg-blog-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .kg-post-card__body,
  .kg-empty-state,
  .kg-page-content__body {
    padding: 20px;
  }
  .navigation.pagination .page-numbers {
    min-height: 40px;
    min-width: 40px;
    padding: 0 14px;
  }
  .woocommerce-account .container {
    width: min(100%, calc(100% - 24px));
  }
  .kg-account-panel,
  .kg-account-navigation {
    padding: 18px;
    border-radius: 18px;
  }
  .kg-auth-card {
    border-radius: 18px;
  }
  .kg-auth-card__header,
  .kg-auth-form,
  .kg-auth-promo {
    padding: 18px;
  }
  .kg-auth-form__field-row {
    grid-template-columns: 1fr;
  }
  .kg-auth-form__links--login {
    grid-template-columns: 1fr;
  }
  .kg-auth-form__links--login a:last-child {
    justify-self: start;
    text-align: left;
  }
  .kg-auth-shell__header {
    flex-direction: column;
    align-items: flex-start;
  }
  .kg-auth-card__header--promo {
    padding-bottom: 18px;
    text-align: left;
  }
  .kg-auth-promo__features {
    grid-template-columns: 1fr;
  }
  .kg-auth-form .button,
  .kg-auth-form button.button,
  .kg-auth-form .woocommerce-button,
  .kg-auth-card__action {
    width: 100%;
  }
  .kg-account-form__section,
  .kg-account-verify-card,
  .kg-account-form__footer {
    padding: 18px;
  }
  .kg-account-panel__header,
  .kg-account-order-card__header,
  .kg-account-profile-card {
    flex-direction: column;
    align-items: flex-start;
  }
  .kg-account-panel__title,
  .kg-account-panel__header h2 {
    font-size: 24px;
  }
  .kg-account-verify-card {
    align-items: flex-start;
  }
  .kg-account-form__hero-title,
  .kg-account-verify-card__copy h3 {
    font-size: 22px;
  }
  .kg-account-form__field {
    padding: 16px;
  }
  .kg-account-navigation a {
    min-height: 42px;
  }
  .woocommerce-account .woocommerce-orders-table,
  .woocommerce-account .woocommerce-orders-table thead,
  .woocommerce-account .woocommerce-orders-table tbody,
  .woocommerce-account .woocommerce-orders-table tr,
  .woocommerce-account .woocommerce-orders-table td,
  .woocommerce-account .woocommerce-orders-table th {
    display: block;
    width: 100%;
  }
  .woocommerce-account .woocommerce-orders-table thead {
    display: none;
  }
  .woocommerce-account .woocommerce-orders-table tr {
    padding: 18px;
    border-bottom: 1px solid #e4e7ec;
  }
  .woocommerce-account .woocommerce-orders-table td,
  .woocommerce-account .woocommerce-orders-table th {
    padding: 8px 0;
    border: 0;
  }
  .woocommerce-account .woocommerce-orders-table td::before,
  .woocommerce-account .woocommerce-orders-table th::before {
    content: attr(data-title);
    display: block;
    margin-bottom: 4px;
    font-size: 12px;
    font-weight: 700;
    color: #667085;
    text-transform: uppercase;
    letter-spacing: .04em;
  }
}

.site-header__mobile-shell,
.site-header__mobile-bar,
.site-header__mobile-panel {
  display: none;
}

.site-header__mobile-panel[hidden] {
  display: none !important;
}

@media (max-width: 991px) {
  .site-header > .container.kg-home-header {
    display: none;
  }

  .site-header {
    overflow: visible;
    background: var(--kg-mobile-header-bg);
    border-bottom-color: var(--kg-mobile-header-border);
    color: var(--kg-mobile-header-text);
  }

  .site-header--homepage {
    border-bottom-color: transparent;
  }

  .site-header--hero.is-stuck,
  .site-header--hero.is-mobile-panel-open,
  .site-header--hero.is-mobile-search-open {
    background: var(--kg-mobile-header-bg);
    color: var(--kg-mobile-header-text);
    border-bottom: 1px solid var(--kg-mobile-header-border);
    box-shadow: 0 14px 30px rgba(2, 10, 20, 0.18);
  }

  .site-header--hero:not(.is-stuck):not(.is-mobile-panel-open):not(.is-mobile-search-open) {
    background: transparent;
    color: var(--kg-header-text);
    border-bottom: 1px solid transparent;
    box-shadow: none;
  }

  .site-header--hero::before,
  .site-header--hero::after {
    display: none;
  }

  .site-header__mobile-shell,
  .site-header__mobile-bar {
    display: block;
  }

  .site-header > .container.header-row,
  .site-header > .container.header-nav-row,
  .site-header > .container.site-header__hero-shell {
    display: none;
  }

  .site-header .container {
    width: min(100%, calc(100% - 24px));
  }

  .site-header__mobile-bar {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 14px;
    align-items: center;
    min-height: 72px;
    padding: 14px 0;
  }

  .branding--mobile {
    min-width: 0;
    display: flex;
    align-items: center;
  }

  .branding--mobile .custom-logo-link {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    width: 132px;
    height: 30px;
    max-width: 132px;
  }

  .branding--mobile img.custom-logo,
  .branding--mobile img {
    display: block;
    width: 100%;
    height: 100%;
    max-width: none;
    max-height: none;
    object-fit: contain;
    object-position: left center;
  }

  .branding--mobile .site-title {
    font-size: 1.28rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    color: var(--kg-mobile-header-text);
  }

  .site-header__mobile-search-form {
    min-width: 0;
    width: 100%;
  }

  .site-header__mobile-search-form input {
    min-height: 44px;
    padding: 0 46px 0 16px;
    border: 1px solid var(--kg-mobile-header-border);
    border-radius: 12px;
    background: var(--kg-mobile-header-surface);
    color: var(--kg-mobile-header-text);
    font-size: 0.95rem;
  }

  .site-header__mobile-search-form input::placeholder {
    color: var(--kg-mobile-header-muted);
  }

  .site-header__mobile-search-form input:focus {
    outline: 2px solid var(--kg-primary-ring);
    box-shadow: 0 0 0 1px var(--kg-primary-border-soft);
    background: var(--kg-mobile-header-surface-strong);
  }

  .site-header__mobile-search-form button {
    right: 5px;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    color: var(--kg-mobile-header-muted);
  }

  .site-header__mobile-actions {
    display: inline-flex;
    align-items: center;
    justify-self: end;
    gap: 14px;
  }

  .site-header__mobile-meta {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0 11px;
    border: 1px solid var(--kg-mobile-header-border);
    border-radius: 10px;
    background: var(--kg-mobile-header-surface);
    color: var(--kg-mobile-header-text);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    white-space: nowrap;
  }

  .site-header__mobile-meta-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .site-header__mobile-meta-divider {
    width: 1px;
    height: 14px;
    margin: 0 8px;
    background: var(--kg-mobile-header-border);
  }

  .site-header__mobile-icon-link,
  .site-header__mobile-menu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: 24px;
    height: 24px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: var(--kg-mobile-header-text);
    box-shadow: none;
    backdrop-filter: none;
  }

  .site-header__mobile-menu-toggle {
    position: relative;
    justify-self: start;
    cursor: pointer;
    transition: opacity 0.18s ease;
  }

  .site-header__mobile-icon-link:hover,
  .site-header__mobile-icon-link:focus-visible,
  .site-header__mobile-menu-toggle:hover,
  .site-header__mobile-menu-toggle:focus-visible {
    opacity: 0.82;
  }

  .site-header__mobile-menu-toggle span {
    position: absolute;
    width: 18px;
    height: 2.2px;
    border-radius: 999px;
    background: currentColor;
    transition: transform 0.18s ease, opacity 0.18s ease;
  }

  .site-header__mobile-menu-toggle span:nth-child(1) {
    transform: translateY(-6px);
  }

  .site-header__mobile-menu-toggle span:nth-child(3) {
    transform: translateY(6px);
  }

  .site-header.is-mobile-panel-open .site-header__mobile-menu-toggle span:nth-child(1) {
    transform: rotate(45deg);
  }

  .site-header.is-mobile-panel-open .site-header__mobile-menu-toggle span:nth-child(2) {
    opacity: 0;
  }

  .site-header.is-mobile-panel-open .site-header__mobile-menu-toggle span:nth-child(3) {
    transform: rotate(-45deg);
  }

  .site-header__mobile-icon-link svg {
    width: 23px;
    height: 23px;
    stroke: currentColor;
    stroke-width: 1.9;
    fill: none;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .site-header .header-cart--mobile,
  .site-header .header-cart--mobile:hover,
  .site-header .header-cart--mobile:focus-visible {
    width: 24px;
    height: 24px;
    border: 0;
    border-radius: 0;
    background: transparent;
    background-color: transparent;
    color: var(--kg-mobile-header-text);
    transform: none;
  }

  .site-header .header-cart--mobile svg {
    width: 23px;
    height: 23px;
  }

  .header-cart--mobile {
    position: relative;
  }

  .header-cart--mobile .header-cart__count {
    top: -6px;
    right: -8px;
    min-width: 16px;
    height: 16px;
    padding: 0 3px;
    border-color: var(--kg-mobile-header-bg);
    background: var(--kg-mobile-header-count);
    color: var(--kg-mobile-header-count-text);
    font-size: 0.62rem;
  }

  .site-header__mobile-panel--menu {
    position: fixed;
    left: 0;
    right: 0;
    top: var(--kg-site-header-height);
    bottom: 0;
    z-index: 5;
    display: block;
    background: rgba(2, 10, 20, 0.26);
    border-top: 0;
    box-shadow: none;
    backdrop-filter: blur(6px);
  }

  .site-header__mobile-panel--search {
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    z-index: 5;
    display: block;
    background: transparent;
    border-top: 0;
    box-shadow: none;
    backdrop-filter: none;
  }

  .site-header__mobile-search-sheet {
    background: var(--kg-mobile-header-bg);
    border-top: 1px solid var(--kg-mobile-header-border);
    box-shadow: 0 18px 38px rgba(2, 10, 20, 0.22);
  }

  .site-header__mobile-drawer {
    width: min(84vw, 320px);
    max-width: 100%;
    height: 100%;
    background: var(--kg-mobile-header-bg);
    box-shadow: 24px 0 42px rgba(2, 10, 20, 0.32);
  }

  .site-header__mobile-panel-inner {
    display: grid;
    gap: 18px;
    height: 100%;
    padding: 18px 20px 24px;
    overflow-y: auto;
  }

  .site-header__mobile-panel-inner--search {
    height: auto;
    padding: 16px 0 18px;
    overflow: visible;
  }

  .kg-search--mobile {
    display: block;
  }

  .kg-search--mobile button {
    display: inline-flex;
  }

  .site-header__mobile-panel-tools {
    display: flex;
  }

  .site-header .header-login--mobile {
    width: 100%;
    justify-content: center;
    min-height: 46px;
    border-color: var(--kg-mobile-header-border);
    background: var(--kg-mobile-header-surface);
    background-color: var(--kg-mobile-header-surface);
    color: var(--kg-mobile-header-text);
    transform: none;
  }

  .site-header .header-login--mobile:hover,
  .site-header .header-login--mobile:focus-visible {
    border-color: var(--kg-primary-border-soft);
    background: var(--kg-mobile-header-surface-strong);
    background-color: var(--kg-mobile-header-surface-strong);
    color: var(--kg-mobile-header-text);
    transform: none;
  }

  .header-nav-row--mobile {
    padding-bottom: 0;
  }

  .primary-nav:empty {
    display: none;
  }

  .primary-menu--mobile {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    min-height: 0;
    overflow: visible;
    padding-bottom: 0;
  }

  .primary-menu--mobile > li > a {
    min-height: 40px;
    padding: 0;
    border-radius: 0;
    background: transparent;
    font-size: 1.02rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    text-transform: uppercase;
  }

  .primary-menu--mobile > li > a:hover,
  .primary-menu--mobile > li > a:focus-visible,
  .primary-menu--mobile > li.current-menu-item > a,
  .primary-menu--mobile > li.current-menu-ancestor > a,
  .primary-menu--mobile > li.current_page_parent > a {
    color: var(--kg-header-menu-hover);
  }

  .primary-menu--mobile > li.current-menu-item > a::before,
  .primary-menu--mobile > li.current-menu-ancestor > a::before,
  .primary-menu--mobile > li.current_page_parent > a::before {
    display: none;
  }

  .primary-menu--mobile > .menu-item-has-children {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    column-gap: 10px;
    align-items: center;
  }

  .primary-menu--mobile > .menu-item-has-children::after,
  .primary-menu--mobile .sub-menu .menu-item-has-children::after {
    content: none;
    display: none;
  }

  .primary-menu--mobile > .menu-item-has-children > a::after {
    display: none;
  }

  .primary-menu__submenu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: var(--kg-mobile-header-muted);
    cursor: pointer;
  }

  .primary-menu__submenu-toggle::before {
    content: "";
    width: 7px;
    height: 7px;
    border-right: 1.7px solid currentColor;
    border-bottom: 1.7px solid currentColor;
    transform: rotate(45deg) translateY(-1px);
    transition: transform 0.18s ease;
  }

  .primary-menu--mobile > .menu-item-has-children.is-submenu-open > .primary-menu__submenu-toggle::before {
    transform: rotate(-135deg) translate(-1px, -1px);
  }

  .primary-menu--mobile .sub-menu {
    grid-column: 1 / -1;
    margin-top: 2px;
    padding: 0 0 0 14px;
    background: transparent;
    border: 0;
    box-shadow: none;
  }

  .primary-menu--mobile .sub-menu[hidden] {
    display: none !important;
  }

  .primary-menu--mobile .sub-menu a {
    padding: 8px 0 8px 8px;
    color: var(--kg-mobile-header-text);
    font-size: 1.02rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    text-transform: uppercase;
  }

  .primary-menu--mobile .sub-menu a:hover,
  .primary-menu--mobile .sub-menu a:focus-visible,
  .primary-menu--mobile .sub-menu .current-menu-item > a,
  .primary-menu--mobile .sub-menu .current-menu-ancestor > a {
    color: var(--kg-header-menu-hover);
  }

  .primary-menu--mobile > li > a {
    color: var(--kg-mobile-header-text);
  }

  .site-header__mobile-meta {
    display: none;
  }

  .site-header .header-cart--mobile {
    display: inline-flex;
  }

  body.kg-mobile-panel-open {
    overflow: hidden;
  }
}

@media (max-width: 640px) {
  .site-header__mobile-bar {
    min-height: 68px;
    gap: 10px;
  }

  .branding--mobile .custom-logo-link {
    width: 118px;
    height: 28px;
    max-width: 118px;
  }

  .site-header__mobile-search-form input {
    min-height: 42px;
    font-size: 0.88rem;
  }

  .site-header__mobile-search-form button {
    right: 4px;
    width: 34px;
    height: 34px;
  }

  .site-header__mobile-panel-inner {
    padding: 18px 18px 20px;
  }

  .site-header__mobile-panel-inner--search {
    padding: 14px 0 16px;
  }

  .site-header__mobile-actions {
    gap: 10px;
  }

  .site-header__mobile-meta {
    min-height: 36px;
    padding: 0 10px;
    font-size: 0.78rem;
  }

  .site-header__mobile-meta-divider {
    margin: 0 7px;
  }
}

/* Category page (reference layout) */
.kg-cat-v2-page {
  padding: 22px 0 40px;
  background: #ffffff;
}

.kg-cat-v2-container {
  width: min(1320px, calc(100% - 46px));
  margin: 0 auto;
}

.kg-cat-v2-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  color: #4b5563;
  font-size: 14px;
  font-weight: 500;
}

.kg-cat-v2-breadcrumbs strong {
  color: #111827;
}

.kg-cat-v2-hero {
  display: grid;
  grid-template-columns: 136px minmax(0, 1fr) 320px;
  gap: 22px;
  align-items: center;
  margin-bottom: 20px;
}

.kg-cat-v2-hero__logo {
  width: 132px;
  height: 132px;
  border-radius: 12px;
  border: 1px solid #d9e3ee;
  background: linear-gradient(180deg, #1360c5 0%, #0a3f8f 100%);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  font-size: 34px;
  font-weight: 700;
}

.kg-cat-v2-hero__logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.kg-cat-v2-hero__copy h1 {
  margin: 0;
  font-size: clamp(34px, 3.3vw, 58px);
  line-height: 1.04;
  color: #0f1635;
  letter-spacing: -0.02em;
}

.kg-cat-v2-hero__copy p {
  margin: 12px 0 0;
  color: #4b5563;
  font-size: 15px;
  line-height: 1.6;
  max-width: 720px;
}

.kg-cat-v2-hero__benefits {
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.kg-cat-v2-hero__benefit {
  position: relative;
  padding-left: 30px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.kg-cat-v2-hero__benefit::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 2px;
  color: #15a34a;
  font-size: 18px;
  font-weight: 800;
}

.kg-cat-v2-hero__benefit strong {
  font-size: 16px;
  color: #111827;
  font-weight: 700;
}

.kg-cat-v2-hero__benefit span {
  font-size: 14px;
  color: #6b7280;
}

.kg-cat-v2-trust {
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: #ffffff;
}

.kg-cat-v2-trust strong {
  font-size: 21px;
  line-height: 1.25;
  color: #111827;
}

.kg-cat-v2-trust__stars {
  color: #f7b900;
  letter-spacing: 0.2em;
  font-size: 15px;
}

.kg-cat-v2-trust span {
  color: #4b5563;
  font-size: 15px;
  font-weight: 600;
}

.kg-cat-v2-region-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 14px;
  margin-bottom: 14px;
}

.kg-cat-v2-region-box,
.kg-cat-v2-region-note {
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #ffffff;
  min-height: 88px;
}

.kg-cat-v2-region-box {
  padding: 18px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 250px;
  gap: 18px;
  align-items: center;
}

.kg-cat-v2-region-box__intro {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.kg-cat-v2-region-box__intro strong {
  font-size: 20px;
  color: #111827;
}

.kg-cat-v2-region-box__intro span {
  color: #6b7280;
  font-size: 14px;
}

.kg-cat-v2-region-box__select {
  width: 100%;
  min-height: 52px;
  border: 1px solid #d1d5db;
  border-radius: 10px;
  padding: 0 14px;
  background: #ffffff;
  color: #111827;
  font-size: 16px;
  font-weight: 600;
}

.kg-cat-v2-region-note {
  padding: 18px;
  background: #fffdf4;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.kg-cat-v2-region-note strong {
  color: #6d5b00;
  font-size: 16px;
}

.kg-cat-v2-region-note span {
  color: #4b5563;
  font-size: 14px;
}

.kg-cat-v2-shop {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 304px;
  gap: 14px;
  align-items: start;
}

.kg-cat-v2-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.kg-cat-v2-card {
  position: relative;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #ffffff;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.kg-cat-v2-card:hover {
  border-color: #c6d4e2;
  transform: translateY(-1px);
}

.kg-cat-v2-card.is-active {
  border-color: #19a849;
  box-shadow: 0 0 0 1px rgba(25, 168, 73, 0.28);
}

.kg-cat-v2-card__badge {
  position: absolute;
  left: 50%;
  top: -10px;
  transform: translateX(-50%);
  background: #14a03f;
  border: 1px solid #0f8a34;
  color: #ffffff;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  border-radius: 999px;
  padding: 4px 12px;
  z-index: 2;
}

.kg-cat-v2-card__button {
  width: 100%;
  border: 0;
  border-radius: 12px;
  background: transparent;
  text-align: left;
  padding: 16px 14px 14px;
  cursor: pointer;
}

.kg-cat-v2-card__image-wrap {
  aspect-ratio: 4 / 5;
  border-radius: 9px;
  background: #f3f5f9;
  border: 1px solid #e5e7eb;
  overflow: hidden;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.kg-cat-v2-card__image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.kg-cat-v2-card h3 {
  margin: 0;
  color: #111827;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.35;
  min-height: 44px;
}

.kg-cat-v2-card__code {
  margin: 8px 0 0;
  color: #6b7280;
  font-size: 12px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.kg-cat-v2-card__price {
  margin: 10px 0 0;
  color: #189e3f;
  font-size: 36px;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.kg-cat-v2-summary {
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  background: #ffffff;
  padding: 16px;
  position: sticky;
  top: calc(var(--kg-site-header-height) + 12px);
}

.kg-cat-v2-summary__qty,
.kg-cat-v2-summary__item,
.kg-cat-v2-summary__total {
  padding-bottom: 18px;
  margin-bottom: 18px;
  border-bottom: 1px solid #eceff3;
}

.kg-cat-v2-summary strong {
  display: block;
  color: #111827;
  font-size: 24px;
  line-height: 1.2;
  margin-bottom: 12px;
}

.kg-cat-v2-qty-stepper {
  display: inline-flex;
  align-items: center;
  border: 1px solid #d7dbe1;
  border-radius: 10px;
  overflow: hidden;
}

.kg-cat-v2-qty-stepper button,
.kg-cat-v2-qty-stepper span {
  width: 44px;
  height: 42px;
  border: 0;
  background: #ffffff;
  color: #111827;
  font-size: 21px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.kg-cat-v2-qty-stepper button {
  cursor: pointer;
}

.kg-cat-v2-qty-stepper button:hover {
  background: #f8fafc;
}

.kg-cat-v2-summary__product {
  display: grid;
  grid-template-columns: 80px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}

.kg-cat-v2-summary__product img {
  width: 80px;
  height: 100px;
  border-radius: 8px;
  object-fit: cover;
  background: #f5f7fb;
  border: 1px solid #e5e7eb;
}

.kg-cat-v2-summary__product p {
  margin: 0;
  color: #111827;
  font-size: 20px;
  line-height: 1.3;
  font-weight: 600;
}

.kg-cat-v2-summary__product span {
  color: #6b7280;
  font-size: 14px;
}

.kg-cat-v2-summary__total {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.kg-cat-v2-summary__total strong {
  margin: 0;
}

.kg-cat-v2-summary__total span {
  color: #16a34a;
  font-size: 48px;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.kg-cat-v2-summary__button {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  width: 100%;
  border-radius: 10px;
  background: #0f9a2f;
  color: #ffffff;
  font-size: 30px;
  font-weight: 700;
  transition: background 0.18s ease;
}

.kg-cat-v2-summary__button:hover,
.kg-cat-v2-summary__button:focus-visible {
  background: #0d8729;
  color: #ffffff;
}

.kg-cat-v2-summary__security {
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.kg-cat-v2-summary__security strong {
  margin: 0;
  font-size: 20px;
}

.kg-cat-v2-summary__security span {
  color: #6b7280;
  font-size: 14px;
}

.kg-cat-v2-store-benefits {
  margin-top: 18px;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #ffffff;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding: 18px 22px;
}

.kg-cat-v2-store-benefits__item {
  position: relative;
  padding-left: 28px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.kg-cat-v2-store-benefits__item::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 1px;
  color: #1aa24a;
  font-size: 16px;
  font-weight: 800;
}

.kg-cat-v2-store-benefits__item strong {
  font-size: 19px;
  color: #111827;
}

.kg-cat-v2-store-benefits__item span {
  color: #6b7280;
  font-size: 14px;
}

.kg-cat-v2-description {
  margin-top: 18px;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #ffffff;
  padding: 22px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.45fr);
  gap: 22px;
  align-items: center;
}

.kg-cat-v2-description__copy h2,
.kg-cat-v2-faq h2 {
  margin: 0 0 14px;
  color: #111827;
  font-size: 38px;
  letter-spacing: -0.02em;
}

.kg-cat-v2-description__copy p {
  margin: 0 0 12px;
  color: #374151;
  font-size: 19px;
  line-height: 1.65;
}

.kg-cat-v2-description__copy ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.kg-cat-v2-description__copy li {
  position: relative;
  padding-left: 24px;
  color: #111827;
  font-size: 19px;
  font-weight: 500;
}

.kg-cat-v2-description__copy li::before {
  content: "●";
  position: absolute;
  left: 0;
  top: 0;
  color: #18a94a;
  font-size: 14px;
  line-height: 1.7;
}

.kg-cat-v2-description__banner {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  min-height: 320px;
  border: 1px solid #c5d5ee;
  background: linear-gradient(135deg, #0a2f79 0%, #003ca0 55%, #113a8d 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}

.kg-cat-v2-description__banner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.62;
}

.kg-cat-v2-description__banner > span {
  color: #ffffff;
  font-size: 68px;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.kg-cat-v2-description__overlay {
  position: absolute;
  right: 22px;
  top: 22px;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  color: #ffffff;
  text-shadow: 0 2px 8px rgba(4, 11, 30, 0.45);
}

.kg-cat-v2-description__overlay strong {
  font-size: 44px;
  letter-spacing: 0.03em;
  line-height: 1.05;
}

.kg-cat-v2-description__overlay span {
  font-size: 28px;
  letter-spacing: 0.08em;
}

.kg-cat-v2-faq {
  margin-top: 14px;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #ffffff;
  padding: 20px;
}

.kg-cat-v2-faq__items {
  display: grid;
  gap: 8px;
}

.kg-cat-v2-faq details {
  border-bottom: 1px solid #e5e7eb;
  padding-bottom: 10px;
}

.kg-cat-v2-faq details:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.kg-cat-v2-faq summary {
  cursor: pointer;
  list-style: none;
  font-size: 22px;
  line-height: 1.4;
  color: #111827;
  font-weight: 600;
  padding: 10px 26px 10px 0;
  position: relative;
}

.kg-cat-v2-faq summary::-webkit-details-marker {
  display: none;
}

.kg-cat-v2-faq summary::after {
  content: "+";
  position: absolute;
  right: 2px;
  top: 7px;
  color: #6b7280;
  font-size: 24px;
  font-weight: 500;
}

.kg-cat-v2-faq details[open] summary::after {
  content: "−";
}

.kg-cat-v2-faq p {
  margin: 0;
  padding: 0 0 6px;
  color: #4b5563;
  font-size: 17px;
  line-height: 1.6;
}

.kg-cat-v2-empty {
  margin: 0;
  padding: 18px;
  border: 1px dashed #d1d5db;
  border-radius: 10px;
  color: #6b7280;
  font-size: 14px;
}

@media (max-width: 1360px) {
  .kg-cat-v2-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .kg-cat-v2-card__price {
    font-size: 32px;
  }

  .kg-cat-v2-summary strong {
    font-size: 22px;
  }

  .kg-cat-v2-summary__total span {
    font-size: 42px;
  }

  .kg-cat-v2-summary__button {
    font-size: 26px;
  }
}

@media (max-width: 1200px) {
  .kg-cat-v2-hero {
    grid-template-columns: 116px minmax(0, 1fr) 280px;
  }

  .kg-cat-v2-hero__logo {
    width: 112px;
    height: 112px;
  }

  .kg-cat-v2-shop {
    grid-template-columns: minmax(0, 1fr) 276px;
  }

  .kg-cat-v2-summary {
    padding: 14px;
  }

  .kg-cat-v2-summary__product {
    grid-template-columns: 66px minmax(0, 1fr);
  }

  .kg-cat-v2-summary__product img {
    width: 66px;
    height: 84px;
  }

  .kg-cat-v2-summary__product p {
    font-size: 18px;
  }

  .kg-cat-v2-description__copy h2,
  .kg-cat-v2-faq h2 {
    font-size: 32px;
  }

  .kg-cat-v2-description__copy p,
  .kg-cat-v2-description__copy li,
  .kg-cat-v2-faq p,
  .kg-cat-v2-faq summary {
    font-size: 16px;
  }
}

@media (max-width: 1060px) {
  .kg-cat-v2-shop {
    grid-template-columns: 1fr;
  }

  .kg-cat-v2-summary {
    position: static;
  }

  .kg-cat-v2-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .kg-cat-v2-region-box {
    grid-template-columns: 1fr;
  }

  .kg-cat-v2-store-benefits {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .kg-cat-v2-container {
    width: min(1320px, calc(100% - 30px));
  }

  .kg-cat-v2-hero {
    grid-template-columns: 96px minmax(0, 1fr);
  }

  .kg-cat-v2-trust {
    grid-column: 1 / -1;
  }

  .kg-cat-v2-hero__copy h1 {
    font-size: clamp(29px, 7vw, 48px);
  }

  .kg-cat-v2-hero__benefits {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .kg-cat-v2-region-row,
  .kg-cat-v2-description {
    grid-template-columns: 1fr;
  }

  .kg-cat-v2-description__banner {
    min-height: 260px;
  }

  .kg-cat-v2-description__overlay strong {
    font-size: 34px;
  }

  .kg-cat-v2-description__overlay span {
    font-size: 22px;
  }
}

@media (max-width: 700px) {
  .kg-cat-v2-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .kg-cat-v2-card__price {
    font-size: 30px;
  }

  .kg-cat-v2-store-benefits {
    grid-template-columns: 1fr;
  }

  .kg-cat-v2-summary strong,
  .kg-cat-v2-store-benefits__item strong {
    font-size: 20px;
  }

  .kg-cat-v2-summary__total span {
    font-size: 36px;
  }
}

@media (max-width: 520px) {
  .kg-cat-v2-page {
    padding-top: 16px;
  }

  .kg-cat-v2-container {
    width: calc(100% - 22px);
  }

  .kg-cat-v2-breadcrumbs {
    font-size: 12px;
    margin-bottom: 12px;
  }

  .kg-cat-v2-hero {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .kg-cat-v2-hero__logo {
    width: 92px;
    height: 92px;
  }

  .kg-cat-v2-grid {
    grid-template-columns: 1fr;
  }

  .kg-cat-v2-card__button {
    padding: 14px;
  }

  .kg-cat-v2-card__image-wrap {
    max-height: 240px;
  }

  .kg-cat-v2-summary {
    padding: 12px;
  }

  .kg-cat-v2-summary__button {
    min-height: 48px;
    font-size: 22px;
  }

  .kg-cat-v2-description {
    padding: 14px;
  }

  .kg-cat-v2-description__copy h2,
  .kg-cat-v2-faq h2 {
    font-size: 24px;
  }
}

/* Single product reference layout */
.single-product .kg-single-product.kg-pdp {
  width: min(1180px, calc(100% - 48px));
  margin: 0 auto;
}

.single-product .kg-single-product.kg-pdp .kg-product-content-wrap {
  width: 100%;
  padding-bottom: 56px;
}

.single-product .kg-single-product.kg-pdp .kg-breadcrumb {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 22px;
  color: #7b8190;
  font-size: 13px;
}

.single-product .kg-single-product.kg-pdp .kg-breadcrumb a {
  color: inherit;
  text-decoration: none;
}

.single-product .kg-single-product.kg-pdp .kg-breadcrumb span:last-child {
  color: #202938;
}

.kg-pdp-hero,
.kg-pdp-region-row,
.kg-pdp-purchase-grid,
.kg-pdp-details {
  display: grid;
  gap: 18px;
}

.kg-pdp-hero {
  grid-template-columns: 126px minmax(0, 1fr) 252px;
  align-items: start;
  gap: 28px;
  margin-bottom: 28px;
}

.kg-pdp-hero__media {
  display: flex;
  justify-content: center;
}

.kg-pdp-brand-card {
  width: 126px;
  min-height: 146px;
  padding: 16px 14px;
  border: 1px solid #e7ebf0;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(17, 24, 39, 0.04);
}

.kg-pdp-brand-card .woocommerce-product-gallery,
.kg-pdp-brand-card .images,
.kg-pdp-brand-card .woocommerce-product-gallery__wrapper,
.kg-pdp-brand-card .woocommerce-product-gallery__image {
  width: 100%;
  margin: 0 !important;
}

.kg-pdp-brand-card .woocommerce-product-gallery__wrapper img,
.kg-pdp-brand-card .woocommerce-product-gallery__image img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.kg-pdp-brand-card .flex-control-thumbs,
.kg-pdp-brand-card .woocommerce-product-gallery__trigger,
.kg-pdp-brand-card .zoomImg {
  display: none !important;
}

.kg-pdp-hero__copy {
  display: grid;
  gap: 16px;
  align-content: start;
}

.kg-pdp-title {
  margin: 0;
  color: #1d2440;
  font-size: clamp(36px, 4vw, 58px);
  line-height: 1.04;
  font-weight: 700;
  letter-spacing: -0.03em;
}

.kg-pdp-subtitle {
  margin: 0;
  color: #30384a;
  font-size: 17px;
  line-height: 1.65;
  max-width: 720px;
}

.kg-pdp-hero-benefits,
.kg-pdp-benefits-row {
  display: grid;
  gap: 16px;
}

.kg-pdp-hero-benefits {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.kg-pdp-hero-benefit,
.kg-pdp-benefits-row__item {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.kg-pdp-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  color: #20aa39;
}

.kg-pdp-icon svg,
.kg-pdp-panel__icon svg,
.kg-pdp-note-panel__icon svg,
.kg-pdp-security-note__icon svg,
.kg-pdp-trust-card__shield svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
}

.kg-pdp-hero-benefit__copy strong,
.kg-pdp-benefits-row__copy strong {
  display: block;
  margin-bottom: 2px;
  color: #171f31;
  font-size: 16px;
  font-weight: 700;
}

.kg-pdp-hero-benefit__copy span,
.kg-pdp-benefits-row__copy span {
  display: block;
  color: #5f6879;
  font-size: 14px;
  line-height: 1.55;
}

.kg-pdp-trust-card {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 14px;
  padding: 20px 18px;
  border: 1px solid #ecf0f4;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 16px 34px rgba(17, 24, 39, 0.05);
}

.kg-pdp-trust-card__shield {
  color: #20aa39;
}

.kg-pdp-trust-card__content strong {
  display: block;
  margin-bottom: 8px;
  color: #171f31;
  font-size: 20px;
  line-height: 1.35;
}

.kg-pdp-trust-card__content strong a,
.kg-cat-ref-trust strong a {
  color: inherit;
}

.kg-pdp-trust-card__rating {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  color: #4d5565;
  font-size: 16px;
  font-weight: 600;
}

.kg-pdp-stars {
  font-size: 0.94rem;
}

.kg-pdp-purchase-shell {
  margin-bottom: 28px;
}

.kg-pdp-purchase-shell .stock {
  display: none;
}

.kg-pdp-related-shell {
  margin: 4px 0 28px;
}

.kg-pdp-related-shell .related.products {
  margin: 0;
}

.kg-pdp-related-shell .kg-related-heading {
  margin: 0 0 16px;
  padding-left: 0;
  color: #171f31;
  font-size: clamp(24px, 2.4vw, 34px);
  line-height: 1.15;
  font-weight: 700;
}

.kg-pdp-related-shell .related.products ul.products {
  width: 100%;
  margin: 0;
}

.kg-pdp-related-shell .related.products ul.products li.product {
  width: auto;
  margin: 0;
}

.kg-pdp-related-shell .related.products ul.products li.product .product-card {
  min-height: 100%;
}

.kg-pdp-form,
.kg-pdp-form__layout,
.kg-pdp-form__main {
  display: grid;
  gap: 18px;
}

.kg-pdp-form {
  margin: 0;
}

.kg-pdp-region-row {
  grid-template-columns: minmax(0, 1fr) minmax(300px, 430px);
}

.kg-pdp-panel {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) minmax(180px, 240px);
  gap: 14px;
  align-items: center;
  padding: 16px 18px;
  border: 1px solid #edf0f3;
  border-radius: 14px;
  background: #fff;
}

.kg-pdp-panel__icon,
.kg-pdp-note-panel__icon,
.kg-pdp-security-note__icon {
  width: 28px;
  height: 28px;
  color: #20aa39;
}

.kg-pdp-panel__copy strong,
.kg-pdp-note-panel__copy strong {
  display: block;
  margin-bottom: 3px;
  color: #171f31;
  font-size: 17px;
  font-weight: 700;
}

.kg-pdp-panel__copy span,
.kg-pdp-note-panel__copy p {
  display: block;
  margin: 0;
  color: #5f6879;
  font-size: 14px;
  line-height: 1.55;
}

.kg-pdp-note-panel {
  grid-template-columns: 52px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
  padding: 20px 24px;
  border-color: #f4e4bb;
  border-radius: 18px;
  background: linear-gradient(180deg, #fffaf1 0%, #fff8ee 100%);
  box-shadow: 0 6px 16px rgba(214, 161, 34, 0.08);
}

.kg-pdp-note-panel__icon {
  width: 48px;
  height: 48px;
  color: #ffbf1f;
}

.kg-pdp-note-panel__copy {
  display: grid;
  gap: 4px;
}

.kg-pdp-note-panel__copy strong {
  display: inline;
  margin: 0;
  color: #111111;
  font-size: inherit;
  line-height: inherit;
  font-weight: 700;
}

.kg-pdp-note-panel__copy p {
  margin: 0;
  color: #111111;
  font-size: 18px;
  line-height: 1.4;
}

.kg-pdp-panel__control {
  width: 100%;
}

.kg-pdp-select,
.kg-pdp-panel__control select,
.kg-pdp-extra-options select {
  width: 100%;
  height: 52px;
  padding: 0 42px 0 16px;
  border: 1px solid #d9dee4;
  border-radius: 10px;
  background-color: #fff;
  color: #111827;
  font-size: 16px;
  font-weight: 600;
  appearance: none;
  -webkit-appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, #818795 50%), linear-gradient(135deg, #818795 50%, transparent 50%);
  background-position: calc(100% - 21px) calc(50% - 3px), calc(100% - 15px) calc(50% - 3px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}

.kg-pdp-hidden-select {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  overflow: hidden;
  white-space: nowrap;
}

.kg-pdp-extra-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}

.kg-pdp-extra-options__field {
  display: grid;
  gap: 8px;
}

.kg-pdp-extra-options__field label {
  color: #171f31;
  font-size: 15px;
  font-weight: 600;
}

.kg-pdp-purchase-grid {
  grid-template-columns: minmax(0, 1fr) minmax(280px, 320px);
  gap: 16px;
  align-items: start;
}

.kg-pdp-value-grid-wrap {
  position: relative;
}

.kg-pdp-value-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}

.kg-pdp-value-grid__empty {
  padding: 18px;
  border: 1px dashed #d9dee4;
  border-radius: 14px;
  color: #5f6879;
  font-size: 15px;
}

.kg-pdp-value-card {
  position: relative;
  display: grid;
  gap: 10px;
  align-content: start;
  min-height: 248px;
  padding: 18px 14px 16px;
  border: 1px solid #e7ebf0;
  border-radius: 16px;
  background: #fff;
  text-align: center;
  cursor: pointer;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.kg-pdp-related-card[hidden],
.kg-pdp-related-empty[hidden] {
  display: none !important;
}

.kg-pdp-value-card:hover,
.kg-pdp-value-card:focus-visible {
  border-color: #20aa39;
  box-shadow: 0 16px 26px rgba(21, 40, 71, 0.07);
  transform: translateY(-2px);
}

.kg-pdp-value-card.is-selected {
  border-color: #20aa39;
  box-shadow: 0 18px 30px rgba(18, 145, 45, 0.08);
}

.kg-pdp-value-card.is-disabled,
.kg-pdp-value-card:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
  transform: none;
}

.kg-pdp-value-card--link {
  color: inherit;
  text-decoration: none;
}

.kg-pdp-value-card--current {
  cursor: default;
}

.kg-pdp-value-card__badge {
  position: absolute;
  top: -11px;
  left: 50%;
  transform: translateX(-50%);
  padding: 5px 14px;
  border-radius: 999px;
  background: #20aa39;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.kg-pdp-value-card__art {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 126px;
  padding: 6px 0 2px;
}

.kg-pdp-value-card__art img {
  max-width: 92px;
  max-height: 126px;
  width: auto;
  height: auto;
  object-fit: contain;
}

.kg-pdp-value-card__content {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.kg-pdp-value-card__type {
  color: #1f2937;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.kg-pdp-value-card__title {
  color: #171f31;
  font-size: 15px;
  line-height: 1.45;
  font-weight: 600;
}

.kg-pdp-value-card__price,
.kg-pdp-value-card__price .woocommerce-Price-amount {
  color: #20aa39;
  font-size: 17px;
  line-height: 1.3;
  font-weight: 700;
}

.kg-pdp-summary {
  align-self: start;
  position: sticky;
  top: calc(var(--kg-site-header-height) + 12px);
}

.kg-pdp-summary .woocommerce-variation,
.kg-pdp-summary .woocommerce-variation-price,
.kg-pdp-summary .woocommerce-variation-description,
.kg-pdp-summary .woocommerce-variation-availability {
  display: none !important;
}

.kg-pdp-summary-card {
  display: grid;
  gap: 18px;
  padding: 18px;
  border: 1px solid #ebeff3;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(17, 24, 39, 0.05);
}

.kg-pdp-summary-card__section {
  display: grid;
  gap: 12px;
}

.kg-pdp-summary-card__heading span,
.kg-pdp-summary-total span {
  display: block;
  color: #171f31;
  font-size: 16px;
  font-weight: 700;
}

.kg-pdp-summary-card__section + .kg-pdp-summary-card__section {
  padding-top: 18px;
  border-top: 1px solid #eef2f6;
}

.kg-pdp-summary .quantity,
.kg-pdp-summary-card .quantity {
  margin: 0;
}

.kg-pdp-summary .quantity::before,
.kg-pdp-summary-card .quantity::before {
  content: none !important;
}

.kg-pdp-summary .kg-quantity-stepper,
.kg-pdp-summary-card .kg-quantity-stepper {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 42px;
  align-items: center;
  border: 1px solid #dde2e8;
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
}

.kg-pdp-summary .kg-quantity-stepper__button,
.kg-pdp-summary-card .kg-quantity-stepper__button {
  height: 42px;
  border: 0;
  background: #fff;
  color: #495264;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
}

.kg-pdp-summary .kg-quantity-stepper .qty,
.kg-pdp-summary-card .kg-quantity-stepper .qty {
  width: 100%;
  height: 42px;
  border: 0;
  border-left: 1px solid #dde2e8;
  border-right: 1px solid #dde2e8;
  border-radius: 0;
  box-shadow: none;
  color: #111827;
  font-size: 22px;
  font-weight: 600;
  text-align: center;
  appearance: textfield;
  -moz-appearance: textfield;
}

.kg-pdp-summary .kg-quantity-stepper .qty::-webkit-outer-spin-button,
.kg-pdp-summary .kg-quantity-stepper .qty::-webkit-inner-spin-button,
.kg-pdp-summary-card .kg-quantity-stepper .qty::-webkit-outer-spin-button,
.kg-pdp-summary-card .kg-quantity-stepper .qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.kg-pdp-selected-item {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}

.kg-pdp-selected-item__thumb {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 88px;
  padding: 6px;
  border-radius: 12px;
  background: #f4f8fc;
}

.kg-pdp-selected-item__thumb img {
  max-width: 52px;
  max-height: 76px;
  width: auto;
  height: auto;
  object-fit: contain;
}

.kg-pdp-selected-item__title {
  display: block;
  margin-bottom: 4px;
  color: #171f31;
  font-size: 15px;
  line-height: 1.45;
  font-weight: 700;
}

.kg-pdp-selected-item__type {
  display: block;
  color: #5f6879;
  font-size: 14px;
}

.kg-pdp-summary-total {
  display: grid;
  gap: 8px;
  padding-top: 18px;
  border-top: 1px solid #eef2f6;
}

.kg-pdp-summary-total__value,
.kg-pdp-summary-total__value .woocommerce-Price-amount {
  color: #20aa39;
  font-size: 24px;
  line-height: 1.1;
  font-weight: 800;
}

.kg-pdp-summary .single_add_to_cart_button.button.alt,
.kg-pdp-summary-card .single_add_to_cart_button.button.alt {
  width: 100%;
  margin-top: 0;
  padding: 15px 18px;
  border: 1px solid var(--kg-accent, #18a118);
  border-radius: 12px;
  background: var(--kg-accent, #18a118);
  color: var(--kg-accent-text, #fff);
  font-size: 16px;
  font-weight: 700;
  box-shadow: none;
}

.kg-pdp-summary .single_add_to_cart_button.button.alt:hover,
.kg-pdp-summary .single_add_to_cart_button.button.alt:focus-visible,
.kg-pdp-summary-card .single_add_to_cart_button.button.alt:hover,
.kg-pdp-summary-card .single_add_to_cart_button.button.alt:focus-visible {
  background: var(--kg-accent-hover, #138016);
  border-color: var(--kg-accent-hover, #138016);
  color: var(--kg-accent-text, #fff);
}

.kg-pdp-summary .single_add_to_cart_button.disabled,
.kg-pdp-summary .single_add_to_cart_button:disabled,
.kg-pdp-summary-card .single_add_to_cart_button.disabled,
.kg-pdp-summary-card .single_add_to_cart_button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.kg-pdp-security-note {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding-top: 18px;
  border-top: 1px solid #eef2f6;
}

.kg-pdp-security-note strong {
  display: block;
  margin-bottom: 3px;
  color: #171f31;
  font-size: 15px;
  font-weight: 700;
}

.kg-pdp-security-note span {
  color: #5f6879;
  font-size: 14px;
  line-height: 1.5;
}

.kg-pdp-benefits-row {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  padding: 22px 24px;
  border: 1px solid #edf0f3;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 14px 30px rgba(17, 24, 39, 0.03);
}

.kg-pdp-details {
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.45fr);
  align-items: stretch;
  gap: 26px;
  margin: 28px 0;
}

.kg-pdp-description,
.kg-pdp-feature-panel {
  border: 1px solid #edf0f3;
  border-radius: 18px;
  background: #fff;
}

.single-product .kg-pdp-feature-panel {
  display: none !important;
}

.single-product .kg-pdp-details {
  grid-template-columns: 1fr;
}

.kg-pdp-description {
  padding: 28px 24px;
}

.kg-pdp-description h2,
.kg-pdp-faq h2 {
  margin: 0 0 18px;
  color: #171f31;
  font-size: clamp(28px, 2.6vw, 40px);
  line-height: 1.12;
  font-weight: 700;
}

.kg-pdp-description__content p {
  margin: 0 0 14px;
  color: #3d4656;
  font-size: 16px;
  line-height: 1.72;
}

.kg-pdp-description__checks {
  display: grid;
  gap: 12px;
  margin: 22px 0 0;
  padding: 0;
  list-style: none;
}

.kg-pdp-description__checks li {
  position: relative;
  padding-left: 34px;
  color: #1f2937;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 400;
}

.kg-pdp-description__checks li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 4px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: linear-gradient(180deg, #24b540 0%, #15962d 100%);
  box-shadow: inset 0 0 0 5px #fff;
}

.kg-pdp-feature-panel {
  overflow: hidden;
  padding: 0;
  background: linear-gradient(135deg, #0e3a8a 0%, #0a1f54 100%);
  color: #fff;
}

.kg-pdp-feature-panel__content {
  display: grid;
  grid-template-columns: minmax(0, 220px) minmax(0, 1fr);
  align-items: center;
  gap: 18px;
  min-height: 100%;
  padding: 24px 28px;
}

.kg-pdp-feature-panel__eyebrow {
  grid-column: 2;
  margin: 0 0 6px;
  color: rgba(255, 255, 255, 0.82);
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.kg-pdp-feature-panel h3 {
  grid-column: 2;
  margin: 0;
  color: #fff;
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1.05;
  font-weight: 700;
}

.kg-pdp-feature-panel__image {
  grid-column: 1;
  grid-row: 1 / span 2;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 0;
}

.kg-pdp-feature-panel__image img {
  max-width: 220px;
  max-height: 280px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 18px 30px rgba(0, 0, 0, 0.28));
}

.kg-pdp-faq {
  margin-top: 6px;
}

.kg-pdp-faq__items {
  border: 1px solid #edf0f3;
  border-radius: 18px;
  background: #fff;
  overflow: hidden;
}

.kg-pdp-faq__item + .kg-pdp-faq__item {
  border-top: 1px solid #edf0f3;
}

.kg-pdp-faq__item summary {
  position: relative;
  padding: 20px 54px 20px 24px;
  list-style: none;
  cursor: pointer;
  color: #171f31;
  font-size: 19px;
  line-height: 1.4;
  font-weight: 700;
}

.kg-pdp-faq__item summary::-webkit-details-marker {
  display: none;
}

.kg-pdp-faq__item summary::after {
  content: "";
  position: absolute;
  right: 24px;
  top: 50%;
  width: 10px;
  height: 10px;
  border-right: 2px solid #202938;
  border-bottom: 2px solid #202938;
  transform: translateY(-60%) rotate(45deg);
  transition: transform 0.18s ease;
}

.kg-pdp-faq__item[open] summary::after {
  transform: translateY(-35%) rotate(-135deg);
}

.kg-pdp-faq__answer {
  padding: 0 24px 22px;
}

.kg-pdp-faq__answer p {
  margin: 0;
  color: #4e5768;
  font-size: 16px;
  line-height: 1.7;
}

@media (max-width: 1180px) {
  .kg-pdp-hero {
    grid-template-columns: 116px minmax(0, 1fr);
  }

  .kg-pdp-trust-card {
    grid-column: 1 / -1;
    max-width: 360px;
  }

  .kg-pdp-value-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .kg-pdp-benefits-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .kg-pdp-related-shell .related.products ul.products {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}

@media (max-width: 1080px) {
  .kg-pdp-purchase-grid {
    grid-template-columns: minmax(0, 1fr) minmax(250px, 280px);
  }

  .kg-pdp-value-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  .single-product .kg-single-product.kg-pdp {
    width: calc(100% - 28px);
  }

  .kg-pdp-hero,
  .kg-pdp-region-row,
  .kg-pdp-purchase-grid,
  .kg-pdp-details {
    grid-template-columns: 1fr;
  }

  .kg-pdp-hero {
    gap: 22px;
  }

  .kg-pdp-hero__media {
    justify-content: flex-start;
  }

  .kg-pdp-brand-card {
    width: 118px;
  }

  .kg-pdp-hero-benefits {
    grid-template-columns: 1fr;
  }

  .kg-pdp-panel {
    grid-template-columns: 28px minmax(0, 1fr);
  }

  .kg-pdp-panel__control {
    grid-column: 1 / -1;
  }

  .kg-pdp-value-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .kg-pdp-related-shell .related.products ul.products {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .kg-pdp-summary {
    position: static;
  }

  .kg-pdp-feature-panel__content {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .kg-pdp-feature-panel__eyebrow,
  .kg-pdp-feature-panel h3,
  .kg-pdp-feature-panel__image {
    grid-column: 1;
    grid-row: auto;
  }

  .kg-pdp-feature-panel__image {
    order: -1;
  }
}

@media (max-width: 767px) {
  .kg-pdp-title {
    font-size: clamp(30px, 11vw, 42px);
  }

  .kg-pdp-subtitle {
    font-size: 15px;
  }

  .kg-pdp-value-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .kg-pdp-related-shell .related.products ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .kg-pdp-value-card {
    min-height: 220px;
    padding: 16px 12px 14px;
  }

  .kg-pdp-benefits-row {
    grid-template-columns: 1fr;
    padding: 20px 18px;
  }

  .kg-pdp-description,
  .kg-pdp-feature-panel {
    border-radius: 16px;
  }

  .kg-pdp-description {
    padding: 24px 18px;
  }
}

@media (max-width: 520px) {
  .single-product .kg-single-product.kg-pdp {
    width: calc(100% - 18px);
  }

  .kg-pdp-brand-card {
    width: 104px;
    min-height: 128px;
  }

  .kg-pdp-value-grid {
    grid-template-columns: 1fr;
  }

  .kg-pdp-related-shell .related.products ul.products {
    grid-template-columns: 1fr;
  }

  .kg-pdp-faq__item summary,
  .kg-pdp-faq__answer {
    padding-left: 18px;
    padding-right: 18px;
  }

  .kg-pdp-faq__item summary::after {
    right: 18px;
  }
}

/* Reference single product page refinements. */
.single-product .kg-single-product.kg-pdp {
  width: min(1220px, calc(100% - 48px));
  color: #070b22;
}

.single-product .kg-single-product.kg-pdp .kg-product-content-wrap {
  padding-bottom: 48px;
}

.single-product .kg-single-product.kg-pdp .kg-breadcrumb {
  margin: 24px 0 24px;
  color: #111827;
  font-size: 15px;
  line-height: 1.4;
}

.single-product .kg-single-product.kg-pdp .kg-breadcrumb a {
  color: #15803D;
}

.single-product .kg-single-product.kg-pdp .kg-breadcrumb a:hover,
.single-product .kg-single-product.kg-pdp .kg-breadcrumb a:focus-visible {
  color: #0F5F2D;
}

.single-product .kg-single-product.kg-pdp .kg-breadcrumb span:last-child {
  color: #111827;
  font-weight: 700;
}

.kg-pdp-hero {
  grid-template-columns: 132px minmax(0, 1fr) 296px;
  gap: 28px;
  align-items: start;
  margin-bottom: 36px;
}

.kg-pdp-brand-card {
  width: 132px;
  min-height: 146px;
  padding: 0;
  border: 0;
  border-radius: 8px;
  background: transparent;
  box-shadow: none;
  overflow: hidden;
}

.kg-pdp-brand-card .woocommerce-product-gallery,
.kg-pdp-brand-card .images,
.kg-pdp-brand-card .woocommerce-product-gallery__wrapper,
.kg-pdp-brand-card .woocommerce-product-gallery__image,
.kg-pdp-brand-card .woocommerce-product-gallery__image a {
  display: block;
  width: 100% !important;
  min-height: 146px;
  height: 146px;
  margin: 0 !important;
}

.kg-pdp-brand-card .woocommerce-product-gallery__wrapper img,
.kg-pdp-brand-card .woocommerce-product-gallery__image img,
.kg-pdp-brand-card img.wp-post-image {
  width: 100% !important;
  min-width: 100%;
  height: 146px !important;
  min-height: 146px;
  max-width: none;
  max-height: none;
  object-fit: cover !important;
  object-position: center;
  display: block;
  border-radius: 8px;
}

.kg-pdp-hero__copy {
  gap: 14px;
  padding-top: 4px;
}

.kg-pdp-title {
  color: #070b22;
  font-size: 36px;
  line-height: 1.16;
  font-weight: 800;
  letter-spacing: 0;
}

.kg-pdp-subtitle {
  max-width: 680px;
  color: #111827;
  font-size: 15px;
  line-height: 1.6;
}

@media (min-width: 992px) {
  .kg-pdp-subtitle__intro,
  .kg-pdp-subtitle__detail {
    max-width: none;
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
    overflow-wrap: anywhere;
  }
}

@media (min-width: 768px) {
  .kg-pdp-subtitle__detail {
    display: block;
  }
}

.kg-pdp-hero-benefits {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 26px;
  margin-top: 22px;
  max-width: 600px;
}

.kg-pdp-hero-benefit,
.kg-pdp-benefits-row__item {
  grid-template-columns: 30px minmax(0, 1fr);
  gap: 11px;
}

.kg-pdp-icon {
  width: 30px;
  height: 30px;
  color: #00a82d;
}

.kg-pdp-hero__copy .kg-pdp-hero-benefit:first-child .kg-pdp-icon {
  color: #f3c21a;
}

.kg-pdp-hero-benefit__copy strong,
.kg-pdp-benefits-row__copy strong {
  margin-bottom: 2px;
  color: #070b22;
  font-size: 15px;
  line-height: 1.3;
  font-weight: 800;
}

.kg-pdp-hero-benefit__copy span,
.kg-pdp-benefits-row__copy span {
  color: #3f4656;
  font-size: 13px;
  line-height: 1.45;
}

.kg-pdp-trust-card {
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 14px;
  margin-top: 4px;
  padding: 25px 22px;
  border-color: #eceff3;
  border-radius: 8px;
  box-shadow: 0 12px 30px rgba(17, 24, 39, 0.05);
}

.kg-pdp-trust-card__shield {
  color: #00a82d;
}

.kg-pdp-trust-card__content strong {
  margin-bottom: 12px;
  color: #070b22;
  font-size: 16px;
  line-height: 1.35;
  font-weight: 800;
}

.kg-pdp-trust-card__rating {
  gap: 14px;
  color: #111827;
  font-size: 15px;
  font-weight: 600;
}

.kg-pdp-stars {
  font-size: 0.92rem;
}

.kg-pdp-purchase-shell {
  margin-bottom: 32px;
}

.kg-pdp-form,
.kg-pdp-form__layout,
.kg-pdp-form__main {
  gap: 18px;
}

.kg-pdp-region-row {
  grid-template-columns: minmax(0, 1fr) minmax(360px, 1fr);
  gap: 18px;
}

.kg-pdp-panel {
  min-height: 80px;
  grid-template-columns: 34px minmax(0, 1fr) minmax(190px, 284px);
  gap: 14px;
  padding: 16px 18px;
  border-color: #edf0f4;
  border-radius: 8px;
  box-shadow: 0 8px 22px rgba(17, 24, 39, 0.025);
}

.kg-pdp-panel__icon,
.kg-pdp-note-panel__icon,
.kg-pdp-security-note__icon {
  width: 30px;
  height: 30px;
}

.kg-pdp-panel__copy strong,
.kg-pdp-note-panel__copy strong {
  margin-bottom: 4px;
  color: #070b22;
  font-size: 15px;
  line-height: 1.3;
  font-weight: 800;
}

.kg-pdp-panel__copy span,
.kg-pdp-note-panel__copy p {
  color: #3f4656;
  font-size: 13px;
  line-height: 1.5;
}

.kg-pdp-note-panel {
  grid-template-columns: 48px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  padding: 18px 20px;
  border-color: #f4e4bb;
  border-radius: 18px;
  background: linear-gradient(180deg, #fffaf1 0%, #fff8ee 100%);
  box-shadow: 0 6px 16px rgba(214, 161, 34, 0.08);
}

.kg-pdp-note-panel__icon {
  width: 44px;
  height: 44px;
  color: #ffbf1f;
}

.kg-pdp-note-panel__copy {
  gap: 4px;
}

.kg-pdp-note-panel__copy strong {
  display: inline;
  margin: 0;
  color: #111111;
  font-size: inherit;
  line-height: inherit;
  font-weight: 700;
}

.kg-pdp-note-panel__copy p {
  color: #111111;
  font-size: 16px;
  line-height: 1.42;
}

.kg-pdp-select,
.kg-pdp-panel__control select,
.kg-pdp-extra-options select {
  height: 48px;
  padding-left: 14px;
  border-color: #e6e9ef;
  border-radius: 6px;
  color: #070b22;
  font-size: 15px;
  font-weight: 700;
}

.kg-pdp-region-panel .kg-pdp-select,
.kg-pdp-region-panel select {
  border-radius: 12px;
}

.kg-pdp-purchase-grid {
  grid-template-columns: minmax(0, 1fr) 284px;
  gap: 16px;
}

.kg-pdp-purchase-grid.kg-pdp-purchase-grid--related-only {
  grid-template-columns: minmax(0, 1fr);
}

.kg-pdp-value-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.kg-pdp-value-card {
  min-height: 246px;
  gap: 9px;
  padding: 20px 14px 18px;
  border-color: #e9edf2;
  border-radius: 8px;
  box-shadow: 0 10px 24px rgba(17, 24, 39, 0.03);
}

.kg-pdp-value-card:hover,
.kg-pdp-value-card:focus-visible {
  border-color: #00a82d;
  box-shadow: 0 12px 26px rgba(0, 168, 45, 0.09);
  transform: none;
}

.kg-pdp-value-card.is-selected {
  border-color: #00a82d;
  box-shadow: 0 0 0 1px rgba(0, 168, 45, 0.18), 0 16px 30px rgba(0, 168, 45, 0.08);
}

.kg-pdp-value-card__badge {
  top: -8px;
  right: auto;
  left: 50%;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transform: translateX(-50%);
  padding: 5px 10px;
  border-radius: 999px;
  background: #009d22;
  font-size: 9px;
  line-height: 1;
  letter-spacing: 0;
}

.kg-pdp-value-card__badge::before {
  content: "★";
  color: #ffc21a;
  font-size: 11px;
  line-height: 1;
}

.kg-pdp-value-card__art {
  min-height: 130px;
  padding: 0;
}

.kg-pdp-value-card__art img {
  max-width: 106px;
  max-height: 134px;
}

.kg-pdp-value-card__type {
  display: none;
}

.kg-pdp-value-card__title {
  color: #070b22;
  font-size: 14px;
  line-height: 1.35;
  font-weight: 700;
}

.kg-pdp-value-card__price,
.kg-pdp-value-card__price .woocommerce-Price-amount {
  color: #009d22;
  font-size: 18px;
  line-height: 1.25;
  font-weight: 800;
}

@media (min-width: 992px) {
  body.single-product .kg-pdp-purchase-grid.kg-pdp-purchase-grid--related-only {
    grid-template-columns: minmax(0, 1fr) minmax(260px, 284px);
  }

  body.single-product .kg-pdp-purchase-grid.kg-pdp-purchase-grid--related-only .kg-pdp-value-grid-wrap {
    grid-column: 1;
  }

  body.single-product .kg-pdp-value-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    align-items: stretch;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: auto 1fr;
    align-items: stretch;
    align-content: start;
    gap: 12px;
    min-height: 0;
    height: 100%;
    padding: 14px 14px 18px;
    border: 1px solid #edf0f4;
    border-radius: 8px;
    background: #fff;
    text-align: center;
    box-shadow: 0 8px 20px rgba(17, 24, 39, 0.045);
    overflow: visible;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card:hover,
  body.single-product .kg-pdp-value-grid .kg-pdp-value-card:focus-visible {
    border-color: #14a638;
    box-shadow: 0 12px 28px rgba(20, 166, 56, 0.12);
    transform: none;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card.is-selected {
    border-color: #12a536;
    background: #f6fbf7;
    box-shadow: 0 0 0 1px #12a536, 0 14px 30px rgba(18, 165, 54, 0.13);
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card--no-price .kg-pdp-value-card__price {
    min-height: 23px;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card__badge {
    top: -12px;
    right: auto;
    left: 18px;
    gap: 5px;
    transform: none;
    padding: 6px 12px;
    border-radius: 999px;
    background: #13a538;
    color: #fff;
    font-size: 11px;
    line-height: 1;
    font-weight: 800;
    letter-spacing: 0;
    box-shadow: 0 7px 16px rgba(19, 165, 56, 0.2);
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card__badge::before {
    color: #fff;
    font-size: 12px;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card__art {
    display: block;
    width: 100%;
    min-height: 0;
    padding: 0;
    border: 1px solid #eef1f4;
    border-radius: 8px;
    overflow: hidden;
    background: #fff;
    box-shadow: none;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card__art picture {
    display: block;
    width: 100%;
    aspect-ratio: 1.12 / 1;
    height: auto;
    min-height: 0;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card__art img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 1.12 / 1;
    max-width: none;
    max-height: none;
    border-radius: 8px 8px 0 0;
    object-fit: cover;
    object-position: center;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card__art::after {
    content: "DIGITAL CODE";
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    padding: 0 8px;
    color: #08a730;
    background: #fff;
    font-size: 11px;
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card__art picture img {
    height: 100%;
    aspect-ratio: auto;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card__content {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 0;
    gap: 8px;
    padding: 0 2px;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card__type {
    display: none;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card__title {
    margin: 0;
    color: #070b22;
    font-size: 14px;
    line-height: 1.32;
    font-family: Inter, Arial, sans-serif;
    font-weight: 700;
    letter-spacing: 0;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card__title.kg-pdp-value-card__title--single-line {
    margin-bottom: 0;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card__price {
    display: block;
    margin: 0;
    min-height: 1.2em;
  }

  body.single-product .kg-pdp-value-grid .kg-pdp-value-card__price,
  body.single-product .kg-pdp-value-grid .kg-pdp-value-card__price .woocommerce-Price-amount {
    color: #08a730;
    font-size: 19px;
    line-height: 1.2;
    font-family: Inter, Arial, sans-serif;
    font-weight: 800;
    letter-spacing: 0;
  }
}

.kg-pdp-summary {
  top: calc(var(--kg-site-header-height) + 12px);
  z-index: 20;
}

.kg-pdp-summary--viewport-sticky {
  z-index: 50;
}

.kg-pdp-summary-card {
  gap: 20px;
  padding: 20px 18px;
  border-color: #eceff3;
  border-radius: 8px;
  box-shadow: 0 14px 30px rgba(17, 24, 39, 0.06);
}

.kg-pdp-summary-card__section:first-child {
  grid-template-columns: minmax(0, 1fr) 124px;
  align-items: center;
}

.kg-pdp-summary-card__heading span,
.kg-pdp-summary-total span {
  color: #070b22;
  font-size: 16px;
  font-weight: 800;
}

.kg-pdp-summary-card__section + .kg-pdp-summary-card__section {
  padding-top: 18px;
  border-top-color: #edf0f4;
}

.kg-pdp-summary .kg-quantity-stepper,
.kg-pdp-summary-card .kg-quantity-stepper {
  grid-template-columns: 36px 52px 36px;
  border-color: #e7ebf0;
  border-radius: 6px;
}

.kg-pdp-summary .kg-quantity-stepper__button,
.kg-pdp-summary-card .kg-quantity-stepper__button,
.kg-pdp-summary .kg-quantity-stepper .qty,
.kg-pdp-summary-card .kg-quantity-stepper .qty {
  height: 36px;
}

.kg-pdp-summary .kg-quantity-stepper__button,
.kg-pdp-summary-card .kg-quantity-stepper__button {
  color: #070b22;
  font-size: 20px;
}

.kg-pdp-summary .kg-quantity-stepper .qty,
.kg-pdp-summary-card .kg-quantity-stepper .qty {
  font-size: 16px;
  font-weight: 700;
}

.kg-pdp-selected-item {
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 14px;
}

.kg-pdp-selected-item__thumb {
  min-height: 84px;
  padding: 0;
  border-radius: 6px;
  background: transparent;
}

.kg-pdp-selected-item__thumb img {
  max-width: 56px;
  max-height: 84px;
}

.kg-pdp-selected-item__title {
  color: #070b22;
  font-size: 15px;
  line-height: 1.45;
  font-weight: 800;
}

.kg-pdp-selected-item__type {
  color: #111827;
  font-size: 15px;
}

.kg-pdp-summary-total {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding-top: 18px;
  border-top-color: #edf0f4;
}

.kg-pdp-summary-total__value,
.kg-pdp-summary-total__value .woocommerce-Price-amount {
  color: #009d22;
  font-size: 28px;
  font-weight: 900;
}

.kg-pdp-summary .single_add_to_cart_button.button.alt,
.kg-pdp-summary-card .single_add_to_cart_button.button.alt {
  min-height: 54px;
  padding: 15px 18px;
  border-color: #009d22;
  border-radius: 6px;
  background: #009d22;
  font-size: 18px;
  font-weight: 800;
}

.kg-pdp-summary .single_add_to_cart_button.button.alt:hover,
.kg-pdp-summary .single_add_to_cart_button.button.alt:focus-visible,
.kg-pdp-summary-card .single_add_to_cart_button.button.alt:hover,
.kg-pdp-summary-card .single_add_to_cart_button.button.alt:focus-visible {
  border-color: #00831e;
  background: #00831e;
}

.kg-pdp-security-note {
  grid-template-columns: 28px minmax(0, 1fr);
  padding-top: 18px;
  border-top-color: #edf0f4;
}

.kg-pdp-security-note strong {
  color: #070b22;
  font-size: 15px;
  font-weight: 800;
}

.kg-pdp-security-note span {
  color: #3f4656;
  font-size: 13px;
}

.kg-pdp-benefits-row {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin-bottom: 30px;
  padding: 22px 26px;
  border-color: #edf0f4;
  border-radius: 8px;
  box-shadow: 0 12px 26px rgba(17, 24, 39, 0.035);
  display: none;
}

.kg-pdp-details {
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.45fr);
  gap: 28px;
  margin: 0 0 24px;
}

.kg-pdp-description,
.kg-pdp-feature-panel {
  border-color: #edf0f4;
  border-radius: 8px;
}

.kg-pdp-description {
  padding: 26px 24px;
}

.kg-pdp-description h2,
.kg-pdp-faq h2 {
  margin-bottom: 16px;
  color: #070b22;
  font-size: 24px;
  line-height: 1.2;
  font-weight: 800;
  letter-spacing: 0;
}

.kg-pdp-description h2 {
  font-weight: 500;
}

.kg-pdp-faq h2 {
  font-weight: 500;
}

.kg-pdp-description h2::after,
.kg-pdp-faq h2::after {
  content: "";
  display: block;
  width: 54px;
  height: 2px;
  margin-top: 8px;
  background: #009d22;
}

.kg-pdp-description__content p {
  margin-bottom: 11px;
  color: #111827;
  font-size: 14px;
  line-height: 1.65;
}

.kg-pdp-description__checks {
  gap: 9px;
  margin-top: 18px;
}

.kg-pdp-description__checks li {
  padding-left: 28px;
  color: #070b22;
  font-size: 14px;
  line-height: 1.45;
  font-weight: 400;
}

.kg-pdp-description__checks li::before {
  top: 1px;
  width: 17px;
  height: 17px;
  background: #009d22;
  box-shadow: none;
}

.kg-pdp-description__checks li::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 5px;
  width: 6px;
  height: 3px;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(-45deg);
}

.kg-pdp-feature-panel {
  min-height: 292px;
  background: radial-gradient(circle at 20% 20%, #1056b5 0%, #063789 35%, #061b50 100%);
}

.kg-pdp-feature-panel__content {
  grid-template-columns: minmax(170px, 0.8fr) minmax(260px, 1fr);
  gap: 30px;
  min-height: 292px;
  padding: 24px 28px;
}

.kg-pdp-feature-panel__image {
  grid-column: 1;
  grid-row: 1;
}

.kg-pdp-feature-panel__image img {
  max-width: 210px;
  max-height: 230px;
}

.kg-pdp-feature-panel__copy {
  display: grid;
  gap: 14px;
  align-content: center;
}

.kg-pdp-feature-panel h3 {
  grid-column: auto;
  color: #fff;
  font-size: 36px;
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: 0;
}

.kg-pdp-feature-panel__icons {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.kg-pdp-feature-panel__icons span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 6px;
  background: rgba(1, 14, 51, 0.65);
  color: #fff;
}

.kg-pdp-feature-panel__icons svg {
  width: 22px;
  height: 22px;
  fill: currentColor;
}

.kg-pdp-feature-panel__icons span:nth-child(2) {
  color: #f5c418;
}

.kg-pdp-feature-panel__tiles {
  display: grid;
  grid-template-columns: repeat(4, minmax(54px, 1fr));
  gap: 8px;
  max-width: 360px;
}

.kg-pdp-feature-panel__tile {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 76px;
  aspect-ratio: 4 / 5;
  border-radius: 6px;
  background: rgba(1, 14, 51, 0.58);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.18);
  overflow: hidden;
  text-decoration: none;
}

.kg-pdp-feature-panel__tile img {
  display: block;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
}

.kg-pdp-faq {
  margin-top: 0;
}

.kg-pdp-faq__items {
  border-color: #edf0f4;
  border-radius: 8px;
}

.kg-pdp-faq__item + .kg-pdp-faq__item {
  border-top-color: #edf0f4;
}

.kg-pdp-faq__item summary {
  display: grid;
  grid-template-columns: 26px minmax(0, 1fr);
  gap: 8px;
  padding: 14px 52px 2px 22px;
  color: #070b22;
  font-size: 14px;
  line-height: 1.35;
  font-weight: 400;
  letter-spacing: 0;
}

.kg-pdp-faq__item summary::after {
  right: 24px;
  width: 8px;
  height: 8px;
  border-color: #070b22;
  transform: translateY(-40%) rotate(45deg);
}

.kg-pdp-faq__item[open] summary::after {
  transform: translateY(-40%) rotate(45deg);
}

.kg-pdp-faq__answer {
  display: grid;
  grid-template-columns: 26px minmax(0, 1fr);
  gap: 8px;
  padding: 2px 52px 14px 22px;
  color: #111827;
  font-size: 13px;
  line-height: 1.45;
}

.kg-pdp-faq__answer p {
  color: inherit;
  font-size: inherit;
  line-height: inherit;
}

.kg-pdp-faq__prefix {
  color: #009d22;
  font-weight: 900;
}

@media (max-width: 1180px) {
  .kg-pdp-hero {
    grid-template-columns: 132px minmax(0, 1fr);
  }

  .kg-pdp-trust-card {
    grid-column: 1 / -1;
    max-width: 300px;
  }

  .kg-pdp-region-row {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 1fr);
  }
}

@media (max-width: 1080px) {
  .kg-pdp-purchase-grid {
    grid-template-columns: minmax(0, 1fr) 260px;
  }

  .kg-pdp-value-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  .single-product .kg-single-product.kg-pdp {
    width: calc(100% - 28px);
  }

  .kg-pdp-hero,
  .kg-pdp-region-row,
  .kg-pdp-purchase-grid,
  .kg-pdp-details {
    grid-template-columns: 1fr;
  }

  .kg-pdp-title {
    font-size: 32px;
  }

  .kg-pdp-hero-benefits {
    grid-template-columns: 1fr;
    max-width: none;
  }

  .kg-pdp-panel {
    grid-template-columns: 30px minmax(0, 1fr);
  }

  .kg-pdp-summary {
    position: static !important;
    width: auto !important;
    left: auto !important;
    top: auto !important;
  }

  .kg-pdp-benefits-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .single-product .kg-single-product.kg-pdp {
    width: calc(100% - 20px);
  }

  .kg-pdp-brand-card {
    width: 112px;
    min-height: 124px;
  }

  .kg-pdp-brand-card .woocommerce-product-gallery,
  .kg-pdp-brand-card .images,
  .kg-pdp-brand-card .woocommerce-product-gallery__wrapper,
  .kg-pdp-brand-card .woocommerce-product-gallery__image,
  .kg-pdp-brand-card .woocommerce-product-gallery__image a {
    min-height: 124px;
    height: 124px;
  }

  .kg-pdp-brand-card .woocommerce-product-gallery__wrapper img,
  .kg-pdp-brand-card .woocommerce-product-gallery__image img,
  .kg-pdp-brand-card img.wp-post-image {
    height: 124px !important;
    min-height: 124px;
  }

  .kg-pdp-value-grid,
  .kg-pdp-benefits-row {
    grid-template-columns: 1fr;
  }

  .kg-pdp-value-card {
    min-height: 220px;
  }

  .kg-pdp-summary-card__section:first-child {
    grid-template-columns: 1fr;
  }

  .kg-pdp-feature-panel__content {
    grid-template-columns: 1fr;
    gap: 18px;
    text-align: center;
  }

  .kg-pdp-feature-panel__icons,
  .kg-pdp-feature-panel__tiles {
    justify-content: center;
    margin-inline: auto;
  }

  .kg-pdp-feature-panel h3 {
    font-size: 30px;
  }
}

/* WooCommerce category reference layout */
body.tax-product_cat {
  background: #ffffff;
}

.kg-cat-ref-page {
  --kg-cat-accent: #16a34a;
  --kg-cat-soft: color-mix(in srgb, var(--kg-cat-accent) 7%, #ffffff);
  --kg-cat-soft-strong: color-mix(in srgb, var(--kg-cat-accent) 14%, #ffffff);
  padding: 30px 0 72px;
  background: #ffffff;
  color: #111827;
}

.kg-cat-ref-page a {
  text-decoration: none;
}

.kg-cat-ref-container {
  width: min(1184px, calc(100% - 56px));
  margin: 0 auto;
}

.kg-cat-ref-breadcrumbs {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  margin: 0 0 34px;
  color: #111827;
  font-size: 18px;
  line-height: 1.2;
  font-weight: 500;
}

.kg-cat-ref-breadcrumbs a {
  color: #15803D;
}

.kg-cat-ref-breadcrumbs strong {
  color: #111827;
  font-weight: 800;
}

.kg-cat-ref-breadcrumbs span {
  width: 8px;
  height: 8px;
  border-right: 2px solid #9ca3af;
  border-bottom: 2px solid #9ca3af;
  transform: rotate(-45deg);
}

.kg-cat-ref-hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: 560px;
  border-radius: 14px;
  background:
    radial-gradient(circle at 20% 10%, rgba(255, 255, 255, 0.82), transparent 32%),
    linear-gradient(110deg, #fbfefb 0%, var(--kg-cat-soft) 55%, var(--kg-cat-soft-strong) 100%);
  display: grid;
  grid-template-columns: 164px 274px minmax(0, 1fr);
  align-items: center;
  gap: 34px;
  padding: 56px 62px 54px;
  box-shadow: inset 0 0 0 1px rgba(22, 163, 74, 0.06);
}

.kg-cat-ref-hero::before,
.kg-cat-ref-hero::after {
  content: "";
  position: absolute;
  width: 70px;
  height: 2px;
  border-radius: 999px;
  background: var(--kg-cat-accent);
  opacity: 0.9;
  transform: rotate(-33deg);
}

.kg-cat-ref-hero::before {
  right: 43.4%;
  top: 150px;
  box-shadow: 28px 42px 0 var(--kg-cat-accent);
}

.kg-cat-ref-hero::after {
  right: 100px;
  top: 234px;
  box-shadow: -62px 58px 0 var(--kg-cat-accent);
}

.kg-cat-ref-hero__watermark {
  position: absolute;
  left: 128px;
  top: 34px;
  z-index: -1;
  width: 365px;
  height: 365px;
  object-fit: contain;
  opacity: 0.035;
  filter: grayscale(1);
  transform: rotate(-8deg);
  pointer-events: none;
}

.kg-cat-ref-hero__brand-card {
  position: relative;
  z-index: 1;
  width: 164px;
  height: 206px;
  border-radius: 12px;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  box-shadow: 0 16px 32px rgba(11, 88, 30, 0.13);
}

.kg-cat-ref-hero__brand-card img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.kg-cat-ref-hero__brand-card span {
  color: #ffffff;
  font-size: 46px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: 0;
}

.kg-cat-ref-hero__copy {
  position: relative;
  z-index: 1;
  align-self: center;
}

.kg-cat-ref-hero__copy h1 {
  margin: 0 0 18px;
  color: #0f172a;
  font-size: 46px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: 0;
}

.kg-cat-ref-hero__copy p {
  max-width: 260px;
  margin: 0;
  color: #20293a;
  font-size: 20px;
  line-height: 1.52;
  font-weight: 500;
}

.kg-cat-ref-hero__stage {
  position: relative;
  z-index: 1;
  min-height: 430px;
}

.kg-cat-ref-trust {
  position: absolute;
  top: -32px;
  right: -30px;
  z-index: 3;
  min-width: 294px;
  min-height: 88px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(15, 23, 42, 0.06);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
}

.kg-cat-ref-trust__icon {
  position: relative;
  width: 34px;
  height: 40px;
  display: inline-block;
}

.kg-cat-ref-trust__icon::before {
  content: "";
  position: absolute;
  inset: 0;
  clip-path: polygon(50% 0, 92% 16%, 86% 70%, 50% 100%, 14% 70%, 8% 16%);
  background: var(--kg-cat-accent);
}

.kg-cat-ref-trust__icon::after {
  content: "";
  position: absolute;
  left: 10px;
  top: 14px;
  width: 14px;
  height: 8px;
  border-left: 4px solid #ffffff;
  border-bottom: 4px solid #ffffff;
  transform: rotate(-45deg);
}

.kg-cat-ref-trust__copy {
  display: grid;
  gap: 10px;
}

.kg-cat-ref-trust strong {
  color: #111827;
  font-size: 14px;
  line-height: 1.2;
  font-weight: 700;
}

.kg-cat-ref-trust__rating {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  flex-wrap: wrap;
  color: #4b5563;
  font-size: 15px;
  font-weight: 700;
}

.kg-cat-ref-trust__stars {
  font-size: 0.92rem;
}

.kg-cat-ref-hero__product {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 1;
  display: block;
  width: min(520px, 94%);
  height: 390px;
  object-fit: contain;
  filter: drop-shadow(0 22px 26px rgba(15, 23, 42, 0.18));
}

.kg-cat-ref-related {
  margin-top: 64px;
}

.kg-cat-ref-related__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin: 0 26px 34px;
}

.kg-cat-ref-related__header h2 {
  margin: 0;
  color: #111827;
  font-size: 31px;
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: 0;
}

.kg-cat-ref-related__header a {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--kg-cat-accent);
  font-size: 16px;
  font-weight: 800;
  white-space: nowrap;
}

.kg-cat-ref-related__header a span,
.kg-cat-ref-card__arrow::before {
  width: 14px;
  height: 14px;
  border-top: 3px solid currentColor;
  border-right: 3px solid currentColor;
  transform: rotate(45deg);
}

.kg-cat-ref-related__header a span {
  content: "";
  display: inline-block;
}

.kg-cat-ref-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 34px;
  padding: 0 26px;
}

.kg-cat-ref-card {
  --kg-cat-card-radius: 12px;
  overflow: hidden;
  border-radius: var(--kg-cat-card-radius);
  border: 1px solid #edf0f2;
  box-shadow: 0 5px 16px rgba(15, 23, 42, 0.07);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.kg-cat-ref-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.1);
}

.kg-cat-ref-card a {
  position: relative;
  display: flex;
  align-items: flex-end;
  min-height: 100%;
  height: 418px;
  border-radius: inherit;
  color: inherit;
}

.kg-cat-ref-card__media {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    radial-gradient(circle at 45% 34%, rgba(255, 255, 255, 0.68), transparent 28%),
    linear-gradient(180deg, #f8fdf8, var(--kg-cat-soft));
  overflow: hidden;
}

.kg-cat-ref-card__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.kg-cat-ref-card__media span {
  width: 100%;
  height: 100%;
  background: var(--kg-cat-accent);
  background: linear-gradient(180deg, color-mix(in srgb, var(--kg-cat-accent) 90%, #ffffff), #078e21);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 42px;
  font-weight: 800;
  letter-spacing: 0;
}

.kg-cat-ref-card__body {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 48px;
  align-items: center;
  gap: 18px;
  width: 100%;
  min-height: 104px;
  padding: 20px 20px 22px;
  border-radius: var(--kg-cat-card-radius);
  background: #ffffff;
}

.kg-cat-ref-card h3 {
  margin: 0 0 12px;
  color: #111827;
  font-size: 20px;
  line-height: 1.2;
  font-weight: 800;
  letter-spacing: 0;
}

.kg-cat-ref-card p {
  margin: 0;
  color: var(--kg-cat-accent);
  font-size: 16px;
  line-height: 1.2;
  font-weight: 800;
}

.kg-cat-ref-card__arrow {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid #e5e7eb;
  color: var(--kg-cat-accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: end;
}

.kg-cat-ref-card__arrow::before {
  content: "";
  display: block;
  margin-left: -4px;
}

.kg-cat-ref-empty {
  margin: 0 26px;
  padding: 22px;
  border: 1px dashed #d1d5db;
  border-radius: 8px;
  color: #4b5563;
  background: #f9fafb;
  font-size: 16px;
}

.kg-cat-ref-browser .kg-cat-ref-related__header {
  margin-bottom: 16px;
}

.kg-cat-ref-browser__current {
  margin: 0 26px 18px;
  color: #0f172a;
  font-size: 42px;
  line-height: 1.05;
  font-weight: 800;
  letter-spacing: 0;
}

.kg-cat-ref-filter-nav {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  margin: 0 0 24px;
  padding: 0 26px;
}

.kg-cat-ref-filter {
  --kg-cat-filter-color: var(--kg-cat-accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  padding: 0 16px;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  background: #ffffff;
  color: #111827;
  font: inherit;
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.04);
  cursor: pointer;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.kg-cat-ref-filter:hover,
.kg-cat-ref-filter:focus-visible {
  border-color: color-mix(in srgb, var(--kg-cat-filter-color) 52%, #d1d5db);
  color: var(--kg-cat-filter-color);
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.08);
}

.kg-cat-ref-filter:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--kg-cat-filter-color) 22%, transparent);
  outline-offset: 3px;
}

.kg-cat-ref-filter.is-active {
  border-color: color-mix(in srgb, var(--kg-cat-filter-color) 58%, #d1d5db);
  color: var(--kg-cat-filter-color);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--kg-cat-filter-color) 18%, transparent), 0 8px 18px rgba(15, 23, 42, 0.07);
}

.kg-cat-ref-filter__icon {
  flex: 0 0 20px;
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.kg-cat-ref-filter__icon img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.kg-cat-ref-filter__icon--mark {
  border-radius: 999px;
  background: color-mix(in srgb, var(--kg-cat-filter-color) 13%, #ffffff);
  color: var(--kg-cat-filter-color);
  font-size: 8px;
  font-weight: 900;
  letter-spacing: 0;
}

.kg-cat-ref-filter__label {
  min-width: 0;
}

.kg-cat-ref-products {
  position: relative;
}

.kg-cat-ref-products-panel[hidden] {
  display: none;
}

.kg-cat-ref-products-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 16px;
  padding: 0 26px;
}

.kg-cat-ref-products-grid .kg-product-loop__item {
  display: flex;
}

.kg-cat-ref-products-grid .product-card {
  --kg-product-card-radius: 8px;
  --kg-product-card-media-radius: 8px;
  height: 100%;
  width: 100%;
  border-color: #edf0f2;
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.06);
}

.kg-cat-ref-products-grid .product-card:hover {
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.1);
}

.kg-cat-ref-products-grid .product-card__media {
  aspect-ratio: 1 / 1.1;
  border-radius: 8px 8px 0 0;
  clip-path: inset(0 round 8px 8px 0 0);
}

.kg-cat-ref-products-grid .product-card__body {
  justify-content: center;
  min-height: 78px;
  padding: 14px 14px 0;
}

.kg-cat-ref-products-grid .product-card__title {
  min-height: 0;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
}

.kg-cat-ref-products-grid .product-card__title a {
  color: #111827;
}

.kg-cat-ref-products-grid .product-card__description,
.kg-cat-ref-products-grid .product-card__trust-badges,
.kg-cat-ref-products-grid .product-card__button {
  display: none;
}

@media (max-width: 1180px) {
  .kg-cat-ref-hero {
    grid-template-columns: 150px minmax(220px, 0.7fr) minmax(340px, 1fr);
    padding: 44px;
  }

  .kg-cat-ref-hero__brand-card {
    width: 146px;
    height: 184px;
  }

  .kg-cat-ref-trust {
    right: -10px;
  }

  .kg-cat-ref-grid {
    gap: 22px;
  }

  .kg-cat-ref-products-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .kg-cat-ref-hero {
    grid-template-columns: 130px minmax(0, 1fr);
    min-height: auto;
  }

  .kg-cat-ref-hero__brand-card {
    width: 128px;
    height: 128px;
  }

  .kg-cat-ref-hero__stage {
    grid-column: 1 / -1;
    min-height: 340px;
  }

  .kg-cat-ref-trust {
    top: 0;
    right: 0;
  }

  .kg-cat-ref-hero__product {
    right: 50%;
    bottom: 8px;
    width: min(520px, 90%);
    transform: translateX(50%);
  }

  .kg-cat-ref-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .kg-cat-ref-products-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .kg-cat-ref-page {
    padding: 18px 0 46px;
  }

  .kg-cat-ref-container {
    width: min(100%, calc(100% - 24px));
  }

  .kg-cat-ref-breadcrumbs {
    margin-bottom: 18px;
    font-size: 14px;
  }

  .kg-cat-ref-hero {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 28px;
    border-radius: 12px;
  }

  .kg-cat-ref-hero::before,
  .kg-cat-ref-hero::after {
    display: none;
  }

  .kg-cat-ref-hero__brand-card {
    width: 118px;
    height: 118px;
  }

  .kg-cat-ref-hero__copy h1 {
    font-size: 36px;
  }

  .kg-cat-ref-hero__copy p {
    max-width: none;
    font-size: 17px;
  }

  .kg-cat-ref-hero__stage {
    min-height: 310px;
  }

  .kg-cat-ref-trust {
    position: relative;
    top: auto;
    right: auto;
    min-width: 0;
    width: 100%;
    margin-bottom: 18px;
  }

  .kg-cat-ref-hero__product {
    right: 50%;
    width: min(100%, 430px);
    height: 210px;
    transform: translateX(50%);
  }

  .kg-cat-ref-related {
    margin-top: 42px;
  }

  .kg-cat-ref-related__header {
    margin-inline: 0;
  }

  .kg-cat-ref-browser__current {
    margin-inline: 0;
    font-size: 34px;
  }

  .kg-cat-ref-filter-nav {
    gap: 10px;
    padding: 0;
  }

  .kg-cat-ref-grid {
    grid-template-columns: 1fr;
    padding: 0;
  }

  .kg-cat-ref-products-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    padding: 0;
  }

  .kg-cat-ref-card a {
    height: 364px;
  }

  .kg-cat-ref-empty {
    margin-inline: 0;
  }
}

@media (max-width: 520px) {
  .kg-cat-ref-hero {
    padding: 22px;
  }

  .kg-cat-ref-related__header {
    align-items: flex-start;
    flex-direction: column;
    gap: 12px;
  }

  .kg-cat-ref-related__header h2 {
    font-size: 26px;
  }

  .kg-cat-ref-browser__current {
    font-size: 30px;
  }

  .kg-cat-ref-filter {
    min-height: 38px;
    padding: 0 12px;
    font-size: 13px;
  }

  .kg-cat-ref-card__body {
    grid-template-columns: minmax(0, 1fr) 42px;
  }

  .kg-cat-ref-card h3 {
    font-size: 18px;
  }
}

@media (min-width: 992px) {
  .kg-category-container,
  .kg-category-header__inner,
  .kg-category-header__nav-inner,
  .kg-category-footer__trust-inner,
  .kg-category-footer__help-inner,
  .kg-category-footer__legal-inner,
  .kg-cat-v2-container,
  .kg-cat-ref-container,
  .woocommerce-account .container,
  .single-product .kg-single-product,
  .single-product .kg-single-product.kg-pdp {
    width: min(var(--kg-layout-max), calc(100% - var(--kg-layout-gutter)));
  }

  .kg-cat-ref-related__header {
    margin-left: 0;
    margin-right: 0;
  }

  .kg-cat-ref-grid {
    padding-left: 0;
    padding-right: 0;
  }

  .kg-cat-ref-browser__current,
  .kg-cat-ref-filter-nav,
  .kg-cat-ref-products-grid {
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
    padding-right: 0;
  }
}

/* Mobile single product reference layout. */
@media (max-width: 767px) {
  body.single-product {
    background: #fff;
    padding-bottom: calc(104px + env(safe-area-inset-bottom, 0px));
  }

  .single-product .kg-single-product.kg-pdp {
    width: min(100% - 32px, 640px);
  }

  .single-product .kg-single-product.kg-pdp .kg-product-content-wrap {
    padding-bottom: 28px;
  }

  .single-product .kg-single-product.kg-pdp .kg-breadcrumb {
    gap: 12px;
    margin: 18px 0 24px;
    color: #111827;
    font-size: 14px;
    line-height: 1.25;
    font-weight: 600;
  }

  .single-product .kg-single-product.kg-pdp .kg-breadcrumb a {
    color: #176b21;
    font-weight: 500;
  }

  .single-product .kg-single-product.kg-pdp .kg-breadcrumb span:first-of-type {
    color: #8f98a8;
    font-size: 28px;
    line-height: 0.75;
    font-weight: 400;
  }

  .single-product .kg-single-product.kg-pdp .kg-breadcrumb span:last-child {
    color: #111827;
    font-weight: 700;
  }

  .kg-pdp-hero {
    grid-template-columns: minmax(116px, 37%) minmax(0, 1fr);
    gap: 10px 18px;
    align-items: center;
    margin-bottom: 26px;
  }

  .kg-pdp-hero__media {
    grid-column: 1;
    grid-row: 1 / span 2;
    justify-content: flex-start;
  }

  .kg-pdp-hero__copy {
    display: contents;
  }

  .kg-pdp-trust-card {
    display: none;
  }

  .kg-pdp-brand-card {
    width: 100%;
    max-width: 150px;
    min-height: 0;
    aspect-ratio: 1 / 1.18;
    border-radius: 8px;
    box-shadow: 0 14px 28px rgba(18, 82, 36, 0.16);
  }

  .kg-pdp-brand-card .woocommerce-product-gallery,
  .kg-pdp-brand-card .images,
  .kg-pdp-brand-card .woocommerce-product-gallery__wrapper,
  .kg-pdp-brand-card .woocommerce-product-gallery__image,
  .kg-pdp-brand-card .woocommerce-product-gallery__image a {
    min-height: 0;
    height: 100% !important;
  }

  .kg-pdp-brand-card .woocommerce-product-gallery__wrapper img,
  .kg-pdp-brand-card .woocommerce-product-gallery__image img,
  .kg-pdp-brand-card img.wp-post-image {
    height: 100% !important;
    min-height: 0;
    border-radius: 8px;
    object-fit: cover !important;
  }

  .kg-pdp-title {
    grid-column: 2;
    grid-row: 1;
    align-self: end;
    transform: translateY(-4px);
    font-size: clamp(21px, 6.4vw, 30px);
    line-height: 1.12;
    font-weight: 900;
  }

  .kg-pdp-title.kg-pdp-title--single-line {
    transform: translateY(-8px);
  }

  .kg-pdp-subtitle {
    grid-column: 2;
    grid-row: 2;
    align-self: start;
    max-width: none;
    color: #2b3445;
    font-size: 14px;
    line-height: 1.55;
  }

  .kg-pdp-hero-benefits {
    grid-column: 1 / -1;
    grid-row: 3;
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    max-width: none;
    margin-top: 8px;
  }

  .kg-pdp-hero-benefit {
    display: inline-flex;
    width: auto;
    grid-template-columns: none;
    align-items: center;
    gap: 4px;
    padding: 6px 8px;
    border-radius: 999px;
    background: #edf8ef;
    color: #176b21;
  }

  .kg-pdp-hero-benefit .kg-pdp-icon {
    width: 13px;
    height: 13px;
    color: currentColor;
  }

  .kg-pdp-hero-benefit__copy strong {
    margin: 0;
    color: currentColor;
    font-size: 10px;
    line-height: 1;
    font-weight: 700;
    white-space: nowrap;
  }

  .kg-pdp-hero-benefit__copy span {
    display: none;
  }

  .kg-pdp-purchase-shell {
    margin-bottom: 24px;
  }

  .kg-pdp-form,
  .kg-pdp-form__layout,
  .kg-pdp-form__main {
    gap: 18px;
  }

  .kg-pdp-region-row {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .kg-pdp-note-panel {
    order: 1;
    grid-template-columns: 46px minmax(0, 1fr);
    gap: 16px;
    min-height: 0;
    padding: 18px 18px 20px;
    border-color: #f4e4bb;
    border-radius: 18px;
    background: linear-gradient(180deg, #fffaf1 0%, #fff8ee 100%);
    box-shadow: 0 6px 16px rgba(214, 161, 34, 0.08);
  }

  .kg-pdp-note-panel__icon {
    width: 44px;
    height: 44px;
    color: #ffbf1f;
  }

  .kg-pdp-note-panel__copy {
    gap: 3px;
  }

  .kg-pdp-note-panel__copy strong {
    font-size: inherit;
    line-height: inherit;
  }

  .kg-pdp-note-panel__copy p {
    color: #111111;
    font-size: 11px;
    line-height: 1.3;
    white-space: nowrap;
  }

  .kg-pdp-note-panel__copy p:last-child {
    font-size: 10px;
  }

  .kg-pdp-region-panel {
    order: 2;
    display: block;
    width: 224px;
    max-width: 100%;
    min-height: 0;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
  }

  .kg-pdp-region-panel .kg-pdp-panel__icon,
  .kg-pdp-region-panel .kg-pdp-panel__copy {
    display: none;
  }

  .kg-pdp-region-panel .kg-pdp-panel__control {
    grid-column: auto;
  }

  .kg-pdp-region-panel .kg-pdp-select,
  .kg-pdp-region-panel select {
    height: 58px;
    border-color: #e8ebef;
    border-radius: 12px;
    background-color: #fff;
    color: #111827;
    font-size: 17px;
    font-weight: 500;
    box-shadow: 0 5px 14px rgba(17, 24, 39, 0.08);
  }

  .kg-pdp-purchase-grid {
    display: block;
  }

  .kg-pdp-value-grid-wrap {
    margin-top: 24px;
  }

  .kg-pdp-value-grid-wrap::before {
    content: "Choose Product";
    display: block;
    margin: 0 0 14px;
    color: #070b22;
    font-size: 23px;
    line-height: 1.2;
    font-weight: 900;
  }

  .kg-pdp-value-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px 10px;
  }

  .kg-pdp-value-card {
    grid-template-columns: 72px minmax(0, 1fr);
    grid-template-rows: 1fr;
    align-items: center;
    gap: 0 13px;
    min-height: 150px;
    padding: 14px 12px;
    border-color: #eef1f4;
    border-radius: 8px;
    background: #fff;
    text-align: left;
    box-shadow: 0 8px 22px rgba(17, 24, 39, 0.09);
    overflow: hidden;
  }

  .kg-pdp-value-card.is-selected {
    border-color: #16851f;
    background: #f6fbf7;
    box-shadow: 0 0 0 1px rgba(22, 133, 31, 0.26), 0 10px 24px rgba(22, 133, 31, 0.12);
  }

  .kg-pdp-value-card__badge {
    display: inline-flex;
    align-items: center;
    top: 10px;
    right: 10px;
    left: auto;
    gap: 3px;
    transform: none;
    padding: 4px 9px;
    border-radius: 999px;
    background: #16851f;
    font-size: 8px;
    line-height: 1;
    letter-spacing: 0;
    box-shadow: 0 4px 10px rgba(22, 133, 31, 0.18);
  }

  .kg-pdp-value-card__badge::before {
    content: "★";
    color: #ffc21a;
    font-size: 10px;
    line-height: 1;
  }

  .kg-pdp-value-card__art {
    grid-column: 1;
    grid-row: 1;
    align-self: center;
    width: 72px;
    min-height: 0;
    height: auto;
    aspect-ratio: 1 / 1.18;
    padding: 0;
    border-radius: 8px;
    overflow: hidden;
    background: #f3f5f4;
    box-shadow: 0 7px 14px rgba(17, 24, 39, 0.08);
  }

  .kg-pdp-value-card__art img {
    display: block;
    width: 100%;
    height: 100%;
    max-width: none;
    max-height: none;
    border-radius: inherit;
    object-fit: cover;
    object-position: center;
  }

  .kg-pdp-value-card__content {
    grid-column: 2;
    grid-row: 1;
    align-self: center;
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    align-items: start;
    min-width: 0;
    min-height: calc(72px * 1.18);
    gap: 6px;
    padding: 10px 0 5px;
  }

  .kg-pdp-value-card__type {
    display: none !important;
  }

  .kg-pdp-value-card__title {
    align-self: end;
    margin: 0 0 2px;
    color: #070b22;
    font-size: 12px;
    line-height: 1.28;
    font-family: Inter, Arial, sans-serif;
    font-weight: 600;
    letter-spacing: 0;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .kg-pdp-value-card__title.kg-pdp-value-card__title--single-line {
    margin-bottom: 4px;
  }

  .kg-pdp-value-card__price {
    display: block;
    margin: 0;
  }

  .kg-pdp-value-card__price,
  .kg-pdp-value-card__price .woocommerce-Price-amount {
    color: #16851f;
    font-size: 14px;
    line-height: 1.3;
    font-family: Inter, Arial, sans-serif;
    font-weight: 600;
    letter-spacing: 0;
  }

  .kg-pdp-summary {
    position: fixed !important;
    top: auto !important;
    right: 12px;
    bottom: max(10px, env(safe-area-inset-bottom, 0px));
    left: 12px !important;
    width: auto !important;
    z-index: 999;
  }

  .kg-pdp-summary .single_variation_wrap,
  .kg-pdp-summary .woocommerce-variation-add-to-cart {
    margin: 0;
  }

  .kg-pdp-summary-card {
    grid-template-columns: minmax(72px, 0.85fr) 82px minmax(98px, 1fr);
    align-items: center;
    gap: 7px 13px;
    padding: 7px 8px;
    border-color: rgba(17, 24, 39, 0.08);
    border-radius: 24px;
    background: #f8f9f4;
    box-shadow: 0 10px 24px rgba(17, 24, 39, 0.2);
  }

  .kg-pdp-summary-card__section:first-child {
    order: 2;
    display: block;
    min-width: 0;
  }

  .kg-pdp-summary-card__section:nth-of-type(2),
  .kg-pdp-security-note {
    display: none;
  }

  .kg-pdp-summary-card__section + .kg-pdp-summary-card__section,
  .kg-pdp-summary-total {
    padding-top: 0;
    border-top: 0;
  }

  .kg-pdp-summary-card__heading {
    display: none;
  }

  .kg-pdp-summary-total {
    order: 1;
    display: flex;
    align-items: baseline;
    gap: 4px;
    min-width: 0;
    white-space: nowrap;
  }

  .kg-pdp-summary-total span {
    color: #070b22;
    font-size: 0;
    line-height: 1;
  }

  .kg-pdp-summary-total span::before {
    content: "From";
    font-size: 14px;
    line-height: 1;
    font-weight: 900;
  }

  .kg-pdp-summary-total__value,
  .kg-pdp-summary-total__value .woocommerce-Price-amount {
    color: #070b22;
    font-size: 16px;
    line-height: 1;
    font-weight: 900;
  }

  .kg-pdp-summary .kg-quantity-stepper,
  .kg-pdp-summary-card .kg-quantity-stepper {
    grid-template-columns: 24px 28px 24px;
    gap: 4px;
    border: 0;
    border-radius: 0;
    background: transparent;
    overflow: visible;
  }

  .kg-pdp-summary .kg-quantity-stepper__button,
  .kg-pdp-summary-card .kg-quantity-stepper__button {
    width: 24px;
    height: 28px;
    border: 1px solid #e5e8ed;
    border-radius: 8px;
    background: #fff;
    color: #070b22;
    font-size: 18px;
    font-weight: 700;
    box-shadow: 0 2px 8px rgba(17, 24, 39, 0.06);
  }

  .kg-pdp-summary .kg-quantity-stepper .qty,
  .kg-pdp-summary-card .kg-quantity-stepper .qty {
    width: 28px;
    height: 30px;
    border: 0;
    border-radius: 999px;
    background: #fff;
    color: #070b22;
    font-size: 14px;
    font-weight: 800;
    box-shadow: 0 3px 12px rgba(17, 24, 39, 0.15);
  }

  .kg-pdp-summary .single_add_to_cart_button.button.alt,
  .kg-pdp-summary-card .single_add_to_cart_button.button.alt {
    order: 3;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    height: 40px;
    padding: 0 8px;
    border-color: #16851f;
    border-radius: 999px;
    background: #16851f;
    color: #fff;
    font-size: 0;
    font-weight: 900;
    white-space: nowrap;
    box-shadow: 0 8px 18px rgba(22, 133, 31, 0.22);
  }

  .kg-pdp-summary .single_add_to_cart_button.button.alt::after,
  .kg-pdp-summary-card .single_add_to_cart_button.button.alt::after {
    content: "BUY NOW";
    font-size: 13px;
    line-height: 1;
    font-weight: 900;
  }
}

@media (max-width: 380px) {
  .single-product .kg-single-product.kg-pdp {
    width: min(100% - 24px, 640px);
  }

  .kg-pdp-hero {
    grid-template-columns: 112px minmax(0, 1fr);
    gap: 14px;
  }

  .kg-pdp-title {
    font-size: 21px;
  }

  .kg-pdp-subtitle {
    font-size: 13px;
    line-height: 1.45;
  }

  .kg-pdp-value-grid {
    gap: 14px 8px;
  }

  .kg-pdp-value-card {
    grid-template-columns: 64px minmax(0, 1fr);
    gap: 0 9px;
    min-height: 132px;
    padding: 10px;
  }

  .kg-pdp-value-card__art {
    width: 64px;
    min-height: 0;
    height: auto;
  }

  .kg-pdp-value-card__art img {
    width: 100%;
    height: 100%;
  }

  .kg-pdp-value-card__content {
    min-height: calc(64px * 1.18);
    gap: 6px;
    padding: 8px 0 5px;
  }

  .kg-pdp-value-card__title {
    font-size: 11px;
  }

  .kg-pdp-value-card__price,
  .kg-pdp-value-card__price .woocommerce-Price-amount {
    font-size: 13px;
  }

  .kg-pdp-summary {
    right: 8px;
    left: 8px !important;
  }

  .kg-pdp-summary-card {
    grid-template-columns: minmax(62px, 0.82fr) 70px minmax(82px, 1fr);
    gap: 5px 12px;
    padding: 6px;
  }

  .kg-pdp-summary-total span::before {
    font-size: 12px;
  }

  .kg-pdp-summary-total__value,
  .kg-pdp-summary-total__value .woocommerce-Price-amount {
    font-size: 14px;
  }

  .kg-pdp-summary .kg-quantity-stepper,
  .kg-pdp-summary-card .kg-quantity-stepper {
    grid-template-columns: 22px 26px 22px;
    gap: 3px;
  }

  .kg-pdp-summary .kg-quantity-stepper__button,
  .kg-pdp-summary-card .kg-quantity-stepper__button {
    width: 22px;
    height: 26px;
    font-size: 16px;
  }

  .kg-pdp-summary .kg-quantity-stepper .qty,
  .kg-pdp-summary-card .kg-quantity-stepper .qty {
    width: 26px;
    height: 28px;
    font-size: 13px;
  }

  .kg-pdp-summary .single_add_to_cart_button.button.alt,
  .kg-pdp-summary-card .single_add_to_cart_button.button.alt {
    min-height: 36px;
    height: 36px;
    padding-inline: 6px;
  }

  .kg-pdp-summary .single_add_to_cart_button.button.alt::after,
  .kg-pdp-summary-card .single_add_to_cart_button.button.alt::after {
    font-size: 12px;
  }
}

/* ── Product page related products – desktop horizontal layout ──────────── */

.product-card__description,
.product-card__trust-badges {
  display: none;
}

.product-card__trust-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 11px 5px 9px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
  line-height: 1;
  border: 1px solid transparent;
  white-space: nowrap;
}

.product-card__trust-badge--fast {
  background: #fefce8;
  color: #854d0e;
  border-color: #fde68a;
}

.product-card__trust-badge--safe {
  background: #f0fdf4;
  color: #166534;
  border-color: #86efac;
}

.product-card__trust-badge--support {
  background: #eff6ff;
  color: #1e40af;
  border-color: #93c5fd;
}

.kg-pdp-value-card__description,
.kg-pdp-value-card__delivery,
.kg-pdp-value-card__trust-badges {
  display: none;
}

.kg-pdp-value-card__trust-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 11px 5px 9px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
  line-height: 1;
  border: 1px solid transparent;
  white-space: nowrap;
}

.kg-pdp-value-card__trust-badge--fast {
  background: #fefce8;
  color: #854d0e;
  border-color: #fde68a;
}

.kg-pdp-value-card__trust-badge--safe {
  background: #f0fdf4;
  color: #166534;
  border-color: #86efac;
}

.kg-pdp-value-card__trust-badge--support {
  background: #eff6ff;
  color: #1e40af;
  border-color: #93c5fd;
}

@media (min-width: 992px) {
  .kg-pdp-related-shell .related.products ul.products li.product .product-card {
    flex-direction: row;
    align-items: center;
    padding: 12px;
    gap: 12px;
    height: auto;
    min-height: 0;
    border-radius: 16px !important;
  }

  .kg-pdp-related-shell .product-card__media {
    flex: 0 0 100px;
    width: 100px;
    min-width: 100px;
    height: 100px;
    aspect-ratio: 1 / 1;
    border-radius: 12px;
    clip-path: inset(0 round 12px);
  }

  .kg-pdp-related-shell .product-card__body {
    padding: 0;
    flex: 1 1 0;
    min-width: 0;
    justify-content: center;
  }

  .kg-pdp-related-shell .product-card__title {
    text-align: left;
    font-size: 17px;
    font-weight: 700;
    min-height: 0;
    display: block;
  }

  .kg-pdp-related-shell .product-card__title a {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    width: auto;
    justify-content: unset;
  }

  .kg-pdp-related-shell .product-card__description {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    font-size: 13px;
    color: var(--kg-muted);
    margin: 5px 0 12px;
    line-height: 1.5;
  }

  .kg-pdp-related-shell .product-card__trust-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
  }
}

body.single-product .kg-pdp-value-card__title,
body.single-product .kg-pdp-related-shell .product-card__title,
body.single-product .kg-pdp-related-shell .product-card__title a {
  display: block;
  -webkit-box-orient: initial;
  -webkit-line-clamp: unset;
  overflow: visible;
}

/* Hero media + copy combined card — mirrors .kg-pdp-value-card.kg-pdp-related-card.kg-pdp-value-card--link */
@media (min-width: 768px) {
  .kg-pdp-hero {
    grid-template-columns: minmax(0, 1fr) 296px;
  }
}

@media (min-width: 768px) {
  .kg-pdp-hero__card {
    display: grid;
    grid-template-columns: minmax(210px, 248px) minmax(0, 1fr);
    gap: 42px;
    align-items: center;
    min-height: 356px;
    padding: 48px 40px;
    border: 1px solid #edf0f4;
    border-radius: 14px;
    background: #fff;
    box-shadow: 0 14px 36px rgba(17, 24, 39, 0.08);
    color: inherit;
    text-decoration: none;
    overflow: hidden;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
  }

  .kg-pdp-hero__card .kg-pdp-hero__media {
    justify-content: flex-start;
  }

  .kg-pdp-hero__card .kg-pdp-brand-card {
    width: min(248px, 100%);
    max-width: none;
    min-height: 0;
    aspect-ratio: 1 / 1;
    padding: 0;
    border: 0;
    border-radius: 8px;
    background: transparent;
    box-shadow: none;
    overflow: hidden;
  }

  .kg-pdp-hero__card .kg-pdp-brand-card .woocommerce-product-gallery,
  .kg-pdp-hero__card .kg-pdp-brand-card .images,
  .kg-pdp-hero__card .kg-pdp-brand-card .woocommerce-product-gallery__wrapper,
  .kg-pdp-hero__card .kg-pdp-brand-card .woocommerce-product-gallery__image,
  .kg-pdp-hero__card .kg-pdp-brand-card .woocommerce-product-gallery__image a {
    display: block;
    width: 100% !important;
    min-height: 0;
    height: 100% !important;
    margin: 0 !important;
  }

  .kg-pdp-hero__card .kg-pdp-brand-card .woocommerce-product-gallery__wrapper img,
  .kg-pdp-hero__card .kg-pdp-brand-card .woocommerce-product-gallery__image img,
  .kg-pdp-hero__card .kg-pdp-brand-card img.wp-post-image {
    display: block;
    width: 100% !important;
    min-width: 100%;
    height: 100% !important;
    min-height: 0;
    max-width: none;
    max-height: none;
    border-radius: inherit;
    object-fit: cover !important;
    object-position: center;
  }

  .kg-pdp-hero__card .kg-pdp-hero__copy {
    display: grid;
    align-content: center;
    gap: 16px;
    min-width: 0;
    padding: 0;
  }

  .kg-pdp-hero__card .kg-pdp-title {
    margin: 0;
    color: #070b22;
    font-size: clamp(28px, 2.7vw, 32px);
    line-height: 1.16;
    font-weight: 800;
    letter-spacing: 0;
  }

  .kg-pdp-hero__card .kg-pdp-subtitle {
    max-width: 390px;
    margin: 0;
    color: #334155;
    font-size: 15px;
    line-height: 1.65;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefits {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    max-width: none;
    margin-top: 34px;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 94px;
    min-height: 44px;
    gap: 12px;
    padding: 10px 18px;
    border: 1px solid #e6edf5;
    border-radius: 7px;
    background: #fff;
    box-shadow: 0 5px 14px rgba(17, 24, 39, 0.05);
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit:nth-child(1) {
    border-color: #f8e7bd;
    background: #fffaf0;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit:nth-child(2) {
    border-color: #d6f4df;
    background: #ecfff3;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit:nth-child(3) {
    min-width: 158px;
    border-color: #d7eefd;
    background: #f3faff;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit .kg-pdp-icon {
    width: 22px;
    height: 22px;
    flex: 0 0 22px;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit:nth-child(1) .kg-pdp-icon {
    color: #f7b500;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit:nth-child(2) .kg-pdp-icon {
    color: #19bd4b;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit:nth-child(3) .kg-pdp-icon {
    color: #2496e8;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit__copy strong {
    margin: 0;
    color: #101827;
    font-size: 13px;
    line-height: 1;
    font-weight: 800;
    white-space: nowrap;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit__copy span {
    display: none;
  }
}

@media (min-width: 992px) {
  .kg-pdp-hero__card .kg-pdp-subtitle {
    max-width: 560px;
  }

  .kg-pdp-hero__card .kg-pdp-hero__media {
    align-self: center;
  }

  .kg-pdp-hero__card .kg-pdp-hero__copy {
    grid-template-rows: auto auto minmax(0, 1fr);
    align-self: stretch;
    align-content: stretch;
    gap: 10px;
    padding: 50px 0 4px;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefits {
    align-self: end;
    margin-top: 0;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit {
    display: grid;
    grid-template-columns: 22px auto;
    align-items: center;
    justify-content: center;
    justify-items: center;
    column-gap: 10px;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit .kg-pdp-icon {
    justify-self: center;
    align-self: center;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit__copy {
    display: block;
    margin: 0;
    text-align: center;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit__copy strong {
    margin: 0;
    font-size: 0;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit__copy strong::after {
    display: block;
    font-size: 13px;
    line-height: 1.1;
    font-weight: 800;
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit:nth-child(1) .kg-pdp-hero-benefit__copy strong::after {
    content: "Fast";
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit:nth-child(2) .kg-pdp-hero-benefit__copy strong::after {
    content: "Safe";
  }

  .kg-pdp-hero__card .kg-pdp-hero-benefit:nth-child(3) .kg-pdp-hero-benefit__copy strong::after {
    content: "Full Time Support";
  }
}

@media (min-width: 768px) and (max-width: 1180px) {
  .kg-pdp-hero {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  .kg-pdp-hero__card {
    grid-template-columns: minmax(160px, 220px) minmax(0, 1fr);
    gap: 28px;
    padding: 34px 28px;
  }
}

@media (max-width: 767px) {
  .kg-pdp-hero__card {
    display: contents;
  }
}

/* ============================================================
   WhiteBIT-inspired global theme tweaks
   - Translucent dark navy/purple header w/ backdrop blur (every page, mobile + desktop)
   - Neon lime-to-yellow gradient applied to CTA buttons (not the homepage slider button)
   Uses literal color values so they aren't overridden by the customizer's
   `--kg-header-bg` value defined by functions.php.
   ============================================================ */

.site-header,
.site-header--homepage,
.site-header--hero {
  background: rgba(24, 24, 52, 0.9) !important;
  background-color: rgba(24, 24, 52, 0.9) !important;
  background-image: none !important;
  -webkit-backdrop-filter: blur(16px) !important;
  backdrop-filter: blur(16px) !important;
}

.site-header--homepage .kg-home-header,
.site-header__desktop-menu-bar {
  background: transparent !important;
  background-color: transparent !important;
}

.site-header .kg-home-header__locale,
.site-header .site-header__mobile-meta-chip {
  background: rgba(255, 255, 255, 0.06);
}

.site-header .header-login,
.site-header .header-login--homepage,
.site-header--hero .header-login,
.site-header--homepage .header-login--homepage,
.hero-cta,
.kg-pdp-summary .single_add_to_cart_button.button.alt,
.kg-pdp-summary-card .single_add_to_cart_button.button.alt,
.kg-product-info .single_add_to_cart_button.button.alt,
.woocommerce-cart .wc-proceed-to-checkout .checkout-button.button.alt,
.woocommerce-cart .wc-proceed-to-checkout .checkout-button.button.alt.wc-forward,
.woocommerce #place_order,
.woocommerce-checkout #place_order,
.woocommerce-page #place_order,
.kg-account-panel .button:not(.is-secondary),
.kg-account-inline-form .button:not(.is-secondary),
.kg-account-form button.button:not(.is-secondary),
.kg-auth-form .button:not(.is-secondary),
.kg-auth-form button.button:not(.is-secondary),
.wp-element-button,
.wp-block-button__link,
button.alt.wc-forward,
a.button.alt {
  background: linear-gradient(48deg, #90d610 -13.21%, #ddf218 51.2%) !important;
  background-color: #90d610 !important;
  background-image: linear-gradient(48deg, #90d610 -13.21%, #ddf218 51.2%) !important;
  color: #000000 !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

.site-header .header-login:hover,
.site-header .header-login:focus-visible,
.site-header .header-login--homepage:hover,
.site-header .header-login--homepage:focus-visible,
.site-header--hero .header-login:hover,
.site-header--hero .header-login:focus-visible,
.hero-cta:hover,
.hero-cta:focus-visible,
.kg-pdp-summary .single_add_to_cart_button.button.alt:hover,
.kg-pdp-summary .single_add_to_cart_button.button.alt:focus-visible,
.kg-pdp-summary-card .single_add_to_cart_button.button.alt:hover,
.kg-pdp-summary-card .single_add_to_cart_button.button.alt:focus-visible,
.kg-product-info .single_add_to_cart_button.button.alt:hover,
.kg-product-info .single_add_to_cart_button.button.alt:focus-visible,
.woocommerce-cart .wc-proceed-to-checkout .checkout-button.button.alt:hover,
.woocommerce-cart .wc-proceed-to-checkout .checkout-button.button.alt.wc-forward:hover,
.woocommerce #place_order:hover,
.woocommerce-checkout #place_order:hover,
.kg-account-panel .button:not(.is-secondary):hover,
.kg-account-inline-form .button:not(.is-secondary):hover,
.kg-account-form button.button:not(.is-secondary):hover,
.kg-auth-form .button:not(.is-secondary):hover,
.kg-auth-form button.button:not(.is-secondary):hover,
.wp-element-button:hover,
.wp-block-button__link:hover,
button.alt.wc-forward:hover,
a.button.alt:hover {
  background: linear-gradient(48deg, #a6e024 -13.21%, #e9f84a 51.2%) !important;
  background-color: #a6e024 !important;
  background-image: linear-gradient(48deg, #a6e024 -13.21%, #e9f84a 51.2%) !important;
  color: #000000 !important;
  filter: brightness(1.04);
}

.site-header .header-login,
.site-header .header-login--homepage {
  border-radius: 100px !important;
}

/* ============================================================
   WhiteBIT-inspired typography
   - Body / paragraphs / inputs / buttons: Inter
   - All headings (h1-h6) and big display titles: Montserrat 800
   ============================================================ */

body,
input,
select,
textarea,
button,
.button {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif !important;
}

h1, h2, h3, h4, h5, h6,
.site-header__hero-title,
.kg-hero-slider__title,
.home-section__title,
[class*="__title"],
[class*="__heading"] {
  font-family: 'Montserrat', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif !important;
  font-weight: 800;
}


