:root{--paper:#f4f3ef;--ink:#0b0b0b;--muted:#888;--line:rgba(11,11,11,.16);--red:#a70f17;--pad:clamp(24px,5vw,80px);--radius:3px}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--paper);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","PingFang SC","Helvetica Neue",Arial,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}a{color:inherit;text-decoration:none}img{display:block;width:100%;height:auto}figure{margin:0}.grain{position:fixed;inset:0;z-index:100;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.75'/%3E%3C/svg%3E")}.cursor{position:fixed;z-index:101;width:10px;height:10px;border-radius:50%;background:#fff;mix-blend-mode:difference;pointer-events:none;transform:translate(-50%,-50%);transition:width .25s,height .25s;display:none}.cursor.is-active{width:48px;height:48px}.site-header{position:fixed;inset:0 0 auto 0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:24px var(--pad);mix-blend-mode:difference;color:#fff}.brand{font-size:17px;font-weight:800;letter-spacing:-.04em}.brand span{font-size:8px;vertical-align:top;margin-left:2px}.site-header nav{display:flex;gap:32px;font-size:11px;letter-spacing:.12em}.menu-toggle{display:none;border:0;background:none;color:inherit;font:inherit;font-size:11px}.section-pad{padding-left:var(--pad);padding-right:var(--pad)}.eyebrow{font-size:10px;letter-spacing:.2em;text-transform:uppercase}.hero{position:relative;height:100svh;min-height:680px;padding:130px var(--pad) 48px;overflow:hidden}.hero-kicker{font-size:10px;letter-spacing:.22em}.hero-title{position:relative;z-index:2;margin:8vh 0 0;font-size:clamp(72px,15vw,230px);line-height:.72;letter-spacing:-.085em;font-weight:800}.hero-title .line{display:block;overflow:hidden;padding-right:.08em}.hero-title .line span{display:block;animation:heroIn 1.2s cubic-bezier(.16,1,.3,1) both}.hero-title .line:nth-child(2) span{animation-delay:.12s}.hero-title .outline{color:transparent;-webkit-text-stroke:1.5px var(--ink);margin-left:12vw}.hero-meta{position:absolute;left:var(--pad);right:var(--pad);bottom:45px;display:flex;justify-content:space-between;border-top:1px solid var(--line);padding-top:14px;font-size:10px;letter-spacing:.1em}.hero-object{position:absolute;width:min(36vw,550px);right:8vw;top:16vh;transform:rotate(-4deg);box-shadow:0 24px 80px rgba(0,0,0,.14)}.hero-object img{filter:grayscale(1);mix-blend-mode:multiply}.scroll-cue{position:absolute;z-index:3;right:var(--pad);bottom:95px;display:flex;align-items:center;gap:14px;font-size:9px;letter-spacing:.2em}.scroll-cue i{width:55px;height:1px;background:var(--ink);position:relative;overflow:hidden}.scroll-cue i:after{content:"";position:absolute;inset:0;background:var(--paper);animation:scan 2s infinite}.statement{min-height:95vh;padding-top:18vh;padding-bottom:14vh;display:flex;flex-direction:column;justify-content:space-between;background:#101010;color:#f5f5f2}.statement-copy{max-width:1200px;margin:10vh 0;font-size:clamp(34px,5.2vw,82px);line-height:1.14;letter-spacing:-.045em}.statement-foot{display:flex;justify-content:space-between;border-top:1px solid #333;padding-top:16px;font-size:11px;color:#aaa}.work-index{padding-top:16vh;padding-bottom:16vh}.section-head{display:flex;justify-content:space-between;border-bottom:1px solid var(--line);padding-bottom:16px}.index-list{margin-top:5vh}.index-row{display:grid;grid-template-columns:8% 1fr 25%;align-items:center;padding:28px 0;border-bottom:1px solid var(--line);transition:padding .4s cubic-bezier(.16,1,.3,1),background .3s}.index-row:hover{padding-left:18px;padding-right:18px;background:#fff}.index-row span{font-size:10px}.index-row h2{font-size:clamp(28px,4vw,58px);letter-spacing:-.05em;margin:0;font-weight:500}.index-row em{font-style:normal;font-size:11px;text-align:right;color:var(--muted)}.project{position:relative;padding-bottom:12vh}.project-dark{background:#0d0d0d;color:#f2f2ef}.project-light{background:var(--paper);color:var(--ink)}.project-intro{min-height:80vh;padding-top:16vh;padding-bottom:10vh;display:grid;grid-template-columns:1fr 2fr 1.2fr;gap:4vw;align-items:end}.project-no{align-self:start;font-size:10px;letter-spacing:.18em}.project-title{grid-column:2;margin:0;font-size:clamp(70px,11vw,170px);font-weight:500;line-height:.75;letter-spacing:-.08em}.project-summary{grid-column:3;font-size:13px;line-height:1.7}.project-summary>p{font-size:17px}.project-summary dl{margin-top:40px}.project-summary dl div{display:grid;grid-template-columns:70px 1fr;border-top:1px solid currentColor;padding:10px 0;opacity:.62}.project-summary dt,.project-summary dd{margin:0}.project-cover{margin:0 var(--pad);overflow:hidden;background:#222}.project-cover img{transition:transform 1.2s cubic-bezier(.16,1,.3,1)}.project-cover:hover img{transform:scale(1.015)}.project-story{padding-top:16vh;padding-bottom:16vh;display:grid;grid-template-columns:1fr 1.5fr;gap:10vw}.story-copy h3{font-size:clamp(34px,4vw,64px);line-height:1.05;letter-spacing:-.05em;font-weight:500}.story-copy>p:last-child{max-width:520px;line-height:1.8;color:#aaa}.sticky-copy{position:sticky;top:15vh;align-self:start}.compare-stack{display:grid;gap:14vh}.media-card{overflow:hidden}.media-card img,.shot img,.render-cascade img,.photo-grid img{transition:transform 1.1s cubic-bezier(.16,1,.3,1);will-change:transform}.media-card:hover img,.shot:hover img,.render-cascade figure:hover img,.photo-grid figure:hover img{transform:scale(1.025)}figcaption{display:flex;justify-content:space-between;margin-top:12px;font-size:10px;color:#888}.mood-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:8vw 3vw;padding-bottom:16vh}.mood-grid .tall{grid-row:span 2}.quote-block{align-self:end;padding:40px 0;border-top:1px solid #333}.quote-block p{font-size:clamp(24px,3vw,45px);line-height:1.15;margin:0 0 30px;letter-spacing:-.04em}.quote-block span{font-size:10px;color:#777}.cinema-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:3vw;padding-bottom:14vh}.shot-xl,.shot-wide{grid-column:span 2}.project-note{display:grid;grid-template-columns:1fr 2fr;gap:4vw;border-top:1px solid #333;padding-top:30px}.project-note span{font-size:9px;letter-spacing:.18em}.project-note p{max-width:750px;margin:0;line-height:1.7;color:#aaa}.triptych{display:grid;grid-template-columns:repeat(3,1fr);gap:2vw;padding-top:14vh;padding-bottom:16vh}.horizontal-gallery{overflow:hidden;padding:5vh 0 14vh}.rail{display:flex;gap:3vw;padding:0 var(--pad);width:max-content}.rail figure{width:min(68vw,1050px);flex:none}.rail figure:nth-child(even){width:min(48vw,720px);margin-top:12vh}.concept-band{position:relative;padding-top:16vh;padding-bottom:16vh;display:grid;grid-template-columns:1fr 1fr;gap:10vw}.concept-band .offset{margin-top:28vh}.concept-word{position:absolute;z-index:0;left:33%;top:36%;font-size:22vw;font-weight:800;letter-spacing:-.1em;color:var(--red);opacity:.45}.concept-band figure{position:relative;z-index:1}.plan-band{display:grid;grid-template-columns:.8fr 1fr 1fr;gap:3vw;padding-top:12vh;padding-bottom:18vh}.accent-red .project-title{color:#f2f2ef}.accent-red .project-no,.accent-red .eyebrow{color:#d63139}.render-cascade{display:grid;grid-template-columns:1fr 1fr;gap:8vh 4vw}.render-cascade figure:nth-child(even){margin-top:20vh}.photo-project{background:#e9e9e5;color:#0b0b0b;padding-bottom:14vh}.photo-head{min-height:75vh;padding-top:17vh;display:grid;grid-template-columns:2fr 1fr;align-content:center;gap:4vw}.photo-head h2{font-size:clamp(80px,13vw,200px);line-height:.72;letter-spacing:-.085em;font-weight:500;margin:0}.photo-head p:last-child{align-self:end;max-width:430px;line-height:1.7}.photo-marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:20px 0;font-size:clamp(30px,5vw,75px);white-space:nowrap;letter-spacing:-.04em}.photo-marquee span{display:inline-block;animation:marquee 24s linear infinite}.photo-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:8vw 2vw;padding-top:14vh}.photo-grid figure{overflow:hidden}.photo-grid .portrait{grid-column:span 5}.photo-grid .landscape{grid-column:span 7}.photo-grid .small{grid-column:span 4}.photo-grid figure:nth-child(2),.photo-grid figure:nth-child(5),.photo-grid figure:nth-child(8){margin-top:18vh}.aigc-flow{display:grid;grid-template-columns:repeat(2,1fr);gap:3vw;padding-top:5vh}.aigc-flow .hero-result{grid-column:span 2}.about{min-height:100vh;padding-top:18vh;padding-bottom:18vh;background:#111;color:#f3f3f0}.about-grid{display:grid;grid-template-columns:1.4fr .8fr;gap:6vw;margin-top:8vh}.about h2{font-size:clamp(64px,10vw,150px);line-height:.78;letter-spacing:-.07em;font-weight:500;margin:0}.about-copy{align-self:center;font-size:17px;line-height:1.8;color:#bbb}.facts{grid-column:1/-1;display:grid;grid-template-columns:repeat(4,1fr);gap:2vw;border-top:1px solid #333;padding-top:24px;font-size:10px;color:#888}.footer{min-height:80vh;padding-top:15vh;padding-bottom:5vh;display:flex;flex-direction:column;justify-content:space-between}.mail{font-size:clamp(42px,8vw,130px);letter-spacing:-.07em;border-bottom:2px solid var(--ink);width:max-content;max-width:100%}.footer-foot{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding-top:16px;font-size:10px}.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s,transform .9s cubic-bezier(.16,1,.3,1)}.reveal.in-view{opacity:1;transform:none}.reveal-media{clip-path:inset(0 0 100% 0);transition:clip-path 1.2s cubic-bezier(.16,1,.3,1)}.reveal-media.in-view{clip-path:inset(0)}.split-text{opacity:0;transform:translateY(24px);transition:opacity .8s,transform 1s cubic-bezier(.16,1,.3,1)}.split-text.in-view{opacity:1;transform:none}@keyframes heroIn{from{transform:translateY(110%)}to{transform:none}}@keyframes scan{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}@keyframes marquee{to{transform:translateX(-50%)}}
@media(max-width:900px){.site-header nav{display:none}.menu-toggle{display:block}.hero-object{width:58vw;right:-10vw;top:26vh}.hero-title{margin-top:14vh}.hero-title .outline{margin-left:0}.hero-meta p:nth-child(2){display:none}.project-intro{grid-template-columns:1fr;min-height:auto;padding-top:18vh}.project-title,.project-summary{grid-column:1}.project-title{margin:10vh 0 5vh}.project-story{grid-template-columns:1fr}.sticky-copy{position:static}.mood-grid,.plan-band{grid-template-columns:1fr}.mood-grid .tall{grid-row:auto}.triptych{grid-template-columns:1fr}.concept-band{gap:3vw}.concept-word{top:42%;left:18%}.photo-head{grid-template-columns:1fr}.photo-head .eyebrow{grid-column:1}.facts{grid-template-columns:1fr 1fr}.index-row{grid-template-columns:12% 1fr}.index-row em{display:none}}
@media(max-width:600px){:root{--pad:20px}.hero{min-height:720px;padding-top:110px}.hero-title{font-size:22vw;line-height:.8;margin-top:18vh}.hero-object{width:78vw;top:31vh;right:-25vw}.hero-meta{display:grid;gap:4px}.scroll-cue{display:none}.statement-copy{font-size:32px}.index-row{padding:20px 0}.project-intro{padding-top:120px}.project-title{font-size:24vw}.project-story{padding-top:100px}.cinema-grid,.render-cascade,.aigc-flow{grid-template-columns:1fr}.shot-xl,.shot-wide,.aigc-flow .hero-result{grid-column:auto}.project-note{grid-template-columns:1fr}.triptych{padding-top:90px}.rail figure,.rail figure:nth-child(even){width:86vw;margin-top:0}.concept-band{grid-template-columns:1fr}.concept-band .offset{margin-top:10vh}.plan-band{padding-top:80px}.render-cascade figure:nth-child(even){margin-top:0}.photo-head{min-height:680px}.photo-grid{grid-template-columns:1fr;gap:8vh}.photo-grid .portrait,.photo-grid .landscape,.photo-grid .small{grid-column:auto}.photo-grid figure:nth-child(2),.photo-grid figure:nth-child(5),.photo-grid figure:nth-child(8){margin-top:0}.about-grid{grid-template-columns:1fr}.facts{grid-template-columns:1fr}.mail{font-size:11vw}.cursor{display:none!important}}
@media(pointer:fine){.cursor{display:block}}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation:none!important;transition-duration:.01ms!important}.parallax{transform:none!important}}

/* Keep all content visible when local browser policies block JavaScript. */
.reveal,.split-text{opacity:1;transform:none}
.reveal-media{clip-path:inset(0)}
.motion .reveal{opacity:0;transform:translateY(30px)}
.motion .reveal.in-view{opacity:1;transform:none}
.motion .split-text{opacity:0;transform:translateY(24px)}
.motion .split-text.in-view{opacity:1;transform:none}
.motion .reveal-media{clip-path:inset(0)}
.motion .reveal-media img{transform:scale(1.018);transition:transform 1.2s cubic-bezier(.16,1,.3,1)}
.motion .reveal-media.in-view img{transform:scale(1)}

/* Pure typographic hero: no duplicated PDF cover image. */
.hero:before{content:"";position:absolute;width:min(42vw,620px);aspect-ratio:1;border:1px solid rgba(11,11,11,.14);border-radius:50%;right:-7vw;top:8vh}
.hero:after{content:"";position:absolute;width:42vw;height:1px;background:var(--line);right:0;top:33vh;transform:rotate(-32deg);transform-origin:right}
.hero-kicker,.hero-meta{z-index:2}
.hero-title{margin-top:11vh}

@media(max-width:600px){.hero:before{width:92vw;right:-44vw;top:20vh}.hero:after{width:78vw;top:35vh}.hero-title{margin-top:18vh}}
@media(prefers-reduced-motion:reduce){.motion .reveal,.motion .split-text{opacity:1;transform:none}.motion .reveal-media{clip-path:inset(0)}}

/* Profile follows the design statement and rebuilds the PDF resume as HTML. */
.profile{padding-top:16vh;padding-bottom:16vh;background:#e9e8e3}
.profile-head{display:grid;grid-template-columns:1.45fr .55fr;gap:3vw 7vw;align-items:end}
.profile-head>.eyebrow{grid-column:1/-1;border-bottom:1px solid var(--line);padding-bottom:16px}
.profile-head h2{margin:5vh 0 0;font-size:clamp(80px,13vw,190px);line-height:.72;letter-spacing:-.08em;font-weight:500}
.profile-portrait{grid-column:2;grid-row:2;width:min(100%,340px);justify-self:end;border-radius:50%;overflow:hidden;aspect-ratio:1;background:#d7d5cf}
.profile-portrait img{width:100%;height:100%;object-fit:cover}
.profile-lead{grid-column:1;max-width:820px;font-size:clamp(20px,2.2vw,34px);line-height:1.45;letter-spacing:-.025em;margin-top:4vh}
.profile-lead p{margin:0 0 18px}.profile-lead p:last-child{color:#777}
.profile-meta{display:grid;grid-template-columns:repeat(4,1fr);margin-top:10vh;border-top:1px solid var(--ink);border-bottom:1px solid var(--line)}
.profile-meta div{padding:18px 18px 18px 0;border-right:1px solid var(--line)}
.profile-meta div:last-child{border-right:0;padding-left:18px}.profile-meta div:not(:first-child){padding-left:18px}
.profile-meta span{display:block;font-size:9px;letter-spacing:.16em;color:#888;margin-bottom:8px}.profile-meta strong{font-size:13px;font-weight:500}
.resume-grid{display:grid;grid-template-columns:1.35fr .85fr;gap:9vw;margin-top:13vh}
.resume-column h3{font-size:clamp(28px,3vw,48px);font-weight:500;letter-spacing:-.04em;margin:0 0 5vh}
.resume-column h3 small{display:block;font-size:9px;letter-spacing:.18em;color:#888;margin-top:8px;text-transform:uppercase}
.resume-item{position:relative;border-top:1px solid var(--line);padding:26px 0 42px}
.resume-item h4{font-size:20px;margin:0 0 5px;font-weight:600}.resume-item>strong{font-size:12px;font-weight:500;color:#666}
.resume-item p{max-width:720px;font-size:13px;line-height:1.85;color:#666;margin:18px 0 0}.resume-date{float:right;font-size:10px;letter-spacing:.08em;color:#888;margin-top:7px}
.toolkit{margin-top:8vh;border-top:1px solid var(--ink);padding-top:24px}
.toolkit>div{display:grid;grid-template-columns:repeat(6,1fr);margin-top:30px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.toolkit span{padding:24px 10px;border-right:1px solid var(--line);text-align:center;font-size:12px}.toolkit span:last-child{border-right:0}
.toolkit .tool-card{min-width:0;padding:28px 14px 22px;border-right:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:18px;transition:background .35s,transform .35s}
.toolkit .tool-card:last-child{border-right:0}.toolkit .tool-card:hover{background:#f6f5f1;transform:translateY(-5px)}
.toolkit .tool-card img{width:clamp(58px,6vw,92px);height:clamp(58px,6vw,92px);object-fit:contain;filter:drop-shadow(0 8px 14px rgba(0,0,0,.1))}
.toolkit .tool-card span{padding:0;border:0;font-size:11px;letter-spacing:.03em}

/* Cropped source images now behave as image assets, not PDF pages. */
.project-cover{max-height:78vh}.project-cover img{width:100%;height:100%;max-height:78vh;object-fit:cover}
.compare-stack img{background:#efefec}.cinema-grid .shot{background:#171717}.cinema-grid .shot img{height:100%;object-fit:cover}
.cinema-grid .shot:not(.shot-xl):not(.shot-wide){aspect-ratio:1.2}.render-cascade figure{aspect-ratio:1.72;overflow:hidden}.render-cascade img{width:100%;height:100%;object-fit:cover}
.photo-grid figure{background:#ddd}.photo-grid img{width:100%;height:100%;object-fit:cover}.photo-grid .portrait{aspect-ratio:1.2}.photo-grid .landscape{aspect-ratio:1.75}.photo-grid .small{aspect-ratio:1}

@media(max-width:900px){.profile-head{grid-template-columns:1fr .35fr}.profile-meta{grid-template-columns:1fr 1fr}.resume-grid{grid-template-columns:1fr}.toolkit>div{grid-template-columns:repeat(3,1fr)}.toolkit .tool-card:nth-child(3){border-right:0}.toolkit .tool-card:nth-child(-n+3){border-bottom:1px solid var(--line)}}
@media(max-width:600px){.profile{padding-top:110px;padding-bottom:110px}.profile-head{grid-template-columns:1fr}.profile-head h2{font-size:24vw}.profile-portrait{grid-column:1;grid-row:auto;justify-self:start;width:180px;margin-top:20px}.profile-lead{grid-column:1;font-size:21px}.profile-meta{grid-template-columns:1fr}.profile-meta div,.profile-meta div:not(:first-child),.profile-meta div:last-child{padding:15px 0;border-right:0;border-bottom:1px solid var(--line)}.resume-grid{margin-top:90px}.resume-date{float:none;margin:0 0 12px}.toolkit>div{grid-template-columns:1fr 1fr}.toolkit .tool-card:nth-child(3){border-right:1px solid var(--line)}.toolkit .tool-card:nth-child(even){border-right:0}.toolkit .tool-card:nth-child(-n+4){border-bottom:1px solid var(--line)}}
