*,: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:Plus Jakarta Sans,sans-serif;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:DM Mono,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}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root,html[data-mode=dark]{--safe-top: env(safe-area-inset-top, 0px);--bg: #0e0e10;--bg-2: #141418;--bg-card: #1a1a1f;--border: rgba(255, 255, 255, .08);--border-2: rgba(255, 255, 255, .04);--text: #e6e4de;--text-2: rgba(230, 228, 222, .5);--text-3: rgba(230, 228, 222, .24);--nav-blur: rgba(14, 14, 16, .84)}html[data-mode=light]{--bg: #f4f1ec;--bg-2: #eae6de;--bg-card: #ffffff;--border: rgba(0, 0, 0, .08);--border-2: rgba(0, 0, 0, .04);--text: #181510;--text-2: rgba(24, 21, 16, .5);--text-3: rgba(24, 21, 16, .26);--nav-blur: rgba(244, 241, 236, .88)}@media(prefers-color-scheme:light){:root:not([data-mode]){--bg: #f4f1ec;--bg-2: #eae6de;--bg-card: #ffffff;--border: rgba(0, 0, 0, .08);--border-2: rgba(0, 0, 0, .04);--text: #181510;--text-2: rgba(24, 21, 16, .5);--text-3: rgba(24, 21, 16, .26);--nav-blur: rgba(244, 241, 236, .88)}}:root,[data-palette=teal]{--accent-a: oklch(72% .17 190);--accent-b: oklch(56% .24 290);--accent: linear-gradient(120deg, var(--accent-a), var(--accent-b));--accent-solid: oklch(64% .2 240)}[data-palette=amber]{--accent-a: #b8941e;--accent-b: #d4ac3a;--accent: linear-gradient(120deg, #b8941e, #d4ac3a);--accent-solid: #c9a32a}[data-palette=forest]{--accent-a: #1a5c42;--accent-b: #2d8a68;--accent: linear-gradient(120deg, #1a5c42, #2d8a68);--accent-solid: #237a56}[data-palette=crimson]{--accent-a: #b8302a;--accent-b: #d94e40;--accent: linear-gradient(120deg, #b8302a, #d94e40);--accent-solid: #c63a30}[data-palette=indigo]{--accent-a: #3730a3;--accent-b: #6366f1;--accent: linear-gradient(120deg, #3730a3, #6366f1);--accent-solid: #4f46e5}[data-palette=rose]{--accent-a: #9f1239;--accent-b: #e11d72;--accent: linear-gradient(120deg, #9f1239, #e11d72);--accent-solid: #be185d}[data-palette=copper]{--accent-a: #92400e;--accent-b: #c2763a;--accent: linear-gradient(120deg, #92400e, #c2763a);--accent-solid: #b45309}[data-palette=slate]{--accent-a: #334155;--accent-b: #64748b;--accent: linear-gradient(120deg, #334155, #64748b);--accent-solid: #475569}[data-palette=sky]{--accent-a: #0369a1;--accent-b: #38bdf8;--accent: linear-gradient(120deg, #0369a1, #38bdf8);--accent-solid: #0284c7}html[data-mode=dark][data-palette=amber]{--bg: #0d0d0a;--bg-2: #131310;--bg-card: #1a1a16}html[data-mode=dark][data-palette=crimson]{--bg: #0e0c0c;--bg-2: #161212;--bg-card: #1c1717}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:Plus Jakarta Sans,sans-serif;line-height:1.6;overflow-x:hidden;transition:background .4s,color .4s}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");opacity:.025;pointer-events:none;z-index:9999}.brand-grad{background:linear-gradient(120deg,#01bdb6,#01b4bd,#00aac8,#299ed4,#4790db 50%,#6770e8,#7a47f3);background:linear-gradient(120deg,color(xyz 0.237 0.406 0.542),color(xyz 0.241 0.367 0.583),color(xyz 0.245 0.33 0.624),#299ed4,#4790db 50%,#6770e8,#7a47f3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}html[data-logo-grad=palette] .brand-grad{background:var(--accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav{position:fixed;top:0;left:0;right:0;z-index:100;isolation:isolate;padding:calc(28px + var(--safe-top)) 52px 28px;display:flex;align-items:center;justify-content:space-between;transition:background .4s,backdrop-filter .4s,border-color .4s,padding .3s;border-bottom:1px solid transparent}.nav:before{content:"";position:absolute;top:calc((var(--safe-top) + 120px) * -1);left:0;right:0;bottom:0;z-index:-1;pointer-events:none;transition:background .4s}.nav.scrolled{border-color:var(--border);padding:calc(18px + var(--safe-top)) 52px 18px}.nav.scrolled:before{background:var(--bg)}.nav-logo{font-family:Plus Jakarta Sans,sans-serif;font-size:16px;font-weight:600;letter-spacing:-.01em;text-decoration:none;color:var(--text)}.nav-right{display:flex;align-items:center;gap:32px}.nav-links{display:flex;gap:32px;list-style:none;align-items:center}.nav-links a{color:var(--text-2);text-decoration:none;font-size:14px;font-weight:500;letter-spacing:.01em;transition:color .2s}.nav-links a:hover{color:var(--text)}.nav-cta{padding:0 22px;height:38px;display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:100px;color:var(--text)!important;font-size:13px!important;transition:border-color .2s,background .2s!important}.nav-cta:hover{border-color:var(--accent-solid)!important;background:#8080800f!important}.theme-btn{width:38px;height:38px;border-radius:50%;border:1px solid var(--border);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--text-2);transition:border-color .2s,color .2s,transform .3s;flex-shrink:0}.theme-btn:hover{border-color:var(--accent-solid);color:var(--text);transform:rotate(20deg)}.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}.reveal.visible{opacity:1;transform:translateY(0)}.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}.section{padding:130px 52px}.inner{max-width:1160px;margin:0 auto}.label{display:inline-flex;align-items:center;gap:12px;font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--text-3);margin-bottom:28px}.label:after{content:"";display:block;width:32px;height:1px;background:var(--accent-solid);opacity:.7}#hero{min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;padding:0 52px 80px;position:relative;overflow:hidden}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;transition:opacity .5s}#hero[data-pattern=lines] .hero-bg{background:linear-gradient(to bottom,transparent 0%,var(--border) 20%,var(--border) 80%,transparent 100%) 10% 0 / 1px 100% no-repeat,linear-gradient(to bottom,transparent 0%,var(--border-2) 20%,var(--border-2) 80%,transparent 100%) 30% 0 / 1px 100% no-repeat,linear-gradient(to bottom,transparent 0%,var(--border-2) 20%,var(--border-2) 80%,transparent 100%) 70% 0 / 1px 100% no-repeat,linear-gradient(to bottom,transparent 0%,var(--border) 20%,var(--border) 80%,transparent 100%) 90% 0 / 1px 100% no-repeat}#hero[data-pattern=grid] .hero-bg{background-image:linear-gradient(var(--border-2) 1px,transparent 1px),linear-gradient(90deg,var(--border-2) 1px,transparent 1px);background-size:80px 80px;opacity:.7;mask-image:radial-gradient(ellipse 55% 60% at 50% 50%,black 0%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 55% 60% at 50% 50%,black 0%,transparent 100%)}#hero[data-pattern=dots] .hero-bg{background-image:radial-gradient(circle,var(--border) 1.5px,transparent 1.5px);background-size:40px 40px;mask-image:radial-gradient(ellipse 75% 80% at 50% 50%,black 20%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 75% 80% at 50% 50%,black 20%,transparent 100%)}#hero[data-pattern=diagonal] .hero-bg{background-image:repeating-linear-gradient(45deg,transparent,transparent 39px,var(--border) 39px,var(--border) 40px);mask-image:radial-gradient(ellipse 80% 90% at 50% 50%,black 20%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 80% 90% at 50% 50%,black 20%,transparent 100%)}#hero[data-pattern=circles] .hero-bg{background:radial-gradient(circle at 80% 15%,transparent 100px,var(--border-2) 101px,transparent 102px),radial-gradient(circle at 80% 15%,transparent 160px,var(--border-2) 161px,transparent 162px),radial-gradient(circle at 80% 15%,transparent 240px,var(--border) 241px,transparent 242px),radial-gradient(circle at 80% 15%,transparent 340px,var(--border-2) 341px,transparent 342px),radial-gradient(circle at 80% 15%,transparent 460px,var(--border-2) 461px,transparent 462px),radial-gradient(circle at 80% 15%,transparent 600px,var(--border-2) 601px,transparent 602px)}#hero[data-pattern=crosshatch] .hero-bg{background-image:repeating-linear-gradient(45deg,transparent,transparent 59px,var(--border-2) 59px,var(--border-2) 60px),repeating-linear-gradient(-45deg,transparent,transparent 59px,var(--border-2) 59px,var(--border-2) 60px);mask-image:radial-gradient(ellipse 75% 80% at 50% 50%,black 20%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 75% 80% at 50% 50%,black 20%,transparent 100%)}#hero[data-pattern=none] .hero-bg{opacity:0}.hero-mark{position:absolute;top:52px;right:52px;width:220px;height:220px;border-radius:50%;border:1px solid var(--border);pointer-events:none;opacity:.4;display:none}.hero-mark:before{content:"";position:absolute;top:30px;right:30px;bottom:30px;left:30px;border-radius:50%;border:1px solid var(--border-2)}.hero-content{max-width:1160px;width:100%;margin:0 auto;position:relative;z-index:1}.hero-status{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:500;letter-spacing:.06em;color:var(--text-2);margin-bottom:48px}.status-dot{width:7px;height:7px;border-radius:50%;background:var(--accent-solid);animation:pulse-dot 2.4s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 color-mix(in oklch,var(--accent-solid) 40%,transparent)}50%{opacity:.7;box-shadow:0 0 0 5px color-mix(in oklch,var(--accent-solid) 0%,transparent)}}.hero-heading{font-family:Cormorant Garant,serif;font-size:clamp(60px,8.5vw,130px);font-weight:400;letter-spacing:-.025em;line-height:1.02;margin-bottom:48px}.hero-heading em{font-style:italic;color:var(--text-2)}.hero-footer{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;padding-top:40px}.hero-desc{font-size:16px;color:var(--text-2);line-height:1.7;max-width:440px;font-weight:400}.hero-actions{display:flex;gap:14px;flex-shrink:0}.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:100px;font-size:14px;font-weight:500;font-family:Plus Jakarta Sans,sans-serif;text-decoration:none;cursor:pointer;transition:all .25s;letter-spacing:.01em;white-space:nowrap}.btn-primary{background:var(--text);color:var(--bg);border:none}.btn-primary:hover{opacity:.86;transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-ghost:hover{border-color:color-mix(in srgb,var(--text) 30%,transparent);transform:translateY(-1px)}.scroll-hint{position:absolute;bottom:216px;right:52px;writing-mode:vertical-lr;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--text-3);font-weight:500;display:flex;align-items:center;gap:16px}.scroll-hint:before{content:"";display:block;width:1px;height:56px;background:linear-gradient(to bottom,var(--accent-solid),transparent);animation:grow-line 2s ease-in-out infinite alternate}@keyframes grow-line{0%{height:36px}to{height:64px}}#about{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);transition:background .4s}.about-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:100px;align-items:start}.about-left .label{margin-bottom:36px}.about-name{font-family:Cormorant Garant,serif;font-size:48px;font-weight:400;line-height:1.1;letter-spacing:-.02em;margin-bottom:32px}.about-name em{font-style:italic;color:var(--text-2)}.about-body{font-size:16px;color:var(--text-2);line-height:1.8;font-weight:400}.about-body p+p{margin-top:20px}.about-right{padding-top:8px}.fact-list{list-style:none}.fact-item{display:flex;justify-content:space-between;align-items:baseline;padding:20px 0;border-bottom:1px solid var(--border);font-size:15px}.fact-item:first-child{border-top:1px solid var(--border)}.fact-key{color:var(--text-3);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase}.fact-val{color:var(--text);font-weight:500;text-align:right}.fact-val .accent-text{background:var(--accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}#work{padding:130px 52px}.work-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:72px}.work-title{font-family:Cormorant Garant,serif;font-size:clamp(40px,5vw,68px);font-weight:400;letter-spacing:-.025em;line-height:1.05}.work-intro{font-size:15px;color:var(--text-2);max-width:300px;text-align:right;line-height:1.7}.project-list{list-style:none}.project-item{position:relative;display:grid;grid-template-columns:56px 1fr 240px auto;align-items:start;gap:32px;padding:40px 0;border-bottom:1px solid var(--border);transition:opacity .2s}.project-item:not(:has(.project-preview)){grid-template-columns:56px 1fr auto}.project-preview{width:240px;align-self:center;background:none;border:0;padding:0;margin:0;cursor:zoom-in;-webkit-appearance:none;-moz-appearance:none;appearance:none;color:inherit;font:inherit}.project-preview:focus-visible{outline:2px solid var(--accent-solid);outline-offset:8px;border-radius:6px}.project-preview-frame{position:relative;padding:10px 10px 36px;background:var(--bg);border:1px solid var(--border);border-radius:4px;box-shadow:0 1px 2px #0000000a,0 12px 28px -16px #00000040;transform:rotate(2.5deg) translateY(0);transform-origin:50% 100%;transition:transform .5s cubic-bezier(.2,.8,.2,1),box-shadow .5s ease,border-color .4s ease}.project-preview-frame:after{content:"";position:absolute;left:50%;bottom:14px;width:36px;height:1px;background:var(--text-3);opacity:.35;transform:translate(-50%);transition:background .4s ease,opacity .4s ease}.project-preview-frame img{display:block;width:100%;height:160px;-o-object-fit:cover;object-fit:cover;border-radius:2px;filter:saturate(.55) contrast(.96);transition:filter .5s ease}.project-item:hover .project-preview-frame{transform:rotate(-1.2deg) translateY(-6px) scale(1.04);border-color:var(--accent-solid);box-shadow:0 2px 4px #0000000f,0 24px 48px -20px color-mix(in oklab,var(--accent-solid) 55%,transparent)}.project-item:hover .project-preview-frame img{filter:saturate(1) contrast(1)}.project-item:hover .project-preview-frame:after{background:var(--accent-solid);opacity:.8}.project-list:hover .project-item{opacity:.4}.project-list:hover .project-item:hover{opacity:1}.project-num{font-family:DM Mono,monospace;font-size:12px;color:var(--text-3);padding-top:6px;letter-spacing:.05em}.project-name{font-family:Cormorant Garant,serif;font-size:32px;font-weight:400;letter-spacing:-.02em;line-height:1.1;margin-bottom:12px}.project-name a{color:inherit;text-decoration:none;border-bottom:1px solid var(--border);padding-bottom:2px;transition:border-color .2s}.project-name a:hover{border-color:var(--accent-solid)}.project-role{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-solid);margin-bottom:14px}.project-desc{font-size:15px;color:var(--text-2);line-height:1.75;max-width:560px}.project-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:18px}.tag{font-size:11px;font-family:DM Mono,monospace;padding:4px 10px;border-radius:100px;border:1px solid var(--border);color:var(--text-3)}.project-year{font-family:DM Mono,monospace;font-size:12px;color:var(--text-3);padding-top:6px;white-space:nowrap}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:grid;place-items:center;padding:5vh 5vw;cursor:zoom-out}.lightbox:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:color-mix(in oklab,var(--bg) 78%,transparent);backdrop-filter:blur(18px) saturate(1.1);-webkit-backdrop-filter:blur(18px) saturate(1.1);animation:lightbox-fade-in .35s ease forwards}.lightbox-closing:before,.lightbox-closing .lightbox-close{animation:lightbox-fade-out .28s ease forwards}.lightbox-close{animation:lightbox-fade-in .35s ease forwards}@keyframes lightbox-fade-in{0%{opacity:0}to{opacity:1}}@keyframes lightbox-fade-out{0%{opacity:1}to{opacity:0}}.lightbox-frame{--img-w: min(880px, 82vw, 77vh);position:relative;z-index:1;width:var(--img-w);padding:calc(var(--img-w) / 22) calc(var(--img-w) / 22) calc(var(--img-w) * .1636);background:var(--bg);border:1px solid var(--border);border-radius:6px;box-shadow:0 8px 24px #0000002e,0 32px 80px -16px #00000073;transform-origin:center center;will-change:transform;cursor:default}.lightbox-frame:after{content:"";position:absolute;left:50%;bottom:calc(var(--img-w) * .0637);width:calc(var(--img-w) * .1636);height:1px;background:var(--accent-solid);opacity:.7;transform:translate(-50%)}.lightbox-frame img{display:block;width:100%;height:auto;aspect-ratio:220 / 160;-o-object-fit:cover;object-fit:cover;border-radius:3px}.lightbox-close{position:absolute;top:24px;right:28px;width:44px;height:44px;padding:0;border-radius:50%;border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;display:grid;place-items:center;transition:border-color .2s,color .2s,transform .2s}.lightbox-close:before{content:"";width:16px;height:16px;background:currentColor;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M3 3 L13 13 M13 3 L3 13' stroke='black' stroke-width='1.6' stroke-linecap='round' fill='none'/></svg>") center / contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><path d='M3 3 L13 13 M13 3 L3 13' stroke='black' stroke-width='1.6' stroke-linecap='round' fill='none'/></svg>") center / contain no-repeat}.lightbox-close:hover{border-color:var(--accent-solid);color:var(--accent-solid);transform:scale(1.06)}.work-note{margin-top:48px;padding:28px 32px;border:1px solid var(--border);border-radius:12px;font-size:14px;color:var(--text-2);line-height:1.7;background:#80808008}#stack{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);transition:background .4s}.stack-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}.stack-category{padding:36px 32px;border-right:1px solid var(--border)}.stack-category:last-child{border-right:none}.stack-cat-name{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);margin-bottom:20px}.stack-items{list-style:none}.stack-items li{font-size:15px;color:var(--text-2);padding:6px 0;border-bottom:1px solid var(--border-2);font-weight:400;transition:color .2s}.stack-items li:last-child{border-bottom:none}.stack-items li:hover{color:var(--text)}.stack-items li:before{content:"—  ";color:var(--text-3);font-family:DM Mono,monospace;font-size:12px}#contact{padding:160px 52px}.contact-inner{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end}.contact-heading{font-family:Cormorant Garant,serif;font-size:clamp(48px,6vw,88px);font-weight:400;letter-spacing:-.03em;line-height:1.05}.contact-heading em{font-style:italic;color:var(--text-2)}.contact-desc{font-size:16px;color:var(--text-2);line-height:1.75;margin-bottom:40px}.contact-email-big{display:block;font-family:Cormorant Garant,serif;font-size:26px;font-weight:400;color:var(--text);text-decoration:none;border-bottom:1px solid var(--border);padding-bottom:16px;margin-bottom:32px;transition:border-color .2s;letter-spacing:-.01em}.contact-email-big:hover{border-color:var(--accent-solid)}.contact-actions{display:flex;gap:12px}footer{border-top:1px solid var(--border);padding:28px 52px;display:flex;align-items:center;justify-content:space-between}.footer-logo{font-size:14px;font-weight:600;color:var(--text-3)}.footer-copy{font-size:13px;color:var(--text-3)}.footer-links{display:flex;gap:24px}.footer-links a{font-size:13px;color:var(--text-3);text-decoration:none;transition:color .2s}.footer-links a:hover{color:var(--text)}.footer-link-btn{font-size:13px;color:var(--text-3);background:none;border:0;padding:0;cursor:pointer;font-family:inherit;transition:color .2s}.footer-link-btn:hover{color:var(--text)}.legal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:color-mix(in oklab,var(--bg) 70%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:24px;animation:legal-fade .18s ease-out}@keyframes legal-fade{0%{opacity:0}to{opacity:1}}.legal-modal{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:36px 40px 32px;max-width:480px;width:100%;color:var(--text);box-shadow:0 24px 60px -20px #00000059;animation:legal-rise .22s ease-out}@keyframes legal-rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.legal-close{position:absolute;top:12px;right:14px;background:none;border:0;font-size:24px;line-height:1;color:var(--text-3);cursor:pointer;padding:4px 8px;transition:color .2s}.legal-close:hover{color:var(--text)}.legal-title{font-family:Cormorant Garant,serif;font-size:28px;font-weight:500;letter-spacing:-.01em;margin:0 0 20px}.legal-list{display:grid;grid-template-columns:96px 1fr;gap:10px 20px;margin:0 0 20px;font-size:14px;line-height:1.55}.legal-list dt{color:var(--text-3);font-family:DM Mono,monospace;font-size:11px;text-transform:uppercase;letter-spacing:.08em;padding-top:2px}.legal-list dd{margin:0;color:var(--text-2)}.legal-list dd a{color:var(--accent-solid);text-decoration:none;border-bottom:1px solid var(--border-2)}.legal-list dd a:hover{border-color:var(--accent-solid)}.legal-note{font-size:12px;color:var(--text-3);line-height:1.5;margin:0;padding-top:16px;border-top:1px solid var(--border)}@media(max-width:960px){.nav{padding:calc(20px + var(--safe-top)) 24px 20px}.nav.scrolled{padding:calc(16px + var(--safe-top)) 24px 16px}.nav-links{display:none}.section,#work,#contact{padding:80px 24px}#hero{padding:0 24px 60px}.scroll-hint,.hero-mark{display:none}.hero-footer{flex-direction:column;align-items:flex-start}.about-grid{grid-template-columns:1fr;gap:48px}.work-header{flex-direction:column;align-items:flex-start;gap:16px}.work-intro{text-align:left}.project-item,.project-item:not(:has(.project-preview)){grid-template-columns:1fr;gap:12px}.project-num,.project-year,.project-preview{display:none}.stack-grid{grid-template-columns:1fr 1fr}.stack-category{border-bottom:1px solid var(--border)}.stack-category:nth-child(odd){border-right:1px solid var(--border)}.stack-category:nth-child(2n){border-right:none}.stack-category:nth-last-child(-n+2){border-bottom:none}.contact-inner{grid-template-columns:1fr;gap:40px}footer{flex-direction:column;gap:16px;text-align:center}.footer-links{flex-wrap:wrap;justify-content:center}.legal-modal{padding:28px 24px 24px}.legal-list{grid-template-columns:1fr;gap:4px 0}.legal-list dd{margin-bottom:10px}}.visible{visibility:visible}.grid{display:grid}.hidden{display:none}.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))}.accent-text{accent-color:var(--text)}.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}
