@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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration: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-blue-600:oklch(54.6% .245 262.881);--color-gray-800:oklch(27.8% .033 256.848);--color-white:#fff;--spacing:.25rem;--container-md:28rem;--container-lg:32rem;--container-2xl:42rem;--container-3xl:48rem;--container-6xl:72rem;--container-7xl:80rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-base:var(--primary);--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--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-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--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;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-wide:.025em;--tracking-widest:.1em;--leading-snug:1.375;--leading-relaxed:1.625;--radius-sm:.25rem;--radius-lg:.5rem;--radius-2xl:1rem;--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);--primary:#cad2c5;--secondary:#84a98c;--tertiary:#2f3e46;--complementary:#52796f;--contrast:#354f52;--background:#2f3e46;--text-muted:var(--secondary);--surface:var(--tertiary);--surface-elevated:var(--complementary);--border:var(--contrast)}}@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{.app-container{min-height:100vh;padding-inline:calc(var(--spacing)*4);background-image:radial-gradient(circle,#2f3e4699 1px,#0000 1px);justify-content:center}@supports (color:color-mix(in lab,red,red)){.app-container{background-image:radial-gradient(circle,color-mix(in srgb,var(--surface)60%,transparent)1px,transparent 1px)}}.app-container{background-size:28px 28px;transition:background-color .3s,color .3s}.app-content{width:100%;max-width:var(--container-md);margin-inline:auto}@media(min-width:48rem){.app-content{max-width:var(--container-6xl)}}.tech-grid-wrapper{width:100%}.tech-grid-inner{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:10px;display:grid}.tech-card{background-color:var(--surface);border:1px solid var(--border);cursor:default;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:12px 8px;transition:transform .2s,background-color .2s,box-shadow .2s;display:flex}.tech-label{color:var(--text-muted);letter-spacing:.02em;text-align:center;font-size:10px;font-weight:500;line-height:1.2}}@layer utilities{.mx-auto{margin-inline:auto}.mt-0\.5{margin-top:calc(var(--spacing)*.5)}.mt-1{margin-top:calc(var(--spacing)*1)}.mt-8{margin-top:calc(var(--spacing)*8)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-3{margin-bottom:calc(var(--spacing)*3)}.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-10{margin-bottom:calc(var(--spacing)*10)}.mb-12{margin-bottom:calc(var(--spacing)*12)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.h-36{height:calc(var(--spacing)*36)}.h-px{height:1px}.min-h-0{min-height:calc(var(--spacing)*0)}.min-h-screen{min-height:100vh}.w-16{width:calc(var(--spacing)*16)}.w-36{width:calc(var(--spacing)*36)}.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-\[200px\]{max-width:200px}.max-w-lg{max-width:var(--container-lg)}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing)*1)}.gap-1\.5{gap:calc(var(--spacing)*1.5)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.gap-5{gap:calc(var(--spacing)*5)}.gap-6{gap:calc(var(--spacing)*6)}.gap-8{gap:calc(var(--spacing)*8)}.gap-10{gap:calc(var(--spacing)*10)}:where(.space-y-2\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*2.5)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*2.5)*calc(1 - var(--tw-space-y-reverse)))}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-t-sm{border-top-left-radius:var(--radius-sm);border-top-right-radius:var(--radius-sm)}.rounded-b-sm{border-bottom-right-radius:var(--radius-sm);border-bottom-left-radius:var(--radius-sm)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-\[color\:var\(--tertiary\)\]{border-color:var(--tertiary)}.bg-\[color\:var\(--contrast\)\]{background-color:var(--contrast)}.bg-\[color\:var\(--primary\)\]{background-color:var(--primary)}.bg-\[color\:var\(--secondary\)\]{background-color:var(--secondary)}.object-cover{object-fit:cover}.p-4{padding:calc(var(--spacing)*4)}.p-6{padding:calc(var(--spacing)*6)}.p-8{padding:calc(var(--spacing)*8)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-2\.5{padding-inline:calc(var(--spacing)*2.5)}.px-4{padding-inline:calc(var(--spacing)*4)}.py-0\.5{padding-block:calc(var(--spacing)*.5)}.py-1{padding-block:calc(var(--spacing)*1)}.py-3{padding-block:calc(var(--spacing)*3)}.py-4{padding-block:calc(var(--spacing)*4)}.py-16{padding-block:calc(var(--spacing)*16)}.pt-1{padding-top:calc(var(--spacing)*1)}.text-center{text-align:center}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--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-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--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))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-snug{--tw-leading:var(--leading-snug);line-height:var(--leading-snug)}.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)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.text-pretty{text-wrap:pretty}.text-\[color\:var\(--complementary\)\]{color:var(--complementary)}.text-\[color\:var\(--contrast\)\]{color:var(--contrast)}.text-\[color\:var\(--primary\)\]{color:var(--primary)}.text-\[color\:var\(--secondary\)\]{color:var(--secondary)}.text-blue-600{color:var(--color-blue-600)}.text-gray-800{color:var(--color-gray-800)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.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,)}.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))}.duration-300{--tw-duration:.3s;transition-duration:.3s}@media(hover:hover){.group-hover\:text-white:is(:where(.group):hover *){color:var(--color-white)}.hover\:bg-blue-600:hover{background-color:var(--color-blue-600)}.hover\:bg-gray-800:hover{background-color:var(--color-gray-800)}.hover\:text-\[color\:var\(--complementary\)\]:hover{color:var(--complementary)}.hover\:text-white:hover{color:var(--color-white)}}@media(min-width:40rem){.sm\:h-44{height:calc(var(--spacing)*44)}.sm\:w-44{width:calc(var(--spacing)*44)}.sm\:flex-row{flex-direction:row}.sm\:px-6{padding-inline:calc(var(--spacing)*6)}.sm\:text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.sm\:text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.sm\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.sm\:text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.sm\:text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}.sm\:text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.sm\:text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.sm\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}}@media(min-width:48rem){.md\:col-span-1{grid-column:span 1/span 1}.md\:col-span-2{grid-column:span 2/span 2}.md\:col-span-3{grid-column:span 3/span 3}.md\:grid{display:grid}.md\:h-52{height:calc(var(--spacing)*52)}.md\:w-52{width:calc(var(--spacing)*52)}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.md\:items-start{align-items:flex-start}.md\:justify-start{justify-content:flex-start}.md\:gap-8{gap:calc(var(--spacing)*8)}.md\:gap-12{gap:calc(var(--spacing)*12)}.md\:px-8{padding-inline:calc(var(--spacing)*8)}.md\:py-20{padding-block:calc(var(--spacing)*20)}.md\:text-left{text-align:left}.md\:text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.md\:text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.md\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.md\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}}@media(min-width:64rem){.lg\:h-60{height:calc(var(--spacing)*60)}.lg\:w-60{width:calc(var(--spacing)*60)}.lg\:gap-12{gap:calc(var(--spacing)*12)}.lg\:px-12{padding-inline:calc(var(--spacing)*12)}.lg\:text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}}@media(min-width:80rem){.xl\:text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}}}:root,.dark{--primary:#cad2c5;--secondary:#84a98c;--tertiary:#354f52;--complementary:#52796f;--contrast:#2f3e46;--background:#1b2b30;--text-base:#cad2c5;--text-muted:#84a98c;--surface:#2f3e46;--surface-elevated:#354f52;--border:#52796f;background-color:var(--background);transition:background-color .3s}.light{--primary:#2f4f4f;--secondary:#4a7c6f;--tertiary:#d8e8df;--complementary:#a8c5ba;--contrast:#b8d4c8;--background:#f4f7f5;--text-base:#2f4f4f;--text-muted:#4a7c6f;--surface:#e8f0ec;--surface-elevated:#fff;--border:#a8c5ba;background-color:var(--background);transition:background-color .3s}@media(min-width:768px){.tech-grid-wrapper{height:100%}.tech-grid-inner{grid-template-columns:repeat(2,1fr);grid-auto-rows:1fr;height:100%}.tech-card{padding:14px 8px}.tech-label{font-size:11px}}@keyframes fade-up{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.hero-animate{animation:.55s ease-out both fade-up}@media(prefers-reduced-motion:reduce){.hero-animate{animation:none}}@keyframes name-shimmer{0%{background-position:0%}to{background-position:200%}}.hero-name{background:linear-gradient(120deg,var(--primary)0%,var(--secondary)40%,var(--primary)60%,var(--secondary)100%);-webkit-text-fill-color:transparent;background-size:200%;-webkit-background-clip:text;background-clip:text;animation:6s linear infinite name-shimmer}.hero-animate.hero-name{animation:.55s ease-out both fade-up,6s linear .55s infinite name-shimmer}@media(prefers-reduced-motion:reduce){.hero-animate.hero-name{animation:6s linear infinite name-shimmer}}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}.typewriter-cursor{color:var(--complementary);margin-left:1px;font-weight:300;animation:1s step-end infinite cursor-blink}.social-link{background-color:var(--surface);border:1px solid var(--border);width:36px;height:36px;color:var(--text-muted);border-radius:8px;justify-content:center;align-items:center;text-decoration:none;transition:background-color .2s,color .2s,transform .2s;display:flex}.social-link:hover{background-color:var(--surface-elevated);color:var(--primary);transform:translateY(-2px)}.hero-btn-primary{background-color:var(--complementary);color:var(--background);border:1px solid #0000;border-radius:10px;align-items:center;gap:8px;padding:10px 22px;font-size:.875rem;font-weight:600;text-decoration:none;transition:opacity .2s,transform .2s;display:inline-flex}.hero-btn-primary:hover{opacity:.88;transform:translateY(-1px)}.hero-btn-secondary{color:var(--primary);border:1px solid var(--border);background-color:#0000;border-radius:10px;align-items:center;gap:8px;padding:10px 22px;font-size:.875rem;font-weight:600;text-decoration:none;transition:background-color .2s,transform .2s;display:inline-flex}.hero-btn-secondary:hover{background-color:var(--surface-elevated);transform:translateY(-1px)}.bg-orb{pointer-events:none;z-index:0;will-change:transform;border-radius:50%;position:fixed}.bg-orb-1{filter:blur(70px);background:radial-gradient(circle,#52796f47,#52796f14 50%,#0000 70%);width:620px;height:620px;animation:16s ease-in-out infinite alternate orb-drift-1;top:-15%;left:-8%}.bg-orb-2{filter:blur(90px);background:radial-gradient(circle,#84a98c33,#84a98c0f 50%,#0000 70%);width:560px;height:560px;animation:20s ease-in-out infinite alternate orb-drift-2;bottom:0%;right:-10%}@keyframes orb-drift-1{0%{transform:translate(0)scale(1)}to{transform:translate(50px,35px)scale(1.12)}}@keyframes orb-drift-2{0%{transform:translate(0)scale(1)}to{transform:translate(-45px,-50px)scale(1.08)}}@media(max-width:768px){.bg-orb-1{width:380px;height:380px}.bg-orb-2{width:320px;height:320px}}@media(prefers-reduced-motion:reduce){.bg-orb{animation:none}}@keyframes gradient-border{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.hero-photo-frame{background:linear-gradient(135deg,var(--secondary),var(--complementary),var(--primary),var(--complementary),var(--secondary));background-size:300% 300%;border-radius:20px;padding:3px;animation:6s infinite gradient-border;box-shadow:0 0 30px #52796f40,0 8px 32px #0000004d}.hero-photo-frame img{border-radius:18px;display:block}.hero-name{filter:drop-shadow(0 0 18px #84a98c47)}.social-link-full{background-color:var(--surface);border:1px solid var(--border);width:100%;color:var(--text-muted);border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:.8125rem;font-weight:500;text-decoration:none;transition:background-color .2s,color .2s,transform .2s,border-color .2s;display:flex}.social-link-full:hover{background-color:var(--surface-elevated);color:var(--primary);border-color:var(--complementary);transform:translateY(-2px)}.social-link-full.social-link-primary{background-color:var(--complementary);color:var(--background);border-color:#0000;font-weight:600}.social-link-full.social-link-primary:hover{opacity:.88;color:var(--background);border-color:#0000}@keyframes btn-glow{0%,to{box-shadow:0 0 8px #52796f4d}50%{box-shadow:0 0 20px #52796f8c,0 0 40px #52796f26}}.hero-btn-primary{animation:3.5s ease-in-out infinite btn-glow}.navbar{z-index:50;background:#2f3e46b3;width:calc(100% - 32px);position:fixed;top:12px;left:50%;transform:translate(-50%)}@supports (color:color-mix(in lab,red,red)){.navbar{background:color-mix(in srgb,var(--surface)70%,transparent)}}.navbar{-webkit-backdrop-filter:blur(18px)saturate(180%);border:1px solid #354f5273}@supports (color:color-mix(in lab,red,red)){.navbar{border:1px solid color-mix(in srgb,var(--border)45%,transparent)}}.navbar{border-radius:14px;padding:10px 16px;box-shadow:0 4px 24px #00000038,inset 0 1px #ffffff0f}.navbar__mobile{justify-content:space-between;align-items:center;display:flex}.navbar__desktop{align-items:center;gap:2px;display:none}@media(min-width:768px){.navbar{border-radius:50px;width:auto;max-width:820px;padding:7px 14px 7px 20px}.navbar__mobile{display:none}.navbar__desktop{display:flex}}.navbar__logo{letter-spacing:.06em;color:var(--primary);background:#52796f2e;font-size:.8125rem;font-weight:700}@supports (color:color-mix(in lab,red,red)){.navbar__logo{background:color-mix(in srgb,var(--complementary)18%,transparent)}}.navbar__logo{border:1px solid #52796f59}@supports (color:color-mix(in lab,red,red)){.navbar__logo{border:1px solid color-mix(in srgb,var(--complementary)35%,transparent)}}.navbar__logo{border-radius:8px;padding:4px 10px}.navbar-link{color:var(--text-muted);white-space:nowrap;border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:6px 11px;font-size:.8125rem;font-weight:500;text-decoration:none;transition:color .2s,background-color .2s;display:flex;position:relative}.navbar-link:hover{color:var(--primary);background-color:#52796f8c}@supports (color:color-mix(in lab,red,red)){.navbar-link:hover{background-color:color-mix(in srgb,var(--surface-elevated)55%,transparent)}}.navbar-link--active{color:var(--primary);font-weight:600}.navbar-link__dot{background-color:var(--complementary);border-radius:50%;width:4px;height:4px;animation:.2s both dot-scale}@keyframes dot-scale{0%{transform:scale(0)}to{transform:scale(1)}}.navbar__separator{background:#354f528c;width:1px;height:18px;margin:0 8px}@supports (color:color-mix(in lab,red,red)){.navbar__separator{background:color-mix(in srgb,var(--border)55%,transparent)}}.theme-btn{background-color:#52796f8c;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}@supports (color:color-mix(in lab,red,red)){.theme-btn{background-color:color-mix(in srgb,var(--surface-elevated)55%,transparent)}}.theme-btn{border:1px solid #354f5273}@supports (color:color-mix(in lab,red,red)){.theme-btn{border:1px solid color-mix(in srgb,var(--border)45%,transparent)}}.theme-btn{color:var(--text-muted);cursor:pointer;transition:background-color .2s,color .2s,transform .35s}.theme-btn:hover{background-color:var(--complementary);color:var(--background);transform:rotate(25deg)}.hamburger-btn{background-color:#52796f80;border-radius:9px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}@supports (color:color-mix(in lab,red,red)){.hamburger-btn{background-color:color-mix(in srgb,var(--surface-elevated)50%,transparent)}}.hamburger-btn{border:1px solid #354f5273}@supports (color:color-mix(in lab,red,red)){.hamburger-btn{border:1px solid color-mix(in srgb,var(--border)45%,transparent)}}.hamburger-btn{color:var(--text-muted);cursor:pointer;transition:background-color .2s,color .2s}.hamburger-btn:hover{background-color:var(--surface-elevated);color:var(--primary)}.drawer-overlay{z-index:60;pointer-events:none;background:0 0;transition:background .28s;position:fixed;inset:0}.drawer-overlay--open{pointer-events:all;background:#00000073}.drawer{z-index:70;background:#2f3e46d1;width:50%;min-width:240px;max-width:320px;transition:transform .28s cubic-bezier(.4,0,.2,1);position:fixed;top:0;bottom:0;right:0;transform:translate(100%)}@supports (color:color-mix(in lab,red,red)){.drawer{background:color-mix(in srgb,var(--surface)82%,transparent)}}.drawer{-webkit-backdrop-filter:blur(24px)saturate(200%);border-left:1px solid #354f5280}@supports (color:color-mix(in lab,red,red)){.drawer{border-left:1px solid color-mix(in srgb,var(--border)50%,transparent)}}.drawer{flex-direction:column;display:flex;box-shadow:-8px 0 40px #00000047}.drawer--open{transform:translate(0)}.drawer__header{border-bottom:1px solid #354f5261;justify-content:space-between;align-items:center;padding:18px 20px;display:flex}@supports (color:color-mix(in lab,red,red)){.drawer__header{border-bottom:1px solid color-mix(in srgb,var(--border)38%,transparent)}}.drawer__nav{flex-direction:column;flex:1;gap:2px;padding:10px 12px;display:flex}.drawer-link{color:var(--text-muted);border-left:2px solid #0000;border-radius:10px;align-items:center;padding:13px 16px;font-size:.9375rem;font-weight:500;text-decoration:none;transition:color .2s,background-color .2s,border-color .2s,padding-left .2s;display:flex}.drawer-link:hover{color:var(--primary);background-color:#52796f99}@supports (color:color-mix(in lab,red,red)){.drawer-link:hover{background-color:color-mix(in srgb,var(--surface-elevated)60%,transparent)}}.drawer-link:hover{padding-left:20px}.drawer-link--active{color:var(--primary);background-color:#52796f1f}@supports (color:color-mix(in lab,red,red)){.drawer-link--active{background-color:color-mix(in srgb,var(--complementary)12%,transparent)}}.drawer-link--active{border-left-color:var(--complementary);padding-left:20px;font-weight:600}.drawer__footer{border-top:1px solid #354f5261;padding:14px 20px}@supports (color:color-mix(in lab,red,red)){.drawer__footer{border-top:1px solid color-mix(in srgb,var(--border)38%,transparent)}}@media(prefers-reduced-motion:reduce){.navbar,.drawer,.drawer-overlay{transition:none}}.exp-timeline{flex-direction:column;padding-left:8px;display:flex}.exp-item{grid-template-columns:28px 1fr;gap:16px;display:grid}.exp-item__left{flex-direction:column;align-items:center;padding-top:20px;display:flex}.exp-item__dot{background-color:var(--surface-elevated);border:2px solid var(--border);border-radius:50%;flex-shrink:0;width:13px;height:13px;transition:background-color .2s,box-shadow .2s}.exp-item__line{background:linear-gradient(to bottom,var(--border),#354f524d);flex:1;width:1px;min-height:32px;margin-top:8px}@supports (color:color-mix(in lab,red,red)){.exp-item__line{background:linear-gradient(to bottom,var(--border),color-mix(in srgb,var(--border)30%,transparent))}}.exp-card{background:#2f3e46bf}@supports (color:color-mix(in lab,red,red)){.exp-card{background:color-mix(in srgb,var(--surface)75%,transparent)}}.exp-card{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:14px;transition:border-color .2s,box-shadow .2s;overflow:hidden}.exp-card:hover{border-color:#52796f99}@supports (color:color-mix(in lab,red,red)){.exp-card:hover{border-color:color-mix(in srgb,var(--complementary)60%,transparent)}}.exp-card:hover{box-shadow:0 4px 20px #0000001f}.exp-card__header{border-bottom:1px solid #354f5299;flex-direction:column;gap:10px;padding:16px 20px;display:flex}@supports (color:color-mix(in lab,red,red)){.exp-card__header{border-bottom:1px solid color-mix(in srgb,var(--border)60%,transparent)}}.exp-card__header{background:#52796f66}@supports (color:color-mix(in lab,red,red)){.exp-card__header{background:color-mix(in srgb,var(--surface-elevated)40%,transparent)}}@media(min-width:640px){.exp-card__header{flex-direction:row;justify-content:space-between;align-items:flex-start}}.exp-card__body{padding:16px 20px}.stack-grid{grid-template-columns:1fr;gap:16px;display:grid}@media(min-width:768px){.stack-grid{grid-template-columns:repeat(3,1fr);gap:20px}}.stack-card{background:#2f3e46bf}@supports (color:color-mix(in lab,red,red)){.stack-card{background:color-mix(in srgb,var(--surface)75%,transparent)}}.stack-card{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:16px;flex-direction:column;transition:border-color .2s,box-shadow .2s;display:flex;overflow:hidden}.stack-card:hover{border-color:#52796f8c}@supports (color:color-mix(in lab,red,red)){.stack-card:hover{border-color:color-mix(in srgb,var(--complementary)55%,transparent)}}.stack-card:hover{box-shadow:0 4px 24px #0000001f}.stack-card__header{background:#52796f66;flex-direction:row;justify-content:space-between;align-items:flex-start;gap:12px;padding:16px 18px;display:flex}@supports (color:color-mix(in lab,red,red)){.stack-card__header{background:color-mix(in srgb,var(--surface-elevated)40%,transparent)}}.stack-card__body{flex-direction:column;flex:1;gap:16px;padding:16px 18px;display:flex}.stack-category{flex-direction:column;display:flex}.stack-pill{background-color:var(--surface-elevated);border:1px solid var(--border);cursor:default;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;transition:border-color .2s,background-color .2s,transform .2s;display:inline-flex}.stack-pill:hover{background-color:#52796f}@supports (color:color-mix(in lab,red,red)){.stack-pill:hover{background-color:color-mix(in srgb,var(--surface-elevated)80%,var(--complementary))}}.stack-pill:hover{border-color:#52796f80}@supports (color:color-mix(in lab,red,red)){.stack-pill:hover{border-color:color-mix(in srgb,var(--complementary)50%,transparent)}}.stack-pill:hover{transform:translateY(-1px)}.stack-pill__name{color:var(--text-muted);white-space:nowrap;font-size:.75rem;font-weight:500}.stack-pill__context{color:var(--text-muted);opacity:.7;font-size:.6875rem}.portfolio-card{background:#2f3e46bf}@supports (color:color-mix(in lab,red,red)){.portfolio-card{background:color-mix(in srgb,var(--surface)75%,transparent)}}.portfolio-card{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);cursor:pointer;border-radius:16px;flex-direction:column;transition:border-color .25s,box-shadow .25s,transform .25s;display:flex;overflow:hidden}.portfolio-card:hover{border-color:#52796f8c}@supports (color:color-mix(in lab,red,red)){.portfolio-card:hover{border-color:color-mix(in srgb,var(--complementary)55%,transparent)}}.portfolio-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0000002e}.portfolio-card__img-wrap{height:200px;position:relative;overflow:hidden}.portfolio-card__img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.portfolio-card:hover .portfolio-card__img{transform:scale(1.05)}.portfolio-card__img-overlay{background:linear-gradient(#0000 40%,#2f3e46b3);position:absolute;inset:0}@supports (color:color-mix(in lab,red,red)){.portfolio-card__img-overlay{background:linear-gradient(to bottom,transparent 40%,color-mix(in srgb,var(--surface)70%,transparent)100%)}}.portfolio-card__dev-badge{background:#2f3e46cc;border-radius:20px;padding:3px 10px;font-size:.6875rem;font-weight:600;position:absolute;top:12px;right:12px}@supports (color:color-mix(in lab,red,red)){.portfolio-card__dev-badge{background:color-mix(in srgb,var(--surface)80%,transparent)}}.portfolio-card__dev-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);color:var(--secondary)}.portfolio-card__body{flex-direction:column;flex:1;padding:16px 18px;display:flex}.portfolio-modal-overlay{-webkit-backdrop-filter:blur(6px);z-index:80;background:#0000008c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.portfolio-modal{background:#2f3e46e0}@supports (color:color-mix(in lab,red,red)){.portfolio-modal{background:color-mix(in srgb,var(--surface)88%,transparent)}}.portfolio-modal{-webkit-backdrop-filter:blur(24px)saturate(180%);border:1px solid var(--border);border-radius:20px;flex-direction:column;width:100%;max-width:680px;max-height:88vh;display:flex;overflow-y:auto;box-shadow:0 24px 64px #00000059}.portfolio-modal__header{background:#52796fcc;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 22px;display:flex;position:sticky;top:0}@supports (color:color-mix(in lab,red,red)){.portfolio-modal__header{background:color-mix(in srgb,var(--surface-elevated)80%,transparent)}}.portfolio-modal__header{-webkit-backdrop-filter:blur(16px);border-bottom:1px solid #354f5299}@supports (color:color-mix(in lab,red,red)){.portfolio-modal__header{border-bottom:1px solid color-mix(in srgb,var(--border)60%,transparent)}}.portfolio-modal__header{z-index:1;border-radius:20px 20px 0 0}.portfolio-modal__close{background:#2f3e46b3;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}@supports (color:color-mix(in lab,red,red)){.portfolio-modal__close{background:color-mix(in srgb,var(--surface)70%,transparent)}}.portfolio-modal__close{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:background-color .2s,color .2s}.portfolio-modal__close:hover{background-color:var(--surface-elevated);color:var(--primary)}.portfolio-modal__img-wrap{height:240px;overflow:hidden}.portfolio-modal__img{object-fit:cover;width:100%;height:100%}.portfolio-modal__body{padding:22px 22px 24px}.about-contact-card{background:#2f3e46bf}@supports (color:color-mix(in lab,red,red)){.about-contact-card{background:color-mix(in srgb,var(--surface)75%,transparent)}}.about-contact-card{-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:16px;flex-direction:column;height:100%;display:flex;overflow:hidden}.about-contact-card__header{border-bottom:1px solid #354f5299;padding:16px 18px}@supports (color:color-mix(in lab,red,red)){.about-contact-card__header{border-bottom:1px solid color-mix(in srgb,var(--border)60%,transparent)}}.about-contact-card__header{background:#52796f66}@supports (color:color-mix(in lab,red,red)){.about-contact-card__header{background:color-mix(in srgb,var(--surface-elevated)40%,transparent)}}.about-footer{border-top:1px solid #354f5280;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-top:48px;padding-top:20px;display:flex}@supports (color:color-mix(in lab,red,red)){.about-footer{border-top:1px solid color-mix(in srgb,var(--border)50%,transparent)}}.about-footer{color:var(--text-muted);opacity:.7;font-size:.75rem}.site-footer{background:#2f3e46cc;margin-top:auto;position:relative}@supports (color:color-mix(in lab,red,red)){.site-footer{background:color-mix(in srgb,var(--surface)80%,transparent)}}.site-footer{-webkit-backdrop-filter:blur(18px)saturate(160%)}.site-footer__divider{background:linear-gradient(90deg,#0000,#52796f80 35% 65%,#0000);height:1px}@supports (color:color-mix(in lab,red,red)){.site-footer__divider{background:linear-gradient(to right,transparent,color-mix(in srgb,var(--complementary)50%,transparent)35%,color-mix(in srgb,var(--complementary)50%,transparent)65%,transparent)}}.site-footer__inner{flex-direction:column;align-items:flex-start;gap:24px;max-width:1100px;margin:0 auto;padding:32px 24px 24px;display:flex}@media(min-width:640px){.site-footer__inner{flex-direction:row;justify-content:space-between;align-items:center;gap:32px}}.site-footer__brand{flex-direction:column;display:flex}.site-footer__nav{flex-wrap:wrap;gap:4px 2px;display:flex}.site-footer__nav-link{color:var(--text-muted);border-radius:6px;padding:5px 10px;font-size:.75rem;font-weight:500;text-decoration:none;transition:color .2s,background-color .2s}.site-footer__nav-link:hover{color:var(--primary);background-color:#52796f99}@supports (color:color-mix(in lab,red,red)){.site-footer__nav-link:hover{background-color:color-mix(in srgb,var(--surface-elevated)60%,transparent)}}.site-footer__social{gap:8px;display:flex}.site-footer__social-icon{background-color:var(--surface-elevated);border:1px solid var(--border);width:34px;height:34px;color:var(--text-muted);border-radius:9px;justify-content:center;align-items:center;text-decoration:none;transition:background-color .2s,color .2s,border-color .2s,transform .2s;display:flex}.site-footer__social-icon:hover{background-color:var(--complementary);border-color:var(--complementary);color:var(--background);transform:translateY(-2px)}.site-footer__bottom{border-top:1px solid #354f5273;max-width:1100px;margin:0 auto;padding:14px 24px}@supports (color:color-mix(in lab,red,red)){.site-footer__bottom{border-top:1px solid color-mix(in srgb,var(--border)45%,transparent)}}.site-footer__bottom{color:var(--text-muted);opacity:.65;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;font-size:.6875rem;display:flex}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-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}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}
