:root{
  --background:#f5f1e8; --foreground:#1f2a24;
  --cream:#faf6ec; --sand:#ece5d3; --sand-deep:#ddd3bc;
  --moss:#2f4a3a; --moss-soft:#5a6f5f; --olive:#8a9a5b; --ink:#15201a;
  --border:#d8d0bc;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;font-weight:300;color:var(--foreground);background:var(--background);line-height:1.6;letter-spacing:.005em}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,.font-display{font-family:'Cormorant Garamond',serif;font-weight:400;letter-spacing:-.01em;line-height:1.05}
.italic{font-style:italic}
.container{max-width:1240px;margin:0 auto;padding:0 24px}
@media(min-width:768px){.container{padding:0 40px}}
.eyebrow{font-family:'Inter',sans-serif;text-transform:uppercase;letter-spacing:.28em;font-size:.7rem;font-weight:500;color:var(--moss-soft)}

/* Header */
.header{position:absolute;top:0;left:0;right:0;z-index:50}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:24px 0;color:var(--cream)}
.logo{display:flex;align-items:center;gap:8px;font-family:'Cormorant Garamond',serif;font-size:1.25rem}
.nav{display:none;gap:36px;font-size:.875rem}
.nav a{opacity:.85;transition:opacity .3s}
.nav a:hover{opacity:1}
.cta-link{display:none;align-items:center;gap:8px;font-size:.875rem;border-bottom:1px solid rgba(250,246,236,.4);padding-bottom:4px;transition:border-color .3s}
.cta-link:hover{border-color:var(--cream)}
@media(min-width:768px){.nav,.cta-link{display:inline-flex}}

/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(20,40,30,.55),rgba(30,45,35,.25),rgba(15,30,22,.85))}
.hero-content{position:relative;padding:160px 0 96px;color:var(--cream)}
.hero h1{font-size:clamp(3rem,7vw,6rem);margin-top:24px;max-width:980px}
.hero h1 .italic{opacity:.85}
.hero-bottom{margin-top:40px;display:flex;flex-direction:column;gap:32px;max-width:980px}
.hero-bottom p{max-width:560px;font-size:1.05rem;color:rgba(250,246,236,.8)}
.hero-actions{display:flex;align-items:center;gap:16px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:0 32px;height:48px;background:var(--cream);color:var(--moss);font-size:.9rem;font-weight:500;transition:opacity .3s}
.btn:hover{opacity:.9}
.link-underline{font-size:.875rem;color:rgba(250,246,236,.85);border-bottom:1px solid rgba(250,246,236,.4);padding-bottom:4px;transition:border-color .3s}
.link-underline:hover{border-color:var(--cream)}
@media(min-width:768px){.hero-bottom{flex-direction:row;align-items:flex-end;justify-content:space-between}.hero-content{padding-bottom:128px}}

/* Marquee */
.marquee-section{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--cream);overflow:hidden;padding:24px 0}
.marquee{display:flex;gap:64px;white-space:nowrap;animation:marquee 40s linear infinite;font-family:'Cormorant Garamond',serif;font-size:1.875rem;color:rgba(90,111,95,.7)}
.marquee-group{display:flex;gap:64px;flex-shrink:0}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Sections */
section{padding:112px 0}
@media(min-width:768px){section{padding:160px 0}}

/* About */
.about-grid{display:grid;gap:48px;align-items:center}
.about-img{width:100%;height:520px;object-fit:cover;box-shadow:0 30px 60px -30px rgba(20,30,25,.25)}
.about h2{font-size:clamp(2.25rem,4vw,3.75rem);margin-top:20px;color:var(--moss)}
.about p{margin-top:24px;color:var(--moss-soft);font-size:1.075rem}
.about p+p{margin-top:20px;font-size:1rem}
.stats{margin-top:40px;display:grid;grid-template-columns:repeat(2,1fr);gap:32px 24px}
.stat-v{font-family:'Cormorant Garamond',serif;font-size:2.25rem;color:var(--moss)}
.stat-l{font-size:.875rem;color:var(--moss-soft);margin-top:4px}
@media(min-width:768px){.about-grid{grid-template-columns:5fr 1fr 6fr}.about-text{grid-column:3}}

/* Services */
.services{background:var(--sand)}
.services-head{display:flex;flex-direction:column;gap:24px;margin-bottom:64px}
.services-head h2{font-size:clamp(2.25rem,4vw,3.75rem);margin-top:20px;color:var(--moss);max-width:640px}
.services-head p{color:var(--moss-soft);max-width:380px}
@media(min-width:768px){.services-head{flex-direction:row;align-items:flex-end;justify-content:space-between}}
.services-grid{display:grid;gap:32px}
@media(min-width:768px){.services-grid{grid-template-columns:repeat(3,1fr)}}
.service{background:var(--cream);box-shadow:0 1px 0 rgba(216,208,188,.6),0 24px 48px -24px rgba(20,30,25,.18);overflow:hidden;transition:transform .3s}
.service-img{overflow:hidden;height:288px}
.service-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s ease-out}
.service:hover .service-img img{transform:scale(1.04)}
.service-body{padding:32px}
.service-meta{display:flex;justify-content:space-between;font-size:.75rem;color:var(--moss-soft)}
.service h3{font-size:1.75rem;margin-top:16px;color:var(--moss)}
.service-body>p{margin-top:16px;color:var(--moss-soft)}

/* Approach */
.approach-grid{display:grid;gap:48px}
@media(min-width:768px){.approach-grid{grid-template-columns:1fr 2fr}}
.approach h2{font-size:clamp(2.25rem,3.5vw,3rem);margin-top:20px;color:var(--moss)}
.approach-intro p{color:var(--moss-soft);margin-top:24px;max-width:380px}
.approach-items{display:grid;gap:48px 40px}
@media(min-width:640px){.approach-items{grid-template-columns:repeat(2,1fr)}}
.approach-item{border-top:1px solid var(--border);padding-top:24px}
.approach-item-head{display:flex;justify-content:space-between;align-items:center;color:var(--moss-soft)}
.approach-item-head .num{font-family:'Cormorant Garamond',serif;font-size:1.25rem}
.approach-item h3{font-size:1.75rem;margin-top:24px;color:var(--moss)}
.approach-item p{margin-top:12px;color:var(--moss-soft)}

/* Projects */
.projects{background:var(--sand-deep)}
.projects-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:48px}
.projects-head h2{font-size:clamp(2.25rem,3.5vw,3rem);margin-top:20px;color:var(--moss)}
.projects-head a{display:none;align-items:center;gap:8px;font-size:.875rem;color:var(--moss);border-bottom:1px solid rgba(47,74,58,.4);padding-bottom:4px}
@media(min-width:768px){.projects-head a{display:inline-flex}}
.project-list{list-style:none}
.project{display:grid;grid-template-columns:auto 1fr auto auto;gap:16px;align-items:center;padding:32px 0;border-top:1px solid rgba(47,74,58,.15);cursor:pointer;transition:padding .3s}
.project:last-child{border-bottom:1px solid rgba(47,74,58,.15)}
.project-year{color:var(--moss-soft);min-width:60px}
.project-title{font-family:'Cormorant Garamond',serif;font-size:1.75rem;color:var(--moss);transition:font-style .3s}
.project:hover .project-title{font-style:italic}
.project-loc{color:var(--moss-soft);font-size:.875rem}
.project-arrow{transition:transform .3s}
.project:hover .project-arrow{transform:translate(4px,-4px)}
@media(max-width:767px){.project{grid-template-columns:1fr auto}.project-year{grid-column:1}.project-arrow{grid-column:2;grid-row:1}.project-title{grid-column:1/-1}.project-loc{grid-column:1/-1}}

/* Quote */
.quote{text-align:center}
.quote-icon{margin:0 auto;color:var(--olive)}
.quote blockquote{font-family:'Cormorant Garamond',serif;font-size:clamp(1.875rem,4vw,3rem);line-height:1.15;color:var(--moss);margin-top:40px;font-style:italic}
.quote-author{margin-top:40px;color:var(--moss-soft)}

/* Contact */
.contact{background:linear-gradient(135deg,#2c4536,#3a5043);color:var(--cream)}
.contact-grid{display:grid;gap:48px}
@media(min-width:768px){.contact-grid{grid-template-columns:7fr 5fr}}
.contact .eyebrow{color:rgba(250,246,236,.7)}
.contact h2{font-size:clamp(2.25rem,4.5vw,4rem);margin-top:20px}
.contact h2 .italic{opacity:.85}
.contact>div>p{margin-top:24px;max-width:520px;color:rgba(250,246,236,.75)}
.contact-info{display:flex;flex-direction:column;gap:32px}
.contact-info .label{color:rgba(250,246,236,.6);font-size:.875rem;text-transform:uppercase;letter-spacing:.2em}
.contact-info .value{font-family:'Cormorant Garamond',serif;font-size:1.5rem;margin-top:8px;display:inline-block}
.contact-info .value.link{border-bottom:1px solid rgba(250,246,236,.3);padding-bottom:4px;transition:border-color .3s}
.contact-info .value.link:hover{border-color:var(--cream)}
.contact-info .addr{margin-top:8px;line-height:1.6}

/* Footer */
.footer{background:var(--ink);color:rgba(250,246,236,.7);padding:40px 0}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:16px;font-size:.875rem;text-align:center}
@media(min-width:768px){.footer-inner{flex-direction:row;justify-content:space-between;text-align:left}}
.footer .logo{color:var(--cream);font-size:1rem}

/* Reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 1.1s cubic-bezier(.22,1,.36,1),transform 1.1s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}

/* Icons */
.icon{width:20px;height:20px;stroke:currentColor;stroke-width:1.4;fill:none}
.icon-lg{width:32px;height:32px;stroke-width:1.2}
.icon-md{width:24px;height:24px;stroke-width:1.3}
