/*
! tailwindcss v3.4.3 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.\!inline{display:inline!important}.inline{display:inline}.flex{display:flex}.contents{display:contents}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--accent-1:#7c7cff;--accent-2:#b18cff;--accent-3:#ff9fe5;--accent-glow:rgba(124,124,255,.45);--bg:#f7f6f3;--bg-2:#eceae4;--bg-card:hsla(0,0%,100%,.6);--border:hsla(0,0%,7%,.08);--border-strong:hsla(0,0%,7%,.14);--ink:#111214;--ink-dim:#5a5b62;--ink-faint:#8e8f97;--chip-bg:hsla(0,0%,7%,.04);--font-display:"Space Grotesk",system-ui,sans-serif;--font-body:"Geist",system-ui,sans-serif;--font-mono:"Geist Mono","JetBrains Mono",ui-monospace,monospace;--font-serif:"Instrument Serif","Fraunces",serif;--radius-sm:10px;--radius:16px;--radius-lg:22px;--shadow-soft:0 1px 0 hsla(0,0%,7%,.04),0 10px 30px -12px hsla(0,0%,7%,.08);--shadow-pop:0 1px 0 hsla(0,0%,7%,.06),0 20px 40px -16px hsla(0,0%,7%,.16)}html.dark{--bg:#0b0b0f;--bg-2:#121218;--bg-card:rgba(22,22,28,.6);--border:hsla(0,0%,100%,.08);--border-strong:hsla(0,0%,100%,.14);--ink:#ededef;--ink-dim:#a1a1aa;--ink-faint:#6b6b74;--chip-bg:hsla(0,0%,100%,.05);--shadow-soft:0 1px 0 hsla(0,0%,100%,.04),0 20px 50px -18px rgba(0,0,0,.6);--shadow-pop:0 1px 0 hsla(0,0%,100%,.06),0 30px 60px -20px rgba(0,0,0,.8)}*{box-sizing:border-box}body,html{margin:0;padding:0;min-height:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-feature-settings:"ss01","cv11";overflow-x:hidden}a{color:inherit;text-decoration:none}.ambient{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55}html.dark .blob{opacity:.35}.blob.b1{width:620px;height:620px;top:-180px;left:-120px;background:var(--accent-1)}.blob.b2{width:520px;height:520px;top:30vh;right:-160px;background:var(--accent-2)}.blob.b3{width:420px;height:420px;top:90vh;left:30vw;background:var(--accent-3)}.noise{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.4;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}html.dark .noise{opacity:.25}.wrap{max-width:1120px;margin:0 auto;padding:0 28px}.nav{position:sticky;top:0;z-index:40;backdrop-filter:saturate(140%) blur(16px);-webkit-backdrop-filter:saturate(140%) blur(16px);background:color-mix(in oklab,var(--bg) 72%,transparent);border-bottom:1px solid var(--border)}.nav-inner{justify-content:space-between;padding:14px 28px;max-width:1120px;margin:0 auto}.brand,.nav-inner{display:flex;align-items:center}.brand{gap:10px;font-family:var(--font-mono);font-size:13px;letter-spacing:-.01em;color:var(--ink-dim)}.brand-dot{width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,var(--accent-1),var(--accent-2) 50%,var(--accent-3));box-shadow:0 0 0 3px color-mix(in oklab,var(--accent-1) 25%,transparent);animation:pulse 2.4s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 3px color-mix(in oklab,var(--accent-1) 20%,transparent)}50%{box-shadow:0 0 0 7px color-mix(in oklab,var(--accent-1) 8%,transparent)}}.nav-links{display:flex;gap:4px;align-items:center;flex-wrap:wrap}.nav-links a{font-family:var(--font-mono);font-size:12.5px;color:var(--ink-dim);padding:8px 12px;border-radius:8px;transition:all .18s ease}.nav-links a.active,.nav-links a:hover{color:var(--ink);background:var(--chip-bg)}.theme-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;border:1px solid var(--border);background:var(--bg-card);cursor:pointer;color:var(--ink-dim);transition:all .2s ease}.theme-btn:hover{color:var(--ink);border-color:var(--border-strong)}.nav-toggle{display:none;background:none;border:1px solid var(--border);width:34px;height:34px;border-radius:10px;color:var(--ink-dim);align-items:center;justify-content:center;cursor:pointer}@media (max-width:760px){.nav-toggle{display:inline-flex}.nav-links{display:none}.nav-links.open{display:flex;flex-direction:column;align-items:stretch;position:absolute;top:62px;left:14px;right:14px;background:var(--bg);border:1px solid var(--border-strong);border-radius:var(--radius);padding:10px;gap:2px;box-shadow:var(--shadow-pop)}.nav-links.open a{padding:10px 12px}.nav-links.open .theme-btn{margin-top:4px;align-self:flex-start}.nav-inner{position:relative}}.eyebrow{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);display:inline-flex;align-items:center;gap:8px}.eyebrow:before{content:"";width:18px;height:1px;background:currentColor;opacity:.5}.h-display{font-size:clamp(40px,6.4vw,84px);letter-spacing:-.035em;line-height:1.02}.h-display,.h-section{font-family:var(--font-display);font-weight:500;margin:0}.h-section{font-size:clamp(28px,3.6vw,44px);letter-spacing:-.028em;line-height:1.05}.gradient-text{background:linear-gradient(100deg,var(--accent-1) 0,var(--accent-2) 45%,var(--accent-3) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.serif-i{font-family:var(--font-serif);font-style:italic;font-weight:400}section.page-section{padding:120px 0;position:relative}section.page-section:first-of-type{padding-top:40px}.section-head{display:flex;align-items:end;justify-content:space-between;gap:40px;margin-bottom:56px;flex-wrap:wrap}.section-head .lede{max-width:520px;color:var(--ink-dim);font-size:16px;line-height:1.55}.reveal{opacity:0;transform:translateY(18px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}.reveal.in{opacity:1;transform:none}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);backdrop-filter:blur(14px) saturate(130%);-webkit-backdrop-filter:blur(14px) saturate(130%);transition:transform .3s cubic-bezier(.2,.7,.2,1),border-color .3s ease,box-shadow .3s ease}.card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-soft)}.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:12px;font-family:var(--font-mono);font-size:13px;border:1px solid var(--border);background:var(--bg-card);color:var(--ink);cursor:pointer;transition:transform .2s ease,border-color .2s ease,background .2s ease}.btn:hover{border-color:var(--border-strong);transform:translateY(-1px)}.btn.primary{background:linear-gradient(135deg,var(--accent-1),var(--accent-2));color:#fff;border-color:transparent;box-shadow:0 8px 22px -8px var(--accent-glow)}.btn.primary:hover{box-shadow:0 12px 28px -8px var(--accent-glow)}.tag{font-family:var(--font-mono);font-size:11.5px;padding:5px 10px;border-radius:6px;background:var(--chip-bg);color:var(--ink-dim);border:1px solid var(--border);transition:all .2s ease}.tag:hover{color:var(--ink);border-color:var(--border-strong);transform:translateY(-1px)}footer.site-footer{padding:60px 0 40px;border-top:1px solid var(--border);color:var(--ink-faint);font-family:var(--font-mono);font-size:12.5px}.foot-inner{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}.hero-inner{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center;padding-top:40px;min-height:84vh}@media (max-width:900px){.hero-inner{grid-template-columns:1fr;gap:32px;min-height:0;padding-top:20px}}.hero-avatar,.hero-left{position:relative}.hero-avatar{width:72px;height:72px;border-radius:50%;margin-bottom:24px;background:linear-gradient(135deg,var(--accent-1),var(--accent-2) 50%,var(--accent-3));padding:3px;display:inline-flex;box-shadow:0 10px 30px -10px var(--accent-glow);transition:transform .4s cubic-bezier(.2,.7,.2,1)}.hero-avatar:hover{transform:scale(1.05) rotate(-3deg)}.hero-avatar:before{content:"";position:absolute;inset:-6px;border-radius:50%;background:conic-gradient(from 0deg,var(--accent-1),var(--accent-2),var(--accent-3),var(--accent-1));opacity:.3;z-index:-1;filter:blur(14px);animation:spin 8s linear infinite}.hero-avatar .inner{width:100%;height:100%;border-radius:50%;background:var(--bg-2);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:500;font-size:26px;letter-spacing:-.02em;color:var(--ink);overflow:hidden;position:relative}.hero-avatar .inner img{width:100%;height:100%;object-fit:cover}.hero-avatar .status-pip{position:absolute;right:2px;bottom:2px;width:18px;height:18px;border-radius:50%;background:#34d399;border:3px solid var(--bg);box-shadow:0 0 0 2px rgba(52,211,153,.3)}@keyframes spin{to{transform:rotate(1turn)}}.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:6px 12px 6px 10px;border:1px solid var(--border);border-radius:999px;background:var(--bg-card);backdrop-filter:blur(10px);font-family:var(--font-mono);font-size:12px;color:var(--ink-dim);margin-bottom:28px}.hero-eyebrow .status{width:7px;height:7px;border-radius:50%;background:#34d399;box-shadow:0 0 0 3px rgba(52,211,153,.22)}.hero-title{margin:0 0 22px}.hero-title .line1{display:block;color:var(--ink)}.hero-title .line2{display:block}.hero-title .wave{display:inline-block;transform-origin:70% 70%;animation:wave 2.6s ease-in-out infinite}@keyframes wave{0%,60%,to{transform:rotate(0deg)}10%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}30%{transform:rotate(14deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}}.hero-sub{font-size:19px;line-height:1.55;color:var(--ink-dim);max-width:540px;margin:0 0 36px}.hero-sub b{color:var(--ink);font-weight:600}.hero-ctas{gap:10px}.hero-ctas,.hero-quick{display:flex;flex-wrap:wrap}.hero-quick{gap:28px;margin-top:52px;padding-top:28px;border-top:1px dashed var(--border)}.hero-quick .qi{display:flex;flex-direction:column;gap:4px}.hero-quick .qn{font-family:var(--font-display);font-size:26px;font-weight:500;letter-spacing:-.02em}.hero-quick .ql{font-family:var(--font-mono);font-size:11.5px;color:var(--ink-faint);letter-spacing:.05em;text-transform:uppercase}.term{position:relative;border-radius:12px;overflow:hidden;background:#1e1e2e;border:1px solid #313244;box-shadow:0 1px 0 hsla(0,0%,100%,.04) inset,0 30px 80px -24px rgba(0,0,0,.7),0 0 0 1px var(--border);font-family:JetBrains Mono,Geist Mono,ui-monospace,monospace;color:#cdd6f4;transform:perspective(1400px) rotateY(-3deg) rotateX(2deg);transition:transform .5s cubic-bezier(.2,.7,.2,1)}.term:hover{transform:perspective(1400px) rotateY(-1.5deg) rotateX(1deg)}.term:before{content:"";position:absolute;inset:-1px;background:conic-gradient(from 200deg,transparent,#cba6f7,#f5c2e7,#89b4fa,transparent 60%);opacity:.25;z-index:-1;filter:blur(20px);animation:spin 10s linear infinite}.term-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid #313244;background:#181825}.term-dots{display:flex;gap:6px}.term-dots i{width:11px;height:11px;border-radius:50%;display:block}.term-dots i:first-child{background:#f38ba8}.term-dots i:nth-child(2){background:#f9e2af}.term-dots i:nth-child(3){background:#a6e3a1}.term-title{flex:1;text-align:center;font-size:11.5px;color:#a6adc8;letter-spacing:.02em}.term-title .bullet{color:#6c7086;margin:0 8px}.term-body{padding:18px 20px 24px;font-size:13.5px;line-height:1.7;min-height:360px;max-height:460px;overflow:hidden;background:#1e1e2e}.term-line{white-space:pre-wrap;word-break:break-word}.term-line .prompt{color:#a6e3a1;margin-right:8px;font-weight:500}.term-line .prompt .at{color:#fab387}.term-line .prompt .tilde{color:#89b4fa}.term-line .cmd{color:#cdd6f4}.term-line .comment{color:#6c7086;font-style:italic}.term-line .ok{color:#a6e3a1}.term-line .key{color:#cba6f7}.term-line .str{color:#f9e2af}.term-line .dim{color:#a6adc8}.term-line .hl{color:#f5c2e7}.cursor{display:inline-block;width:8px;height:1.1em;background:#f5e0dc;vertical-align:-2px;margin-left:2px;animation:blink 1s steps(2) infinite}@keyframes blink{50%{opacity:0}}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}@media (max-width:800px){.about-grid{grid-template-columns:1fr;gap:28px}}.about-copy{font-family:var(--font-serif);font-size:clamp(22px,2.2vw,30px);line-height:1.38;letter-spacing:-.012em;color:var(--ink);max-width:580px}.about-copy p{margin:0 0 18px}.about-copy em{color:var(--ink-dim);font-style:italic}.about-copy .hl{background:linear-gradient(180deg,transparent 62%,color-mix(in oklab,var(--accent-2) 40%,transparent) 62%);padding:0 2px}.about-meta{display:grid;gap:14px;font-family:var(--font-mono);font-size:13px}.about-meta .row{display:grid;grid-template-columns:100px 1fr;padding:14px 0;border-bottom:1px dashed var(--border);color:var(--ink)}.about-meta .row:last-child{border-bottom:none}.about-meta .k{color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;font-size:11.5px}.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}.timeline{padding-left:24px;border-left:1px solid var(--border)}.job,.timeline{position:relative}.job{padding:0 0 48px 28px}.job:last-child{padding-bottom:8px}.job:before{content:"";position:absolute;left:-30px;top:8px;width:12px;height:12px;border-radius:50%;background:var(--bg);border:2px solid var(--accent-1);box-shadow:0 0 0 3px var(--bg);transition:all .3s ease}.job:hover:before{background:var(--accent-1);box-shadow:0 0 0 4px color-mix(in oklab,var(--accent-1) 20%,transparent)}.job-head{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin-bottom:6px;flex-wrap:wrap}.job-role{font-family:var(--font-display);font-size:22px;font-weight:500;letter-spacing:-.02em;margin:0}.job-role .at{color:var(--ink-faint);font-weight:400}.job-role .co{color:var(--ink)}.job-time{font-family:var(--font-mono);font-size:12px;color:var(--ink-faint);letter-spacing:.04em;white-space:nowrap}.job-desc{color:var(--ink-dim);font-size:15.5px;line-height:1.6;margin:8px 0 10px;max-width:680px}.job-desc ul{margin:8px 0 0;padding-left:20px}.job-desc li{margin:4px 0}.job-stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}.proj-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}@media (max-width:900px){.proj-grid{grid-template-columns:1fr}}.proj{grid-column:span 3;padding:26px;min-height:220px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;text-decoration:none;color:inherit}.proj.feat{grid-column:span 6;min-height:280px}@media (max-width:900px){.proj,.proj.feat{grid-column:span 1;min-height:0}}.proj-top{display:flex;align-items:start;justify-content:space-between;gap:14px;margin-bottom:20px}.proj-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;padding:4px 8px;border-radius:5px;background:var(--chip-bg);color:var(--ink-dim);letter-spacing:.04em;text-transform:uppercase}.proj-badge .dot{width:5px;height:5px;border-radius:50%;background:var(--accent-1)}.proj-badge.oss .dot{background:#34d399}.proj-badge.private .dot,.proj-badge.saas .dot{background:var(--accent-2)}.proj-badge.side .dot{background:#ffc66d}.proj-links{display:flex;gap:6px}.proj-link{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--ink-faint);transition:all .3s ease;background:var(--bg-card)}.proj:hover .proj-link{border-color:var(--accent-1);color:var(--accent-1)}.proj-link:hover{transform:translate(2px,-2px)}.proj-name{font-family:var(--font-display);font-size:22px;font-weight:500;letter-spacing:-.02em;margin:0 0 6px}.proj.feat .proj-name{font-size:32px}.proj-desc{color:var(--ink-dim);font-size:14.5px;line-height:1.55;margin:0 0 16px}.proj.feat .proj-desc{font-size:16px;max-width:640px}.proj-meta{display:flex;gap:12px;font-family:var(--font-mono);font-size:11.5px;color:var(--ink-faint);flex-wrap:wrap}.proj-meta span{display:inline-flex;align-items:center;gap:5px}.proj.feat:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 110% 10%,color-mix(in oklab,var(--accent-1) 18%,transparent),transparent 50%),radial-gradient(circle at 100% 110%,color-mix(in oklab,var(--accent-3) 18%,transparent),transparent 50%);pointer-events:none}.proj.feat>*{position:relative}.homelab-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:24px}@media (max-width:900px){.homelab-grid{grid-template-columns:1fr}}.rack{padding:24px;background:linear-gradient(180deg,color-mix(in oklab,var(--accent-1) 6%,var(--bg-card)),var(--bg-card));border:1px solid var(--border);border-radius:var(--radius);backdrop-filter:blur(14px) saturate(130%);-webkit-backdrop-filter:blur(14px) saturate(130%)}.rack-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.rack-head h3{margin:0;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-dim)}.rack-head h3,.rack-up{font-family:var(--font-mono)}.rack-up{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;color:var(--ink-faint)}.rack-up .dot{width:7px;height:7px;border-radius:50%;background:#34d399;box-shadow:0 0 0 3px rgba(52,211,153,.22)}.services{display:grid;gap:6px;grid-template-columns:1fr 1fr}@media (max-width:600px){.services{grid-template-columns:1fr}}.svc{display:grid;grid-template-columns:28px 1fr;gap:12px;align-items:center;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;font-size:13px;transition:all .25s ease}.svc:hover{border-color:var(--border-strong);transform:translateY(-1px)}.svc-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10.5px;font-weight:600;color:#fff;letter-spacing:-.02em;flex-shrink:0}.svc-icon-img{background:#fff;padding:3px}html.dark .svc-icon-img{background:hsla(0,0%,100%,.95)}.svc-icon-img img{width:100%;height:100%;object-fit:contain}.svc-name{font-weight:500;line-height:1.2}.svc-url{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-faint);margin-top:2px;letter-spacing:.01em}.box-stats{display:grid;gap:14px;align-content:start}.stat-card{padding:22px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);backdrop-filter:blur(14px) saturate(130%);-webkit-backdrop-filter:blur(14px) saturate(130%)}.stat-card .label{font-family:var(--font-mono);font-size:11px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.stat-card .val{font-family:var(--font-display);font-size:36px;font-weight:500;letter-spacing:-.02em;margin:0}.stat-card .sub{font-family:var(--font-mono);font-size:11.5px;color:var(--ink-dim);margin-top:6px}.bar{height:6px;background:var(--chip-bg);overflow:hidden;margin-top:14px}.bar,.bar i{border-radius:999px}.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--accent-1),var(--accent-2));width:0;transition:width 1.4s cubic-bezier(.2,.7,.2,1)}.posts{display:grid;gap:2px}.post{display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:24px;padding:22px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:padding .3s ease,background .3s ease}.post:hover{padding-left:12px}.post-num{font-family:var(--font-mono);font-size:12px;color:var(--ink-faint);letter-spacing:.06em}.post-title{font-family:var(--font-display);font-size:20px;font-weight:500;letter-spacing:-.018em;margin:0 0 4px;transition:color .2s ease}.post:hover .post-title{color:var(--accent-1)}.post-meta{display:flex;gap:12px;font-family:var(--font-mono);font-size:12px;flex-wrap:wrap}.post-meta,.post-meta .dot,.post-read{color:var(--ink-faint)}.post-read{font-family:var(--font-mono);font-size:11.5px;display:flex;align-items:center;gap:8px}.post-read svg{transition:transform .3s ease}.post:hover .post-read svg{transform:translateX(4px);color:var(--accent-1)}@media (max-width:700px){.post{grid-template-columns:40px 1fr}.post-read{display:none}}.uses-grid{display:grid;gap:80px}.uses-cat{display:grid;grid-template-columns:380px 1fr;gap:48px;align-items:start}@media (max-width:1050px){.uses-cat{grid-template-columns:300px 1fr;gap:32px}}@media (max-width:800px){.uses-cat{grid-template-columns:1fr;gap:20px}}.uses-cat-left{position:sticky;top:88px;align-self:start}.uses-cat h3{font-family:var(--font-display);font-size:22px;font-weight:500;letter-spacing:-.02em;margin:0 0 8px}.uses-cat .hint{font-family:var(--font-mono);font-size:11.5px;color:var(--ink-faint);letter-spacing:.04em;text-transform:uppercase}.uses-preview{margin-top:20px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);backdrop-filter:blur(10px);overflow:hidden;aspect-ratio:1;position:relative;opacity:0;transform:translateY(8px);transition:opacity .35s ease,transform .35s ease;pointer-events:none}.uses-preview.show{opacity:1;transform:none}.uses-preview img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:24px}.uses-preview-label{position:absolute;left:14px;right:14px;bottom:14px;font-family:var(--font-mono);font-size:12px;color:var(--ink);background:var(--bg);border:1px solid var(--border);padding:8px 12px;border-radius:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width:800px){.uses-cat-left{position:static}.uses-preview{display:none}}.uses-items{display:grid;gap:4px}.item{display:grid;grid-template-columns:56px 1fr auto;align-items:center;gap:18px;padding:16px 0;border-bottom:1px dashed var(--border);transition:padding .3s ease}.item:last-child{border-bottom:none}.item:hover{padding-left:10px}.item-thumb{width:56px;height:56px;border-radius:10px;background:var(--chip-bg);border:1px solid var(--border);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;opacity:.85;transition:opacity .3s ease,transform .3s ease}.item:hover .item-thumb{opacity:1;transform:scale(1.05)}.item-thumb img{width:100%;height:100%;object-fit:contain;padding:6px}.item-thumb-placeholder{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--ink-faint);letter-spacing:.02em}.item-name{font-family:var(--font-display);font-size:17px;font-weight:500;letter-spacing:-.014em}.item-note{color:var(--ink-dim);font-size:14px;line-height:1.5;margin-top:4px;max-width:520px}.item-aff{font-family:var(--font-mono);font-size:11px;color:var(--ink-faint);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.item-aff svg{transition:transform .3s ease}.item:hover .item-aff{color:var(--accent-1)}.item:hover .item-aff svg{transform:translate(2px,-2px)}.wp-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:140px;gap:12px}@media (max-width:900px){.wp-grid{grid-template-columns:repeat(6,1fr);grid-auto-rows:120px}}@media (max-width:500px){.wp-grid{grid-template-columns:repeat(2,1fr)}}.wp{border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer;transition:transform .4s cubic-bezier(.2,.7,.2,1);border:1px solid var(--border);background:var(--bg-card)}.wp img{width:100%;height:100%;object-fit:cover;display:block}.wp:hover{transform:translateY(-4px)}.wp:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.7));opacity:0;transition:opacity .3s ease;pointer-events:none}.wp:hover:after{opacity:1}.wp .cap{position:absolute;left:14px;bottom:12px;right:14px;color:#fff;font-family:var(--font-mono);font-size:11.5px;opacity:0;transform:translateY(6px);transition:opacity .3s ease,transform .3s ease;z-index:2;display:flex;justify-content:space-between;gap:8px}.wp:hover .cap{opacity:1;transform:none}.wp.s-6x2{grid-column:span 6;grid-row:span 2}.wp.s-4x2{grid-column:span 4;grid-row:span 2}.wp.s-3x2{grid-column:span 3;grid-row:span 2}.wp.s-4x1{grid-column:span 4;grid-row:span 1}@media (max-width:900px){.wp.s-6x2{grid-column:span 6}.wp.s-3x2,.wp.s-4x1,.wp.s-4x2{grid-column:span 3}}@media (max-width:500px){.wp,.wp.s-3x2,.wp.s-4x1,.wp.s-4x2,.wp.s-6x2{grid-column:span 1;grid-row:span 1}}.wp-filter-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}.wp-filter{font-family:var(--font-mono);font-size:11.5px;padding:6px 12px;border-radius:999px;background:var(--chip-bg);color:var(--ink-dim);border:1px solid var(--border);cursor:pointer;transition:all .2s ease}.wp-filter:hover{color:var(--ink);border-color:var(--border-strong)}.wp-filter.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}.wp-foot{margin-top:28px;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:12px;color:var(--ink-faint);padding-top:20px;border-top:1px solid var(--border);flex-wrap:wrap;gap:12px}.article-wrap{max-width:720px;margin:0 auto;padding:60px 28px 80px}.article-back{font-family:var(--font-mono);font-size:12.5px;color:var(--ink-faint);display:inline-flex;align-items:center;gap:8px;margin-bottom:32px;transition:color .2s ease}.article-back:hover{color:var(--ink)}.article-cover{width:100%;border-radius:var(--radius);overflow:hidden;margin-bottom:36px;aspect-ratio:16/9;position:relative;border:1px solid var(--border)}.article-head{margin-bottom:40px}.article-head .tag-row{margin-top:0;margin-bottom:18px}.article-title{font-family:var(--font-display);font-weight:500;font-size:clamp(32px,4vw,52px);letter-spacing:-.03em;line-height:1.05;margin:0 0 14px}.article-meta{font-family:var(--font-mono);font-size:12.5px;color:var(--ink-faint);display:flex;gap:12px;flex-wrap:wrap}.article-body{font-family:var(--font-serif);font-size:20px;line-height:1.65;color:var(--ink)}.article-body p{margin:0 0 20px}.article-body h1,.article-body h2,.article-body h3,.article-body h4{font-family:var(--font-display);font-weight:500;letter-spacing:-.025em;line-height:1.15;color:var(--ink);margin:48px 0 16px}.article-body h1{font-size:36px}.article-body h2{font-size:28px}.article-body h3{font-size:22px}.article-body h4{font-size:18px}.article-body a{color:var(--accent-1);text-decoration:underline;text-underline-offset:3px}.article-body a:hover{color:var(--accent-2)}.article-body ol,.article-body ul{padding-left:24px;margin:0 0 20px}.article-body li{margin:6px 0}.article-body blockquote{border-left:3px solid var(--accent-1);padding:4px 0 4px 18px;margin:24px 0;color:var(--ink-dim);font-style:italic}.article-body code{font-family:var(--font-mono);font-size:.85em;background:var(--chip-bg);padding:2px 6px;border-radius:5px;border:1px solid var(--border)}.article-body pre{background:#1e1e2e;color:#cdd6f4;padding:20px;border-radius:var(--radius);overflow-x:auto;margin:24px 0;font-family:"JetBrains Mono",var(--font-mono),monospace;font-size:13.5px;line-height:1.6}.article-body pre code{background:none;border:none;padding:0;color:inherit;font-size:inherit}.article-body img{max-width:100%;height:auto;border-radius:var(--radius);margin:24px auto;display:block;border:1px solid var(--border)}.article-body table{width:100%;border-collapse:collapse;margin:24px 0;font-family:var(--font-body);font-size:15px}.article-body td,.article-body th{border:1px solid var(--border);padding:10px 14px;text-align:left}.article-body th{background:var(--chip-bg);font-weight:600}