/* =====================================================================
   Keygrip — Public (logged-out) brand design system
   Light / editorial: off-white canvas, bright-cyan blocks, serif display,
   monospace technical labels. Sourced from the 2026 brand deck.

   Linked via {% static 'css/public-brand.css' %} from base_public.html.
   A linked stylesheet needs NO CSP nonce (only inline <style> blocks do).

   Tokens are CSS custom properties — to match the deck's exact serif/cyan,
   change the single variable here and every page follows.
   ===================================================================== */

/* ============================ fonts ============================ */
/* Kateka — the deck's display serif (self-hosted, licensed web kit).
   Same-origin, so no CSP change needed. Paths are relative to THIS file
   (/static/css/ -> /static/fonts/). */
@font-face {
    font-family: 'Kateka';
    src: url('../fonts/Kateka-Regular.woff2') format('woff2');
    font-weight: 400 500;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Kateka';
    src: url('../fonts/Kateka-Bold.woff2') format('woff2');
    font-weight: 600 700;
    font-style: normal;
    font-display: swap;
}

:root {
    /* ===== 6-COLOR CORE (the entire public palette) =====
       Everything else is one of these at reduced opacity. */
    --kg-canvas:  #EEF2F6;   /* 1. page background (cool off-white) */
    --kg-surface: #FFFFFF;   /* 2. cards, panels */
    --kg-ink:     #0F172A;   /* 3. headings, numbers, dark-section bg, text-on-cyan */
    --kg-grey:    #475569;   /* 4. all secondary text, labels, eyebrows */
    --kg-line:    #E2E8F0;   /* 5. borders, dividers */
    --kg-cyan:    #61D9EF;   /* 6. brand accent — FILLS ONLY (blocks, buttons, nodes) */

    /* Aliases — old token names resolve into the 6 so existing refs keep working.
       Cyan is fill-only (illegible as small text on white), so accents -> grey,
       text-on-cyan -> ink. Hovers use brightness filters, not new shades. */
    --kg-surface-2:   var(--kg-surface);
    --kg-ink-soft:    var(--kg-grey);
    --kg-ink-faint:   var(--kg-grey);
    --kg-line-strong: var(--kg-line);
    --kg-cyan-soft:   var(--kg-cyan);
    --kg-cyan-strong: var(--kg-grey);
    --kg-cyan-ink:    var(--kg-ink);

    /* --- type --- */
    --kg-serif: 'Kateka', Georgia, 'Times New Roman', serif;
    --kg-sans:  'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;

    /* --- scale / layout --- */
    --kg-maxw:    1180px;
    --kg-gutter:  28px;
    --kg-radius:  14px;
    --kg-radius-sm: 8px;
    --kg-header-h: 68px;

    /* --- motion --- */
    --kg-ease: cubic-bezier(0.16, 1, 0.3, 1);
}

/* ============================ reset ============================ */
.kg, .kg *, .kg *::before, .kg *::after { box-sizing: border-box; }
.kg { margin: 0; }

html { scroll-behavior: smooth; overflow-x: clip; }

body.kg {
    margin: 0;
    font-family: var(--kg-sans);
    background: var(--kg-canvas);
    color: var(--kg-ink-soft);
    font-size: 17px;
    line-height: 1.6;
    font-weight: 500;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: clip;   /* clip (not hidden) so position:sticky header still works */
}

.kg a { color: inherit; text-decoration: none; }
.kg img, .kg svg { display: block; max-width: 100%; }

/* ============================ layout ============================ */
.kg-container { max-width: var(--kg-maxw); margin: 0 auto; padding: 0 var(--kg-gutter); }
.kg-section   { padding: clamp(64px, 9vw, 128px) 0; }
.kg-section--tight { padding: clamp(40px, 6vw, 80px) 0; }
.kg-divider   { border: none; border-top: 1px solid var(--kg-line); margin: 0; }

/* ============================ type ============================ */
.kg-eyebrow {
    font-family: var(--kg-serif);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--kg-cyan-strong);
    margin: 0 0 18px;
}

.kg-display {
    font-family: var(--kg-serif);
    font-weight: 400;
    color: var(--kg-ink);
    line-height: 1.04;
    letter-spacing: -0.015em;
    font-size: clamp(2.6rem, 6vw, 4.6rem);
    margin: 0;
    overflow-wrap: break-word;   /* never overflow narrow viewports */
}
.kg-h2 {
    font-family: var(--kg-serif);
    font-weight: 400;
    color: var(--kg-ink);
    line-height: 1.1;
    letter-spacing: -0.01em;
    font-size: clamp(1.7rem, 3.4vw, 2.5rem);   /* uniform section-header size */
    margin: 0 0 20px;
}
.kg-h3 {
    font-family: var(--kg-serif);
    font-weight: 500;
    color: var(--kg-ink);
    line-height: 1.2;
    font-size: clamp(1.3rem, 2vw, 1.6rem);
    margin: 0 0 12px;
}
.kg-lead {
    font-size: clamp(1.05rem, 1.6vw, 1.3rem);
    color: var(--kg-ink-soft);
    line-height: 1.55;
    max-width: 38ch;
    margin: 0;
}
.kg-prose { color: var(--kg-ink-soft); }
.kg-prose p { margin: 0 0 1.1em; }
.kg-ink { color: var(--kg-ink); }
.kg-serif { font-family: var(--kg-serif); }
.kg-mono  { font-family: var(--kg-serif); } /* legacy alias — mono retired, now Kateka */
.kg-cyan-text { color: var(--kg-ink); }

/* ============================ buttons ============================ */
.kg-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-family: var(--kg-sans);
    font-weight: 600;
    font-size: 0.95rem;
    line-height: 1;
    padding: 14px 22px;
    border-radius: var(--kg-radius-sm);
    border: 1px solid transparent;
    cursor: pointer;
    transition: transform 0.18s var(--kg-ease), background 0.18s var(--kg-ease), border-color 0.18s var(--kg-ease);
    white-space: nowrap;
}
.kg-btn:active { transform: translateY(1px); }

.kg-btn--primary {
    background: var(--kg-cyan);
    color: var(--kg-cyan-ink);
}
.kg-btn--primary:hover { filter: brightness(1.07); }

.kg-btn--dark {
    background: var(--kg-ink);
    color: #fff;
}
.kg-btn--dark:hover { filter: brightness(1.5); }

.kg-btn--ghost {
    background: transparent;
    color: var(--kg-ink);
    border-color: rgba(71, 85, 105, 0.45);   /* core grey @ 45% — visible but quiet */
}
.kg-btn--ghost:hover { border-color: var(--kg-ink); }

.kg-btn--lg { padding: 16px 28px; font-size: 1rem; }

.kg-link-arrow {
    font-weight: 600;
    color: var(--kg-cyan-strong);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.kg-link-arrow:hover { gap: 10px; color: var(--kg-ink); transition: gap 0.18s var(--kg-ease), color 0.18s var(--kg-ease); }

/* ============================ header ============================ */
.kg-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(238, 242, 246, 0.85);
    backdrop-filter: saturate(180%) blur(12px);
    border-bottom: 1px solid var(--kg-line);
}
.kg-header__inner {
    display: flex;
    align-items: center;
    height: var(--kg-header-h);
    gap: 24px;
}
.kg-wordmark {
    font-family: var(--kg-serif);
    font-weight: 500;
    font-size: 1.6rem;
    letter-spacing: -0.02em;
    color: var(--kg-ink);
}
.kg-nav { display: flex; align-items: center; gap: 30px; margin-left: auto; margin-right: 40px; }
.kg-nav a {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--kg-ink-soft);
    transition: color 0.15s ease;
}
.kg-nav a:hover { color: var(--kg-ink); }
.kg-header__cta { display: flex; align-items: center; gap: 16px; }
.kg-nav-toggle { display: none; background: none; border: 0; cursor: pointer; color: var(--kg-ink); }

/* ============================ hero / cyan block ============================ */
.kg-hero {
    display: grid;
    grid-template-columns: 0.85fr 1.15fr;
    align-items: stretch;
    min-height: min(78vh, 720px);
}
.kg-hero__block {
    background: var(--kg-cyan);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px;
}
.kg-hero__block .kg-wordmark--xl {
    font-family: var(--kg-serif);
    font-weight: 500;
    color: var(--kg-cyan-ink);
    font-size: clamp(3rem, 7vw, 6rem);
    letter-spacing: -0.03em;
    line-height: 1;
}
.kg-hero__content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: clamp(40px, 7vw, 96px);
    padding-right: var(--kg-gutter);
}
.kg-hero__actions { display: flex; gap: 14px; margin-top: 36px; flex-wrap: wrap; }

/* Blinking terminal-style cursor after the hero wordmark */
.kg-cursor {
    display: inline-block;
    width: 0.06em;
    height: 0.74em;
    margin-left: 0.06em;
    vertical-align: -0.02em;
    background: var(--kg-ink);
    animation: kg-blink 1.1s 5 forwards;   /* blink 5x then disappear */
}
@keyframes kg-blink { 0%, 49% { opacity: 1; } 50%, 100% { opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .kg-cursor { display: none; } }

/* full-bleed cyan band (section breaker / CTA) */
.kg-band-cyan { background: var(--kg-cyan); color: var(--kg-cyan-ink); }
.kg-band-cyan .kg-display,
.kg-band-cyan .kg-h2 { color: var(--kg-cyan-ink); }
.kg-band-cyan .kg-lead { color: var(--kg-ink); }
.kg-band-dark { background: var(--kg-ink); color: rgba(255, 255, 255, 0.72); }
.kg-band-dark .kg-display,
.kg-band-dark .kg-h2,
.kg-band-dark .kg-h3 { color: #fff; }
.kg-band-dark .kg-lead { color: rgba(255, 255, 255, 0.6); }
/* Diagram/matrix inside a dark band: ONE dark shade (var(--kg-ink)) for every
   surface, separated only by a hairline of white. Greys here are white@opacity,
   not extra hues. */
.kg-band-dark .kg-diagram { background: var(--kg-ink); border-color: rgba(255, 255, 255, 0.12); }
.kg-band-dark .kg-diagram__label { color: rgba(255, 255, 255, 0.45); }
.kg-band-dark .kg-node { background: var(--kg-ink); border-color: rgba(255, 255, 255, 0.16); color: rgba(255, 255, 255, 0.88); }
.kg-band-dark .kg-node--accent { background: var(--kg-cyan); border-color: var(--kg-cyan); color: var(--kg-ink); }
.kg-band-dark .kg-arrow { color: rgba(255, 255, 255, 0.3); }
.kg-band-dark .kg-matrix th { background: var(--kg-ink); color: rgba(255, 255, 255, 0.45); border-color: rgba(255, 255, 255, 0.12); }
.kg-band-dark .kg-matrix td { color: rgba(255, 255, 255, 0.78); border-color: rgba(255, 255, 255, 0.12); }

/* ============================ feature grid ============================ */
.kg-grid { display: grid; gap: clamp(20px, 3vw, 40px); }
.kg-grid--2 { grid-template-columns: repeat(2, 1fr); }
.kg-grid--3 { grid-template-columns: repeat(3, 1fr); }
.kg-grid--single { max-width: 620px; margin-inline: auto; }
.kg-split { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(32px, 6vw, 72px); align-items: center; }

.kg-card {
    background: var(--kg-surface);
    border: 1px solid var(--kg-line);
    border-radius: var(--kg-radius);
    padding: 32px;
}
.kg-card__num {
    font-family: var(--kg-serif);
    font-size: 0.8rem;
    color: var(--kg-cyan-strong);
    letter-spacing: 0.1em;
}
/* team / founder cards */
.kg-team__photo { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; object-position: top center; border: 1px solid var(--kg-line); border-radius: var(--kg-radius); display: block; margin-bottom: 22px; }
.kg-team__photo--mono { display: flex; align-items: center; justify-content: center; background: var(--kg-canvas); font-family: var(--kg-serif); font-size: clamp(2.2rem, 4vw, 3rem); color: var(--kg-grey); }
/* a card that is itself a link */
a.kg-card { display: block; text-decoration: none; color: inherit; transition: border-color 0.25s var(--kg-ease), transform 0.25s var(--kg-ease); }
a.kg-card:hover { border-color: var(--kg-ink); transform: translateY(-2px); }

/* ============================ metric / stat cards ============================ */
.kg-metric-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; max-width: 720px; }
.kg-metric {
    background: var(--kg-surface);
    border: 1px solid var(--kg-line);
    border-radius: var(--kg-radius);
    padding: 34px 28px;
    text-align: center;
}
.kg-metric__label {
    font-family: var(--kg-sans);  /* sans header */
    font-size: 1rem;
    font-weight: 600;
    margin: 0 0 12px;
    color: var(--kg-grey);        /* all card headers grey */
}
.kg-metric__value {
    font-family: var(--kg-serif);   /* Kateka */
    font-weight: 400;               /* not bold */
    font-size: clamp(2.1rem, 4.1vw, 2.85rem);   /* 2px smaller */
    line-height: 1;
    color: var(--kg-ink);
}

/* ============================ channel performance chart ============================ */
.kg-chart {
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--kg-radius);
    padding: clamp(18px, 2vw, 26px);
    max-width: none;
    margin: 0;   /* fills the right column of the compatibility row */
    width: 110%;  /* 10% wider, bleeding into the right margin (left edge fixed) */
    text-align: left;
}
@media (max-width: 860px) { .kg-chart { width: 100%; } }
.kg-chart__head { display: flex; justify-content: space-between; align-items: center; gap: 16px; margin-bottom: 18px; }
.kg-chart__title { font-family: var(--kg-sans); font-weight: 700; font-size: 1.25rem; color: #fff; }
.kg-chart__range { display: inline-flex; background: rgba(255, 255, 255, 0.06); border-radius: 8px; padding: 3px; }
.kg-chart__range button { font-family: var(--kg-sans); font-size: 0.8rem; font-weight: 600; color: rgba(255, 255, 255, 0.55); background: none; border: 0; padding: 6px 14px; border-radius: 6px; cursor: pointer; }
.kg-chart__range button.is-active { background: rgba(255, 255, 255, 0.12); color: #fff; }
.kg-chart__tabs { display: flex; gap: 8px; margin-bottom: 16px; }
.kg-chart__tabs button { font-family: var(--kg-sans); font-size: 0.85rem; font-weight: 600; color: rgba(255, 255, 255, 0.55); background: none; border: 1px solid transparent; padding: 7px 16px; border-radius: 999px; cursor: pointer; }
.kg-chart__tabs button.is-active { color: var(--kg-cyan); border-color: rgba(97, 217, 239, 0.4); }
.kg-chart__canvas-wrap { position: relative; height: clamp(220px, 22vw, 290px); }
.kg-chart__canvas-wrap canvas { width: 100%; height: 100%; display: block; }
.kg-chart__legend { display: flex; flex-wrap: wrap; gap: 18px; justify-content: center; margin-top: 18px; }
.kg-chart__legend button { display: inline-flex; align-items: center; gap: 8px; font-family: var(--kg-sans); font-size: 0.9rem; font-weight: 600; color: rgba(255, 255, 255, 0.85); background: none; border: 0; cursor: pointer; transition: opacity 0.15s ease; }
.kg-chart__legend button.is-off { opacity: 0.35; }
.kg-chart__legend .dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }

/* ============================ system diagram ============================ */
.kg-diagram {
    background: var(--kg-surface);
    border: 1px solid var(--kg-line);
    border-radius: var(--kg-radius);
    padding: clamp(24px, 4vw, 48px);
}
.kg-diagram__label {
    font-family: var(--kg-serif);
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--kg-ink-faint);
    margin-bottom: 20px;
}
.kg-node {
    font-family: var(--kg-serif);
    font-size: 0.82rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--kg-ink);
    border: 1px solid var(--kg-line-strong);
    border-radius: var(--kg-radius-sm);
    background: var(--kg-surface);
    padding: 16px 20px;
    text-align: center;
}
.kg-node--accent { background: var(--kg-cyan); border-color: var(--kg-cyan); color: var(--kg-cyan-ink); }
.kg-arrow { display: flex; justify-content: center; color: var(--kg-line-strong); font-size: 1.3rem; line-height: 1; padding: 6px 0; }
.kg-node-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }

/* ============================ compatibility matrix ============================ */
.kg-matrix {
    width: 100%;
    border-collapse: collapse;
    font-family: var(--kg-serif);
    font-size: 0.8rem;
}
.kg-matrix th, .kg-matrix td {
    border: 1px solid var(--kg-line);
    padding: 12px 16px;
    text-align: left;
    color: var(--kg-ink-soft);
}
.kg-matrix th {
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--kg-ink-faint);
    font-weight: 500;
    background: var(--kg-surface-2);
}
/* Borderless / no-box variant */
.kg-matrix--bare th, .kg-matrix--bare td { border: 0; padding: 9px 48px 9px 0; }
.kg-band-dark .kg-matrix--bare th { background: transparent; }

/* ============================ compatibility chips ============================ */
/* Two-column: chips (left) + chart (right) */
.kg-compat-row { display: grid; grid-template-columns: 0.82fr 1.18fr; gap: clamp(32px, 5vw, 56px); align-items: start; }
/* Two-column directory table: LLMs | Content Management, each a header rule + divided rows */
.kg-compat { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px, 3vw, 36px); align-items: start; }
.kg-compat__label {
    font-family: var(--kg-serif);
    font-size: 0.85rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.5);
    text-align: left;
    margin: 0 0 4px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.16);
}
.kg-compat__grid { display: block; }
.kg-chip {
    display: block;
    font-family: var(--kg-serif);
    font-size: 1.05rem;
    color: rgba(255, 255, 255, 0.88);
    padding: 13px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.kg-compat__grid .kg-chip:last-child { border-bottom: none; }
@media (max-width: 860px) { .kg-compat-row { grid-template-columns: 1fr; gap: 40px; } }
@media (max-width: 560px) { .kg-compat { grid-template-columns: 1fr; } }

/* ============================ quote ============================ */
.kg-quote {
    border-left: 3px solid var(--kg-cyan);
    padding: 6px 0 6px 28px;
    max-width: 60ch;
    margin: 0;
}
.kg-quote p {
    font-family: var(--kg-serif);
    font-size: clamp(1.25rem, 2vw, 1.6rem);
    line-height: 1.4;
    color: var(--kg-ink);
    margin: 0 0 14px;
}
.kg-quote cite {
    font-family: var(--kg-sans);
    font-style: normal;
    font-size: 0.95rem;
    color: var(--kg-grey);
}
.kg-band-dark .kg-quote p { color: #fff; }
.kg-band-dark .kg-quote cite { color: rgba(255, 255, 255, 0.55); }
.kg-band-dark .kg-link-arrow { color: rgba(255, 255, 255, 0.7); }
.kg-band-dark .kg-link-arrow:hover { color: #fff; }

/* ============================ proof / logo strip ============================ */
.kg-proof { display: flex; flex-direction: column; gap: 28px; }
.kg-proof__row {
    display: grid;
    grid-template-columns: 180px 1fr;
    gap: 28px;
    align-items: center;
    padding-bottom: 28px;
    border-bottom: 1px solid var(--kg-line);
}
.kg-proof__row:last-child { border-bottom: none; padding-bottom: 0; }
.kg-proof__logo {
    font-family: var(--kg-serif);
    font-size: 1.35rem;
    color: var(--kg-ink);
    font-weight: 500;
    transition: opacity 0.15s var(--kg-ease);
}
a.kg-proof__logo:hover { opacity: 0.6; }
.kg-proof__text { color: var(--kg-ink-soft); font-size: 1.02rem; }
.kg-proof__text em { font-style: italic; color: var(--kg-ink); }

/* ============================ pricing ============================ */
.kg-price-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; align-items: stretch; }
.kg-price-card {
    background: var(--kg-surface);
    border: 1px solid var(--kg-line);
    border-radius: var(--kg-radius);
    padding: 56px 32px;
    display: flex;
    flex-direction: column;
}
.kg-price-card--featured { border-color: var(--kg-cyan); box-shadow: 0 0 0 1px var(--kg-cyan); }
.kg-price-card__tag {
    font-family: var(--kg-serif);
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--kg-cyan-strong);
    margin-bottom: 14px;
}
.kg-price-card__name { font-family: var(--kg-serif); font-size: 1.7rem; color: var(--kg-ink); margin: 0 0 8px; }
.kg-price-card__price { display: flex; align-items: baseline; gap: 6px; margin: 8px 0 4px; }
.kg-price-card__amount { font-family: var(--kg-serif); font-size: 3rem; color: var(--kg-ink); line-height: 1; }
.kg-price-card__period { color: var(--kg-ink-faint); font-size: 0.95rem; }
.kg-price-card__credits {
    font-family: var(--kg-serif);
    font-size: 0.85rem;
    color: var(--kg-cyan-strong);
    letter-spacing: 0.04em;
    margin: 6px 0 24px;
}
.kg-price-card ul { list-style: none; margin: 28px 0 28px; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.kg-price-card li { display: flex; gap: 10px; font-size: 0.95rem; color: var(--kg-ink-soft); }
.kg-price-card li::before { content: "·"; color: var(--kg-cyan-strong); }
.kg-price-card .kg-btn { margin-top: auto; width: 100%; }

/* ============================ forms ============================ */
.kg-form-card {
    background: var(--kg-surface);
    border: 1px solid var(--kg-line);
    border-radius: var(--kg-radius);
    padding: clamp(28px, 4vw, 44px);
    max-width: 560px;
    margin: 0 auto;
}
.kg-form { display: flex; flex-direction: column; gap: 20px; }
.kg-field { display: flex; flex-direction: column; gap: 8px; }
.kg-label { font-weight: 600; font-size: 0.9rem; color: var(--kg-ink); }
.kg-label span { color: var(--kg-ink-faint); font-weight: 500; }
.kg-input, .kg-textarea {
    font-family: var(--kg-sans);
    font-size: 1rem;
    color: var(--kg-ink);
    background: #fff;
    border: 1px solid var(--kg-line-strong);
    border-radius: var(--kg-radius-sm);
    padding: 13px 15px;
    width: 100%;
    transition: border-color 0.15s var(--kg-ease), box-shadow 0.15s var(--kg-ease);
}
.kg-input::placeholder, .kg-textarea::placeholder { color: var(--kg-ink-faint); }
.kg-input:focus, .kg-textarea:focus {
    outline: none;
    border-color: var(--kg-cyan);
    box-shadow: 0 0 0 3px rgba(97, 217, 239, 0.3);
}
.kg-input--error { border-color: #DC2626; }
.kg-field__error { color: #DC2626; font-size: 0.85rem; }
.kg-textarea { resize: vertical; min-height: 96px; }

/* ============================ footer ============================ */
.kg-footer {
    background: var(--kg-surface);
    border-top: 1px solid var(--kg-line);
    padding: 56px 0 40px;
}
.kg-footer__row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}
.kg-footer__brand { font-family: var(--kg-serif); font-size: 1.3rem; color: var(--kg-ink); font-weight: 500; }
.kg-footer__links { display: flex; flex-wrap: wrap; gap: 24px; }
.kg-footer__links a { font-size: 0.92rem; color: var(--kg-ink-soft); }
.kg-footer__links a:hover { color: var(--kg-ink); }
.kg-footer__meta { font-size: 0.85rem; color: var(--kg-ink-faint); }

/* ============================ scroll reveal ============================ */
.kg-reveal {
    opacity: 0;
    transform: translateY(22px);
    transition: opacity 0.8s var(--kg-ease), transform 0.8s var(--kg-ease);
}
.kg-reveal.is-visible { opacity: 1; transform: none; }
.kg-reveal-d1 { transition-delay: 0.08s; }
.kg-reveal-d2 { transition-delay: 0.16s; }
.kg-reveal-d3 { transition-delay: 0.24s; }
@media (prefers-reduced-motion: reduce) {
    .kg-reveal { opacity: 1; transform: none; transition: none; }
    html { scroll-behavior: auto; }
}

/* ============================ responsive ============================ */
@media (max-width: 860px) {
    .kg-hero { grid-template-columns: 1fr; min-height: auto; }
    .kg-hero__block { padding: 56px 32px; }
    .kg-hero__content { padding: 48px var(--kg-gutter); }
    .kg-grid--2, .kg-grid--3, .kg-price-grid, .kg-node-row, .kg-split { grid-template-columns: 1fr; }
    .kg-nav { display: none; }
    .kg-nav-toggle { display: inline-flex; }
    .kg-proof__row { grid-template-columns: 1fr; gap: 10px; }
}
@media (max-width: 480px) {
    body.kg { font-size: 16px; }
    /* Shrink display type so long serif headlines don't overflow narrow screens. */
    .kg-display { font-size: clamp(2rem, 9vw, 2.6rem); }
    .kg-h2 { font-size: clamp(1.6rem, 7vw, 2rem); }
    .kg-hero__content { padding: 40px 20px; }
    .kg-hero__block { padding: 44px 20px; }
    .kg-hero__block .kg-wordmark--xl { font-size: clamp(2.6rem, 14vw, 3.4rem); }
    .kg-header__cta a:not(.kg-btn) { display: none; } /* hide "Log in" text; keep primary CTA */
    .kg-lead { max-width: none; }
}

/* ============================================================
   PRODUCT PAGE — answer card (hero visual) + FAQ accordion
   ============================================================ */

/* Hero "answer card": a static mock of an LLM answer citing the brand. */
.kg-answer {
    background: var(--kg-surface);
    border: 1px solid var(--kg-line);
    border-radius: 16px;
    padding: 26px;
    box-shadow: 0 26px 64px -34px rgba(15, 23, 42, 0.30);
}
.kg-answer__tabs { display: flex; gap: 8px; margin-bottom: 20px; }
.kg-answer__tab {
    font-family: var(--kg-sans); font-size: 0.8rem; font-weight: 600;
    padding: 6px 13px; border-radius: 999px; border: 1px solid var(--kg-line);
    color: var(--kg-grey); background: var(--kg-canvas);
}
.kg-answer__tab.is-active { background: var(--kg-ink); color: var(--kg-surface); border-color: var(--kg-ink); }
.kg-answer__body {
    font-family: var(--kg-sans); font-size: 1.02rem; line-height: 1.62;
    color: var(--kg-ink); margin: 0 0 22px;
}
.kg-answer__body mark { background: rgba(97, 217, 239, 0.34); color: inherit; padding: 0 3px; border-radius: 3px; }
.kg-answer__meta {
    display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
    border-top: 1px solid var(--kg-line); padding-top: 18px;
}
.kg-answer__score { font-family: var(--kg-serif); font-size: 1.5rem; color: var(--kg-ink); line-height: 1; }
.kg-answer__score small { font-family: var(--kg-sans); font-size: 0.74rem; font-weight: 600; color: var(--kg-grey); letter-spacing: 0.06em; text-transform: uppercase; display: block; margin-top: 5px; }
.kg-answer__badge {
    font-family: var(--kg-sans); font-size: 0.78rem; font-weight: 600; color: var(--kg-ink);
    background: rgba(97, 217, 239, 0.28); padding: 6px 12px; border-radius: 999px;
}
.kg-answer__date { font-family: var(--kg-sans); font-size: 0.78rem; color: var(--kg-grey); margin-left: auto; }

/* FAQ — native <details> accordion, no JS. */
.kg-faq { border-top: 1px solid var(--kg-line); margin-top: 44px; }
.kg-faq__item { border-bottom: 1px solid var(--kg-line); }
.kg-faq__item > summary {
    list-style: none; cursor: pointer; display: flex; justify-content: space-between;
    align-items: center; gap: 24px; padding: 26px 0;
    font-family: var(--kg-serif); font-size: clamp(1.15rem, 1.9vw, 1.4rem);
    font-weight: 400; color: var(--kg-ink);
}
.kg-faq__item > summary::-webkit-details-marker { display: none; }
.kg-faq__item > summary::after {
    content: "+"; font-family: var(--kg-sans); font-size: 1.6rem; font-weight: 300;
    color: var(--kg-grey); flex: none;
}
.kg-faq__item[open] > summary::after { content: "\2212"; }
.kg-faq__answer {
    font-family: var(--kg-sans); color: var(--kg-grey); font-size: 1rem; line-height: 1.62;
    max-width: 72ch; padding: 0 0 28px; margin: 0;
}

/* ============================================================
   PRODUCT PAGE — "The System": three stacked layer cards (light, editorial).
   Web / Agents / Data — centered serif header + centered item list.
   Connectors = two thin rails, cyan dashes flowing in opposite directions
   (publish up / outcomes down).
   ============================================================ */
.kg-flow { display: flex; flex-direction: column; max-width: 860px; margin: 112px auto 0; }
.kg-flow__box {
    display: flex; flex-direction: column; align-items: center; text-align: center; gap: 14px;
    background: var(--kg-surface); border: 1px solid var(--kg-line);
    border-radius: var(--kg-radius);
    padding: clamp(28px, 3vw, 40px) clamp(24px, 3vw, 38px);
}
.kg-flow__label { font-family: var(--kg-serif); font-size: clamp(1.4rem, 2vw, 1.8rem); color: var(--kg-ink); margin: 0; line-height: 1.1; }
.kg-flow__items { font-family: var(--kg-serif); font-size: 0.95rem; line-height: 2.15; color: var(--kg-grey); margin: 0; max-width: none; }
.kg-flow__sep { margin: 0 22px; color: var(--kg-grey); opacity: 0.5; }

/* connector: two rails with cyan dashes flowing in opposite directions */
.kg-flow__arrow { display: flex; justify-content: center; gap: 100px; align-self: center; height: 48px; margin: 8px 0; }
.kg-flow__rail { position: relative; width: 2px; height: 100%; background: var(--kg-line); overflow: hidden; }
.kg-flow__rail::after { content: ""; position: absolute; left: 0; top: 0; width: 2px; height: 15px; background: var(--kg-cyan); }
.kg-flow__rail--up::after { animation: kg-flow-rise 1.6s linear infinite; }
.kg-flow__rail--down::after { animation: kg-flow-fall 1.6s linear infinite; }
@keyframes kg-flow-rise { from { transform: translateY(48px); } to { transform: translateY(-15px); } }
@keyframes kg-flow-fall { from { transform: translateY(-15px); } to { transform: translateY(48px); } }

.kg-flow__note { text-align: center; margin: 30px auto 0; max-width: 52ch; font-family: var(--kg-serif); font-size: 0.9rem; letter-spacing: 0.02em; color: var(--kg-grey); }

@media (prefers-reduced-motion: reduce) {
    .kg-flow__rail::after { animation: none; top: 50%; height: 10px; transform: translateY(-50%); }
}

/* ============================================================
   PRODUCT PAGE — Slack integration card (.kg-slack*) — light, editorial.
   A minimal Slack-style conversation: channel header + user msg + bot reply.
   Square avatars (no round images); cyan only on the bot mark + primary action.
   ============================================================ */
.kg-slack {
    background: var(--kg-surface); border: 1px solid var(--kg-line);
    border-radius: var(--kg-radius); overflow: hidden; align-self: center;
    box-shadow: 0 24px 60px -34px rgba(15, 23, 42, 0.26);
}
.kg-slack__head {
    display: flex; align-items: center; gap: 5px; padding: 14px 20px;
    border-bottom: 1px solid var(--kg-line);
    font-family: var(--kg-sans); font-weight: 700; font-size: 0.95rem; color: var(--kg-ink);
}
.kg-slack__hash { color: var(--kg-grey); font-weight: 600; }
.kg-slack__msg { display: flex; gap: 12px; padding: 16px 20px; }
.kg-slack__msg + .kg-slack__msg { padding-top: 2px; }
.kg-slack__avatar {
    flex: none; width: 38px; height: 38px; border-radius: 9px;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--kg-sans); font-weight: 700; font-size: 0.8rem;
}
.kg-slack__avatar--user { background: var(--kg-canvas); color: var(--kg-grey); border: 1px solid var(--kg-line); }
.kg-slack__avatar--bot { background: var(--kg-cyan); color: var(--kg-ink); font-family: var(--kg-serif); font-size: 1.25rem; }
.kg-slack__body { min-width: 0; }
.kg-slack__meta { display: flex; align-items: center; gap: 8px; margin: 0 0 4px; font-family: var(--kg-sans); font-size: 0.82rem; font-weight: 700; color: var(--kg-ink); }
.kg-slack__time { font-weight: 500; color: var(--kg-grey); }
.kg-slack__app { font-size: 0.6rem; font-weight: 700; letter-spacing: 0.04em; color: var(--kg-grey); background: var(--kg-canvas); border: 1px solid var(--kg-line); padding: 1px 5px; border-radius: 4px; }
.kg-slack__text { font-family: var(--kg-sans); font-size: 0.92rem; line-height: 1.55; color: var(--kg-ink); margin: 0; }
.kg-slack__text b { font-weight: 600; }
.kg-slack__actions { display: flex; gap: 8px; margin-top: 12px; }
.kg-slack__btn { font-family: var(--kg-sans); font-size: 0.8rem; font-weight: 600; padding: 7px 14px; border-radius: 7px; border: 1px solid var(--kg-line); color: var(--kg-ink); }
.kg-slack__btn--primary { background: var(--kg-cyan); border-color: var(--kg-cyan); color: var(--kg-ink); }

/* source citation links (stat cards) */
.kg-src { color: var(--kg-grey); text-decoration: underline; text-decoration-color: var(--kg-line); text-underline-offset: 3px; transition: text-decoration-color 0.15s ease; }
.kg-src:hover { text-decoration-color: var(--kg-grey); }

/* ============================================================
   PRODUCT PAGE — "Brand visibility" tracker (.kg-track*) — dark panel.
   A faithful static replica of the app's AEO keyword list (Keyword /
   Volume / SEO Rank / AEO Visibility / Est. Traffic). Cyan accent only.
   Bars fill on scroll-in via the shared reveal observer.
   ============================================================ */
.kg-track { background: rgba(255, 255, 255, 0.02); border: 1px solid rgba(255, 255, 255, 0.10); border-radius: var(--kg-radius); padding: clamp(20px, 2.2vw, 32px); }
.kg-track__head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 20px; }
.kg-track__title { font-family: var(--kg-serif); font-weight: 400; font-size: 1.15rem; color: #fff; }
.kg-track__period { font-family: var(--kg-sans); font-size: 0.8rem; color: rgba(255, 255, 255, 0.5); }

/* summary strip */
.kg-track__summary { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; padding-bottom: 22px; border-bottom: 1px solid rgba(255, 255, 255, 0.08); }
.kg-track__summary > div { text-align: center; }
.kg-track__stat-label { font-family: var(--kg-sans); font-size: 0.7rem; letter-spacing: 0.05em; text-transform: uppercase; color: rgba(255, 255, 255, 0.5); margin: 0 0 7px; }
.kg-track__stat-value { font-family: var(--kg-serif); font-size: clamp(1.4rem, 2vw, 1.7rem); color: #fff; line-height: 1; }

/* table */
.kg-track__row { display: grid; grid-template-columns: 1.5fr 0.7fr 0.7fr 1.3fr 0.8fr; align-items: center; gap: 40px; padding: 22px 0; }
.kg-track__row + .kg-track__row { border-top: 1px solid rgba(255, 255, 255, 0.06); }
.kg-track__row--head { padding: 16px 0 12px; border-bottom: 1px solid rgba(255, 255, 255, 0.08); }
.kg-track__th { font-family: var(--kg-sans); font-size: 0.7rem; letter-spacing: 0.05em; text-transform: uppercase; color: rgba(255, 255, 255, 0.45); }
.kg-track__th--c { justify-self: center; }
.kg-track__kw { font-family: var(--kg-sans); font-size: 0.98rem; color: #fff; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.kg-track__num { font-family: var(--kg-sans); font-variant-numeric: tabular-nums; color: rgba(255, 255, 255, 0.65); font-size: 0.9rem; }
.kg-track__num--r { text-align: right; }
.kg-track__rank { justify-self: center; font-family: var(--kg-sans); font-size: 0.78rem; font-weight: 600; padding: 3px 10px; border-radius: 999px; }
.kg-track__rank--top { background: rgba(255, 255, 255, 0.10); color: rgba(255, 255, 255, 0.85); }
.kg-track__rank--mid { background: rgba(255, 255, 255, 0.10); color: rgba(255, 255, 255, 0.85); }
.kg-track__rank--none { color: rgba(255, 255, 255, 0.4); }
.kg-track__vis { display: flex; align-items: center; gap: 12px; }
.kg-track__vis-bar { position: relative; flex: 1; height: 6px; border-radius: 999px; background: rgba(255, 255, 255, 0.08); overflow: hidden; }
.kg-track__vis-fill { position: absolute; inset: 0 auto 0 0; width: 0; border-radius: 999px; background: var(--kg-cyan); transition: width 1s var(--kg-ease); }
.kg-reveal.is-visible .kg-track__vis-fill { width: var(--score); }
.kg-track__vis-pct { font-family: var(--kg-sans); font-variant-numeric: tabular-nums; color: #fff; font-size: 0.85rem; width: 36px; text-align: right; }

@media (max-width: 720px) {
    .kg-track__summary { grid-template-columns: repeat(2, 1fr); gap: 20px 16px; }
    .kg-track__row { grid-template-columns: 1.4fr 0.6fr 1fr; }
    .kg-track__col-hide { display: none; }
}
@media (prefers-reduced-motion: reduce) { .kg-track__vis-fill { transition: none; } }



/* ============================================================
   PRICING PAGE — Coverage + Integrations (.kg-cov*) — light, editorial.
   Four white model cards (ink serif name + grey versions), then a quiet
   centered typographic integrations list. No logos, no icons.
   ============================================================ */
.kg-cov-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(16px, 2vw, 24px); }
.kg-cov-card { background: var(--kg-surface); border: 1px solid var(--kg-line); border-radius: var(--kg-radius); padding: 32px 24px; text-align: center; }
.kg-cov-card__name { font-family: var(--kg-serif); font-size: clamp(1.3rem, 2vw, 1.6rem); color: var(--kg-ink); margin: 0 0 8px; line-height: 1.1; }
.kg-cov-card__models { font-family: var(--kg-sans); font-size: 0.92rem; color: var(--kg-grey); margin: 0; line-height: 1.5; }
.kg-cov-int { margin-top: clamp(48px, 6vw, 72px); padding-top: clamp(40px, 5vw, 56px); border-top: 1px solid var(--kg-line); }
.kg-cov-int__list { font-family: var(--kg-serif); font-size: clamp(1rem, 1.5vw, 1.2rem); color: var(--kg-ink); line-height: 2; margin: 0 auto; max-width: 56ch; }
.kg-cov-int__sep { color: var(--kg-grey); opacity: 0.5; padding: 0 4px; }
@media (max-width: 720px) { .kg-cov-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 420px) { .kg-cov-grid { grid-template-columns: 1fr; } }

/* Coverage model-card logo — monochrome (ink), single color */
.kg-cov-card__icon { display: flex; justify-content: center; margin-bottom: 16px; color: var(--kg-ink); }
.kg-cov-card__icon svg { width: 28px; height: 28px; display: block; }


/* ============================================================
   CUSTOMERS — case-study list cards (.kg-study-card)
   ============================================================ */
.kg-study-card { display: flex; flex-direction: column; background: var(--kg-surface); border: 1px solid var(--kg-line); border-radius: var(--kg-radius); padding: clamp(28px, 3vw, 40px); transition: border-color 0.18s var(--kg-ease), transform 0.18s var(--kg-ease); }
.kg-study-card:hover { border-color: rgba(15, 23, 42, 0.22); transform: translateY(-2px); }
.kg-study-card__client { font-family: var(--kg-sans); font-size: 0.78rem; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--kg-grey); margin: 0 0 14px; }
.kg-study-card__title { font-family: var(--kg-serif); font-weight: 400; font-size: clamp(1.4rem, 2.2vw, 1.9rem); line-height: 1.15; color: var(--kg-ink); margin: 0 0 14px; }
.kg-study-card__excerpt { font-family: var(--kg-sans); color: var(--kg-grey); line-height: 1.55; margin: 0; }
.kg-study-card__metrics { display: flex; flex-wrap: wrap; justify-content: center; gap: 28px; margin: 26px 0 0; padding-top: 22px; border-top: 1px solid var(--kg-line); }
.kg-study-card__metric { display: flex; flex-direction: column; }
.kg-study-card__metric b { font-family: var(--kg-serif); font-weight: 400; font-size: 1.4rem; color: var(--kg-ink); line-height: 1; }
.kg-study-card__metric span { font-family: var(--kg-sans); font-size: 0.74rem; color: var(--kg-grey); margin-top: 6px; }
.kg-study-card__more { margin-top: 26px; align-self: flex-end; }

/* results metrics row (detail page, dark band) */
.kg-results-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; margin-top: 24px; max-width: 720px; margin-inline: auto; }
@media (max-width: 640px) { .kg-results-grid { grid-template-columns: repeat(2, 1fr); } }

/* ============================================================
   CASE STUDY — article body (.kg-article) — light editorial prose
   ============================================================ */
.kg-article { max-width: 70ch; margin: 0 auto; font-family: var(--kg-sans); color: var(--kg-grey); font-size: 1.05rem; line-height: 1.85; }
.kg-article h2 { font-family: var(--kg-serif); font-weight: 400; color: var(--kg-ink); font-size: clamp(1.6rem, 2.6vw, 2.1rem); line-height: 1.15; margin: 3.2em 0 0; }
.kg-article h3 { font-family: var(--kg-serif); font-weight: 500; color: var(--kg-ink); font-size: clamp(1.2rem, 1.8vw, 1.45rem); margin: 1.6em 0 0; }
.kg-article p { margin: 1.5em 0 0; }
.kg-article a { color: var(--kg-ink); text-decoration: underline; text-decoration-color: var(--kg-line); text-underline-offset: 3px; }
.kg-article a:hover { text-decoration-color: var(--kg-grey); }
.kg-article strong { color: var(--kg-ink); font-weight: 600; }
.kg-article ul { list-style: none; padding: 0; margin: 1.5em 0 0; }
.kg-article ul li { position: relative; padding-left: 22px; margin: 0.9em 0 0; }
.kg-article ul li::before { content: ""; position: absolute; left: 3px; top: 0.8em; width: 6px; height: 6px; border-radius: 50%; background: var(--kg-cyan); }
.kg-article table { width: 100%; border-collapse: collapse; margin: 1.7em 0 0; font-family: var(--kg-sans); font-size: 0.95rem; }
.kg-article th { text-align: left; font-weight: 600; color: var(--kg-grey); font-size: 0.74rem; letter-spacing: 0.05em; text-transform: uppercase; padding: 0 16px 12px 0; border-bottom: 1px solid var(--kg-line); }
.kg-article td { padding: 13px 16px 13px 0; border-bottom: 1px solid var(--kg-line); color: var(--kg-ink); }
.kg-article blockquote { border-left: 3px solid var(--kg-cyan); padding: 4px 0 4px 28px; margin: 2.8em 0; }
.kg-article blockquote p { font-family: var(--kg-serif); font-size: clamp(1.2rem, 1.8vw, 1.5rem); line-height: 1.4; color: var(--kg-ink); margin: 0; }
.kg-article blockquote cite { display: block; font-family: var(--kg-sans); font-style: normal; font-size: 0.9rem; color: var(--kg-grey); margin-top: 12px; }
.kg-article figure { margin: 3.4em 0 0; }
.kg-article figure img { width: 65%; border: 1px solid var(--kg-line); border-radius: var(--kg-radius); display: block; margin: 0 auto; }
.kg-article figcaption { font-family: var(--kg-sans); font-size: 0.82rem; color: var(--kg-grey); margin-top: 10px; text-align: center; }
.kg-article__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin: 1.9em 0 0; }
.kg-article__stats > div { background: var(--kg-canvas); border: 1px solid var(--kg-line); border-radius: var(--kg-radius); padding: 26px 18px; text-align: center; }
.kg-article__stats b { display: block; font-family: var(--kg-serif); font-weight: 400; font-size: clamp(1.8rem, 3vw, 2.4rem); color: var(--kg-ink); line-height: 1; }
.kg-article__stats span { display: block; font-family: var(--kg-sans); font-size: 0.8rem; color: var(--kg-grey); margin-top: 8px; }
@media (max-width: 560px) { .kg-article__stats { grid-template-columns: 1fr; } }
/* content examples — linked cards (e.g. case-study published work) */
.kg-article .kg-examples { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin: 1.4em 0 0; }
.kg-article .kg-example { display: block; background: var(--kg-surface); border: 1px solid var(--kg-line); border-radius: var(--kg-radius); padding: 22px; text-decoration: none; transition: border-color 0.25s var(--kg-ease), transform 0.25s var(--kg-ease); }
.kg-article .kg-example:hover { border-color: var(--kg-ink); transform: translateY(-2px); }
.kg-article .kg-example__tag { font-family: var(--kg-serif); font-size: 0.7rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--kg-grey); }
.kg-article .kg-example__title { font-family: var(--kg-sans); font-weight: 600; font-size: 1.05rem; color: var(--kg-ink); margin-top: 12px; line-height: 1.3; }
.kg-article .kg-example__url { font-family: ui-monospace, 'JetBrains Mono', SFMono-Regular, Menlo, monospace; font-size: 0.78rem; color: var(--kg-grey); margin-top: 10px; word-break: break-all; }
@media (max-width: 560px) { .kg-article .kg-examples { grid-template-columns: 1fr; } }

/* extra .kg-article elements for legal/long-form (h1, h4, ordered lists) */
.kg-article h1 { font-family: var(--kg-serif); font-weight: 400; color: var(--kg-ink); font-size: clamp(1.8rem, 3vw, 2.4rem); line-height: 1.15; margin: 1.9em 0 0; }
.kg-article h4 { font-family: var(--kg-serif); font-weight: 500; color: var(--kg-ink); font-size: 1.1rem; margin: 1.5em 0 0; }
.kg-article ol { padding-left: 1.3em; margin: 1.5em 0 0; }
.kg-article ol li { margin: 0.9em 0 0; }
.kg-article > h1:first-child, .kg-article > h2:first-child { margin-top: 0; }
.kg-article h2 { scroll-margin-top: 120px; }

/* table of contents — right rail on article pages */
.kg-article-layout { max-width: 1300px; margin: 0 auto; padding: 0 var(--kg-gutter); display: grid; grid-template-columns: 1fr min(780px, 100%) 1fr; align-items: start; }
.kg-article-layout > .kg-article { grid-column: 2; }
.kg-toc { grid-column: 3; justify-self: start; position: sticky; top: 110px; width: 100%; max-width: 240px; padding-left: 36px; box-sizing: border-box; }
.kg-toc__label { font-family: var(--kg-serif); text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.72rem; color: var(--kg-grey); margin: 0 0 12px; }
.kg-toc__nav { display: flex; flex-direction: column; border-left: 1px solid var(--kg-line); }
.kg-toc__link { font-family: var(--kg-sans); font-size: 0.82rem; line-height: 1.4; color: var(--kg-grey); text-decoration: none; padding: 7px 0 7px 14px; margin-left: -1px; border-left: 2px solid transparent; transition: color 0.2s var(--kg-ease), border-color 0.2s var(--kg-ease); }
.kg-toc__link:hover { color: var(--kg-ink); }
.kg-toc__link:focus-visible { outline: none; color: var(--kg-ink); border-left-color: var(--kg-cyan); }
.kg-toc__link.is-active { color: var(--kg-ink); border-left-color: var(--kg-cyan); }
@media (max-width: 1080px) {
    .kg-article-layout { grid-template-columns: min(780px, 100%); justify-content: center; }
    .kg-toc { display: none; }
}

/* legal page Terms/Privacy switcher */
.kg-legal-nav { display: flex; gap: 8px; margin-top: 28px; }
.kg-legal-nav a { font-family: var(--kg-sans); font-size: 0.9rem; font-weight: 600; color: var(--kg-grey); padding: 8px 18px; border: 1px solid var(--kg-line); border-radius: 999px; transition: border-color 0.15s ease, color 0.15s ease; }
.kg-legal-nav a:hover { border-color: var(--kg-grey); color: var(--kg-ink); }
.kg-legal-nav a.is-active { background: var(--kg-ink); color: #fff; border-color: var(--kg-ink); }

/* ============================================================
   LEARN (blog) — list + detail, light/editorial
   ============================================================ */
.kg-learn-search { display: flex; gap: 10px; max-width: 460px; margin: 30px auto 0; }
.kg-learn-search input { flex: 1; font-family: var(--kg-sans); font-size: 0.95rem; padding: 12px 16px; border: 1px solid var(--kg-line); border-radius: var(--kg-radius-sm); background: var(--kg-surface); color: var(--kg-ink); }
.kg-learn-search input::placeholder { color: var(--kg-grey); }

.kg-pills { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.kg-pill { font-family: var(--kg-sans); font-size: 0.85rem; font-weight: 600; color: var(--kg-grey); padding: 7px 16px; border: 1px solid var(--kg-line); border-radius: 999px; transition: border-color 0.15s ease, color 0.15s ease; }
.kg-pill:hover { border-color: var(--kg-grey); color: var(--kg-ink); }
.kg-pill.is-active { background: var(--kg-ink); color: #fff; border-color: var(--kg-ink); }

.kg-post-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(20px, 3vw, 32px); }
@media (max-width: 760px) { .kg-post-grid { grid-template-columns: 1fr; } }
.kg-post-grid--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 860px) { .kg-post-grid--3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .kg-post-grid--3 { grid-template-columns: 1fr; } }

.kg-post-card { display: flex; flex-direction: column; background: var(--kg-surface); border: 1px solid var(--kg-line); border-radius: var(--kg-radius); overflow: hidden; transition: border-color 0.18s var(--kg-ease), transform 0.18s var(--kg-ease); }
.kg-post-card:hover { border-color: rgba(15, 23, 42, 0.22); transform: translateY(-2px); }
.kg-post-card__img { width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block; background: var(--kg-canvas); border-bottom: 1px solid var(--kg-line); }
.kg-post-card__body { padding: clamp(20px, 2.2vw, 28px); display: flex; flex-direction: column; flex: 1; }
.kg-post-card__cat { font-family: var(--kg-sans); font-size: 0.72rem; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--kg-grey); margin: 0 0 12px; }
.kg-post-card__title { font-family: var(--kg-serif); font-weight: 400; font-size: clamp(1.2rem, 1.9vw, 1.5rem); line-height: 1.2; color: var(--kg-ink); margin: 0 0 12px; }
.kg-post-card__excerpt { font-family: var(--kg-sans); font-size: 0.95rem; color: var(--kg-grey); line-height: 1.55; margin: 0; }
.kg-post-card__meta { font-family: var(--kg-sans); font-size: 0.8rem; color: var(--kg-grey); margin-top: 18px; display: flex; gap: 10px; align-items: center; }
.kg-post-card__meta .sep { opacity: 0.45; }

.kg-post-featured { display: grid; grid-template-columns: 1.1fr 1fr; background: var(--kg-surface); border: 1px solid var(--kg-line); border-radius: var(--kg-radius); overflow: hidden; }
.kg-post-featured:hover { border-color: rgba(15, 23, 42, 0.22); }
.kg-post-featured__img { width: 100%; height: 100%; min-height: 300px; object-fit: cover; display: block; background: var(--kg-canvas); }
.kg-post-featured__body { padding: clamp(28px, 3.4vw, 48px); display: flex; flex-direction: column; justify-content: center; }
@media (max-width: 760px) { .kg-post-featured { grid-template-columns: 1fr; } .kg-post-featured__img { min-height: 200px; } }

.kg-pagination { display: flex; justify-content: center; align-items: center; gap: 28px; margin-top: 56px; font-family: var(--kg-sans); font-size: 0.9rem; color: var(--kg-grey); }
.kg-pagination a { color: var(--kg-ink); font-weight: 600; }

/* post detail meta row */
.kg-post-meta { font-family: var(--kg-sans); font-size: 0.9rem; color: var(--kg-grey); display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.kg-post-meta .sep { opacity: 0.45; }
