/* ============================================================
   KOIOS — bespoke stylesheet (forest-green appliance brand)
   Built from scratch for the ko- component system.
   ============================================================ */

:root {
  --forest: #0f5132;
  --forest-deep: #0b3d26;
  --forest-ink: #082b1b;
  --leaf: #145a3c;
  --grass: #1f9d55;
  --grass-bright: #27ae60;
  --lime: #7be0a4;
  --mint: #e6f5ec;
  --mint-line: #cfe9d9;
  --cream: #f6f9f5;
  --paper: #ffffff;
  --ink: #17241d;
  --muted: #56695e;
  --faint: #7d8f84;
  --line: #e2ebe4;
  --gold: #f4b731;
  --koios: #f5920d;
  --shadow-sm: 0 2px 8px rgba(11, 61, 38, .06);
  --shadow: 0 10px 30px rgba(11, 61, 38, .10);
  --shadow-lg: 0 24px 60px rgba(11, 61, 38, .16);
  --r-sm: 10px;
  --r: 16px;
  --r-lg: 26px;
  --r-pill: 999px;
  --wrap: 1180px;
  --font-head: 'Sora', system-ui, sans-serif;
  --font-body: 'Inter', system-ui, -apple-system, sans-serif;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.65;
  font-size: 16px;
  overflow-x: hidden;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

h1, h2, h3, h4 { font-family: var(--font-head); line-height: 1.14; margin: 0 0 .5em; letter-spacing: -.02em; color: var(--ink); }
h1 { font-size: clamp(2rem, 4.6vw, 3.4rem); font-weight: 800; }
h2 { font-size: clamp(1.5rem, 3vw, 2.2rem); font-weight: 700; }
h3 { font-size: 1.18rem; font-weight: 600; }
p { margin: 0 0 1rem; }
a { color: var(--forest); text-decoration: none; transition: color .18s ease; }
a:hover { color: var(--grass); }
img { max-width: 100%; display: block; }
ul, ol { margin: 0 0 1rem; padding-left: 1.15rem; }

.ko-wrap { width: 100%; max-width: var(--wrap); margin-inline: auto; padding-inline: 22px; }

/* ---------- shared eyebrow / section head ---------- */
.ko-eyebrow {
  display: inline-block;
  font-family: var(--font-head);
  font-weight: 600;
  font-size: .74rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--grass);
  background: var(--mint);
  padding: .38em .9em;
  border-radius: var(--r-pill);
  margin-bottom: 1rem;
}
.ko-eyebrow-light { color: var(--lime); background: rgba(123, 224, 164, .14); }

.ko-head { max-width: 640px; margin: 0 auto 2.4rem; text-align: center; }
.ko-head h2 { margin-bottom: .4rem; }
.ko-head p { color: var(--muted); font-size: 1.05rem; margin: 0; }

.ko-section { padding: clamp(3rem, 6vw, 5rem) 22px; }

/* ---------- buttons ---------- */
.ko-btn {
  --btn-bg: var(--grass);
  --btn-fg: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5em;
  font-family: var(--font-head);
  font-weight: 600;
  font-size: .95rem;
  line-height: 1;
  padding: .82em 1.5em;
  border-radius: var(--r-pill);
  background: var(--btn-bg);
  color: var(--btn-fg);
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease;
  box-shadow: 0 6px 18px rgba(31, 157, 85, .28);
  white-space: nowrap;
}
.ko-btn:hover { color: #fff; background: var(--forest); transform: translateY(-2px); box-shadow: 0 10px 24px rgba(15, 81, 50, .34); }
.ko-btn-sm { font-size: .82rem; padding: .6em 1.05em; box-shadow: none; }
.ko-btn-lg { font-size: 1.02rem; padding: 1em 1.9em; }
.ko-btn-block { display: flex; width: 100%; }
.ko-btn-ghost { --btn-bg: transparent; --btn-fg: var(--forest); border-color: var(--mint-line); box-shadow: none; }
.ko-btn-ghost:hover { background: var(--mint); color: var(--forest); box-shadow: none; }

/* ---------- topbar ---------- */
.ko-topbar {
  background: var(--forest-ink);
  color: #d9f0e2;
  text-align: center;
  font-size: .8rem;
  letter-spacing: .04em;
  padding: .55rem 16px;
  font-weight: 500;
}

/* ---------- header / nav ---------- */
.ko-header {
  position: sticky;
  top: 0;
  z-index: 60;
  background: #ffffff;
  border-bottom: 1px solid var(--line);
}
.ko-logo { display: block; height: 40px; width: auto; }
.ko-header-in { display: flex; align-items: center; gap: 1.5rem; min-height: 72px; }

.ko-brand { display: inline-flex; align-items: center; gap: .6rem; font-family: var(--font-head); font-weight: 800; }
.ko-brand-mark {
  display: grid;
  place-items: center;
  width: 38px; height: 38px;
  border-radius: 11px;
  background: linear-gradient(150deg, var(--grass), var(--forest));
  color: #fff;
  font-size: 1.28rem;
  font-weight: 800;
  box-shadow: 0 5px 14px rgba(15, 81, 50, .3);
}
.ko-brand-word { font-size: 1.32rem; letter-spacing: .04em; color: var(--forest-ink); }

.ko-nav { display: flex; align-items: center; gap: .35rem; margin-left: auto; }
.ko-nav a {
  font-family: var(--font-head);
  font-weight: 500;
  font-size: .92rem;
  color: var(--ink);
  padding: .5rem .8rem;
  border-radius: var(--r-pill);
  transition: background .16s ease, color .16s ease;
}
.ko-nav a:hover { background: var(--mint); color: var(--forest); }
.ko-nav a.on { background: var(--forest); color: #fff; }

.ko-burger {
  display: none;
  margin-left: auto;
  width: 44px; height: 44px;
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 12px;
  cursor: pointer;
  padding: 0;
  position: relative;
}
.ko-burger span {
  position: absolute;
  left: 12px; right: 12px;
  height: 2px;
  background: var(--forest-ink);
  border-radius: 2px;
  transition: transform .25s ease, opacity .2s ease;
}
.ko-burger span:nth-child(1) { top: 15px; }
.ko-burger span:nth-child(2) { top: 21px; }
.ko-burger span:nth-child(3) { top: 27px; }
body.nav-open .ko-burger span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
body.nav-open .ko-burger span:nth-child(2) { opacity: 0; }
body.nav-open .ko-burger span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* ---------- hero ---------- */
.ko-hero {
  position: relative;
  background:
    radial-gradient(120% 130% at 100% 0%, rgba(31, 157, 85, .12), transparent 55%),
    radial-gradient(90% 120% at 0% 100%, rgba(123, 224, 164, .16), transparent 60%),
    var(--cream);
  overflow: hidden;
}
.ko-hero-in {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
  padding: clamp(3rem, 6vw, 5.5rem) 22px;
}
.ko-hero-copy h1 { margin-bottom: 1.1rem; }
.ko-hl {
  background: linear-gradient(120deg, var(--grass), var(--leaf));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
.ko-lede { font-size: 1.14rem; color: var(--muted); max-width: 34ch; margin-bottom: 1.8rem; }
.ko-hero-cta { display: flex; flex-wrap: wrap; gap: .8rem; margin-bottom: 1.8rem; }
.ko-hero-trust { display: flex; flex-wrap: wrap; gap: 1.4rem; color: var(--muted); font-size: .9rem; font-weight: 500; }
.ko-hero-trust span { display: inline-flex; align-items: center; gap: .35em; }

.ko-hero-art { position: relative; display: grid; place-items: center; min-height: 340px; }
.ko-hero-blob {
  position: absolute;
  inset: 6% 8%;
  background: linear-gradient(155deg, var(--grass), var(--forest));
  border-radius: 42% 58% 55% 45% / 52% 44% 56% 48%;
  filter: blur(2px);
  box-shadow: var(--shadow-lg);
  animation: ko-morph 14s ease-in-out infinite;
}
@keyframes ko-morph {
  0%, 100% { border-radius: 42% 58% 55% 45% / 52% 44% 56% 48%; }
  50% { border-radius: 56% 44% 40% 60% / 42% 58% 42% 58%; }
}
.ko-hero-art img {
  position: relative;
  z-index: 2;
  width: min(80%, 400px);
  aspect-ratio: 1;
  object-fit: contain;
  filter: drop-shadow(0 24px 34px rgba(8, 43, 27, .34));
}
.ko-hero-chip {
  position: absolute;
  z-index: 3;
  bottom: 6%;
  right: 4%;
  background: #fff;
  color: var(--forest-ink);
  font-family: var(--font-head);
  font-weight: 600;
  font-size: .82rem;
  padding: .6rem 1rem;
  border-radius: var(--r-pill);
  box-shadow: var(--shadow);
  max-width: 62%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ko-hero-chip:hover { color: var(--grass); }

/* ---------- marquee ---------- */
.ko-marquee { background: var(--forest-ink); color: #cdeeda; overflow: hidden; }
.ko-marquee-in {
  display: flex;
  gap: 2.6rem;
  padding: .95rem 22px;
  font-family: var(--font-head);
  font-weight: 500;
  font-size: .9rem;
  white-space: nowrap;
  flex-wrap: wrap;
  justify-content: center;
}
.ko-marquee-in span { display: inline-flex; align-items: center; gap: .4em; }

/* ---------- category tiles ---------- */
.ko-tiles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.3rem;
}
.ko-tile {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.ko-tile:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: var(--mint-line); }
.ko-tile-img { aspect-ratio: 16/10; background: var(--mint); display: grid; place-items: center; overflow: hidden; }
.ko-tile-img img { width: 76%; height: 76%; object-fit: contain; mix-blend-mode: multiply; transition: transform .3s ease; }
.ko-tile:hover .ko-tile-img img { transform: scale(1.06); }
.ko-tile-txt { padding: 1.3rem 1.4rem 1.5rem; position: relative; }
.ko-tile-icon {
  position: absolute;
  top: -1.4rem; right: 1.3rem;
  width: 46px; height: 46px;
  display: grid; place-items: center;
  background: #fff;
  border-radius: 14px;
  font-size: 1.4rem;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--line);
}
.ko-tile-txt h3 { margin-bottom: .25rem; color: var(--forest-ink); }
.ko-tile-txt p { color: var(--muted); font-size: .92rem; margin-bottom: .9rem; }
.ko-tile-count { font-family: var(--font-head); font-weight: 600; font-size: .84rem; color: var(--grass); }

/* ---------- product grid + card ---------- */
.ko-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.3rem;
}
.ko-card {
  display: flex;
  flex-direction: column;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.ko-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: var(--mint-line); }
.ko-card-media {
  position: relative;
  display: block;
  aspect-ratio: 1;
  background: #fff;
  padding: 1.1rem;
}
.ko-card-media img { width: 100%; height: 100%; object-fit: contain; mix-blend-mode: multiply; transition: transform .3s ease; }
.ko-card:hover .ko-card-media img { transform: scale(1.05); }
.ko-card-badge {
  position: absolute;
  top: .8rem; left: .8rem;
  background: var(--mint);
  color: var(--forest);
  font-family: var(--font-head);
  font-weight: 600;
  font-size: .68rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: .32em .7em;
  border-radius: var(--r-pill);
}
.ko-card-body { display: flex; flex-direction: column; gap: .6rem; padding: 1rem 1.1rem 1.2rem; flex: 1; }
.ko-card-title { font-size: .98rem; font-weight: 600; line-height: 1.35; margin: 0; }
.ko-card-title a { color: var(--ink); }
.ko-card-title a:hover { color: var(--forest); }
.ko-card-rate { display: flex; align-items: center; gap: .45rem; font-size: .82rem; color: var(--muted); }
.ko-card-rate.ko-new { color: var(--grass); font-family: var(--font-head); font-weight: 600; }
.ko-card-foot { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: .5rem; }
.ko-price { font-family: var(--font-head); font-weight: 800; font-size: 1.28rem; color: var(--forest-ink); }
.ko-unavail { font-size: .9rem; font-weight: 600; color: var(--faint); }
.ko-rcount { white-space: nowrap; }

/* stars */
.ko-stars { display: inline-flex; gap: 1px; color: #d7e2da; font-size: .95em; line-height: 1; }
.ko-star { font-style: normal; }
.ko-star.on { color: var(--gold); }

/* ---------- banner (split promo) ---------- */
.ko-banner { padding: clamp(2.5rem, 5vw, 4rem) 0; }
.ko-banner-in {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: clamp(1.5rem, 4vw, 3.5rem);
  background: linear-gradient(150deg, var(--forest), var(--forest-ink));
  border-radius: var(--r-lg);
  overflow: hidden;
  color: #eaf7ef;
  box-shadow: var(--shadow-lg);
}
.ko-banner-txt { padding: clamp(2rem, 4vw, 3.4rem); }
.ko-banner-txt h2 { color: #fff; }
.ko-banner-txt p { color: #c8e6d5; max-width: 40ch; margin-bottom: 1.6rem; }
.ko-banner-txt .ko-btn { background: var(--lime); color: var(--forest-ink); box-shadow: none; }
.ko-banner-txt .ko-btn:hover { background: #fff; color: var(--forest-ink); }
.ko-banner-img { height: 100%; min-height: 260px; }
.ko-banner-img img { width: 100%; height: 100%; object-fit: cover; }

/* ---------- features ---------- */
.ko-features { padding-top: clamp(3rem, 6vw, 5rem); }
.ko-feat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.3rem; }
.ko-feat {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 1.7rem 1.5rem;
  text-align: left;
  box-shadow: var(--shadow-sm);
  transition: transform .2s ease, box-shadow .2s ease;
}
.ko-feat:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.ko-feat-ic {
  width: 50px; height: 50px;
  display: grid; place-items: center;
  background: var(--mint);
  color: var(--forest);
  border-radius: 14px;
  font-size: 1.5rem;
  margin-bottom: 1rem;
}
.ko-feat h3 { margin-bottom: .35rem; color: var(--forest-ink); }
.ko-feat p { color: var(--muted); font-size: .92rem; margin: 0; }

/* ---------- stats ---------- */
.ko-stats { background: var(--forest-ink); color: #fff; }
.ko-stats-in {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  padding: clamp(2.4rem, 4vw, 3.4rem) 22px;
  text-align: center;
}
.ko-stat strong {
  display: block;
  font-family: var(--font-head);
  font-weight: 800;
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  color: var(--lime);
  line-height: 1;
  margin-bottom: .35rem;
}
.ko-stat span { color: #b7d8c6; font-size: .9rem; letter-spacing: .03em; }

/* ---------- seo prose block ---------- */
.ko-seo { background: var(--paper); padding: clamp(3rem, 6vw, 5rem) 0; border-block: 1px solid var(--line); }
.ko-seo .ko-wrap { max-width: 900px; }
.ko-seo h2 { margin-bottom: 1rem; }
.ko-seo h3 { margin-top: 2rem; color: var(--forest); }
.ko-seo p { color: var(--muted); }
.ko-seo ul { color: var(--muted); }
.ko-seo li { margin-bottom: .4rem; }
.ko-seo table, .ko-prose table, .ko-info table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.4rem 0;
  font-size: .92rem;
  border-radius: var(--r-sm);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.ko-seo th, .ko-prose th, .ko-info th { background: var(--forest); color: #fff; text-align: left; padding: .8rem 1rem; font-family: var(--font-head); font-weight: 600; }
.ko-seo td, .ko-prose td, .ko-info td { padding: .75rem 1rem; border-bottom: 1px solid var(--line); background: #fff; color: var(--ink); }
.ko-seo tr:nth-child(even) td { background: var(--cream); }

/* ---------- voices / testimonials ---------- */
.ko-voice-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.3rem; }
.ko-voice {
  margin: 0;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 1.8rem 1.6rem;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: .8rem;
}
.ko-voice .ko-stars { font-size: 1.05rem; }
.ko-voice p { color: var(--ink); font-size: 1rem; margin: 0; }
.ko-voice cite { color: var(--muted); font-style: normal; font-weight: 600; font-family: var(--font-head); font-size: .9rem; margin-top: auto; }

/* ---------- category hero ---------- */
.ko-cathero {
  background:
    radial-gradient(90% 140% at 100% 0%, rgba(31, 157, 85, .12), transparent 55%),
    var(--mint);
  padding: clamp(2rem, 4vw, 3.4rem) 0 clamp(2.4rem, 4vw, 3.4rem);
  border-bottom: 1px solid var(--mint-line);
}
.ko-crumb { font-size: .84rem; color: var(--muted); margin-bottom: 1.4rem; display: flex; flex-wrap: wrap; gap: .4rem; align-items: center; }
.ko-crumb a { color: var(--forest); font-weight: 500; }
.ko-crumb span { color: var(--faint); }
.ko-cathero-in { display: flex; align-items: center; gap: 1.5rem; }
.ko-cathero-icon {
  flex: none;
  width: 84px; height: 84px;
  display: grid; place-items: center;
  background: #fff;
  border-radius: 22px;
  font-size: 2.6rem;
  box-shadow: var(--shadow);
}
.ko-cathero-in h1 { margin-bottom: .5rem; }
.ko-cathero-in p { color: var(--muted); max-width: 60ch; margin: 0; }
.ko-cathero-plain { text-align: left; }
.ko-cathero-sub { color: var(--muted); max-width: 60ch; margin: .4rem 0 0; }

/* more categories chip row */
.ko-morecats { padding-top: 0; }
.ko-chip-row { display: flex; flex-wrap: wrap; gap: .7rem; justify-content: center; }
.ko-chip {
  display: inline-flex;
  align-items: center;
  gap: .5em;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-pill);
  padding: .6rem 1.15rem;
  font-family: var(--font-head);
  font-weight: 500;
  font-size: .9rem;
  color: var(--ink);
  box-shadow: var(--shadow-sm);
  transition: transform .16s ease, border-color .16s ease, color .16s ease;
}
.ko-chip span { font-size: 1.1em; }
.ko-chip:hover { transform: translateY(-2px); border-color: var(--grass); color: var(--forest); }

/* ---------- product detail (PDP) ---------- */
.ko-pdp { padding: clamp(1.6rem, 3vw, 2.6rem) 22px clamp(2rem, 4vw, 3rem); }
.ko-pdp-in {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.6rem, 4vw, 3.2rem);
  align-items: start;
}
.ko-pdp-media {
  position: sticky;
  top: 92px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 2rem;
  box-shadow: var(--shadow-sm);
  display: grid;
  place-items: center;
}
.ko-pdp-media img { width: 100%; max-width: 440px; aspect-ratio: 1; object-fit: contain; mix-blend-mode: multiply; }
.ko-pdp-cat {
  display: inline-block;
  font-family: var(--font-head);
  font-weight: 600;
  font-size: .72rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--grass);
  background: var(--mint);
  padding: .35em .85em;
  border-radius: var(--r-pill);
  margin-bottom: .9rem;
}
.ko-pdp-info h1 { font-size: clamp(1.5rem, 3vw, 2.1rem); margin-bottom: .8rem; }
.ko-pdp-rate { display: flex; align-items: center; gap: .6rem; margin-bottom: 1.1rem; color: var(--muted); font-size: .92rem; }
.ko-pdp-rate .ko-stars { font-size: 1.1rem; }
.ko-pdp-price {
  font-family: var(--font-head);
  font-weight: 800;
  font-size: clamp(1.8rem, 3.5vw, 2.4rem);
  color: var(--forest-ink);
  margin-bottom: 1.2rem;
}
.ko-pdp-price .ko-unavail { font-size: 1.1rem; }
.ko-pdp-ship { color: var(--muted); font-size: .88rem; margin: 1rem 0 1.6rem; display: flex; flex-wrap: wrap; gap: .8rem; }
.ko-pdp-highlights { border-top: 1px solid var(--line); padding-top: 1.4rem; }
.ko-pdp-highlights h2 { font-size: 1.15rem; margin-bottom: .7rem; }
.ko-bullets { list-style: none; padding: 0; margin: 0; display: grid; gap: .6rem; }
.ko-bullets li { position: relative; padding-left: 1.7rem; color: var(--ink); font-size: .95rem; }
.ko-bullets li::before {
  content: "";
  position: absolute;
  left: 0; top: .45em;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--grass);
  box-shadow: 0 0 0 3px var(--mint);
}
.ko-specs { width: 100%; border-collapse: collapse; margin-top: 1.6rem; font-size: .92rem; }
.ko-specs th { text-align: left; font-family: var(--font-head); font-weight: 600; color: var(--muted); padding: .6rem 1rem .6rem 0; width: 34%; vertical-align: top; border-bottom: 1px solid var(--line); }
.ko-specs td { padding: .6rem 0; color: var(--ink); border-bottom: 1px solid var(--line); }

/* pdp description */
.ko-pdp-desc { max-width: 820px; padding-block: clamp(1.5rem, 3vw, 2.5rem); }
.ko-pdp-desc h2 { font-size: 1.4rem; margin-bottom: .6rem; }
.ko-pdp-desc p { color: var(--muted); }

/* ---------- reviews ---------- */
.ko-reviews { padding-block: clamp(1.5rem, 3vw, 2.5rem) clamp(2.5rem, 5vw, 4rem); max-width: 900px; }
.ko-reviews-head { display: flex; flex-wrap: wrap; align-items: baseline; justify-content: space-between; gap: 1rem; margin-bottom: 1.6rem; padding-bottom: 1.2rem; border-bottom: 1px solid var(--line); }
.ko-reviews-head h2 { margin: 0; }
.ko-reviews-sum { display: flex; align-items: center; gap: .6rem; font-size: .92rem; color: var(--muted); }
.ko-reviews-sum .ko-stars { font-size: 1.1rem; }
.ko-reviews-sum b { color: var(--forest-ink); font-family: var(--font-head); }
.ko-review-list { display: grid; gap: 1.1rem; }
.ko-review { background: var(--paper); border: 1px solid var(--line); border-radius: var(--r); padding: 1.4rem 1.5rem; box-shadow: var(--shadow-sm); }
.ko-review-top { display: flex; align-items: center; gap: .7rem; margin-bottom: .4rem; }
.ko-review-author { font-family: var(--font-head); font-weight: 600; color: var(--forest-ink); }
.ko-verified { font-size: .7rem; font-weight: 600; color: var(--grass); background: var(--mint); padding: .22em .6em; border-radius: var(--r-pill); }
.ko-review-rate { display: flex; align-items: center; gap: .55rem; margin-bottom: .3rem; }
.ko-review-title { font-family: var(--font-head); font-weight: 600; font-size: .95rem; color: var(--ink); }
.ko-review-date { font-size: .78rem; color: var(--faint); margin-bottom: .6rem; }
.ko-review p { margin: 0; color: var(--muted); font-size: .95rem; }

/* ---------- info / legal prose ---------- */
.ko-info { padding: clamp(2.5rem, 5vw, 4rem) 22px; }
.ko-prose { max-width: 820px; }
.ko-prose h2 { font-size: 1.4rem; margin-top: 2rem; color: var(--forest); }
.ko-prose h3 { margin-top: 1.4rem; }
.ko-prose h2:first-child { margin-top: 0; }
.ko-prose p, .ko-prose li { color: var(--muted); }
.ko-prose a { text-decoration: underline; }

/* ---------- footer ---------- */
.ko-footer { background: var(--forest-ink); color: #b7d8c6; margin-top: auto; }
.ko-foot-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 2rem;
  padding: clamp(2.6rem, 5vw, 4rem) 22px 2.4rem;
}
.ko-brand-foot { display: inline-block; }
.ko-logo-foot { display: block; box-sizing: content-box; height: 30px; width: auto; background: #fff; padding: 11px 18px; border-radius: var(--r-sm); }
.ko-foot-tag { color: #eaf7ef; font-family: var(--font-head); font-weight: 600; margin: 1rem 0 .6rem; }
.ko-foot-note { color: #90b8a2; font-size: .9rem; max-width: 42ch; }
.ko-foot-contact { display: flex; flex-direction: column; gap: .4rem; margin-top: 1rem; font-size: .88rem; color: #b7d8c6; }
.ko-foot-col h4 { color: #fff; font-size: .95rem; letter-spacing: .04em; margin-bottom: 1rem; }
.ko-foot-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .55rem; }
.ko-foot-col a { color: #b7d8c6; font-size: .9rem; }
.ko-foot-col a:hover { color: var(--lime); }
.ko-foot-bottom {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.4rem 22px 2rem;
  border-top: 1px solid rgba(255, 255, 255, .1);
  font-size: .8rem;
  color: #8fb3a1;
}
.ko-foot-bottom p { margin: 0; }
.ko-disclaimer { max-width: 62ch; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 980px) {
  .ko-tiles, .ko-feat-grid, .ko-voice-grid { grid-template-columns: repeat(2, 1fr); }
  .ko-grid { grid-template-columns: repeat(3, 1fr); }
  .ko-stats-in { grid-template-columns: repeat(2, 1fr); }
  .ko-foot-grid { grid-template-columns: 1fr 1fr; }
  .ko-hero-in { grid-template-columns: 1fr; }
  .ko-hero-art { order: -1; min-height: 280px; }
  .ko-pdp-in { grid-template-columns: 1fr; }
  .ko-pdp-media { position: static; }
  .ko-banner-in { grid-template-columns: 1fr; }
  .ko-banner-img { order: -1; min-height: 220px; }
}

@media (max-width: 760px) {
  .ko-nav {
    position: fixed;
    inset: 0 0 0 auto;
    width: min(80vw, 320px);
    flex-direction: column;
    align-items: stretch;
    gap: .3rem;
    background: #fff;
    padding: 5.5rem 1.4rem 2rem;
    box-shadow: -20px 0 60px rgba(8, 43, 27, .2);
    transform: translateX(100%);
    transition: transform .28s ease;
    margin-left: 0;
    z-index: 55;
  }
  body.nav-open .ko-nav { transform: translateX(0); }
  .ko-nav a { padding: .8rem 1rem; font-size: 1rem; }
  .ko-burger { display: block; }
  body.nav-open::after {
    content: "";
    position: fixed; inset: 0;
    background: rgba(8, 43, 27, .4);
    z-index: 50;
  }
  body.nav-open { overflow: hidden; }
  .ko-cathero-in { flex-direction: column; align-items: flex-start; text-align: left; }
}

@media (max-width: 560px) {
  .ko-grid { grid-template-columns: repeat(2, 1fr); }
  .ko-tiles, .ko-feat-grid, .ko-voice-grid { grid-template-columns: 1fr; }
  .ko-card-body { padding: .9rem; }
  .ko-price { font-size: 1.15rem; }
  .ko-hero-trust { gap: .8rem 1.1rem; }
  .ko-reviews-head { flex-direction: column; gap: .5rem; }
}
