.read-progress{position:fixed;top:0;left:0;right:0;height:3px;background:transparent;z-index:60;pointer-events:none}.read-progress span{display:block;height:100%;width:0%;background:var(--accent);box-shadow:0 0 0 1px color-mix(in oklab,var(--accent) 40%,transparent);transition:width .08s linear}.measure{max-width:720px;margin-inline:auto}.post-top{padding-block:clamp(2rem,4vw,3.25rem) clamp(1.25rem,2.5vw,2rem)}.crumb{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.06em;color:var(--ink-muted);margin-bottom:1.6rem;display:flex;gap:.55rem;align-items:center;flex-wrap:wrap}.crumb a{color:var(--ink-muted);text-decoration:none}.crumb a:hover{color:var(--accent-ink)}.crumb .sep{color:var(--ink-faint)}.crumb .here{color:var(--ink)}.post-meta-row{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;font-family:var(--font-mono);font-size:.76rem;letter-spacing:.04em;color:var(--ink-muted);margin-bottom:1.1rem}.post-meta-row .sep{color:var(--ink-faint)}.post-title{font-family:var(--font-display);font-weight:600;font-size:clamp(2.1rem,5.2vw,3.4rem);line-height:1.06;letter-spacing:-.015em;margin:0 0 1.1rem;text-wrap:balance}.post-dek{font-size:clamp(1.12rem,2.2vw,1.32rem);line-height:1.55;color:var(--ink-soft);margin:0}.post-dek code{font-family:var(--font-mono);font-size:.92em;background:var(--surface-2);border:1px solid var(--line);border-radius:4px;padding:.06em .34em}.byline{display:flex;align-items:center;gap:.85rem;margin-top:1.8rem}.byline img{width:44px;height:44px;border-radius:50%;object-fit:cover;object-position:top;border:1px solid var(--line-strong)}.byline-text{display:flex;flex-direction:column;line-height:1.3}.byline-name{font-weight:600;color:var(--ink)}.byline-sub{font-size:.84rem;color:var(--ink-muted)}.post-body{padding-top:clamp(1.5rem,3vw,2.4rem)}.post-body>*{margin-block:0 1.35rem}.post-body p{font-size:1.12rem;line-height:1.72;color:var(--ink)}.post-body>p:first-of-type:first-letter{font-family:var(--font-display);font-weight:600;float:left;font-size:3.4em;line-height:.78;padding:.06em .12em 0 0;color:var(--accent-ink)}.post-body h2{font-family:var(--font-display);font-weight:600;font-size:clamp(1.5rem,3vw,1.95rem);line-height:1.18;letter-spacing:-.01em;margin-top:2.6rem;color:var(--ink)}.post-body h2 code{font-size:.86em}.post-body ul{padding-left:0;list-style:none;display:flex;flex-direction:column;gap:.7rem}.post-body ul li{position:relative;padding-left:1.5rem;font-size:1.08rem;line-height:1.62;color:var(--ink)}.post-body ul li:before{content:"";position:absolute;left:.15rem;top:.72em;width:7px;height:7px;background:var(--accent);border-radius:1px;transform:rotate(45deg)}.post-body strong{font-weight:600;color:var(--ink)}.post-body a{color:var(--accent-ink);text-decoration:underline;text-decoration-color:color-mix(in oklab,var(--accent) 45%,transparent);text-underline-offset:3px}.post-body a:hover{text-decoration-color:var(--accent)}.post-body figure{margin:2rem 0}.post-body figure img{width:100%;height:auto;border-radius:var(--radius-lg);border:1px solid var(--line);box-shadow:var(--shadow-photo);display:block}.post-body figcaption{margin-top:.7rem;font-family:var(--font-body);font-size:.88rem;line-height:1.45;color:var(--ink-muted);text-align:center;font-style:italic}.post-body figure.float-right{float:right;width:min(38%,280px);margin:.3rem 0 1.25rem 2rem}.post-note{font-size:.92rem;color:var(--ink-muted);font-style:italic}.post-body code,.post-dek code,.post-meta-row code{font-family:var(--font-mono);font-size:.88em;background:var(--surface-2);border:1px solid var(--line);border-radius:4px;padding:.08em .36em;color:var(--accent-ink);white-space:nowrap}.pullquote{margin:2.4rem 0;padding:.2rem 0 .2rem 1.5rem;border-left:3px solid var(--accent);font-family:var(--font-display);font-weight:500;font-size:clamp(1.4rem,3vw,1.85rem);line-height:1.32;color:var(--ink);letter-spacing:-.01em}.post-body blockquote:not(.pullquote){margin:1.8rem 0;padding:.15rem 0 .15rem 1.25rem;border-left:3px solid var(--accent);color:var(--ink-soft);font-style:italic}.post-body blockquote:not(.pullquote) p{color:inherit}.callout{margin:2rem 0;background:var(--surface-2);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--radius);padding:1.1rem 1.3rem}.callout p{margin:0;font-size:1.02rem;color:var(--ink-soft)}.post-body pre{margin:1.8rem 0;background:#232118;border:1px solid #3a362a;border-radius:var(--radius-lg);padding:1.2rem 1.35rem;overflow-x:auto;box-shadow:var(--shadow-card);-webkit-overflow-scrolling:touch}.post-body pre code{font-family:var(--font-mono);font-size:.86rem;line-height:1.7;color:#e8dcc4;background:none;border:0;padding:0;white-space:pre;display:block}.tok-kw{color:#d39074}.tok-str{color:#a7bd84}.tok-fn{color:#84b2d1}.tok-value{color:#d9b873}.tok-attr{color:#d39074}.tok-sel{color:#ece0c8}.tok-comment{color:#8d8268;font-style:italic}.post-bio{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--line);display:flex;gap:1.1rem;align-items:flex-start}.post-bio img{width:60px;height:60px;border-radius:50%;object-fit:cover;object-position:top;border:1px solid var(--line-strong);flex-shrink:0}.post-bio-label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin:0 0 .3rem}.post-bio-name{font-family:var(--font-display);font-weight:600;font-size:1.2rem;margin:0 0 .35rem}.post-bio-name a{color:var(--ink);text-decoration:none}.post-bio-name a:hover{color:var(--accent-ink)}.post-bio p.bio-text{margin:0;font-size:.96rem;color:var(--ink-muted);line-height:1.55}.post-endcap{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--line)}.post-endcap-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.post-endcap-label{margin:0;color:var(--ink-faint);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase}.post-nav-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.post-nav-card{display:flex;flex-direction:column;min-height:11rem;padding:1.15rem;border:1px solid var(--line);border-radius:var(--radius-lg);background:color-mix(in oklab,var(--surface) 88%,white 12%);box-shadow:var(--shadow-card);color:inherit;text-decoration:none;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.post-nav-card:hover,.post-nav-card:focus-visible{transform:translateY(-2px);border-color:var(--line-strong);box-shadow:0 16px 40px -28px #2c2a248c}.post-nav-card:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.post-nav-kicker{color:var(--accent-ink);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase}.post-nav-title{margin-top:.7rem;color:var(--ink);font-size:1.25rem;font-weight:600;line-height:1.16}.post-nav-meta{display:flex;flex-wrap:wrap;gap:.45rem .7rem;margin-top:.75rem;color:var(--ink-muted);font-size:.78rem}.post-nav-direction{display:inline-flex;align-items:center;gap:.4rem;margin-top:auto;padding-top:1rem;color:var(--ink-faint);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}.post-nav-arrow{transition:transform .18s ease}.post-nav-arrow.is-left{transform:rotate(180deg)}.post-nav-card:hover .post-nav-arrow:not(.is-left){transform:translate(3px)}.post-nav-card:hover .post-nav-arrow.is-left{transform:rotate(180deg) translate(3px)}.post-foot{margin-top:2.2rem;display:flex;align-items:center;justify-content:flex-end;gap:1rem;flex-wrap:wrap}.back-link{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-muted);text-decoration:none;display:inline-flex;align-items:center;gap:.45em}.back-link:hover{color:var(--accent-ink)}.back-link .arrow{transform:rotate(180deg);transition:transform .16s ease}.back-link:hover .arrow{transform:rotate(180deg) translate(3px)}.share-row{display:flex;align-items:center;gap:.6rem}.share-row .lbl{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint)}.share-btn{width:36px;height:36px;display:grid;place-items:center;border:1px solid var(--line-strong);border-radius:var(--radius);background:var(--surface);color:var(--ink-soft);cursor:pointer;text-decoration:none;transition:border-color .15s ease,color .15s ease,background .15s ease}.share-btn:hover,.share-btn.copied{border-color:var(--accent);color:var(--accent-ink);background:color-mix(in oklab,var(--accent) 9%,var(--surface))}.share-btn svg{width:17px;height:17px}.post-related{border-top:1px solid var(--line);padding-top:clamp(2rem,4vw,3rem)}.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2rem}.related-card{display:flex;flex-direction:column;gap:.7rem;padding:1.4rem;text-decoration:none}.related-card .post-meta-row{margin-bottom:0}.related-title{font-family:var(--font-display);font-weight:600;font-size:1.18rem;line-height:1.2;color:var(--ink);margin:0}.related-desc{font-size:.92rem;color:var(--ink-muted);line-height:1.5;margin:0}.related-card .case-link{margin-top:auto}@media(max-width:760px){.post-endcap-head{align-items:flex-start;flex-direction:column}.post-nav-grid,.related-grid{grid-template-columns:1fr}.post-body figure.float-right{float:none;width:100%;margin:1.5rem 0}}
