/* kit.css — the CP52 website-kit component styles.
   A premium creative-studio aesthetic, fully driven by brand tokens (--kit-*)
   injected per build. Re-skinning a site = editing brand.json, never this file.
   Responsive (mobile-first), accessible (focus states, reduced-motion, contrast).

   Sections:
     1. Reset + base typography
     2. Layout primitives + buttons + eyebrow
     3. Header / nav (+ mobile)
     4. Hero
     5. Section / richtext
     6. Featured work + cards
     7. Gallery
     8. Feature grid
     9. Stat band
    10. Testimonials
    11. About (split)
    12. CTA band
    13. Contact + form
    14. SDK blocks (events / LMS)
    15. Footer
    16. Motion (reveal) + reduced-motion + print
*/

/* ============ 1. reset + base ============ */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  margin: 0;
  font-family: var(--kit-font-body, system-ui, sans-serif);
  color: var(--kit-fg);
  background: var(--kit-bg);
  line-height: 1.6;
  font-size: clamp(1rem, 0.96rem + 0.2vw, 1.0625rem);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  /* keep UA form controls / scrollbars in step with the brand bg/fg, incl. the
     optional dark palette — the body bg/fg derive from --kit-bg/--kit-fg above. */
  color-scheme: light;
}
@media (prefers-color-scheme: dark) {
  /* only flips when a brand opts into a dark palette (brand.colors.dark);
     otherwise --kit-bg/--kit-fg stay light and this is cosmetically inert. */
  body { color-scheme: light dark; }
}

img { max-width: 100%; height: auto; display: block; }

h1, h2, h3, h4 {
  font-family: var(--kit-font-heading, var(--kit-font-body));
  line-height: 1.1;
  margin: 0 0 0.5em;
  letter-spacing: -0.01em;
  font-weight: 600;
}
h1 { font-size: clamp(2.25rem, 1.6rem + 3vw, 3.75rem); }
h2 { font-size: clamp(1.65rem, 1.3rem + 1.6vw, 2.5rem); }
h3 { font-size: clamp(1.2rem, 1.05rem + 0.6vw, 1.45rem); }
p { margin: 0 0 1rem; }

a { color: var(--kit-accent); text-underline-offset: 0.15em; }

/* visible, brand-aware focus ring for keyboard users */
:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--kit-accent) 60%, transparent);
  outline-offset: 2px;
  border-radius: 4px;
}

.kit-skip-link {
  position: absolute;
  left: 0.75rem;
  top: -3rem;
  z-index: 100;
  padding: 0.6rem 1rem;
  background: var(--kit-accent);
  color: var(--kit-accent-contrast);
  border-radius: var(--kit-radius);
  text-decoration: none;
  font-weight: 600;
  transition: top 0.18s ease;
}
.kit-skip-link:focus { top: 0.75rem; }

/* ============ 2. primitives ============ */
.kit-section-inner,
.kit-header-inner,
.kit-hero-inner,
.kit-footer-inner,
.kit-cta-inner,
.kit-stat-inner {
  width: 100%;
  max-width: var(--kit-max-width, 1120px);
  margin-inline: auto;
  padding-inline: clamp(1.25rem, 5vw, 2.5rem);
}

.kit-eyebrow {
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--kit-accent);
  margin: 0 0 0.75rem;
}
.kit-eyebrow--on-accent { color: color-mix(in srgb, var(--kit-accent-contrast) 85%, transparent); }

.kit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.8rem 1.6rem;
  border-radius: var(--kit-radius);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.975rem;
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
  line-height: 1.2;
}
.kit-btn:hover { transform: translateY(-2px); }
.kit-btn:active { transform: translateY(0); }

.kit-btn-primary {
  background: var(--kit-accent);
  color: var(--kit-accent-contrast);
  box-shadow: 0 8px 22px -10px color-mix(in srgb, var(--kit-accent) 70%, transparent);
}
.kit-btn-primary:hover { box-shadow: 0 14px 30px -10px color-mix(in srgb, var(--kit-accent) 75%, transparent); }

.kit-btn-ghost {
  background: transparent;
  color: var(--kit-fg);
  border-color: var(--kit-border);
}
.kit-btn-ghost:hover { border-color: var(--kit-accent); color: var(--kit-accent); }

.kit-btn-on-accent {
  background: var(--kit-accent-contrast);
  color: var(--kit-accent);
}
.kit-btn-ghost-on-accent {
  background: transparent;
  color: var(--kit-accent-contrast);
  border-color: color-mix(in srgb, var(--kit-accent-contrast) 55%, transparent);
}
.kit-btn-ghost-on-accent:hover { border-color: var(--kit-accent-contrast); }

/* ============ 3. header ============
   The header is a faithful copy of the live damiansemonin.art three-row stack:
   ROW 1 (utilbar)  — categories left, social + search + account + basket right
   ROW 2 (brandbar) — small CCS mark left | big Sémonin wordmark CENTRED | CTA right
   ROW 3 (pagebar)  — primary page nav, right-aligned, uppercase
   Single-logo clients (no subLogo) collapse to a left-aligned wordmark with the
   page nav on the same row, so the kit still reads well without the twin lockup. */
.kit-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--kit-bg);
  border-bottom: 1px solid transparent;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.kit-header.is-scrolled {
  border-bottom-color: var(--kit-border);
  box-shadow: 0 6px 20px -16px rgba(0, 0, 0, 0.5);
}

/* ROW 2 — brand lockup bar (cream surface, like the live e4e2dd row) */
.kit-brandbar { background: var(--kit-surface); }
.kit-brandbar-inner {
  width: 100%; max-width: var(--kit-max-width, 1120px); margin-inline: auto;
  padding: 0.55rem clamp(1.25rem, 5vw, 3.75rem);
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 1.25rem;
}
.kit-brandbar-left { display: flex; align-items: center; justify-content: flex-start; }
.kit-brandbar-right { display: flex; align-items: center; justify-content: flex-end; gap: 0.75rem; }
.kit-brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: var(--kit-fg);
}
.kit-sublogo-link { display: inline-flex; }
/* Sémonin wordmark — BIG + centred (enlarged ~50% to match live presence). CCS mark sized to its native 90×120. */
.kit-logo { width: 280px; max-width: 48vw; height: auto; display: block; }
.kit-sublogo { width: 96px; height: auto; display: block; }
.kit-wordmark {
  font-family: var(--kit-font-heading, var(--kit-font-body));
  font-weight: 700;
  font-size: 1.5rem;
  letter-spacing: -0.01em;
}
/* the soft (woad/clay) subscribe button used in the brand bar — matches live */
.kit-btn-soft { background: var(--kit-accent-2, var(--kit-accent)); color: #fff; border: 1px solid transparent; border-radius: 999px; padding: 0.5rem 1.4rem; font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.02em; }
.kit-btn-soft:hover { filter: brightness(0.94); color: #fff; }

/* ROW 3 — page-nav bar (same cream surface) */
.kit-pagebar { background: #ffffff; border-top: 1px solid color-mix(in srgb, var(--kit-border) 60%, transparent); }
.kit-pagebar-inner {
  width: 100%; max-width: var(--kit-max-width, 1120px); margin-inline: auto;
  padding: 0.15rem clamp(1.25rem, 5vw, 3.75rem) 0.45rem;
  display: flex; align-items: center; justify-content: flex-end; gap: 1rem;
}
/* search now lives at the LEFT of the white nav row; nav stays right */
.kit-pagebar-search { margin-right: auto; }

/* single-logo clients (no twin lockup): left-align the wordmark + put nav inline */
.kit-header:not(.kit-header--twotier) .kit-brandbar-inner { grid-template-columns: auto 1fr; }
.kit-header:not(.kit-header--twotier) .kit-brand { justify-content: flex-start; }
.kit-header:not(.kit-header--twotier) .kit-brandbar-left { display: none; }
.kit-header:not(.kit-header--twotier) .kit-logo { width: auto; height: 44px; }

@media (max-width: 768px) {
  .kit-logo { width: 210px; }
  .kit-sublogo { width: 76px; }
  .kit-wordmark { font-size: 1.25rem; }
}
.kit-nav {
  display: flex;
  align-items: center;
  gap: clamp(0.9rem, 2vw, 1.6rem);
  flex-wrap: wrap;
}
.kit-nav a {
  text-decoration: none;
  color: var(--kit-fg);
  font-weight: 500;
  font-size: 0.975rem;
  position: relative;
}
.kit-nav a:not(.kit-btn)::after {
  content: "";
  position: absolute;
  left: 0; right: 100%;
  bottom: -4px;
  height: 2px;
  background: var(--kit-accent);
  transition: right 0.2s ease;
}
.kit-nav a:not(.kit-btn):hover { color: var(--kit-accent); }
.kit-nav a:not(.kit-btn):hover::after { right: 0; }
/* current page — persistent underline + accent text (accessible: aria-current) */
.kit-nav a.is-active:not(.kit-btn) { color: var(--kit-accent); }
.kit-nav a.is-active:not(.kit-btn)::after { right: 0; }
.kit-nav-cta { color: var(--kit-accent-contrast); }
.kit-nav-cta::after { display: none; }

.kit-nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid var(--kit-border);
  border-radius: var(--kit-radius);
  cursor: pointer;
}
.kit-nav-toggle-bar {
  display: block;
  width: 20px;
  height: 2px;
  background: var(--kit-fg);
  transition: transform 0.2s ease, opacity 0.2s ease;
}
.kit-nav-toggle[aria-expanded="true"] .kit-nav-toggle-bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.kit-nav-toggle[aria-expanded="true"] .kit-nav-toggle-bar:nth-child(2) { opacity: 0; }
.kit-nav-toggle[aria-expanded="true"] .kit-nav-toggle-bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ---- utility/category bar (categories left · social + search + account + basket right)
   Light strip with dark text, like the live dh_top row (#f5f0e9). ---- */
.kit-utilbar { background: var(--kit-util-bg, #f5f0e9); color: var(--kit-fg); font-size: 0.82rem; border-bottom: 1px solid color-mix(in srgb, var(--kit-border) 50%, transparent); }
.kit-utilbar-inner {
  width: 100%; max-width: var(--kit-max-width, 1120px); margin-inline: auto;
  padding: 0.25rem clamp(1.25rem, 5vw, 3.75rem);
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}
/* category nav living in the top strip */
.kit-utilnav { display: flex; align-items: center; gap: clamp(0.8rem, 1.8vw, 1.5rem); }
.kit-utilnav-link, .kit-utilnav .kit-nav-ddbtn {
  font-family: var(--kit-font-heading, inherit); font-size: 0.8rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.02em; color: var(--kit-fg); text-decoration: none;
  background: none; border: none; cursor: pointer; padding: 0; display: inline-flex; align-items: center; gap: 0.2rem;
}
.kit-utilnav-link:hover, .kit-utilnav .kit-nav-ddbtn:hover { color: var(--kit-accent); }
@media (max-width: 900px) { .kit-utilnav { display: none; } }
.kit-util-social { display: flex; gap: 0.45rem; list-style: none; margin: 0; padding: 0; }
.kit-util-social a, .kit-util-link, .kit-util-search button {
  display: inline-flex; align-items: center; justify-content: center;
  width: 2.1rem; height: 2.1rem; border-radius: 6px;
  color: var(--kit-fg); text-decoration: none;
  transition: background 0.15s ease, color 0.15s ease;
}
.kit-util-link:hover, .kit-util-search button:hover { background: color-mix(in srgb, var(--kit-accent) 12%, transparent); color: var(--kit-accent); }
/* social icons = circular dark-filled (matches live); search/account/basket stay plain */
.kit-util-social a { background: var(--kit-fg); color: var(--kit-bg); border-radius: 50%; width: 2.35rem; height: 2.35rem; }
.kit-util-social a:hover { background: var(--kit-accent); color: #fff; }
/* the GLYPH inside each social circle reads too small at 17px — grow it
   noticeably while the circle stays the same size (Damian, 2026-06-29). */
.kit-util-social .kit-util-ico { width: 23px; height: 23px; }
.kit-util-actions { display: flex; align-items: center; gap: 0.25rem; }
.kit-util-ico {
  width: 17px; height: 17px; display: inline-block;
  background: currentColor; -webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
  -webkit-mask-position: center; mask-position: center; -webkit-mask-size: contain; mask-size: contain;
}
.kit-util-ico[data-ico="substack"]  { -webkit-mask-image: var(--ico-substack); mask-image: var(--ico-substack); }
.kit-util-ico[data-ico="instagram"] { -webkit-mask-image: var(--ico-instagram); mask-image: var(--ico-instagram); }
.kit-util-ico[data-ico="youtube"]   { -webkit-mask-image: var(--ico-youtube); mask-image: var(--ico-youtube); }
.kit-util-ico[data-ico="facebook"]  { -webkit-mask-image: var(--ico-facebook); mask-image: var(--ico-facebook); }
.kit-util-ico[data-ico="search"]    { -webkit-mask-image: var(--ico-search); mask-image: var(--ico-search); }
.kit-util-ico[data-ico="user"]      { -webkit-mask-image: var(--ico-user); mask-image: var(--ico-user); }
.kit-util-ico[data-ico="cart"]      { -webkit-mask-image: var(--ico-cart); mask-image: var(--ico-cart); }
:root {
  --ico-substack: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M3 4h18v2.6H3zM3 9.1h18V24l-9-5-9 5zM3 13.9V11.7h18v2.2z'/%3E%3C/svg%3E");
  --ico-instagram: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2.2c3.2 0 3.6 0 4.9.07 1.2.05 1.8.25 2.2.42.6.2 1 .5 1.4.9.4.4.7.8.9 1.4.17.4.37 1 .42 2.2.06 1.3.07 1.7.07 4.9s0 3.6-.07 4.9c-.05 1.2-.25 1.8-.42 2.2-.2.6-.5 1-.9 1.4-.4.4-.8.7-1.4.9-.4.17-1 .37-2.2.42-1.3.06-1.7.07-4.9.07s-3.6 0-4.9-.07c-1.2-.05-1.8-.25-2.2-.42-.6-.2-1-.5-1.4-.9-.4-.4-.7-.8-.9-1.4-.17-.4-.37-1-.42-2.2C2.2 15.6 2.2 15.2 2.2 12s0-3.6.07-4.9c.05-1.2.25-1.8.42-2.2.2-.6.5-1 .9-1.4.4-.4.8-.7 1.4-.9.4-.17 1-.37 2.2-.42C8.4 2.2 8.8 2.2 12 2.2m0 5a4.8 4.8 0 100 9.6 4.8 4.8 0 000-9.6m0 7.9a3.1 3.1 0 110-6.2 3.1 3.1 0 010 6.2m6.1-8.1a1.1 1.1 0 11-2.2 0 1.1 1.1 0 012.2 0'/%3E%3C/svg%3E");
  --ico-youtube: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M23 7.5a3 3 0 00-2.1-2.1C19 5 12 5 12 5s-7 0-8.9.4A3 3 0 001 7.5 31 31 0 00.6 12 31 31 0 001 16.5a3 3 0 002.1 2.1C5 19 12 19 12 19s7 0 8.9-.4a3 3 0 002.1-2.1A31 31 0 0023.4 12 31 31 0 0023 7.5M9.8 15.3V8.7l5.7 3.3z'/%3E%3C/svg%3E");
  --ico-facebook: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M22 12a10 10 0 10-11.6 9.9v-7H7.9V12h2.5V9.8c0-2.5 1.5-3.9 3.8-3.9 1.1 0 2.2.2 2.2.2v2.5h-1.3c-1.2 0-1.6.8-1.6 1.6V12h2.8l-.4 2.9h-2.4v7A10 10 0 0022 12'/%3E%3C/svg%3E");
  --ico-search: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle cx='11' cy='11' r='7' fill='none' stroke='black' stroke-width='2'/%3E%3Cline x1='16.5' y1='16.5' x2='21' y2='21' stroke='black' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
  --ico-user: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='2' d='M4 21a8 8 0 0116 0M12 11a4 4 0 100-8 4 4 0 000 8z'/%3E%3C/svg%3E");
  --ico-cart: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='2' d='M3 4h2l2.4 12.3a1 1 0 001 .8h9.8a1 1 0 001-.8L21 8H6M9 21a1 1 0 100-2 1 1 0 000 2zm9 0a1 1 0 100-2 1 1 0 000 2z'/%3E%3C/svg%3E");
}
.kit-util-search { display: flex; align-items: center; gap: 0.2rem; }
.kit-util-search input {
  width: 0; padding: 0; border: none; background: color-mix(in srgb, var(--kit-fg) 8%, transparent); color: var(--kit-fg);
  border-radius: 6px; font: inherit; font-size: 0.82rem; height: 1.7rem; opacity: 0;
  transition: width 0.2s ease, opacity 0.2s ease, padding 0.2s ease;
}
.kit-util-search input::placeholder { color: var(--kit-muted); }
.kit-util-search:focus-within input, .kit-util-search input:not(:placeholder-shown) { width: 9rem; opacity: 1; padding: 0 0.5rem; }
.kit-util-cart { position: relative; }
.kit-util-cartcount {
  position: absolute; top: 1px; right: 1px; min-width: 15px; height: 15px; padding: 0 3px;
  font-size: 0.62rem; font-weight: 800; line-height: 15px; text-align: center;
  background: var(--kit-accent); color: var(--kit-accent-contrast); border-radius: 999px;
}
/* collapse the hover-expand utilbar search on small screens, but NOT the
   always-visible pill search (.kit-brand-search) that lives in the white nav row */
@media (max-width: 600px) { .kit-util-search:not(.kit-brand-search) input { display: none; } }

/* the site search now lives at the LEFT of the white page-nav row.
   Visible + usable by default (a bordered pill), not a hover-expand. */
.kit-brand-search { gap: 0; border: 1px solid var(--kit-border); border-radius: 999px; background: var(--kit-bg); padding: 0.1rem 0.1rem 0.1rem 0.6rem; }
.kit-brand-search input {
  width: 7.5rem; opacity: 1; height: 1.7rem; padding: 0 0.25rem;
  background: transparent; border: none; color: var(--kit-fg); font: inherit; font-size: 0.82rem;
  transition: width 0.2s ease;
}
.kit-brand-search:focus-within input { width: 9.5rem; }
.kit-brand-search input::placeholder { color: var(--kit-muted); }
.kit-brand-search button { width: 1.9rem; height: 1.9rem; border-radius: 50%; }
@media (max-width: 768px) { .kit-brand-search input { width: 6rem; } }
/* keep search visible + reachable on phones (it sits in the white bar beside the burger) */
@media (max-width: 480px) { .kit-brand-search input { width: 5rem; } }

/* ---- page nav (row 3) ---- */
.kit-navwrap { display: flex; align-items: center; justify-content: flex-end; gap: clamp(0.6rem, 1.5vw, 1.2rem); }
.kit-nav--mobileonly { display: none; }  /* secondary (About/Support/Contact) lives in the top strip on desktop */
/* account + basket icons, moved DOWN into the primary white nav (right side) */
.kit-nav-icons { display: flex; align-items: center; gap: 0.3rem; }
.kit-nav-icons .kit-nav-icon-label { display: none; } /* icon-only on desktop */
/* these read as tiny — bump the tap target + the glyph (Damian, 2026-06-29) */
.kit-nav-icons .kit-util-link { width: 2.5rem; height: 2.5rem; }
.kit-nav-icons .kit-util-ico { width: 24px; height: 24px; }
/* keep the basket count badge proportional to the larger basket glyph */
.kit-nav-icons .kit-util-cartcount { top: 3px; right: 3px; }
.kit-nav--pages { gap: clamp(0.9rem, 2vw, 1.7rem); }
.kit-nav--pages .kit-nav-link {
  font-family: var(--kit-font-heading, inherit);
  font-size: 0.95rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.02em;
  color: var(--kit-fg); padding-block: 0.35rem;
}
.kit-nav--pages .kit-nav-link.is-active { color: var(--kit-accent); border-bottom: 3px solid var(--kit-accent); }
.kit-nav--pages .kit-nav-link.is-active::after { display: none; }
/* dropdown trigger inside the primary nav inherits the page-link look */
.kit-nav--pages .kit-nav-ddbtn {
  font-family: var(--kit-font-heading, inherit);
  font-size: 0.95rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.02em;
  color: var(--kit-fg); padding-block: 0.35rem;
}
.kit-nav--pages .kit-nav-ddbtn:hover { color: var(--kit-accent); }
/* mark the dropdown open when one of its children is the current page */
.kit-nav--pages .kit-nav-ddlink.is-active { color: var(--kit-accent); font-weight: 700; }

/* SPLIT dropdown (Blog): label is a real link to /blog/, the caret button
   opens the submenu. The whole group still opens on hover/focus (desktop). */
.kit-nav-dd--split { display: inline-flex; align-items: center; gap: 0.1rem; }
.kit-nav--pages .kit-nav-ddlabel { display: inline-flex; align-items: center; }
.kit-nav-ddcaretbtn {
  font: inherit; cursor: pointer; background: none; border: none; color: var(--kit-fg);
  display: inline-flex; align-items: center; padding: 0.35rem 0.1rem; line-height: 1;
}
.kit-nav-ddcaretbtn:hover { color: var(--kit-accent); }
.kit-nav-dd:hover .kit-nav-ddcaretbtn .kit-nav-ddcaret,
.kit-nav-dd:focus-within .kit-nav-ddcaretbtn .kit-nav-ddcaret { transform: rotate(180deg); }

/* the magnifier search ICON (replaces the oblong input pill); stays in the
   white nav, left. Clicking it goes to /search/ (which works). */
.kit-search-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 2.3rem; height: 2.3rem; border-radius: 50%;
  color: var(--kit-fg); text-decoration: none;
  transition: background 0.15s ease, color 0.15s ease;
}
.kit-search-icon:hover { background: color-mix(in srgb, var(--kit-accent) 12%, transparent); color: var(--kit-accent); }
.kit-search-icon .kit-util-ico { width: 22px; height: 22px; }

/* dropdown (ART) — hover + focus, no hide-then-reveal of page content */
.kit-nav-dd { position: relative; }
.kit-nav-ddbtn { font: inherit; cursor: pointer; background: none; border: none; color: var(--kit-fg); display: inline-flex; align-items: center; gap: 0.2rem; padding: 0; }
.kit-nav-ddcaret { font-size: 0.7em; transition: transform 0.15s ease; }
.kit-nav-ddmenu {
  position: absolute; top: 100%; left: 0; margin-top: 0.5rem; min-width: 12rem;
  background: var(--kit-bg); border: 1px solid var(--kit-border); border-radius: 10px;
  box-shadow: 0 16px 34px -18px rgba(0,0,0,0.4); padding: 0.4rem;
  display: flex; flex-direction: column; gap: 0.1rem;
  opacity: 0; visibility: hidden; transform: translateY(-6px);
  transition: opacity 0.16s ease, transform 0.16s ease, visibility 0.16s;
  z-index: 60;
}
.kit-nav-dd:hover .kit-nav-ddmenu,
.kit-nav-dd:focus-within .kit-nav-ddmenu,
.kit-nav-ddbtn[aria-expanded="true"] + .kit-nav-ddmenu,
.kit-nav-ddcaretbtn[aria-expanded="true"] + .kit-nav-ddmenu { opacity: 1; visibility: visible; transform: translateY(0); }
.kit-nav-dd:hover .kit-nav-ddcaret, .kit-nav-dd:focus-within .kit-nav-ddcaret { transform: rotate(180deg); }
.kit-nav-ddlink { padding: 0.5rem 0.7rem; border-radius: 7px; text-decoration: none; color: var(--kit-fg); font-size: 0.92rem; font-weight: 500; }
.kit-nav-ddlink:hover { background: color-mix(in srgb, var(--kit-accent) 12%, transparent); color: var(--kit-accent); }

@media (max-width: 900px) {
  .kit-header { position: relative; }
  .kit-nav-toggle { display: flex; }
  /* mobile: the page-nav links live in the toggle drawer; the white bar keeps
     the search pill (left) visible + reachable. */
  .kit-pagebar { border-top: none; }
  .kit-nav--mobileonly { display: flex; }
  .kit-pagebar-inner { padding-block: 0.3rem; min-height: 0; }
  .kit-pagebar-search { margin-right: auto; }
  .kit-navwrap {
    position: absolute;
    left: 0; right: 0;
    top: 100%;
    align-items: stretch;
    flex-direction: column;
    gap: 0;
    background: var(--kit-bg);
    border-bottom: 1px solid var(--kit-border);
    box-shadow: 0 16px 30px -20px rgba(0, 0, 0, 0.5);
    padding: 0.5rem clamp(1.25rem, 5vw, 2.5rem) 1.25rem;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
    transition: max-height 0.3s ease, opacity 0.2s ease;
    z-index: 55;
  }
  .kit-navwrap.is-open { max-height: 85vh; overflow-y: auto; opacity: 1; pointer-events: auto; }
  .kit-nav { flex-direction: column; align-items: stretch; gap: 0; width: 100%; }
  /* the PRIMARY nav is first in source -> it reveals at the TOP of the drawer */
  .kit-nav--pages { order: 0; }
  /* account/basket icons sit between primary and secondary, as a labelled row */
  .kit-nav-icons { order: 1; width: 100%; flex-direction: column; align-items: stretch; gap: 0; }
  .kit-nav-icons .kit-util-link { display: flex; align-items: center; gap: 0.6rem; padding: 0.8rem 0; border-bottom: 1px solid var(--kit-border); border-radius: 0; width: auto; height: auto; justify-content: flex-start; text-transform: uppercase; font-weight: 600; font-size: 0.85rem; }
  .kit-nav-icons .kit-nav-icon-label { display: inline; }
  /* the SECONDARY (About/Support/Contact) is last in source -> LOWER in the drawer */
  .kit-nav--top { order: 2; border-top: 1px solid var(--kit-border); padding-top: 0.3rem; margin-top: 0.3rem; }
  .kit-nav a, .kit-nav-ddbtn { padding: 0.8rem 0; border-bottom: 1px solid var(--kit-border); text-transform: uppercase; }
  .kit-nav a:not(.kit-btn)::after { display: none; }
  .kit-nav--pages .kit-nav-link.is-active { border-bottom: 1px solid var(--kit-border); }
  .kit-nav-dd { width: 100%; }
  .kit-nav-ddbtn { width: 100%; justify-content: space-between; }
  /* split dropdown (Blog) on mobile: label-link fills the row, caret button on
     the right keeps the row's tap rhythm + opens the submenu. */
  .kit-nav-dd--split { width: 100%; justify-content: space-between; gap: 0; border-bottom: 1px solid var(--kit-border); }
  .kit-nav-dd--split .kit-nav-ddlabel { flex: 1; padding: 0.8rem 0; border-bottom: none; }
  .kit-nav-ddcaretbtn { padding: 0.8rem 0.5rem; border-bottom: none; }
  /* dropdowns: collapsed by default on mobile, EXPAND ON TAP (aria-expanded).
     Progressive enhancement — with JS off they fall back to always-open so no
     link is ever unreachable. */
  .kit-nav-ddmenu { position: static; box-shadow: none; border: none; margin: 0; padding: 0 0 0 0.8rem; min-width: 0; opacity: 1; visibility: visible; transform: none; }
  .kit-nav-dd--split .kit-nav-ddmenu { flex-basis: 100%; }
  .kit-nav-ddlink { border-bottom: 1px solid var(--kit-border); border-radius: 0; }
  .kit-nav-cta { margin-top: 0.85rem; border-bottom: none; }
}
/* Mobile dropdown collapse/expand — only when JS has marked the page (so a
   no-JS visitor keeps every link visible). The .kit-js flag is set by kit.js. */
@media (max-width: 900px) {
  .kit-js .kit-navwrap .kit-nav-ddbtn[aria-expanded="false"] + .kit-nav-ddmenu,
  .kit-js .kit-navwrap .kit-nav-ddcaretbtn[aria-expanded="false"] + .kit-nav-ddmenu { display: none; }
}
@media (max-width: 900px) { .kit-brandbar-cta { display: none; } }

/* ============ 4. hero ============ */
.kit-hero {
  position: relative;
  padding-block: clamp(1.6rem, 3vw, 2.5rem);
  background:
    radial-gradient(120% 120% at 100% 0%, color-mix(in srgb, var(--kit-accent) 12%, transparent) 0%, transparent 55%),
    var(--kit-surface);
  overflow: hidden;
}
.kit-hero-inner { text-align: center; max-width: 820px; }
.kit-hero-copy h1 { margin-bottom: 0.3em; }
.kit-hero-sub {
  font-size: clamp(1.05rem, 1rem + 0.4vw, 1.25rem);
  color: var(--kit-muted);
  margin: 0 auto 1.2rem;
  max-width: 60ch;
}
.kit-hero-actions { display: flex; gap: 0.85rem; justify-content: center; flex-wrap: wrap; }

/* split hero with media */
.kit-hero--split .kit-hero-inner {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
  text-align: left;
  max-width: var(--kit-max-width, 1120px);
}
.kit-hero--split .kit-hero-sub { margin-inline: 0; }
.kit-hero--split .kit-hero-actions { justify-content: flex-start; }
.kit-hero-media img {
  width: 100%;
  border-radius: calc(var(--kit-radius) * 1.6);
  box-shadow: 0 30px 60px -30px rgba(0, 0, 0, 0.4);
  aspect-ratio: 4 / 5;
  object-fit: cover;
}
@media (max-width: 820px) {
  .kit-hero--split .kit-hero-inner { grid-template-columns: 1fr; text-align: center; }
  .kit-hero--split .kit-hero-sub { margin-inline: auto; }
  .kit-hero--split .kit-hero-actions { justify-content: center; }
  .kit-hero-media { order: -1; max-width: 420px; margin-inline: auto; }
}

/* ============ 5. section / richtext ============
   Spacing tightened (Damian: "masses of too much space around elements") —
   sections, intros, CTAs and gaps pulled in for a compact, professional feel. */
.kit-section { padding-block: clamp(1.25rem, 2.4vw, 1.9rem); }
.kit-section > .kit-section-inner > h2 { max-width: 24ch; margin-bottom: 0.4em; }
.kit-section-intro {
  color: var(--kit-muted);
  max-width: 62ch;
  font-size: 1.04rem;
  margin-bottom: 1.3rem;
}
.kit-richtext { max-width: 68ch; }
/* a richtext section directly after an article body (e.g. a post split around a
   video embed) keeps the article's narrow, centred measure so the text aligns. */
.kit-article + .kit-section .kit-richtext,
.kit-section:has(> .kit-section-inner > .kit-richtext) > .kit-section-inner { max-width: 46rem; }
.kit-richtext p { margin-bottom: 1.1rem; }
.kit-richtext a { font-weight: 500; }
.kit-section-cta { margin-top: 1.5rem; }
.kit-section-cta--left { text-align: left; }

/* ============ 6. featured work + cards ============ */
.kit-card {
  background: var(--kit-bg);
  border: 1px solid var(--kit-border);
  border-radius: calc(var(--kit-radius) * 1.3);
  overflow: hidden;
  transition: transform 0.2s ease, box-shadow 0.25s ease, border-color 0.2s ease;
}
.kit-card:hover {
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--kit-accent) 35%, var(--kit-border));
  box-shadow: 0 24px 44px -28px rgba(0, 0, 0, 0.45);
}

.kit-featured-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 300px), 1fr));
  gap: clamp(1.25rem, 3vw, 2rem);
}
.kit-featured-media { display: block; aspect-ratio: 3 / 2; overflow: hidden; }
.kit-featured-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.kit-featured-card:hover .kit-featured-media img { transform: scale(1.04); }
.kit-card-body { padding: 1.25rem 1.4rem 1.5rem; }
.kit-card-tag {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--kit-accent);
  margin: 0 0 0.4rem;
}
.kit-card-title { margin: 0 0 0.4rem; }
.kit-card-title a { color: inherit; text-decoration: none; }
.kit-card-title a:hover { color: var(--kit-accent); }
.kit-card-summary { color: var(--kit-muted); margin: 0; font-size: 0.97rem; }

/* empty state — calm, branded, never a broken-looking blank grid */
.kit-empty {
  grid-column: 1 / -1;
  list-style: none;
  text-align: center;
  color: var(--kit-muted);
  background: var(--kit-surface);
  border: 1.5px dashed var(--kit-border);
  border-radius: calc(var(--kit-radius) * 1.2);
  padding: 2.5rem 1.5rem;
  margin: 0;
}

/* ============ 7. gallery ============ */
.kit-gallery { list-style: none; margin: 0; padding: 0; }
.kit-gallery--grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr));
  gap: clamp(0.85rem, 2vw, 1.25rem);
}
.kit-gallery--wide {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 380px), 1fr));
  gap: clamp(0.85rem, 2vw, 1.5rem);
}
/* masonry via CSS columns — graceful, no JS */
.kit-gallery--masonry { columns: 3 240px; column-gap: clamp(0.85rem, 2vw, 1.25rem); }
.kit-gallery--masonry .kit-gallery-item { break-inside: avoid; margin-bottom: clamp(0.85rem, 2vw, 1.25rem); }

.kit-gallery-item { margin: 0; }
.kit-gallery figure {
  margin: 0;
  position: relative;
  border-radius: var(--kit-radius);
  overflow: hidden;
  background: var(--kit-surface);
}
.kit-gallery--grid figure img,
.kit-gallery--wide figure img { aspect-ratio: 1 / 1; object-fit: cover; width: 100%; }
.kit-gallery--wide figure img { aspect-ratio: 4 / 3; }
.kit-gallery figure img { transition: transform 0.4s ease; }
.kit-gallery figure:hover img { transform: scale(1.05); }
.kit-gallery figcaption {
  position: absolute;
  inset: auto 0 0 0;
  padding: 1.5rem 1rem 0.85rem;
  background: linear-gradient(to top, rgba(0,0,0,0.72), transparent);
  color: #fff;
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.25s ease, transform 0.25s ease;
}
.kit-gallery figure:hover figcaption,
.kit-gallery figure:focus-within figcaption { opacity: 1; transform: translateY(0); }
.kit-gallery-title { font-weight: 600; }
.kit-gallery-meta { font-size: 0.85rem; opacity: 0.85; }
.kit-gallery-link { display: block; cursor: zoom-in; }
.kit-gallery-link:focus-visible { outline: 3px solid var(--kit-accent); outline-offset: 2px; }

/* lightbox dialog (A5) — only used when JS is on; degrades to a plain image link */
.kit-lightbox {
  border: none;
  background: transparent;
  max-width: 96vw;
  max-height: 96vh;
  padding: 0;
  margin: auto;
  color: #fff;
}
.kit-lightbox::backdrop { background: rgba(0, 0, 0, 0.86); }
.kit-lightbox[open] {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 0.5rem;
}
.kit-lightbox-figure { margin: 0; text-align: center; }
.kit-lightbox-figure img {
  max-width: 88vw;
  max-height: 84vh;
  border-radius: var(--kit-radius);
  display: block;
  margin: 0 auto;
}
.kit-lightbox-figure figcaption { margin-top: 0.6rem; font-size: 0.95rem; opacity: 0.9; }
.kit-lightbox-close,
.kit-lightbox-nav {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  border: none;
  border-radius: 50%;
  width: 2.75rem;
  height: 2.75rem;
  font-size: 1.6rem;
  line-height: 1;
  cursor: pointer;
}
.kit-lightbox-close { position: fixed; top: 1rem; right: 1rem; }
.kit-lightbox-close:hover,
.kit-lightbox-nav:hover { background: rgba(255, 255, 255, 0.24); }
.kit-lightbox-close:focus-visible,
.kit-lightbox-nav:focus-visible { outline: 3px solid #fff; outline-offset: 2px; }
@media (max-width: 640px) {
  .kit-lightbox[open] { grid-template-columns: 1fr; }
  .kit-lightbox-nav { position: fixed; bottom: 1rem; }
  .kit-lightbox-prev { left: 1rem; }
  .kit-lightbox-next { right: 1rem; }
}

/* ============ 7b. blog / article (A6) ============ */
.kit-article-inner { max-width: 46rem; }
.kit-article-title { font-size: clamp(1.8rem, 4vw, 2.6rem); margin: 0.25rem 0 0.5rem; }
.kit-article-meta { color: var(--kit-muted); font-size: 0.9rem; margin: 0 0 1.25rem; }
.kit-article-cover { width: 100%; border-radius: var(--kit-radius); margin-bottom: 1.5rem; }
.kit-article-body { font-size: 1.05rem; line-height: 1.7; }
.kit-article-tags, .kit-post-card .kit-article-tags { list-style: none; display: flex; flex-wrap: wrap; gap: 0.5rem; padding: 0; margin: 1.5rem 0 0; }
.kit-tag {
  font-size: 0.78rem; padding: 0.2rem 0.6rem; border-radius: 999px;
  background: color-mix(in srgb, var(--kit-accent) 12%, transparent); color: var(--kit-fg);
}
.kit-post-list { list-style: none; margin: 0; padding: 0; display: grid; gap: clamp(1.25rem, 3vw, 2rem); }
.kit-post-card {
  border: 1px solid var(--kit-border); border-radius: calc(var(--kit-radius) * 1.2);
  background: var(--kit-surface); padding: clamp(1.25rem, 3vw, 1.75rem);
}
.kit-post-title { margin: 0.1rem 0 0.4rem; font-size: 1.3rem; }
.kit-post-title a { color: var(--kit-fg); text-decoration: none; }
.kit-post-title a:hover { color: var(--kit-accent); }
.kit-post-summary { margin: 0; color: var(--kit-muted); }

/* optional cover image on a post card (carousel + grid) */
.kit-post-card { padding: 0; overflow: hidden; display: flex; flex-direction: column; }
.kit-post-card > article { display: flex; flex-direction: column; height: 100%; }
.kit-post-cover { display: block; aspect-ratio: 16 / 9; overflow: hidden; background: color-mix(in srgb, var(--kit-accent) 10%, var(--kit-surface)); }
.kit-post-cover img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.kit-post-card:hover .kit-post-cover img { transform: scale(1.04); }
.kit-post-body { padding: clamp(1.1rem, 3vw, 1.6rem); display: flex; flex-direction: column; flex: 1; }
.kit-post-body .kit-article-tags { margin-top: auto; padding-top: 1rem; }

/* ---- blog carousel (the live homepage journal strip) ---- */
.kit-carousel { position: relative; }
.kit-carousel-track {
  display: flex; gap: clamp(1rem, 2.5vw, 1.6rem);
  overflow-x: auto; scroll-snap-type: x mandatory;
  scroll-behavior: smooth; padding: 0.5rem 0.25rem 1.25rem;
  -webkit-overflow-scrolling: touch; scrollbar-width: thin;
}
.kit-carousel-slide {
  flex: 0 0 calc((100% - clamp(1rem, 2.5vw, 1.6rem)) / 2);
  scroll-snap-align: start;
}
@media (max-width: 760px) { .kit-carousel-slide { flex-basis: 88%; } }
@media (min-width: 1100px) { .kit-carousel-slide { flex-basis: calc((100% - 2 * clamp(1rem, 2.5vw, 1.6rem)) / 3); } }
.kit-carousel-arrow {
  position: absolute; top: 40%; transform: translateY(-50%);
  z-index: 3; width: 42px; height: 42px; border-radius: 999px;
  border: 1px solid var(--kit-border); background: color-mix(in srgb, var(--kit-bg) 85%, transparent);
  backdrop-filter: blur(4px); color: var(--kit-fg);
  font-size: 1.5rem; line-height: 1; cursor: pointer;
  display: grid; place-items: center; box-shadow: 0 6px 18px -8px rgba(16,24,40,.3);
  transition: background .15s, color .15s, border-color .15s, opacity .15s;
}
.kit-carousel-arrow:hover { background: var(--kit-accent); color: var(--kit-accent-contrast); border-color: var(--kit-accent); }
.kit-carousel-arrow[hidden] { display: none; }
.kit-carousel-prev { left: -8px; }
.kit-carousel-next { right: -8px; }
@media (max-width: 760px) { .kit-carousel-arrow { display: none; } }
.kit-carousel-track:focus-visible { outline: 3px solid color-mix(in srgb, var(--kit-accent) 60%, transparent); outline-offset: 3px; border-radius: var(--kit-radius); }

/* ============ 8. feature grid ============ */
.kit-feature-grid {
  list-style: none; margin: 0; padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
  gap: clamp(0.85rem, 1.8vw, 1.35rem);
}
.kit-feature {
  padding: 1.15rem 1.25rem;
  border: 1px solid var(--kit-border);
  border-radius: calc(var(--kit-radius) * 1.2);
  background: var(--kit-surface);
}
.kit-feature-icon {
  display: inline-flex;
  font-size: 1.35rem;
  width: 2.4rem; height: 2.4rem;
  align-items: center; justify-content: center;
  border-radius: 50%;
  background: color-mix(in srgb, var(--kit-accent) 14%, transparent);
  margin-bottom: 0.6rem;
}
.kit-feature-title { margin: 0 0 0.3rem; font-size: 1.12rem; }
.kit-feature-body { margin: 0; color: var(--kit-muted); font-size: 0.97rem; }

/* ============ 8a. explore-by-medium image tiles (live hallmark) ============ */
.kit-medium-section { background: var(--kit-bg); }
.kit-medium-h { text-align: center; }
.kit-medium-intro { text-align: center; margin-inline: auto; }
.kit-medium-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
}
@media (max-width: 991px) { .kit-medium-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .kit-medium-grid { grid-template-columns: 1fr; } }
.kit-medium-card {
  position: relative; display: flex; align-items: center; justify-content: center;
  min-height: 260px; padding: 36px 24px; border-radius: calc(var(--kit-radius) * 1.4);
  overflow: hidden; text-decoration: none;
  background-color: var(--kit-accent-2, #8f8074); background-size: cover; background-position: center;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  box-shadow: 0 12px 30px -22px rgba(0,0,0,0.55);
}
.kit-medium-card:hover { transform: translateY(-3px); box-shadow: 0 18px 36px -20px rgba(0,0,0,0.6); }
.kit-medium-card-inner {
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 0.6rem;
}
.kit-medium-title { font-family: var(--kit-font-heading); font-weight: 600; font-size: 1.5rem; color: #fff; }
.kit-medium-body { font-size: 0.95rem; color: #f5f0e9; line-height: 1.5; max-width: 22ch; }
.kit-medium-btn {
  margin-top: 0.35rem; display: inline-block; background: #fff; color: var(--kit-fg);
  font-family: var(--kit-font-heading); font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.02em;
  padding: 0.5rem 1.25rem; border-radius: 999px;
}
.kit-medium-card:hover .kit-medium-btn { background: var(--kit-accent); color: var(--kit-accent-contrast); }

/* ============ 8a2. shop category tiles ============ */
.kit-cattiles { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: clamp(0.85rem, 1.8vw, 1.35rem); }
.kit-cattile {
  display: flex; flex-direction: column; text-decoration: none; color: var(--kit-fg);
  border: 1px solid var(--kit-border); border-radius: calc(var(--kit-radius) * 1.2);
  overflow: hidden; background: var(--kit-surface); transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.kit-cattile:hover { transform: translateY(-3px); box-shadow: 0 16px 32px -22px rgba(0,0,0,0.5); }
.kit-cattile-media { display: block; aspect-ratio: 4 / 3; overflow: hidden; background: color-mix(in srgb, var(--kit-accent) 10%, var(--kit-surface)); }
.kit-cattile-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.kit-cattile:hover .kit-cattile-media img { transform: scale(1.05); }
.kit-cattile-body { padding: 0.75rem 0.9rem; display: flex; align-items: baseline; justify-content: space-between; gap: 0.5rem; }
.kit-cattile-title { font-family: var(--kit-font-heading); font-weight: 600; font-size: 1rem; }
.kit-cattile-count { font-size: 0.78rem; color: var(--kit-muted); }

/* ============ 8a3. reads (book grid + book detail page) ============ */
.kit-reads-section .kit-reads-h { text-align: center; }
.kit-reads-intro { margin-left: auto; margin-right: auto; }
.kit-reads-grid {
  list-style: none; margin: 1.6rem 0 0; padding: 0;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: clamp(1.1rem, 2.4vw, 1.9rem);
}
@media (max-width: 560px) { .kit-reads-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; } }
.kit-read-card { display: flex; }
.kit-read-link {
  display: flex; flex-direction: column; gap: 0.55rem; width: 100%;
  text-decoration: none; color: var(--kit-fg);
}
.kit-read-cover {
  display: block; position: relative; aspect-ratio: 2 / 3; overflow: hidden;
  border-radius: calc(var(--kit-radius) * 0.8);
  background: color-mix(in srgb, var(--kit-accent) 8%, var(--kit-surface));
  box-shadow: 0 12px 26px -16px rgba(0,0,0,0.55);
  transition: transform 0.22s ease, box-shadow 0.22s ease;
}
.kit-read-link:hover .kit-read-cover { transform: translateY(-4px); box-shadow: 0 20px 38px -18px rgba(0,0,0,0.6); }
.kit-read-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.kit-read-cover--type { display: flex; align-items: center; justify-content: center;
  background: linear-gradient(150deg, color-mix(in srgb, var(--kit-accent) 80%, #000), var(--kit-accent)); }
.kit-read-cover-type { display: flex; flex-direction: column; gap: 0.5rem; padding: 1rem; text-align: center; color: #fff; }
.kit-read-cover-title { font-family: var(--kit-font-heading); font-weight: 700; font-size: 1.05rem; line-height: 1.2; }
.kit-read-cover-author { font-size: 0.78rem; opacity: 0.85; }
.kit-read-meta { display: flex; flex-direction: column; gap: 0.15rem; }
.kit-read-title { font-family: var(--kit-font-heading); font-weight: 600; font-size: 0.98rem; line-height: 1.25; }
.kit-read-link:hover .kit-read-title { color: var(--kit-accent); }
.kit-read-author { font-size: 0.82rem; color: var(--kit-muted); }
.kit-read-hook { font-size: 0.82rem; color: var(--kit-muted); margin-top: 0.2rem; }

.kit-book-inner.kit-book-inner {
  display: grid; grid-template-columns: minmax(200px, 280px) 1fr;
  gap: clamp(1.6rem, 4vw, 3rem); align-items: start;
}
@media (max-width: 640px) { .kit-book-inner.kit-book-inner { grid-template-columns: 1fr; max-width: 420px; } }
.kit-book-cover {
  position: relative; aspect-ratio: 2 / 3; overflow: hidden;
  border-radius: calc(var(--kit-radius) * 0.9);
  background: color-mix(in srgb, var(--kit-accent) 8%, var(--kit-surface));
  box-shadow: 0 20px 44px -20px rgba(0,0,0,0.6);
}
.kit-book-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.kit-book-cover--type { display: flex; align-items: center; justify-content: center;
  background: linear-gradient(150deg, color-mix(in srgb, var(--kit-accent) 80%, #000), var(--kit-accent)); }
.kit-book-cover-type { display: flex; flex-direction: column; gap: 0.6rem; padding: 1.4rem; text-align: center; color: #fff; }
.kit-book-cover-title { font-family: var(--kit-font-heading); font-weight: 700; font-size: 1.3rem; line-height: 1.2; }
.kit-book-cover-author { font-size: 0.9rem; opacity: 0.85; }
.kit-book-eyebrow { margin-top: 0; }
.kit-book-title { margin: 0.2rem 0 0.3rem; }
.kit-book-author { font-size: 1.05rem; color: var(--kit-muted); margin: 0 0 1rem; }
.kit-book-hook { font-size: 1.12rem; font-weight: 600; line-height: 1.45; margin: 0 0 1rem; }
.kit-book-take { color: var(--kit-fg); line-height: 1.7; }
.kit-book-take p { margin: 0 0 0.9rem; }
.kit-book-actions { display: flex; flex-wrap: wrap; gap: 0.7rem; margin: 1.4rem 0 0.8rem; }
.kit-book-buynote { font-size: 0.8rem; color: var(--kit-muted); margin: 0; }

/* ============ 8a4. podcast show grid ============ */
.kit-shows-section .kit-shows-h { text-align: center; }
.kit-shows-intro { margin-left: auto; margin-right: auto; }
.kit-shows-grid {
  list-style: none; margin: 1.6rem 0 0; padding: 0;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: clamp(1.2rem, 2.6vw, 2rem);
}
.kit-show-card {
  display: flex; flex-direction: column; overflow: hidden;
  border: 1px solid var(--kit-border); border-radius: calc(var(--kit-radius) * 1.2);
  background: var(--kit-surface); transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.kit-show-card:hover { transform: translateY(-3px); box-shadow: 0 18px 34px -22px rgba(0,0,0,0.5); }
.kit-show-cover {
  position: relative; aspect-ratio: 16 / 9; background-size: cover; background-position: center;
  background-color: color-mix(in srgb, var(--kit-accent) 12%, var(--kit-surface));
}
.kit-show-cover--type {
  display: flex; align-items: center; justify-content: center; padding: 1.4rem; text-align: center;
  background: linear-gradient(150deg, color-mix(in srgb, var(--kit-accent) 80%, #000), var(--kit-accent));
}
.kit-show-cover-type { font-family: var(--kit-font-heading); font-weight: 700; font-size: 1.3rem; color: #fff; }
.kit-show-status {
  position: absolute; top: 0.7rem; left: 0.7rem; font-size: 0.7rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.05em; padding: 0.3rem 0.6rem;
  border-radius: 999px; background: rgba(20,18,16,0.78); color: #fff;
}
.kit-show-status--live { background: var(--kit-accent); color: var(--kit-accent-contrast, #fff); }
.kit-show-body { padding: 1.1rem 1.2rem 1.3rem; display: flex; flex-direction: column; gap: 0.5rem; flex: 1; }
.kit-show-title { margin: 0; font-size: 1.15rem; }
.kit-show-host { margin: 0; font-size: 0.82rem; color: var(--kit-muted); font-style: italic; }
.kit-show-blurb { margin: 0; color: var(--kit-muted); line-height: 1.55; flex: 1; }
.kit-show-cta { align-self: flex-start; margin-top: 0.4rem; }

/* ============ 8a5. product showcase (with colourways) ============ */
.kit-product-inner { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: clamp(1.5rem, 4vw, 3rem); align-items: center; }
@media (max-width: 720px) { .kit-product-inner { grid-template-columns: 1fr; } }
.kit-product-hero {
  width: 100%; aspect-ratio: 4 / 3; object-fit: cover; display: block;
  border-radius: calc(var(--kit-radius) * 1.2); box-shadow: 0 20px 44px -22px rgba(0,0,0,0.5);
}
.kit-product-swatches { list-style: none; margin: 1rem 0 0; padding: 0; display: flex; flex-wrap: wrap; gap: 0.7rem; }
.kit-product-swatch-link {
  display: flex; flex-direction: column; align-items: center; gap: 0.35rem; width: 76px;
  text-decoration: none; color: var(--kit-muted); font-size: 0.74rem; text-align: center;
}
.kit-product-swatch-img { width: 64px; height: 64px; object-fit: cover; border-radius: 10px; border: 2px solid var(--kit-border); transition: border-color 0.18s ease; }
.kit-product-swatch-dot { width: 44px; height: 44px; border-radius: 50%; border: 2px solid var(--kit-border); display: block; }
.kit-product-swatch-link:hover .kit-product-swatch-img,
.kit-product-swatch-link:hover .kit-product-swatch-dot { border-color: var(--kit-accent); }
.kit-product-swatch-link:hover { color: var(--kit-accent); }
.kit-product-title { margin: 0 0 0.4rem; }
.kit-product-price { font-family: var(--kit-font-heading); font-weight: 700; font-size: 1.3rem; margin: 0 0 0.8rem; }
.kit-product-pricenote { font-weight: 400; font-size: 0.85rem; color: var(--kit-muted); }
.kit-product-desc { color: var(--kit-muted); line-height: 1.6; margin: 0 0 1.1rem; }
.kit-product-actions { margin-top: 1rem; }

/* ============ 8a6. tabbed blog (tab-topped, all-visible) ============ */
.kit-tabblog-tabs { display: flex; flex-wrap: wrap; gap: 0.5rem; border-bottom: 1px solid var(--kit-border); padding-bottom: 0.2rem; margin: 1.4rem 0 1.6rem; }
.kit-tabblog-tab {
  text-decoration: none; font-family: var(--kit-font-heading); font-weight: 600; font-size: 0.92rem;
  color: var(--kit-muted); padding: 0.5rem 0.95rem; border-radius: 999px 999px 0 0;
  border: 1px solid transparent; border-bottom: none; transition: color 0.16s ease, background 0.16s ease;
}
.kit-tabblog-tab:hover { color: var(--kit-accent); background: color-mix(in srgb, var(--kit-accent) 8%, transparent); }
.kit-tabblog-tab.is-active { color: var(--kit-accent); background: var(--kit-surface); border-color: var(--kit-border); }
.kit-tabblog-panel { margin: 0 0 2.4rem; scroll-margin-top: 90px; }
.kit-tabblog-panel-h { font-size: 1.2rem; margin: 0 0 1rem; }
.kit-tabblog-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 1.1rem; }
.kit-tabblog-item { display: grid; grid-template-columns: 88px 1fr; gap: 1rem; align-items: start; }
@media (max-width: 480px) { .kit-tabblog-item { grid-template-columns: 1fr; } }
.kit-tabblog-thumb img { width: 88px; height: 66px; object-fit: cover; border-radius: 8px; border: 1px solid var(--kit-border); }
.kit-tabblog-title { font-family: var(--kit-font-heading); font-weight: 600; text-decoration: none; color: var(--kit-fg); }
.kit-tabblog-title:hover { color: var(--kit-accent); }
.kit-tabblog-date { display: block; font-size: 0.78rem; color: var(--kit-muted); margin-top: 0.15rem; }
.kit-tabblog-summary { margin: 0.35rem 0 0; color: var(--kit-muted); font-size: 0.9rem; line-height: 1.5; }

/* ============ 8b. onboarding steps (guided self-serve) ============ */
.kit-steps { list-style: none; margin: 0; padding: 0; display: grid; gap: 1.1rem; }
.kit-step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem 1.1rem;
  align-items: start;
  padding: 1.4rem 1.5rem;
  border: 1px solid var(--kit-border);
  border-radius: calc(var(--kit-radius) * 1.2);
  background: var(--kit-surface);
}
.kit-step-num {
  display: inline-flex;
  width: 2.4rem; height: 2.4rem;
  align-items: center; justify-content: center;
  border-radius: 50%;
  font-weight: 700;
  background: var(--kit-accent);
  color: var(--kit-accent-contrast);
}
.kit-step-title { margin: 0.25rem 0 0.4rem; font-size: 1.15rem; }
.kit-step-text { margin: 0 0 0.5rem; color: var(--kit-muted); }
.kit-step-note {
  margin: 0 0 0.5rem;
  font-size: 0.9rem;
  color: var(--kit-muted);
  padding: 0.5rem 0.7rem;
  border-left: 3px solid color-mix(in srgb, var(--kit-accent) 50%, var(--kit-border));
  background: color-mix(in srgb, var(--kit-accent) 6%, transparent);
  border-radius: 0 6px 6px 0;
}
.kit-step-link { margin: 0; font-weight: 600; }

/* ============ 8c. pricing tiers (3-tier offering shape) ============ */
.kit-pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
  gap: clamp(1.25rem, 3vw, 1.75rem);
  align-items: stretch;
}
.kit-tier {
  display: flex; flex-direction: column;
  padding: 1.75rem 1.6rem;
  border: 1px solid var(--kit-border);
  border-radius: calc(var(--kit-radius) * 1.3);
  background: var(--kit-surface);
}
.kit-tier--featured {
  border-color: var(--kit-accent);
  box-shadow: 0 18px 40px -22px color-mix(in srgb, var(--kit-accent) 60%, transparent);
}
.kit-tier-badge {
  align-self: flex-start;
  margin: 0 0 0.75rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.3rem 0.65rem;
  border-radius: 999px;
  background: var(--kit-accent);
  color: var(--kit-accent-contrast);
}
.kit-tier-name { margin: 0 0 0.3rem; font-size: 1.35rem; }
.kit-tier-summary { margin: 0 0 1rem; color: var(--kit-muted); font-size: 0.97rem; }
.kit-tier-price { margin: 0 0 0.15rem; }
.kit-tier-amount { font-size: 2rem; font-weight: 700; }
.kit-tier-suffix { color: var(--kit-muted); font-size: 0.95rem; }
.kit-tier-pricenote { margin: 0 0 1.1rem; font-size: 0.82rem; color: var(--kit-muted); font-style: italic; }
.kit-tier-features { list-style: none; margin: 0 0 1.4rem; padding: 0; display: grid; gap: 0.55rem; }
.kit-tier-features li {
  position: relative;
  padding-left: 1.5rem;
  font-size: 0.95rem;
}
.kit-tier-features li::before {
  content: "✓";
  position: absolute; left: 0;
  color: var(--kit-accent);
  font-weight: 700;
}
.kit-tier-cta { margin: auto 0 0; }
.kit-tier-cta .kit-btn { width: 100%; text-align: center; }
.kit-pricing-footnote { margin: 1.5rem 0 0; text-align: center; color: var(--kit-muted); font-size: 0.88rem; }

/* ============ 9. stat band ============ */
.kit-stat-band { background: var(--kit-surface); border-block: 1px solid var(--kit-border); }
.kit-stat-inner {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 1.5rem;
  padding-block: clamp(2rem, 4vw, 3rem);
  text-align: center;
}
.kit-stat { display: flex; flex-direction: column; gap: 0.25rem; }
.kit-stat-value {
  font-family: var(--kit-font-heading, var(--kit-font-body));
  font-size: clamp(2rem, 1.4rem + 2vw, 3rem);
  font-weight: 700;
  color: var(--kit-accent);
  line-height: 1;
}
.kit-stat-label { color: var(--kit-muted); font-size: 0.95rem; }

/* ============ 10. testimonials ============ */
.kit-testimonials {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr));
  gap: clamp(1.25rem, 3vw, 2rem);
}
.kit-testimonial { padding: 1.75rem; display: flex; flex-direction: column; gap: 1rem; }
.kit-quote {
  margin: 0;
  font-size: 1.1rem;
  line-height: 1.55;
  font-family: var(--kit-font-heading, var(--kit-font-body));
}
.kit-quote::before { content: "\201C"; color: var(--kit-accent); font-size: 1.4em; line-height: 0; vertical-align: -0.3em; margin-right: 0.05em; }
.kit-quote-by { display: flex; flex-direction: column; }
.kit-quote-name { font-weight: 600; }
.kit-quote-role { color: var(--kit-muted); font-size: 0.9rem; }

/* ============ 11. about (split) ============ */
.kit-about--split .kit-about-inner {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}
.kit-about-media img {
  width: 100%;
  border-radius: calc(var(--kit-radius) * 1.5);
  aspect-ratio: 4 / 5;
  object-fit: cover;
  box-shadow: 0 30px 60px -34px rgba(0, 0, 0, 0.45);
}
@media (max-width: 820px) {
  .kit-about--split .kit-about-inner { grid-template-columns: 1fr; }
  .kit-about-media { max-width: 380px; }
}

/* ============ 12. cta band ============ */
.kit-cta-band {
  background:
    radial-gradient(120% 140% at 0% 0%, color-mix(in srgb, var(--kit-accent-2) 75%, black 0%) 0%, transparent 60%),
    var(--kit-accent);
  color: var(--kit-accent-contrast);
}
.kit-cta-inner {
  padding-block: clamp(3rem, 6vw, 5rem);
  text-align: center;
  max-width: 720px;
}
.kit-cta-heading { color: var(--kit-accent-contrast); margin-bottom: 0.5rem; }
.kit-cta-body { color: color-mix(in srgb, var(--kit-accent-contrast) 88%, transparent); font-size: 1.1rem; margin-bottom: 1.75rem; }
.kit-cta-actions { display: flex; gap: 0.85rem; justify-content: center; flex-wrap: wrap; }

/* ============ 13. contact + form ============ */
.kit-contact-inner {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
@media (max-width: 768px) { .kit-contact-inner { grid-template-columns: 1fr; } }
.kit-contact-details { list-style: none; margin: 1.5rem 0 0; padding: 0; display: flex; flex-direction: column; gap: 1rem; }
.kit-contact-detail { display: flex; flex-direction: column; gap: 0.15rem; }
.kit-contact-label { font-size: 0.78rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--kit-muted); }
.kit-contact-detail a { font-weight: 500; }

.kit-form {
  background: var(--kit-surface);
  border: 1px solid var(--kit-border);
  border-radius: calc(var(--kit-radius) * 1.3);
  padding: clamp(1.5rem, 3vw, 2.25rem);
}
.kit-form-note { font-size: 0.88rem; color: var(--kit-muted); margin-bottom: 1.25rem; }
.kit-field { margin-bottom: 1.1rem; display: flex; flex-direction: column; gap: 0.35rem; }
.kit-field label { font-weight: 600; font-size: 0.92rem; }
.kit-field input,
.kit-field textarea {
  font: inherit;
  color: var(--kit-fg);
  background: var(--kit-bg);
  border: 1.5px solid var(--kit-border);
  border-radius: var(--kit-radius);
  padding: 0.7rem 0.85rem;
  width: 100%;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}
.kit-field input:focus,
.kit-field textarea:focus {
  outline: none;
  border-color: var(--kit-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--kit-accent) 22%, transparent);
}
.kit-field textarea { resize: vertical; }
/* honeypot: removed from layout + a11y tree; only bots reach it */
.kit-hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

/* ============ 14. SDK blocks (events / LMS) ============ */
.kit-sdk-block {
  position: relative;
  margin: 1.5rem 0 0;
  padding: 1.25rem;
  border: 1px solid var(--kit-border);
  border-radius: calc(var(--kit-radius) * 1.2);
  background: var(--kit-surface);
}
.kit-test-badge {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 0.22rem 0.55rem;
  border-radius: 999px;
  background: #f0a000;
  color: #1a1300;
}
.kit-sdk-placeholder {
  padding: 2.5rem 1rem;
  text-align: center;
  color: var(--kit-muted);
  border: 1.5px dashed var(--kit-border);
  border-radius: var(--kit-radius);
}
.kit-sdk-placeholder span { font-weight: 700; color: var(--kit-fg); }

/* Visitor-facing LMS loading/empty state (replaces the old debug-string
   placeholder). A calm, on-brand card with a subtle shimmer skeleton + an honest
   line — what a polished creator site shows before an embed mounts or before the
   member signs in. Light/cream theme only. */
.kit-sdk-empty {
  padding: 2.25rem 1.5rem;
  text-align: center;
  border: 1px solid var(--kit-border);
  border-radius: var(--kit-radius);
  background: var(--kit-surface);
}
.kit-sdk-empty-title { margin: 0.9rem 0 0.3rem; font-weight: 700; color: var(--kit-fg); font-size: 1.05rem; }
.kit-sdk-empty-body { margin: 0 auto; max-width: 46ch; color: var(--kit-muted); font-size: 0.95rem; line-height: 1.5; }
.kit-sdk-skeleton { display: flex; flex-direction: column; gap: 0.6rem; max-width: 22rem; margin: 0 auto; }
.kit-sdk-skeleton span {
  display: block; height: 0.85rem; border-radius: 999px;
  background: linear-gradient(90deg,
    color-mix(in srgb, var(--kit-border) 60%, transparent) 25%,
    color-mix(in srgb, var(--kit-border) 30%, transparent) 37%,
    color-mix(in srgb, var(--kit-border) 60%, transparent) 63%);
  background-size: 400% 100%;
  animation: kit-shimmer 1.4s ease-in-out infinite;
}
.kit-sdk-skeleton span:nth-child(1) { width: 80%; }
.kit-sdk-skeleton span:nth-child(2) { width: 100%; }
.kit-sdk-skeleton span:nth-child(3) { width: 60%; }
@keyframes kit-shimmer { 0% { background-position: 100% 0; } 100% { background-position: 0 0; } }
@media (prefers-reduced-motion: reduce) { .kit-sdk-skeleton span { animation: none; } }

/* Events stub — deliberately distinct from the LMS TEST badge so it reads as
   "not wired yet", not "test mode". Neutral, not amber. */
.kit-events-stub { background: var(--kit-surface); }
.kit-stub-badge {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 0.22rem 0.55rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--kit-muted) 22%, transparent);
  color: var(--kit-muted);
  border: 1px dashed var(--kit-border);
}
.kit-sdk-placeholder.kit-stub { text-align: left; padding: 1.75rem 1.5rem; }
.kit-sdk-placeholder.kit-stub p { margin: 0 0 0.75rem; }
.kit-stub-note { font-weight: 500; color: var(--kit-fg); }
.kit-stub-code {
  margin: 0.5rem 0 0;
  padding: 0.9rem 1rem;
  overflow-x: auto;
  font-size: 0.78rem;
  line-height: 1.5;
  background: var(--kit-bg);
  border: 1px solid var(--kit-border);
  border-radius: var(--kit-radius);
  color: var(--kit-fg);
}
.kit-sdk-placeholder.kit-stub code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }

/* ============ 14a. events-list (like-for-like with live cp52-events grid) ===
   A faithful port of the live damiansemonin.art /events-list/ card grid. All
   rules are scoped under `.cp52ev` (the wrapper carries `--accent` inline from
   the brand) so nothing leaks into the rest of the kit page — exactly like the
   plugin's own self-contained stylesheet. Tokens mirror the plugin defaults but
   take the brand surface/ink/line for coherence with the rest of the site. */
.cp52ev {
  --accent-tint: color-mix(in srgb, var(--accent) 12%, transparent);
  --ink: var(--kit-fg);
  --muted: var(--kit-muted);
  --faint: color-mix(in srgb, var(--kit-fg) 45%, transparent);
  --line: var(--kit-border);
  --surface: #fff;
  --ok: #2f8f5b; --warn: #c1762a; --danger: #b4503f;
  --radius: calc(var(--kit-radius) * 1.4);
  --shadow-sm: 0 1px 2px rgba(16,24,40,.05);
  --shadow-md: 0 1px 2px rgba(16,24,40,.04), 0 10px 28px rgba(16,24,40,.08);
  color: var(--ink);
  line-height: 1.5;
}
.cp52ev .ev-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 22px;
  padding: 4px;
}
.cp52ev .ev-card[hidden] { display: none; }
/* filter toolbar (by medium + by time) */
.cp52ev .ev-filters { display: flex; flex-direction: column; gap: 0.8rem; margin: 0 4px 1.4rem; }
.cp52ev .ev-filter-group { display: flex; align-items: center; gap: 0.7rem; flex-wrap: wrap; }
.cp52ev .ev-filter-label { font-family: var(--kit-font-heading, inherit); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); min-width: 3.6rem; }
.cp52ev .ev-filter-row { display: flex; gap: 0.45rem; flex-wrap: wrap; }
.cp52ev .ev-filter-btn {
  font: inherit; font-size: 0.82rem; cursor: pointer; padding: 0.4rem 0.95rem;
  border-radius: 999px; border: 1px solid var(--line); background: var(--surface); color: var(--ink);
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.cp52ev .ev-filter-btn:hover { border-color: var(--accent); color: var(--accent); }
.cp52ev .ev-filter-btn.is-on { background: var(--accent); border-color: var(--accent); color: #fff; }
.cp52ev .ev-filter-empty { color: var(--muted); font-size: 0.95rem; margin: 0.4rem 0 0; }
.cp52ev .ev-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-sm);
  transition: box-shadow .18s, transform .18s, border-color .18s;
}
.cp52ev .ev-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--accent) 35%, var(--line));
}
.cp52ev .ev-card.is-past { opacity: .66; filter: saturate(.65); }
.cp52ev .ev-card.is-past:hover { transform: none; box-shadow: var(--shadow-sm); }
.cp52ev .ev-img {
  height: 172px;
  position: relative;
  overflow: hidden;
  display: block;
  background: linear-gradient(135deg, var(--accent), var(--accent-deep, var(--accent)));
}
.cp52ev .ev-img::after {
  content: ""; position: absolute; inset: 0; opacity: .16;
  background-image:
    radial-gradient(circle at 18% 22%, rgba(255,255,255,.9) 0 2px, transparent 3px),
    radial-gradient(circle at 78% 64%, rgba(255,255,255,.7) 0 6px, transparent 8px),
    linear-gradient(115deg, transparent 40%, rgba(255,255,255,.25) 41% 44%, transparent 45%);
}
.cp52ev .ev-img img { width: 100%; height: 100%; object-fit: cover; position: relative; z-index: 1; }
.cp52ev .ev-date {
  position: absolute; top: 10px; left: 10px; z-index: 2;
  background: #fff; border-radius: 9px; overflow: hidden;
  text-align: center; line-height: 1; min-width: 46px;
  box-shadow: 0 3px 10px rgba(0,0,0,.24); font-family: inherit;
}
.cp52ev .ev-date--right { left: auto; right: 10px; }
.cp52ev .ev-date .m {
  display: block; background: var(--accent); color: #fff;
  font-size: 11px; font-weight: 700; letter-spacing: .07em;
  text-transform: uppercase; padding: 3px 8px;
}
.cp52ev .ev-date .d { display: block; font-size: 22px; font-weight: 800; color: #23303a; padding: 4px 8px 5px; }
.cp52ev .ev-card.is-past .ev-date .m { background: #9aa3ab; }
.cp52ev .ev-card-body { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.cp52ev .ev-card h3 { margin: 0; font-size: 18px; line-height: 1.25; }
.cp52ev .ev-card h3 a { color: var(--ink); text-decoration: none; }
.cp52ev .ev-card h3 a:hover { color: var(--accent); }
.cp52ev .ev-meta { display: flex; flex-direction: column; gap: 7px; }
.cp52ev .ev-meta .row { display: flex; align-items: flex-start; gap: 9px; color: var(--muted); font-size: 14px; }
.cp52ev .ev-meta .row svg { flex: none; width: 16px; height: 16px; margin-top: 2px; color: var(--accent); }
.cp52ev .ev-card-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: auto; padding-top: 6px; }
.cp52ev .ev-price { font-weight: 800; color: var(--ink); font-size: 17px; }
.cp52ev .ev-price .per { font-weight: 600; color: var(--muted); font-size: .78em; }
.cp52ev .ev-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 700; padding: 5px 10px;
  border-radius: 999px; line-height: 1; white-space: nowrap;
}
.cp52ev .ev-badge .dot { width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.cp52ev .ev-badge--ok { background: rgba(47,143,91,.12); color: var(--ok); }
.cp52ev .ev-badge--low { background: rgba(193,118,42,.14); color: var(--warn); }
.cp52ev .ev-badge--out { background: rgba(180,80,63,.13); color: var(--danger); }
.cp52ev .ev-badge--past { background: #eef0f2; color: var(--faint); }

/* ---- sidebar layout (29-Jun workshops redesign): grid LEFT + filter RHS ---- */
.cp52ev--sidebar .ev-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) clamp(220px, 22%, 280px);
  gap: clamp(1.4rem, 3vw, 2.6rem);
  align-items: start;
}
/* 3-per-row event grid (the redesign asks for 3, not 4) */
.cp52ev .ev-grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.cp52ev .ev-grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
@media (max-width: 1024px) {
  .cp52ev .ev-grid--3, .cp52ev .ev-grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
  .cp52ev .ev-grid--3, .cp52ev .ev-grid--2 { grid-template-columns: 1fr; }
}
/* the right-hand filter rail */
.cp52ev .ev-sidebar {
  position: sticky; top: 1.5rem;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 1.1rem 1.15rem 1.25rem;
  box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column; gap: 0.85rem;
}
.cp52ev .ev-sidebar-h {
  margin: 0; font-family: var(--kit-font-heading, inherit);
  font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--muted);
}
.cp52ev .ev-sidebar-field { display: flex; flex-direction: column; gap: 0.35rem; }
.cp52ev .ev-sidebar-label {
  font-size: 0.82rem; font-weight: 700; color: var(--ink);
}
.cp52ev .ev-select-wrap { position: relative; }
.cp52ev .ev-select-wrap::after {
  content: "▾"; position: absolute; right: 0.7rem; top: 50%;
  transform: translateY(-50%); pointer-events: none;
  color: var(--accent); font-size: 0.7rem;
}
.cp52ev .ev-select {
  appearance: none; -webkit-appearance: none;
  width: 100%; font: inherit; font-size: 0.92rem;
  padding: 0.55rem 2rem 0.55rem 0.7rem;
  border: 1px solid var(--line); border-radius: calc(var(--kit-radius) * 0.9);
  background: #fff; color: var(--ink); cursor: pointer;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.cp52ev .ev-select:hover { border-color: var(--accent); }
.cp52ev .ev-select:focus-visible {
  outline: none; border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 22%, transparent);
}
.cp52ev .ev-sidebar-reset {
  align-self: flex-start; font: inherit; font-size: 0.82rem; cursor: pointer;
  background: none; border: none; padding: 0; color: var(--accent);
  text-decoration: underline; text-underline-offset: 2px;
}
.cp52ev .ev-sidebar-reset:hover { color: var(--accent-deep, var(--accent)); }
.cp52ev .ev-sidebar-count { margin: 0; font-size: 0.8rem; color: var(--muted); }
.cp52ev--sidebar .ev-filter-empty { margin: 0; }
/* On narrow screens drop the sidebar below the grid, full width, non-sticky */
@media (max-width: 760px) {
  .cp52ev--sidebar .ev-layout { grid-template-columns: 1fr; }
  .cp52ev .ev-sidebar { position: static; }
}

/* ============ 14b. storefront (CP52 eCommerce engine, REST) ============ */
.kit-storefront { padding: 1.5rem; }
.kit-storefront .kit-test-badge { position: static; display: inline-block; margin-bottom: 1rem; }
.kit-store-toolbar { display: flex; gap: 0.5rem; margin-bottom: 1.25rem; flex-wrap: wrap; }
.kit-store-q { flex: 1; min-width: 12rem; padding: 0.55rem 0.8rem; border: 1px solid var(--kit-border); border-radius: var(--kit-radius); background: var(--kit-bg); color: var(--kit-fg); }
.kit-store-search, .kit-store-clear, .kit-store-add, .kit-store-checkout, .kit-store-ordersbtn, .kit-store-refund {
  font: inherit; font-weight: 600; cursor: pointer; border-radius: var(--kit-radius);
  border: 1px solid var(--kit-border); background: var(--kit-bg); color: var(--kit-fg); padding: 0.5rem 0.9rem;
}
.kit-store-add, .kit-store-checkout, .kit-store-ordersbtn, .kit-store-search { background: var(--kit-accent); color: var(--kit-accent-contrast); border-color: transparent; }
.kit-store-add:hover, .kit-store-checkout:hover, .kit-store-search:hover { filter: brightness(1.05); }
.kit-store-add:disabled, .kit-store-checkout:disabled { opacity: 0.5; cursor: not-allowed; filter: none; }
.kit-store-grid-wrap { display: grid; grid-template-columns: 1fr 20rem; gap: 1.75rem; align-items: start; }
@media (max-width: 720px) { .kit-store-grid-wrap { grid-template-columns: 1fr; } }
.kit-store-catalog { display: grid; grid-template-columns: repeat(auto-fill, minmax(13rem, 1fr)); gap: 1rem; }
.kit-store-card { border: 1px solid var(--kit-border); border-radius: var(--kit-radius); padding: 1rem; background: var(--kit-bg); display: flex; flex-direction: column; gap: 0.4rem; }
.kit-store-card h4 { margin: 0.2rem 0; font-size: 1rem; }
.kit-store-tags { display: flex; gap: 0.35rem; flex-wrap: wrap; }
.kit-store-tag { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.04em; padding: 0.18rem 0.5rem; border-radius: 999px; background: color-mix(in srgb, var(--kit-muted) 18%, transparent); color: var(--kit-muted); text-transform: uppercase; }
.kit-store-tag-digital { background: color-mix(in srgb, var(--kit-accent) 18%, transparent); color: var(--kit-accent); }
.kit-store-tag-sale { background: #f0a000; color: #1a1300; }
.kit-store-desc { font-size: 0.85rem; color: var(--kit-muted); margin: 0; flex: 1; }
.kit-store-price { font-weight: 800; font-size: 1.05rem; }
.kit-store-rrp { font-weight: 500; color: var(--kit-muted); text-decoration: line-through; margin-left: 0.4rem; font-size: 0.9rem; }
.kit-store-add { margin-top: 0.5rem; }
/* product card image + clickable card link */
.kit-store-cardlink { display: flex; flex-direction: column; gap: 0.4rem; text-decoration: none; color: inherit; }
.kit-store-cardlink:hover .kit-store-media img { transform: scale(1.03); }
.kit-store-cardlink:hover h4 { color: var(--kit-accent); }
.kit-store-card { padding: 0; overflow: hidden; }
.kit-store-card .kit-store-tags, .kit-store-card h4, .kit-store-card .kit-store-desc, .kit-store-card .kit-store-price { padding-left: 1rem; padding-right: 1rem; }
.kit-store-card > .kit-store-add { margin: 0.5rem 1rem 1rem; }
.kit-store-media { aspect-ratio: 4 / 3; overflow: hidden; background: var(--kit-surface); }
.kit-store-media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.25s ease; }
.kit-store-media-none { display: flex; align-items: center; justify-content: center; background: color-mix(in srgb, var(--kit-accent) 12%, var(--kit-surface)); }
.kit-store-media-none span { font-family: var(--kit-font-heading, inherit); font-size: 2.4rem; font-weight: 700; color: color-mix(in srgb, var(--kit-accent) 60%, var(--kit-muted)); }
/* ── single product page (PDP) ── */
.kit-store-pdp { margin: 0 0 0.5rem; }
.kit-pdp-back { display: inline-block; margin-bottom: 1.2rem; color: var(--kit-accent); text-decoration: none; font-weight: 600; font-size: 0.92rem; }
.kit-pdp-back:hover { text-decoration: underline; }
.kit-pdp-cols { display: grid; grid-template-columns: 1.1fr 1fr; gap: 2.4rem; align-items: start; }
@media (max-width: 760px) { .kit-pdp-cols { grid-template-columns: 1fr; gap: 1.4rem; } }
.kit-pdp-figure { margin: 0; border: 1px solid var(--kit-border); border-radius: var(--kit-radius); overflow: hidden; background: var(--kit-surface); }
.kit-pdp-figure img { width: 100%; display: block; object-fit: cover; }
.kit-pdp-figure-none { aspect-ratio: 4 / 3; display: flex; align-items: center; justify-content: center; background: color-mix(in srgb, var(--kit-accent) 12%, var(--kit-surface)); }
.kit-pdp-figure-none span { font-family: var(--kit-font-heading, inherit); font-size: 4rem; font-weight: 700; color: color-mix(in srgb, var(--kit-accent) 60%, var(--kit-muted)); }
.kit-pdp-thumbs { display: flex; gap: 0.5rem; margin-top: 0.6rem; flex-wrap: wrap; }
.kit-pdp-thumb { width: 4.2rem; height: 4.2rem; padding: 0; border: 2px solid transparent; border-radius: calc(var(--kit-radius) - 2px); overflow: hidden; cursor: pointer; background: var(--kit-surface); }
.kit-pdp-thumb.is-active { border-color: var(--kit-accent); }
.kit-pdp-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.kit-pdp-title { margin: 0 0 0.6rem; font-size: 1.7rem; line-height: 1.15; }
.kit-pdp-pricerow { display: flex; align-items: center; gap: 0.8rem; flex-wrap: wrap; margin-bottom: 1rem; }
.kit-pdp-price { font-weight: 800; font-size: 1.5rem; }
.kit-pdp-rrp { color: var(--kit-muted); text-decoration: line-through; font-size: 1.05rem; }
.kit-pdp-stock { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; padding: 0.2rem 0.55rem; border-radius: 999px; background: color-mix(in srgb, var(--kit-muted) 18%, transparent); color: var(--kit-muted); }
.kit-pdp-stock-digital { background: color-mix(in srgb, var(--kit-accent) 18%, transparent); color: var(--kit-accent); }
.kit-pdp-stock-out { background: #f3d2d2; color: #7a1d1d; }
.kit-pdp-desc { font-size: 0.98rem; line-height: 1.65; color: var(--kit-fg); margin-bottom: 1.4rem; }
.kit-pdp-imgnote { font-size: 0.8rem; color: var(--kit-muted); font-style: italic; margin: 0 0 1rem; }
.kit-pdp-add { display: inline-block; font-size: 1rem; padding: 0.7rem 1.6rem; }
.kit-pdp-cartmsg { font-size: 0.85rem; color: var(--kit-accent); margin: 0.6rem 0 0; min-height: 1.1em; }
.kit-store-cart-panel { border: 1px solid var(--kit-border); border-radius: var(--kit-radius); padding: 1.1rem; background: var(--kit-surface); position: sticky; top: 1rem; }
.kit-store-cart-panel h3 { margin: 0 0 0.75rem; font-size: 1.05rem; }
.kit-store-empty, .kit-store-loading, .kit-store-orderslook { color: var(--kit-muted); font-size: 0.88rem; margin: 0.3rem 0; }
.kit-store-line { display: flex; align-items: center; gap: 0.5rem; padding: 0.5rem 0; border-bottom: 1px solid var(--kit-border); }
.kit-store-line-name { flex: 1; font-size: 0.88rem; }
.kit-store-line-price { font-weight: 700; }
.kit-store-rm { border: none; background: none; cursor: pointer; color: var(--kit-muted); font-size: 1.1rem; line-height: 1; padding: 0 0.3rem; }
.kit-store-trow { display: flex; justify-content: space-between; font-size: 0.85rem; color: var(--kit-muted); margin-top: 0.35rem; }
.kit-store-total { font-weight: 800; font-size: 1rem; color: var(--kit-fg); margin-top: 0.6rem; padding-top: 0.6rem; border-top: 1px solid var(--kit-border); }
.kit-store-emailwrap { margin-top: 0.8rem; display: flex; flex-direction: column; gap: 0.3rem; font-size: 0.82rem; }
.kit-store-emailwrap input, .kit-store-orderswrap input { padding: 0.5rem 0.7rem; border: 1px solid var(--kit-border); border-radius: var(--kit-radius); background: var(--kit-bg); color: var(--kit-fg); }
.kit-store-emailnote { color: var(--kit-muted); font-weight: 400; }
.kit-store-checkout { width: 100%; margin-top: 0.9rem; }
.kit-store-msg { font-size: 0.85rem; margin: 0.6rem 0 0; min-height: 1em; }
.kit-store-orders { margin-top: 1.1rem; border-top: 1px solid var(--kit-border); padding-top: 0.8rem; }
.kit-store-orders summary { cursor: pointer; font-weight: 600; font-size: 0.9rem; }
.kit-store-orderswrap { display: flex; gap: 0.4rem; margin: 0.5rem 0; }
.kit-store-orderswrap input { flex: 1; }
.kit-store-order { border: 1px solid var(--kit-border); border-radius: var(--kit-radius); padding: 0.7rem; margin-top: 0.6rem; background: var(--kit-bg); font-size: 0.82rem; }
.kit-store-order-head { display: flex; justify-content: space-between; align-items: center; }
.kit-store-order-status { color: var(--kit-muted); font-size: 0.78rem; }
.kit-store-order-items { margin: 0.4rem 0; padding-left: 1.1rem; color: var(--kit-muted); }
.kit-store-order-foot { display: flex; justify-content: space-between; align-items: center; gap: 0.5rem; }
.kit-store-refund { padding: 0.35rem 0.7rem; font-size: 0.8rem; background: var(--kit-bg); color: var(--kit-fg); }
.kit-storefront-stub { background: var(--kit-surface); }

/* ============ 14c. taxonomy storefront (Catalog+ browsing) ============ */
.kit-taxstore { padding: 1.5rem; }
.kit-taxstore .kit-test-badge { position: static; display: inline-block; margin-bottom: 1rem; }
.kit-tax-topbar { display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: center; justify-content: space-between; margin-bottom: 0.75rem; }
.kit-tax-search { display: flex; gap: 0.5rem; flex: 1; min-width: 14rem; }
.kit-tax-q { flex: 1; padding: 0.55rem 0.8rem; border: 1px solid var(--kit-border); border-radius: var(--kit-radius); background: var(--kit-bg); color: var(--kit-fg); }
.kit-tax-sortwrap { display: flex; align-items: center; gap: 0.4rem; }
.kit-tax-sortlabel { font-size: 0.82rem; color: var(--kit-muted); font-weight: 600; }
.kit-tax-sort { font: inherit; padding: 0.5rem 0.7rem; border: 1px solid var(--kit-border); border-radius: var(--kit-radius); background: var(--kit-bg); color: var(--kit-fg); }
.kit-tax-searchbtn, .kit-tax-add, .kit-tax-checkout { font: inherit; font-weight: 600; cursor: pointer; border-radius: var(--kit-radius); border: 1px solid transparent; background: var(--kit-accent); color: var(--kit-accent-contrast); padding: 0.5rem 0.9rem; }
.kit-tax-searchbtn:hover, .kit-tax-add:hover, .kit-tax-checkout:hover { filter: brightness(1.05); }
.kit-tax-add:disabled, .kit-tax-checkout:disabled { opacity: 0.5; cursor: not-allowed; filter: none; }
.kit-tax-crumbs { font-size: 0.85rem; color: var(--kit-muted); margin-bottom: 0.4rem; }
.kit-tax-crumbs a { color: var(--kit-accent); text-decoration: none; }
.kit-tax-crumbs .kit-tax-sep { color: var(--kit-muted); margin: 0 0.15rem; }
.kit-tax-active { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-bottom: 0.9rem; }
.kit-tax-active:empty { margin: 0; }
.kit-tax-chip { font: inherit; font-size: 0.78rem; font-weight: 600; cursor: pointer; border: 1px solid var(--kit-accent); background: color-mix(in srgb, var(--kit-accent) 12%, transparent); color: var(--kit-accent); border-radius: 999px; padding: 0.25rem 0.6rem; }
.kit-tax-layout { display: grid; grid-template-columns: 14rem 1fr 18rem; gap: 1.5rem; align-items: start; }
@media (max-width: 960px) { .kit-tax-layout { grid-template-columns: 13rem 1fr; } .kit-tax-cartpanel { grid-column: 1 / -1; } }
@media (max-width: 680px) { .kit-tax-layout { grid-template-columns: 1fr; } }
.kit-tax-side { border: 1px solid var(--kit-border); border-radius: var(--kit-radius); padding: 1rem; background: var(--kit-surface); display: flex; flex-direction: column; gap: 1.1rem; position: sticky; top: 1rem; }
.kit-tax-side h4 { margin: 0 0 0.5rem; font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--kit-muted); }
.kit-tax-cattree { display: flex; flex-direction: column; }
.kit-tax-catrow { display: flex; align-items: center; justify-content: space-between; gap: 0.4rem; padding: 0.2rem 0; }
.kit-tax-catrow a { color: var(--kit-fg); text-decoration: none; font-size: 0.9rem; }
.kit-tax-catrow.is-active > a, .kit-tax-catrow.in-path > a { color: var(--kit-accent); font-weight: 700; }
.kit-tax-catrow a:hover { color: var(--kit-accent); }
.kit-tax-cnt { font-size: 0.72rem; color: var(--kit-muted); background: color-mix(in srgb, var(--kit-muted) 14%, transparent); border-radius: 999px; padding: 0.05rem 0.4rem; min-width: 1.3rem; text-align: center; }
.kit-tax-facet { border-top: 1px solid var(--kit-border); padding-top: 0.8rem; }
.kit-tax-opt { display: flex; align-items: center; gap: 0.4rem; font-size: 0.88rem; padding: 0.18rem 0; cursor: pointer; }
.kit-tax-opt span:first-of-type { flex: 1; }
.kit-tax-opt input { accent-color: var(--kit-accent); }
.kit-tax-pricebox { display: flex; flex-direction: column; gap: 0.3rem; }
.kit-tax-pricevals { font-size: 0.85rem; font-weight: 600; color: var(--kit-fg); }
.kit-tax-prange { width: 100%; accent-color: var(--kit-accent); }
.kit-tax-clear { font: inherit; font-weight: 600; font-size: 0.82rem; cursor: pointer; border: 1px solid var(--kit-border); background: var(--kit-bg); color: var(--kit-fg); border-radius: var(--kit-radius); padding: 0.45rem 0.7rem; }
.kit-tax-clear:hover { border-color: var(--kit-accent); color: var(--kit-accent); }
.kit-tax-count { font-size: 0.85rem; color: var(--kit-muted); margin-bottom: 0.7rem; }
.kit-tax-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(12rem, 1fr)); gap: 1rem; }
.kit-tax-card { border: 1px solid var(--kit-border); border-radius: var(--kit-radius); padding: 1rem; background: var(--kit-bg); display: flex; flex-direction: column; gap: 0.35rem; }
.kit-tax-card-cat { font-size: 0.66rem; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--kit-accent); }
.kit-tax-card h4 { margin: 0; font-size: 0.98rem; }
.kit-tax-card-desc { font-size: 0.82rem; color: var(--kit-muted); margin: 0; flex: 1; }
.kit-tax-card-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 0.3rem; }
.kit-tax-price { font-weight: 800; font-size: 1.02rem; }
.kit-tax-cartpanel { border: 1px solid var(--kit-border); border-radius: var(--kit-radius); padding: 1.1rem; background: var(--kit-surface); position: sticky; top: 1rem; }
.kit-tax-cartpanel h3 { margin: 0 0 0.75rem; font-size: 1.05rem; }
.kit-tax-empty, .kit-tax-loading { color: var(--kit-muted); font-size: 0.88rem; margin: 0.3rem 0; }
.kit-tax-line { display: flex; align-items: center; gap: 0.5rem; padding: 0.5rem 0; border-bottom: 1px solid var(--kit-border); font-size: 0.86rem; }
.kit-tax-line span:first-child { flex: 1; }
.kit-tax-rm { border: none; background: none; cursor: pointer; color: var(--kit-muted); font-size: 1.1rem; line-height: 1; padding: 0 0.3rem; }
.kit-tax-trow { display: flex; justify-content: space-between; font-size: 0.85rem; color: var(--kit-muted); margin-top: 0.35rem; }
.kit-tax-total { font-weight: 800; font-size: 1rem; color: var(--kit-fg); margin-top: 0.6rem; padding-top: 0.6rem; border-top: 1px solid var(--kit-border); }
.kit-tax-emailwrap { margin-top: 0.8rem; display: flex; flex-direction: column; gap: 0.3rem; font-size: 0.82rem; }
.kit-tax-emailwrap input { padding: 0.5rem 0.7rem; border: 1px solid var(--kit-border); border-radius: var(--kit-radius); background: var(--kit-bg); color: var(--kit-fg); }
.kit-tax-emailnote { color: var(--kit-muted); font-weight: 400; }
.kit-tax-checkout { width: 100%; margin-top: 0.9rem; }
.kit-tax-msg { font-size: 0.85rem; margin: 0.6rem 0 0; min-height: 1em; }

/* ============ 15. footer ============
   Dark, brand-reinforced footer (like the live site's #3e3732 bar): the Sémonin
   wordmark + the CCS mark, the tagline, page nav, and round social icons. */
.kit-footer {
  margin-top: clamp(3rem, 7vw, 6rem);
  padding-block: clamp(2.5rem, 5vw, 3.5rem) 0;
  background: var(--kit-footer-bg, #3e3732);
  color: #f5f0e9;
}
.kit-footer-inner {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem 2.5rem;
  justify-content: space-between;
  align-items: flex-start;
}
.kit-footer-brand { max-width: 40ch; display: flex; flex-direction: column; gap: 0.85rem; align-items: flex-start; }
.kit-footer-lockup { display: flex; align-items: center; gap: 1rem; }
.kit-footer-logolink { display: inline-flex; }
.kit-footer-logo { height: 56px; width: auto; display: block; filter: brightness(0) invert(1); }
.kit-footer-sublogo { height: 64px; width: auto; display: block; filter: brightness(0) invert(1); opacity: 0.92; }
.kit-footer .kit-wordmark { color: #fff; }
.kit-footer-tagline { color: color-mix(in srgb, #f5f0e9 78%, transparent); margin: 0.25rem 0 0; font-size: 0.9rem; line-height: 1.6; }
.kit-footer-nav, .kit-footer-social { display: flex; gap: 0.7rem 1.1rem; flex-wrap: wrap; list-style: none; margin: 0; padding: 0; align-items: center; }
.kit-footer-nav { flex-direction: column; align-items: flex-start; gap: 0.55rem; }
.kit-footer-nav a { text-decoration: none; color: color-mix(in srgb, #f5f0e9 85%, transparent); font-weight: 500; font-size: 0.92rem; }
.kit-footer-nav a:hover { color: #fff; }
.kit-footer-social a {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 50%;
  background: color-mix(in srgb, #ffffff 14%, transparent); color: #fff; text-decoration: none;
  transition: background 0.15s ease;
}
.kit-footer-social a:hover { background: var(--kit-accent); }
.kit-footer-social .kit-util-ico { width: 18px; height: 18px; }
.kit-footer-social-label { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
.kit-footer-meta {
  border-top: 1px solid color-mix(in srgb, #ffffff 14%, transparent);
  margin-top: clamp(2rem, 4vw, 3rem);
}
.kit-footer-meta p {
  max-width: var(--kit-max-width, 1120px);
  margin: 0 auto;
  padding: 1.5rem clamp(1.25rem, 5vw, 3.75rem);
  font-size: 0.85rem;
  color: color-mix(in srgb, #f5f0e9 70%, transparent);
}

/* ============ 15b. 404 ============ */
.kit-404 { text-align: center; padding-block: clamp(4rem, 12vw, 8rem); }
.kit-404 .kit-section-inner { max-width: 40rem; margin-inline: auto; }
.kit-404 .kit-section-intro { margin-inline: auto; }

/* ============ 16. motion ============ */
/* GUARDRAIL: content is VISIBLE BY DEFAULT. No hide-then-reveal. The old
   zero-opacity + IntersectionObserver pattern blanked pages when the observer
   didn't fire — it is gone. .kit-reveal is kept only as a visible-by-default
   no-op so any stale markup can never blank a page. */
.kit-reveal { opacity: 1; transform: none; }
.kit-reveal.is-visible { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
  }
  .kit-reveal { opacity: 1; transform: none; }
  .kit-btn:hover, .kit-card:hover { transform: none; }
}

/* ============ 17. sticky subscribe rail ============ */
/* Vertical edge widget. VISIBLE BY DEFAULT — pure-CSS <details> toggle, no JS. */
.kit-visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
.kit-subscribe-rail {
  position: fixed; top: 38%; right: 0; z-index: 40;
}
.kit-subscribe-rail-panel { display: block; }
.kit-subscribe-rail-tab {
  list-style: none; cursor: pointer; user-select: none;
  writing-mode: vertical-rl; transform: rotate(180deg);
  display: inline-flex; align-items: center; justify-content: center; gap: 0.35rem;
  background: var(--kit-accent); color: var(--kit-accent-contrast, #fff);
  font-family: var(--kit-font-heading); font-weight: 600; letter-spacing: 0.04em;
  text-transform: uppercase; font-size: 0.74rem; line-height: 1;
  /* NARROWER tab — trimmed horizontal padding so the vertical strip is slim
     (Damian: it read too wide). The arrow is a flex child so it sits in-line
     with the SUBSCRIBE text, not nudged out by trailing whitespace. */
  padding: 0.95rem 0.3rem;
  border-radius: 0 12px 12px 0;
  box-shadow: -3px 2px 14px rgba(0,0,0,0.16);
  position: absolute; right: 0; top: 0;
}
.kit-subscribe-rail-tab::-webkit-details-marker { display: none; }
.kit-subscribe-rail-tab::after { content: "↑"; font-size: 0.8em; }
.kit-subscribe-rail-panel[open] .kit-subscribe-rail-tab { display: none; }
.kit-subscribe-rail-body {
  width: min(300px, 80vw);
  background: var(--kit-surface); color: var(--kit-fg);
  border: 1px solid var(--kit-border); border-right: none;
  border-radius: 14px 0 0 14px;
  box-shadow: -4px 4px 22px rgba(0,0,0,0.16);
  padding: 1.1rem 1.15rem 1.25rem;
}
.kit-subscribe-rail-heading {
  font-family: var(--kit-font-heading); font-weight: 700; font-size: 1.05rem;
  margin: 0 0 0.3rem;
}
.kit-subscribe-rail-intro { font-size: 0.86rem; color: var(--kit-muted); margin: 0 0 0.8rem; }
.kit-subscribe-rail-form { display: flex; flex-direction: column; gap: 0.5rem; }
.kit-subscribe-rail-form input[type="email"] {
  width: 100%; padding: 0.6rem 0.7rem; font: inherit;
  border: 1px solid var(--kit-border); border-radius: var(--kit-radius, 8px);
  background: var(--kit-bg); color: var(--kit-fg);
}
.kit-subscribe-rail-form .kit-btn, .kit-subscribe-rail-link { width: 100%; text-align: center; }
.kit-subscribe-rail-link { display: inline-block; }
.kit-subscribe-rail-note { font-size: 0.74rem; color: var(--kit-muted); margin: 0.6rem 0 0; }
@media (max-width: 640px) {
  .kit-subscribe-rail { top: auto; bottom: 12px; }
  .kit-subscribe-rail-body { width: min(290px, 86vw); }
}

/* ============ 18. breadcrumbs ============ */
.kit-breadcrumbs { border-bottom: 1px solid var(--kit-border); background: color-mix(in srgb, var(--kit-surface) 60%, var(--kit-bg)); }
.kit-breadcrumbs-inner { max-width: var(--kit-max-width, 1120px); margin-inline: auto; padding: 0.55rem clamp(1.25rem, 5vw, 2.5rem); }
.kit-crumb-list { list-style: none; display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem; margin: 0; padding: 0; font-size: 0.82rem; }
.kit-crumb a { color: var(--kit-muted); text-decoration: none; }
.kit-crumb a:hover { color: var(--kit-accent); }
.kit-crumb span[aria-current] { color: var(--kit-fg); font-weight: 600; }
.kit-crumb-sep { color: var(--kit-muted); opacity: 0.6; }

/* ============ 19. blog layout + sidebar (live DSA blog parity) ============ */
.kit-blog-layout--sidebar { display: grid; grid-template-columns: 1fr 19rem; gap: clamp(1.5rem, 3.5vw, 2.75rem); align-items: start; }
@media (max-width: 900px) { .kit-blog-layout--sidebar { grid-template-columns: 1fr; } }
.kit-blog-sidebar { display: flex; flex-direction: column; gap: 1.1rem; position: sticky; top: 5.5rem; }
@media (max-width: 900px) { .kit-blog-sidebar { position: static; } }
/* "Learn this · take it further" — medium-hub course/product rail (top of the blog sidebar) */
.kit-learn-rail { background: var(--kit-surface); border: 1px solid var(--kit-border); border-left: 3px solid var(--kit-accent); border-radius: var(--kit-radius); padding: 1.1rem 1.2rem; }
.kit-learn-h { font-family: var(--kit-font-heading, inherit); font-weight: 700; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--kit-accent); margin: 0 0 0.85rem; }
.kit-learn-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 1rem; }
.kit-learn-item { display: flex; flex-direction: column; gap: 0.35rem; padding-bottom: 1rem; border-bottom: 1px solid color-mix(in srgb, var(--kit-border) 60%, transparent); }
.kit-learn-item:last-child { border-bottom: 0; padding-bottom: 0; }
.kit-learn-badge { align-self: flex-start; font-size: 0.66rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: var(--kit-accent-contrast); background: var(--kit-accent); padding: 0.15rem 0.55rem; border-radius: 999px; }
.kit-learn-title { font-weight: 600; font-size: 1rem; color: var(--kit-fg); text-decoration: none; line-height: 1.3; }
.kit-learn-title:hover { color: var(--kit-accent); }
.kit-learn-blurb { margin: 0; font-size: 0.85rem; color: var(--kit-muted); line-height: 1.45; }
.kit-learn-cta { align-self: flex-start; margin-top: 0.2rem; font-size: 0.8rem; padding: 0.4rem 0.9rem; }
/* course grid — self-paced course tiles (full 16:9 artwork + coming-soon + register) */
.kit-courses-h { font-family: var(--kit-font-heading, inherit); font-size: clamp(1.5rem, 3vw, 2rem); font-weight: 700; margin: 0 0 0.4rem; }
.kit-courses-intro { max-width: 62ch; }
.kit-courses-grid { list-style: none; margin: 1.4rem 0 0; padding: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.6rem; }
.kit-course-card { display: flex; flex-direction: column; background: var(--kit-surface); border: 1px solid var(--kit-border); border-radius: var(--kit-radius); overflow: hidden; }
.kit-course-cover { position: relative; aspect-ratio: 16 / 9; background: var(--kit-border); }
.kit-course-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.kit-course-cover-type { display: flex; align-items: center; justify-content: center; height: 100%; padding: 1rem; font-family: var(--kit-font-heading, inherit); font-weight: 700; text-align: center; }
.kit-course-status { align-self: flex-start; font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: var(--kit-accent-contrast); background: var(--kit-accent); padding: 0.2rem 0.6rem; border-radius: 999px; }
.kit-course-foot { padding: 1rem 1.1rem 1.2rem; display: flex; flex-direction: column; gap: 0.7rem; }
.kit-course-blurb { margin: 0; font-size: 0.9rem; color: var(--kit-muted); line-height: 1.45; }
.kit-course-cta { align-self: flex-start; font-size: 0.85rem; }
.kit-blogbio, .kit-blog-subcard, .kit-blog-recent, .kit-blog-followcard {
  border: 1px solid var(--kit-border); border-radius: calc(var(--kit-radius) * 1.3);
  background: var(--kit-surface); padding: 1.25rem;
}
.kit-blogbio { text-align: center; }
.kit-blogbio-photo { width: 150px; height: 150px; border-radius: 50%; object-fit: cover; object-position: center top; margin: 0 auto 1rem; box-shadow: 0 12px 26px -16px rgba(0,0,0,0.5); border: 3px solid var(--kit-bg); }
.kit-blogbio-name { font-family: var(--kit-font-heading); font-weight: 700; font-size: 1.15rem; margin: 0 0 0.4rem; }
.kit-blogbio-body { color: var(--kit-muted); font-size: 0.9rem; margin: 0 0 0.9rem; line-height: 1.55; }
.kit-blogbio-cta { font-size: 0.85rem; padding: 0.5rem 1rem; }
.kit-blog-subcard-heading { font-family: var(--kit-font-heading); font-weight: 700; font-size: 1rem; margin: 0 0 0.3rem; }
.kit-blog-subcard-intro { color: var(--kit-muted); font-size: 0.85rem; margin: 0 0 0.8rem; }
.kit-blogbio-subform, .kit-blog-subcard form { display: flex; flex-direction: column; gap: 0.5rem; }
.kit-blog-subcard input[type="email"] { width: 100%; padding: 0.55rem 0.7rem; font: inherit; border: 1px solid var(--kit-border); border-radius: var(--kit-radius); background: var(--kit-bg); color: var(--kit-fg); }
.kit-blog-subcard .kit-btn, .kit-blogbio-subbtn { width: 100%; text-align: center; }
.kit-blog-recent-h { font-family: var(--kit-font-heading); font-weight: 700; font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--kit-muted); margin: 0 0 0.7rem; }
.kit-blog-recent-list, .kit-blog-follow { list-style: none; margin: 0; padding: 0; }
.kit-blog-recent-item { display: flex; gap: 0.7rem; padding: 0.55rem 0; border-bottom: 1px solid var(--kit-border); }
.kit-blog-recent-item:last-child { border-bottom: none; }
.kit-blog-recent-thumb { flex: none; width: 3.4rem; height: 3.4rem; border-radius: 8px; overflow: hidden; background: color-mix(in srgb, var(--kit-accent) 10%, var(--kit-surface)); }
.kit-blog-recent-thumb img { width: 100%; height: 100%; object-fit: cover; }
.kit-blog-recent-meta { display: flex; flex-direction: column; gap: 0.15rem; min-width: 0; }
.kit-blog-recent-title { color: var(--kit-fg); text-decoration: none; font-weight: 600; font-size: 0.88rem; line-height: 1.3; }
.kit-blog-recent-title:hover { color: var(--kit-accent); }
.kit-blog-recent-date { color: var(--kit-muted); font-size: 0.76rem; }
.kit-blog-follow { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.kit-blog-follow a { font-size: 0.82rem; font-weight: 600; padding: 0.3rem 0.7rem; border-radius: 999px; text-decoration: none; background: color-mix(in srgb, var(--kit-accent) 12%, transparent); color: var(--kit-accent); }
.kit-blog-follow a:hover { background: var(--kit-accent); color: var(--kit-accent-contrast); }
.kit-blog-catlist { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.kit-blog-catlist li + li { border-top: 1px solid color-mix(in srgb, var(--kit-border) 60%, transparent); }
.kit-blog-cat { display: block; padding: 0.5rem 0; text-decoration: none; color: var(--kit-fg); font-size: 0.9rem; font-weight: 600; }
.kit-blog-cat:hover { color: var(--kit-accent); }

/* CCS promo tile — photo + dark opacity overlay + white copy + "Explore",
   like the live blog sidebar. Background image carries the gradient overlay
   inline; this styles the card + text. Content is plain text (no JS reveal). */
.kit-blog-tile {
  display: block; border-radius: var(--kit-radius); overflow: hidden;
  background-size: cover; background-position: center; min-height: 13rem;
  text-decoration: none; color: #fff; box-shadow: 0 12px 26px -16px rgba(0,0,0,0.5);
  background-color: var(--kit-fg);
}
.kit-blog-tile-body { display: flex; flex-direction: column; justify-content: flex-end; height: 100%; min-height: 13rem; padding: 1.1rem; gap: 0.3rem; }
.kit-blog-tile-eyebrow { font-family: var(--kit-font-heading); font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; margin: 0; color: #fff; opacity: 0.92; }
.kit-blog-tile-heading { font-family: var(--kit-font-heading); font-size: 1.2rem; font-weight: 700; line-height: 1.2; margin: 0; color: #fff; }
.kit-blog-tile-intro { font-size: 0.85rem; margin: 0; color: #fff; opacity: 0.9; }
.kit-blog-tile-cta { display: inline-block; margin-top: 0.5rem; font-family: var(--kit-font-heading); font-size: 0.8rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; color: #fff; border-bottom: 2px solid #fff; padding-bottom: 1px; width: fit-content; }
.kit-blog-tile:hover .kit-blog-tile-cta { color: var(--kit-accent-2, var(--kit-accent)); border-color: currentColor; }

/* the blue clickable subcategory label above an article title (live blog) */
.kit-article-eyebrow { margin-bottom: 0.5rem; }
.kit-eyebrow-link { color: inherit; text-decoration: none; }
.kit-eyebrow-link:hover { text-decoration: underline; }
/* In the sidebar blog layout each post is a compact horizontal row —
   thumbnail left, title/meta/summary right — so several posts read nicely
   down the page (a faithful copy of the live blog list, NOT one big card). */
.kit-blog-layout--sidebar .kit-post-list { grid-template-columns: 1fr; gap: clamp(1rem, 2.4vw, 1.5rem); }
.kit-blog-layout--sidebar .kit-post-card { padding: 0; }
.kit-blog-layout--sidebar .kit-post-card > article {
  display: grid; grid-template-columns: 240px 1fr; align-items: stretch; height: 100%;
}
.kit-blog-layout--sidebar .kit-post-cover { aspect-ratio: auto; height: 100%; min-height: 170px; }
.kit-blog-layout--sidebar .kit-post-body { padding: clamp(1rem, 2.4vw, 1.4rem); justify-content: center; }
.kit-blog-layout--sidebar .kit-post-title { font-size: 1.2rem; }
.kit-blog-layout--sidebar .kit-post-body .kit-article-tags { margin-top: 0.9rem; padding-top: 0; }
@media (max-width: 560px) {
  .kit-blog-layout--sidebar .kit-post-card > article { grid-template-columns: 1fr; }
  .kit-blog-layout--sidebar .kit-post-cover { aspect-ratio: 16 / 9; min-height: 0; }
}

/* ============ 20. video poster (click-to-play) ============ */
.kit-video { margin: 0 0 1.25rem; }
.kit-video-poster { position: relative; display: block; border-radius: calc(var(--kit-radius) * 1.3); overflow: hidden; background: var(--kit-surface); aspect-ratio: 16 / 9; box-shadow: 0 24px 50px -30px rgba(0,0,0,0.5); }
.kit-video-poster img, .kit-video-poster-fallback { width: 100%; height: 100%; object-fit: cover; display: block; }
.kit-video-poster-fallback { background: linear-gradient(135deg, var(--kit-accent), var(--kit-accent-2)); }
.kit-video-poster::after { content: ""; position: absolute; inset: 0; background: rgba(0,0,0,0.18); transition: background 0.2s ease; }
.kit-video-poster:hover::after { background: rgba(0,0,0,0.08); }
.kit-video-play { position: absolute; inset: 0; margin: auto; width: 4.5rem; height: 4.5rem; border-radius: 50%; background: var(--kit-accent); color: var(--kit-accent-contrast); display: grid; place-items: center; z-index: 2; box-shadow: 0 10px 30px -8px rgba(0,0,0,0.5); transition: transform 0.18s ease; padding-left: 4px; }
.kit-video-poster:hover .kit-video-play { transform: scale(1.08); }
.kit-video-frame { width: 100%; aspect-ratio: 16 / 9; border: 0; border-radius: calc(var(--kit-radius) * 1.3); display: block; }
.kit-video-caption { color: var(--kit-muted); font-size: 0.88rem; margin: 0.6rem 0 0; text-align: center; }

/* ============ 21. site search ============ */
.kit-search-form { display: flex; gap: 0.5rem; max-width: 36rem; margin-bottom: 1rem; }
.kit-search-input { flex: 1; padding: 0.7rem 0.9rem; font: inherit; border: 1.5px solid var(--kit-border); border-radius: var(--kit-radius); background: var(--kit-bg); color: var(--kit-fg); }
.kit-search-input:focus { outline: none; border-color: var(--kit-accent); box-shadow: 0 0 0 3px color-mix(in srgb, var(--kit-accent) 22%, transparent); }
.kit-search-status { color: var(--kit-muted); font-size: 0.9rem; margin: 0 0 1rem; }
.kit-search-results { margin-top: 0.5rem; }

/* ============ 22. draft / sign-off flag ============ */
.kit-draft-flag {
  background: color-mix(in srgb, #f0a000 18%, var(--kit-bg)); border: 1px solid #f0a000;
  border-radius: var(--kit-radius); padding: 0.7rem 1rem; font-size: 0.88rem; color: var(--kit-fg);
  margin: 0 0 1.5rem;
}

@media print {
  .kit-header, .kit-nav-toggle, .kit-cta-band, .kit-sdk-block, .kit-subscribe-rail, .kit-utilbar, .kit-breadcrumbs { display: none !important; }
  body { color: #000; background: #fff; }
}
