:root{--color-bg: #ffffff;--color-bg-subtle: #f9f9f9;--color-text-main: #1a1a1a;--color-text-muted: #666666;--color-accent-wood: #8d6e63;--color-accent-roof: #2c3e50;--color-accent-red: #c62828;--color-code-bg: #1e1e1e;--font-sans: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, Roboto, "Helvetica Neue", "Segoe UI", "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", sans-serif;--font-serif: "Noto Serif KR", serif;--spacing-unit: 8px;--border-radius: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}:root[data-season=winter]{--color-accent-wood: #607d8b;--color-accent-roof: #263238;--color-accent-red: #546e7a;--color-code-bg: #111827}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text-main);line-height:1.7;-webkit-font-smoothing:antialiased}html{font-size:87.5%}html,body{overflow-x:clip;width:100%;position:relative}a{color:inherit;text-decoration:none;transition:color .2s ease}ul{list-style:none}.container{max-width:1024px;margin:0 auto;padding:0 32px}.page-container{padding-top:120px;padding-bottom:80px;width:100%}@media(max-width:768px){.page-container{padding-top:60px;padding-bottom:40px;margin:0 auto}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.grid{display:grid}.gap-4{gap:16px}.gap-8{gap:32px}@media(max-width:768px){.gap-8{gap:16px}.container{padding:0 24px}}@media(min-width:769px)and (max-width:1024px){.container{padding:0 80px}}.posts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;justify-content:center}@media(min-width:768px){.posts-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.posts-grid{grid-template-columns:1fr!important;gap:20px!important}}h1,h2,h3,h4,h5,h6{font-weight:700;color:var(--color-text-main);line-height:1.3;letter-spacing:-.02em}h1{font-size:3.5rem;font-weight:800}h2{font-size:2rem;margin-bottom:1.5rem}h3{font-size:1.25rem;font-weight:600}p{color:var(--color-text-muted);margin-bottom:1em}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;background-color:var(--color-text-main);color:#fff;border:none;border-radius:50px;cursor:pointer;transition:all .2s ease;font-weight:600;font-size:.95rem}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);background-color:var(--color-accent-roof)}.card{background-color:#fff;border:1px solid rgba(0,0,0,.05);padding:32px;border-radius:var(--border-radius);transition:all .3s cubic-bezier(.4,0,.2,1)}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#0000}.text-serif{font-family:var(--font-serif)}.hanok-accent-line{width:40px;height:2px;background-color:var(--color-accent-wood);margin:24px 0}.bg-pattern-subtle{background-image:radial-gradient(var(--color-text-muted) .5px,transparent .5px);background-size:24px 24px;opacity:.03}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:#9696964d;border-radius:5px;border:2px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background-color:#96969680}.toc-sidebar{width:240px;position:sticky;top:180px;align-self:start;margin-left:60px;font-size:.9rem;border-left:2px solid rgba(0,0,0,.05);padding-left:20px;display:none;max-height:calc(100vh - 200px);overflow-y:auto;overflow-x:hidden}@media(min-width:1280px){.toc-sidebar{display:block}}.toc-title{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:16px}.toc-link{display:block;color:var(--color-text-muted);text-decoration:none;margin-bottom:.8em;transition:all .2s ease;line-height:1.4;word-break:keep-all}.toc-link:hover{color:var(--color-text-main)}.toc-link.active{color:var(--color-accent-wood);font-weight:600;transform:translate(4px)}.toc-link.h2{font-size:.95rem}.toc-link.h3{font-size:.85rem;margin-left:12px}.not-found-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding-top:60px}.not-found-watermark{font-size:6rem;font-weight:900;color:#000;line-height:1;-webkit-user-select:none;user-select:none}.not-found-title{font-size:2rem;margin:20px 0 16px;color:var(--color-text-main)}.not-found-text{color:var(--color-text-muted);margin-bottom:40px;max-width:400px;line-height:1.6}.not-found-button{padding:12px 32px;background:var(--color-text-main);color:var(--color-bg);border:none;border-radius:var(--border-radius);font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s;font-family:var(--font-sans)}.not-found-button:hover{opacity:.9}.post-header{margin-bottom:60px;text-align:center}.post-category{font-size:.9rem;color:var(--color-accent-wood);font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px}.post-title{font-size:2.5rem;margin-bottom:24px;word-break:keep-all}.post-date{color:var(--color-text-muted);font-size:.95rem}.post-footer{margin-top:80px;padding-top:40px;border-top:1px solid rgba(0,0,0,.05);text-align:center}.post-footer-text{font-family:var(--font-serif);font-style:italic;color:var(--color-text-muted);margin-bottom:20px}._markdownContent_1rbwe_2{font-size:1.22rem;line-height:1.8;color:var(--color-text-main)}._markdownContent_1rbwe_2 h1,._markdownContent_1rbwe_2 h2,._markdownContent_1rbwe_2 h3,._markdownContent_1rbwe_2 h4{margin-top:1.625em;margin-bottom:1em;color:var(--color-text-main);line-height:1.4;text-align:center}._markdownContent_1rbwe_2 h1{font-size:2.2rem}._markdownContent_1rbwe_2 h2{font-size:1.8rem;border-bottom:2px solid var(--color-accent-wood);padding-bottom:.5rem;margin-bottom:1.5rem;display:inline-block;width:100%}._markdownContent_1rbwe_2 h3{font-size:1.4rem;font-weight:600;color:var(--color-accent-roof)}._markdownContent_1rbwe_2 p{margin-bottom:1.8em;word-break:keep-all;text-align:left}._markdownContent_1rbwe_2 blockquote{border-left:4px solid var(--color-accent-wood);padding:1.5rem;margin:2rem 0;font-style:italic;color:var(--color-text-muted);background-color:var(--color-bg-subtle);border-radius:0 var(--border-radius) var(--border-radius) 0;text-align:left}._markdownContent_1rbwe_2 blockquote p{margin:0}._markdownContent_1rbwe_2 a{color:var(--color-accent-wood);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;transition:all .2s ease;font-weight:500}._markdownContent_1rbwe_2 a:hover{color:var(--color-accent-roof);text-decoration-thickness:2px}._markdownContent_1rbwe_2 ul,._markdownContent_1rbwe_2 ol{margin-bottom:1.8em;padding-left:1.5em;text-align:left}._markdownContent_1rbwe_2 ul{list-style-type:disc}._markdownContent_1rbwe_2 ol{list-style-type:decimal}._markdownContent_1rbwe_2 li{margin-bottom:.3em;padding-left:.5em}._markdownContent_1rbwe_2 li::marker{color:var(--color-accent-wood)}._markdownContent_1rbwe_2 img{max-width:100%;border-radius:var(--border-radius);box-shadow:var(--shadow-md);margin:2.5em 0;display:block}._markdownContent_1rbwe_2 code{background-color:var(--color-bg-subtle);padding:.2em .4em;border-radius:4px;font-family:monospace;font-size:.9em;color:var(--color-accent-roof)}._markdownContent_1rbwe_2 pre{margin:2rem 0;border-radius:var(--border-radius);max-width:100%;overflow-x:auto}._markdownContent_1rbwe_2 hr{border:0;height:1px;background:linear-gradient(to right,transparent,var(--color-accent-wood),transparent);margin:4rem 0;opacity:.5}._markdownContent_1rbwe_2 strong{font-weight:700;color:var(--color-accent-roof)}._markdownContent_1rbwe_2 em{font-family:var(--font-serif);color:var(--color-accent-wood)}._markdownContent_1rbwe_2 table{width:100%;border-collapse:collapse;margin:2rem 0;overflow-x:auto;display:table}._markdownContent_1rbwe_2 th,._markdownContent_1rbwe_2 td{padding:12px 16px;border:1px solid rgba(0,0,0,.1);text-align:left;font-size:.95rem}._markdownContent_1rbwe_2 th{background-color:var(--color-bg-subtle);font-weight:600;color:var(--color-text-main);border-bottom:2px solid rgba(0,0,0,.1)}._markdownContent_1rbwe_2 tr:nth-child(2n){background-color:#00000005}._codeBlockContainer_1rbwe_167{margin:8px 0;border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid rgba(0,0,0,.1);background-color:#1e1e1e;max-width:100%}._codeHeader_1rbwe_177{background:#1e1e1e;padding:12px 16px;display:flex;align-items:center;border-bottom:1px solid #333}._codeControls_1rbwe_185{display:flex;gap:8px}._codeControlDot_1rbwe_190{width:12px;height:12px;border-radius:50%}._codeTitle_1rbwe_196{flex:1;text-align:center;color:#888;font-size:.8rem;font-family:var(--font-sans);font-weight:500;-webkit-user-select:none;user-select:none}._codeContentWrapper_1rbwe_206{position:relative}._inlineCode_1rbwe_210{background:var(--color-bg-subtle);padding:.2em .4em;border-radius:4px;color:var(--color-accent-roof);font-size:.9em;font-family:Menlo,Monaco,Courier New,monospace}._copyButton_1rbwe_219{background:transparent;border:none;color:#adbac7;padding:6px 12px;border-radius:6px;font-size:.75rem;font-family:var(--font-sans);font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;letter-spacing:.02em;min-width:70px;text-align:center}._copyButton_1rbwe_219:hover{background:#ffffff14;color:#e6edf3}._copyButton_1rbwe_219:active{background:#ffffff1f;transform:scale(.98)}@media(max-width:768px){._markdownContent_1rbwe_2{max-width:100%;overflow-x:hidden;font-size:1rem!important}._markdownContent_1rbwe_2 h1{font-size:1.8rem!important}._markdownContent_1rbwe_2 h2{font-size:1.5rem!important}._markdownContent_1rbwe_2 h3{font-size:1.2rem!important}._markdownContent_1rbwe_2 p{font-size:.95rem!important}._markdownContent_1rbwe_2 pre,._codeBlockContainer_1rbwe_167{max-width:100%;overflow-x:auto}._markdownContent_1rbwe_2 code{word-wrap:break-word;overflow-wrap:break-word;font-size:.85em!important}._markdownContent_1rbwe_2 img{max-width:100%;height:auto}}#root{width:100%;margin:0;padding:0;text-align:left}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
