@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-page: #FFFBF5;--bg-card: #FFFFFF;--bg-code: #F9F5F0;--bg-blockquote: #FAF7F3;--border-card: #E8DDD0;--border-light: #EDE6DC;--text-primary: #2C2420;--text-secondary: #5A4D3E;--text-muted: #8C7D6D;--text-faint: #B0A090;--accent: #7B5EA7;--accent-light: #9B7EC7;--accent-bg: #F0EDF8;--content-width: 680px;--image-breakout: 960px;--font-body: "Pretendard", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "SF Mono", "Fira Code", "Consolas", monospace}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--text-primary);background:var(--bg-page);line-height:1.8}a{color:var(--accent);text-decoration:none;transition:color .15s ease}a:hover{color:var(--accent-light)}.article-header{max-width:var(--content-width);margin:0 auto;padding:80px 24px 0}.article-header .series-badge{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--accent);background:var(--accent-bg);padding:4px 12px;border-radius:20px;margin-bottom:16px}.article-header h1{font-size:36px;font-weight:700;line-height:1.35;color:var(--text-primary);margin-bottom:12px;letter-spacing:-.02em}.article-header .meta{font-size:14px;color:var(--text-muted);display:flex;align-items:center;gap:12px}.article-header .meta .author{display:flex;align-items:center;gap:6px}.article-header .meta .author-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.article-header .meta .dot{color:var(--border-card)}.article-body{max-width:var(--content-width);margin:0 auto;padding:48px 24px 80px}.article-body h1{display:none}.article-body h2{font-size:26px;font-weight:700;margin-top:64px;margin-bottom:16px;color:var(--text-primary);letter-spacing:-.01em}.article-body h3{font-size:20px;font-weight:600;margin-top:56px;margin-bottom:12px;color:var(--text-primary)}.article-body h4{font-size:18px;font-weight:600;margin-top:48px;margin-bottom:10px;color:var(--text-primary)}.article-body p{margin-bottom:12px;font-size:16.5px;line-height:1.8;color:var(--text-primary);word-break:keep-all}.article-body img{display:block;max-width:var(--image-breakout);width:calc(100% + 140px);margin:40px -70px;border-radius:12px;border:1px solid var(--border-card);box-shadow:0 4px 24px #2c24201a}@media(max-width:1100px){.article-body img{width:100%;margin:32px 0}}.article-body blockquote{border-left:3px solid var(--accent);background:var(--bg-blockquote);padding:16px 24px;margin:32px 0;border-radius:0 8px 8px 0}.article-body blockquote p{color:var(--text-secondary);font-size:15.5px;margin-bottom:0}.article-body code{font-family:var(--font-mono);font-size:14px;background:var(--bg-code);color:var(--accent);padding:2px 6px;border-radius:4px}.article-body pre{background:#2c2420;color:#f0ede8;padding:20px 24px;border-radius:10px;overflow-x:auto;margin:32px 0;line-height:1.6;white-space:pre-wrap;word-break:break-word}.article-body pre code{background:none;color:inherit;padding:0;font-size:14px;white-space:pre-wrap;word-break:break-word}.article-body ul,.article-body ol{padding-left:24px;margin-bottom:24px}.article-body li{margin-bottom:8px;font-size:16.5px;line-height:1.75}.article-body .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:24px 0}.article-body table{width:100%;border-collapse:collapse;margin:24px 0;font-size:14.5px;line-height:1.6}.article-body thead th{background:var(--bg-muted, #F5F0EB);font-weight:700;font-size:13.5px;color:var(--text-primary, #1A1512);padding:10px 14px;text-align:left;border-bottom:2px solid var(--border-light, #E8DDD0);white-space:nowrap}.article-body tbody td{padding:10px 14px;border-bottom:1px solid var(--border-light, #E8DDD0);color:var(--text-secondary, #2C2420);vertical-align:top}.article-body tbody tr:last-child td{border-bottom:none}.article-body tbody tr:hover{background:#f5f0eb80}@media(max-width:640px){.article-body table{font-size:13px;display:block;overflow-x:auto;white-space:nowrap}.article-body thead th,.article-body tbody td{padding:8px 10px}}.article-body hr{border:none;height:1px;background:var(--border-light);margin:40px 0}.article-body hr+hr{display:none}.article-body strong{font-weight:600;color:var(--text-primary)}.article-body em{font-style:italic;color:var(--text-secondary)}.back-to-list{max-width:var(--content-width);margin:0 auto;padding:40px 24px 0}.back-to-list.top{padding:24px 24px 0}.back-to-list a{display:inline-flex;align-items:center;font-size:14px;color:var(--text-secondary);text-decoration:none;transition:color .2s}.back-to-list.top a{font-size:20px}.back-to-list a:hover{color:var(--accent)}.article-nav{max-width:var(--content-width);margin:0 auto;padding:40px 24px 80px;display:flex;justify-content:space-between;gap:16px;border-top:1px solid var(--border-light)}.article-nav a{display:flex;flex-direction:column;gap:4px;padding:16px 20px;border-radius:12px;background:var(--bg-card);border:1px solid var(--border-card);transition:all .15s ease;max-width:48%}.article-nav a:hover{border-color:var(--accent);box-shadow:0 2px 12px #7b5ea714}.article-nav .nav-label{font-size:12px;color:var(--text-muted);font-weight:500}.article-nav .nav-title{font-size:15px;font-weight:600;color:var(--text-primary)}.article-nav .next{text-align:right;margin-left:auto}.site-header{position:sticky;top:0;z-index:100;background:#fffbf5d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-light);padding:0 24px}.site-header-inner{max-width:var(--image-breakout);margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:56px}.site-logo{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700;color:var(--text-primary);text-decoration:none}.site-logo .logo-icon{font-size:20px}.site-nav{display:flex;gap:24px}.site-nav a{font-size:14px;font-weight:500;color:var(--text-muted);transition:color .15s}.site-nav a:hover,.site-nav a.active{color:var(--accent)}.site-footer{text-align:center;padding:40px 24px;border-top:1px solid var(--border-light);color:var(--text-muted);font-size:13px}.site-footer a{color:var(--text-muted)}.site-footer a:hover{color:var(--accent)}@media(max-width:768px){.article-header{padding-top:48px}.article-header h1{font-size:28px}.article-body h2{font-size:22px}.article-body{padding:32px 20px 60px}.article-nav{flex-direction:row;gap:10px}.article-nav a{max-width:50%;padding:12px 14px}.article-nav .nav-title{font-size:13px}}
