@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap";*{box-sizing:border-box;margin:0;padding:0}:root{--bg-color:#f5f5f5;--text-color:#2a2a2a;--text-muted:#444;--divider-color:#d0d0d0;--accent-color:#2a2a2a;--accent-warm:#ff6b35;--accent-cool:#3c8cff;--overlay-subtle:#00000005;--overlay-hover:#00000008;--overlay-light:#00000005;--overlay-border:#0000000f;--glow-warm:#ff6b3526;--glow-cool:#3c8cff1a;--progress-glow:#ff6b3566;--modal-overlay:#f5f5f5f2;--modal-shadow:#0000001a;--highlight-bg:#d0d0d008;--contact-border:#f5f5f51f;--contact-border-hover:#f5f5f5cc;--contact-cta-border:#f5f5f54d;--contact-footer-text:#f5f5f559;--contact-time-text:#f5f5f580;--logo-bg:white;--logo-filter:grayscale(1) contrast(1.2);--status-color:#4ade80;--hero-title-size:clamp(4rem, 12vw, 11rem);--section-title-size:clamp(2.5rem, 6vw, 4rem);--stat-size:clamp(4rem, 10vw, 8rem);--quote-size:clamp(2.5rem, 5.5vw, 4rem);--ease-out-expo:cubic-bezier(.16, 1, .3, 1);--container-width:1400px;--section-gap:clamp(10rem, 18vw, 16rem);color:var(--text-color);background-color:var(--bg-color);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Space Grotesk,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.6}body{min-height:100vh;margin:0;transition:background-color .5s,color .5s}#root{min-height:100vh}a{color:var(--text-color);text-decoration:none;transition:all .3s;position:relative}a:hover{color:var(--accent-color);opacity:.7}::selection{background-color:var(--text-color);color:var(--bg-color)}html.lenis{scrollbar-width:none}html.lenis::-webkit-scrollbar{display:none}:root[data-theme=dark]{--bg-color:#1a1a1a;--text-color:#e8e8e8;--text-muted:#a0a0a0;--divider-color:#333;--accent-color:#e8e8e8;--accent-warm:#ff7a4a;--accent-cool:#4a9bff;--overlay-subtle:#ffffff08;--overlay-hover:#ffffff0d;--overlay-light:#ffffff08;--overlay-border:#ffffff14;--glow-warm:#ffffff12;--glow-cool:#ffffff08;--progress-glow:#ff7a4a80;--modal-overlay:#1a1a1af2;--modal-shadow:#0006;--highlight-bg:#ffffff08;--contact-border:#2a2a2a4d;--contact-border-hover:#2a2a2acc;--contact-cta-border:#2a2a2a66;--contact-footer-text:#2a2a2a99;--contact-time-text:#2a2a2ab3;--logo-bg:#2a2a2a;--logo-filter:grayscale(1) contrast(1.2) invert(1);--status-color:#4ade80}.portfolio{width:100%;min-height:100vh;overflow-x:clip}.loader-overlay{background:var(--text-color);z-index:9999;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loader-line{background:var(--bg-color);transform-origin:top;width:2px;height:60px}.fixed-nav{z-index:90;mix-blend-mode:difference;pointer-events:auto;position:fixed;top:2rem;left:2rem}.nav-initials{color:#fff;letter-spacing:.1em;font-size:1.2rem;font-weight:500}.custom-scrollbar-track{z-index:100;cursor:pointer;justify-content:flex-end;width:12px;height:100vh;display:flex;position:fixed;top:0;right:0}.custom-scrollbar-thumb{background:var(--text-muted);opacity:0;border-radius:3px;width:3px;height:8%;transition:opacity .3s,width .2s;position:absolute;right:0}.custom-scrollbar-track.visible .custom-scrollbar-thumb{opacity:1}.custom-scrollbar-track:hover .custom-scrollbar-thumb{opacity:1;width:5px}.weather-progress{z-index:90;pointer-events:auto;cursor:pointer;-webkit-tap-highlight-color:transparent;color:#fff;mix-blend-mode:difference;background:0 0;border:none;outline:none;padding:0;position:fixed;bottom:2rem;right:2rem}.weather-rain-drop{animation:.8s ease-in infinite rain-fall}.weather-star{transform-origin:50%;transform-box:fill-box;animation:2s ease-in-out infinite star-twinkle}@keyframes rain-fall{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(8px)}}@media (width<=768px){.weather-progress{bottom:1rem;right:1rem}.weather-progress svg{width:40px;height:40px}}.hero{flex-direction:column;justify-content:center;min-height:100vh;padding:0 3rem;display:flex;position:relative;overflow:hidden}.hero-glow{background:radial-gradient(circle, var(--glow-warm) 0%, var(--glow-cool) 40%, transparent 70%);pointer-events:none;filter:blur(60px);z-index:0;will-change:transform;border-radius:50%;width:900px;height:900px;position:absolute;transform:translate(-50%,-50%)}:root[data-theme=dark] .hero-glow{filter:blur(40px);width:500px;height:500px}.hero-top-bar{z-index:2;justify-content:space-between;align-items:center;display:flex;position:absolute;top:2.5rem;left:3rem;right:3rem}.hero-role-label{letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);font-size:.8rem;font-weight:400}.hero-status{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);align-items:center;gap:.5rem;font-size:.8rem;font-weight:400;display:flex}.hero-status-dot{background:var(--status-color);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse-dot}.hero-name-block{z-index:1;max-width:var(--container-width);width:100%;position:relative}.hero-name{font-size:var(--hero-title-size);letter-spacing:-.05em;font-weight:200;line-height:.9;display:flex}.hero-name-outline{-webkit-text-stroke:1.5px var(--text-color);color:#0000}.hero-name-solid{color:var(--text-color);padding-left:clamp(2rem,8vw,7rem)}.hero-accent-line{background:var(--divider-color);transform-origin:0;height:1px;margin:clamp(.75rem,1.5vw,1.5rem) 0}.hero-aside{z-index:1;max-width:420px;margin-top:clamp(2rem,4vw,3.5rem);margin-left:auto;padding-right:1rem;position:relative}.hero-description{color:var(--text-muted);font-size:clamp(1rem,1.8vw,1.15rem);font-weight:300;line-height:1.8}.scroll-indicator{z-index:2;flex-direction:column;align-items:center;gap:.75rem;display:flex;position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%)}.scroll-text{text-transform:uppercase;letter-spacing:.25em;color:var(--text-muted);font-size:.7rem;font-weight:400}.scroll-line{background:var(--text-muted);opacity:.5;width:1px;height:40px}.char-reveal{flex-wrap:wrap;display:flex;overflow:visible}.char-mask{padding-bottom:.15em;display:inline-block;overflow:hidden}.char-inner{display:inline-block}.text-reveal{flex-wrap:wrap;gap:0 .35em;display:flex}.tr-word{display:inline-block}.section-label-track{pointer-events:none;z-index:10;width:0;position:absolute;top:0;bottom:0;left:0}.section-label-sticky{height:0;position:sticky;top:50vh;overflow:visible}.section-label-anchor{transform-origin:0 0;position:absolute;left:1.25rem;transform:rotate(-90deg)translate(-50%)}.section-label-inner{white-space:nowrap;align-items:center;gap:.75rem;display:flex}.section-label-number{letter-spacing:.15em;color:var(--text-muted);font-size:.75rem;font-weight:500}.section-label-text{text-transform:uppercase;letter-spacing:.2em;color:var(--text-muted);font-size:.7rem;font-weight:400}.stats-section,.about-section,.experience-section,.projects-split-container,.philosophy-section,.skills-section,.photos-parallax-section{background:var(--bg-color);isolation:isolate}.stats-section{margin:var(--section-gap) 0;position:relative}.stats-band{border-top:1px solid var(--divider-color);border-bottom:1px solid var(--divider-color);z-index:1;position:relative}.stats-band-inner{max-width:var(--container-width);margin:0 auto;display:flex}.stat-cell{flex:1;padding:3rem 3rem 2.5rem;position:relative}.stat-cell:not(:last-child):after{content:"";background:var(--divider-color);width:1px;position:absolute;top:2rem;bottom:2rem;right:0}.stat-index{letter-spacing:.1em;opacity:.2;margin-bottom:1rem;font-size:.7rem;font-weight:500;display:block}.stat-number{font-size:var(--stat-size);color:var(--text-color);margin-bottom:1rem;font-weight:200;line-height:1}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;font-size:.8rem;font-weight:400}.about-section{max-width:var(--container-width);margin:var(--section-gap) auto;padding:0 3rem;position:relative}.about-accent-line{background:var(--accent-warm);z-index:0;width:2px;position:absolute;top:0;left:3rem}.about-text-col{z-index:1;flex-direction:column;gap:3rem;max-width:900px;margin-left:auto;display:flex;position:relative}.about-text{color:var(--text-color);font-size:clamp(1.3rem,3vw,2rem);font-weight:400;line-height:1.7}.experience-section{max-width:var(--container-width);margin:var(--section-gap) auto;padding:0 3rem;position:relative}.timeline{z-index:1;flex-direction:column;gap:1.25rem;margin-top:2rem;display:flex;position:relative}.experience-card-wrap{position:relative}.exp-block{cursor:pointer;transition:all .4s var(--ease-out-expo);border-radius:2px;padding:2.5rem 3rem;position:relative;overflow:hidden}.exp-block:before{content:"";background:var(--overlay-subtle);opacity:1;border-radius:inherit;transition:opacity .4s;position:absolute;inset:0}.exp-block:hover:before{opacity:0;background:0 0}.exp-block:hover{background:var(--overlay-hover)}.exp-block-accent{width:3px;height:0;transition:height .5s var(--ease-out-expo);border-radius:0 2px 2px 0;position:absolute;top:0;left:0}.exp-block:hover .exp-block-accent,.exp-block.is-expanded .exp-block-accent{height:100%}.exp-block .exp-block-accent{background:var(--text-color)}.exp-block-head{justify-content:space-between;align-items:flex-start;gap:2rem;display:flex;position:relative}.exp-block-left{flex:1;min-width:0}.exp-block-company{letter-spacing:-.03em;align-items:center;gap:1rem;margin:0;font-size:clamp(1.8rem,4vw,3rem);font-weight:400;line-height:1.15;display:flex}.exp-block-logo{background:var(--logo-bg);vertical-align:middle;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:inline-flex;overflow:hidden}.exp-block-logo img{object-fit:contain;width:100%;height:100%;filter:var(--logo-filter);padding:3px}.exp-block-meta{flex-wrap:wrap;align-items:center;gap:.6rem;margin-top:.6rem;display:flex}.exp-block-role{color:var(--text-muted);font-size:1rem;font-weight:300}.exp-block-dot{color:var(--divider-color);font-size:.8rem}.exp-block-date{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;opacity:.7;font-size:.8rem;font-weight:400}.exp-block-toggle{border:1px solid var(--divider-color);width:40px;height:40px;color:var(--text-color);transition:all .35s var(--ease-out-expo);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:.5rem;display:flex}.exp-block:hover .exp-block-toggle{border-color:var(--text-color)}.exp-block.is-expanded .exp-block-toggle{background:var(--accent-warm);border-color:var(--accent-warm);color:#fff}.experience-expandable{grid-template-rows:0fr;transition:grid-template-rows .5s;display:grid}.experience-expandable.is-open{grid-template-rows:1fr}.experience-expandable-inner{min-height:0;overflow:hidden}.exp-block-body{max-width:800px;padding-top:2rem}.exp-block-description{color:var(--text-muted);margin:0 0 2rem;font-size:1rem;font-weight:300;line-height:1.75}.exp-block-achievements{grid-template-columns:repeat(2,1fr);gap:1.5rem;display:grid}.exp-achieve{padding-left:2.5rem;position:relative}.exp-achieve-num{opacity:.2;letter-spacing:.05em;font-size:.75rem;font-weight:500;position:absolute;top:.15rem;left:0}.exp-achieve p{color:var(--text-muted);margin:0;font-size:.95rem;font-weight:300;line-height:1.65}.projects-mobile{max-width:var(--container-width);margin:var(--section-gap) auto;padding:0 3rem;display:none;position:relative}.projects-mobile-grid{flex-direction:column;gap:4rem;margin-top:2rem;display:flex}.projects-hscroll-container{height:200vh;position:relative}.projects-hscroll-sticky{flex-direction:column;justify-content:center;height:100vh;padding:0 3rem;display:flex;position:sticky;top:0;overflow:hidden}.projects-hscroll-track{gap:2rem;width:max-content;display:flex}.hscroll-card{cursor:pointer;flex-shrink:0;position:relative}.project-card-trigger{display:inline-block}.view-details{color:var(--text-color);text-transform:uppercase;letter-spacing:.1em;opacity:.4;transition:all .4s var(--ease-out-expo);cursor:pointer;font-size:.85rem;font-weight:400;display:inline-block}.hscroll-card:hover .view-details{opacity:1;transform:translate(5px)}.hscroll-card--split{border:1px solid var(--divider-color);border-radius:2px;flex-direction:row;width:min(70vw,800px);min-height:400px;transition:background .4s;display:flex;overflow:hidden}.hscroll-card--split:hover{background:var(--overlay-hover)}.hscroll-card--split:before{content:"";background:var(--card-accent);transform-origin:0;height:2px;transition:transform .6s var(--ease-out-expo);z-index:2;position:absolute;top:-1px;left:-1px;right:-1px;transform:scaleX(0)}.hscroll-card--split:hover:before{transform:scaleX(1)}.split-left{flex-shrink:0;justify-content:center;align-items:center;width:38%;display:flex;position:relative;overflow:hidden}.split-number{-webkit-text-stroke:1.5px var(--text-color);-webkit-text-fill-color:transparent;opacity:.07;letter-spacing:-.04em;-webkit-user-select:none;user-select:none;transition:opacity .6s var(--ease-out-expo), transform .6s var(--ease-out-expo);font-size:clamp(8rem,14vw,14rem);font-weight:200;line-height:1}.hscroll-card--split:hover .split-number{opacity:.15;transform:translate(-4px,-3px)}.split-divider{background:var(--divider-color);flex-shrink:0;align-self:stretch;width:1px;transition:background .4s}.hscroll-card--split:hover .split-divider{background:var(--card-accent)}.split-right{flex-direction:column;flex:1;justify-content:center;min-width:0;padding:2.5rem 3rem;display:flex}.split-tags{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.split-tags span{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);opacity:.6;font-size:.75rem;font-weight:500}.split-right h3{letter-spacing:-.02em;margin-bottom:1rem;font-size:clamp(1.5rem,3vw,2.2rem);font-weight:400;line-height:1.2}.split-desc{color:var(--text-muted);margin-bottom:1.5rem;font-size:1rem;font-weight:300;line-height:1.7}.hscroll-card--tall{border:1px solid var(--divider-color);border-radius:2px;flex-direction:column;width:min(38vw,400px);min-height:520px;padding:2.5rem 2.5rem 2rem;transition:background .4s;display:flex;overflow:hidden}.hscroll-card--tall:hover{background:var(--overlay-hover)}.hscroll-card--tall:before{content:"";background:var(--card-accent);transform-origin:top;width:3px;transition:transform .5s var(--ease-out-expo);z-index:2;position:absolute;top:-1px;bottom:-1px;left:-1px;transform:scaleY(0)}.hscroll-card--tall:hover:before{transform:scaleY(1)}.tall-number{-webkit-text-stroke:1.5px var(--text-color);-webkit-text-fill-color:transparent;opacity:.1;letter-spacing:-.04em;-webkit-user-select:none;user-select:none;transition:opacity .5s var(--ease-out-expo);font-size:clamp(4rem,7vw,5.5rem);font-weight:200;line-height:1}.hscroll-card--tall:hover .tall-number{opacity:.2}.tall-rule{background:var(--divider-color);width:3rem;height:1px;transition:width .5s var(--ease-out-expo), background .4s ease;margin:1.5rem 0}.hscroll-card--tall:hover .tall-rule{background:var(--card-accent);width:5rem}.tall-title{letter-spacing:-.02em;margin-bottom:1rem;font-size:clamp(1.3rem,2.5vw,1.8rem);font-weight:400;line-height:1.25}.tall-desc{color:var(--text-muted);margin-bottom:1.5rem;font-size:.95rem;font-weight:300;line-height:1.7}.tall-tags{flex-direction:column;gap:.4rem;margin-bottom:1.5rem;display:flex}.tall-tags span{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);opacity:.5;font-size:.75rem;font-weight:400}.tall-bottom{margin-top:auto}.hscroll-card--poster{border:1px solid var(--divider-color);border-radius:2px;flex-direction:column;justify-content:flex-end;width:min(70vw,800px);min-height:420px;padding:3rem;transition:background .4s;display:flex;overflow:hidden}.hscroll-card--poster:hover{background:var(--overlay-hover)}.hscroll-card--poster:before{content:"";background:var(--card-accent);transform-origin:0;height:2px;transition:transform .6s var(--ease-out-expo);z-index:2;position:absolute;top:-1px;left:-1px;right:-1px;transform:scaleX(0)}.hscroll-card--poster:hover:before{transform:scaleX(1)}.poster-number{-webkit-text-stroke:1.5px var(--text-color);-webkit-text-fill-color:transparent;opacity:.05;letter-spacing:-.04em;-webkit-user-select:none;user-select:none;pointer-events:none;transition:opacity .6s var(--ease-out-expo), transform .6s var(--ease-out-expo);font-size:clamp(14rem,25vw,22rem);font-weight:200;line-height:1;position:absolute;top:-.15em;right:-.02em}.hscroll-card--poster:hover .poster-number{opacity:.1;transform:translate(-6px,4px)}.poster-content{z-index:1;position:relative}.poster-tags{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.poster-tags span{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);opacity:.5;font-size:.75rem;font-weight:500}.poster-content h3{letter-spacing:-.02em;margin-bottom:1rem;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:400;line-height:1.15}.poster-desc{color:var(--text-muted);max-width:550px;margin-bottom:1.5rem;font-size:1.05rem;font-weight:300;line-height:1.7}.hscroll-progress{align-items:center;gap:1.5rem;max-width:300px;margin-top:2rem;display:flex}.hscroll-progress-num{color:var(--text-muted);letter-spacing:.05em;font-size:.85rem;font-weight:400}.hscroll-progress-bar{background:var(--divider-color);flex:1;height:1px;position:relative}.hscroll-progress-fill{background:var(--text-color);height:100%;position:absolute;top:0;left:0}.projects-reveal-container{height:500vh;position:relative}.projects-reveal-sticky{height:100vh;position:sticky;top:0;overflow:hidden}.projects-reveal-label{z-index:100;pointer-events:none;position:absolute;top:0;left:3rem}.reveal-slide{background:var(--bg-color);will-change:clip-path, transform;flex-direction:column;justify-content:center;align-items:center;padding:3rem;display:flex;position:absolute;inset:0}.reveal-number{-webkit-text-stroke:1.5px var(--text-color);-webkit-text-fill-color:transparent;opacity:.05;letter-spacing:-.04em;-webkit-user-select:none;user-select:none;pointer-events:none;font-size:clamp(18rem,35vw,30rem);font-weight:200;line-height:1;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.reveal-content{z-index:1;text-align:center;max-width:700px;position:relative}.reveal-tags{justify-content:center;gap:1.5rem;margin-bottom:2rem;display:flex}.reveal-tags span{text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);opacity:.5;font-size:.75rem;font-weight:500}.reveal-title{letter-spacing:-.03em;margin-bottom:1.5rem;font-size:clamp(2.5rem,6vw,5rem);font-weight:300;line-height:1.1}.reveal-desc{color:var(--text-muted);margin-bottom:2rem;font-size:clamp(1rem,1.5vw,1.2rem);font-weight:300;line-height:1.8}.projects-deck-container{height:400vh;position:relative}.projects-deck-sticky{justify-content:center;align-items:center;height:100vh;padding:3rem;display:flex;position:sticky;top:0;overflow:hidden}.projects-deck-label{z-index:100;pointer-events:none;position:absolute;top:0;left:3rem}.projects-deck-stack{width:min(85vw,1100px);height:min(65vh,550px);position:relative}.deck-card{will-change:transform, opacity;transform-origin:bottom;background:var(--bg-color);position:absolute;inset:0}.deck-card-inner{border:1px solid var(--divider-color);background:var(--bg-color);border-radius:2px;flex-direction:row;width:100%;height:100%;display:flex;overflow:hidden}.deck-left{flex-shrink:0;justify-content:center;align-items:center;width:35%;display:flex;position:relative}.deck-number{-webkit-text-stroke:1.5px var(--text-color);-webkit-text-fill-color:transparent;opacity:.08;letter-spacing:-.04em;-webkit-user-select:none;user-select:none;font-size:clamp(7rem,12vw,12rem);font-weight:200;line-height:1}.deck-accent{opacity:.4;height:2px;position:absolute;bottom:0;left:2rem;right:2rem}.deck-divider{background:var(--divider-color);flex-shrink:0;align-self:stretch;width:1px}.deck-right{flex-direction:column;flex:1;justify-content:center;min-width:0;padding:3rem;display:flex}.deck-tags{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.deck-tags span{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);opacity:.5;font-size:.75rem;font-weight:500}.deck-title{letter-spacing:-.02em;margin-bottom:1.2rem;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:400;line-height:1.15}.deck-desc{color:var(--text-muted);max-width:500px;margin-bottom:1.5rem;font-size:1.05rem;font-weight:300;line-height:1.7}.projects-split-container{height:280vh;position:relative}.projects-split-sticky{align-items:center;height:100vh;padding:0 3rem;display:flex;position:sticky;top:0;overflow:hidden}.split-columns{width:100%;max-width:var(--container-width);align-items:center;gap:0;height:100%;margin:0 auto;display:flex;position:relative}.split-col{will-change:transform}.split-col-left{flex-direction:column;gap:8rem;width:45%;padding-right:4rem;display:flex}.split-col-right{flex-direction:column;gap:8rem;width:55%;padding-left:4rem;display:flex}.split-col-divider-wrap{align-items:center;width:1px;display:flex;position:absolute;top:10%;bottom:10%;left:45%}.split-col-divider{background:var(--divider-color);transform-origin:50%;width:1px;height:100%}.split-col-item-left{position:relative}.split-col-number{-webkit-text-stroke:1.5px var(--text-color);-webkit-text-fill-color:transparent;opacity:.08;letter-spacing:-.04em;margin-bottom:1rem;font-size:clamp(5rem,10vw,8rem);font-weight:200;line-height:1;display:block}.split-col-title{letter-spacing:-.02em;font-size:clamp(1.8rem,3.5vw,3rem);font-weight:400;line-height:1.15}.split-col-item-right{padding-left:1.5rem;position:relative}.split-col-accent{background:var(--accent-warm);border-radius:2px;width:3px;height:100%;position:absolute;top:0;left:0}.split-col-desc{color:var(--text-muted);margin-bottom:1.5rem;font-size:1.1rem;font-weight:300;line-height:1.8}.split-col-tags{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.split-col-tags span{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);opacity:.5;font-size:.75rem;font-weight:500}.projects-index-section{max-width:var(--container-width);margin:var(--section-gap) auto;padding:0 3rem;position:relative}.projects-index-list{z-index:1;margin-top:2rem;position:relative}.index-item{border-bottom:1px solid var(--divider-color);position:relative;overflow:hidden}.index-item:first-child{border-top:1px solid var(--divider-color)}.index-header{align-items:baseline;gap:2rem;display:flex;position:relative}.index-number{-webkit-text-stroke:1px var(--text-color);-webkit-text-fill-color:transparent;letter-spacing:-.04em;-webkit-user-select:none;user-select:none;transform-origin:0;flex-shrink:0;font-size:clamp(3rem,5vw,4.5rem);font-weight:200;line-height:1;display:inline-block}.index-title{letter-spacing:-.02em;font-size:clamp(1.5rem,3vw,2.5rem);font-weight:400;line-height:1.2}.index-accent{background:var(--accent-warm);border-radius:1px;height:2px;margin:1.5rem 0}.index-details{max-width:700px;padding-bottom:1rem;padding-left:clamp(5rem,8vw,7.5rem)}.index-desc{color:var(--text-muted);margin-bottom:1.5rem;font-size:1.05rem;font-weight:300;line-height:1.7}.index-tags{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.index-tags span{text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);opacity:.5;font-size:.75rem;font-weight:500}.project-modal-overlay{background:var(--modal-overlay);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0;overflow-y:auto}.project-modal{background:var(--bg-color);border:1px solid var(--divider-color);overscroll-behavior:contain;width:100%;max-width:900px;max-height:90vh;box-shadow:0 20px 60px var(--modal-shadow);border-radius:8px;position:relative;overflow-y:auto}.modal-close{border:1px solid var(--divider-color);background:var(--bg-color);width:40px;height:40px;color:var(--text-color);cursor:pointer;z-index:10;border-radius:50%;font-size:2rem;line-height:1;transition:all .3s;position:absolute;top:2rem;right:2rem}.modal-close:hover{background:var(--text-color);color:var(--bg-color);transform:rotate(90deg)}.modal-content{padding:4rem}.modal-header{margin-bottom:3rem}.modal-number{color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;margin-bottom:1rem;font-size:1rem;font-weight:300;display:block}.modal-header h2{letter-spacing:-.02em;margin-bottom:1.5rem;font-size:clamp(2rem,5vw,3.5rem);font-weight:300;line-height:1.1}.modal-description{color:var(--text-muted);font-size:1.3rem;line-height:1.7}.modal-meta{border-top:1px solid var(--divider-color);border-bottom:1px solid var(--divider-color);grid-template-columns:repeat(3,1fr);gap:2rem;margin-bottom:3rem;padding:2rem 0;display:grid}.meta-item{flex-direction:column;gap:.5rem;display:flex}.meta-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:.85rem;font-weight:300}.meta-value{color:var(--text-color);font-size:1.1rem;font-weight:400}.modal-highlights h3{margin-bottom:2rem;font-size:1.5rem;font-weight:400}.highlights-grid{gap:1.5rem;display:grid}.highlight-card{border:1px solid var(--divider-color);background:var(--highlight-bg);border-radius:4px;gap:1rem;padding:1.5rem;display:flex}.highlight-icon{background:var(--text-color);width:24px;height:24px;color:var(--bg-color);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:600;display:flex}.highlight-card p{color:var(--text-muted);margin:0;font-size:1.05rem;line-height:1.7}.philosophy-section{max-width:var(--container-width);margin:var(--section-gap) auto;padding:0 3rem;position:relative}.philosophy-inner{z-index:1;max-width:900px;position:relative}.philosophy-rule{background:var(--divider-color);width:100%;height:1px;margin-bottom:3.5rem}.philosophy-quote-block{padding-left:2.5rem;position:relative}.philosophy-accent-bar{background:var(--accent-warm);border-radius:2px;width:3px;position:absolute;top:0;left:0}.philosophy-text{font-size:var(--quote-size);color:var(--text-color);font-weight:300;line-height:1.35}.philosophy-author{color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;text-align:right;margin-top:3rem;font-size:.85rem;font-weight:400}.skills-section{margin:var(--section-gap) 0;padding:4rem 3rem;position:relative}.skills-grid{z-index:1;border-top:1px solid var(--divider-color);border-left:1px solid var(--divider-color);grid-template-columns:repeat(2,1fr);gap:0;display:grid;position:relative}.skill-category{border-right:1px solid var(--divider-color);border-bottom:1px solid var(--divider-color);padding:2.5rem 3rem;transition:background .4s}.skill-category:hover{background:var(--overlay-light)}.skill-category-header{align-items:baseline;gap:1rem;margin-bottom:2rem;display:flex}.skill-category-index{opacity:.15;letter-spacing:-.02em;font-size:clamp(2.5rem,4vw,3.5rem);font-weight:200;line-height:1}.skill-category-label{text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);font-size:.8rem;font-weight:500}.skill-list{flex-direction:column;gap:0;margin:0;padding:0;list-style:none;display:flex}.skill-item{color:var(--text-color);cursor:default;border-bottom:1px solid #0000;align-items:center;gap:.75rem;padding:.7rem 0;font-size:1.05rem;font-weight:300;transition:all .3s;display:flex}.skill-item:not(:last-child){border-bottom-color:var(--overlay-border)}.skill-item svg{opacity:.4;flex-shrink:0;transition:opacity .3s}.skill-item:hover svg{opacity:1}.skill-item:hover{color:var(--text-color);padding-left:.5rem}@media (width<=768px){.skills-section{padding:4rem 1.5rem}.skills-grid{grid-template-columns:1fr}.skill-category{padding:2rem 1.5rem}}.cursor-dot{pointer-events:none;z-index:9998;mix-blend-mode:difference;background:#fff;border-radius:50%;width:8px;height:8px;position:fixed;transform:translate(-50%,-50%)}.cursor-follower{pointer-events:none;z-index:9997;mix-blend-mode:difference;transform-origin:50%;background:0 0;border:1.5px solid #fff;border-radius:50%;width:40px;height:40px;transition:background .25s,border-color .25s;position:fixed;transform:translate(-50%,-50%)}.cursor-follower--text{background:#fff;border-color:#fff}.custom-cursor-active,.custom-cursor-active *{cursor:none!important}@media (hover:none){.cursor-dot,.cursor-follower{display:none!important}}.contact-section{background:var(--text-color);color:var(--bg-color);flex-direction:column;justify-content:space-between;min-height:100vh;padding:8rem 3rem 2rem;display:flex;position:relative}.contact-top{max-width:var(--container-width);justify-content:space-between;align-items:flex-end;gap:3rem;width:100%;margin:0 auto 5rem;display:flex}.contact-heading .contact-title{letter-spacing:-.04em;color:var(--bg-color);font-size:clamp(3rem,8vw,7rem);font-weight:200;line-height:.95}.contact-heading .contact-title-indent{padding-left:clamp(2rem,6vw,5rem)}.contact-heading .char-reveal{color:var(--bg-color)}.contact-cta-area{flex-shrink:0}.cta-circle{border:1px solid var(--contact-cta-border);width:clamp(160px,18vw,220px);height:clamp(160px,18vw,220px);color:var(--bg-color);border-radius:50%;justify-content:center;align-items:center;text-decoration:none;transition:border-color .4s;display:flex;position:relative}.cta-circle:hover{border-color:var(--contact-border-hover);color:var(--bg-color);opacity:1}.cta-circle-text{width:100%;height:100%;animation:12s linear infinite rotateText;position:absolute;inset:0}.cta-circle-text text{fill:var(--bg-color);letter-spacing:2.5px;text-transform:uppercase;font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:500}@keyframes rotateText{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.cta-circle-arrow{transition:transform .4s var(--ease-out-expo);font-size:clamp(2rem,3vw,3rem);font-weight:200;line-height:1}.cta-circle:hover .cta-circle-arrow{transform:translate(3px,-3px)}.contact-links{max-width:var(--container-width);border-top:1px solid var(--contact-border);width:100%;margin:0 auto}.contact-row{border-bottom:1px solid var(--contact-border);color:var(--bg-color);transition:all .4s var(--ease-out-expo);grid-template-columns:3rem 8rem 1fr auto;align-items:center;gap:1.5rem;padding:1.5rem 0;text-decoration:none;display:grid;position:relative}.contact-row:after{content:"";background:var(--bg-color);width:0;height:1px;transition:width .6s var(--ease-out-expo);position:absolute;bottom:-1px;left:0}.contact-row:hover{opacity:1;color:var(--bg-color);padding-left:1rem}.contact-row:hover:after{width:100%}.contact-row-index{opacity:.3;letter-spacing:.05em;font-size:.8rem;font-weight:400}.contact-row-label{text-transform:uppercase;letter-spacing:.15em;opacity:.5;font-size:.8rem;font-weight:500}.contact-row-value{font-size:clamp(1.1rem,2vw,1.4rem);font-weight:300}.contact-row-arrow{opacity:.3;transition:all .4s var(--ease-out-expo)}.contact-row:hover .contact-row-arrow{opacity:1;transform:translate(3px,-3px)}.contact-footer{max-width:var(--container-width);justify-content:space-between;align-items:center;width:100%;margin:auto auto 0;padding-top:3rem;display:flex}.contact-footer p{color:var(--contact-footer-text);font-size:.85rem;font-weight:300}.contact-time{color:var(--contact-time-text);letter-spacing:.05em;align-items:center;gap:.5rem;font-size:.85rem;font-weight:300;display:flex}.contact-time-dot{background:var(--status-color);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}@keyframes star-twinkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.6)}}.photos-cinema-img{object-fit:contain;width:100%;height:100%;display:block}.photos-marquee-img{object-fit:cover;width:100%;height:100%;display:block}.photos-parallax-img{width:100%;height:100%;display:block}.photos-cinema-section{position:relative}.photos-cinema-sticky{align-items:center;height:100vh;display:flex;position:sticky;top:0;overflow:hidden}.photos-cinema-track{will-change:transform;flex-shrink:0;gap:2rem;width:max-content;padding:0 3rem;display:flex}.photos-cinema-frame{border-radius:12px;flex-shrink:0;width:50vw;height:80vh;position:relative;overflow:hidden}.photos-cinema-number{letter-spacing:.1em;color:#ffffff80;font-size:.75rem;font-weight:500;font-family:var(--font-mono,monospace);position:absolute;bottom:1.5rem;right:1.5rem}.photos-parallax-section{height:400vh;position:relative}@media (width>=769px){.photos-parallax-section .section-label-anchor{left:calc(15vw - 1.5rem)}}.photos-parallax-sticky{justify-content:center;align-items:center;height:100vh;display:flex;position:sticky;top:0;overflow:hidden}.photos-parallax-stack{width:70vw;max-width:1000px;height:65vh;position:relative}.photos-parallax-card{will-change:transform, opacity;border-radius:12px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0;overflow:hidden}.photos-parallax-img{object-fit:contain;border-radius:12px}.photos-parallax-number{letter-spacing:.1em;color:#ffffff80;font-size:.75rem;font-weight:500;font-family:var(--font-mono,monospace);position:absolute;bottom:1.5rem;right:1.5rem}.photos-scattered-section{padding:6rem 3rem;position:relative}.photos-scattered-canvas{width:100%;height:110vh;max-height:1000px;position:relative}.photos-scattered-item{will-change:transform, opacity;position:absolute}.photos-scattered-card{cursor:pointer;will-change:transform;border-radius:8px;transition:box-shadow .4s;display:inline-block;position:relative;overflow:hidden;box-shadow:0 8px 40px #0000001f}.photos-scattered-card:hover{box-shadow:0 20px 60px #00000040}.photos-scattered-img{width:auto;max-width:100%;height:auto;max-height:420px;display:block}.photos-scattered-number{letter-spacing:.1em;color:#ffffff80;font-size:.65rem;font-weight:500;font-family:var(--font-mono,monospace);position:absolute;bottom:.75rem;right:.75rem}.photos-marquee-section{padding:6rem 0;overflow:hidden}.photos-marquee-overflow{padding:2rem 0;overflow:hidden}.photos-marquee-track{will-change:transform}.photos-marquee-loop{gap:1.5rem;animation:30s linear infinite marquee-scroll;display:flex}.photos-marquee-loop:hover{animation-play-state:paused}@keyframes marquee-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.photos-marquee-frame{border-radius:8px;flex-shrink:0;width:400px;height:300px;position:relative;overflow:hidden}.photos-marquee-caption{justify-content:flex-end;padding:1rem;display:flex;position:absolute;bottom:0;left:0;right:0}.photos-marquee-number{letter-spacing:.1em;color:#ffffff80;font-size:.65rem;font-weight:500;font-family:var(--font-mono,monospace)}.hero-glow,.exp-block:before,.exp-block-logo,.skill-category,.highlight-card,.project-modal-overlay,.project-modal{transition:background .5s,box-shadow .5s,border-color .5s}.magnetic{display:inline-block}@media (width<=768px){.section-label-track{width:100%}.section-label-sticky{top:1.75rem}.section-label-anchor{left:auto;right:1.5rem;transform:none}.section-label-inner{background:var(--bg-color);border:1px solid var(--divider-color);border-radius:3px;padding:.35rem .65rem}.hero{padding:0 1.5rem}.hero-top-bar{left:1.5rem;right:1.5rem}.hero-name-solid{padding-left:1.5rem}.hero-name-outline{-webkit-text-stroke-width:1px}.hero-aside{max-width:100%;margin-top:2rem;margin-left:0;padding-right:0}.hero-glow{width:400px;height:400px}.stats-band-inner{flex-wrap:wrap}.stat-cell{flex:50%;padding:2rem 1.5rem}.stat-cell:nth-child(2):after,.about-accent-line{display:none}.about-text-col{margin-left:0}.exp-block{padding:1.75rem 1.5rem}.exp-block-company{font-size:1.4rem}.exp-block-logo{width:32px;height:32px}.exp-block-meta{flex-direction:column;align-items:flex-start;gap:.25rem}.exp-block-dot{display:none}.exp-block-achievements{grid-template-columns:1fr;gap:1rem}.projects-mobile{display:block}.projects-hscroll-container{display:none}.hscroll-card{width:100%}.hscroll-card--split{flex-direction:column;min-height:auto}.split-left{width:100%;height:160px}.split-divider{align-self:auto;width:auto;height:1px}.split-right{padding:2rem 1.5rem}.hscroll-card--tall{width:100%;min-height:auto;padding:2rem 1.5rem}.hscroll-card--poster{min-height:320px;padding:2rem 1.5rem}.poster-number{-webkit-text-stroke-width:1px;font-size:clamp(8rem,30vw,14rem)}.contact-top{flex-direction:column;align-items:flex-start;gap:2rem;margin-bottom:3rem}.contact-heading .contact-title-indent{padding-left:1.5rem}.contact-row{grid-template-columns:2rem 5rem 1fr auto;gap:.75rem;padding:1.2rem 0}.contact-footer{text-align:center;flex-direction:column;align-items:center;gap:1rem}.modal-content{padding:3rem 2rem}.modal-meta{grid-template-columns:1fr}.about-section,.experience-section,.projects-mobile,.projects-hscroll-sticky{padding:0 1.5rem}.contact-section{padding:6rem 1.5rem 2rem}.photos-cinema-frame{width:85vw}.photos-cinema-track{gap:1rem;padding:0 1.5rem}}@media (width<=480px){.stat-cell{flex:100%}.stat-cell:after{display:none!important}.hero-name{font-size:clamp(3rem,14vw,5rem)}}@media (hover:none){.magnetic{transform:none!important}}
