:root{
  --bg:#f4f1eb;
  --surface:#ffffff;
  --surface-soft:#ebe4d8;
  --text:#1f1d1a;
  --muted:#6f6a62;
  --line:#ddd4c7;
  --accent:#26231f;
  --max:1240px;
  --radius:24px;
  --shadow:0 18px 48px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
.container{width:min(92%, var(--max));margin:0 auto}
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(244,241,235,.88);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(0,0,0,.06);
}
.nav{
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.brand{
  font-size:1rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.nav-links{
  display:flex;
  gap:28px;
  flex-wrap:wrap;
}
.nav-links a{
  color:var(--muted);
  font-size:.94rem;
}
.nav-links a:hover,
.nav-links a.active{color:var(--text)}
.section{padding:96px 0}
.eyebrow{
  display:block;
  margin-bottom:14px;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.78rem;
  font-weight:700;
  color:var(--muted);
}
.section-title{
  margin:0 0 16px;
  font-size:clamp(2rem,3.3vw,3.5rem);
  line-height:1.02;
  letter-spacing:-.045em;
}
.lead{
  margin:0;
  max-width:760px;
  font-size:1.08rem;
  color:var(--muted);
}
.hero{padding:34px 0 36px}
.hero-grid{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:34px;
  align-items:stretch;
}
.hero-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:44px 6px 44px 0;
}
.hero-copy h1{
  margin:0 0 18px;
  font-size:clamp(3rem,5.4vw,5.7rem);
  line-height:.95;
  letter-spacing:-.06em;
}
.hero-copy p{
  margin:0 0 30px;
  max-width:620px;
  font-size:1.1rem;
  color:var(--muted);
}
.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-bottom:34px;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 22px;
  border-radius:999px;
  border:1px solid var(--accent);
  font-size:.95rem;
  font-weight:600;
  transition:.25s ease;
}
.btn-dark{background:var(--accent);color:#fff}
.btn-dark:hover{transform:translateY(-1px);opacity:.95}
.btn-light{background:transparent;color:var(--text)}
.btn-light:hover{background:rgba(0,0,0,.03)}
.hero-meta{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  padding-top:24px;
  border-top:1px solid var(--line);
}
.hero-meta strong{display:block;font-size:1rem}
.hero-meta span{display:block;margin-top:4px;color:var(--muted);font-size:.92rem}
.hero-visual{
  position:relative;
  min-height:680px;
  border-radius:30px;
  overflow:hidden;
  box-shadow:var(--shadow);
  background:#d7d0c4 url('images/hero.jpg') center/cover no-repeat;
}
.hero-visual:after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.22));
}
.floating-card{
  position:absolute;
  left:24px;
  bottom:24px;
  z-index:2;
  width:min(86%, 380px);
  background:rgba(255,255,255,.92);
  border-radius:18px;
  padding:18px 18px;
  box-shadow:0 10px 28px rgba(0,0,0,.08);
}
.floating-card strong{display:block;margin-bottom:6px}
.floating-card span{color:var(--muted);font-size:.93rem}
.band{
  background:var(--surface);
  border-top:1px solid rgba(0,0,0,.04);
  border-bottom:1px solid rgba(0,0,0,.04);
}
.split{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:34px;
  align-items:start;
}
.cards-4{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:22px;
  margin-top:28px;
}
.card{
  background:var(--surface);
  border-radius:var(--radius);
  padding:28px;
  box-shadow:var(--shadow);
}
.card h3{margin:0 0 10px;font-size:1.18rem}
.card p{margin:0;color:var(--muted)}
.feature-grid{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:30px;
  align-items:center;
}
.image-frame{
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow);
  background:var(--surface);
}
.image-frame img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.mosaic{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:22px;
  margin-top:26px;
}
.tile{
  background:var(--surface);
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.tile img{
  width:100%;
  aspect-ratio:1.12/1;
  object-fit:cover;
}
.tile-copy{padding:18px 20px 20px}
.tile-copy small{
  display:block;
  margin-bottom:8px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.12em;
}
.tile-copy h3{margin:0 0 8px;font-size:1.14rem}
.tile-copy p{margin:0;color:var(--muted)}
.value-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin-top:28px;
}
.value{
  background:var(--surface-soft);
  border-radius:20px;
  padding:24px;
}
.value h3{margin:0 0 10px;font-size:1.02rem}
.value p{margin:0;color:var(--muted);font-size:.96rem}
.cta-box{
  background:var(--accent);
  color:#fff;
  border-radius:30px;
  padding:54px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:24px;
  align-items:end;
  box-shadow:var(--shadow);
}
.cta-box p{
  margin:12px 0 0;
  color:rgba(255,255,255,.78);
  max-width:680px;
}
.footer{
  padding:34px 0 48px;
  border-top:1px solid rgba(0,0,0,.06);
}
.footer-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
}
.footer small{color:var(--muted)}
/* Projects page */
.page-hero{
  padding:70px 0 28px;
}
.page-hero-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:34px;
  align-items:end;
}
.project-stack{
  display:grid;
  gap:42px;
}
.project-hero{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:28px;
  align-items:center;
}
.project-copy p{margin:0 0 14px;color:var(--muted)}
.project-gallery{
  display:grid;
  grid-template-columns:1.16fr .84fr .84fr;
  gap:22px;
}
.project-gallery .image-frame img{min-height:310px}
.note-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.note{
  background:var(--surface);
  border-radius:20px;
  padding:22px;
  box-shadow:var(--shadow);
}
.note h4{margin:0 0 8px;font-size:1rem}
.note p{margin:0;color:var(--muted);font-size:.96rem}
.pair-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
}
.project-card{
  background:var(--surface);
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.project-card img{
  width:100%;
  aspect-ratio:1.32/1;
  object-fit:cover;
}
.project-card-copy{padding:20px 22px 24px}
.project-card-copy small{
  display:block;
  margin-bottom:8px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.12em;
}
.project-card-copy h3{margin:0 0 8px}
.project-card-copy p{margin:0;color:var(--muted)}
.approach{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:30px;
  align-items:center;
}
@media (max-width: 980px){
  .hero-grid,.split,.feature-grid,.page-hero-grid,.project-hero,.approach,.cta-box{grid-template-columns:1fr}
  .hero-visual{min-height:520px}
  .hero-meta,.note-grid{grid-template-columns:repeat(2,1fr)}
  .value-grid{grid-template-columns:repeat(2,1fr)}
  .project-gallery{grid-template-columns:1fr 1fr}
}
@media (max-width: 720px){
  .section{padding:72px 0}
  .nav{min-height:68px}
  .cards-4,.mosaic,.value-grid,.pair-grid,.note-grid,.project-gallery,.hero-meta{grid-template-columns:1fr}
  .footer-row{flex-direction:column;align-items:flex-start}
  .cta-box{padding:34px}
}


/* v11 aligned image + text cards */
.detail-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.detail-card{
  background:var(--surface);
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.detail-card img{
  width:100%;
  aspect-ratio:1.1/1;
  object-fit:cover;
}
.detail-copy{
  padding:20px 22px 24px;
}
.detail-copy h4{
  margin:0 0 8px;
  font-size:1rem;
}
.detail-copy p{
  margin:0;
  color:var(--muted);
  font-size:.96rem;
}
@media (max-width: 980px){
  .detail-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 720px){
  .detail-grid{grid-template-columns:1fr}
}



/* --- v13 DESIGN POLISH --- */

body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Inter, sans-serif;
}

/* smoother buttons */
.btn {
    transition: all 0.25s ease;
}
.btn:hover {
    transform: translateY(-2px);
}

/* image hover */
.image-frame img,
.project-card img,
.tile img {
    transition: transform 0.4s ease;
}
.image-frame:hover img,
.project-card:hover img,
.tile:hover img {
    transform: scale(1.04);
}

/* subtle card hover */
.card,
.project-card,
.detail-card {
    transition: all 0.25s ease;
}
.card:hover,
.project-card:hover,
.detail-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 25px 60px rgba(0,0,0,0.12);
}

/* better spacing */
.section {
    padding: 110px 0;
}

/* typography refinement */
.section-title {
    letter-spacing: -0.04em;
}

.lead {
    line-height: 1.7;
}

/* CTA stronger */
.cta-box {
    background: linear-gradient(135deg, #1f1d1a, #2f2b25);
}

/* nav refinement */
.nav-links a {
    position: relative;
}
.nav-links a::after {
    content: "";
    position: absolute;
    bottom: -4px;
    left: 0;
    width: 0%;
    height: 1px;
    background: #222;
    transition: 0.25s;
}
.nav-links a:hover::after {
    width: 100%;
}



/* v15 services image layout */
.service-layout{
  display:grid;
  gap:24px;
}
.service-feature{
  padding:0;
  overflow:hidden;
}
.service-feature-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:0;
  align-items:stretch;
}
.service-feature-copy{
  padding:28px;
}
.service-feature-copy small{
  display:block;
  margin-bottom:8px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.12em;
}
.service-feature-copy h3{
  margin:0 0 12px;
}
.service-feature-copy p{
  margin:0 0 10px;
  color:var(--muted);
}
.service-image-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  min-height:100%;
}
.service-image-grid img{
  width:100%;
  height:100%;
  object-fit:cover;
  min-height:320px;
}
.service-visualization img{
  width:100%;
  aspect-ratio:1.6/1;
  object-fit:cover;
}
@media (max-width: 980px){
  .service-feature-grid{
    grid-template-columns:1fr;
  }
  .service-image-grid{
    grid-template-columns:repeat(3,1fr);
  }
}
@media (max-width: 720px){
  .service-image-grid{
    grid-template-columns:1fr;
  }
  .service-image-grid img{
    min-height:220px;
  }
}



/* v16 cleanup */
.page-wrap{padding-top:18px}
.service-page{display:grid;gap:28px}
.service-hero{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
  align-items:stretch;
}
.placeholder{
  min-height:100%;
  border-radius:28px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.52), rgba(255,255,255,.18)),
    repeating-linear-gradient(
      -45deg,
      #ddd6cc 0px,
      #ddd6cc 18px,
      #e9e3d8 18px,
      #e9e3d8 36px
    );
  border:1px dashed rgba(38,35,31,.18);
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  box-shadow:var(--shadow);
}
.placeholder span{
  display:block;
  padding:20px;
  color:var(--muted);
  font-size:.95rem;
  line-height:1.5;
  max-width:260px;
}
.placeholder.tall{min-height:520px}
.placeholder.medium{min-height:340px}
.placeholder.short{min-height:220px}

.service-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
}
.service-block{
  background:var(--surface);
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.service-block-copy{
  padding:24px 24px 28px;
}
.service-block-copy small{
  display:block;
  margin-bottom:8px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.12em;
}
.service-block-copy h3{
  margin:0 0 10px;
  font-size:1.25rem;
}
.service-block-copy p{
  margin:0 0 10px;
  color:var(--muted);
}
.service-list{
  margin:14px 0 0;
  padding-left:18px;
  color:var(--muted);
}
.service-list li{margin:6px 0}
.service-feature-clean{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:28px;
  align-items:stretch;
}
.deliverables-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.deliverable{
  background:var(--surface-soft);
  border-radius:20px;
  padding:22px;
}
.deliverable h4{margin:0 0 8px;font-size:1rem}
.deliverable p{margin:0;color:var(--muted);font-size:.96rem}
.faq-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}
.faq-item{
  background:var(--surface);
  border-radius:20px;
  padding:22px;
  box-shadow:var(--shadow);
}
.faq-item h4{margin:0 0 8px;font-size:1rem}
.faq-item p{margin:0;color:var(--muted);font-size:.96rem}
.simple-page{
  display:grid;
  gap:26px;
}
.simple-card{
  background:var(--surface);
  border-radius:24px;
  padding:28px;
  box-shadow:var(--shadow);
}
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.contact-line{margin:10px 0;color:var(--muted)}
@media (max-width: 980px){
  .service-hero,
  .service-feature-clean,
  .contact-grid{grid-template-columns:1fr}
  .deliverables-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 720px){
  .service-grid,
  .deliverables-grid,
  .faq-grid{grid-template-columns:1fr}
}



/* v23 projects refinements */
.apartment-project{
  background:var(--surface);
  border-radius:30px;
  padding:32px;
  box-shadow:var(--shadow);
}
.apartment-head{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:24px;
  align-items:start;
  margin-bottom:24px;
}
.apartment-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr .85fr;
  gap:20px;
  align-items:stretch;
}
.apartment-main{
  grid-row:span 2;
  border-radius:22px;
  overflow:hidden;
  background:var(--surface-soft);
}
.apartment-main img{
  width:100%;
  height:100%;
  min-height:520px;
  object-fit:cover;
}
.apartment-detail{
  background:var(--bg);
  border-radius:22px;
  overflow:hidden;
}
.apartment-detail img{
  width:100%;
  aspect-ratio:1.18/1;
  object-fit:cover;
}
.apartment-detail-copy{
  padding:18px 18px 20px;
}
.apartment-detail-copy h4{
  margin:0 0 8px;
  font-size:1rem;
}
.apartment-detail-copy p{
  margin:0;
  color:var(--muted);
  font-size:.94rem;
}
.bathroom-study-card{
  padding:0;
  overflow:hidden;
}
.bath-study-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
}
.bath-study-grid img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
}
@media (max-width: 980px){
  .apartment-head,
  .apartment-grid{
    grid-template-columns:1fr;
  }
  .apartment-main{
    grid-row:auto;
  }
  .apartment-main img{
    min-height:360px;
  }
}
@media (max-width: 720px){
  .bath-study-grid{
    grid-template-columns:1fr;
  }
}



/* v24 projects refinement */
.apartment-title-row{
  margin-bottom:20px;
}
.apartment-hero-row{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:20px;
  align-items:stretch;
  margin-bottom:20px;
}
.apartment-text-panel{
  background:var(--bg);
  border-radius:22px;
  padding:26px;
}
.apartment-cards-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.apartment-detail{
  background:var(--bg);
  border-radius:22px;
  overflow:hidden;
}
.pair-grid{
  grid-template-columns:1fr;
}
.bathroom-study-row{
  margin-top:24px;
}
.bathroom-study-card{
  padding:0;
  overflow:hidden;
}
.bathroom-study-head{
  display:grid;
  grid-template-columns:.6fr 1.4fr;
  gap:20px;
  padding:22px 24px 18px;
}
.bathroom-study-head small{
  display:block;
  margin-bottom:8px;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.12em;
}
.bathroom-study-head h3{
  margin:0;
}
.bathroom-study-head p{
  margin:0;
  color:var(--muted);
}
.bath-study-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
}
.bath-study-grid img{
  width:100%;
  aspect-ratio:1.2/1;
  object-fit:cover;
}
@media (max-width: 980px){
  .apartment-hero-row,
  .apartment-cards-row,
  .bathroom-study-head{
    grid-template-columns:1fr;
  }
}
@media (max-width: 720px){
  .bath-study-grid{
    grid-template-columns:1fr;
  }
}



/* v26 fix: prevent oversized white card in Services */
.service-grid{
  align-items:start;
}
.service-block{
  height:auto;
  align-self:start;
}






/* v32 definitive Services image layout */
.service-hero-image img{
  width:100%;
  min-height:520px;
  object-fit:cover;
}

.service-advanced-v25{
  overflow:hidden;
}

.service-advanced-v25 img{
  width:100%;
  aspect-ratio:1.5/1;
  object-fit:cover;
}

@media (max-width: 980px){
  }

@media (max-width: 720px){
  }


/* v34 ABOUT */
.about-hero{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:40px;
  align-items:center;
}
.about-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.about-split{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:40px;
  align-items:center;
}
@media (max-width: 900px){
  .about-hero,
  .about-split{
    grid-template-columns:1fr;
  }
}


/* v35 definitive Services strip and Contact image */
.service-image-grid-v25{
  display:flex;
  flex-direction:row;
  gap:0;
  height:340px;
  overflow:hidden;
  border-radius:28px;
  box-shadow:var(--shadow);
}

.service-image-grid-v25 img{
  width:33.3333%;
  height:100%;
  object-fit:cover;
  display:block;
  flex:0 0 33.3333%;
}

.contact-image-frame img{
  width:100%;
  min-height:340px;
  object-fit:cover;
}

@media (max-width: 980px){
  .service-image-grid-v25{
    height:280px;
  }
}

@media (max-width: 720px){
  .service-image-grid-v25{
    height:220px;
  }
}


/* home v1 refinements */
.home-feature-tags{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:22px;
}
.home-feature-tags span{
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  background:var(--surface-soft);
  color:var(--text);
  font-size:.84rem;
  font-weight:600;
}


/* home v2 refinements */
.home-feature-tags{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:22px;
}
.home-feature-tags span{
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  background:var(--surface-soft);
  color:var(--text);
  font-size:.84rem;
  font-weight:600;
}
.process-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:28px;
}
.process-step{
  background:var(--surface);
  border-radius:24px;
  padding:28px;
  box-shadow:var(--shadow);
}
.process-step strong{
  display:inline-flex;
  margin-bottom:14px;
  color:var(--muted);
  font-size:.92rem;
  letter-spacing:.12em;
}
.process-step h3{
  margin:0 0 10px;
  font-size:1.18rem;
}
.process-step p{
  margin:0;
  color:var(--muted);
}
@media (max-width: 900px){
  .process-grid{
    grid-template-columns:1fr;
  }
}
