:root{
  --heading-accent:#751A0C;
  --accent:#d62a20;
  --accent-deep:#811b0d;
  --cookie-safe:64px;
}

.has-cookie-safe{
  padding-bottom:var(--cookie-safe);
}


.breadcrumbs{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(0,0,0,.55);
  margin-bottom:1.5rem;
}
.breadcrumbs a{
  text-decoration:none;
  color:rgba(0,0,0,.55);
}
.breadcrumbs a:hover{
  color:#111;
  text-decoration:underline;
  text-decoration-thickness:1px;
  text-underline-offset:3px;
}


.page-hero.page-hero-split,
.project-hero{
  padding:3.2rem 0 2.6rem;
}

.page-hero-grid,
.project-hero-grid{
  display:grid;
  grid-template-columns:1.05fr 1.2fr;
  gap:3.2rem;
  align-items:center;
}

.page-hero-copy,
.project-hero-copy{
  max-width:520px;
}

.page-hero h1{
  margin:0 0 .9rem;
  font-family:"Playfair Display",serif;
  font-weight:500;
  font-size:clamp(2.1rem,4vw,2.7rem);
  line-height:1.2;
  color:var(--heading-accent);
}

.page-lead,
.project-lead{
  margin:0;
  color:rgba(0,0,0,.55);
  font-size:1rem;
  max-width:720px;
}

.page-actions{
  margin-top:1.6rem;
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
}

.page-hero-media,
.project-hero-media{
  width:100%;
  aspect-ratio:4/3;
  border-radius:16px;
  overflow:hidden;
  background:#2a2a2a;
}

.page-hero-media img,
.project-hero-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}


.content-section{
  padding:4.2rem 0;
}

.content-grid{
  display:grid;
  grid-template-columns:1.6fr .8fr;
  gap:3.2rem;
  align-items:start;
}


.content-main h2,
.project-article h2{
  font-family:"Playfair Display",serif;
  font-weight:500;
  font-size:1.65rem;
  margin:2.6rem 0 1.1rem;
  color:var(--heading-accent);
}


.content-main p,
.project-article p{
  color:#2b2b2b;
}


.content-steps{
  margin:0 0 2.1rem;
  padding-left:1.25rem;
  color:#2b2b2b;
}
.content-steps li+li{
  margin-top:.7rem;
}


.content-aside{
  display:grid;
  gap:1.2rem;
}

.content-card,
.project-card{
  border:1px solid rgba(0,0,0,.06);
  border-radius:14px;
  padding:1.35rem 1.25rem;
  background:rgba(0,0,0,.015);
}


.content-card h3,
.project-card h3,
.faq-item h3{
  font-family:"Playfair Display",serif;
  font-weight:500;
  font-size:1.25rem;
  margin:0 0 .9rem;
  color:#111;
}


.content-faq h3,
.faq-item h3{
  text-transform:none;
  letter-spacing:normal;
}


.content-card p{
  margin:0;
  color:#2b2b2b;
}

.content-list{
  margin:0;
  padding-left:1.1rem;
  color:#2b2b2b;
}
.content-list li+li{
  margin-top:.45rem;
}


.content-faq{
  display:grid;
  gap:1.4rem;
  margin-top:.6rem;
}

.faq-item h3{
  display:flex;
  align-items:baseline;
  line-height:1.3;
}

.faq-bullet{
  width:8px;
  height:8px;
  background:rgba(0,0,0,.35);
  border-radius:999px;
  margin-right:.55rem;
  transform:translateY(-1px);
  flex:0 0 auto;
}


.faq-item p{
  margin:0;
  color:#2b2b2b;
  max-width:620px;
}


.projects-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:2.8rem 1.8rem;
}

.project-image{
  width:100%;
  aspect-ratio:4/3;
  border-radius:14px;
  overflow:hidden;
  background:#2a2a2a;
  border:1px solid rgba(0,0,0,.06);
}

.project-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.project h3{
  margin:.9rem 0 0;
  font-family:"Playfair Display",serif;
  font-weight:500;
  font-size:1rem;
}

.project h3 a{
  text-decoration:none;
}
.project h3 a:hover{
  color:var(--accent);
}


.project-body{
  padding:4.2rem 0 4.8rem;
}

.project-layout{
  display:grid;
  grid-template-columns:1.55fr .75fr;
  gap:3.2rem;
  align-items:start;
}

.project-title{
  margin:0 0 .9rem;
  font-family:"Playfair Display",serif;
  font-weight:500;
  font-size:clamp(2.3rem,4.2vw,3.2rem);
  line-height:1.15;
  color:var(--heading-accent);
}

.project-inline-media{
  margin:0 0 2.1rem;
}
.project-inline-media img{
  width:100%;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.06);
}

.project-aside{
  position:sticky;
  top:110px;
  display:grid;
  gap:1.2rem;
  align-self:start;
}

.project-meta{
  margin:0;
  display:grid;
  gap: .55rem;
}
.project-meta dt{
  font-size:.74rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(0,0,0,.55);
  margin: 0 0 .1rem;
}
.project-meta dd{
  margin:0;
  color:#111;
  font-size:.92rem;
}


.service-tags{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
}

.tag{
  display:inline-flex;
  align-items:center;
  border:1px solid rgba(0,0,0,.14);
  border-radius:999px;
  padding:.45rem .8rem;
  font-size:.74rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  text-decoration:none;
  color:#111;
  background:transparent;
}
.tag:hover{
  border-color:rgba(0,0,0,.35);
  color:var(--accent);
}


.projects-grid-4{
  grid-template-columns:repeat(4,minmax(0,1fr));
  row-gap:2.8rem;
}


.site-footer{
  background:#2c2c2c;
}


@media (max-width:980px){
  .page-hero-grid,
  .project-hero-grid{
    grid-template-columns:1fr;
    gap:1.6rem;
  }

  .content-grid,
  .project-layout{
    grid-template-columns:1fr;
    gap:2.2rem;
  }

  .project-aside{
    position:static;
  }

  .projects-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .projects-grid-4{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media (max-width:720px){
  :root{--cookie-safe:92px}

  .projects-grid,
  .projects-grid-4{
    grid-template-columns:1fr;
  }
}

.content-card h3{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  font-size: .78rem;
  margin-bottom: .85rem;
  color: rgba(0,0,0,.75);
}

.faq-item h3{
  margin:0 0 .35rem;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  font-weight:500;
  font-size:1.05rem;
  color:var(--text);
  text-transform:none;
  letter-spacing:normal;
  display:flex;
  align-items:baseline;
  line-height:1.35;
}

.card-note {
  margin-bottom: 1.2rem;
  font-size: 1rem;
  color: var(--text-muted);
}

.content-list {
  margin-top: 0.8rem;
}

.phases-list {
  padding-left: 1.2rem;
}

.phases-list li {
  margin-bottom: 1.6rem;
}

.phases-list li:last-child {
  margin-bottom: 0;
}

.phases-list strong {
  display: block;
  margin-bottom: 0.35rem;
  font-weight: 500;
}

.phases-list p {
  margin: 0;
}

body {
  padding-bottom: 0;
}

.has-cookie-safe{ padding-bottom:0; }

/* Sidebar CTA: ensure it renders as a button even if link styles exist elsewhere */
.project-sidebar-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  border-radius:4px;
  padding:0.6rem 1.35rem;
  font-size:0.86rem;
  font-weight:500;
  text-decoration:none;
  border:1px solid var(--accent);
  background-color:var(--accent);
  color:#ffffff;
}
.project-sidebar-cta:hover{
  background-color:var(--accent-deep);
  border-color:var(--accent-deep);
  color:#ffffff;
}

.project-article figure {
  margin: 2rem 0;
}

.project-article figure img {
  max-width: 100%;
  width: auto;
  height: auto;
}