*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}:root{--background: 0 0% 100%;--foreground: 0 0% 3.9%;--card: 0 0% 100%;--card-foreground: 0 0% 3.9%;--popover: 0 0% 100%;--popover-foreground: 0 0% 3.9%;--primary: 0 0% 9%;--primary-foreground: 0 0% 98%;--secondary: 0 0% 96.1%;--secondary-foreground: 0 0% 9%;--muted: 0 0% 96.1%;--muted-foreground: 0 0% 45.1%;--accent: 0 0% 96.1%;--accent-foreground: 0 0% 9%;--destructive: 0 84.2% 60.2%;--destructive-foreground: 0 0% 98%;--border: 0 0% 89.8%;--input: 0 0% 89.8%;--ring: 0 0% 3.9%;--chart-1: 12 76% 61%;--chart-2: 173 58% 39%;--chart-3: 197 37% 24%;--chart-4: 43 74% 66%;--chart-5: 27 87% 67%;--radius: .5rem}.dark{--background: 0 0% 3.9%;--foreground: 0 0% 98%;--card: 0 0% 3.9%;--card-foreground: 0 0% 98%;--popover: 0 0% 3.9%;--popover-foreground: 0 0% 98%;--primary: 0 0% 98%;--primary-foreground: 0 0% 9%;--secondary: 0 0% 14.9%;--secondary-foreground: 0 0% 98%;--muted: 0 0% 14.9%;--muted-foreground: 0 0% 63.9%;--accent: 0 0% 14.9%;--accent-foreground: 0 0% 98%;--destructive: 0 62.8% 30.6%;--destructive-foreground: 0 0% 98%;--border: 0 0% 14.9%;--input: 0 0% 14.9%;--ring: 0 0% 83.1%;--chart-1: 220 70% 50%;--chart-2: 160 60% 45%;--chart-3: 30 80% 55%;--chart-4: 280 65% 60%;--chart-5: 340 75% 55%}*{border-color:hsl(var(--border))}body{background-color:hsl(var(--background));color:hsl(var(--foreground))}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.mb-6{margin-bottom:1.5rem}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.size-4{width:1rem;height:1rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.translate-y-0\.5{--tw-translate-y: .125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-4{gap:1rem}.rounded-md{border-radius:calc(var(--radius) - 2px)}.border-b{border-bottom-width:1px}.py-4{padding-top:1rem;padding-bottom:1rem}.pb-4{padding-bottom:1rem}.pt-0{padding-top:0}.text-left{text-align:left}.text-sm{font-size:.875rem;line-height:1.25rem}.font-medium{font-weight:500}.text-accent{color:hsl(var(--accent))}.text-muted-foreground{color:hsl(var(--muted-foreground))}.opacity-0{opacity:0}.outline-none{outline:2px solid transparent;outline-offset:2px}.blur{--tw-blur: blur(8px);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)}.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{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}@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))}}.duration-200{animation-duration:.2s}:root{font-family:Google Sans,sans-serif;line-height:1.6;font-weight:400;--grid: clamp(32px, 6vw, 48px);--grid-half: calc(var(--grid) / 2);--grid-quarter: calc(var(--grid) / 4);--bg: #313131;--panel: #313131;--panel-strong: #313131;--panel-focus: rgba(36, 36, 37, .82);--grid-highlight: rgba(102, 104, 118, .25);--grid-line: rgba(203, 206, 216, .45);--accent: #f4f1e6;--text: #f5f5f5;--subtle: #b4b8c0;--muted: #80848d;--toggle-glow: #f4894b;--toggle-glow-2: #65c0fdaa;color:var(--text);background-color:var(--bg);text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;font-synthesis:none}[data-theme=light]{--bg: #d6d3cc;--panel: #d6d3cc;--panel-strong: #d6d3cc;--panel-focus: #e3ded5;--grid-highlight: #e3ded5;--grid-line: rgba(0, 0, 0, .737);--accent: #2f323d;--text: #1f2024;--subtle: #4b4f58;--muted: #7d8088;--toggle-glow: #3f2414;--toggle-glow-2: #0b3f62aa}*{box-sizing:border-box}html,body{height:100%}body{margin:0;background-color:var(--bg);color:var(--text);overflow:hidden}@media(max-width:640px){body{overflow-y:auto;overflow-x:hidden}}a{color:var(--text);text-decoration:none}a:hover{color:var(--accent)}#root{min-height:100%;height:100%}.last\:border-b-0:last-child{border-bottom-width:0px}.hover\:underline:hover{text-decoration-line:underline}.focus-visible\:border-ring:focus-visible{border-color:hsl(var(--ring))}.focus-visible\:ring-\[3px\]:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color: hsl(var(--ring) / .5)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:opacity-100{opacity:1}.\[\&\[data-state\=open\]\>svg\]\:rotate-180[data-state=open]>svg{--tw-rotate: 180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&_\[stroke-dasharray\=\'1px_1px\'\]\]\:\!\[stroke-dasharray\:1px_0px\] [stroke-dasharray="1px 1px"]{stroke-dasharray:1px 0px!important}.loading-screen{position:fixed;inset:0;z-index:9999;background-color:var(--bg);display:flex;align-items:center;justify-content:center}.loading-screen__content{display:flex;flex-direction:column;align-items:center;gap:2rem}.loading-screen__catto{width:clamp(100px,20vw,180px);height:auto;-o-object-fit:contain;object-fit:contain}.loading-screen__progress-container{width:clamp(120px,25vw,200px)}.loading-screen__progress-bar{width:100%;height:3px;background-color:var(--muted);border-radius:2px;overflow:hidden}.loading-screen__progress-fill{height:100%;background-color:var(--accent);border-radius:2px;transition:width .1s linear}@media(max-width:1024px){.loading-screen__catto{width:clamp(80px,18vw,150px)}.loading-screen__progress-container{width:clamp(100px,22vw,180px)}}@media(max-width:640px){.loading-screen__catto{width:clamp(70px,25vw,120px)}.loading-screen__progress-container{width:clamp(90px,30vw,150px)}.loading-screen__progress-bar{height:2px}}.text-accent{font-family:Google Sans Code,monospace}.app-shell{width:100%;height:100%;padding:var(--grid);display:grid;justify-content:center;align-items:stretch;position:relative;z-index:1}.theme-ripple{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:999;overflow:hidden}.theme-ripple:before{content:"";position:absolute;left:var(--ripple-x);top:var(--ripple-y);width:10px;height:10px;background:var(--ripple-color);border-radius:50%}.theme-ripple--expand:before{transform:translate(-50%,-50%) scale(0);animation:theme-ripple-expand .8s cubic-bezier(.4,0,.2,1) forwards}.theme-ripple--contract:before{transform:translate(-50%,-50%) scale(400);animation:theme-ripple-contract .8s cubic-bezier(.4,0,.2,1) forwards}@keyframes theme-ripple-expand{0%{transform:translate(-50%,-50%) scale(0);opacity:.4}85%{transform:translate(-50%,-50%) scale(400);opacity:1}to{transform:translate(-50%,-50%) scale(400);opacity:1}}@keyframes theme-ripple-contract{0%{transform:translate(-50%,-50%) scale(400);opacity:1}85%{transform:translate(-50%,-50%) scale(0);opacity:.5}to{transform:translate(-50%,-50%) scale(0);opacity:0}}.grid-layout{width:100%;max-width:calc(var(--grid) * 24);display:grid;grid-template-columns:repeat(12,minmax(0,1fr));position:relative;overflow:hidden;height:100%;align-items:stretch}.grid-overlay{position:fixed;inset:0;pointer-events:none;z-index:0}.grid-line{position:absolute;background:var(--grid-line)}.grid-line--vertical{top:0;height:100vh;width:1px;transform:translate(-.5px)}.grid-line--horizontal{left:0;width:100vw;height:1px;transform:translateY(-.5px)}.grid-panel{background:var(--panel);display:flex;flex-direction:column;min-height:0;height:100%;padding:calc(var(--grid)/2);overflow:hidden;position:relative;z-index:1;-webkit-backdrop-filter:blur(.5rem);backdrop-filter:blur(.5rem)}.grid-panel__nav{margin-bottom:calc(var(--grid)/2)}.grid-panel__body{flex:1;min-height:0;overflow-y:auto;width:100%}.grid-panel__body::-webkit-scrollbar,.works-field::-webkit-scrollbar{width:6px}.grid-panel__body::-webkit-scrollbar-thumb,.works-field::-webkit-scrollbar-thumb{background:#ffffff40}.grid-panel--primary{grid-column:span 8}.grid-panel--secondary{grid-column:span 3;background:var(--panel-strong)}.grid-panel--divider{grid-column:span 1;background-color:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.nav{display:grid;grid-template-columns:var(--grid) 1fr;align-items:center;gap:var(--grid);background-color:var(--grid-highlight);padding-left:.5em;border:1px solid var(--grid-line)}.nav__icon{font-size:1.5rem}.nav__icon img{transform:scale(.8)}.nav__links{list-style:none;display:flex;justify-content:flex-end;align-items:center;gap:var(--grid-half);margin:0;padding:0}.nav__toggle{width:var(--grid);height:var(--grid);display:flex;align-items:center;justify-content:center}.theme-toggle{display:inline-flex;align-items:center;gap:var(--grid-quarter);padding:var(--grid-quarter) var(--grid-half);border:1px solid var(--grid-line);border-radius:999px;background:transparent;color:inherit;text-transform:lowercase;letter-spacing:.1em;cursor:pointer;will-change:filter;transition:filter,color .3s}.theme-toggle span:first-child{font-size:1.3rem;font-weight:700}.theme-toggle:hover{color:#fff;filter:drop-shadow(0 0 1em var(--toggle-glow)) drop-shadow(0 0 1em var(--toggle-glow-2))}.nav__links button{background:transparent;border:none;color:var(--muted);text-transform:lowercase;letter-spacing:.1em;padding:0;cursor:pointer}.nav__links button.is-active,.nav__links button:hover{color:var(--text)}.nav__links button.is-active{border-bottom:2px solid var(--subtle)}.hover-underline-animation{position:relative;color:#fff;padding-bottom:20px}.hover-underline-animation:after{content:"";position:absolute;width:100%;transform:scaleX(0);height:2px;bottom:0;left:0;background-color:var(--subtle);transform-origin:bottom right;transition:transform .25s ease-out}.nav__links li:hover .hover-underline-animation:after{transform:scaleX(1);transform-origin:bottom left}.nav__hamburger,.nav__mobile-overlay{display:none}.eyebrow{font-size:.7rem;color:var(--muted);margin:0 0 var(--grid-quarter)}.eyebrow b{cursor:pointer;color:var(--text)}.label,.tech-label{text-transform:uppercase;font-size:.65rem;letter-spacing:.25em;color:var(--muted);margin-bottom:var(--grid-quarter)}.about{display:flex;flex-direction:column;gap:calc(var(--grid)/8);padding:0 var(--grid-half);padding-top:calc(var(--grid));width:100%}.about h1{font-size:clamp(1.5rem,3.4vw,2.6rem);line-height:1.3}.about p{margin:0 0 var(--grid-half);color:var(--subtle)}.about__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(calc(var(--grid) * 3),1fr));gap:var(--grid)}.about__mobile-photo,.about__mobile-tech{display:none}.grid-card{background:var(--panel-strong);padding:var(--grid-half);display:flex;flex-direction:column;gap:var(--grid-quarter);color:var(--text);text-align:left;width:100%}.grid-card.is-active,.grid-card:hover{background:var(--panel-focus)}button.grid-card,a.grid-card{border:none;background:inherit;color:inherit;font:inherit;text-align:left;cursor:pointer;text-decoration:none}.project-stack{display:flex;flex-direction:column;gap:calc(var(--grid)/2);width:100%}.card-row{display:flex;justify-content:space-between;gap:var(--grid-half);align-items:baseline}.card-row h3{margin:0;font-size:1.3rem}.tag-row{display:flex;flex-wrap:wrap;margin-top:.618em;gap:var(--grid-quarter);text-transform:uppercase;letter-spacing:.15em;font-size:.75rem}.tag-row span{padding:var(--grid-quarter) var(--grid-half);background:var(--panel)}.works-field{display:grid;grid-template-columns:repeat(auto-fit,minmax(calc(var(--grid) * 2),1fr));gap:var(--grid-half);overflow-x:hidden;height:100%;width:100%}.work-chip{background:var(--panel-strong);padding:var(--grid-half);display:flex;flex-direction:column;gap:var(--grid-quarter);text-align:left;color:var(--text);border:none;cursor:pointer}.work-chip.is-active,.work-chip:hover{background:var(--panel-focus)}.contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--grid);overflow:hidden;width:100%}.secondary-stack{display:flex;flex-direction:column;gap:calc(var(--grid)/2)}.secondary-stack h3{color:var(--subtle)}.link-stack{padding:0 1rem;display:flex;flex-direction:column;gap:var(--grid-quarter)}.link-stack a{font-size:.9em;text-transform:uppercase;letter-spacing:.25em;color:var(--muted)}.link-stack a:hover{color:var(--text);text-decoration:none}.tech-stack-categories{padding:0 1rem;overflow:hidden}.tech-stack-categories div{border-bottom:none}.tech-stack{display:flex;flex-wrap:wrap;gap:.618em;overflow:visible}.tech-stack i{font-size:1.2em;color:var(--subtle);transition:color .15s ease}.tech-stack .tech-icon-tooltip:hover i{color:var(--text)}.tech-icon-tooltip{position:relative;cursor:pointer;display:inline-flex}.tech-icon-tooltip:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%) scale(.5);transform-origin:bottom center;background:var(--panel-focus);color:var(--text);padding:.25rem .5rem;font-size:.65rem;font-family:inherit;font-style:normal;white-space:nowrap;opacity:0;visibility:hidden;transition:all .15s ease-out;z-index:9999;border:.1px solid var(--grid-line);pointer-events:none}.tech-icon-tooltip:before{content:"";position:absolute;bottom:calc(100% + 2px);left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--panel-focus);opacity:0;visibility:hidden;transition:all .15s ease-out;z-index:9999;pointer-events:none}.tech-icon-tooltip:hover:after,.tech-icon-tooltip:hover:before{opacity:1;visibility:visible}.tech-icon-tooltip:hover:after{transform:translate(-50%) scale(1)}.tech-stack-categories [data-slot=accordion-content]{overflow:visible!important;mask-image:none!important;-webkit-mask-image:none!important}.tech-stack-categories [data-slot=accordion-content]>div{overflow:visible!important}.tech-label{margin-bottom:0;padding-bottom:.618em;padding-top:1em}.tech-label:hover{color:var(--text);text-decoration:none}.photo-slot{min-height:calc(var(--grid) * 2);background:var(--panel);display:flex;flex-direction:column;align-items:center;justify-content:center;letter-spacing:.2em;color:var(--muted)}.photo-slot img{width:100%;height:auto;display:block}.project-image-slot{min-height:calc(var(--grid) * 4);background:var(--panel);display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;overflow:hidden}.project-image-slot img{width:100%;height:auto;-o-object-fit:cover;object-fit:cover;display:block}.project-details{font-size:.85rem;color:var(--subtle);margin-top:var(--grid-quarter);line-height:1.5}.project-card-image,.project-card-footer,.illust-mobile-info,.contact-mobile-header{display:none}.work-meta-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--grid-quarter)}.work-meta-list li{display:flex;justify-content:space-between}.value{margin:0;font-size:1.1rem;display:flex;align-items:center;justify-content:space-between}.value span{margin-left:.5em}.abt_title{display:flex;flex-direction:row;justify-content:space-between;gap:calc(var(--grid) / 2);margin-bottom:1em}.abt_title_txt{width:100%;text-align:center}.abt_title_unicode{color:var(--muted)}@media(max-width:960px){.grid-layout{grid-template-columns:repeat(6,minmax(0,1fr))}.grid-panel--primary,.grid-panel--secondary{grid-column:span 6}.grid-panel--divider{display:none}.contact-grid{grid-template-columns:repeat(2,1fr);gap:var(--grid-half);border-top:.5px solid var(--grid-line);padding:var(--grid-half)}}@media(max-width:960px){.app-shell{justify-content:stretch;justify-items:stretch}.grid-layout{grid-template-columns:1fr;height:auto;min-height:100%;max-width:none;width:100%}.grid-panel{width:100%}.grid-panel--primary{grid-column:1;min-height:auto;width:100%}.grid-panel__body{width:100%}.grid-panel--secondary{grid-column:1;display:none}.about__mobile-photo,.about__mobile-tech{display:block}.about__mobile-photo{width:100%;max-width:180px;margin:0 auto var(--grid)}.about__mobile-photo img{width:100%;height:auto;display:block}.about__mobile-tech{margin-top:var(--grid)}.about__grid{margin-top:var(--grid);padding-top:var(--grid);border-top:.5px solid var(--grid-line)}.contact-grid{grid-template-columns:1fr;gap:var(--grid-half);width:100%}.contact-mobile-header{display:block;margin-bottom:var(--grid)}.contact-section{padding:0 var(--grid-half);padding-top:calc(var(--grid))}.contact-mobile-header h3{margin:0 0 var(--grid-quarter);font-size:1.2rem}.contact-mobile-header p{margin:0;color:var(--subtle);font-size:.9rem}.works-field{display:block;width:100%;height:auto}.works-masonry-container{width:100%;height:auto}.project-card-image{display:block;width:100%;border-radius:6px;overflow:hidden;margin-bottom:var(--grid-half);background:var(--panel)}.project-card-image img{width:100%;height:auto;-o-object-fit:cover;object-fit:cover;display:block}.project-card-footer{display:flex;flex-wrap:wrap;gap:var(--grid-half);margin-top:var(--grid-half);padding-top:var(--grid-half);border-top:1px solid var(--grid-line);align-items:center}.project-card-links{display:flex;flex-wrap:wrap;gap:var(--grid-quarter) var(--grid-half)}.project-card-links a{font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);padding:var(--grid-quarter) var(--grid-half);background:var(--panel);border-radius:4px}.project-card-links a:hover{color:var(--text);text-decoration:none}.project-card-codevs{font-size:.75rem;color:var(--muted);display:flex;flex-wrap:wrap;align-items:center;gap:.25em}.project-card-codevs .codev-label{text-transform:uppercase;letter-spacing:.1em;opacity:.7}.project-card-codevs a{color:var(--subtle)}.project-card-codevs a:hover{color:var(--text);text-decoration:none}.illust-mobile-info{display:block;margin-top:var(--grid);padding:var(--grid);background:var(--panel-strong);border-top:.5px solid var(--grid-line)}.illust-mobile-info .wip-banner{text-align:center;margin-bottom:var(--grid);font-size:.85rem}.illust-mobile-links{display:flex;flex-direction:column;gap:var(--grid);justify-content:center}.illust-link-group{display:flex;flex-direction:column;gap:var(--grid-quarter)}.illust-link-group .label{text-align:left}.illust-link-group>a{font-size:.8rem;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);padding:var(--grid-quarter) var(--grid-half);background:var(--panel);border-radius:4px}.illust-link-group>a:hover{color:var(--text);text-decoration:none}.illust-socials{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--grid-quarter)}.illust-socials a{font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);padding:var(--grid-quarter) var(--grid-half);background:var(--panel);border-radius:4px}.illust-socials a:hover{color:var(--text);text-decoration:none}}@media(max-width:640px){:root{--grid: clamp(24px, 5vw, 32px)}.app-shell{padding:var(--grid);justify-content:stretch}.grid-layout{grid-template-columns:1fr;height:auto;min-height:100%;max-width:none;width:100%}.grid-panel{padding:var(--grid-half);width:100%}.grid-panel--primary{grid-column:1;min-height:auto;width:100%}.grid-panel--divider{display:none}.grid-panel--secondary{grid-column:1;display:none;border-top:1px solid var(--grid-line)}.grid-panel__body{width:100%}.grid-panel__nav{margin-bottom:var(--grid-half)}.nav{display:flex;justify-content:space-between;gap:var(--grid-half);padding:var(--grid-quarter);position:relative}.nav__icon{max-width:1.6em}.nav__icon img{transform:scale(.7)}.nav__links--desktop{display:none}.nav__hamburger{display:flex;align-items:center;justify-content:center;width:var(--grid);height:var(--grid);background:transparent;border:none;cursor:pointer;padding:0;z-index:1001}.hamburger-icon{display:flex;flex-direction:column;justify-content:center;align-items:center;width:20px;height:16px;position:relative}.hamburger-icon span{display:block;width:100%;height:2px;background-color:var(--text);transition:all .3s ease;position:absolute;left:0}.hamburger-icon span:nth-child(1){top:0}.hamburger-icon span:nth-child(2){top:50%;transform:translateY(-50%)}.hamburger-icon span:nth-child(3){bottom:0}.hamburger-icon.is-open span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}.hamburger-icon.is-open span:nth-child(2){opacity:0}.hamburger-icon.is-open span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}.nav__mobile-overlay{display:flex;flex-direction:column;position:fixed;inset:0;background-color:var(--panel);z-index:1000;padding:calc(var(--grid) * 2) var(--grid);opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .3s ease,visibility .3s ease,transform .3s ease}.nav__mobile-overlay.is-open{opacity:1;visibility:visible;transform:translateY(0)}.nav__mobile-links{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--grid-half);flex:1;justify-content:center}.nav__mobile-links li{text-align:center}.nav__mobile-link{background:transparent;border:none;color:var(--muted);font-size:1.5rem;text-transform:lowercase;letter-spacing:.15em;padding:var(--grid-half) var(--grid);cursor:pointer;position:relative;transition:color .25s ease;width:100%}.nav__mobile-link:hover,.nav__mobile-link.is-active{color:var(--text)}.nav__mobile-link.is-active:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:40px;height:2px;background-color:var(--subtle)}.nav__mobile-link:before{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%) scaleX(0);width:40px;height:2px;background-color:var(--subtle);transition:transform .25s ease;transform-origin:center}.nav__mobile-link:hover:before{transform:translate(-50%) scaleX(1)}.nav__mobile-link.is-active:before{transform:translate(-50%) scaleX(1)}.nav__mobile-footer{display:flex;justify-content:center;padding-top:var(--grid);border-top:1px solid var(--grid-line)}.nav__mobile-footer .theme-toggle{padding:var(--grid-half) var(--grid)}.nav__mobile-footer .theme-toggle span:first-child{font-size:1.2rem}.hover-underline-animation{padding-bottom:12px}.nav__toggle{width:auto;height:auto}.theme-toggle{padding:var(--grid-quarter)}.theme-toggle span:first-child{font-size:1rem}.about{padding:var(--grid);padding-top:var(--grid-half);height:100%;justify-content:space-evenly;width:100%}.about h1{font-size:clamp(1.1rem,5vw,1.5rem)}.about p{font-size:.8rem}.abt_title{gap:var(--grid-quarter);margin-bottom:1em}.abt_title_unicode{display:none}.abt_title_txt{font-size:1.1em}.about__grid{margin-top:calc(var(--grid) * 1.618);padding-top:var(--grid);gap:var(--grid-half);border-top:.5px solid var(--grid-line)}.about__mobile-photo,.about__mobile-tech{display:block}.about__mobile-photo{width:100%;max-width:70%;margin:0 auto var(--grid)}.about__mobile-photo img{width:100%;height:auto;display:block}.about__mobile-tech{margin-top:var(--grid-half)}.contact-grid{grid-template-columns:1fr;gap:var(--grid-half);width:100%;padding:0}.contact-section{padding:var(--grid)}.contact-mobile-header{display:block;margin-bottom:var(--grid-half)}.contact-mobile-header h3{margin:0 0 var(--grid-quarter);font-size:1.1rem}.contact-mobile-header p{margin:0;color:var(--subtle);font-size:.8rem}.value{font-size:.9rem;word-break:break-word}.project-stack{gap:var(--grid-half);width:100%}.card-row{flex-direction:column;gap:var(--grid-quarter)}.card-row h3{font-size:1.1rem}.tag-row{font-size:.65rem;gap:calc(var(--grid-quarter) / 2)}.tag-row span{padding:calc(var(--grid-quarter) / 2) var(--grid-quarter)}.project-details{font-size:.8rem}.project-card-image{display:block;width:100%;border-radius:6px;overflow:hidden;margin-bottom:var(--grid-half);background:var(--panel)}.project-card-image img{width:100%;height:auto;-o-object-fit:cover;object-fit:cover;display:block}.project-card-footer{display:flex;flex-wrap:wrap;gap:var(--grid-half);margin-top:var(--grid-half);padding-top:var(--grid-half);border-top:1px solid var(--grid-line);align-items:center}.project-card-links{display:flex;flex-wrap:wrap;gap:var(--grid-quarter) var(--grid-half)}.project-card-links a{font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);padding:var(--grid-quarter) var(--grid-half);background:var(--panel);border-radius:4px}.project-card-links a:hover{color:var(--text);text-decoration:none}.project-card-codevs{font-size:.7rem;color:var(--muted);display:flex;flex-wrap:wrap;align-items:center;gap:.25em}.project-card-codevs .codev-label{text-transform:uppercase;letter-spacing:.1em;opacity:.7}.project-card-codevs a{color:var(--subtle)}.project-card-codevs a:hover{color:var(--text);text-decoration:none}.project-image-slot{min-height:calc(var(--grid) * 3)}.works-field{display:block;width:100%;height:auto}.works-masonry-container{width:100%;height:100%}.illust-mobile-info{display:block;margin-top:var(--grid);padding:var(--grid-half);background:var(--panel-strong)}.illust-mobile-info .wip-banner{text-align:center;margin-bottom:var(--grid-half);font-size:.75rem}.illust-mobile-links{display:flex;flex-direction:column;gap:var(--grid-half)}.illust-link-group{display:flex;flex-direction:column;gap:var(--grid-quarter)}.illust-link-group .label{text-align:left;margin-bottom:0}.illust-link-group>a{font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);padding:var(--grid-quarter) var(--grid-half);background:var(--panel);border-radius:4px}.illust-link-group>a:hover{color:var(--text);text-decoration:none}.illust-socials{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--grid-quarter)}.illust-socials a{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:var(--grid-quarter) var(--grid-half);background:var(--panel);border-radius:4px}.illust-socials a:hover{color:var(--text);text-decoration:none}.secondary-stack{gap:var(--grid-half)}.photo-slot{min-height:calc(var(--grid) * 1.5)}.tech-stack-categories{padding:0 var(--grid-quarter)}.tech-stack{gap:.5em}.tech-stack i{font-size:1em}.link-stack{padding:0 var(--grid-quarter)}.link-stack a{font-size:.8em}.grid-card{padding:var(--grid-half)}.grid-card p{font-size:.75rem}.eyebrow{font-size:.65rem}.label,.tech-label{font-size:.6rem}}@media(max-width:400px){.about h1{font-size:clamp(.9rem,4.5vw,1.2rem)}.nav__links button{font-size:.65rem;letter-spacing:.05em}.value{font-size:.8rem}.card-row h3{font-size:1rem}}.text-type{display:inline-block;white-space:pre-wrap}.text-type__cursor{margin-left:.25rem;display:inline-block;opacity:1}.text-type__cursor--hidden{display:none}.animated-portrait{position:relative;width:100%;display:flex;align-items:center;justify-content:center}.animated-portrait__image{width:100%;height:auto;display:block}.animated-portrait__dialogue{position:absolute;top:-5%;left:50%;transform:translate(-50%);background:var(--panel-focus);color:var(--text);padding:.35rem .65rem;font-size:.7rem;font-family:inherit;white-space:nowrap;z-index:10;border:.5px solid var(--grid-line);animation:dialogue-appear .2s ease-out forwards}.animated-portrait__dialogue:before{content:"";position:absolute;bottom:-12px;left:30%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--panel-focus)}@keyframes dialogue-appear{0%{opacity:0;transform:translate(-20%) scale(.8) translateY(50px)}to{opacity:1;transform:translate(10%) scale(1) translateY(20px)}}@media(max-width:960px){.animated-portrait__dialogue{top:-8%;font-size:.65rem;padding:.25rem .5rem}}@media(max-width:640px){.animated-portrait__dialogue{top:-10%}}.list{position:relative;width:100%;height:100%;min-height:inherit}.item-wrapper{position:absolute;will-change:transform,width,height,opacity;padding:3px;cursor:pointer;top:0;left:0}.item-wrapper>.item-img{position:relative;background-size:cover;background-position:center center;width:100%;height:100%;text-transform:uppercase;font-size:10px;line-height:10px}.image-modal-overlay{position:fixed;inset:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:99999;animation:modalFadeIn .3s ease-out}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.image-modal-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;justify-content:center;animation:modalScaleIn .3s cubic-bezier(.4,0,.2,1)}.image-modal-container{display:flex;max-width:95vw;max-height:90vh;overflow:hidden;animation:modalScaleIn .3s cubic-bezier(.4,0,.2,1)}.image-modal-image-section{display:flex;align-items:center;justify-content:center;max-width:70vw;flex:1}.image-modal-sidebar{width:320px;background:var(--panel);display:flex;flex-direction:column;position:relative;transition:width .3s cubic-bezier(.4,0,.2,1),min-width .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.image-modal-sidebar.expanded{width:320px;min-width:280px}.image-modal-sidebar.collapsed{width:40px;min-width:40px;cursor:pointer;background:transparent}.image-modal-sidebar.collapsed .image-modal-info{opacity:0;pointer-events:none}.sidebar-toggle{position:absolute;top:12px;left:8px;width:24px;height:24px;border:none;background:#ffffff1a;color:var(--text);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.sidebar-toggle:hover{background:#fff3}.sidebar-toggle-icon{transition:transform .3s ease;display:inline-block}.sidebar-toggle-icon.collapsed{transform:rotate(180deg)}@keyframes modalScaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.image-modal-close{top:1em;right:20px}.image-modal-close:hover{background:#fff3;transform:translate(-50%) scale(1.1)}.image-modal-img{max-width:100%;max-height:90vh;-o-object-fit:contain;object-fit:contain}.image-modal-info{padding:3rem 1rem 1rem;display:flex;flex-direction:column;gap:.75rem;transition:opacity .2s ease}.image-modal-title{color:var(--text);font-size:1.1rem;font-weight:600;margin:.25rem 0 .5rem}.image-modal-nav{position:fixed;transform:translateY(-50%);width:48px;height:48px;border:none;border-radius:50%;color:#fff;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:100001}.image-modal-nav:hover{background:#fff3;transform:translateY(-50%) scale(1.1)}.image-modal-nav--prev{left:20px;font-size:3.5em}.image-modal-nav--next{right:20px;font-size:3.5em}.image-modal-counter{color:var(--text);font-size:.75rem;margin:0}.image-modal-description{color:var(--text-secondary);font-size:.85rem;margin:0;line-height:1.6;margin:.5rem 0 1rem}.image-modal-meta{display:flex;flex-direction:column;gap:.6rem;padding-top:.75rem;border-top:1px solid var(--subtle)}.meta-item{display:flex;justify-content:space-between;align-items:center}.meta-label{color:var(--subtle);font-size:.8rem}.meta-value{color:var(--text);font-size:.85rem}.works-masonry-container{width:100%;height:400px;position:relative}@media(max-width:960px){.works-masonry-container{height:auto;min-height:400px}}@media(max-width:768px){.image-modal-container{flex-direction:column;max-width:100vw;max-height:100vh}.image-modal-image-section{max-width:100vw;max-height:50vh}.image-modal-img{max-height:50vh}.image-modal-sidebar{width:100%;max-height:45vh;overflow-y:auto}.image-modal-sidebar.expanded{width:100%;min-width:auto}.image-modal-sidebar.collapsed{height:40px;width:100%;min-width:auto}.image-modal-nav{width:36px;height:36px}.image-modal-nav--prev{left:10px;font-size:2em}.image-modal-nav--next{right:10px;font-size:2em}.image-modal-info{padding:2.5rem .75rem .75rem}.image-modal-title{font-size:1rem}.image-modal-description{font-size:.8rem}.works-masonry-container{width:100%;height:auto;min-height:400px}}@media(max-width:400px){.image-modal-nav--prev{left:5px;font-size:1.5em}.image-modal-nav--next{right:5px;font-size:1.5em}.works-masonry-container{height:auto;min-height:300px}}
