*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--w:#f0ede8;--w2:#c8c4be;--w3:#888480;--bg:#0a0a0a;--bg2:#111;--bg3:#181818;--bdr:#f0ede81a;--bdr2:#f0ede847;--mono:"Share Tech Mono", monospace;--dis:"Bebas Neue", sans-serif;--body:"Barlow", sans-serif}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--w);font-family:var(--body);-webkit-user-select:none;user-select:none;overflow-x:hidden}#grain{z-index:9000;pointer-events:none;opacity:.038;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px 200px;animation:80ms step-end infinite gs;position:fixed;inset:0}@keyframes gs{0%{transform:translate(0)}25%{transform:translate(-4px,2px)}50%{transform:translate(3px,-1px)}75%{transform:translate(-2px,4px)}}#nav{z-index:500;-webkit-backdrop-filter:blur();backdrop-filter:blur();opacity:0;pointer-events:none;background:#0a0a0a00;border-bottom:1px solid #0000;justify-content:space-between;align-items:center;padding:16px 52px;transition:background .5s,border-color .5s,-webkit-backdrop-filter .5s,backdrop-filter .5s,opacity .5s;display:flex;position:fixed;top:0;left:0;right:0}#nav.visible{opacity:1;pointer-events:all;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-color:var(--bdr);background:#0a0a0af0}.nav-id{font-family:var(--mono);letter-spacing:.22em;color:var(--w2);font-size:10px}.nav-links{gap:30px;list-style:none;display:flex}.nav-links a{font-family:var(--mono);letter-spacing:.22em;color:var(--w3);text-transform:uppercase;font-size:9px;text-decoration:none;transition:color .2s}.nav-links a:hover{color:var(--w)}#cine-wrap{height:700vh;position:relative}#cine-stage{background:#000;width:100%;height:100vh;position:sticky;top:0;overflow:hidden}#lb-t,#lb-b{display:none}#prog-bar{z-index:401;background:#ffffff14;height:1px;position:absolute;bottom:66px;left:52px;right:52px}#prog-fill{background:var(--w);width:0%;height:100%}#scene-dots{z-index:401;align-items:center;gap:8px;display:flex;position:absolute;bottom:76px;right:52px}.sdot{background:#ffffff2e;border-radius:50%;width:4px;height:4px;transition:background .3s,transform .3s}.sdot.on{background:var(--w);transform:scale(1.6)}#scroll-hint{z-index:401;font-family:var(--mono);letter-spacing:.3em;color:#ffffff40;text-transform:uppercase;font-size:9px;transition:opacity .5s;animation:2s ease-in-out infinite hb;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}@keyframes hb{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(5px)}}.scene{opacity:0;will-change:opacity;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}#s1{background:#000;flex-direction:column}.s1-name{font-family:var(--dis);color:var(--w);text-align:center;text-transform:uppercase;font-size:clamp(64px,12vw,180px);line-height:.88}.s1-name .ln{display:block;overflow:hidden}.s1-name .ln span{animation:.9s cubic-bezier(.16,1,.3,1) forwards s1Up;display:block;transform:translateY(110%)}.s1-name .ln:first-child span{animation-delay:.1s}.s1-name .ln:nth-child(2) span{color:var(--w2);animation-delay:.3s}@keyframes s1Up{to{transform:translateY(0)}}.s1-sub{font-family:var(--body);letter-spacing:.45em;color:var(--w3);text-transform:uppercase;opacity:0;margin-top:20px;font-size:clamp(10px,1.2vw,14px);font-weight:100;animation:.8s .75s forwards s1Fi}.s1-meta{opacity:0;justify-content:center;gap:48px;margin-top:44px;animation:.8s 1.05s forwards s1Fi;display:flex}.s1-mi{font-family:var(--mono);letter-spacing:.22em;color:var(--w3);text-transform:uppercase;text-align:center;font-size:9px}.s1-mi span{color:var(--w2);margin-top:5px;font-size:11px;display:block}.s1-scroll{font-family:var(--mono);letter-spacing:.3em;color:#f0ede847;text-transform:uppercase;opacity:0;white-space:nowrap;font-size:9px;animation:.6s 1.5s forwards s1Fi;position:absolute;bottom:28px;left:50%;transform:translate(-50%)}@keyframes s1Fi{to{opacity:1}}#particle-canvas{z-index:1;pointer-events:auto;will-change:opacity;width:100%;height:100%;position:absolute;top:0;left:0}#s1 .s1-name,#s1 .s1-sub,#s1 .s1-meta,#s1 .s1-scroll{z-index:2;position:relative}#s2{background:#070707;flex-direction:column}.s2-eye{font-family:var(--mono);letter-spacing:.38em;color:var(--w3);text-transform:uppercase;opacity:0;margin-bottom:20px;font-size:10px;transition:opacity .6s .1s,transform .6s .1s;transform:translateY(14px)}#s2.play .s2-eye{opacity:1;transform:translateY(0)}.s2-name{font-family:var(--dis);color:var(--w);text-align:center;text-transform:uppercase;font-size:clamp(68px,13vw,190px);line-height:.88}.s2-ln{display:block;overflow:hidden}.s2-ln span{transition:transform .85s cubic-bezier(.16,1,.3,1);display:block;transform:translateY(110%)}#s2.play .s2-ln:first-child span{transition-delay:.2s;transform:translateY(0)}#s2.play .s2-ln:nth-child(2) span{color:var(--w2);transition-delay:.4s;transform:translateY(0)}.s2-sub{font-family:var(--body);letter-spacing:.45em;color:var(--w3);text-transform:uppercase;opacity:0;margin-top:24px;font-size:clamp(11px,1.3vw,15px);font-weight:100;transition:opacity .8s .85s}#s2.play .s2-sub{opacity:1}#s3{background:#000;flex-direction:column;align-items:stretch;gap:0;padding:0 8vw}.role-row{opacity:0;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:baseline;padding:16px 0;transition:opacity .45s,transform .45s;display:flex;transform:translate(-22px)}#s3.play .role-row:first-child{opacity:1;transition-delay:80ms;transform:translate(0)}#s3.play .role-row:nth-child(2){opacity:1;transition-delay:.18s;transform:translate(0)}#s3.play .role-row:nth-child(3){opacity:1;transition-delay:.28s;transform:translate(0)}#s3.play .role-row:nth-child(4){opacity:1;transition-delay:.38s;transform:translate(0)}#s3.play .role-row:nth-child(5){opacity:1;transition-delay:.48s;transform:translate(0)}.rn{font-family:var(--dis);color:var(--w);text-transform:uppercase;letter-spacing:.03em;font-size:clamp(20px,3.2vw,46px)}.ro{font-family:var(--mono);letter-spacing:.18em;color:var(--w3);text-transform:uppercase;font-size:clamp(8px,.9vw,11px)}.ry{font-family:var(--mono);letter-spacing:.15em;color:var(--w2);font-size:10px}#s4{background:#060606;overflow:hidden}.s4-bg{background:radial-gradient(50% 50%,#ffffff08 0%,#0000 70%);position:absolute;inset:0}.reticle{opacity:0;width:min(56vw,56vh);height:min(56vw,56vh);transition:opacity .7s .2s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}#s4.play .reticle{opacity:1}.reticle circle{fill:none;stroke:#f0ede812}.spin1{transform-origin:50%;animation:16s linear infinite spn}.spin2{transform-origin:50%;animation:22s linear infinite reverse spn}@keyframes spn{to{transform:rotate(360deg)}}.s4-inner{z-index:2;text-align:center;flex-direction:column;align-items:center;display:flex;position:relative}.s4-tag{font-family:var(--mono);letter-spacing:.42em;color:var(--w3);text-transform:uppercase;opacity:0;margin-bottom:20px;font-size:9px;transition:opacity .5s .15s}#s4.play .s4-tag{opacity:1}.s4-title{font-family:var(--dis);color:var(--w);text-transform:uppercase;letter-spacing:.04em;font-size:clamp(50px,11vw,155px);line-height:.88}.s4-ln{display:block;overflow:hidden}.s4-ln span{transition:transform .9s cubic-bezier(.16,1,.3,1);display:block;transform:translateY(110%)}#s4.play .s4-ln:first-child span{transition-delay:.28s;transform:translateY(0)}#s4.play .s4-ln:nth-child(2) span{color:var(--w2);transition-delay:.48s;transform:translateY(0)}.s4-sep{opacity:0;background:linear-gradient(#f0ede866,#0000);width:1px;height:44px;margin:26px auto;transition:opacity .5s .95s}#s4.play .s4-sep{opacity:1}.s4-desc{font-family:var(--body);color:var(--w3);letter-spacing:.06em;opacity:0;max-width:460px;font-size:clamp(12px,1.3vw,16px);font-style:italic;font-weight:300;line-height:1.85;transition:opacity .8s 1.05s}#s4.play .s4-desc{opacity:1}.s4-tags{opacity:0;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:28px;transition:opacity .7s 1.3s;display:flex}#s4.play .s4-tags{opacity:1}.s4t{font-family:var(--mono);letter-spacing:.2em;color:var(--w3);text-transform:uppercase;border:1px solid #f0ede829;padding:5px 12px;font-size:9px}#s5{background:#040404;flex-direction:column;align-items:flex-start;gap:0;padding:0 8vw}.s5-head{font-family:var(--mono);letter-spacing:.38em;color:#f0ede847;text-transform:uppercase;opacity:0;margin-bottom:28px;font-size:9px;transition:opacity .4s 50ms}#s5.play .s5-head{opacity:1}.sk-row{opacity:0;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:baseline;width:100%;padding:14px 0;transition:opacity .4s,transform .4s;display:flex;transform:translate(18px)}#s5.play .sk-row:nth-child(2){opacity:1;transition-delay:.1s;transform:translate(0)}#s5.play .sk-row:nth-child(3){opacity:1;transition-delay:.2s;transform:translate(0)}#s5.play .sk-row:nth-child(4){opacity:1;transition-delay:.3s;transform:translate(0)}#s5.play .sk-row:nth-child(5){opacity:1;transition-delay:.4s;transform:translate(0)}#s5.play .sk-row:nth-child(6){opacity:1;transition-delay:.5s;transform:translate(0)}#s5.play .sk-row:nth-child(7){opacity:1;transition-delay:.6s;transform:translate(0)}#s5.play .sk-row:nth-child(8){opacity:1;transition-delay:.7s;transform:translate(0)}.sk-name{font-family:var(--dis);color:var(--w);text-transform:uppercase;letter-spacing:.03em;font-size:clamp(22px,3.8vw,54px)}.sk-cat{font-family:var(--mono);letter-spacing:.2em;color:var(--w3);font-size:9px}#s6{text-align:center;background:#000;flex-direction:column;align-items:center}.s6-msg{font-family:var(--dis);color:#f0ede866;text-transform:uppercase;letter-spacing:.22em;opacity:0;font-size:clamp(20px,3.8vw,50px);transition:opacity .9s .2s}#s6.play .s6-msg{opacity:1}.s6-arrow{font-family:var(--mono);letter-spacing:.3em;color:var(--w2);opacity:0;margin-top:30px;font-size:11px;transition:opacity .6s .65s;animation:1.7s ease-in-out infinite ab}#s6.play .s6-arrow{opacity:1}@keyframes ab{0%,to{transform:translateY(0)}50%{transform:translateY(7px)}}#portfolio{background:var(--bg);position:relative}.psec{padding:96px 0}.psec-inner{max-width:1080px;margin:0 auto;padding:0 56px}.sec-eyebrow{font-family:var(--mono);letter-spacing:.36em;color:var(--w3);text-transform:uppercase;align-items:center;gap:12px;margin-bottom:10px;font-size:9px;display:flex}.sec-eyebrow:before{content:"";background:var(--w3);width:26px;height:1px}.sec-title{font-family:var(--dis);color:var(--w);text-transform:uppercase;letter-spacing:.03em;margin-bottom:50px;font-size:clamp(36px,5.5vw,68px);line-height:1}.sec-title em{color:var(--w2);font-style:normal}.rv{opacity:0;transition:opacity .7s,transform .7s;transform:translateY(24px)}.rv.vis{opacity:1;transform:translateY(0)}#about{background:var(--bg);border-bottom:1px solid var(--bdr)}.about-grid{grid-template-columns:1.1fr .9fr;align-items:start;gap:60px;display:grid}.about-text{color:#f0ede8a6;font-size:15px;font-weight:300;line-height:1.88}.about-text p+p{margin-top:18px}.about-stats{grid-template-columns:1fr 1fr;gap:2px;display:grid}.astat{background:var(--bg2);border:1px solid var(--bdr);padding:22px 18px;transition:border-color .3s;position:relative;overflow:hidden}.astat:hover{border-color:var(--bdr2)}.astat:before{content:"";background:var(--w2);transform-origin:0;height:1px;transition:transform .4s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.astat:hover:before{transform:scaleX(1)}.astat-n{font-family:var(--dis);color:var(--w);font-size:44px;line-height:1;display:block}.astat-l{font-family:var(--mono);letter-spacing:.2em;color:var(--w3);text-transform:uppercase;margin-top:6px;font-size:9px}#experience{background:var(--bg2);border-bottom:1px solid var(--bdr)}.timeline{padding-left:36px;position:relative}.timeline:before{content:"";background:linear-gradient(180deg,var(--w2),transparent);width:1px;position:absolute;top:6px;bottom:6px;left:0}.titem{opacity:0;padding:0 0 48px 44px;transition:opacity .6s,transform .6s;position:relative;transform:translate(-16px)}.titem.vis{opacity:1;transform:translate(0)}.titem:before{content:"";background:var(--w2);border:2px solid var(--bg2);width:8px;height:8px;position:absolute;top:10px;left:-3px;transform:rotate(45deg)}.t-date{font-family:var(--mono);letter-spacing:.22em;color:var(--w3);text-transform:uppercase;margin-bottom:7px;font-size:9px}.t-role{font-family:var(--dis);color:var(--w);text-transform:uppercase;letter-spacing:.04em;font-size:clamp(20px,2.6vw,32px);line-height:1.1}.t-org{font-family:var(--mono);letter-spacing:.14em;color:var(--w3);text-transform:uppercase;margin:6px 0 14px;font-size:11px}.t-bullets{flex-direction:column;gap:7px;list-style:none;display:flex}.t-bullets li{color:#f0ede88c;padding-left:18px;font-size:13px;font-weight:300;line-height:1.65;position:relative}.t-bullets li:before{content:"/";color:var(--w3);font-size:12px;position:absolute;left:0}#projects{background:var(--bg);border-bottom:1px solid var(--bdr)}.proj-grid{grid-template-columns:1fr 1fr;gap:2px;display:grid}.pcard{background:var(--bg2);border:1px solid var(--bdr);padding:28px 24px;transition:border-color .3s,background .3s;position:relative;overflow:hidden}.pcard:hover{border-color:var(--bdr2);background:var(--bg3)}.pcard.feat{background:var(--bg3);border-color:#f0ede82e;grid-column:span 2}.pcard.feat:before{content:"";background:linear-gradient(90deg,var(--w2),transparent);height:1px;position:absolute;top:0;left:0;right:0}.ptag{font-family:var(--mono);letter-spacing:.22em;color:var(--w3);text-transform:uppercase;border:1px solid #f0ede829;margin-bottom:14px;padding:3px 10px;font-size:8px;display:inline-block}.pname{font-family:var(--dis);color:var(--w);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:clamp(22px,2.8vw,38px);line-height:1}.feat .pname{font-size:clamp(30px,4.2vw,54px)}.psub{font-family:var(--mono);letter-spacing:.14em;color:var(--w3);text-transform:uppercase;margin-bottom:14px;font-size:10px}.pdesc{color:#f0ede88c;margin-bottom:16px;font-size:13px;font-weight:300;line-height:1.72}.ptech{flex-wrap:wrap;gap:7px;margin-top:14px;display:flex}.pill{font-family:var(--mono);letter-spacing:.1em;color:var(--w3);border:1px solid var(--bdr);text-transform:uppercase;background:#ffffff05;padding:3px 10px;font-size:9px;transition:color .2s,border-color .2s}.pcard:hover .pill{color:var(--w2);border-color:var(--bdr2)}.feat-inner{grid-template-columns:1fr 1fr;align-items:start;gap:36px;display:grid}.g-metrics{grid-template-columns:1fr 1fr;gap:1px;margin-top:16px;display:grid}.gm{border:1px solid var(--bdr);background:#ffffff08;padding:14px}.gmv{font-family:var(--dis);color:var(--w);font-size:26px}.gml{font-family:var(--mono);letter-spacing:.18em;color:var(--w3);text-transform:uppercase;margin-top:3px;font-size:8px}.g-status{flex-direction:column;gap:8px;margin-top:16px;display:flex}.gsr{border:1px solid var(--bdr);font-family:var(--mono);background:#ffffff05;justify-content:space-between;align-items:center;padding:9px 14px;font-size:10px;display:flex}.gsrk{color:var(--w3);letter-spacing:.1em;text-transform:uppercase}.gsrv{color:var(--w2);letter-spacing:.1em}.gsrv.dim{color:var(--w3)}#skills{background:var(--bg2);border-bottom:1px solid var(--bdr)}.skills-grid{grid-template-columns:repeat(3,1fr);gap:2px;display:grid}.scat{background:var(--bg);border:1px solid var(--bdr);padding:26px 22px}.scat-h{font-family:var(--mono);letter-spacing:.3em;color:var(--w3);text-transform:uppercase;border-bottom:1px solid var(--bdr);margin-bottom:18px;padding-bottom:12px;font-size:9px}.skill-list{flex-direction:column;gap:11px;list-style:none;display:flex}.ski{flex-direction:column;gap:5px;display:flex}.ski-top{font-family:var(--mono);letter-spacing:.08em;color:#f0ede899;justify-content:space-between;font-size:10px;display:flex}.ski-track{background:#f0ede814;height:1px;position:relative}.ski-fill{background:var(--w2);width:0;transition:width 1.2s;position:absolute;top:0;bottom:0;left:0}.ski.vis .ski-fill{width:var(--w)}#contact{background:var(--bg)}.ct-grid{grid-template-columns:1fr 1fr;align-items:center;gap:72px;display:grid}.ct-head{font-family:var(--dis);color:var(--w);text-transform:uppercase;letter-spacing:.02em;font-size:clamp(36px,6vw,80px);line-height:.95}.ct-head em{color:var(--w2);font-style:normal}.ct-blurb{font-family:var(--mono);letter-spacing:.18em;color:var(--w3);text-transform:uppercase;margin-top:22px;font-size:10px;line-height:2.1}.ct-links{flex-direction:column;gap:10px;display:flex}.ct-link{background:var(--bg2);border:1px solid var(--bdr);font-family:var(--mono);letter-spacing:.12em;color:#f0ede8a6;align-items:center;gap:14px;padding:14px 18px;font-size:11px;text-decoration:none;transition:all .2s;display:flex}.ct-link:hover{border-color:var(--bdr2);color:var(--w);transform:translate(4px)}.ct-link-lbl{letter-spacing:.28em;color:var(--w3);text-transform:uppercase;margin-bottom:2px;font-size:8px;display:block}footer{background:var(--bg);border-top:1px solid var(--bdr);justify-content:space-between;align-items:center;padding:20px 56px;display:flex}footer span{font-family:var(--mono);letter-spacing:.22em;color:var(--w3);text-transform:uppercase;font-size:8px}.photo-wrap{aspect-ratio:1;width:100%;max-width:340px;position:relative;overflow:hidden}.photo-wrap img{object-fit:cover;object-position:center top;filter:grayscale();width:100%;height:100%;transition:filter .5s;display:block}.photo-wrap:hover img{filter:grayscale(60%)}.photo-wrap:after{content:"";border:1px solid var(--bdr2);pointer-events:none;position:absolute;inset:0}@media (width<=760px){.about-grid,.proj-grid,.feat-inner,.ct-grid,.skills-grid{grid-template-columns:1fr}.photo-wrap{max-width:200px;margin:0 auto}.pcard.feat{grid-column:span 1}#nav{padding:14px 20px}.nav-links{display:none}.psec-inner{padding:0 24px}}
