@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&display=swap");*,: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: }

/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:var(--font-primary);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]){-webkit-text-decoration:underline dotted;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::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}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]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.inset-1\.5{inset:.375rem}.row-span-1{grid-row:span 1/span 1}.mx-auto{margin-left:auto;margin-right:auto}.my-4{margin-top:1rem;margin-bottom:1rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-\[10px\]{margin-bottom:10px}.mt-0{margin-top:0}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.contents{display:contents}.hidden{display:none}.h-0\.5{height:.125rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-9{height:2.25rem}.min-h-\[42px\]{min-height:42px}.w-\[50px\]{width:50px}.w-full{width:100%}.max-w-3xl{max-width:48rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-\[1100px\]{max-width:1100px}.max-w-none{max-width:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-stretch{justify-content:stretch}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-\[15px\]{gap:15px}.space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(0px * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0px * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.whitespace-nowrap{white-space:nowrap}.rounded-\[10px\]{border-radius:10px}.rounded-\[13px\]{border-radius:13px}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-xl{border-radius:var(--radius-xl)}.\!border{border-width:1px!important}.border{border-width:1px}.border-2{border-width:2px}.\!border-solid{border-style:solid!important}.\!border-\[var\(--card-border\)\]{border-color:var(--card-border)!important}.\!border-white\/\[0\.14\]{border-color:hsla(0,0%,100%,.14)!important}.border-\[\#854ce6\]{--tw-border-opacity:1;border-color:rgb(133 76 230/var(--tw-border-opacity,1))}.border-\[var\(--card-border\)\]{border-color:var(--card-border)}.border-\[var\(--card-border-hover\)\]{border-color:var(--card-border-hover)}.border-white\/10{border-color:hsla(0,0%,100%,.1)}.\!bg-white\/\[0\.025\]{background-color:hsla(0,0%,100%,.025)!important}.bg-\[var\(--bg-primary\)\]{background-color:var(--bg-primary)}.bg-\[var\(--card-bg\2c \#0a0a0a\)\]{background-color:var(--card-bg,#0a0a0a)}.bg-\[var\(--card-surface\)\]{background-color:var(--card-surface)}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-white\/\[0\.04\]{background-color:hsla(0,0%,100%,.04)}.bg-white\/\[0\.05\]{background-color:hsla(0,0%,100%,.05)}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-purple-brand{--tw-gradient-from:var(--purple-primary) var(--tw-gradient-from-position);--tw-gradient-to:hsla(0,0%,100%,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-transparent{--tw-gradient-from:transparent var(--tw-gradient-from-position);--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.to-purple-brand{--tw-gradient-to:var(--purple-primary) var(--tw-gradient-to-position)}.to-transparent{--tw-gradient-to:transparent var(--tw-gradient-to-position)}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-7{padding-left:1.75rem;padding-right:1.75rem}.px-\[10px\]{padding-left:10px;padding-right:10px}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pl-\[18px\]{padding-left:18px}.text-left{text-align:left}.text-center{text-align:center}.font-display{font-family:var(--font-display)}.font-sans{font-family:var(--font-primary)}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-\[13px\]{font-size:13px}.text-base{font-size:1rem;line-height:1.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-5{line-height:1.25rem}.leading-8{line-height:2rem}.leading-tight{line-height:1.25}.tracking-\[0\.16em\]{letter-spacing:.16em}.text-\[\#F2F3F4\]{--tw-text-opacity:1;color:rgb(242 243 244/var(--tw-text-opacity,1))}.text-\[var\(--text-secondary\)\]{color:var(--text-secondary)}.text-black{--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity,1))}.text-muted{color:var(--text-muted)}.text-purple-brand{color:var(--purple-primary)}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-zinc-300{--tw-text-opacity:1;color:rgb(212 212 216/var(--tw-text-opacity,1))}.text-zinc-400{--tw-text-opacity:1;color:rgb(161 161 170/var(--tw-text-opacity,1))}.shadow-\[0_0_12px_4px_rgba\(0\2c 0\2c 0\2c 0\.22\)\]{--tw-shadow:0 0 12px 4px rgba(0,0,0,.22);--tw-shadow-colored:0 0 12px 4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-\[inset_0_1px_0_rgba\(255\2c 255\2c 255\2c 0\.06\)\]{--tw-shadow:inset 0 1px 0 hsla(0,0%,100%,.06);--tw-shadow-colored:inset 0 1px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-\[rgba\(133\2c 76\2c 230\2c 0\.1\)_0px_4px_24px\]{--tw-shadow:rgba(133,76,230,.1) 0px 4px 24px;--tw-shadow-colored:0px 4px 24px var(--tw-shadow-color)}.shadow-\[rgba\(133\2c 76\2c 230\2c 0\.1\)_0px_4px_24px\],.shadow-sm{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.outline{outline-style:solid}.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)}.blur{--tw-blur:blur(8px)}.blur,.drop-shadow{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)}.drop-shadow{--tw-drop-shadow:drop-shadow(0 1px 2px rgba(0,0,0,.1)) drop-shadow(0 1px 1px rgba(0,0,0,.06))}.invert{--tw-invert:invert(100%)}.filter,.invert{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)}.backdrop-blur-\[var\(--glass-blur\)\]{--tw-backdrop-blur:blur(var(--glass-blur))}.backdrop-blur-\[var\(--glass-blur\)\],.backdrop-filter{backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.\!transition-none{transition-property:none!important}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--bg-primary:#000;--bg-secondary:#0a0a16;--bg-card:hsla(0,0%,100%,.03);--card-surface:hsla(0,0%,4%,.756);--card-surface-strong:rgba(5,5,5,.8);--card-border:hsla(0,0%,100%,.069);--card-border-hover:hsla(0,0%,100%,.14);--purple-primary:#854ce6;--purple-light:#a855f7;--purple-dark:#6d28d9;--purple-glow:rgba(133,76,230,.3);--teal-accent:#20b2a6;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--accent-primary:#a78bfa;--accent-secondary:#818cf8;--border-subtle:hsla(0,0%,100%,.06);--border-purple:rgba(133,76,230,.3);--glass-bg:hsla(0,0%,100%,.04);--glass-border:hsla(0,0%,100%,.08);--glass-blur:20px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--font-primary:var(--font-inter),"Inter",-apple-system,BlinkMacSystemFont,sans-serif;--font-display:var(--font-instrument),"Instrument Serif",Georgia,serif;--transition-fast:0.2s cubic-bezier(0.4,0,0.2,1);--transition-smooth:0.35s cubic-bezier(0.4,0,0.2,1);--transition-spring:0.5s cubic-bezier(0.175,0.885,0.32,1.275)}*,:after,:before{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body,html{width:100%;overflow-x:clip}body{font-family:var(--font-primary);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6}a{color:inherit;text-decoration:none}button{border:none;cursor:pointer;font-family:inherit;background:none}input,select,textarea{font-family:inherit;outline:none}img{max-width:100%;display:block}::-webkit-scrollbar{display:none}body{-ms-overflow-style:none;scrollbar-width:none}::-moz-selection{background:rgba(133,76,230,.3);color:#fff}::selection{background:rgba(133,76,230,.3);color:#fff}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px rgba(133,76,230,.2)}50%{box-shadow:0 0 40px rgba(133,76,230,.4)}}@keyframes gradient-shift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}@keyframes slide-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes spin-slow{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes bubble-float{0%{transform:translateY(0) scale(1);opacity:.3}50%{opacity:.6}to{transform:translateY(-100vh) scale(.5);opacity:0}}.page-container{min-height:100vh;position:relative;overflow-x:clip}.page-container:before{content:"";position:fixed;inset:0;background: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.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;z-index:0}.section{position:relative;z-index:1;padding:100px 24px}.section-inner{max-width:1200px;margin:0 auto}.glass-card{background:var(--card-surface);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--card-border);border-radius:10px}@keyframes scroll-left{0%{transform:translateX(0)}to{transform:translateX(-50%)}}@keyframes scroll-right{0%{transform:translateX(-50%)}to{transform:translateX(0)}}.marquee-left{animation:scroll-left 45s linear infinite}.marquee-left:hover{animation-play-state:paused}.marquee-right{animation:scroll-right 45s linear infinite}.marquee-right:hover{animation-play-state:paused}@keyframes slow-drift{0%{transform:translateY(0) translateX(0) scale(1);opacity:.6}25%{transform:translateY(-30px) translateX(15px) scale(1.1);opacity:.8}50%{transform:translateY(-15px) translateX(-20px) scale(.9);opacity:.5}75%{transform:translateY(-40px) translateX(10px) scale(1.05);opacity:.7}to{transform:translateY(0) translateX(0) scale(1);opacity:.6}}.hero-bubble{animation:slow-drift ease-in-out infinite}@keyframes blink-dot{0%,to{opacity:1;box-shadow:0 0 6px #22c55e}50%{opacity:.3;box-shadow:none}}.blink-dot{animation:blink-dot 1.4s ease-in-out infinite}@keyframes float-badge{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.float-badge{animation:float-badge 3s ease-in-out infinite}@keyframes pulse-glow-aura{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.pulse-glow{animation:pulse-glow-aura 3s ease-in-out infinite}@media (max-width:900px){.section{padding:60px 20px}.section-inner{max-width:100%}.project-row{grid-template-columns:1fr!important;direction:ltr!important;gap:24px!important}}.blog-post-layout{display:flex;flex-direction:column;gap:64px;position:relative;align-items:stretch}.blog-content{flex:1;min-width:0;width:100%}.blog-sidebar{width:100%;flex-shrink:0;display:block;position:static;align-self:flex-start}@media (min-width:768px){.blog-post-layout{flex-direction:row;align-items:flex-start}.blog-content{max-width:calc(100% - 320px)}.blog-sidebar{width:280px;position:sticky;top:100px;max-height:calc(100vh - 120px);overflow:hidden;z-index:5}}@media (max-width:640px){.section{padding:40px 16px}.section-inner{max-width:100%}.project-row{grid-template-columns:1fr!important;direction:ltr!important;gap:20px!important}}.markdown-prose{color:var(--text-secondary);font-size:.95rem;line-height:1.8;font-family:var(--font-primary)}.markdown-prose h2,.markdown-prose h3,.markdown-prose h4,.markdown-prose h5,.markdown-prose h6{font-family:var(--font-heading);letter-spacing:-.01em}.markdown-prose h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-top:48px;margin-bottom:24px}.markdown-prose h3{font-size:1.25rem;font-weight:600;color:#dfdfe8;margin-top:32px;margin-bottom:16px}.markdown-prose p{margin-bottom:24px}.markdown-prose img{width:100%;height:auto;margin:32px 0;border:1px solid var(--border-subtle);border-radius:14px;background:hsla(0,0%,100%,.025)}.markdown-prose .project-brand-lockup{display:flex;align-items:center;gap:14px;margin-bottom:28px}.markdown-prose .project-brand-lockup .project-brand-icon{width:48px;height:48px;flex:0 0 48px;margin:0;padding:7px;border-radius:12px}.markdown-prose .project-brand-lockup div{display:flex;flex-direction:column;line-height:1.4}.markdown-prose .project-brand-lockup strong{color:var(--text-primary);font-size:1.1rem}.markdown-prose .project-brand-lockup span{color:var(--text-muted);font-size:.78rem}.markdown-prose .project-tech-stack{width:auto;max-width:100%;margin:24px 0 30px;padding:12px}.markdown-prose .project-screenshot-frame{width:100%;aspect-ratio:2000/1270;margin:32px 0;overflow:hidden;border:1px solid var(--border-subtle);border-radius:14px;background:hsla(0,0%,100%,.025)}.markdown-prose .project-screenshot-frame img{width:100%;height:100%;margin:0;border:0;border-radius:0;-o-object-fit:cover;object-fit:cover;-o-object-position:top;object-position:top}.markdown-prose a{color:var(--purple-primary);text-decoration:none;border-bottom:1px solid transparent;transition:border-color var(--transition-fast)}.markdown-prose a:hover{border-color:var(--purple-primary)}.markdown-prose ol,.markdown-prose ul{margin-left:24px;margin-bottom:24px}.markdown-prose li{margin-bottom:8px}.markdown-prose ul{list-style-type:disc}.markdown-prose ol{list-style-type:decimal}.markdown-prose blockquote{border-left:3px solid var(--purple-primary);padding:0 0 0 20px;font-style:italic;margin:28px 0;color:#a1a1aa;background:transparent}.markdown-prose code.inline-code{background:#1a1a1a;color:var(--purple-light);padding:2px 6px;border-radius:4px;font-family:Courier,monospace;font-size:.9em;border:1px solid #333}.markdown-prose .code-block-container{margin:32px 0;border-radius:12px;overflow:hidden;border:1px solid hsla(0,0%,100%,.08);background:#0b0b0f;box-shadow:0 4px 30px rgba(0,0,0,.4)}.markdown-prose .code-block-header,.markdown-prose .code-block-header-minimal{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;background:hsla(0,0%,100%,.02);border-bottom:1px solid hsla(0,0%,100%,.08);font-size:.75rem}.markdown-prose .code-block-filename{font-family:JetBrains Mono,monospace;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);padding:4px 10px;border-radius:6px;color:#e2e8f0}.markdown-prose .code-block-lang{font-family:JetBrains Mono,monospace;color:var(--text-muted);text-transform:uppercase;font-weight:500;letter-spacing:.05em}.markdown-prose .code-block-copy-btn{display:flex;align-items:center;gap:6px;background:transparent;color:var(--text-muted);font-size:.75rem;padding:4px 8px;border-radius:4px;transition:all var(--transition-fast)}.markdown-prose .code-block-copy-btn:hover{color:#fff;background:hsla(0,0%,100%,.05)}.markdown-prose .code-block-content pre{margin:0;padding:20px 0;overflow-x:auto;font-family:JetBrains Mono,monospace;font-size:.85rem;line-height:1.6;background-color:transparent!important}.markdown-prose .code-block-content code{display:block;width:-moz-max-content;width:max-content;min-width:100%}.markdown-prose .code-block-content .line{display:block;min-height:1.6rem;padding-left:20px;padding-right:20px}.markdown-prose .code-block-content .highlighted-line{background:hsla(0,0%,100%,.055)!important;border-left:4px solid var(--purple-primary);padding-left:16px}.blog-borders:after,.blog-borders:before{content:"";position:fixed;top:0;bottom:0;width:clamp(20px,5vw,80px);background:repeating-linear-gradient(-45deg,hsla(0,0%,100%,.03),hsla(0,0%,100%,.03) 1px,transparent 0,transparent 6px);z-index:1;pointer-events:none}.blog-borders:before{left:0;border-right:1px solid var(--border-subtle);background-color:#030303}.blog-borders:after{right:0;border-left:1px solid var(--border-subtle);background-color:#030303}@media (max-width:768px){body,html{max-width:100%;overflow-x:clip;overscroll-behavior-x:none;touch-action:pan-y}.page-container,.section,footer{width:100%;max-width:100%;overflow-x:clip}.blog-borders,.blog-borders:after,.blog-borders:before{display:none!important}}.blog-single-page{min-height:100vh;padding:0 clamp(24px,6vw,96px) 80px;max-width:1200px;margin:0 auto;position:relative;z-index:1}.blog-post-hero-img-wrap{width:100vw;max-width:100%;height:40vh;min-height:300px;position:relative;left:50%;transform:translateX(-50%);margin-bottom:60px;border-bottom:1px solid var(--border-subtle)}@media (max-width:768px){.project-toc-sidebar{display:none!important}.project-content-area{padding:20px 0 60px!important}}.blog-post-hero-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:.8;mask-image:linear-gradient(180deg,#000 50%,transparent);-webkit-mask-image:linear-gradient(180deg,#000 50%,transparent)}.blog-header{margin-bottom:60px;text-align:left;max-width:900px}.blog-header h1{font-family:Georgia,Times New Roman,Times,serif;font-size:clamp(2.5rem,4vw,3.5rem);font-weight:400;color:#fff;line-height:1.2;margin-bottom:16px;letter-spacing:-.02em}.blog-header-desc{font-size:1.125rem;color:var(--text-secondary);line-height:1.6;max-width:800px;margin-bottom:32px}.blog-header-meta{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);padding:16px 0;flex-wrap:wrap;gap:16px}.blog-author-info{display:flex;align-items:center;gap:12px}.blog-author-avatar{width:32px;height:32px;border-radius:50%;background:var(--purple-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.8rem}.blog-meta-text{font-family:monospace;font-size:.85rem;color:var(--text-muted);gap:12px}.blog-copy-btn,.blog-meta-text{display:flex;align-items:center}.blog-copy-btn{gap:8px;font-size:.8rem;color:var(--text-secondary);background:hsla(0,0%,100%,.05);border:1px solid var(--border-subtle);padding:6px 12px;border-radius:6px;cursor:pointer;transition:all var(--transition-fast)}.blog-copy-btn:hover{background:hsla(0,0%,100%,.1);color:#fff}.blog-master-page{min-height:100vh;padding:160px 0 60px;width:min(calc(100% - clamp(48px, 8vw, 120px)),1100px);margin:0 auto}.blog-hero{text-align:center;margin-bottom:60px}.blog-hero-top{font-family:monospace;font-size:.75rem;letter-spacing:.2em;color:var(--text-muted);text-transform:uppercase;margin-bottom:16px;display:block}.blog-hero-title{font-family:Georgia,Times New Roman,Times,serif;font-size:clamp(3rem,5vw,4.5rem);font-weight:400;color:#fff;letter-spacing:-.02em}.blog-hero-title-italic{font-style:italic;font-weight:300;background:linear-gradient(135deg,#ff4d9e,#ff8c42,#fc0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;padding-left:8px;position:relative}.blog-hero-title-italic:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:140%;height:140%;background:radial-gradient(circle,rgba(255,77,158,.15) 0,transparent 70%);z-index:-1;pointer-events:none}.blog-filter-bar{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-subtle);padding-bottom:24px;margin-bottom:40px;flex-wrap:nowrap;gap:12px}.blog-categories{display:flex;flex:1;min-width:0;gap:12px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.blog-categories::-webkit-scrollbar{display:none}.blog-category-btn{font-size:.76rem;color:var(--text-secondary);white-space:nowrap;transition:color var(--transition-fast)}.blog-category-btn:hover{color:#fff}.blog-category-btn.active{color:#fff;border-radius:999px}.blog-category-btn.active,.blog-search-container{background:var(--glass-bg);padding:6px 12px;border:1px solid var(--border-subtle)}.blog-search-container{display:flex;align-items:center;flex-shrink:0;border-radius:999px;gap:8px}.blog-search-input{background:transparent;border:none;color:#fff;font-size:.78rem;width:104px}.blog-search-input::-moz-placeholder{color:var(--text-muted)}.blog-search-input::placeholder{color:var(--text-muted)}.blog-cmd-k{display:flex;gap:4px}.blog-cmd-k kbd{background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.05);font-size:.65rem;padding:2px 6px;border-radius:4px;color:var(--text-muted);font-family:inherit}.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:32px;align-items:stretch}.blog-grid-card,.blog-preview-card{display:flex;flex-direction:column;width:100%;height:100%;min-height:520px;padding:16px;overflow:hidden;transition:transform var(--transition-smooth);cursor:pointer}.blog-grid-card-image-wrap,.blog-preview-image-wrap{width:100%;aspect-ratio:16/10.8;overflow:hidden;border-radius:18px;position:relative;background:hsla(0,0%,100%,.04)}.blog-grid-card-img,.blog-preview-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .6s cubic-bezier(.16,1,.3,1)}.blog-preview-body{display:flex;flex:1;flex-direction:column;padding:22px 8px 0}.blog-preview-meta{display:flex;align-items:center;gap:10px;color:hsla(0,0%,100%,.48);font-family:Space Mono,Courier New,monospace;font-size:.75rem;font-weight:700;letter-spacing:.12em;line-height:1.4;text-transform:uppercase;margin-bottom:18px}.blog-grid-card-title,.blog-preview-title{font-family:var(--font-primary);font-size:clamp(.75rem,2vw,1.25rem);font-weight:500;color:var(--text-primary);line-height:1.22;margin:0 0 18px;letter-spacing:0}.blog-grid-card-desc,.blog-preview-desc{font-size:clamp(.5rem,1.3vw,.85rem);color:hsla(0,0%,100%,.56);line-height:1.75;margin:0;flex:1}.blog-preview-action{display:flex;align-items:center;justify-content:flex-end;gap:10px;margin-top:auto;padding-top:34px;color:hsla(0,0%,100%,.72);font-size:.82rem;font-weight:600}.blog-preview-action-icon{width:30px;height:30px;border-radius:9px;border:1px solid hsla(0,0%,100%,.12);background:hsla(0,0%,100%,.06);display:inline-flex;align-items:center;justify-content:center;color:#fff}@media (max-width:640px){.blog-grid-card,.blog-preview-card{min-height:460px;padding:12px}.blog-preview-body{padding:18px 4px 0}.blog-preview-meta{font-size:.68rem;gap:8px;letter-spacing:.08em;margin-bottom:14px}.blog-grid-card-title,.blog-preview-title{font-size:1.3rem}.blog-grid-card-desc,.blog-preview-desc{font-size:.92rem;line-height:1.65}.blog-preview-action{font-size:.78rem;padding-top:24px}.blog-preview-action-icon{width:28px;height:28px;border-radius:8px}}.toc-container{position:relative;max-height:inherit;overflow-y:auto;scrollbar-width:none;padding-right:16px}.toc-container::-webkit-scrollbar{display:none}.toc-title{font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:12px}.toc-wrapper{position:relative;padding-left:20px}.toc-list{display:flex;flex-direction:column;gap:0;list-style:none;margin:0;padding:0}.toc-item{padding:6px 0;transition:background var(--transition-fast)}.toc-item[data-level="2"]{margin-top:16px;margin-bottom:4px}.toc-item[data-level="3"]{padding-left:12px}.toc-link{display:flex;align-items:center;font-size:.85rem;color:var(--text-muted);transition:color var(--transition-fast);line-height:1;height:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.toc-link.active{color:#fff}.gear-container{width:100%;max-width:1200px;margin:0 auto;padding:120px 24px;color:var(--text-primary)}.gear-hero{text-align:center;margin-bottom:120px}.gear-hero-top{font-family:monospace;font-size:.75rem;letter-spacing:.3em;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px;display:block}.gear-hero-title{font-family:Georgia,Times New Roman,Times,serif;font-size:clamp(2rem,4vw,3.5rem);font-weight:400;color:#fff;line-height:1.1}.gear-hero-italic{font-style:italic;font-weight:300;display:inline-block;background:linear-gradient(135deg,#ff4d9e,#854ce6);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.gear-section{display:grid;grid-template-columns:240px 1px 1fr;gap:0;border-top:1px solid var(--border-subtle);position:relative}.gear-sidebar{padding:40px 0;position:sticky;top:100px;height:-moz-fit-content;height:fit-content}.gear-num{font-family:monospace;font-size:.75rem;color:var(--text-muted);display:block;margin-bottom:8px}.gear-side-title{font-family:Georgia,Times New Roman,Times,serif;font-size:1.75rem;font-weight:400;color:#fff;margin-bottom:12px}.gear-side-desc{font-size:.85rem;color:var(--text-muted);line-height:1.5;max-width:180px}.gear-divider{background:repeating-linear-gradient(to bottom,var(--border-subtle),var(--border-subtle) 4px,transparent 4px,transparent 8px);width:1px}.gear-content{padding:40px 40px 100px}.workstation-card{background:#000;border:1px solid var(--border-subtle);border-radius:12px;overflow:hidden;margin-bottom:32px;transition:border-color .3s ease}.workstation-card:hover{border-color:hsla(0,0%,100%,.2)}.workstation-img-wrap{width:100%;aspect-ratio:16/9;background:#0a0a0a;display:flex;align-items:center;justify-content:center}.workstation-img{width:80%;height:auto;-o-object-fit:contain;object-fit:contain}.workstation-info{padding:24px;display:flex;justify-content:space-between;align-items:flex-end}.workstation-name{font-family:Space Grotesk,sans-serif;font-size:1.1rem;font-weight:600;color:#fff;margin-bottom:4px}.workstation-specs{font-size:.75rem;letter-spacing:.05em}.workstation-specs,.workstation-tag{font-family:monospace;color:var(--text-muted);text-transform:uppercase}.workstation-tag{background:hsla(0,0%,100%,.05);border:1px solid var(--border-subtle);padding:4px 12px;border-radius:999px;font-size:.65rem}.tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:48px;padding-top:20px}.tool-item{flex-direction:column;gap:16px;text-align:center}.tool-icon-wrap,.tool-item{display:flex;align-items:center}.tool-icon-wrap{width:56px;height:56px;background:#000;border:1px solid var(--border-subtle);border-radius:12px;justify-content:center;position:relative;transition:transform .3s ease}.tool-item:hover .tool-icon-wrap{transform:translateY(-4px);border-color:var(--purple-primary)}.tool-icon{width:32px;height:32px;-o-object-fit:contain;object-fit:contain}.tool-name{font-size:.85rem;color:var(--text-muted);font-family:Inter,sans-serif}@media (max-width:768px){.gear-section{grid-template-columns:1fr}.gear-sidebar{position:static;padding-bottom:0}.gear-divider{display:none}.gear-content{padding:32px 0}.gear-side-desc{max-width:100%}.tool-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:32px}}.liquid-glass{background:hsla(0,0%,100%,.01);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);box-shadow:inset 0 1px 1px hsla(0,0%,100%,.1);position:relative}.liquid-glass:before{content:"";position:absolute;inset:0;padding:1.4px;border-radius:inherit;background:linear-gradient(180deg,hsla(0,0%,100%,.15),hsla(0,0%,100%,0));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.hover\:\!border-\[var\(--card-border\)\]:hover{border-color:var(--card-border)!important}.hover\:\!border-white\/25:hover{border-color:hsla(0,0%,100%,.25)!important}.hover\:border-\[var\(--card-border-hover\)\]:hover{border-color:var(--card-border-hover)}.hover\:border-white\/25:hover{border-color:hsla(0,0%,100%,.25)}.hover\:\!bg-white\/\[0\.06\]:hover{background-color:hsla(0,0%,100%,.06)!important}.hover\:bg-white\/90:hover{background-color:hsla(0,0%,100%,.9)}.hover\:bg-white\/\[0\.06\]:hover{background-color:hsla(0,0%,100%,.06)}.hover\:bg-white\/\[0\.08\]:hover{background-color:hsla(0,0%,100%,.08)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-50:disabled{opacity:.5}.group\/bento:hover .group-hover\/bento\:translate-x-2{--tw-translate-x:0.5rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@media (min-width:768px){.md\:col-span-1{grid-column:span 1/span 1}.md\:col-span-2{grid-column:span 2/span 2}.md\:auto-rows-\[20rem\]{grid-auto-rows:20rem}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:text-5xl{font-size:3rem;line-height:1}.md\:text-lg{font-size:1.125rem;line-height:1.75rem}}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/ba9851c3c22cd980-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/21350d82a1f187e9-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Inter_Fallback_f367f3;src:local("Arial");ascent-override:90.49%;descent-override:22.56%;line-gap-override:0.00%;size-adjust:107.06%}.__className_f367f3{font-family:__Inter_f367f3,__Inter_Fallback_f367f3;font-style:normal}.__variable_f367f3{--font-inter:"__Inter_f367f3","__Inter_Fallback_f367f3"}@font-face{font-family:"__Instrument_Serif_1f5468";font-style:italic;font-weight:400;font-display:swap;src:url(/_next/static/media/5ece437c7024c161-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:"__Instrument_Serif_1f5468";font-style:italic;font-weight:400;font-display:swap;src:url(/_next/static/media/9cc5b37ab1350db7-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:"__Instrument_Serif_1f5468";font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/35f3de0ebb1cfc70-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:"__Instrument_Serif_1f5468";font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/e6099e249fd938cc-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:"__Instrument_Serif_Fallback_1f5468";src:local("Times New Roman");ascent-override:117.94%;descent-override:36.93%;line-gap-override:0.00%;size-adjust:83.94%}.__className_1f5468{font-family:"__Instrument_Serif_1f5468","__Instrument_Serif_Fallback_1f5468";font-weight:400}.__variable_1f5468{--font-instrument:"__Instrument_Serif_1f5468","__Instrument_Serif_Fallback_1f5468"}