*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--black:#111;--dark:#1a1a1a;--gray-900:#222;--gray-800:#333;--gray-700:#444;--gray-600:#666;--gray-500:#888;--gray-400:#aaa;--gray-300:#ccc;--gray-200:#e0e0e0;--gray-100:#f0f0f0;--white:#fafafa;--sidebar-width:280px;--font-sans:"Pretendard",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--ease:cubic-bezier(.16,1,.3,1);--duration:.6s;--bg-overlay:#fafafad9;--bg-overlay-heavy:#fafafae6;--shadow-subtle:#0000000a;--shadow-medium:#0000000f;--shadow-heavy:#0000004d}[data-theme=dark]{--black:#e8e8e8;--dark:#d4d4d4;--gray-900:#d0d0d0;--gray-800:#b0b0b0;--gray-700:#999;--gray-600:#888;--gray-500:#777;--gray-400:#666;--gray-300:#444;--gray-200:#333;--gray-100:#222;--white:#161616;--bg-overlay:#161616d9;--bg-overlay-heavy:#161616e6;--shadow-subtle:#00000026;--shadow-medium:#00000040;--shadow-heavy:#00000080}[data-theme=dark] .blog-post pre{color:#ccc;background:#1a1a1a}[data-theme=dark] .blog-post code{color:silver;background:#2a2a2a;border-color:#3a3a3a}[data-theme=dark] .cursor-label{color:#161616;background:#e8e8e8}[data-theme=dark] .scroll-progress{background:#e8e8e8}[data-theme=dark] .about__illustration{background:#fafafa;border-radius:12px;padding:12px}[data-theme=dark] .about__illustration img{mix-blend-mode:normal}[data-theme=dark] .blog-post img{border-radius:8px}[data-theme=dark] .blog-card__category{color:#eee;background:#555}.theme-toggle{border:1px solid var(--gray-200);cursor:pointer;color:var(--gray-600);font-size:.75rem;font-family:var(--font-sans);background:0 0;border-radius:8px;justify-content:center;align-items:center;gap:6px;width:100%;padding:6px 12px;transition:border-color .2s,color .2s;display:flex}.theme-toggle:hover{border-color:var(--gray-400);color:var(--black)}.theme-toggle__icon{width:14px;height:14px}.cursor-label{pointer-events:none;z-index:10000;color:var(--white);background:var(--black);opacity:0;transition:opacity .25s var(--ease),transform .25s var(--ease);white-space:nowrap;border-radius:20px;padding:6px 14px;font-size:.7rem;font-weight:600;position:fixed;transform:translate(-50%,-50%)scale(.7)}.cursor-label--visible{opacity:1;transform:translate(-50%,-50%)scale(1)}.scroll-progress{background:var(--black);z-index:10000;width:0%;height:2px;transition:width .1s linear;position:fixed;top:0;left:0}.noise-overlay{z-index:9998;pointer-events:none;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px;position:fixed;inset:0}.reveal{opacity:0;transition:opacity .8s var(--ease),transform .8s var(--ease);transform:translateY(24px)}.reveal--active{opacity:1;transform:translateY(0)}.reveal-stagger>*{opacity:0;transition:opacity var(--duration)var(--ease),transform var(--duration)var(--ease);transform:translateY(16px)}.reveal-stagger--active>*{opacity:1;transform:translateY(0)}.reveal-stagger--active>:first-child{transition-delay:.1s}.reveal-stagger--active>:nth-child(2){transition-delay:.2s}.reveal-stagger--active>:nth-child(3){transition-delay:.3s}.reveal-stagger--active>:nth-child(4){transition-delay:.4s}.no-js .reveal,.no-js .reveal-stagger>*{opacity:1;transform:none}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background-color:var(--white);color:var(--black);word-break:keep-all;overflow-wrap:break-word;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;cursor:auto;line-height:1.7}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);border-right:1px solid var(--gray-200);background:var(--white);z-index:100;flex-direction:column;justify-content:space-between;height:100vh;padding:48px 32px;display:flex;position:fixed;top:0;left:0}.sidebar__header{flex-direction:column;display:flex}.sidebar__logo{letter-spacing:-.03em;color:var(--black);margin-bottom:8px;font-size:1.2rem;font-weight:800}.sidebar__tagline{color:var(--gray-600);margin-bottom:48px;font-size:.8rem;line-height:1.5}.sidebar__nav{flex-direction:column;gap:4px;display:flex}.sidebar__link{color:var(--gray-600);transition:color var(--duration)var(--ease),background var(--duration)var(--ease);border-radius:6px;align-items:center;gap:10px;padding:10px 12px;font-size:.875rem;font-weight:500;display:flex}.sidebar__link:hover{color:var(--black);background:var(--gray-100)}.sidebar__link--active{color:var(--black);background:var(--gray-100);font-weight:600}.sidebar__link-icon{opacity:.6;width:18px;height:18px}.sidebar__link--active .sidebar__link-icon{opacity:1}.sidebar__footer{flex-direction:column;gap:12px;display:flex}.sidebar__contact{flex-direction:column;gap:8px;display:flex}.sidebar__contact-link{color:var(--gray-600);transition:color var(--duration)var(--ease);align-items:center;gap:8px;font-size:.8rem;display:flex}.sidebar__contact-link:hover{color:var(--black)}.sidebar__contact-icon{opacity:.5;width:14px;height:14px}.sidebar__stats{border-top:1px solid var(--gray-800);color:var(--gray-500);flex-direction:column;gap:6px;margin-top:16px;padding-top:16px;font-size:.72rem;display:flex}.sidebar__stat-row{align-items:center;gap:6px;display:flex}.sidebar__stat-label{flex:1}.sidebar__stat-value{color:var(--gray-300);font-variant-numeric:tabular-nums}.sidebar__presence-dot{background:#4ade80;border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:2s ease-in-out infinite presence-pulse;box-shadow:0 0 6px #4ade8099}@keyframes presence-pulse{0%,to{opacity:1}50%{opacity:.4}}.sidebar__copy{color:var(--gray-500);margin-top:8px;font-size:.7rem}.main{margin-left:var(--sidebar-width);flex:1;justify-content:center;min-height:100vh;display:flex}.main__content{width:100%;max-width:1100px;padding:64px 56px;overflow-x:hidden}.hero{grid-template-columns:1fr 1fr;align-items:center;gap:48px;padding-bottom:40px;display:grid}.hero__text{flex-direction:column;display:flex}.hero__visual{justify-content:center;align-items:center;max-width:100%;min-height:360px;display:flex;overflow:hidden}#hero-canvas{border-radius:8px;width:100%;max-width:100%;height:100%;min-height:360px;display:block}.hero__label{letter-spacing:.12em;text-transform:uppercase;color:var(--gray-600);margin-bottom:20px;font-size:.7rem;font-weight:600}.hero__title{letter-spacing:-.03em;color:var(--black);margin-bottom:20px;font-size:clamp(2rem,3.5vw,2.75rem);font-weight:800;line-height:1.2}.hero__title .char{transition:opacity .1s;display:inline-block}.hero__subtitle{color:var(--gray-600);margin-bottom:36px;font-size:.95rem;line-height:1.8}.hero__highlight{color:var(--black);font-weight:800}.wg{word-break:keep-all;display:inline-block}.hero__cta{color:var(--black);border-bottom:1.5px solid var(--black);transition:gap var(--duration)var(--ease);align-self:flex-start;align-items:center;gap:8px;padding-bottom:4px;font-size:.85rem;font-weight:600;display:inline-flex}.hero__cta:hover{gap:12px}.hero__cta svg{width:16px;height:16px;transition:transform var(--duration)var(--ease)}.hero__cta:hover svg{transform:translate(3px)}.section{border-top:1px solid var(--gray-200);padding:40px 0 36px}.section__label{letter-spacing:.12em;text-transform:uppercase;color:var(--gray-600);margin-bottom:12px;font-size:.7rem;font-weight:600}.section__title{letter-spacing:-.02em;margin-bottom:32px;font-size:1.75rem;font-weight:700}.about__grid{grid-template-columns:1fr 1fr;align-items:start;gap:48px;display:grid}.about__text p{color:var(--gray-700);margin-bottom:12px;font-size:.95rem;line-height:1.8}.about__illustration{opacity:.8;width:80%;max-width:320px;transition:opacity .4s var(--ease);margin-top:20px}.about__illustration img{mix-blend-mode:multiply}.about__illustration:hover{opacity:1}.about__traits{grid-template-columns:1fr;gap:16px;margin-top:0;display:grid}.trait{border:1px solid var(--gray-200);transition:border-color var(--duration)var(--ease),transform .15s ease-out,box-shadow var(--duration)var(--ease);transform-style:preserve-3d;will-change:transform;border-radius:8px;padding:20px 24px;position:relative;overflow:hidden}.trait:before{content:"";border-radius:inherit;opacity:0;transition:opacity .4s var(--ease);pointer-events:none;background:radial-gradient(300px circle at var(--glow-x,50%)var(--glow-y,50%),#0000000a,transparent 60%);position:absolute;inset:0}.trait:hover:before{opacity:1}.trait:hover{border-color:var(--gray-400);box-shadow:0 8px 24px #0000000f}.trait__header{align-items:center;gap:10px;margin-bottom:8px;display:flex}.trait__icon-svg{width:20px;height:20px;color:var(--gray-600);flex-shrink:0}.trait__title{color:var(--black);font-size:.85rem;font-weight:700}.trait__desc{color:var(--gray-600);font-size:.8rem;line-height:1.6}.page-header{padding-bottom:24px}.page-header__title{letter-spacing:-.03em;margin-bottom:8px;font-size:clamp(2rem,4vw,2.5rem);font-weight:800}.page-header__desc{color:var(--gray-600);font-size:.95rem}.projects__grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.project-card{border:1px solid var(--gray-200);transition:border-color var(--duration)var(--ease),transform .15s ease-out,box-shadow var(--duration)var(--ease);transform-style:preserve-3d;will-change:transform;border-radius:10px;position:relative;overflow:hidden}.project-card:before{content:"";border-radius:inherit;opacity:0;transition:opacity .4s var(--ease);pointer-events:none;z-index:1;background:radial-gradient(400px circle at var(--glow-x,50%)var(--glow-y,50%),#00000008,transparent 60%);position:absolute;inset:0}.project-card:hover:before{opacity:1}.project-card:hover{border-color:var(--gray-400);box-shadow:0 12px 32px #00000014}.project-card__thumb{aspect-ratio:2;background:var(--gray-100);width:100%;color:var(--gray-500);letter-spacing:.05em;border-bottom:1px solid var(--gray-200);justify-content:center;align-items:center;font-size:.75rem;display:flex}.project-card__body{padding:16px}.project-card__meta-row{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.project-card__tag{letter-spacing:.05em;text-transform:uppercase;color:var(--gray-600);background:var(--gray-100);border-radius:4px;padding:3px 8px;font-size:.65rem;font-weight:600;display:inline-block}.project-card__views{color:var(--gray-400);font-size:.65rem}.project-card__title{letter-spacing:-.01em;color:var(--black);margin-bottom:4px;font-size:1rem;font-weight:700}.project-card__desc{color:var(--gray-600);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:10px;font-size:.8rem;line-height:1.6;display:-webkit-box;overflow:hidden}.project-card__stack{flex-wrap:wrap;gap:6px;display:flex}.project-card__stack-item{font-size:.65rem;font-weight:500;font-family:var(--font-mono);border:1px solid var(--gray-200);color:var(--gray-600);border-radius:4px;padding:3px 8px}.project-card{cursor:auto}.project-card__link{color:var(--black);border-bottom:1px solid var(--black);align-items:center;gap:6px;margin-top:10px;padding-bottom:2px;font-size:.75rem;font-weight:600;display:inline-flex}@media (min-width:860px){.project-card__link{opacity:0;height:0;margin:0;padding:0;overflow:hidden}}.mobile-header{display:none}.hamburger{cursor:auto;background:0 0;border:none;padding:8px}.hamburger svg{width:22px;height:22px;color:var(--black)}.sidebar__overlay{display:none}@media (max-width:1200px){.hero{grid-template-columns:1fr;gap:32px}.hero__visual{max-height:320px}#hero-canvas{min-height:280px}.about__grid{grid-template-columns:1fr;gap:32px}.projects__grid{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}.reveal,.reveal-stagger>*{opacity:1;transform:none}.noise-overlay,#hero-canvas{display:none}}@media (max-width:860px){body{cursor:auto}.sidebar{transition:transform .4s var(--ease);z-index:200;transform:translate(-100%)}.sidebar--open{transform:translate(0)}.sidebar__overlay{z-index:150;background:#0000004d;display:none;position:fixed;inset:0}.sidebar__overlay--visible{display:block}.mobile-header{background:var(--bg-overlay-heavy);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--gray-200);z-index:100;justify-content:space-between;align-items:center;height:56px;padding:0 20px;display:flex;position:fixed;top:0;left:0;right:0}.mobile-header__logo{letter-spacing:-.02em;color:var(--black);font-size:1rem;font-weight:800}.hamburger{cursor:pointer}.main{margin-left:0}.main__content{padding:80px 24px 48px}.hero{grid-template-columns:1fr;gap:32px}.hero__visual{order:-1;min-height:260px}#hero-canvas{min-height:260px}.about__grid,.about__traits,.projects__grid{grid-template-columns:1fr}}.project-card__thumb--terminal{background:var(--gray-900);border-bottom:1px solid var(--gray-800);padding:0}.terminal-mock{flex-direction:column;width:100%;height:100%;display:flex}.terminal-mock__bar{background:var(--gray-800);gap:6px;padding:10px 14px;display:flex}.terminal-mock__dot{background:var(--gray-600);border-radius:50%;width:10px;height:10px}.terminal-mock__dot:first-child{background:#ff5f57}.terminal-mock__dot:nth-child(2){background:#febc2e}.terminal-mock__dot:nth-child(3){background:#28c840}.terminal-mock__body{font-family:var(--font-mono);color:var(--gray-300);flex-direction:column;gap:4px;padding:14px 18px;font-size:.72rem;line-height:1.6;display:flex}.project-card__thumb--app-mock{background:var(--gray-900);justify-content:center;align-items:center;padding:0;display:flex}.app-mock{background:var(--white);border-radius:16px;width:55%;max-width:200px;margin:16px 0;overflow:hidden;box-shadow:0 8px 32px #0000004d}.app-mock__statusbar{color:var(--gray-600);background:var(--gray-100);justify-content:space-between;align-items:center;padding:6px 12px;font-size:.55rem;font-weight:600;display:flex}.app-mock__body{flex-direction:column;gap:8px;padding:12px;display:flex}.app-mock__card{background:var(--gray-100);border-radius:8px;align-items:center;gap:8px;padding:10px;display:flex}.app-mock__emoji{font-size:1.2rem}.app-mock__restaurant{color:var(--black);font-size:.7rem;font-weight:700}.app-mock__votes{justify-content:center;gap:6px;display:flex}.app-mock__vote{border-radius:12px;padding:3px 10px;font-size:.6rem;font-weight:600}.app-mock__vote--yes{color:#166534;background:#dcfce7}.app-mock__vote--no{background:var(--gray-100);color:var(--gray-500)}.app-mock__roulette{text-align:center;background:var(--black);color:var(--white);border-radius:6px;padding:6px;font-size:.6rem;font-weight:600}.project-card__thumb--video{background:var(--gray-900);padding:0;overflow:hidden}.project-card__thumb--video video{object-fit:cover;width:100%;height:100%;display:block}.terminal-mock__green{color:#28c840}.terminal-mock__dim{color:var(--gray-600)}.terminal-mock__body--animated .terminal-mock__line{opacity:0;animation:terminal-line-in .4s var(--ease)forwards;animation-delay:calc(.8s + var(--line-index)*.6s);transform:translateY(6px)}.terminal-mock__body--animated .terminal-mock__line:first-child:after{content:"▋";color:var(--gray-400);margin-left:2px;animation:1s step-end .8s infinite terminal-blink}@keyframes terminal-line-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes terminal-blink{0%,to{opacity:1}50%{opacity:0}}.project-detail__header-meta{align-items:center;gap:12px;margin-bottom:16px;display:flex}.page-header__views{color:var(--gray-500);font-size:.75rem}.project-detail__back{width:fit-content;color:var(--gray-600);transition:color var(--duration)var(--ease);align-items:center;gap:4px;margin-bottom:28px;font-size:.8rem;font-weight:500;display:flex}.project-detail__back:hover{color:var(--black)}.project-detail__overview{grid-template-columns:1fr;gap:24px;display:grid}.project-detail__overview-text p{color:var(--gray-700);margin-bottom:12px;font-size:.95rem;line-height:1.8}.project-detail__meta{flex-wrap:wrap;gap:8px;display:flex}.project-detail__badge{font-size:.7rem;font-weight:500;font-family:var(--font-mono);border:1px solid var(--gray-200);color:var(--gray-600);border-radius:4px;padding:4px 10px}.project-detail__code{background:var(--gray-100);border:1px solid var(--gray-200);border-radius:8px;margin-bottom:32px;padding:24px;overflow-x:auto}.project-detail__code pre{font-family:var(--font-mono);color:var(--gray-700);margin:0;font-size:.8rem;line-height:1.7}.project-detail__modules,.project-detail__features{grid-template-columns:1fr 1fr;gap:16px;display:grid}.project-detail__flow{flex-direction:column;gap:0;display:flex}.project-detail__flow-step{border:1px solid var(--gray-200);background:var(--white);border-radius:8px;align-items:flex-start;gap:16px;padding:20px 24px;display:flex}.project-detail__flow-step strong{margin-bottom:4px;font-size:.85rem;font-weight:700;display:block}.project-detail__flow-step p{color:var(--gray-600);font-size:.8rem;line-height:1.5}.project-detail__flow-num{font-family:var(--font-mono);color:var(--gray-500);background:var(--gray-100);border-radius:4px;flex-shrink:0;padding:4px 8px;font-size:.7rem;font-weight:700}.project-detail__flow-connector{background:var(--gray-300);width:1px;height:16px;margin-left:38px}.project-detail__footer{border-top:1px solid var(--gray-200);margin-top:20px;padding:40px 0 20px}.project-detail__github{color:var(--black);border-bottom:1.5px solid var(--black);transition:gap var(--duration)var(--ease);align-items:center;gap:8px;padding-bottom:4px;font-size:.85rem;font-weight:600;display:inline-flex}.project-detail__github:hover{gap:12px}.project-detail__stats{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.project-detail__stat{border:1px solid var(--gray-200);border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:24px 16px;display:flex}.project-detail__stat-value{font-family:var(--font-mono);color:var(--black);letter-spacing:-.02em;font-size:1.5rem;font-weight:800}.project-detail__stat-label{color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:500}.floating-toc{z-index:50;background:var(--bg-overlay);-webkit-backdrop-filter:blur(12px);border:1px solid var(--gray-200);border-radius:10px;flex-direction:column;gap:2px;padding:8px 4px;display:flex;position:fixed;top:50%;right:36px;transform:translateY(-50%)}.floating-toc__item{cursor:pointer;transition:background .25s var(--ease);background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;padding:7px 14px 7px 12px;display:flex}.floating-toc__item:hover{background:var(--gray-100)}.floating-toc__indicator{background:var(--gray-300);width:3px;height:14px;transition:background .3s var(--ease),height .3s var(--ease);border-radius:2px;flex-shrink:0}.floating-toc__label{color:var(--gray-500);letter-spacing:.02em;white-space:nowrap;transition:color .3s var(--ease);font-size:.75rem;font-weight:500}.floating-toc__item:hover .floating-toc__label{color:var(--gray-700)}.floating-toc__item:hover .floating-toc__indicator{background:var(--gray-500)}.floating-toc__item--active{background:var(--gray-100)}.floating-toc__item--active .floating-toc__indicator{background:var(--black);height:18px}.floating-toc__item--active .floating-toc__label{color:var(--black);font-weight:700}@media (max-width:1200px){.floating-toc{display:none}.project-detail__modules,.project-detail__features{grid-template-columns:1fr}.project-detail__stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:860px){.section{padding:28px 0 24px}.section__title{margin-bottom:20px;font-size:1.35rem}.page-header__title{font-size:1.6rem}.page-header__desc{font-size:.85rem;line-height:1.7}.project-detail__back{margin-bottom:20px}.project-detail__modules,.project-detail__features{grid-template-columns:1fr}.project-detail__stats{grid-template-columns:repeat(2,1fr)}.project-detail__code{margin-bottom:20px;padding:16px}.project-detail__code pre{font-size:.7rem;line-height:1.6}.project-detail__overview-text p{font-size:.85rem;line-height:1.7}.project-detail__flow-step{gap:12px;padding:14px 16px}.project-detail__flow-step strong{font-size:.8rem}.project-detail__flow-step p{font-size:.75rem}.project-detail__flow-connector{height:12px;margin-left:30px}.project-detail__stat{padding:16px 12px}.project-detail__stat-value{font-size:1.2rem}.project-detail__footer{padding:28px 0 16px}.trait{padding:20px}.trait__title{font-size:.85rem}.trait__desc{font-size:.78rem}}@media (max-width:480px){.section__title{margin-bottom:16px;font-size:1.2rem}.page-header__title{font-size:1.35rem}.project-detail__stats{grid-template-columns:1fr 1fr;gap:10px}.project-detail__stat{padding:14px 8px}.project-detail__stat-value{font-size:1rem}.project-detail__stat-label{font-size:.6rem}.project-detail__code{border-radius:6px;padding:12px}.project-detail__code pre{font-size:.62rem}.project-detail__flow-step{gap:10px;padding:12px}.project-detail__flow-num{padding:3px 6px;font-size:.6rem}.project-detail__flow-connector{margin-left:24px}.trait{padding:16px}}.blog-categories{flex-wrap:wrap;gap:8px;margin-bottom:32px;display:flex}.blog-categories__chip{border:1px solid var(--gray-200);color:var(--gray-600);background:0 0;border-radius:20px;padding:6px 16px;font-size:.8rem;font-weight:600;text-decoration:none;transition:all .2s}.blog-categories__chip:hover{border-color:var(--gray-400);color:var(--gray-800)}.blog-categories__chip--active{background:var(--gray-900);border-color:var(--gray-900);color:var(--gray-100)}.blog-categories__chip--active:hover{background:var(--gray-800);border-color:var(--gray-800);color:var(--gray-100)}.blog-filters{margin-bottom:32px}.blog-filters .blog-categories{margin-bottom:0}.blog-series-filters{border-top:1px solid var(--gray-150,#e8e8e8);flex-wrap:wrap;gap:6px;margin-top:10px;padding-top:10px;display:flex}.blog-series-filters__chip{border:1px solid var(--gray-150,#e8e8e8);color:var(--gray-500);background:0 0;border-radius:14px;align-items:center;gap:4px;padding:4px 12px;font-size:.75rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.blog-series-filters__chip:hover{border-color:var(--gray-300);color:var(--gray-700)}.blog-series-filters__chip--active{background:var(--gray-800);border-color:var(--gray-800);color:var(--gray-100)}.blog-series-filters__chip--active:hover{background:var(--gray-700);border-color:var(--gray-700);color:var(--gray-100)}.blog-series-filters__count{color:var(--gray-400);background:var(--gray-100);text-align:center;border-radius:8px;min-width:16px;padding:0 5px;font-size:.65rem;font-weight:600}.blog-series-filters__chip--active .blog-series-filters__count{color:var(--gray-300);background:var(--gray-600)}.blog-series-float{z-index:50;background:var(--bg-overlay);-webkit-backdrop-filter:blur(12px);border:1px solid var(--gray-200);border-radius:10px;flex-direction:column;gap:2px;width:200px;max-height:70vh;padding:10px 6px;display:flex;position:fixed;top:50%;right:36px;overflow-y:auto;transform:translateY(-50%)}@media (min-width:1201px){.blog-series-filters{display:none}}@media (max-width:1200px){.blog-series-float{display:none}}.blog-series-float__title{color:var(--gray-400);text-transform:uppercase;letter-spacing:.06em;margin:0;padding:4px 12px 6px;font-size:.65rem;font-weight:700}.blog-series-card{color:inherit;border-radius:6px;align-items:center;gap:10px;padding:7px 12px;text-decoration:none;transition:background .2s;display:flex}.blog-series-card:hover{background:var(--gray-100)}.blog-series-card__thumb{background:var(--gray-100);border-radius:5px;flex-shrink:0;width:28px;height:28px;overflow:hidden}.blog-series-card__thumb img{object-fit:cover;width:100%;height:100%}.blog-series-card__content{flex-direction:column;gap:1px;min-width:0;display:flex}.blog-series-card__label{color:var(--gray-800);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;font-weight:600;overflow:hidden}.blog-series-card__meta{color:var(--gray-500);font-size:.65rem}.blog-series-header{align-items:baseline;gap:10px;margin-bottom:20px;display:flex}.blog-series-header__title{color:var(--gray-900);margin:0;font-size:1.1rem;font-weight:700}.blog-series-header__count{color:var(--gray-500);font-size:.8rem;font-weight:500}.blog-list{flex-direction:column;gap:0;display:flex}.blog-card{border-bottom:1px solid var(--gray-200)}.blog-card:first-child{border-top:1px solid var(--gray-200)}.blog-card__link{transition:background .25s var(--ease);gap:20px;padding:20px 0;display:flex;position:relative}.blog-card__link:hover{background:var(--gray-100);border-radius:8px;margin:0 -16px;padding:20px 16px}.blog-card__link:hover .blog-card__views{right:16px}.blog-card__thumb{background:var(--gray-100);border-radius:6px;flex-shrink:0;width:160px;height:100px;overflow:hidden}.blog-card__thumb img{object-fit:cover;width:100%;height:100%}.blog-card__body{flex-direction:column;justify-content:center;min-width:0;display:flex}.blog-card__date{color:var(--gray-500);margin-bottom:6px;font-size:.75rem}.blog-card__title{letter-spacing:-.01em;color:var(--black);margin-bottom:6px;font-size:1.1rem;font-weight:700;line-height:1.4}.blog-card__desc{color:var(--gray-600);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:10px;font-size:.85rem;line-height:1.6;display:-webkit-box;overflow:hidden}.blog-card__tags{flex-wrap:wrap;gap:6px;display:flex}.blog-card__tag{letter-spacing:.03em;color:var(--gray-600);background:var(--gray-100);border-radius:4px;padding:3px 8px;font-size:.65rem;font-weight:600}.blog-card__meta{align-items:center;gap:8px;margin-bottom:6px;display:flex}.blog-card__meta .blog-card__date{margin-bottom:0}.blog-card__views{color:var(--gray-500);white-space:nowrap;font-size:.75rem;position:absolute;top:20px;right:0}.blog-card__category{letter-spacing:.03em;color:var(--gray-100);background:var(--gray-700);border-radius:10px;padding:2px 8px;font-size:.65rem;font-weight:700}.blog-card__series-badge{letter-spacing:.02em;color:var(--gray-700);background:var(--gray-150,#e8e8e8);border:1px solid var(--gray-200);border-radius:10px;padding:2px 8px;font-size:.65rem;font-weight:600}.blog-series-nav{border:1px solid var(--gray-200);border-radius:8px;margin-bottom:40px;overflow:hidden}.blog-series-nav__header{background:var(--gray-50);cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--gray-800);align-items:center;gap:8px;padding:14px 20px;font-size:.85rem;font-weight:700;display:flex}.blog-series-nav__header::-webkit-details-marker{display:none}.blog-series-nav__header:before{content:"▶";color:var(--gray-500);font-size:.6rem;transition:transform .2s}details[open]>.blog-series-nav__header:before{transform:rotate(90deg)}.blog-series-nav__count{color:var(--gray-500);background:var(--gray-200);border-radius:10px;padding:1px 7px;font-size:.7rem;font-weight:600}.blog-series-nav__list{counter-reset:series;margin:0;padding:8px 0;list-style:none}.blog-series-nav__item{counter-increment:series;padding:0}.blog-series-nav__link,.blog-series-nav__current{color:var(--gray-600);padding:8px 20px;font-size:.8rem;line-height:1.5;text-decoration:none;transition:background .15s,color .15s;display:block}.blog-series-nav__link:hover{background:var(--gray-50);color:var(--gray-900)}.blog-series-nav__item--current{background:var(--gray-100)}.blog-series-nav__current{color:var(--gray-900);font-weight:700}.blog-pagination{justify-content:center;align-items:center;gap:8px;padding:48px 0 24px;display:flex}.blog-pagination__link{color:var(--gray-600);border-radius:6px;padding:6px 14px;font-size:.8rem;font-weight:500;transition:color .2s,background .2s}.blog-pagination__link:hover{color:var(--black);background:var(--gray-100)}.blog-pagination__pages{gap:4px;display:flex}.blog-pagination__page{color:var(--gray-500);border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:.8rem;font-weight:500;transition:color .2s,background .2s;display:flex}.blog-pagination__page:hover{color:var(--black);background:var(--gray-100)}.blog-pagination__page--active{color:var(--black);background:var(--gray-100);font-weight:700}.blog-post{padding-bottom:64px}.blog-post__meta{align-items:center;gap:12px;margin-bottom:12px;display:flex}.blog-post__date,.blog-post__reading-time{color:var(--gray-500);font-size:.8rem}.blog-post__reading-time:before{content:"·";margin-right:12px}.blog-post__views{color:var(--gray-500);font-size:.8rem}.blog-post__views:before{content:"·";margin-right:12px}.blog-post__tags{gap:6px;display:flex}.blog-post h2{letter-spacing:-.02em;color:var(--black);border-top:1px solid var(--gray-200);margin-top:48px;margin-bottom:16px;padding-top:24px;font-size:1.4rem;font-weight:700}.blog-post h3{color:var(--black);margin-top:32px;margin-bottom:12px;font-size:1.1rem;font-weight:700}.blog-post p{color:var(--gray-700);margin-bottom:16px;font-size:.95rem;line-height:1.85}.blog-post a{color:var(--black);border-bottom:1px solid var(--gray-400);font-weight:600;transition:border-color .2s}.blog-post a:hover{border-color:var(--black)}.blog-post img{border:1px solid var(--gray-200);border-radius:8px;max-width:100%;margin:24px 0}.blog-post blockquote{border-left:3px solid var(--gray-300);background:var(--gray-100);border-radius:0 6px 6px 0;margin:24px 0;padding:12px 20px}.blog-post blockquote p{color:var(--gray-600);margin-bottom:0;font-size:.9rem;font-style:italic}.blog-post pre{background:var(--gray-900);color:var(--gray-300);font-family:var(--font-mono);border-radius:8px;margin:20px 0;padding:20px 24px;font-size:.82rem;line-height:1.7;overflow-x:auto}.blog-post pre code{font-family:var(--font-mono);font-size:inherit;color:inherit;background:0 0;border:none;padding:0}.blog-post .hljs-keyword,.blog-post .hljs-selector-tag,.blog-post .hljs-built_in{color:#e0e0e0;font-weight:600}.blog-post .hljs-string,.blog-post .hljs-attr{color:#b0b0b0}.blog-post .hljs-comment,.blog-post .hljs-quote{color:#666;font-style:italic}.blog-post .hljs-number,.blog-post .hljs-literal{color:#ccc}.blog-post .hljs-title,.blog-post .hljs-function{color:#d8d8d8}.blog-post .hljs-type,.blog-post .hljs-class{color:silver}.blog-post .hljs-meta,.blog-post .hljs-doctag{color:#999}.blog-post .hljs-variable,.blog-post .hljs-params{color:#d0d0d0}.blog-post .hljs-addition{color:#a0d0a0}.blog-post .hljs-deletion{color:#d0a0a0}.blog-post code{font-family:var(--font-mono);background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-200);border-radius:4px;padding:2px 6px;font-size:.85em}.blog-post ul{margin-bottom:16px;padding-left:24px;list-style-type:disc}.blog-post ol{margin-bottom:16px;padding-left:24px;list-style-type:decimal}.blog-post ul ul{margin-top:6px;margin-bottom:6px;list-style-type:circle}.blog-post ul ul ul{list-style-type:square}.blog-post ol ol{margin-top:6px;margin-bottom:6px;list-style-type:lower-alpha}.blog-post li{color:var(--gray-700);margin-bottom:6px;font-size:.95rem;line-height:1.8}.blog-post li>p{margin-bottom:4px}.blog-post hr{border:none;border-top:1px solid var(--gray-200);margin:40px 0}.blog-post table{border-collapse:collapse;width:100%;margin:20px 0;font-size:.85rem}.blog-post th,.blog-post td{border:1px solid var(--gray-200);text-align:left;padding:8px 12px}.blog-post th{background:var(--gray-100);font-weight:600}.tldr-box{border:1px solid var(--gray-300);background:0 0;border-radius:8px;align-items:baseline;gap:12px;margin-bottom:32px;padding:16px 20px;display:flex}.tldr-box__label{letter-spacing:.06em;text-transform:uppercase;color:var(--gray-500);white-space:nowrap;flex-shrink:0;font-size:.7rem;font-weight:800}.tldr-box__text{color:var(--gray-700);margin:0;font-size:.9rem;line-height:1.6}.related-posts{border-top:1px solid var(--gray-200);margin-top:48px;padding-top:32px}.related-posts__title{color:var(--black);margin-bottom:16px;font-size:1rem;font-weight:700}.related-posts__grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.related-posts__card{border:1px solid var(--gray-200);transition:background .25s var(--ease),border-color .25s var(--ease);border-radius:8px;flex-direction:column;gap:6px;padding:16px;display:flex}.related-posts__card:hover{background:var(--gray-100);border-color:var(--gray-300)}.related-posts__card-title{color:var(--black);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.85rem;font-weight:600;line-height:1.4;display:-webkit-box;overflow:hidden}.related-posts__card-desc{color:var(--gray-600);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.78rem;line-height:1.5;display:-webkit-box;overflow:hidden}.blog-post iframe{border:1px solid var(--gray-200);border-radius:8px;max-width:100%;margin:24px 0}.blog-nav{border-top:1px solid var(--gray-200);justify-content:space-between;gap:24px;margin-top:20px;padding:40px 0 24px;display:flex}.blog-nav__link{max-width:45%;transition:background .25s var(--ease);border-radius:8px;flex-direction:column;gap:4px;padding:16px;display:flex}.blog-nav__link:hover{background:var(--gray-100)}.blog-nav__link--next{text-align:right;margin-left:auto}.blog-nav__label{color:var(--gray-500);font-size:.75rem;font-weight:500}.blog-nav__title{color:var(--black);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.85rem;font-weight:600;line-height:1.4;display:-webkit-box;overflow:hidden}@media (max-width:860px){.blog-card__link{flex-direction:column;gap:12px}.blog-card__thumb{width:100%;height:180px}.blog-post h2{font-size:1.2rem}.blog-post pre{padding:16px;font-size:.78rem}.blog-nav{flex-direction:column;gap:12px}.blog-nav__link{max-width:100%}.blog-nav__link--next{text-align:left}}.blog-comments{border-top:1px solid var(--gray-200);margin-top:48px;padding-top:48px}.comments__form{flex-direction:column;gap:12px;margin-bottom:32px;display:flex}.comments__form-row{gap:12px;display:flex}.comments__input{background:var(--white);border:1px solid var(--gray-200);color:var(--black);font-family:var(--font-sans);transition:border-color .3s var(--ease);border-radius:6px;outline:none;flex:1;padding:10px 14px;font-size:.85rem}.comments__input::placeholder,.comments__textarea::placeholder{color:var(--gray-500)}.comments__input:focus{border-color:var(--gray-400)}.comments__input--small{flex:0 0 160px}.comments__textarea{background:var(--white);border:1px solid var(--gray-200);width:100%;color:var(--black);font-family:var(--font-sans);resize:vertical;transition:border-color .3s var(--ease);border-radius:6px;outline:none;min-height:80px;padding:12px 14px;font-size:.85rem}.comments__textarea:focus{border-color:var(--gray-400)}.comments__form-actions{justify-content:flex-end;align-items:center;gap:12px;display:flex}.comments__error{color:var(--gray-600);font-size:.8rem}.comments__submit{background:var(--gray-900);color:var(--gray-100);font-family:var(--font-sans);cursor:pointer;transition:background .3s var(--ease);border:none;border-radius:6px;padding:10px 24px;font-size:.85rem;font-weight:600}.comments__submit:hover{background:var(--black)}.comments__submit:disabled{opacity:.4;cursor:not-allowed}.comments__list{flex-direction:column;display:flex}.comments__empty{text-align:center;color:var(--gray-500);padding:32px 0;font-size:.85rem}.comments__item{border-top:1px solid var(--gray-200);padding:20px 0}.comments__item:last-child{border-bottom:1px solid var(--gray-200)}.comments__item-header{align-items:center;gap:12px;margin-bottom:8px;display:flex}.comments__nickname{color:var(--black);font-size:.85rem;font-weight:700}.comments__date{color:var(--gray-500);font-size:.75rem}.comments__content{color:var(--gray-700);white-space:pre-wrap;word-break:break-word;font-size:.85rem;line-height:1.7}.comments__item-actions{gap:8px;margin-top:10px;display:flex}.comments__action-btn{color:var(--gray-500);font-size:.75rem;font-family:var(--font-sans);cursor:pointer;background:0 0;border:none;padding:2px 4px;transition:color .2s}.comments__action-btn:hover{color:var(--black)}.comments__edit-form,.comments__delete-confirm{margin-top:8px}.comments__edit-actions{align-items:center;gap:8px;margin-top:8px;display:flex}.comments__btn{background:var(--gray-100);color:var(--black);border:1px solid var(--gray-200);font-family:var(--font-sans);cursor:pointer;transition:border-color .3s var(--ease),background .3s var(--ease);border-radius:4px;padding:6px 16px;font-size:.8rem}.comments__btn:hover{border-color:var(--gray-400);background:var(--gray-200)}.comments__btn--cancel{border-color:var(--gray-200);color:var(--gray-500);background:0 0}.comments__btn--cancel:hover{color:var(--black);border-color:var(--gray-400);background:0 0}.comments__btn--danger{border-color:var(--gray-200);color:var(--gray-600);background:0 0}.comments__btn--danger:hover{border-color:var(--gray-400);color:var(--black)}@media (max-width:600px){.comments__form-row{flex-direction:column}.comments__input--small{flex:1}}
