/* ============================================================
   CAVARO — PROJECT TEMPLATE (editorial)
   Shared styling inherited by every portfolio project page.
   Layers on styles.css (palette, fonts, nav, footer, reveal, buttons).
   Pages are generated from projects/build.mjs — do not hand-edit
   individual project HTML.
   ============================================================ */

/* ---------- Hero ---------- */
.cs-hero {
  position: relative; height: 100svh; min-height: 640px;
  display: flex; align-items: flex-end; overflow: hidden;
}
.cs-hero__media { position: absolute; inset: 0; z-index: -2; animation: heroIn 1.9s var(--ease-2) both; }
.cs-hero__media img { width: 100%; height: 116%; will-change: transform; filter: brightness(0.86) saturate(1.02); }
.cs-hero__overlay {
  position: absolute; inset: 0; z-index: -1;
  background:
    linear-gradient(180deg, rgba(10,10,10,0.5) 0%, rgba(10,10,10,0.14) 30%, rgba(10,10,10,0.9) 100%),
    linear-gradient(90deg, rgba(10,10,10,0.7) 0%, rgba(10,10,10,0.3) 34%, transparent 70%);
}
.cs-hero__inner {
  position: relative; z-index: 1; width: 100%;
  max-width: var(--maxw); margin: 0 auto;
  padding: 0 var(--pad) clamp(3.5rem, 8vw, 7rem);
}
.cs-hero__title {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(2.6rem, 6.6vw, 6rem); line-height: 1.02;
  letter-spacing: -0.01em; max-width: 18ch;
  text-shadow: 0 2px 40px rgba(0,0,0,0.45);
}
.cs-hero__caption {
  margin-top: 1.8rem; max-width: 60ch;
  color: rgba(247,245,242,0.84); font-size: clamp(0.98rem, 1.3vw, 1.16rem);
  text-shadow: 0 1px 20px rgba(0,0,0,0.6);
}

/* ---------- Facts strip ---------- */
.facts { border-bottom: 1px solid var(--line); }
.facts__grid { max-width: var(--maxw); margin: 0 auto; display: grid; }
.facts__item {
  padding: clamp(2.2rem, 4vw, 3.4rem) clamp(1.2rem, 2.4vw, 2.4rem);
  border-left: 1px solid var(--line);
}
.facts__item:first-child { border-left: 0; }
.facts__item dt {
  font-size: 0.62rem; letter-spacing: 0.26em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 0.9rem;
}
.facts__item dd { font-family: var(--serif); font-size: clamp(1.1rem, 1.6vw, 1.55rem); line-height: 1.2; color: var(--ink); }

/* ---------- Editorial ---------- */
.editorial { max-width: 1180px; margin: 0 auto; padding: clamp(5rem, 11vw, 10rem) var(--pad); }
.editorial__lead { display: grid; grid-template-columns: 0.7fr 1.3fr; gap: clamp(2rem, 6vw, 6rem); align-items: start; }
.editorial__kicker { font-family: var(--serif); font-style: italic; font-size: clamp(1.5rem, 2.4vw, 2.2rem); line-height: 1.25; color: var(--ink); }
.editorial__body p { color: var(--ink-soft); font-size: clamp(1.02rem, 1.25vw, 1.18rem); margin-bottom: 1.5rem; max-width: 66ch; }
.editorial__body p:last-child { margin-bottom: 0; }

.pullquote { max-width: 1000px; margin: 0 auto; padding: clamp(2rem, 6vw, 5rem) var(--pad) clamp(4rem, 9vw, 8rem); text-align: center; }
.pullquote p { font-family: var(--serif); font-weight: 300; font-size: clamp(1.7rem, 3.4vw, 3rem); line-height: 1.22; letter-spacing: -0.01em; color: var(--ink); }
.pullquote span { display: block; margin-top: 1.8rem; font-family: var(--sans); font-size: 0.68rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--accent); }

/* ---------- Scope of works ---------- */
.scope { padding: clamp(5rem, 11vw, 10rem) var(--pad); border-top: 1px solid var(--line); }
.scope__inner { max-width: var(--maxw); margin: 0 auto; }
.scope__head { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: clamp(2rem, 5vw, 5rem); align-items: end; margin-bottom: clamp(3rem, 6vw, 5rem); }
.scope__head h2 { font-family: var(--serif); font-weight: 400; font-size: clamp(2rem, 4vw, 3.4rem); line-height: 1.06; }
.scope__head p { color: var(--ink-soft); max-width: 50ch; }
.scope__list { list-style: none; columns: 3; column-gap: clamp(2rem, 4vw, 4rem); }
.scope__list li {
  break-inside: avoid; padding: 1.05rem 0; border-top: 1px solid var(--line);
  display: flex; gap: 1rem; align-items: baseline; font-size: clamp(0.96rem, 1.1vw, 1.06rem); color: var(--ink);
}
.scope__list li::before { content: ""; flex: none; width: 5px; height: 5px; margin-top: 0.55em; background: var(--accent); border-radius: 50%; }

/* ---------- Gallery (cinematic bands + duos) ---------- */
.gallery { padding-bottom: clamp(3rem, 7vw, 6rem); }
.gallery__head { max-width: var(--maxw); margin: 0 auto; padding: clamp(4rem, 9vw, 8rem) var(--pad) clamp(2.5rem, 5vw, 4rem); }
.gallery__head h2 { font-family: var(--serif); font-weight: 400; font-size: clamp(2rem, 4vw, 3.4rem); }

.shot { position: relative; overflow: hidden; }
.shot--bleed { height: clamp(560px, 92vh, 1060px); }
.shot--bleed img { position: absolute; inset: 0; width: 100%; height: 118%; will-change: transform; }
.shot--bleed .shot__cap { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; padding: clamp(2.2rem, 6vw, 5rem) var(--pad); max-width: 820px; pointer-events: none; }
.shot--bleed::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(0deg, rgba(12,12,12,0.82) 0%, rgba(12,12,12,0.18) 38%, transparent 64%);
}

.duo2 { max-width: var(--maxw); margin: 0 auto; padding: clamp(1rem, 2.5vw, 2rem) var(--pad); display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1rem, 2.5vw, 2rem); }
.figpair { margin: 0; }
.figpair__media { position: relative; overflow: hidden; aspect-ratio: 16 / 9; }
.figcap { margin-top: 1.2rem; }
.figcap__room { font-size: 0.66rem; letter-spacing: 0.26em; text-transform: uppercase; color: var(--accent); }
.figcap__text { margin-top: 0.5rem; color: var(--ink-soft); font-size: clamp(0.95rem, 1.1vw, 1.05rem); max-width: 52ch; }
.shot__cap .figcap__text { color: rgba(247,245,242,0.86); text-shadow: 0 1px 18px rgba(0,0,0,0.5); }
.shot__cap .figcap__room { font-size: 0.7rem; }

/* clickable gallery image -> lightbox */
.lb-img { cursor: zoom-in; transition: transform 1.4s var(--ease), filter 1s var(--ease); filter: brightness(1) saturate(1.01); }
.figpair__media .lb-img { width: 100%; height: 100%; }
.shot:hover .lb-img, .figpair:hover .lb-img { transform: scale(1.045); filter: brightness(1.05) saturate(1.03); }

/* ---------- Lightbox ---------- */
.lightbox {
  position: fixed; inset: 0; z-index: 1000; display: flex; align-items: center; justify-content: center;
  background: rgba(8,8,8,0.95); -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  opacity: 0; visibility: hidden; transition: opacity 0.5s var(--ease), visibility 0.5s var(--ease);
}
.lightbox.open { opacity: 1; visibility: visible; }
.lightbox__stage { position: relative; max-width: min(1500px, 92vw); max-height: 86vh; display: flex; flex-direction: column; align-items: center; }
.lightbox__img { max-width: 92vw; max-height: 80vh; width: auto; height: auto; object-fit: contain; box-shadow: 0 40px 120px rgba(0,0,0,0.6); transition: opacity 0.45s var(--ease); opacity: 1; }
.lightbox__cap { display: flex; align-items: center; gap: 1.2rem; margin-top: 1.4rem; }
.lightbox__room { font-family: var(--serif); font-style: italic; font-size: clamp(1.1rem, 1.6vw, 1.45rem); color: var(--ink); }
.lightbox__counter { font-size: 0.66rem; letter-spacing: 0.26em; text-transform: uppercase; color: var(--accent); }
.lightbox__close, .lightbox__nav {
  position: absolute; z-index: 2; background: none; border: 1px solid rgba(247,245,242,0.28); color: var(--ink); cursor: pointer;
  display: grid; place-items: center; transition: border-color 0.4s var(--ease), background 0.4s var(--ease), color 0.4s var(--ease);
}
.lightbox__close { top: clamp(1.2rem,3vw,2.2rem); right: clamp(1.2rem,3vw,2.2rem); width: 50px; height: 50px; border-radius: 50%; font-size: 1.4rem; font-weight: 300; }
.lightbox__nav { top: 50%; transform: translateY(-50%); width: 58px; height: 58px; border-radius: 50%; font-family: var(--serif); font-size: 2rem; line-height: 1; }
.lightbox__prev { left: clamp(1rem,3vw,2.6rem); }
.lightbox__next { right: clamp(1rem,3vw,2.6rem); }
.lightbox__close:hover, .lightbox__nav:hover { border-color: var(--accent); background: rgba(176,141,87,0.16); color: var(--accent); }

/* ---------- Previous / Next ---------- */
.p-pnav { border-top: 1px solid var(--line); }
.p-pnav__grid { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; }
.p-pnav__link { display: block; padding: clamp(3rem, 7vw, 6rem) var(--pad); transition: background 0.5s var(--ease); }
.p-pnav__link:hover { background: var(--bg-2); }
.p-pnav__link--next { text-align: right; border-left: 1px solid var(--line); }
.p-pnav__dir { font-size: 0.64rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--accent); }
.p-pnav__name { display: block; margin-top: 1rem; font-family: var(--serif); font-size: clamp(1.5rem, 3vw, 2.6rem); line-height: 1.1; color: var(--ink); }
.p-pnav__solo { grid-column: 1 / -1; }
.p-pnav__solo.p-pnav__link--next { border-left: 0; }

/* ---------- Closing CTA ---------- */
.cs-cta { position: relative; overflow: hidden; padding: clamp(6rem, 14vw, 12rem) var(--pad); border-top: 1px solid var(--line); text-align: center; }
.cs-cta__inner { max-width: 760px; margin: 0 auto; position: relative; z-index: 1; }
.cs-cta h2 { font-family: var(--serif); font-weight: 400; font-size: clamp(2.2rem, 5vw, 4rem); line-height: 1.05; }
.cs-cta p { color: var(--ink-soft); margin: 1.8rem auto 2.8rem; max-width: 56ch; font-size: clamp(1rem, 1.3vw, 1.16rem); }

/* ---------- Coming soon ---------- */
.coming { min-height: 100svh; display: flex; align-items: center; justify-content: center; text-align: center; padding: 8rem var(--pad); }
.coming__inner { max-width: 720px; }
.coming h1 { font-family: var(--serif); font-weight: 300; font-size: clamp(2.6rem, 6vw, 5rem); line-height: 1.04; margin-top: 1.2rem; }
.coming p { color: var(--ink-soft); margin: 1.6rem auto 0; max-width: 48ch; font-size: clamp(1rem, 1.3vw, 1.16rem); }
.coming .btn { margin-top: 2.6rem; }

/* ---------- Active nav state ---------- */
.nav__links a[aria-current="page"] { color: var(--ink); }
.nav__links a[aria-current="page"]::after { transform: scaleX(1); transform-origin: left; }

/* ---------- Responsive ---------- */
@media (max-width: 1080px) {
  .facts__grid { grid-template-columns: repeat(2, 1fr) !important; }
  .facts__item { border-left: 0; }
  .facts__item:nth-child(even) { border-left: 1px solid var(--line); }
  .facts__item:nth-child(n+3) { border-top: 1px solid var(--line); }
  .scope__list { columns: 2; }
}
@media (max-width: 860px) {
  .editorial__lead { grid-template-columns: 1fr; gap: 1.6rem; }
  .scope__head { grid-template-columns: 1fr; gap: 1.2rem; }
  .duo2 { grid-template-columns: 1fr; }
  .shot--bleed { height: 72vh; min-height: 440px; }
}
@media (max-width: 560px) {
  .facts__grid { grid-template-columns: 1fr !important; }
  .facts__item { border-left: 0 !important; border-top: 1px solid var(--line); }
  .facts__item:first-child { border-top: 0; }
  .scope__list { columns: 1; }
  .p-pnav__grid { grid-template-columns: 1fr; }
  .p-pnav__link--next { border-left: 0; border-top: 1px solid var(--line); text-align: left; }
  .lightbox__nav { width: 46px; height: 46px; font-size: 1.5rem; }
}
