*,: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]:where(:not([hidden=until-found])){display:none}.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}}.visible{visibility:visible}.shrink{flex-shrink:1}.transform{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}.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}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{scrollbar-width:none}html::-webkit-scrollbar,body::-webkit-scrollbar{display:none}html{background:var(--bg-base);color:var(--text-body);font-family:var(--font-body);font-kerning:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:clip}body{overflow-x:clip}:root{--font-body: "Instrument Sans", "Segoe UI", sans-serif;--font-display: "Clash Display", sans-serif;--type-xs: .75rem;--type-sm: .875rem;--type-body: 1rem;--type-lead: 1.25rem;--leading-tight: 1.15;--leading-snug: 1.35;--leading-body: 1.7;--tracking-label: .14em;--bg-base: oklch(9% .006 20);--bg-elevated: oklch(13% .006 20);--bg-elevated-strong: oklch(21% .007 20);--bg-panel: oklch(97% .005 20 / .025);--bg-panel-strong: oklch(97% .005 20 / .045);--text-strong: oklch(97% .005 20);--text-body: oklch(78% .006 20);--text-muted: oklch(58% .005 20);--text-soft: oklch(44% .004 20);--border-soft: oklch(22% .006 20);--border-strong: oklch(28% .007 20);--accent-primary: oklch(48% .2 24);--accent-primary-hover: oklch(42% .18 24);--accent-primary-soft: oklch(48% .2 24 / .07);--accent-primary-border: oklch(48% .2 24 / .32);--accent-secondary: oklch(62% .16 22);--accent-secondary-soft: oklch(62% .16 22 / .07);--accent-secondary-border: oklch(62% .16 22 / .3);--surface-shadow: 0 0 0 1px oklch(97% .005 20 / .05), 0 18px 48px oklch(0% 0 0 / .3);--surface-shadow-active: 0 0 0 1px oklch(48% .2 24 / .16), 0 22px 56px oklch(0% 0 0 / .36);--image-outline: oklch(97% .005 20 / .08)}::-moz-selection{background:var(--accent-primary);color:var(--text-strong)}::selection{background:var(--accent-primary);color:var(--text-strong)}a{color:inherit;text-decoration:none}.noise-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px}.page-transition{will-change:opacity,transform}.page-enter{animation:pageIn .35s cubic-bezier(.23,1,.32,1) forwards}.page-exit{animation:pageOut .2s cubic-bezier(.23,1,.32,1) forwards}@keyframes pageIn{0%{opacity:0;transform:translateY(16px);filter:blur(3px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}@keyframes pageOut{0%{opacity:1;transform:translateY(0);filter:blur(0)}to{opacity:0;transform:translateY(-8px);filter:blur(3px)}}.anim-text{transition:opacity .25s cubic-bezier(.23,1,.32,1)}.anim-text--out{opacity:0}.anim-text--in{opacity:1}.mask-counter{display:inline-block;overflow:hidden;width:2.5ch;height:1em;line-height:1}.mask-counter__inner{display:block;height:100%;line-height:1;will-change:transform}.reveal{opacity:0;transform:translateY(20px);filter:blur(3px);transition:opacity .6s cubic-bezier(.23,1,.32,1),transform .6s cubic-bezier(.23,1,.32,1),filter .6s cubic-bezier(.23,1,.32,1)}.reveal.revealed{opacity:1;transform:translateY(0);filter:blur(0)}.eyebrow{display:inline-block;font-size:var(--type-xs);letter-spacing:var(--tracking-label);font-weight:600;text-transform:uppercase;color:var(--accent-secondary);border:1px solid var(--accent-secondary-border);border-radius:999px;padding:6px 18px;margin-bottom:24px}.section-heading{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:600;color:var(--text-strong);line-height:1.15;text-wrap:balance;margin-bottom:64px}.text-stamp{color:var(--accent-primary);font-style:italic}.nav-pill{position:fixed;top:0;left:50%;transform:translate(-50%);z-index:40;margin-top:24px}.nav-pill__inner{display:flex;align-items:center;gap:32px;background:#0a0a0abf;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08);border-radius:999px;padding:10px 12px 10px 24px;box-shadow:0 0 0 1px #ffffff08,0 16px 48px #00000080}.nav-logo{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--text-strong)}.nav-links{display:flex;align-items:center;gap:24px}.nav-links a{font-size:var(--type-sm);font-weight:500;letter-spacing:.02em;color:var(--text-muted);transition:color .2s cubic-bezier(.23,1,.32,1)}@media (hover: hover) and (pointer: fine){.nav-links a:hover{color:var(--text-strong)}}.nav-links a.active{color:var(--text-strong)}.nav-cta{display:inline-flex!important;align-items:center;justify-content:center;gap:8px;background:var(--accent-primary);color:var(--text-strong)!important;border-radius:999px;min-height:40px;padding:8px 8px 8px 18px;font-size:var(--type-sm);font-weight:600;transition:background .2s cubic-bezier(.23,1,.32,1),transform .16s ease-out}@media (hover: hover) and (pointer: fine){.nav-cta:hover{background:var(--accent-primary-hover)}}.nav-cta:active{transform:scale(.97)}.nav-cta__arrow{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#0003;border-radius:50%;color:var(--text-strong);transition:transform .2s cubic-bezier(.23,1,.32,1)}@media (hover: hover) and (pointer: fine){.nav-cta:hover .nav-cta__arrow{transform:translate(2px) scale(1.05)}}@media (max-width: 768px){.nav-pill{margin-top:12px}.nav-links a:not(.nav-cta){display:none}.nav-pill__inner{gap:16px;padding:8px 8px 8px 20px}}.hero{min-height:100dvh;display:flex;align-items:center;position:relative;padding:120px 48px 80px;overflow:visible;background:var(--bg-base)}.wavy-grid{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:0;mask-image:linear-gradient(to right,white 35%,transparent 55%);-webkit-mask-image:linear-gradient(to right,white 35%,transparent 55%)}.hero__inner{position:relative;z-index:1;max-width:1400px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}.hero__left{display:flex;flex-direction:column}.hero__headline{font-family:var(--font-display);font-size:clamp(3rem,6vw,5rem);font-weight:700;line-height:1.05;text-wrap:balance;color:var(--text-strong);letter-spacing:-.02em;margin-bottom:16px}.hero__typing-line{font-size:clamp(1.125rem,1rem + .8vw,1.375rem);color:var(--text-body);font-weight:400;line-height:1.65;text-wrap:balance;margin-bottom:24px}.hero__typed{color:var(--accent-secondary);font-weight:500}.hero__cursor{color:var(--accent-primary);font-weight:300;animation:cursorBlink 1s step-end infinite;margin-left:1px}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.hero__bio{font-size:var(--type-body);line-height:1.75;color:var(--text-muted);max-width:62ch;text-wrap:pretty;margin-bottom:48px}.hero__scroll-hint{display:flex;flex-direction:column;align-items:flex-start;gap:12px;color:var(--text-soft);font-size:var(--type-xs);letter-spacing:.3em;text-transform:uppercase}.hero__scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,rgba(196,30,30,.6),transparent);animation:scrollPulse 2s ease-in-out infinite}@keyframes scrollPulse{0%,to{opacity:.3;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.2)}}.hero__right{display:flex;align-items:center;justify-content:center;overflow:visible}.hero__interactive-space{width:100%;overflow:visible}.ascii-donut{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:24px}.ascii-donut__gesture-area{display:inline-flex;align-items:center;justify-content:center;width:-moz-fit-content;width:fit-content;max-width:100%;cursor:grab;touch-action:none}.ascii-donut__gesture-area:active{cursor:grabbing}.ascii-donut__pre{font-family:Courier New,Courier,monospace;font-size:clamp(9px,1.3vw,14px);line-height:1.1;letter-spacing:.1em;color:#f3ede6c7;white-space:pre;margin:0;pointer-events:none}.ascii-donut__hint{font-size:10px;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:var(--text-soft);transition:opacity .3s cubic-bezier(.23,1,.32,1),color .3s cubic-bezier(.23,1,.32,1);pointer-events:none}.ascii-donut__hint--pulse{animation:asciiHintPulse 1.7s cubic-bezier(.22,1,.36,1) infinite}.ascii-donut__hint--hidden{opacity:0;transform:translateY(-4px);animation:none}@keyframes asciiHintPulse{0%,to{opacity:.56;color:var(--text-soft)}50%{opacity:1;color:var(--text-strong)}}@media (prefers-reduced-motion: reduce){.ascii-donut__hint,.ascii-donut__hint--pulse,.ascii-donut__hint--hidden{animation:none}}@media (max-width: 768px){.hero{align-items:flex-start;padding:148px 20px 56px}.wavy-grid{mask-image:linear-gradient(to bottom,transparent 0%,transparent 60%,white 72%,white 94%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,transparent 60%,white 72%,white 94%,transparent 100%)}.hero__inner{grid-template-columns:1fr;gap:16px;align-items:start}.hero__left{max-width:34rem;order:2}.hero__right{order:1;width:100%}.hero__interactive-space{max-width:100%;display:flex;justify-content:center;overflow:hidden}.ascii-donut{flex-direction:column-reverse;padding:12px 0;gap:10px}.ascii-donut__gesture-area{max-width:min(100%,320px);overflow:hidden}.ascii-donut__pre{font-size:clamp(5px,1.55vw,7px);letter-spacing:.04em}.ascii-donut__hint{font-size:9px;letter-spacing:.18em}}.motivation{padding:120px 48px;background:var(--bg-base)}.motivation__inner{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}.motivation__left{display:flex;flex-direction:column}.motivation__title{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2rem);font-weight:700;color:var(--text-strong);letter-spacing:.08em;margin-bottom:16px}.motivation__title-line{width:100%;max-width:500px;height:1px;background:linear-gradient(90deg,var(--accent-primary),transparent);margin-bottom:40px}.motivation__hook{font-family:var(--font-display);font-size:clamp(1.3rem,2.5vw,1.8rem);font-weight:600;color:var(--text-body);line-height:1.35;margin-bottom:32px}.motivation__body{font-family:var(--font-display);font-size:clamp(1.1rem,1.8vw,1.45rem);font-weight:500;line-height:1.45;color:var(--text-strong);text-wrap:pretty;max-width:760px;margin-bottom:8px}.motivation__right{display:flex;align-items:center;justify-content:flex-end}.motivation__image-placeholder{width:100%;max-width:520px;aspect-ratio:4 / 5;border:1px solid var(--border-soft);border-radius:16px;display:flex;align-items:center;justify-content:center;background:#ffffff04;overflow:hidden}.motivation__image-placeholder span{font-family:var(--font-display);font-size:1rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:#ffffff14}@media (max-width: 768px){.motivation{padding:80px 20px}.motivation__inner{grid-template-columns:1fr;gap:40px}.motivation__right{justify-content:center}.motivation__image-placeholder{max-width:100%;aspect-ratio:16 / 10}}.work-scroll{background:var(--bg-base);padding:80px 0;min-height:100vh}.work-scroll__container{max-width:1560px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1.28fr) minmax(340px,.72fr);gap:40px;padding:0 36px}.work-scroll__left{display:flex;flex-direction:column;gap:40px}.work-scroll__card{min-height:70vh;display:flex;align-items:center;justify-content:center}.work-scroll__card-inner{width:100%;border-radius:10px;overflow:hidden;background:var(--bg-elevated);box-shadow:var(--surface-shadow);transition:box-shadow .25s cubic-bezier(.23,1,.32,1),transform .16s ease-out}.work-scroll__card--active .work-scroll__card-inner{box-shadow:var(--surface-shadow-active)}.work-scroll__placeholder{width:100%;aspect-ratio:2.02 / 1;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;overflow:hidden}.work-scroll__thumbnail{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;outline:1px solid var(--image-outline);outline-offset:-1px;filter:saturate(.92) contrast(.96) brightness(.92);transition:transform .25s cubic-bezier(.23,1,.32,1),filter .25s cubic-bezier(.23,1,.32,1)}.work-scroll__card--active .work-scroll__thumbnail{transform:scale(1.02);filter:saturate(1) contrast(1) brightness(1)}.view-cursor{position:fixed;top:0;left:0;z-index:30;width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:var(--text-strong);font-family:var(--font-display);font-size:12px;font-weight:600;letter-spacing:.15em;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:0;transition:opacity .25s cubic-bezier(.23,1,.32,1);will-change:transform}.view-cursor--visible{opacity:1}.work-scroll__card-link{display:block;width:100%;text-decoration:none;color:inherit}@media (hover: hover) and (pointer: fine){.work-scroll__card-link:hover{cursor:none}.work-scroll__card-link:hover .work-scroll__card-inner{box-shadow:0 0 0 1px var(--accent-primary-border),0 22px 56px #00000057}}.work-scroll__card-link:active .work-scroll__card-inner{transform:scale(.97);transition:transform .16s ease-out,border-color .25s cubic-bezier(.23,1,.32,1)}.work-scroll__right{position:relative}.work-scroll__sticky{position:sticky;top:20vh;padding:40px 0}.work-scroll__header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:16px}.work-scroll__section-title{font-family:var(--font-display);font-size:var(--type-body);font-weight:600;letter-spacing:var(--tracking-label);color:var(--accent-secondary)}.work-scroll__handle{font-family:var(--font-body);font-size:var(--type-sm);color:var(--text-soft);letter-spacing:.05em}.work-scroll__divider{width:100%;height:1px;background:linear-gradient(90deg,#c41e1e4d,#ffffff14);margin-bottom:48px}.work-scroll__counter{font-family:var(--font-display);font-size:var(--type-sm);font-weight:400;color:var(--text-soft);font-variant-numeric:tabular-nums;letter-spacing:.3em;margin-bottom:24px;display:flex;align-items:center;height:20px}.work-scroll__counter-current{color:var(--text-strong);font-weight:600}.work-scroll__counter-sep{letter-spacing:.15em}.work-scroll__title{font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.5rem);font-weight:600;color:var(--text-strong);line-height:1.15;text-wrap:balance;margin-bottom:12px;height:2.3em;overflow:hidden}.work-scroll__category{font-size:var(--type-sm);color:var(--accent-secondary);letter-spacing:.05em;margin-bottom:24px;height:20px;overflow:hidden}.work-scroll__desc{font-size:var(--type-body);line-height:var(--leading-body);color:var(--text-muted);max-width:44ch;text-wrap:pretty;height:3.5em;overflow:hidden}.work-carousel{padding:0 20px}.work-carousel__intro{will-change:transform,opacity}.work-carousel__header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:16px}.work-carousel__section-title{font-family:var(--font-display);font-size:var(--type-body);font-weight:600;letter-spacing:var(--tracking-label);color:var(--accent-secondary)}.work-carousel__handle{font-size:var(--type-sm);color:var(--text-soft);letter-spacing:.05em}.work-carousel__divider{width:100%;height:1px;background:linear-gradient(90deg,#c41e1e4d,#ffffff14);margin-bottom:32px}.work-carousel__counter{font-family:var(--font-display);font-size:var(--type-sm);font-weight:400;color:var(--text-soft);font-variant-numeric:tabular-nums;letter-spacing:.3em;margin-bottom:20px;display:flex;align-items:center;height:20px}.work-carousel__counter-current{color:var(--text-strong);font-weight:600}.work-carousel__counter-sep{letter-spacing:.15em}.work-carousel__meta-swap{animation:workCarouselMetaIn .42s cubic-bezier(.22,1,.36,1);transform-origin:top left}.work-carousel__title{font-family:var(--font-display);font-size:clamp(1.8rem,6vw,2.4rem);font-weight:600;color:var(--text-strong);line-height:1.1;text-wrap:balance;margin-bottom:12px;min-height:2.2em}.work-carousel__category{font-size:14px;color:var(--accent-secondary);letter-spacing:.05em;margin-bottom:18px;min-height:20px}.work-carousel__desc{font-size:var(--type-body);line-height:var(--leading-body);color:var(--text-muted);max-width:42ch;text-wrap:pretty;margin-bottom:28px;min-height:5.25em}.work-carousel__track{display:flex;gap:16px;overflow-x:auto;padding:4px 19vw 8px;margin:0 -20px;scroll-snap-type:x mandatory;touch-action:pan-x;overscroll-behavior-x:contain;overscroll-behavior-y:none;-ms-overflow-style:none;scrollbar-width:none;-webkit-overflow-scrolling:touch}.work-carousel__track::-webkit-scrollbar{display:none}.work-carousel__card{flex:0 0 62vw;border:0;background:transparent;padding:0;scroll-snap-align:center;text-align:left;text-decoration:none;color:inherit;display:flex;justify-content:center;opacity:.72;transform:translateY(16px);transition:transform .32s cubic-bezier(.22,1,.36,1),opacity .32s cubic-bezier(.22,1,.36,1);touch-action:pan-x}.work-carousel__card--active{opacity:1;transform:translateY(0)}.work-carousel__card-inner{width:100%;aspect-ratio:3 / 2;border-radius:12px;overflow:hidden;background:var(--bg-elevated);box-shadow:var(--surface-shadow);transform:scale(.97);transform-origin:center;transition:transform .22s cubic-bezier(.23,1,.32,1),box-shadow .22s cubic-bezier(.23,1,.32,1),filter .22s cubic-bezier(.23,1,.32,1)}.work-carousel__card--active .work-carousel__card-inner{transform:scale(1);box-shadow:var(--surface-shadow-active)}.work-carousel__card:active .work-carousel__card-inner{transform:scale(.985)}.work-carousel__image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;outline:1px solid var(--image-outline);outline-offset:-1px;filter:saturate(.94) contrast(.97) brightness(.94);transition:filter .22s cubic-bezier(.23,1,.32,1)}.work-carousel__card--active .work-carousel__image{filter:saturate(1) contrast(1) brightness(1)}.work-carousel__hint{margin-top:14px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-soft)}@keyframes workCarouselMetaIn{0%{opacity:0;transform:translateY(14px);filter:blur(4px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}.phone-frame{position:relative;width:100%;aspect-ratio:390 / 844;background:#1a1a1a;border-radius:40px;border:3px solid rgba(255,255,255,.12);box-shadow:0 0 0 1px #ffffff0f,0 20px 50px #0006;overflow:hidden;touch-action:pan-x;transform:scale(.92);opacity:.6;transition:transform .3s cubic-bezier(.23,1,.32,1),box-shadow .3s cubic-bezier(.23,1,.32,1),opacity .3s cubic-bezier(.23,1,.32,1)}.work-carousel__card--active .phone-frame{transform:scale(1);opacity:1;box-shadow:0 0 0 1px #ffffff1a,0 24px 60px #00000080}.work-carousel__card:active .phone-frame{transform:scale(.97)}.phone-frame__notch{position:absolute;top:10px;left:50%;transform:translate(-50%);width:90px;height:24px;background:#000;border-radius:14px;z-index:2}.phone-frame__screen{position:absolute;top:42px;left:0;right:0;bottom:0;border-radius:0 0 37px 37px;overflow:hidden}.phone-frame__image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:top center;object-position:top center;display:block}.mobile-project-sheet{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70}.mobile-project-sheet__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:0;padding:0;background:#0000008c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:mobileSheetBackdropIn .22s ease-out forwards}.mobile-project-sheet--closing .mobile-project-sheet__backdrop{animation:mobileSheetBackdropOut .18s ease-in forwards}.mobile-project-sheet__panel{position:absolute;left:0;right:0;bottom:0;max-height:min(92dvh,860px);border-radius:24px 24px 0 0;background:#0c0c0cf5;box-shadow:0 0 0 1px var(--border-soft),0 -18px 48px #0000005c;overflow:hidden;animation:mobileSheetIn .32s cubic-bezier(.23,1,.32,1) forwards}.mobile-project-sheet--closing .mobile-project-sheet__panel{animation:mobileSheetOut .18s ease-in forwards}.mobile-project-sheet__handle{width:54px;height:5px;border-radius:999px;background:#f4e0c92e;margin:12px auto 0}.mobile-project-sheet__topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px 18px;border-bottom:1px solid var(--border-soft)}.mobile-project-sheet__eyebrow{font-size:var(--type-xs);letter-spacing:var(--tracking-label);text-transform:uppercase;color:var(--accent-secondary)}.mobile-project-sheet__close{display:inline-flex;align-items:center;justify-content:center;min-width:40px;min-height:40px;padding:0 12px;border:0;border-radius:999px;background:var(--bg-panel-strong);color:var(--text-muted);font-size:13px;letter-spacing:.04em;transition:background-color .16s ease-out,color .16s ease-out,transform .16s ease-out}.mobile-project-sheet__close:active{transform:scale(.96)}.mobile-project-sheet__body{overflow-y:auto;max-height:calc(min(92dvh,860px) - 58px);padding:24px 20px 28px}.mobile-project-sheet__title{font-family:var(--font-display);font-size:clamp(1.8rem,8vw,2.5rem);line-height:1.05;text-wrap:balance;color:var(--text-strong);margin-bottom:14px}.mobile-project-sheet__desc{font-size:var(--type-body);line-height:var(--leading-body);color:var(--text-muted);max-width:60ch;text-wrap:pretty;margin-bottom:24px}.mobile-project-sheet__media{aspect-ratio:16 / 10;border-radius:16px;overflow:hidden;background:var(--bg-elevated);box-shadow:var(--surface-shadow);margin-bottom:24px}.mobile-project-sheet__image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;outline:1px solid var(--image-outline);outline-offset:-1px}.mobile-project-sheet__meta{display:grid;grid-template-columns:1fr;gap:14px;padding-top:20px;border-top:1px solid var(--border-soft)}.mobile-project-sheet__meta-item{display:flex;flex-direction:column;gap:6px}.mobile-project-sheet__meta-label{font-size:var(--type-xs);letter-spacing:var(--tracking-label);text-transform:uppercase;color:var(--accent-secondary)}.mobile-project-sheet__meta-value{font-family:var(--font-display);font-size:1rem;color:var(--text-strong)}@keyframes mobileSheetIn{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes mobileSheetBackdropIn{0%{opacity:0}to{opacity:1}}@keyframes mobileSheetOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(12px)}}@keyframes mobileSheetBackdropOut{0%{opacity:1}to{opacity:0}}@media (max-width: 768px){.work-scroll{padding:60px 0}.work-scroll__container{grid-template-columns:1fr;padding:0 20px;gap:0}.work-scroll__right{order:-1;margin-bottom:32px}.work-scroll__sticky{position:relative;top:auto;padding:0}.work-scroll__card{min-height:auto;padding:20px 0}.work-scroll__placeholder{aspect-ratio:16 / 9;border-radius:8px}}@media (prefers-reduced-motion: reduce){.work-carousel__meta-swap{animation:none}.work-carousel__card,.work-carousel__card--active{transition:none;transform:none;opacity:1}}.about{min-height:100vh;background:var(--bg-base);padding:160px 0 80px}.about__container{max-width:1520px;margin:0 auto;display:grid;grid-template-columns:240px minmax(0,1fr);gap:88px;padding:0 64px}.about__left{position:relative}.about__left-sticky{position:sticky;top:160px;display:flex;flex-direction:column;gap:28px}.about__fact{display:flex;flex-direction:column;gap:4px}.about__fact-label{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--text-strong)}.about__fact-value{font-size:1rem;color:var(--text-muted);line-height:1.4}.about__socials{display:flex;flex-direction:column;gap:12px;margin-top:8px}.about__social-icon{width:42px;height:42px;border-radius:50%;border:1px solid var(--border-strong);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--text-muted);transition:border-color .2s cubic-bezier(.23,1,.32,1),color .2s cubic-bezier(.23,1,.32,1),background .2s cubic-bezier(.23,1,.32,1)}@media (hover: hover) and (pointer: fine){.about__social-icon:hover{border-color:var(--accent-primary-border);color:var(--accent-primary);background:var(--accent-primary-soft)}}.about__right{display:flex;flex-direction:column}.about__intro-block{margin-bottom:80px}.about__bio{font-family:var(--font-display);font-size:clamp(1.4rem,2.5vw,2rem);font-weight:500;line-height:1.55;color:var(--text-strong);max-width:44ch;text-wrap:pretty}.about__bio strong{color:var(--text-strong);font-weight:600}.about__resume-section{margin-bottom:80px}.about__section-heading{font-family:var(--font-display);font-size:clamp(1.4rem,2.5vw,1.8rem);font-weight:700;color:var(--text-strong);padding-bottom:16px;margin-bottom:8px;position:relative}.about__section-heading:after{content:"";position:absolute;bottom:0;left:0;width:60px;height:2px;background:linear-gradient(90deg,var(--accent-primary),transparent)}.about__exp-entry{padding:28px 0;border-bottom:1px solid var(--border-soft)}.about__exp-entry:last-child{border-bottom:none}.about__exp-header{display:flex;justify-content:space-between;align-items:baseline;gap:24px;margin-bottom:10px}.about__exp-left{flex:1;min-width:0}.about__exp-company{font-family:var(--font-display);font-size:clamp(1.1rem,1.8vw,1.25rem);font-weight:600;color:var(--text-strong);line-height:1.3}.about__exp-location{font-weight:400;color:var(--text-soft)}.about__exp-role{font-size:var(--type-sm);color:var(--text-muted);margin-top:2px}.about__exp-type{color:var(--text-soft)}.about__exp-dates{font-size:var(--type-xs);letter-spacing:.04em;color:var(--text-soft);white-space:nowrap;flex-shrink:0}.about__exp-desc{font-size:var(--type-body);line-height:var(--leading-body);color:var(--text-muted);max-width:62ch}.about__skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:24px}.about__skill-category{font-family:var(--font-display);font-size:var(--type-xs);font-weight:600;color:var(--accent-secondary);letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px}.about__skill-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.about__skill-item{font-size:var(--type-sm);line-height:1.5;color:var(--text-muted);padding-left:14px;position:relative}.about__skill-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:4px;border-radius:50%;background:var(--accent-primary);opacity:.4}.about__edu-entry{padding:28px 0}.about__edu-meta{font-size:.85rem;line-height:1.6;color:var(--text-soft)}.about__edu-sep{color:var(--accent-primary);opacity:.4}@media (max-width: 768px){.about{padding:100px 0 60px}.about__container{grid-template-columns:1fr;padding:0 20px;gap:40px}.about__left-sticky{position:relative;top:auto;flex-direction:row;flex-wrap:wrap;gap:20px 32px}.about__fact{min-width:120px}.about__socials{flex-direction:row;gap:10px;width:100%;margin-top:0}.about__resume-section{margin-bottom:56px}.about__section-heading{margin-bottom:4px}.about__exp-header{flex-direction:column;gap:2px}.about__exp-dates{order:-1;font-size:.75rem}.about__skills-grid{grid-template-columns:1fr;gap:28px}.about__edu-entry .about__exp-header{flex-direction:column;gap:2px}}.contact{padding:140px 48px;background:var(--bg-base);text-align:center;display:flex;flex-direction:column;align-items:center}.contact__heading{font-family:var(--font-display);font-size:clamp(2.5rem,6vw,4.5rem);font-weight:700;color:var(--text-strong);line-height:1.15;margin-bottom:48px}.contact__cta{display:inline-flex;align-items:center;gap:16px;background:var(--accent-primary);color:var(--text-strong);border-radius:999px;padding:16px 16px 16px 36px;font-family:var(--font-display);font-size:1.15rem;font-weight:600;letter-spacing:.01em;transition:background .2s cubic-bezier(.23,1,.32,1),transform .16s ease-out}@media (hover: hover) and (pointer: fine){.contact__cta:hover{background:var(--accent-primary-hover);transform:scale(1.02)}}.contact__cta:active{transform:scale(.97)}.contact__cta-arrow{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:#0003;border-radius:50%;font-size:1.25rem;color:var(--text-strong);transition:transform .2s cubic-bezier(.23,1,.32,1)}@media (hover: hover) and (pointer: fine){.contact__cta:hover .contact__cta-arrow{transform:translate(3px) scale(1.05)}}.contact__socials{display:flex;gap:32px;margin-top:48px}.contact__social-icon{width:42px;height:42px;border-radius:50%;border:1px solid var(--border-strong);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:border-color .2s cubic-bezier(.23,1,.32,1),color .2s cubic-bezier(.23,1,.32,1),background .2s cubic-bezier(.23,1,.32,1)}@media (hover: hover) and (pointer: fine){.contact__social-icon:hover{border-color:var(--accent-primary-border);color:var(--accent-primary);background:var(--accent-primary-soft)}}@media (max-width: 768px){.contact{padding:80px 20px}.contact__socials{flex-wrap:wrap;gap:20px;justify-content:center}}.footer{padding:32px 48px;border-top:1px solid var(--border-soft)}.footer__inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.footer__logo{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--text-strong)}.footer__copy{font-size:12px;color:var(--text-soft);letter-spacing:.05em}@media (max-width: 768px){.footer{padding:24px 20px}.footer__inner{flex-direction:column;gap:12px;text-align:center}}.project-detail{min-height:100vh;background:var(--bg-base);padding:120px 0 80px}.project-detail__container{max-width:1000px;margin:0 auto;padding:0 48px}.project-detail__back{display:inline-flex;align-items:center;min-height:40px;gap:8px;font-size:13px;letter-spacing:.05em;color:var(--text-muted);margin-bottom:64px;transition:color .2s cubic-bezier(.23,1,.32,1),transform .16s ease-out}@media (hover: hover) and (pointer: fine){.project-detail__back:hover{color:var(--text-strong)}}.project-detail__back:active{transform:scale(.97)}.project-detail__back-arrow{transition:transform .2s cubic-bezier(.23,1,.32,1)}@media (hover: hover) and (pointer: fine){.project-detail__back:hover .project-detail__back-arrow{transform:translate(-3px)}}.project-detail__hero{margin-bottom:48px}.project-detail__eyebrow{font-size:var(--type-xs);letter-spacing:var(--tracking-label);text-transform:uppercase;color:var(--accent-secondary);margin-bottom:16px;display:block}.project-detail__title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:700;color:var(--text-strong);line-height:1.1;text-wrap:balance;margin-bottom:20px}.project-detail__desc{font-size:1.0625rem;line-height:1.75;color:var(--text-muted);max-width:62ch;text-wrap:pretty}.project-detail__media{width:100%;aspect-ratio:2 / 1;border-radius:16px;overflow:hidden;background:var(--bg-elevated);box-shadow:var(--surface-shadow);margin-bottom:64px}.project-detail__media-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;outline:1px solid var(--image-outline);outline-offset:-1px}.project-detail__content{margin-bottom:80px}.project-detail__info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;padding:32px 0;border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft)}.project-detail__info-item{display:flex;flex-direction:column;gap:8px}.project-detail__info-label{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-secondary)}.project-detail__info-value{font-family:var(--font-display);font-size:1rem;font-weight:500;color:var(--text-strong)}.project-detail__nav{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding-top:48px;border-top:1px solid var(--border-soft)}.project-detail__nav-link{display:flex;flex-direction:column;gap:8px;padding:24px;border-radius:12px;background:var(--bg-panel);box-shadow:var(--surface-shadow);transition:box-shadow .2s cubic-bezier(.23,1,.32,1),transform .16s ease-out}@media (hover: hover) and (pointer: fine){.project-detail__nav-link:hover{box-shadow:0 0 0 1px var(--accent-secondary-border),0 20px 52px #00000052}}.project-detail__nav-link:active{transform:scale(.97)}.project-detail__nav-link--next{text-align:right}.project-detail__nav-dir{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--accent-secondary)}.project-detail__nav-title{font-family:var(--font-display);font-size:clamp(.9rem,1.5vw,1.1rem);font-weight:600;color:var(--text-strong);line-height:1.3}@media (max-width: 768px){.project-detail{padding:100px 0 60px}.project-detail__container{padding:0 20px}.project-detail__info-grid{grid-template-columns:1fr;gap:20px}.project-detail__nav{grid-template-columns:1fr}.project-detail__nav-link--next{text-align:left}}
