:root{--tech-max-width:780px;--ease-out-soft:cubic-bezier(.16, 1, .3, 1);--ease-out-swift:cubic-bezier(.2, 0, .15, 1)}[data-theme=dark] .tech-page{--bg:#18181c;--surface:#212126;--surface-hover:#28282e;--hover-bg:#28282e;--border:#ffffff12;--border-hover:#ffffff1f;--border-subtle:#ffffff0a;--text-secondary:#a0a0a8;--text-muted:#606068;--code-bg:#141418;--code-header-bg:#1a1a1f;background-color:var(--bg)}@keyframes tech-fade-up{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.tech-shell>*{animation:tech-fade-up .7s var(--ease-out-soft) both}.tech-shell>:first-child{animation-delay:0s}.tech-shell>:nth-child(2){animation-delay:80ms}.tech-shell>:nth-child(3){animation-delay:.16s}.tech-shell>:nth-child(4){animation-delay:.22s}.tech-shell>:nth-child(5){animation-delay:.27s}.tech-shell>:nth-child(6){animation-delay:.31s}.tech-shell>:nth-child(7){animation-delay:.34s}.tech-shell>:nth-child(n+8){animation-delay:.36s}@media (prefers-reduced-motion:reduce){.tech-shell>*{animation:none!important}}.sticky-nav{z-index:150;pointer-events:none;opacity:0;transition:transform .4s var(--ease-out-soft), opacity .32s ease;position:fixed;top:0;left:0;right:0;transform:translateY(-100%)}.sticky-nav-visible{opacity:1;pointer-events:auto;transform:translateY(0)}.sticky-nav-inner{background:color-mix(in srgb, var(--bg) 82%, transparent);-webkit-backdrop-filter:saturate(1.4)blur(18px);border-bottom:1px solid var(--border);align-items:center;gap:18px;max-width:100%;padding:10px 20px;display:flex}.sticky-nav-title{letter-spacing:-.012em;max-width:240px;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;border-right:1px solid var(--border);flex-shrink:0;padding-right:18px;font-size:.82rem;font-weight:600;overflow:hidden}.sticky-nav-chips{scroll-behavior:smooth;scrollbar-width:none;flex:1;gap:4px;min-width:0;display:flex;overflow:auto hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 16px calc(100% - 20px),#0000);mask-image:linear-gradient(90deg,#0000,#000 16px calc(100% - 20px),#0000)}.sticky-nav-chips::-webkit-scrollbar{display:none}.sticky-nav-chip{color:var(--text-muted);white-space:nowrap;border-radius:9999px;flex-shrink:0;align-items:center;padding:6px 12px;font-size:.74rem;font-weight:500;text-decoration:none;transition:color .2s,background .2s;display:inline-flex}.sticky-nav-chip:hover{color:var(--text-secondary);background:var(--hover-bg)}.sticky-nav-chip.is-active{color:var(--text-primary);background:var(--hover-bg)}[data-theme=dark] .sticky-nav-chip.is-active{background:var(--surface-hover)}@media (max-width:640px){.sticky-nav-inner{gap:12px;padding:9px 14px}.sticky-nav-title{max-width:130px;padding-right:12px;font-size:.76rem}.sticky-nav-chip{padding:5px 10px;font-size:.7rem}}@media (prefers-reduced-motion:reduce){.sticky-nav{transition:none}}.tech-page{isolation:isolate;text-align:left;background-image:radial-gradient(circle at 1px 1px,#00000007 1px,#0000 0);background-size:30px 30px;background-attachment:fixed;justify-content:center;align-items:flex-start;width:100%;min-height:100vh;padding:48px 16px 96px;display:flex;position:relative}[data-theme=dark] .tech-page{background-image:radial-gradient(circle at 1px 1px,#ffffff06 1px,#0000 0);background-size:30px 30px;background-attachment:fixed}@media (min-width:640px){.tech-page{padding-top:72px}}.tech-page:before{content:"";background:radial-gradient(circle, var(--section-glow,#5a5a5a0d), transparent 60%);filter:blur(90px);pointer-events:none;z-index:-1;border-radius:50%;width:960px;height:960px;position:fixed;top:-480px;right:-280px}.tech-page:after{content:"";pointer-events:none;z-index:-1;background:linear-gradient(#00000006,#0000);height:320px;position:fixed;inset:0 0 auto}[data-theme=dark] .tech-page:before{filter:blur(120px);background:radial-gradient(circle,#8c8c8c06,#0000 60%)}[data-theme=dark] .tech-page:after{background:linear-gradient(#ffffff08,#0000)}.tech-page>.tech-shell:after{content:"";pointer-events:none;z-index:100;opacity:.025;mix-blend-mode:multiply;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");background-size:160px 160px;position:fixed;inset:0}[data-theme=dark] .tech-page>.tech-shell:after{opacity:.05;mix-blend-mode:screen}@media (prefers-reduced-motion:reduce){.tech-page>.tech-shell:after{display:none}}.tech-shell{width:100%;min-width:0;max-width:var(--tech-max-width);position:relative}.tech-nav{justify-content:space-between;align-items:center;margin-bottom:56px;display:flex}.tech-hero{margin-bottom:40px;display:block}@media (min-width:768px){.tech-hero{margin-bottom:48px}}@media (max-width:640px){.tech-hero{margin-bottom:32px}}.tech-title{letter-spacing:-.045em;color:var(--text-primary);text-wrap:balance;margin:0;font-size:2.2rem;font-weight:700;line-height:1.04}@media (min-width:640px){.tech-title{font-size:2.9rem}}@media (min-width:768px){.tech-title{letter-spacing:-.05em;font-size:3.4rem;line-height:1.02}}.tech-description{max-width:580px;color:var(--text-secondary);text-wrap:pretty;margin:18px 0 0;font-size:1rem;line-height:1.65}.tech-eyebrow{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);align-items:center;gap:10px;font-size:.7rem;font-weight:500;display:inline-flex}.tech-eyebrow:before{content:"";background:var(--text-muted);opacity:.7;border-radius:50%;flex-shrink:0;width:4px;height:4px}.tech-back{color:var(--text-muted);border:1px solid #0000;border-radius:9999px;align-items:center;gap:6px;padding:7px 14px 7px 10px;font-size:.78rem;text-decoration:none;transition:background .15s,border-color .15s,color .15s,transform .15s,box-shadow .2s;display:inline-flex}.tech-back svg{transition:transform .2s}.tech-back:hover{background:var(--surface);border-color:var(--border);color:var(--text-primary);box-shadow:0 1px 2px #00000008}.tech-back:hover svg{transform:translate(-2px)}[data-theme=dark] .tech-back:hover{background:var(--surface);border-color:#ffffff17;box-shadow:inset 0 1px #ffffff0a}.tech-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;align-items:flex-start;gap:20px;padding:24px 26px;text-decoration:none;transition:transform .2s cubic-bezier(.2,0,.2,1),background .18s,border-color .18s,box-shadow .25s;display:flex;position:relative;box-shadow:0 1px 2px #00000006}@media (min-width:640px){.tech-card{align-items:center}}@media (max-width:640px){.tech-card{border-radius:12px;gap:16px;padding:18px}}.tech-card-body{flex:auto;min-width:0}.tech-card-head{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.tech-card-title{letter-spacing:-.015em;color:var(--text-primary);margin:0;font-size:1rem;font-weight:600;line-height:1.3}.tech-card-meta{font-family:var(--font-mono);letter-spacing:.04em;color:var(--text-muted);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:.68rem;font-weight:500}.tech-card-desc{color:var(--text-muted);margin:6px 0 0;font-size:.86rem;line-height:1.6}@media (max-width:640px){.tech-card-title{font-size:.95rem}.tech-card-desc{font-size:.82rem}}.tech-card-icon-lg{flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.tech-card-icon-sm{flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}@media (max-width:640px){.tech-card-icon-lg{width:48px;height:48px}.tech-card-icon-sm{width:40px;height:40px}}.tech-card-index{width:32px;font-family:var(--font-mono);font-variant-numeric:tabular-nums;letter-spacing:-.01em;color:var(--text-muted);opacity:.6;text-align:right;flex-shrink:0;font-size:.95rem;font-weight:400;transition:color .25s,opacity .25s,transform .25s}.group:hover .tech-card-index{color:var(--section-color,var(--text-primary));opacity:1}@media (max-width:640px){.tech-card-index{display:none}}.tech-card-leading{flex-shrink:0;align-items:center;gap:18px;display:flex}@media (max-width:640px){.tech-card-leading{gap:0}}.tech-card:hover{background:var(--surface);border-color:var(--border-hover);box-shadow:0 1px 2px #00000008, 0 20px 48px -18px #0000001f, 0 0 0 1px var(--card-accent,transparent);transform:translateY(-2px)}[data-theme=dark] .tech-card{background:var(--surface);border-color:var(--border);box-shadow:inset 0 1px #ffffff09}[data-theme=dark] .tech-card:hover{background:var(--surface-hover);border-color:var(--border-hover);box-shadow:inset 0 1px #ffffff0d}.tech-card:active{transition-duration:.1s;transform:translateY(0)}.tech-icon{border:1px solid var(--border);border-radius:10px;transition:transform .3s cubic-bezier(.2,0,.2,1),border-color .25s,box-shadow .3s}.group:hover .tech-icon{border-color:var(--border-hover);box-shadow:0 8px 24px -8px var(--section-glow,#00000014);transform:scale(1.05)}[data-theme=dark] .tech-icon{border-color:#ffffff0f;box-shadow:inset 0 1px #ffffff0a}[data-theme=dark] .group:hover .tech-icon{border-color:var(--border-hover);box-shadow:inset 0 1px 0 #ffffff14, 0 10px 28px -8px var(--section-glow-dark,#ffffff0f)}.tech-icon-hero{border:1px solid var(--border);box-shadow:0 1px 2px #00000008, 0 16px 40px -18px var(--section-glow,#00000014);border-radius:14px}[data-theme=dark] .tech-icon-hero{box-shadow:inset 0 1px 0 #ffffff0f, 0 20px 50px -18px var(--section-glow-dark,#ffffff0d);border-color:#ffffff14}.tech-pill{border:1px solid var(--border);background:0 0;border-radius:5px;transition:background .15s,border-color .15s,color .15s}.group:hover .tech-pill{background:var(--hover-bg);border-color:var(--border-hover);color:var(--text-secondary)}[data-theme=dark] .tech-pill{border-color:var(--border)}[data-theme=dark] .group:hover .tech-pill{border-color:var(--border-hover);background:#ffffff0a}.tech-chip{border:1px solid var(--border);font-variant-numeric:tabular-nums;background:0 0;border-radius:9999px;align-items:center;transition:background .15s,border-color .15s,transform .12s,color .15s;display:inline-flex}a.tech-chip:hover,button.tech-chip:hover{background:var(--hover-bg);border-color:var(--border-hover);color:var(--text-primary);transform:translateY(-1px)}[data-theme=dark] .tech-chip{border-color:#ffffff14}[data-theme=dark] a.tech-chip:hover,[data-theme=dark] button.tech-chip:hover{border-color:var(--border-hover);background:#ffffff0a}.tech-divider{background:linear-gradient(90deg, transparent, var(--border-hover) 20%, var(--border-hover) 80%, transparent);opacity:.5;height:1px}.tech-page ::selection{background:color-mix(in srgb, var(--section-color,var(--text-primary)) 14%, transparent);color:var(--text-primary)}.tech-page :focus-visible{outline:2px solid var(--border-hover);outline-offset:3px;border-radius:8px}.article-body{min-width:0;max-width:100%}.article-body h2{color:var(--text-primary);letter-spacing:-.035em;text-wrap:balance;margin:72px 0 14px;scroll-margin-top:72px;font-size:1.5rem;font-weight:700;line-height:1.2;position:relative}.article-body h2:first-child{margin-top:8px}.article-body h2:before{content:"";background:var(--border-hover);opacity:.6;border-radius:1px;width:20px;height:1px;margin-bottom:12px;display:block}[data-theme=dark] .article-body h2:before{opacity:.45}.article-body h2:first-child:before{margin-bottom:10px}.article-body h3{color:var(--text-muted);letter-spacing:.11em;text-transform:uppercase;font-size:.74rem;font-weight:600;font-family:var(--font-mono);margin:40px 0 10px}.article-body p{color:var(--text-secondary);text-wrap:pretty;margin-bottom:18px;font-size:.97rem;line-height:1.78}.article-body p strong{color:var(--text-primary);font-weight:600}.article-body a{color:var(--text-primary);text-decoration:underline;-webkit-text-decoration-color:var(--border-hover);text-decoration-color:var(--border-hover);text-underline-offset:4px;text-decoration-thickness:1px;transition:text-decoration-color .25s,color .25s,text-decoration-thickness .25s}.article-body a:hover{color:var(--section-color,var(--text-primary));-webkit-text-decoration-color:var(--section-color,var(--text-primary));text-decoration-color:var(--section-color,var(--text-primary));text-decoration-thickness:2px}.article-body blockquote{color:var(--text-primary);letter-spacing:-.012em;margin:38px 0;padding:4px 0 4px 26px;font-size:1.2rem;font-style:italic;font-weight:500;line-height:1.55;position:relative}.article-body blockquote:before{content:"";background:var(--section-color,var(--border-hover));opacity:.9;border-radius:2px;width:2px;position:absolute;top:10px;bottom:10px;left:0}.article-body blockquote p{color:inherit;font-size:inherit;line-height:inherit;font-weight:inherit;font-style:inherit;margin:0}.article-body code{font-size:.84em;font-family:var(--font-mono);background:var(--hover-bg);border:1px solid var(--border);color:var(--text-primary);white-space:nowrap;border-radius:5px;padding:1.5px 6px;font-weight:500}[data-theme=dark] .article-body code{border-color:var(--border);background:#ffffff0b}.article-body pre{border:1px solid var(--border);background:#fafafa;border-radius:12px;margin:22px 0 26px;padding:18px 20px;font-size:.82rem;line-height:1.75;overflow-x:auto}[data-theme=dark] .article-body pre{background:var(--code-bg,#0f0f11);border-color:var(--border)}.article-body pre code{-webkit-backdrop-filter:none;box-shadow:none;background:0 0;border:none;padding:0;font-weight:400}.code-block{min-width:0;max-width:100%;margin:24px 0 28px;position:relative}.code-block>div{min-width:0;max-width:100%}.code-block:before{content:"";background:linear-gradient(90deg, transparent, var(--section-color,var(--border-hover)), transparent);opacity:.18;z-index:2;pointer-events:none;height:1px;position:absolute;top:0;left:22%;right:22%}[data-theme=dark] .code-block:before{opacity:.25}.code-block-header{border:1px solid var(--border);border-bottom:1px solid var(--border-subtle);background:#fafafa;border-radius:12px 12px 0 0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}[data-theme=dark] .code-block-header{background:var(--code-bg,#0f0f11);border-color:var(--border);border-bottom-color:#ffffff09}.code-block-lang{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:.66rem;font-weight:500;display:inline-flex}.code-block-lang:before{content:"";background:var(--text-muted);opacity:.45;border-radius:50%;width:5px;height:5px}.code-block-filename{font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:-.003em;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;min-width:0;font-size:.72rem;font-weight:500;display:inline-flex}.code-block-filename svg{color:var(--text-muted);opacity:.7;flex-shrink:0}.code-block-filename-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:260px;font-weight:500;overflow:hidden}.code-block-filename-suffix{border-left:1px solid var(--border);color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;align-items:center;margin-left:2px;padding-left:8px;font-size:.62rem;font-weight:500;display:inline-flex}[data-theme=dark] .code-block-filename-suffix{border-left-color:#ffffff14}@media (max-width:640px){.code-block-filename{font-size:.66rem}.code-block-filename-name{max-width:160px}.code-block-filename-suffix{padding-left:6px;font-size:.58rem}}.code-block pre .line.line-highlighted{background:color-mix(in srgb, var(--section-color,var(--text-primary)) 7%, transparent);border-left:2px solid color-mix(in srgb, var(--section-color,var(--text-primary)) 55%, transparent);box-sizing:border-box;width:calc(100% + 40px);margin:0 -20px;padding:0 20px 0 18px;display:inline-block}[data-theme=dark] .code-block pre .line.line-highlighted{background:color-mix(in srgb, var(--section-color,var(--text-primary)) 11%, transparent);border-left-color:color-mix(in srgb, var(--section-color,var(--text-primary)) 70%, transparent)}@media (max-width:640px){.code-block pre .line.line-highlighted{width:calc(100% + 32px);margin:0 -16px;padding:0 16px 0 14px}}.copy-btn{width:28px;height:28px;color:var(--text-muted);cursor:pointer;opacity:.45;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:opacity .22s,background .18s,color .18s,transform .14s;display:flex}.group\/code:hover .copy-btn{opacity:1}.copy-btn:hover{color:var(--text-primary);background:#0000000d}.copy-btn:active{transform:scale(.88)}[data-theme=dark] .copy-btn{opacity:.55}[data-theme=dark] .copy-btn:hover{color:var(--text-primary);background:#ffffff12}.code-block pre{font-size:.82rem;line-height:1.75;border:1px solid var(--border)!important;background:#fafafa!important;border-top:none!important;border-radius:0 0 12px 12px!important;min-width:0!important;max-width:100%!important;margin:0!important;padding:18px 20px!important;overflow-x:auto!important}[data-theme=dark] .code-block pre{background:var(--code-bg,#0f0f11)!important;border-color:#ffffff12!important}.code-block code{font-family:var(--font-mono);-webkit-backdrop-filter:none!important;font-weight:400!important;font-size:inherit!important;box-shadow:none!important;background:0 0!important;border:none!important;padding:0!important}.code-block code span{font-weight:inherit}.code-block .shiki,.code-block .shiki span{color:var(--shiki-light)!important;font-style:var(--shiki-light-font-style,inherit)!important;font-weight:var(--shiki-light-font-weight,inherit)!important}[data-theme=dark] .code-block .shiki,[data-theme=dark] .code-block .shiki span{color:var(--shiki-dark)!important;font-style:var(--shiki-dark-font-style,inherit)!important;font-weight:var(--shiki-dark-font-weight,inherit)!important}.article-body ul,.article-body ol{margin:8px 0 22px 22px;padding-left:4px}.article-body li{color:var(--text-secondary);margin-bottom:8px;font-size:.955rem;line-height:1.8}.article-body li strong{color:var(--text-primary);font-weight:600}.article-body li::marker{color:var(--text-muted)}.article-callout{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin:32px 0;padding:20px 22px 20px 26px;position:relative;box-shadow:0 1px 2px #00000005}.article-callout:before{content:"";background:var(--border-hover);opacity:.5;border-radius:0 2px 2px 0;width:2px;position:absolute;top:20px;bottom:20px;left:0}.article-callout p,.article-callout li{margin-bottom:8px;font-size:.92rem;line-height:1.72}.article-callout p:last-child,.article-callout ul:last-child,.article-callout ol:last-child{margin-bottom:0}.article-callout ul,.article-callout ol{margin:6px 0 0 18px}.article-callout code{font-size:.82em}[data-theme=dark] .article-callout{background:var(--surface);border-color:var(--border);box-shadow:inset 0 1px #ffffff0a}[data-theme=dark] .article-callout:before{opacity:.95}.callout-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);align-items:center;gap:10px;margin-bottom:10px;font-size:.6rem;font-weight:600;display:inline-flex}.callout-label-line{background:var(--border-hover);opacity:.7;width:16px;height:1px;display:inline-block}.callout-body{color:var(--text-secondary)}.callout-body>:first-child{margin-top:0}.callout-body strong{color:var(--text-primary);font-weight:600}@media (max-width:640px){.article-callout{padding:18px 18px 18px 22px}.article-callout:before{top:18px;bottom:18px}.callout-label{font-size:.6rem}}.article-img-wrap{border:1px solid var(--border);border-radius:14px;margin:22px 0 30px;overflow:hidden}.article-img-wrap img{width:100%;display:block}[data-theme=dark] .article-img-light{display:none!important}[data-theme=dark] .article-img-dark{display:block!important}.section-badge{background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);border-radius:9999px;align-items:center;gap:8px;padding:6px 14px 6px 8px;font-size:.74rem;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s,transform .15s,box-shadow .2s;display:inline-flex;box-shadow:0 1px 2px #00000006}.section-badge:hover{border-color:var(--border-hover);transform:translateY(-1px);box-shadow:0 1px 2px #00000008,0 8px 20px -10px #00000014}.section-badge-icon{justify-content:center;align-items:center;width:20px;height:20px;display:inline-flex}[data-theme=dark] .section-badge{background:var(--surface);border-color:var(--border);box-shadow:inset 0 1px #ffffff08}[data-theme=dark] .section-badge:hover{background:var(--surface-hover);border-color:var(--border-hover);box-shadow:inset 0 1px #ffffff0a}.scrollbar-none::-webkit-scrollbar{display:none}.chip-row{flex-wrap:nowrap;gap:6px;display:flex;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#000 calc(100% - 32px),#0000);mask-image:linear-gradient(90deg,#000 calc(100% - 32px),#0000)}.chip-wrap{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.stack-grid{grid-template-columns:1fr;gap:14px;display:grid}@media (min-width:768px){.stack-grid{grid-template-columns:repeat(2,1fr);gap:16px}}.stack-sequence{margin-top:4px;position:relative}.stack-sequence-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.18em;color:var(--text-muted);justify-content:center;align-items:center;gap:14px;margin-bottom:28px;font-size:.64rem;font-weight:500;display:flex}.stack-sequence-label-line{background:linear-gradient(90deg, transparent, var(--border-hover), transparent);opacity:.55;flex:1;max-width:80px;height:1px}.stack-sequence-list{flex-direction:column;gap:0;margin:0;padding:0;list-style:none;display:flex;position:relative}.stack-sequence-item{grid-template-columns:56px 1fr;gap:18px;padding-bottom:22px;display:grid;position:relative}.stack-sequence-item:last-child{padding-bottom:0}.stack-sequence-rail{flex-direction:column;align-items:center;padding-top:22px;display:flex;position:relative}.stack-sequence-rail:before{content:"";background:linear-gradient(to bottom, transparent, var(--border-hover) 10%, var(--border-hover) 90%, transparent);opacity:.5;pointer-events:none;width:1px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.stack-sequence-item:first-child .stack-sequence-rail:before{top:22px}.stack-sequence-item:last-child .stack-sequence-rail:before{bottom:22px}[data-theme=dark] .stack-sequence-rail:before{opacity:.7;background:linear-gradient(#0000,#ffffff1a 10% 90%,#0000)}.stack-sequence-dot{z-index:1;width:40px;height:40px;font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--text-secondary);background:var(--bg);border:1px solid var(--border);transition:color .28s var(--ease-out-swift), border-color .28s var(--ease-out-swift), background .28s var(--ease-out-swift), box-shadow .3s ease, transform .35s var(--ease-out-soft);border-radius:9999px;justify-content:center;align-items:center;font-size:.8rem;font-weight:600;display:inline-flex;position:relative;box-shadow:0 1px 2px #00000008}.stack-sequence-dot:before{content:"";background:var(--section-color,transparent);opacity:0;filter:blur(10px);z-index:-1;border-radius:9999px;transition:opacity .4s;position:absolute;inset:-6px}.stack-sequence-item:hover .stack-sequence-dot{transform:scale(1.06)}.stack-sequence-item:hover .stack-sequence-dot:before{opacity:.25}[data-theme=dark] .stack-sequence-item:hover .stack-sequence-dot:before{opacity:.35}[data-theme=dark] .stack-sequence-dot{background:var(--bg);border-color:#ffffff17;box-shadow:inset 0 1px #ffffff0d}.stack-sequence-item:hover .stack-sequence-dot{color:var(--section-color,var(--text-primary));border-color:color-mix(in srgb, var(--section-color,var(--text-muted)) 40%, var(--border-hover));box-shadow:0 1px 2px #00000008, 0 8px 24px -12px var(--section-glow,#00000014)}[data-theme=dark] .stack-sequence-item:hover .stack-sequence-dot{box-shadow:inset 0 1px 0 #ffffff12, 0 10px 28px -10px var(--section-glow-dark,#ffffff0d)}.stack-sequence-card{flex-direction:column;gap:14px;align-items:stretch!important;padding:22px 24px!important}.stack-sequence-card-head{align-items:center;gap:14px;display:flex}.stack-sequence-card-head-text{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.stack-sequence-tag{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.12em;color:var(--section-color,var(--text-muted));opacity:.95;font-size:.62rem;font-weight:500}.stack-sequence-card .tech-card-title{letter-spacing:-.022em;font-size:1.2rem}.stack-sequence-card .tech-card-desc{margin:0;font-size:.9rem;line-height:1.6}.stack-sequence-card-foot{border-top:1px solid var(--border-subtle);padding-top:14px}[data-theme=dark] .stack-sequence-card-foot{border-top-color:#ffffff0d}@media (max-width:640px){.stack-sequence-item{grid-template-columns:44px 1fr;gap:14px;padding-bottom:18px}.stack-sequence-rail{padding-top:18px}.stack-sequence-dot{width:32px;height:32px;font-size:.7rem}.stack-sequence-card{padding:18px!important}.stack-sequence-card .tech-card-title{font-size:1.05rem}}.stack-projects{margin-top:48px}.stack-projects-head{flex-direction:column;gap:10px;margin-bottom:28px;display:flex}.stack-projects-title{letter-spacing:-.025em;color:var(--text-primary);text-wrap:balance;margin:4px 0 0;font-size:1.35rem;font-weight:700;line-height:1.15}@media (min-width:640px){.stack-projects-title{font-size:1.5rem}}.stack-projects-grid{grid-template-columns:1fr;gap:14px;display:grid}@media (min-width:720px){.stack-projects-grid{grid-template-columns:repeat(3,1fr)}}.stack-project-card{flex-direction:column;gap:12px;align-items:stretch!important;padding:22px 22px 20px!important}.stack-project-card-head{justify-content:space-between;align-items:center;display:flex}.stack-project-icon{border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;display:inline-flex}.stack-project-emoji{font-size:1.15rem;line-height:1}.stack-project-title{letter-spacing:-.018em;font-size:1.05rem}.stack-project-stack{flex-wrap:wrap;gap:5px;margin-top:2px;display:flex}.stack-card{flex-direction:column;gap:0;align-items:stretch!important;padding:24px 24px 22px!important;display:flex!important}.stack-card-head{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.stack-card-body{flex:1;min-width:0}.stack-card-body .tech-card-title{letter-spacing:-.022em;font-size:1.15rem}.stack-card-body .tech-card-desc{margin-top:8px;font-size:.89rem;line-height:1.6}.stack-card-foot{border-top:1px solid var(--border-subtle);margin-top:18px;padding-top:16px}[data-theme=dark] .stack-card-foot{border-top-color:#ffffff0d}@media (max-width:640px){.stack-card{padding:20px 20px 18px!important}.stack-card-head{margin-bottom:16px}.stack-card-body .tech-card-title{font-size:1.05rem}.stack-card-foot{margin-top:14px;padding-top:12px}}.article-nav{grid-template-columns:1fr 1fr;gap:14px;margin-top:88px;padding-top:32px;display:grid;position:relative}.article-nav:before{content:"";background:linear-gradient(90deg, transparent, var(--border-hover), transparent);opacity:.7;height:1px;position:absolute;top:0;left:25%;right:25%}.article-nav-card{background:var(--surface);border:1px solid var(--border);color:inherit;border-radius:12px;flex-direction:column;gap:6px;min-width:0;padding:18px 20px;text-decoration:none;transition:transform .2s cubic-bezier(.2,0,.2,1),background .18s,border-color .18s,box-shadow .25s;display:flex;box-shadow:0 1px 2px #00000006}.article-nav-card:hover{background:var(--surface);border-color:var(--border-hover);transform:translateY(-1px);box-shadow:0 1px 2px #00000008,0 14px 36px -14px #00000014}.article-nav-card.is-next{text-align:right;align-items:flex-end}.article-nav-label{font-family:var(--font-mono);letter-spacing:.11em;text-transform:uppercase;color:var(--text-muted);align-items:center;gap:6px;font-size:.66rem;font-weight:500;display:inline-flex}.article-nav-title{color:var(--text-primary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.9rem;font-weight:600;line-height:1.4;display:-webkit-box;overflow:hidden}.article-nav-card.is-next .article-nav-label svg{order:2;transition:transform .2s}.article-nav-card.is-prev .article-nav-label svg{transition:transform .2s}.article-nav-card.is-prev:hover .article-nav-label svg{transform:translate(-2px)}.article-nav-card.is-next:hover .article-nav-label svg{transform:translate(2px)}[data-theme=dark] .article-nav-card{background:var(--surface);border-color:var(--border);box-shadow:inset 0 1px #ffffff08}[data-theme=dark] .article-nav-card:hover{background:var(--surface-hover);border-color:var(--border-hover);box-shadow:inset 0 1px #ffffff0a}.project-hero-head{align-items:center;gap:14px;margin-bottom:4px;display:flex}.project-hero-icon{border-radius:12px;justify-content:center;align-items:center;width:52px;height:52px;display:inline-flex}.project-hero-emoji{font-size:1.4rem;line-height:1}.project-hero-eyebrow{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);align-items:center;gap:10px;font-size:.7rem;font-weight:500;display:inline-flex}.project-hero-eyebrow-dot{background:var(--section-color,var(--text-muted));border-radius:50%;width:6px;height:6px}.project-stack-chips{flex-wrap:wrap;gap:6px;margin:22px 0 0;display:flex}@media (max-width:640px){.project-hero-icon{border-radius:11px;width:46px;height:46px}.project-hero-emoji{font-size:1.25rem}}.phase-group{flex-direction:column;display:flex}.phase-label{align-items:center;gap:12px;margin-bottom:18px;padding-left:2px;display:flex}.phase-label-index{font-family:var(--font-mono);letter-spacing:.02em;color:var(--section-color,var(--text-muted));opacity:.85;font-variant-numeric:tabular-nums;font-size:.68rem;font-weight:500}.phase-label-line{background:var(--section-color,var(--border-hover));opacity:.55;flex-shrink:0;width:28px;height:1px}.phase-label-text{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.16em;color:var(--text-secondary);font-size:.66rem;font-weight:600}@media (max-width:640px){.phase-label{gap:10px;margin-bottom:14px}.phase-label-line{width:20px}.phase-label-text{font-size:.62rem}}.tech-card-start{font-family:var(--font-mono);letter-spacing:.09em;text-transform:uppercase;color:var(--section-color,var(--text-primary));background:color-mix(in srgb, var(--section-color,var(--text-muted)) 12%, transparent);border:1px solid color-mix(in srgb, var(--section-color,var(--text-muted)) 30%, transparent);vertical-align:middle;white-space:nowrap;border-radius:9999px;align-items:center;margin-left:10px;padding:2px 8px;font-size:.58rem;font-weight:600;display:inline-flex}[data-theme=dark] .tech-card-start{background:color-mix(in srgb, var(--section-color,var(--text-muted)) 18%, transparent);border-color:color-mix(in srgb, var(--section-color,var(--text-muted)) 38%, transparent)}@media (max-width:640px){.tech-card-start{margin-left:6px;padding:1px 6px;font-size:.55rem}}.diagram{background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;align-items:center;gap:18px;margin:40px 0;padding:28px 24px 22px;display:flex;box-shadow:0 1px 2px #00000006}[data-theme=dark] .diagram{background:var(--surface);border-color:var(--border);box-shadow:inset 0 1px #ffffff08}.diagram-svg{width:100%;max-width:560px;height:auto}.diagram-caption{color:var(--text-muted);text-align:center;text-wrap:pretty;max-width:440px;font-size:.82rem;line-height:1.55}.diagram-node rect{fill:var(--surface);stroke:var(--border-hover);stroke-width:1px}[data-theme=dark] .diagram-node rect{fill:var(--surface-hover,#2c2c33);stroke:#ffffff1f}.diagram-node-label{font-family:var(--font-inter), sans-serif;fill:var(--text-primary);font-size:13px;font-weight:600}.diagram-node-sub{font-family:var(--font-mono);fill:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;font-size:9px;font-weight:500}.diagram-node-middle rect{stroke:var(--section-color,var(--border-hover));stroke-width:1.5px}.diagram-line{fill:none;stroke:var(--border-hover);stroke-width:1px;stroke-dasharray:3 4;opacity:.85}[data-theme=dark] .diagram-line{stroke:#ffffff1f}.diagram-arc{stroke:var(--border-hover);stroke-width:1px;stroke-dasharray:3 4;opacity:.85}[data-theme=dark] .diagram-arc{stroke:#ffffff1f}.diagram-arrow{fill:none;stroke:var(--border-hover);stroke-width:1.4px;stroke-linecap:round;stroke-linejoin:round}[data-theme=dark] .diagram-arrow{stroke:#fff3}.diagram-line-label{font-family:var(--font-mono);fill:var(--text-muted);letter-spacing:.04em;font-size:9px;font-weight:500}.diagram-dot{fill:var(--section-color,#54c5f8);filter:drop-shadow(0 0 6px var(--section-color,#54c5f8));opacity:0}.diagram-auth .diagram-dot-1{--travel-start-x:138;--travel-end-x:272;--travel-y:70;animation:6s ease-in-out infinite dot-travel-right}.diagram-auth .diagram-dot-2{--travel-start-x:272;--travel-end-x:138;--travel-y:150;animation:6s ease-in-out 1.5s infinite dot-travel-left}.diagram-auth .diagram-dot-3{--travel-start-x:288;--travel-end-x:422;--travel-y:70;animation:6s ease-in-out 3s infinite dot-travel-right}.diagram-auth .diagram-dot-4{--travel-start-x:422;--travel-end-x:288;--travel-y:150;animation:6s ease-in-out 4.5s infinite dot-travel-left}@keyframes dot-travel-right{0%,to{cx:var(--travel-start-x);cy:var(--travel-y);opacity:0}5%{opacity:1}20%{cx:var(--travel-end-x);cy:var(--travel-y);opacity:1}25%,to{opacity:0}}@keyframes dot-travel-left{0%,to{cx:var(--travel-start-x);cy:var(--travel-y);opacity:0}5%{opacity:1}20%{cx:var(--travel-end-x);cy:var(--travel-y);opacity:1}25%,to{opacity:0}}.diagram-cycle-dot{fill:var(--section-color,#54c5f8);filter:drop-shadow(0 0 8px var(--section-color,#54c5f8));offset-path:path("M 215 70 Q 260 50 310 70 L 370 95 Q 420 165 370 205 L 310 230 Q 260 250 215 230 L 155 205 Q 105 165 155 95 Z");offset-rotate:0deg;animation:7s linear infinite cycle-travel}@keyframes cycle-travel{0%{offset-distance:0%}to{offset-distance:100%}}@media (prefers-reduced-motion:reduce){.diagram-dot,.diagram-cycle-dot{opacity:0!important;animation:none!important}}@media (max-width:640px){.diagram{margin:32px 0;padding:22px 16px 18px}.diagram-caption{font-size:.78rem}}.tech-hero-hairline{background:linear-gradient(90deg, var(--border-hover), transparent 80%);opacity:.45;max-width:520px;height:1px;margin-top:32px;position:relative}[data-theme=dark] .tech-hero-hairline{opacity:.35}.tech-hero-article .tech-hero-hairline{max-width:320px}.related-reading{margin-top:80px;position:relative}.related-reading-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);align-items:center;gap:12px;margin-bottom:18px;font-size:.66rem;font-weight:600;display:flex}.related-reading-label:before{content:"";background:var(--border-hover);opacity:.5;width:20px;height:1px}.related-reading-grid{grid-template-columns:1fr;gap:12px;display:grid}@media (min-width:640px){.related-reading-grid{grid-template-columns:repeat(2,1fr)}}.related-reading-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:12px;min-width:0;padding:20px 22px;text-decoration:none;transition:transform .2s cubic-bezier(.2,0,.2,1),background .18s,border-color .18s,box-shadow .25s;display:flex;box-shadow:0 1px 2px #00000006}.related-reading-card:hover{border-color:var(--border-hover);box-shadow:0 1px 2px #00000008, 0 14px 36px -14px #00000014, 0 0 0 1px var(--card-accent,transparent);transform:translateY(-1px)}[data-theme=dark] .related-reading-card{background:var(--surface);border-color:var(--border);box-shadow:inset 0 1px #ffffff08}[data-theme=dark] .related-reading-card:hover{background:var(--surface-hover);border-color:var(--border-hover);box-shadow:inset 0 1px #ffffff0a}.related-reading-card-head{align-items:center;gap:10px;display:flex}.related-reading-card-icon{border:1px solid var(--border);border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:inline-flex}[data-theme=dark] .related-reading-card-icon{border-color:var(--border)}.related-reading-card-section{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);font-size:.62rem;font-weight:500}.related-reading-card-title{color:var(--text-primary);letter-spacing:-.015em;margin:0;font-size:1rem;font-weight:600;line-height:1.35}.related-reading-card-desc{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.85rem;line-height:1.55;display:-webkit-box;overflow:hidden}@media (max-width:640px){.related-reading{margin-top:64px}.related-reading-card{padding:18px}}.apps-cta{flex-direction:column;align-items:stretch;margin-top:72px;display:flex}.apps-cta-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.18em;color:var(--text-muted);justify-content:center;align-items:center;gap:14px;margin-bottom:20px;font-size:.62rem;font-weight:500;display:flex}.apps-cta-label-line{background:linear-gradient(90deg, transparent, var(--border-hover), transparent);opacity:.55;flex:1;max-width:60px;height:1px}.apps-cta-chips{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}@media (min-width:640px){.apps-cta-chips{grid-template-columns:repeat(3,1fr)}}@media (min-width:900px){.apps-cta-chips{grid-template-columns:repeat(5,1fr)}}.apps-cta-chip{background:var(--surface);border:1px solid var(--border);color:var(--text-primary);border-radius:12px;align-items:center;gap:10px;min-width:0;padding:12px 14px;text-decoration:none;transition:transform .2s cubic-bezier(.2,0,.2,1),background .18s,border-color .18s,box-shadow .25s;display:flex;box-shadow:0 1px 2px #00000005}.apps-cta-chip:hover{border-color:var(--border-hover);transform:translateY(-1px);box-shadow:0 1px 2px #00000008,0 14px 28px -14px #00000014}[data-theme=dark] .apps-cta-chip{background:var(--surface);border-color:var(--border);box-shadow:inset 0 1px #ffffff08}[data-theme=dark] .apps-cta-chip:hover{background:var(--surface-hover);border-color:var(--border-hover);box-shadow:inset 0 1px #ffffff0a}.apps-cta-chip-author{background:color-mix(in srgb, var(--text-muted) 4%, var(--surface))}[data-theme=dark] .apps-cta-chip-author{background:var(--surface)}.apps-cta-chip-avatar{object-fit:contain;background:var(--hover-bg);border:1px solid var(--border);border-radius:50%;flex-shrink:0;width:26px;height:26px}[data-theme=dark] .apps-cta-chip-avatar{background:#ffffff0a;border-color:#ffffff14}.apps-cta-chip-emoji{background:var(--hover-bg);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:.95rem;line-height:1;display:inline-flex}[data-theme=dark] .apps-cta-chip-emoji{background:#ffffff0d}.apps-cta-chip-body{text-align:left;flex-direction:column;gap:1px;min-width:0;display:flex}.apps-cta-chip-name{color:var(--text-primary);letter-spacing:-.005em;white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;overflow:hidden}.apps-cta-chip-sub{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.66rem;overflow:hidden}@media (max-width:640px){.apps-cta{margin-top:56px}.apps-cta-chip{padding:11px 12px}}@media (pointer:coarse){.copy-btn{opacity:.6}}@media (max-width:768px){.article-nav{margin-top:64px;padding-top:22px}}@media (max-width:640px){.tech-page:before{opacity:.7;width:520px;height:520px;top:-260px;right:-180px}.article-body h2{margin:52px 0 12px;font-size:1.26rem}.article-body h2:first-child{margin-top:4px}.article-body h3{margin:30px 0 8px;font-size:.72rem}.article-body p,.article-body li{font-size:.92rem;line-height:1.72}.article-body pre{border-radius:10px;padding:14px 16px;font-size:.76rem}.code-block pre{font-size:.76rem;border-radius:0 0 10px 10px!important;padding:14px 16px!important}.code-block-header{border-radius:10px 10px 0 0;padding:9px 14px}.code-block-lang{font-size:.62rem}.article-body code{padding:1px 5px;font-size:.78em}.article-nav{grid-template-columns:1fr;margin-top:72px;padding-top:28px}.article-nav-card{padding:16px 18px}}
