/* =============================================================
   Kimezu Website — editorial / chapter direction (system fonts)
   ============================================================= */

@import url("kimezu-tokens.css");

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
    font-family: var(--k-font-sans);
    background: var(--k-bg);
    color: var(--k-ink-2);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    line-height: 1.6;
    transition: background-color var(--k-dur-slow) var(--k-ease), color var(--k-dur-slow) var(--k-ease);
}

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

.wrap   { max-width: 1280px; margin: 0 auto; padding: 0 40px; }
.wrap-n { max-width: 920px;  margin: 0 auto; padding: 0 40px; }

/* ────── editorial type ────── */
.mono { font-family: var(--k-font-mono); }
.eyebrow {
    font: 600 11px/1 var(--k-font-sans);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--k-ink-4);
}
.eyebrow.accent { color: var(--k-accent); }
.kicker {
    font-family: var(--k-font-mono);
    font-weight: 500;
    font-size: 12px;
    letter-spacing: 0.06em;
    color: var(--k-ink-4);
}
.display {
    font-family: var(--k-font-sans);
    font-weight: 300;
    letter-spacing: -0.035em;
    line-height: 1.0;
    color: var(--k-ink);
    text-wrap: balance;
    margin: 0;
}
.h2 {
    font-family: var(--k-font-sans);
    font-weight: 300;
    letter-spacing: -0.028em;
    line-height: 1.04;
    color: var(--k-ink);
    text-wrap: balance;
    margin: 0;
}
.h2 em { font-style: italic; font-weight: 300; color: var(--k-accent); }
.h3 {
    font-family: var(--k-font-sans);
    font-weight: 500;
    letter-spacing: -0.012em;
    line-height: 1.18;
    color: var(--k-ink);
    margin: 0;
}
.lede {
    font-size: 19px;
    line-height: 1.55;
    color: var(--k-ink-3);
    max-width: 54ch;
    margin: 0;
}
.body { font: 400 16px/1.7 var(--k-font-sans); color: var(--k-ink-3); margin: 0; }
.dropcap::first-letter {
    float: left;
    font-size: 80px;
    line-height: 0.85;
    font-weight: 300;
    color: var(--k-ink);
    padding: 6px 14px 0 0;
    letter-spacing: -0.04em;
}

/* ────── NAV ────── */
.nav {
    position: sticky; top: 0; z-index: 100;
    background: color-mix(in srgb, var(--k-bg) 86%, transparent);
    backdrop-filter: saturate(150%) blur(12px);
    -webkit-backdrop-filter: saturate(150%) blur(12px);
    border-bottom: 1px solid var(--k-line);
}
.nav-row {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    min-height: 72px;
    gap: 24px;
}
.nav-left, .nav-right {
    display: flex; align-items: center; gap: 22px;
}
.nav-right { justify-content: flex-end; }
.nav-logo { display: inline-flex; height: 26px; }
.nav-logo img { height: 26px; display: block; }
.nav-a {
    font: 400 13.5px/1 var(--k-font-sans);
    color: var(--k-ink-3);
    text-decoration: none;
    transition: color var(--k-dur-base) var(--k-ease);
}
.nav-a:hover, .nav-a.is-active { color: var(--k-ink); }
.nav-meta {
    font: 500 11px/1 var(--k-font-mono);
    color: var(--k-ink-4);
    letter-spacing: 0.06em;
}
.theme-btn {
    width: 34px; height: 34px;
    display: inline-flex; align-items: center; justify-content: center;
    background: transparent;
    border: 1px solid var(--k-line);
    border-radius: 999px;
    color: var(--k-ink-3); cursor: pointer;
    transition: all var(--k-dur-base) var(--k-ease);
}
.theme-btn:hover { color: var(--k-ink); border-color: var(--k-ink-3); }
.theme-btn svg { width: 14px; height: 14px; }
.nav-cta {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 9px 16px;
    background: var(--k-ink);
    color: var(--k-bg);
    text-decoration: none;
    border-radius: 999px;
    font: 500 13px/1 var(--k-font-sans);
    transition: opacity var(--k-dur-base) var(--k-ease);
}
.nav-cta:hover { opacity: 0.88; }

/* ────── HAMBURGER + DRAWER (mobile only — shown ≤ 760 px) ────── */
.nav-burger {
    display: none;
    width: 36px; height: 36px;
    padding: 0;
    background: transparent;
    border: 1px solid var(--k-line);
    border-radius: 999px;
    cursor: pointer;
    align-items: center; justify-content: center;
    flex-direction: column;
    gap: 4px;
    transition: border-color var(--k-dur-base) var(--k-ease);
}
.nav-burger:hover { border-color: var(--k-ink-3); }
.nav-burger > span {
    display: block;
    width: 16px; height: 1.5px;
    background: var(--k-ink);
    border-radius: 2px;
}
.nav-backdrop {
    position: fixed; inset: 0;
    background: rgba(31, 27, 22, 0.5);
    opacity: 0;
    z-index: 200;
    transition: opacity var(--k-dur-base) var(--k-ease);
    pointer-events: none;
}
.nav-backdrop.is-open {
    opacity: 1;
    pointer-events: auto;
}
.nav-drawer {
    position: fixed; top: 0; right: 0; bottom: 0;
    width: 80vw; max-width: 360px;
    background: var(--k-surface);
    box-shadow: -16px 0 40px rgba(31, 27, 22, 0.14);
    z-index: 210;
    transform: translateX(100%);
    transition: transform var(--k-dur-base) var(--k-ease);
    display: flex; flex-direction: column;
    padding: 22px 28px 32px;
    overflow-y: auto;
}
.nav-drawer.is-open { transform: translateX(0); }
.nav-drawer__head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 32px;
}
.nav-drawer__meta {
    font: 500 11px/1 var(--k-font-mono);
    color: var(--k-ink-4);
    letter-spacing: 0.06em;
}
.nav-drawer__close {
    width: 32px; height: 32px;
    background: var(--k-bg-alt);
    border: 0; border-radius: 999px;
    color: var(--k-ink);
    cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
    transition: background var(--k-dur-base) var(--k-ease);
}
.nav-drawer__close:hover { background: var(--k-line); }
.nav-drawer__links {
    display: flex; flex-direction: column;
    gap: 4px;
    margin-bottom: auto;
}
.nav-drawer__links a {
    font: 400 18px/1.2 var(--k-font-sans);
    color: var(--k-ink);
    text-decoration: none;
    padding: 14px 0;
    border-bottom: 1px solid var(--k-line);
}
.nav-drawer__links a:last-child { border-bottom: 0; }
.nav-drawer__cta {
    margin-top: 24px;
    display: inline-flex; align-items: center; justify-content: center;
    padding: 14px 20px;
    background: var(--k-ink);
    color: var(--k-bg);
    text-decoration: none;
    border-radius: 999px;
    font: 500 14px/1 var(--k-font-sans);
}

/* Lock body scroll when drawer is open. */
body.nav-drawer-open { overflow: hidden; }

/* ────── BUTTONS ────── */
.btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 14px 22px; border-radius: 999px;
    font: 500 14px/1 var(--k-font-sans);
    text-decoration: none; cursor: pointer; border: 0;
    transition: all var(--k-dur-base) var(--k-ease);
    white-space: nowrap;
}
.btn-primary { background: var(--k-ink); color: var(--k-bg); }
.btn-primary:hover { box-shadow: var(--k-sh-3); transform: translateY(-1px); }
.btn-accent { background: var(--k-accent); color: #fff; }
.btn-accent:hover { background: var(--k-accent-hover); box-shadow: var(--k-sh-accent); }
/* Saffron-coded CTA — reserved for premium-tier and emphasis moments
   (e.g. Pricing "Run as operator"). Do not use for everyday actions. */
.btn-accent-2 { background: var(--k-accent-2); color: #fff; }
.btn-accent-2:hover { background: var(--k-accent-2-hover); box-shadow: 0 6px 20px rgba(201, 122, 43, 0.22); }
.btn-line { background: transparent; color: var(--k-ink); border: 1px solid var(--k-line-2); }
.btn-line:hover { border-color: var(--k-ink); background: var(--k-bg-alt); }

/* ────── COVER (hero) — editorial split ────── */
.cover {
    position: relative;
    border-bottom: 1px solid var(--k-line);
    overflow: hidden;
    isolation: isolate;
}
.cover::before {
    content: "";
    position: absolute; inset: 0; z-index: -1;
    background:
        radial-gradient(60rem 36rem at 14% 22%, color-mix(in srgb, var(--k-accent) 16%, transparent) 0%, transparent 60%),
        radial-gradient(48rem 30rem at 86% 10%, color-mix(in srgb, var(--k-warn) 14%, transparent) 0%, transparent 60%);
}
.cover-grid {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 56px;
    align-items: stretch;
}
.cover-left {
    padding: 96px 0 84px;
    display: flex; flex-direction: column;
    justify-content: center;
}
.cover-meta {
    display: flex; align-items: center; gap: 22px;
    margin-bottom: 32px;
}
.cover-meta .vol {
    font: 500 11.5px/1 var(--k-font-mono);
    color: var(--k-ink-3);
    letter-spacing: 0.06em;
}
.cover-meta .rule {
    flex: 1; max-width: 120px;
    height: 1px; background: var(--k-line-strong);
}
.cover h1 {
    font-family: var(--k-font-sans);
    font-weight: 300;
    font-size: clamp(48px, 6.4vw, 92px);
    line-height: 0.96;
    letter-spacing: -0.045em;
    color: var(--k-ink);
    margin: 0 0 28px;
    text-wrap: balance;
}
.cover h1 .ital { font-style: italic; font-weight: 300; color: var(--k-accent); }
.cover-lede {
    max-width: 540px;
    font-size: 19px;
    line-height: 1.55;
    color: var(--k-ink-3);
    margin: 0 0 36px;
}
.cover-cta { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.cover-cta .note {
    margin-left: 12px;
    font: 400 13px/1.4 var(--k-font-sans);
    color: var(--k-ink-4);
}
.cover-foot {
    margin-top: 56px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    padding-top: 28px;
    border-top: 1px solid var(--k-line);
}
.cover-foot .item .lab { font: 500 10.5px/1 var(--k-font-mono); color: var(--k-ink-4); letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 6px; }
.cover-foot .item .v   { font: 400 17px/1.2 var(--k-font-sans); color: var(--k-ink); letter-spacing: -0.01em; }
.cover-foot .item p    { margin: 4px 0 0; font: 400 12.5px/1.45 var(--k-font-sans); color: var(--k-ink-3); }

.cover-right {
    position: relative;
    min-height: 640px;
    border-left: 1px solid var(--k-line);
    overflow: hidden;
    background: var(--k-bg-alt);
}
.cover-photo {
    position: absolute; inset: 0;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    filter: contrast(1.02) saturate(0.94);
}
.cover-photo::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(31,27,22,0) 60%, rgba(31,27,22,0.36) 100%);
}
.cover-caption {
    position: absolute; left: 28px; bottom: 24px;
    color: rgba(255,255,255,0.92);
    font: 500 11.5px/1.5 var(--k-font-mono);
    letter-spacing: 0.05em;
    z-index: 2;
    max-width: 340px;
}
.cover-caption .l { color: var(--k-accent); margin-bottom: 6px; }
.cover-stamp {
    position: absolute; right: 24px; top: 24px;
    padding: 8px 14px;
    background: var(--k-surface);
    border: 1px solid var(--k-line);
    border-radius: 999px;
    font: 500 11px/1 var(--k-font-mono);
    color: var(--k-ink-3);
    letter-spacing: 0.06em;
    z-index: 2;
    display: inline-flex; align-items: center; gap: 8px;
}
.cover-stamp::before {
    content: ""; width: 7px; height: 7px; border-radius: 999px;
    background: var(--k-success);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--k-success) 22%, transparent);
}

/* ────── BRAND STRIP ────── */
.brand-strip {
    border-bottom: 1px solid var(--k-line);
    background: var(--k-bg);
    padding: 26px 0;
    overflow: hidden;
}
.brand-row {
    display: flex; align-items: center; gap: 44px;
    flex-wrap: nowrap;
    overflow-x: auto;
    scrollbar-width: none;
}
.brand-row::-webkit-scrollbar { display: none; }
.brand-label {
    font: 500 11px/1 var(--k-font-mono);
    color: var(--k-ink-4);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    white-space: nowrap;
    flex-shrink: 0;
}
.brand-item {
    display: inline-flex; align-items: center; gap: 10px;
    flex-shrink: 0;
}
.brand-item .glyph {
    width: 22px; height: 22px; border-radius: 4px;
    flex-shrink: 0;
}
.brand-item .name {
    display: inline-flex;
    flex-direction: column;
    gap: 2px;
    font: 500 15.5px/1 var(--k-font-sans);
    letter-spacing: -0.005em;
    color: var(--k-ink-2);
}
.brand-item .name small {
    font: 400 10.5px/1.2 var(--k-font-mono);
    color: var(--k-ink-4);
    letter-spacing: 0.04em;
    text-transform: lowercase;
}
.brand-sep {
    width: 1px; height: 18px; background: var(--k-line);
    flex-shrink: 0;
}

/* ────── SECTION ────── */
.section {
    padding: 120px 0;
    border-bottom: 1px solid var(--k-line);
    position: relative;
}
.section--alt { background: var(--k-bg-alt); }

/* Chapter mast head — Roman numeral + label + rule line */
.chap {
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: 32px;
    align-items: baseline;
    margin-bottom: 56px;
    padding-bottom: 32px;
    border-bottom: 1px solid var(--k-line);
}
.chap .rn {
    font-family: var(--k-font-sans);
    font-weight: 300;
    font-size: 56px;
    line-height: 0.9;
    letter-spacing: -0.04em;
    color: var(--k-ink-4);
}
.chap .body-side {
    display: flex; flex-direction: column; gap: 6px;
}
.chap .top-row {
    display: flex; align-items: center; gap: 16px;
}
.chap h2 {
    font-family: var(--k-font-sans);
    font-weight: 300;
    font-size: clamp(34px, 4.4vw, 56px);
    line-height: 1.02;
    letter-spacing: -0.03em;
    color: var(--k-ink);
    margin: 12px 0 0;
    text-wrap: balance;
    max-width: 22ch;
}
.chap h2 em { font-style: italic; font-weight: 300; color: var(--k-accent); }
.chap .sub {
    margin-top: 10px;
    font-size: 17px; line-height: 1.6;
    color: var(--k-ink-3);
    max-width: 60ch;
}

/* ────── CHAPTER I — operator outcomes (prose + photo) ────── */
.outcome-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: stretch;
}
.outcome-prose {
    display: flex; flex-direction: column; gap: 26px;
}
.outcome-prose p {
    font: 400 17px/1.65 var(--k-font-sans);
    color: var(--k-ink-2);
    margin: 0;
    max-width: 56ch;
}
.outcome-prose p + p::before {
    content: "—";
    display: block;
    color: var(--k-ink-4);
    margin: 8px 0 14px;
    font-size: 16px;
}
.outcome-prose .pull {
    border-left: 2px solid var(--k-accent);
    padding: 6px 0 6px 22px;
    margin: 8px 0;
    font-family: var(--k-font-sans);
    font-weight: 300;
    font-size: 26px;
    letter-spacing: -0.012em;
    line-height: 1.25;
    color: var(--k-ink);
    max-width: 22ch;
    font-style: italic;
}
.outcome-photo {
    position: relative;
    border-radius: var(--k-r-lg);
    overflow: hidden;
    background: var(--k-bg-alt);
    min-height: 460px;
    border: 1px solid var(--k-line);
}
.outcome-photo .img {
    position: absolute; inset: 0;
    background-position: center;
    background-size: cover;
    filter: saturate(0.95) contrast(1.02);
}
.outcome-photo .caption {
    position: absolute; left: 18px; bottom: 16px;
    padding: 9px 14px;
    background: color-mix(in srgb, var(--k-surface) 88%, transparent);
    backdrop-filter: blur(4px);
    border: 1px solid var(--k-line);
    border-radius: 999px;
    font: 500 11.5px/1 var(--k-font-mono);
    color: var(--k-ink-2);
    letter-spacing: 0.04em;
}

/* ────── CHAPTER II — browser frame product preview ────── */
.product-block {
    display: grid;
    grid-template-columns: 0.95fr 1.1fr;
    gap: 56px;
    align-items: center;
}
.product-notes { display: flex; flex-direction: column; gap: 22px; }
.product-notes h3 { font-size: 26px; }
.product-notes p {
    font: 400 16px/1.65 var(--k-font-sans);
    color: var(--k-ink-3);
    margin: 0;
    max-width: 48ch;
}
.product-feats {
    display: flex; flex-direction: column;
    border-top: 1px solid var(--k-line);
    margin-top: 8px;
}
.product-feats .row {
    display: grid;
    grid-template-columns: 56px 1fr auto;
    gap: 16px;
    align-items: baseline;
    padding: 16px 0;
    border-bottom: 1px solid var(--k-line);
}
.product-feats .row .n { font: 500 11.5px/1 var(--k-font-mono); color: var(--k-ink-4); }
.product-feats .row .t { font: 500 15px/1.4 var(--k-font-sans); color: var(--k-ink); }
.product-feats .row .t small { display: block; font-weight: 400; color: var(--k-ink-3); font-size: 13.5px; margin-top: 3px; }
.product-feats .row .tag {
    font: 500 10.5px/1 var(--k-font-mono);
    color: var(--k-accent);
    padding: 5px 10px;
    border: 1px solid color-mix(in srgb, var(--k-accent) 38%, var(--k-line));
    border-radius: 999px;
    background: var(--k-accent-soft);
}

.browser {
    background: var(--k-surface);
    border: 1px solid var(--k-line);
    border-radius: var(--k-r-lg);
    box-shadow: var(--k-sh-4);
    overflow: hidden;
}
.browser-bar {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 16px;
    align-items: center;
    padding: 12px 16px;
    background: var(--k-surface-sunk);
    border-bottom: 1px solid var(--k-line);
}
.browser-bar .dots { display: flex; gap: 7px; }
.browser-bar .dots span { width: 11px; height: 11px; border-radius: 50%; background: var(--k-line-2); }
.browser-bar .dots span:nth-child(1) { background: #F4A356; }
.browser-bar .dots span:nth-child(2) { background: #79C5E6; }
.browser-bar .dots span:nth-child(3) { background: #5DC089; }
.browser-bar .url {
    text-align: center;
    padding: 6px 14px;
    background: var(--k-bg);
    border: 1px solid var(--k-line);
    border-radius: 999px;
    font: 500 12px/1 var(--k-font-mono);
    color: var(--k-ink-3);
    max-width: 320px;
    margin: 0 auto;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.browser-bar .url::before { content: "⌁ "; color: var(--k-accent); margin-right: 4px; }
.browser-bar .actions { display: flex; gap: 8px; }
.browser-bar .actions span {
    width: 24px; height: 24px;
    border-radius: 6px;
    background: var(--k-bg-alt);
    border: 1px solid var(--k-line);
}
.browser-body { position: relative; aspect-ratio: 4 / 3; overflow: hidden; }
.browser-body img { width: 100%; height: 100%; object-fit: cover; object-position: top left; display: block; }
.browser-tabs {
    position: absolute; top: 16px; left: 16px;
    display: flex; gap: 6px;
    background: var(--k-surface);
    border: 1px solid var(--k-line);
    border-radius: 999px;
    padding: 4px;
    z-index: 3;
    box-shadow: var(--k-sh-2);
}
.browser-tabs button {
    padding: 6px 14px;
    border: 0; background: transparent;
    font: 500 12px/1 var(--k-font-sans);
    color: var(--k-ink-3);
    border-radius: 999px;
    cursor: pointer;
    display: inline-flex; align-items: center; gap: 6px;
    transition: all var(--k-dur-base) var(--k-ease);
}
.browser-tabs button .sw { width: 10px; height: 10px; border-radius: 3px; }
.browser-tabs button[aria-pressed="true"] {
    background: var(--k-ink);
    color: var(--k-bg);
}

/* ────── CHAPTER III — industries (vertical strips) ────── */
.industries { display: flex; flex-direction: column; }
.industry {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 56px;
    align-items: center;
    padding: 64px 0;
    border-top: 1px solid var(--k-line);
}
.industry:first-child { border-top: 0; padding-top: 0; }
.industry:nth-child(even) .industry-photo { order: -1; }
.industry-photo {
    border-radius: var(--k-r-lg);
    overflow: hidden;
    aspect-ratio: 1.3 / 1;
    border: 1px solid var(--k-line);
    background: var(--k-bg-alt);
    position: relative;
}
.industry-photo .img {
    position: absolute; inset: 0;
    background-size: cover; background-position: center;
    filter: saturate(0.94);
}
.industry-photo .tag {
    position: absolute; top: 16px; left: 16px;
    padding: 7px 14px 7px 10px;
    background: color-mix(in srgb, var(--k-surface) 92%, transparent);
    backdrop-filter: blur(4px);
    border: 1px solid var(--k-line);
    border-radius: 999px;
    font: 500 11px/1 var(--k-font-mono);
    color: var(--k-ink);
    letter-spacing: 0.04em;
    display: inline-flex; align-items: center; gap: 8px;
}
.industry-photo .tag .dot { width: 8px; height: 8px; border-radius: 999px; background: var(--k-accent); }
.industry-text { display: flex; flex-direction: column; gap: 20px; }
.industry-text .kicker { color: var(--k-accent); }
.industry-text h3 {
    font-family: var(--k-font-sans);
    font-weight: 300;
    font-size: clamp(28px, 3vw, 38px);
    letter-spacing: -0.02em;
    line-height: 1.08;
    color: var(--k-ink);
    margin: 0;
    text-wrap: balance;
}
.industry-text p {
    font: 400 16px/1.65 var(--k-font-sans);
    color: var(--k-ink-3);
    margin: 0;
    max-width: 48ch;
}
.industry-meta {
    display: flex; gap: 28px;
    padding-top: 18px;
    border-top: 1px solid var(--k-line);
    margin-top: 4px;
}
.industry-meta .stat .v {
    font-family: var(--k-font-sans);
    font-weight: 400;
    font-size: 22px;
    color: var(--k-ink);
    letter-spacing: -0.012em;
}
.industry-meta .stat .l {
    font: 500 11px/1 var(--k-font-mono);
    color: var(--k-ink-4);
    margin-top: 4px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

/* ────── CHAPTER IV — build vs buy comparison ────── */
.compare {
    background: var(--k-surface);
    border: 1px solid var(--k-line);
    border-radius: var(--k-r-lg);
    overflow: hidden;
}
.compare table { width: 100%; border-collapse: collapse; }
.compare th, .compare td {
    padding: 18px 20px;
    text-align: left;
    border-bottom: 1px solid var(--k-line);
    vertical-align: middle;
}
.compare th {
    background: var(--k-bg-alt);
    font: 600 11px/1 var(--k-font-sans);
    color: var(--k-ink);
    text-transform: uppercase;
    letter-spacing: 0.12em;
}
.compare th.col-k {
    background: var(--k-ink);
    color: var(--k-bg);
    position: relative;
}
.compare th.col-k::before {
    content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: var(--k-accent);
}
.compare td {
    font: 400 14.5px/1.5 var(--k-font-sans);
    color: var(--k-ink-2);
}
.compare td.row-label {
    font-weight: 500;
    color: var(--k-ink);
    width: 28%;
}
.compare td.row-label small {
    display: block;
    font-weight: 400;
    color: var(--k-ink-4);
    font-size: 12.5px;
    margin-top: 3px;
    letter-spacing: 0;
    text-transform: none;
}
.compare td.col-k {
    background: color-mix(in srgb, var(--k-accent-soft) 50%, var(--k-surface));
    border-left: 1px solid color-mix(in srgb, var(--k-accent) 22%, var(--k-line));
    border-right: 1px solid color-mix(in srgb, var(--k-accent) 22%, var(--k-line));
    font-weight: 500;
    color: var(--k-ink);
}
.compare tr:last-child td { border-bottom: 0; }
.compare .check { color: var(--k-accent); font-weight: 600; }
.compare .x { color: var(--k-ink-4); }
.compare .dash { color: var(--k-ink-4); }

/* ────── CHAPTER V — Compliance / Europe map ────── */
.eu-grid {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: 56px;
    align-items: center;
}
.eu-text { max-width: 50ch; }
.eu-text p {
    font: 400 17px/1.7 var(--k-font-sans);
    color: var(--k-ink-3);
    margin: 0 0 22px;
}
.eu-list {
    display: flex; flex-direction: column;
    border-top: 1px solid var(--k-line);
}
.eu-list .row {
    display: grid;
    grid-template-columns: 56px 1fr auto;
    gap: 16px;
    align-items: center;
    padding: 16px 0;
    border-bottom: 1px solid var(--k-line);
}
.eu-list .row .n { font: 500 11.5px/1 var(--k-font-mono); color: var(--k-ink-4); }
.eu-list .row .l { font: 500 15px/1.4 var(--k-font-sans); color: var(--k-ink); }
.eu-list .row .l small { display: block; font-weight: 400; color: var(--k-ink-3); font-size: 13px; margin-top: 3px; }
.eu-list .row .v { font: 500 12px/1 var(--k-font-mono); color: var(--k-accent); }

.eu-map {
    position: relative;
    background: var(--k-surface);
    border: 1px solid var(--k-line);
    border-radius: var(--k-r-lg);
    padding: 36px;
    overflow: hidden;
    aspect-ratio: 1.05 / 1;
}
.eu-map img { width: 100%; height: 100%; object-fit: contain; }
.eu-map .pin {
    position: absolute;
    transform: translate(-50%, -50%);
}
.eu-map .pin .ring {
    width: 14px; height: 14px;
    border-radius: 999px;
    background: var(--k-accent);
    box-shadow: 0 0 0 6px color-mix(in srgb, var(--k-accent) 22%, transparent),
                0 0 0 14px color-mix(in srgb, var(--k-accent) 10%, transparent);
    animation: pulse 2.6s var(--k-ease) infinite;
}
@keyframes pulse {
    0%, 100% { box-shadow: 0 0 0 6px color-mix(in srgb, var(--k-accent) 22%, transparent), 0 0 0 14px color-mix(in srgb, var(--k-accent) 10%, transparent); }
    50%      { box-shadow: 0 0 0 9px color-mix(in srgb, var(--k-accent) 18%, transparent), 0 0 0 22px color-mix(in srgb, var(--k-accent) 6%, transparent); }
}
.eu-map .pin .label {
    position: absolute;
    left: 20px; top: 50%;
    transform: translateY(-50%);
    white-space: nowrap;
    padding: 5px 11px;
    background: var(--k-surface);
    border: 1px solid var(--k-line);
    border-radius: 999px;
    font: 500 11px/1 var(--k-font-mono);
    color: var(--k-ink-2);
    letter-spacing: 0.04em;
    box-shadow: var(--k-sh-1);
}
.eu-map .stamp {
    position: absolute; right: 18px; bottom: 18px;
    padding: 8px 12px;
    background: var(--k-bg);
    border: 1px solid var(--k-line);
    border-radius: var(--k-r-sm);
    font: 500 11px/1.4 var(--k-font-mono);
    color: var(--k-ink-3);
    letter-spacing: 0.04em;
    max-width: 180px;
}
.eu-map .stamp b { display: block; font-weight: 500; color: var(--k-ink); margin-bottom: 4px; }

/* ────── CHAPTER VI — case notes ────── */
.cases-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}
.case {
    background: var(--k-surface);
    border: 1px solid var(--k-line);
    border-radius: var(--k-r-lg);
    padding: 32px 28px;
    display: flex; flex-direction: column; gap: 18px;
    transition: all var(--k-dur-base) var(--k-ease);
}
.case:hover {
    transform: translateY(-4px);
    box-shadow: var(--k-sh-3);
    border-color: color-mix(in srgb, var(--k-accent) 40%, var(--k-line));
}
.case .top {
    display: flex; align-items: center; gap: 14px;
}
.case .top img { width: 56px; height: 56px; border-radius: 50%; border: 1px solid var(--k-line); background: var(--k-bg-alt); }
.case .top .who { font: 500 15px/1.3 var(--k-font-sans); color: var(--k-ink); }
.case .top .role { font: 400 12.5px/1.3 var(--k-font-sans); color: var(--k-ink-3); margin-top: 2px; }
.case h3 {
    font-family: var(--k-font-sans);
    font-weight: 400;
    font-size: 22px;
    letter-spacing: -0.015em;
    line-height: 1.2;
    color: var(--k-ink);
    margin: 0;
    text-wrap: balance;
}
.case p {
    font: 400 15px/1.65 var(--k-font-sans);
    color: var(--k-ink-3);
    margin: 0;
}
.case .meta {
    margin-top: auto;
    padding-top: 18px;
    border-top: 1px solid var(--k-line);
    display: flex; justify-content: space-between; align-items: center;
    font: 500 11.5px/1 var(--k-font-mono);
    color: var(--k-ink-4);
    letter-spacing: 0.04em;
}
.case .meta a {
    color: var(--k-ink);
    text-decoration: none;
}
.case .meta a:hover { color: var(--k-accent); }
.case .meta a::after { content: " →"; }

/* ────── CHAPTER VII — pricing (horizontal table) ────── */
.pricing-card {
    background: var(--k-surface);
    border: 1px solid var(--k-line);
    border-radius: var(--k-r-lg);
    overflow: hidden;
}
.pricing-head {
    display: grid;
    grid-template-columns: 1.2fr repeat(5, 1fr);
    border-bottom: 1px solid var(--k-line);
}
.pricing-head > div { padding: 32px 28px; border-left: 1px solid var(--k-line); }
.pricing-head > div:first-child { border-left: 0; }
.pricing-head > div.feat { background: var(--k-ink); color: var(--k-bg); position: relative; }
.pricing-head > div.feat::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--k-accent-2); }
.pricing-head .label { font: 500 11px/1 var(--k-font-mono); color: var(--k-ink-4); letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 12px; }
.pricing-head .feat .label { color: rgba(245,239,227,0.6); }
.pricing-head .lede {
    font-family: var(--k-font-sans);
    font-weight: 300;
    font-size: 28px;
    line-height: 1.05;
    letter-spacing: -0.02em;
    color: var(--k-ink);
    margin: 0;
    max-width: 14ch;
}
.pricing-head .tier-name {
    font: 500 18px/1.2 var(--k-font-sans);
    letter-spacing: -0.01em;
    color: var(--k-ink);
    margin-bottom: 6px;
}
.pricing-head .feat .tier-name { color: var(--k-bg); }
.pricing-head .price {
    font-family: var(--k-font-sans);
    font-weight: 300;
    font-size: 36px;
    line-height: 1;
    letter-spacing: -0.025em;
    color: var(--k-ink);
    margin: 14px 0 6px;
}
.pricing-head .feat .price { color: var(--k-bg); }
.pricing-head .price small { font: 400 14px/1 var(--k-font-sans); color: var(--k-ink-4); margin-left: 4px; }
.pricing-head .feat .price small { color: rgba(245,239,227,0.7); }
.pricing-head .desc { font: 400 13.5px/1.5 var(--k-font-sans); color: var(--k-ink-3); margin: 0; }
.pricing-head .feat .desc { color: rgba(245,239,227,0.72); }
.pricing-head .tag {
    display: inline-block;
    font: 600 9.5px/1 var(--k-font-sans);
    color: var(--k-ink);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    padding: 5px 9px;
    background: var(--k-accent);
    border: 1px solid var(--k-accent-hover);
    border-radius: 999px;
    margin-bottom: 10px;
}

.pricing-rows .pr {
    display: grid;
    grid-template-columns: 1.2fr repeat(5, 1fr);
    border-top: 1px solid var(--k-line);
}
.pricing-rows .pr > div { padding: 16px 28px; border-left: 1px solid var(--k-line); font: 400 14px/1.5 var(--k-font-sans); color: var(--k-ink-2); }
.pricing-rows .pr > div:first-child { border-left: 0; color: var(--k-ink); font-weight: 500; }
.pricing-rows .pr > div.feat { background: color-mix(in srgb, var(--k-accent-soft) 32%, var(--k-surface)); }
.pricing-rows .pr.head > div:first-child { background: var(--k-bg-alt); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--k-ink); }
.pricing-cta {
    display: grid;
    grid-template-columns: 1.2fr repeat(5, 1fr);
    border-top: 1px solid var(--k-line);
}
.pricing-cta > div { padding: 24px 28px; border-left: 1px solid var(--k-line); }
.pricing-cta > div:first-child { border-left: 0; }
.pricing-cta > div.feat { background: var(--k-ink); }

/* ────── FAQ ────── */
.faq { display: flex; flex-direction: column; margin-top: 16px; }
.faq-item { border-bottom: 1px solid var(--k-line); }
.faq-item summary {
    list-style: none;
    cursor: pointer;
    padding: 26px 0;
    display: grid;
    grid-template-columns: 56px 1fr 36px;
    gap: 18px;
    align-items: center;
    font-family: var(--k-font-sans);
    font-weight: 400;
    font-size: 20px;
    letter-spacing: -0.012em;
    line-height: 1.3;
    color: var(--k-ink);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary .n { font: 500 12px/1 var(--k-font-mono); color: var(--k-ink-4); }
.faq-item summary .ic {
    width: 32px; height: 32px;
    border-radius: 50%;
    background: var(--k-bg-alt);
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--k-ink);
    transition: background var(--k-dur-base) var(--k-ease), color var(--k-dur-base) var(--k-ease);
}
.faq-item summary .ic svg {
    display: block;
    transition: transform var(--k-dur-base) var(--k-ease);
}
.faq-item[open] summary .ic { background: var(--k-accent-2); color: #fff; }
.faq-item[open] summary .ic svg { transform: rotate(45deg); }
.faq-item .answer {
    padding: 0 0 26px 74px;
    font: 400 15.5px/1.65 var(--k-font-sans);
    color: var(--k-ink-3);
    max-width: 70ch;
}

/* ────── CLOSING CTA ────── */
.closing {
    padding: 140px 0;
    position: relative;
    overflow: hidden;
    background: var(--k-ink);
    color: #fff;
    isolation: isolate;
    border-bottom: 1px solid var(--k-line);
}
.closing::before {
    content: "";
    position: absolute; inset: 0; z-index: -1;
    background:
        radial-gradient(48rem 30rem at 8% 24%, color-mix(in srgb, var(--k-accent) 38%, transparent) 0%, transparent 60%),
        radial-gradient(46rem 28rem at 92% 78%, color-mix(in srgb, var(--k-trust) 36%, transparent) 0%, transparent 60%);
    opacity: 0.85;
}
.closing-grid {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    gap: 64px;
    align-items: center;
}
.closing h2 {
    font-family: var(--k-font-sans);
    font-weight: 200;
    font-size: clamp(40px, 5.4vw, 72px);
    letter-spacing: -0.04em;
    line-height: 0.98;
    color: #fff;
    margin: 0 0 28px;
    text-wrap: balance;
}
.closing h2 em { font-style: italic; font-weight: 300; color: var(--k-accent); }
.closing p {
    font-size: 18.5px; color: rgba(255,255,255,0.78);
    max-width: 56ch;
    margin: 0 0 40px;
}
.closing .btns { display: flex; flex-wrap: wrap; gap: 12px; }
.closing .btn-primary { background: #fff; color: var(--k-ink); }
.closing .btn-line { color: #fff; border-color: rgba(255,255,255,0.32); }
.closing .btn-line:hover { border-color: #fff; background: rgba(255,255,255,0.06); }

.closing-side {
    border-left: 1px solid rgba(255,255,255,0.18);
    padding-left: 48px;
    display: flex; flex-direction: column; gap: 24px;
}
.closing-side .item .lab { font: 500 10.5px/1 var(--k-font-mono); color: var(--k-accent); letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 8px; }
.closing-side .item .v {
    font-family: var(--k-font-sans);
    font-weight: 300;
    font-size: 24px;
    letter-spacing: -0.018em;
    color: #fff;
}
.closing-side .item p { font: 400 13.5px/1.55 var(--k-font-sans); color: rgba(255,255,255,0.66); margin: 6px 0 0; }

/* ────── FOOTER ────── */
.foot {
    background: var(--k-bg);
    padding: 96px 0 40px;
}
.foot-mast {
    display: grid;
    grid-template-columns: 1.4fr 3fr;
    gap: 64px;
    align-items: start;
    margin-bottom: 64px;
    padding-bottom: 56px;
    border-bottom: 1px solid var(--k-line);
}
.foot-brand img { height: 28px; margin-bottom: 18px; }
.foot-brand p { margin: 0; font: 400 14.5px/1.65 var(--k-font-sans); color: var(--k-ink-3); max-width: 360px; }
.foot-cols {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
}
.foot-cols h5 {
    margin: 0 0 16px;
    font: 600 11px/1 var(--k-font-sans);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--k-ink);
}
.foot-cols a {
    display: block;
    padding: 7px 0;
    font: 400 14px/1.4 var(--k-font-sans);
    color: var(--k-ink-3);
    text-decoration: none;
    transition: color var(--k-dur-base) var(--k-ease);
}
.foot-cols a:hover { color: var(--k-ink); }
.foot-base {
    display: flex; justify-content: space-between; gap: 16px;
    font: 400 12.5px/1.5 var(--k-font-sans);
    color: var(--k-ink-4);
    flex-wrap: wrap;
}
.foot-base a { color: var(--k-ink-3); text-decoration: none; }
.foot-base a:hover { color: var(--k-ink); }
.foot-base .legal { display: flex; gap: 22px; }

/* ────── RESPONSIVE ────── */
@media (max-width: 1080px) {
    .cover-grid { grid-template-columns: 1fr; }
    .cover-right { border-left: 0; border-top: 1px solid var(--k-line); min-height: 480px; }
    .outcome-grid, .product-block, .eu-grid, .closing-grid { grid-template-columns: 1fr; gap: 40px; }
    .industry { grid-template-columns: 1fr; gap: 32px; }
    .industry:nth-child(even) .industry-photo { order: 0; }
    .cases-grid { grid-template-columns: repeat(2, 1fr); }
    .closing-side { border-left: 0; padding-left: 0; padding-top: 32px; border-top: 1px solid rgba(255,255,255,0.18); }
    .pricing-head, .pricing-rows .pr, .pricing-cta { grid-template-columns: 1.2fr repeat(5, 1fr); }
    .compare th, .compare td { padding: 14px 14px; font-size: 13px; }
}
@media (max-width: 760px) {
    .wrap, .wrap-n { padding: 0 24px; }
    .nav-row { grid-template-columns: 1fr auto; }
    .nav-left { display: none; }
    .nav-logo { order: -1; justify-self: start; }
    .nav-right > :not(.nav-burger) { display: none; }
    .nav-burger { display: inline-flex; }
    .section { padding: 80px 0; }
    .chap { grid-template-columns: 1fr; gap: 8px; padding-bottom: 24px; margin-bottom: 36px; }
    .chap .rn { font-size: 40px; }
    .cases-grid { grid-template-columns: 1fr; }
    .pricing-head, .pricing-rows .pr, .pricing-cta { grid-template-columns: 1fr; }
    .pricing-head > div, .pricing-rows .pr > div, .pricing-cta > div { border-left: 0; border-top: 1px solid var(--k-line); }
    .pricing-rows .pr > div:first-child, .pricing-cta > div:first-child { border-top: 0; }
    .compare { overflow-x: auto; }
    .foot-mast { grid-template-columns: 1fr; }
    .foot-cols { grid-template-columns: repeat(2, 1fr); }
}
