a[data-astro-cid-5sjhwv6c]:after,button[data-astro-cid-5sjhwv6c]:after{content:"";position:absolute;inset:0;background:var(--button-shine);transform:translate(-135%);transition:transform .7s var(--ease-smooth);pointer-events:none}a[data-astro-cid-5sjhwv6c]:hover:after,button[data-astro-cid-5sjhwv6c]:hover:after,a[data-astro-cid-5sjhwv6c]:focus-visible:after,button[data-astro-cid-5sjhwv6c]:focus-visible:after{transform:translate(135%)}a[data-astro-cid-rpw4o4y4]{svg{width:20px;height:20px}transition:transform .2s ease-in-out}a[data-astro-cid-rpw4o4y4]:hover{transform:scale(1.1);transition:transform .3s ease-in-out}.lang-select[data-astro-cid-65uu2w6m]{position:relative;display:inline-flex}.lang-trigger[data-astro-cid-65uu2w6m]{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer}.lang-popover[data-astro-cid-65uu2w6m]{position:absolute;right:0;top:calc(100% + .5rem);display:grid;gap:.25rem;min-width:9rem;padding:.5rem;border-radius:.75rem;background:var(--surface-card);box-shadow:var(--shadow-soft);z-index:20;transform:translateY(-2px);transition:transform .1s ease}.lang-popover[data-astro-cid-65uu2w6m][hidden]{transform:translateY(-2px)}.lang-option[data-astro-cid-65uu2w6m]{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .5rem;border-radius:.5rem;color:var(--text-primary);text-decoration:none;transition:background .2s ease,transform .1s ease}.lang-option[data-astro-cid-65uu2w6m]:is(:hover,:focus-visible){background:var(--surface-subtle);outline:none;transform:translateY(-1px)}.lang-flag[data-astro-cid-65uu2w6m]{width:1.5rem;height:1.5rem;object-fit:cover;border-radius:50%;border:1px solid var(--border-subtle)}.nav-link[data-astro-cid-rq4qnsko]{position:relative;display:inline-block;margin-top:.25rem;transition:color .3s ease}.nav-link[data-astro-cid-rq4qnsko]:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background-color:currentColor;transition:width .3s ease,left .3s ease}.nav-link[data-astro-cid-rq4qnsko]:before{content:"";position:absolute;right:-.5rem;bottom:0;width:2px;height:0;background-color:currentColor;transition:height .3s ease .1s;opacity:0}.nav-link[data-astro-cid-rq4qnsko]:hover:after,.nav-link[data-astro-cid-rq4qnsko]:active:after{width:100%;left:0}.nav-link[data-astro-cid-rq4qnsko]:hover:before,.nav-link[data-astro-cid-rq4qnsko]:active:before{height:100%;opacity:1}.nav-link[data-astro-cid-rq4qnsko]:hover{color:var(--text-primary)}/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */@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-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--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-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0}}}@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-red-50:oklch(97.1% .013 17.38);--color-red-200:oklch(88.5% .062 18.334);--color-red-600:oklch(57.7% .245 27.325);--color-red-800:oklch(44.4% .177 26.899);--color-green-50:oklch(98.2% .018 155.826);--color-green-200:oklch(92.5% .084 155.995);--color-green-600:oklch(62.7% .194 149.214);--color-green-800:oklch(44.8% .119 151.328);--color-white:#fff;--spacing:.25rem;--container-4xl:56rem;--container-7xl:80rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--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;--font-weight-light:300;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-wide:.025em;--leading-tight:1.25;--leading-relaxed:1.625;--radius-sm:.25rem;--radius-lg:.5rem;--radius-2xl:1rem;--blur-sm:8px;--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);--font-primary:"Inter", sans-serif;--font-secondary:"Homemade Apple", cursive;--font-display:"Inter", sans-serif;--color-bg-1:#d5d1c5;--color-bg-2:#e7e1d5;--color-bg-3:#dbd5cb;--color-text-1:#111;--color-text-2:#3d3d3f;--color-text-3:#a78002;--color-button-text:#fff;--color-button-bg:#111;--color-bg-1-dark:#1a1a1a;--color-bg-2-dark:#2a2a2a;--color-bg-3-dark:#3a3a3a;--color-text-1-dark:#f4eee2;--color-text-2-dark:#e7e1d5;--color-text-3-dark:#f0d67a;--color-button-text-dark:#111;--color-button-bg-dark:#f4eee2;--ease-smooth:cubic-bezier(.4, 0, .2, 1)}}@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{.pointer-events-none{pointer-events:none}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing) * 0)}.-top-px{top:-1px}.top-3{top:calc(var(--spacing) * 3)}.-right-px{right:-1px}.right-3{right:calc(var(--spacing) * 3)}.-left-px{left:-1px}.z-10{z-index:10}.z-20{z-index:20}.order-1{order:1}.order-2{order:2}.m-auto{margin:auto}.mx-0{margin-inline:calc(var(--spacing) * 0)}.mx-auto{margin-inline:auto}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-auto{margin-top:auto}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.ml-0\.5{margin-left:calc(var(--spacing) * .5)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.size-5{width:calc(var(--spacing) * 5);height:calc(var(--spacing) * 5)}.size-12{width:calc(var(--spacing) * 12);height:calc(var(--spacing) * 12)}.size-16{width:calc(var(--spacing) * 16);height:calc(var(--spacing) * 16)}.h-1\.5{height:calc(var(--spacing) * 1.5)}.h-2\.5{height:calc(var(--spacing) * 2.5)}.h-3{height:calc(var(--spacing) * 3)}.h-3\.5{height:calc(var(--spacing) * 3.5)}.h-3\/4{height:75%}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-18{height:calc(var(--spacing) * 18)}.h-24{height:calc(var(--spacing) * 24)}.h-\[54px\]{height:54px}.h-\[var\(--project-poster-size\)\]{height:var(--project-poster-size)}.h-full{height:100%}.h-px{height:1px}.max-h-\[84\%\]{max-height:84%}.max-h-\[85vh\]{max-height:85vh}.max-h-\[90vh\]{max-height:90vh}.min-h-11{min-height:calc(var(--spacing) * 11)}.min-h-12{min-height:calc(var(--spacing) * 12)}.min-h-14{min-height:calc(var(--spacing) * 14)}.min-h-\[2\.6rem\]{min-height:2.6rem}.min-h-\[100svh\]{min-height:100svh}.min-h-\[340px\]{min-height:340px}.min-h-screen{min-height:100vh}.w-1\.5{width:calc(var(--spacing) * 1.5)}.w-2\.5{width:calc(var(--spacing) * 2.5)}.w-3{width:calc(var(--spacing) * 3)}.w-3\.5{width:calc(var(--spacing) * 3.5)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-6{width:calc(var(--spacing) * 6)}.w-9{width:calc(var(--spacing) * 9)}.w-10{width:calc(var(--spacing) * 10)}.w-14{width:calc(var(--spacing) * 14)}.w-\[1px\]{width:1px}.w-\[54px\]{width:54px}.w-\[var\(--project-poster-size\)\]{width:var(--project-poster-size)}.w-auto{width:auto}.w-full{width:100%}.max-w-4xl{max-width:var(--container-4xl)}.max-w-7xl{max-width:var(--container-7xl)}.max-w-\[22rem\]{max-width:22rem}.max-w-\[26rem\]{max-width:26rem}.max-w-\[30rem\]{max-width:30rem}.max-w-\[32rem\]{max-width:32rem}.max-w-\[84\%\]{max-width:84%}.max-w-\[90vw\]{max-width:90vw}.max-w-full{max-width:100%}.min-w-40{min-width:calc(var(--spacing) * 40)}.flex-1{flex:1}.flex-shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-rows-\[auto_1fr_auto\]{grid-template-rows:auto 1fr auto}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.place-items-center{place-items:center}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-0{gap:calc(var(--spacing) * 0)}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-2\.5{gap:calc(var(--spacing) * 2.5)}.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-7{gap:calc(var(--spacing) * 7)}.gap-8{gap:calc(var(--spacing) * 8)}.gap-10{gap:calc(var(--spacing) * 10)}.gap-12{gap:calc(var(--spacing) * 12)}: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)))}.overflow-hidden{overflow:hidden}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-\[27px\]{border-radius:27px}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-t-\[26px\]{border-top-left-radius:26px;border-top-right-radius:26px}.rounded-br-full{border-bottom-right-radius:3.40282e38px}.rounded-bl-full{border-bottom-left-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.border-0{border-style:var(--tw-border-style);border-width:0}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-\[color-mix\(in_srgb\,var\(--border-strong\)_30\%\,transparent\)\]{border-color:var(--border-strong)}@supports (color:color-mix(in lab,red,red)){.border-\[color-mix\(in_srgb\,var\(--border-strong\)_30\%\,transparent\)\]{border-color:color-mix(in srgb,var(--border-strong) 30%,transparent)}}.border-\[color-mix\(in_srgb\,var\(--border-strong\)_40\%\,transparent\)\]{border-color:var(--border-strong)}@supports (color:color-mix(in lab,red,red)){.border-\[color-mix\(in_srgb\,var\(--border-strong\)_40\%\,transparent\)\]{border-color:color-mix(in srgb,var(--border-strong) 40%,transparent)}}.border-\[color-mix\(in_srgb\,var\(--border-subtle\)_40\%\,transparent\)\]{border-color:var(--border-subtle)}@supports (color:color-mix(in lab,red,red)){.border-\[color-mix\(in_srgb\,var\(--border-subtle\)_40\%\,transparent\)\]{border-color:color-mix(in srgb,var(--border-subtle) 40%,transparent)}}.border-\[var\(--border-accent\)\]{border-color:var(--border-accent)}.border-\[var\(--border-subtle\)\]{border-color:var(--border-subtle)}.border-\[var\(--button-bg\)\]{border-color:var(--button-bg)}.border-\[var\(--project-category-client-border\)\]{border-color:var(--project-category-client-border)}.border-\[var\(--project-category-myself-border\)\]{border-color:var(--project-category-myself-border)}.border-\[var\(--project-category-test-case-border\)\]{border-color:var(--project-category-test-case-border)}.border-\[var\(--project-type-api-border\)\]{border-color:var(--project-type-api-border)}.border-\[var\(--project-type-mobile-border\)\]{border-color:var(--project-type-mobile-border)}.border-\[var\(--project-type-web-border\)\]{border-color:var(--project-type-web-border)}.border-green-200{border-color:var(--color-green-200)}.border-red-200{border-color:var(--color-red-200)}.border-transparent{border-color:#0000}.bg-\[color-mix\(in_srgb\,var\(--border-accent\)_75\%\,transparent\)\]{background-color:var(--border-accent)}@supports (color:color-mix(in lab,red,red)){.bg-\[color-mix\(in_srgb\,var\(--border-accent\)_75\%\,transparent\)\]{background-color:color-mix(in srgb,var(--border-accent) 75%,transparent)}}.bg-\[color-mix\(in_srgb\,var\(--border-strong\)_40\%\,transparent\)\]{background-color:var(--border-strong)}@supports (color:color-mix(in lab,red,red)){.bg-\[color-mix\(in_srgb\,var\(--border-strong\)_40\%\,transparent\)\]{background-color:color-mix(in srgb,var(--border-strong) 40%,transparent)}}.bg-\[color-mix\(in_srgb\,var\(--border-strong\)_70\%\,transparent\)\]{background-color:var(--border-strong)}@supports (color:color-mix(in lab,red,red)){.bg-\[color-mix\(in_srgb\,var\(--border-strong\)_70\%\,transparent\)\]{background-color:color-mix(in srgb,var(--border-strong) 70%,transparent)}}.bg-\[color-mix\(in_srgb\,var\(--surface-card\)_20\%\,transparent\)\]{background-color:var(--surface-card)}@supports (color:color-mix(in lab,red,red)){.bg-\[color-mix\(in_srgb\,var\(--surface-card\)_20\%\,transparent\)\]{background-color:color-mix(in srgb,var(--surface-card) 20%,transparent)}}.bg-\[color-mix\(in_srgb\,var\(--text-accent\)_50\%\,transparent\)\]{background-color:var(--text-accent)}@supports (color:color-mix(in lab,red,red)){.bg-\[color-mix\(in_srgb\,var\(--text-accent\)_50\%\,transparent\)\]{background-color:color-mix(in srgb,var(--text-accent) 50%,transparent)}}.bg-\[var\(--button-bg\)\]{background-color:var(--button-bg)}.bg-\[var\(--project-category-client-bg\)\]{background-color:var(--project-category-client-bg)}.bg-\[var\(--project-category-myself-bg\)\]{background-color:var(--project-category-myself-bg)}.bg-\[var\(--project-category-test-case-bg\)\]{background-color:var(--project-category-test-case-bg)}.bg-\[var\(--project-type-api-bg\)\]{background-color:var(--project-type-api-bg)}.bg-\[var\(--project-type-mobile-bg\)\]{background-color:var(--project-type-mobile-bg)}.bg-\[var\(--project-type-web-bg\)\]{background-color:var(--project-type-web-bg)}.bg-\[var\(--surface-card\)\]{background-color:var(--surface-card)}.bg-\[var\(--surface-footer\)\]{background-color:var(--surface-footer)}.bg-\[var\(--surface-panel\)\]{background-color:var(--surface-panel)}.bg-\[var\(--surface-panel-strong\)\]{background-color:var(--surface-panel-strong)}.bg-\[var\(--surface-poster-gloss\)\]{background-color:var(--surface-poster-gloss)}.bg-\[var\(--surface-poster-vignette\)\]{background-color:var(--surface-poster-vignette)}.bg-\[var\(--surface-section\)\]{background-color:var(--surface-section)}.bg-\[var\(--surface-subtle\)\]{background-color:var(--surface-subtle)}.bg-green-50{background-color:var(--color-green-50)}.bg-red-50{background-color:var(--color-red-50)}.bg-transparent{background-color:#0000}.bg-\[radial-gradient\(circle_at_1px_1px\,var\(--text-accent\)_1px\,transparent_1px\)\]{background-image:radial-gradient(circle at 1px 1px,var(--text-accent) 1px,transparent 1px)}.bg-\[radial-gradient\(circle_at_50\%_50\%\,var\(--border-accent\)_1px\,transparent_1px\)\]{background-image:radial-gradient(circle at 50% 50%,var(--border-accent) 1px,transparent 1px)}.bg-\[size\:18px_18px\]{background-size:18px 18px}.bg-\[size\:28px_28px\]{background-size:28px 28px}.fill-current{fill:currentColor}.fill-white{fill:var(--color-white)}.stroke-current{stroke:currentColor}.object-contain{object-fit:contain}.object-cover{object-fit:cover}.object-center{object-position:center}.p-0{padding:calc(var(--spacing) * 0)}.p-2{padding:calc(var(--spacing) * 2)}.p-6{padding:calc(var(--spacing) * 6)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-3\.5{padding-inline:calc(var(--spacing) * 3.5)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-7{padding-inline:calc(var(--spacing) * 7)}.px-\[0\.6rem\]{padding-inline:.6rem}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-16{padding-block:calc(var(--spacing) * 16)}.py-20{padding-block:calc(var(--spacing) * 20)}.py-24{padding-block:calc(var(--spacing) * 24)}.py-\[0\.22rem\]{padding-block:.22rem}.py-\[0\.25rem\]{padding-block:.25rem}.pt-1{padding-top:calc(var(--spacing) * 1)}.text-center{text-align:center}.font-display{font-family:var(--font-display)}.font-primary{font-family:var(--font-primary)}.font-secondary{font-family:var(--font-secondary)}.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-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-\[0\.6rem\]{font-size:.6rem}.text-\[0\.65rem\]{font-size:.65rem}.text-\[0\.68rem\]{font-size:.68rem}.text-\[0\.72rem\]{font-size:.72rem}.text-\[0\.78rem\]{font-size:.78rem}.text-\[0\.82rem\]{font-size:.82rem}.text-\[0\.85rem\]{font-size:.85rem}.text-\[0\.92rem\]{font-size:.92rem}.text-\[1\.4rem\]{font-size:1.4rem}.text-\[1\.45rem\]{font-size:1.45rem}.text-\[1\.55rem\]{font-size:1.55rem}.text-\[2rem\]{font-size:2rem}.text-\[11px\]{font-size:11px}.leading-\[1\.1\]{--tw-leading:1.1;line-height:1.1}.leading-\[1\.04\]{--tw-leading:1.04;line-height:1.04}.leading-\[1\.05\]{--tw-leading:1.05;line-height:1.05}.leading-\[1\.6\]{--tw-leading:1.6;line-height:1.6}.leading-\[1\.55\]{--tw-leading:1.55;line-height:1.55}.leading-\[1\.65\]{--tw-leading:1.65;line-height:1.65}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-light{--tw-font-weight:var(--font-weight-light);font-weight:var(--font-weight-light)}.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-\[-0\.01em\]{--tw-tracking:-.01em;letter-spacing:-.01em}.tracking-\[-0\.02em\]{--tw-tracking:-.02em;letter-spacing:-.02em}.tracking-\[-0\.03em\]{--tw-tracking:-.03em;letter-spacing:-.03em}.tracking-\[-0\.04em\]{--tw-tracking:-.04em;letter-spacing:-.04em}.tracking-\[-0\.06em\]{--tw-tracking:-.06em;letter-spacing:-.06em}.tracking-\[0\.01em\]{--tw-tracking:.01em;letter-spacing:.01em}.tracking-\[0\.08em\]{--tw-tracking:.08em;letter-spacing:.08em}.tracking-\[0\.12em\]{--tw-tracking:.12em;letter-spacing:.12em}.tracking-\[0\.14em\]{--tw-tracking:.14em;letter-spacing:.14em}.tracking-\[0\.16em\]{--tw-tracking:.16em;letter-spacing:.16em}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.whitespace-nowrap{white-space:nowrap}.text-\[var\(--button-text\)\]{color:var(--button-text)}.text-\[var\(--project-category-client-text\)\]{color:var(--project-category-client-text)}.text-\[var\(--project-category-myself-text\)\]{color:var(--project-category-myself-text)}.text-\[var\(--project-category-test-case-text\)\]{color:var(--project-category-test-case-text)}.text-\[var\(--project-type-api-text\)\]{color:var(--project-type-api-text)}.text-\[var\(--project-type-mobile-text\)\]{color:var(--project-type-mobile-text)}.text-\[var\(--project-type-web-text\)\]{color:var(--project-type-web-text)}.text-\[var\(--surface-footer-text\)\]{color:var(--surface-footer-text)}.text-\[var\(--text-accent\)\]{color:var(--text-accent)}.text-\[var\(--text-accent-strong\)\]{color:var(--text-accent-strong)}.text-\[var\(--text-muted\)\]{color:var(--text-muted)}.text-\[var\(--text-primary\)\]{color:var(--text-primary)}.text-\[var\(--text-secondary\)\]{color:var(--text-secondary)}.text-green-600{color:var(--color-green-600)}.text-green-800{color:var(--color-green-800)}.text-red-600{color:var(--color-red-600)}.text-red-800{color:var(--color-red-800)}.uppercase{text-transform:uppercase}.no-underline{text-decoration-line:none}.underline{text-decoration-line:underline}.underline-offset-2{text-underline-offset:2px}.opacity-40{opacity:.4}.opacity-\[0\.025\]{opacity:.025}.shadow-\[var\(--shadow-button\)\]{--tw-shadow:var(--shadow-button);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[var\(--shadow-elevated\)\]{--tw-shadow:var(--shadow-elevated);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[var\(--shadow-media-control\)\]{--tw-shadow:var(--shadow-media-control);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[var\(--shadow-overlay\)\]{--tw-shadow:var(--shadow-overlay);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[var\(--shadow-soft\)\]{--tw-shadow:var(--shadow-soft);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.drop-shadow-\[var\(--shadow-media-poster\)\]{--tw-drop-shadow-size:drop-shadow(var(--shadow-media-poster));--tw-drop-shadow:var(--tw-drop-shadow-size);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(var(--blur-sm));-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-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.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-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.duration-700{--tw-duration:.7s;transition-duration:.7s}.duration-\[350ms\]{--tw-duration:.35s;transition-duration:.35s}.duration-\[400ms\]{--tw-duration:.4s;transition-duration:.4s}.\[transition-timing-function\:var\(--ease-smooth\)\]{transition-timing-function:var(--ease-smooth)}.select-none{-webkit-user-select:none;user-select:none}.duration-200{animation-duration:.2s}.duration-300{animation-duration:.3s}.duration-700{animation-duration:.7s}.duration-\[350ms\]{animation-duration:.35s}.duration-\[400ms\]{animation-duration:.4s}@media(hover:hover){.group-hover\:scale-110:is(:where(.group):hover *){--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x) var(--tw-scale-y)}.group-hover\:scale-\[1\.03\]:is(:where(.group):hover *){scale:1.03}.group-hover\:bg-\[var\(--border-accent\)\]:is(:where(.group):hover *){background-color:var(--border-accent)}.group-hover\:shadow-\[var\(--shadow-media-control-hover\)\]:is(:where(.group):hover *){--tw-shadow:var(--shadow-media-control-hover);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.group-hover\/card\:scale-\[1\.02\]:is(:where(.group\/card):hover *){scale:1.02}.group-hover\/tech\:bg-\[var\(--surface-card-hover\)\]:is(:where(.group\/tech):hover *){background-color:var(--surface-card-hover)}}.placeholder\:text-\[var\(--text-muted\)\]::placeholder{color:var(--text-muted)}.backdrop\:bg-\[var\(--surface-overlay\)\]::backdrop{background-color:var(--surface-overlay)}.backdrop\:backdrop-blur-sm::backdrop{--tw-backdrop-blur:blur(var(--blur-sm));-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,)}@media(hover:hover){.hover\:-translate-y-0\.5:hover{--tw-translate-y:calc(var(--spacing) * -.5);translate:var(--tw-translate-x) var(--tw-translate-y)}.hover\:-translate-y-\[1px\]:hover{--tw-translate-y: -1px ;translate:var(--tw-translate-x) var(--tw-translate-y)}.hover\:border-\[var\(--border-strong\)\]:hover{border-color:var(--border-strong)}.hover\:bg-\[color-mix\(in_srgb\,var\(--surface-card\)_35\%\,transparent\)\]:hover{background-color:var(--surface-card)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-\[color-mix\(in_srgb\,var\(--surface-card\)_35\%\,transparent\)\]:hover{background-color:color-mix(in srgb,var(--surface-card) 35%,transparent)}}.hover\:bg-\[var\(--surface-card-hover\)\]:hover{background-color:var(--surface-card-hover)}.hover\:bg-\[var\(--surface-subtle\)\]:hover{background-color:var(--surface-subtle)}.hover\:text-\[var\(--text-secondary\)\]:hover{color:var(--text-secondary)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-95:hover{opacity:.95}.hover\:shadow-\[var\(--shadow-button-hover\)\]:hover{--tw-shadow:var(--shadow-button-hover);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-\[var\(--shadow-elevated-hover\)\]:hover{--tw-shadow:var(--shadow-elevated-hover);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-\[var\(--shadow-soft-hover\)\]:hover{--tw-shadow:var(--shadow-soft-hover);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-\[var\(--border-accent\)\]:focus-visible{--tw-ring-color:var(--border-accent)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus-visible\:ring-offset-\[var\(--surface-card\)\]:focus-visible{--tw-ring-offset-color:var(--surface-card)}.focus-visible\:ring-offset-\[var\(--surface-page\)\]:focus-visible{--tw-ring-offset-color:var(--surface-page)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.active\:scale-\[0\.985\]:active{scale:.985}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-50:disabled{opacity:.5}@media(min-width:40rem){.sm\:order-1{order:1}.sm\:order-2{order:2}.sm\:block{display:block}.sm\:flex{display:flex}.sm\:hidden{display:none}.sm\:size-3\/4{width:75%;height:75%}.sm\:size-20{width:calc(var(--spacing) * 20);height:calc(var(--spacing) * 20)}.sm\:h-auto{height:auto}.sm\:w-3\/4{width:75%}.sm\:w-4\/4{width:100%}.sm\:max-w-7xl{max-width:var(--container-7xl)}.sm\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-\[1fr_1px_1fr\]{grid-template-columns:1fr 1px 1fr}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:items-start{align-items:flex-start}.sm\:justify-between{justify-content:space-between}.sm\:justify-start{justify-content:flex-start}.sm\:gap-0{gap:calc(var(--spacing) * 0)}.sm\:gap-8{gap:calc(var(--spacing) * 8)}.sm\:p-7{padding:calc(var(--spacing) * 7)}.sm\:p-8{padding:calc(var(--spacing) * 8)}.sm\:px-6{padding-inline:calc(var(--spacing) * 6)}.sm\:px-7{padding-inline:calc(var(--spacing) * 7)}.sm\:px-9{padding-inline:calc(var(--spacing) * 9)}.sm\:px-10{padding-inline:calc(var(--spacing) * 10)}.sm\:px-\[0\.7rem\]{padding-inline:.7rem}.sm\:py-20{padding-block:calc(var(--spacing) * 20)}.sm\:py-24{padding-block:calc(var(--spacing) * 24)}.sm\:py-28{padding-block:calc(var(--spacing) * 28)}.sm\:py-\[0\.3rem\]{padding-block:.3rem}.sm\:py-\[0\.25rem\]{padding-block:.25rem}.sm\:text-left{text-align:left}.sm\:text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.sm\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.sm\:text-\[0\.7rem\]{font-size:.7rem}.sm\:text-\[0\.62rem\]{font-size:.62rem}.sm\:text-\[0\.95rem\]{font-size:.95rem}.sm\:text-\[1\.55rem\]{font-size:1.55rem}.sm\:text-\[1\.65rem\]{font-size:1.65rem}.sm\:text-\[2rem\]{font-size:2rem}}@media(min-width:48rem){.md\:w-3\/4{width:75%}.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\:px-12{padding-inline:calc(var(--spacing) * 12)}.md\:text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}}@media(min-width:64rem){.lg\:min-h-0{min-height:calc(var(--spacing) * 0)}.lg\:w-2\/4{width:50%}.lg\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-\[1fr_minmax\(200px\,0\.5fr\)\]{grid-template-columns:1fr minmax(200px,.5fr)}.lg\:grid-cols-\[5fr_4fr\]{grid-template-columns:5fr 4fr}.lg\:grid-cols-\[minmax\(0\,0\.70fr\)_minmax\(0\,0\.50fr\)\]{grid-template-columns:minmax(0,.7fr) minmax(0,.5fr)}.lg\:items-stretch{align-items:stretch}.lg\:gap-10{gap:calc(var(--spacing) * 10)}.lg\:rounded-l-\[26px\]{border-top-left-radius:26px;border-bottom-left-radius:26px}.lg\:rounded-r-none{border-top-right-radius:0;border-bottom-right-radius:0}.lg\:border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.lg\:border-b-0{border-bottom-style:var(--tw-border-style);border-bottom-width:0}.lg\:border-r-\[var\(--border-subtle\)\]{border-right-color:var(--border-subtle)}.lg\:px-16{padding-inline:calc(var(--spacing) * 16)}.lg\:py-28{padding-block:calc(var(--spacing) * 28)}.lg\:py-32{padding-block:calc(var(--spacing) * 32)}.lg\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.lg\:text-\[2\.25rem\]{font-size:2.25rem}}@media(min-width:80rem){.xl\:px-0{padding-inline:calc(var(--spacing) * 0)}}}:root{--surface-page:var(--color-bg-1);--surface-section:var(--color-bg-2);--surface-subtle:var(--color-bg-3);--surface-card:#fffbf5;--surface-card-hover:#f7f3ec;--surface-panel:#f8f4ee;--surface-panel-strong:#ece4d8;--surface-footer:#111;--surface-footer-text:#fff;--surface-overlay:#0000008c;--surface-poster-default:linear-gradient(180deg, var(--surface-card) 0%, var(--surface-subtle) 100%);--surface-poster-gloss:linear-gradient(180deg, #fffcf729 0%, #f7efe414 100%);--surface-poster-vignette:radial-gradient(circle_at_center, transparent 0%, transparent 58%, #0000000d 100%);--text-primary:var(--color-text-1);--text-secondary:var(--color-text-2);--text-muted:#6b5e4c;--text-accent:var(--color-text-3);--text-accent-strong:#5c3817;--text-on-accent:#fff;--border-subtle:#e0d5c3;--border-strong:#c9b896;--border-accent:#1c1812;--shadow-soft:0 10px 30px #11111114;--shadow-soft-hover:0 16px 36px #11111124;--shadow-button:0 10px 30px #11111129;--shadow-button-hover:0 18px 38px #11111138;--shadow-elevated:0 12px 36px #62482012;--shadow-elevated-hover:0 4px 32px #64461e17;--shadow-media-control:0 8px 24px #00000024;--shadow-media-control-hover:0 12px 32px #00000038;--shadow-media-poster:0 18px 32px #5f27042e;--shadow-overlay:0 24px 60px #0006;--button-shine:linear-gradient(120deg, transparent 20%, #ffffff29 50%, transparent 80%);--project-type-web-border:#d6c2a4;--project-type-web-bg:#fff8ef;--project-type-web-text:#9b672b;--project-type-mobile-border:#b7caf3;--project-type-mobile-bg:#f6f9ff;--project-type-mobile-text:#3568d4;--project-type-api-border:#c7d8c1;--project-type-api-bg:#f2faf0;--project-type-api-text:#3d7a49;--project-category-test-case-border:#ead3c0;--project-category-test-case-bg:#fffaf6;--project-category-test-case-text:#8f5a2f;--project-category-client-border:#c8d5f3;--project-category-client-bg:#f6f8ff;--project-category-client-text:#4a62c8;--project-category-myself-border:#d9c7eb;--project-category-myself-bg:#fbf8ff;--project-category-myself-text:#7c58a8;--bg-1:var(--color-bg-1);--bg-2:var(--color-bg-2);--bg-3:var(--color-bg-3);--text-1:var(--color-text-1);--text-2:var(--color-text-2);--text-3:var(--color-text-3);--button-text:var(--color-button-text);--button-bg:var(--color-button-bg)}[data-theme=dark]{--surface-page:var(--color-bg-1-dark);--surface-section:var(--color-bg-2-dark);--surface-subtle:var(--color-bg-3-dark);--surface-card:#2a2420;--surface-card-hover:#332d28;--surface-panel:#26201c;--surface-panel-strong:#312a24;--surface-footer:#f4eee2;--surface-footer-text:#111;--surface-overlay:#000000b3;--surface-poster-default:linear-gradient(180deg, #2f2924 0%, #24201c 100%);--surface-poster-gloss:linear-gradient(180deg, #f4eee214 0%, #e7e1d50a 100%);--surface-poster-vignette:radial-gradient(circle_at_center, transparent 0%, transparent 58%, #ffffff0f 100%);--text-primary:var(--color-text-1-dark);--text-secondary:var(--color-text-2-dark);--text-muted:#b9ac95;--text-accent:var(--color-text-3-dark);--text-accent-strong:#f3d79c;--text-on-accent:#111;--border-subtle:#4a4138;--border-strong:#6d5b46;--border-accent:#f4eee2;--shadow-soft:0 10px 30px #0000003d;--shadow-soft-hover:0 16px 36px #00000052;--shadow-button:0 10px 30px #0000004d;--shadow-button-hover:0 18px 38px #0006;--shadow-elevated:0 12px 36px #00000038;--shadow-elevated-hover:0 4px 32px #00000047;--shadow-media-control:0 8px 24px #0000002e;--shadow-media-control-hover:0 12px 32px #00000047;--shadow-media-poster:0 18px 32px #00000038;--shadow-overlay:0 24px 60px #0009;--button-shine:linear-gradient(120deg, transparent 20%, #ffffff1f 50%, transparent 80%);--project-type-web-border:#6e5538;--project-type-web-bg:#2d241d;--project-type-web-text:#e9b87a;--project-type-mobile-border:#3e5680;--project-type-mobile-bg:#202734;--project-type-mobile-text:#9ab9ff;--project-type-api-border:#3f5943;--project-type-api-bg:#202b21;--project-type-api-text:#8dc19a;--project-category-test-case-border:#6a4a36;--project-category-test-case-bg:#2a221d;--project-category-test-case-text:#f2c39a;--project-category-client-border:#44527c;--project-category-client-bg:#202536;--project-category-client-text:#adc0ff;--project-category-myself-border:#54406f;--project-category-myself-bg:#26202f;--project-category-myself-text:#d1b7ef;--bg-1:var(--color-bg-1-dark);--bg-2:var(--color-bg-2-dark);--bg-3:var(--color-bg-3-dark);--text-1:var(--color-text-1-dark);--text-2:var(--color-text-2-dark);--text-3:var(--color-text-3-dark);--button-text:var(--color-button-text-dark);--button-bg:var(--color-button-bg-dark)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--surface-page:var(--color-bg-1-dark);--surface-section:var(--color-bg-2-dark);--surface-subtle:var(--color-bg-3-dark);--surface-card:#2a2420;--surface-card-hover:#332d28;--surface-panel:#26201c;--surface-panel-strong:#312a24;--surface-footer:#f4eee2;--surface-footer-text:#111;--surface-overlay:#000000b3;--surface-poster-default:linear-gradient(180deg, #2f2924 0%, #24201c 100%);--surface-poster-gloss:linear-gradient(180deg, #f4eee214 0%, #e7e1d50a 100%);--surface-poster-vignette:radial-gradient(circle_at_center, transparent 0%, transparent 58%, #ffffff0f 100%);--text-primary:var(--color-text-1-dark);--text-secondary:var(--color-text-2-dark);--text-muted:#b9ac95;--text-accent:var(--color-text-3-dark);--text-accent-strong:#f3d79c;--text-on-accent:#111;--border-subtle:#4a4138;--border-strong:#6d5b46;--border-accent:#f4eee2;--shadow-soft:0 10px 30px #0000003d;--shadow-soft-hover:0 16px 36px #00000052;--shadow-button:0 10px 30px #0000004d;--shadow-button-hover:0 18px 38px #0006;--shadow-elevated:0 12px 36px #00000038;--shadow-elevated-hover:0 4px 32px #00000047;--shadow-media-control:0 8px 24px #0000002e;--shadow-media-control-hover:0 12px 32px #00000047;--shadow-media-poster:0 18px 32px #00000038;--shadow-overlay:0 24px 60px #0009;--button-shine:linear-gradient(120deg, transparent 20%, #ffffff1f 50%, transparent 80%);--project-type-web-border:#6e5538;--project-type-web-bg:#2d241d;--project-type-web-text:#e9b87a;--project-type-mobile-border:#3e5680;--project-type-mobile-bg:#202734;--project-type-mobile-text:#9ab9ff;--project-type-api-border:#3f5943;--project-type-api-bg:#202b21;--project-type-api-text:#8dc19a;--project-category-test-case-border:#6a4a36;--project-category-test-case-bg:#2a221d;--project-category-test-case-text:#f2c39a;--project-category-client-border:#44527c;--project-category-client-bg:#202536;--project-category-client-text:#adc0ff;--project-category-myself-border:#54406f;--project-category-myself-bg:#26202f;--project-category-myself-text:#d1b7ef;--bg-1:var(--color-bg-1-dark);--bg-2:var(--color-bg-2-dark);--bg-3:var(--color-bg-3-dark);--text-1:var(--color-text-1-dark);--text-2:var(--color-text-2-dark);--text-3:var(--color-text-3-dark);--button-text:var(--color-button-text-dark);--button-bg:var(--color-button-bg-dark)}}html{scroll-behavior:smooth}body{font-family:var(--font-primary);background-color:var(--surface-page);color:var(--text-primary);width:100%;height:100%;transition:background-color .3s,color .3s}.bg-1{background-color:var(--surface-page)}.bg-2{background-color:var(--surface-section)}.bg-3{background-color:var(--surface-subtle)}.text-1{color:var(--text-primary)}.text-2{color:var(--text-secondary)}.text-3{color:var(--text-accent)}.font-primary{font-family:var(--font-primary)}.font-secondary{font-family:var(--font-secondary)}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0) scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1)) rotate(var(--tw-enter-rotate,0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0) scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1)) rotate(var(--tw-exit-rotate,0))}}@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-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@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-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}.mask-linear[data-astro-cid-vmasiem7]{mask-image:linear-gradient(black 90%,transparent 100%);-webkit-mask-image:linear-gradient(black 90%,transparent 100%)}.contact-status-dialog{position:fixed;inset:0;margin:0;padding:0;border:0;width:100vw;height:100dvh;max-width:none;max-height:none;display:none;background:transparent;z-index:50;place-items:center}.contact-status-dialog[open]{display:grid;place-items:center;background:transparent}.contact-status-dialog::backdrop{position:fixed;inset:0;background:var(--surface-overlay)}body.dialog-open{overflow:hidden}
