:root{
  --bone:#f4f0e8; --bone-2:#eae4d8; --ink:#26211c; --ink-soft:#5b554c;
  --clay:#a8643c; --clay-deep:#8a4f2d; --line:rgba(38,33,28,.14);
  --serif:"Fraunces",Georgia,serif; --sans:"Hanken Grotesk",-apple-system,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bone);color:var(--ink);font-family:var(--sans);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--clay);color:var(--bone)}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover}
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
.eyebrow{font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--clay-deep)}

/* Header */
header{position:fixed;top:0;left:0;right:0;z-index:100;backdrop-filter:blur(8px);background:rgba(244,240,232,.78);border-bottom:1px solid transparent;transition:border-color .4s}
header.scrolled{border-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:var(--serif);font-size:21px;font-weight:500}
.brand span{color:var(--clay)}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{font-size:14px;font-weight:500;color:var(--ink-soft);position:relative;transition:color .25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--clay);transition:width .3s}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a.active::after{width:100%}
.nav-links a:hover::after{width:100%}
.nav-cta{border:1px solid var(--ink);padding:9px 20px;border-radius:40px;font-size:13px;font-weight:600;color:var(--ink)!important;transition:.3s}
.nav-cta::after{display:none}
.nav-cta:hover{background:var(--ink);color:var(--bone)!important}
.menu-btn{display:none;font-size:14px;font-weight:600}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:9px;padding:15px 26px;border-radius:40px;font-size:14px;font-weight:600;transition:transform .25s,background .3s}
.btn-primary{background:var(--ink);color:var(--bone)}
.btn-primary:hover{background:var(--clay-deep);transform:translateY(-2px)}
.btn-ghost{color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn .arr{transition:transform .3s}
.btn:hover .arr{transform:translate(3px,-3px)}
.hero-actions{display:flex;gap:16px;align-items:center;flex-wrap:wrap}

/* Home hero */
.hero{padding:150px 0 0}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:end}
.hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(44px,6vw,82px);line-height:.98;letter-spacing:-.015em;margin:22px 0 26px}
.hero h1 em{font-style:italic;color:var(--clay)}
.hero p{font-size:18px;color:var(--ink-soft);max-width:30ch;margin-bottom:34px}
.hero-img{position:relative;aspect-ratio:4/4.6;border-radius:6px;overflow:hidden;box-shadow:0 40px 80px -30px rgba(38,33,28,.4)}
.hero-img img{transition:transform 1.2s cubic-bezier(.2,.8,.2,1)}
.hero-img:hover img{transform:scale(1.04)}
.hero-tag{position:absolute;left:18px;bottom:18px;z-index:2;background:rgba(244,240,232,.92);backdrop-filter:blur(4px);padding:9px 16px;border-radius:40px;font-size:12px;font-weight:600;letter-spacing:.04em}

/* Inner page hero */
.page-hero{padding:160px 0 70px}
.page-hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(42px,5.5vw,74px);line-height:1;letter-spacing:-.015em;margin:20px 0 22px;max-width:18ch}
.page-hero h1 em{font-style:italic;color:var(--clay)}
.page-hero p{font-size:18px;color:var(--ink-soft);max-width:52ch}

.marquee-strip{margin-top:90px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:18px 0}
.marquee{display:flex;gap:64px;white-space:nowrap;animation:scroll 32s linear infinite;width:max-content}
.marquee span{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--ink-soft);display:flex;align-items:center;gap:64px}
.marquee span::after{content:"✦";color:var(--clay);font-style:normal;font-size:13px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* Sections */
.section{padding:120px 0}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:54px;gap:40px;flex-wrap:wrap}
.sec-head h2{font-family:var(--serif);font-weight:300;font-size:clamp(32px,4vw,52px);line-height:1.05;letter-spacing:-.01em;max-width:18ch}
.sec-head p{color:var(--ink-soft);max-width:38ch;font-size:16px}

/* Services */
.services{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden}
.service{background:var(--bone);padding:38px 30px 34px;min-height:230px;display:flex;flex-direction:column;justify-content:space-between;transition:background .4s}
.service:hover{background:var(--bone-2)}
.service .num{font-family:var(--serif);font-size:13px;color:var(--clay);letter-spacing:.1em}
.service h3{font-family:var(--serif);font-weight:400;font-size:25px;margin:auto 0 12px}
.service p{font-size:14px;color:var(--ink-soft);line-height:1.5}

/* Projects */
.projects{display:flex;flex-direction:column;gap:8px}
.project{display:grid;grid-template-columns:.85fr 1.15fr;border-top:1px solid var(--line);align-items:stretch;transition:background .4s}
.project:hover{background:var(--bone-2)}
.proj-info{padding:46px 40px 46px 8px;display:flex;flex-direction:column;justify-content:center}
.proj-info .loc{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--clay-deep);font-weight:600}
.proj-info h3{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3vw,42px);line-height:1.02;margin:10px 0 16px;letter-spacing:-.01em}
.proj-info p{font-size:15px;color:var(--ink-soft);max-width:40ch}
.proj-imgs{display:grid;grid-template-columns:1.4fr 1fr;gap:8px;padding:14px 0 14px 14px}
.proj-imgs > div{overflow:hidden;border-radius:4px;min-height:300px}
.proj-imgs img{transition:transform 1s cubic-bezier(.2,.8,.2,1)}
.project:hover .proj-imgs img{transform:scale(1.05)}

/* Dark band / craft */
.craft{background:var(--ink);color:var(--bone);border-radius:6px;overflow:hidden;padding:80px 0}
.craft .eyebrow{color:#d99a6c}
.craft h2{font-family:var(--serif);font-weight:300;font-size:clamp(30px,3.4vw,46px);line-height:1.08;margin:18px 0 14px;letter-spacing:-.01em}
.craft > .wrap > p{color:rgba(244,240,232,.72);font-size:16px;max-width:52ch;margin-bottom:44px}
.craft-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.craft-item{position:relative;aspect-ratio:3/4;border-radius:4px;overflow:hidden}
.craft-item img{transition:transform .9s cubic-bezier(.2,.8,.2,1)}
.craft-item:hover img{transform:scale(1.06)}
.craft-item span{position:absolute;left:12px;bottom:12px;background:rgba(38,33,28,.78);backdrop-filter:blur(4px);color:var(--bone);padding:7px 13px;border-radius:30px;font-size:12px;font-weight:500;letter-spacing:.03em}

/* Progress grid */
.progress-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.progress-item{position:relative;aspect-ratio:4/3;border-radius:4px;overflow:hidden}
.progress-item img{transition:transform .9s cubic-bezier(.2,.8,.2,1)}
.progress-item:hover img{transform:scale(1.05)}
.progress-item span{position:absolute;left:12px;bottom:12px;background:rgba(244,240,232,.92);padding:7px 13px;border-radius:30px;font-size:12px;font-weight:600}

/* About page */
.about-band{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.about-band h2{font-family:var(--serif);font-weight:300;font-size:clamp(30px,3.6vw,48px);line-height:1.06;letter-spacing:-.01em;margin:16px 0 22px}
.about-band p{color:var(--ink-soft);font-size:16px;margin-bottom:16px;max-width:54ch}
.about-img{border-radius:6px;overflow:hidden;aspect-ratio:4/5;box-shadow:0 30px 60px -25px rgba(38,33,28,.35)}
.stats{display:flex;gap:48px;margin-top:38px;flex-wrap:wrap}
.stat .n{font-family:var(--serif);font-size:40px;color:var(--clay-deep);line-height:1}
.stat .l{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-top:8px}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden}
.value{background:var(--bone);padding:38px 32px}
.value h3{font-family:var(--serif);font-weight:400;font-size:24px;margin-bottom:12px}
.value p{font-size:14.5px;color:var(--ink-soft)}

/* Areas page */
.areas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden}
.area{background:var(--bone);padding:36px 30px;transition:background .4s}
.area:hover{background:var(--bone-2)}
.area h3{font-family:var(--serif);font-weight:400;font-size:24px;margin-bottom:10px}
.area p{font-size:14.5px;color:var(--ink-soft)}

/* Contact page */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-card{border:1px solid var(--line);border-radius:6px;padding:36px;margin-bottom:16px;transition:background .4s,border-color .4s;display:block}
.contact-card:hover{background:var(--bone-2);border-color:var(--ink)}
.contact-card .label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--clay-deep);font-weight:600;margin-bottom:10px}
.contact-card .big{font-family:var(--serif);font-size:clamp(20px,2.4vw,28px);font-weight:400}
.steps{counter-reset:step}
.step{border-top:1px solid var(--line);padding:26px 0;display:grid;grid-template-columns:60px 1fr;gap:18px;align-items:baseline}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--serif);font-style:italic;font-size:24px;color:var(--clay)}
.step h3{font-family:var(--serif);font-weight:400;font-size:21px;margin-bottom:6px}
.step p{font-size:14.5px;color:var(--ink-soft)}

/* CTA */
.cta{text-align:center;padding:130px 0}
.cta .eyebrow{display:block;margin-bottom:22px}
.cta h2{font-family:var(--serif);font-weight:300;font-size:clamp(40px,6vw,86px);line-height:.98;letter-spacing:-.02em;margin-bottom:34px}
.cta h2 em{font-style:italic;color:var(--clay)}
.cta .phone{font-family:var(--serif);font-size:22px;margin-top:30px;color:var(--ink-soft)}
.cta .phone a{color:var(--ink);border-bottom:1px solid var(--clay);padding-bottom:2px}

/* Footer */
footer{background:var(--ink);color:var(--bone);padding:72px 0 40px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(244,240,232,.14)}
.foot-brand{font-family:var(--serif);font-size:26px;font-weight:500}
.foot-brand span{color:#d99a6c}
.foot-grid p{color:rgba(244,240,232,.62);font-size:15px;margin-top:16px;max-width:34ch}
.foot-col h4{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(244,240,232,.5);margin-bottom:18px;font-weight:600}
.foot-col a,.foot-col p{display:block;color:rgba(244,240,232,.82);font-size:15px;margin:0 0 11px;transition:color .25s}
.foot-col a:hover{color:#d99a6c}
.foot-bottom{display:flex;justify-content:space-between;padding-top:28px;font-size:13px;color:rgba(244,240,232,.5);flex-wrap:wrap;gap:12px}

/* Reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.8,.2,1),transform .9s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}

/* Responsive */
@media(max-width:900px){
  .nav-links{display:none}.menu-btn{display:block}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-img{aspect-ratio:4/5;order:-1}
  .services{grid-template-columns:1fr 1fr}
  .project{grid-template-columns:1fr}
  .proj-info{padding:36px 0 8px}
  .proj-imgs{padding:0}
  .craft-grid{grid-template-columns:1fr 1fr}
  .progress-grid{grid-template-columns:1fr 1fr}
  .about-band{grid-template-columns:1fr;gap:36px}
  .about-img{order:-1;aspect-ratio:4/3}
  .values{grid-template-columns:1fr}
  .areas-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .foot-grid{grid-template-columns:1fr;gap:36px}
}
@media(max-width:560px){
  .wrap{padding:0 22px}
  .services{grid-template-columns:1fr}
  .proj-imgs{grid-template-columns:1fr}
  .progress-grid{grid-template-columns:1fr}
  .areas-grid{grid-template-columns:1fr}
}


/* Contact enquiry form */
.form-card{border:1px solid var(--line);border-radius:6px;padding:clamp(28px,4vw,48px);background:var(--bone)}
.form-card .field{margin-bottom:20px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-card label{display:block;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--clay-deep);font-weight:600;margin-bottom:8px}
.form-card input,.form-card select,.form-card textarea{width:100%;font-family:var(--sans);font-size:15px;color:var(--ink);background:var(--bone-2);border:1px solid var(--line);border-radius:6px;padding:13px 15px;transition:border-color .3s,background .3s}
.form-card input:focus,.form-card select:focus,.form-card textarea:focus{outline:none;border-color:var(--ink);background:#fff}
.form-card textarea{resize:vertical}
.form-card button{margin-top:6px;border:none;cursor:pointer}
.hp{position:absolute;left:-9999px;visibility:hidden}
@media(max-width:680px){.field-row{grid-template-columns:1fr;gap:0}}

/* Prose (privacy/legal) */
.prose{max-width:760px}
.prose h2{font-family:var(--serif);font-weight:400;font-size:clamp(22px,2.4vw,28px);margin:34px 0 12px}
.prose h2:first-child{margin-top:0}
.prose p{font-size:15.5px;color:var(--ink-soft);margin-bottom:14px}
.prose a{color:var(--clay-deep);text-decoration:underline}
