.astro-route-announcer{clip:rect(0 0 0 0);clip-path:inset(50%);white-space:nowrap;width:1px;height:1px;position:absolute;top:0;left:0;overflow:hidden}:root,[data-theme=light]{--background:#fdfdfd;--foreground:#282728;--accent:#6667ab;--accent-foreground:#fff;--muted:#e9e9ef;--muted-foreground:#6b6b78;--border:#ece9e9;--font-body:"Geist Variable", -apple-system, BlinkMacSystemFont, system-ui, "Segoe UI", "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", sans-serif;--font-title:"Google Sans Code", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Apple SD Gothic Neo", "Noto Sans KR", monospace;color-scheme:light}[data-theme=dark]{--background:#1f2433;--foreground:#edf0f7;--accent:#9ea0ff;--accent-foreground:#10131d;--muted:#333a52;--muted-foreground:#b5bed0;--border:#4f5576;color-scheme:dark}*{box-sizing:border-box;border-color:var(--border)}html{background:var(--background);color:var(--foreground);scrollbar-width:auto;scrollbar-color:var(--muted-foreground) transparent;overflow-x:hidden}body{background:var(--background);min-width:0;min-height:100svh;color:var(--foreground);font-family:var(--font-body);text-rendering:optimizelegibility;flex-direction:column;margin:0;line-height:1.72;display:flex;overflow-x:hidden}a,button{color:inherit;outline-color:color-mix(in srgb, var(--accent) 75%, transparent);outline-offset:2px}a:hover,button:hover{color:var(--accent)}a:focus-visible,button:focus-visible{outline:2px dashed var(--accent)}button{font:inherit;cursor:pointer;background:0 0;border:0}img,video,iframe,table,pre,code{max-width:100%}img,video{height:auto}iframe{width:100%;display:block}pre{font-family:var(--font-title);background:color-mix(in srgb, var(--foreground) 8%, var(--background));border-radius:8px;padding:1rem;overflow-x:auto}code{font-family:var(--font-title);overflow-wrap:anywhere}table{border-collapse:collapse;display:block;overflow-x:auto}th,td{border:1px solid var(--border);padding:.55rem .7rem}.app-layout{width:100%;max-width:48rem;margin-inline:auto;padding-inline:1rem}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.skip-link{inset-inline-start:4rem;z-index:50;background:var(--background);color:var(--accent);padding:.5rem .75rem;transition:top .16s;position:absolute;top:-100%}.skip-link:focus{top:1rem}.site-header{flex-direction:column;display:flex}.top-nav{border-bottom:1px solid var(--border);justify-content:space-between;align-items:baseline;width:100%;padding-block:1rem;display:flex;position:relative}.brand{font-family:var(--font-title);white-space:nowrap;padding-block:.25rem;font-size:1.25rem;font-weight:700;line-height:2rem;text-decoration:none;position:absolute}.nav-menu{flex-direction:column;align-items:center;width:100%;display:flex}.menu-btn{align-self:flex-end;padding:.5rem}.menu-btn svg{width:1.5rem;height:1.5rem}.hidden{display:none!important}.menu-items{grid-template-columns:repeat(2,minmax(0,1fr));place-content:center;gap:.5rem;width:11rem;margin:1rem 0 0;padding:0;list-style:none;display:grid}.menu-items a,.menu-items button{width:100%;min-height:2.75rem;font-family:var(--font-title);text-align:center;padding:.75rem 1rem;font-weight:600;text-decoration:none;display:block}.menu-items svg{width:1.5rem;height:1.5rem}.nav-wide{grid-column:span 2}.nav-icon{justify-content:center;align-items:center;display:flex}.active-nav{color:var(--accent);text-underline-offset:.45rem;text-decoration:underline 2px wavy}.theme-btn{position:relative}.theme-btn .sun-icon{display:none}[data-theme=dark] .theme-btn .sun-icon{display:block}[data-theme=dark] .theme-btn .moon-icon{display:none}main{flex:1}.site-footer{margin-top:auto}.footer-inner{border-top:1px solid var(--border);flex-direction:column;justify-content:space-between;align-items:center;gap:.75rem;padding-block:1.5rem;display:flex}.socials{flex-wrap:wrap;align-items:center;gap:.25rem;display:flex}.socials a{justify-content:center;align-items:center;padding:.5rem;transition:transform .16s;display:inline-flex}.socials a:hover{transform:rotate(6deg)}.socials svg{width:1.5rem;height:1.5rem}.copyright{color:var(--muted-foreground);font-family:var(--font-title);white-space:nowrap;flex-direction:column;align-items:center;font-size:.92rem;display:flex}.post-list{margin:0;padding:0;list-style:none}.post-list li{margin-block:1.5rem}.post-title{color:var(--accent);font-family:var(--font-title);font-size:1.125rem;font-weight:650;text-decoration:none;display:inline-block}.post-title:hover{text-underline-offset:.25rem;text-decoration:underline dashed}.post-title :where(h2,h3){font-size:inherit;letter-spacing:0;margin:0;line-height:1.45}.post-list p{color:var(--foreground);margin:.45rem 0 0}.date-line{color:var(--muted-foreground);font-family:var(--font-title);align-items:center;gap:.45rem;font-size:.9rem;display:flex}.date-line svg{width:1.25rem;min-width:1.25rem;height:1.25rem}.page-head{padding-block:2.5rem 4rem}.page-head>h1{font-family:var(--font-title);letter-spacing:0;margin:0 0 .6rem;font-size:clamp(2.25rem,8vw,3rem);line-height:1.12}.page-head>p{color:var(--muted-foreground);margin:0 0 2rem}.prose{width:100%;max-width:48rem;margin-inline:auto;padding:2.5rem 1rem 4rem}.prose :where(h1,h2,h3){font-family:var(--font-title);letter-spacing:0;line-height:1.25}.prose h1{margin:0 0 1rem;font-size:clamp(2rem,7vw,2.75rem)}.prose h2{margin-top:2.5rem}.prose p,.prose li{overflow-wrap:anywhere}.prose a{color:var(--accent);text-underline-offset:.2rem;text-decoration-style:dashed}.prose blockquote{border-left:3px solid var(--accent);color:var(--muted-foreground);margin:2rem 0;padding-left:1rem}.prose figure{margin:2rem 0}.prose .kg-image-card img{border-radius:6px;margin-inline:auto;display:block}.prose .kg-bookmark-card{border:1px solid var(--border);background:color-mix(in srgb, var(--background) 92%, var(--foreground));border-radius:8px;overflow:hidden}.prose .kg-bookmark-container{min-height:9rem;color:inherit;grid-template-columns:minmax(0,1fr) minmax(10rem,13rem);text-decoration:none;display:grid}.prose .kg-bookmark-content{min-width:0;padding:1rem}.prose .kg-bookmark-title{color:var(--foreground);font-family:var(--font-title);overflow-wrap:anywhere;font-size:1rem;font-weight:700;line-height:1.45}.prose .kg-bookmark-description{color:var(--muted-foreground);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:.45rem;font-size:.92rem;line-height:1.55;display:-webkit-box;overflow:hidden}.prose .kg-bookmark-metadata{min-width:0;color:var(--muted-foreground);align-items:center;gap:.4rem;margin-top:.8rem;font-size:.82rem;line-height:1.4;display:flex}.prose .kg-bookmark-metadata span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.prose .kg-bookmark-icon{object-fit:contain;border-radius:4px;width:1.25rem;min-width:1.25rem;height:1.25rem}.prose .kg-bookmark-thumbnail{background:var(--muted);min-width:0}.prose .kg-bookmark-thumbnail img{object-fit:cover;width:100%;height:100%;max-height:11rem;display:block}.prose figcaption{color:var(--muted-foreground);text-align:center;margin-top:.5rem;font-size:.92rem}.article-header{border-bottom:1px solid var(--border);margin-bottom:2rem;padding-bottom:1.5rem}.description{color:var(--muted-foreground);margin:1rem 0 0}.tag-list{flex-wrap:wrap;gap:.45rem;margin:1rem 0 0;padding:0;list-style:none;display:flex}.tag-list a,.tag-list span{color:var(--accent);font-size:.9rem;text-decoration:none;display:inline-block}.tag-list a:before,.tag-list span:before{content:"#"}.archive-page ol{margin:2rem 0 0;padding:0;list-style:none}.archive-page li{grid-template-columns:8.5rem minmax(0,1fr);gap:1rem;padding-block:.45rem;display:grid}.archive-page time{color:var(--muted-foreground);font-size:.9rem}.archive-page a{color:var(--accent);overflow-wrap:anywhere;text-underline-offset:.2rem;text-decoration-style:dashed}@media (width>=640px){.top-nav{align-items:center;padding-block:1.5rem}.brand{margin-block:auto;font-size:1.5rem;line-height:1;position:static}.nav-menu{flex-direction:row;justify-content:flex-end;margin-inline-start:.5rem}.menu-btn{display:none}.menu-items{align-items:center;gap:1.05rem;width:auto;margin:0;display:flex!important}.menu-items a,.menu-items button{min-height:2rem;padding:.25rem .2rem}.nav-wide{grid-column:auto}.footer-inner{flex-direction:row-reverse;padding-block:1rem}.copyright{flex-direction:row}.copyright .sep{display:inline}}@media (width<=639px){.sep{display:none}.archive-page li{grid-template-columns:1fr;gap:.1rem}.prose .kg-bookmark-container{grid-template-columns:1fr}.prose .kg-bookmark-thumbnail{order:-1}.prose .kg-bookmark-thumbnail img{max-height:12rem}}
