:root{color-scheme:light dark;--bg:#fff;--bg-alt:#fbfbfa;--text:#37352f;--muted:#787774;--border:#e9e9e7;--line-strong:#d9d8d6;--accent:#0b6e99;--shadow:rgba(17,24,39,.05);--sidebar-width:160px;--right-width:220px;--layout-gap:32px;--content-width:1240px;--radius:6px;--notion-default:#37352f;--notion-gray:#787774;--notion-brown:#9f6b53;--notion-orange:#d9730d;--notion-yellow:#cb912f;--notion-green:#448361;--notion-blue:#337ea9;--notion-purple:#9065b0;--notion-pink:#c14c8a;--notion-red:#d44c47;--pill-bg:#f1f1ef;--code-bg:#f7f6f3;--code-border:#e9e9e7;--code-text:#37352f;--code-meta:#787774}:root[data-theme=light]{color-scheme:light}:root[data-theme=dark]{color-scheme:dark;--bg:#191919;--bg-alt:#202020;--text:#e9e9e7;--muted:#9b9a97;--border:#373737;--line-strong:#4a4a4a;--accent:#5ba9d6;--shadow:rgba(0,0,0,.35);--notion-default:#e9e9e7;--notion-gray:#9b9a97;--notion-brown:#937264;--notion-orange:#ffa344;--notion-yellow:#ffdc49;--notion-green:#4dad84;--notion-blue:#529cca;--notion-purple:#9a6dd7;--notion-pink:#e255a1;--notion-red:#ff7369;--pill-bg:#2c2c2c;--code-bg:#2a2b2e;--code-border:#3a3d42;--code-text:#e9e9e7;--code-meta:#9b9a97}@media (prefers-color-scheme:dark){:root:not([data-theme]){color-scheme:dark;--bg:#191919;--bg-alt:#202020;--text:#e9e9e7;--muted:#9b9a97;--border:#373737;--line-strong:#4a4a4a;--accent:#5ba9d6;--shadow:rgba(0,0,0,.35);--notion-default:#e9e9e7;--notion-gray:#9b9a97;--notion-brown:#937264;--notion-orange:#ffa344;--notion-yellow:#ffdc49;--notion-green:#4dad84;--notion-blue:#529cca;--notion-purple:#9a6dd7;--notion-pink:#e255a1;--notion-red:#ff7369;--pill-bg:#2c2c2c;--code-bg:#2a2b2e;--code-border:#3a3d42;--code-text:#e9e9e7;--code-meta:#9b9a97}}*{box-sizing:border-box}html{scrollbar-gutter:stable}body{margin:0;overflow-y:scroll;font-family:Pretendard,IBM Plex Sans KR,system-ui,-apple-system,sans-serif;color:var(--text);background:var(--bg)}a{color:inherit;text-decoration:none;transition:color .15s ease}a:hover{color:var(--accent)}img{max-width:100%;display:block}.page{min-height:100vh}.meta{color:var(--muted);font-size:12px;display:flex;gap:8px;align-items:center}.header{position:-webkit-sticky;position:sticky;top:0;z-index:40;background:color-mix(in srgb,var(--bg) 92%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.header__inner{max-width:var(--content-width);margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between}.header__logo{font-family:inherit;font-weight:700;font-size:20px;letter-spacing:-.02em}.header__nav{display:flex;align-items:center;gap:20px;font-size:12px;text-transform:uppercase;letter-spacing:.12em;font-family:inherit}.header__nav a{display:inline-flex;align-items:center;min-height:32px}.header__menu-toggle{display:none;width:34px;height:34px;padding:7px 6px;align-items:stretch;flex-direction:column;justify-content:space-between;border-radius:8px;border:1px solid var(--border);background:var(--bg-alt);color:var(--muted);cursor:pointer}.header__menu-toggle span{display:block;width:100%;height:2px;border-radius:999px;background:currentColor;transition:transform .2s ease,opacity .2s ease}.header__menu-toggle.is-open span:first-child{transform:translateY(9px) rotate(45deg)}.header__menu-toggle.is-open span:nth-child(2){opacity:0}.header__menu-toggle.is-open span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}.header__menu-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.28);border:none;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:39}.header__menu-backdrop.is-open{display:block;opacity:1;pointer-events:auto}.header__menu-panel{display:none;position:fixed;top:0;right:0;width:min(340px,90vw);height:100dvh;padding:18px 18px 24px;background:var(--bg);border-left:1px solid var(--border);transform:translateX(100%);transition:transform .24s ease;z-index:40;overflow-y:auto}.header__menu-panel.is-open{display:block;transform:translateX(0)}.header__menu-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.header__menu-head button{border:1px solid var(--border);background:var(--bg-alt);color:var(--muted);border-radius:999px;padding:6px 12px;font-size:12px;cursor:pointer}.header__menu-title{margin:14px 0 10px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.header__menu-section{display:flex;flex-direction:column;gap:2px}.header__menu-section a{padding:10px 8px;border-radius:8px;transition:background-color .18s ease,color .18s ease}.header__menu-section a:hover{background:color-mix(in srgb,var(--bg-alt) 82%,transparent)}.theme-toggle{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:var(--bg-alt);color:var(--muted);border-radius:999px;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;padding:0;font-size:14px;line-height:1;cursor:pointer}.theme-toggle:hover{color:var(--accent);border-color:var(--line-strong)}.theme-toggle__icon{width:16px;height:16px;display:inline-flex}.theme-toggle__icon svg{width:100%;height:100%;display:block}.layout{max-width:var(--content-width);margin:0 auto;padding:32px 24px 80px;display:grid;grid-template-columns:var(--sidebar-width) minmax(0,1fr) var(--right-width);grid-gap:var(--layout-gap);gap:var(--layout-gap);background:transparent}.sidebar-left,.sidebar-right{position:relative}.sidebar-left__inner{position:-webkit-sticky;position:sticky;top:120px;display:flex;flex-direction:column;gap:28px}.main{min-width:0}.sidebar-profile{position:-webkit-sticky;position:sticky;top:120px;gap:32px}.profile,.sidebar-profile{display:flex;flex-direction:column}.profile{gap:8px;padding:0;background:transparent;align-items:center}.profile__image{width:96px;height:96px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}.profile__placeholder{background:var(--border)}.profile__name{font-weight:600;font-size:18px}.profile__role{color:var(--muted);font-size:13px}.profile-section h3{font-size:12px;text-transform:uppercase;letter-spacing:.12em;margin:0 0 12px;color:var(--muted)}.profile-section ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.profile-section{border-top:1px solid color-mix(in srgb,var(--border) 80%,transparent);padding-top:16px}.profile-section a,.profile-section__item{display:flex;align-items:center;gap:8px;font-size:14px;padding-bottom:8px;border-bottom:none}.contact-icon,.project-icon{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;background:var(--pill-bg);font-size:12px}.contact-list img,.project-icon img{width:18px;height:18px;border-radius:4px}.category-menu h3,.related h3,.toc h3{font-size:12px;text-transform:uppercase;letter-spacing:.12em}.category-menu ul{list-style:none;padding:0;margin:12px 0 0;display:flex;flex-direction:column;gap:2px}.category-menu li a{display:block;padding:8px 0;border-radius:0;font-size:14px;color:var(--muted);background:transparent;border:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .2s ease}.category-menu li a:hover{color:var(--accent)}.category-menu li a.is-active{color:var(--text);font-weight:600}.toc__list{display:flex;gap:12px}.toc__line{width:1px;background:var(--border);border-radius:0}.toc__list ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.toc__item a{font-size:13px;color:var(--muted);display:inline-block;border-radius:6px;padding:2px 6px;margin-left:-6px;transition:color .18s ease,background-color .18s ease,transform .18s ease}.toc__item a:hover{color:var(--text);background:color-mix(in srgb,var(--pill-bg) 75%,transparent);transform:translateX(2px)}.toc__item.level-2 a{color:var(--text);font-weight:600}.related li{padding:10px 0;border-bottom:1px solid var(--border)}.feed{display:flex;flex-direction:column;gap:24px}.feed__search{position:static;display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:12px;border:1px solid var(--border);background:color-mix(in srgb,var(--bg-alt) 94%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:none}.feed__search input{border:none;outline:none;width:100%;background:transparent;color:var(--text);font-size:14px}.feed__list{display:flex;flex-direction:column;gap:0}.feed__item{display:flex;justify-content:space-between;gap:24px;padding:24px 0;min-height:168px;border-bottom:1px solid var(--border)}.feed__item:last-child{border-bottom:none}.feed__text{display:flex;flex:1 1;min-width:0;flex-direction:column}.feed__text h2{margin:0 0 8px;font-size:28px;letter-spacing:-.02em}.feed__text h2 a{transition:color .2s ease}.feed__text p{margin:0 0 14px;color:var(--muted)}.feed__meta-group{margin-top:auto;display:flex;flex-direction:column;gap:8px}.feed__categories{display:flex;flex-wrap:wrap;gap:6px}.feed__categories .category-pill{font-size:11px}.feed__thumb{width:180px;flex-shrink:0;margin-left:auto;border-radius:10px;overflow:hidden}.feed__thumb img{width:100%;height:120px;border-radius:10px;object-fit:cover;background:var(--border);border:none;transition:transform .28s ease}.feed__item .meta{transition:color .2s ease}.feed__item:hover .feed__text h2 a{color:var(--accent)}.feed__item:hover .feed__thumb img{transform:scale(1.03)}.feed__item:hover .meta{color:color-mix(in srgb,var(--muted) 70%,var(--text))}.home__content{display:flex;flex-direction:column;gap:16px}.home__empty{padding:24px;border-radius:12px;background:var(--bg-alt);border:1px solid var(--border)}.post-detail{display:flex;flex-direction:column;gap:24px}.post-detail__header h1{font-size:42px;margin:8px 0;line-height:1.1;letter-spacing:-.03em}.post-detail__categories{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.category-pill{padding:5px 10px;border-radius:999px;font-size:12px;background:var(--pill-bg)}.post-detail__hero img{margin-top:24px;border-radius:12px;width:100%;height:auto;border:none}.post-detail__content p{line-height:1.8;margin:12px 0}.post-detail__content h2,.post-detail__content h3,.post-detail__content h4{margin:32px 0 10px;padding-top:0;border-top:none;scroll-margin-top:110px}.post-detail__content blockquote{margin:20px 0;padding:12px 16px;border-left:3px solid var(--accent);background:color-mix(in srgb,var(--bg-alt) 75%,var(--bg));border-top:none;border-bottom:none}.post-detail__content-loading{min-height:240px;display:grid;place-items:center}.callout{display:flex;gap:12px;padding:16px;border-radius:10px;background:color-mix(in srgb,var(--bg-alt) 85%,var(--bg));border:1px solid var(--border)}.callout-icon{font-size:20px}table{width:100%;border-collapse:collapse;margin:16px 0;font-size:14px}td{border:1px solid var(--border);padding:8px 12px}.code-block{background:var(--code-bg);color:var(--code-text);padding:14px 16px;border-radius:8px;overflow-x:auto;border:1px solid var(--code-border);font-size:13px;line-height:1.6}.code-block__meta{font-size:11px;color:var(--code-meta);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.code-block__content{display:block;white-space:pre;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.embed iframe{width:100%;min-height:360px;border:none;border-radius:12px}.post-detail__nav{display:flex;justify-content:space-between;gap:20px;font-size:13px;border-top:1px solid var(--border);padding-top:16px}.category-list ul,.post-detail__related ul,.series-detail ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.category-list li,.series-detail li{padding:12px 16px;border-radius:10px;background:var(--bg-alt);border:1px solid var(--border)}.post-detail__related-item{padding:14px 0;border-bottom:1px solid var(--border)}.post-detail__related-item a{font-weight:600}.post-detail__related-summary{margin:6px 0 0;color:var(--muted);line-height:1.6;min-height:1.6em}.post-detail__related-date{display:inline-block;margin-top:6px;font-size:12px;color:var(--muted)}.post-detail__series ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.post-detail__related,.post-detail__series{min-height:140px}.post-detail__related-empty,.post-detail__series-empty{height:100px}.category-detail__header,.category-menu,.post-detail__related,.post-detail__series,.related,.series-detail__header,.toc{border:none;background:transparent;padding:0}.category-detail__header,.series-detail__header{margin-bottom:16px}.post-detail__related{border-top:1px solid var(--border);padding-top:20px}.color-default{color:var(--notion-default)}.color-default,.color-gray{border:1px solid var(--border)}.color-gray{color:var(--notion-gray)}.color-brown{color:var(--notion-brown);border:1px solid var(--notion-brown)}.color-orange{color:var(--notion-orange);border:1px solid var(--notion-orange)}.color-yellow{color:var(--notion-yellow);border:1px solid var(--notion-yellow)}.color-green{color:var(--notion-green);border:1px solid var(--notion-green)}.color-blue{color:var(--notion-blue);border:1px solid var(--notion-blue)}.color-purple{color:var(--notion-purple);border:1px solid var(--notion-purple)}.color-pink{color:var(--notion-pink);border:1px solid var(--notion-pink)}.color-red{color:var(--notion-red);border:1px solid var(--notion-red)}:root[data-theme=light] .category-pill{font-weight:500}:root[data-theme=light] .category-pill.color-default{color:var(--notion-default);border-color:color-mix(in srgb,var(--notion-default) 22%,#fff);background:color-mix(in srgb,var(--notion-default) 10%,#fff)}:root[data-theme=light] .category-pill.color-gray{color:var(--notion-gray);border-color:color-mix(in srgb,var(--notion-gray) 36%,#fff);background:color-mix(in srgb,var(--notion-gray) 14%,#fff)}:root[data-theme=light] .category-pill.color-brown{color:var(--notion-brown);border-color:color-mix(in srgb,var(--notion-brown) 58%,#fff);background:color-mix(in srgb,var(--notion-brown) 18%,#fff)}:root[data-theme=light] .category-pill.color-orange{color:var(--notion-orange);border-color:color-mix(in srgb,var(--notion-orange) 58%,#fff);background:color-mix(in srgb,var(--notion-orange) 18%,#fff)}:root[data-theme=light] .category-pill.color-yellow{color:color-mix(in srgb,var(--notion-yellow) 80%,#4e3a00);border-color:color-mix(in srgb,var(--notion-yellow) 58%,#fff);background:color-mix(in srgb,var(--notion-yellow) 22%,#fff)}:root[data-theme=light] .category-pill.color-green{color:var(--notion-green);border-color:color-mix(in srgb,var(--notion-green) 58%,#fff);background:color-mix(in srgb,var(--notion-green) 18%,#fff)}:root[data-theme=light] .category-pill.color-blue{color:var(--notion-blue);border-color:color-mix(in srgb,var(--notion-blue) 58%,#fff);background:color-mix(in srgb,var(--notion-blue) 18%,#fff)}:root[data-theme=light] .category-pill.color-purple{color:var(--notion-purple);border-color:color-mix(in srgb,var(--notion-purple) 58%,#fff);background:color-mix(in srgb,var(--notion-purple) 18%,#fff)}:root[data-theme=light] .category-pill.color-pink{color:var(--notion-pink);border-color:color-mix(in srgb,var(--notion-pink) 58%,#fff);background:color-mix(in srgb,var(--notion-pink) 18%,#fff)}:root[data-theme=light] .category-pill.color-red{color:var(--notion-red);border-color:color-mix(in srgb,var(--notion-red) 58%,#fff);background:color-mix(in srgb,var(--notion-red) 18%,#fff)}@media (prefers-color-scheme:light){:root:not([data-theme]) .category-pill{font-weight:500}:root:not([data-theme]) .category-pill.color-default{color:var(--notion-default);border-color:color-mix(in srgb,var(--notion-default) 22%,#fff);background:color-mix(in srgb,var(--notion-default) 10%,#fff)}:root:not([data-theme]) .category-pill.color-gray{color:var(--notion-gray);border-color:color-mix(in srgb,var(--notion-gray) 36%,#fff);background:color-mix(in srgb,var(--notion-gray) 14%,#fff)}:root:not([data-theme]) .category-pill.color-brown{color:var(--notion-brown);border-color:color-mix(in srgb,var(--notion-brown) 58%,#fff);background:color-mix(in srgb,var(--notion-brown) 18%,#fff)}:root:not([data-theme]) .category-pill.color-orange{color:var(--notion-orange);border-color:color-mix(in srgb,var(--notion-orange) 58%,#fff);background:color-mix(in srgb,var(--notion-orange) 18%,#fff)}:root:not([data-theme]) .category-pill.color-yellow{color:color-mix(in srgb,var(--notion-yellow) 80%,#4e3a00);border-color:color-mix(in srgb,var(--notion-yellow) 58%,#fff);background:color-mix(in srgb,var(--notion-yellow) 22%,#fff)}:root:not([data-theme]) .category-pill.color-green{color:var(--notion-green);border-color:color-mix(in srgb,var(--notion-green) 58%,#fff);background:color-mix(in srgb,var(--notion-green) 18%,#fff)}:root:not([data-theme]) .category-pill.color-blue{color:var(--notion-blue);border-color:color-mix(in srgb,var(--notion-blue) 58%,#fff);background:color-mix(in srgb,var(--notion-blue) 18%,#fff)}:root:not([data-theme]) .category-pill.color-purple{color:var(--notion-purple);border-color:color-mix(in srgb,var(--notion-purple) 58%,#fff);background:color-mix(in srgb,var(--notion-purple) 18%,#fff)}:root:not([data-theme]) .category-pill.color-pink{color:var(--notion-pink);border-color:color-mix(in srgb,var(--notion-pink) 58%,#fff);background:color-mix(in srgb,var(--notion-pink) 18%,#fff)}:root:not([data-theme]) .category-pill.color-red{color:var(--notion-red);border-color:color-mix(in srgb,var(--notion-red) 58%,#fff);background:color-mix(in srgb,var(--notion-red) 18%,#fff)}}@media (max-width:1280px){.layout{padding:28px 20px 72px;grid-template-columns:148px minmax(0,1fr) 200px;gap:24px}.header__inner{padding:14px 20px}.feed__text h2{font-size:24px}.post-detail__header h1{font-size:36px}}@media (max-width:1080px){.layout{grid-template-columns:1fr;gap:20px}.sidebar-left,.sidebar-right{display:none}.header__menu-toggle{display:inline-flex}.feed__item{min-height:0;flex-direction:column;gap:16px}.feed__thumb{width:100%;margin-left:0}.feed__thumb img{height:180px}.post-detail__header h1{font-size:34px}}@media (max-width:900px){.layout{padding:20px 16px 56px}.header__inner{padding:12px 16px}.header__logo{font-size:18px}.header__nav{gap:14px;font-size:11px;letter-spacing:.1em}.meta{flex-wrap:wrap;row-gap:4px}.feed{gap:18px}.feed__item{padding:18px 0}.feed__text h2{font-size:22px}.post-detail{gap:20px}.post-detail__header h1{font-size:30px;line-height:1.15}.post-detail__nav{flex-direction:column;align-items:flex-start;gap:10px}.post-detail__related,.post-detail__series{min-height:120px}}@media (max-width:640px){.layout{padding:16px 12px 44px}.header__inner{padding:10px 12px}.header__logo{max-width:64vw;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.header__nav{gap:10px}.theme-toggle{width:30px;height:30px}.feed{gap:16px}.feed__search{padding:10px 12px;gap:8px}.feed__search input{font-size:13px}.feed__text h2{font-size:20px;margin-bottom:6px;line-height:1.25}.feed__text p{margin-bottom:10px;font-size:14px}.feed__thumb img{height:150px}.post-detail{gap:16px}.post-detail__header h1{font-size:28px;margin:6px 0;letter-spacing:-.02em}.post-detail__content p{margin:10px 0;font-size:15px;line-height:1.75}.post-detail__content h2,.post-detail__content h3,.post-detail__content h4{margin:24px 0 8px;scroll-margin-top:92px}.post-detail__content blockquote{margin:16px 0;padding:10px 12px}.post-detail__content-loading{min-height:180px}.embed iframe{min-height:240px}.code-block{padding:12px;font-size:12px}table{display:block;overflow-x:auto;white-space:nowrap}td{padding:6px 8px}.post-detail__related-item{padding:12px 0}.post-detail__related-summary{font-size:14px}.post-detail__related,.post-detail__series{min-height:100px}.post-detail__related-empty,.post-detail__series-empty{height:72px}}@font-face{font-family:__pretendard_6bb8e5;src:url(/_next/static/media/d83e92f0af8b17e4-s.p.woff2) format("woff2");font-display:swap;font-weight:100;font-style:normal}@font-face{font-family:__pretendard_6bb8e5;src:url(/_next/static/media/e52907b750a6f61e-s.p.woff2) format("woff2");font-display:swap;font-weight:200;font-style:normal}@font-face{font-family:__pretendard_6bb8e5;src:url(/_next/static/media/ed42d1b51efd45f6-s.p.woff2) format("woff2");font-display:swap;font-weight:300;font-style:normal}@font-face{font-family:__pretendard_6bb8e5;src:url(/_next/static/media/9031250013752d4b-s.p.woff2) format("woff2");font-display:swap;font-weight:400;font-style:normal}@font-face{font-family:__pretendard_6bb8e5;src:url(/_next/static/media/fba9d678ff638e59-s.p.woff2) format("woff2");font-display:swap;font-weight:500;font-style:normal}@font-face{font-family:__pretendard_6bb8e5;src:url(/_next/static/media/eb9adf802b0a60eb-s.p.woff2) format("woff2");font-display:swap;font-weight:600;font-style:normal}@font-face{font-family:__pretendard_6bb8e5;src:url(/_next/static/media/81b352a4d7a000ae-s.p.woff2) format("woff2");font-display:swap;font-weight:700;font-style:normal}@font-face{font-family:__pretendard_6bb8e5;src:url(/_next/static/media/41b9b3ece820718f-s.p.woff2) format("woff2");font-display:swap;font-weight:800;font-style:normal}@font-face{font-family:__pretendard_6bb8e5;src:url(/_next/static/media/d587d1c112526568-s.p.woff2) format("woff2");font-display:swap;font-weight:900;font-style:normal}@font-face{font-family:__pretendard_Fallback_6bb8e5;src:local("Arial");ascent-override:93.76%;descent-override:23.75%;line-gap-override:0.00%;size-adjust:101.55%}.__className_6bb8e5{font-family:__pretendard_6bb8e5,__pretendard_Fallback_6bb8e5}