@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500&family=Cormorant+Garamond:wght@300;400;500;600&display=swap");*,:after,:before{margin:0;padding:0;box-sizing:border-box}:root{--white:#fff;--snow:#fafafa;--silver:#f0f0f0;--ash:#e0e0e0;--mist:silver;--stone:#999;--graphite:#555;--charcoal:#333;--ink:#111;--black:#000;--font-sans:"Inter",-apple-system,sans-serif;--font-serif:"Cormorant Garamond",Georgia,serif;--section-pad:clamp(80px,10vw,160px);--content-max:1340px;--ease-out:cubic-bezier(.25,.46,.45,.94);--ease-smooth:cubic-bezier(.4,0,.2,1)}html{scroll-behavior:smooth;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);color:var(--ink);background:var(--white);line-height:1.6;overflow-x:hidden}img{display:block;max-width:100%;height:auto}a{color:inherit;text-decoration:none}ul{list-style:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-smooth),transform .8s var(--ease-smooth)}.reveal.visible{opacity:1;transform:translateY(0)}.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:20px 40px;background:hsla(0,0%,100%,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--silver);transform:translateY(-100%);opacity:0;transition:transform .5s var(--ease-smooth),opacity .5s var(--ease-smooth),padding .3s var(--ease-smooth),background .4s var(--ease-smooth)}.site-header.header-visible{transform:translateY(0);opacity:1}.site-header.scrolled{padding:14px 40px;background:hsla(0,0%,100%,.96)}.header-brand{display:flex;align-items:center}.header-logo{height:36px;width:auto;display:block}.header-nav{display:flex;gap:36px}.header-nav a{font-size:.78rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--graphite);position:relative;padding-bottom:3px;transition:color .3s var(--ease-smooth)}.header-nav a:after{content:"";position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--ink);transition:width .35s var(--ease-out)}.header-nav a:hover{color:var(--ink)}.header-nav a:hover:after{width:100%}.mobile-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}.mobile-toggle span{display:block;width:24px;height:1.5px;background:var(--ink);transition:transform .3s var(--ease-smooth),opacity .2s}.mobile-toggle.active span:first-child{transform:translateY(6.5px) rotate(45deg)}.mobile-toggle.active span:nth-child(2){opacity:0}.mobile-toggle.active span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.hero{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--white);text-align:center;padding:40px 24px 80px;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 49.8%,var(--silver) 49.8%,var(--silver) 50.2%,transparent 50.2%),linear-gradient(0deg,transparent 49.8%,var(--silver) 49.8%,var(--silver) 50.2%,transparent 50.2%);background-size:120px 120px;opacity:.35;pointer-events:none}.hero-logo{position:relative;z-index:1;margin-bottom:36px}.hero-logo-img{width:clamp(440px,55vw,760px);height:auto;display:block;opacity:0;transform:scale(.6);animation:logoPop 1s var(--ease-out) .2s forwards}@keyframes logoPop{0%{opacity:0;transform:scale(.6)}60%{opacity:1;transform:scale(1.04)}80%{transform:scale(.98)}to{opacity:1;transform:scale(1)}}.hero-subtitle{font-size:clamp(.95rem,1.4vw,1.15rem);font-weight:500;letter-spacing:.38em;text-transform:uppercase;color:var(--charcoal);margin-top:0;position:relative;z-index:1;opacity:0;animation:heroTextUp .9s var(--ease-smooth) 1.2s forwards}.hero-scroll-cue{position:absolute;bottom:48px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;opacity:0;animation:heroScrollUp .9s var(--ease-smooth) 1.8s forwards}@keyframes heroScrollUp{0%{opacity:0;transform:translate(-50%,24px)}to{opacity:1;transform:translate(-50%)}}.hero-scroll-cue span{font-size:.75rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--graphite)}.scroll-chevron{width:22px;height:22px;color:var(--charcoal);animation:chevronBounce 2s var(--ease-smooth) infinite}@keyframes chevronBounce{0%,to{transform:translateY(0);opacity:.6}50%{transform:translateY(6px);opacity:1}}.hero-scroll-cue .scroll-line{width:1.5px;height:48px;background:linear-gradient(to bottom,var(--charcoal),transparent);position:relative;overflow:hidden;border-radius:1px}.hero-scroll-cue .scroll-line:after{content:"";position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--ink);animation:scrollPulse 2.4s ease-in-out infinite}@keyframes scrollPulse{0%{top:-100%}50%{top:100%}to{top:100%}}@keyframes heroTextUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.section{padding:var(--section-pad) 24px;scroll-margin-top:100px}.section-inner{max-width:var(--content-max);margin:0 auto}.section-label{font-size:.7rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--mist);margin-bottom:12px}.section-heading{font-family:var(--font-serif);font-size:clamp(2rem,4vw,3.4rem);font-weight:300;letter-spacing:.03em;color:var(--ink);margin-bottom:16px}.section-rule{width:48px;height:1px;background:var(--ash);margin-bottom:48px}.portfolio{background:var(--snow);padding-bottom:20px}.portfolio-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:48px}.portfolio-tab{font-family:var(--font-sans);font-size:.75rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:10px 24px;border:1px solid var(--ash);border-radius:100px;background:var(--white);color:var(--graphite);cursor:pointer;transition:all .3s var(--ease-smooth)}.portfolio-tab.active,.portfolio-tab:hover{background:var(--ink);color:var(--white);border-color:var(--ink)}.portfolio-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:20px;gap:20px}.portfolio-item{position:relative;overflow:hidden;border-radius:4px;background:var(--white);cursor:pointer;aspect-ratio:4/3}.portfolio-item img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%);transform:translateY(var(--parallax-y,0));transition:transform .6s var(--ease-smooth),filter .6s var(--ease-smooth)}.portfolio-item:hover img{filter:grayscale(0);transform:scale(1.04) translateY(var(--parallax-y,0))}.portfolio-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;background:linear-gradient(0deg,rgba(0,0,0,.48) 0,transparent 60%);opacity:0;transition:opacity .45s var(--ease-smooth)}.portfolio-item:hover .portfolio-overlay{opacity:1}.portfolio-overlay h3{font-family:var(--font-serif);font-size:1.25rem;font-weight:400;color:var(--white);letter-spacing:.03em}.portfolio-overlay p{font-size:.72rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;color:hsla(0,0%,100%,.7);margin-top:4px}.portfolio-item.hidden{display:none}.project-modal{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s var(--ease-smooth)}.project-modal.open{opacity:1;pointer-events:all}.project-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.project-modal-content{position:relative;width:90vw;max-width:900px;max-height:90vh;overflow-y:auto;background:var(--white);border-radius:6px;box-shadow:0 24px 80px rgba(0,0,0,.12);transform:translateY(30px) scale(.97);transition:transform .4s var(--ease-smooth)}.project-modal.open .project-modal-content{transform:translateY(0) scale(1)}.project-modal-content::-webkit-scrollbar{width:4px}.project-modal-content::-webkit-scrollbar-thumb{background:var(--ash);border-radius:4px}.project-modal-close{position:-webkit-sticky;position:sticky;top:16px;float:right;margin:16px 16px 0 0;z-index:10;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:hsla(0,0%,100%,.85);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--ash);border-radius:50%;cursor:pointer;transition:border-color .3s,transform .3s}.project-modal-close:hover{border-color:var(--ink);transform:rotate(90deg)}.project-modal-close svg{width:15px;height:15px;stroke:var(--ink);stroke-width:1.5}.project-hero{width:100%;aspect-ratio:16/9;overflow:hidden}.project-hero img{width:100%;height:100%;object-fit:cover}.project-details{padding:36px 40px 28px}.project-details-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px}.project-category-label{font-size:.68rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--mist);margin-bottom:6px}.project-title{font-family:var(--font-serif);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:400;color:var(--ink)}.project-area{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0}.project-area-label{font-size:.65rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--mist);margin-bottom:4px}.project-area-value{font-family:var(--font-serif);font-size:1.1rem;font-weight:400;color:var(--charcoal)}.project-divider{width:100%;height:1px;background:var(--silver);margin:20px 0 24px}.project-description{font-size:.92rem;font-weight:300;line-height:1.8;color:var(--graphite)}.project-gallery{display:grid;grid-template-columns:1fr 1fr;grid-gap:4px;gap:4px;padding:0 40px 40px}.project-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:3px}.modal-reveal{opacity:0;transform:translateY(40px);transition:opacity .7s var(--ease-smooth),transform .7s var(--ease-smooth)}.modal-reveal.modal-visible{opacity:1;transform:translateY(0)}.modal-reveal-delay-1{transition-delay:.08s}.modal-reveal-delay-2{transition-delay:.16s}.modal-reveal-delay-3{transition-delay:.24s}.modal-reveal-delay-4{transition-delay:.32s}.project-gallery img.modal-reveal{opacity:0;transform:translateY(30px) scale(.96);transition:opacity .6s var(--ease-smooth),transform .6s var(--ease-smooth)}.project-gallery img.modal-reveal.modal-visible{opacity:1;transform:translateY(0) scale(1)}@media (max-width:680px){.project-modal-content{width:96vw;max-height:94vh}.project-details{padding:24px 20px 20px}.project-details-header{flex-direction:column;gap:12px}.project-area{align-items:flex-start}.project-gallery{grid-template-columns:1fr;padding:0 20px 24px}}.stats{background:transparent;padding-top:10px;padding-bottom:60px}.stats-inline{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:20px;font-family:var(--font-sans)}.stat-inline-item{display:flex;align-items:center;gap:8px}.stat-inline-number{font-weight:300;font-size:1.2rem;color:var(--ink)}.stat-inline-label{font-weight:500;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--graphite)}.stat-divider{width:1px;height:16px;background:var(--stone);opacity:.5}@media (max-width:768px){.stats-inline{flex-direction:column;gap:12px}.stat-divider{display:none}}.clients{background:var(--snow);padding-top:20px;padding-bottom:40px}.clients-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:32px;gap:32px;align-items:center;justify-items:center}.client-logo{width:100%;max-width:160px;opacity:.6;filter:grayscale(100%);transition:opacity .4s var(--ease-smooth),filter .4s var(--ease-smooth),transform .4s var(--ease-smooth)}.client-logo img{width:100%;height:auto;object-fit:contain}.client-logo:hover{opacity:1;filter:grayscale(0);transform:scale(1.05)}@media (max-width:768px){.clients-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.clients-grid{grid-template-columns:1fr}}.testimonials-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:32px;gap:32px;margin-top:80px}.testimonial-card{background:var(--white);padding:40px;border-radius:4px;box-shadow:0 4px 24px rgba(0,0,0,.03)}.testimonial-text{font-family:var(--font-serif);font-size:1.15rem;font-style:italic;color:var(--charcoal);line-height:1.6;margin-bottom:20px}.testimonial-author{font-size:.8rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--stone)}@media (max-width:768px){.testimonials-grid{grid-template-columns:1fr;margin-top:60px}.testimonial-card{padding:32px}}.team{background:var(--white);padding-top:40px;padding-bottom:40px}.team-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:32px;gap:32px}.team-card{text-align:center}.team-photo{position:relative;width:50%;margin-left:auto;margin-right:auto;aspect-ratio:3/4;overflow:hidden;border-radius:4px;margin-bottom:24px;background:var(--snow)}.team-photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%);transition:filter .5s var(--ease-smooth),transform .5s var(--ease-smooth)}.team-card:hover .team-photo img{filter:grayscale(0);transform:scale(1.03)}.team-badge{display:inline-block;font-size:.65rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:5px 14px;background:var(--ink);color:var(--white);border-radius:100px;margin-bottom:14px}.team-name{font-family:var(--font-serif);font-size:1.3rem;font-weight:400;color:var(--ink);margin-bottom:4px}.team-role{font-size:.78rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--stone);margin-bottom:10px}.team-specialization{font-size:.82rem;font-weight:300;color:var(--graphite);line-height:1.6;margin-bottom:14px}.team-contact{display:flex;flex-direction:column;gap:4px}.team-contact a{font-size:.78rem;font-weight:400;color:var(--stone);transition:color .3s var(--ease-smooth)}.team-contact a:hover{color:var(--ink)}.about{background:var(--white);padding-top:40px}.about-content{display:grid;grid-template-columns:1fr 1fr;grid-gap:80px;gap:80px;align-items:start}.about-text h3{font-family:var(--font-serif);font-size:1.6rem;font-weight:400;color:var(--ink);margin-bottom:20px}.about-text p{font-size:.95rem;font-weight:300;color:var(--graphite);line-height:1.8;margin-bottom:16px}.about-details{padding-top:16px;display:flex;gap:40px}.about-info-blocks{flex:1 1}.about-map-block{flex:1.2 1}.about-map-block iframe{width:100%;height:100%;min-height:250px;border-radius:4px;filter:grayscale(100%);transition:filter .5s var(--ease-smooth)}.about-map-block iframe:hover{filter:grayscale(40%)}.about-detail-block{margin-bottom:36px}.about-detail-block h4{font-size:.7rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--mist);margin-bottom:10px}.about-detail-block address,.about-detail-block p{font-style:normal;font-size:.92rem;font-weight:300;color:var(--charcoal);line-height:1.7}.social-links{display:flex;gap:16px;margin-top:6px}.social-link{width:42px;height:42px;display:flex;align-items:center;justify-content:center;border:1px solid var(--ash);border-radius:50%;transition:all .3s var(--ease-smooth)}.social-link:hover{border-color:var(--ink);background:var(--ink)}.social-link svg{width:18px;height:18px;fill:var(--charcoal);transition:fill .3s var(--ease-smooth)}.social-link:hover svg{fill:var(--white)}.contact{background:var(--snow);padding:40px 24px}.contact-compact{max-width:900px;margin:0 auto}.contact-form{display:flex;align-items:flex-end;gap:20px}.contact-form input{font-family:var(--font-sans);font-size:.85rem;padding:8px 0;border:none;border-bottom:1px solid var(--mist);background:transparent;color:var(--ink);transition:border-color .3s;flex:1 1}.contact-form input::placeholder{color:var(--stone);font-weight:300;text-transform:uppercase;letter-spacing:.08em;font-size:.7rem}.contact-form input:focus{outline:none;border-bottom-color:var(--ink)}.btn-submit{font-family:var(--font-sans);font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;padding:10px 24px;background:var(--ink);color:var(--white);border:none;border-radius:4px;cursor:pointer;transition:background .3s,transform .3s;flex-shrink:0}.btn-submit:hover{background:var(--charcoal);transform:translateY(-2px)}@media (max-width:768px){.contact-form{flex-direction:column;align-items:stretch;gap:16px}}.site-footer{padding:40px;border-top:1px solid var(--silver);display:flex;align-items:center;justify-content:space-between;background:var(--white)}.footer-copy{font-size:.72rem;font-weight:400;letter-spacing:.08em;color:var(--stone)}.footer-links{display:flex;gap:28px}.footer-links a{font-size:.7rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--stone);transition:color .3s}.footer-links a:hover{color:var(--ink)}@media (max-width:960px){.portfolio-grid,.team-grid{grid-template-columns:repeat(2,1fr)}.team-grid{gap:40px}.about-content{grid-template-columns:1fr;gap:48px}}@media (max-width:840px){.about-details{flex-direction:column;gap:32px}}@media (max-width:680px){.site-header{padding:16px 20px}.header-nav{position:fixed;top:0;right:0;width:100%;height:100vh;flex-direction:column;align-items:center;justify-content:center;gap:32px;background:hsla(0,0%,100%,.98);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transform:translateX(100%);transition:transform .4s var(--ease-smooth)}.header-nav.open{transform:translateX(0)}.header-nav a{font-size:1rem;letter-spacing:.18em}.mobile-toggle{display:flex;z-index:1001}.portfolio-grid,.team-grid{grid-template-columns:1fr}.team-grid{max-width:360px;margin:0 auto}.portfolio-tabs{justify-content:center}.site-footer{flex-direction:column;gap:16px;text-align:center;padding:32px 20px}.hero-logo-img{width:clamp(280px,80vw,440px)}}