*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
--ink:#1A1A1A;--paper:#FAFAF8;--stone:#8B7355;--warm-gray:#B5AFA6;
--light-gray:#E8E5E0;--cloud:#F3F1ED;--deep:#0E0E0E;--slate:#4A4A48;
--serif:'Cormorant Garamond',Georgia,serif;
--sans:'DM Sans','Helvetica Neue',sans-serif;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);
overflow-x:hidden;-webkit-font-smoothing:antialiased;
-webkit-text-size-adjust:100%;text-size-adjust:100%;
-webkit-tap-highlight-color:transparent}
::selection{background:var(--stone);color:var(--paper)}

body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;
opacity:.03;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='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

.nav{position:fixed;top:0;left:0;right:0;z-index:100;
padding:1.5rem 3rem;display:flex;align-items:center;justify-content:space-between;
transition:all .5s cubic-bezier(.4,0,.2,1)}
.nav.scrolled{background:rgba(14,14,14,.92);backdrop-filter:blur(20px);padding:1rem 3rem}
.nav-logo img{height:56px;transition:opacity .3s;animation:signIn 1.7s cubic-bezier(.76,0,.24,1) .35s both}
.nav-links{display:flex;gap:2.5rem;align-items:center}
.nav-links a{font-family:var(--sans);font-size:.75rem;font-weight:400;
letter-spacing:.15em;text-transform:uppercase;color:var(--paper);
text-decoration:none;opacity:.7;transition:opacity .3s}
.nav-links a:hover{opacity:1}
.nav-cta{padding:.5rem 1.5rem;border:1px solid rgba(240,237,232,.3);
opacity:1!important;transition:all .3s}
.nav-cta:hover{background:var(--paper);color:var(--deep)!important;border-color:var(--paper)}

.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:100;
width:44px;height:44px;align-items:center;justify-content:center;margin-right:-10px;
background:none;border:none}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--paper);transition:all .3s}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

.mobile-menu{display:none;position:fixed;inset:0;background:var(--deep);z-index:105;
flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;padding:2rem}
.mobile-menu.open{display:flex}
.menu-close{position:absolute;top:1rem;right:1rem;width:44px;height:44px;display:flex;
align-items:center;justify-content:center;background:none;border:none;color:var(--paper);cursor:pointer;transition:color .3s}
.menu-close:hover,.menu-close:active{color:var(--stone)}
.menu-close svg{width:26px;height:26px}
.menu-links{display:flex;flex-direction:column;align-items:center;gap:1.75rem}
.menu-link{font-family:var(--serif);font-size:2rem;font-weight:300;color:var(--paper);
text-decoration:none;opacity:.8;transition:opacity .3s}
.menu-link:hover,.menu-link:active{opacity:1}
.menu-cta{display:flex;flex-direction:column;gap:.85rem;width:100%;max-width:300px}
.mobile-menu .cta-call:hover{background:var(--paper);color:var(--deep)}
.mobile-menu .cta-wa{color:var(--paper);border-color:rgba(240,237,232,.3)}
.mobile-menu .cta-wa:hover{border-color:var(--stone);color:var(--paper);background:rgba(139,115,85,.15)}
@keyframes menuItemIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.mobile-menu.open .menu-close,.mobile-menu.open .menu-link,.mobile-menu.open .menu-cta{
animation:menuItemIn .55s cubic-bezier(.4,0,.2,1) both}
.mobile-menu.open .menu-links .menu-link:nth-child(1){animation-delay:.08s}
.mobile-menu.open .menu-links .menu-link:nth-child(2){animation-delay:.14s}
.mobile-menu.open .menu-links .menu-link:nth-child(3){animation-delay:.20s}
.mobile-menu.open .menu-links .menu-link:nth-child(4){animation-delay:.26s}
.mobile-menu.open .menu-cta{animation-delay:.36s}

.hero{position:relative;height:100vh;height:100svh;min-height:700px;background:var(--deep);
display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;
background:radial-gradient(ellipse 80% 60% at 50% 40%,rgba(139,115,85,.08),transparent),
radial-gradient(ellipse 50% 50% at 80% 20%,rgba(139,115,85,.05),transparent),
linear-gradient(180deg,transparent 0%,rgba(14,14,14,.4) 100%)}
.hero-bg-pattern{position:absolute;inset:0;opacity:.015;
background-image:repeating-linear-gradient(90deg,var(--paper) 0,var(--paper) 1px,transparent 1px,transparent 120px),
repeating-linear-gradient(0deg,var(--paper) 0,var(--paper) 1px,transparent 1px,transparent 120px)}

.hero-content{position:relative;z-index:2;padding:0 3rem 6rem;max-width:1400px;width:100%}
.hero-eyebrow{font-family:var(--sans);font-size:.7rem;font-weight:300;
letter-spacing:.3em;text-transform:uppercase;color:var(--stone);margin-bottom:1.5rem;
opacity:0;transform:translateY(20px);animation:fadeUp .8s .3s forwards}
.hero-title{font-family:var(--serif);font-weight:300;font-size:clamp(3rem,7vw,6.5rem);
line-height:.95;color:var(--paper);margin-bottom:2rem;
opacity:0;transform:translateY(30px);animation:fadeUp 1s .5s forwards}
.hero-title em{font-style:italic;color:var(--stone)}
.hero-title .hero-accent{color:var(--stone)}
.hero-sub{font-family:var(--sans);font-weight:300;font-size:1rem;
color:rgba(240,237,232,.5);max-width:500px;line-height:1.7;
opacity:0;transform:translateY(20px);animation:fadeUp .8s .8s forwards}

.hero-logo-watermark{position:absolute;top:50%;right:5%;transform:translateY(-50%);
opacity:.03;z-index:1;pointer-events:none}
.hero-logo-watermark img{height:400px;filter:invert(1)}

.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
display:flex;flex-direction:column;align-items:center;gap:.5rem;z-index:2;
opacity:0;animation:fadeUp .6s 1.2s forwards}
.hero-scroll span{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;
color:rgba(240,237,232,.3)}
.hero-scroll-line{width:1px;height:40px;background:linear-gradient(180deg,var(--stone),transparent);
animation:scrollPulse 2s infinite}

@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
@keyframes scrollPulse{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:1;transform:scaleY(.6)}}
/* The signature "signs itself" — one-time left-to-right reveal on load */
@keyframes signIn{from{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}

.reveal{opacity:0;transform:translateY(40px);transition:all .9s cubic-bezier(.4,0,.2,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Typographic polish — avoid single-word orphans/widows */
.hero-title,.section-title{text-wrap:balance}
.quote-text,.hero-sub,.about-body p,.approach-card p,.contact-grid > p{text-wrap:pretty}

.stats-bar{background:var(--deep);border-top:1px solid rgba(240,237,232,.06);
display:grid;grid-template-columns:repeat(3,1fr);padding:0}
.stat{padding:3rem;text-align:center;border-right:1px solid rgba(240,237,232,.06)}
.stat:last-child{border-right:none}
.stat-number{font-family:var(--serif);font-size:3.5rem;font-weight:300;color:var(--stone);line-height:1}
.stat-label{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
color:rgba(240,237,232,.35);margin-top:.5rem}

.section{padding:8rem 3rem}
.section-dark{background:var(--deep);color:var(--paper)}
.section-label{font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;
color:var(--stone);margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem}
.section-label::before{content:'';width:40px;height:1px;background:var(--stone)}
.section-title{font-family:var(--serif);font-weight:300;
font-size:clamp(2rem,4vw,3.5rem);line-height:1.15;margin-bottom:2rem}

.about{max-width:900px;margin:0 auto;text-align:center}
.about .section-label{justify-content:center}
.about .section-label::before{display:none}
.about-body{margin-top:2rem}
.about-body p{font-weight:300;line-height:1.8;color:var(--slate);margin-bottom:1.5rem;
font-size:1.1rem;max-width:780px;margin-left:auto;margin-right:auto}

.quote-section{padding:9rem 3rem;background:var(--paper);text-align:center;position:relative;overflow:hidden}
.quote-section::before{content:'';position:absolute;top:0;left:50%;width:1px;height:60px;
background:linear-gradient(180deg,transparent,var(--stone));transform:translateX(-50%)}
.quote-section::after{content:'';position:absolute;bottom:0;left:50%;width:1px;height:60px;
background:linear-gradient(0deg,transparent,var(--stone));transform:translateX(-50%)}
.quote-inner{max-width:900px;margin:0 auto;position:relative}
.quote-mark{font-family:var(--serif);font-size:10rem;color:var(--stone);opacity:.18;
line-height:1;display:block;margin-bottom:-3rem;font-style:italic}
.quote-text{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:300;
font-style:italic;line-height:1.45;color:var(--ink);margin:0 auto 2.5rem;max-width:780px}
.quote-text em{font-style:normal;color:var(--stone)}
.quote-attribution{font-family:var(--sans);font-size:.7rem;letter-spacing:.3em;
text-transform:uppercase;color:var(--slate);display:flex;align-items:center;justify-content:center;gap:1rem}
.quote-attribution::before,.quote-attribution::after{content:'';width:30px;height:1px;background:var(--warm-gray)}

.projects-header{max-width:1400px;margin:0 auto 3rem;
display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:2rem}
.filter-bar{display:flex;gap:.5rem;flex-wrap:wrap}
.filter-btn{font-family:var(--sans);font-size:.7rem;letter-spacing:.15em;
text-transform:uppercase;padding:.6rem 1.2rem;background:none;border:1px solid rgba(240,237,232,.15);
color:rgba(240,237,232,.4);cursor:pointer;transition:all .3s}
.filter-btn:hover,.filter-btn.active{color:var(--paper);border-color:var(--stone);background:rgba(139,115,85,.15)}

.filter-select-wrap{display:none;position:relative;width:100%}
.filter-select-wrap::after{content:'';position:absolute;right:1.1rem;top:50%;width:8px;height:8px;
border-right:1.5px solid var(--stone);border-bottom:1.5px solid var(--stone);
transform:translateY(-70%) rotate(45deg);pointer-events:none}
#filterSelect{width:100%;appearance:none;-webkit-appearance:none;background:rgba(240,237,232,.04);
border:1px solid rgba(240,237,232,.18);color:var(--paper);font-family:var(--sans);
font-size:.8rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;
padding:.95rem 2.6rem .95rem 1.1rem;cursor:pointer;border-radius:0;min-height:48px}
#filterSelect:focus{outline:none;border-color:var(--stone);background:rgba(139,115,85,.12)}
#filterSelect option{background:var(--deep);color:var(--paper);text-transform:none;letter-spacing:0}

.projects-grid{max-width:1400px;margin:0 auto;
display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.project-card{position:relative;overflow:hidden;cursor:pointer;
aspect-ratio:4/5;background:var(--deep);display:block;color:inherit;text-decoration:none}
.project-card.wide{grid-column:span 2;aspect-ratio:8/5}
.project-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.4,0,.2,1)}
.project-card:hover .project-img{transform:scale(1.05)}
.project-overlay{position:absolute;inset:0;
background:linear-gradient(0deg,rgba(14,14,14,.85) 0%,rgba(14,14,14,.1) 50%,transparent 100%);
transition:all .5s}
.project-card:hover .project-overlay{background:linear-gradient(0deg,rgba(14,14,14,.9) 0%,rgba(14,14,14,.3) 60%,rgba(139,115,85,.05) 100%)}
.project-info{position:absolute;bottom:0;left:0;right:0;padding:2rem;
transform:translateY(10px);transition:transform .5s cubic-bezier(.4,0,.2,1)}
.project-card:hover .project-info{transform:translateY(0)}
.project-category{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--stone);margin-bottom:.5rem}
.project-name{font-family:var(--serif);font-size:1.5rem;font-weight:400;
color:var(--paper);line-height:1.2;margin-bottom:.3rem}
.project-location{font-size:.75rem;font-weight:300;color:rgba(240,237,232,.4)}
.project-details{font-size:.75rem;font-weight:300;color:rgba(240,237,232,.3);
margin-top:.5rem;max-height:0;overflow:hidden;transition:max-height .5s,opacity .5s;opacity:0}
.project-card:hover .project-details{max-height:60px;opacity:1}
.project-badge{position:absolute;top:1.5rem;right:1.5rem;font-size:.6rem;
letter-spacing:.15em;text-transform:uppercase;padding:.4rem .8rem;
background:var(--stone);color:var(--paper);z-index:2}


.approach-grid{max-width:1400px;margin:0 auto;
display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:4rem}
.approach-card{padding:3rem;background:rgba(240,237,232,.03);
border:1px solid rgba(240,237,232,.06);transition:all .5s}
.approach-card:hover{background:rgba(139,115,85,.08);border-color:rgba(139,115,85,.2)}
.approach-num{font-family:var(--serif);font-size:3rem;font-weight:300;
color:var(--stone);opacity:.4;margin-bottom:1.5rem}
.approach-card h4{font-family:var(--serif);font-size:1.4rem;font-weight:400;
color:var(--paper);margin-bottom:1rem}
.approach-card p{font-size:.9rem;font-weight:300;line-height:1.7;
color:rgba(240,237,232,.4)}

.contact-section{max-width:1400px;margin:0 auto}
.contact-grid{max-width:900px;margin:3rem auto 0;text-align:center}
.contact-grid > p{font-weight:300;line-height:1.8;color:var(--slate);font-size:1.05rem;max-width:600px;margin:0 auto}
.contact-info{margin-top:4rem;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;
padding-top:3rem;border-top:1px solid var(--light-gray);text-align:left}
.contact-cell-label{font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;
color:var(--warm-gray);margin-bottom:.75rem}
.contact-cell-value{font-family:var(--serif);font-size:1.2rem;font-weight:300;color:var(--ink);line-height:1.4}
.contact-cell-value a{color:var(--ink);text-decoration:none;transition:color .3s}
.contact-cell-value a:hover{color:var(--stone)}

.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2.5rem}
.cta-call,.cta-wa{display:inline-flex;align-items:center;gap:.7rem;text-decoration:none;
padding:1.1rem 2.2rem;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
font-weight:500;transition:all .3s;min-height:54px}
.cta-call{background:var(--stone);color:var(--paper)}
.cta-call:hover{background:var(--deep);color:var(--paper)}
.cta-wa{background:transparent;color:var(--ink);border:1px solid rgba(26,26,26,.2)}
.cta-wa:hover{border-color:var(--stone);color:var(--stone)}
.cta-call svg,.cta-wa svg{width:18px;height:18px;flex-shrink:0}

.enquiry-intro{text-align:center;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
color:var(--warm-gray);margin-top:3.5rem;display:flex;align-items:center;justify-content:center;gap:1rem}
.enquiry-intro::before,.enquiry-intro::after{content:'';width:40px;height:1px;background:var(--light-gray)}
.enquiry{max-width:520px;margin:2rem auto 0;text-align:left;display:grid;gap:1.4rem}
.enquiry .field{display:flex;flex-direction:column;gap:.4rem}
.enquiry label{font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--warm-gray)}
.enquiry input,.enquiry select,.enquiry textarea{font-family:var(--sans);font-size:1rem;color:var(--ink);
background:transparent;border:none;border-bottom:1px solid var(--light-gray);padding:.55rem 0;transition:border-color .3s}
.enquiry input:focus,.enquiry select:focus,.enquiry textarea:focus{outline:none;border-color:var(--stone)}
.enquiry textarea{resize:vertical;min-height:80px}
.enquiry button.cta-call{width:100%;justify-content:center;border:none;cursor:pointer;
font-family:var(--sans);margin-top:.5rem}
.form-note{text-align:center;font-size:.9rem;color:var(--slate);min-height:1.2em;margin-top:.25rem}

.to-top{position:fixed;bottom:1.5rem;right:1.5rem;z-index:90;width:46px;height:46px;
display:flex;align-items:center;justify-content:center;background:rgba(14,14,14,.7);
backdrop-filter:blur(8px);color:var(--paper);border:1px solid rgba(240,237,232,.18);
cursor:pointer;opacity:0;visibility:hidden;transform:translateY(12px);
transition:opacity .4s,transform .4s,background .3s,border-color .3s}
.to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.to-top:hover{background:var(--stone);border-color:var(--stone)}
.to-top svg{width:18px;height:18px}

.footer{background:var(--deep);padding:3rem;
display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.5rem}
.footer-left{display:flex;align-items:center;gap:2rem}
.footer-logo img{height:24px}
.footer-copy{font-size:.7rem;color:rgba(240,237,232,.3);letter-spacing:.05em}
.footer-right{font-size:.7rem;color:rgba(240,237,232,.3);letter-spacing:.05em}

@media(max-width:1024px){
  .nav{padding:1.2rem 2rem}
  .nav.scrolled{padding:1rem 2rem}
  .projects-grid{grid-template-columns:repeat(2,1fr)}
  .project-card.wide{grid-column:span 1;aspect-ratio:4/5}
  .approach-grid{grid-template-columns:1fr}
  .stats-bar{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid rgba(240,237,232,.06);padding:2rem}
  .stat:last-child{border-bottom:none}
  .quote-section{padding:7rem 2rem}
  .approach-card{padding:2.5rem 2rem}
  .section{padding:6rem 2rem}
}
@media(max-width:768px){
  .brk{display:none}
  .nav{padding:1rem max(1.25rem,env(safe-area-inset-right)) 1rem max(1.25rem,env(safe-area-inset-left))}
  .nav.scrolled{padding:.7rem max(1.25rem,env(safe-area-inset-right)) .7rem max(1.25rem,env(safe-area-inset-left))}
  .nav-logo img{height:52px}
  .nav-links{display:none}
  .hamburger{display:flex}
  .section{padding:4rem 1.25rem}
  .hero{height:auto;min-height:auto;justify-content:flex-start}
  .hero-content{padding:6rem 1.25rem 3.5rem}
  .hero-eyebrow{margin-bottom:1rem;font-size:.65rem}
  .hero-title{margin-bottom:1.25rem}
  .hero-sub{font-size:.95rem}
  .stat{padding:1.75rem}
  .stat-number{font-size:2.75rem}
  .quote-section{padding:4.5rem 1.25rem}
  .quote-section::before,.quote-section::after{height:40px}
  .quote-mark{font-size:6rem;margin-bottom:-1.5rem}
  .quote-attribution{flex-direction:row;font-size:.6rem;letter-spacing:.2em}
  .quote-attribution::before,.quote-attribution::after{width:18px}
  .projects-header{flex-direction:column;align-items:flex-start;gap:1.5rem;margin-bottom:2rem}
  .projects-grid{grid-template-columns:repeat(2,1fr);gap:.6rem}
  .project-card{aspect-ratio:3/4}
  .project-card.wide{grid-column:span 2;aspect-ratio:16/10}
  .project-info{padding:1rem .9rem}
  .project-category{font-size:.55rem;margin-bottom:.3rem}
  .project-name{font-size:1rem;line-height:1.15;margin-bottom:.2rem}
  .project-location{font-size:.7rem}
  .project-card:not(.wide) .project-location{display:none}
  .project-card:not(.wide) .project-name{display:-webkit-box;-webkit-line-clamp:2;
    -webkit-box-orient:vertical;overflow:hidden}
  .project-card.wide .project-info{padding:1.5rem}
  .project-card.wide .project-name{font-size:1.4rem}
  .project-card.wide .project-location{display:block}
  .filter-bar{display:none}
  .filter-select-wrap{display:block}
  .about-body p{font-size:1rem}
  .approach-card{padding:2rem 1.5rem}
  .cta-actions{flex-direction:column}
  .cta-call,.cta-wa{width:100%;justify-content:center}
  .contact-info{grid-template-columns:1fr;gap:1.5rem;text-align:center;margin-top:3rem;padding-top:2rem}
  .contact-cell-value{font-size:1.1rem}
  .footer{flex-direction:column;text-align:center;gap:1rem;padding:2rem 1.25rem}
  .footer-left{flex-direction:column;gap:1rem}
  .hero-logo-watermark{display:none}
}
@media(max-width:480px){
  .hero-eyebrow{letter-spacing:.2em}
  .hero-title{font-size:clamp(2.4rem,11vw,3rem)}
  .hero-scroll{display:none}
  .stat{padding:1.5rem}
  .stat-number{font-size:2.4rem}
  .quote-mark{font-size:4.5rem}
  .quote-text{font-size:1.35rem;line-height:1.4}
  .project-badge{top:1rem;right:1rem;font-size:.55rem}
  .approach-num{font-size:2.25rem;margin-bottom:1rem}
  .approach-card h4{font-size:1.2rem}
}

/* Touch devices: no hover. Keep cards clean — show name/location/category over a
   readable overlay; the full description lives on each project's detail page. */
@media(hover:none){
  .project-info{transform:none}
  .project-overlay{background:linear-gradient(0deg,rgba(14,14,14,.9) 0%,rgba(14,14,14,.35) 45%,transparent 80%)}
  .project-card:active{opacity:.94}
  .filter-btn:active{background:rgba(139,115,85,.25);color:var(--paper)}
  .nav-cta:active{background:var(--paper);color:var(--deep)!important}
  .menu-link:active{opacity:1;color:var(--stone)}
}

/* Respect users who prefer reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal,.reveal-left,.reveal-right{opacity:1!important;transform:none!important}
  .hero-eyebrow,.hero-title,.hero-sub,.hero-scroll{opacity:1!important;transform:none!important;animation:none!important}
  .nav-logo img{animation:none!important;clip-path:none!important}
}
