:root{--bg-primary: #f8fafc;--bg-secondary: #f1f5f9;--bg-tertiary: #e2e8f0;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #94a3b8;--accent: #3b82f6;--accent-hover: #2563eb;--accent-subtle: #dbeafe;--border: #e2e8f0;--shadow: 0 1px 3px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .1);--code-bg: #1e293b;--code-inline-bg: #f1f5f9;--code-inline-text: #d946ef;--card-bg: #ffffff;--scroll-progress: #3b82f6}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #64748b;--accent: #3b82f6;--accent-hover: #60a5fa;--accent-subtle: #1e3a5f;--border: #334155;--shadow: 0 1px 3px rgba(0, 0, 0, .3);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .4);--code-bg: #0d1117;--code-inline-bg: #1e293b;--code-inline-text: #f472b6;--card-bg: #1e293b;--scroll-progress: #3b82f6}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:5rem}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans KR,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.7;transition:background-color .2s ease,color .2s ease;min-height:100vh;display:flex;flex-direction:column}a{color:var(--accent);text-decoration:none;transition:color .15s ease}a:hover{color:var(--accent-hover)}img{max-width:100%;height:auto;display:block}h1,h2,h3,h4,h5,h6{line-height:1.3;font-weight:700;color:var(--text-primary)}h1{font-size:2rem;margin-bottom:1rem}h2{font-size:1.5rem;margin-top:2.5rem;margin-bottom:.75rem}h3{font-size:1.25rem;margin-top:2rem;margin-bottom:.5rem}h4{font-size:1.1rem;margin-top:1.5rem;margin-bottom:.5rem}p{margin-bottom:1.25rem;color:var(--text-secondary)}.container{max-width:768px;margin:0 auto;padding:0 1.5rem;width:100%}.container-wide{max-width:1200px;margin:0 auto;padding:0 1.5rem;width:100%}main{flex:1}.prose{font-size:1rem;line-height:1.8}.prose h2{padding-bottom:.5rem;border-bottom:1px solid var(--border)}.prose h2 a,.prose h3 a,.prose h4 a{color:inherit;text-decoration:none}.prose ul,.prose ol{padding-left:1.5rem;margin-bottom:1.25rem}.prose li{margin-bottom:.35rem;color:var(--text-secondary)}.prose li::marker{color:var(--text-muted)}.prose blockquote{border-left:3px solid var(--accent);padding:.75rem 1rem;margin:1.5rem 0;background:var(--bg-secondary);border-radius:0 8px 8px 0}.prose blockquote p{margin-bottom:0;color:var(--text-secondary)}.prose hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.prose table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.9rem}.prose th,.prose td{padding:.6rem .8rem;border:1px solid var(--border);text-align:left}.prose th{background:var(--bg-secondary);font-weight:600}.prose strong{font-weight:600;color:var(--text-primary)}.prose code:not(pre code){background:var(--code-inline-bg);color:var(--code-inline-text);padding:.15em .4em;border-radius:4px;font-size:.875em;font-family:SF Mono,Fira Code,Cascadia Code,monospace}.prose pre{background:var(--code-bg)!important;border-radius:8px;padding:1.25rem;margin:1.5rem 0;overflow-x:auto;position:relative;border:1px solid var(--border)}.prose pre code{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:.85rem;line-height:1.6}.prose pre:before{content:attr(data-language);position:absolute;top:0;right:0;padding:.2rem .6rem;font-size:.7rem;font-family:SF Mono,monospace;color:var(--text-muted);background:var(--bg-tertiary);border-radius:0 8px 0 6px;text-transform:uppercase;letter-spacing:.05em}.code-block-wrapper{position:relative}.code-block-wrapper:before{content:"";display:block;background:var(--code-bg);border-radius:8px 8px 0 0;padding:.5rem 1rem;border:1px solid var(--border);border-bottom:none;background-image:radial-gradient(circle at 1rem 50%,#ff5f57 5px,transparent 5px),radial-gradient(circle at 2.25rem 50%,#febc2e 5px,transparent 5px),radial-gradient(circle at 3.5rem 50%,#28c840 5px,transparent 5px);background-repeat:no-repeat;height:2rem}.code-block-wrapper pre{border-radius:0 0 8px 8px;margin-top:0;border-top:none}.scroll-progress{position:fixed;top:0;left:0;width:0%;height:3px;background:var(--scroll-progress);z-index:100;transition:width .1s linear}.site-header{position:sticky;top:0;z-index:50;background:var(--bg-primary);border-bottom:1px solid var(--border);backdrop-filter:blur(12px);background-color:color-mix(in srgb,var(--bg-primary) 85%,transparent)}.site-header .header-inner{display:flex;align-items:center;justify-content:space-between;height:3.5rem;max-width:1200px;margin:0 auto;padding:0 1.5rem}.site-header .logo{font-size:1.1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.site-header nav{display:flex;align-items:center;gap:1.5rem}.site-header nav a{color:var(--text-secondary);font-size:.9rem;font-weight:500;transition:color .15s ease}.site-header nav a:hover,.site-header nav a.active{color:var(--accent)}.theme-toggle{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:.35rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease}.theme-toggle:hover{background:var(--bg-secondary);color:var(--text-primary)}.theme-toggle svg{width:1.15rem;height:1.15rem}.site-footer{border-top:1px solid var(--border);padding:2rem 0;text-align:center;color:var(--text-muted);font-size:.85rem;margin-top:4rem}.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-muted);margin-bottom:1.5rem;flex-wrap:wrap}.breadcrumb a{color:var(--text-muted)}.breadcrumb a:hover{color:var(--accent)}.breadcrumb .separator{color:var(--text-muted);user-select:none}.breadcrumb .current{color:var(--text-secondary)}.post-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;font-size:.85rem;color:var(--text-muted);margin-bottom:2rem}.post-meta .divider{width:3px;height:3px;border-radius:50%;background:var(--text-muted)}.tag{display:inline-block;padding:.15rem .6rem;font-size:.75rem;font-weight:500;background:var(--accent-subtle);color:var(--accent);border-radius:9999px;transition:background-color .15s ease}.tag:hover{background:var(--accent);color:#fff}.blog-card{display:block;padding:1.25rem;background:var(--card-bg);border:1px solid var(--border);border-radius:10px;transition:box-shadow .2s ease,transform .2s ease,border-color .2s ease}.blog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--accent)}.blog-card .card-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;line-height:1.4}.blog-card .card-desc{font-size:.875rem;color:var(--text-secondary);margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-card .card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-muted)}.blog-card .card-tags{display:flex;gap:.35rem;margin-top:.5rem}.blog-grid{display:grid;grid-template-columns:1fr;gap:1rem}.category-filter{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}.category-btn{padding:.4rem 1rem;font-size:.85rem;font-weight:500;border:1px solid var(--border);border-radius:9999px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;font-family:inherit}.category-btn:hover{border-color:var(--accent);color:var(--accent)}.category-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:3rem}.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:2.25rem;height:2.25rem;padding:0 .5rem;border-radius:6px;font-size:.9rem;font-weight:500;border:1px solid var(--border);color:var(--text-secondary);transition:all .15s ease}.pagination a:hover{border-color:var(--accent);color:var(--accent)}.pagination .active{background:var(--accent);border-color:var(--accent);color:#fff}.pagination .disabled{opacity:.4;pointer-events:none}.toc-wrapper{display:none}.toc{position:sticky;top:5rem;max-height:calc(100vh - 7rem);overflow-y:auto;padding-right:.5rem}.toc-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.75rem}.toc-list{list-style:none;padding:0;margin:0;border-left:2px solid var(--border)}.toc-list li{margin:0}.toc-list a{display:block;padding:.3rem 0 .3rem 1rem;font-size:.8rem;color:var(--text-muted);border-left:2px solid transparent;margin-left:-2px;transition:color .15s ease,border-color .15s ease;line-height:1.4}.toc-list a:hover{color:var(--text-primary)}.toc-list a.active{color:var(--accent);border-left-color:var(--accent)}.toc-list .depth-3{padding-left:2rem}.toc-mobile{display:block;margin-bottom:2rem}.toc-mobile-toggle{display:flex;align-items:center;gap:.5rem;width:100%;padding:.6rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;font-family:inherit}.toc-mobile-toggle svg{width:1rem;height:1rem;transition:transform .2s ease}.toc-mobile-toggle.open svg{transform:rotate(180deg)}.toc-mobile-content{display:none;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-top:none;border-radius:0 0 8px 8px}.toc-mobile-content.open{display:block}.post-layout{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;gap:3rem}.post-content{flex:1;min-width:0;max-width:768px}.post-sidebar{display:none;width:240px;flex-shrink:0}.about-content h1{margin-bottom:1.5rem}.about-content p{font-size:1.05rem}.hero{padding:4rem 0 3rem;text-align:center}.hero h1{font-size:2.5rem;font-weight:800;letter-spacing:-.03em;margin-bottom:1rem}.hero p{font-size:1.15rem;color:var(--text-secondary);max-width:480px;margin:0 auto 2rem}.hero-link{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.5rem;background:var(--accent);color:#fff;border-radius:8px;font-weight:600;font-size:.95rem;transition:background-color .15s ease}.hero-link:hover{background:var(--accent-hover);color:#fff}.section-title{font-size:1.35rem;font-weight:700;margin-bottom:1.5rem}@media(min-width:768px){.blog-grid{grid-template-columns:repeat(2,1fr)}h1{font-size:2.25rem}}@media(min-width:1024px){.toc-wrapper{display:block}.toc-mobile{display:none}.post-sidebar{display:block}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--accent);color:#fff}.prose a{text-decoration:underline;text-decoration-color:var(--accent);text-underline-offset:2px}.prose a:hover{text-decoration-color:var(--accent-hover)}.prose img{border-radius:8px;margin:1.5rem 0}
