@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Playfair+Display:ital,wght@0,400;0,500;0,600;1,400;1,500&display=swap";.navbar{z-index:100;width:100%;transition:height 1s cubic-bezier(.85,0,.15,1),background 1s,border-bottom 1s;position:fixed;top:0;left:0;overflow:hidden}.navbar--intro{-webkit-backdrop-filter:blur(12px);background:#ffffffb3;border-bottom:1px solid #fff3;height:100vh}.navbar--shrunk{-webkit-backdrop-filter:blur(12px);background:#ffffffd9;border-bottom:1px solid #0000000d;height:80px}.navbar__container{width:100%;max-width:1280px;height:100%;margin:0 auto;position:relative}.navbar__logo{text-decoration:none;transition:all 1s cubic-bezier(.85,0,.15,1);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.navbar--shrunk .navbar__logo{top:50%;left:2rem;transform:translateY(-50%)}.navbar__logo-img{object-fit:contain;mix-blend-mode:multiply;width:auto;height:180px;transition:height 1s cubic-bezier(.85,0,.15,1)}.navbar--shrunk .navbar__logo-img{height:40px}.navbar__links{opacity:0;pointer-events:none;align-items:center;gap:1.5rem;transition:opacity .5s .5s;display:flex;position:absolute;top:50%;right:2rem;transform:translateY(-50%)}.navbar--shrunk .navbar__links{opacity:1;pointer-events:auto}.navbar__link{font-family:var(--font-sans);color:#00000080;text-transform:uppercase;letter-spacing:.1em;transition:color var(--duration-fast) ease;font-size:.85rem;text-decoration:none}.navbar__link:hover,.navbar__link.active{color:var(--color-accent)}@media (width<=900px){.navbar__links{display:none}}.global-footer{text-align:center;color:var(--color-text);font-family:var(--font-sans);background-color:#0000;flex-direction:column;align-items:center;margin-top:4rem;padding:4rem 2rem 2rem;display:flex}.footer-scroll-top{cursor:pointer;margin-bottom:2rem;transition:transform .3s}.footer-scroll-top:hover{transform:translateY(-5px)}.footer-scroll-top svg{width:40px;height:40px}.footer-logo{margin-bottom:2rem}.footer-logo img{filter:invert()hue-rotate(180deg);mix-blend-mode:screen;width:60px;height:auto}.footer-address{color:var(--color-text-muted);margin-bottom:1rem;font-size:.95rem;font-weight:300;line-height:1.6}.footer-address p{margin:0}.footer-phone{margin-bottom:2rem}.footer-phone a{color:var(--color-text-muted);font-size:.95rem;font-weight:300;text-decoration:none;transition:color .2s}.footer-phone a:hover{color:var(--color-text)}.footer-socials{gap:1.5rem;margin-bottom:3rem;display:flex}.footer-socials a{color:var(--color-text-subtle);transition:color .2s,transform .2s}.footer-socials a:hover{color:var(--color-text);transform:translateY(-2px)}.footer-socials svg{width:28px;height:28px}.footer-copyright{font-size:.85rem;font-style:italic;font-family:var(--font-sans);color:var(--color-text-subtle);font-weight:300}.preloader{z-index:9999;pointer-events:all;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.preloader__curtain{background:var(--color-dark);will-change:transform;width:100%;height:50%;transition:transform var(--duration-glacial) var(--ease-in-out);position:absolute}.preloader__curtain--top{top:0}.preloader__curtain--bottom{bottom:0}.preloader.is-revealing .preloader__curtain--top{transform:translateY(-100%)}.preloader.is-revealing .preloader__curtain--bottom{transform:translateY(100%)}.preloader.is-revealing .preloader__content{opacity:0;transform:scale(.94)}.preloader.is-done{pointer-events:none;visibility:hidden}.preloader__content{z-index:10;opacity:1;flex-direction:column;align-items:center;gap:2rem;transition:opacity .5s,transform .5s;display:flex;position:relative;transform:scale(1)}.preloader__logo{filter:invert()hue-rotate(180deg);mix-blend-mode:screen;opacity:0;width:clamp(100px,16vw,180px);height:auto;animation:preloader-fadeUp .8s var(--ease-out-expo) .3s forwards;transform:translateY(16px)}.preloader__counter-wrap{opacity:0;align-items:baseline;gap:2px;animation:.6s .6s forwards preloader-fadeIn;display:flex}.preloader__counter{font-family:var(--font-sans);color:var(--color-light-on-dark);letter-spacing:-.04em;font-variant-numeric:tabular-nums;font-size:clamp(2.5rem,5.5vw,4.5rem);font-weight:300;line-height:1}.preloader__percent{font-family:var(--font-sans);color:var(--color-light-muted);font-size:clamp(1rem,1.8vw,1.4rem);font-weight:300;line-height:1}.preloader__progress{background:var(--color-light-subtle);opacity:0;width:clamp(120px,18vw,220px);height:1px;animation:.6s .8s forwards preloader-fadeIn;position:relative;overflow:hidden}.preloader__progress-fill{background:var(--color-accent);width:0%;height:100%;transition:width 80ms linear;position:absolute;top:0;left:0}.preloader__tagline{font-family:var(--font-serif);color:var(--color-light-muted);letter-spacing:.15em;text-transform:lowercase;opacity:0;font-size:clamp(.7rem,1.1vw,.9rem);font-style:italic;font-weight:400;animation:.6s 1s forwards preloader-fadeIn}.preloader__seam{background:var(--color-light-subtle);z-index:5;width:0;height:1px;transition:width 2.2s var(--ease-out-expo) .4s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.preloader__seam.is-active{width:55%}@keyframes preloader-fadeUp{to{opacity:1;transform:translateY(0)}}@keyframes preloader-fadeIn{to{opacity:1}}.scroll-sequence-container{background-color:var(--color-bg);z-index:0;width:100%;height:400vh;position:relative}.scroll-sequence-sticky{width:100%;height:100vh;position:sticky;top:0;overflow:hidden}.scroll-sequence-canvas{object-fit:cover;width:100%;height:100%;display:block}.hero-overlay{z-index:1;text-align:center;width:100%;height:100vh;padding:var(--space-lg) var(--space-md) 15vh;pointer-events:none;flex-direction:column;justify-content:flex-end;align-items:center;display:flex;position:absolute;top:0;left:0}.hero-overlay *{pointer-events:auto}.beams-container{z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.notebook-gallery{flex-direction:column;align-items:center;max-width:1300px;margin:0 auto;padding:2rem 1rem;display:flex}.notebook-controls{justify-content:space-between;align-items:center;width:100%;margin-bottom:2rem;display:flex}.notebook-btn{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text);opacity:.7;font-size:.8rem;transition:opacity .3s}.notebook-btn:hover:not(:disabled){opacity:1}.notebook-btn:disabled{opacity:.2;cursor:not-allowed}.notebook-page-indicator{font-family:var(--font-serif);color:var(--color-text-muted);font-size:.9rem;font-style:italic}.notebook{aspect-ratio:2.2;perspective:1000px;border-radius:20px;gap:2px;width:100%;display:flex;position:relative}.notebook__page{background:var(--color-surface);flex:1;transition:filter .4s;position:relative;overflow:hidden}.notebook__page.clickable{cursor:pointer}.notebook__page--left{border-radius:20px 0 0 20px;box-shadow:-15px 20px 40px #00000026}.notebook__page--right{border-radius:0 20px 20px 0;box-shadow:15px 20px 40px #00000026}.notebook__page--left:after{content:"";z-index:5;background-image:radial-gradient(circle,#1a1a1a 4px,#0000 5px);background-position:0 10px;background-size:100% 36px;width:12px;position:absolute;top:5%;bottom:5%;right:-6px}.notebook__page--right:before{content:"";z-index:5;background-image:radial-gradient(circle,#1a1a1a 4px,#0000 5px);background-position:0 10px;background-size:100% 36px;width:12px;position:absolute;top:5%;bottom:5%;left:-6px}.notebook__spiral{z-index:10;pointer-events:none;filter:drop-shadow(0 4px 6px #0009);background-image:repeating-linear-gradient(#0000 0 14px,#222 14px,#777 17px,#111 20px,#0000 20px 36px);width:50px;position:absolute;top:5%;bottom:5%;left:50%;transform:translate(-50%)}.notebook__image{object-fit:cover;width:100%;height:100%;display:block}.notebook__overlay{text-align:center;color:#fff;opacity:0;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;flex-direction:column;justify-content:center;align-items:center;transition:opacity .4s;display:flex;position:absolute;inset:0}.notebook__page:hover .notebook__overlay{opacity:1}.notebook__title{font-family:var(--font-serif);margin-bottom:.5rem;font-size:clamp(1.5rem,3vw,2.5rem);font-weight:400}.notebook__category{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.2em;color:#fff;opacity:.8;font-size:.85rem}@media (width<=768px){.notebook{aspect-ratio:auto;flex-direction:column;height:800px}.notebook__page--left{border-radius:20px 20px 0 0;box-shadow:0 15px 40px #00000026}.notebook__page--right{border-radius:0 0 20px 20px;box-shadow:0 15px 40px #00000026}.notebook__page--left:after{background-image:radial-gradient(circle,#1a1a1a 4px,#0000 5px);background-position:10px 0;background-size:36px 100%;width:auto;height:12px;inset:auto 5% -6px}.notebook__page--right:before{background-image:radial-gradient(circle,#1a1a1a 4px,#0000 5px);background-position:10px 0;background-size:36px 100%;width:auto;height:12px;inset:-6px 5% auto}.notebook__spiral{background-image:repeating-linear-gradient(90deg,#0000 0 14px,#222 14px,#777 17px,#111 20px,#0000 20px 36px);width:auto;height:50px;top:50%;left:5%;right:5%;transform:translateY(-50%)}}.featured-ongoing{grid-template-columns:repeat(4,1fr);align-items:center;gap:3rem;max-width:1400px;margin:10rem auto 4rem;padding:0 2rem;display:grid}.ft-img{cursor:pointer;width:100%;transition:transform .4s,box-shadow .4s;overflow:hidden;box-shadow:0 10px 30px #0000000d}.ft-img img{object-fit:cover;width:100%;height:100%;transition:transform .4s;display:block}.ft-img:hover{transform:translateY(-5px);box-shadow:0 15px 40px #0000001a}.ft-img:hover img{transform:scale(1.03)}.ft-img-1{aspect-ratio:1;grid-area:1/1/2/2}.ft-img-2{aspect-ratio:4/3;grid-area:1/2/2/3}.ft-img-3{aspect-ratio:4/3;grid-area:2/2/3/3}.ft-img-4{aspect-ratio:4/3;grid-area:2/3/3/4}.ft-img-5{aspect-ratio:4/3;grid-area:2/4/3/5}.ft-text{cursor:pointer;flex-direction:column;grid-area:1/3/2/5;justify-content:center;align-items:center;padding-left:2rem;display:flex}.ft-text h2{font-family:var(--font-serif);color:var(--color-accent);margin-bottom:.5rem;font-size:clamp(3rem,5vw,4.5rem);font-style:italic;font-weight:400;transition:transform .3s}.ft-text:hover h2{transform:scale(1.02)}.ft-text p{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.15em;color:var(--color-text-muted);align-self:center;margin-left:4rem;font-size:.85rem}@media (width<=900px){.featured-ongoing{grid-template-rows:auto;grid-template-columns:repeat(2,1fr);gap:1.5rem}.ft-img-1{grid-area:auto/1/auto/2}.ft-img-2{grid-area:auto/2/auto/3}.ft-text{grid-area:auto/1/auto/3;align-items:center;margin:3rem 0;padding-left:0}.ft-text p{margin-left:0}.ft-img-3{grid-area:auto/1/auto/2}.ft-img-4{grid-area:auto/2/auto/3}.ft-img-5{grid-area:auto/1/auto/3}}.category-page{padding:calc(var(--space-xl) + 80px) var(--space-md) var(--space-xl);max-width:1280px;min-height:100vh;margin:0 auto}.category-page__header{text-align:center;margin-bottom:3rem}.category-page__header h1{font-family:var(--font-serif);color:var(--color-text);letter-spacing:-.02em;font-size:clamp(2rem,4vw,3rem);font-weight:400}.category-page__empty{text-align:center;font-family:var(--font-sans);color:var(--color-text-muted);padding:4rem 0}.category-grid .project-card{opacity:0;animation:fadeUp var(--duration-medium) var(--ease-out-expo) forwards;transform:translateY(20px)}@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}.project-details{min-height:100vh;padding:calc(var(--space-xl) + 80px) var(--space-md) var(--space-xl);z-index:1;max-width:1400px;margin:0 auto;position:relative}.project-details__header{text-align:center;animation:fadeUp var(--duration-medium) var(--ease-out-expo) forwards;margin-bottom:6rem}.project-details__category{font-family:var(--font-sans);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.15em;margin-top:1rem;font-size:.85rem}.themed-layout{animation:fadeUp var(--duration-medium) var(--ease-out-expo) .1s forwards;opacity:0;grid-template-columns:1fr;gap:4rem;display:grid}@media (width>=1024px){.themed-layout{grid-template-columns:1fr 1fr;align-items:start;gap:8rem}}.themed-layout__left{flex-direction:column;max-width:600px;margin:0 auto;display:flex}.themed-image-main{object-fit:cover;width:100%;height:auto;margin-bottom:3rem;box-shadow:0 10px 30px #0000000d}.project-info-grid{border-top:1px solid #0000001a;border-bottom:1px solid #0000001a;flex-wrap:wrap;gap:2rem;margin-bottom:3rem;padding:1.5rem 0;display:flex}.info-column{flex-direction:column;min-width:120px;display:flex}.info-label{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:.25rem;font-size:.75rem}.info-value{font-family:var(--font-sans);color:var(--color-text);font-size:.95rem;font-weight:500}.themed-writeup{text-align:left;color:var(--color-text);font-size:clamp(.95rem,1.2vw,1.05rem);line-height:1.8;font-family:var(--font-sans)}.themed-writeup p{margin-bottom:1.5rem}.themed-layout__right{flex-direction:column;align-items:center;gap:8rem;display:flex}@media (width>=1024px){.themed-layout__right{align-items:flex-end}}.themed-image-secondary-wrapper{width:100%;max-width:250px;box-shadow:0 10px 30px #0000000d}.themed-image-secondary{width:100%;height:auto;display:block}.themed-illustration-wrapper{width:100%;max-width:700px;position:relative}.themed-illustration{mix-blend-mode:multiply;filter:contrast(1.1);width:100%;height:auto;display:block}.themed-palette{flex-direction:column;gap:.5rem;display:flex;position:absolute;bottom:10%;right:-20px}.palette-color{width:16px;height:16px;box-shadow:0 2px 5px #0000001a}.project-details__gallery{animation:fadeUp var(--duration-medium) var(--ease-out-expo) .3s forwards;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;display:grid}.gallery-item{border-radius:4px;width:100%;overflow:hidden;box-shadow:0 10px 30px #00000014}.gallery-item img{width:100%;height:auto;transition:transform .4s;display:block}.gallery-item:hover img{transform:scale(1.02)}.hero{z-index:1;text-align:center;justify-content:flex-end;width:100%;position:relative}.hero__logo{opacity:0;width:clamp(140px,20vw,260px);height:auto;transition:opacity var(--duration-slow) var(--ease-out-expo), transform var(--duration-slow) var(--ease-out-expo);margin-bottom:2.5rem;transform:translateY(30px)}.hero__logo.visible{opacity:1;transform:translateY(0)}.hero__title{font-family:var(--font-serif);color:#fff;letter-spacing:-.02em;opacity:0;max-width:680px;transition:opacity var(--duration-slow) var(--ease-out-expo) .15s, transform var(--duration-slow) var(--ease-out-expo) .15s;font-size:clamp(1.6rem,3.8vw,3.2rem);font-weight:400;line-height:1.25;transform:translateY(30px)}.hero__title.visible{opacity:1;transform:translateY(0)}.hero__subtitle{font-family:var(--font-sans);color:#fffc;text-transform:uppercase;letter-spacing:.22em;opacity:0;transition:opacity var(--duration-slow) var(--ease-out-expo) .3s, transform var(--duration-slow) var(--ease-out-expo) .3s;margin-top:1.5rem;font-size:clamp(.75rem,1vw,.95rem);font-weight:300;transform:translateY(20px)}.hero__subtitle.visible{opacity:1;transform:translateY(0)}.hero__accent{background:var(--color-accent);opacity:0;width:40px;height:3px;transition:opacity .8s ease .5s, transform .8s var(--ease-out-expo) .5s;margin-top:2rem;transform:scaleX(0)}.hero__accent.visible{opacity:1;transform:scaleX(1)}.projects{z-index:1;padding:var(--space-xl) var(--space-md);max-width:1280px;margin:0 auto;position:relative}.projects__header{font-family:var(--font-serif);color:var(--color-accent);letter-spacing:.1em;opacity:0;transition:opacity var(--duration-medium) var(--ease-out-expo), transform var(--duration-medium) var(--ease-out-expo);margin-bottom:3rem;font-size:clamp(.85rem,1.2vw,1.05rem);font-style:italic;font-weight:400;transform:translateY(20px)}.projects__header.visible{opacity:1;transform:translateY(0)}.projects__grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}@media (width<=900px){.projects__grid{grid-template-columns:repeat(2,1fr)}}@media (width<=560px){.projects__grid{grid-template-columns:1fr}}.project-card{aspect-ratio:4/3;cursor:pointer;opacity:0;transition:opacity var(--duration-medium) var(--ease-out-expo), transform var(--duration-medium) var(--ease-out-expo);position:relative;overflow:hidden;transform:translateY(40px)}.project-card.visible{opacity:1;transform:translateY(0)}.project-card__image{object-fit:cover;filter:grayscale(25%)brightness(.97);width:100%;height:100%;transition:filter var(--duration-medium) ease, transform var(--duration-medium) var(--ease-out-expo)}.project-card:hover .project-card__image{filter:grayscale(0%)brightness();transform:scale(1.04)}.project-card__overlay{opacity:0;transition:opacity var(--duration-fast) ease, transform var(--duration-fast) ease;background:linear-gradient(#0000,#0000008c);padding:1.5rem;position:absolute;bottom:0;left:0;right:0;transform:translateY(8px)}.project-card:hover .project-card__overlay{opacity:1;transform:translateY(0)}.project-card__title{font-family:var(--font-serif);color:#fff;margin-bottom:.2rem;font-size:1.15rem}.project-card__category{font-family:var(--font-sans);color:#fff9;text-transform:uppercase;letter-spacing:.15em;font-size:.65rem}.footer{z-index:1;padding:var(--space-lg) var(--space-md);text-align:center;border-top:1px solid #1a1a1a0f;position:relative}.footer__text{font-family:var(--font-sans);color:var(--color-text-subtle);letter-spacing:.1em;font-size:.72rem;font-weight:300}:root{--color-bg:#121212;--color-bg-warm:#1a1a1a;--color-surface:#1e1e1e;--color-text:#fff;--color-text-muted:#fff9;--color-text-subtle:#ffffff4d;--color-accent:#e03c31;--color-accent-soft:#e03c3126;--color-dark:#000;--color-dark-surface:#111;--color-light-on-dark:#fff;--color-light-muted:#fff6;--color-light-subtle:#ffffff1f;--color-dot:#333;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-serif:"Playfair Display", Georgia, "Times New Roman", serif;--space-xs:.5rem;--space-sm:1rem;--space-md:2rem;--space-lg:4rem;--space-xl:6rem;--space-2xl:8rem;--ease-out-expo:cubic-bezier(.16, 1, .3, 1);--ease-out-quart:cubic-bezier(.25, 1, .5, 1);--ease-in-out:cubic-bezier(.76, 0, .24, 1);--duration-fast:.3s;--duration-medium:.6s;--duration-slow:1s;--duration-glacial:1.4s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);line-height:1.6;overflow:hidden}body.loaded{overflow:hidden auto}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}.dot-grid{z-index:0;background-image:radial-gradient(circle, var(--color-dot) 1px, transparent 1px);pointer-events:none;opacity:.8;background-size:32px 32px;position:fixed;inset:0}.text-highlight-red{background-color:var(--color-accent);color:#fff;font-family:var(--font-serif);margin-bottom:.2rem;padding:0 .2em;font-style:italic;display:inline-block}.heading-red-serif{font-family:var(--font-serif);color:var(--color-accent);font-size:clamp(2rem,4vw,3rem);font-style:italic}.reveal-up{opacity:0;transition:opacity var(--duration-slow) var(--ease-out-expo), transform var(--duration-slow) var(--ease-out-expo);transform:translateY(40px)}.reveal-up.visible{opacity:1;transform:translateY(0)}.reveal-up.visible:nth-child(2){transition-delay:.1s}.reveal-up.visible:nth-child(3){transition-delay:.2s}.reveal-up.visible:nth-child(4){transition-delay:.3s}.reveal-up.visible:nth-child(5){transition-delay:.4s}.reveal-up.visible:nth-child(6){transition-delay:.5s}
