.brunch-article{max-width:100%;margin:0 auto;padding-bottom:4rem}.brunch-header{position:relative;overflow:hidden;padding:3rem 1.5rem 2rem;text-align:center}.brunch-header-hero{display:flex;min-height:420px;align-items:center;justify-content:center;padding:5rem 1.5rem 4rem}.brunch-header-hero .brunch-header-inner{display:flex;width:min(100%,720px);min-height:230px;flex-direction:column;justify-content:center;max-width:760px;padding:2rem 1.75rem;border-radius:2rem;background:hsla(0,0%,100%,.2);box-shadow:0 24px 80px rgba(68,48,28,.1);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.brunch-hero-backdrop{position:absolute;inset:0;z-index:0;background:#f6f1ea}.brunch-hero-backdrop-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transform:scale(1.1);filter:blur(24px) saturate(115%);opacity:.62}.brunch-hero-backdrop-overlay{position:absolute;inset:0;background:radial-gradient(circle at 50% 28%,hsla(0,0%,100%,.2),transparent 38%),linear-gradient(180deg,hsla(0,0%,100%,.34),hsla(0,0%,100%,.74) 66%,#fff)}.brunch-header-inner{position:relative;z-index:1;max-width:680px;margin:0 auto}[data-theme=dark] .brunch-hero-backdrop{background:#12100f}[data-theme=dark] .brunch-hero-backdrop-image{opacity:.42}[data-theme=dark] .brunch-hero-backdrop-overlay{background:radial-gradient(circle at 50% 24%,hsla(0,0%,100%,.08),transparent 38%),linear-gradient(180deg,rgba(0,0,0,.28),rgba(0,0,0,.76) 62%,#000)}[data-theme=dark] .brunch-header-hero .brunch-header-inner{background:rgba(0,0,0,.18);box-shadow:0 24px 80px rgba(0,0,0,.28)}.brunch-meta{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.85rem;color:#999;letter-spacing:.02em;margin-bottom:1.5rem}.brunch-meta-dot{width:3px;height:3px;border-radius:50%;background:#ccc}.brunch-title{font-family:Pretendard,sans-serif;font-size:2.2rem;font-weight:700;line-height:1.35;color:#1a1a1a;letter-spacing:-.03em;word-break:keep-all;margin:0 0 1rem}[data-theme=dark] .brunch-title{color:#f0f0f0}.brunch-subtitle{font-size:1.1rem;line-height:1.7;color:#666;font-weight:300;margin:0 0 1.5rem;word-break:keep-all}[data-theme=dark] .brunch-subtitle{color:#aaa}.brunch-tags{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.brunch-tag{font-size:.8rem;color:#888;text-decoration:none;transition:color .2s;letter-spacing:.01em}.brunch-tag:hover{color:#333}[data-theme=dark] .brunch-tag:hover{color:#fff}.brunch-divider{display:flex;justify-content:center;padding:1rem 0}.brunch-divider span{display:block;width:40px;height:1px;background:#e0e0e0}[data-theme=dark] .brunch-divider span{background:#333}.brunch-content{max-width:680px;margin:0 auto;padding:0 1.5rem 3rem;font-family:Pretendard,sans-serif;font-size:17px;line-height:1.9;color:#333;letter-spacing:-.01em;word-break:normal;overflow-wrap:anywhere}[data-theme=dark] .brunch-content{color:#ddd}.brunch-content p{margin:0 0 1.8rem;font-weight:400;word-break:normal;overflow-wrap:anywhere}.brunch-content p:last-child{margin-bottom:0}.brunch-content h1{font-size:1.8rem;font-weight:700;color:#1a1a1a;margin:3.5rem 0 1rem;line-height:1.4;letter-spacing:-.02em}.brunch-content h2{font-size:1.45rem;font-weight:600;color:#1a1a1a;margin:3rem 0 .8rem;line-height:1.45;letter-spacing:-.02em}.brunch-content h3{font-size:1.2rem;font-weight:600;color:#333;margin:2.5rem 0 .7rem;line-height:1.5}.brunch-content h4{font-size:1.05rem;font-weight:600;color:#444;margin:2rem 0 .6rem}[data-theme=dark] .brunch-content h1,[data-theme=dark] .brunch-content h2{color:#f0f0f0}[data-theme=dark] .brunch-content h3{color:#ddd}[data-theme=dark] .brunch-content h4{color:#ccc}.brunch-content ol,.brunch-content ul{margin:0 0 1.8rem;padding-left:1.5rem}.brunch-content li{margin:.5rem 0;line-height:1.8}.brunch-content li>p{margin:0}.brunch-content blockquote{margin:2rem 0;padding:1.2rem 1.5rem;border-left:3px solid #e8e8e8;background:transparent;color:#666;font-size:1.05rem;font-style:italic;line-height:1.8}[data-theme=dark] .brunch-content blockquote{border-left-color:#444;color:#aaa}.brunch-content a{color:#3a7bd5;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}.brunch-content a:hover{border-bottom-color:#3a7bd5}.brunch-content strong{font-weight:600;color:#1a1a1a}[data-theme=dark] .brunch-content strong{color:#f0f0f0}.brunch-content .inline-code{font-family:JetBrains Mono,SF Mono,Menlo,Monaco,Consolas,monospace!important;font-size:.85em!important;background:#f0f2f5!important;padding:.2rem .45rem!important;border-radius:4px!important;color:#d63384!important;font-weight:500!important;white-space:nowrap}[data-theme=dark] .brunch-content .inline-code{background:#2a2d35!important;color:#e5c07b!important}.brunch-content .code-block-wrapper.code-light{margin:1.8rem -1.5rem;background:#fafbfc;border-radius:8px;overflow:hidden;border:1px solid #e4e8ec}.code-light .code-block-header{display:flex;align-items:center;justify-content:space-between;padding:.45rem 1.2rem;background:#f0f2f5;border-bottom:1px solid #e4e8ec}.code-light .code-block-lang{font-family:JetBrains Mono,SF Mono,Menlo,monospace;font-size:.7rem;color:#888;text-transform:uppercase;letter-spacing:.08em}.code-light .code-block-copy{font-family:Pretendard,sans-serif;font-size:.72rem;color:#666;background:#fff;border:1px solid #ddd;border-radius:4px;padding:.2rem .6rem;cursor:pointer;transition:all .15s}.code-light .code-block-copy:hover{color:#333;border-color:#aaa}.code-light .code-line-number{display:inline-block;width:2.5rem;text-align:right;margin-right:1rem;color:#b0b8c4;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-size:.8em}.code-light .code-block-toggle{display:block;width:100%;padding:.5rem;font-family:Pretendard,sans-serif;font-size:.75rem;color:#888;background:#f0f2f5;border:none;border-top:1px solid #e4e8ec;cursor:pointer;transition:color .15s;text-align:center}.code-light .code-block-toggle:hover{color:#333}.code-light .code-block-body.code-collapsed:after{background:linear-gradient(transparent,#fafbfc)}.brunch-content .code-block-wrapper.code-dark{margin:1.8rem -1.5rem;background:#1e1e2e;border-radius:8px;overflow:hidden;border:1px solid #2a2a3a}.code-dark .code-block-header{display:flex;align-items:center;justify-content:space-between;padding:.45rem 1.2rem;background:#16161e;border-bottom:1px solid #2a2a3a}.code-dark .code-block-lang{font-family:JetBrains Mono,SF Mono,Menlo,monospace;font-size:.7rem;color:#888;text-transform:uppercase;letter-spacing:.08em}.code-dark .code-block-copy{font-family:Pretendard,sans-serif;font-size:.72rem;color:#888;background:none;border:1px solid #3a3a4a;border-radius:4px;padding:.2rem .6rem;cursor:pointer;transition:all .15s}.code-dark .code-block-copy:hover{color:#ccc;border-color:#666}.code-dark .code-line-number{display:inline-block;width:2.5rem;text-align:right;margin-right:1rem;color:#4a4a5a;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-size:.8em}.code-dark .code-block-toggle{display:block;width:100%;padding:.5rem;font-family:Pretendard,sans-serif;font-size:.75rem;color:#888;background:#16161e;border:none;border-top:1px solid #2a2a3a;cursor:pointer;transition:color .15s;text-align:center}.code-dark .code-block-toggle:hover{color:#ccc}.code-dark .code-block-body.code-collapsed:after{background:linear-gradient(transparent,#1e1e2e)}.code-block-body{position:relative;overflow:hidden}.code-block-body.code-collapsed{max-height:calc(1.65em * 5 + 2rem + 10px)}.code-block-body.code-collapsed:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3rem;pointer-events:none}.code-block-body pre{margin:0!important;border:none!important;box-shadow:none!important;overflow-x:auto!important;max-width:100%}.code-block-body code,.code-block-body pre{font-family:JetBrains Mono,SF Mono,Menlo,Monaco,Consolas,monospace!important;border-radius:0!important}.code-block-body code{background:transparent!important;padding:0!important;color:inherit!important;font-size:inherit!important;white-space:pre!important}.brunch-content .code-block-wrapper{overflow:hidden;max-width:calc(100% + 3rem)}.brunch-article{overflow-x:hidden}.brunch-content .brunch-blockquote{margin:2rem 0!important;padding:1.2rem 1.5rem!important;border-left:3px solid #ddd!important;background:transparent!important;color:#666!important;font-size:1.02rem!important;font-style:italic;line-height:1.8!important}[data-theme=dark] .brunch-content .brunch-blockquote{border-left-color:#444!important;color:#aaa!important}.brunch-figure{margin:2rem 0;text-align:center}.brunch-img{display:block;max-width:100%;margin:0 auto;border-radius:6px;cursor:zoom-in;transition:opacity .2s}.brunch-img:hover{opacity:.9}.brunch-figcaption{margin-top:.6rem;font-size:.82rem;color:#999;text-align:center}[data-theme=dark] .brunch-figcaption{color:#666}.lightbox-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;cursor:zoom-out;animation:lightbox-in .2s ease}@keyframes lightbox-in{0%{opacity:0}to{opacity:1}}.lightbox-img{max-width:90vw;max-height:90vh;-o-object-fit:contain;object-fit:contain;border-radius:4px;cursor:default}.lightbox-close{position:absolute;top:1.2rem;right:1.5rem;background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;opacity:.7;transition:opacity .15s;z-index:10000}.lightbox-close:hover{opacity:1}.brunch-content table{width:100%;border-collapse:collapse;margin:2rem 0;font-size:.92rem}.brunch-content td,.brunch-content th{padding:.75rem 1rem;border-bottom:1px solid #eee;text-align:left}[data-theme=dark] .brunch-content td,[data-theme=dark] .brunch-content th{border-bottom-color:#333}.brunch-content th{font-weight:600;color:#555;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}[data-theme=dark] .brunch-content th{color:#999}.brunch-content hr{border:none;margin:3rem auto;width:40px;height:1px;background:#ddd}[data-theme=dark] .brunch-content hr{background:#444}.brunch-loading{display:flex;flex-direction:column;gap:1rem;padding:2rem 0}.brunch-loading div{height:16px;background:#f0f0f0;border-radius:4px;animation:pulse 1.5s ease-in-out infinite}.brunch-loading div:first-child{width:75%}.brunch-loading div:nth-child(2){width:100%}.brunch-loading div:nth-child(3){width:85%}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}[data-theme=dark] .brunch-loading div{background:#2a2a2a}.brunch-footer{max-width:680px;margin:0 auto;padding:0 1.5rem}.brunch-author{display:flex;align-items:center;gap:1rem;padding:1.5rem 0;justify-content:center}.brunch-author-img{width:48px;height:48px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.brunch-author-name{font-size:.95rem;font-weight:600;color:#333;margin:0}[data-theme=dark] .brunch-author-name{color:#eee}.brunch-author-desc{font-size:.82rem;color:#999;margin:.15rem 0 0}.brunch-back{display:block;margin:2rem auto 0;padding:.7rem 1.5rem;font-size:.85rem;color:#888;background:none;border:1px solid #e0e0e0;border-radius:20px;cursor:pointer;transition:all .2s;font-family:Pretendard,sans-serif}.brunch-back:hover{color:#333;border-color:#999}[data-theme=dark] .brunch-back{border-color:#444;color:#888}[data-theme=dark] .brunch-back:hover{color:#eee;border-color:#777}.brunch-comments{margin-top:3rem}.brunch-related{max-width:680px;margin:0 auto 2.5rem;text-align:left}.brunch-section-kicker{margin:0 0 .35rem;font-family:SF Mono,Menlo,monospace!important;font-size:.68rem;color:#aaa;letter-spacing:.22em;text-transform:uppercase}.brunch-section-title{margin:0 0 1rem;font-size:1.15rem;font-weight:600;color:#222;letter-spacing:-.02em}[data-theme=dark] .brunch-section-title{color:#eee}.brunch-related-list{border-top:1px solid #eee}[data-theme=dark] .brunch-related-list{border-top-color:#2c2c2c}.brunch-related-item{display:flex;gap:1rem;padding:1rem 0;border-bottom:1px solid #eee;text-decoration:none}[data-theme=dark] .brunch-related-item{border-bottom-color:#2c2c2c}.brunch-related-number{flex:0 0 auto;margin-top:.1rem;font-family:SF Mono,Menlo,monospace!important;font-size:.75rem;color:#bbb}.brunch-related-body{display:flex;min-width:0;flex-direction:column;gap:.35rem}.brunch-related-title{color:#333;font-size:1rem;font-weight:500;line-height:1.5;word-break:keep-all}.brunch-related-item:hover .brunch-related-title{text-decoration:underline;text-underline-offset:4px}[data-theme=dark] .brunch-related-title{color:#eee}.brunch-related-meta{color:#999;font-size:.78rem;line-height:1.5}.brunch-post-nav{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:1rem;max-width:680px;margin:0 auto 2.5rem}.brunch-post-nav-card{display:flex;min-height:96px;flex-direction:column;justify-content:center;gap:.5rem;padding:1rem;border:1px solid #eee;border-radius:18px;text-decoration:none;transition:border-color .2s,transform .2s}.brunch-post-nav-card:hover{border-color:#bbb;transform:translateY(-2px)}[data-theme=dark] .brunch-post-nav-card{border-color:#333}[data-theme=dark] .brunch-post-nav-card:hover{border-color:#666}.brunch-post-nav-next{text-align:right}.brunch-post-nav-label{font-size:.78rem;color:#999}.brunch-post-nav-title{color:#333;font-size:.98rem;font-weight:500;line-height:1.5;word-break:keep-all}[data-theme=dark] .brunch-post-nav-title{color:#eee}@media (max-width:768px){.brunch-header{padding:2rem 1rem 1.5rem}.brunch-header-hero{min-height:340px;padding:4rem 1rem 3rem}.brunch-header-hero .brunch-header-inner{width:100%;min-height:210px;padding:1.5rem 1rem;border-radius:1.5rem}.brunch-title{font-size:1.7rem}.brunch-subtitle{font-size:1rem}.brunch-content{padding:0 1rem 2rem;font-size:16px;line-height:1.85}.brunch-content .code-block-wrapper{margin:1.5rem -1rem;border-radius:0}.brunch-content img{margin:2rem -1rem;max-width:calc(100% + 2rem)}.brunch-footer{padding:0 1rem}.brunch-post-nav{grid-template-columns:1fr}.brunch-post-nav-next{text-align:left}}@media (min-width:769px){.brunch-header{padding:4rem 2rem 2.5rem}.brunch-header-hero{padding:5.5rem 2rem 4.5rem}.brunch-title{font-size:2.5rem}}