/* ───────────────────────────────────────────────────────────
   Do One Thing — the short guide (web edition)
   A digital version of a designed paper object. London Review of
   Books online, not a SaaS landing page. Paper ground, ink type,
   one accent red, hairline rules, generous whitespace. No gradients,
   no sticky chrome, no animated calls to action.
   ─────────────────────────────────────────────────────────── */

:root {
  --paper:       #f1e9d8;
  --paper-soft:  #ebe1cd;
  --paper-card:  #f6f0e2;
  --ink:         #1c1813;
  --ink-soft:    #2b251e;
  --ink-mute:    rgba(28, 24, 19, 0.62);
  --ink-faint:   rgba(28, 24, 19, 0.42);
  --rule:        rgba(28, 24, 19, 0.20);
  --rule-soft:   rgba(28, 24, 19, 0.10);
  --accent:      #8a2c1f;
  --accent-2:    #c0492f;
  --serif:       "Source Serif 4", Georgia, serif;
  --mono:        "JetBrains Mono", ui-monospace, "SF Mono", monospace;
  --hand:        "Caveat", cursive;
  --measure:     38rem;          /* reading width */
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--serif);
  font-size: 19px;
  line-height: 1.62;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-variant-numeric: oldstyle-nums;
}

::selection { background: rgba(138, 44, 31, 0.16); }

a { color: inherit; }

/* ─── Nav (identical to site template) ───────────────────── */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(241, 233, 216, 0.86);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--rule);
}
.nav-inner {
  max-width: 1100px; margin: 0 auto;
  padding: 14px clamp(20px, 4vw, 40px);
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px;
}
.brand {
  display: flex; align-items: baseline; gap: 12px;
  text-decoration: none; color: var(--ink);
  min-width: 0;
}
.brand-name {
  font-family: var(--serif); font-style: italic;
  font-size: clamp(19px, 2.4vw, 23px);
  letter-spacing: -0.008em;
  white-space: nowrap;
}
.brand-tag {
  font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.22em;
  color: var(--ink-mute); text-transform: uppercase;
  white-space: nowrap;
}
@media (max-width: 640px) { .brand-tag { display: none; } }
.buy-pill {
  background: var(--ink); color: var(--paper);
  border: 0; padding: 10px 22px;
  border-radius: 999px;
  font-family: var(--serif); font-size: 14px; font-style: italic;
  cursor: pointer; text-decoration: none;
  white-space: nowrap;
  transition: background .2s ease, transform .2s ease;
}
.buy-pill:hover { background: var(--accent); transform: translateY(-1px); }
.buy-pill::after { content: " →"; font-style: normal; opacity: 0.7; }
.nav-links { display: flex; align-items: center; gap: clamp(14px, 3vw, 26px); }
.nav-links a:not(.buy-pill) {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-mute); text-decoration: none; white-space: nowrap;
  padding-bottom: 2px; border-bottom: 1px solid transparent; transition: color .2s, border-color .2s;
}
.nav-links a:not(.buy-pill):hover { color: var(--accent); }
.nav-links a.active { color: var(--accent); border-color: var(--accent); }
.nav-links a:not(.buy-pill) + a:not(.buy-pill) { border-left: 1px solid var(--rule); padding-left: clamp(14px, 3vw, 26px); }
.nav-links a:not(.buy-pill) + a.active { border-bottom-color: transparent; background-image: linear-gradient(var(--accent), var(--accent)); background-repeat: no-repeat; background-position: right bottom; background-size: calc(100% - clamp(14px, 3vw, 26px) + 6px) 1px; }
@media (max-width: 560px) { .nav-links a:not(.buy-pill) { display: none; } }

/* ─── Chapter shell ──────────────────────────────────────── */
.chapter {
  max-width: 1100px;
  margin: 0 auto;
  padding: clamp(48px, 9vh, 104px) clamp(20px, 4vw, 40px) 0;
}
.wide { max-width: 1100px; }

/* full-width hero (kicker · title · standfirst), like the Product page */
.ch-hero { margin: 0 0 clamp(30px, 5vh, 52px); }
.ch-hero h1 { font-size: clamp(44px, 8vw, 92px); line-height: 0.98; margin: 0 0 26px; }
.ch-hero .g-standfirst { max-width: none; }
.ch-hero .g-rule.short { margin: 0; }

/* two-column band: in-flow rail + buy on the left, body on the right */
.ch-cols { display: grid; grid-template-columns: 214px minmax(0, 1fr); gap: clamp(34px, 5vw, 76px); align-items: start; padding-top: clamp(28px, 5vh, 52px); }
.ch-main { min-width: 0; max-width: var(--measure); }
.ch-side { position: sticky; top: 36px; align-self: start; }
.ch-side-buy { display: inline-block; margin-top: 24px; font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-mute); text-decoration: none; border: 1px solid var(--rule); border-radius: 999px; padding: 9px 16px; transition: background .2s ease, color .2s ease, border-color .2s ease; }
.ch-side-buy:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }
@media (max-width: 940px) {
  .ch-cols { grid-template-columns: 1fr; gap: 0; }
  .ch-side { display: none; }
}

.g-kicker {
  font-family: var(--mono);
  font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 22px;
}
.g-kicker .k-sep { color: var(--ink-faint); margin: 0 0.5em; }

h1 {
  font-weight: 400;
  font-size: clamp(38px, 6vw, 64px);
  line-height: 1.0; letter-spacing: -0.022em;
  margin: 0 0 30px; text-wrap: pretty;
}
h1 em { font-style: italic; }

.g-standfirst {
  font-size: clamp(20px, 2.4vw, 25px);
  line-height: 1.42; color: var(--ink-soft);
  font-style: italic;
  margin: 0 0 14px; max-width: 30ch; text-wrap: pretty;
}

.g-rule {
  border: 0; border-top: 1px solid var(--rule);
  margin: 40px 0 44px;
}
.g-rule.short { width: 56px; border-top-width: 2px; border-color: var(--accent); margin: 36px 0 40px; }

/* ─── Body prose ─────────────────────────────────────────── */
.g-body { }
.g-body > p {
  margin: 0 0 1.45em; text-wrap: pretty;
  text-align: justify; text-align-last: left;
  -webkit-hyphens: none; hyphens: none;
}
.g-body > p:first-of-type { }
.g-body .drop::first-letter {
  font-size: 3.4em; line-height: 0.84; float: left;
  padding: 0.04em 0.10em 0 0; font-style: italic; color: var(--accent);
}
.g-body em { font-style: italic; }
.g-body strong { font-weight: 600; }

/* the one-line closer that ends most chapters */
.g-coda {
  font-size: clamp(24px, 3.2vw, 34px);
  line-height: 1.18; letter-spacing: -0.015em;
  font-style: italic; color: var(--ink);
  margin: 48px 0 8px; max-width: 34ch; text-wrap: pretty;
}
.g-coda + .g-coda-by {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--ink-faint); margin: 0;
}

/* pull / aside quote inside flow */
.g-pull {
  margin: 40px 0; padding: 0 0 0 26px;
  border-left: 2px solid var(--accent);
  font-size: clamp(21px, 2.6vw, 27px); line-height: 1.3;
  font-style: italic; color: var(--ink-soft); text-wrap: pretty;
}

/* hand-drawn red underline under an emphasis word */
.uline {
  font-style: italic;
  background-image: linear-gradient(var(--accent), var(--accent));
  background-repeat: no-repeat;
  background-position: 0 92%;
  background-size: 100% 0.08em;
  padding-bottom: 0.04em;
}

/* ─── Numbered steps / filters ───────────────────────────── */
.g-steps { list-style: none; margin: 36px 0; padding: 0; counter-reset: step; }
.g-steps > li {
  position: relative; padding: 0 0 26px 0; margin: 0 0 26px 0;
  border-bottom: 1px solid var(--rule-soft);
}
.g-steps > li:last-child { border-bottom: 0; margin-bottom: 0; padding-bottom: 0; }
.g-steps .s-label {
  display: block; font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 8px;
}
.g-steps .s-label .s-num { color: var(--ink-faint); margin-right: 0.9em; }
.g-steps .s-body { margin: 0; }
.g-steps .s-body strong { font-weight: 600; }

/* code chip, eg [M1] */
.code {
  font-family: var(--mono); font-size: 0.78em; letter-spacing: 0.04em;
  color: var(--accent); white-space: nowrap;
}
.code-pill {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em;
  color: var(--paper); background: var(--accent);
  border-radius: 4px; padding: 3px 8px; white-space: nowrap;
}

/* ─── The funnel diagram (static, restrained) ────────────── */
figure.funnel { margin: 48px auto; max-width: 30rem; padding: 0; }
.funnel-stack { display: flex; flex-direction: column; align-items: center; gap: 0; }
.funnel-row {
  width: 100%; text-align: center; position: relative;
  border: 1px solid var(--rule); border-bottom: 0;
  background: var(--paper-card);
  padding: 16px 20px;
}
.funnel-row:last-of-type { border-bottom: 1px solid var(--rule); }
.funnel-row .fr-scope {
  display: block; font-family: var(--mono);
  font-size: 9.5px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-faint); margin-bottom: 5px;
}
.funnel-row .fr-text { font-style: italic; color: var(--ink-soft); }
.funnel-row.r1 { width: 100%; }
.funnel-row.r2 { width: 78%; }
.funnel-row.r3 { width: 56%; }
.funnel-tip {
  width: 0; height: 0; margin: 0 auto;
  border-left: 13px solid transparent; border-right: 13px solid transparent;
  border-top: 13px solid var(--accent);
}
.funnel-one {
  margin-top: 18px; text-align: center;
}
.funnel-one .fo-pill {
  display: inline-flex; align-items: baseline; gap: 10px;
  background: var(--accent); color: var(--paper);
  border-radius: 7px; padding: 12px 22px;
}
.funnel-one .fo-code {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em;
  opacity: 0.85;
}
.funnel-one .fo-line { font-style: italic; font-size: 19px; }
figure.funnel figcaption {
  margin-top: 22px; text-align: center; font-style: italic;
  color: var(--ink-mute); font-size: 16px; text-wrap: pretty;
}

/* cascade (one code, three pages) */
figure.cascade { margin: 44px auto; max-width: 27rem; padding: 0; }
.cm-stack {
  list-style: none; margin: 0; padding: 0; position: relative;
  display: flex; flex-direction: column; gap: 14px;
}
.cm-stack::before {
  content: ""; position: absolute; left: 30px; top: 24px; bottom: 24px;
  border-left: 1.5px dashed rgba(138, 44, 31, 0.45);
}
.cm-card {
  position: relative; display: flex; align-items: center; gap: 14px;
  background: var(--paper-card); border: 1px solid var(--rule);
  border-radius: 6px; padding: 13px 18px;
}
.cm-code {
  position: relative; z-index: 1; font-family: var(--mono);
  font-size: 11px; letter-spacing: 0.06em; color: var(--paper);
  background: var(--accent); border-radius: 4px; padding: 3px 8px; flex: none;
}
.cm-scope {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-faint);
  width: 42px; flex: none;
}
.cm-line { font-style: italic; font-size: 16px; color: var(--ink); }
figure.cascade figcaption {
  margin-top: 18px; text-align: center; font-style: italic;
  color: var(--ink-mute); font-size: 16px;
}

/* ─── Diary-page facsimile (worked example) ──────────────── */
.diary {
  background: var(--paper-card);
  border: 1px solid var(--rule);
  padding: clamp(22px, 4vw, 38px);
  margin: 0 0 26px;
}
.diary-head {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 16px; flex-wrap: wrap;
  border-bottom: 1px solid var(--rule); padding-bottom: 12px; margin-bottom: 20px;
}
.diary-title {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.24em;
  text-transform: uppercase; color: var(--ink);
}
.diary-meta {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--ink-mute);
}
.diary-sub {
  font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--ink-faint);
  margin: 20px 0 10px;
}
.diary-sub:first-child { margin-top: 0; }
.drow {
  display: flex; align-items: baseline; gap: 12px;
  padding: 9px 0; border-bottom: 1px solid var(--rule-soft);
}
.drow:last-child { border-bottom: 0; }
.drow .d-code {
  font-family: var(--mono); font-size: 11px; flex: none; width: 42px;
  color: var(--accent); letter-spacing: 0.02em;
}
.drow .d-code.empty { color: var(--ink-faint); }
.drow .d-star { font-family: var(--mono); color: var(--accent); flex: none; }
.drow .d-dot  { font-family: var(--mono); color: var(--ink-faint); flex: none; }
.drow .d-task { flex: 1; min-width: 0; }
.drow .d-task .hand { font-family: var(--hand); font-size: 23px; line-height: 1; color: var(--ink); }
.drow .d-time {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em;
  color: var(--ink-mute); flex: none;
}
.diary-note {
  font-family: var(--hand); font-size: 22px; line-height: 1.25;
  color: var(--ink-soft); margin: 6px 0 0;
}
.diary-review {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
  margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--rule);
}
.diary-review .dr-q {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ink);
}
.diary-review .dr-yn { font-family: var(--mono); font-size: 12px; letter-spacing: 0.2em; }
.diary-review .dr-yn .yes { color: var(--accent); }
.diary-review .dr-yn .no  { color: var(--ink-faint); }
.example-link {
  display: block; font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-mute);
  text-align: center; margin: 4px 0 30px;
}

/* draft flag (for pages awaiting verbatim copy) */
.g-draftflag {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--accent);
  border: 1px dashed rgba(138, 44, 31, 0.5); border-radius: 5px;
  padding: 9px 14px; margin: 0 0 30px; text-align: center;
}

/* ─── Sequence nav (prev · contents · next) ──────────────── */
.g-seq {
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
  gap: 14px; margin: 64px 0 0; padding: 22px 0;
  border-top: 1px solid var(--rule);
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase;
}
.g-seq a { color: var(--ink-mute); text-decoration: none; transition: color .2s ease; }
.g-seq a:hover { color: var(--accent); }
.g-seq .sq-prev { justify-self: start; }
.g-seq .sq-toc  { justify-self: center; color: var(--ink-faint); }
.g-seq .sq-next { justify-self: end; text-align: right; color: var(--ink); }
.g-seq .sq-dim { color: var(--ink-faint); }
.g-seq .sq-cap { display: block; font-size: 9px; letter-spacing: 0.2em; color: var(--ink-faint); margin-bottom: 4px; }

/* ─── Buy moment ─────────────────────────────────────────── */
.g-buy {
  text-align: center;
  margin: clamp(46px, 7vh, 76px) 0 clamp(40px, 6vh, 64px);
  padding: clamp(30px, 4.5vh, 46px) clamp(24px, 5vw, 48px);
  background: var(--paper-card);
  border: 1px solid var(--rule);
  border-radius: 12px;
  box-shadow: 0 30px 64px -44px rgba(40, 30, 20, 0.5);
}
.g-buy .gb-line {
  font-size: clamp(24px, 3.4vw, 36px); line-height: 1.08; letter-spacing: -0.018em;
  margin: 0 auto 22px; max-width: 24ch; text-wrap: pretty;
}
.g-buy .gb-line em { font-style: italic; color: var(--accent); }
.g-cta {
  display: inline-block; background: var(--ink); color: var(--paper);
  text-decoration: none; padding: 16px 40px; border-radius: 999px;
  font-family: var(--serif); font-style: italic; font-size: 20px;
  transition: background .2s ease, transform .2s ease;
}
.g-cta:hover { background: var(--accent); transform: translateY(-1px); }
.g-cta::after { content: " →"; font-style: normal; opacity: 0.7; }
.g-buy .gb-fine {
  margin: 18px 0 0; font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-faint);
}

/* ─── Footer (identical to site template) ────────────────── */
footer {
  border-top: 1px solid var(--rule);
  padding: 48px clamp(20px, 4vw, 40px) 64px;
  max-width: 1100px; margin: 0 auto;
  display: flex; justify-content: space-between;
  flex-wrap: wrap; gap: 16px;
  font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
footer a { color: inherit; text-decoration: none; border-bottom: 1px solid currentColor; padding-bottom: 1px; }
footer em {
  font-family: var(--serif); font-style: italic;
  text-transform: none; letter-spacing: 0.01em;
  font-size: 15px; color: var(--ink-mute);
}

/* ─── Legacy footer (PDF keepsake line) ──────────────────── */
.g-foot {
  max-width: 1100px; margin: 0 auto;
  padding: clamp(40px, 8vh, 80px) clamp(20px, 4vw, 40px) clamp(48px, 10vh, 96px);
}
.chapter + .g-foot, .g-foot.tight { padding-top: clamp(34px, 6vh, 60px); }
.g-foot-inner {
  border-top: 1px solid var(--rule); padding-top: 26px;
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 18px; flex-wrap: wrap;
}
.g-foot .gf-keepsake {
  font-style: italic; color: var(--ink-mute); font-size: 16px;
  max-width: 34ch; text-wrap: pretty; margin: 0;
}
.g-foot .gf-keepsake a {
  font-style: normal; color: var(--accent); text-decoration: none;
  border-bottom: 1px solid var(--rule); padding-bottom: 1px;
}
.g-foot .gf-keepsake a:hover { border-color: var(--accent); }
.g-foot .gf-mark {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--ink-faint); white-space: nowrap;
}

/* ─── Cover (index) ──────────────────────────────────────── */
.cover {
  max-width: 46rem; margin: 0 auto;
  padding: clamp(48px, 9vh, 104px) clamp(22px, 5vw, 44px) 0;
  text-align: center;
}
.cover .cv-kick {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.34em;
  text-transform: uppercase; color: var(--ink-mute); margin: 0 0 28px;
}
.cover h1 {
  font-size: clamp(46px, 9vw, 100px); line-height: 0.94;
  letter-spacing: -0.028em; margin: 0 0 6px;
}
.cover .cv-tag {
  font-style: italic; font-size: clamp(20px, 3vw, 28px);
  color: var(--ink-soft); margin: 0 0 4px;
}
.cover .cv-star { color: var(--accent); font-size: 20px; margin: 26px 0; }
.cover .cv-lede {
  font-size: clamp(19px, 2.2vw, 22px); color: var(--ink-soft);
  line-height: 1.5; max-width: 40ch; margin: 0 auto 8px; text-wrap: pretty;
}

/* contents list */
.toc-list {
  max-width: 40rem; margin: 0 auto; padding: 0;
  list-style: none; counter-reset: ch;
  text-align: left;
}
.toc-list li { border-top: 1px solid var(--rule); }
.toc-list li:last-child { border-bottom: 1px solid var(--rule); }
.toc-list a {
  display: flex; align-items: baseline; gap: 18px;
  padding: 17px 6px; text-decoration: none; color: var(--ink);
  transition: background .15s ease, padding .15s ease;
}
.toc-list a:hover { background: var(--paper-soft); padding-left: 14px; }
.toc-list .tc-num {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em;
  color: var(--ink-faint); flex: none; width: 28px;
}
.toc-list .tc-title { flex: 1; font-size: 20px; }
.toc-list .tc-title em { font-style: italic; }
.toc-list .tc-gloss {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--ink-mute); flex: none;
  max-width: 42%; text-align: right;
}
@media (max-width: 540px) { .toc-list .tc-gloss { display: none; } }

.section-label {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.26em;
  text-transform: uppercase; color: var(--ink-faint);
  text-align: center; margin: 48px 0 18px;
}

/* contents page — kicker · leader dots · standfirst (per guide brief) */
.intro {
  max-width: 34rem; margin: 0 auto 8px; text-align: center;
  font-style: italic; color: var(--ink-mute); font-size: 18px; line-height: 1.5; text-wrap: pretty;
}
.contents { max-width: 40rem; margin: 0 auto; }
.c-row {
  display: flex; align-items: baseline; gap: 14px;
  padding: 16px 6px; text-decoration: none; color: var(--ink);
  border-top: 1px solid var(--rule-soft);
  transition: background .15s ease, padding .15s ease;
}
.c-row:last-child { border-bottom: 1px solid var(--rule-soft); }
.c-row:hover { background: var(--paper-soft); padding-left: 14px; }
.c-row .ck { font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink); flex: none; }
.c-row .ck .cn { color: var(--accent); margin-right: 0.8em; }
.c-row .cd { flex: 1; border-bottom: 1px dotted var(--rule); transform: translateY(-4px); min-width: 16px; }
.c-row .ct { font-style: italic; color: var(--ink-soft); font-size: 18px; flex: none; text-align: right; }
.c-group { font-family: var(--mono); font-size: 9px; letter-spacing: 0.26em; text-transform: uppercase; color: var(--ink-faint); text-align: center; margin: 30px 0 4px; }
.pdf-line { text-align: center; margin: 32px 0 0; }
.pdf-line a { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); text-decoration: none; border-bottom: 1px solid var(--rule); padding-bottom: 2px; }
.pdf-line a:hover { border-color: var(--accent); }
@media (max-width: 540px) {
  .c-row { flex-wrap: wrap; gap: 4px 14px; }
  .c-row .cd { display: none; }
  .c-row .ct { text-align: left; flex: 1 0 100%; }
}


/* chapter rail — in-flow editorial index in the left column */
.g-rail{width:auto;padding-right:16px;border-right:1px solid var(--rule-soft);}
.g-rail-home{display:block;font-family:var(--mono);font-size:9px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-faint);text-decoration:none;margin-bottom:16px;}
.g-rail-home:hover{color:var(--accent);}
.g-rail ol{list-style:none;margin:0;padding:0;}
.g-rail li a{display:block;padding:6px 0 6px 15px;border-left:2px solid transparent;font-family:var(--serif);font-size:14px;line-height:1.3;color:var(--ink-mute);text-decoration:none;white-space:nowrap;transition:color .2s ease,border-color .2s ease;}
.g-rail li a .rn{font-family:var(--mono);font-size:9px;letter-spacing:0.08em;color:var(--ink-faint);margin-right:9px;}
.g-rail li a:hover{color:var(--ink);}
.g-rail li a.active{color:var(--accent);border-left-color:var(--accent);}
.g-rail li a.active .rn{color:var(--accent);}
