@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-space-y-reverse:0;--tw-space-x-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-purple-400:oklch(71.4% .203 305.504);--color-gray-400:oklch(70.7% .022 261.325);--spacing:.25rem;--container-2xl:42rem;--container-3xl:48rem;--container-7xl:80rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5/2.25);--text-5xl:3rem;--text-5xl--line-height:1;--text-6xl:3.75rem;--text-6xl--line-height:1;--text-7xl:4.5rem;--text-7xl--line-height:1;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--leading-relaxed:1.625;--radius-lg:.5rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);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}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.fixed{position:fixed}.relative{position:relative}.top-0{top:calc(var(--spacing)*0)}.z-10{z-index:10}.z-50{z-index:50}.mx-auto{margin-inline:auto}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-12{margin-top:calc(var(--spacing)*12)}.mr-2{margin-right:calc(var(--spacing)*2)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.mb-8{margin-bottom:calc(var(--spacing)*8)}.mb-12{margin-bottom:calc(var(--spacing)*12)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-flex{display:inline-flex}.h-5{height:calc(var(--spacing)*5)}.h-6{height:calc(var(--spacing)*6)}.h-12{height:calc(var(--spacing)*12)}.min-h-screen{min-height:100vh}.w-5{width:calc(var(--spacing)*5)}.w-6{width:calc(var(--spacing)*6)}.w-12{width:calc(var(--spacing)*12)}.w-full{width:100%}.max-w-2xl{max-width:var(--container-2xl)}.max-w-3xl{max-width:var(--container-3xl)}.max-w-7xl{max-width:var(--container-7xl)}.max-w-80{max-width:calc(var(--spacing)*80)}.cursor-pointer{cursor:pointer}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:calc(var(--spacing)*2)}.gap-4{gap:calc(var(--spacing)*4)}.gap-6{gap:calc(var(--spacing)*6)}.gap-12{gap:calc(var(--spacing)*12)}:where(.space-y-0>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*0)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*0)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*2)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*3)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*3)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*4)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*6)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*6)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-x-8>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*8)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*8)*calc(1 - var(--tw-space-x-reverse)))}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.p-6{padding:calc(var(--spacing)*6)}.p-8{padding:calc(var(--spacing)*8)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-6{padding-inline:calc(var(--spacing)*6)}.py-1{padding-block:calc(var(--spacing)*1)}.py-4{padding-block:calc(var(--spacing)*4)}.py-12{padding-block:calc(var(--spacing)*12)}.py-20{padding-block:calc(var(--spacing)*20)}.pt-4{padding-top:calc(var(--spacing)*4)}.pt-20{padding-top:calc(var(--spacing)*20)}.pb-1{padding-bottom:calc(var(--spacing)*1)}.pb-2{padding-bottom:calc(var(--spacing)*2)}.pb-12{padding-bottom:calc(var(--spacing)*12)}.text-center{text-align:center}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-gray-400{color:var(--color-gray-400)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.delay-100{transition-delay:.1s}.delay-200{transition-delay:.2s}.delay-300{transition-delay:.3s}.delay-400{transition-delay:.4s}@media(hover:hover){.hover\:text-purple-400:hover{color:var(--color-purple-400)}.hover\:opacity-80:hover{opacity:.8}}@media(min-width:48rem){.md\:mt-0{margin-top:calc(var(--spacing)*0)}.md\:block{display:block}.md\:flex{display:flex}.md\:hidden{display:none}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:flex-row{flex-direction:row}.md\:items-start{align-items:flex-start}.md\:justify-between{justify-content:space-between}.md\:p-8{padding:calc(var(--spacing)*8)}.md\:p-12{padding:calc(var(--spacing)*12)}.md\:text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.md\:text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}}@media(min-width:64rem){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:text-7xl{font-size:var(--text-7xl);line-height:var(--tw-leading,var(--text-7xl--line-height))}}}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@layer base{*{margin:0;padding:0;box-sizing:border-box}}:root{--bg-primary: #0a0e1a;--bg-primary-rgb: 10, 14, 26;--bg-secondary: #111827;--bg-card: #1a1f35;--accent: #7c3aed;--accent-rgb: 124, 58, 237;--accent-bright: #a78bfa;--accent-secondary: #ec4899;--accent-secondary-rgb: 236, 72, 153;--text-primary: #e2e8f0;--text-secondary: #94a3b8;--border: #2d3748;--code-bg: #0d1117;--code-border: #30363d;--code-keyword: #ff7b72;--code-string: #a5d6ff;--code-property: #79c0ff;--code-function: #d2a8ff;--code-comment: #8b949e}[data-theme=light]{--bg-primary: #fafafa;--bg-primary-rgb: 250, 250, 250;--bg-secondary: #ffffff;--bg-card: #ffffff;--accent: #7c3aed;--accent-rgb: 124, 58, 237;--accent-bright: #6d28d9;--accent-secondary: #ec4899;--accent-secondary-rgb: 236, 72, 153;--text-primary: #1a1a1a;--text-secondary: #6b7280;--border: #e5e7eb;--code-bg: #f6f8fa;--code-border: #d0d7de;--code-keyword: #cf222e;--code-string: #0550ae;--code-property: #8250df;--code-function: #8250df;--code-comment: #6e7781}body{font-family:Space Grotesk,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}@media(min-width:768px){body{font-size:18px}}.code-font{font-family:Fira Code,monospace}html{scroll-behavior:smooth}@layer components{.grid-background{background-image:linear-gradient(to right,rgba(var(--accent-rgb),.05) 1px,transparent 1px),linear-gradient(to bottom,rgba(var(--accent-rgb),.05) 1px,transparent 1px);background-size:40px 40px;position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;opacity:.6;transition:opacity .3s}[data-theme=light] .grid-background{background-image:linear-gradient(to right,rgba(var(--accent-rgb),.03) 1px,transparent 1px),linear-gradient(to bottom,rgba(var(--accent-rgb),.03) 1px,transparent 1px)}.content-wrapper{position:relative;z-index:1}.theme-toggle{width:50px;height:26px;background:var(--border);border-radius:13px;position:relative;cursor:pointer;transition:background .15s}.theme-toggle:hover{background:var(--accent)}.theme-toggle-slider{position:absolute;top:3px;left:3px;width:20px;height:20px;background:var(--bg-card);border-radius:50%;transition:transform .15s;display:flex;align-items:center;justify-content:center;font-size:10px}.theme-toggle.active .theme-toggle-slider{transform:translate(24px)}.nav-blur{background:rgba(var(--bg-primary-rgb),.8);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);transition:background .3s}.gradient-text{background:linear-gradient(135deg,var(--accent-bright) 0%,var(--accent) 50%,var(--accent-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.profile-image{width:100%;height:100%;object-fit:cover;border-radius:1rem;border:3px solid var(--accent);box-shadow:0 20px 60px rgba(var(--accent-rgb),.3);transition:transform .2s,box-shadow .2s}.profile-image:hover{transform:scale(1.02);box-shadow:0 25px 70px rgba(var(--accent-rgb),.4)}.profile-container{position:relative;max-width:500px;margin:0 auto}.profile-container:before{content:"";position:absolute;inset:-10px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-secondary) 100%);border-radius:1.25rem;opacity:.2;z-index:-1}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:1rem;transition:all .15s cubic-bezier(.4,0,.2,1)}.card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 20px 60px rgba(var(--accent-rgb),.15)}[data-theme=light] .card:hover{box-shadow:0 20px 60px rgba(var(--accent-rgb),.1)}.glow-on-hover{position:relative;overflow:hidden}.glow-on-hover:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(var(--accent-rgb),.1),transparent);transition:left .25s}.glow-on-hover:hover:before{left:100%}.code-block{background:var(--code-bg);border:1px solid var(--code-border);border-radius:.5rem;padding:1.5rem;font-family:Fira Code,monospace;font-size:1rem;line-height:1.8;overflow-x:auto}.code-block .keyword{color:var(--code-keyword)}.code-block .string{color:var(--code-string)}.code-block .property{color:var(--code-property)}.code-block .function{color:var(--code-function)}.code-block .comment{color:var(--code-comment)}.skill-container{position:relative;height:3px;background:var(--border);border-radius:2px;overflow:hidden}.skill-fill{height:100%;background:linear-gradient(90deg,var(--accent) 0%,var(--accent-bright) 50%,var(--accent-secondary) 100%);border-radius:2px;transition:width 1.5s cubic-bezier(.4,0,.2,1);position:relative}.skill-fill:after{content:"";position:absolute;top:0;right:0;width:30%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3));animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.timeline-item{position:relative;padding-left:2.5rem}.timeline-item:before{content:"";position:absolute;left:0;top:0;bottom:-3rem;width:2px;background:linear-gradient(180deg,var(--accent) 0%,var(--border) 100%)}.timeline-item:last-child:before{background:linear-gradient(180deg,var(--accent) 0%,transparent 100%)}.timeline-dot{position:absolute;left:-5px;top:.5rem;width:12px;height:12px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-primary);box-shadow:0 0 20px var(--accent)}.btn-primary{background:var(--accent);color:#fff;padding:.875rem 2rem;border-radius:.5rem;font-weight:600;transition:all .15s;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem}.btn-primary:hover{background:var(--accent-bright);transform:translateY(-2px);box-shadow:0 10px 30px rgba(var(--accent-rgb),.3)}.btn-secondary{background:transparent;color:var(--text-primary);padding:.875rem 2rem;border:1px solid var(--border);border-radius:.5rem;font-weight:600;transition:all .15s;cursor:pointer;display:inline-flex;align-items:center;gap:.5rem}.btn-secondary:hover{border-color:var(--accent);color:var(--accent);background:rgba(var(--accent-rgb),.05)}.tech-badge{padding:.5rem 1rem;background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.3);border-radius:.375rem;font-size:.875rem;font-weight:500;color:var(--accent-bright);transition:all .15s;font-family:Fira Code,monospace}.tech-badge:hover{background:rgba(var(--accent-rgb),.2);border-color:var(--accent);transform:translateY(-2px)}.stat-card{text-align:center;padding:1.5rem;background:rgba(var(--accent-rgb),.05);border:1px solid rgba(var(--accent-rgb),.2);border-radius:.75rem;transition:all .15s}.stat-card:hover{background:rgba(var(--accent-rgb),.1);border-color:var(--accent)}.stat-number{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,var(--accent-bright) 0%,var(--accent) 50%,var(--accent-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.fade-in{animation:fadeInUp .8s ease-out forwards;opacity:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.delay-100{animation-delay:.1s}.delay-200{animation-delay:.2s}.delay-300{animation-delay:.3s}.delay-400{animation-delay:.4s}input,textarea{width:100%;padding:1rem 1.25rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:1rem;transition:all .15s}input:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.1)}textarea{resize:vertical;min-height:150px}.icon-link{width:2.75rem;height:2.75rem;display:inline-flex;align-items:center;justify-content:center;border-radius:.5rem;border:1px solid var(--border);color:var(--text-secondary);transition:all .15s;font-size:1.25rem}.icon-link:hover{border-color:var(--accent);color:var(--accent);background:rgba(var(--accent-rgb),.05);transform:translateY(-2px)}.project-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(var(--accent-rgb),.1),rgba(var(--accent-secondary-rgb),.1));opacity:0;transition:opacity .2s;border-radius:1rem}.card:hover .project-overlay{opacity:1}.mobile-menu{max-height:0;overflow:hidden;transition:max-height .3s ease}.mobile-menu.active{max-height:500px}.section{padding:6rem 0}@media(max-width:768px){.section{padding:3rem 0}}::selection{background:var(--accent);color:#fff}.accent-line{width:4rem;height:3px;background:linear-gradient(90deg,var(--accent) 0%,var(--accent-secondary) 100%);margin-bottom:2rem}.hero-glow{position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(var(--accent-rgb),.15) 0%,transparent 70%);border-radius:50%;filter:blur(60px);pointer-events:none}[data-theme=light] .hero-glow{background:radial-gradient(circle,rgba(var(--accent-rgb),.08) 0%,transparent 70%)}}
