.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-space-y-reverse:0;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-border-style:solid}}}@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;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--font-weight-medium:500;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.static{position:static}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-8{margin-top:calc(var(--spacing) * 8)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.h-full{height:100%}.min-h-\[280px\]{min-height:280px}.min-h-\[var\(--content-min-h\)\]{min-height:var(--content-min-h)}.min-h-full{min-height:100%}.w-full{width:100%}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-5{gap:calc(var(--spacing) * 5)}:where(.space-y-5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 5) * calc(1 - var(--tw-space-y-reverse)))}.overflow-hidden{overflow:hidden}.bg-\[var\(--surface-3\)\]{background-color:var(--surface-3)}.px-2{padding-inline:calc(var(--spacing) * 2)}.pb-5{padding-bottom:calc(var(--spacing) * 5)}.text-left{text-align:left}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[clamp\(0\.8rem\,1vw\,1rem\)\]{font-size:clamp(.8rem,1vw,1rem)}.text-\[clamp\(1\.4rem\,3vw\,3\.15rem\)\]{font-size:clamp(1.4rem,3vw,3.15rem)}.leading-none{--tw-leading:1;line-height:1}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.tracking-\[-0\.03em\]{--tw-tracking:-.03em;letter-spacing:-.03em}.tracking-\[-0\.06em\]{--tw-tracking:-.06em;letter-spacing:-.06em}.tracking-\[0\.3em\]{--tw-tracking:.3em;letter-spacing:.3em}.text-\[var\(--text-faint\)\]{color:var(--text-faint)}.text-\[var\(--text-soft\)\]{color:var(--text-soft)}.uppercase{text-transform:uppercase}.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))}@media(min-width:48rem){.md\:grid-cols-\[1\.08fr_0\.92fr\]{grid-template-columns:1.08fr .92fr}.md\:gap-6{gap:calc(var(--spacing) * 6)}.md\:gap-8{gap:calc(var(--spacing) * 8)}.md\:border-b-0{border-bottom-style:var(--tw-border-style);border-bottom-width:0}.md\:px-3{padding-inline:calc(var(--spacing) * 3)}.md\:pr-8{padding-right:calc(var(--spacing) * 8)}.md\:pb-0{padding-bottom:calc(var(--spacing) * 0)}.md\:text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}}.font-primary{font-family:var(--font-primary)}.font-secondary{font-family:var(--font-secondary)}h1,h2,.section-title,.portfolio-card-title,.category-switch-title,.game-card-title,.project-selected-title,.personal-work-card-title{font-family:var(--font-primary)}.section-kicker,.section-copy,.nav-link,.portfolio-card-meta,.portfolio-card-arrow,.portfolio-project-tab,.portfolio-subheader-item,.category-switch-kicker,.game-card-kicker,.game-subheader-item,.project-tab,.project-thumb-label,.project-header-link,.project-link-item,.project-marquee-label,.personal-work-year{font-family:var(--font-secondary)}.site-wrap{min-height:100dvh;padding-inline:var(--page-pad-x);padding-block:var(--page-pad-y);background:var(--bg);margin-inline:auto}.site-stage{min-height:calc(100dvh - (var(--page-pad-y) * 2));isolation:isolate;background:0 0;border:0;grid-template-rows:auto minmax(0,1fr) auto;display:grid;position:relative;overflow:hidden}.stage-lines:before,.stage-lines:after{display:none}.header-shell{z-index:60;height:var(--header-h);background:var(--surface-2);border:var(--border-thick) solid var(--line-strong);-webkit-backdrop-filter:none;backdrop-filter:none;border-bottom:0;position:sticky;top:0}.footer-shell{z-index:60;height:var(--footer-h);background:var(--surface-3);border:var(--border-thick) solid var(--line-strong);-webkit-backdrop-filter:none;backdrop-filter:none;border-top:0;position:sticky;bottom:0}.content-shell{background:var(--surface);border-left:var(--border-thick) solid var(--line-strong);border-right:var(--border-thick) solid var(--line-strong);min-height:0;position:relative;overflow:hidden auto}.page-inner{height:auto;min-height:100%;padding:var(--inner-pad);background:var(--surface)}.home-page,.portfolio-landing-page{height:100%;min-height:100%;display:grid}.home-stage{align-items:stretch;height:100%;min-height:100%}.portfolio-landing-page .portfolio-shell{grid-template-rows:1fr;height:100%;min-height:100%;display:grid}.portfolio-landing-page .portfolio-grid{grid-auto-rows:1fr;align-items:stretch;height:100%;min-height:100%}.portfolio-landing-page .portfolio-card{height:100%;min-height:0}.portfolio-landing-page .portfolio-card-content{height:100%;min-height:100%}.hairline{border:var(--border-thick) solid var(--line-strong);background:var(--surface-2)}.section-kicker{text-transform:uppercase;letter-spacing:.24em;color:var(--text-soft);font-size:.66rem}.section-title{letter-spacing:-.06em;font-size:clamp(1.6rem,4.4vw,4.8rem);font-weight:500;line-height:.92}.section-copy{color:var(--text-soft);max-width:62ch;font-size:clamp(.88rem,1.2vw,1rem);line-height:1.42}.nav-link{opacity:.5;transition:opacity .22s var(--ease-smooth),transform .22s var(--ease-smooth);position:relative}.nav-link:hover{opacity:.8;transform:translateY(-1px)}.nav-link-active{opacity:1}.nav-link-active:after{content:"";background:var(--line-strong);height:2px;position:absolute;bottom:-6px;left:0;right:0}.page-enter{animation:pageEnter .42s var(--ease-smooth)}@keyframes pageEnter{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translate(0)}}.portfolio-shell{grid-template-rows:1fr;gap:0;height:auto;min-height:100%;display:grid}.portfolio-grid{gap:var(--section-gap);grid-template-columns:repeat(2,minmax(0,1fr));justify-content:stretch;align-items:stretch;height:auto;min-height:100%;display:grid}.portfolio-card{border:var(--border-thick) solid var(--line-strong);background:var(--surface-3);height:auto;min-height:clamp(280px,42vh,720px);box-shadow:none;position:relative;overflow:hidden}.portfolio-card-media{background:linear-gradient(to top,var(--color-overlay-dark),transparent 44%),linear-gradient(to bottom,var(--color-overlay-soft),transparent 24%),var(--surface-4);opacity:.95;transition:transform .7s var(--ease-smooth),opacity .5s var(--ease-smooth);will-change:transform;position:absolute;inset:0}.portfolio-card-content{z-index:2;min-height:inherit;height:100%;padding:var(--block-pad);flex-direction:column;justify-content:space-between;display:flex;position:relative}.portfolio-card-title{letter-spacing:-.06em;font-size:clamp(2rem,4vw,4.5rem);font-weight:500;line-height:.95}.portfolio-card-meta{color:var(--text-soft);max-width:28ch;font-size:.9rem}.portfolio-card-arrow{text-transform:uppercase;letter-spacing:.22em;color:var(--text-soft);align-items:center;gap:10px;font-size:.75rem;display:inline-flex}.portfolio-subheader{gap:var(--section-gap);border-bottom:0;grid-template-columns:repeat(2,minmax(0,1fr));padding-bottom:0;display:grid}.portfolio-subheader-item{border:var(--border-thick) solid var(--line-strong);background:var(--surface-3);letter-spacing:-.04em;color:var(--text-soft);cursor:pointer;min-height:58px;padding:8px 10px;font-size:clamp(1rem,1.6vw,1.5rem)}.portfolio-subheader-item-active{background:var(--surface-2);color:var(--text)}.portfolio-project-tabs{gap:var(--section-gap);flex-wrap:wrap;display:flex}.portfolio-project-tab{border:var(--border-thick) solid var(--line-strong);background:var(--surface-4);color:var(--text-soft);padding:8px 10px;font-size:.9rem}.portfolio-thumb-grid{gap:var(--section-gap);grid-template-columns:repeat(4,minmax(0,1fr));min-height:0;display:grid}.portfolio-thumb{aspect-ratio:4/5;border:var(--border-thick) solid var(--line-strong);background:var(--surface-3);padding:var(--block-pad);align-items:end;display:flex}.category-route-shell{gap:var(--section-gap);grid-template-rows:auto minmax(0,1fr);min-height:100%;display:grid}.category-switcher{gap:var(--section-gap);grid-template-columns:4fr 1fr;align-items:stretch;min-height:74px;display:grid}.category-switcher[data-active=personal-works]{grid-template-columns:1fr 4fr}.category-switch-card{border:var(--border-thick) solid var(--line-strong);background:var(--surface-3);min-height:74px;transition:background .45s var(--ease-smooth),opacity .45s var(--ease-smooth),border-color .45s var(--ease-smooth);cursor:pointer;will-change:contents;align-items:center;padding:8px 10px;display:flex;position:relative;overflow:hidden}.category-switch-card-inactive{background:var(--surface-4);opacity:1}.category-switch-kicker{text-transform:uppercase;letter-spacing:.22em;color:var(--text-soft);margin-bottom:6px;font-size:.66rem}.category-switch-title{letter-spacing:-.05em;font-size:clamp(1rem,2vw,2rem);font-weight:600;line-height:.95}.category-stage-fill{height:auto;min-height:0}.game-stage{gap:var(--section-gap);grid-template-rows:1fr;height:100%;min-height:100%;display:grid}.game-cards-shell{grid-template-rows:1fr;align-items:stretch;height:100%;min-height:100%;display:grid}.game-cards-row{gap:var(--section-gap);grid-template-columns:repeat(5,minmax(0,1fr));align-items:stretch;height:100%;min-height:100%;display:grid}.game-card{cursor:pointer;border:var(--border-thick) solid var(--line-strong);background:var(--surface-3);height:100%;min-height:100%;box-shadow:none;position:relative;overflow:hidden}.game-card-image{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.game-card-overlay{opacity:1;pointer-events:none;background:linear-gradient(#0000000a 50%,#0000005c),linear-gradient(#ffffff14,#0000 24%);position:absolute;inset:0}.game-card-body{z-index:2;height:100%;padding:var(--block-pad);flex-direction:column;justify-content:flex-start;display:flex;position:relative}.game-card-header{inset-inline:0;flex-direction:column;justify-content:center;align-items:center;padding-top:12px;display:flex;position:absolute;top:0}.game-card-title{letter-spacing:-.05em;text-align:center;font-size:clamp(1.5rem,2vw,2.5rem);font-weight:600;line-height:.95}.game-card-kicker{text-transform:uppercase;letter-spacing:.22em;color:var(--text-soft);margin-bottom:10px;font-size:.68rem}.game-subheader{gap:var(--section-gap);border-bottom:0;grid-template-columns:repeat(5,minmax(0,1fr));padding-bottom:0;display:grid}.game-subheader-item{border:var(--border-thick) solid var(--line-strong);background:var(--surface-4);letter-spacing:-.02em;color:var(--text-soft);cursor:pointer;padding:8px 10px;font-size:.82rem}.game-subheader-item-active{background:var(--surface-2);color:var(--text)}.game-detail-panel{gap:var(--section-gap);grid-template-columns:1.1fr .9fr;min-height:0;display:grid}.game-detail-hero,.game-detail-copy{border:var(--border-thick) solid var(--line-strong);background:var(--surface-3);min-height:320px}.game-detail-hero{padding:var(--block-pad);align-items:end;display:flex}.game-detail-copy{padding:var(--block-pad);flex-direction:column;justify-content:space-between;display:flex}.category-content-shell{gap:var(--section-gap);grid-template-rows:auto auto 1fr;min-height:100%;display:grid}.project-tabs-row{gap:var(--section-gap);flex-wrap:wrap;align-items:flex-start;display:flex}.project-tab{border:var(--border-thick) solid var(--line-strong);background:var(--surface-4);color:var(--text-soft);transition:background .25s var(--ease-smooth),color .25s var(--ease-smooth),transform .25s var(--ease-smooth);cursor:pointer;padding:8px 10px;font-size:.9rem}.project-tab:hover{transform:translateY(-1px)}.project-tab-active{background:var(--surface-2);color:var(--text)}.project-grid{gap:var(--section-gap);grid-template-columns:repeat(4,minmax(0,1fr));min-height:0;display:grid}.project-thumb{aspect-ratio:4/5;border:var(--border-thick) solid var(--line-strong);background:var(--surface-3);padding:var(--block-pad);align-items:end;display:flex;position:relative;overflow:hidden}.project-thumb-image{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.project-thumb:after{content:"";pointer-events:none;background:linear-gradient(#0000 56%,#0000005c),linear-gradient(#ffffff14,#0000 24%);position:absolute;inset:0}.project-thumb-label{z-index:1;letter-spacing:.18em;text-transform:uppercase;color:var(--text-soft);font-size:.72rem;position:relative}.project-header-shell{gap:var(--section-gap);grid-template-rows:auto auto;display:grid}.project-header-bar{border:var(--border-thick) solid var(--line-strong);background:var(--surface-3);grid-template-columns:repeat(5,minmax(0,1fr));gap:0;min-height:42px;display:grid;overflow:hidden}.project-header-link{min-height:42px;color:var(--text-soft);border-right:var(--border-thick) solid var(--line-strong);background:var(--surface-4);transition:background .22s var(--ease-smooth),color .22s var(--ease-smooth);justify-content:center;align-items:center;padding:8px 10px;font-size:.88rem;display:flex}.project-header-link:last-child{border-right:0}.project-header-link-active{background:var(--surface-2);color:var(--text)}.project-selected-title{text-align:center;letter-spacing:-.05em;padding:2px 0 0;font-size:clamp(1.4rem,3vw,2.8rem);font-weight:600;line-height:1}.project-detail-shell{gap:var(--section-gap);grid-template-rows:auto minmax(0,1fr) auto;height:100%;min-height:100%;display:grid}.project-slide-shell{gap:var(--section-gap);grid-template-columns:56px minmax(0,1fr) 56px;align-items:stretch;height:100%;min-height:0;display:grid}.project-slide-nav{border:var(--border-thick) solid var(--line-strong);background:var(--surface-3);cursor:pointer;transition:background .22s var(--ease-smooth),transform .22s var(--ease-smooth);justify-content:center;align-items:center;font-size:2rem;display:flex}.project-slide-nav:hover{background:var(--surface-2);transform:translateY(-1px)}.project-slide-frame{border:var(--border-thick) solid var(--line-strong);background:var(--surface-2);height:100%;min-height:0;position:relative;overflow:hidden}.project-marquee-stage{gap:var(--section-gap);grid-template-rows:repeat(2,minmax(0,1fr));height:100%;min-height:100%;display:grid;overflow:hidden}.project-marquee-row{align-items:stretch;height:100%;min-height:0;display:flex;overflow:hidden}.project-marquee-track{will-change:transform;align-items:stretch;width:max-content;height:100%;display:flex}.project-marquee-track-a{animation:90s linear infinite projectMarqueeA}.project-marquee-track-b{animation:90s linear infinite projectMarqueeB}.project-marquee-item{aspect-ratio:auto;border:1px solid var(--line-strong);background:var(--surface-3);flex:none;align-items:stretch;width:clamp(180px,18vw,300px);height:100%;display:flex;position:relative;overflow:hidden}.project-marquee-image{object-fit:cover;width:100%;height:100%}.project-marquee-label{text-transform:uppercase;letter-spacing:.18em;color:var(--text-soft);font-size:.68rem}@keyframes projectMarqueeA{0%{transform:translate(0)}to{transform:translate(calc(-50% - 6px))}}@keyframes projectMarqueeB{0%{transform:translate(calc(-50% - 6px))}to{transform:translate(0)}}.project-info-stage{height:100%;min-height:100%;padding:var(--block-pad);gap:var(--section-gap);grid-template-columns:.9fr 1.1fr .9fr;align-items:stretch;display:grid}.project-info-side,.project-info-main,.project-info-copy{border:var(--border-thick) solid var(--line-strong);background:var(--surface-3);min-height:0}.project-info-side{padding:var(--block-pad);flex-direction:column;justify-content:space-between;min-height:220px;display:flex}.project-info-main{min-height:420px;padding:var(--block-pad);justify-content:center;align-items:end;display:flex}.project-info-copy{min-height:220px;padding:var(--block-pad);justify-content:space-between;gap:var(--section-gap);flex-direction:column;display:flex}.project-link-list{gap:var(--section-gap);flex-direction:column;display:flex}.project-link-item{border:var(--border-thick) solid var(--line-strong);background:var(--surface-4);color:var(--text-soft);padding:8px 10px;font-size:.9rem}.project-slide-indicator{justify-content:center;gap:8px;display:flex}.project-slide-dot{border:1px solid var(--line-strong);background:0 0;border-radius:999px;width:8px;height:8px}.project-slide-dot-active{background:var(--text)}.personal-works-page-shell{height:auto;min-height:100%;overflow:visible}.personal-works-route-shell{grid-template-rows:auto minmax(0,1fr);height:auto;min-height:100%;display:grid}.personal-works-stage{align-content:start;gap:clamp(32px,4vw,60px);min-height:100%;display:grid}.personal-work-strip{content-visibility:auto;contain-intrinsic-size:1200px;gap:clamp(14px,1.6vw,20px);display:grid}.personal-work-yearline{align-items:center;min-height:14px;display:flex;position:relative}.personal-work-yearline:before{content:"";background:#ffffff2e;width:100%;height:1px}.personal-work-year{background:var(--surface);letter-spacing:.28em;text-transform:uppercase;color:#ffffff9e;padding-right:12px;font-size:.64rem;line-height:1;position:absolute;top:50%;left:0;transform:translateY(-50%)}.personal-work-masonry{column-count:3;column-gap:clamp(12px,1.3vw,18px)}.personal-work-media{break-inside:avoid;-webkit-column-break-inside:avoid;opacity:0;filter:blur(5px);transition:opacity .72s var(--ease-smooth),transform .9s var(--ease-smooth),filter .9s var(--ease-smooth);transition-delay:var(--reveal-delay,0s);will-change:opacity,transform,filter;background:0 0;border:0;margin:0 0 clamp(12px,1.3vw,18px);padding:0;transform:translateY(34px)scale(.985)}.personal-work-media[data-visible=true]{opacity:1;filter:blur();transform:translate(0)scale(1)}.personal-work-media-offset-sm{margin-top:10px}.personal-work-media-offset-lg{margin-top:24px}.personal-work-media-rise{margin-top:-12px}.personal-work-media-tight{margin-bottom:10px}.personal-work-image{object-fit:contain;backface-visibility:hidden;background:0 0;width:100%;height:auto;display:block;transform:translateZ(0)}@media(prefers-reduced-motion:reduce){.personal-work-media{opacity:1;filter:none;transition:none;transform:none}}}:root{color-scheme:dark;--color-page-bg:#312839;--color-stage-bg:#9a9a9a;--color-stage-bg-2:#8a8a8a;--color-surface-main:#1c2243;--color-surface-soft:#1d1426;--color-surface-muted:#2d345a;--color-surface-strong:#383e54;--color-surface-dark:#7c7c7c;--color-text-main:#fff;--color-text-soft:#d1d1d1;--color-text-faint:#372f2f;--color-border-main:#3f3f3f;--color-border-soft:#fff;--color-overlay-dark:#00000047;--color-overlay-soft:#ffffff1a;--color-accent-1:#cfcfcf;--color-accent-2:#bbb;--color-accent-3:#a3a3a3;--color-accent-4:#8d8d8d;--bg:var(--color-page-bg);--surface:var(--color-surface-main);--surface-2:var(--color-surface-soft);--surface-3:var(--color-surface-muted);--surface-4:var(--color-surface-strong);--text:var(--color-text-main);--text-soft:var(--color-text-soft);--text-faint:var(--color-text-faint);--line:var(--color-border-soft);--line-strong:var(--color-border-main);--font-primary:"Montserrat", Arial, Helvetica, sans-serif;--font-secondary:"Montserrat", Arial, Helvetica, sans-serif;--page-max:1720px;--page-pad-x:6px;--page-pad-y:6px;--header-h:clamp(66px, 7vw, 84px);--footer-h:clamp(58px, 6vw, 72px);--section-gap:8px;--inner-pad:8px;--block-pad:8px;--border-thick:2px;--shadow-soft:none;--shadow-card:none;--ease-smooth:cubic-bezier(.22, 1, .36, 1);--ease-snappy:cubic-bezier(.2, .8, .2, 1)}@media(max-width:767px){:root{--page-pad-x:4px;--page-pad-y:4px;--header-h:60px;--footer-h:58px;--section-gap:6px;--inner-pad:6px;--block-pad:6px}}html,body{background:var(--bg);width:100%;min-height:100%;color:var(--text);margin:0;overflow-x:hidden}html{scroll-behavior:smooth}body{font-family:var(--font-secondary);text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,:before,:after{box-sizing:border-box;min-width:0}img,picture,video,canvas,svg{max-width:100%;display:block}button,input,textarea,select{font:inherit}a{color:inherit;text-decoration:none}::selection{background:#0000001f}@media(max-width:1100px){.project-info-stage{grid-template-columns:1fr}.project-info-main{min-height:300px}.personal-work-masonry{column-count:2}}@media(max-width:900px){.portfolio-grid{grid-template-columns:1fr;min-height:auto}.game-detail-panel{grid-template-columns:1fr}.project-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.game-cards-row{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:767px){.page-inner{padding:var(--inner-pad)}.nav-link-active:after{bottom:-4px}.portfolio-card{min-height:220px}.portfolio-card-meta{max-width:100%}.portfolio-subheader{grid-template-columns:1fr}.portfolio-thumb-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.category-switcher{gap:var(--section-gap);grid-template-columns:4fr 1fr;align-items:stretch;min-height:74px}.category-switcher[data-active=personal-works]{grid-template-columns:1fr 4fr}.category-switch-card{min-height:74px;padding:8px 10px}.game-cards-shell{min-height:auto}.game-cards-row{gap:var(--section-gap);grid-template-columns:1fr}.game-card{min-height:52svh}.game-subheader{grid-template-columns:1fr}.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.project-tabs-row{scrollbar-width:none;flex-wrap:nowrap;padding-bottom:2px;overflow-x:auto}.project-tabs-row::-webkit-scrollbar{display:none}.project-header-bar{grid-template-columns:1fr}.project-header-link{border-right:0;border-bottom:var(--border-thick) solid var(--line-strong);justify-content:flex-start}.project-header-link:last-child{border-bottom:0}.project-slide-shell{gap:var(--section-gap);grid-template-columns:40px minmax(0,1fr) 40px;min-height:clamp(360px,52vh,620px)}.project-marquee-item{width:42vw}.project-info-main{min-height:240px}.personal-work-masonry{column-count:1}.personal-work-media-offset-sm,.personal-work-media-offset-lg,.personal-work-media-rise{margin-top:0}.personal-work-year{letter-spacing:.22em}}.game-art-page,.game-art-detail-page{height:100%;min-height:100%;display:grid}.game-art-page .category-route-shell,.game-art-detail-page .category-route-shell{height:100%;min-height:100%}.game-art-page .category-stage-fill,.game-art-detail-page .category-stage-fill{height:100%;min-height:0;display:grid}.game-art-page .game-stage,.game-art-page .game-cards-shell,.game-art-page .game-cards-row,.game-art-detail-page .project-detail-shell,.game-art-detail-page .project-slide-shell,.game-art-detail-page .project-slide-frame,.game-art-detail-page .project-marquee-stage{height:100%;min-height:100%}@media(max-width:900px){.game-cards-row{grid-template-columns:repeat(2,minmax(0,1fr));height:auto}.game-card{min-height:42svh}}@media(max-width:767px){.project-slide-shell{grid-template-columns:40px minmax(0,1fr) 40px;height:52svh;min-height:52svh}.project-marquee-item{width:42vw}}.game-art-detail-page{height:100%;min-height:100%;display:grid}.game-art-detail-page .category-route-shell{grid-template-rows:auto minmax(0,1fr);height:100%;min-height:100%;display:grid}.game-art-detail-page .category-stage-fill{height:100%;min-height:0;display:grid}.game-art-detail-page .category-content-shell{grid-template-rows:auto auto minmax(0,1fr);height:100%;min-height:0;display:grid}.game-art-detail-page .project-detail-shell{gap:var(--section-gap);grid-template-rows:auto minmax(0,1fr) auto;height:100%;min-height:0;display:grid}.game-art-detail-page .project-slide-shell{gap:var(--section-gap);grid-template-columns:clamp(32px,3vw,56px) minmax(0,1fr) clamp(32px,3vw,56px);align-items:stretch;height:100%;min-height:0;display:grid}.game-art-detail-page .project-slide-nav{justify-content:center;align-items:center;height:100%;min-height:0;display:flex}.game-art-detail-page .project-slide-frame{height:100%;min-height:0;display:grid;overflow:hidden}.game-art-detail-page .project-marquee-stage{gap:var(--section-gap);grid-template-rows:repeat(2,minmax(0,1fr));height:100%;min-height:0;display:grid;overflow:hidden}.game-art-detail-page .project-marquee-row{align-items:stretch;height:100%;min-height:0;display:flex;overflow:hidden}.game-art-detail-page .project-marquee-track{align-items:stretch;gap:var(--section-gap);will-change:transform;width:max-content;height:100%;display:flex}.game-art-detail-page .project-marquee-item{aspect-ratio:1;background:var(--surface-3);border:1px solid var(--line-strong);flex:none;width:auto;height:100%;display:block;overflow:hidden}.game-art-detail-page .project-marquee-image{object-fit:cover;object-position:center;width:100%;height:100%}.game-art-detail-page .project-slide-shell{--detail-gallery-height:clamp(320px, 54vh, 760px);height:var(--detail-gallery-height)}@media(min-width:1400px){.game-art-detail-page .project-slide-shell{--detail-gallery-height:clamp(420px, 64vh, 860px)}}@media(max-width:1100px){.game-art-detail-page .project-slide-shell{--detail-gallery-height:clamp(300px, 50vh, 620px)}}@media(max-width:767px){.game-art-detail-page .project-slide-shell{--detail-gallery-height:clamp(260px, 46vh, 520px);grid-template-columns:40px minmax(0,1fr) 40px}.game-art-detail-page .project-marquee-track{gap:10px}}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@keyframes astroFadeInOut{0%{opacity:1}to{opacity:0}}@keyframes astroFadeIn{0%{opacity:0;mix-blend-mode:plus-lighter}to{opacity:1;mix-blend-mode:plus-lighter}}@keyframes astroFadeOut{0%{opacity:1;mix-blend-mode:plus-lighter}to{opacity:0;mix-blend-mode:plus-lighter}}@keyframes astroSlideFromRight{0%{transform:translate(100%)}}@keyframes astroSlideFromLeft{0%{transform:translate(-100%)}}@keyframes astroSlideToRight{to{transform:translate(100%)}}@keyframes astroSlideToLeft{to{transform:translate(-100%)}}@media(prefers-reduced-motion){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}[data-astro-transition-scope]{animation:none!important}}
