/* ════════════════════════════════════════════
   sacré studio — project article pages
   loads AFTER style.css (tokens, nav, contact, footer)
   ════════════════════════════════════════════ */

body.proj-page { background: var(--linen); }

/* project pages: the centred nav logo is always shown (no hero animation) */
.proj-page .nav__brand { opacity: 1; }
/* nav sits over the dark hero at the top, light text */
.proj-page .nav { color: var(--offwhite); }

/* ─── reveal gating (no-JS → visible) ─── */
.proj-anim .reveal { opacity: 0; transform: translateY(42px); }

/* ─── project hero ─── */
.proj-hero {
  position: relative;
  height: 92vh;
  min-height: 560px;
  overflow: hidden;
  background: #2A0E0E;
}
.proj-hero__img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  will-change: transform;
}
.proj-hero__veil {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(42,14,14,.55) 0%, rgba(42,14,14,0) 26%),
    linear-gradient(0deg, rgba(42,14,14,.62) 0%, rgba(42,14,14,0) 50%);
}
.proj-hero__intro {
  position: absolute;
  left: clamp(1.2rem, 5vw, 4.5rem);
  bottom: clamp(3rem, 8vh, 6rem);
  right: clamp(1.2rem, 5vw, 4.5rem);
  color: var(--offwhite);
  max-width: 900px;
}
.proj-hero__eyebrow {
  font-size: .78rem; letter-spacing: .24em; text-transform: uppercase;
  color: var(--sand); margin-bottom: 1rem;
}
.proj-hero__title {
  font-family: var(--serif); font-weight: 300;
  font-variation-settings: "opsz" 144;
  font-size: clamp(2.6rem, 7vw, 6rem); line-height: 1; letter-spacing: -.01em;
  text-shadow: 0 4px 40px rgba(20,6,6,.5);
}
.proj-hero__desc {
  margin-top: 1.2rem; max-width: 48ch; color: var(--sand);
  font-size: clamp(.95rem, 1.4vw, 1.1rem); line-height: 1.6;
  text-shadow: 0 2px 22px rgba(20,6,6,.55);
}

/* ─── spec card ─── */
.proj-spec {
  background: var(--sand);
  padding: clamp(2.4rem, 5vw, 4rem) clamp(1.2rem, 5vw, 4.5rem);
}
.proj-spec__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: clamp(1.4rem, 3vw, 3rem);
  max-width: 1200px; margin-inline: auto;
}
.proj-spec__grid > div { border-top: 1px solid rgba(51,32,28,.22); padding-top: 1rem; }
.proj-spec dt {
  font-size: .72rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--ink-soft); margin-bottom: .5rem;
}
.proj-spec dd {
  font-family: var(--serif); font-size: clamp(1.1rem, 1.8vw, 1.5rem);
  color: var(--ink); line-height: 1.2;
}

/* ─── article body + blocks ─── */
.proj-body {
  max-width: 1280px; margin-inline: auto;
  padding: clamp(3.5rem, 8vh, 7rem) clamp(1.2rem, 4vw, 3.5rem);
  display: flex; flex-direction: column;
  gap: clamp(3rem, 8vh, 7rem);
}
.block { margin: 0; }

.block--full figure, .block--full { margin: 0; }
.block--full img {
  width: 100%; height: auto; display: block; border-radius: 3px;
}
.block--full figcaption,
.block__caption {
  margin-top: .9rem; font-size: .82rem; letter-spacing: .04em;
  color: var(--ink-soft);
}

.block--text {
  max-width: 62ch; margin-inline: auto;
  font-size: clamp(1.05rem, 1.6vw, 1.3rem); line-height: 1.7; color: var(--ink);
}
.block--text h2 {
  font-family: var(--serif); font-weight: 300; font-size: clamp(1.6rem, 3vw, 2.4rem);
  line-height: 1.1; margin-bottom: 1.2rem;
}
.block--text p + p { margin-top: 1.1rem; }

.block--split {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(1.4rem, 4vw, 3.5rem); align-items: center;
}
.block--split img { width: 100%; height: auto; display: block; border-radius: 3px; }
.block--split .block__text {
  font-size: clamp(1rem, 1.4vw, 1.18rem); line-height: 1.7; color: var(--ink);
}
.block--split .block__text h2 {
  font-family: var(--serif); font-weight: 300; font-size: clamp(1.5rem, 2.6vw, 2.2rem);
  line-height: 1.1; margin-bottom: 1rem;
}

.block--duo { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1rem, 2.5vw, 2rem); }
.block--duo img { width: 100%; height: 100%; object-fit: cover; display: block; border-radius: 3px; aspect-ratio: 4/5; }

.block--quote {
  max-width: 24ch; margin-inline: auto; text-align: center;
  font-family: var(--serif); font-style: italic; font-weight: 300;
  font-size: clamp(1.8rem, 4vw, 3.2rem); line-height: 1.2; color: var(--bordeaux-mid);
}

.block--plans h2 {
  font-family: var(--serif); font-weight: 300; font-size: clamp(1.6rem, 3vw, 2.4rem);
  letter-spacing: .01em; margin-bottom: 1.6rem; text-align: center;
}
.block--plans img {
  width: 100%; height: auto; display: block;
  background: var(--plaster); border-radius: 3px; padding: clamp(1rem, 3vw, 3rem);
}

/* ─── related projects ─── */
.proj-related {
  background: var(--sand);
  padding: clamp(4rem, 9vh, 8rem) clamp(1.2rem, 4vw, 3.5rem);
}
.proj-related__title {
  font-family: var(--serif); font-weight: 300; font-size: clamp(1.8rem, 4vw, 3rem);
  text-align: center; margin-bottom: clamp(2.4rem, 5vh, 4rem);
}
.proj-related__grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(1.4rem, 3vw, 2.6rem); max-width: 1200px; margin-inline: auto;
}
/* single teaser card (when there's only one thing to point to) */
.proj-related__grid--solo { grid-template-columns: minmax(0, 480px); justify-content: center; }
.rel-card { display: block; }
.rel-card__media { overflow: hidden; border-radius: 3px; aspect-ratio: 4/3; }
.rel-card__media img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform .8s var(--ease-out);
}
.rel-card:hover .rel-card__media img { transform: scale(1.05); }
.rel-card__name {
  font-family: var(--serif); font-weight: 300; font-size: 1.5rem; margin-top: 1rem;
}
.rel-card__meta {
  font-size: .76rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--ink-soft); margin-top: .4rem;
}

/* ─── responsive ─── */
@media (max-width: 760px) {
  .block--split, .block--duo { grid-template-columns: 1fr; }
  .proj-hero { height: 80vh; }
}

@media (prefers-reduced-motion: reduce) {
  .proj-anim .reveal { opacity: 1; transform: none; }
  .proj-hero__img { will-change: auto; }
}
