*,: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.18 | 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;-o-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{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{color:inherit;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}}@media (min-width:1600px){.container{max-width:1600px}}.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}.-bottom-2{bottom:-.5rem}.bottom-4{bottom:1rem}.left-0{left:0}.left-1\/2{left:50%}.right-10{right:2.5rem}.right-2{right:.5rem}.right-4{right:1rem}.right-6{right:1.5rem}.top-0{top:0}.top-1\/2{top:50%}.top-10{top:2.5rem}.top-2{top:.5rem}.-z-10{z-index:-10}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-50{z-index:50}.z-\[10000\]{z-index:10000}.z-\[20\]{z-index:20}.z-\[9999\]{z-index:9999}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-10{margin-bottom:2.5rem}.mb-14{margin-bottom:3.5rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mr-20{margin-right:5rem}.mr-4{margin-right:1rem}.mt-10{margin-top:2.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.block{display:block}.flex{display:flex}.hidden{display:none}.aspect-square{aspect-ratio:1/1}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-20{height:5rem}.h-48{height:12rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-80{height:20rem}.h-\[4px\]{height:4px}.h-full{height:100%}.h-screen{height:100vh}.max-h-20{max-height:5rem}.max-h-\[95vh\]{max-height:95vh}.min-h-\[400px\]{min-height:400px}.min-h-screen{min-height:100vh}.w-16{width:4rem}.w-20{width:5rem}.w-28{width:7rem}.w-6{width:1.5rem}.w-80{width:20rem}.w-\[calc\(100\%-2rem\)\]{width:calc(100% - 2rem)}.w-full{width:100%}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-\[1100px\]{max-width:1100px}.max-w-\[32rem\]{max-width:32rem}.max-w-xl{max-width:36rem}.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-16,.-translate-x-1\/2{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-x-16{--tw-translate-x:-4rem}.-translate-y-1\/2{--tw-translate-y:-50%}.-translate-y-1\/2,.translate-x-0{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-x-0{--tw-translate-x:0px}.translate-x-16{--tw-translate-x:4rem}.-rotate-45,.translate-x-16{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))}.-rotate-45{--tw-rotate:-45deg}.rotate-45{--tw-rotate:45deg}.rotate-45,.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))}.animate-pulse{animation:pulse var(--tw-animate-duration,2s) var(--tw-animate-easing,cubic-bezier(.4,0,.6,1)) var(--tw-animate-delay,0s) var(--tw-animate-iteration,infinite) var(--tw-animate-fill,none)}@keyframes spin{to{transform:rotate(1turn)}}.animate-spin{animation:spin var(--tw-animate-duration,1s) var(--tw-animate-easing,linear) var(--tw-animate-delay,0s) var(--tw-animate-iteration,infinite) var(--tw-animate-fill,none)}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.resize{resize:both}.scroll-mt-4{scroll-margin-top:1rem}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-10{gap:2.5rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-y-auto{overflow-y:auto}.rounded-3xl{border-radius:1.5rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-sm{border-radius:.125rem}.rounded-xl{border-radius:.75rem}.rounded-b-xl{border-bottom-right-radius:.75rem;border-bottom-left-radius:.75rem}.rounded-t-xl{border-top-left-radius:.75rem;border-top-right-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-\[10px\]{border-width:10px}.border-l{border-left-width:1px}.border-green-400\/35{border-color:rgba(74,222,128,.35)}.border-green-500\/60{border-color:rgba(34,197,94,.6)}.border-green-800{--tw-border-opacity:1;border-color:rgb(22 101 52/var(--tw-border-opacity,1))}.border-neutral-700{--tw-border-opacity:1;border-color:rgb(64 64 64/var(--tw-border-opacity,1))}.border-neutral-800{--tw-border-opacity:1;border-color:rgb(38 38 38/var(--tw-border-opacity,1))}.border-white\/15{border-color:hsla(0,0%,100%,.15)}.border-t-transparent{border-top-color:transparent}.bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity,1))}.bg-black\/0{background-color:transparent}.bg-black\/10{background-color:rgba(0,0,0,.1)}.bg-black\/55{background-color:rgba(0,0,0,.55)}.bg-black\/90{background-color:rgba(0,0,0,.9)}.bg-green-500{--tw-bg-opacity:1;background-color:rgb(34 197 94/var(--tw-bg-opacity,1))}.bg-green-500\/10{background-color:rgba(34,197,94,.1)}.bg-neutral-900{--tw-bg-opacity:1;background-color:rgb(23 23 23/var(--tw-bg-opacity,1))}.bg-neutral-950{--tw-bg-opacity:1;background-color:rgb(10 10 10/var(--tw-bg-opacity,1))}.bg-red-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-transparent{background-color:transparent}.bg-opacity-100{--tw-bg-opacity:1}.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-black{--tw-gradient-from:#000 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)}.from-green-500\/20{--tw-gradient-from:rgba(34,197,94,.2) var(--tw-gradient-from-position);--tw-gradient-to:rgba(34,197,94,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.to-black{--tw-gradient-to:#000 var(--tw-gradient-to-position)}.to-emerald-500\/20{--tw-gradient-to:rgba(16,185,129,.2) var(--tw-gradient-to-position)}.object-contain{-o-object-fit:contain;object-fit:contain}.p-2{padding:.5rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-\[6\%\]{padding:6%}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pl-4{padding-left:1rem}.pr-2{padding-right:.5rem}.pt-4{padding-top:1rem}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-\[10px\]{font-size:10px}.text-\[2\.9rem\]{font-size:2.9rem}.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}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-none{line-height:1}.leading-tight{line-height:1.25}.tracking-wider{letter-spacing:.05em}.text-black{--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-green-200{--tw-text-opacity:1;color:rgb(187 247 208/var(--tw-text-opacity,1))}.text-green-300{--tw-text-opacity:1;color:rgb(134 239 172/var(--tw-text-opacity,1))}.text-green-400{--tw-text-opacity:1;color:rgb(74 222 128/var(--tw-text-opacity,1))}.text-green-500{--tw-text-opacity:1;color:rgb(34 197 94/var(--tw-text-opacity,1))}.text-neutral-300{--tw-text-opacity:1;color:rgb(212 212 212/var(--tw-text-opacity,1))}.text-neutral-400{--tw-text-opacity:1;color:rgb(163 163 163/var(--tw-text-opacity,1))}.text-red-500{--tw-text-opacity:1;color:rgb(239 68 68/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-white\/90{color:hsla(0,0%,100%,.9)}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-0{opacity:0}.opacity-100{opacity:1}.shadow-2xl{--tw-shadow:0 25px 50px -12px rgba(0,0,0,.25);--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color)}.shadow-2xl,.shadow-\[0_0_0_0_rgba\(0\2c 0\2c 0\2c 0\.4\)\]{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-\[0_0_0_0_rgba\(0\2c 0\2c 0\2c 0\.4\)\]{--tw-shadow:0 0 0 0 rgba(0,0,0,.4);--tw-shadow-colored:0 0 0 0 var(--tw-shadow-color)}.shadow-\[0_0_55px_12px_rgba\(0\2c 0\2c 0\2c 0\.35\)\]{--tw-shadow:0 0 55px 12px rgba(0,0,0,.35);--tw-shadow-colored:0 0 55px 12px 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-\[0_8px_32px_rgba\(34\2c 197\2c 94\2c 0\.25\)\]{--tw-shadow:0 8px 32px rgba(34,197,94,.25);--tw-shadow-colored:0 8px 32px var(--tw-shadow-color)}.shadow-\[0_8px_32px_rgba\(34\2c 197\2c 94\2c 0\.25\)\],.shadow-xl{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color)}.shadow-green-800{--tw-shadow-color:#166534;--tw-shadow:var(--tw-shadow-colored)}.ring-4{--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(4px + 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-green-500\/10{--tw-ring-color:rgba(34,197,94,.1)}.blur-2xl{--tw-blur:blur(40px)}.blur-2xl,.blur-xl{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)}.blur-xl{--tw-blur:blur(24px)}.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-sm{--tw-backdrop-blur:blur(4px);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{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}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.duration-700{transition-duration:.7s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--background:#fff;--foreground:#171717}@media (prefers-color-scheme:dark){:root{--background:#0a0a0a;--foreground:#ededed}}html{scroll-behavior:smooth}body{margin:0;color:var(--foreground);background:var(--background);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.hover\:scale-110:hover{--tw-scale-x:1.1;--tw-scale-y:1.1}.hover\:scale-110:hover,.hover\:scale-125:hover{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\:scale-125:hover{--tw-scale-x:1.25;--tw-scale-y:1.25}.hover\:scale-150:hover{--tw-scale-x:1.5;--tw-scale-y:1.5}.hover\:scale-150:hover,.hover\:scale-\[1\.02\]:hover{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\:scale-\[1\.02\]:hover{--tw-scale-x:1.02;--tw-scale-y:1.02}.hover\:animate-pulse:hover{animation:pulse var(--tw-animate-duration,2s) var(--tw-animate-easing,cubic-bezier(.4,0,.6,1)) var(--tw-animate-delay,0s) var(--tw-animate-iteration,infinite) var(--tw-animate-fill,none)}.hover\:bg-\[\#1c1d25\]:hover{--tw-bg-opacity:1;background-color:rgb(28 29 37/var(--tw-bg-opacity,1))}.hover\:bg-green-400:hover{--tw-bg-opacity:1;background-color:rgb(74 222 128/var(--tw-bg-opacity,1))}.hover\:text-green-500:hover{--tw-text-opacity:1;color:rgb(34 197 94/var(--tw-text-opacity,1))}.hover\:text-white:hover{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.hover\:opacity-55:hover{opacity:.55}.hover\:shadow-\[0_0_18px_6px_rgba\(0\2c 0\2c 0\2c 0\.6\)\]:hover{--tw-shadow:0 0 18px 6px rgba(0,0,0,.6);--tw-shadow-colored:0 0 18px 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)}.hover\:shadow-\[0_12px_48px_rgba\(34\2c 197\2c 94\2c 0\.35\)\]:hover{--tw-shadow:0 12px 48px rgba(34,197,94,.35);--tw-shadow-colored:0 12px 48px 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\:ring-green-500\/20:hover{--tw-ring-color:rgba(34,197,94,.2)}.focus\:border-green-500:focus{--tw-border-opacity:1;border-color:rgb(34 197 94/var(--tw-border-opacity,1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.group:hover .group-hover\:pointer-events-none{pointer-events:none}.group:hover .group-hover\:block{display:block}.group:hover .group-hover\:scale-105{--tw-scale-x:1.05;--tw-scale-y:1.05}.group:hover .group-hover\:scale-105,.group:hover .group-hover\:scale-110{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))}.group:hover .group-hover\:scale-110{--tw-scale-x:1.1;--tw-scale-y:1.1}@keyframes flip-up{0%{transform:rotateX(90deg);transform-origin:bottom}to{transform:rotateX(0);transform-origin:bottom}}.group:hover .group-hover\:animate-flip-up{animation:flip-up var(--tw-animate-duration,1s) var(--tw-animate-easing,ease) var(--tw-animate-delay,0s) var(--tw-animate-iteration,1) var(--tw-animate-fill,both)}.group:hover .group-hover\:bg-\[\#1c1d25\]{--tw-bg-opacity:1;background-color:rgb(28 29 37/var(--tw-bg-opacity,1))}.group:hover .group-hover\:bg-black\/30{background-color:rgba(0,0,0,.3)}.group:hover .group-hover\:from-neutral-800{--tw-gradient-from:#262626 var(--tw-gradient-from-position);--tw-gradient-to:rgba(38,38,38,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.group:hover .group-hover\:to-neutral-800{--tw-gradient-to:#262626 var(--tw-gradient-to-position)}.group:hover .group-hover\:opacity-0{opacity:0}.group:hover .group-hover\:opacity-100{opacity:1}.group:hover .group-hover\:opacity-75{opacity:.75}.group:hover .group-hover\:opacity-95{opacity:.95}.group:hover .group-hover\:shadow-\[0_0_80px_26px_rgba\(0\2c 0\2c 0\2c 0\.5\)\]{--tw-shadow:0 0 80px 26px rgba(0,0,0,.5);--tw-shadow-colored:0 0 80px 26px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.group:hover .group-hover\:blur-2xl{--tw-blur:blur(40px)}.group:hover .group-hover\:blur-2xl,.group:hover .group-hover\:blur-3xl{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)}.group:hover .group-hover\:blur-3xl{--tw-blur:blur(64px)}.group:hover .group-hover\:blur-sm{--tw-blur:blur(4px);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)}.dark\:text-black:is(.dark *){--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity,1))}.dark\:invert-0:is(.dark *){--tw-invert:invert(0);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)}@media (min-width:640px){.sm\:flex{display:flex}.sm\:h-24{height:6rem}.sm\:h-32{height:8rem}.sm\:min-h-\[450px\]{min-height:450px}.sm\:w-24{width:6rem}.sm\:w-32{width:8rem}.sm\:flex-col{flex-direction:column}.sm\:items-center{align-items:center}.sm\:gap-5{gap:1.25rem}.sm\:gap-6{gap:1.5rem}.sm\:border-\[14px\]{border-width:14px}.sm\:p-8{padding:2rem}.sm\:px-3{padding-left:.75rem;padding-right:.75rem}.sm\:py-3{padding-top:.75rem;padding-bottom:.75rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-5xl{font-size:3rem;line-height:1}.sm\:text-base{font-size:1rem;line-height:1.5rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}}@media (min-width:768px){.md\:right-3{right:.75rem}.md\:top-3{top:.75rem}.md\:mb-5{margin-bottom:1.25rem}.md\:block{display:block}.md\:hidden{display:none}.md\:h-8{height:2rem}.md\:h-\[5px\]{height:5px}.md\:max-h-\[8rem\]{max-height:8rem}.md\:max-h-\[90vh\]{max-height:90vh}.md\:min-h-\[4\.5rem\]{min-height:4.5rem}.md\:w-8{width:2rem}.md\:basis-1\/2{flex-basis:50%}.md\:flex-row{flex-direction:row}.md\:gap-3{gap:.75rem}.md\:gap-4{gap:1rem}.md\:gap-6{gap:1.5rem}.md\:overflow-hidden{overflow:hidden}.md\:rounded-none{border-radius:0}.md\:rounded-b-none{border-bottom-right-radius:0;border-bottom-left-radius:0}.md\:rounded-l-xl{border-top-left-radius:.75rem;border-bottom-left-radius:.75rem}.md\:rounded-r-xl{border-top-right-radius:.75rem;border-bottom-right-radius:.75rem}.md\:rounded-t-none{border-top-left-radius:0;border-top-right-radius:0}.md\:bg-green-500\/0{background-color:rgba(34,197,94,0)}.md\:from-green-400{--tw-gradient-from:#4ade80 var(--tw-gradient-from-position);--tw-gradient-to:rgba(74,222,128,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.md\:via-green-500{--tw-gradient-to:rgba(34,197,94,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#22c55e var(--tw-gradient-via-position),var(--tw-gradient-to)}.md\:to-green-600{--tw-gradient-to:#16a34a var(--tw-gradient-to-position)}.md\:p-12{padding:3rem}.md\:p-14{padding:3.5rem}.md\:p-3{padding:.75rem}.md\:px-0{padding-left:0;padding-right:0}.md\:px-12{padding-left:3rem;padding-right:3rem}.md\:px-8{padding-left:2rem;padding-right:2rem}.md\:py-8{padding-top:2rem;padding-bottom:2rem}.md\:text-3xl{font-size:1.875rem;line-height:2.25rem}.md\:text-5xl{font-size:3rem;line-height:1}.md\:text-6xl{font-size:3.75rem;line-height:1}.md\:text-lg{font-size:1.125rem;line-height:1.75rem}.md\:text-sm{font-size:.875rem;line-height:1.25rem}.md\:text-xl{font-size:1.25rem;line-height:1.75rem}.md\:shadow-\[0_0_55px_12px_rgba\(34\2c 197\2c 94\2c 0\.35\)\]{--tw-shadow:0 0 55px 12px rgba(34,197,94,.35);--tw-shadow-colored:0 0 55px 12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.md\:hover\:shadow-\[0_0_18px_6px_rgba\(34\2c 197\2c 94\2c 0\.6\)\]:hover{--tw-shadow:0 0 18px 6px rgba(34,197,94,.6);--tw-shadow-colored:0 0 18px 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)}.group:hover .md\:group-hover\:bg-green-500\/30{background-color:rgba(34,197,94,.3)}.group:hover .md\:group-hover\:from-green-300{--tw-gradient-from:#86efac var(--tw-gradient-from-position);--tw-gradient-to:rgba(134,239,172,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.group:hover .md\:group-hover\:to-green-500{--tw-gradient-to:#22c55e var(--tw-gradient-to-position)}.group:hover .md\:group-hover\:shadow-\[0_0_80px_26px_rgba\(34\2c 197\2c 94\2c 0\.5\)\]{--tw-shadow:0 0 80px 26px rgba(34,197,94,.5);--tw-shadow-colored:0 0 80px 26px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}}@media (min-width:1024px){.lg\:mb-0{margin-bottom:0}.lg\:mb-4{margin-bottom:1rem}.lg\:ml-4{margin-left:1rem}.lg\:block{display:block}.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:h-\[500px\]{height:500px}.lg\:w-1\/2{width:50%}.lg\:w-\[500px\]{width:500px}.lg\:w-\[600px\]{width:600px}.lg\:max-w-md{max-width:28rem}.lg\:flex-row{flex-direction:row}.lg\:text-left{text-align:left}.lg\:text-2xl{font-size:1.5rem;line-height:2rem}.lg\:text-4xl{font-size:2.25rem;line-height:2.5rem}.lg\:text-7xl{font-size:4.5rem;line-height:1}.lg\:text-\[6rem\]{font-size:6rem}.lg\:leading-tight{line-height:1.25}}@media (min-width:1280px){.xl\:text-\[8rem\]{font-size:8rem}}@media (min-width:1600px){.xxl\:h-\[800px\]{height:800px}.xxl\:w-\[800px\]{width:800px}.xxl\:max-w-\[800px\]{max-width:800px}.xxl\:max-w-none{max-width:none}.xxl\:text-3xl{font-size:1.875rem;line-height:2.25rem}.xxl\:text-\[12rem\]{font-size:12rem}}.portfolio-site{--bg:#fff;--ink:#0a0a0a;--ink-2:#1a1a1a;--muted:#5a5a5a;--line:#e6e6e6;--card:#fafafa;--accent:#1cc66a;--accent-deep:#0e8d4a;--accent-soft:#d6f5e3;--shadow:0 1px 2px rgba(0,0,0,.04),0 8px 24px -12px rgba(0,0,0,.08);background:radial-gradient(circle at 80% 10%,#ecf8f1 0,transparent 42%),var(--bg);color:var(--ink);min-height:100vh}.portfolio-site[data-theme=dark]{--bg:#0b0d0c;--ink:#f4f6f4;--ink-2:#e8eae8;--muted:#9aa19c;--line:#1f2522;--card:#11140f;--accent:#28e07d;--accent-deep:#1cc66a;--accent-soft:#14361f;--shadow:0 1px 2px rgba(0,0,0,.5),0 12px 40px -12px rgba(0,0,0,.6);background:radial-gradient(circle at 80% 10%,#112118 0,transparent 42%),var(--bg)}.portfolio-site *{box-sizing:border-box}.portfolio-site a{color:inherit;text-decoration:none}.portfolio-site img{max-width:100%;display:block}.portfolio-site ::-moz-selection{background:var(--accent);color:#06241a}.portfolio-site ::selection{background:var(--accent);color:#06241a}.portfolio-wrap{max-width:1200px;margin:0 auto;padding:0 28px}.portfolio-site .nav{position:sticky;top:0;z-index:50;background:color-mix(in oklab,var(--bg) 88%,transparent);backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid color-mix(in oklab,var(--line) 70%,transparent)}.portfolio-site .nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px}.portfolio-site .logo{display:inline-flex;align-items:center;gap:10px;font-weight:700;letter-spacing:-.01em}.portfolio-site .logo .mark{width:38px;height:38px;border-radius:999px;border:1.5px solid var(--ink);display:grid;place-items:center;font-size:20px;font-style:italic;color:var(--ink);background:var(--bg)}.portfolio-site .nav-links{display:flex;align-items:center;gap:28px}.portfolio-site .nav-links a,.portfolio-site .nav-links button{font-size:14.5px;color:var(--muted);transition:color .2s;border:none;background:transparent;cursor:pointer}.portfolio-site .nav-links a:hover,.portfolio-site .nav-links button:hover{color:var(--ink)}.portfolio-site .nav-links .pill{background:var(--ink);color:var(--bg);padding:9px 16px;border-radius:999px;font-weight:600}.portfolio-site .nav-links .pill:hover{background:var(--accent);color:#06241a}.portfolio-site .theme-btn{border:1px solid var(--line);color:var(--ink);width:38px;height:38px;border-radius:50%;display:grid;place-items:center}.portfolio-site .hero{padding:72px 0 80px;position:relative;overflow:hidden}.portfolio-site .notes{position:absolute;inset:0;pointer-events:none;z-index:2;overflow:hidden}.portfolio-site .note{position:absolute;color:var(--accent);opacity:.18;font-size:24px;animation:drift 14s linear infinite}.portfolio-site[data-theme=light] .note{color:#16a34a;opacity:.75;font-weight:700;text-shadow:0 0 10px rgba(22,163,74,.2)}.portfolio-site .note:nth-child(2){animation-duration:18s;animation-delay:-3s;font-size:18px;opacity:.12}.portfolio-site[data-theme=light] .note:nth-child(2){opacity:.6}.portfolio-site .note:nth-child(3){animation-duration:22s;animation-delay:-7s;font-size:30px;opacity:.1}.portfolio-site[data-theme=light] .note:nth-child(3){opacity:.55}.portfolio-site .note:nth-child(4){animation-duration:16s;animation-delay:-2s;font-size:20px;opacity:.14}.portfolio-site[data-theme=light] .note:nth-child(4){opacity:.65}.portfolio-site .note:nth-child(5){animation-duration:24s;animation-delay:-10s;font-size:26px;opacity:.08}.portfolio-site[data-theme=light] .note:nth-child(5){opacity:.5}@keyframes drift{0%{transform:translate(0) rotate(-10deg)}50%{transform:translate(20px,-30px) rotate(10deg)}to{transform:translate(0) rotate(-10deg)}}.portfolio-site .hero-grid{display:grid;grid-template-columns:1fr 460px;gap:60px;align-items:center;position:relative;z-index:1}.portfolio-site .eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.14em;margin-bottom:22px}.portfolio-site .eyebrow .dot{width:8px;height:8px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 4px color-mix(in oklab,var(--accent) 25%,transparent);animation:pulse 2s ease-in-out infinite}@keyframes pulse{50%{box-shadow:0 0 0 8px color-mix(in oklab,var(--accent) 0,transparent)}}.portfolio-site h1.display{font-size:clamp(56px,9vw,124px);line-height:.92;letter-spacing:-.035em;font-weight:800;margin:0 0 28px}.portfolio-site h1.display .green{color:var(--accent)}.portfolio-site .serif,.portfolio-site h1.display em{font-style:italic;font-weight:400;letter-spacing:-.02em}.portfolio-site .lede{font-size:19px;line-height:1.55;color:var(--ink-2);max-width:560px;margin:0 0 28px}.portfolio-site .lede b{font-weight:600;background:linear-gradient(180deg,transparent 60%,var(--accent-soft) 60%);padding:0 2px}.portfolio-site .meta-row{display:flex;flex-wrap:wrap;gap:20px;color:var(--muted);font-size:14.5px;margin-bottom:28px}.portfolio-site .cta-row{display:flex;gap:12px;flex-wrap:wrap}.portfolio-site .btn{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;border-radius:999px;font-weight:600;font-size:14.5px;border:1px solid transparent;transition:all .2s}.portfolio-site .btn.primary{background:var(--ink);color:var(--bg)}.portfolio-site .btn.primary:hover{background:var(--accent);color:#06241a;transform:translateY(-1px)}.portfolio-site .btn.ghost{border-color:var(--line)}.portfolio-site .portrait-wrap{position:relative;width:100%;aspect-ratio:1;max-width:460px;justify-self:end}.portfolio-site .portrait-glow{position:absolute;inset:-20px;border-radius:50%;background:radial-gradient(circle at 50% 50%,color-mix(in oklab,var(--accent) 35%,transparent),transparent 70%);filter:blur(20px)}.portfolio-site .portrait{position:relative;width:100%;height:100%;border-radius:50%;overflow:hidden;border:2px solid var(--ink);box-shadow:0 30px 80px -30px rgba(0,0,0,.4)}.portfolio-site .portrait img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center center;object-position:center center;transform:translateX(5%)}.portfolio-site .badge-float{position:absolute;background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:10px 14px;box-shadow:var(--shadow);font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:8px}.portfolio-site .badge-float .num{color:var(--accent);font-weight:800;font-size:18px}.portfolio-site .badge-1{top:18%;left:-30px}.portfolio-site .badge-2{bottom:14%;right:-20px}.portfolio-site section{padding:80px 0;border-top:1px solid var(--line)}.portfolio-site .section-head{display:flex;align-items:end;justify-content:space-between;gap:20px;margin-bottom:48px}.portfolio-site .section-head h2{font-size:clamp(32px,4.4vw,52px);letter-spacing:-.025em;font-weight:700;margin:0;line-height:1}.portfolio-site .section-head h2 em{color:var(--accent)}.portfolio-site .section-head .sub{color:var(--muted);font-size:15px;max-width:340px;text-align:right}.portfolio-site .label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px;display:inline-flex;align-items:center;gap:8px}.portfolio-site .label:before{content:"";width:24px;height:1px;background:var(--accent)}.portfolio-site .about-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:60px}.portfolio-site .about-grid p{font-size:18px;line-height:1.65;color:var(--ink-2);margin:0 0 18px}.portfolio-site .stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden;margin-top:32px}.portfolio-site .stat{padding:24px;background:var(--card)}.portfolio-site .stat .v{font-size:40px;font-weight:800;line-height:1;color:var(--accent)}.portfolio-site .stat .k{font-size:13px;color:var(--muted);margin-top:8px}.portfolio-site .work-list{display:flex;flex-direction:column;gap:20px}.portfolio-site .project{display:grid;grid-template-columns:1.1fr 1.4fr;background:var(--card);border:1px solid var(--line);border-radius:24px;overflow:hidden;transition:all .3s ease}.portfolio-site .project:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.portfolio-site .project .preview{aspect-ratio:4/3;border-right:1px solid var(--line)}.portfolio-site .project .body{padding:32px 36px;display:flex;flex-direction:column;justify-content:space-between;gap:20px}.portfolio-site .project .num{font-size:12px;color:var(--muted)}.portfolio-site .project h3{font-size:30px;letter-spacing:-.02em;margin:8px 0 12px}.portfolio-site .project p{font-size:15.5px;line-height:1.55;color:var(--ink-2)}.portfolio-site .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:18px}.portfolio-site .tag{font-size:12px;color:var(--muted);background:var(--bg);border:1px solid var(--line);padding:4px 10px;border-radius:999px}.portfolio-site .project .links{display:flex;gap:18px;margin-top:18px}.portfolio-site .project .links a{font-size:13.5px;font-weight:600;border-bottom:1px solid var(--ink);padding-bottom:2px}@media (max-width:1100px){.portfolio-site .project{grid-template-columns:1fr 1.2fr}.portfolio-site .project .body{padding:26px;gap:16px}.portfolio-site .project h3{font-size:clamp(24px,3.6vw,28px)}.portfolio-site .project p{font-size:14.5px}.portfolio-site .frame{padding:18px}}.portfolio-site .metric-row{display:flex;gap:24px;padding-top:14px;border-top:1px dashed var(--line);margin-top:18px}.portfolio-site .metric-row .v{font-weight:700;color:var(--accent)}.portfolio-site .metric-row .k{font-size:12px;color:var(--muted)}.portfolio-site .frame{width:100%;height:100%;display:grid;place-items:center;padding:24px}.portfolio-site .frame.skinstric{background:linear-gradient(135deg,#f6f7f5,#ecf0e9)}.portfolio-site .frame.clinical{background:linear-gradient(135deg,#0a1628,#142a4a)}.portfolio-site .frame.summarist{background:linear-gradient(135deg,#fff7e6,#ffe8b8)}.portfolio-site .frame.lingo{background:linear-gradient(135deg,#ecfdf5,#d1fae5)}.portfolio-site .mock{width:100%;max-width:360px;background:#fff;border-radius:14px;box-shadow:0 20px 50px -20px rgba(0,0,0,.25);overflow:hidden;font-size:11px;border:1px solid rgba(0,0,0,.06)}.portfolio-site .mock-bar{height:22px;background:#f5f5f5;display:flex;align-items:center;gap:4px;padding:0 8px;border-bottom:1px solid #ececec}.portfolio-site .mock-bar span{width:8px;height:8px;border-radius:999px;background:#e0e0e0}.portfolio-site .mock-bar span:first-child{background:#ff5f57}.portfolio-site .mock-bar span:nth-child(2){background:#febc2e}.portfolio-site .mock-bar span:nth-child(3){background:#28c840}.portfolio-site .mock-body{padding:18px;color:#1a1a1a}.portfolio-site .skinstric-mock{max-width:100%;background:linear-gradient(180deg,#fdfefe,#eef4ee)}.portfolio-site .skinstric-mock .mock-body{padding:16px}.portfolio-site .skinstric-mock .face-circ{position:relative;width:min(100%,210px);aspect-ratio:1;margin:8px auto 12px;border-radius:50%;border:1px solid rgba(16,185,129,.08);background:radial-gradient(circle at 50% 10%,hsla(0,0%,100%,.45),hsla(0,0%,100%,0) 34%),radial-gradient(circle at 50% 50%,rgba(243,247,244,.6) 0,rgba(233,240,235,.3) 74%,rgba(225,233,228,.14) 100%);overflow:hidden;box-shadow:inset 0 0 0 1px hsla(0,0%,100%,.28)}.portfolio-site .skinstric-mock .face-circ:before{content:"";position:absolute;inset:12% 22% 10% 22%;border-radius:46% 46% 50% 50%/42% 42% 58% 58%;background:radial-gradient(ellipse at 50% 27%,rgba(255,236,223,.95),rgba(255,236,223,0) 36%),radial-gradient(ellipse at 50% 66%,rgba(159,102,79,.26),rgba(159,102,79,0) 62%),radial-gradient(ellipse at 50% 48%,#f1cfb6 0,#e2b796 58%,#cb987a 100%);box-shadow:inset 0 -8px 18px rgba(118,74,54,.22)}.portfolio-site .skinstric-mock .face-circ:after{content:"";position:absolute;left:50%;top:29%;width:36%;height:8%;transform:translateX(-50%);border-radius:999px;background:radial-gradient(circle at 25% 50%,rgba(98,60,45,.26) 0,rgba(98,60,45,0) 52%),radial-gradient(circle at 75% 50%,rgba(98,60,45,.26) 0,rgba(98,60,45,0) 52%);opacity:.9}.portfolio-site .skinstric-mock .scan{position:absolute;inset:14% 24% 12% 24%;border-radius:46% 46% 50% 50%/42% 42% 58% 58%;overflow:hidden;background:linear-gradient(180deg,transparent,transparent 44%,rgba(16,185,129,.18) 50%,transparent 56%,transparent),radial-gradient(circle at 50% 50%,rgba(16,185,129,.09) 0,rgba(16,185,129,0) 64%);animation:scanSweep 2.4s linear infinite}.portfolio-site .skinstric-mock .pill-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.portfolio-site .skinstric-mock .pill-row b{font-size:10px;padding:5px 8px;border-radius:999px;background:#eef4ef;color:#1f2937;border:1px solid rgba(0,0,0,.06)}.portfolio-site .skinstric-mock .pill-row .green{color:#0f7a42;background:#dcf7e6}.portfolio-site .skinstric-mock .row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:11px;color:#4b5563;margin-bottom:8px}.portfolio-site .skinstric-mock .row b{color:#111827}.portfolio-site .skinstric-mock .meter{height:8px;border-radius:999px;background:#dbe5dd;overflow:hidden}.portfolio-site .skinstric-mock .meter i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#16a34a,#22c55e,#86efac);box-shadow:0 0 16px rgba(34,197,94,.35)}@keyframes scanSweep{0%,to{transform:translateY(-48%);opacity:.35}50%{transform:translateY(48%);opacity:.9}}.portfolio-site .clinical-mock{max-width:100%;background:linear-gradient(180deg,#0d1a31,#101c2f);color:#edf4ff}.portfolio-site .clinical-mock .mock-body{padding:16px;color:#edf4ff}.portfolio-site .clinical-mock .topline{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.portfolio-site .clinical-mock h4,.portfolio-site .lingo-mock h4,.portfolio-site .summarist-mock h4{margin:0;font-size:13px;letter-spacing:-.01em}.portfolio-site .clinical-mock .day,.portfolio-site .lingo-mock .streak,.portfolio-site .summarist-mock span{font-size:10px;color:#7a8aa6;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.portfolio-site .clinical-mock .kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.portfolio-site .clinical-mock .kpi{border-radius:12px;padding:10px 8px;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.08);text-align:center}.portfolio-site .clinical-mock .kpi .v{font-size:18px;line-height:1;font-weight:800;color:#28e07d;margin-bottom:4px}.portfolio-site .clinical-mock .kpi .k{font-size:9px;color:#a8b4cb;letter-spacing:.04em;text-transform:uppercase}.portfolio-site .clinical-mock .chart{height:62px;margin-bottom:12px;border-radius:14px;overflow:hidden;background:linear-gradient(180deg,rgba(40,224,125,.12),rgba(40,224,125,.03));border:1px solid rgba(40,224,125,.12)}.portfolio-site .clinical-mock .chart svg{width:100%;height:100%;display:block}.portfolio-site .clinical-mock .alerts{display:flex;flex-direction:column;gap:8px}.portfolio-site .clinical-mock .alert{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 10px;border-radius:12px;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.08);font-size:10px;color:#edf4ff}.portfolio-site .clinical-mock .alert.amber{background:rgba(245,184,64,.08)}.portfolio-site .clinical-mock .alert.red{background:rgba(239,91,91,.08)}.portfolio-site .summarist-mock{max-width:100%;background:linear-gradient(180deg,#fffaf1,#f4ead5)}.portfolio-site .summarist-mock .mock-body{padding:16px}.portfolio-site .lingo-mock .head,.portfolio-site .summarist-mock .head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.portfolio-site .summarist-mock .head span{color:#d97706}.portfolio-site .summarist-mock .book{display:flex;align-items:center;gap:10px;padding:9px;border-radius:14px;background:hsla(0,0%,100%,.72);border:1px solid rgba(17,24,39,.08);margin-bottom:9px}.portfolio-site .summarist-mock .cover{width:36px;height:48px;border-radius:8px;background:linear-gradient(180deg,#8b5cf6,#c084fc);flex-shrink:0}.portfolio-site .summarist-mock .cover.b2{background:linear-gradient(180deg,#0f172a,#334155)}.portfolio-site .summarist-mock .cover.b3{background:linear-gradient(180deg,#22c55e,#86efac)}.portfolio-site .summarist-mock .b-info{display:flex;flex-direction:column;gap:2px;min-width:0}.portfolio-site .summarist-mock .b-info b{font-size:12px;color:#111827}.portfolio-site .summarist-mock .b-info span{font-size:10px;color:#6b7280;text-transform:none;letter-spacing:0;font-weight:600}.portfolio-site .summarist-mock .play{color:#d97706!important;font-weight:700!important}.portfolio-site .lingo-mock{max-width:100%;background:linear-gradient(180deg,#f6fff9,#e8f8ef)}.portfolio-site .lingo-mock .mock-body{padding:16px}.portfolio-site .lingo-mock .streak{color:#10b981}.portfolio-site .lingo-mock .lesson{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 11px;margin-bottom:8px;border-radius:12px;background:hsla(0,0%,100%,.75);border:1px solid rgba(16,185,129,.1)}.portfolio-site .lingo-mock .lesson b{font-size:11px;color:#111827}.portfolio-site .lingo-mock .lesson.active{background:rgba(16,185,129,.08);border-color:rgba(16,185,129,.22)}.portfolio-site .lingo-mock .lesson.locked{opacity:.72}.portfolio-site .lingo-mock .check{color:#10b981;font-size:12px;font-weight:800}.portfolio-site .lingo-mock .progress{height:8px;border-radius:999px;background:#dbece3;overflow:hidden;margin-top:4px}.portfolio-site .lingo-mock .progress i{display:block;width:62%;height:100%;border-radius:inherit;background:linear-gradient(90deg,#10b981,#34d399,#86efac)}.portfolio-site .stack-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}.portfolio-site .tech{aspect-ratio:1;background:var(--card);border:1px solid var(--line);border-radius:18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;transition:all .2s}.portfolio-site .tech:hover{transform:translateY(-3px);border-color:var(--ink)}.portfolio-site .tech-icon{display:grid;place-items:center}.portfolio-site .tech-icon svg{width:38px;height:38px;display:block}.portfolio-site .tech b{font-size:13px;font-weight:600}.portfolio-site .tech .lvl{font-size:10.5px;color:var(--muted)}.portfolio-site .xp-list{display:flex;flex-direction:column}.portfolio-site .xp{display:grid;grid-template-columns:220px 1fr;gap:42px;padding:32px 0;border-top:1px solid var(--line)}.portfolio-site .xp:first-child{border-top:none;padding-top:0}.portfolio-site .xp .when{font-size:13px;color:var(--muted)}.portfolio-site .xp h3{margin:0 0 4px;font-size:22px}.portfolio-site .xp .where{font-size:14px;color:var(--muted);margin-bottom:14px}.portfolio-site .xp ul{margin:0;padding-left:18px;color:var(--ink-2);font-size:15px;line-height:1.6}.portfolio-site .contact{position:relative;overflow:hidden;padding:120px 0 100px;text-align:center}.portfolio-site .contact-notes{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}.portfolio-site .contact-notes .note{position:absolute;color:var(--accent);opacity:.14;font-size:28px;animation:drift 14s linear infinite}.portfolio-site[data-theme=light] .contact-notes .note{color:#16a34a;opacity:.62;text-shadow:0 0 10px rgba(22,163,74,.15)}.portfolio-site .contact-notes .note:nth-child(2){animation-duration:18s;animation-delay:-3s;font-size:18px;opacity:.1}.portfolio-site[data-theme=light] .contact-notes .note:nth-child(2){opacity:.5}.portfolio-site .contact-notes .note:nth-child(3){animation-duration:22s;animation-delay:-7s;font-size:30px;opacity:.08}.portfolio-site[data-theme=light] .contact-notes .note:nth-child(3){opacity:.48}.portfolio-site .contact-notes .note:nth-child(4){animation-duration:16s;animation-delay:-2s;font-size:20px;opacity:.12}.portfolio-site[data-theme=light] .contact-notes .note:nth-child(4){opacity:.55}.portfolio-site .contact-notes .note:nth-child(5){animation-duration:24s;animation-delay:-10s;font-size:26px;opacity:.08}.portfolio-site[data-theme=light] .contact-notes .note:nth-child(5){opacity:.42}.portfolio-site .contact-content{position:relative;z-index:1}.portfolio-site .contact h2{font-size:clamp(48px,8vw,110px);font-weight:800;letter-spacing:-.035em;line-height:.95;margin:0 0 24px}.portfolio-site .contact p{font-size:18px;color:var(--muted);max-width:540px;margin:0 auto 36px}.portfolio-site .contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:720px;margin:0 auto}.portfolio-site .contact-card{display:flex;align-items:center;gap:14px;padding:20px;background:var(--card);border:1px solid var(--line);border-radius:16px;text-align:left;transition:all .2s}.portfolio-site .contact-card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:var(--shadow)}.portfolio-site .contact-card-btn{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;color:inherit;font:inherit}.portfolio-site .contact-card .ic{width:40px;height:40px;border-radius:10px;background:var(--bg);border:1px solid var(--line);display:grid;place-items:center;flex-shrink:0;color:var(--accent)}.portfolio-site .contact-card .lab{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.portfolio-site .contact-card .val{font-weight:600;font-size:14.5px;margin-top:2px;word-break:break-all}.portfolio-site .modal-shell{position:fixed;inset:0;display:grid;place-items:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .28s ease;z-index:100}.portfolio-site .modal-shell.open{opacity:1;pointer-events:auto}.portfolio-site .modal-backdrop{position:absolute;inset:0;background:rgba(6,10,8,.62);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.portfolio-site .modal-card{position:relative;width:min(100%,580px);border:1px solid color-mix(in oklab,var(--line) 72%,transparent);border-radius:28px;background:linear-gradient(180deg,color-mix(in oklab,var(--bg) 96%,var(--accent-soft)),var(--bg));box-shadow:0 35px 80px -35px rgba(0,0,0,.5);padding:36px;transform:translateY(18px) scale(.98);transition:transform .28s ease}.portfolio-site .modal-shell.open .modal-card{transform:translateY(0) scale(1)}.portfolio-site .modal-close{position:absolute;top:18px;right:18px;width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:var(--card);color:var(--ink);display:grid;place-items:center}.portfolio-site .modal-title{font-size:clamp(30px,5vw,46px);line-height:.95;letter-spacing:-.04em;font-weight:800;margin:0 0 10px}.portfolio-site .modal-sub{margin:0 0 24px;color:var(--muted);font-size:15px}.portfolio-site .modal-fields-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}.portfolio-site .modal-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.portfolio-site .modal-field label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.portfolio-site .modal-field input,.portfolio-site .modal-field textarea{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:11px 14px;font-size:14.5px;color:var(--ink);outline:none;width:100%;resize:vertical}.portfolio-site .modal-field input:focus,.portfolio-site .modal-field textarea:focus{border-color:var(--accent)}.portfolio-site .modal-field .err{border-color:#ef5b5b}.portfolio-site .modal-field textarea{min-height:100px}.portfolio-site .modal-actions{display:flex;gap:12px;flex-wrap:wrap}.portfolio-site .modal-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;padding:13px 22px;font-weight:700;font-size:14.5px;cursor:pointer;border:1px solid transparent}.portfolio-site .modal-btn.primary{background:var(--ink);color:var(--bg);flex:1}.portfolio-site .modal-btn.secondary{background:transparent;color:var(--ink);border-color:var(--line)}.portfolio-site .modal-toast{margin-top:14px;font-size:13px;min-height:18px;border-radius:10px;padding:10px 14px;display:none}.portfolio-site .modal-toast.ok{display:flex;background:var(--accent-soft);color:var(--accent-deep)}.portfolio-site .modal-toast.fail{display:flex;background:#fde8e8;color:#c0392b}.portfolio-site footer{border-top:1px solid var(--line);padding:32px 0;color:var(--muted);font-size:13.5px}.portfolio-site footer .mark{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--ink);display:inline-grid;place-items:center;font-style:italic;font-size:16px;color:var(--ink)}@media (max-width:920px){.portfolio-site .hero-grid{grid-template-columns:1fr;gap:40px}.portfolio-site .portrait-wrap{justify-self:center;max-width:340px}.portfolio-site .badge-float{position:absolute;padding:8px 10px;font-size:12px;line-height:1.2;background:color-mix(in oklab,var(--bg) 88%,transparent);border-color:color-mix(in oklab,var(--line) 70%,transparent);box-shadow:0 8px 24px -16px rgba(0,0,0,.35);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:.92}.portfolio-site .badge-float .num{font-size:15px}.portfolio-site .badge-1{top:14%;left:-6px}.portfolio-site .badge-2{bottom:10%;right:-6px}}@media (max-width:820px){.portfolio-site .about-grid{grid-template-columns:1fr}.portfolio-site .section-head{flex-direction:column;align-items:flex-start}.portfolio-site .section-head .sub{text-align:left}.portfolio-site .project{grid-template-columns:1fr}.portfolio-site .project .preview{aspect-ratio:auto;border-right:none;border-bottom:1px solid var(--line)}.portfolio-site .project .body{padding:24px 20px}.portfolio-site .project h3{font-size:clamp(22px,6vw,28px)}.portfolio-site .metric-row{gap:14px;flex-wrap:wrap}.portfolio-site .project .links{flex-wrap:wrap;gap:12px}.portfolio-site .stack-grid{grid-template-columns:repeat(3,1fr)}.portfolio-site .xp{grid-template-columns:1fr;gap:8px}}@media (max-width:720px){.portfolio-site .contact-grid{grid-template-columns:1fr}}@media (max-width:520px){.portfolio-site .hero{padding-top:56px}.portfolio-site .section-head{margin-bottom:28px}.portfolio-site .frame{padding:14px}.portfolio-site .mock{border-radius:12px}.portfolio-site .project .body{padding:18px 16px}.portfolio-site .tags{gap:5px}.portfolio-site .tag{font-size:11px;padding:4px 8px}.portfolio-site .badge-float{font-size:11px;padding:6px 8px;opacity:.86}.portfolio-site .badge-float .num{font-size:13px}.portfolio-site .badge-1{top:12%;left:-8px}.portfolio-site .badge-2{bottom:8%;right:-8px}.portfolio-site .nav-links a:not(.pill){display:none}.portfolio-site .modal-fields-row{grid-template-columns:1fr}.portfolio-wrap{padding:0 18px}}