.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}:root{--font-base: "Noto Serif KR", "Apple SD Gothic Neo", Batang, Georgia, serif;--font-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Apple SD Gothic Neo", sans-serif;--bg: #f7f6f2;--fg: #1a1a1a;--muted: #6b7280;--accent: #2563eb;--border: #e5e7eb;--code-bg: #f3f4f6;--measure: 42rem}@media(prefers-color-scheme:dark){:root{--bg: #0f1115;--fg: #e6e7e9;--muted: #9ca3af;--accent: #7aa2ff;--border: #262a33;--code-bg: #1b1f27}}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font-base);background:var(--bg);color:var(--fg);line-height:1.7;font-size:18px;word-break:keep-all;overflow-wrap:break-word}.wrap{max-width:var(--measure);margin:0 auto;padding:0 1.25rem}body[data-width=wide] .wrap{max-width:72rem}a{color:var(--accent);text-decoration:none;text-underline-offset:.16em}a:hover{text-decoration:underline}.site-header{border-bottom:1px solid var(--border);margin-bottom:2.5rem}.site-header .wrap{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;padding-top:1.25rem;padding-bottom:1.25rem;flex-wrap:wrap}.site-title{font-weight:700;font-size:1.1rem;color:var(--fg)}.site-nav{display:flex;gap:1.1rem;font-size:.95rem}.site-nav a{color:var(--muted)}.site-nav a[aria-current=page]{color:var(--fg);font-weight:600}.site-footer{border-top:1px solid var(--border);margin-top:4rem;padding:2rem 0;color:var(--muted);font-size:.875rem}.post-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2rem}.post-list__item{display:flex;gap:1.1rem;align-items:flex-start}.post-thumb{flex:0 0 160px;display:block}.post-thumb img{width:100%;aspect-ratio:16 / 10;object-fit:cover;border-radius:8px;display:block;background:var(--code-bg)}.post-body{flex:1 1 auto;min-width:0}@media(max-width:560px){.post-list__item{flex-direction:column;gap:.55rem}.post-thumb{flex-basis:auto;width:100%}.post-thumb img{aspect-ratio:16 / 9}}.post-list__item h2{margin:0 0 .25rem;font-size:1.3rem;line-height:1.35}.post-list__item h2 a{color:var(--fg)}.post-meta{color:var(--muted);font-size:.85rem;margin:0 0 .4rem;font-family:var(--font-ui)}.post-summary{margin:.3rem 0 0;color:var(--fg)}.tags{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.5rem;font-size:.8rem;font-family:var(--font-ui)}.tags a{color:var(--muted)}.featured{display:flex;flex-direction:column;gap:1.5rem}.featured-card{display:block;color:var(--fg);border:1px solid var(--border);border-radius:12px;overflow:hidden}.featured-card:hover{text-decoration:none;border-color:var(--accent)}.featured-cover{width:100%;aspect-ratio:16 / 9;object-fit:cover;display:block;background:var(--code-bg)}.featured-body{padding:1.1rem 1.3rem 1.4rem}.featured-badge{display:inline-block;background:var(--accent);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.05em;padding:.1rem .45rem;border-radius:4px;margin-right:.5rem;vertical-align:middle;text-transform:uppercase}.featured-title{font-size:1.65rem;line-height:1.25;margin:.35rem 0 .4rem}.featured-card:hover .featured-title{color:var(--accent)}.latest{margin-top:2.75rem}.prose h1{font-size:2rem;line-height:1.25;margin:0 0 .5rem}.prose h2{margin-top:2.2rem}.prose img{max-width:100%;height:auto;border-radius:6px}.prose pre{background:var(--code-bg);padding:1rem;border-radius:6px;overflow-x:auto;font-size:.9rem}.prose code{background:var(--code-bg);padding:.1rem .35rem;border-radius:4px;font-size:.9em}.prose pre code{background:none;padding:0}.prose blockquote{border-left:3px solid var(--border);margin:1.5rem 0;padding:.2rem 0 .2rem 1rem;color:var(--muted)}.prose a{color:inherit;text-decoration:underline;text-decoration-color:var(--muted);text-decoration-thickness:1px;text-underline-offset:.18em}.prose a:hover{text-decoration-color:currentColor}.article-head{max-width:46rem;margin:2.4rem auto 2.8rem;text-align:center}.article-title{font-size:clamp(1.9rem,3.6vw,2.7rem);line-height:1.2;letter-spacing:-.025em;margin:0 0 1.3rem;font-weight:600}.article-date{display:block;margin:0}.post-hero{width:100%;max-width:58rem;aspect-ratio:16 / 9;object-fit:cover;border-radius:14px;display:block;margin:0 auto 3.4rem;background:var(--code-bg)}.article-content{display:grid;grid-template-columns:1fr minmax(0,42rem) 1fr;align-items:start}.article-body{grid-column:2;min-width:0}.article-toc{grid-column:1;justify-self:end;width:12rem;margin-right:2.5rem;position:sticky;top:2rem;align-self:start;max-height:calc(100vh - 4rem);overflow-y:auto;font-family:var(--font-ui)}.toc-h{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700;margin:0 0 .9rem}.article-toc ul{list-style:none;margin:0;padding:0;border-left:1px solid var(--border)}.article-toc li a{display:block;padding:.35rem 0 .35rem .9rem;margin-left:-1px;border-left:2px solid transparent;color:var(--muted);font-size:.85rem;line-height:1.4;text-decoration:none}.article-toc li a:hover{color:var(--fg)}.article-toc li a.active{color:var(--accent);border-left-color:var(--accent)}@media(max-width:1000px){.article-content{grid-template-columns:minmax(0,42rem);justify-content:center}.article-body{grid-column:auto}.article-toc{display:none}}.archived-notice{border:1px solid var(--border);background:var(--code-bg);border-radius:6px;padding:.75rem 1rem;margin-bottom:1.5rem;color:var(--muted);font-size:.9rem}.subscribe-cta{display:inline-block;border:1px solid var(--accent);color:var(--accent);padding:.5rem 1rem;border-radius:6px;font-size:.95rem;margin:.5rem 0 1.5rem}.subscribe-cta:hover{text-decoration:none;background:var(--accent);color:#fff}
