/* ============================================================
   FONTS (self-hosted)
   Replaces the previous <link rel="stylesheet" href="https://fonts.googleapis.com/...">.
   Privacy + speed: visitor IP no longer goes to Google for every pageview;
   one local round-trip instead of remote stylesheet + remote .woff2.
   Subsets: latin / latin-ext / vietnamese / greek / cyrillic auto-selected
   by unicode-range. font-display: swap preserved.
   ============================================================ */
/* vietnamese */
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/fraunces-500-italic-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/fraunces-500-italic-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/fraunces-500-italic-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/fraunces-500-italic-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/fraunces-500-italic-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/fraunces-500-italic-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/fraunces-500-normal-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/fraunces-500-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/fraunces-500-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/fraunces-500-normal-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/fraunces-500-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/fraunces-500-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-cyrillic-ext.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-cyrillic.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-greek-ext.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-greek.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-cyrillic-ext.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-cyrillic.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-greek-ext.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-greek.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-cyrillic-ext.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-cyrillic.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-greek-ext.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-greek.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-cyrillic-ext.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-cyrillic.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-greek-ext.woff2) format('woff2');
  unicode-range: U+1F00-1FFF;
}
/* greek */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-greek.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter Tight';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(fonts/inter-tight-600-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/jetbrains-mono-500-normal-cyrillic-ext.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/jetbrains-mono-500-normal-cyrillic.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/jetbrains-mono-500-normal-greek.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/jetbrains-mono-500-normal-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/jetbrains-mono-500-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(fonts/jetbrains-mono-500-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/jetbrains-mono-500-normal-cyrillic-ext.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/jetbrains-mono-500-normal-cyrillic.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/jetbrains-mono-500-normal-greek.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/jetbrains-mono-500-normal-vietnamese.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/jetbrains-mono-500-normal-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(fonts/jetbrains-mono-500-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ============================================================
   Kanonik - Option C Hybrid Design System
   Source-of-truth tokens from /kanonik-brand/src/tokens.css
   ============================================================ */

:root {
  /* ---------- LIGHT SURFACES (body) ---------- */
  --kn-bg:              #F5F1EB;
  --kn-bg-warm:         #EFE9DF;
  --kn-bg-paper:        #FAF7F1;
  --kn-surface:         #FFFFFF;
  --kn-border:          #E4DDD0;
  --kn-border-strong:   #C9BFAB;

  /* ---------- LIGHT INK ---------- */
  --kn-ink:             #0B0B0F;
  --kn-ink-soft:        #2C2A26;
  --kn-ink-muted:       #6B655A;
  --kn-ink-dim:         #5E574B;  /* was #9A9285; darkened for WCAG 2.2 AA on cream (ADR-0013) */

  /* ---------- DARK SURFACES (hero + CTA + footer) ---------- */
  --kn-dark-bg:         #0B0B0F;
  --kn-dark-elev:       #15110D;
  --kn-dark-surface:    #1C1813;
  --kn-dark-border:     #2C2620;
  --kn-dark-border-strong: #3A332B;

  /* ---------- DARK INK ---------- */
  --kn-dark-ink:        #F0EADD;
  --kn-dark-ink-muted:  #A89E8B;
  --kn-dark-ink-dim:    #8F8576;  /* was #6B6055; lightened for WCAG 2.2 AA on dark (ADR-0013) */

  /* ---------- ACCENTS (semantic) ---------- */
  --kn-accent:          #446640;  /* sage dark - WCAG 2.2 AA on cream (was #5F7F58, ADR-0013 supersedes ADR-0009) */
  --kn-accent-light:    #87A878;  /* sage primary - brand voice on dark (unchanged; already AAA on dark) */
  --kn-accent-deep:     #2F4F2A;  /* hover, pressed - kept distinctly darker than new accent (was #3F5F38) */
  --kn-verified:        #2D5F4F;  /* forest - Verifier passed */
  --kn-verified-light:  #7BC4A8;  /* on dark */
  --kn-warn:            #7A5A1C;  /* dark amber - approval required (was #B8862B; darkened for WCAG 2.2 AA, ADR-0013) */
  --kn-warn-light:      #E0B968;  /* on dark */

  /* ---------- TYPOGRAPHY ---------- */
  --kn-font-display:    "Fraunces", Georgia, "Times New Roman", serif;
  --kn-font-sans:       "Inter Tight", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --kn-font-mono:       "JetBrains Mono", ui-monospace, "SF Mono", Monaco, Consolas, monospace;

  --kn-text-xs:         12px;
  --kn-text-sm:         14px;
  --kn-text-base:       16px;
  --kn-text-lg:         18px;
  --kn-text-xl:         20px;
  --kn-text-2xl:        24px;
  --kn-text-3xl:        32px;
  --kn-text-4xl:        48px;
  --kn-text-5xl:        64px;
  --kn-text-6xl:        96px;

  /* ---------- SPACING ---------- */
  --kn-space-1:  4px;
  --kn-space-2:  8px;
  --kn-space-3:  12px;
  --kn-space-4:  16px;
  --kn-space-6:  24px;
  --kn-space-8:  32px;
  --kn-space-12: 48px;
  --kn-space-16: 64px;
  --kn-space-20: 80px;
  --kn-space-24: 96px;
  --kn-space-32: 128px;

  /* ---------- LAYOUT ---------- */
  --kn-container:        1280px;
  --kn-container-narrow: 880px;
  --kn-radius-sm: 4px;
  --kn-radius-md: 8px;
  --kn-radius-lg: 12px;

  /* ---------- MOTION ---------- */
  --kn-ease:          cubic-bezier(0.2, 0.7, 0.2, 1);
  --kn-duration-fast: 150ms;
  --kn-duration-base: 250ms;
  --kn-duration-slow: 600ms;
}

/* ============================================================
   GLOBAL RESETS
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }

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

body {
  background: var(--kn-bg);
  color: var(--kn-ink);
  font-family: var(--kn-font-sans);
  font-size: var(--kn-text-base);
  font-weight: 400;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* Subtle paper grain - site-wide */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 100;
  opacity: 0.04;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; transition: color var(--kn-duration-base) var(--kn-ease); }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
ul, ol { list-style: none; }

/* ============================================================
   DARK-SCOPE
   Wrap any section in .kn-dark for inverted palette.
   ============================================================ */
.kn-dark {
  background: var(--kn-dark-bg);
  color: var(--kn-dark-ink);
  position: relative;
  overflow: hidden;
}
.kn-dark a { color: var(--kn-dark-ink); }
.kn-dark p { color: var(--kn-dark-ink-muted); }

/* Soft transition into the light body, matching the mockup */
.kn-dark.with-fade::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 80px;
  background: linear-gradient(180deg, transparent 0%, var(--kn-bg) 100%);
  pointer-events: none;
  z-index: 2;
}

/* ============================================================
   TYPOGRAPHY PRIMITIVES
   ============================================================ */
.kn-display, h1, h2, h3 {
  font-family: var(--kn-font-display);
  font-weight: 400;
  letter-spacing: -0.03em;
  line-height: 1.02;
  color: var(--kn-ink);
}
h1 em, h2 em, h3 em, .kn-display em {
  font-style: italic;
  color: var(--kn-accent);
  font-weight: 400;
}
.kn-dark h1, .kn-dark h2, .kn-dark h3 { color: var(--kn-dark-ink); }
.kn-dark h1 em, .kn-dark h2 em, .kn-dark h3 em { color: var(--kn-accent-light); }

h1 { font-size: clamp(48px, 7.5vw, 96px); line-height: 0.98; letter-spacing: -0.035em; margin: 0 0 32px; }
h2 { font-size: clamp(36px, 4.8vw, 60px); line-height: 1.08; margin: 0 0 32px; }
h3 { font-size: var(--kn-text-3xl); margin: 0 0 16px; }

p {
  color: var(--kn-ink-soft);
  font-size: var(--kn-text-base);
  line-height: 1.55;
}

strong { font-weight: 500; }

/* Mono utilities */
.kn-mono { font-family: var(--kn-font-mono); }

.kn-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 14px;
  border: 1px solid var(--kn-border-strong);
  border-radius: 100px;
  font-family: var(--kn-font-mono);
  font-size: var(--kn-text-xs);
  color: var(--kn-ink-soft);
  background: var(--kn-bg-paper);
  margin-bottom: 36px;
}
.kn-eyebrow .dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--kn-accent);
  box-shadow: 0 0 8px var(--kn-accent);
}
.kn-dark .kn-eyebrow {
  background: var(--kn-dark-elev);
  border-color: var(--kn-dark-border-strong);
  color: var(--kn-dark-ink-muted);
}
.kn-dark .kn-eyebrow .dot {
  background: var(--kn-accent-light);
  box-shadow: 0 0 8px var(--kn-accent-light);
}

.kn-section-eyebrow {
  display: block;
  font-family: var(--kn-font-mono);
  /* Was 12px (--kn-text-xs) - flagged as barely readable. 14px reads
     cleanly at viewing distance without crowding the H2 below. */
  font-size: var(--kn-text-sm);
  color: var(--kn-accent);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 20px;
}
.kn-dark .kn-section-eyebrow { color: var(--kn-accent-light); }

.section-sub {
  font-size: var(--kn-text-lg);
  color: var(--kn-ink-soft);
  max-width: 660px;
  line-height: 1.55;
  /* margin-top: 0 keeps the h2 -> section-sub gap equal to h2's margin-bottom
     (32px), instead of stacking with default p margin-top. */
  margin: 0 0 64px;
}
.kn-dark .section-sub { color: var(--kn-dark-ink-muted); }

/* Secondary technical note below a feature grid or section.
   Replaces inline-styled <p> with font-size: 13px on three pages -
   barely legible. Mono kept where the prose names a binary; size
   raised to 15px so it reads cleanly without dominating. */
.section-note {
  margin-top: 32px;
  font-family: var(--kn-font-mono);
  font-size: 15px;
  color: var(--kn-ink-muted);
  line-height: 1.6;
  max-width: 880px;
}
.section-note-narrow {
  /* Variant used in tight columns (pricing / waitlist) where 880px would overflow. */
  margin-top: 20px;
  font-size: 15px;
  color: var(--kn-ink-muted);
  line-height: 1.55;
}

/* Waitlist form privacy fineprint - was 13px mono, barely readable.
   Same family + alignment, bumped to 14px and ink-soft for legibility. */
.form-fineprint {
  margin-top: 16px;
  font-size: 14px;
  color: var(--kn-ink-muted);
  text-align: center;
  font-family: var(--kn-font-mono);
  line-height: 1.55;
}

/* ============================================================
   LAYOUT
   ============================================================ */
.kn-container {
  max-width: var(--kn-container);
  margin: 0 auto;
  padding: 0 32px;
}
section {
  padding: 120px 32px;
  max-width: var(--kn-container);
  margin: 0 auto;
  position: relative;
}

.divider-warm {
  background: var(--kn-bg-warm);
  border-top: 1px solid var(--kn-border);
  border-bottom: 1px solid var(--kn-border);
}

/* ============================================================
   NAV
   ============================================================ */
nav.site-nav {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
}

.kn-dark nav.site-nav {
  background: rgba(11, 11, 15, 0.7);
  border-bottom: 1px solid var(--kn-dark-border);
}

body:not(.has-dark-hero) nav.site-nav {
  background: rgba(245, 241, 235, 0.8);
  border-bottom: 1px solid var(--kn-border);
}

.nav-inner {
  max-width: var(--kn-container);
  margin: 0 auto;
  padding: 18px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.logo {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--kn-font-display);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--kn-ink);
}
.kn-dark .logo { color: var(--kn-dark-ink); }

.logo-mark {
  width: 56px;
  height: 56px;
  flex-shrink: 0;
  display: block;
}
.kn-dark .logo-mark,
.footer-brand .logo-mark {
  filter: invert(1);
}

.nav-links {
  display: flex;
  gap: 36px;
  align-items: center;
}
.nav-links a {
  color: var(--kn-ink-muted);
  font-size: var(--kn-text-sm);
  font-weight: 400;
}
.nav-links a:hover { color: var(--kn-accent); }
.kn-dark .nav-links a { color: var(--kn-dark-ink-muted); }
.kn-dark .nav-links a:hover { color: var(--kn-accent-light); }
.nav-links a.active { color: var(--kn-ink); }
.kn-dark .nav-links a.active { color: var(--kn-dark-ink); }

.nav-right {
  display: flex;
  align-items: center;
  gap: 20px;
}

.nav-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--kn-font-mono);
  font-size: var(--kn-text-xs);
  color: var(--kn-ink-muted);
}
.kn-dark .nav-status { color: var(--kn-dark-ink-muted); }
.nav-status .dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--kn-verified);
  box-shadow: 0 0 8px var(--kn-verified);
  animation: kn-pulse 2s ease-in-out infinite;
}
.kn-dark .nav-status .dot {
  background: var(--kn-verified-light);
  box-shadow: 0 0 8px var(--kn-verified-light);
}
@keyframes kn-pulse { 0%,100% { opacity:1 } 50% { opacity:0.5 } }
@media (prefers-reduced-motion: reduce) {
  /* Honor the OS motion preference: the nav-status dot is the only
     element on the site that pulses indefinitely. Disable it when
     the user has asked for reduced motion. The dot still renders
     in --kn-verified so the "all systems operational" semantic
     survives without the animation. */
  .nav-status .dot { animation: none; }
}

.nav-toggle {
  display: none;
  width: 36px; height: 36px;
  align-items: center;
  justify-content: center;
  color: var(--kn-ink);
}
.kn-dark .nav-toggle { color: var(--kn-dark-ink); }

/* ============================================================
   BUTTONS
   ============================================================ */
.kn-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: var(--kn-radius-sm);
  font-family: var(--kn-font-sans);
  font-size: var(--kn-text-sm);
  font-weight: 500;
  border: 1px solid transparent;
  transition: all var(--kn-duration-base) var(--kn-ease);
  cursor: pointer;
  white-space: nowrap;
}

.kn-btn-primary {
  background: var(--kn-ink);
  color: var(--kn-bg);
}
.kn-btn-primary:hover {
  background: var(--kn-accent);
  transform: translateY(-1px);
}
.kn-dark .kn-btn-primary {
  background: var(--kn-dark-ink);
  color: var(--kn-dark-bg);
}
.kn-dark .kn-btn-primary:hover {
  background: var(--kn-accent-light);
  color: var(--kn-dark-bg);
}

.kn-btn-ghost {
  color: var(--kn-ink);
  border-color: var(--kn-border-strong);
  background: transparent;
}
.kn-btn-ghost:hover {
  background: var(--kn-bg-paper);
  border-color: var(--kn-ink-muted);
}
.kn-dark .kn-btn-ghost {
  color: var(--kn-dark-ink);
  border-color: var(--kn-dark-ink-muted);
  background: rgba(240, 234, 221, 0.04);
}
.kn-dark .kn-btn-ghost:hover {
  background: rgba(240, 234, 221, 0.10);
  border-color: var(--kn-dark-ink);
}

.kn-btn-large {
  padding: 14px 22px;
  font-size: var(--kn-text-base);
}

/* .final-cta is dark but lacks a .kn-dark wrapper class;
   button styles need to flip to the dark-theme variants. */
.final-cta .kn-btn-primary {
  background: var(--kn-dark-ink);
  color: var(--kn-dark-bg);
}
.final-cta .kn-btn-primary:hover {
  background: var(--kn-accent-light);
  color: var(--kn-dark-bg);
}
.final-cta .kn-btn-ghost {
  color: var(--kn-dark-ink);
  border-color: var(--kn-dark-ink-muted);
  background: rgba(240, 234, 221, 0.04);
}
.final-cta .kn-btn-ghost:hover {
  background: rgba(240, 234, 221, 0.10);
  border-color: var(--kn-dark-ink);
}

/* ============================================================
   HERO (dark)
   ============================================================ */
.hero {
  position: relative;
  padding: 100px 32px 120px;
  max-width: var(--kn-container);
  margin: 0 auto;
  z-index: 1;
}
.hero h1 {
  margin-bottom: 32px;
  max-width: 980px;
  /* Slightly smaller than global h1 so the longer verb-first hero line breaks gracefully. */
  font-size: clamp(40px, 6vw, 76px);
  /* Fraunces variable optical-size axis; nudge toward display-tuned glyphs
     (heavier serifs, slightly higher contrast) so the H1 reads cleanly on dark. */
  font-variation-settings: "opsz" 120;
}
.hero-sub {
  font-size: var(--kn-text-xl);
  line-height: 1.55;
  /* Bumped from --kn-dark-ink-muted to full --kn-dark-ink (#F0EADD on #0B0B0F = ~17:1)
     and font-weight 400 -> 500 so the hero subhead reads as primary copy, not as
     a faded quote. Founder feedback: the dark-hero text was hard to read. */
  color: var(--kn-dark-ink);
  font-weight: 500;
  max-width: 640px;
  margin-bottom: 44px;
}
.hero-cta {
  display: flex;
  gap: 12px;
  margin-bottom: 40px;
  flex-wrap: wrap;
}

/* Credibility anchor strip - under hero CTAs, above terminal */
.hero-anchors {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 32px;
  align-items: center;
  margin-bottom: 60px;
  font-family: var(--kn-font-mono);
  /* Bumped from --kn-text-xs (12px) and --kn-dark-ink-muted (low presence)
     to 14px in full ink. The trust-strip bullets (NIST AU-10, EU AI Act 12,
     Founding Customer cohort) are the proof the hero is making; they need
     to actually read at glance. */
  font-size: var(--kn-text-sm);
  color: var(--kn-dark-ink);
  letter-spacing: 0.02em;
  line-height: 1.5;
}
.hero-anchors > span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.hero-anchors .anchor-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--kn-verified-light);
  box-shadow: 0 0 6px var(--kn-verified-light);
  flex-shrink: 0;
}
.hero-anchors .anchor-dot.warn { background: var(--kn-warn-light); box-shadow: 0 0 6px var(--kn-warn-light); }
.hero-anchors .anchor-dot.accent { background: var(--kn-accent-light); box-shadow: 0 0 6px var(--kn-accent-light); }

/* ============================================================
   Trust-flow diagram (home page, between quote and deploy section)
   ============================================================ */
.trust-flow {
  max-width: 1080px;
  margin: 0 auto;
  padding: 32px 24px 0;
}

.trust-flow-label {
  font-family: var(--kn-font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--kn-ink-muted);
  text-align: center;
  margin-bottom: 28px;
}

.trust-flow-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
  gap: 12px;
  align-items: stretch;
}

.trust-flow-node {
  background: var(--kn-surface);
  border: 1px solid var(--kn-border);
  border-radius: var(--kn-radius-md);
  padding: 22px 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: center;
  position: relative;
  transition: border-color var(--kn-duration-base) var(--kn-ease);
}
.trust-flow-node:hover { border-color: var(--kn-border-strong); }

.trust-flow-node.center {
  background: var(--kn-ink);
  color: var(--kn-dark-ink);
  border-color: var(--kn-ink);
}
.trust-flow-node.center .trust-flow-node-name { color: var(--kn-dark-ink); }
.trust-flow-node.center .trust-flow-node-meta { color: var(--kn-dark-ink-muted); }

.trust-flow-node-icon {
  width: 22px;
  height: 22px;
  margin: 0 auto 4px;
  color: var(--kn-accent);
}
.trust-flow-node.center .trust-flow-node-icon { color: var(--kn-accent-light); }
.trust-flow-node.verified .trust-flow-node-icon { color: var(--kn-verified); }
.trust-flow-node.warn .trust-flow-node-icon { color: var(--kn-warn); }

.trust-flow-node-name {
  font-family: var(--kn-font-display);
  font-size: 16px;
  font-weight: 500;
  color: var(--kn-ink);
  letter-spacing: -0.01em;
}

.trust-flow-node-meta {
  font-family: var(--kn-font-mono);
  font-size: 11px;
  color: var(--kn-ink-muted);
  letter-spacing: 0.04em;
}

.trust-flow-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--kn-border-strong);
  min-width: 24px;
}

.trust-flow-arrow svg {
  width: 18px;
  height: 18px;
}

/* Pricing-card cost-promise line under each price */
.pricing-card-promise {
  font-family: var(--kn-font-mono);
  font-size: var(--kn-text-xs);
  letter-spacing: 0.02em;
  color: var(--kn-accent);
  margin-top: -8px;
  font-weight: 500;
}
.pricing-card.featured .pricing-card-promise { color: var(--kn-accent-light); }

/* ============================================================
   TERMINAL DEMO
   ============================================================ */
.terminal {
  background: var(--kn-dark-elev);
  border: 1px solid var(--kn-dark-border);
  border-radius: 10px;
  overflow: hidden;
  box-shadow:
    0 30px 80px -20px rgba(0, 0, 0, 0.6),
    0 0 0 1px rgba(135, 168, 120, 0.05);
  max-width: 880px;
  margin: 0 auto;
}
.terminal-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid var(--kn-dark-border);
  background: var(--kn-dark-bg);
}
.terminal-dots { display: flex; gap: 7px; }
.terminal-dots span {
  width: 11px; height: 11px;
  border-radius: 50%;
  background: var(--kn-dark-border-strong);
}
.terminal-label {
  font-family: var(--kn-font-mono);
  font-size: 11px;
  color: var(--kn-dark-ink-dim);
}
.terminal-body {
  padding: 26px;
  font-family: var(--kn-font-mono);
  font-size: 13.5px;
  line-height: 1.85;
  color: var(--kn-dark-ink);
}
.term-line { display: flex; gap: 14px; align-items: flex-start; }
.term-prompt { color: var(--kn-dark-ink-dim); flex-shrink: 0; width: 14px; }
.term-user, .term-claude { color: var(--kn-dark-ink); }
.term-tool { color: var(--kn-accent-light); font-size: 12.5px; }
.term-verify { color: var(--kn-verified-light); font-size: 12.5px; }
.term-arrow { color: var(--kn-warn-light); font-size: 12.5px; }
.term-divider {
  height: 1px;
  background: var(--kn-dark-border);
  margin: 14px 0;
}
.term-claude strong { color: var(--kn-accent-light); font-weight: 500; }

/* ============================================================
   LOGOS STRIP
   ============================================================ */
.logos-strip {
  border-bottom: 1px solid var(--kn-border);
  padding: 48px 32px;
  background: var(--kn-bg-warm);
  position: relative;
  z-index: 1;
}
.logos-inner {
  max-width: var(--kn-container);
  margin: 0 auto;
  text-align: center;
}
.logos-label {
  font-family: var(--kn-font-mono);
  font-size: 11px;
  color: var(--kn-ink-muted);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 32px;
}
.logos-row {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 48px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}
.logo-item {
  color: var(--kn-ink-soft);
  font-family: var(--kn-font-display);
  font-size: 28px;
  font-weight: 500;
  letter-spacing: -0.02em;
  display: inline-flex;
  align-items: baseline;
  gap: 12px;
}
.logo-status {
  font-family: var(--kn-font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--kn-accent);
}
.logos-roadmap {
  font-family: var(--kn-font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--kn-ink-muted);
  text-align: center;
}

/* ============================================================
   COMPARE GRID
   ============================================================ */
.compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 48px;
}
.compare-card {
  background: var(--kn-surface);
  border: 1px solid var(--kn-border);
  border-radius: 10px;
  padding: 36px;
}
.compare-card.helm {
  background: var(--kn-ink);
  border-color: var(--kn-ink);
  color: var(--kn-bg);
}
.compare-title {
  font-family: var(--kn-font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: 28px;
  color: var(--kn-ink-muted);
}
.compare-card.helm .compare-title { color: var(--kn-accent-light); }
.compare ul {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.compare li {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  color: var(--kn-ink-soft);
  line-height: 1.55;
  font-size: 15px;
  line-height: 1.5;
}
.compare-card.helm li { color: var(--kn-dark-ink); }
.compare-icon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  margin-top: 3px;
}

/* ============================================================
   VERIFIER CHECKS
   ============================================================ */
.verifier {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.verifier-checks {
  background: var(--kn-surface);
  border: 1px solid var(--kn-border);
  border-radius: 10px;
  padding: 32px;
  font-family: var(--kn-font-mono);
  font-size: 13.5px;
}
.check-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0;
  border-bottom: 1px dashed var(--kn-border);
}
.check-row:last-child { border-bottom: none; }
.check-left {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--kn-ink);
}
.check-mark { color: var(--kn-verified); font-weight: 500; }
.check-value { color: var(--kn-ink-muted); }

/* ============================================================
   HASH CHAIN
   ============================================================ */
.chain-section {
  background: var(--kn-bg-warm);
  border-top: 1px solid var(--kn-border);
  border-bottom: 1px solid var(--kn-border);
}
.chain-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.chain-vis {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.chain-block {
  background: var(--kn-surface);
  border: 1px solid var(--kn-border);
  border-radius: 8px;
  padding: 18px 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: var(--kn-font-mono);
  font-size: 13px;
  position: relative;
}
.chain-block::after {
  content: '';
  position: absolute;
  bottom: -15px;
  left: 32px;
  width: 1px;
  height: 14px;
  background: var(--kn-border-strong);
}
.chain-block:last-child::after { display: none; }
.chain-step {
  color: var(--kn-ink-muted);
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 0.12em;
}
.chain-hash { color: var(--kn-accent); font-weight: 500; }

/* ============================================================
   FRAMEWORKS GRID
   ============================================================ */
.frameworks {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-top: 48px;
}
.framework {
  background: var(--kn-surface);
  border: 1px solid var(--kn-border);
  border-radius: 8px;
  padding: 28px 24px;
  transition: all var(--kn-duration-base) var(--kn-ease);
}
.framework:hover {
  border-color: var(--kn-border-strong);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px -8px rgba(70, 50, 30, 0.15);
}
.framework-name {
  font-family: var(--kn-font-display);
  font-size: 30px;
  color: var(--kn-ink);
  line-height: 1;
  margin-bottom: 6px;
  letter-spacing: -0.025em;
  font-weight: 500;
}
.framework-version {
  font-family: var(--kn-font-mono);
  font-size: 12px;
  color: var(--kn-ink-muted);
}
.framework-status {
  margin-top: 20px;
  font-family: var(--kn-font-mono);
  font-size: 11px;
  color: var(--kn-verified);
  text-transform: uppercase;
  letter-spacing: 0.12em;
}
.framework-status.next { color: var(--kn-accent); }
.framework-status.soon { color: var(--kn-ink-dim); }

/* ============================================================
   SMALL UTILITY CLASSES (replaces inline style="..." in HTML)
   ============================================================ */

/* "See the full mapping..." style follow-up link under a section-sub paragraph. */
.section-link {
  margin-top: 16px;
}

/* Pricing-page: HR that abuts a kn-section-eyebrow with no extra top margin. */
.hr-flush-top {
  margin-top: 0;
}

/* Pricing-page: "What you are not paying for" lead-in needs a touch more breathing
   room than a default <p> after a <table> would give. */
.section-lead-strong {
  margin-top: 28px;
}

/* Terminal-bar right-side spacer balances the three terminal dots on the left
   so the session label centers visually. */
.terminal-bar-spacer {
  width: 50px;
  flex-shrink: 0;
}

/* About page: How-we-work card grid sits inside the content-narrow body
   and benefits from slightly tighter top spacing than the default
   .features-grid would give after a <p>. */
.about-how-grid {
  margin-top: 20px;
}

/* ============================================================
   QUOTE SECTION
   ============================================================ */
.quote-section {
  text-align: center;
  padding: 100px 32px;
  background: var(--kn-bg-paper);
  border-top: 1px solid var(--kn-border);
  border-bottom: 1px solid var(--kn-border);
}
.quote-mark {
  font-family: var(--kn-font-display);
  font-size: 80px;
  color: var(--kn-accent);
  line-height: 0.5;
  margin-bottom: 16px;
  font-style: italic;
}
blockquote {
  font-family: var(--kn-font-display);
  font-size: clamp(28px, 3.8vw, 46px);
  line-height: 1.2;
  letter-spacing: -0.025em;
  color: var(--kn-ink);
  max-width: 920px;
  margin: 0 auto 32px;
  font-weight: 400;
}
blockquote em { font-style: italic; color: var(--kn-accent); }
.quote-attr {
  font-family: var(--kn-font-mono);
  font-size: 12px;
  color: var(--kn-ink-muted);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* ============================================================
   FINAL CTA (dark)
   ============================================================ */
.final-cta {
  background: var(--kn-dark-bg);
  color: var(--kn-dark-ink);
  text-align: center;
  padding: 140px 32px;
  position: relative;
  overflow: hidden;
}
.final-cta-inner {
  max-width: 800px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.final-cta h2 { color: var(--kn-dark-ink); margin: 0 auto 24px; }
.final-cta h2 em { color: var(--kn-accent-light); }
.final-cta p {
  font-size: 18px;
  color: var(--kn-dark-ink-muted);
  line-height: 1.55;
  margin: 0 auto 44px;
  max-width: 580px;
}
.final-cta-buttons {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}
.final-cta-tag {
  font-family: var(--kn-font-display);
  font-size: clamp(22px, 2.4vw, 30px);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--kn-dark-ink-muted);
  margin: 56px auto 0;
  max-width: 580px;
}
.final-cta-tag em {
  font-style: italic;
  color: var(--kn-accent-light);
}

/* ============================================================
   CATEGORY CALLOUT (locked positioning, 2026-05-22)
   Warm-paper band between differentiator and chain sections.
   Reframes the market: competitors as assertion systems,
   Kanonik as evidence system.
   ============================================================ */
.category-callout {
  background: var(--kn-bg-paper);
  border-top: 1px solid var(--kn-border);
  border-bottom: 1px solid var(--kn-border);
  padding: 96px 32px;
  text-align: center;
}
.category-callout blockquote {
  font-family: var(--kn-font-display);
  font-size: clamp(28px, 3.6vw, 44px);
  line-height: 1.18;
  letter-spacing: -0.025em;
  color: var(--kn-ink);
  max-width: 980px;
  margin: 0 auto;
  font-weight: 400;
}
.category-callout blockquote em {
  font-style: italic;
  color: var(--kn-accent);
}

/* ============================================================
   PROOF LINE (locked brand-level closer, 2026-05-22)
   Mid-page anchor between chain section and frameworks.
   The five-word compression of the entire positioning.
   ============================================================ */
.proof-line {
  background: var(--kn-bg);
  padding: 80px 32px;
  text-align: center;
}
.proof-line p {
  font-family: var(--kn-font-display);
  font-size: clamp(32px, 4vw, 56px);
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: var(--kn-accent);
  margin: 0 auto;
  font-weight: 400;
}
.proof-line em {
  font-style: italic;
}

/* ============================================================
   AUDITOR CHANNEL (homepage)
   The auditor-as-recommender mechanic, expressed as a deliberate
   pricing-model choice. Two-column: copy left, $0 stat right.
   Stat block uses the dark-ink surface pattern from .compare-card.helm
   so the pull-out reads as a structural claim rather than decoration.
   ============================================================ */
.auditor-channel-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 80px;
  align-items: center;
}
.auditor-channel-grid h2 { margin-bottom: 24px; }
.auditor-channel-grid .section-sub { margin-bottom: 20px; }
.auditor-channel-grid .section-link { margin-top: 8px; }

.auditor-channel-stat {
  background: var(--kn-ink);
  color: var(--kn-dark-ink);
  border-radius: 10px;
  padding: 56px 36px;
  text-align: center;
}
.auditor-channel-stat-value {
  font-family: var(--kn-font-display);
  font-size: clamp(72px, 8vw, 112px);
  font-weight: 500;
  line-height: 0.95;
  letter-spacing: -0.04em;
  color: var(--kn-accent-light);
  margin-bottom: 14px;
}
.auditor-channel-stat-label {
  font-family: var(--kn-font-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--kn-dark-ink-muted);
  line-height: 1.6;
}

/* ============================================================
   HERO MNEMONIC (locked V3 spine, 2026-05-22)
   Compresses Propose / Verify / Approve / Commit into the
   hero subtitle's first line.
   ============================================================ */
.hero-mnemonic {
  font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--kn-dark-ink);
}

/* ============================================================
   FOOTER (always dark)
   ============================================================ */
footer {
  background: var(--kn-dark-bg);
  border-top: 1px solid var(--kn-dark-border);
  padding: 64px 32px 40px;
  color: var(--kn-dark-ink-muted);
}
.footer-inner {
  max-width: var(--kn-container);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 64px;
  margin-bottom: 48px;
}
.footer-brand { max-width: 280px; }
.footer-brand .logo { color: var(--kn-dark-ink); }
.footer-brand p {
  color: var(--kn-dark-ink-muted);
  font-size: 14px;
  margin-top: 18px;
  line-height: 1.5;
  font-style: italic;
  font-family: var(--kn-font-display);
}
footer h4 {
  font-family: var(--kn-font-mono);
  /* 11px tested below comfortable scan threshold for column labels;
     12px (--kn-text-xs) reads cleanly without dominating the footer. */
  font-size: var(--kn-text-xs);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--kn-dark-ink-dim);
  margin-bottom: 20px;
  font-weight: 500;
}
footer ul { display: flex; flex-direction: column; gap: 12px; }
footer a {
  color: var(--kn-dark-ink-muted);
  font-size: 14px;
}
footer a:hover { color: var(--kn-accent-light); }
.footer-bottom {
  max-width: var(--kn-container);
  margin: 0 auto;
  padding-top: 32px;
  border-top: 1px solid var(--kn-dark-border);
  display: flex;
  justify-content: space-between;
  color: var(--kn-dark-ink-dim);
  font-family: var(--kn-font-mono);
  font-size: 12px;
  flex-wrap: wrap;
  gap: 16px;
}

/* ============================================================
   PAGE HEADER (light pages - warm-paper hero band)
   ============================================================ */
.page-hero {
  padding: 120px 32px 80px;
  background: var(--kn-bg-paper);
  border-bottom: 1px solid var(--kn-border);
}
.page-hero-inner {
  max-width: var(--kn-container);
  margin: 0 auto;
  text-align: center;
}
.page-hero h1 {
  font-size: clamp(40px, 5vw, 64px);
  margin-bottom: 24px;
  letter-spacing: -0.03em;
  line-height: 1.1;
}
.page-hero p {
  font-size: var(--kn-text-lg);
  color: var(--kn-ink-soft);
  max-width: 680px;
  margin: 0 auto;
  line-height: 1.55;
}

/* ============================================================
   INTERIOR PAGE COMPONENTS - light scope
   ============================================================ */
.section-head {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 64px;
}
.section-head p {
  margin-top: 16px;
  font-size: var(--kn-text-lg);
  color: var(--kn-ink-soft);
}

/* Features grid */
.features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
}
.feature-card {
  background: var(--kn-surface);
  border: 1px solid var(--kn-border);
  border-radius: 10px;
  padding: 32px;
  transition: all var(--kn-duration-base) var(--kn-ease);
}
.feature-card:hover {
  border-color: var(--kn-border-strong);
  box-shadow: 0 8px 20px -8px rgba(70, 50, 30, 0.12);
  transform: translateY(-2px);
}
.feature-icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: var(--kn-bg-warm);
  color: var(--kn-accent);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
}
.feature-card h3 {
  font-size: 20px;
  margin-bottom: 10px;
  letter-spacing: -0.015em;
}
.feature-card p {
  font-size: 15px;
  color: var(--kn-ink-soft);
  line-height: 1.55;
}

/* Status pills */
.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 10px;
  border-radius: 100px;
  font-family: var(--kn-font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.status-pill .dot {
  width: 6px; height: 6px;
  border-radius: 50%;
}
.status-pill.available {
  color: var(--kn-verified);
  background: rgba(45, 95, 79, 0.08);
  border: 1px solid rgba(45, 95, 79, 0.18);
}
.status-pill.available .dot { background: var(--kn-verified); }
.status-pill.soon {
  color: var(--kn-warn);
  background: rgba(184, 134, 43, 0.08);
  border: 1px solid rgba(184, 134, 43, 0.18);
}
.status-pill.soon .dot { background: var(--kn-warn); }
.status-pill.roadmap {
  color: var(--kn-ink-muted);
  background: var(--kn-bg-warm);
  border: 1px solid var(--kn-border);
}
.status-pill.roadmap .dot { background: var(--kn-ink-dim); }

/* Numbered flow */
.flow-steps {
  display: flex;
  flex-direction: column;
  gap: 0;
  max-width: 880px;
  margin: 0 auto;
}
.flow-step {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 24px;
  padding: 24px 0;
  position: relative;
}
.flow-step:not(:last-child)::after {
  content: '';
  position: absolute;
  left: 27px;
  top: 64px;
  bottom: -8px;
  width: 2px;
  background: linear-gradient(180deg, var(--kn-border-strong), transparent);
}
.flow-step-num {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--kn-surface);
  border: 1px solid var(--kn-border-strong);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--kn-font-mono);
  color: var(--kn-accent);
  font-weight: 500;
  position: relative;
  z-index: 1;
}
.flow-step.highlight .flow-step-num {
  background: var(--kn-ink);
  color: var(--kn-accent-light);
  border-color: var(--kn-ink);
}
.flow-step-body h3 { font-size: 22px; margin-bottom: 8px; }
.flow-step-body p { font-size: 16px; line-height: 1.6; }
.flow-step-meta {
  display: inline-block;
  font-family: var(--kn-font-mono);
  font-size: 11px;
  color: var(--kn-accent);
  background: var(--kn-bg-paper);
  border: 1px solid var(--kn-border);
  padding: 3px 10px;
  border-radius: 100px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-top: 12px;
}

/* Architecture diagram (used on how-it-works) */
.architecture {
  background: var(--kn-bg-paper);
  border: 1px solid var(--kn-border);
  border-radius: 12px;
  padding: 48px 32px;
}
.architecture-grid {
  display: grid;
  grid-template-columns: 1fr auto 1.2fr auto 1fr;
  gap: 16px;
  align-items: stretch;
}
.arch-node {
  background: var(--kn-surface);
  border: 1px solid var(--kn-border);
  border-radius: var(--kn-radius-md);
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.arch-node.center {
  background: var(--kn-ink);
  color: var(--kn-dark-ink);
  border-color: var(--kn-ink);
}
.arch-node.center h4, .arch-node.center .arch-node-label { color: var(--kn-dark-ink); }
.arch-node.center p { color: var(--kn-dark-ink-muted); }
.arch-node.center ul li { color: var(--kn-dark-ink); }
.arch-node-label {
  font-family: var(--kn-font-mono);
  font-size: 11px;
  color: var(--kn-ink-muted);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.arch-node h4 {
  font-family: var(--kn-font-display);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.01em;
}
.arch-node p {
  font-size: 14px;
  color: var(--kn-ink-soft);
  margin: 0;
}
.arch-node ul {
  display: flex; flex-direction: column; gap: 6px;
  margin-top: 4px;
}
.arch-node ul li {
  font-size: 13px;
  color: var(--kn-ink-soft);
  padding-left: 14px;
  position: relative;
  font-family: var(--kn-font-mono);
}
.arch-node ul li::before {
  content: '';
  position: absolute;
  left: 0; top: 8px;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--kn-accent);
}
.arch-arrow {
  display: flex; align-items: center; justify-content: center;
  color: var(--kn-ink-muted);
  font-family: var(--kn-font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  position: relative;
  min-width: 60px;
}
.arch-arrow::before {
  content: '';
  position: absolute;
  left: 0; right: 0; top: 50%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--kn-border-strong) 20%, var(--kn-border-strong) 80%, transparent);
}
.arch-arrow span {
  background: var(--kn-bg-paper);
  padding: 2px 8px;
  position: relative;
}

/* Callouts */
.callout {
  background: var(--kn-surface);
  border: 1px solid var(--kn-border);
  border-left: 3px solid var(--kn-accent);
  border-radius: var(--kn-radius-md);
  /* base padding lives below */
  padding: 24px 28px;
  margin: 32px 0;
}
.callout p {
  font-size: 16px;
  color: var(--kn-ink);
  line-height: 1.55;
  margin: 0;
}
.callout p + p {
  margin-top: 12px;
}
.callout strong { color: var(--kn-accent); }

/* Cohort-program callout - slightly warmer, more prominent on the pricing hero band */
.callout-cohort {
  background: var(--kn-bg-paper);
  border-left-color: var(--kn-accent);
  padding: 28px 32px;
}
.callout-cohort .callout-title {
  font-size: 17px;
  margin-bottom: 8px;
}

/* Spec cards */
.spec-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}
.spec-card {
  background: var(--kn-surface);
  border: 1px solid var(--kn-border);
  border-radius: var(--kn-radius-md);
  padding: 24px;
}
.spec-card h4 {
  font-family: var(--kn-font-display);
  font-size: 17px;
  font-weight: 500;
  margin-bottom: 8px;
  display: flex; align-items: center; gap: 8px;
}
.spec-card h4 .spec-check {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: rgba(45, 95, 79, 0.1);
  color: var(--kn-verified);
  display: inline-flex; align-items: center; justify-content: center;
}
.spec-card p { font-size: 14px; color: var(--kn-ink-soft); margin: 0; }

/* Integration cards */
.integration-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
}
.integration-card {
  background: var(--kn-surface);
  border: 1px solid var(--kn-border);
  border-radius: var(--kn-radius-md);
  padding: 24px;
  display: flex; flex-direction: column; gap: 14px;
  transition: all var(--kn-duration-base) var(--kn-ease);
}
.integration-card:hover {
  border-color: var(--kn-border-strong);
  transform: translateY(-1px);
}
/* "Coming soon" integration cards. Previously `opacity: 0.65`, which
   dimmed all text inside (including the .status-pill.soon's warn-coloured
   "Coming soon" label) below WCAG 2.2 AA contrast. Replaced with a
   muted background + reduced saturation; the .status-pill.soon already
   communicates the "not-yet" semantic. ADR-0013. */
.integration-card.disabled {
  background: var(--kn-bg-warm);
  border-style: dashed;
}
.integration-card.disabled .integration-mark { filter: grayscale(0.4); opacity: 0.85; }
.integration-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 12px;
}
.integration-mark {
  width: 40px; height: 40px;
  border-radius: 10px;
  background: var(--kn-bg-warm);
  border: 1px solid var(--kn-border);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 600;
  letter-spacing: -0.02em;
  font-family: var(--kn-font-display);
  flex-shrink: 0;
}
.integration-card h3 {
  font-size: 17px;
  margin: 0;
  font-weight: 500;
}
.integration-card p {
  font-size: 14px;
  color: var(--kn-ink-soft);
  margin: 0;
  line-height: 1.55;
}
.integration-section { margin-bottom: 80px; }
.integration-section:last-child { margin-bottom: 0; }
.integration-group-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--kn-border);
}
.integration-group-head h2 {
  font-size: 28px;
  letter-spacing: -0.02em;
}
.integration-group-head p {
  font-size: 15px;
  color: var(--kn-ink-muted);
  margin: 0;
}

/* Pricing cards */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.pricing-card {
  background: var(--kn-surface);
  border: 1px solid var(--kn-border);
  border-radius: 12px;
  padding: 36px 28px;
  display: flex; flex-direction: column; gap: 20px;
  position: relative;
  transition: border-color var(--kn-duration-base) var(--kn-ease);
}
.pricing-card:hover { border-color: var(--kn-border-strong); }
.pricing-card.featured {
  background: var(--kn-ink);
  color: var(--kn-dark-ink);
  border-color: var(--kn-ink);
}
.pricing-card.featured::before {
  content: 'Most popular';
  position: absolute;
  top: -12px; left: 50%;
  transform: translateX(-50%);
  background: var(--kn-accent);
  color: var(--kn-bg);
  font-family: var(--kn-font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 100px;
  white-space: nowrap;
}
.pricing-card-name {
  font-family: var(--kn-font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--kn-accent);
}
.pricing-card.featured .pricing-card-name { color: var(--kn-accent-light); }
.pricing-card-price {
  display: flex;
  align-items: baseline;
  gap: 4px;
}
.pricing-card-price .currency {
  font-family: var(--kn-font-display);
  font-size: 22px;
  color: var(--kn-ink-muted);
  align-self: flex-start;
  margin-top: 8px;
}
.pricing-card.featured .pricing-card-price .currency { color: var(--kn-dark-ink-muted); }
.pricing-card-price .amount {
  font-family: var(--kn-font-display);
  font-size: clamp(44px, 5vw, 56px);
  font-weight: 500;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--kn-ink);
}
.pricing-card.featured .pricing-card-price .amount { color: var(--kn-dark-ink); }
.pricing-card-price .period {
  font-family: var(--kn-font-mono);
  font-size: 14px;
  color: var(--kn-ink-muted);
  margin-left: 4px;
}
.pricing-card.featured .pricing-card-price .period { color: var(--kn-dark-ink-muted); }
.pricing-card-tagline {
  font-size: 15px;
  color: var(--kn-ink-soft);
  margin: 0;
  line-height: 1.5;
}
.pricing-card.featured .pricing-card-tagline { color: var(--kn-dark-ink-muted); }
.pricing-card-features {
  display: flex; flex-direction: column;
  gap: 12px;
  padding-top: 20px;
  border-top: 1px solid var(--kn-border);
  flex: 1;
}
.pricing-card.featured .pricing-card-features { border-top-color: var(--kn-dark-border); }
.pricing-card-features li {
  display: flex; align-items: flex-start;
  gap: 10px;
  font-size: 14.5px;
  color: var(--kn-ink);
}
.pricing-card.featured .pricing-card-features li { color: var(--kn-dark-ink); }
.pricing-card-features li::before {
  content: '✓';
  color: var(--kn-verified);
  font-weight: 600;
  margin-top: 1px;
}
.pricing-card.featured .pricing-card-features li::before { color: var(--kn-verified-light); }
.pricing-card-features li.muted { color: var(--kn-ink-dim); }
.pricing-card.featured .pricing-card-features li.muted { color: var(--kn-dark-ink-dim); }
.pricing-card-features li.muted::before { content: '-'; color: var(--kn-ink-dim); }
.pricing-card.featured .pricing-card-features li.muted::before { color: var(--kn-dark-ink-dim); }
.pricing-card .kn-btn { width: 100%; justify-content: center; }
.pricing-card.featured .kn-btn-secondary {
  background: var(--kn-dark-ink);
  color: var(--kn-dark-bg);
}

.pricing-enterprise {
  margin-top: 24px;
  padding: 36px;
  background: var(--kn-bg-paper);
  border: 1px solid var(--kn-border);
  border-radius: 12px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 32px;
  align-items: center;
}
.pricing-enterprise h3 {
  font-size: 26px;
  margin-bottom: 8px;
  font-weight: 500;
}
.pricing-enterprise p {
  font-size: 15px;
  color: var(--kn-ink-soft);
  margin: 0;
  max-width: 720px;
}

/* FAQ */
.faq {
  max-width: 760px;
  margin: 0 auto;
  display: flex; flex-direction: column;
}
.faq details {
  border-bottom: 1px solid var(--kn-border);
  padding: 20px 0;
}
.faq details:first-child { border-top: 1px solid var(--kn-border); }
.faq summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  font-family: var(--kn-font-display);
  font-size: 19px;
  font-weight: 500;
  color: var(--kn-ink);
  letter-spacing: -0.01em;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: '+';
  font-size: 22px;
  font-family: var(--kn-font-mono);
  color: var(--kn-ink-muted);
  transition: transform var(--kn-duration-base) var(--kn-ease);
  flex-shrink: 0;
  line-height: 1;
}
.faq details[open] summary::after { content: '-'; }
.faq details > p, .faq details > ul {
  margin-top: 12px;
  font-size: 15px;
  color: var(--kn-ink-soft);
  line-height: 1.6;
}
.faq details > ul {
  padding-left: 20px;
  display: flex; flex-direction: column; gap: 6px;
}
.faq details > ul li { list-style: disc; }

/* Form (waitlist + contact) */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 64px;
  align-items: start;
}
.contact-info-block { margin-bottom: 32px; }
.contact-info-block h3 {
  font-size: 18px;
  margin-bottom: 8px;
  font-weight: 500;
}
.contact-info-block p,
.contact-info-block a {
  color: var(--kn-ink-soft);
  font-size: 15px;
  display: block;
  margin-bottom: 4px;
}
.contact-info-block a:hover { color: var(--kn-accent); }
.contact-form {
  background: var(--kn-surface);
  border: 1px solid var(--kn-border);
  border-radius: 12px;
  padding: 40px;
}
.form-group { margin-bottom: 20px; }
.form-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
}
label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 8px;
  color: var(--kn-ink);
  font-family: var(--kn-font-mono);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
input, textarea, select {
  width: 100%;
  padding: 12px 14px;
  background: var(--kn-bg);
  border: 1px solid var(--kn-border-strong);
  border-radius: var(--kn-radius-sm);
  color: var(--kn-ink);
  font-family: var(--kn-font-sans);
  font-size: 15px;
  transition: all var(--kn-duration-base) var(--kn-ease);
}
input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: var(--kn-accent);
  box-shadow: 0 0 0 3px rgba(95, 127, 88, 0.12);
}
textarea { resize: vertical; min-height: 120px; }
.form-submit {
  width: 100%;
  padding: 14px;
  font-size: 15px;
  font-weight: 500;
  background: var(--kn-ink);
  color: var(--kn-bg);
  border-radius: var(--kn-radius-sm);
  border: 0;
  cursor: pointer;
  transition: all var(--kn-duration-base) var(--kn-ease);
}
.form-submit:hover {
  background: var(--kn-accent);
  transform: translateY(-1px);
}
.form-submit:disabled,
.form-submit[disabled] {
  cursor: default;
  opacity: 0.85;
  transform: none;
}

.form-status {
  margin: 12px 0 0;
  min-height: 1.4em;
  font-size: 13px;
  font-family: var(--kn-font-mono);
  text-align: center;
  color: var(--kn-ink-muted);
}
.form-status.is-error { color: var(--kn-warn); }
.form-status.is-success { color: var(--kn-verified); }

.hp-field {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* ============================================================
   LEGAL PAGES
   ============================================================ */
.legal {
  max-width: 780px;
  margin: 0 auto;
  padding: 0 24px 100px;
}
.legal-meta {
  display: flex; flex-wrap: wrap;
  gap: 8px 24px;
  font-size: 13px;
  color: var(--kn-ink-muted);
  padding-bottom: 32px;
  margin-bottom: 40px;
  border-bottom: 1px solid var(--kn-border);
  font-family: var(--kn-font-mono);
}
.legal-meta strong { color: var(--kn-ink); font-weight: 500; }
.legal-toc {
  background: var(--kn-bg-paper);
  border: 1px solid var(--kn-border);
  border-radius: var(--kn-radius-md);
  padding: 24px 28px;
  margin-bottom: 48px;
}
.legal-toc h2 {
  font-family: var(--kn-font-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--kn-ink-muted);
  margin-bottom: 14px;
}
.legal-toc ol {
  list-style: decimal;
  padding-left: 24px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px 24px;
  font-size: 14px;
}
.legal-toc a { color: var(--kn-ink-soft); }
.legal-toc a:hover { color: var(--kn-accent); }
.legal section {
  padding: 0;
  margin-bottom: 40px;
  max-width: none;
  scroll-margin-top: 100px;
}
.legal h2 {
  font-size: 28px;
  letter-spacing: -0.02em;
  margin-bottom: 16px;
}
.legal h3 {
  font-size: 18px;
  font-weight: 500;
  margin-top: 24px;
  margin-bottom: 10px;
}
.legal p, .legal li {
  font-size: 16px;
  line-height: 1.65;
  color: var(--kn-ink-soft);
}
.legal p { margin-bottom: 14px; }
.legal strong { color: var(--kn-ink); font-weight: 500; }
.legal ul, .legal ol { padding-left: 24px; margin-bottom: 16px; }
.legal ul li { list-style: disc; margin-bottom: 6px; }
.legal ol li { list-style: decimal; margin-bottom: 6px; }
.legal a { color: var(--kn-accent); text-decoration: underline; text-underline-offset: 2px; }
.legal table {
  width: 100%;
  border-collapse: collapse;
  margin: 16px 0;
  font-size: 14px;
}
.legal th, .legal td {
  padding: 12px 14px;
  border: 1px solid var(--kn-border);
  text-align: left;
  vertical-align: top;
}
.legal th {
  background: var(--kn-bg-paper);
  font-weight: 500;
  font-family: var(--kn-font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.legal td { color: var(--kn-ink-soft); }
.legal-annex {
  margin-top: 56px;
  padding-top: 32px;
  border-top: 1px solid var(--kn-border);
}
.legal-annex h2 {
  font-family: var(--kn-font-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--kn-accent);
  margin-bottom: 8px;
}
.legal-annex h3 {
  font-family: var(--kn-font-display);
  font-size: 26px;
  margin-bottom: 24px;
  font-weight: 500;
}
.legal-back-to-top {
  display: inline-block;
  margin-top: 24px;
  font-family: var(--kn-font-mono);
  font-size: 12px;
  color: var(--kn-ink-muted);
}
.legal-back-to-top:hover { color: var(--kn-accent); }

/* ============================================================
   CONTENT TABLE (security, compliance pages)
   ============================================================ */
.content-table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
  font-size: 14.5px;
}
.content-table th,
.content-table td {
  padding: 16px 18px;
  border: 1px solid var(--kn-border);
  text-align: left;
  vertical-align: top;
}
.content-table th {
  background: var(--kn-bg-paper);
  font-family: var(--kn-font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--kn-ink);
}
.content-table td {
  color: var(--kn-ink-soft);
  line-height: 1.55;
}
.content-table td strong { color: var(--kn-ink); }
.content-table code,
.content-table .mono {
  font-family: var(--kn-font-mono);
  font-size: 12.5px;
  color: var(--kn-accent-deep);
}

.content-narrow {
  max-width: 880px;
  margin: 0 auto;
}
.content-narrow h2 {
  font-size: clamp(28px, 3.4vw, 42px);
  margin-bottom: 16px;
  /* Clear the sticky-blurred site-nav when arriving via an in-page anchor. */
  scroll-margin-top: 100px;
}
.content-narrow h3 {
  font-size: 22px;
  font-weight: 500;
  margin-top: 32px;
  margin-bottom: 12px;
}
.content-narrow p {
  font-size: 16.5px;
  line-height: 1.65;
  color: var(--kn-ink-soft);
  margin-bottom: 14px;
}
.content-narrow p strong { color: var(--kn-ink); }
.content-narrow ul,
.content-narrow ol {
  padding-left: 24px;
  margin-bottom: 16px;
}
.content-narrow ul li { list-style: disc; margin-bottom: 6px; }
.content-narrow ol li { list-style: decimal; margin-bottom: 6px; }
.content-narrow li {
  font-size: 16px;
  color: var(--kn-ink-soft);
  line-height: 1.6;
}
.content-narrow a {
  color: var(--kn-accent);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.content-narrow pre {
  background: var(--kn-dark-elev);
  color: var(--kn-dark-ink);
  padding: 20px 22px;
  border-radius: var(--kn-radius-md);
  overflow-x: auto;
  margin: 16px 0;
  font-family: var(--kn-font-mono);
  font-size: 13px;
  line-height: 1.6;
}
.content-narrow code {
  font-family: var(--kn-font-mono);
  font-size: 13.5px;
  color: var(--kn-accent-deep);
  background: var(--kn-bg-paper);
  padding: 1px 6px;
  border-radius: 4px;
}
.content-narrow pre code { background: transparent; color: inherit; padding: 0; font-size: inherit; }
.content-narrow hr {
  border: 0;
  border-top: 1px solid var(--kn-border);
  margin: 56px 0;
}

.roadmap-list {
  list-style: decimal inside;
  font-family: var(--kn-font-display);
  font-size: 18px;
  color: var(--kn-ink-soft);
  line-height: 2;
  margin: 24px 0 32px;
  padding: 0;
  max-width: 480px;
}
.roadmap-list strong { font-weight: 500; color: var(--kn-ink); }
.roadmap-list li { padding-left: 4px; }

/* Focus state */
:focus-visible {
  outline: 2px solid var(--kn-accent);
  outline-offset: 2px;
  border-radius: 4px;
}

::selection {
  background: var(--kn-accent);
  color: var(--kn-bg);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px) {
  section { padding: 80px 24px; }
  .nav-inner { padding: 14px 20px; }
  .nav-links { display: none; }
  .nav-status { display: none; }
  .nav-toggle { display: inline-flex; }
  /* Logo mark + wordmark were sized for desktop; on mobile they
     compete with the nav CTA for header width. Trim both so the
     "Apply for the cohort" button has room to render without
     overlapping the logo. */
  .logo { font-size: 18px; gap: 10px; }
  .logo-mark { width: 40px; height: 40px; }
  /* Shrink the nav CTA on narrow viewports - tighter padding +
     smaller text - so it stays one line and inside the row. */
  .nav-right .kn-btn-primary {
    padding: 8px 14px;
    font-size: 13px;
    letter-spacing: 0;
  }
  .nav-right { gap: 12px; }
  .nav-links.open {
    display: flex;
    position: absolute;
    top: 100%;
    left: 0; right: 0;
    flex-direction: column;
    background: var(--kn-bg);
    border-top: 1px solid var(--kn-border);
    border-bottom: 1px solid var(--kn-border);
    padding: 16px 24px;
    gap: 0;
  }
  .kn-dark .nav-links.open {
    background: var(--kn-dark-bg);
    border-color: var(--kn-dark-border);
  }
  .nav-links.open li { width: 100%; }
  .nav-links.open a {
    display: block;
    padding: 14px 0;
    font-size: 15px;
    border-bottom: 1px solid var(--kn-border);
  }
  .kn-dark .nav-links.open a { border-color: var(--kn-dark-border); }
  .nav-links.open li:last-child a { border-bottom: 0; }

  .hero { padding: 64px 24px 80px; }
  .compare, .verifier, .chain-grid, .contact-grid, .auditor-channel-grid {
    grid-template-columns: 1fr; gap: 32px;
  }
  /* Auditor-channel stat block reduces padding on mobile so the $0 figure
     stays prominent without dominating the column. */
  .auditor-channel-stat { padding: 40px 28px; }
  .frameworks, .pricing-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-inner { grid-template-columns: 1fr 1fr; gap: 40px; }
  .logos-row { gap: 24px; justify-content: center; }
  .logo-item { font-size: 16px; }
  .final-cta { padding: 80px 24px; }
  .architecture-grid { grid-template-columns: 1fr; gap: 20px; }
  .arch-arrow { transform: rotate(90deg); padding: 8px 0; }
  .trust-flow-grid { grid-template-columns: 1fr; gap: 10px; }
  .trust-flow-arrow { transform: rotate(90deg); min-height: 24px; }

  /* Tables - make horizontally scrollable rather than overflowing the viewport */
  .content-table { display: block; overflow-x: auto; max-width: 100%; -webkit-overflow-scrolling: touch; }
  .content-narrow pre { font-size: 12px; padding: 16px; }
  .content-narrow h2 { font-size: 26px; }
  .content-narrow h3 { font-size: 19px; }

  /* Hero anchors - already flex-wrap, but tighten on mobile.
     12px (--kn-text-xs) keeps the anchors scannable for the CISO
     demographic that buys this product; 11px was below comfort. */
  .hero-anchors { gap: 6px 18px; font-size: var(--kn-text-xs); margin-bottom: 48px; }
  .hero-cta { margin-bottom: 28px; }
  .hero { padding: 56px 24px 72px; }

  /* Page hero on legal/about pages - tighter padding on mobile */
  .page-hero { padding: 80px 24px 56px; }
  .pricing-enterprise { grid-template-columns: 1fr; gap: 20px; padding: 28px; }
  .legal-toc ol { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .contact-form { padding: 28px; }
}

@media (max-width: 560px) {
  .hero-cta, .final-cta-buttons {
    flex-direction: column; align-items: stretch;
  }
  .hero-cta .kn-btn, .final-cta-buttons .kn-btn { justify-content: center; }
  .footer-inner { grid-template-columns: 1fr; }
  .frameworks, .pricing-grid { grid-template-columns: 1fr; }
  /* On the smallest screens the nav CTA still wraps; shorten the
     visible text to "Apply" via CSS so the button stays inside the
     row without an HTML change. */
  .nav-right .kn-btn-primary {
    font-size: 0;
    padding: 8px 12px;
  }
  .nav-right .kn-btn-primary::after {
    content: "Apply";
    font-size: 13px;
  }
  .logo-mark { width: 36px; height: 36px; }
}

/* ============================================================
   NAV SEARCH
   ============================================================ */
.hero-direct {
  margin-top: 14px;
  font-family: var(--kn-font-mono);
  font-size: 14px;
  color: var(--kn-dark-ink-muted);
}
.hero-direct a { color: var(--kn-dark-ink); border-bottom: 1px solid var(--kn-dark-border); }
.hero-direct a:hover { color: var(--kn-accent-light); border-color: var(--kn-accent-light); }

.nav-search {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  color: var(--kn-ink-soft);
  background: transparent;
  border: 1px solid var(--kn-border);
  border-radius: 8px;
  margin-right: 10px;
  transition: background var(--kn-duration-fast) var(--kn-ease),
              color var(--kn-duration-fast) var(--kn-ease);
}
.nav-search:hover { color: var(--kn-accent); background: rgba(0,0,0,0.03); }
.kn-dark .nav-search {
  color: var(--kn-dark-ink-muted);
  border-color: var(--kn-dark-border);
}
.kn-dark .nav-search:hover { color: var(--kn-accent-light); background: rgba(255,255,255,0.04); }

.search-panel {
  position: absolute;
  top: 100%;
  left: 0; right: 0;
  z-index: 50;
  margin: 0 auto;
  max-width: 720px;
  background: var(--kn-bg-paper);
  border: 1px solid var(--kn-border);
  border-radius: 12px;
  box-shadow: 0 12px 32px -8px rgba(70, 50, 30, 0.20);
  padding: 16px;
  margin-top: 8px;
}
.kn-dark .search-panel {
  background: var(--kn-dark-elev);
  border-color: var(--kn-dark-border);
  color: var(--kn-dark-ink);
}
.search-input {
  width: 100%;
  font-family: var(--kn-font-body);
  font-size: 16px;
  padding: 12px 14px;
  border: 1px solid var(--kn-border);
  border-radius: 8px;
  background: var(--kn-surface);
  color: var(--kn-ink);
  outline: none;
}
.search-input:focus { border-color: var(--kn-accent); }
.kn-dark .search-input {
  background: var(--kn-dark-surface);
  border-color: var(--kn-dark-border);
  color: var(--kn-dark-ink);
}
.search-results {
  list-style: none;
  margin: 12px 0 0;
  padding: 0;
  max-height: 60vh;
  overflow-y: auto;
}
.search-results li {
  padding: 12px 14px;
  border-radius: 8px;
  cursor: pointer;
  border-bottom: 1px solid var(--kn-border);
}
.kn-dark .search-results li { border-bottom-color: var(--kn-dark-border); }
.search-results li:last-child { border-bottom: none; }
.search-results li:hover,
.search-results li.is-active {
  background: var(--kn-bg-warm);
}
.kn-dark .search-results li:hover,
.kn-dark .search-results li.is-active {
  background: var(--kn-dark-surface);
}
.search-results .sr-title {
  font-family: var(--kn-font-display);
  font-size: 18px;
  font-weight: 500;
  color: var(--kn-ink);
  display: block;
  margin-bottom: 2px;
}
.kn-dark .search-results .sr-title { color: var(--kn-dark-ink); }
.search-results .sr-summary {
  font-size: 14px;
  color: var(--kn-ink-muted);
  display: block;
  line-height: 1.4;
  margin-bottom: 4px;
}
.kn-dark .search-results .sr-summary { color: var(--kn-dark-ink-muted); }
.search-results .sr-url {
  font-family: var(--kn-font-mono);
  font-size: 12px;
  color: var(--kn-ink-dim);
}
.kn-dark .search-results .sr-url { color: var(--kn-dark-ink-dim); }
.search-results .sr-empty {
  padding: 24px 14px;
  text-align: center;
  color: var(--kn-ink-muted);
  font-style: italic;
}

@media (max-width: 700px) {
  .nav-search { margin-right: 8px; width: 32px; height: 32px; }
  .search-panel { padding: 12px; }
  .search-input { font-size: 14px; padding: 10px 12px; }
}

/* ============================================================
   CAPABILITIES PAGE
   ============================================================ */
.capability-meta {
  margin-top: 12px;
  font-family: var(--kn-font-mono);
  font-size: 14px;
  color: var(--kn-ink-muted);
  line-height: 1.6;
}
.capability-meta strong { color: var(--kn-ink-soft); font-weight: 500; }
.capability-meta a { color: var(--kn-accent); border-bottom: 1px dotted var(--kn-accent); }
.capability-meta a:hover { color: var(--kn-accent-deep); border-bottom-color: var(--kn-accent-deep); }

.capabilities-phase2 {
  background: var(--kn-bg-warm);
  border-top: 1px solid var(--kn-border);
  border-bottom: 1px solid var(--kn-border);
}
.phase2-list {
  list-style: none;
  padding: 0;
  margin: 32px 0 24px;
  display: grid;
  gap: 28px;
}
.phase2-list li {
  padding: 24px 28px;
  background: var(--kn-bg-paper);
  border: 1px solid var(--kn-border);
  border-radius: 12px;
  line-height: 1.6;
  color: var(--kn-ink-soft);
}
.phase2-list strong {
  display: block;
  font-family: var(--kn-font-display);
  font-size: 22px;
  font-weight: 500;
  color: var(--kn-ink);
  margin-bottom: 8px;
}
.phase2-foot {
  margin-top: 16px;
  font-size: 15px;
  color: var(--kn-ink-muted);
  font-style: italic;
}

/* Pricing upsell-trigger line under each tier card */
.pricing-card-trigger {
  margin-top: 20px;
  padding: 12px 16px;
  background: var(--kn-bg-warm);
  border-left: 2px solid var(--kn-accent);
  font-size: 14px;
  font-style: italic;
  line-height: 1.5;
  color: var(--kn-ink-muted);
}
.pricing-card-trigger strong { color: var(--kn-ink-soft); font-style: normal; font-weight: 500; }

/* Integrations: source-destination pair matrix */
.pair-matrix {
  list-style: none;
  padding: 0;
  margin: 24px 0;
  display: grid;
  gap: 14px;
}
.pair-matrix li {
  padding: 14px 18px;
  background: var(--kn-bg-paper);
  border: 1px solid var(--kn-border);
  border-radius: 8px;
  font-size: 16px;
  line-height: 1.55;
  color: var(--kn-ink-soft);
}
.pair-matrix strong {
  color: var(--kn-ink);
  font-weight: 500;
  margin-right: 6px;
}
.callout-note {
  margin: 24px 0;
  padding: 14px 18px;
  background: var(--kn-bg-warm);
  border-left: 2px solid var(--kn-accent);
  font-size: 15px;
  font-style: italic;
  color: var(--kn-ink-muted);
  line-height: 1.55;
}

/* Integrations: source-destination pair matrix */
.pair-matrix {
  list-style: none;
  padding: 0;
  margin: 24px 0;
  display: grid;
  gap: 14px;
}
.pair-matrix li {
  padding: 14px 18px;
  background: var(--kn-bg-paper);
  border: 1px solid var(--kn-border);
  border-radius: 8px;
  font-size: 16px;
  line-height: 1.55;
  color: var(--kn-ink-soft);
}
.pair-matrix strong {
  color: var(--kn-ink);
  font-weight: 500;
  margin-right: 6px;
}
.callout-note {
  margin: 24px 0;
  padding: 14px 18px;
  background: var(--kn-bg-warm);
  border-left: 2px solid var(--kn-accent);
  font-size: 15px;
  font-style: italic;
  color: var(--kn-ink-muted);
  line-height: 1.55;
}
