:root,html[data-theme=light]{--background: #fdfdfd;--foreground: #282728;--accent: #006cac;--accent-foreground: #ffffff;--muted: #e6e6e6;--muted-foreground: #6b7280;--border: #ece9e9;--code: #c7254e}html[data-theme=dark]{--background: #212737;--foreground: #eaedf3;--accent: #ff6b01;--accent-foreground: #ffffff;--muted: #343f60;--muted-foreground: #afb9ca;--border: #ab4b08;--code: #ff7b72}:root{--font-app: var(--font-google-sans-code), "Pretendard Variable", Pretendard, ui-monospace, SFMono-Regular, Menlo, "Apple SD Gothic Neo", monospace;--font-serif: "Noto Serif KR", Georgia, "Times New Roman", serif;--font-sans: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, system-ui, "Apple SD Gothic Neo", sans-serif;--maxw: 64rem;--maxw-prose: 48rem;--sidebar-w: 15rem}*{box-sizing:border-box}html{background:var(--background);scroll-behavior:smooth;scroll-padding-top:5rem}body{margin:0;min-height:100svh;color:var(--foreground);background:var(--background);font-family:var(--font-serif);font-size:1rem;line-height:1.75}::selection{background:color-mix(in srgb,var(--accent) 75%,transparent);color:var(--accent-foreground)}a{color:var(--foreground);text-decoration:none}a:hover{color:var(--accent);text-decoration:underline;text-underline-offset:4px}:where(a,button,input,summary):focus-visible{outline:2px dashed var(--accent);outline-offset:2px;border-radius:2px}img{max-width:100%;height:auto}hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.container{max-width:var(--maxw);margin:0 auto;width:100%;padding:0 1rem}.sidebar,.card-cat,.tag,.chip,.tag-cloud{font-family:var(--font-app)}.side-title,.cat-list,.page-head h1,.card-title,.card-date,.section-head{font-family:var(--font-sans)}.site-header{position:sticky;top:0;z-index:50;font-family:var(--font-app);border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--background) 85%,transparent);backdrop-filter:saturate(180%) blur(8px);-webkit-backdrop-filter:saturate(180%) blur(8px)}.header-inner{max-width:var(--maxw);margin:0 auto;width:100%;padding:0 1rem;display:flex;align-items:center;gap:1rem;min-height:64px;flex-wrap:wrap}.brand{font-size:1.35rem;font-weight:700;letter-spacing:-.01em}.brand:hover{text-decoration:none;color:var(--accent)}.menu-btn{display:none;margin-left:auto;background:none;border:none;color:var(--foreground);cursor:pointer;padding:.4rem}.site-nav{margin-left:auto;display:flex;align-items:center;gap:1.25rem}.nav-links{list-style:none;display:flex;align-items:center;gap:1.25rem;margin:0;padding:0}.nav-links a{color:var(--foreground);font-size:.95rem;font-weight:500}.nav-links a:hover{color:var(--accent);text-decoration:none}.active-nav{text-decoration:underline;text-decoration-style:wavy;text-decoration-color:var(--accent);text-decoration-thickness:2px;text-underline-offset:6px}.nav-actions{display:flex;align-items:center;gap:.25rem}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;background:none;border:none;color:var(--foreground);cursor:pointer;border-radius:8px}.icon-btn:hover{color:var(--accent);background:var(--muted);text-decoration:none}.icon-btn.active-icon{color:var(--accent)}.icon{width:1.3rem;height:1.3rem;display:block}.theme-toggle .sun,html[data-theme=dark] .theme-toggle .moon{display:none}html[data-theme=dark] .theme-toggle .sun{display:block}@media(max-width:640px){.menu-btn{display:inline-flex}.header-inner{position:relative;flex-wrap:nowrap}.site-nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:.5rem;margin:0;padding:.5rem 1rem .75rem;background:var(--background);border-bottom:1px solid var(--border);max-height:calc(100svh - 64px);overflow-y:auto}.site-nav.open{display:flex}.nav-links{flex-direction:column;align-items:stretch;gap:.25rem;width:100%}.nav-links a{display:block;padding:.5rem .25rem}.nav-actions{justify-content:flex-start}}main{flex:1;padding:2.5rem 0 4rem}.layout{max-width:var(--maxw);margin:0 auto;width:100%;padding:0 1rem;display:grid;grid-template-columns:var(--sidebar-w) 1fr;gap:2.5rem;align-items:start}.content{min-width:0}.prose-wrap{max-width:var(--maxw-prose);margin:0 auto;width:100%;padding:0 1rem}.sidebar{position:sticky;top:5rem;display:flex;flex-direction:column;gap:2rem}.side-block{font-size:.9rem}.side-title{font-size:1.05rem;font-weight:700;margin:0 0 .75rem;color:var(--muted-foreground);letter-spacing:.02em}.cat-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.15rem;font-size:.95rem}.cat-list a{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.3rem .5rem;border-radius:6px;color:var(--foreground)}.cat-list a:hover{background:var(--muted);color:var(--accent);text-decoration:none}.cat-list a.active{background:var(--muted);color:var(--accent);font-weight:600}.cat-list .count{color:var(--muted-foreground);font-size:.8rem}.cat-list .cat-list{margin:.1rem 0 .1rem .55rem;padding-left:.55rem;border-left:1px solid var(--border);gap:0}.profile{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding-top:1.5rem;border-top:1px solid var(--border)}.profile .avatar{width:3rem;height:3rem;border-radius:50%;background:var(--accent);color:var(--accent-foreground);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;margin-bottom:.4rem}.profile .pname{font-weight:700;font-size:1rem}.profile .ptitle{color:var(--muted-foreground);font-size:.82rem}.profile .pbio{color:var(--muted-foreground);font-size:.82rem;line-height:1.6;margin:.5rem 0}.profile .socials{margin-top:.25rem}.socials{display:flex;gap:.35rem}.social-link{display:inline-flex;align-items:center;justify-content:center;width:2.1rem;height:2.1rem;color:var(--foreground);border-radius:8px;transition:transform .18s ease,color .18s ease,background .18s ease}.social-link:hover{color:var(--accent);background:var(--muted);transform:rotate(6deg) scale(1.05);text-decoration:none}.social-link svg{width:1.25rem;height:1.25rem;display:block}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.page-head{display:flex;align-items:baseline;gap:.75rem;margin-bottom:1.75rem}.page-head h1{font-size:1.3rem;font-weight:700;margin:0;letter-spacing:-.02em}.page-count{color:var(--muted-foreground);font-size:.85rem}.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.card{border:1px solid var(--border);border-radius:10px;padding:1.1rem 1.2rem;display:flex;flex-direction:column;gap:.35rem;transition:border-color .15s ease,transform .15s ease}.card:hover{border-color:var(--accent);transform:translateY(-2px)}.card-cat{align-self:flex-start;font-size:.72rem;color:var(--accent);text-transform:uppercase;letter-spacing:.03em}.card-cat:hover{text-decoration:underline}.card-title{font-size:1.15rem;font-weight:700;line-height:1.4;margin:0}.card-title a{color:var(--foreground)}.card-title a:hover{color:var(--accent);text-decoration:none}.card-date{color:var(--muted-foreground);font-size:.8rem}.card-excerpt{color:var(--muted-foreground);font-size:.9rem;line-height:1.6;margin:.25rem 0 0;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.card-tags{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.6rem}.chip{display:inline-block;font-size:.72rem;color:var(--muted-foreground);border:1px solid var(--border);border-radius:999px;padding:.1rem .6rem;margin:0 .35rem .5rem 0}@media(max-width:860px){.layout{grid-template-columns:1fr;gap:2rem}.sidebar{position:static;flex-direction:column}.card-grid{grid-template-columns:1fr}}.intro{margin-bottom:3rem}.intro h1{font-size:2.25rem;font-weight:700;margin:1rem 0}.intro p{color:var(--foreground);margin:0;font-size:1rem;font-weight:400;line-height:1.5}@media(min-width:640px){.intro h1{font-size:3rem;margin:2rem 0}}.section-head{font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.intro{font-family:var(--font-app)}.intro-social{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem}.intro-social-label{font-family:var(--font-app);font-size:1rem;color:var(--foreground)}.intro-social .social-link{width:2.6rem;height:2.6rem}.intro-social .social-link svg{width:1.6rem;height:1.6rem}.home-section{margin-top:2.5rem;padding-top:2.5rem;border-top:1px solid var(--border)}.home-section .card-grid{margin-top:1rem}.all-posts-link{margin-top:1.5rem;text-align:right}.all-posts-link a{color:var(--accent);font-family:var(--font-app);font-size:.95rem}.post-list{list-style:none;padding:0;margin:1rem 0 0}.post-item{margin-bottom:1.6rem}.post-item h2{font-size:1.3rem;font-weight:700;margin:0 0 .15rem;line-height:1.4}.post-item h2 a{color:var(--accent)}.post-item h2 a:hover{text-decoration:underline;text-decoration-style:wavy}.post-item .date{color:var(--muted-foreground);font-size:.85rem}.post-item .excerpt{color:var(--foreground);margin:.4rem 0 0}.post-item .tags{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.8rem}.tag{font-size:.8rem;color:var(--muted-foreground)}.tag:hover{color:var(--accent)}.prose{font-family:var(--font-serif)}.prose :is(h1,h2,h3,h4,h5,h6){font-family:var(--font-sans)}.prose h1.title{font-size:1.9rem;font-weight:700;margin:0 0 .4rem;line-height:1.35}.prose .post-meta{color:var(--muted-foreground);font-size:.85rem;margin-bottom:2.5rem}.prose p{line-height:2;margin-block-start:0;margin-block-end:1em}.prose :is(h1,h2,h3,h4,h5,h6):not(.title){line-height:1.6;padding-top:1.2em;margin-block-start:1.4em;margin-block-end:.4em}.prose h2{font-size:1.45rem}.prose h3{font-size:1.2rem}.prose h4{font-size:1.05rem}.prose ul,.prose ol{line-height:1.7;margin-block-start:.2em;margin-block-end:.2em;padding-left:1.4em}.prose li{line-height:1.7;margin-block-end:.1em}.prose ul:not(li ul)>li,.prose ol:not(li ol)>li{margin-block-end:.5em}.prose li>ul,.prose li>ol{margin-block-start:.3em}.prose ul:not(li ul),.prose ol:not(li ol){margin-block-end:1.5em}.prose a{color:var(--foreground);text-decoration:underline;text-decoration-style:dashed;text-underline-offset:4px}.prose a:hover{color:var(--accent);text-decoration-style:dashed}.prose pre,.prose pre code{font-family:var(--font-app);color:var(--code)}.prose pre{background:var(--muted);padding:1rem 1.1rem;border-radius:6px;overflow-x:auto;font-size:.9rem;line-height:1.6;margin-block-start:.1em;margin-block-end:2em}.prose p:has(+pre){margin-block-end:.1em}html[data-theme=dark] .prose pre{background:#1b2030}.prose :not(pre)>code{font-family:var(--font-app);color:var(--code);background:var(--muted);padding:.1rem .35rem;border-radius:4px;font-size:.9em}.prose blockquote{border-left:3px solid var(--accent);margin:1.3rem 0;padding:.1rem 1rem;color:var(--muted-foreground);font-style:italic}.prose img{border-radius:6px}.comments{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border)}.comments-note{font-family:var(--font-app);color:var(--muted-foreground);font-size:.9rem}.back-link{display:inline-block;font-family:var(--font-app);font-size:.9rem;color:var(--muted-foreground);margin-bottom:1.5rem}.back-link:hover{color:var(--accent)}.tag-cloud{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.5rem}.tag-cloud a{border:1px solid var(--border);border-radius:6px;padding:.35rem .75rem;color:var(--foreground);font-size:.9rem}.tag-cloud a:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}.tag-cloud .count{color:var(--muted-foreground)}.page-desc{font-family:var(--font-app);font-style:italic;color:var(--muted-foreground);font-size:.95rem;margin:-.75rem 0 2rem}.archive-year,.archive-list{font-family:var(--font-sans)}.archive-year{margin-top:2rem}.archive-year h2{font-size:1.4rem;font-weight:700;margin:0 0 .75rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}.archive-month{margin:0 0 1.1rem}.archive-month h3{font-size:1.05rem;font-weight:600;margin:1rem 0 .4rem;color:var(--muted-foreground)}.archive-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.archive-list li{display:flex;gap:.6rem;padding:.3rem 0;align-items:baseline}.archive-list a{color:var(--foreground)}.archive-list a:hover{color:var(--accent);text-decoration:underline;text-decoration-style:dashed;text-underline-offset:4px}.archive-list time{color:var(--muted-foreground);font-size:.8rem;font-variant-numeric:tabular-nums;flex:none}.search-note{color:var(--muted-foreground)}#pagefind-search{--pagefind-ui-primary: var(--accent);--pagefind-ui-text: var(--foreground);--pagefind-ui-background: var(--background);--pagefind-ui-border: var(--border);--pagefind-ui-tag: var(--muted);--pagefind-ui-border-radius: 8px;--pagefind-ui-font: var(--font-app)}@keyframes fade-up{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}main .page-head,main .page-desc,main .intro,main .prose,main .tag-cloud,main .archive-year,main #pagefind-search{animation:fade-up .45s ease both}.card{animation:fade-up .5s ease both;animation-delay:calc(var(--i, 0) * 55ms)}html.theme-vt::view-transition-old(root){animation:none;z-index:1}html.theme-vt::view-transition-new(root){animation:none;z-index:9999}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-delay:0s!important;transition-duration:.001ms!important}}.site-footer{border-top:1px solid var(--border);color:var(--muted-foreground);font-size:.85rem;padding:1.5rem 0;display:flex;flex-direction:column;align-items:center;gap:.6rem}.site-footer .socials{justify-content:center}.footer-copy{margin:0;font-family:var(--font-app)}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}
