@import"https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..700;1,9..144,300..700&family=JetBrains+Mono:wght@400&display=swap";@import"https://api.fontshare.com/v2/css?f[]=satoshi@300,400,500,700,300i,400i,500i,700i&display=swap";@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.min.css";@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-space-y-reverse:0}}}@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;--spacing:4px;--container-2xl:42rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-primary:#0a0a0a;--color-background:#fff;--color-muted:#737373;--color-rule:#e5e5e5;--color-ink-50:#fafafa;--color-ink-100:#f5f5f5;--color-ink-300:#d4d4d4;--color-ink-600:#525252;--color-ink-700:#404040;--font-display:"Fraunces", "Source Serif 4", "Pretendard Variable", "Pretendard", ui-serif, Georgia, serif;--font-body:"Satoshi", "Pretendard Variable", "Pretendard", "Inter", system-ui, -apple-system, sans-serif;--font-meta:"JetBrains Mono", "Pretendard Variable", "Pretendard", ui-monospace, SFMono-Regular, monospace;--text-section-head:26px;--text-section-head--line-height:1.2;--text-section-head--letter-spacing:-.02em;--text-section-head--font-weight:500;--text-prose:40px;--text-prose--line-height:1.75;--text-prose--letter-spacing:-.01em;--text-bodyLarge:16px;--text-bodyLarge--line-height:1.5}}@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}html{font-family:var(--font-body);color:var(--color-primary);background:var(--color-background)}body{font-feature-settings:"kern","liga";-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility}.font-display{font-variation-settings:"opsz" 40,"SOFT" 0,"WONK" 0;font-weight:300}.font-display strong{font-weight:700}.font-display em{font-variation-settings:"opsz" 40,"SOFT" 100,"WONK" 1;font-style:italic;font-weight:300}}@layer components{.anchor{cursor:pointer;display:inline;position:relative}.anchor strong,.anchor em{z-index:2;white-space:nowrap;-webkit-text-decoration:underline dashed var(--color-ink-300);text-decoration:underline dashed var(--color-ink-300);text-underline-offset:8px;text-decoration-thickness:1px;transition:text-decoration-color .35s ease-out;position:relative}.anchor:hover strong,.anchor:hover em{-webkit-text-decoration-color:var(--color-ink-600);text-decoration-color:var(--color-ink-600)}.anchor.expanded strong,.anchor.expanded em{text-decoration-color:#0000}.anchor .expansion{font-variation-settings:"opsz" 40,"SOFT" 0,"WONK" 0;font-style:italic;font-weight:300}.scribble{pointer-events:none;opacity:.65;color:var(--color-primary);z-index:1;transition:opacity .22s ease-out;position:absolute}.anchor.expanded .scribble{opacity:1}.scribble path{stroke-dasharray:100;stroke-dashoffset:0}.anchor[data-mark=asterisk] .scribble{width:14px;height:14px;top:-14px;left:-2px;transform:rotate(-12deg)}.anchor[data-mark=circle] .scribble{width:calc(100% + 20px);height:calc(100% + 14px);top:-7px;left:-10px;transform:rotate(-1.5deg)}.anchor[data-mark=tilde] .scribble{width:28px;height:6px;bottom:-10px;left:4px}.anchor[data-mark=star] .scribble{width:12px;height:12px;top:-14px;right:-2px;transform:rotate(20deg)}.anchor[data-mark=underline] strong,.anchor[data-mark=underline] em{position:relative}.anchor[data-mark=underline] strong:after,.anchor[data-mark=underline] em:after{content:"";background-color:var(--color-primary);pointer-events:none;z-index:1;width:0;height:3px;transition:width .6s cubic-bezier(.22,1,.36,1);position:absolute;bottom:-10px;left:0}.anchor[data-mark=underline].expanded strong:after,.anchor[data-mark=underline].expanded em:after{width:100%}.glyph-mark{font-family:var(--font-body);color:var(--color-primary);opacity:0;pointer-events:none;z-index:1;transform-origin:50%;font-size:18px;line-height:1;transition:opacity .22s ease-out,transform .45s cubic-bezier(.22,1,.36,1);position:absolute;transform:rotate(-25deg)scale(.4)}.anchor.expanded .glyph-mark{opacity:1;transform:rotate(0)scale(1)}.anchor[data-mark=sun] .glyph-mark{top:-18px;left:4px}.anchor[data-font=italic] .expansion{font-variation-settings:"opsz" 40,"SOFT" 100,"WONK" 1;font-style:italic}.anchor[data-font=sans] .expansion{font-family:var(--font-body);font-variation-settings:normal;letter-spacing:-.005em;font-size:1em;font-style:normal;font-weight:300}.anchor[data-font=mono] .expansion{font-family:var(--font-meta);font-variation-settings:normal;letter-spacing:.01em;font-size:.62em;font-style:normal;font-weight:400}@media(prefers-reduced-motion:reduce){.anchor[data-mark=underline] strong:after,.anchor[data-mark=underline] em:after,.glyph-mark,.scribble,.scribble path{transition:none}.scribble path{stroke-dashoffset:0}}.welcome-banner{font-family:var(--font-display);color:var(--color-primary);letter-spacing:-.005em;font-variation-settings:"opsz" 16,"SOFT" 0,"WONK" 0;-webkit-user-select:none;user-select:none;padding:48px 32px 0;font-size:16px;font-style:italic;font-weight:300;line-height:1.4}@media(min-width:768px){.welcome-banner{padding:64px 64px 0}}.welcome-target{font-style:italic;font-weight:400;display:inline-block}.page-flow{display:block}@media(min-width:768px){.page-flow{padding-left:224px}}.section{padding:48px 32px}@media(min-width:768px){.section{padding:64px}}.site-footer{padding:96px 32px 64px}@media(min-width:768px){.site-footer{padding:128px 64px 96px}}.footer-links{font-family:var(--font-body);margin:0;font-size:14px;line-height:1.5}.footer-sep{color:var(--color-muted);margin:0 8px}.footer-meta{font-family:var(--font-display);color:var(--color-muted);letter-spacing:0;font-variation-settings:"opsz" 14,"SOFT" 0,"WONK" 0;margin-top:32px;font-size:14px;font-style:italic;font-weight:300;line-height:1.4}.projects-list{flex-direction:column;gap:20px;max-width:640px;padding:0;list-style:none;display:flex}.projects-list li{grid-template-columns:1fr;gap:4px;list-style:none;display:grid}@media(min-width:768px){.projects-list li{grid-template-columns:140px 1fr;align-items:baseline;gap:28px}}.project-name{font-family:var(--font-body);letter-spacing:-.01em;color:var(--color-primary);font-size:16px;font-weight:500;line-height:1.4;display:inline-block}a.project-name{text-decoration:underline;-webkit-text-decoration-color:var(--color-ink-300);text-decoration-color:var(--color-ink-300);text-underline-offset:5px;text-decoration-thickness:1px;transition:text-decoration-color .2s ease-out}a.project-name:hover{-webkit-text-decoration-color:var(--color-primary);text-decoration-color:var(--color-primary)}.project-desc{font-family:var(--font-body);color:var(--color-muted);margin-top:0;font-size:14px;font-weight:400;line-height:1.5}.project-subtitle{font-family:var(--font-display);color:var(--color-muted);letter-spacing:0;font-variation-settings:"opsz" 12,"SOFT" 0,"WONK" 0;margin-top:1px;font-size:12px;font-style:italic;font-weight:300;line-height:1.3;text-decoration:none;display:block}.projects-group-title{font-family:var(--font-display);color:var(--color-muted);letter-spacing:0;font-variation-settings:"opsz" 14,"SOFT" 0,"WONK" 0;margin-top:56px;margin-bottom:14px;font-size:14px;font-style:italic;font-weight:400;line-height:1.4}.projects-group-title:first-of-type{margin-top:0}.subtle-link{color:var(--color-primary);text-decoration:underline;-webkit-text-decoration-color:var(--color-ink-300);text-decoration-color:var(--color-ink-300);text-underline-offset:4px;text-decoration-thickness:1px;transition:text-decoration-color .2s ease-out}.subtle-link:hover{-webkit-text-decoration-color:var(--color-primary);text-decoration-color:var(--color-primary)}.influences-row{grid-template-columns:1fr;align-items:start;gap:24px;display:grid}@media(min-width:768px){.influences-row{grid-template-columns:1fr auto;gap:40px}}.tilted-photos{grid-template-columns:repeat(2,100px);gap:12px;display:grid}@media(min-width:768px){.tilted-photos{grid-template-columns:repeat(2,110px)}}.tilted-photos img{aspect-ratio:1;object-fit:cover;background:var(--color-ink-100);width:100%;transition:transform .35s cubic-bezier(.22,1,.36,1);box-shadow:0 1px #0000000a}.tilted-photos img:first-child{transform:rotate(-2.5deg)}.tilted-photos img:nth-child(2){transform:rotate(1.8deg)}.tilted-photos img:nth-child(3){transform:rotate(-1.2deg)}.tilted-photos img:nth-child(4){transform:rotate(2.2deg)}.tilted-photos img:hover{z-index:1;transform:rotate(0)translateY(-4px)scale(1.04);box-shadow:0 6px 20px #00000014}@media(prefers-reduced-motion:reduce){.tilted-photos img,.tilted-photos img:hover{transition:none;transform:rotate(0)}}.rail{display:none}@media(min-width:768px){.rail{pointer-events:none;z-index:5;width:224px;height:100vh;display:block;position:fixed;top:0;left:0}}.rail-label{pointer-events:auto;cursor:pointer;width:160px;font-family:var(--font-body);color:var(--color-muted);letter-spacing:-.005em;text-underline-offset:4px;text-decoration:underline;text-decoration-thickness:1px;-webkit-text-decoration-color:var(--color-ink-300);text-decoration-color:var(--color-ink-300);font-size:16px;font-weight:400;line-height:1.3;transition:color .35s ease-out,font-size .35s ease-out,font-weight .35s ease-out,text-decoration-color .35s ease-out;position:fixed;left:64px}.rail-label:hover{color:var(--color-primary);-webkit-text-decoration-color:var(--color-ink-600);text-decoration-color:var(--color-ink-600)}.rail-label.active{color:var(--color-primary);-webkit-text-decoration-color:var(--color-primary);text-decoration-color:var(--color-primary);font-size:20px;font-weight:500}.rail-label.active:before{content:"[•] ";margin-right:2px;font-weight:400}@media(prefers-reduced-motion:reduce){.rail-label{transition:color .2s ease-out,text-decoration-color .2s ease-out}}.writing-shell{max-width:720px;margin:0 auto;padding:64px 24px 96px}@media(min-width:768px){.writing-shell{padding:96px 32px 128px}}.writing-back{font-family:var(--font-body);color:var(--color-muted);letter-spacing:-.005em;text-decoration:underline;-webkit-text-decoration-color:var(--color-ink-300);text-decoration-color:var(--color-ink-300);text-underline-offset:4px;font-size:13px;font-weight:400;text-decoration-thickness:1px;transition:color .2s ease-out,text-decoration-color .2s ease-out;display:inline-block}.writing-back:hover{color:var(--color-primary);-webkit-text-decoration-color:var(--color-primary);text-decoration-color:var(--color-primary)}.writing-header{margin-top:48px}.writing-header .meta{font-family:var(--font-body);letter-spacing:0;color:var(--color-muted);font-feature-settings:"tnum" 1;font-size:13px;font-weight:400;line-height:1.5}.writing-header .meta-sep{color:var(--color-ink-300);margin:0 8px}.writing-header .lang-toggles{align-items:baseline;gap:10px;display:inline-flex}.writing-header .lang-badge{color:var(--color-primary);text-transform:uppercase;letter-spacing:.04em;text-decoration:underline;-webkit-text-decoration-color:var(--color-primary);text-decoration-color:var(--color-primary);text-underline-offset:3px;font-size:12px;text-decoration-thickness:1px}.writing-header .lang-toggle{color:var(--color-muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px;text-decoration:none;transition:color .2s ease-out,text-decoration-color .2s ease-out}.writing-header .lang-toggle:hover{color:var(--color-primary);text-decoration:underline;-webkit-text-decoration-color:var(--color-primary);text-decoration-color:var(--color-primary);text-underline-offset:3px;text-decoration-thickness:1px}.writing-tags{font-family:var(--font-body);color:var(--color-muted);flex-wrap:wrap;gap:14px;margin-top:14px;font-size:13px;line-height:1.5;display:flex}.writing-tags a{color:var(--color-muted);text-decoration:underline;-webkit-text-decoration-color:var(--color-ink-300);text-decoration-color:var(--color-ink-300);text-underline-offset:3px;text-decoration-thickness:1px;transition:color .2s ease-out,text-decoration-color .2s ease-out}.writing-tags a:hover{color:var(--color-primary);-webkit-text-decoration-color:var(--color-primary);text-decoration-color:var(--color-primary)}.writing-header h1{font-family:var(--font-body);letter-spacing:-.02em;color:var(--color-primary);margin-top:16px;font-size:28px;font-weight:500;line-height:1.25}@media(min-width:768px){.writing-header h1{font-size:32px}}.writing-header .description{font-family:var(--font-display);color:var(--color-muted);font-variation-settings:"opsz" 18,"SOFT" 0,"WONK" 0;margin-top:12px;font-size:17px;font-style:italic;font-weight:300;line-height:1.5}.writing-prose{font-family:var(--font-body);color:var(--color-primary);margin-top:56px;font-size:17px;line-height:1.75}.writing-prose>*+*{margin-top:1.4em}.writing-prose h2{font-family:var(--font-body);letter-spacing:-.01em;margin-top:2.4em;font-size:22px;font-weight:500;line-height:1.3}.writing-prose h3{font-family:var(--font-body);letter-spacing:-.005em;margin-top:2em;font-size:18px;font-weight:500;line-height:1.35}.writing-prose strong{font-weight:600}.writing-prose em{font-style:italic}.writing-prose a{color:var(--color-primary);text-decoration:underline;-webkit-text-decoration-color:var(--color-ink-300);text-decoration-color:var(--color-ink-300);text-underline-offset:4px;text-decoration-thickness:1px;transition:text-decoration-color .2s ease-out}.writing-prose a:hover{-webkit-text-decoration-color:var(--color-primary);text-decoration-color:var(--color-primary)}.writing-prose code{font-family:var(--font-meta);background:var(--color-ink-100);border-radius:2px;padding:2px 5px;font-size:.88em}.writing-prose pre{font-family:var(--font-meta);background:var(--color-ink-50);border:1px solid var(--color-rule);border-radius:4px;padding:20px 24px;font-size:13px;line-height:1.65;overflow-x:auto}.writing-prose pre code{font-size:inherit;background:0 0;padding:0}.writing-prose blockquote{border-left:1px solid var(--color-ink-300);color:var(--color-ink-700);padding-left:20px;font-style:italic}.writing-prose hr{border:0;border-top:1px solid var(--color-rule);margin:56px 0}.writing-prose ul,.writing-prose ol{padding-left:24px}.writing-prose ul li{list-style:outside}.writing-prose ol li{list-style:decimal}.writing-prose ul li+li,.writing-prose ol li+li{margin-top:.4em}.writing-prose img{border-radius:4px;max-width:100%;margin:0 auto;display:block}.writing-index-title{font-family:var(--font-body);letter-spacing:-.015em;color:var(--color-primary);margin-top:48px;font-size:22px;font-weight:500;line-height:1.25}.writing-index-description{font-family:var(--font-display);color:var(--color-muted);font-variation-settings:"opsz" 18,"SOFT" 0,"WONK" 0;margin-top:12px;font-size:17px;font-style:italic;font-weight:300;line-height:1.5}.writing-list{margin:48px 0 0;padding:0;list-style:none}.writing-list li{flex-wrap:wrap;align-items:baseline;gap:14px;padding:8px 0;list-style:none;display:flex}.writing-list .row-main{color:var(--color-primary);font-family:var(--font-body);align-items:baseline;gap:14px;font-size:16px;line-height:1.6;text-decoration:none;display:inline-flex}.writing-list .row-date{font-family:var(--font-body);letter-spacing:0;color:var(--color-muted);font-feature-settings:"tnum" 1;font-size:13px}.writing-list .row-title{color:var(--color-primary)}.writing-list .row-main:hover .row-title{text-decoration:underline;-webkit-text-decoration-color:var(--color-primary);text-decoration-color:var(--color-primary);text-underline-offset:4px;text-decoration-thickness:1px}.writing-list .row-meta{font-family:var(--font-body);color:var(--color-muted);letter-spacing:0;flex-wrap:wrap;align-items:baseline;gap:10px;font-size:12px;line-height:1.5;display:inline-flex}.writing-list .row-langs{text-transform:uppercase;letter-spacing:.04em}.writing-list .row-meta-sep{color:var(--color-ink-300)}.writing-list .row-tags{flex-wrap:wrap;gap:10px;display:inline-flex}.writing-list .row-tags a{color:var(--color-muted);text-decoration:underline;-webkit-text-decoration-color:var(--color-ink-300);text-decoration-color:var(--color-ink-300);text-underline-offset:3px;text-decoration-thickness:1px;transition:color .2s ease-out,text-decoration-color .2s ease-out}.writing-list .row-tags a:hover{color:var(--color-primary);-webkit-text-decoration-color:var(--color-primary);text-decoration-color:var(--color-primary)}}@layer utilities{.visible{visibility:visible}.fixed{position:fixed}.static{position:static}.start{inset-inline-start:var(--spacing)}.mt-8{margin-top:calc(var(--spacing) * 8)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.min-h-screen{min-height:100vh}.max-w-2xl{max-width:var(--container-2xl)}.resize{resize:both}:where(.space-y-5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 5) * calc(1 - var(--tw-space-y-reverse)))}.rounded{border-radius:.25rem}.px-8{padding-inline:calc(var(--spacing) * 8)}.py-12{padding-block:calc(var(--spacing) * 12)}.pt-24{padding-top:calc(var(--spacing) * 24)}.pb-32{padding-bottom:calc(var(--spacing) * 32)}.font-body{font-family:var(--font-body)}.font-display{font-family:var(--font-display)}.text-section-head{font-size:var(--text-section-head);line-height:var(--tw-leading,var(--text-section-head--line-height));letter-spacing:var(--tw-tracking,var(--text-section-head--letter-spacing));font-weight:var(--tw-font-weight,var(--text-section-head--font-weight))}.text-prose{font-size:var(--text-prose);line-height:var(--tw-leading,var(--text-prose--line-height));letter-spacing:var(--tw-tracking,var(--text-prose--letter-spacing))}.text-bodyLarge{font-size:var(--text-bodyLarge);line-height:var(--tw-leading,var(--text-bodyLarge--line-height))}.text-muted{color:var(--color-muted)}.text-primary{color:var(--color-primary)}.italic{font-style:italic}.underline{text-decoration-line:underline}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media(min-width:48rem){.md\:px-16{padding-inline:calc(var(--spacing) * 16)}.md\:py-16{padding-block:calc(var(--spacing) * 16)}}}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}
