*,: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:#b8b8b8;--gray-700:#a8a8a8;--gray-600:#999;--gray-500:#888;--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}.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;overflow-x:hidden}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__sub-nav{flex-direction:column;margin-top:2px;margin-bottom:2px;padding-left:30px;display:flex}.sidebar__sub-link{color:var(--gray-500);border-radius:4px;align-items:center;gap:6px;padding:5px 10px;font-size:.75rem;text-decoration:none;transition:all .15s;display:flex}.sidebar__sub-link:hover{color:var(--black);background:var(--gray-100)}[data-theme=dark] .sidebar__sub-link:hover{color:var(--white);background:var(--gray-800)}.sidebar__status-badge{letter-spacing:.02em;border-radius:3px;flex-shrink:0;margin-left:auto;padding:1px 6px;font-size:.6rem;font-weight:600}.sidebar__status-badge--done{background:var(--gray-800);color:var(--white)}.sidebar__status-badge--wip{color:#16a34a;background:#dcfce7}[data-theme=dark] .sidebar__status-badge--wip{color:#86efac;background:#14532d}.sidebar__status-badge--todo{background:var(--gray-200);color:var(--gray-500)}.sidebar__new-badge{letter-spacing:.05em;color:#fff;cursor:default;background:#22c55e;border-radius:4px;margin-left:auto;padding:2px 6px;font-size:.55rem;font-weight:700;animation:2s ease-in-out infinite new-badge-pulse;position:relative}.sidebar__new-badge:after{content:attr(data-tooltip);white-space:nowrap;background:var(--gray-900);color:#fff;letter-spacing:0;opacity:0;pointer-events:none;z-index:100;border-radius:6px;padding:6px 10px;font-size:.7rem;font-weight:500;transition:opacity .15s;position:absolute;top:50%;left:calc(100% + 10px);transform:translateY(-50%)}[data-theme=dark] .sidebar__new-badge:after{background:var(--gray-200);color:#111}.sidebar__new-badge:hover:after{opacity:1}@keyframes new-badge-pulse{0%,to{opacity:1}50%{opacity:.6}}.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}.sidebar__comments{margin-top:24px;position:relative}.sidebar__comments-toggle{width:100%;color:var(--gray-600);cursor:pointer;transition:color var(--duration)var(--ease),background var(--duration)var(--ease);text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;padding:10px 12px;font-family:inherit;font-size:.875rem;font-weight:500;display:flex}.sidebar__comments-toggle:hover{color:var(--black);background:var(--gray-100)}.sidebar__comments-badge{background:var(--black);min-width:18px;height:18px;color:var(--white);animation:badge-pop .3s var(--ease);border-radius:9px;justify-content:center;align-items:center;margin-left:auto;padding:0 5px;font-size:.65rem;font-weight:700;line-height:1;display:inline-flex}@keyframes badge-pop{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.sidebar__comments-panel{border:1px solid var(--gray-200);background:var(--white);border-radius:8px;max-height:320px;margin-top:4px;overflow-y:auto}.sidebar__comments-empty{text-align:center;color:var(--gray-500);padding:20px;font-size:.78rem}.sidebar__comments-list{margin:0;padding:0;list-style:none}.sidebar__comments-item{border-bottom:1px solid var(--gray-100)}.sidebar__comments-item:last-child{border-bottom:none}.sidebar__comments-link{transition:background var(--duration)var(--ease);flex-direction:column;gap:3px;padding:10px 12px;display:flex}.sidebar__comments-link:hover{background:var(--gray-50)}.sidebar__comments-nick{color:var(--black);font-size:.75rem;font-weight:600}.sidebar__comments-text{color:var(--gray-600);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.75rem;line-height:1.4;display:-webkit-box;overflow:hidden}.sidebar__comments-time{color:var(--gray-400);margin-top:1px;font-size:.65rem}.sidebar__comments-type-badge{color:#16a34a;background:#22c55e1a;border-radius:4px;margin-bottom:2px;padding:1px 5px;font-size:.6rem;font-weight:700;display:inline-block}[data-theme=dark] .sidebar__comments-type-badge{color:#4ade80;background:#22c55e26}.sidebar__comments-item--suggestion .sidebar__comments-link{border-left:2px solid #22c55e66;padding-left:8px}.main{margin-left:var(--sidebar-width);flex:1;justify-content:center;min-height:100vh;display:flex;overflow-x:hidden}.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}.section__desc{color:var(--gray-500);margin-top:-24px;margin-bottom:20px;font-size:.85rem}.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}.project-card__thumb--image{background:var(--gray-100);padding:24px 32px;overflow:hidden}.project-card__thumb-img{object-fit:contain;width:100%;height:100%;box-shadow:0 2px 8px var(--shadow-subtle);transition:transform .4s var(--ease);border-radius:8px}.project-card:hover .project-card__thumb-img{transform:scale(1.03)}.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--habit-mock{background:var(--white);justify-content:center;align-items:center;padding:0;display:flex}.habit-mock{width:65%;max-width:220px;padding:16px}.habit-mock__date{color:var(--gray-400);letter-spacing:-.01em;margin-bottom:12px;font-size:.6rem;font-weight:600}.habit-mock__list{flex-direction:column;gap:8px;display:flex}.habit-mock__item{border:1px solid var(--gray-200);border-radius:8px;align-items:center;gap:8px;padding:8px 10px;transition:all .15s;display:flex}.habit-mock__item--done{border-color:var(--gray-300);background:var(--gray-50)}.habit-mock__check{color:var(--gray-300);flex-shrink:0;font-size:.55rem}.habit-mock__item--done .habit-mock__check{color:var(--black)}.habit-mock__icon{flex-shrink:0;font-size:.75rem}.habit-mock__label{color:var(--gray-500);font-size:.65rem;font-weight:500}.habit-mock__item--done .habit-mock__label{color:var(--black);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-blog-nav{border:1px solid var(--gray-200);border-radius:8px;margin-bottom:40px;overflow:hidden}.project-blog-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}.project-blog-nav__header::-webkit-details-marker{display:none}.project-blog-nav__badge{color:var(--white);background:var(--black);letter-spacing:.02em;border-radius:4px;padding:2px 8px;font-size:.65rem;font-weight:700}.project-blog-nav__header:before{content:"▶";color:var(--gray-500);font-size:.6rem;transition:transform .2s}details[open]>.project-blog-nav__header:before{transform:rotate(90deg)}.project-blog-nav__count{color:var(--gray-500);background:var(--gray-200);border-radius:10px;padding:1px 7px;font-size:.7rem;font-weight:600}.project-blog-nav__list{counter-reset:series;margin:0;padding:8px 0;list-style:none}.project-blog-nav__item{counter-increment:series;padding:0}.project-blog-nav__link{color:var(--gray-600);padding:8px 20px;font-size:.8rem;line-height:1.5;text-decoration:none;transition:background .15s,color .15s;display:block}.project-blog-nav__link:before{content:counter(series)". ";color:var(--gray-400);font-weight:600}.project-blog-nav__link:hover{background:var(--gray-50);color:var(--gray-900)}.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-600);background:var(--gray-200);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-100);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);overflow:hidden}.blog-card:first-child{border-top:1px solid var(--gray-200)}.blog-card__link{transition:background .25s var(--ease);gap:20px;padding:20px 12px;display:flex;position:relative}.blog-card__link:hover{background:var(--gray-100);border-radius:8px;margin:0 -4px;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;flex:1;justify-content:center;min-width:0;display:flex;overflow:hidden}.blog-card__date{color:var(--gray-500);margin-bottom:6px;font-size:.75rem}.blog-card__title{letter-spacing:-.01em;color:var(--black);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:6px;font-size:1.1rem;font-weight:700;line-height:1.4;display:-webkit-box;overflow:hidden}.blog-card__new{letter-spacing:.05em;color:#fff;vertical-align:middle;background:#22c55e;border-radius:4px;margin-right:6px;padding:2px 6px;font-size:.55rem;font-weight:700;animation:2s ease-in-out infinite new-badge-pulse;display:inline-block}.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-600);background:var(--gray-100);border:1px solid var(--gray-200);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{flex-wrap:wrap;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{flex-wrap:wrap;justify-content:center;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}.blog-search{margin-bottom:24px}.blog-search__input{width:100%;color:var(--black);background:var(--gray-50,#fafafa);border:1px solid var(--gray-200);transition:border-color .2s var(--ease);border-radius:8px;outline:none;padding:10px 16px;font-family:inherit;font-size:.9rem}.blog-search__input::placeholder{color:var(--gray-400)}.blog-search__input:focus{border-color:var(--gray-400)}.blog-search__results{margin-top:16px}.blog-search__count{color:var(--gray-500);margin-bottom:12px;font-size:.8rem}.blog-search__empty{color:var(--gray-500);text-align:center;padding:32px 0;font-size:.85rem}.blog-search__list{flex-direction:column;gap:0;display:flex}[data-searching=true] .blog-list,[data-searching=true] .blog-pagination,[data-searching=true] .blog-series-float,[data-searching=true] .blog-series-header{display:none}.blog-card__reading-time{color:var(--gray-400);font-size:.7rem}.blog-card__content-type{letter-spacing:.03em;color:var(--gray-600);border:1px solid var(--gray-300);background:0 0;border-radius:10px;padding:1px 6px;font-size:.6rem;font-weight:700}@media (max-width:860px){.blog-card__link{flex-direction:column;gap:12px}.blog-card__thumb{flex-shrink:1;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}}.blog-dashboard{flex-direction:column;gap:1.8rem;display:flex}.blog-dashboard__metrics{grid-template-columns:repeat(4,1fr);gap:1rem;display:grid}.blog-dashboard__metric{border:1px solid var(--gray-200);background:var(--gray-100);border-radius:8px;flex-direction:column;align-items:center;gap:.25rem;padding:1rem .5rem;display:flex}.blog-dashboard__metric-value{color:var(--black);font-size:1.6rem;font-weight:700;line-height:1}.blog-dashboard__metric-value small{color:var(--gray-500);margin-left:2px;font-size:.75rem;font-weight:500}.blog-dashboard__metric-label{color:var(--gray-500);font-size:.75rem}.blog-dashboard__section-title{color:var(--gray-600);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.75rem;font-size:.8rem;font-weight:600}.blog-dashboard__bar-chart{flex-direction:column;gap:.5rem;display:flex}.blog-dashboard__bar-row{align-items:center;gap:.75rem;display:flex}.blog-dashboard__bar-label{color:var(--gray-700);text-align:right;flex:0 0 80px;font-size:.8rem}.blog-dashboard__bar-track{background:var(--gray-200);border-radius:4px;flex:1;height:8px;overflow:hidden}.blog-dashboard__bar-fill{background:var(--gray-600);min-width:4px;height:100%;transition:width .4s var(--ease);border-radius:4px}.blog-dashboard__bar-value{color:var(--gray-500);font-variant-numeric:tabular-nums;flex:0 0 85px;font-size:.75rem}.blog-dashboard__activity-chart{align-items:flex-end;gap:.5rem;height:120px;display:flex}.blog-dashboard__activity-col{flex-direction:column;flex:1;align-items:center;gap:4px;height:100%;display:flex}.blog-dashboard__activity-count{color:var(--gray-500);font-variant-numeric:tabular-nums;font-size:.7rem}.blog-dashboard__activity-bar-wrapper{flex:1;justify-content:center;align-items:flex-end;width:100%;display:flex}.blog-dashboard__activity-bar{background:var(--gray-600);width:70%;max-width:40px;min-height:4px;transition:height .4s var(--ease);border-radius:4px 4px 0 0}.blog-dashboard__activity-month{color:var(--gray-500);font-size:.7rem}.blog-dashboard__tags{flex-wrap:wrap;gap:.5rem;display:flex}.blog-dashboard__tag{color:var(--gray-700);background:var(--gray-100);border:1px solid var(--gray-200);border-radius:100px;align-items:center;gap:.35rem;padding:.3rem .65rem;font-size:.78rem;display:inline-flex}.blog-dashboard__tag-count{color:var(--gray-500);font-variant-numeric:tabular-nums;font-size:.68rem}.blog-dashboard__series-list{flex-direction:column;gap:.4rem;list-style:none;display:flex}.blog-dashboard__series-item{border:1px solid var(--gray-200);border-radius:6px;justify-content:space-between;align-items:center;padding:.5rem .75rem;font-size:.82rem;display:flex}.blog-dashboard__series-label{color:var(--gray-700)}.blog-dashboard__series-count{color:var(--gray-500);font-variant-numeric:tabular-nums;font-size:.75rem}@media (max-width:860px){.blog-dashboard__metrics{grid-template-columns:repeat(2,1fr)}.blog-dashboard__activity-chart{height:90px}.blog-dashboard__bar-label{flex:0 0 60px;font-size:.75rem}.blog-dashboard__bar-value{flex:0 0 70px;font-size:.7rem}}.live-indicator{color:var(--gray-500);background:var(--gray-100);border:1px solid var(--gray-200);border-radius:10px;margin-top:14px;padding:12px 14px;font-size:.82rem}[data-theme=dark] .live-indicator{border-color:var(--gray-700);background:#ffffff0a}.live-indicator__top{align-items:center;gap:8px;display:flex}.live-indicator__dot{background:var(--gray-400);border-radius:50%;flex-shrink:0;width:10px;height:10px}.live-indicator__badge{letter-spacing:.08em;color:var(--gray-400);font-size:.65rem;font-weight:700}.live-indicator__text{color:var(--gray-500);white-space:pre-line;margin-top:6px;font-size:.8rem;line-height:1.5}.live-indicator--live{background:#22c55e14;border-color:#22c55e4d;animation:3s ease-in-out infinite live-glow}[data-theme=dark] .live-indicator--live{background:#22c55e1a;border-color:#22c55e59}.live-indicator--live .live-indicator__dot{background:#22c55e;animation:2s ease-in-out infinite live-pulse}.live-indicator--live .live-indicator__badge{color:#22c55e}.live-indicator--live .live-indicator__text{color:#16a34a;font-weight:600}[data-theme=dark] .live-indicator--live .live-indicator__text{color:#4ade80}@keyframes live-pulse{0%,to{opacity:1;box-shadow:0 0 #22c55e80}50%{opacity:.8;box-shadow:0 0 0 8px #22c55e00}}@keyframes live-glow{0%,to{box-shadow:0 0 #22c55e00}50%{box-shadow:0 0 12px 2px #22c55e26}}.emoji-reactions{border:1px solid var(--gray-200);text-align:center;border-radius:12px;margin:2rem 0;padding:1.5rem}[data-theme=dark] .emoji-reactions{border-color:var(--gray-700)}.emoji-reactions__label{color:var(--gray-600);margin-bottom:1rem;font-size:.9rem}.emoji-reactions__buttons{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.emoji-reactions__btn{border:1px solid var(--gray-200);cursor:pointer;color:var(--gray-600);background:0 0;border-radius:999px;align-items:center;gap:4px;padding:8px 14px;font-size:.85rem;transition:all .2s;display:flex}[data-theme=dark] .emoji-reactions__btn{border-color:var(--gray-700)}.emoji-reactions__btn:hover{border-color:var(--gray-400);transform:translateY(-1px)}.emoji-reactions__btn--active{border-color:var(--gray-800);background:var(--gray-100)}[data-theme=dark] .emoji-reactions__btn--active{border-color:var(--gray-500);background:#ffffff14}.emoji-reactions__emoji{font-size:1.1rem;line-height:1}.emoji-reactions__count{font-variant-numeric:tabular-nums;color:var(--gray-500);font-size:.8rem}.popular-highlights{flex-direction:column;gap:10px;display:flex}.popular-highlights__card{border:1px solid var(--gray-200);transition:all .2s var(--ease);border-left:3px solid var(--gray-300);border-radius:8px;padding:16px 20px;animation:.3s both highlight-in;display:block}.popular-highlights__card:hover{border-left-color:var(--gray-600);background:var(--gray-50);transform:translate(2px);box-shadow:0 2px 8px #0000000a}@keyframes highlight-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.popular-highlights__text{color:var(--gray-700);margin:0 0 8px;font-size:.9rem;font-style:italic;line-height:1.6}.popular-highlights__meta{justify-content:space-between;align-items:center;display:flex}.popular-highlights__reactions{gap:8px;display:flex}.popular-highlights__emoji{color:var(--gray-500);font-size:.78rem}[data-theme=dark] .popular-highlights__card{border-color:var(--gray-700);border-left-color:var(--gray-600)}[data-theme=dark] .popular-highlights__card:hover{border-left-color:var(--gray-400);background:#ffffff08}[data-theme=dark] .popular-highlights__text{color:var(--gray-300)}[data-theme=dark] .popular-highlights__emoji{color:var(--gray-400)}.slack-block{border-radius:6px;transition:background .15s;position:relative}.slack-block:hover{background:#00000005}.slack-reactions-portal{min-height:0}.slack-reactions-portal:empty{display:none}.slack-toolbar{background:var(--white);border:1px solid var(--gray-200);z-index:10;border-radius:6px;align-items:center;gap:1px;padding:2px 3px;animation:.12s slack-toolbar-in;display:flex;position:absolute;top:-14px;right:4px;box-shadow:0 1px 3px #0000000f,0 2px 8px #0000000a}@keyframes slack-toolbar-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.slack-toolbar__btn{cursor:pointer;background:0 0;border:none;border-radius:5px;justify-content:center;align-items:center;width:30px;height:28px;font-size:1rem;transition:all .1s;display:flex;position:relative}.slack-toolbar__btn:hover{background:var(--gray-100);transform:scale(1.15)}.slack-toolbar__btn--active{background:var(--blue-50,#eff6ff)}.slack-toolbar__btn--active:after{content:"";background:var(--blue-500,#3b82f6);border-radius:50%;width:4px;height:4px;position:absolute;bottom:2px;left:50%;transform:translate(-50%)}.slack-reaction-pills{flex-wrap:wrap;gap:4px;padding:2px 0 4px;display:flex}.slack-reaction-pill{border:1px solid var(--gray-200);background:var(--white);cursor:pointer;color:var(--gray-600);border-radius:16px;align-items:center;gap:4px;height:26px;padding:2px 8px;font-size:.8rem;line-height:1.5;transition:all .12s;display:inline-flex}.slack-reaction-pill:hover{background:var(--gray-50);border-color:var(--gray-300)}.slack-reaction-pill--active{background:var(--blue-50,#eff6ff);border-color:var(--blue-300,#93c5fd);color:var(--blue-700,#1d4ed8)}.slack-reaction-pill--active:hover{background:var(--blue-100,#dbeafe)}.slack-reaction-pill--add{color:var(--gray-400);border-style:dashed;padding:2px 6px}.slack-reaction-pill--add:hover{border-color:var(--gray-400);color:var(--gray-600);background:var(--gray-50)}.slack-reaction-pill__emoji{font-size:.9rem;line-height:1}.slack-reaction-pill__count{font-variant-numeric:tabular-nums;font-size:.75rem;font-weight:600}[data-theme=dark] .slack-block:hover{background:#ffffff08}[data-theme=dark] .slack-toolbar{background:#2a2a2e;border-color:#3a3a3e;box-shadow:0 2px 8px #0006}[data-theme=dark] .slack-toolbar__btn:hover{background:#ffffff14}[data-theme=dark] .slack-toolbar__btn--active{background:#3b82f626}[data-theme=dark] .slack-reaction-pill{color:var(--gray-400);background:#ffffff0f;border-color:#ffffff1a}[data-theme=dark] .slack-reaction-pill:hover{background:#ffffff1a;border-color:#ffffff26}[data-theme=dark] .slack-reaction-pill--active{color:#93c5fd;background:#3b82f626;border-color:#3b82f659}[data-theme=dark] .slack-reaction-pill--active:hover{background:#3b82f638}[data-theme=dark] .slack-reaction-pill--add{color:var(--gray-500);border-color:#ffffff1a}[data-theme=dark] .slack-reaction-pill--add:hover{color:var(--gray-400);background:#ffffff0f;border-color:#fff3}@media (max-width:768px){.slack-toolbar{padding:2px 3px;top:-14px;right:-4px}.slack-toolbar__btn{width:26px;height:24px;font-size:.9rem}}.suggestion-fab{z-index:900;border:1px solid var(--gray-200);background:var(--white);width:48px;height:48px;color:var(--gray-600);cursor:pointer;box-shadow:0 4px 12px var(--shadow-medium),0 1px 3px var(--shadow-subtle);border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:fixed;bottom:24px;right:24px}.suggestion-fab:hover{box-shadow:0 6px 20px var(--shadow-medium);color:var(--black);transform:translateY(-2px)}[data-theme=dark] .suggestion-fab{border-color:var(--gray-700);background:#1a1a1a}@media (max-width:860px){.suggestion-fab{width:44px;height:44px;bottom:16px;right:16px}}.suggestion-modal__overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;animation:.2s suggestion-fade-in;display:flex;position:fixed;inset:0}@keyframes suggestion-fade-in{0%{opacity:0}to{opacity:1}}.suggestion-modal{background:var(--white);border:1px solid var(--gray-200);width:90%;max-width:480px;box-shadow:0 20px 60px var(--shadow-heavy);border-radius:16px;animation:.25s suggestion-slide-up}[data-theme=dark] .suggestion-modal{border-color:var(--gray-700);background:#1a1a1a}@keyframes suggestion-slide-up{0%{opacity:0;transform:translateY(20px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.suggestion-modal__header{justify-content:space-between;align-items:center;padding:20px 24px 0;display:flex}.suggestion-modal__title{color:var(--black);font-size:1.1rem;font-weight:600}.suggestion-modal__close{width:32px;height:32px;color:var(--gray-500);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:background .15s;display:flex}.suggestion-modal__close:hover{background:var(--gray-100)}[data-theme=dark] .suggestion-modal__close:hover{background:#ffffff14}.suggestion-modal__body{padding:16px 24px 24px}.suggestion-modal__desc{color:var(--gray-500);margin-bottom:16px;font-size:.85rem;line-height:1.5}.suggestion-modal__textarea{border:1px solid var(--gray-200);width:100%;color:var(--black);font-size:.9rem;font-family:var(--font-sans);resize:vertical;background:0 0;border-radius:10px;min-height:120px;padding:12px 14px;line-height:1.6}[data-theme=dark] .suggestion-modal__textarea{border-color:var(--gray-700)}.suggestion-modal__textarea:focus{border-color:var(--gray-400);outline:none}.suggestion-modal__nickname{border:1px solid var(--gray-200);width:100%;color:var(--black);font-size:.9rem;font-family:var(--font-sans);background:0 0;border-radius:10px;margin-top:10px;padding:10px 14px}[data-theme=dark] .suggestion-modal__nickname{border-color:var(--gray-700)}.suggestion-modal__nickname:focus{border-color:var(--gray-400);outline:none}.suggestion-modal__footer{justify-content:space-between;align-items:center;margin-top:14px;display:flex}.suggestion-modal__charcount{color:var(--gray-400);font-variant-numeric:tabular-nums;font-size:.8rem}.suggestion-modal__submit{border:1px solid var(--gray-300);background:var(--black);color:var(--white);font-size:.9rem;font-family:var(--font-sans);cursor:pointer;border-radius:8px;padding:8px 24px;font-weight:500;transition:all .15s}.suggestion-modal__submit:hover:not(:disabled){opacity:.85}.suggestion-modal__submit:disabled{opacity:.3;cursor:not-allowed}.suggestion-modal__thanks{color:#22c55e;text-align:center;padding:40px 0;font-size:1rem;font-weight:500}.suggestion-modal__error{color:#ef4444;margin-top:10px;font-size:.8rem}.wiki-badge--ai{color:#7c3aed;background:#ede9fe;border:1px solid #a78bfa;border-radius:6px;align-items:center;gap:6px;margin-bottom:16px;padding:6px 12px;font-size:.78rem;display:inline-flex}[data-theme=dark] .wiki-badge--ai{color:#c4b5fd;background:#2e1065;border-color:#6d28d9}.wiki-badge--ai svg{color:#8b5cf6;flex-shrink:0}[data-theme=dark] .wiki-badge--ai svg{color:#a78bfa}.wiki-badge--ai__date{color:#8b5cf6;margin-left:8px;font-size:.72rem}[data-theme=dark] .wiki-badge--ai__date{color:#a78bfa}.wiki-badge--real-use{color:#059669;background:#ecfdf5;border:1px solid #34d399;border-radius:999px;align-items:center;gap:6px;margin-bottom:16px;padding:6px 12px;font-size:.78rem;font-weight:600;display:inline-flex}[data-theme=dark] .wiki-badge--real-use{color:#6ee7b7;background:#022c22;border-color:#047857}.wiki-badge--real-use svg{color:#10b981;flex-shrink:0}[data-theme=dark] .wiki-badge--real-use svg{color:#34d399}.wiki-progress{margin-bottom:32px}.wiki-progress__info{color:var(--gray-600);justify-content:space-between;align-items:center;margin-bottom:6px;font-size:.8rem;display:flex}.wiki-progress__bar{background:var(--gray-200);border-radius:3px;height:6px;overflow:hidden}.wiki-progress__fill{background:var(--gray-700);height:100%;transition:width .4s var(--ease);border-radius:3px}.wiki-toc{flex-direction:column;gap:8px;display:flex}.wiki-toc__part{border:1px solid var(--gray-200);border-radius:8px;overflow:hidden}.wiki-toc__part-header{cursor:pointer;color:var(--gray-800);background:var(--gray-100);align-items:center;gap:10px;padding:14px 18px;font-size:.95rem;font-weight:600;list-style:none;transition:background .15s;display:flex}.wiki-toc__part-header::-webkit-details-marker{display:none}.wiki-toc__part-header::marker{content:"";display:none}.wiki-toc__part-header:hover{background:var(--gray-200)}.wiki-toc__part-number{background:var(--gray-800);color:var(--white);border-radius:4px;padding:2px 8px;font-size:.78rem;font-weight:500}.wiki-toc__part-count{color:var(--gray-500);margin-left:auto;font-size:.75rem;font-weight:400}.wiki-toc__chapters{margin:0;padding:0;list-style:none}.wiki-toc__chapter{border-top:1px solid var(--gray-200)}.wiki-toc__chapter-link{color:inherit;grid-template-rows:auto auto;grid-template-columns:42px 1fr;gap:2px 12px;padding:14px 18px;text-decoration:none;transition:background .15s;display:grid}.wiki-toc__chapter-link:hover{background:var(--gray-100)}.wiki-toc__chapter-slug{font-family:var(--font-mono);color:var(--gray-500);grid-row:1/-1;justify-content:center;align-items:center;font-size:.78rem;font-weight:500;display:flex}.wiki-toc__chapter-title{color:var(--gray-800);font-size:.92rem;font-weight:500}.wiki-toc__chapter-meta{color:var(--gray-500);align-items:center;gap:12px;font-size:.78rem;display:flex}.wiki-toc__chapter-desc{text-overflow:ellipsis;white-space:nowrap;max-width:400px;overflow:hidden}.wiki-toc__chapter-time{flex-shrink:0}.wiki-breadcrumb{color:var(--gray-500);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;font-size:.8rem;display:flex}.wiki-breadcrumb__link{color:var(--gray-600);text-decoration:none;transition:color .15s}.wiki-breadcrumb__link:hover{color:var(--gray-800)}.wiki-breadcrumb__sep{color:var(--gray-400)}.wiki-breadcrumb__current{color:var(--gray-700);font-weight:500}.wiki-detail__meta{flex-wrap:wrap;align-items:center;gap:12px;margin-top:8px;display:flex}.wiki-detail__reading-time{color:var(--gray-500);font-size:.8rem}.wiki-chapter-nav{border:1px solid var(--gray-200);border-radius:8px;margin-bottom:32px;padding:16px 18px}.wiki-chapter-nav__title{color:var(--gray-600);margin-bottom:10px;font-size:.85rem;font-weight:600}.wiki-chapter-nav__list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.wiki-chapter-nav__item{font-size:.85rem}.wiki-chapter-nav__link{color:var(--gray-600);border-radius:4px;padding:4px 8px;text-decoration:none;transition:all .15s;display:block}.wiki-chapter-nav__link:hover{color:var(--gray-800);background:var(--gray-100)}.wiki-chapter-nav__item--current{font-weight:600}.wiki-chapter-nav__current{color:var(--gray-800);background:var(--gray-100);border-radius:4px;padding:4px 8px;display:block}.wiki-side-toc{display:none}@media (min-width:1440px){.wiki-side-toc{width:200px;max-height:calc(100vh - 120px);display:block;position:fixed;top:80px;right:32px;overflow-y:auto}}.wiki-side-toc__label{text-transform:uppercase;letter-spacing:.08em;color:var(--gray-500);margin-bottom:10px;font-size:.7rem;font-weight:600;display:block}.wiki-side-toc__list{border-left:2px solid var(--gray-200);margin:0;padding:0;list-style:none}.wiki-side-toc__item{padding:0}.wiki-side-toc__item--h3{padding-left:10px}.wiki-side-toc__link{color:var(--gray-500);border-left:2px solid #0000;margin-left:-2px;padding:4px 0 4px 12px;font-size:.75rem;line-height:1.4;text-decoration:none;transition:all .15s;display:block}.wiki-side-toc__link:hover{color:var(--gray-700)}.wiki-side-toc__link--active{color:var(--gray-800);border-left-color:var(--gray-700);font-weight:600}.wiki-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.wiki-series-card{border:1px solid var(--gray-200);color:inherit;border-radius:10px;flex-direction:column;text-decoration:none;transition:border-color .2s,box-shadow .2s;display:flex;overflow:hidden}.wiki-series-card:hover{border-color:var(--gray-400);box-shadow:0 4px 16px var(--shadow-subtle)}.wiki-series-card--placeholder{opacity:.5;pointer-events:none;border-style:dashed}.wiki-series-card__visual{background:var(--gray-100);height:140px;color:var(--gray-500);justify-content:center;align-items:center;display:flex}[data-theme=dark] .wiki-series-card__visual{background:var(--gray-800)}.wiki-series-card:hover .wiki-series-card__visual{color:var(--gray-700)}.wiki-series-card__icon{width:56px;height:56px}.wiki-series-card__body{flex-direction:column;flex:1;padding:18px 20px 20px;display:flex}.wiki-series-card__header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.wiki-series-card__title{color:var(--black);margin:0;font-size:1rem;font-weight:700}.wiki-series-card__desc{color:var(--gray-600);flex:1;margin-bottom:14px;font-size:.82rem;line-height:1.55}.wiki-series-card__progress{align-items:center;gap:10px;display:flex}.wiki-series-card__progress-bar{background:var(--gray-200);border-radius:3px;flex:1;height:5px;overflow:hidden}.wiki-series-card__progress-fill{height:100%;transition:width .4s var(--ease);background:#16a34a;border-radius:3px}.wiki-series-card__progress-text{color:var(--gray-500);flex-shrink:0;font-size:.72rem}.wiki-card__status{letter-spacing:.02em;border-radius:4px;flex-shrink:0;padding:2px 8px;font-size:.65rem;font-weight:600}.wiki-card__status--wip{color:#16a34a;background:#dcfce7}[data-theme=dark] .wiki-card__status--wip{color:#86efac;background:#14532d}.wiki-card__status--planned{background:var(--gray-200);color:var(--gray-500)}.wiki-article img,.wiki-article .wiki-img-pair{width:calc(100% + 80px);max-width:calc(100% + 80px);margin-left:-40px;margin-right:-40px}@media (max-width:768px){.wiki-article img,.wiki-article .wiki-img-pair{border-radius:0;width:calc(100% + 32px);max-width:calc(100% + 32px);margin-left:-16px;margin-right:-16px}}.wiki-article .wiki-img--small,.wiki-article .wiki-img--medium{width:auto;max-width:initial;margin-left:auto;margin-right:auto;display:block}.wiki-article .wiki-img--small img,.wiki-article .wiki-img--medium img{width:auto;max-width:100%;margin-left:auto;margin-right:auto;display:block}.wiki-article .wiki-img--small{max-width:320px}.wiki-article .wiki-img--medium{max-width:560px}.wiki-article strong{color:var(--black);background:linear-gradient(#0000 60%,#16a36a26 60%);font-weight:700}[data-theme=dark] .wiki-article strong{color:#86efac;background:0 0}.wiki-summary-section{margin-bottom:40px}.wiki-summary-section__title{color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px;font-size:.85rem;font-weight:600}.wiki-slideshow{border:1px solid var(--gray-200);background:var(--gray-100);border-radius:10px;margin:24px 0;position:relative;overflow:hidden}[data-theme=dark] .wiki-slideshow{background:#1e1e1e;border-color:#333}.wiki-slideshow__track{position:relative}.wiki-slide{display:none}.wiki-slide--active{display:block}.wiki-slide img{border:none;border-radius:0;width:100%;margin:0;display:block}.wiki-slide .wiki-img--dark,[data-theme=dark] .wiki-slide .wiki-img--light{display:none}[data-theme=dark] .wiki-slide .wiki-img--dark{display:block}.wiki-slideshow__controls{border-top:1px solid var(--gray-200);justify-content:center;align-items:center;gap:16px;padding:10px 0;display:flex}[data-theme=dark] .wiki-slideshow__controls{border-top-color:#333}.wiki-slideshow__btn{border:1px solid var(--gray-300);background:var(--white);width:32px;height:32px;color:var(--gray-600);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;font-size:.85rem;transition:all .15s;display:flex}.wiki-slideshow__btn:hover{background:var(--gray-200);color:var(--black)}[data-theme=dark] .wiki-slideshow__btn{background:var(--gray-700);border-color:var(--gray-600);color:var(--gray-400)}[data-theme=dark] .wiki-slideshow__btn:hover{background:var(--gray-600);color:var(--white)}.wiki-slideshow__indicator{color:var(--gray-500);font-variant-numeric:tabular-nums;text-align:center;min-width:40px;font-size:.78rem}.wiki-article .wiki-summary-section,.wiki-article .wiki-slideshow,.wiki-article .wiki-slideshow img{width:100%;max-width:100%;margin-left:0;margin-right:0}.wiki-img-pair{display:block}.wiki-img--dark,[data-theme=dark] .wiki-img--light{display:none}[data-theme=dark] .wiki-img--dark{display:block}.wiki-mermaid{text-align:center;background:var(--bg-secondary);border-radius:12px;margin:2rem 0;padding:1.5rem;overflow-x:auto}.wiki-mermaid svg{max-width:100%;height:auto}.wiki-empty{text-align:center;color:var(--gray-500);padding:40px 0;font-size:.9rem}
