@import url(https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700&family=Manrope:wght@400;500;600;700;800&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:#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: }::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: }/*
! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-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;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}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-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height: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:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.-top-\[38px\]{top:-38px}.bottom-0{bottom:0}.left-0{left:0}.left-1\/2{left:50%}.right-0{right:0}.top-0{top:0}.top-1\/2{top:50%}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-40{z-index:40}.z-\[12\]{z-index:12}.z-\[1\]{z-index:1}.z-\[2\]{z-index:2}.z-\[5\]{z-index:5}.m-0{margin:0}.m-\[14px_0_0\]{margin:14px 0 0}.mx-px{margin-left:1px;margin-right:1px}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-7{margin-top:1.75rem}.mt-\[14px\]{margin-top:14px}.mt-\[18px\]{margin-top:18px}.mt-\[26px\]{margin-top:26px}.mt-\[42px\]{margin-top:42px}.mt-\[6px\]{margin-top:6px}.mt-auto{margin-top:auto}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.h-10{height:2.5rem}.h-8{height:2rem}.h-\[1\.1em\]{height:1.1em}.h-\[100svh\]{height:100svh}.h-\[110px\]{height:110px}.h-\[13px\]{height:13px}.h-\[14px\]{height:14px}.h-\[1em\]{height:1em}.h-\[22px\]{height:22px}.h-\[2px\]{height:2px}.h-\[82px\]{height:82px}.h-full{height:100%}.h-screen{height:100vh}.min-h-24{min-height:6rem}.min-h-\[78px\]{min-height:78px}.min-h-\[calc\(100svh_-_140px\)\]{min-height:calc(100svh - 140px)}.w-10{width:2.5rem}.w-\[110px\]{width:110px}.w-\[13px\]{width:13px}.w-\[14px\]{width:14px}.w-\[22px\]{width:22px}.w-\[82px\]{width:82px}.w-\[var\(--sm-toggle-width\2c auto\)\]{width:auto;width:var(--sm-toggle-width,auto)}.w-auto{width:auto}.w-fit{width:-webkit-fit-content;width:fit-content}.w-full{width:100%}.w-px{width:1px}.w-screen{width:100vw}.min-w-\[var\(--sm-toggle-width\2c auto\)\]{min-width:auto;min-width:var(--sm-toggle-width,auto)}.max-w-\[18ch\]{max-width:18ch}.max-w-\[26ch\]{max-width:26ch}.max-w-\[36ch\]{max-width:36ch}.max-w-\[48ch\]{max-width:48ch}.max-w-\[50ch\]{max-width:50ch}.flex-1{flex:1 1}.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.-translate-y-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-y-1\/2{--tw-translate-y:-50%}.translate-x-0{--tw-translate-x:0px}.transform,.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))}.animate-\[code-caret-blink_1s_steps\(1\2c end\)_infinite\]{animation:code-caret-blink 1s step-end infinite}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;user-select:none}.resize{resize:both}.list-none{list-style-type:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.place-items-center{place-items:center}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-\[0\.3rem\]{gap:.3rem}.gap-\[10px\]{gap:10px}.gap-\[14px\]{gap:14px}.gap-px{gap:1px}.self-start{align-self:flex-start}.self-center{align-self:center}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.whitespace-nowrap{white-space:nowrap}.break-all{word-break:break-all}.rounded-\[2px\]{border-radius:2px}.rounded-full{border-radius:9999px}.border{border-width:1px}.border-0{border-width:0}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-\[var\(--hover-border\)\]{border-color:var(--hover-border)}.border-\[var\(--line\)\]{border-color:var(--line)}.border-\[var\(--line-soft\)\]{border-color:var(--line-soft)}.border-\[var\(--pill-border\)\]{border-color:var(--pill-border)}.border-\[var\(--toggle-border\)\]{border-color:var(--toggle-border)}.bg-\[var\(--accent\)\]{background-color:var(--accent)}.bg-\[var\(--accent-soft\)\]{background-color:var(--accent-soft)}.bg-\[var\(--bg-panel\)\]{background-color:var(--bg-panel)}.bg-\[var\(--tooltip-bg\)\]{background-color:var(--tooltip-bg)}.bg-current{background-color:currentColor}.bg-transparent{background-color:initial}.bg-white{--tw-bg-opacity:1;background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.fill-current{fill:currentColor}.object-contain{object-fit:contain}.p-0{padding:0}.p-\[15px\]{padding:15px}.p-\[2em\]{padding:2em}.p-\[6em_2em_2em_2em\]{padding:6em 2em 2em}.px-3{padding-left:.75rem;padding-right:.75rem}.px-\[14px\]{padding-left:14px;padding-right:14px}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-\[2px\]{padding-bottom:2px;padding-top:2px}.py-\[9px\]{padding-bottom:9px;padding-top:9px}.pb-\[30px\]{padding-bottom:30px}.pb-\[62px\]{padding-bottom:62px}.pl-2{padding-left:.5rem}.pr-\[1\.4em\]{padding-right:1.4em}.pt-14{padding-top:3.5rem}.pt-8{padding-top:2rem}.pt-\[18px\]{padding-top:18px}.pt-\[62px\]{padding-top:62px}.text-left{text-align:left}.text-center{text-align:center}.font-\[\'Courier_New\'\2c Consolas\2c monospace\]{font-family:Courier New,Consolas,monospace}.font-\[\'Manrope\'\2c \'Space_Grotesk\'\2c sans-serif\]{font-family:Manrope,Space Grotesk,sans-serif}.font-\[\'Space_Grotesk\'\2c \'Manrope\'\2c sans-serif\]{font-family:Space Grotesk,Manrope,sans-serif}.text-\[\.82rem\]{font-size:.82rem}.text-\[\.84rem\]{font-size:.84rem}.text-\[\.92rem\]{font-size:.92rem}.text-\[\.95rem\]{font-size:.95rem}.text-\[\.98rem\]{font-size:.98rem}.text-\[0\.9rem\]{font-size:.9rem}.text-\[1\.05rem\]{font-size:1.05rem}.text-\[1\.2rem\]{font-size:1.2rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[2\.5rem\]{font-size:2.5rem}.text-\[4rem\]{font-size:4rem}.text-\[clamp\(\.95rem\2c 3\.8vw\2c 1\.35rem\)\]{font-size:clamp(.95rem,3.8vw,1.35rem)}.text-\[clamp\(1\.18rem\2c 6\.6vw\2c 1\.8rem\)\]{font-size:clamp(1.18rem,6.6vw,1.8rem)}.text-\[clamp\(1\.6rem\2c 9vw\2c 2\.6rem\)\]{font-size:clamp(1.6rem,9vw,2.6rem)}.text-\[clamp\(1\.7rem\2c 9vw\2c 2\.6rem\)\]{font-size:clamp(1.7rem,9vw,2.6rem)}.text-\[clamp\(1\.8rem\2c 11vw\2c 2\.8rem\)\]{font-size:clamp(1.8rem,11vw,2.8rem)}.text-\[clamp\(1\.9rem\2c 11vw\2c 3rem\)\]{font-size:clamp(1.9rem,11vw,3rem)}.text-\[clamp\(2\.4rem\2c 14vw\2c 4\.6rem\)\]{font-size:clamp(2.4rem,14vw,4.6rem)}.text-base{font-size:1rem;line-height:1.5rem}.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-\[0\.94\]{line-height:.94}.leading-\[0\.98\]{line-height:.98}.leading-\[1\.08\]{line-height:1.08}.leading-\[1\.15\]{line-height:1.15}.leading-\[1\.25\]{line-height:1.25}.leading-\[1\.2\]{line-height:1.2}.leading-\[1\.45\]{line-height:1.45}.leading-\[1\.5\]{line-height:1.5}.leading-\[1\.6\]{line-height:1.6}.leading-\[1\.7\]{line-height:1.7}.leading-none{line-height:1}.tracking-\[-0\.02em\]{letter-spacing:-.02em}.tracking-\[-0\.03em\]{letter-spacing:-.03em}.tracking-\[-2px\]{letter-spacing:-2px}.tracking-\[0\.01em\]{letter-spacing:.01em}.tracking-\[0\.06em\]{letter-spacing:.06em}.tracking-\[0\.08em\]{letter-spacing:.08em}.tracking-\[0\.12em\]{letter-spacing:.12em}.tracking-\[0\.14em\]{letter-spacing:.14em}.tracking-\[0\.18em\]{letter-spacing:.18em}.tracking-\[0\.1em\]{letter-spacing:.1em}.tracking-\[0\.2em\]{letter-spacing:.2em}.text-\[\#111\]{--tw-text-opacity:1;color:#111;color:rgb(17 17 17/var(--tw-text-opacity,1))}.text-\[\#e9e9ef\]{--tw-text-opacity:1;color:#e9e9ef;color:rgb(233 233 239/var(--tw-text-opacity,1))}.text-\[var\(--accent\)\]{color:var(--accent)}.text-\[var\(--body-muted\)\]{color:var(--body-muted)}.text-\[var\(--code-string\)\]{color:var(--code-string)}.text-\[var\(--hero-body\)\]{color:var(--hero-body)}.text-\[var\(--link-muted\)\]{color:var(--link-muted)}.text-\[var\(--muted\)\]{color:var(--muted)}.text-\[var\(--project-muted\)\]{color:var(--project-muted)}.text-\[var\(--project-title\)\]{color:var(--project-title)}.text-\[var\(--text\)\]{color:var(--text)}.text-black{--tw-text-opacity:1;color:#000;color:rgb(0 0 0/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1))}.no-underline{-webkit-text-decoration-line:none;text-decoration-line:none}.opacity-0{opacity:0}.outline{outline-style:solid}.blur{--tw-blur:blur(8px)}.blur,.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)}.invert{--tw-invert:invert(100%)}.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-\[12px\]{--tw-backdrop-blur:blur(12px)}.backdrop-blur-\[12px\],.backdrop-filter{-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{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-\[background\2c color\]{transition-duration:.15s;transition-property:background,color;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-\[color\2c opacity\]{transition-duration:.15s;transition-property:color,opacity;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-property:color,background-color,border-color,fill,stroke,-webkit-text-decoration-color;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,-webkit-text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-150,.transition-colors{transition-duration:.15s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-linear{transition-timing-function:linear}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.will-change-transform{will-change:transform}.\[color\:var\(--sm-accent\2c \#ff0000\)\]{color:red;color:var(--sm-accent,red)}.\[isolation\:isolate\]{isolation:isolate}.\[transform-origin\:50\%_100\%\]{transform-origin:50% 100%}.\[will-change\:transform\]{will-change:transform}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.before\:absolute:before{content:var(--tw-content);position:absolute}.before\:inset-0:before{content:var(--tw-content);inset:0}.before\:z-0:before{content:var(--tw-content);z-index:0}.before\:origin-left:before{content:var(--tw-content);transform-origin:left}.before\:translate-y-full:before{--tw-translate-y:100%}.before\:scale-x-0:before,.before\:translate-y-full:before{content:var(--tw-content);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))}.before\:scale-x-0:before{--tw-scale-x:0}.before\:bg-\[var\(--skill-hover\)\]:before{background-color:var(--skill-hover);content:var(--tw-content)}.before\:bg-\[linear-gradient\(90deg\2c var\(--accent-soft\)_0\%\2c transparent_75\%\)\]:before{background-image:linear-gradient(90deg,var(--accent-soft) 0,#0000 75%);content:var(--tw-content)}.before\:transition-transform:before{content:var(--tw-content);transition-duration:.15s;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.before\:duration-300:before{content:var(--tw-content);transition-duration:.3s}.before\:content-\[\'\'\]:before{--tw-content:"";content:var(--tw-content)}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:left-3:after{content:var(--tw-content);left:.75rem}.after\:top-3:after{content:var(--tw-content);top:.75rem}.after\:z-\[1\]:after{content:var(--tw-content);z-index:1}.after\:h-2:after{content:var(--tw-content);height:.5rem}.after\:w-2:after{content:var(--tw-content);width:.5rem}.after\:rounded-full:after{border-radius:9999px;content:var(--tw-content)}.after\:bg-\[color-mix\(in_srgb\2c var\(--accent\)_55\%\2c transparent\)\]:after{background-color:color-mix(in srgb,var(--accent) 55%,#0000);content:var(--tw-content)}.odd\:bg-\[color-mix\(in_srgb\2c var\(--accent-soft\)_20\%\2c transparent\)\]:nth-child(odd){background-color:color-mix(in srgb,var(--accent-soft) 20%,#0000)}.hover\:-translate-y-px:hover{--tw-translate-y:-1px}.hover\:-translate-y-px:hover,.hover\:scale-\[1\.03\]: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\.03\]:hover{--tw-scale-x:1.03;--tw-scale-y:1.03}.hover\:border-\[var\(--hover-border\)\]:hover{border-color:var(--hover-border)}.hover\:bg-\[var\(--accent-soft\)\]:hover{background-color:var(--accent-soft)}.hover\:bg-\[var\(--card-hover\)\]:hover{background-color:var(--card-hover)}.hover\:text-\[var\(--text\)\]:hover{color:var(--text)}.hover\:before\:translate-y-0:hover:before{--tw-translate-y:0px}.hover\:before\:scale-x-100:hover:before,.hover\:before\:translate-y-0:hover:before{content:var(--tw-content);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\:before\:scale-x-100:hover:before{--tw-scale-x:1}.group:hover .group-hover\:bg-\[var\(--hover-border\)\]{background-color:var(--hover-border)}.group:hover .group-hover\:text-\[var\(--text\)\]{color:var(--text)}@media (max-width:420px){.max-\[420px\]\:h-\[74px\]{height:74px}.max-\[420px\]\:min-h-\[calc\(100svh_-_112px\)\]{min-height:calc(100svh - 112px)}.max-\[420px\]\:w-\[74px\]{width:74px}.max-\[420px\]\:max-w-full{max-width:100%}.max-\[420px\]\:gap-2{gap:.5rem}.max-\[420px\]\:px-\[10px\]{padding-left:10px;padding-right:10px}.max-\[420px\]\:py-\[7px\]{padding-bottom:7px;padding-top:7px}.max-\[420px\]\:pb-\[42px\]{padding-bottom:42px}.max-\[420px\]\:pl-\[7px\]{padding-left:7px}.max-\[420px\]\:pt-\[38px\]{padding-top:38px}.max-\[420px\]\:text-\[\.84rem\]{font-size:.84rem}.max-\[420px\]\:text-\[2\.2rem\]{font-size:2.2rem}.max-\[420px\]\:text-\[clamp\(2\.2rem\2c 15vw\2c 3\.7rem\)\]{font-size:clamp(2.2rem,15vw,3.7rem)}.max-\[420px\]\:leading-\[1\.55\]{line-height:1.55}.max-\[420px\]\:tracking-\[0\.1em\]{letter-spacing:.1em}}@media (min-width:720px){.min-\[720px\]\:mr-\[clamp\(88px\2c 5vw\2c 180px\)\]{margin-right:clamp(88px,5vw,180px)}.min-\[720px\]\:mt-0{margin-top:0}.min-\[720px\]\:mt-\[22px\]{margin-top:22px}.min-\[720px\]\:block{display:block}.min-\[720px\]\:flex{display:flex}.min-\[720px\]\:h-\[100vh\]{height:100vh}.min-\[720px\]\:h-\[90px\]{height:90px}.min-\[720px\]\:min-h-\[106px\]{min-height:106px}.min-\[720px\]\:min-h-\[90px\]{min-height:90px}.min-\[720px\]\:min-h-\[calc\(100vh_-_78px\)\]{min-height:calc(100vh - 78px)}.min-\[720px\]\:w-\[90px\]{width:90px}.min-\[720px\]\:max-w-\[340px\]{max-width:340px}.min-\[720px\]\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.min-\[720px\]\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.min-\[720px\]\:flex-row{flex-direction:row}.min-\[720px\]\:items-end{align-items:flex-end}.min-\[720px\]\:items-center{align-items:center}.min-\[720px\]\:justify-start{justify-content:flex-start}.min-\[720px\]\:justify-between{justify-content:space-between}.min-\[720px\]\:gap-4{gap:1rem}.min-\[720px\]\:gap-\[10px\]{gap:10px}.min-\[720px\]\:self-auto{align-self:auto}.min-\[720px\]\:border-b-0{border-bottom-width:0}.min-\[720px\]\:border-r{border-right-width:1px}.min-\[720px\]\:py-5{padding-bottom:1.25rem;padding-top:1.25rem}.min-\[720px\]\:pb-\[70px\]{padding-bottom:70px}.min-\[720px\]\:pb-\[76px\]{padding-bottom:76px}.min-\[720px\]\:pt-\[76px\]{padding-top:76px}.min-\[720px\]\:pt-\[9vh\]{padding-top:9vh}.min-\[720px\]\:text-right{text-align:right}.min-\[720px\]\:text-\[11px\]{font-size:11px}.min-\[720px\]\:text-\[2\.35rem\]{font-size:2.35rem}.min-\[720px\]\:text-\[clamp\(1\.05rem\2c 2\.1vw\2c 1\.55rem\)\]{font-size:clamp(1.05rem,2.1vw,1.55rem)}.min-\[720px\]\:text-\[clamp\(3\.6rem\2c 11vw\2c 6\.4rem\)\]{font-size:clamp(3.6rem,11vw,6.4rem)}.min-\[720px\]\:even\:border-r-0:nth-child(2n){border-right-width:0}.group:hover .min-\[720px\]\:group-hover\:-translate-y-1{--tw-translate-y:-0.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))}.group:hover .min-\[720px\]\:group-hover\:opacity-100{opacity:1}}@media (min-width:980px){.min-\[980px\]\:mt-20{margin-top:5rem}.min-\[980px\]\:mt-8{margin-top:2rem}.min-\[980px\]\:mt-\[18px\]{margin-top:18px}.min-\[980px\]\:mt-\[26px\]{margin-top:26px}.min-\[980px\]\:mt-\[30px\]{margin-top:30px}.min-\[980px\]\:mt-\[38px\]{margin-top:38px}.min-\[980px\]\:mt-\[42px\]{margin-top:42px}.min-\[980px\]\:h-11{height:2.75rem}.min-\[980px\]\:min-h-\[104px\]{min-height:104px}.min-\[980px\]\:min-h-\[calc\(100vh_-_80px\)\]{min-height:calc(100vh - 80px)}.min-\[980px\]\:w-11{width:2.75rem}.min-\[980px\]\:max-w-\[610px\]{max-width:610px}.min-\[980px\]\:max-w-\[690px\]{max-width:690px}.min-\[980px\]\:max-w-\[900px\]{max-width:900px}.min-\[980px\]\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.min-\[980px\]\:grid-cols-\[190px_1fr\]{grid-template-columns:190px 1fr}.min-\[980px\]\:gap-3{gap:.75rem}.min-\[980px\]\:gap-4{gap:1rem}.min-\[980px\]\:gap-6{gap:1.5rem}.min-\[980px\]\:gap-8{gap:2rem}.min-\[980px\]\:pb-\[42px\]{padding-bottom:42px}.min-\[980px\]\:pb-\[92px\]{padding-bottom:92px}.min-\[980px\]\:pt-\[12vh\]{padding-top:12vh}.min-\[980px\]\:pt-\[22px\]{padding-top:22px}.min-\[980px\]\:pt-\[92px\]{padding-top:92px}.min-\[980px\]\:text-\[\.98rem\]{font-size:.98rem}.min-\[980px\]\:text-\[1\.25rem\]{font-size:1.25rem}.min-\[980px\]\:text-\[11px\]{font-size:11px}.min-\[980px\]\:text-\[clamp\(\.85rem\2c 1\.8vw\2c 1rem\)\]{font-size:clamp(.85rem,1.8vw,1rem)}.min-\[980px\]\:text-\[clamp\(1\.15rem\2c 1\.5vw\2c 1\.8rem\)\]{font-size:clamp(1.15rem,1.5vw,1.8rem)}.min-\[980px\]\:text-\[clamp\(1\.4rem\2c 4vw\2c 2\.8rem\)\]{font-size:clamp(1.4rem,4vw,2.8rem)}.min-\[980px\]\:text-\[clamp\(1\.9rem\2c 11vw\2c 3rem\)\]{font-size:clamp(1.9rem,11vw,3rem)}.min-\[980px\]\:text-\[clamp\(1\.9rem\2c 4\.4vw\2c 3\.2rem\)\]{font-size:clamp(1.9rem,4.4vw,3.2rem)}.min-\[980px\]\:text-\[clamp\(2rem\2c 5\.8vw\2c 4rem\)\]{font-size:clamp(2rem,5.8vw,4rem)}.min-\[980px\]\:text-\[clamp\(2rem\2c 7vw\2c 4\.4rem\)\]{font-size:clamp(2rem,7vw,4.4rem)}.min-\[980px\]\:text-\[clamp\(4\.8rem\2c 12vw\2c 8\.25rem\)\]{font-size:clamp(4.8rem,12vw,8.25rem)}.min-\[980px\]\:text-xs{font-size:.75rem;line-height:1rem}.min-\[980px\]\:tracking-\[0\.15em\]{letter-spacing:.15em}.min-\[980px\]\:even\:border-r:nth-child(2n){border-right-width:1px}.group:hover .min-\[980px\]\:group-hover\:translate-x-1{--tw-translate-x:0.25rem}.group:hover .min-\[980px\]\:group-hover\:translate-x-1,.group:hover .min-\[980px\]\:group-hover\:translate-x-\[-4px\]{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 .min-\[980px\]\:group-hover\:translate-x-\[-4px\]{--tw-translate-x:-4px}.min-\[980px\]\:\[\&\:nth-child\(4n\)\]\:border-r-0:nth-child(4n){border-right-width:0}}@media (min-width:720px){.min-\[720px\]\:\[\&\:nth-last-child\(-n\+2\)\]\:border-b-0:nth-last-child(-n+2){border-bottom-width:0}}@media (min-width:980px){.min-\[980px\]\:\[\&\:nth-last-child\(-n\+4\)\]\:border-b-0:nth-last-child(-n+4){border-bottom-width:0}}:root{--bg:#040408;--bg-top:#2d0b66;--line:#1d1440;--line-soft:#2a1b57;--text:#edf1f8;--muted:#b197ff;--accent:#8f4dff;--accent-soft:#8f4dff2e;--bg-panel:#12092aa6;--tooltip-bg:#190e37;--link-muted:#b8a6ff;--hero-body:#d2c3ff;--body-muted:#c5b2ff;--project-muted:#bda8ff;--progress-track:#ffffff0a;--toggle-border:#dce5ff;--pill-border:#dce5ff;--hover-border:#a67cff;--hover-bg:#7f47ee;--card-hover:#8f4dff14;--skill-hover:#8f4dff2e;--project-title:#f0e9ff;--code-string:#68c690}.site-shell.theme-light{--bg:#eef3ff;--bg-top:#dfe9ff;--line:#ccd7e8;--line-soft:#b8c8de;--text:#0f1b30;--muted:#3f5fb3;--accent:#1d4fd1;--accent-soft:#1d4fd124;--bg-panel:#f4f8fff2;--tooltip-bg:#e6eeff;--link-muted:#3e5aac;--hero-body:#2f4ea8;--body-muted:#3655ad;--project-muted:#3959b2;--progress-track:#1d4fd12e;--toggle-border:#728dbd;--pill-border:#728dbd;--hover-border:#315fce;--hover-bg:#1d4fd129;--card-hover:#1d4fd11a;--skill-hover:#1d4fd12e;--project-title:#122543;--code-string:#196a44;background:linear-gradient(180deg,#fff,#f2f5fb 52%,#e9eef6)}html{background:#040408;overflow-x:clip;overflow-y:auto;scroll-behavior:smooth}*{box-sizing:border-box}body{margin:0}#root,body{background:#040408;overflow-x:hidden;overflow-y:clip}#root{min-height:100dvh}.site-shell{background:linear-gradient(180deg,#000,#06050f 74%,#2d0b66),#040408;background:linear-gradient(180deg,#000 0,#06050f 74%,var(--bg-top) 100%),var(--bg);color:#edf1f8;color:var(--text);min-height:100vh;min-height:100dvh;overflow-x:hidden;overflow-y:clip;transition:background-color .35s ease,color .35s ease}.scroll-progress{background:#ffffff0a;background:var(--progress-track);height:3px;left:0;position:fixed;top:0;width:100%;z-index:10000}.scroll-progress-bar{background:linear-gradient(90deg,#4f82ff,#7aa1ff);height:100%;transition:width .15s linear}.theme-light .scroll-progress-bar{background:linear-gradient(90deg,#3d74e8,#6f92f2)}.portfolio-page{transform:translateY(100vh);transition:transform 1s cubic-bezier(.25,1,.5,1)}.portfolio-page.page-enter{transform:translateY(0)}.section-pad{margin:0 auto;width:calc(100% - 28px)}.desktop-pill-nav{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid color-mix(in srgb,#2a1b57 62%,#fff 18%);border:1px solid color-mix(in srgb,var(--line-soft) 62%,#fff 18%);border-radius:999px;box-shadow:0 12px 30px #03061073,inset 0 1px 0 #ffffff14;padding:12px 20px}.theme-light .desktop-pill-nav{box-shadow:0 8px 22px #2139621f,inset 0 1px 0 #fffc}.nav-dot:after{background:#8f4dff;background:var(--accent);border-radius:50%;bottom:-8px;content:"";height:6px;left:50%;opacity:0;position:absolute;transform:translateX(-50%) scale(.2);transition:transform .2s ease,opacity .2s ease;width:6px}.nav-dot:focus-visible:after,.nav-dot:hover:after{opacity:1;transform:translateX(-50%) scale(1)}.scroll-fill-btn{isolation:isolate;overflow:hidden;position:relative}.scroll-fill-btn:before{background:#7f47ee;background:var(--hover-bg);border-radius:inherit;content:"";inset:0;pointer-events:none;position:absolute;transform:scaleY(0);transform-origin:top;transition:transform .4s ease;z-index:0}.scroll-fill-btn:focus-visible:before,.scroll-fill-btn:hover:before{transform:scaleY(1);transform-origin:bottom}@keyframes code-caret-blink{0%,49%{opacity:1}50%,to{opacity:0}}@media (min-width:720px){.section-pad{width:calc(100% - 44px)}}@media (min-width:980px){.section-pad{width:min(1160px,calc(100% - 64px))}}@media (min-width:1240px){.section-pad{width:min(1220px,calc(100% - 84px))}}.loader-container{align-items:center;background-color:#151515;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;transition:transform 1s cubic-bezier(.25,1,.5,1),border-radius 1s cubic-bezier(.25,1,.5,1);width:100vw;z-index:9999}.loader-text{color:#fff;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:3rem;font-weight:200;letter-spacing:2px;text-align:center}.loader-text.lang-ar{font-family:Arial,sans-serif;font-weight:400}.loader-content{transition:opacity .3s ease-out}@keyframes fadeInOut{0%{opacity:0;transform:translateY(10px)}20%{opacity:1;transform:translateY(0)}80%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.loader-container.slide-up{border-bottom-left-radius:50% 20%;border-bottom-right-radius:50% 20%;transform:translateY(-100%)}.loader-container.slide-up .loader-content{opacity:0}.darkveil-canvas{display:block;height:100%;width:100%}
/*# sourceMappingURL=main.6c33c021.css.map*/