/* =========================================================================
 * Komo proposals — base theme (light mode default)
 * Use the `kp-` prefix on every utility/component class to avoid clashing
 * with proposal-specific styles.
 * ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Figtree:wght@400;500;600;700;800&display=swap');

/* ---- Tokens ----------------------------------------------------------- */
:root {
  /* Brand */
  --kp-yellow: #ECDE0A;
  --kp-yellow-hover: #baac00;
  --kp-ink: #121212;
  --kp-ink-2: #21222A;
  --kp-ink-3: #71727A;
  --kp-line: #E6E6E6;
  --kp-line-2: #D0D0D0;
  --kp-bg: #ffffff;
  --kp-bg-alt: #FAFAFA;
  --kp-bg-tint: #FFFCE0;     /* yellow-tinted hero / callouts */
  --kp-danger: #C0272D;
  --kp-success: #1F8A45;
  --kp-info: #2C6CB0;

  /* Type */
  --kp-font: 'Figtree', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --kp-font-mono: ui-monospace, 'JetBrains Mono', 'Fira Code', Menlo, monospace;
  --kp-fs-xs: 12px;
  --kp-fs-sm: 14px;
  --kp-fs-base: 16px;
  --kp-fs-lg: 18px;
  --kp-fs-xl: 22px;
  --kp-fs-2xl: 28px;
  --kp-fs-3xl: 36px;
  --kp-fs-4xl: 48px;
  --kp-fs-5xl: 64px;

  /* Spacing */
  --kp-s-1: 4px;
  --kp-s-2: 8px;
  --kp-s-3: 12px;
  --kp-s-4: 16px;
  --kp-s-5: 24px;
  --kp-s-6: 32px;
  --kp-s-7: 48px;
  --kp-s-8: 64px;
  --kp-s-9: 96px;

  /* Radii */
  --kp-r-sm: 6px;
  --kp-r-md: 10px;
  --kp-r-lg: 16px;
  --kp-r-xl: 24px;
  --kp-r-pill: 999px;

  /* Shadows */
  --kp-shadow-sm: 0 1px 2px rgba(18,18,18,0.06), 0 1px 1px rgba(18,18,18,0.04);
  --kp-shadow-md: 0 6px 16px rgba(18,18,18,0.08), 0 2px 4px rgba(18,18,18,0.04);
  --kp-shadow-lg: 0 20px 40px rgba(18,18,18,0.10), 0 4px 8px rgba(18,18,18,0.04);

  /* Layout */
  --kp-content: 1080px;
  --kp-narrow: 720px;
}

/* ---- Reset ------------------------------------------------------------ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--kp-bg);
  color: var(--kp-ink);
  font-family: var(--kp-font);
  font-size: var(--kp-fs-base);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;             /* never let the page scroll horizontally */
}
html { overflow-x: hidden; }
img, video, svg { display: block; max-width: 100%; height: auto; }
a { color: var(--kp-ink); text-decoration: underline; text-underline-offset: 2px; }
a:hover { color: var(--kp-yellow-hover); }
button { font: inherit; }
hr { border: 0; border-top: 1px solid var(--kp-line); margin: 0; }
::selection { background: var(--kp-yellow); color: var(--kp-ink); }

/* ---- Typography ------------------------------------------------------- */
.kp-h1, .kp-h2, .kp-h3, .kp-h4 {
  font-family: var(--kp-font);
  color: var(--kp-ink);
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin: 0 0 var(--kp-s-4);
}
.kp-h1 { font-size: clamp(var(--kp-fs-3xl), 4.5vw, var(--kp-fs-5xl)); font-weight: 800; }
.kp-h2 { font-size: clamp(var(--kp-fs-2xl), 3.5vw, var(--kp-fs-4xl)); font-weight: 700; }
.kp-h3 { font-size: clamp(var(--kp-fs-xl), 2.5vw, var(--kp-fs-2xl)); font-weight: 700; }
.kp-h4 { font-size: var(--kp-fs-lg); font-weight: 600; letter-spacing: -0.01em; }

.kp-eyebrow {
  display: inline-block;
  font-size: var(--kp-fs-xs);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--kp-ink-3);
  margin-bottom: var(--kp-s-3);
}
.kp-eyebrow.kp-yellow-bar {
  position: relative; padding-left: 28px;
}
.kp-eyebrow.kp-yellow-bar::before {
  content: ""; position: absolute; left: 0; top: 50%;
  width: 20px; height: 3px; background: var(--kp-yellow);
  transform: translateY(-50%);
}
.kp-lead { font-size: var(--kp-fs-lg); color: var(--kp-ink-2); }
.kp-muted { color: var(--kp-ink-3); }
.kp-fineprint { font-size: var(--kp-fs-sm); color: var(--kp-ink-3); }

/* ---- Layout ----------------------------------------------------------- */
.kp-container { max-width: var(--kp-content); margin: 0 auto; padding: 0 var(--kp-s-5); }
.kp-narrow { max-width: var(--kp-narrow); margin: 0 auto; padding: 0 var(--kp-s-5); }
.kp-section { padding: var(--kp-s-9) 0; }
.kp-section-tight { padding: var(--kp-s-7) 0; }
.kp-section-alt { background: var(--kp-bg-alt); }
.kp-section-tint { background: var(--kp-bg-tint); }

.kp-grid { display: grid; gap: var(--kp-s-5); min-width: 0; }
.kp-grid > * { min-width: 0; }   /* grid items shrink rather than overflow */
.kp-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.kp-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.kp-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
@media (max-width: 720px) {
  .kp-grid-2, .kp-grid-3, .kp-grid-4 { grid-template-columns: 1fr; }
}
@media (min-width: 721px) and (max-width: 960px) {
  .kp-grid-3, .kp-grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.kp-stack > * + * { margin-top: var(--kp-s-4); }
.kp-stack-lg > * + * { margin-top: var(--kp-s-6); }

/* ---- Top nav (legacy, still available) -------------------------------- */
.kp-nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,0.92);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--kp-line);
}
.kp-nav-inner {
  max-width: var(--kp-content); margin: 0 auto;
  padding: 0 var(--kp-s-5);
  display: flex; align-items: center; gap: var(--kp-s-5);
  height: 60px;
}
.kp-nav-brand { display: flex; align-items: center; gap: var(--kp-s-3); text-decoration: none; }
.kp-nav-brand img { height: 24px; }
.kp-nav-divider { width: 1px; height: 24px; background: var(--kp-line); }
.kp-nav-links { display: flex; gap: var(--kp-s-5); margin-left: auto; }
.kp-nav-links a { text-decoration: none; color: var(--kp-ink-2); font-size: var(--kp-fs-sm); font-weight: 500; }
.kp-nav-links a:hover { color: var(--kp-ink); }
@media (max-width: 720px) { .kp-nav-links { display: none; } }

/* ---- Sidebar nav (preferred) ----------------------------------------- *
 * Layout model:
 *   <body class="kp-has-sidebar">
 *     <aside class="kp-sidebar"> ... </aside>
 *     <button class="kp-sidebar-toggle" ...>☰</button>
 *     <main class="kp-main"> ... </main>
 *   </body>
 *
 * Desktop ≥ 1024px: sidebar is a fixed left rail (260px), main is offset.
 * Below 1024px:    sidebar slides in from the left as an overlay drawer.
 * ----------------------------------------------------------------------*/
:root {
  --kp-sidebar-w: 260px;
  --kp-sidebar-w-collapsed: 60px;
}
.kp-has-sidebar { /* nothing here at small sizes */ }

.kp-sidebar {
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: var(--kp-sidebar-w);
  max-width: 85vw;                 /* never exceed viewport on tiny screens */
  background: #fff;
  border-right: 1px solid var(--kp-line);
  padding: var(--kp-s-5) var(--kp-s-5) var(--kp-s-6);
  overflow-y: auto;
  overflow-x: hidden;              /* no horizontal scroll inside the rail */
  z-index: 60;
  transform: translateX(-100%);
  transition: transform .25s cubic-bezier(.2,.8,.2,1),
              width .22s cubic-bezier(.2,.8,.2,1),
              padding .22s cubic-bezier(.2,.8,.2,1);
  display: flex; flex-direction: column; gap: var(--kp-s-5);
}
.kp-sidebar.kp-open { transform: translateX(0); box-shadow: var(--kp-shadow-lg); }

/* Header row: brand on the left, collapse-toggle (desktop) or close-button
   (mobile) on the right. */
.kp-sidebar-head {
  display: flex; align-items: center; gap: var(--kp-s-2);
  min-width: 0;
  /* Push the brand row down a touch on mobile so it doesn't visually
     conflict with where the hamburger used to sit. */
}
.kp-sidebar-head .kp-sidebar-brand { flex: 1 1 auto; min-width: 0; }
.kp-sidebar-collapse {
  flex-shrink: 0;
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent; color: var(--kp-ink-3);
  border: 1px solid transparent; border-radius: var(--kp-r-sm);
  cursor: pointer;
  transition: background .15s, color .15s, transform .22s ease;
}
.kp-sidebar-collapse:hover { background: var(--kp-bg-alt); color: var(--kp-ink); }
.kp-sidebar-collapse:focus-visible {
  outline: 2px solid var(--kp-yellow); outline-offset: 2px;
}
.kp-sidebar-collapse svg { width: 16px; height: 16px; }
/* Mobile: the in-sidebar collapse button is hidden — use hamburger/backdrop instead. */
@media (max-width: 1023.98px) {
  .kp-sidebar-collapse { display: none; }
}

.kp-sidebar-brand {
  display: flex; align-items: center; gap: var(--kp-s-3);
  text-decoration: none; color: inherit;
  min-width: 0;                    /* allow children to shrink */
}
.kp-sidebar-brand img { height: 22px; flex-shrink: 0; }
.kp-sidebar-brand strong {
  font-size: var(--kp-fs-sm); font-weight: 600; color: var(--kp-ink-2);
  min-width: 0; line-height: 1.25;
  overflow-wrap: anywhere;         /* break long client names if needed */
}

.kp-sidebar-eyebrow {
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--kp-ink-3); font-weight: 700;
  margin-top: var(--kp-s-3);
}

/* Auto-built scrollspy list */
.kp-side-nav { list-style: none; margin: 0; padding: 0; min-width: 0; }
.kp-side-nav li { margin: 0; min-width: 0; }
.kp-side-nav a {
  display: block;
  padding: 8px 12px;
  margin: 2px 0;
  border-radius: var(--kp-r-md);
  text-decoration: none;
  color: var(--kp-ink-2);
  font-size: var(--kp-fs-sm);
  font-weight: 500;
  border-left: 2px solid transparent;
  transition: background .15s, color .15s, border-color .15s;
  line-height: 1.35;
  /* Long labels: wrap cleanly, never push the rail wider */
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.kp-side-nav a:hover { background: var(--kp-bg-alt); color: var(--kp-ink); }
.kp-side-nav a.kp-active {
  background: var(--kp-bg-tint);
  color: var(--kp-ink);
  border-left-color: var(--kp-yellow);
  font-weight: 600;
}

.kp-sidebar-foot {
  margin-top: auto;
  padding-top: var(--kp-s-4);
  border-top: 1px solid var(--kp-line);
  font-size: var(--kp-fs-xs);
  color: var(--kp-ink-3);
  display: flex; flex-direction: column; gap: 4px;
}
.kp-sidebar-foot a { color: var(--kp-ink-3); }
.kp-sidebar-foot a:hover { color: var(--kp-ink); }

/* Hamburger toggle (mobile) */
.kp-sidebar-toggle {
  position: fixed; top: 16px; left: 16px; z-index: 70;
  width: 44px; height: 44px;
  background: #fff; color: var(--kp-ink);
  border: 1px solid var(--kp-line);
  border-radius: var(--kp-r-md);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; box-shadow: var(--kp-shadow-sm);
  transition: opacity .18s ease, transform .18s ease;
}
.kp-sidebar-toggle:hover { background: var(--kp-bg-alt); }
.kp-sidebar-toggle:focus-visible { outline: 2px solid var(--kp-yellow); outline-offset: 2px; }
.kp-sidebar-toggle svg { width: 20px; height: 20px; }
/* When the drawer is open on mobile, hide the hamburger so it doesn't
   overlap the sidebar's own brand/close. */
.kp-has-sidebar.kp-sidebar-open .kp-sidebar-toggle {
  opacity: 0; pointer-events: none; transform: scale(.9);
}

/* In-sidebar close button (mobile only). Lives inside .kp-sidebar-head. */
.kp-sidebar-close {
  flex-shrink: 0;
  width: 36px; height: 36px;
  display: none;                    /* shown only on mobile */
  align-items: center; justify-content: center;
  background: transparent; color: var(--kp-ink-2);
  border: 1px solid var(--kp-line);
  border-radius: var(--kp-r-md);
  cursor: pointer;
}
.kp-sidebar-close:hover { background: var(--kp-bg-alt); color: var(--kp-ink); }
.kp-sidebar-close:focus-visible { outline: 2px solid var(--kp-yellow); outline-offset: 2px; }
.kp-sidebar-close svg { width: 18px; height: 18px; }
@media (max-width: 1023.98px) {
  .kp-sidebar-close { display: inline-flex; }
}

/* Backdrop for mobile drawer */
.kp-sidebar-backdrop {
  position: fixed; inset: 0; background: rgba(18,18,18,0.45);
  z-index: 55; opacity: 0; pointer-events: none;
  transition: opacity .2s ease;
}
.kp-sidebar-backdrop.kp-visible-bd {
  opacity: 1; pointer-events: auto;
}

/* Main content offset.
 * Use min-width:0 + max-width to prevent overflow when content (e.g. wide
 * images, code blocks) tries to push the layout wider than the available
 * space. */
.kp-main {
  width: 100%; min-width: 0;
  transition: margin-left .22s cubic-bezier(.2,.8,.2,1),
              max-width  .22s cubic-bezier(.2,.8,.2,1);
}

/* Body-level safety net: never allow horizontal scroll. */
.kp-has-sidebar { overflow-x: hidden; }
/* When the mobile drawer is open, lock body vertical scroll so the
   user is interacting with the drawer, not the page beneath. */
.kp-has-sidebar.kp-sidebar-open { overflow: hidden; }
@media (min-width: 1024px) {
  /* Desktop: drawer is permanent; never lock body scroll. */
  .kp-has-sidebar.kp-sidebar-open { overflow: visible; overflow-x: hidden; }
}

/* Desktop ≥ 1024px: rail is permanent, main is offset, no toggle/backdrop */
@media (min-width: 1024px) {
  .kp-sidebar { transform: translateX(0); box-shadow: none; }
  .kp-sidebar-toggle { display: none; }
  .kp-sidebar-backdrop { display: none; }
  /* The rail consumes 260px on the left; the main fills the remaining width
   * (NOT 100% — that would push the page wider than the viewport and cause
   * horizontal scroll). */
  .kp-has-sidebar .kp-main {
    margin-left: var(--kp-sidebar-w);
    max-width: calc(100% - var(--kp-sidebar-w));
  }
  /* Collapsed state on desktop: thin icon rail. */
  .kp-has-sidebar.kp-sidebar-collapsed .kp-sidebar {
    width: var(--kp-sidebar-w-collapsed);
    padding-left: 8px; padding-right: 8px;
  }
  .kp-has-sidebar.kp-sidebar-collapsed .kp-main {
    margin-left: var(--kp-sidebar-w-collapsed);
    max-width: calc(100% - var(--kp-sidebar-w-collapsed));
  }
  /* Rotate the collapse chevron 180deg in collapsed state. */
  .kp-has-sidebar.kp-sidebar-collapsed .kp-sidebar-collapse svg {
    transform: rotate(180deg);
  }
  /* Nudge container so content stays visually centred within the offset main */
  .kp-has-sidebar .kp-main .kp-container,
  .kp-has-sidebar .kp-main .kp-narrow { margin-left: auto; margin-right: auto; }
}

/* Collapsed: hide labels, centre icons, show tooltips on hover.
 * Active only on desktop (mobile uses drawer model instead). */
@media (min-width: 1024px) {
  .kp-has-sidebar.kp-sidebar-collapsed .kp-sidebar-brand strong,
  .kp-has-sidebar.kp-sidebar-collapsed .kp-sidebar-eyebrow,
  .kp-has-sidebar.kp-sidebar-collapsed .kp-sidebar-foot {
    display: none;
  }
  .kp-has-sidebar.kp-sidebar-collapsed .kp-sidebar-brand {
    justify-content: center;
  }
  .kp-has-sidebar.kp-sidebar-collapsed .kp-sidebar-head {
    flex-direction: column;
    gap: 6px;
  }
  /* Side-nav links collapse to a centred dot/initial. */
  .kp-has-sidebar.kp-sidebar-collapsed .kp-side-nav a {
    position: relative;
    padding: 0;
    height: 36px; width: 44px;
    margin: 4px auto;
    display: flex; align-items: center; justify-content: center;
    overflow: hidden;
    /* Show only the first 2 chars of the label as a fallback glyph. */
    color: transparent;
    font-size: 0;
    border-left: 0;
    border-radius: var(--kp-r-md);
  }
  .kp-has-sidebar.kp-sidebar-collapsed .kp-side-nav a::before {
    content: "•";
    color: var(--kp-ink-3);
    font-size: 18px; line-height: 1;
    transition: color .15s;
  }
  .kp-has-sidebar.kp-sidebar-collapsed .kp-side-nav a:hover::before { color: var(--kp-ink); }
  .kp-has-sidebar.kp-sidebar-collapsed .kp-side-nav a.kp-active {
    background: var(--kp-bg-tint);
  }
  .kp-has-sidebar.kp-sidebar-collapsed .kp-side-nav a.kp-active::before {
    color: var(--kp-yellow-hover);
  }
  /* Tooltip on hover/focus when collapsed. The label is read from
   * data-label="..." (set by JS at collapse time). */
  .kp-has-sidebar.kp-sidebar-collapsed .kp-side-nav a[data-label]::after {
    content: attr(data-label);
    position: absolute;
    left: calc(100% + 12px);
    top: 50%; transform: translateY(-50%) translateX(-4px);
    background: var(--kp-ink); color: #fff;
    padding: 6px 10px;
    border-radius: var(--kp-r-sm);
    font-size: var(--kp-fs-xs); font-weight: 500;
    white-space: nowrap;
    opacity: 0; pointer-events: none;
    transition: opacity .15s ease, transform .15s ease;
    z-index: 80;
    box-shadow: var(--kp-shadow-md);
  }
  .kp-has-sidebar.kp-sidebar-collapsed .kp-side-nav a:hover[data-label]::after,
  .kp-has-sidebar.kp-sidebar-collapsed .kp-side-nav a:focus-visible[data-label]::after {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
  }
}

/* Print: hide sidebar entirely */
@media print {
  .kp-sidebar, .kp-sidebar-toggle, .kp-sidebar-backdrop { display: none !important; }
  .kp-has-sidebar .kp-main { margin-left: 0 !important; max-width: 100% !important; }
}

/* Reduced motion: kill the collapse transitions. */
@media (prefers-reduced-motion: reduce) {
  .kp-sidebar, .kp-main, .kp-sidebar-collapse svg { transition: none !important; }
}

/* ---- Buttons ---------------------------------------------------------- */
.kp-btn {
  display: inline-flex; align-items: center; gap: var(--kp-s-2);
  padding: 12px 22px;
  font-size: var(--kp-fs-base); font-weight: 600;
  border: 1px solid transparent; border-radius: var(--kp-r-md);
  text-decoration: none; cursor: pointer;
  transition: background .18s ease, color .18s ease, transform .12s ease, border-color .18s ease;
  line-height: 1; white-space: nowrap;
}
.kp-btn:active { transform: translateY(1px); }
.kp-btn-primary { background: var(--kp-yellow); color: var(--kp-ink); border-color: var(--kp-yellow); }
.kp-btn-primary:hover { background: var(--kp-yellow-hover); border-color: var(--kp-yellow-hover); color: var(--kp-ink); }
.kp-btn-secondary { background: var(--kp-ink); color: #fff; border-color: var(--kp-ink); }
.kp-btn-secondary:hover { background: var(--kp-ink-2); border-color: var(--kp-ink-2); color: #fff; }
.kp-btn-ghost { background: transparent; color: var(--kp-ink); border-color: var(--kp-line-2); }
.kp-btn-ghost:hover { background: var(--kp-bg-alt); border-color: var(--kp-ink); }
.kp-btn-sm { padding: 8px 14px; font-size: var(--kp-fs-sm); }
.kp-btn-lg { padding: 16px 28px; font-size: var(--kp-fs-lg); }
.kp-btn:focus-visible { outline: 3px solid color-mix(in srgb, var(--kp-yellow) 70%, transparent); outline-offset: 2px; }

/* ---- Pills / badges --------------------------------------------------- */
.kp-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 14px;
  background: var(--kp-yellow); color: var(--kp-ink);
  font-size: var(--kp-fs-xs); font-weight: 600;
  border-radius: var(--kp-r-pill);
}
.kp-pill-ghost { background: transparent; border: 1px solid var(--kp-line-2); color: var(--kp-ink-2); }
.kp-pill-dark  { background: var(--kp-ink); color: #fff; }
.kp-pill-dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.kp-badge {
  display: inline-block; padding: 2px 8px;
  font-size: var(--kp-fs-xs); font-weight: 600;
  border-radius: var(--kp-r-sm);
  background: var(--kp-bg-alt); color: var(--kp-ink-2);
}
.kp-badge-success { background: #E7F5EC; color: var(--kp-success); }
.kp-badge-danger  { background: #FBEAEB; color: var(--kp-danger); }
.kp-badge-info    { background: #E7F0FA; color: var(--kp-info); }

/* ---- Cards ------------------------------------------------------------ */
.kp-card {
  background: #fff;
  border: 1px solid var(--kp-line);
  border-radius: var(--kp-r-lg);
  padding: var(--kp-s-6);
  box-shadow: var(--kp-shadow-sm);
  transition: box-shadow .2s ease, transform .15s ease, border-color .2s ease;
}
.kp-card:hover { box-shadow: var(--kp-shadow-md); }
.kp-card-link { display: block; text-decoration: none; color: inherit; }
.kp-card-link:hover { transform: translateY(-2px); border-color: var(--kp-line-2); }
.kp-card-tight { padding: var(--kp-s-5); }
.kp-card-accent { border-left: 4px solid var(--kp-yellow); }

.kp-stat {
  display: flex; flex-direction: column; gap: var(--kp-s-2);
  padding: var(--kp-s-6);
  background: #fff; border: 1px solid var(--kp-line);
  border-radius: var(--kp-r-lg);
}
.kp-stat-num { font-size: var(--kp-fs-4xl); font-weight: 800; letter-spacing: -0.03em; line-height: 1; }
.kp-stat-label { font-size: var(--kp-fs-sm); color: var(--kp-ink-3); font-weight: 500; }

/* Flippable cards */
.kp-flip {
  background: transparent; border: 0; padding: 0; width: 100%;
  perspective: 1000px; cursor: pointer; text-align: left;
  font-family: inherit; color: inherit;
}
.kp-flip-inner {
  position: relative; width: 100%; min-height: 180px;
  transition: transform .55s cubic-bezier(.2,.8,.2,1);
  transform-style: preserve-3d;
}
.kp-flip[aria-expanded="true"] .kp-flip-inner { transform: rotateY(180deg); }
.kp-flip-front, .kp-flip-back {
  position: absolute; inset: 0;
  -webkit-backface-visibility: hidden; backface-visibility: hidden;
  background: #fff; border: 1px solid var(--kp-line);
  border-radius: var(--kp-r-lg);
  padding: var(--kp-s-5);
  display: flex; flex-direction: column; justify-content: space-between;
  box-shadow: var(--kp-shadow-sm);
}
.kp-flip-back { transform: rotateY(180deg); background: var(--kp-ink); color: #fff; border-color: var(--kp-ink); }
@media (hover: hover) and (pointer: fine) {
  .kp-flip:hover .kp-flip-inner { transform: rotateY(180deg); }
}

/* Accordion (disclosure list) */
.kp-accordion { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--kp-line); }
.kp-acc-item { border-bottom: 1px solid var(--kp-line); }
.kp-acc-btn {
  width: 100%; background: transparent; border: 0; padding: var(--kp-s-5) 0;
  display: flex; align-items: center; gap: var(--kp-s-3);
  font-size: var(--kp-fs-lg); font-weight: 600; color: var(--kp-ink); cursor: pointer; text-align: left;
}
.kp-acc-btn:focus-visible { outline: 2px solid var(--kp-yellow); outline-offset: 4px; }
.kp-acc-arrow { margin-left: auto; transition: transform .25s ease; color: var(--kp-ink-3); }
.kp-acc-item[aria-expanded="true"] .kp-acc-arrow { transform: rotate(180deg); }
.kp-acc-body {
  max-height: 0; overflow: hidden;
  transition: max-height .35s ease;
  color: var(--kp-ink-2); font-size: var(--kp-fs-base);
}
.kp-acc-body-inner { padding: 0 0 var(--kp-s-5); max-width: 720px; }

/* ---- Tables ----------------------------------------------------------- */
.kp-table {
  width: 100%; border-collapse: separate; border-spacing: 0;
  background: #fff; border: 1px solid var(--kp-line); border-radius: var(--kp-r-lg);
  overflow: hidden;
}
.kp-table th, .kp-table td { padding: 14px 18px; text-align: left; vertical-align: top; font-size: var(--kp-fs-sm); }
.kp-table thead th { background: var(--kp-bg-alt); font-weight: 600; color: var(--kp-ink-2); border-bottom: 1px solid var(--kp-line); }
.kp-table tbody tr + tr td { border-top: 1px solid var(--kp-line); }
.kp-table tbody tr:hover td { background: var(--kp-bg-alt); }
.kp-table-compare th:first-child, .kp-table-compare td:first-child { font-weight: 600; }
.kp-table-compare td.kp-yes { color: var(--kp-success); font-weight: 600; }
.kp-table-compare td.kp-no { color: var(--kp-ink-3); }

/* ---- Forms ------------------------------------------------------------ */
.kp-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: var(--kp-s-4); }
.kp-label { font-size: var(--kp-fs-sm); font-weight: 600; color: var(--kp-ink-2); }
.kp-input, .kp-select, .kp-textarea {
  font: inherit; color: var(--kp-ink);
  background: #fff; border: 1px solid var(--kp-line-2);
  border-radius: var(--kp-r-md); padding: 12px 14px;
  transition: border-color .15s, box-shadow .15s;
}
.kp-input:focus, .kp-select:focus, .kp-textarea:focus {
  outline: none; border-color: var(--kp-ink);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--kp-yellow) 40%, transparent);
}
.kp-input:disabled, .kp-select:disabled, .kp-textarea:disabled {
  background: var(--kp-bg-alt); color: var(--kp-ink-3); cursor: not-allowed;
}
.kp-input.kp-invalid, .kp-select.kp-invalid, .kp-textarea.kp-invalid { border-color: var(--kp-danger); }
.kp-help { font-size: var(--kp-fs-xs); color: var(--kp-ink-3); }
.kp-help.kp-error { color: var(--kp-danger); }

.kp-alert {
  background: #FBEAEB; color: var(--kp-danger);
  border: 1px solid #F2C8CB; border-radius: var(--kp-r-md);
  padding: var(--kp-s-3) var(--kp-s-4);
  font-size: var(--kp-fs-sm); margin-bottom: var(--kp-s-4);
}
.kp-alert-info { background: #E7F0FA; color: var(--kp-info); border-color: #C5DCEF; }
.kp-alert-success { background: #E7F5EC; color: var(--kp-success); border-color: #BFE2CC; }

/* ---- Modal / drawer --------------------------------------------------- */
.kp-modal-backdrop {
  position: fixed; inset: 0; background: rgba(18,18,18,.55);
  display: flex; align-items: center; justify-content: center;
  z-index: 100; padding: var(--kp-s-5);
}
.kp-modal-backdrop[hidden] { display: none; }
.kp-modal {
  background: #fff; color: var(--kp-ink);
  border-radius: var(--kp-r-lg);
  max-width: 640px; width: 100%;
  max-height: 90vh; overflow: auto;
  padding: var(--kp-s-6);
  box-shadow: var(--kp-shadow-lg);
}
.kp-modal-head { display: flex; align-items: flex-start; gap: var(--kp-s-3); }
.kp-modal-close {
  margin-left: auto; background: transparent; border: 0; padding: 4px; cursor: pointer;
  color: var(--kp-ink-3); border-radius: var(--kp-r-sm);
}
.kp-modal-close:hover { background: var(--kp-bg-alt); color: var(--kp-ink); }

.kp-drawer-backdrop {
  position: fixed; inset: 0; background: rgba(18,18,18,.5);
  z-index: 100;
}
.kp-drawer {
  position: fixed; top: 0; right: 0; bottom: 0; width: min(420px, 100%);
  background: #fff; box-shadow: var(--kp-shadow-lg);
  padding: var(--kp-s-6); overflow: auto;
  z-index: 101;
}

/* ---- Media wrappers --------------------------------------------------- */
.kp-img { border-radius: var(--kp-r-lg); overflow: hidden; }
.kp-img img { width: 100%; height: auto; display: block; }
.kp-img-frame { border: 1px solid var(--kp-line); }

.kp-video {
  position: relative;
  border-radius: var(--kp-r-lg);
  overflow: hidden;
  background: var(--kp-ink);
  aspect-ratio: 16 / 9;
}
.kp-video video, .kp-video iframe {
  position: absolute; inset: 0; width: 100%; height: 100%; border: 0;
}
.kp-video-cover { object-fit: cover; }

.kp-aspect-1 { aspect-ratio: 1 / 1; }
.kp-aspect-4-3 { aspect-ratio: 4 / 3; }
.kp-aspect-16-9 { aspect-ratio: 16 / 9; }
.kp-aspect-21-9 { aspect-ratio: 21 / 9; }

/* ---- Hero ------------------------------------------------------------- */
.kp-hero {
  position: relative;
  padding: var(--kp-s-9) 0 var(--kp-s-8);
  background: linear-gradient(180deg, var(--kp-bg-tint) 0%, #fff 100%);
}
.kp-hero-grid {
  display: grid; gap: var(--kp-s-7); align-items: center;
  grid-template-columns: minmax(0, 1fr);
}
@media (min-width: 880px) {
  .kp-hero-grid { grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr); }
}
/* All direct grid children should respect the cell width, never overflow it. */
.kp-hero-grid > * { min-width: 0; }
.kp-hero-pills { display: flex; gap: var(--kp-s-2); flex-wrap: wrap; margin-top: var(--kp-s-5); }
.kp-hero-actions { display: flex; gap: var(--kp-s-3); flex-wrap: wrap; margin-top: var(--kp-s-5); }
.kp-hero-image {
  border-radius: var(--kp-r-xl); overflow: hidden;
  box-shadow: var(--kp-shadow-lg);
  max-width: 100%;
}
.kp-hero-image img { width: 100%; height: auto; display: block; }

/* ---- Login page ------------------------------------------------------- */
.kp-login-body {
  background: linear-gradient(180deg, var(--kp-bg-tint) 0%, #fff 60%);
  min-height: 100dvh;
  display: flex; align-items: center; justify-content: center;
  padding: var(--kp-s-5);
}
.kp-login-card {
  width: 100%; max-width: 420px;
  background: #fff;
  border: 1px solid var(--kp-line);
  border-radius: var(--kp-r-lg);
  padding: var(--kp-s-7);
  box-shadow: var(--kp-shadow-md);
}
.kp-login-card .kp-brand { display: inline-flex; margin-bottom: var(--kp-s-5); }
.kp-login-card form { margin-top: var(--kp-s-5); }
.kp-login-card .kp-btn { width: 100%; justify-content: center; margin-top: var(--kp-s-3); }
.kp-login-card .kp-fineprint { margin-top: var(--kp-s-5); text-align: center; }

/* ---- Reveal on scroll + reduced motion -------------------------------- */
.kp-reveal { opacity: 0; transform: translateY(24px); transition: opacity .65s ease, transform .65s ease; }
.kp-reveal.kp-visible { opacity: 1; transform: translateY(0); }
.kp-reveal.kp-d1 { transition-delay: .08s; }
.kp-reveal.kp-d2 { transition-delay: .18s; }
.kp-reveal.kp-d3 { transition-delay: .28s; }
.kp-reveal.kp-d4 { transition-delay: .38s; }

@media (prefers-reduced-motion: reduce) {
  .kp-reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  html { scroll-behavior: auto; }
}

/* ---- Utility ---------------------------------------------------------- */
.kp-hide { display: none !important; }
.kp-mt-0 { margin-top: 0 !important; }
.kp-mt-3 { margin-top: var(--kp-s-3); }
.kp-mt-5 { margin-top: var(--kp-s-5); }
.kp-mt-7 { margin-top: var(--kp-s-7); }
.kp-mb-0 { margin-bottom: 0 !important; }
.kp-text-center { text-align: center; }
.kp-text-balance { text-wrap: balance; }
.kp-flex { display: flex; }
.kp-flex-wrap { flex-wrap: wrap; }
.kp-gap-2 { gap: var(--kp-s-2); }
.kp-gap-3 { gap: var(--kp-s-3); }
.kp-gap-5 { gap: var(--kp-s-5); }
.kp-items-center { align-items: center; }
.kp-justify-between { justify-content: space-between; }
.kp-w-full { width: 100%; }
