/* ====== Detail page styles (rijwoning / appartement / bungalow) ====== */

.dhero{
  position: relative;
  height: 80vh;
  min-height: 600px;
  overflow: hidden;
  color: var(--paper);
}
.dhero .bg{
  position:absolute; inset:-8% 0;
  background-size: cover; background-position: center;
  will-change: transform;
}
.dhero .bg::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(37,25,21,.25), rgba(37,25,21,.7) 70%, rgba(37,25,21,.92)),
    linear-gradient(90deg, rgba(37,25,21,.45), transparent 60%);
}
.dhero .content{
  position: relative; z-index: 1;
  height: 100%;
  display:flex; flex-direction: column; justify-content: flex-end;
  padding-bottom: clamp(40px, 6vw, 80px);
}
.dhero .crumbs{ color: rgba(243,234,216,.7); }
.dhero .crumbs a:hover{ color: var(--paper); }
.dhero .head{
  display:grid; grid-template-columns: 1fr auto; gap: 40px; align-items: end;
}
.dhero h1{
  font-family:'Instrument Serif', serif;
  font-style: italic; font-weight: 400;
  font-size: clamp(56px, 9vw, 160px);
  line-height: 0.92;
  color: var(--paper);
  letter-spacing: -0.02em;
  margin-top: 14px;
}
.dhero .tag{
  display:inline-flex; align-items:center; gap: 10px;
  border: 1px solid rgba(243,234,216,.4);
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--paper); font-weight: 700;
  margin-bottom: 30px;
}
.dhero .lede{
  color: #e9d9b9;
  font-size: 17.5px;
  line-height: 1.6;
  max-width: 50ch;
  margin-top: 24px;
}
.dhero-strip{
  position: relative; z-index: 2;
  background: var(--brown-deep);
  color: var(--paper);
}
.dhero-strip .wrap{
  display:grid; grid-template-columns: repeat(5, 1fr);
  padding-top: 22px; padding-bottom: 22px;
  gap: clamp(12px, 1.5vw, 24px);
}
.dhero-strip .cell{
  padding: 6px 0;
  border-right: 1px solid rgba(236,225,204,.15);
  padding-right: clamp(12px, 1.5vw, 22px);
}
.dhero-strip .cell + .cell{ padding-left: clamp(12px, 1.5vw, 22px); }
.dhero-strip .cell:last-child{ border-right: 0; }
.dhero-strip .cell .l{ font-size: 10.5px; letter-spacing: 0.2em; text-transform: uppercase; color: #b09a78; font-weight: 700; margin-bottom: 6px; }
.dhero-strip .cell .v{ font-family:'Instrument Serif', serif; font-style: italic; font-size: 26px; color: var(--paper); line-height: 1; }

.dsec{ padding: var(--space-section) 0; }

/* Floorplan section */
.fp-grid{
  display:grid; grid-template-columns: 1fr 1.4fr; gap: clamp(40px, 6vw, 100px); align-items: start;
}
.fp-grid h2{
  font-family:'Instrument Serif', serif;
  font-style: italic; font-weight: 400;
  font-size: clamp(36px, 4.6vw, 60px); line-height: 1.05;
  color: var(--brown-deep); margin-top: 16px;
}
.fp-grid p{ font-size: 17px; color: var(--ink-soft); line-height: 1.65; max-width: 40ch; }
.fp-grid p + p{ margin-top: 1em; }
.fp-list{ margin-top: 28px; display:grid; gap: 0; }
.fp-list .row{
  display: grid; grid-template-columns: 28px 1fr auto;
  align-items: center; gap: 14px;
  padding: 14px 0;
  border-top: 1px solid var(--line);
  font-size: 15px;
}
.fp-list .row:last-child{ border-bottom: 1px solid var(--line); }
.fp-list .row .n{ font-family:'Instrument Serif', serif; font-style: italic; color: var(--brown); font-size: 18px; }
.fp-list .row .t{ color: var(--brown-deep); font-weight: 500; }
.fp-list .row .a{ color: var(--muted); font-size: 13px; }
.fp-canvas{
  background: var(--paper-warm);
  border-radius: var(--r-lg);
  padding: clamp(32px, 5vw, 60px);
  position: relative;
  border: 1px solid var(--line);
}
.fp-canvas .switch{
  display:inline-flex; padding: 4px; gap: 4px;
  background: var(--paper);
  border-radius: 999px;
  margin-bottom: 22px;
  border: 1px solid var(--line);
}
.fp-canvas .switch button{
  border: 0; background: transparent;
  padding: 8px 18px;
  font-size: 12.5px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--muted);
  border-radius: 999px;
  transition: all .25s;
}
.fp-canvas .switch button.active{ background: var(--brown-deep); color: var(--paper); }
.fp-canvas .plan-stage{
  position: relative; aspect-ratio: 4/3.2;
  background: var(--paper);
  border-radius: var(--r);
  border: 1px dashed var(--line-strong);
  overflow: hidden;
}
.fp-canvas .plan{ position: absolute; inset: 0; opacity: 0; transition: opacity .5s; }
.fp-canvas .plan.active{ opacity: 1; }
.fp-canvas .legend{
  margin-top: 22px;
  display: flex; gap: 22px; flex-wrap: wrap;
  font-size: 12px; color: var(--muted);
}
.fp-canvas .legend .it{ display:inline-flex; align-items:center; gap: 8px; }
.fp-canvas .legend .it::before{
  content:""; width: 12px; height: 12px; border-radius: 3px;
  background: var(--brown-soft);
}
.fp-canvas .legend .it.b::before{ background: var(--brown); }
.fp-canvas .legend .it.c::before{ background: #b8a982; }

/* Materials */
.matters{ background: var(--paper-warm); }
.mat-head{ max-width: 60ch; margin-bottom: 50px; }
.mat-head h2{
  font-family:'Instrument Serif', serif;
  font-style: italic; font-weight: 400;
  font-size: clamp(36px, 4.6vw, 60px); line-height: 1.05;
  color: var(--brown-deep); margin-top: 16px;
}
.mat-grid{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.mat-card{
  background: var(--paper);
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--line);
}
.mat-card .swatch{
  aspect-ratio: 1; position: relative;
}
.mat-card .swatch::after{
  content: attr(data-label);
  position: absolute; bottom: 14px; left: 14px;
  font-size: 10.5px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--paper); background: rgba(37,25,21,.7); padding: 5px 9px; border-radius: 3px;
}
.mat-card .info{ padding: 18px 18px 22px; }
.mat-card .info h4{
  font-family:'Instrument Serif', serif; font-style: italic; font-weight: 400;
  font-size: 22px; color: var(--brown-deep); margin-bottom: 6px;
}
.mat-card .info p{ font-size: 13.5px; color: var(--ink-soft); margin: 0; line-height: 1.55; max-width: 100%; }

/* Related */
.related{ background: var(--paper); }
.rel-head{ display:flex; justify-content:space-between; align-items: end; margin-bottom: 40px; gap: 30px;}
.rel-head h2{
  font-family:'Instrument Serif', serif;
  font-style: italic; font-weight: 400;
  font-size: clamp(34px, 4vw, 56px); line-height: 1.05;
  color: var(--brown-deep);
}
.rel-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.rel-card{
  position: relative;
  aspect-ratio: 16/9;
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: transform .4s var(--ease-out);
}
.rel-card:hover{ transform: translateY(-4px); }
.rel-card .pic{
  position:absolute; inset:0;
  background-size: cover; background-position: center;
  transition: transform 1s var(--ease-out);
}
.rel-card:hover .pic{ transform: scale(1.06); }
.rel-card::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 40%, rgba(37,25,21,.85));
}
.rel-card .meta{
  position: absolute; left: 26px; bottom: 22px; right: 26px;
  color: var(--paper); z-index: 1;
  display:flex; justify-content: space-between; align-items: end;
}
.rel-card .meta h3{
  font-family:'Instrument Serif', serif; font-style: italic; font-weight: 400;
  color: var(--paper); font-size: 30px;
}
.rel-card .meta .num{
  font-size: 11.5px; letter-spacing: 0.2em; text-transform: uppercase; opacity: .8;
}
.rel-card .meta .go{
  width: 44px; height: 44px; border-radius: 50%;
  border: 1px solid rgba(243,234,216,.4);
  display:grid; place-items:center;
}

@media (max-width: 1100px){
  .dhero-strip .wrap{ grid-template-columns: 1fr 1fr; row-gap: 16px; }
  .dhero-strip .cell{ border-right: 0; padding-left: 0 !important; }
  .fp-grid{ grid-template-columns: 1fr; gap: 48px; }
  .mat-grid{ grid-template-columns: 1fr 1fr; }
  .rel-grid{ grid-template-columns: 1fr; }
}
@media (max-width: 640px){
  .dhero{ height: auto; min-height: 0; padding: clamp(120px, 16vw, 180px) 0 clamp(40px, 6vw, 70px); }
  .dhero .content{ padding-bottom: 0; }
  .dhero-strip .wrap{ grid-template-columns: 1fr; }
  .dhero-strip .cell{ border-right: 0; border-bottom: 1px solid rgba(236,225,204,.15); padding: 14px 0; }
  .dhero-strip .cell:last-child{ border-bottom: 0; }
  .mat-grid{ grid-template-columns: 1fr 1fr; }
  .rel-head{ flex-direction: column; align-items: flex-start; }
  .gstrip .gimg{ flex-basis: 320px; }
}

/* Gallery strip */
.gstrip{ background: var(--paper); padding-top: 0; }
.gstrip .gh{
  display:flex; justify-content: space-between; align-items: end;
  margin-bottom: 32px; gap: 30px;
}
.gstrip .gh h2{
  font-family:'Instrument Serif', serif; font-style: italic; font-weight: 400;
  font-size: clamp(32px, 4vw, 56px); color: var(--brown-deep);
}
.gstrip .scroller{
  display:flex; gap: 14px; overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 18px;
  margin: 0 calc(-1 * var(--gutter));
  padding-left: var(--gutter);
  padding-right: var(--gutter);
  scrollbar-width: thin;
}
.gstrip .scroller::-webkit-scrollbar{ height: 6px; }
.gstrip .scroller::-webkit-scrollbar-track{ background: var(--paper-warm); border-radius: 999px; }
.gstrip .scroller::-webkit-scrollbar-thumb{ background: var(--brown); border-radius: 999px; }
.gstrip .gimg{
  flex: 0 0 480px;
  max-width: 80vw;
  aspect-ratio: 4/3;
  border-radius: var(--r-lg);
  background-size: cover; background-position: center;
  scroll-snap-align: start;
}
