/* Logbook.co.uk — "The Authority" (direction B), ported to Ghost.
   Archivo (heavy) + Spline Sans Mono, near-black ink + gold accent.
   Fonts self-hosted from assets/fonts (variable woff2, latin + latin-ext). */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400 900;
  font-display: swap;
  src: url('../fonts/archivo-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;
}
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400 900;
  font-display: swap;
  src: url('../fonts/archivo-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;
}
@font-face {
  font-family: 'Spline Sans Mono';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url('../fonts/spline-sans-mono-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;
}
@font-face {
  font-family: 'Spline Sans Mono';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url('../fonts/spline-sans-mono-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;
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
img { max-width: 100%; height: auto; }
body { background: #f4f4f0; }

.auth { --ink:#15161a; --ink2:#1d1f24; --paper:#f4f4f0; --card:#fcfcfa; --soft:#70726c; --softd:#9b9da4; --rule:#dddcd4; --ruled:#33353c; --acc:#f2c40f;
  font-family: "Archivo", system-ui, sans-serif; color: #1a1b1f; background: var(--paper); min-height: 100vh; display: flex; flex-direction: column; -webkit-font-smoothing: antialiased; }
.auth a { color: inherit; text-decoration: none; }
.auth .wrap { max-width: 1296px; margin: 0 auto; padding: 0 48px; width: 100%; }
.auth .wrap-narrow { max-width: 880px; margin: 0 auto; padding: 0 48px; width: 100%; }
.auth .mono { font-family: "Spline Sans Mono", monospace; }
.auth .grow { flex: 1; }
::selection { background: #f2c40f; color: #15161a; }

/* ticker / marquee */
.dx-marquee { overflow: hidden; width: 100%; }
.dx-mq-track { display: flex; width: max-content; animation: dx-mq-scroll 42s linear infinite; }
.dx-mq-half { display: flex; align-items: center; flex: none; }
.dx-mq-item { display: inline-flex; align-items: center; white-space: nowrap; }
.dx-mq-sep { margin: 0 18px; }
@keyframes dx-mq-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.auth .ticker { background: var(--ink); color: var(--acc); border-bottom: 1px solid var(--ruled); }
.auth .ticker .dx-mq-item { font-family: "Spline Sans Mono", monospace; font-size: 12px; letter-spacing: .06em; padding: 10px 0; text-transform: uppercase; }
.auth .ticker .dx-mq-sep { color: var(--acc); opacity: .9; }

/* masthead */
.auth .mast { background: var(--ink); color: #f1f1ec; position: sticky; top: 0; z-index: 60; }
.auth .mast-in { display: flex; align-items: center; justify-content: space-between; height: 80px; gap: 28px; border-bottom: 1px solid var(--ruled); }
.auth .wm { font-weight: 900; font-size: 26px; letter-spacing: -.02em; text-transform: uppercase; display: flex; align-items: center; gap: 10px; white-space: nowrap; }
.auth .wm-chip { background: var(--acc); color: var(--ink); font-size: 11px; letter-spacing: .1em; padding: 4px 7px; font-family: "Spline Sans Mono", monospace; font-weight: 700; }
.auth .nav { display: flex; gap: 2px; flex-wrap: wrap; justify-content: flex-end; }
.auth .nav a { font-size: 12.5px; font-weight: 600; letter-spacing: .07em; text-transform: uppercase; color: var(--softd); padding: 8px 11px; transition: color .15s; white-space: nowrap; }
.auth .nav a:hover { color: var(--acc); }
.auth .nav a.is-on { color: var(--acc); box-shadow: inset 0 -2px 0 var(--acc); }

/* dark page headers */
.auth .phead { background: var(--ink); color: #f1f1ec; overflow: hidden; }
.auth .kicker { font-family: "Spline Sans Mono", monospace; font-size: 12.5px; letter-spacing: .22em; color: var(--acc); text-transform: uppercase; display: flex; align-items: center; gap: 14px; white-space: nowrap; }
.auth .kicker::before { content: ""; width: 12px; height: 12px; background: var(--acc); flex: none; animation: auth-blink 1.6s steps(2, jump-none) infinite; }
@keyframes auth-blink { 50% { opacity: .25; } }
.auth .crumb { font-family: "Spline Sans Mono", monospace; font-size: 12px; letter-spacing: .06em; text-transform: uppercase; color: var(--softd); display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.auth .crumb a:hover { color: var(--acc); }
.auth .crumb .sep { opacity: .5; }
.auth .h1-line { display: block; }
.auth .h1-hl { color: var(--ink); background: var(--acc); padding: 0 18px 8px; display: inline-block; }

/* hazard divider */
.auth .hazard { height: 18px; background: repeating-linear-gradient(-45deg, var(--acc) 0 22px, var(--ink) 22px 44px); background-size: 62.2px 100%; animation: auth-hz 1.4s linear infinite; }
@keyframes auth-hz { from { background-position: 0 0; } to { background-position: 62.2px 0; } }
.auth.no-motion .hazard, .auth.no-motion .kicker::before, .auth.no-motion .dx-mq-track { animation: none !important; }
@media (prefers-reduced-motion: reduce) { .dx-mq-track, .auth .hazard, .auth .kicker::before { animation: none !important; } }

/* section heads */
.auth .sec { padding: 72px 0 0; }
.auth .sec-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 30px; gap: 16px; flex-wrap: wrap; }
.auth .sec-l { display: flex; align-items: center; gap: 16px; }
.auth .sec-idx { font-family: "Spline Sans Mono", monospace; font-size: 12px; font-weight: 700; background: #1a1b1f; color: var(--acc); padding: 5px 9px; }
.auth .sec-title { font-weight: 900; font-size: 36px; letter-spacing: -.02em; text-transform: uppercase; margin: 0; }
.auth .sec-act { font-family: "Spline Sans Mono", monospace; font-size: 12.5px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--soft); border-bottom: 2px solid var(--acc); padding-bottom: 2px; }
.auth .sec-act:hover { color: #1a1b1f; }

/* chips + meta */
.auth .tag { font-family: "Spline Sans Mono", monospace; font-size: 10.5px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; background: #1a1b1f; color: var(--acc); padding: 4px 8px; white-space: nowrap; }
.auth .tag-line { font-family: "Spline Sans Mono", monospace; font-size: 10.5px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; border: 1.5px solid #1a1b1f; color: #1a1b1f; padding: 3px 8px; white-space: nowrap; }
.auth .meta { font-family: "Spline Sans Mono", monospace; font-size: 12px; color: var(--soft); white-space: nowrap; }
.auth .meta-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }

/* placeholders */
.auth .dx-ph { position: relative; overflow: hidden; background-color: #eceae2; border: 1.5px solid #1a1b1f; background-image: repeating-linear-gradient(45deg, rgba(0,0,0,.045) 0 10px, transparent 10px 20px); }
.auth .dx-ph-tag { position: absolute; left: 12px; bottom: 11px; font-family: "Spline Sans Mono", monospace; font-size: 11px; color: var(--soft); background: var(--card); border: 1px solid var(--rule); padding: 3px 8px; }
.auth .img-frame { border: 1.5px solid #1a1b1f; display: block; width: 100%; }

/* ledger */
.auth .ledger { border: 2.5px solid #1a1b1f; background: var(--card); }
.auth .lhead, .auth .lrow { display: grid; grid-template-columns: 64px 1fr 200px 130px 70px; align-items: center; gap: 18px; padding: 0 24px; }
.auth .lhead { height: 46px; background: #1a1b1f; color: var(--softd); font-family: "Spline Sans Mono", monospace; font-size: 10.5px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; }
.auth .lrow { min-height: 66px; border-bottom: 1.5px solid var(--rule); transition: background .12s; padding-top: 12px; padding-bottom: 12px; }
.auth .lrow:last-child { border-bottom: none; }
.auth .lrow:hover { background: #faf6e3; box-shadow: inset 5px 0 0 var(--acc); }
.auth .r-n { font-family: "Spline Sans Mono", monospace; font-size: 13px; font-weight: 700; }
.auth .r-t { font-weight: 700; font-size: 17px; line-height: 1.25; letter-spacing: -.01em; }
.auth .r-dek { font-weight: 400; font-size: 13.5px; line-height: 1.45; color: var(--soft); margin-top: 5px; }
.auth .r-d, .auth .r-r { font-family: "Spline Sans Mono", monospace; font-size: 12px; color: var(--soft); }

/* subscribe band */
.auth .subband { background: var(--ink); color: #f1f1ec; margin-top: 84px; }
.auth .subband-in { display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center; padding: 56px 48px; max-width: 1296px; margin: 0 auto; }
.auth .subband h3 { font-weight: 900; font-size: 44px; text-transform: uppercase; letter-spacing: -.02em; margin: 0; line-height: 1; }
.auth .subband h3 em { font-style: normal; color: var(--acc); }
.auth .subband p { color: var(--softd); font-size: 15px; margin: 12px 0 0; }
.auth .sub { display: flex; gap: 0; }
.auth .sub input { width: 320px; max-width: 100%; font: 15px/1 "Archivo", sans-serif; padding: 17px 18px; border: 2px solid var(--acc); background: var(--ink2); color: #f1f1ec; outline: none; }
.auth .sub input::placeholder { color: var(--softd); }
.auth .sub button { font: 800 14px/1 "Archivo", sans-serif; letter-spacing: .08em; text-transform: uppercase; padding: 17px 28px; background: var(--acc); color: var(--ink); border: 2px solid var(--acc); cursor: pointer; transition: filter .15s; white-space: nowrap; }
.auth .sub button:hover { filter: brightness(1.08); }
.auth .sub-msg { font-family: "Spline Sans Mono", monospace; font-size: 12px; color: var(--acc); margin-top: 10px; min-height: 14px; }

/* footer */
.auth .foot { background: var(--ink); color: var(--softd); border-top: 1px solid var(--ruled); }
.auth .foot-in { display: grid; grid-template-columns: 1.3fr 1fr 1fr 1fr; gap: 48px; padding: 56px 48px; max-width: 1296px; margin: 0 auto; }
.auth .foot h4 { font-family: "Spline Sans Mono", monospace; font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--acc); margin: 0 0 16px; }
.auth .foot a { display: block; font-size: 13.5px; font-weight: 500; padding: 5px 0; }
.auth .foot a:hover { color: #fff; }
.auth .foot-wm { font-weight: 900; font-size: 24px; text-transform: uppercase; color: #fff; letter-spacing: -.01em; }
.auth .foot-tag { font-size: 14px; line-height: 1.6; margin-top: 14px; max-width: 300px; }
.auth .foot-base { border-top: 1px solid var(--ruled); }
.auth .foot-base-in { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding: 18px 48px; max-width: 1296px; margin: 0 auto; font-family: "Spline Sans Mono", monospace; font-size: 11px; letter-spacing: .08em; }

/* ===== HOME ===== */
.auth .hero { background: var(--ink); color: #f1f1ec; overflow: hidden; }
.auth .hero-in { padding: 84px 48px 0; max-width: 1296px; margin: 0 auto; }
.auth .hero-h1 { font-weight: 900; font-size: clamp(56px, 9vw, 128px); line-height: .92; letter-spacing: -.03em; text-transform: uppercase; margin: 30px 0 0; }
.auth .hero-foot { display: grid; grid-template-columns: 1.2fr 1fr; gap: 64px; align-items: end; padding: 44px 0 64px; }
.auth .hero-deck { font-size: 19px; line-height: 1.6; color: var(--softd); max-width: 560px; margin: 0; }
.auth .stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border: 1px solid var(--ruled); }
.auth .stat { padding: 20px 22px 18px; border-right: 1px solid var(--ruled); }
.auth .stat:last-child { border-right: none; }
.auth .stat-n { font-weight: 900; font-size: 52px; line-height: 1; color: var(--acc); letter-spacing: -.02em; font-variant-numeric: tabular-nums; }
.auth .stat-l { font-family: "Spline Sans Mono", monospace; font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--softd); margin-top: 10px; }
.auth .lead-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 0; border: 2.5px solid #1a1b1f; background: var(--card); }
.auth .lead-main { padding: 28px; border-right: 2.5px solid #1a1b1f; }
.auth .lead-title { font-weight: 800; font-size: 40px; line-height: 1.02; letter-spacing: -.02em; margin: 0; }
.auth .lead-title a:hover { text-decoration: underline; text-decoration-color: var(--acc); text-decoration-thickness: 4px; text-underline-offset: 5px; }
.auth .lead-dek { font-size: 16px; line-height: 1.6; color: var(--soft); margin: 16px 0 0; }
.auth .lead-meta { margin: 22px 0 14px; }
.auth .feat { display: block; padding: 24px 28px; border-bottom: 1.5px solid var(--rule); transition: background .15s; }
.auth .feat:last-child { border-bottom: none; }
.auth .feat:hover { background: #faf6e3; }
.auth .feat-meta { display: flex; gap: 12px; align-items: center; margin-bottom: 12px; }
.auth .feat-title { font-weight: 800; font-size: 21px; line-height: 1.14; letter-spacing: -.01em; margin: 0; }
.auth .feat-dek { font-size: 14px; line-height: 1.55; color: var(--soft); margin: 9px 0 0; }
.auth .cat-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
.auth .cat { border: 2px solid #1a1b1f; background: var(--card); padding: 18px 18px 16px; min-height: 160px; display: flex; flex-direction: column; transition: transform .15s, box-shadow .15s, background .15s; position: relative; }
.auth .cat:hover { background: var(--acc); transform: translate(-3px, -3px); box-shadow: 5px 5px 0 #1a1b1f; }
.auth .cat-top { display: flex; justify-content: space-between; align-items: center; }
.auth .cat-code { font-family: "Spline Sans Mono", monospace; font-size: 11.5px; font-weight: 700; letter-spacing: .08em; background: #1a1b1f; color: var(--acc); padding: 3px 7px; }
.auth .cat-count { font-family: "Spline Sans Mono", monospace; font-size: 10.5px; color: var(--soft); }
.auth .cat:hover .cat-count { color: #3c3a14; }
.auth .cat-name { font-weight: 800; font-size: 19px; letter-spacing: -.01em; margin-top: 20px; line-height: 1.05; text-transform: uppercase; }
.auth .cat-note { font-size: 12.5px; color: var(--soft); margin-top: 7px; line-height: 1.4; }
.auth .cat:hover .cat-note { color: #3c3a14; }
.auth .cat-arrow { margin-top: auto; padding-top: 10px; font-weight: 800; }

/* ===== ARTICLE ===== */
.auth .art-head { padding-top: 36px; padding-bottom: 56px; }
.auth .art-head .crumb { margin-bottom: 34px; }
.auth .art-h1 { font-weight: 900; font-size: clamp(40px, 5.5vw, 58px); line-height: 1.0; letter-spacing: -.025em; text-transform: uppercase; margin: 22px 0 0; max-width: 1080px; }
.auth .art-stand { font-size: 20px; line-height: 1.6; color: var(--softd); max-width: 760px; margin: 26px 0 0; }
.auth .art-byline { display: flex; align-items: center; gap: 16px; margin-top: 36px; font-family: "Spline Sans Mono", monospace; font-size: 12px; letter-spacing: .06em; text-transform: uppercase; color: var(--softd); flex-wrap: wrap; }
.auth .art-byline .who { color: #f1f1ec; }
.auth .art-byline .pill { width: 36px; height: 36px; background: var(--acc); color: var(--ink); display: inline-flex; align-items: center; justify-content: center; font-weight: 900; font-family: "Archivo", sans-serif; font-size: 13px; }
.auth .art-byline .bsep { opacity: .4; }
.auth .art-layout { display: grid; grid-template-columns: 1fr 300px; gap: 64px; max-width: 1180px; margin: 0 auto; padding: 56px 48px 0; align-items: start; }
.auth .art-figure { margin: 0 0 36px; }
.auth .art-body { font-size: 17.5px; line-height: 1.72; }
.auth .art-body p { margin: 0 0 24px; }
.auth .art-body h2 { font-weight: 900; font-size: 28px; line-height: 1.1; letter-spacing: -.015em; text-transform: uppercase; margin: 44px 0 18px; display: flex; align-items: center; gap: 14px; }
.auth .art-body h2::before { content: ""; width: 14px; height: 14px; background: var(--acc); flex: none; }
.auth .art-body h3 { font-weight: 800; font-size: 21px; text-transform: uppercase; letter-spacing: -.01em; margin: 32px 0 12px; }
.auth .art-body a { color: #1a1b1f; box-shadow: inset 0 -2px 0 var(--acc); }
.auth .art-body ul, .auth .art-body ol { margin: 0 0 24px; padding: 0; list-style: none; }
.auth .art-body ul li { position: relative; padding-left: 28px; margin-bottom: 12px; line-height: 1.6; }
.auth .art-body ul li::before { content: "→"; position: absolute; left: 0; font-weight: 800; }
.auth .art-body ol { counter-reset: li; }
.auth .art-body ol li { position: relative; padding-left: 32px; margin-bottom: 12px; line-height: 1.6; counter-increment: li; }
.auth .art-body ol li::before { content: counter(li); position: absolute; left: 0; font-family: "Spline Sans Mono", monospace; font-weight: 700; color: var(--soft); }
.auth .art-body blockquote, .auth .callout { background: var(--acc); color: var(--ink); padding: 26px 30px; margin: 8px 0 30px; font-weight: 700; font-size: 19px; line-height: 1.5; letter-spacing: -.01em; box-shadow: 6px 6px 0 #1a1b1f; }
.auth .art-body blockquote p { margin: 0; }
.auth .records-box { border: 2.5px solid #1a1b1f; background: var(--card); padding: 26px 28px; margin: 8px 0 32px; }
.auth .records-box h3 { font-family: "Spline Sans Mono", monospace; font-size: 12px; letter-spacing: .14em; text-transform: uppercase; margin: 0 0 16px; display: flex; align-items: center; gap: 10px; }
.auth .records-box h3::before { content: ""; width: 10px; height: 10px; background: var(--acc); }
.auth .records-box ul { list-style: none; margin: 0; padding: 0; }
.auth .records-box li { display: flex; gap: 14px; align-items: flex-start; padding: 12px 0; border-top: 1.5px dashed var(--rule); font-size: 15.5px; line-height: 1.5; padding-left: 0; }
.auth .records-box li::before { display: none; }
.auth .records-box li:first-child { border-top: none; padding-top: 0; }
.auth .records-box .chk { flex: none; width: 20px; height: 20px; border: 2px solid #1a1b1f; display: inline-flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 800; margin-top: 2px; background: var(--acc); }
/* records-box overrides so the checklist renders correctly inside .art-body */
.auth .art-body .records-box ul { padding-left: 0; }
.auth .art-body .records-box li { padding-left: 0; margin-bottom: 0; }
.auth .art-body .records-box li::before { display: none; }
/* in-body primary-sources block (reusable snippet) */
.auth .post-sources { border: 2.5px solid #1a1b1f; background: var(--card); padding: 24px 26px; margin: 8px 0 32px; }
.auth .post-sources h3 { font-family: "Spline Sans Mono", monospace; font-size: 12px; letter-spacing: .14em; text-transform: uppercase; margin: 0 0 6px; display: flex; align-items: center; gap: 10px; }
.auth .post-sources h3::before { content: ""; width: 10px; height: 10px; background: var(--acc); flex: none; }
.auth .post-sources a { display: flex; gap: 14px; align-items: baseline; padding: 12px 0; border-top: 1.5px dashed var(--rule); font-size: 15px; line-height: 1.45; }
.auth .post-sources a:hover span { box-shadow: inset 0 -2px 0 var(--acc); }
.auth .post-sources b { font-family: "Spline Sans Mono", monospace; font-size: 11px; letter-spacing: .06em; text-transform: uppercase; white-space: nowrap; color: var(--soft); }

.auth .aside { position: sticky; top: 104px; display: flex; flex-direction: column; gap: 28px; }
.auth .facts { background: var(--ink); color: #f1f1ec; padding: 24px 24px 20px; }
.auth .facts h3 { font-family: "Spline Sans Mono", monospace; font-size: 11.5px; letter-spacing: .18em; text-transform: uppercase; color: var(--acc); margin: 0 0 14px; }
.auth .fact { display: flex; flex-direction: column; gap: 3px; padding: 11px 0; border-top: 1px solid var(--ruled); }
.auth .fact:first-of-type { border-top: none; }
.auth .fact .k { font-family: "Spline Sans Mono", monospace; font-size: 10.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--softd); }
.auth .fact .v { font-size: 14.5px; font-weight: 700; line-height: 1.35; }
.auth .srcs { border: 2px solid #1a1b1f; background: var(--card); padding: 20px 22px; }
.auth .srcs h3 { font-family: "Spline Sans Mono", monospace; font-size: 11.5px; letter-spacing: .18em; text-transform: uppercase; margin: 0 0 12px; }
.auth .src { display: flex; gap: 10px; padding: 9px 0; border-top: 1px solid var(--rule); font-size: 13px; line-height: 1.45; align-items: baseline; }
.auth .src:first-of-type { border-top: none; }
.auth .src b { font-family: "Spline Sans Mono", monospace; font-size: 11px; letter-spacing: .06em; text-transform: uppercase; white-space: nowrap; }
.auth .srcs a:hover { box-shadow: inset 0 -2px 0 var(--acc); }
.auth .related { max-width: 1180px; margin: 0 auto; padding: 64px 48px 0; width: 100%; }
.auth .rel-row { grid-template-columns: 64px 1fr 200px 70px; }

/* ===== CATEGORY ===== */
.auth .cat-head { padding-top: 36px; }
.auth .cat-head .crumb { margin-bottom: 34px; }
.auth .cat-head-grid { display: grid; grid-template-columns: 1fr 320px; gap: 64px; align-items: end; padding-bottom: 56px; }
.auth .cat-h1 { font-weight: 900; font-size: clamp(48px, 7vw, 84px); line-height: .94; letter-spacing: -.03em; text-transform: uppercase; margin: 24px 0 0; }
.auth .cat-blurb { font-size: 17.5px; line-height: 1.65; color: var(--softd); margin: 26px 0 0; max-width: 640px; }
.auth .cat-side { display: flex; flex-direction: column; gap: 0; border: 1px solid var(--ruled); }
.auth .cat-side .stat { padding: 18px 22px 16px; border-bottom: 1px solid var(--ruled); border-right: none; }
.auth .cat-side .stat:last-child { border-bottom: none; }
.auth .cat-side .stat-n { font-weight: 900; font-size: 44px; line-height: 1; color: var(--acc); letter-spacing: -.02em; }
.auth .cat-side .stat-l { font-family: "Spline Sans Mono", monospace; font-size: 10.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--softd); margin-top: 8px; }
.auth .other-cats { display: flex; gap: 10px; flex-wrap: wrap; padding: 28px 0 0; }
.auth .oc { font-family: "Spline Sans Mono", monospace; font-size: 11.5px; font-weight: 700; letter-spacing: .08em; border: 2px solid #1a1b1f; padding: 7px 12px; transition: background .15s; }
.auth .oc:hover { background: var(--acc); }
.auth .oc.is-on { background: #1a1b1f; color: var(--acc); }
.auth .cat-ledger .lhead, .auth .cat-ledger .lrow { grid-template-columns: 64px 1fr 130px 70px 40px; }

/* ===== ABOUT / PAGE ===== */
.auth .ab-head { padding-top: 36px; padding-bottom: 56px; }
.auth .ab-head .crumb { margin-bottom: 34px; }
.auth .ab-h1 { font-weight: 900; font-size: clamp(44px, 5.5vw, 64px); line-height: .98; letter-spacing: -.025em; text-transform: uppercase; margin: 24px 0 0; max-width: 1000px; }
.auth .ab-lede { font-size: 19px; line-height: 1.65; color: var(--softd); margin: 26px 0 0; max-width: 680px; }
.auth .principles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; padding: 64px 0 0; }
.auth .principle { border: 2.5px solid #1a1b1f; background: var(--card); padding: 24px 24px 22px; }
.auth .principle-n { font-weight: 900; font-size: 44px; line-height: 1; color: transparent; -webkit-text-stroke: 2px #1a1b1f; }
.auth .principle-h { font-weight: 800; font-size: 19px; line-height: 1.15; text-transform: uppercase; letter-spacing: -.01em; margin-top: 18px; padding-top: 14px; border-top: 4px solid var(--acc); }
.auth .principle-p { font-size: 14px; line-height: 1.6; color: var(--soft); margin-top: 10px; }
.auth .ab-body { padding: 48px 0 0; font-size: 17px; line-height: 1.72; }
.auth .ab-body h2 { font-weight: 900; font-size: 26px; line-height: 1.1; letter-spacing: -.015em; text-transform: uppercase; margin: 44px 0 16px; display: flex; align-items: center; gap: 14px; }
.auth .ab-body h2::before { content: ""; width: 14px; height: 14px; background: var(--acc); flex: none; }
.auth .ab-body p { margin: 0 0 22px; }
.auth .ab-body a { color: #1a1b1f; box-shadow: inset 0 -2px 0 var(--acc); }
.auth .editor-card { display: flex; align-items: center; gap: 18px; border: 2.5px solid #1a1b1f; background: var(--card); padding: 20px 24px; margin: 8px 0 30px; }
.auth .editor-pic { width: 58px; height: 58px; background: var(--acc); color: var(--ink); display: flex; align-items: center; justify-content: center; font-weight: 900; font-size: 20px; flex: none; }
.auth .editor-name { font-weight: 800; font-size: 19px; letter-spacing: -.01em; }
.auth .editor-role { font-family: "Spline Sans Mono", monospace; font-size: 11px; letter-spacing: .14em; color: var(--soft); margin-top: 4px; }
.auth .sources-strip { display: flex; gap: 10px; flex-wrap: wrap; margin: 4px 0 30px; }
.auth .source-chip { font-family: "Spline Sans Mono", monospace; font-size: 12px; font-weight: 700; letter-spacing: .06em; border: 2px solid #1a1b1f; padding: 7px 12px; transition: background .15s; }
.auth .source-chip:hover { background: var(--acc); }
.auth .ab-note { background: var(--ink); color: #f1f1ec; padding: 26px 30px; margin: 8px 0 0; }
.auth .ab-note h3 { font-family: "Spline Sans Mono", monospace; font-size: 11.5px; letter-spacing: .18em; text-transform: uppercase; color: var(--acc); margin: 0 0 10px; }
.auth .ab-note p { margin: 0; font-size: 15px; line-height: 1.65; color: var(--softd); }

/* ===== A–Z INDEX ===== */
.auth .az-head { padding-top: 36px; padding-bottom: 56px; }
.auth .az-head .crumb { margin-bottom: 34px; }
.auth .az-h1 { font-weight: 900; font-size: clamp(48px, 7vw, 84px); line-height: .94; letter-spacing: -.03em; text-transform: uppercase; margin: 24px 0 0; }
.auth .az-blurb { font-size: 17.5px; line-height: 1.65; color: var(--softd); margin: 26px 0 0; max-width: 620px; }
.auth .az-jump { display: flex; gap: 6px; flex-wrap: wrap; padding: 28px 0 0; }
.auth .az-jump a { font-family: "Spline Sans Mono", monospace; font-size: 12px; font-weight: 700; width: 34px; height: 34px; display: inline-flex; align-items: center; justify-content: center; border: 2px solid #1a1b1f; transition: background .15s; }
.auth .az-jump a.live:hover { background: var(--acc); }
.auth .az-jump a.dead { opacity: .25; border-color: var(--rule); pointer-events: none; }
.auth .az-group { padding: 56px 0 0; scroll-margin-top: 96px; }
.auth .az-letter { display: flex; align-items: center; gap: 20px; margin-bottom: 22px; }
.auth .az-letter b { font-weight: 900; font-size: 64px; line-height: 1; letter-spacing: -.02em; background: #1a1b1f; color: var(--acc); padding: 2px 16px 8px; }
.auth .az-letter .rule { flex: 1; height: 2.5px; background: #1a1b1f; }
.auth .az-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.auth .az-item { border: 2px solid #1a1b1f; background: var(--card); padding: 16px 18px 14px; display: flex; flex-direction: column; gap: 12px; transition: transform .15s, box-shadow .15s, background .15s; }
.auth .az-item:hover { background: var(--acc); transform: translate(-3px, -3px); box-shadow: 5px 5px 0 #1a1b1f; }
.auth .az-name { font-weight: 800; font-size: 17px; line-height: 1.2; letter-spacing: -.01em; }
.auth .az-meta { display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.auth .az-cat { font-family: "Spline Sans Mono", monospace; font-size: 10.5px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; background: #1a1b1f; color: var(--acc); padding: 3px 7px; white-space: nowrap; }
.auth .az-item:hover .az-cat { background: var(--paper); }
.auth .az-arrow { font-weight: 800; }

/* pagination */
.auth .pager { display: flex; justify-content: center; gap: 14px; padding: 48px 0 0; font-family: "Spline Sans Mono", monospace; font-size: 12px; text-transform: uppercase; letter-spacing: .08em; }
.auth .pager a, .auth .pager span { padding: 10px 18px; border: 2px solid #1a1b1f; font-weight: 700; }
.auth .pager a:hover { background: var(--acc); }

/* ===== Koenig editor content ===== */
.auth .gh-content > * { margin-top: 0; }
.auth .gh-content img { display: block; }
.auth .gh-content figure { margin: 8px 0 30px; }
.auth .gh-content figure img { width: 100%; border: 1.5px solid #1a1b1f; }
.auth .gh-content figcaption { font-family: "Spline Sans Mono", monospace; font-size: 12px; color: var(--soft); text-align: center; margin-top: 10px; }
.auth .kg-width-wide { position: relative; width: calc(100% + 160px); margin-left: -80px; }
.auth .kg-width-full { position: relative; width: calc(100% + 120px); margin-left: -60px; }
@media (max-width: 920px) { .auth .kg-width-wide, .auth .kg-width-full { width: 100%; margin-left: 0; } }
.auth .kg-image-card img { margin-left: auto; margin-right: auto; }
.auth .kg-gallery-container { display: flex; flex-direction: column; gap: 10px; margin: 8px 0 30px; }
.auth .kg-gallery-row { display: flex; gap: 10px; }
.auth .kg-gallery-image img { width: 100%; height: 100%; object-fit: cover; border: 1.5px solid #1a1b1f; }
.auth .kg-bookmark-card { margin: 8px 0 30px; }
.auth .kg-bookmark-container { display: flex; min-height: 132px; border: 2px solid #1a1b1f; background: var(--card); overflow: hidden; color: inherit; }
.auth .kg-bookmark-content { display: flex; flex-direction: column; padding: 20px; flex: 1 1 auto; }
.auth .kg-bookmark-title { font-weight: 800; font-size: 16px; }
.auth .kg-bookmark-description { font-size: 14px; color: var(--soft); margin-top: 6px; line-height: 1.5; }
.auth .kg-bookmark-metadata { font-family: "Spline Sans Mono", monospace; font-size: 12px; color: var(--soft); margin-top: auto; padding-top: 12px; display: flex; align-items: center; gap: 8px; }
.auth .kg-bookmark-thumbnail { flex: 0 0 30%; }
.auth .kg-bookmark-thumbnail img { width: 100%; height: 100%; object-fit: cover; }
.auth .kg-bookmark-icon { width: 18px; height: 18px; }
.auth .kg-callout-card { display: flex; gap: 12px; padding: 22px 26px; margin: 8px 0 30px; background: var(--acc); color: var(--ink); font-weight: 700; box-shadow: 6px 6px 0 #1a1b1f; }
.auth .kg-callout-card .kg-callout-emoji { font-style: normal; }
.auth .kg-button-card { display: flex; margin: 8px 0 30px; }
.auth .kg-button-card.kg-align-center { justify-content: center; }
.auth .kg-btn { display: inline-block; padding: 13px 26px; background: #1a1b1f; color: var(--acc); font-weight: 800; text-transform: uppercase; letter-spacing: .06em; font-size: 13px; }
.auth .gh-content hr { border: none; border-top: 2px solid #1a1b1f; margin: 36px 0; }
.auth .gh-content pre { background: var(--ink); color: var(--paper); padding: 18px 20px; overflow-x: auto; font-family: "Spline Sans Mono", monospace; font-size: 14px; line-height: 1.6; margin: 8px 0 28px; }
.auth .gh-content code { font-family: "Spline Sans Mono", monospace; font-size: .9em; background: #ecebe3; padding: 2px 6px; }
.auth .gh-content pre code { background: none; padding: 0; }

/* ===== responsive ===== */
@media (max-width: 1080px) {
  .auth .cat-grid { grid-template-columns: repeat(3, 1fr); }
  .auth .az-grid { grid-template-columns: repeat(2, 1fr); }
  .auth .foot-in { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 920px) {
  .auth .wrap, .auth .wrap-narrow { padding: 0 24px; }
  .auth .hero-in { padding: 56px 24px 0; }
  .auth .hero-foot { grid-template-columns: 1fr; gap: 32px; }
  .auth .lead-grid { grid-template-columns: 1fr; }
  .auth .lead-main { border-right: none; border-bottom: 2.5px solid #1a1b1f; }
  .auth .art-layout { grid-template-columns: 1fr; gap: 40px; padding: 40px 24px 0; }
  .auth .aside { position: static; }
  .auth .cat-head-grid { grid-template-columns: 1fr; gap: 28px; }
  .auth .subband-in { grid-template-columns: 1fr; gap: 24px; padding: 44px 24px; }
  .auth .subband h3 { font-size: 34px; }
  .auth .foot-in { padding: 44px 24px; }
  .auth .related, .auth .art-layout { padding-left: 24px; padding-right: 24px; }
  .auth .lhead { display: none; }
  .auth .lrow, .auth .cat-ledger .lrow, .auth .rel-row { grid-template-columns: 44px 1fr auto; gap: 6px 14px; }
  .auth .lrow .r-d, .auth .lrow .r-r { grid-column: 2; }
}
@media (max-width: 640px) {
  .auth .cat-grid { grid-template-columns: repeat(2, 1fr); }
  .auth .az-grid { grid-template-columns: 1fr; }
  .auth .az-letter b { font-size: 48px; }
  .auth .stats { grid-template-columns: 1fr; }
  .auth .stat { border-right: none; border-bottom: 1px solid var(--ruled); }
  .auth .principles { grid-template-columns: 1fr; }
  .auth .foot-in { grid-template-columns: 1fr; gap: 28px; }
  .auth .sub { flex-direction: column; }
  .auth .sub input { width: 100%; }
}
