:root{color-scheme:dark;font-family:IBM Plex Mono,SFMono-Regular,ui-monospace,monospace;line-height:1.6;font-weight:400;color:#dce8ff;background:#2458db;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg: #2458db;--bg-soft: rgba(255, 255, 255, .08);--line: rgba(255, 255, 255, .18);--text: #dce8ff;--muted: #cad9ff;--accent: #ff6ea8;--heading: #f3f7ff}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top left,rgba(255,255,255,.08),transparent 28%),linear-gradient(180deg,#2b62e2 0%,var(--bg) 100%)}a{color:inherit;text-decoration-color:#dce8ff80;text-underline-offset:.24em}#root{min-height:100vh}.page-shell{max-width:1260px;margin:0 auto;padding:24px 32px 72px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:36px}.brand,.nav a{text-decoration:none}.brand{font-size:.95rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.nav{display:flex;gap:20px}.nav a{color:var(--muted)}.nav a.active,.nav a:hover,.brand:hover{color:var(--heading)}.hero-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(300px,420px);gap:48px;align-items:start}.headline,.blog-layout h1,.post-layout h1{font-family:Georgia,Times New Roman,serif;font-weight:400;color:var(--heading)}.headline{font-size:clamp(3.5rem,9vw,5.5rem);line-height:.95;margin:0 0 28px}.accent-dot{color:var(--accent);margin-left:10px}.lede,.intro,.links-list,.project-list,.about-copy,.post-card p,.post-body p{max-width:700px}.lede,.intro,.links-list,.project-list,.about-copy{font-size:clamp(1rem,1.7vw,1.2rem)}.lede,.intro{color:var(--heading)}.hero-copy p{margin-top:0}.links-list,.project-list{list-style:none;padding:0}.links-list{margin:40px 0 52px;display:grid;gap:8px}.links-list a:hover,.inline-link:hover,.post-card h2 a:hover{color:#fff}.wave-block{margin:28px 0 30px;padding:16px 18px;max-width:42rem;overflow:hidden;border:1px solid var(--line);background:#ffffff0f}.wave-track{white-space:nowrap;color:var(--heading);opacity:.9}.wave-a{animation:drift-left 14s linear infinite}.wave-b{animation:drift-right 18s linear infinite}.wave-c{animation:drift-left 12s linear infinite}.panel{margin-top:46px}.panel h2,.section-heading .eyebrow{margin:0 0 20px;font-size:1.75rem;color:var(--heading)}.section-heading .eyebrow{font-size:.95rem;text-transform:uppercase;letter-spacing:.08em}.project-list{display:grid;gap:16px;color:var(--muted);font-style:italic}.project-list li:before{content:"— "}.project-link{color:var(--heading)}.project-tag-link{text-decoration:none}.feed-list{display:grid;gap:18px}.feed-item h3{margin:4px 0 8px;font-size:1.15rem;color:var(--heading)}.feed-item p:last-child{margin-bottom:0}.hero-art{position:sticky;top:24px}.ascii-card{position:relative;width:min(100%,420px);aspect-ratio:1 / .72;margin-left:auto;border:1px solid rgba(255,255,255,.18);overflow:hidden;background:linear-gradient(140deg,#ffffff38,#ffffff14),linear-gradient(45deg,rgba(255,255,255,.12) 25%,transparent 25% 50%,rgba(255,255,255,.08) 50% 75%,transparent 75%);box-shadow:0 20px 80px #071a5433}.portrait-frame{position:relative;width:100%;height:100%;overflow:hidden;background:linear-gradient(140deg,#ffffff14,#ffffff05),linear-gradient(45deg,rgba(255,255,255,.1) 25%,transparent 25% 50%,rgba(255,255,255,.08) 50% 75%,transparent 75%)}.portrait-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(201,217,255,.22) 1px,transparent 1px),linear-gradient(90deg,rgba(201,217,255,.22) 1px,transparent 1px);background-size:10px 10px;pointer-events:none;z-index:1}.portrait-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block;filter:contrast(1.06) brightness(.98);opacity:0;transition:opacity .7s ease}.portrait-image.is-active{opacity:1}.blog-layout,.post-layout{max-width:880px}.posts-grid{display:grid;gap:24px;margin-top:32px}.blog-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:28px}.tag-cloud{display:flex;flex-wrap:wrap;gap:10px}.tag-filter{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line);background:#ffffff0f;color:var(--heading);padding:8px 12px;cursor:pointer;font:inherit}.tag-filter:hover,.tag-filter.active{background:#ffffff24}.tag-count{color:var(--muted)}.archive-link{margin-top:2px}.post-card,.post-layout{border:1px solid var(--line);background:var(--bg-soft);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.post-card{padding:24px}.post-card h2,.post-layout h1{margin:8px 0 14px}.post-cover,.post-hero{width:100%;display:block;object-fit:cover;border:1px solid var(--line)}.post-cover{aspect-ratio:16 / 9;margin-bottom:16px}.post-hero{max-height:420px;margin:8px 0 18px}.post-card h2 a{text-decoration:none}.post-date{color:var(--muted);margin-bottom:0}.tag-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.tag{border:1px solid var(--line);padding:4px 10px;color:var(--heading)}.post-layout{--article-bg: #f8f7f3;--article-line: rgba(48, 42, 34, .14);--article-text: #312f2a;--article-heading: #1f1c18;--article-muted: #6f685d;--article-link: #1f4fb8;--article-link-hover: #163a86;--article-tag-bg: rgba(31, 79, 184, .06);--article-toc-bg: rgba(31, 28, 24, .035);padding:28px;color:var(--article-text);border-color:var(--article-line);background:var(--article-bg);box-shadow:0 18px 48px #0e193824;-webkit-backdrop-filter:none;backdrop-filter:none}.post-layout h1,.post-layout h2,.post-layout .about-copy,.post-layout .tag,.post-layout .project-link{color:var(--article-heading)}.post-layout .post-date,.post-layout .toc-title,.post-layout .post-figure figcaption{color:var(--article-muted)}.post-layout a{color:var(--article-link);text-decoration-color:#2458db52}.post-layout a:hover{color:var(--article-link-hover);text-decoration-color:#163b9966}.post-layout .inline-link{color:var(--article-link)}.post-layout .inline-link:hover,.post-layout .post-card h2 a:hover,.post-layout .table-of-contents a:hover{color:var(--article-link-hover)}.post-layout .tag{border-color:var(--article-line);background:var(--article-tag-bg)}.post-layout .project-tag-link{text-decoration:none}.post-layout .post-hero,.post-layout .post-cover{border-color:var(--article-line)}.archive-list{display:grid;gap:18px;margin-top:28px}.archive-item{border-bottom:1px solid var(--line);padding-bottom:18px}.archive-item h2{margin:6px 0 0}.archive-item h2 a{text-decoration:none}.post-body{margin-top:30px}.inline-link{display:inline-flex;margin-top:8px}@keyframes drift-left{0%{transform:translate(0)}50%{transform:translate(-28px)}to{transform:translate(0)}}@keyframes drift-right{0%{transform:translate(-18px)}50%{transform:translate(18px)}to{transform:translate(-18px)}}@media (max-width: 960px){.page-shell{padding:18px 20px 56px}.topbar,.hero-grid{gap:24px}.hero-grid{grid-template-columns:1fr}.hero-art{position:static;order:-1}.ascii-card{margin:0}}@media (max-width: 640px){.topbar{align-items:flex-start;flex-direction:column}.blog-toolbar{flex-direction:column}}.post-body ul,.post-body ol{max-width:700px;padding-left:1.4rem;color:var(--text)}.post-body blockquote{max-width:700px;margin:20px 0;padding-left:16px;border-left:2px solid var(--accent);color:var(--heading)}.post-section{scroll-margin-top:100px}.post-section h2{margin-top:42px;margin-bottom:16px;font-size:clamp(1.4rem,2.4vw,2rem);color:var(--heading)}.table-of-contents{max-width:700px;margin:28px 0 32px;padding:18px 20px;border:1px solid var(--line);background:#ffffff0d}.toc-title{margin:0 0 10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.table-of-contents ol{margin:0;padding-left:1.4rem}.table-of-contents a{text-decoration:none}.table-of-contents a:hover{color:var(--heading)}.post-layout .post-body p,.post-layout .post-body ul,.post-layout .post-body ol,.post-layout .post-body li,.post-layout .post-body blockquote{color:var(--article-text)}.post-layout .post-body h2,.post-layout .post-body h3,.post-layout .post-section h2{color:var(--article-heading)}.post-layout .table-of-contents{border-color:var(--article-line);background:var(--article-toc-bg)}.post-layout .post-body blockquote{border-left-color:#1f4fb847;background:#1f4fb80b;padding:14px 18px}.post-layout .table-of-contents li+li{margin-top:8px}.post-layout .table-of-contents .toc-level-3{margin-left:16px}.post-body h2,.post-body h3{max-width:700px;scroll-margin-top:100px}.post-body h3{margin-top:28px;margin-bottom:12px;font-size:clamp(1.1rem,2vw,1.35rem)}.post-body-html>*{max-width:700px}.post-body-html figure,.post-body-html .code-block,.post-body-html .embed-frame,.post-body-html iframe,.post-body-html video{max-width:100%}.post-body-html figure{margin:24px 0}.post-body-html figcaption{margin-bottom:10px;color:var(--article-muted);font-size:.95rem}.post-body-html pre{margin:0;overflow-x:auto;padding:18px 20px;border:1px solid var(--article-line);background:#f0ede6;color:#1f1c18;box-shadow:inset 0 1px #ffffff73}.post-body-html code{display:block;font-family:IBM Plex Mono,SFMono-Regular,ui-monospace,monospace;font-size:.95rem;line-height:1.7;white-space:pre;-moz-tab-size:4;tab-size:4}.post-body-html .embed-frame,.post-body-html iframe{display:block;width:100%;margin:24px 0;border:0}.post-body-html img{width:100%;display:block;border:1px solid var(--article-line)}.code-block{max-width:760px;margin:24px 0}.code-block figcaption{margin-bottom:10px;color:var(--article-muted);font-size:.95rem}.code-block pre{margin:0;overflow-x:auto;padding:18px 20px;border:1px solid var(--article-line);background:#f0ede6;color:#1f1c18;box-shadow:inset 0 1px #ffffff73}.code-block code{display:block;font-family:IBM Plex Mono,SFMono-Regular,ui-monospace,monospace;font-size:.95rem;line-height:1.7;white-space:pre;-moz-tab-size:4;tab-size:4}.code-line{display:inline}.token-comment{color:#7f7464}.token-string{color:#0f766e}.token-keyword{color:#8b2fc9}.token-number{color:#b45309}.token-operator{color:#475569}.post-figure{max-width:700px;margin:24px 0}.post-figure figcaption{color:var(--muted);font-size:.95rem}
