@import "https://fonts.googleapis.com/css2?family=Fira+Code:wght@300..700&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Syne:wght@400;500;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;1,9..40,300&display=swap";*,:before,:after,::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:#3b82f680;--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: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}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{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family: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:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-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,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.-top-20{top:-5rem}.left-1\/2{left:50%}.right-4{right:1rem}.top-1\/2{top:50%}.z-10{z-index:10}.z-50{z-index:50}.mb-12{margin-bottom:3rem}.mb-6{margin-bottom:1.5rem}.mr-3{margin-right:.75rem}.block{display:block}.flex{display:flex}.hidden{display:none}.h-3{height:.75rem}.h-5{height:1.25rem}.h-screen{height:100vh}.max-h-\[60vh\]{max-height:60vh}.w-3{width:.75rem}.w-5{width:1.25rem}.w-full{width:100%}.w-screen{width:100vw}.max-w-2xl{max-width:42rem}.-translate-x-1\/2{--tw-translate-x:-50%;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))}.-translate-y-1\/2{--tw-translate-y:-50%;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))}.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))}@keyframes bounce{0%,to{animation-timing-function:cubic-bezier(.8,0,1,1);transform:translateY(-25%)}50%{animation-timing-function:cubic-bezier(0,0,.2,1);transform:none}}.animate-bounce{animation:1s infinite bounce}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.cursor-pointer{cursor:pointer}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:.5rem}.gap-4{gap:1rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.border{border-width:1px}.border-0{border-width:0}.border-b{border-bottom-width:1px}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.border-white\/30{border-color:#ffffff4d}.bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity,1))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.bg-transparent{background-color:#0000}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-white\/10{background-color:#ffffff1a}.bg-opacity-50{--tw-bg-opacity:.5}.bg-gradient-to-br{background-image:linear-gradient(to bottom right, var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right, var(--tw-gradient-stops))}.from-indigo-950{--tw-gradient-from:#1e1b4b var(--tw-gradient-from-position);--tw-gradient-to:#1e1b4b00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-slate-900{--tw-gradient-from:#0f172a var(--tw-gradient-from-position);--tw-gradient-to:#0f172a00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.from-yellow-300{--tw-gradient-from:#fde047 var(--tw-gradient-from-position);--tw-gradient-to:#fde04700 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), var(--tw-gradient-to)}.via-pink-400{--tw-gradient-to:#f472b600 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), #f472b6 var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-purple-900{--tw-gradient-to:#581c8700 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from), #581c87 var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-cyan-400{--tw-gradient-to:#22d3ee var(--tw-gradient-to-position)}.to-pink-900{--tw-gradient-to:#831843 var(--tw-gradient-to-position)}.to-slate-900{--tw-gradient-to:#0f172a var(--tw-gradient-to-position)}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pt-20{padding-top:5rem}.text-center{text-align:center}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-6xl{font-size:3.75rem;line-height:1}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.font-extrabold{font-weight:800}.font-light{font-weight:300}.font-semibold{font-weight:600}.tracking-wide{letter-spacing:.025em}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-transparent{color:#0000}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-white\/90{color:#ffffffe6}.shadow-xl{--tw-shadow:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.outline-none{outline-offset:2px;outline:2px solid #0000}.ring-2{--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(2px + 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)}.ring-blue-500{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.\!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)!important}.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)}.backdrop-blur-md{--tw-backdrop-blur:blur(12px);-webkit-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);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)}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px);-webkit-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);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-all{transition-property:all;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-property:transform;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-300{transition-duration:.3s}:root{--p-primary-color:#22bbf2;--border-color:#ffffff26;--hover-color:#ffffff26}*,:before,:after{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100vh;margin:0;padding:0;font-family:Fira Code,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;transition:background-color .3s,color .3s}body #root{height:100vh}.hover\:scale-105:hover{--tw-scale-x:1.05;--tw-scale-y:1.05;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))}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.hover\:bg-white\/20:hover{background-color:#fff3}.hover\:shadow-lg:hover{--tw-shadow:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -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)}.hover\:shadow-purple-500\/30:hover{--tw-shadow-color:#a855f74d;--tw-shadow:var(--tw-shadow-colored)}.focus\:border-blue-500:focus{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.focus\:outline-none:focus{outline-offset:2px;outline:2px solid #0000}.focus\:ring-0:focus{--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(0px + 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)}.focus\:ring-2:focus{--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(2px + 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)}.focus\:ring-purple-400:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(192 132 252/var(--tw-ring-opacity,1))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.focus\:ring-offset-transparent:focus{--tw-ring-offset-color:transparent}.group:hover .group-hover\:translate-x-1{--tw-translate-x:.25rem;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))}.dark\:border-gray-800:is(.dark *){--tw-border-opacity:1;border-color:rgb(31 41 55/var(--tw-border-opacity,1))}.dark\:bg-gray-800:is(.dark *){--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity,1))}.dark\:bg-gray-900:is(.dark *){--tw-bg-opacity:1;background-color:rgb(17 24 39/var(--tw-bg-opacity,1))}.dark\:text-gray-400:is(.dark *){--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.dark\:hover\:bg-gray-800:hover:is(.dark *){--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity,1))}.dark\:focus\:border-blue-400:focus:is(.dark *){--tw-border-opacity:1;border-color:rgb(96 165 250/var(--tw-border-opacity,1))}@media (width>=768px){.md\:text-2xl{font-size:1.5rem;line-height:2rem}.md\:text-5xl{font-size:3rem;line-height:1}.md\:text-7xl{font-size:4.5rem;line-height:1}}@media (width>=1024px){.lg\:text-3xl{font-size:1.875rem;line-height:2.25rem}.lg\:text-8xl{font-size:6rem;line-height:1}}a{color:inherit;text-decoration:none}a:hover{color:var(--p-primary-color);text-decoration:underline}p{margin:0 0 1.5em;line-height:1.6}:root{--portfolio-bg:#f6f5ef;--portfolio-surface:#0c0c110b;--portfolio-surface-strong:#0c0c1113;--portfolio-text:#111116;--portfolio-muted:#626268;--portfolio-faint:#9a9aa0;--portfolio-line:#0c0c111a;--portfolio-acid:#22bbf2;--portfolio-acid-strong:#0e9bd6;--portfolio-blue:#0ea5e9}:root.dark{--portfolio-bg:#0a0a0f;--portfolio-surface:#ffffff09;--portfolio-surface-strong:#fff1;--portfolio-text:#f0f0ee;--portfolio-muted:#8e8e92;--portfolio-faint:#4c4c52;--portfolio-line:#ffffff13;--portfolio-acid:#22bbf2;--portfolio-acid-strong:#0e9bd6;--portfolio-blue:#38bdf8}html{scroll-behavior:smooth}body{background:var(--portfolio-bg)}body:has(.portfolio-page-shell){height:auto;min-height:100vh}#root:has(.portfolio-page-shell){height:auto;min-height:100vh}.portfolio-page-shell{min-height:100vh;color:var(--portfolio-text);background:radial-gradient(circle at 92% 5%, #22bbf221, transparent 32rem), radial-gradient(circle at 4% 28%, #38bdf81a, transparent 28rem), var(--portfolio-bg);font-family:DM Sans,sans-serif;transition:background .25s,color .25s;overflow-x:hidden}.portfolio-page-shell *{box-sizing:border-box}.portfolio-page-shell button,.portfolio-page-shell a{font:inherit}.portfolio-page-shell button{cursor:pointer}.portfolio-page-shell img{max-width:100%;display:block}.portfolio-page-shell ::selection{background:var(--portfolio-acid);color:#0a0a0f}.portfolio-page-shell::-webkit-scrollbar{width:3px}.portfolio-page-shell::-webkit-scrollbar-thumb{background:var(--portfolio-acid);border-radius:2px}.portfolio-nav{z-index:40;border-bottom:1px solid var(--portfolio-line);background:color-mix(in srgb, var(--portfolio-bg) 84%, transparent);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);justify-content:space-between;align-items:center;gap:1.25rem;padding:1rem clamp(1rem,4vw,3.75rem);display:flex;position:fixed;top:0;left:0;right:0}.portfolio-logo{color:var(--portfolio-acid);letter-spacing:.14em;background:0 0;border:0;font-family:Bebas Neue,sans-serif;font-size:1.7rem;line-height:1}.portfolio-nav__links,.portfolio-nav__actions{align-items:center;gap:clamp(.6rem,2vw,1.8rem);display:flex}.portfolio-nav__link,.portfolio-footer button:not(.portfolio-logo){color:var(--portfolio-faint);letter-spacing:.1em;text-transform:uppercase;background:0 0;border:0;border-bottom:1px solid #0000;font-family:Syne,sans-serif;font-size:.72rem;font-weight:700;transition:border-color .2s,color .2s}.portfolio-nav__link:hover,.portfolio-nav__link.is-active,.portfolio-footer button:not(.portfolio-logo):hover{border-color:var(--portfolio-acid);color:var(--portfolio-acid)}.button{letter-spacing:.04em;border:1px solid #0000;border-radius:.45rem;justify-content:center;align-items:center;gap:.55rem;min-height:3rem;padding:.85rem 1.55rem;font-family:Syne,sans-serif;font-size:.82rem;font-weight:800;text-decoration:none;transition:border-color .2s,box-shadow .2s,color .2s,transform .2s;display:inline-flex}.button:hover{text-decoration:none;transform:translateY(-2px)}.button--acid{background:var(--portfolio-acid);color:#0a0a0f}.button--acid:hover{color:#0a0a0f;box-shadow:0 12px 36px #22bbf23d}:root.dark .button--acid:hover{box-shadow:0 12px 40px #22bbf257}.button--outline{border-color:var(--portfolio-line);color:var(--portfolio-text);background:0 0}.button--outline:hover{border-color:var(--portfolio-acid);color:var(--portfolio-acid)}.icon-button{border:1px solid var(--portfolio-line);background:var(--portfolio-surface);width:3rem;height:3rem;color:var(--portfolio-muted);border-radius:.75rem;justify-content:center;align-items:center;text-decoration:none;transition:background .2s,border-color .2s,color .2s,transform .2s;display:inline-flex}.icon-button:hover{border-color:var(--portfolio-acid);color:var(--portfolio-acid);background:#22bbf214;transform:translateY(-2px)}.section{width:min(100%,1240px);margin:0 auto;padding:clamp(5rem,10vw,7.5rem) clamp(1rem,4vw,3.75rem)}.section--wide{width:min(100%,1320px)}.section--narrow{width:min(100%,980px)}.section-label{color:var(--portfolio-acid);letter-spacing:.22em;text-transform:uppercase;font-family:Syne,sans-serif;font-size:.72rem;font-weight:800}.section h2,.about-section h2{color:var(--portfolio-text);margin:1rem 0 3.6rem;font-family:Syne,sans-serif;font-size:clamp(2.25rem,4vw,3rem);font-weight:800;line-height:1.16}.hero-section{flex-direction:column;justify-content:center;min-height:100vh;padding:8.5rem clamp(1rem,4vw,3.75rem) 5.5rem;display:flex;position:relative;overflow:hidden}.grid-bg{pointer-events:none;opacity:.35;background-size:72px 72px;position:absolute;inset:0}.hero-section__orb{aspect-ratio:1;pointer-events:none;filter:blur(2px);border-radius:50%;width:min(52vw,760px);animation:10s ease-in-out infinite floatBlob;position:absolute}.hero-section__orb--green{background:radial-gradient(circle,#22bbf221,#0000 68%);top:-15%;right:-8%}.hero-section__orb--blue{background:radial-gradient(circle,#38bdf81c,#0000 68%);animation-duration:13s;animation-direction:reverse;bottom:-24%;left:-8%}.hero-section__status,.hero-section__name,.hero-section__intro,.hero-section__actions,.hero-section__meta{z-index:1;position:relative}.hero-section__status{align-items:center;gap:.7rem;animation:.8s .1s both fadeUp;display:flex}.status-dot{background:var(--portfolio-acid);border-radius:50%;width:.5rem;height:.5rem;animation:2s infinite blink;box-shadow:0 0 .8rem #22bbf299}.hero-section__name{margin-top:1.8rem;animation:.9s .25s both fadeUp}.hero-section__name h1{color:var(--portfolio-text);letter-spacing:0;margin:0;font-family:Bebas Neue,sans-serif;font-size:clamp(5rem,13vw,12rem);line-height:.9}.hero-section__surname-row{align-items:flex-end;gap:clamp(1rem,3vw,1.8rem);display:flex}.hero-section__surname-row h1{color:var(--portfolio-acid)}.hero-section__surname-row p{min-height:2.25rem;color:var(--portfolio-muted);margin:0 0 .9rem;font-family:Syne,sans-serif;font-size:clamp(1.1rem,2.2vw,1.4rem);animation:2.8s ease-in-out both roleIn}.hero-section__intro{width:min(100%,540px);color:var(--portfolio-muted);margin:2.2rem 0 0;font-size:1.06rem;line-height:1.75;animation:.9s .45s both fadeUp}.hero-section__intro strong{color:var(--portfolio-text)}.hero-section__actions{flex-wrap:wrap;gap:.9rem;margin-top:2.75rem;animation:.9s .6s both fadeUp;display:flex}.hero-section__meta{color:var(--portfolio-faint);flex-wrap:wrap;gap:.8rem 1.5rem;margin-top:3.6rem;font-size:.86rem;animation:.9s .75s both fadeUp;display:flex}.hero-section__meta span{align-items:center;gap:.5rem;display:inline-flex}.hero-section__meta svg{color:var(--portfolio-acid)}.hero-section__scroll{z-index:1;color:var(--portfolio-faint);letter-spacing:.14em;text-transform:uppercase;background:0 0;border:0;flex-direction:column;align-items:center;gap:.35rem;font-family:Syne,sans-serif;font-size:.66rem;display:flex;position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%)}.hero-section__scroll svg{animation:1.5s infinite blink}.stat-grid{border:1px solid var(--portfolio-line);background:var(--portfolio-surface);border-radius:.8rem;grid-template-columns:repeat(3,1fr);margin-bottom:clamp(4rem,8vw,6.3rem);display:grid;overflow:hidden}.stat-card{text-align:center;place-items:center;padding:clamp(2.2rem,5vw,3.3rem) 1.25rem;display:grid}.stat-card+.stat-card{border-left:1px solid var(--portfolio-line)}.stat-card strong{color:var(--portfolio-acid);font-family:Bebas Neue,sans-serif;font-size:clamp(3.8rem,8vw,5rem);font-weight:400;line-height:1}.stat-card span{color:var(--portfolio-faint);letter-spacing:.1em;text-transform:uppercase;margin-top:.7rem;font-family:Syne,sans-serif;font-size:.76rem;font-weight:700}.about-section__content{grid-template-columns:minmax(0,1fr) minmax(280px,1fr);align-items:center;gap:clamp(3rem,8vw,6.25rem);display:grid}.about-section h2{margin-bottom:1.6rem}.about-section h2 em{color:var(--portfolio-acid);font-style:italic}.about-section p{max-width:62ch;color:var(--portfolio-muted);font-size:1rem;line-height:1.85}.about-section p strong{color:var(--portfolio-text)}.about-section__facts{flex-wrap:wrap;gap:.9rem;margin-top:2.25rem;display:flex}.about-section__facts div{border:1px solid var(--portfolio-line);background:var(--portfolio-surface);border-radius:.65rem;min-width:10.5rem;padding:.8rem 1.2rem}.about-section__facts div:first-child{background:#22bbf214;border-color:#22bbf233}.about-section__facts span{color:var(--portfolio-faint);letter-spacing:.1em;text-transform:uppercase;font-family:Syne,sans-serif;font-size:.68rem;font-weight:800;display:block}.about-section__facts strong{color:var(--portfolio-text);margin-top:.25rem;font-family:Syne,sans-serif;font-size:.94rem;display:block}.about-section__facts div:first-child strong{color:var(--portfolio-acid)}.skill-bars{gap:1.35rem;display:grid}.skill-bar__label{color:var(--portfolio-text);justify-content:space-between;gap:1rem;margin-bottom:.55rem;font-family:Syne,sans-serif;font-size:.9rem;font-weight:700;display:flex}.skill-bar__label span:last-child{color:var(--portfolio-faint);font-family:DM Sans,sans-serif;font-weight:500}.skill-bar__track{border-radius:1rem;height:.22rem;overflow:hidden}.skill-bar__track span{border-radius:inherit;background:linear-gradient(90deg, var(--portfolio-acid), var(--portfolio-acid-strong));height:100%;transition:width 1.4s cubic-bezier(.22,1,.36,1);display:block}.tech-marquee{border-top:1px solid var(--portfolio-line);border-bottom:1px solid var(--portfolio-line);padding:1.6rem 0;overflow:hidden}.tech-marquee div{white-space:nowrap;width:max-content;animation:28s linear infinite marquee;display:flex}.tech-marquee span{color:var(--portfolio-faint);align-items:center;gap:1.4rem;padding:0 2.25rem;font-family:Syne,sans-serif;font-size:1.05rem;font-weight:800;display:inline-flex}.tech-marquee span:nth-child(4n+1){color:var(--portfolio-acid)}.tech-marquee i{color:var(--portfolio-line);font-style:normal}.skills-grid,.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem;display:grid}.glass-card{border:1px solid var(--portfolio-line);background:var(--portfolio-surface);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:.8rem}.skill-card{padding:clamp(1.4rem,4vw,2.25rem)}.skill-card__heading{align-items:center;gap:1rem;margin-bottom:1.75rem;display:flex}.skill-card__heading span{border-radius:.85rem;justify-content:center;align-items:center;width:3rem;height:3rem;display:inline-flex}.skill-card h3,.timeline h3,.project-card h3{color:var(--portfolio-text);margin:0;font-family:Syne,sans-serif;font-size:1.18rem;font-weight:800}.pill-list{flex-wrap:wrap;gap:.5rem;display:flex}.pill{border:1px solid var(--portfolio-line);background:var(--portfolio-surface);color:var(--portfolio-muted);border-radius:999px;padding:.45rem .9rem;font-size:.82rem;transition:border-color .2s,color .2s,background .2s;display:inline-flex}.pill:hover{color:var(--portfolio-acid);background:#22bbf217;border-color:#22bbf259}.timeline{gap:3.2rem;max-width:760px;display:grid}.timeline__item{border-left:2px solid #22bbf247;grid-template-columns:1fr auto;gap:.75rem 1.5rem;padding-left:1.75rem;display:grid;position:relative}.timeline__item:before{content:"";background:var(--portfolio-acid);border-radius:50%;width:.78rem;height:.78rem;position:absolute;top:.32rem;left:-.45rem;box-shadow:0 0 1rem #22bbf28c}.timeline__item span{color:var(--portfolio-acid);margin-top:.25rem;font-family:Syne,sans-serif;font-size:.88rem;font-weight:800;display:inline-block}.timeline__item time{color:var(--portfolio-faint);white-space:nowrap;font-family:Syne,sans-serif;font-size:.82rem}.timeline__item p{color:var(--portfolio-muted);grid-column:1/-1;margin:0;font-size:.96rem;line-height:1.75}.projects-section{border-top:1px solid var(--portfolio-line);background:var(--portfolio-surface);width:100%;max-width:none}.projects-section>*{width:min(100%,1240px);margin-left:auto;margin-right:auto}.section-heading-row{justify-content:space-between;align-items:flex-end;gap:1.5rem;margin-bottom:3.8rem;display:flex}.section-heading-row h2{margin-bottom:0}.section-heading-row>span{color:var(--portfolio-faint);font-family:Syne,sans-serif;font-size:.88rem}.project-card{border:1px solid var(--portfolio-line);background:color-mix(in srgb, var(--portfolio-bg) 84%, transparent);border-radius:.8rem;transition:border-color .25s,transform .25s;overflow:hidden}.project-card:hover{border-color:color-mix(in srgb, var(--project-color), transparent 45%);transform:translateY(-4px)}.project-card__image{aspect-ratio:16/9;border-bottom:1px solid var(--portfolio-line);background:var(--portfolio-surface-strong);overflow:hidden}.project-card__image img{object-fit:cover;width:100%;height:100%;transition:transform .45s}.project-card:hover .project-card__image img{transform:scale(1.04)}.project-card__body{padding:clamp(1.35rem,4vw,2rem);position:relative}.project-card__body:before{content:"";background:var(--project-color);opacity:0;height:2px;transition:opacity .25s;position:absolute;top:0;left:0;right:0}.project-card:hover .project-card__body:before{opacity:1}.project-card__topline{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.project-card__topline>span{color:color-mix(in srgb, var(--project-color), transparent 48%);font-family:Bebas Neue,sans-serif;font-size:3.1rem;line-height:1}.project-card__category{color:var(--project-color);letter-spacing:.13em;text-transform:uppercase;margin:0 0 .4rem;font-family:Syne,sans-serif;font-size:.7rem;font-weight:800}.project-card__body>p:not(.project-card__category){color:var(--portfolio-muted);font-size:.93rem;line-height:1.72}.project-card__tech{flex-wrap:wrap;gap:.5rem;margin-top:1.45rem;display:flex}.project-card__tech span{border:1px solid color-mix(in srgb, var(--project-color), transparent 70%);background:color-mix(in srgb, var(--project-color), transparent 92%);color:var(--project-color);letter-spacing:.06em;border-radius:999px;padding:.35rem .75rem;font-family:Syne,sans-serif;font-size:.68rem;font-weight:800}.contact-section{text-align:center;padding:clamp(6rem,12vw,8.75rem) clamp(1rem,4vw,3.75rem);position:relative;overflow:hidden}.contact-section__watermark{color:var(--portfolio-surface-strong);letter-spacing:.06em;pointer-events:none;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-family:Bebas Neue,sans-serif;font-size:clamp(6rem,18vw,16rem);display:flex;position:absolute;inset:0}.contact-section__glow{aspect-ratio:1;pointer-events:none;background:radial-gradient(circle,#22bbf214,#0000 65%);border-radius:50%;width:min(80vw,600px);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.contact-section__content{width:min(100%,700px);margin:0 auto;position:relative}.contact-section h2{color:var(--portfolio-text);letter-spacing:0;margin:1.4rem 0 1.75rem;font-family:Bebas Neue,sans-serif;font-size:clamp(4rem,9vw,7rem);font-weight:400;line-height:.95}.contact-section h2 strong{color:var(--portfolio-acid);font-weight:400}.contact-section p{color:var(--portfolio-muted);margin:0 auto 3.1rem;font-size:1.06rem;line-height:1.8}.contact-section__actions,.contact-section__socials{flex-wrap:wrap;justify-content:center;gap:.9rem;display:flex}.contact-section__socials{margin-top:3.8rem}.portfolio-footer{border-top:1px solid var(--portfolio-line);justify-content:space-between;align-items:center;gap:1.25rem;padding:1.5rem clamp(1rem,4vw,3.75rem);display:flex}.portfolio-footer span{color:var(--portfolio-faint);font-size:.86rem}.portfolio-footer div{flex-wrap:wrap;justify-content:flex-end;gap:1.2rem;display:flex}@keyframes floatBlob{0%,to{transform:translate(0)scale(1)}35%{transform:translate(48px,-54px)scale(1.08)}70%{transform:translate(-38px,34px)scale(.92)}}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(36px)}to{opacity:1;transform:translateY(0)}}@keyframes roleIn{0%{opacity:0;transform:translateY(16px)}20%,80%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-16px)}}@keyframes blink{0%,to{opacity:.55}50%{opacity:1}}@media (width<=980px){.portfolio-nav{align-items:flex-start}.portfolio-nav__links{display:none}.about-section__content,.skills-grid,.projects-grid{grid-template-columns:1fr}.portfolio-footer{flex-direction:column;align-items:flex-start}.portfolio-footer div{justify-content:flex-start}}@media (width<=720px){.portfolio-nav__hire{display:none}.hero-section{min-height:100svh}.hero-section__scroll{display:none}.stat-grid{grid-template-columns:1fr}.stat-card+.stat-card{border-top:1px solid var(--portfolio-line);border-left:0}.timeline__item{grid-template-columns:1fr}.timeline__item time{white-space:normal}.section-heading-row{flex-direction:column;align-items:flex-start}}@media (prefers-reduced-motion:reduce){.portfolio-page-shell *,.portfolio-page-shell :before,.portfolio-page-shell :after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
