@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400;1,9..144,500&family=Outfit:wght@300;400;500;600&display=swap');

:root{
  --cream:#F6F0E4;
  --cream-2:#EFE7D6;
  --forest:#27392F;
  --forest-deep:#1B271F;
  --sage:#7C8F6E;
  --brass:#B68D4C;
  --ink:#221E18;
  --ink-soft:#54514A;
  --line:rgba(34,30,24,0.14);
  --line-light:rgba(246,240,228,0.22);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:'Outfit',sans-serif;
  font-weight:300;
  line-height:1.65;
  overflow-x:hidden;
}
h1,h2,h3,h4{
  font-family:'Fraunces',serif;
  font-weight:500;
  line-height:1.08;
  letter-spacing:-0.01em;
}
em, .em{
  font-family:'Fraunces',serif;
  font-style:italic;
  font-weight:400;
  color:var(--forest);
}
a{color:inherit;text-decoration:none;}
img{display:block;width:100%;height:100%;object-fit:cover;}
.wrap{max-width:1180px;margin:0 auto;padding:0 32px;}
.eyebrow{
  font-size:13px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--sage);
  font-weight:500;
  display:flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:'';
  width:22px;height:1px;
  background:var(--brass);
  display:inline-block;
}
section{position:relative;}
.reveal{opacity:0; transform:translateY(28px); transition:opacity 0.9s ease, transform 0.9s ease;}
.reveal.in{opacity:1; transform:translateY(0);}

/* INTRO SPLASH */
.intro{
  position:fixed; inset:0; z-index:999;
  background:var(--forest-deep);
  display:flex; align-items:center; justify-content:center;
  transition:opacity 0.8s ease, visibility 0.8s ease;
}
.intro.hide{opacity:0; visibility:hidden; pointer-events:none;}
.intro-mark{
  display:flex; flex-direction:column; align-items:center; gap:18px;
}
.intro-mark .name{
  font-family:'Fraunces',serif; color:var(--cream); font-size:22px; letter-spacing:0.02em;
  opacity:0; transform:translateY(8px);
  animation:riseIn 0.8s ease forwards 0.5s;
}
.intro-mark .sub{
  font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--sage);
  opacity:0; transform:translateY(8px);
  animation:riseIn 0.8s ease forwards 0.7s;
}
@keyframes riseIn{ to{opacity:1; transform:translateY(0);} }
.intro-mark img.intro-logo{
  width:120px; height:auto; opacity:0;
  animation:logoFadeIn 0.9s ease forwards, logoPulse 1.8s ease-in-out infinite 0.9s;
}
@keyframes logoFadeIn{ to{opacity:1;} }
@keyframes logoPulse{ 0%,100%{opacity:1;} 50%{opacity:0.55;} }

/* NAV */
nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 32px;
  background:rgba(246,240,228,0.0);
  transition:background 0.4s ease, padding 0.4s ease, box-shadow 0.4s ease;
}
nav.scrolled{
  background:rgba(246,240,228,0.92);
  backdrop-filter:blur(10px);
  padding:14px 32px;
  box-shadow:0 1px 0 var(--line);
}
.logo{
  font-family:'Fraunces',serif;
  font-size:20px;
  font-weight:500;
  letter-spacing:0.01em;
  display:flex;
  align-items:baseline;
  gap:8px;
}
.logo span{font-family:'Outfit',sans-serif; font-size:11px; letter-spacing:0.1em; color:var(--ink-soft); text-transform:uppercase;}
.nav-links{display:flex; gap:30px; font-size:14px; letter-spacing:0.01em;}
.nav-links a{position:relative; padding-bottom:4px;}
.nav-links a::after{
  content:''; position:absolute; left:0; bottom:0; width:0; height:1px;
  background:var(--forest); transition:width 0.3s ease;
}
.nav-links a:hover::after, .nav-links a.active::after{width:100%;}
.nav-cta{
  border:1px solid var(--forest);
  padding:9px 20px;
  border-radius:2px;
  font-size:13px;
  letter-spacing:0.04em;
  transition:background 0.3s ease, color 0.3s ease;
  white-space:nowrap;
}
.nav-cta:hover{background:var(--forest); color:var(--cream);}
nav.on-dark:not(.scrolled) .logo{color:var(--cream);}
nav.on-dark:not(.scrolled) .logo span{color:rgba(246,240,228,0.65);}
nav.on-dark:not(.scrolled) .nav-links a{color:var(--cream);}
nav.on-dark:not(.scrolled) .nav-links a::after{background:var(--cream);}
nav.on-dark:not(.scrolled) .nav-cta{color:var(--cream); border-color:var(--cream);}
nav.on-dark:not(.scrolled) .nav-toggle span{background:var(--cream);}
nav.on-dark .nav-links.open a{color:var(--ink);}
nav.on-dark .nav-links.open a::after{background:var(--forest);}
nav.on-dark .nav-toggle.open span{background:var(--ink);}
.nav-toggle{
  display:none; background:none; border:none; cursor:pointer;
  width:28px; height:20px; flex-direction:column; justify-content:space-between;
  padding:0; z-index:201;
}
.nav-toggle span{display:block; height:1.5px; width:100%; background:var(--ink); transition:transform 0.3s ease, opacity 0.3s ease;}
.nav-toggle.open span:nth-child(1){transform:translateY(8.5px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:translateY(-8.5px) rotate(-45deg);}

/* PAGE HEADER (non-home pages) */
.page-header{
  padding:170px 0 90px;
  background:var(--forest);
  color:var(--cream);
}
.page-header .eyebrow{color:var(--brass);}
.page-header .eyebrow::before{background:var(--cream);}
.page-header h1{font-size:clamp(36px,5vw,58px); color:var(--cream); margin-top:18px; max-width:760px;}
.page-header h1 em{color:var(--brass);}
.page-header p.sub{margin-top:20px; max-width:560px; color:rgba(246,240,228,0.75); font-size:16.5px;}
.breadcrumb{font-size:13px; color:rgba(246,240,228,0.55); margin-bottom:18px;}
.breadcrumb a:hover{color:var(--cream);}

/* BUTTONS */
.btn-primary{
  background:var(--forest);
  color:var(--cream);
  padding:15px 30px;
  border-radius:2px;
  font-size:14px;
  letter-spacing:0.03em;
  display:inline-flex;
  align-items:center;
  gap:10px;
  transition:background 0.3s ease, transform 0.3s ease;
}
.btn-primary:hover{background:var(--forest-deep); transform:translateY(-1px);}
.btn-ghost{
  border-bottom:1px solid var(--ink);
  padding:15px 0;
  font-size:14px;
  letter-spacing:0.03em;
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.btn-ghost.on-dark{border-bottom-color:var(--cream); color:var(--cream);}
a.linkmore{
  display:inline-flex; align-items:center; gap:8px;
  margin-top:14px; font-size:14px; color:var(--forest);
  border-bottom:1px solid var(--sage); padding-bottom:3px;
}

/* HERO (home) */
.hero{min-height:100vh; display:flex; align-items:center; padding-top:90px; position:relative;}
.hero-grid{display:grid; grid-template-columns:1fr 0.92fr; gap:60px; align-items:center; width:100%;}
.hero-text h1{font-size:clamp(40px, 5.4vw, 68px); letter-spacing:-0.015em; margin-top:26px;}
.hero-text p.lead{margin-top:26px; max-width:480px; font-size:17px; color:var(--ink-soft);}
.hero-cta-row{display:flex; gap:18px; margin-top:40px; flex-wrap:wrap;}
.hero-img{position:relative; aspect-ratio:3/4; border-radius:2px; overflow:hidden;}
.hero-img video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  display:block; z-index:2; background:var(--cream-2);
}
.hero-fallback-img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1;
}
.hero-img .tag{position:absolute; bottom:22px; left:22px; background:rgba(34,30,24,0.55); backdrop-filter:blur(6px); color:var(--cream); padding:9px 16px; font-size:12.5px; letter-spacing:0.04em; border-radius:2px;}
.compass{position:absolute; top:-40px; left:-60px; width:170px; height:170px; opacity:0.55; z-index:-1;}
.stat-row{display:flex; gap:50px; margin-top:64px; flex-wrap:wrap; border-top:1px solid var(--line); padding-top:34px;}
.stat-row .stat{display:flex; flex-direction:column; gap:4px;}
.stat-row .num{font-family:'Fraunces',serif; font-size:30px; font-weight:500; color:var(--forest);}
.stat-row .label{font-size:12.5px; color:var(--ink-soft); letter-spacing:0.03em;}

/* STORY / GENERIC SPLIT */
.split{padding:130px 0;}
.split-grid{display:grid; grid-template-columns:0.85fr 1.15fr; gap:80px; align-items:center;}
.split-grid.reverse{grid-template-columns:1.15fr 0.85fr;}
.split-grid.reverse .split-img{order:2;}
.split-img{aspect-ratio:4/5; overflow:hidden; border-radius:2px; position:relative;}
.split h2{font-size:clamp(30px, 3.6vw, 44px); margin:18px 0 26px;}
.split p{color:var(--ink-soft); font-size:16px; max-width:560px; margin-bottom:18px;}

/* SERVICES (dark band) */
.services{background:var(--forest); color:var(--cream); padding:130px 0;}
.services .eyebrow{color:var(--brass);}
.services .eyebrow::before{background:var(--cream);}
.services h2{font-size:clamp(30px, 3.6vw, 44px); color:var(--cream); max-width:680px; margin:18px 0 70px;}
.services h2 em{color:var(--brass);}
.service-list{display:flex; flex-direction:column;}
.service-row{display:grid; grid-template-columns:120px 1fr 1fr; gap:40px; align-items:start; padding:38px 0; border-top:1px solid var(--line-light); transition:background 0.35s ease;}
.service-list .service-row:last-child{border-bottom:1px solid var(--line-light);}
.service-row:hover{background:rgba(246,240,228,0.04);}
.service-mark{font-family:'Fraunces',serif; font-style:italic; font-size:15px; color:var(--sage); padding-top:6px;}
.service-row h3{font-size:25px; color:var(--cream); font-weight:500;}
.service-row p{color:rgba(246,240,228,0.68); font-size:15.5px; padding-top:6px;}

/* SERVICE DETAIL CARDS (services page) */
.service-detail-grid{display:flex; flex-direction:column; gap:0;}
.service-detail{display:grid; grid-template-columns:0.9fr 1.1fr; gap:60px; padding:90px 0; border-top:1px solid var(--line); align-items:center;}
.service-detail:first-child{border-top:none;}
.service-detail.reverse{grid-template-columns:1.1fr 0.9fr;}
.service-detail.reverse .sd-img{order:2;}
.sd-img{aspect-ratio:4/3; overflow:hidden; border-radius:2px;}
.service-detail h3{font-size:30px; margin:14px 0 18px;}
.service-detail ul{margin-top:18px; display:flex; flex-direction:column; gap:10px;}
.service-detail ul li{font-size:14.5px; color:var(--ink-soft); padding-left:20px; position:relative;}
.service-detail ul li::before{content:''; position:absolute; left:0; top:9px; width:7px; height:1px; background:var(--brass);}

/* PROJECTS GRID */
.proj-head{display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:64px; gap:30px; flex-wrap:wrap;}
.proj-head h2{font-size:clamp(30px, 3.6vw, 44px); max-width:520px;}
.proj-grid{display:grid; grid-template-columns:1.3fr 1fr; gap:28px;}
.proj-card{position:relative; overflow:hidden; border-radius:2px; cursor:pointer;}
.proj-card.tall{aspect-ratio:4/5;}
.proj-card.wide{aspect-ratio:4/5;}
.proj-card img{transition:transform 0.7s cubic-bezier(.2,.7,.2,1);}
.proj-card:hover img{transform:scale(1.06);}
.proj-overlay{position:absolute; inset:0; background:linear-gradient(180deg, rgba(34,30,24,0) 40%, rgba(27,18,12,0.82) 100%); display:flex; flex-direction:column; justify-content:flex-end; padding:28px; color:var(--cream);}
.proj-overlay .tagline{font-size:12px; letter-spacing:0.08em; text-transform:uppercase; color:var(--brass); margin-bottom:8px;}
.proj-overlay h3{font-size:24px; color:var(--cream); margin-bottom:8px;}
.proj-overlay p{font-size:14px; color:rgba(246,240,228,0.78); max-width:380px;}
.proj-stack{display:flex; flex-direction:column; gap:28px;}

/* FULL PROJECT GALLERY GRID (projects page) */
.gallery-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:28px;}
.gallery-grid .proj-card{aspect-ratio:4/5;}

/* PLACEHOLDER PROJECT CARD (no image yet) */
.proj-card.placeholder{
  background:var(--cream-2);
  border:1px dashed var(--line);
  display:flex; flex-direction:column; justify-content:space-between;
  padding:28px;
}
.proj-card.placeholder .ph-icon{
  width:40px; height:40px; border:1px solid var(--sage); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--sage); font-family:'Fraunces',serif; font-style:italic; font-size:18px;
}
.proj-card.placeholder .tagline{color:var(--brass); font-size:12px; letter-spacing:0.08em; text-transform:uppercase; margin-bottom:8px;}
.proj-card.placeholder h3{font-size:22px; margin-bottom:8px; color:var(--ink);}
.proj-card.placeholder p{font-size:14px; color:var(--ink-soft); max-width:340px;}
.proj-card.placeholder .ph-note{
  font-size:12px; color:var(--sage); letter-spacing:0.03em; margin-top:18px;
  border-top:1px dashed var(--line); padding-top:14px;
}

/* TESTIMONIALS */
.testimonials{background:var(--cream-2); padding:130px 0;}
.test-grid{display:grid; grid-template-columns:repeat(2, 1fr); gap:1px; background:var(--line); border:1px solid var(--line);}
.test-card{background:var(--cream-2); padding:48px 44px;}
.test-card .quote-mark{font-family:'Fraunces',serif; font-size:54px; color:var(--sage); line-height:0.4; display:block; margin-bottom:18px;}
.test-card p.quote{font-family:'Fraunces',serif; font-style:italic; font-size:19px; line-height:1.5; color:var(--ink); margin-bottom:22px;}
.test-card .who{font-size:13.5px; color:var(--ink-soft); letter-spacing:0.02em;}

/* CONTACT */
.contact-band{padding:150px 0 100px; text-align:center;}
.contact-band .eyebrow{justify-content:center;}
.contact-band h2{font-size:clamp(34px, 5vw, 58px); max-width:780px; margin:20px auto 40px;}
.contact-cta-row{display:flex; justify-content:center; gap:20px; flex-wrap:wrap;}

/* CONTACT PAGE FORM */
.contact-page-grid{display:grid; grid-template-columns:1fr 1fr; gap:70px; padding:120px 0;}
.contact-info h3{font-size:26px; margin-bottom:20px;}
.contact-info .info-row{display:flex; flex-direction:column; gap:6px; margin-bottom:26px;}
.contact-info .info-row .lbl{font-size:12px; letter-spacing:0.08em; text-transform:uppercase; color:var(--sage);}
.contact-info .info-row .val{font-size:16px;}
.form-field{margin-bottom:22px;}
.form-field label{display:block; font-size:12.5px; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:8px;}
.form-field input, .form-field textarea{
  width:100%; border:none; border-bottom:1px solid var(--line); background:transparent;
  padding:10px 0; font-family:'Outfit',sans-serif; font-size:15px; color:var(--ink);
  outline:none; transition:border-color 0.3s ease;
}
.form-field input:focus, .form-field textarea:focus{border-color:var(--forest);}
.form-submit{
  margin-top:10px; background:var(--forest); color:var(--cream); padding:15px 34px;
  border:none; border-radius:2px; font-family:'Outfit',sans-serif; font-size:14px;
  letter-spacing:0.03em; cursor:pointer; transition:background 0.3s ease;
}
.form-submit:hover{background:var(--forest-deep);}

/* MAP-ish strip */
.map-strip{height:340px; background:var(--cream-2); display:flex; align-items:center; justify-content:center; border-top:1px solid var(--line); border-bottom:1px solid var(--line);}
.map-strip .addr{font-family:'Fraunces',serif; font-style:italic; font-size:20px; color:var(--ink-soft); text-align:center;}

/* FOOTER */
footer{background:var(--forest-deep); color:rgba(246,240,228,0.72); padding:80px 0 30px;}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:50px; padding-bottom:50px; border-bottom:1px solid var(--line-light);}
.foot-grid h4{color:var(--cream); font-size:18px; margin-bottom:18px; font-weight:500;}
.foot-logo{font-family:'Fraunces',serif; color:var(--cream); font-size:22px; margin-bottom:16px;}
.foot-grid p, .foot-grid li{font-size:14.5px; margin-bottom:10px; color:rgba(246,240,228,0.68);}
.foot-grid ul{list-style:none;}
.foot-bottom{display:flex; justify-content:space-between; padding-top:26px; font-size:13px; color:rgba(246,240,228,0.5); flex-wrap:wrap; gap:12px;}

@media (max-width:880px){
  .nav-links{
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    gap:34px; font-size:20px;
    position:fixed; inset:0; background:var(--cream); z-index:150;
    transform:translateY(-100%); opacity:0; visibility:hidden;
    transition:transform 0.4s ease, opacity 0.4s ease, visibility 0.4s ease;
  }
  .nav-links.open{transform:translateY(0); opacity:1; visibility:visible;}
  .nav-toggle{display:flex;}
  .nav-cta{display:none;}
  .nav-links a.nav-cta-mobile{
    border:1px solid var(--forest); padding:12px 26px; border-radius:2px; font-size:15px; margin-top:10px;
  }
  .hero-grid, .split-grid, .proj-grid, .foot-grid, .service-detail, .contact-page-grid, .gallery-grid{grid-template-columns:1fr !important;}
  .test-grid{grid-template-columns:1fr;}
  .service-row{grid-template-columns:1fr; gap:10px;}
  .hero{padding-top:120px;}
  .compass{display:none;}
  .proj-stack{flex-direction:row;}
  .proj-card.wide{flex:1;}
  .page-header{padding:140px 0 70px;}
}

/* FULL-BLEED QUOTE BANNER */
.quote-banner{
  position:relative; min-height:62vh;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.quote-banner img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0;}
.quote-banner::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(27,18,12,0.55), rgba(27,18,12,0.75));
  z-index:1;
}
.quote-banner .quote-content{position:relative; z-index:2; text-align:center; max-width:780px; padding:0 32px;}
.quote-banner p{
  font-family:'Fraunces',serif; font-style:italic; font-weight:400;
  font-size:clamp(26px, 3.4vw, 42px); color:var(--cream); line-height:1.35;
}
.quote-banner .who{margin-top:26px; font-size:13px; letter-spacing:0.1em; text-transform:uppercase; color:var(--brass);}

/* FEATURE STRIP */
.feature-strip{padding:110px 0; background:var(--cream-2);}
.feature-strip .eyebrow{justify-content:center;}
.feature-strip-head{text-align:center; margin-bottom:60px;}
.feature-strip-head h2{font-size:clamp(28px,3.4vw,40px); margin-top:18px;}
.feature-strip-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line);}
.feature-card{background:var(--cream-2); padding:42px 32px; text-align:left;}
.feature-card .f-num{font-family:'Fraunces',serif; font-style:italic; font-size:15px; color:var(--sage); display:block; margin-bottom:22px;}
.feature-card h4{font-size:19px; margin-bottom:12px;}
.feature-card p{font-size:14px; color:var(--ink-soft);}
@media (max-width:880px){
  .feature-strip-grid{grid-template-columns:1fr;}
}
