:root{
  --paper:#15161a;
  --paper-2:#1c1d22;
  --paper-3:#23252b;
  --paper-deep:#0c0d10;
  --ink:#ece7d8;
  --ink-2:#c8c2b1;
  --muted:#8a8676;
  --rule:#2a2c33;
  --rule-2:#3a3d46;
  --accent: oklch(0.72 0.13 50);
  --accent-fg: oklch(0.16 0.02 60);
  --good:#6fb07b;
  --serif: Iowan Old Style, "Source Serif Pro", Georgia, Cambria, "Times New Roman", serif;
  --sans:  system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --mono:  ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
}

*{box-sizing:border-box;min-width:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html,body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","cv05"}
pre.code{overflow-x:auto;max-width:100%}
.path, .v, code{overflow-wrap:anywhere;word-break:break-word}
::selection{background:var(--accent);color:var(--accent-fg)}
a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--rule-2)}
a:hover{border-bottom-color:var(--accent);color:var(--accent)}
h1,h2,h3,h4{margin:0;font-weight:500;letter-spacing:-0.012em}
p{margin:0 0 14px;text-wrap:pretty;max-width:68ch}
p:last-child{margin-bottom:0}
code,kbd,pre{font-family:var(--mono)}
pre{margin:0}

.shell{display:grid;grid-template-columns:240px minmax(0,1fr);gap:0;min-height:100vh}
.rail{position:sticky;top:0;align-self:start;height:100vh;border-right:1px solid var(--rule);padding:28px 22px 28px 32px;background:var(--paper);overflow:auto}
.rail .brand{display:flex;align-items:center;gap:10px;margin-bottom:24px}
.rail .brand img{width:22px;height:22px}
.rail .brand .name{font-family:var(--serif);font-style:italic;font-size:20px;font-weight:500;letter-spacing:-0.01em}
.rail nav{font-family:var(--mono);font-size:12px;line-height:1.9}
.rail nav .group{color:var(--muted);text-transform:uppercase;font-size:10.5px;letter-spacing:0.08em;margin:18px 0 4px}
.rail nav .group:first-child{margin-top:0}
.rail nav a{display:block;color:var(--ink-2);border:none;padding:1px 0;border-left:2px solid transparent;padding-left:10px;margin-left:-10px}
.rail nav a:hover{color:var(--accent)}
.rail nav a.active{color:var(--ink);border-left-color:var(--accent)}
.rail .foot{margin-top:32px;padding-top:18px;border-top:1px solid var(--rule);font-family:var(--mono);font-size:10.5px;color:var(--muted);line-height:1.7}

main{padding:0;max-width:none;min-width:0}
.doc{max-width:920px;margin:0;padding:64px 64px 96px}

.status{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);margin:0 0 56px;font-family:var(--mono);font-size:11px}
.status > div{padding:14px 18px;border-right:1px solid var(--rule)}
.status > div:last-child{border-right:none}
.status .k{color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;font-size:10px;margin-bottom:4px}
.status .v{color:var(--ink);font-size:13px;font-weight:500;letter-spacing:-0.01em}
.status .v.accent{color:var(--accent)}

.masthead{padding-bottom:36px;border-bottom:1px solid var(--rule)}
.masthead h1{font-family:var(--serif);font-weight:500;font-size:clamp(48px, 7vw, 96px);line-height:0.98;letter-spacing:-0.025em;margin:0 0 4px}
.masthead h1 em{font-style:italic;color:var(--accent);font-weight:500}
.masthead .lede{font-family:var(--serif);font-size:22px;line-height:1.4;color:var(--ink-2);max-width:36ch;margin-top:18px;font-weight:400}
.masthead .lede em{font-style:italic}

section{padding:56px 0;border-top:1px solid var(--rule)}
section:first-of-type{border-top:none;padding-top:0}
.sechead{display:flex;align-items:baseline;gap:18px;margin-bottom:28px}
.sechead h2{font-family:var(--serif);font-size:42px;letter-spacing:-0.02em;font-weight:500;line-height:1.05}
.sechead h2 em{font-style:italic;color:var(--accent);font-weight:500}
.sechead .rule{flex:1;height:1px;background:var(--rule);align-self:center;margin-bottom:12px}
section > p{font-size:16px;color:var(--ink-2);margin-bottom:22px;max-width:64ch}
section > p.intro{font-family:var(--serif);font-size:22px;line-height:1.45;color:var(--ink);max-width:42ch;margin-bottom:32px}
section > p.intro em{font-style:italic;color:var(--accent)}

.picker{background:var(--paper-2);border:1px solid var(--rule);border-radius:2px;overflow:hidden}
.picker .distro{border-bottom:1px solid var(--rule)}
.picker .distro:last-child{border-bottom:none}
.picker .distro > summary{cursor:pointer;list-style:none;padding:14px 20px;display:flex;align-items:baseline;gap:14px;background:var(--paper-3);font-family:var(--mono);font-size:13px;color:var(--ink)}
.picker .distro > summary::-webkit-details-marker{display:none}
.picker .distro > summary::before{content:"+";color:var(--accent);width:12px;font-size:13px}
.picker .distro[open] > summary::before{content:"−"}
.picker .distro > summary .dname{flex:1;font-weight:500}
.picker .distro > summary .dpm{color:var(--muted);text-transform:uppercase;font-size:10.5px;letter-spacing:0.06em}
.picker .distro[open] > summary{background:var(--paper-2);border-bottom:1px solid var(--rule)}
.picker .pane{padding:24px}
.picker .pane h4{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;margin:0 0 6px}
.picker .pane h4:not(:first-child){margin-top:20px}
.picker .pane p.hint{font-size:13.5px;color:var(--ink-2);margin:0 0 10px;max-width:60ch}
pre.code{background:var(--paper-deep);color:var(--ink);padding:14px 16px;border-radius:2px;font-size:12.5px;line-height:1.65;overflow:auto;white-space:pre;border:1px solid var(--rule)}
pre.code .c{color:var(--muted)}
pre.code .k{color:#e8b97c}
pre.code .s{color:#b8d7a0}
pre.code .v{color:#a8c7ff}

.endpoints{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--rule);border-radius:2px;overflow:hidden}
.ep{padding:18px 20px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);background:var(--paper-2);display:flex;flex-direction:column;gap:6px}
.ep:nth-child(2n){border-right:none}
.ep:nth-last-child(-n+2){border-bottom:none}
.ep .name{font-family:var(--serif);font-size:20px;font-weight:500;letter-spacing:-0.01em;line-height:1.1}
.ep .val{font-family:var(--mono);font-size:12.5px;color:var(--ink-2);overflow-wrap:anywhere}
.ep .meta{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;margin-top:auto;padding-top:8px}

.projects{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--rule);border-radius:2px;overflow:hidden}
.proj{padding:18px 20px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);background:var(--paper-2);display:flex;flex-direction:column;gap:6px}
.proj:nth-child(3n){border-right:none}
.proj:nth-last-child(-n+3){border-bottom:none}
.proj .name{font-family:var(--serif);font-size:20px;font-weight:500;letter-spacing:-0.01em;line-height:1.1}
.proj .name a{border:none;color:var(--ink)}
.proj .name a:hover{color:var(--accent)}
.proj .meta{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;margin-top:auto;padding-top:8px}
.proj .tier.t2{color:var(--accent)}
.proj .paths{font-family:var(--mono);font-size:12px;line-height:1.6;display:flex;flex-wrap:wrap;gap:4px 8px}
.proj .paths a{color:var(--ink-2);border-bottom:1px dotted var(--rule-2)}
.proj .paths a:hover{color:var(--accent);border-bottom-color:var(--accent)}

.threeup{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.threeup .card{border:1px solid var(--rule);padding:24px;border-radius:2px;background:var(--paper-2)}
.threeup .card h3{font-family:var(--serif);font-size:24px;font-weight:500;margin-bottom:12px;letter-spacing:-0.015em}
.threeup .card h3 em{font-style:italic;color:var(--accent);font-weight:500}
.threeup .card ul{margin:0;padding:0;list-style:none;font-size:13.5px;color:var(--ink-2)}
.threeup .card ul li{padding:8px 0;border-bottom:1px dashed var(--rule);display:flex;justify-content:space-between;gap:10px}
.threeup .card ul li:last-child{border-bottom:none}
.threeup .card ul li .v{font-family:var(--mono);font-size:11.5px;color:var(--muted);text-align:right;flex-shrink:0}
.verify-grid{grid-template-columns:1fr 1fr}
@media (max-width:760px){ .verify-grid{grid-template-columns:1fr} }

table.t{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:12.5px}
table.t th, table.t td{text-align:left;padding:9px 14px;border-bottom:1px solid var(--rule);vertical-align:top}
table.t th{font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;font-size:10.5px;border-bottom-color:var(--rule-2)}
table.t tr:last-child td{border-bottom:none}
table.t td.path{color:var(--ink-2)}

details{border-bottom:1px solid var(--rule)}
details:last-of-type{border-bottom:none}
details summary{cursor:pointer;list-style:none;padding:16px 0;display:flex;gap:14px;align-items:baseline;font-family:var(--sans);font-size:16px;color:var(--ink);letter-spacing:-0.005em}
details summary::-webkit-details-marker{display:none}
details summary::before{content:"+";font-family:var(--mono);color:var(--accent);width:14px;flex-shrink:0;font-size:14px}
details[open] summary::before{content:"−"}
details summary .q{flex:1}
details .a{padding:0 0 18px 28px;color:var(--ink-2);font-size:14.5px}
details .a p{max-width:62ch}
details .a code{font-family:var(--mono);font-size:12.5px;background:var(--paper-2);padding:1px 5px;border-radius:2px}

.siblings{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--rule)}
.sib{padding:18px 20px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);background:var(--paper-2)}
.sib:nth-child(3n){border-right:none}
.sib:nth-last-child(-n+3){border-bottom:none}
.sib .h{font-family:var(--mono);font-size:13px;font-weight:500;margin-bottom:4px}
.sib .h a{border:none;color:var(--ink)}
.sib .h a:hover{color:var(--accent)}
.sib .h .me{color:var(--accent);margin-left:6px;font-size:10px;text-transform:uppercase;letter-spacing:0.08em}
.sib .d{font-size:13px;color:var(--muted)}

footer{margin-top:96px;padding-top:36px;border-top:1px solid var(--rule);display:grid;grid-template-columns:1fr 1fr;gap:32px;font-size:13px;color:var(--muted)}
footer h4{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:10px;font-weight:500}
footer .signoff{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--ink-2);margin-top:6px;max-width:34ch}
footer code{font-family:var(--mono);font-size:11.5px;background:var(--paper-2);padding:2px 6px;border-radius:2px;word-break:break-all}

.tag{display:inline-block;font-family:var(--mono);font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;padding:2px 7px;border:1px solid var(--rule-2);border-radius:2px;vertical-align:middle}
.tag.accent{color:var(--accent);border-color:color-mix(in oklab, var(--accent) 40%, var(--rule))}

.small{font-size:13px;color:var(--muted)}
ul.bul{margin:0 0 14px;padding-left:18px}
ul.bul li{margin-bottom:4px;color:var(--ink-2)}
ul.bul li::marker{color:var(--muted)}
.subh{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em;margin:24px 0 10px;font-weight:500}
.sponsor-empty{font-family:var(--mono);font-size:12.5px;color:var(--muted);padding:18px 20px;border:1px dashed var(--rule);border-radius:2px;background:var(--paper-2)}



.copy-btn{
  position:absolute;top:6px;right:6px;
  font-family:var(--mono);font-size:10px;line-height:1;
  padding:3px 8px;border:1px solid var(--rule-2);border-radius:2px;
  background:var(--paper-3);color:var(--muted);cursor:pointer;
  opacity:0.7;transition:all .1s ease;
}
.copy-btn:hover{opacity:1;border-color:var(--accent);color:var(--accent)}
pre.code{position:relative;padding-right:64px}
pre.code .copy-btn{top:8px;right:8px}

table.compare{width:100%;border-collapse:collapse;font-size:13px}
table.compare th, table.compare td{padding:9px 12px;border-bottom:1px solid var(--rule);vertical-align:middle}
table.compare th{font-family:var(--mono);font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;font-weight:500;text-align:left}
table.compare tr:last-child td{border-bottom:none}
table.compare td.yes{color:#7fb88a}
table.compare td.no{color:#b88a7f}
table.compare .this{font-weight:600;color:var(--accent)}

.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}

.donate{display:flex;gap:24px;align-items:flex-start;flex-wrap:wrap}
.donate .qr{flex:0 0 160px;border:1px solid var(--rule);padding:8px;background:#fff;border-radius:2px}
.donate .qr img{width:100%;height:auto;display:block}
.donate .info{flex:1;min-width:260px}
.donate .addr{font-family:var(--mono);font-size:13px;background:var(--paper-deep);padding:10px 12px;border:1px solid var(--rule);border-radius:2px;word-break:break-all;margin:8px 0}
.donate .meta{font-size:12px;color:var(--muted)}

.fresh{font-size:12px;color:var(--muted);font-family:var(--mono)}

@media (max-width:1080px){
  .shell{grid-template-columns:200px 1fr}
  .doc{padding:48px 40px 80px}
  .status{grid-template-columns:repeat(3,1fr)}
  .status > div:nth-child(3){border-right:none}
  .status > div:nth-child(-n+3){border-bottom:1px solid var(--rule)}
  .endpoints, .projects, .threeup, .siblings{grid-template-columns:repeat(2,1fr)}
  .ep:nth-child(2n){border-right:none}
  .proj:nth-child(2n){border-right:none}
  .sib:nth-child(2n){border-right:none}
  .sib:nth-last-child(-n+2){border-bottom:none}
}
@media (max-width:760px){
  .shell{grid-template-columns:1fr}
  .rail{position:static;height:auto;border-right:none;border-bottom:1px solid var(--rule);padding:22px 22px}
  .rail nav{columns:2;column-gap:24px}
  .rail nav .group{column-span:all;break-after:avoid;margin-top:10px}
  .rail nav .group:first-child{margin-top:0}
  .doc{padding:32px 18px 56px;max-width:100%}
  .masthead h1{font-size:48px}
  .status{grid-template-columns:repeat(2,1fr)}
  .status > div{border-right:none !important;border-bottom:1px solid var(--rule)}
  .endpoints, .projects, .threeup, .siblings{grid-template-columns:1fr}
  .ep, .proj, .sib{border-right:none !important}
  footer{grid-template-columns:1fr}
  pre.code{font-size:11.5px;padding:12px}
  .picker .distro > summary{padding:12px 14px}
  .picker .pane{padding:18px 14px}
  table.t{font-size:11.5px}
  table.t th, table.t td{padding:8px 10px}
  table.compare{font-size:11px}
  table.compare th, table.compare td{padding:5px 6px}
  .table-scroll{margin:0 -18px;padding:0 18px}
}
@media print{
  .rail,.status,.picker,footer,.copy-btn{display:none!important}
  .shell{grid-template-columns:1fr}
  .doc{padding:0;max-width:none}
  section{border-top:1px solid #ccc;padding-top:1.2em}
  a{border-bottom:none}
  pre.code{white-space:pre-wrap}
}

.post-list{margin:0;padding:0;list-style:none;border:1px solid var(--rule);border-radius:2px;overflow:hidden}
.post-list li{border-bottom:1px solid var(--rule);background:var(--paper-2)}
.post-list li:last-child{border-bottom:none}
.post-list a{display:block;padding:18px 22px}
.post-list .meta{font-family:var(--mono);font-size:11px;color:var(--muted);margin-bottom:4px;letter-spacing:0.04em}
.post-list .title{font-family:var(--serif);font-size:19px;color:var(--ink);line-height:1.25}
.post-list .excerpt{font-size:14px;color:var(--ink-2);margin-top:6px;max-width:64ch}

.post-meta{font-family:var(--mono);font-size:12px;color:var(--muted);margin:12px 0 28px}
.post-meta .tag{display:inline-block;background:var(--paper-3);border:1px solid var(--rule-2);padding:1px 7px;border-radius:2px;font-size:10px;margin-left:8px;vertical-align:1px}

.article{font-family:var(--serif);font-size:17px;line-height:1.72;color:var(--ink)}
.article p{margin:0 0 18px;max-width:68ch}
.article h3{font-family:var(--sans);font-size:18px;letter-spacing:-0.01em;margin:32px 0 12px;color:var(--ink)}
.article ul{margin:0 0 18px;padding-left:20px;color:var(--ink-2)}
.article code{font-family:var(--mono);font-size:14px;background:var(--paper-2);padding:2px 5px;border-radius:2px}

.blog-footer{margin-top:64px;padding-top:28px;border-top:1px solid var(--rule);display:grid;grid-template-columns:1fr 1fr;gap:24px;font-size:13px;color:var(--muted)}
.blog-footer .signoff{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--ink-2)}