@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.relative{position:relative}.static{position:static}.sticky{position:sticky}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.inline{display:inline}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}.underline{text-decoration-line:underline}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}:root{--font-sans:"Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, system-ui, "Apple SD Gothic Neo", sans-serif;--font-mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;--bg:#fafaf7;--bg-2:#f3f1ec;--bg-3:#ecebe4;--ink:#14140f;--ink-2:#4a4942;--ink-3:#7a7870;--ink-4:#b6b3a8;--rule:#e2dfd6;--rule-strong:#cdc9bd;--accent:oklch(62% .13 150);--accent-soft:oklch(62% .13 150/.1);--accent-ink:oklch(42% .1 150);--tag-bg:#ece9df;--tag-ink:#3a3930;--content-w:760px;--content-w-wide:1040px;--fs-base:16.5px;--lh-base:1.72;--fs-h:17px}html[data-density=compact]{--fs-base:14.5px;--lh-base:1.6;--fs-h:14.5px}html[data-theme=dark]{--bg:#0d0d0a;--bg-2:#16161220;--bg-3:#1f1e18;--ink:#e8e6df;--ink-2:#b3b1a8;--ink-3:#7d7b73;--ink-4:#4a4942;--rule:#26251e;--rule-strong:#38362c;--accent:oklch(72% .13 150);--accent-soft:oklch(72% .13 150/.16);--accent-ink:oklch(82% .13 150);--tag-bg:#1f1e18;--tag-ink:#c9c7be}*,:before,:after{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-sans);background:var(--bg);color:var(--ink);font-size:var(--fs-base);line-height:var(--lh-base);font-feature-settings:"ss01","ss02","case","tnum";-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;word-break:keep-all;transition:background .2s,color .2s}button{font-family:inherit}::selection{background:var(--accent-soft);color:var(--accent-ink)}.app{flex-direction:column;min-height:100vh;display:flex}.page-wrap{flex:1}.nav{z-index:50;-webkit-backdrop-filter:blur(14px)saturate(140%);background:var(--bg);position:sticky;top:0}@supports (color:color-mix(in lab,red,red)){.nav{background:color-mix(in oklab,var(--bg) 78%,transparent)}}.nav{border-bottom:1px solid var(--rule)}.nav-inner{max-width:var(--content-w-wide);justify-content:space-between;align-items:center;gap:24px;margin:0 auto;padding:14px 28px;display:flex}.nav-brand{cursor:pointer;font-family:var(--font-mono);color:var(--ink);background:0 0;border:0;align-items:baseline;gap:6px;padding:0;font-size:13.5px;font-weight:500;display:flex}.nav-brand-mark{color:var(--accent-ink);font-weight:600}.nav-brand-cursor{background:var(--accent);width:7px;height:14px;margin-left:2px;animation:1.1s step-end infinite blink;display:inline-block;transform:translateY(2px)}@keyframes blink{50%{opacity:0}}.nav-items{align-items:center;gap:4px;display:flex}.nav-item{cursor:pointer;color:var(--ink-2);background:0 0;border:0;border-radius:6px;flex-direction:column;align-items:flex-start;gap:0;padding:8px 12px;font-size:13.5px;line-height:1.2;display:flex}.nav-item:hover{background:var(--bg-3);color:var(--ink)}.nav-item.is-current{color:var(--ink)}.nav-item.is-current .nav-item-mono{color:var(--accent-ink)}.nav-item-mono{font-family:var(--font-mono);color:var(--ink-3);font-size:10.5px}.nav-item-label{font-weight:500}.nav-theme{border:1px solid var(--rule);cursor:pointer;color:var(--ink-2);font-family:var(--font-mono);background:0 0;border-radius:6px;margin-left:8px;padding:6px 10px;font-size:11.5px}.nav-theme:hover{border-color:var(--rule-strong);color:var(--ink)}.page{max-width:var(--content-w);margin:0 auto;padding:72px 28px 96px}.page-home,.page-blog{max-width:var(--content-w-wide)}.page-project{max-width:var(--content-w)}.hero{border-bottom:1px solid var(--rule);margin-bottom:56px;padding:24px 0 56px}.hero-mono{font-family:var(--font-mono);color:var(--ink-3);margin-bottom:18px;font-size:11.5px}.hero-h{letter-spacing:-.025em;flex-wrap:wrap;align-items:baseline;gap:14px;margin:0 0 18px;font-size:clamp(28px,4vw,38px);font-weight:700;line-height:1.05;display:flex}.hero-name{color:var(--ink)}.hero-divider{color:var(--ink-4);font-weight:300}.hero-role{color:var(--ink-2);font-weight:400}.hero-meta{font-family:var(--font-mono);color:var(--ink-3);flex-wrap:wrap;gap:18px;margin-bottom:28px;font-size:12px;display:flex}.hm-k{color:var(--ink-4);margin-right:6px}.hero-bio{max-width:860px;color:var(--ink-2);font-size:16px;line-height:1.78}.hero-bio p{margin:0 0 12px}.hero-bio p:last-child{margin:0}.section{margin-bottom:64px}.sect-title{align-items:baseline;gap:14px;margin-bottom:28px;display:flex}.sect-title-mono{font-family:var(--font-mono);color:var(--accent-ink);font-size:12px}.sect-title-h{letter-spacing:-.01em;color:var(--ink);margin:0;font-size:22px;font-weight:600}.sect-title-count{font-family:var(--font-mono);color:var(--ink-3);font-size:12px}.sect-title-rule{background:var(--rule);flex:1;height:1px;margin-left:8px}.tag{font-family:var(--font-mono);color:var(--tag-ink);background:var(--tag-bg);white-space:nowrap;border-radius:4px;align-items:center;padding:2.5px 7px;font-size:11px;line-height:1.5;display:inline-flex}.exp-list{flex-direction:column;display:flex}.exp{border-top:1px solid var(--rule);grid-template-columns:200px 1fr;gap:32px;padding:28px 0;display:grid}.exp:last-child{border-bottom:1px solid var(--rule)}.exp-meta{font-family:var(--font-mono);color:var(--ink-3);padding-top:4px;font-size:11.5px}.exp-period{color:var(--ink-2);margin-bottom:4px;font-weight:500}.exp-loc{color:var(--ink-3)}.exp-head{flex-wrap:wrap;align-items:baseline;gap:12px;margin-bottom:12px;display:flex}.exp-company{letter-spacing:-.01em;margin:0;font-size:19px;font-weight:600}.exp-role{color:var(--ink-2);font-size:14.5px}.exp-bullets{flex-direction:column;gap:6px;margin:0 0 14px;padding:0;list-style:none;display:flex}.exp-bullets li{color:var(--ink-2);gap:10px;font-size:14.5px;line-height:1.65;display:flex}.exp-bullet-mark{color:var(--accent-ink);font-family:var(--font-mono);font-weight:600}.exp-stack{flex-wrap:wrap;gap:6px;display:flex}.pc-grid{gap:16px;display:grid}.pc-grid-minimal,.pc-grid-terminal{grid-template-columns:repeat(2,1fr)}.pc-grid-hover{grid-template-columns:repeat(3,1fr)}@media(max-width:720px){.pc-grid-minimal,.pc-grid-terminal,.pc-grid-hover{grid-template-columns:1fr}}.pc{text-align:left;cursor:default;color:inherit;background:0 0;border:0;padding:0;font-family:inherit}.pc-link{cursor:pointer}.pc-min{border:1px solid var(--rule);background:var(--bg);border-radius:8px;flex-direction:column;gap:10px;padding:18px 20px;transition:border-color .16s,transform .16s;display:flex}.pc-min:hover{border-color:var(--rule-strong)}.pc-link.pc-min:hover{transform:translateY(-1px)}.pc-min-top{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.pc-min-name{letter-spacing:-.005em;font-size:15.5px;font-weight:600}.pc-min-period{font-family:var(--font-mono);color:var(--ink-3);font-size:11px}.pc-min-desc{color:var(--ink-2);margin:0;font-size:14px;line-height:1.6}.pc-min-stack{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.pc-min-arrow{color:var(--accent-ink);font-family:var(--font-mono);margin-left:auto;font-size:13px}.pc-min-with-thumb{flex-direction:row;gap:16px}.pc-min-thumb{border-radius:6px;flex-shrink:0;width:80px;height:80px;overflow:hidden}.pc-min-thumb img{object-fit:cover;width:100%;height:100%}.pc-min-content{flex-direction:column;flex:1;gap:10px;min-width:0;display:flex}@media(max-width:720px){.pc-min-thumb{width:60px;height:60px}}.pc-hov{border:1px solid var(--rule);background:var(--bg);border-radius:8px;height:220px;transition:border-color .2s;position:relative;overflow:hidden}.pc-hov:hover{border-color:var(--accent)}.pc-hov-front,.pc-hov-back{flex-direction:column;padding:18px;transition:transform .32s cubic-bezier(.6,.05,.3,1),opacity .22s;display:flex;position:absolute;inset:0}.pc-hov-front{justify-content:space-between}.pc-hov-name{letter-spacing:-.01em;font-size:18px;font-weight:600}.pc-hov-period{font-family:var(--font-mono);color:var(--ink-3);font-size:11px}.pc-hov-back{background:var(--bg-2);opacity:0;gap:10px;transform:translateY(100%)}.pc-hov:hover .pc-hov-front{opacity:0;transform:translateY(-30%)}.pc-hov:hover .pc-hov-back{opacity:1;transform:translateY(0)}.pc-hov-desc{color:var(--ink-2);margin:0;font-size:13.5px;line-height:1.55}.pc-hov-stack{flex-wrap:wrap;gap:5px;display:flex}.pc-hov-cta{font-family:var(--font-mono);color:var(--accent-ink);margin-top:auto;font-size:11.5px}.pc-term{background:var(--bg-3);border:1px solid var(--rule);font-family:var(--font-mono);border-radius:6px;flex-direction:column;gap:6px;padding:14px 16px;font-size:12px;transition:border-color .16s;display:flex}.pc-term:hover{border-color:var(--accent)}.pc-term-head{color:var(--ink-3);border-bottom:1px dashed var(--rule);gap:8px;margin-bottom:4px;padding-bottom:6px;display:flex}.pc-term-prompt{color:var(--accent-ink)}.pc-term-cmd{color:var(--ink-2)}.pc-term-line{color:var(--ink-2);line-height:1.55}.pc-term-desc{color:var(--ink);padding:4px 0}.pc-term-key{color:var(--accent-ink)}.pc-term-stackitem{color:var(--ink-2)}.pc-term-foot{font-family:var(--font-mono);color:var(--accent-ink);margin-top:6px;font-size:11px}.contact-grid{border-top:1px solid var(--rule);flex-direction:column;display:flex}.contact-row{border-bottom:1px solid var(--rule);color:var(--ink);cursor:pointer;grid-template-columns:120px 1fr;align-items:baseline;gap:16px;padding:14px 0;text-decoration:none;display:grid}.contact-row:hover{background:var(--bg-2)}.contact-k{font-family:var(--font-mono);color:var(--ink-3);font-size:12px}.contact-v{font-size:15px}.section-foot{margin-bottom:0}.blog-header{border-bottom:1px solid var(--rule);margin-bottom:32px;padding:24px 0 36px}.blog-header-mono{font-family:var(--font-mono);color:var(--ink-3);margin-bottom:14px;font-size:11.5px}.blog-h{letter-spacing:-.025em;margin:0 0 12px;font-size:clamp(34px,4.5vw,48px);font-weight:700}.blog-sub{color:var(--ink-2);margin:0;font-size:16px}.blog-sub-mono{font-family:var(--font-mono);color:var(--ink-3);margin-left:8px;font-size:12px}.blog-tags{flex-wrap:wrap;gap:6px;margin-bottom:36px;display:flex}.chip{border:1px solid var(--rule);font-family:var(--font-mono);color:var(--ink-2);cursor:pointer;background:0 0;border-radius:999px;align-items:center;gap:6px;padding:6px 11px;font-size:11.5px;display:inline-flex}.chip:hover{border-color:var(--rule-strong);color:var(--ink)}.chip.is-on{background:var(--ink);color:var(--bg);border-color:var(--ink)}.chip.is-on .chip-count{color:var(--ink-4)}.chip-count{color:var(--ink-3);font-size:10.5px}.chip-mark{color:var(--accent-ink)}.post-feat{cursor:pointer;border:1px solid var(--rule);background:linear-gradient(180deg,var(--bg-2) 0%,var(--bg) 100%);color:inherit;border-radius:12px;margin-bottom:36px;padding:28px 28px 26px;text-decoration:none;transition:border-color .16s;display:block}.post-feat:hover{border-color:var(--accent)}.post-feat-tag-row{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:14px;display:flex}.post-feat-mono{font-family:var(--font-mono);color:var(--accent-ink);padding-right:6px;font-size:11px}.post-feat-title{letter-spacing:-.015em;margin:0 0 10px;font-size:26px;font-weight:600}.post-feat-excerpt{color:var(--ink-2);max-width:640px;margin:0 0 16px;font-size:15px;line-height:1.6}.post-feat-foot{font-family:var(--font-mono);color:var(--ink-3);justify-content:space-between;font-size:11.5px;display:flex}.post-feat-read{color:var(--accent-ink)}.post-list{border-top:1px solid var(--rule);margin:0;padding:0;list-style:none}.post-row{border-bottom:1px solid var(--rule)}.post-row-btn{cursor:pointer;text-align:left;width:100%;color:inherit;font:inherit;background:0 0;border:0;grid-template-columns:110px 1fr auto;align-items:baseline;gap:18px;padding:14px 0;display:grid}.post-row-btn:hover{color:var(--accent-ink)}.post-row-date{font-family:var(--font-mono);color:var(--ink-3);font-size:11.5px}.post-row-title{color:inherit;font-size:15.5px}.post-row-tags{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.post-row-tag{font-family:var(--font-mono);color:var(--ink-3);font-size:10.5px}@media(max-width:720px){.post-row-btn{grid-template-columns:90px 1fr}.post-row-tags{display:none}}.post-timeline{flex-direction:column;gap:36px;display:flex}.post-year{grid-template-columns:80px 1fr;gap:28px;display:grid}.post-year-mark{font-family:var(--font-mono);color:var(--ink-4);letter-spacing:-.02em;padding-top:10px;font-size:28px;font-weight:600}.post-year-list{border-top:1px solid var(--rule);margin:0;padding:0;list-style:none}@media(max-width:720px){.post-year{grid-template-columns:1fr;gap:4px}.post-year-mark{padding-top:0;font-size:20px}}.post-cards{grid-template-columns:repeat(2,1fr);gap:18px;display:grid}.post-card{border:1px solid var(--rule);cursor:pointer;text-align:left;color:inherit;font:inherit;background:0 0;border-radius:8px;flex-direction:column;padding:0;transition:border-color .16s,transform .16s;display:flex;overflow:hidden}.post-card:hover{border-color:var(--rule-strong);transform:translateY(-2px)}.post-card-thumb{aspect-ratio:16/9;background:repeating-linear-gradient(45deg,var(--bg-2) 0 8px,var(--bg-3) 8px 16px);font-family:var(--font-mono);color:var(--ink-3);justify-content:center;align-items:center;font-size:12px;display:flex}.post-card-thumb span:before{content:"[ "}.post-card-thumb span:after{content:" ]"}.post-card-body{flex-direction:column;gap:8px;padding:14px 16px 16px;display:flex}.post-card-date{font-family:var(--font-mono);color:var(--ink-3);font-size:11px}.post-card-title{margin:0;font-size:15px;font-weight:600;line-height:1.4}.post-card-tags{flex-wrap:wrap;gap:5px;display:flex}@media(max-width:720px){.post-cards{grid-template-columns:1fr}}.pager{justify-content:center;align-items:center;gap:4px;margin-top:48px;display:flex}.pager-num,.pager-arrow{border:1px solid var(--rule);cursor:pointer;width:36px;height:36px;font-family:var(--font-mono);color:var(--ink-2);background:0 0;border-radius:6px;justify-content:center;align-items:center;font-size:12px;text-decoration:none;display:inline-flex}.pager-num:hover,.pager-arrow:not(:disabled):hover{border-color:var(--rule-strong);color:var(--ink)}.pager-num.is-on{background:var(--ink);color:var(--bg);border-color:var(--ink)}.pager-arrow:disabled{opacity:.3;cursor:not-allowed}.page-post{max-width:var(--content-w);margin:0 auto;padding:72px 28px 96px}.page-post:has(.toc){grid-template-columns:minmax(0,var(--content-w)) 220px;max-width:calc(var(--content-w) + 280px);align-items:start;gap:60px;display:grid}@media(max-width:980px){.page-post:has(.toc){max-width:var(--content-w);grid-template-columns:1fr}.toc{display:none}}.post-progress{background:var(--accent);transform-origin:0;z-index:60;height:2px;transition:transform 80ms linear;position:fixed;top:0;left:0;right:0}.post-back{cursor:pointer;color:var(--ink-3);font-family:var(--font-mono);background:0 0;border:0;align-items:center;gap:6px;margin-bottom:28px;padding:0;font-size:12px;display:inline-flex}.post-back:hover{color:var(--ink)}.post-head{border-bottom:1px solid var(--rule);margin-bottom:40px;padding-bottom:28px}.post-head-meta{font-family:var(--font-mono);color:var(--ink-3);align-items:center;gap:8px;margin-bottom:18px;font-size:11.5px;display:flex}.post-head-dot{color:var(--ink-4)}.post-h{letter-spacing:-.02em;text-wrap:pretty;margin:0 0 18px;font-size:clamp(30px,4vw,40px);font-weight:700;line-height:1.18}.post-head-tags{flex-wrap:wrap;gap:6px;display:flex}.post-body{color:var(--ink);font-size:17px;line-height:1.8}.post-body a{color:var(--accent-ink);text-underline-offset:3px;text-decoration:underline;-webkit-text-decoration-color:var(--accent-soft);text-decoration-color:var(--accent-soft)}.post-body a:hover{-webkit-text-decoration-color:var(--accent);text-decoration-color:var(--accent)}.post-body p{text-wrap:pretty;margin:0 0 22px}.post-body h2{letter-spacing:-.01em;margin:48px 0 16px;scroll-margin-top:80px;font-size:22px;font-weight:600}.h-anchor{color:var(--ink-4);font-family:var(--font-mono);margin-right:4px;font-weight:400;text-decoration:none}.h-anchor:hover{color:var(--accent-ink)}.post-ul,.post-body ul,.proj-body ul{margin:0 0 22px;padding-left:1.2em;list-style:outside}.post-ul li,.post-body ul li,.proj-body ul li{margin:6px 0}.post-body ol,.proj-body ol{margin:0 0 22px;padding-left:1.2em}.post-body ol li,.proj-body ol li{margin:6px 0}.post-body table,.proj-body table{border-collapse:collapse;width:100%;margin:0 0 24px;font-size:14.5px;line-height:1.6}.post-body thead,.proj-body thead{border-bottom:2px solid var(--rule-strong)}.post-body th,.proj-body th{text-align:left;font-family:var(--font-mono);color:var(--ink-3);text-transform:uppercase;letter-spacing:.04em;padding:10px 14px;font-size:12px;font-weight:600}.post-body td,.proj-body td{border-bottom:1px solid var(--rule);color:var(--ink);padding:10px 14px}.post-body tbody tr:hover,.proj-body tbody tr:hover{background:var(--bg-2)}.code{background:var(--bg-3);border:1px solid var(--rule);border-radius:8px;margin:0 0 24px;padding:0;overflow:hidden}.code-bar{border-bottom:1px solid var(--rule);padding:8px 14px;display:flex}.code-lang{font-family:var(--font-mono);color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;font-size:10.5px}.code code{font-family:var(--font-mono);color:var(--ink);white-space:pre;padding:14px 16px;font-size:13px;line-height:1.7;display:block;overflow-x:auto}html[data-theme=light] .shiki,html:not([data-theme]) .shiki{background-color:var(--bg-3)!important}html[data-theme=light] .shiki span,html:not([data-theme]) .shiki span{color:var(--shiki-light)!important}html[data-theme=dark] .shiki{background-color:var(--bg-3)!important}html[data-theme=dark] .shiki span{color:var(--shiki-dark)!important}.post-body pre.astro-code,.proj-body pre.astro-code{border:1px solid var(--rule);white-space:pre-wrap;word-wrap:break-word;font-family:var(--font-mono);border-radius:8px;margin:0 0 24px;padding:14px 16px;font-size:13px;line-height:1.7;overflow-x:hidden;background:var(--bg-3)!important}.post-body pre.astro-code code,.proj-body pre.astro-code code{font-family:inherit;font-size:inherit;line-height:inherit;color:var(--ink);background:0 0;padding:0}.post-body :not(pre)>code,.proj-body :not(pre)>code{background:var(--bg-3);font-family:var(--font-mono);color:var(--ink);border-radius:4px;padding:2px 6px;font-size:.85em}.post-foot{border-top:1px solid var(--rule);margin-top:64px;padding-top:28px}.post-foot-meta{font-family:var(--font-mono);color:var(--ink-3);margin-bottom:24px;font-size:11.5px}.post-nav{grid-template-columns:1fr 1fr;gap:12px;display:grid}.post-nav-btn{background:var(--bg-2);border:1px solid var(--rule);cursor:pointer;text-align:left;color:inherit;font:inherit;border-radius:8px;flex-direction:column;gap:6px;padding:14px 16px;transition:border-color .16s;display:flex}.post-nav-btn:hover{border-color:var(--accent)}.post-nav-next{text-align:right}.post-nav-mono{font-family:var(--font-mono);color:var(--ink-3);font-size:11px}.post-nav-title{color:var(--ink);font-size:14px;line-height:1.4}.post-nav-empty{display:block}.toc{align-self:start;position:sticky;top:80px}.toc-label{font-family:var(--font-mono);color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;font-size:10.5px}.toc ul{border-left:1px solid var(--rule);margin:0;padding:0;list-style:none}.toc li{padding:0}.toc li a{color:var(--ink-3);border-left:2px solid #0000;margin-left:-1px;padding:6px 12px;font-size:12.5px;line-height:1.4;text-decoration:none;transition:color .12s,border-color .12s;display:block}.toc li a:hover{color:var(--ink)}.toc li.is-on a{color:var(--accent-ink);border-left-color:var(--accent)}.proj-head{border-bottom:1px solid var(--rule);margin-bottom:32px;padding-bottom:24px}.proj-head-mono{font-family:var(--font-mono);color:var(--accent-ink);margin-bottom:14px;font-size:11.5px}.proj-h{letter-spacing:-.025em;margin:0 0 16px;font-size:clamp(34px,4.5vw,44px);font-weight:700}.proj-summary{color:var(--ink-2);max-width:640px;margin:0;font-size:17px;line-height:1.7}.proj-meta{grid-template-columns:repeat(3,1fr);gap:24px;margin:0 0 36px;padding:0;display:grid}@media(max-width:720px){.proj-meta{grid-template-columns:1fr;gap:14px}}.proj-meta>div{flex-direction:column;gap:6px;display:flex}.proj-meta dt{font-family:var(--font-mono);color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;font-size:10.5px}.proj-meta dd{color:var(--ink);margin:0;font-size:14.5px}.proj-meta-stack{flex-wrap:wrap;gap:5px;display:flex}.proj-shot{border:1px solid var(--rule);background:var(--bg-2);border-radius:8px;margin:0 0 36px;overflow:hidden}.proj-shot-bar{border-bottom:1px solid var(--rule);background:var(--bg-3);align-items:center;gap:6px;padding:10px 14px;display:flex}.proj-shot-dot{background:var(--rule-strong);border-radius:50%;width:9px;height:9px}.proj-shot-url{font-family:var(--font-mono);color:var(--ink-3);margin-left:16px;font-size:11px}.proj-shot-canvas{aspect-ratio:16/9;background:repeating-linear-gradient(135deg,var(--bg-2) 0 12px,var(--bg-3) 12px 24px);justify-content:center;align-items:center;display:flex}.proj-shot-label{font-family:var(--font-mono);color:var(--ink-3);font-size:12px}.proj-shot-alt .proj-shot-canvas{background:repeating-linear-gradient(45deg,var(--bg-2) 0 12px,var(--bg-3) 12px 24px)}.proj-metrics{grid-template-columns:repeat(3,1fr);gap:12px;margin:0 0 48px;display:grid}@media(max-width:720px){.proj-metrics{grid-template-columns:1fr}}.proj-metric{background:var(--bg-2);border:1px solid var(--rule);border-radius:8px;padding:18px 16px}.proj-metric-v{letter-spacing:-.015em;color:var(--ink);margin-bottom:4px;font-size:22px;font-weight:600}.proj-metric-k{font-family:var(--font-mono);color:var(--ink-3);font-size:11px}.proj-body{flex-direction:column;margin:0 0 36px;display:flex}.proj-body p{text-wrap:pretty;margin:0 0 22px}.proj-body p:last-child{margin-bottom:0}.proj-section-h{letter-spacing:-.01em;align-items:baseline;gap:12px;margin:0 0 12px;font-size:19px;font-weight:600;display:flex}.proj-section-num{font-family:var(--font-mono);color:var(--accent-ink);font-size:12px;font-weight:500}.proj-section p{color:var(--ink-2);margin:0;font-size:15.5px;line-height:1.75}.proj-foot{border-top:1px solid var(--rule);margin-top:48px;padding-top:24px}.proj-foot-btn{cursor:pointer;color:var(--ink-3);font-family:var(--font-mono);background:0 0;border:0;font-size:12px}.proj-foot-btn:hover{color:var(--ink)}.proj-empty{text-align:center;color:var(--ink-3);padding:60px 0}.proj-empty button{border:1px solid var(--rule);cursor:pointer;font-family:var(--font-mono);color:var(--ink-2);background:0 0;border-radius:6px;margin-top:12px;padding:8px 14px;font-size:12px}.page-contact{max-width:640px}.contact-head{border-bottom:1px solid var(--rule);margin-bottom:32px;padding:24px 0 36px}.contact-head-mono{font-family:var(--font-mono);color:var(--ink-3);margin-bottom:14px;font-size:11.5px}.contact-h{letter-spacing:-.02em;margin:0 0 14px;font-size:38px;font-weight:700}.contact-sub{color:var(--ink-2);margin:0;font-size:16px;line-height:1.7}.contact-card{background:var(--bg-2);border:1px solid var(--rule);border-radius:10px;overflow:hidden}.contact-row-static{cursor:default;border-bottom:1px solid var(--rule);padding:14px 18px}.contact-row-static:last-child{border-bottom:0}.contact-row-static:hover{background:var(--bg-2)}.contact-status-dot{background:var(--accent);vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.contact-foot{margin-top:24px}.contact-back{cursor:pointer;color:var(--ink-3);font-family:var(--font-mono);background:0 0;border:0;padding:0;font-size:12px}.contact-back:hover{color:var(--ink)}.footer{border-top:1px solid var(--rule);margin-top:48px;padding:56px 0 64px}.footer-inner{max-width:var(--content-w-wide);justify-content:space-between;gap:24px;margin:0 auto;padding:0 28px;display:flex}.footer-mono{font-family:var(--font-mono);color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-size:10.5px}.footer-name{margin-bottom:4px;font-weight:600}.footer-line{font-family:var(--font-mono);color:var(--ink-3);font-size:11px}.footer-col-end{text-align:right}.footer-links{justify-content:flex-end;gap:14px;display:flex}.footer-links a{font-family:var(--font-mono);color:var(--ink-2);font-size:12px;text-decoration:none}.footer-links a:hover{color:var(--accent-ink)}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
