:root{color-scheme:light;--theme-bg: #fafafa;--theme-link: #567c77;--theme-text: #22272a;--theme-accent: #cc2a42;--theme-accent-2: #111;--theme-quote: #cc2a42;--theme-menu-bg: #fafafad9;--footer-text: oklch(.551 .027 264.364);--button-bg: oklch(.92 .004 286.32);--ring: oklch(.551 .027 264.364)}:root.dark{color-scheme:dark;--theme-bg: #1d1f21;--theme-link: #d480aa;--theme-text: #c9cacc;--theme-accent: #2bbc89;--theme-accent-2: #eee;--theme-quote: #ccffb6;--theme-menu-bg: #1d1f21d9;--footer-text: oklch(.551 .027 264.364);--button-bg: oklch(.37 .013 285.805);--ring: oklch(.551 .027 264.364)}*,:before,:after{box-sizing:border-box;border:0 solid;margin:0;padding:0}html{min-height:100%;scroll-behavior:smooth;background:var(--theme-bg)}body{min-height:100vh;max-width:48rem;margin-inline:auto;padding:64px 32px 0;display:flex;flex-direction:column;background:var(--theme-bg);color:var(--theme-text);font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-size:16px;font-weight:400;line-height:24px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input{font:inherit;color:inherit}button{cursor:pointer;background:transparent}a{color:inherit;text-decoration:inherit}img,svg{display:block;max-width:100%}ul,ol{list-style:none}main{flex:1 0 auto}h1{color:var(--theme-accent-2);font-size:24px;font-weight:600;line-height:32px;margin-bottom:24px}h2{color:var(--theme-accent-2);font-size:20px;font-weight:600;line-height:28px;margin-bottom:16px}p{margin-bottom:16px}.sr-only,.skip-link{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.skip-link:focus{z-index:100;left:16px;top:16px;width:auto;height:auto;padding:8px 12px;overflow:visible;clip:auto;background:var(--theme-bg);color:var(--theme-accent);outline:2px solid var(--theme-accent)}.site-header{position:relative;display:flex;align-items:flex-start;min-height:64px;margin-bottom:112px;padding-left:72px}.brand-link{position:static;width:200px;color:var(--theme-text)}.logo-mark{position:absolute;left:0;top:0;width:64px;height:64px;overflow:visible}.logo-tile{fill:#17a7ff;stroke:#07171f;stroke-width:2;shape-rendering:geometricPrecision}.logo-b,.logo-d,.logo-f{fill:#008de7}.logo-line{fill:none;stroke:var(--theme-accent-2);stroke-linecap:round;stroke-width:1.5;opacity:.75}.brand-text{display:block;color:var(--theme-text);font-size:24px;font-weight:700;line-height:32px}.main-nav{position:absolute;left:56px;top:36px;display:flex;margin-top:0;color:var(--theme-accent);font-size:16px;line-height:24px}.main-nav a{display:block;padding-inline:16px;color:var(--theme-accent)}.main-nav a+a{border-left:1px dotted oklch(.551 .027 264.364)}.main-nav a:hover,.main-nav a.active{text-decoration:underline;text-underline-offset:3px}.header-actions{display:flex;gap:16px;margin-left:auto;padding-top:12px}.icon-button,.theme-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;color:var(--theme-text);border-radius:6px;transition:box-shadow .15s ease,background-color .15s ease}.icon-button:hover,.theme-button:hover,.icon-button:focus-visible,.theme-button:focus-visible{outline:none;box-shadow:0 0 0 2px var(--ring)}.theme-button{display:inline-flex;background:var(--button-bg);padding:8px}.entry-list{margin-bottom:64px}.entry-list li{display:grid;grid-template-columns:144px minmax(0,1fr);column-gap:16px;margin-bottom:8px;line-height:24px}.entry-list time{color:var(--theme-link);white-space:nowrap}.entry-list a{min-width:0;color:var(--theme-text);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}.entry-list a:hover,.prose-page a:hover,.site-footer a:hover,.social-row a:hover{color:var(--theme-accent)}.note-section{width:100%;margin-top:72px}.note-section p{max-width:48rem;margin-bottom:32px}.section-heading-row{display:flex;align-items:baseline;justify-content:space-between;gap:24px;margin-bottom:16px}.section-heading-row h2{margin-bottom:0}.section-heading-row a{color:var(--theme-accent-2);font-weight:600;text-decoration:none}.section-heading-row a:hover{color:var(--theme-accent);text-decoration:underline;text-underline-offset:3px}.project-showcase{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:28px 32px;margin-top:32px}.project-card{display:grid;grid-template-columns:112px minmax(0,1fr);align-items:center;gap:18px;min-height:112px;color:var(--theme-text)}.project-card-title{display:block;margin-bottom:12px;color:var(--theme-text);font-size:18px;font-weight:600;line-height:24px;text-decoration:underline;text-underline-offset:2px}.project-card-image{display:block;width:112px;aspect-ratio:1;overflow:hidden;border-radius:6px;background:linear-gradient(135deg,color-mix(in srgb,var(--theme-accent) 18%,transparent),transparent 42%),color-mix(in srgb,var(--theme-text) 8%,var(--theme-bg))}.project-card-image img{width:100%;height:100%;object-fit:cover;opacity:.74;filter:saturate(.8);transition:transform .18s ease,opacity .18s ease}.project-card:hover .project-card-image img{opacity:.92;transform:scale(1.025)}.project-card-meta{display:flex;flex-wrap:wrap;gap:8px 14px;margin-top:0;color:var(--theme-link);font-size:14px;font-weight:600;line-height:20px}.prose-page{max-width:65ch}.prose-page p,.prose-page li{color:var(--theme-text)}.prose-page a{color:var(--theme-text);text-decoration:underline;text-underline-offset:2px}.prose-page ul{margin:16px 0 0;padding-left:24px;list-style:disc}.prose-page li{margin-bottom:8px}.detail-stack{display:grid;gap:48px;margin-top:40px}.detail-block h2{margin-bottom:8px}.detail-heading{display:flex;align-items:baseline;justify-content:space-between;gap:24px;margin-bottom:8px}.detail-heading h2{margin-bottom:0}.detail-heading span,.project-meta,.back-link,.inline-list li{color:var(--theme-link)}.prose-page .inline-list{display:flex;flex-wrap:wrap;gap:8px 16px;padding-left:0;list-style:none}.prose-page .inline-list li{margin-bottom:0}.project-page section{margin-top:32px}.project-image-stack{display:grid;gap:24px;margin:32px 0}.project-image{margin:0}.project-image img{width:100%;border-radius:6px}.external-action{display:inline-flex;align-items:center;gap:6px}.search-layer{position:fixed;inset:0;z-index:90;display:flex;align-items:flex-start;justify-content:center;padding:80px 24px 24px;background:color-mix(in srgb,var(--theme-bg) 78%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.search-backdrop{position:absolute;inset:0;width:100%;height:100%;cursor:default}.search-panel{position:relative;width:min(100%,42rem);max-height:calc(100vh - 120px);overflow:hidden;border-radius:6px;background:var(--theme-menu-bg);box-shadow:0 16px 40px #0000002e}.search-panel-header{display:flex;gap:12px;padding:12px;border-bottom:1px dotted oklch(.551 .027 264.364)}.search-panel input{flex:1;min-width:0;padding:8px 10px;border-radius:4px;background:color-mix(in srgb,var(--theme-bg) 92%,var(--theme-text));outline:none}.search-panel input:focus{box-shadow:0 0 0 2px var(--theme-accent)}.search-close{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;border-radius:4px;background:var(--button-bg);font-weight:600}.search-results{max-height:min(420px,calc(100vh - 200px));overflow-y:auto;padding:8px}.search-results a,.empty-search{display:block;padding:10px 12px;border-radius:4px}.search-results a:hover{background:color-mix(in srgb,var(--theme-accent) 10%,transparent)}.search-results span,.search-results small{display:block}.search-results small,.empty-search{color:var(--theme-link);font-size:12px;line-height:16px}.social-row{display:flex;align-items:center;gap:28px;margin-top:80px;color:var(--theme-text)}.social-row a{color:var(--theme-text)}.site-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:80px 0 16px;color:var(--footer-text);font-size:12px;line-height:16px}.site-footer nav{display:flex;align-items:center}.site-footer a{display:block;padding-inline:8px;color:var(--footer-text)}.site-footer a+a{border-left:1px solid var(--footer-text)}@media(max-width:640px){body{padding:32px 24px 0}.site-header{min-height:auto;margin-bottom:80px;padding-left:56px;flex-wrap:wrap}.logo-mark{width:48px;height:48px}.brand-text{font-size:22px;line-height:28px}.main-nav{position:static;order:3;width:100%;margin:8px 0 0 -16px}.main-nav a{padding-inline:12px}.header-actions{gap:8px;padding-top:0}.entry-list li{grid-template-columns:1fr;row-gap:2px}.note-section{width:100%}.section-heading-row{align-items:flex-start}.project-showcase{grid-template-columns:1fr;gap:24px}.project-card{grid-template-columns:104px minmax(0,1fr);gap:16px;min-height:104px}.project-card-image{width:104px}.project-card-title{font-size:16px}.detail-heading,.site-footer{align-items:flex-start;flex-direction:column}.social-row{gap:20px}}
