*,*::before,*::after{box-sizing:border-box}
:root{
  --cream:#f5f0e8;
  --cream-dark:#ede7d9;
  --stone:#c8bfaf;
  --ink:#1a1714;
  --ink-2:#3d3830;
  --muted:#746c62;
  --soft:#f9f6f0;
  --accent:#c8a97e;
  --white:#fff;
  --serif:"Playfair Display",serif;
  --sans:"Outfit",sans-serif;
}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.7;
}
a{color:inherit}
img,video{display:block;max-width:100%}
.site-wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.site-nav{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(245,240,232,.94);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--cream-dark);
}
.site-nav-inner{
  min-height:84px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
}
.brand{
  font-family:var(--serif);
  font-size:17px;
  text-decoration:none;
  white-space:nowrap;
}
.brand em{font-style:italic;color:var(--accent)}
.nav-menu{display:flex;align-items:center;gap:30px}
.nav-menu a{
  text-decoration:none;
  color:var(--muted);
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  font-weight:500;
  transition:color .25s,background .25s,border-color .25s;
  white-space:nowrap;
}
.nav-menu a:hover,.nav-menu a.active{color:var(--ink)}
.nav-cta{
  border:1px solid var(--ink);
  color:var(--ink)!important;
  padding:11px 20px;
}
.nav-cta:hover{background:var(--ink);color:var(--cream)!important}
.menu-toggle{
  display:none;
  width:44px;
  height:44px;
  border:1px solid var(--ink);
  background:transparent;
  color:var(--ink);
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
}
.menu-toggle span{width:18px;height:1px;background:currentColor;display:block;transition:.25s}
.site-nav.open .menu-toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.site-nav.open .menu-toggle span:nth-child(2){opacity:0}
.site-nav.open .menu-toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.page-hero{padding:96px 0 64px}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(320px,.75fr);gap:70px;align-items:end}
.eyebrow{
  display:flex;
  align-items:center;
  gap:12px;
  color:var(--muted);
  font-size:10px;
  letter-spacing:4px;
  text-transform:uppercase;
  margin-bottom:24px;
}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--accent);flex:0 0 auto}
h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.05;letter-spacing:-.5px}
h1{font-size:clamp(44px,6.5vw,84px);margin:0 0 24px;max-width:900px}
h1 em,h2 em{font-style:italic;color:var(--muted)}
.lead{max-width:700px;color:#5f574e;font-size:18px;margin:0}
.hero-card{
  background:var(--ink);
  color:var(--cream);
  min-height:360px;
  padding:36px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  position:relative;
  overflow:hidden;
}
.hero-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.42;filter:grayscale(18%)}
.hero-card .hc-body{position:relative;z-index:1}
.hero-card small,.metric small,.card small,.project-tag,.step-num{
  color:var(--accent);
  font-size:10px;
  letter-spacing:3px;
  text-transform:uppercase;
  font-weight:500;
}
.hero-card strong{display:block;font-family:var(--serif);font-size:32px;font-weight:400;margin-top:8px}
.section{padding:72px 0;border-top:1px solid var(--cream-dark)}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:34px}
.section-head h2{font-size:clamp(34px,4vw,56px);margin:0}
.section-head p{max-width:520px;color:var(--muted);margin:0}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--cream-dark)}
.card{background:var(--white);padding:32px;min-height:220px;text-decoration:none;color:inherit}
.card h2,.card h3{font-size:25px;margin:18px 0 12px}
.card p,.card li{color:var(--muted)}
.card ul,.split ul{margin:16px 0 0;padding-left:18px;color:var(--muted)}
.metric-row{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--cream-dark);border-bottom:1px solid var(--cream-dark)}
.metric{padding:28px 24px;border-right:1px solid var(--cream-dark)}
.metric:last-child{border-right:0}
.metric strong{display:block;font-family:var(--serif);font-size:36px;font-weight:400;line-height:1;color:var(--ink)}
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start}
.split-panel{background:var(--white);border:1px solid var(--cream-dark);padding:36px}
.split-panel h2{font-size:38px;margin:0 0 18px}
.split-panel p{color:var(--muted)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--cream-dark)}
.step{background:var(--soft);padding:28px;min-height:190px}
.step h3{font-size:23px;margin:16px 0 10px}
.step p{color:var(--muted);margin:0}
.projects{display:flex;flex-direction:column;gap:18px}
.project{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:430px;
  background:var(--white);
  border:1px solid var(--cream-dark);
  overflow:hidden;
}
.project:nth-child(even) .project-media{order:2}
.project-media img,.project-media video{width:100%;height:100%;min-height:360px;object-fit:cover;filter:grayscale(12%)}
.project-info{padding:48px;display:flex;flex-direction:column;justify-content:center}
.project-info h2{font-size:clamp(30px,3.4vw,48px);margin:14px 0 16px}
.project-info p{color:var(--muted);margin:0 0 20px}
.mini-stats{display:flex;gap:28px;flex-wrap:wrap;margin-top:10px}
.mini-stats strong{display:block;font-family:var(--serif);font-size:30px;font-weight:400;line-height:1}
.quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.quote{background:var(--white);border:1px solid var(--cream-dark);padding:30px}
.stars{color:var(--accent);letter-spacing:3px;margin-bottom:12px}
.quote p{color:var(--muted);font-style:italic}
.quote strong{display:block;margin-top:18px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.blog-card{background:var(--white);border:1px solid var(--cream-dark);overflow:hidden;text-decoration:none;color:inherit}
.blog-card img{width:100%;height:220px;object-fit:cover;filter:grayscale(12%)}
.blog-body{padding:26px}
.blog-body h2{font-size:25px;margin:12px 0 10px}
.blog-body p{color:var(--muted)}
.faq{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.faq-item{background:var(--white);border:1px solid var(--cream-dark);padding:28px}
.faq-item h3{font-size:24px;margin:0 0 10px}
.faq-item p{color:var(--muted);margin:0}
.cta-band{
  margin:72px 0 80px;
  background:var(--ink);
  color:var(--cream);
  padding:54px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:32px;
  align-items:center;
}
.cta-band h2{font-size:clamp(34px,4.5vw,62px);margin:0 0 14px}
.cta-band p{color:var(--stone);margin:0;max-width:620px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  border:1px solid var(--accent);
  padding:13px 24px;
  color:var(--cream);
  text-decoration:none;
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  font-weight:500;
  white-space:nowrap;
}
.btn.dark{color:var(--ink);border-color:var(--ink)}
.footer{border-top:1px solid var(--cream-dark);padding:34px 0 44px;color:var(--muted);font-size:13px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.dynamic-section.is-hidden{display:none}
.cookie-consent{
  position:fixed;
  left:24px;
  right:24px;
  bottom:24px;
  z-index:100;
  max-width:780px;
  margin:auto;
  background:rgba(26,23,20,.96);
  color:var(--cream);
  border:1px solid rgba(200,169,126,.35);
  padding:18px 20px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  box-shadow:0 20px 70px rgba(0,0,0,.28);
}
.cookie-consent strong{font-family:var(--serif);font-size:20px;font-weight:400}
.cookie-consent p{margin:4px 0 0;color:var(--stone);font-size:13px}
.cookie-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.cookie-actions a,.cookie-actions button{
  border:1px solid rgba(245,240,232,.22);
  background:transparent;
  color:var(--cream);
  padding:10px 13px;
  text-decoration:none;
  font:500 10px/1 var(--sans);
  letter-spacing:1.6px;
  text-transform:uppercase;
}
.cookie-actions button[data-cookie="accept"]{background:var(--accent);border-color:var(--accent);color:var(--ink)}
@media(max-width:980px){
  .hero-grid,.split,.project,.cta-band{grid-template-columns:1fr}
  .project:nth-child(even) .project-media{order:0}
  .cards,.blog-grid,.quote-grid{grid-template-columns:repeat(2,1fr)}
  .metric-row,.steps{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:1040px){
  .site-nav-inner{min-height:72px}
  .menu-toggle{display:flex}
  .nav-menu{
    display:none;
    position:absolute;
    top:72px;
    left:0;
    right:0;
    background:rgba(245,240,232,.98);
    border-bottom:1px solid var(--cream-dark);
    padding:18px 28px 24px;
    flex-direction:column;
    align-items:stretch;
    gap:0;
  }
  .site-nav.open .nav-menu{display:flex}
  .nav-menu a{padding:15px 0;border-bottom:1px solid var(--cream-dark)}
  .nav-cta{text-align:center;margin-top:14px;padding:13px 18px!important;background:var(--ink);color:var(--cream)!important}
}
@media(max-width:760px){
  .site-wrap{padding:0 22px}
  .nav-menu{padding-left:22px;padding-right:22px}
  .page-hero{padding:58px 0 42px}
  h1{font-size:clamp(42px,13vw,62px)}
  .lead{font-size:16px}
  .hero-card{min-height:280px}
  .section{padding:54px 0}
  .section-head{display:block}
  .section-head p{margin-top:14px}
  .cards,.blog-grid,.quote-grid,.faq{grid-template-columns:1fr}
  .metric-row,.steps{grid-template-columns:1fr}
  .metric{border-right:0;border-bottom:1px solid var(--cream-dark)}
  .project-info{padding:30px}
  .cta-band{padding:34px 26px}
  .cookie-consent{display:block;left:16px;right:16px;bottom:16px}
  .cookie-actions{justify-content:flex-start;margin-top:14px}
}
