:root{color-scheme:light dark;--bg: light-dark(#fbfaf7, #141413);--ink: light-dark(#1f1d19, #e8e6e3);--body: light-dark(#44413b, #c9c7c2);--muted: light-dark(#8b8579, #8a8782);--faint: light-dark(#e9e5dd, #2a2926);--accent: light-dark(#8f6b33, #c9a87c);--accent-soft: light-dark(rgba(143, 107, 51, .35), rgba(201, 168, 124, .4));--code-bg: light-dark(#f3f1ea, #1d1c1a);--sans: "Pretendard Variable", Pretendard, -apple-system, sans-serif}html[data-theme=light]{color-scheme:light}html[data-theme=dark]{color-scheme:dark}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg);color:var(--body);font-family:var(--sans);font-size:16.5px;line-height:1.85;-webkit-font-smoothing:antialiased}.page{max-width:40rem;margin:0 auto;padding:5rem 1.5rem 6rem}header.site{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4.5rem}.site-name{font-weight:600;font-size:1rem;color:var(--ink);text-decoration:none}.site-name:after{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);margin-left:7px;transform:translateY(-1px)}header.site nav a{color:var(--muted);text-decoration:none;font-size:.87rem;margin-left:1.2rem}header.site nav a:hover{color:var(--accent)}.theme-toggle{background:none;border:none;padding:0;margin-left:1.2rem;cursor:pointer;color:var(--muted);font-size:.95rem;line-height:1;font-family:inherit}.theme-toggle:hover{color:var(--accent)}.theme-toggle .sun{display:none}html[data-theme=dark] .theme-toggle .sun{display:inline}html[data-theme=dark] .theme-toggle .moon{display:none}@media(prefers-color-scheme:dark){html:not([data-theme=light]) .theme-toggle .sun{display:inline}html:not([data-theme=light]) .theme-toggle .moon{display:none}}footer.site{margin-top:5rem;padding-top:1.5rem;border-top:1px solid var(--faint);color:var(--muted);font-size:.82rem;display:flex;justify-content:space-between}footer.site a{color:var(--muted);text-decoration:none}footer.site a:hover{color:var(--accent)}.intro{color:var(--muted);margin-bottom:4rem;font-size:.95rem}.year{font-size:.8rem;font-weight:500;color:var(--accent);margin:3rem 0 1rem;letter-spacing:.12em}.year:first-of-type{margin-top:0}ul.posts{list-style:none}ul.posts li{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:.55rem 0;border-bottom:1px solid var(--faint)}ul.posts li:last-child{border-bottom:none}ul.posts a{color:var(--ink);text-decoration:none;font-size:.98rem}ul.posts a:hover{color:var(--accent)}ul.posts time{color:var(--muted);font-size:.8rem;white-space:nowrap;font-variant-numeric:tabular-nums}ul.projects{list-style:none}ul.projects li{display:flex;align-items:baseline;gap:.75rem;padding:.55rem 0;border-bottom:1px solid var(--faint)}ul.projects li:last-child{border-bottom:none}ul.projects a{color:var(--ink);text-decoration:none;font-size:.98rem;white-space:nowrap}ul.projects a:after{content:"↗";color:var(--muted);font-size:.75em;margin-left:.3em}ul.projects a:hover,ul.projects a:hover:after{color:var(--accent)}ul.projects .desc{color:var(--muted);font-size:.9rem}.back{display:inline-block;margin-bottom:3rem;color:var(--muted);text-decoration:none;font-size:.87rem}.back:hover{color:var(--accent)}article header h1{font-size:1.7rem;font-weight:700;line-height:1.45;letter-spacing:-.01em;color:var(--ink);margin-bottom:.6rem}article header .meta{color:var(--muted);font-size:.85rem;margin-bottom:3rem}.prose h2{font-size:1.18rem;font-weight:600;color:var(--ink);margin:2.75rem 0 1rem}.prose h3{font-size:1.05rem;font-weight:600;color:var(--ink);margin:2.25rem 0 .9rem}.prose p{margin-bottom:1.4rem}.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--accent-soft)}.prose a:hover{text-decoration-color:var(--accent)}.prose code{background:var(--code-bg);border:1px solid var(--faint);padding:.12em .38em;border-radius:4px;font-size:.82em;color:var(--ink)}.prose pre{border:1px solid var(--faint);border-radius:8px;padding:1.1rem 1.3rem;overflow-x:auto;margin-bottom:1.4rem;line-height:1.65;background:var(--code-bg)!important}html[data-theme=dark] .astro-code,html[data-theme=dark] .astro-code span{color:var(--shiki-dark)!important;font-style:var(--shiki-dark-font-style)!important;font-weight:var(--shiki-dark-font-weight)!important;text-decoration:var(--shiki-dark-text-decoration)!important}@media(prefers-color-scheme:dark){html:not([data-theme=light]) .astro-code,html:not([data-theme=light]) .astro-code span{color:var(--shiki-dark)!important;font-style:var(--shiki-dark-font-style)!important;font-weight:var(--shiki-dark-font-weight)!important;text-decoration:var(--shiki-dark-text-decoration)!important}}.prose pre code{background:none;border:none;padding:0;font-size:.8rem}.prose blockquote{border-left:2px solid var(--accent);padding-left:1.2rem;color:var(--muted);margin-bottom:1.4rem}.prose ul,.prose ol{padding-left:1.35rem;margin-bottom:1.4rem}.prose li{margin-bottom:.4rem}.prose li::marker{color:var(--accent)}.prose img{max-width:100%;height:auto;border-radius:8px;margin-bottom:1.4rem}.prose .about-avatar{width:96px;height:96px;border-radius:50%;background:var(--faint);margin-bottom:1.75rem}.prose hr{border:none;border-top:1px solid var(--faint);margin:2.5rem 0}
