/* ============================================================================
   NORVAIN STUDIO - CINEMATIC EXPERIENCE  (scoped to .nv-cinema)
   Tonal journey:  ACT I ink  ->  ACT II warm travertine/linen  ->  ACT III gold dusk
   Display: Fraunces (headlines only).  Body/UI: Host Grotesk.
   ============================================================================ */
.nv-cinema {
  --ink: #0e0b09;
  --ink-soft: #17120d;
  --ink-2: #1d1610;
  --paper: #f4ede1;
  --warm-bg: #ece3d4;
  --warm-panel: #f3ece0;
  --warm-ink: #221b13;
  --warm-muted: #6c5f4d;
  --linen: #e6dccb;
  --brass: #b8915a;
  --brass-bright: #d6ab68;
  --terra: #b15a30;
  --forest: #20342a;
  --dusk: #160f08;
  --on-dark: rgba(247, 242, 233, 0.92);
  --on-dark-soft: rgba(247, 242, 233, 0.6);
  --measure: 1280px;
  --gutter: clamp(1.2rem, 5vw, 4.5rem);
  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  background-color: var(--ink);
  color: var(--on-dark);
  transition: background-color 1100ms var(--ease-cinematic);
}
.nv-cinema[data-act="2"] { background-color: var(--warm-bg); }
.nv-cinema[data-act="3"] { background-color: var(--dusk); }

.nv-cinema .site-main { overflow: clip; }
/* Homepage + thank-you main are full-bleed; specificity matches body:not(.home-page) .site-main so this wins by order. */
body.nv-cinema--home .site-main,
body.nv-cinema--thanks .site-main { max-width: none; margin: 0; padding: 0; }

/* Thank-you page: simple, centred, on-brand. */
.cine-thanks { align-items: center; display: flex; justify-content: center; min-height: 100svh; padding: clamp(5rem, 14vh, 9rem) var(--gutter) clamp(3rem, 8vh, 5rem); text-align: center; }
.cine-thanks__inner { max-width: 640px; }
.cine-thanks__title { color: #fcf8f1; font-family: var(--font-display); font-optical-sizing: auto; font-size: clamp(2.4rem, 1.4rem + 4vw, 5rem); font-weight: 340; letter-spacing: -0.014em; line-height: 1.02; margin: 0.7rem 0 0; }
.cine-thanks__text { color: var(--on-dark); font-size: clamp(1.05rem, 0.98rem + 0.4vw, 1.25rem); line-height: 1.6; margin: 1.4rem auto 0; max-width: 52ch; }
.cine-thanks__meta { color: var(--on-dark-soft); font-size: 0.98rem; margin: 1.2rem 0 0; }
.cine-thanks__actions { display: flex; flex-wrap: wrap; gap: 0.9rem; justify-content: center; margin-top: clamp(2rem, 4vw, 2.8rem); }

/* ---- shared type ---- */
.nv-cinema .cine-eyebrow {
  font: 600 0.72rem/1.3 "Host Grotesk", sans-serif;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin: 0;
  color: var(--brass);
}
.nv-cinema .cine-eyebrow--light { color: var(--brass-bright); }
.nv-cinema h1, .nv-cinema h2, .nv-cinema h3 { font-family: var(--font-display); font-optical-sizing: auto; }
.nv-cinema em { font-style: italic; }

/* ---- premium button ---- */
.nv-cinema .cine-btn {
  align-items: center;
  background: var(--paper);
  border-radius: 999px;
  color: var(--ink);
  display: inline-flex;
  gap: 0.7rem;
  font: 600 0.92rem/1 "Host Grotesk", sans-serif;
  letter-spacing: 0.01em;
  overflow: hidden;
  padding: 1rem 1.6rem;
  position: relative;
  text-decoration: none;
  transition: transform 540ms var(--ease-cinematic), box-shadow 540ms var(--ease-cinematic), background-color 360ms ease, color 360ms ease;
  will-change: transform;
}
.nv-cinema .cine-btn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255, 255, 255, 0.5) 50%, transparent 70%);
  transform: translateX(-120%);
  transition: transform 760ms var(--ease-cinematic);
}
.nv-cinema .cine-btn__label { position: relative; z-index: 1; }
.nv-cinema .cine-btn__arrow { display: inline-flex; position: relative; z-index: 1; transition: transform 540ms var(--ease-cinematic); }
.nv-cinema .cine-btn__arrow svg { width: 24px; height: 10px; }
.nv-cinema .cine-btn:hover { transform: translateY(-3px); box-shadow: 0 20px 44px rgba(0, 0, 0, 0.34); }
.nv-cinema .cine-btn:hover::before { transform: translateX(120%); }
.nv-cinema .cine-btn:hover .cine-btn__arrow { transform: translateX(6px); }
.nv-cinema .cine-btn:active { transform: translateY(-1px) scale(0.99); }
.nv-cinema .cine-btn--ghost {
  background: transparent;
  box-shadow: inset 0 0 0 1px rgba(247, 242, 233, 0.34);
  color: var(--on-dark);
}
.nv-cinema .cine-btn--ghost::before { display: none; }
.nv-cinema .cine-btn--ghost:hover { background: rgba(247, 242, 233, 0.08); box-shadow: inset 0 0 0 1px rgba(247, 242, 233, 0.7); }

/* ---- reveal (reuses the global IntersectionObserver + nv-reveal-ready) ---- */
.nv-reveal-ready .nv-cinema [data-reveal="rise"] {
  opacity: 0;
  transform: translateY(36px);
  transition: opacity 1000ms var(--ease-cinematic), transform 1000ms var(--ease-cinematic);
}
.nv-reveal-ready .nv-cinema [data-reveal="rise"].is-visible { opacity: 1; transform: none; }

/* ============================ ACT I : HERO ============================ */
.cine-hero {
  align-items: flex-end;
  display: flex;
  isolation: isolate;
  min-height: 100svh;
  overflow: hidden;
  position: relative;
}
.cine-hero__stage { position: absolute; inset: 0; z-index: -1; }
.cine-hero__frame {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transform: scale(1.1);
  transition: opacity 1700ms var(--ease-cinematic), transform 8000ms linear;
}
.cine-hero__frame.is-active { opacity: 1; transform: scale(1); }
.cine-hero__veil {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(8, 6, 4, 0.62) 0%, rgba(8, 6, 4, 0.1) 30%, rgba(8, 6, 4, 0.46) 72%, rgba(8, 6, 4, 0.9) 100%),
    radial-gradient(130% 95% at 72% 26%, transparent 38%, rgba(8, 6, 4, 0.52) 100%);
}
.cine-hero__inner {
  margin: 0 auto;
  max-width: var(--measure);
  padding: 0 var(--gutter) clamp(2.2rem, 5.5vh, 4.4rem);
  position: relative;
  width: 100%;
}
.cine-hero__eyebrow { color: var(--on-dark-soft); }
.cine-hero__title {
  color: #fcf8f1;
  font-size: clamp(2.5rem, 1.3rem + 4.2vw, 5.1rem);
  font-weight: 340;
  letter-spacing: -0.014em;
  line-height: 1.03;
  margin: 0.6rem 0 0;
  max-width: 17ch;
  text-wrap: balance;
}
.cine-hero__lede {
  color: var(--on-dark);
  font-size: clamp(1rem, 0.94rem + 0.3vw, 1.15rem);
  line-height: 1.58;
  margin: clamp(1rem, 1.8vw, 1.5rem) 0 0;
  max-width: 50ch;
}
.cine-hero__actions { display: flex; flex-wrap: wrap; gap: 0.9rem; margin-top: clamp(1.3rem, 2.4vw, 1.9rem); }
.cine-hero__meta {
  color: var(--on-dark-soft);
  display: flex;
  flex-direction: column;
  font: 600 0.68rem/1.3 "Host Grotesk", sans-serif;
  gap: 0.45rem;
  letter-spacing: 0.16em;
  position: absolute;
  right: var(--gutter);
  text-align: right;
  text-transform: uppercase;
  top: clamp(5.5rem, 13vh, 8rem);
}

/* ============================ ACT I : MANIFESTO ============================ */
.cine-manifesto {
  margin: 0 auto;
  max-width: 1100px;
  padding: clamp(5rem, 14vh, 11rem) var(--gutter);
  text-align: center;
}
.cine-manifesto__line {
  color: var(--on-dark);
  font-family: var(--font-display);
  font-size: clamp(1.7rem, 1rem + 2.7vw, 3.4rem);
  font-weight: 330;
  letter-spacing: -0.01em;
  line-height: 1.16;
  margin: 0;
  text-wrap: balance;
}
.cine-manifesto__line--soft { color: var(--on-dark-soft); font-size: clamp(1.1rem, 0.8rem + 1.1vw, 1.7rem); margin-top: 1.4rem; }

/* ============================ TRANSFORMATION ============================ */
.cine-transform { height: 230vh; position: relative; }
.cine-transform__sticky {
  align-items: flex-end;
  display: flex;
  height: 100vh;
  overflow: hidden;
  position: sticky;
  top: 0;
}
.cine-transform__media { position: absolute; inset: 0; }
.cine-transform__img { position: absolute; inset: 0; background-size: cover; background-position: center; }
.cine-transform__img--before { filter: saturate(0.42) brightness(0.82) contrast(0.96); transform: scale(1.04); }
.cine-transform__img--after {
  clip-path: inset(0 0 0 calc((1 - var(--reveal, 0)) * 100%));
  filter: saturate(1.04) contrast(1.03);
}
.cine-transform__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(8, 6, 4, 0.36), rgba(8, 6, 4, 0.12) 40%, rgba(8, 6, 4, 0.72));
  pointer-events: none;
}
.cine-transform__tag {
  position: absolute;
  top: clamp(1.4rem, 4vh, 2.4rem);
  font: 600 0.72rem/1.3 "Host Grotesk", sans-serif;
  letter-spacing: 0.04em;
  padding: 0.5rem 0.95rem;
  border-radius: 999px;
  z-index: 2;
  backdrop-filter: blur(6px);
}
.cine-transform__tag--before { left: clamp(1.2rem, 4vw, 3rem); background: rgba(14, 11, 9, 0.6); color: rgba(247, 242, 233, 0.78); opacity: clamp(0, calc((0.62 - var(--reveal, 0)) * 4), 1); }
.cine-transform__tag--after { right: clamp(1.2rem, 4vw, 3rem); background: rgba(184, 145, 90, 0.92); color: #1a120a; opacity: clamp(0, calc((var(--reveal, 0) - 0.5) * 4), 1); }
.cine-transform__copy {
  margin: 0 auto;
  max-width: var(--measure);
  padding: 0 var(--gutter) clamp(3rem, 8vh, 6rem);
  position: relative;
  width: 100%;
  z-index: 2;
}
.cine-transform__title {
  color: #fcf8f1;
  font-size: clamp(2rem, 1.1rem + 3.6vw, 4.2rem);
  font-weight: 340;
  letter-spacing: -0.014em;
  line-height: 1.04;
  margin: 0.6rem 0 0;
  max-width: 20ch;
  text-wrap: balance;
}
.cine-transform__text { color: var(--on-dark); font-size: clamp(1rem, 0.95rem + 0.3vw, 1.16rem); line-height: 1.6; margin: 1.2rem 0 0; max-width: 54ch; }

/* ============================ TRANSITION (transform -> journey) ============================ */
/* Warm breathing band so the transform's full-bleed media clears before the journey media sticks. */
.cine-transition {
  background: var(--warm-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 62vh;
  padding: clamp(4rem, 12vh, 9rem) var(--gutter);
  position: relative;
  z-index: 2;
}
.cine-transition__line {
  color: var(--warm-ink);
  font-family: var(--font-display);
  font-optical-sizing: auto;
  font-size: clamp(1.5rem, 1rem + 2vw, 2.9rem);
  font-weight: 340;
  letter-spacing: -0.01em;
  line-height: 1.16;
  margin: 0;
  max-width: 22ch;
  text-align: center;
  text-wrap: balance;
}

/* ============================ ACT II : JOURNEY ============================ */
.cine-journey { background: var(--warm-bg); color: var(--warm-ink); position: relative; }
.cine-journey__grid { display: grid; grid-template-columns: 1.02fr 0.98fr; }
.cine-journey__media {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  align-self: start;
}
.cine-journey__frame {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transform: scale(1.06);
  transition: opacity 1100ms var(--ease-cinematic), transform 2400ms var(--ease-cinematic);
}
.cine-journey__frame.is-active { opacity: 1; transform: scale(1); }
.cine-journey__grain { position: absolute; inset: 0; background: linear-gradient(100deg, rgba(20, 14, 8, 0.32), transparent 46%); pointer-events: none; }
.cine-journey__rail { padding: 0 var(--gutter) 0 clamp(2rem, 5vw, 5rem); }
.cine-journey__head { min-height: 62vh; display: flex; flex-direction: column; justify-content: center; }
.cine-journey__title { color: var(--warm-ink); font-size: clamp(1.9rem, 1.2rem + 2.4vw, 3.2rem); font-weight: 350; letter-spacing: -0.012em; line-height: 1.06; margin: 0.6rem 0 0; max-width: 18ch; }
.cine-journey__steps { display: grid; gap: 0; list-style: none; margin: 0; padding: 0 0 14vh; }
.cine-step { display: grid; gap: 0.9rem 1.4rem; grid-template-columns: auto 1fr; align-content: center; min-height: 64vh; opacity: 0.32; transition: opacity 700ms var(--ease-cinematic); }
.cine-step.is-active { opacity: 1; }
.cine-step__no { font-family: var(--font-display); font-size: 1.5rem; font-weight: 400; color: var(--terra); line-height: 1; padding-top: 0.2rem; font-variant-numeric: tabular-nums; }
.cine-step__label { color: var(--terra); font: 600 0.72rem/1.2 "Host Grotesk", sans-serif; letter-spacing: 0.16em; margin: 0; text-transform: uppercase; }
.cine-step__title { color: var(--warm-ink); font-size: clamp(1.3rem, 1rem + 1.1vw, 1.95rem); font-weight: 380; letter-spacing: -0.01em; line-height: 1.12; margin: 0.5rem 0 0; }
.cine-step__text { color: var(--warm-muted); font-size: 1rem; line-height: 1.6; margin: 0.7rem 0 0; max-width: 42ch; }

/* ============================ ACT II : OBJECTS ============================ */
.cine-objects { background: var(--warm-bg); color: var(--warm-ink); padding: clamp(4rem, 11vh, 9rem) var(--gutter) clamp(4rem, 9vh, 8rem); }
.cine-objects__head { margin: 0 auto clamp(2.6rem, 5vw, 4rem); max-width: var(--measure); }
.cine-objects__title { color: var(--warm-ink); font-size: clamp(1.9rem, 1.2rem + 2.4vw, 3.3rem); font-weight: 350; letter-spacing: -0.012em; line-height: 1.06; margin: 0.5rem 0 0; max-width: 20ch; }
.cine-objects__row { display: grid; gap: clamp(1.2rem, 2.4vw, 2.2rem); grid-template-columns: repeat(3, 1fr); margin: 0 auto; max-width: var(--measure); perspective: 1400px; }
.cine-object { transform-style: preserve-3d; }
.cine-object__media {
  aspect-ratio: 4 / 3;
  border-radius: 10px;
  margin: 0 0 1.4rem;
  overflow: hidden;
  box-shadow: 0 26px 60px rgba(40, 28, 16, 0.2);
  transition: transform 500ms var(--ease-cinematic), box-shadow 500ms var(--ease-cinematic);
  will-change: transform;
}
.cine-object__media img { display: block; height: 100%; object-fit: cover; width: 100%; transition: transform 1400ms var(--ease-cinematic); }
.cine-object:hover .cine-object__media { box-shadow: 0 36px 80px rgba(40, 28, 16, 0.3); }
.cine-object:hover .cine-object__media img { transform: scale(1.05); }
.cine-object__kicker { color: var(--terra); font: 600 0.7rem/1.2 "Host Grotesk", sans-serif; letter-spacing: 0.16em; margin: 0 0 0.6rem; text-transform: uppercase; }
.cine-object__title { color: var(--warm-ink); font-size: clamp(1.2rem, 1rem + 0.7vw, 1.5rem); font-weight: 400; letter-spacing: -0.01em; line-height: 1.16; margin: 0; }
.cine-object__text { color: var(--warm-muted); font-size: 0.96rem; line-height: 1.56; margin: 0.7rem 0 0; }

/* ============================ ACT II : DEMOS ============================ */
.cine-demos { background: var(--warm-bg); color: var(--warm-ink); padding: clamp(3rem, 7vh, 6rem) var(--gutter) clamp(5rem, 12vh, 10rem); }
.cine-demos__head { margin: 0 auto clamp(2.4rem, 5vw, 4rem); max-width: var(--measure); }
.cine-demos__title { color: var(--warm-ink); font-size: clamp(1.9rem, 1.2rem + 2.4vw, 3.3rem); font-weight: 350; letter-spacing: -0.012em; line-height: 1.06; margin: 0.5rem 0 0; max-width: 22ch; }
.cine-demos__list { display: grid; gap: clamp(1.4rem, 2.5vw, 2.4rem); margin: 0 auto; max-width: var(--measure); }
.cine-demo {
  align-items: stretch;
  border-radius: 12px;
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  min-height: clamp(320px, 42vw, 460px);
  overflow: hidden;
  position: relative;
  text-decoration: none;
  transition: transform 600ms var(--ease-cinematic), box-shadow 600ms var(--ease-cinematic);
  will-change: transform;
}
.cine-demo:nth-child(even) { grid-template-columns: 0.85fr 1.15fr; }
.cine-demo:nth-child(even) .cine-demo__media { order: 2; }
.cine-demo:hover { transform: translateY(-5px); box-shadow: 0 38px 84px rgba(40, 28, 16, 0.26); }
.cine-demo__media { overflow: hidden; position: relative; }
.cine-demo__media img { height: 100%; object-fit: cover; width: 100%; transition: transform 1200ms var(--ease-cinematic); }
.cine-demo:hover .cine-demo__media img { transform: scale(1.06); }
.cine-demo__panel { display: flex; flex-direction: column; justify-content: center; padding: clamp(1.8rem, 3.4vw, 3.4rem); }
.cine-demo__place { font: 600 0.7rem/1.2 "Host Grotesk", sans-serif; letter-spacing: 0.16em; margin: 0 0 0.9rem; text-transform: uppercase; opacity: 0.72; }
.cine-demo__title { font-family: var(--font-display); font-size: clamp(1.6rem, 1.2rem + 1.6vw, 2.6rem); font-weight: 380; letter-spacing: -0.012em; line-height: 1.04; margin: 0; }
.cine-demo__tag { font-size: clamp(1rem, 0.95rem + 0.3vw, 1.15rem); line-height: 1.45; margin: 0.9rem 0 0; opacity: 0.82; }
.cine-demo__cta { align-items: center; display: inline-flex; font: 600 0.9rem/1 "Host Grotesk", sans-serif; gap: 0.55rem; margin-top: 1.8rem; }
.cine-demo__cta svg { width: 22px; transition: transform 460ms var(--ease-cinematic); }
.cine-demo:hover .cine-demo__cta svg { transform: translateX(6px); }
/* distinct demo worlds */
.cine-demo--atelier { background: #f6f1e8; color: #2a2620; }
.cine-demo--atelier .cine-demo__place, .cine-demo--atelier .cine-demo__cta { color: #8a7f6c; }
.cine-demo--vela { background: #12161a; color: #eef1f2; }
.cine-demo--vela .cine-demo__place { color: #8fb4b0; }
.cine-demo--vela .cine-demo__cta { color: #9fc3bd; }
.cine-demo--fjellro { background: #1f3329; color: #ede6d6; }
.cine-demo--fjellro .cine-demo__place { color: #b6cdae; }
.cine-demo--fjellro .cine-demo__cta { color: #d49a5f; }

/* ============================ ACT III : PHILOSOPHY ============================ */
.cine-philosophy { margin: 0 auto; max-width: 1150px; padding: clamp(6rem, 16vh, 13rem) var(--gutter); text-align: center; }
.cine-philosophy__statement {
  color: #f6efe2;
  font-family: var(--font-display);
  font-size: clamp(2rem, 1.1rem + 3.8vw, 4.6rem);
  font-weight: 330;
  letter-spacing: -0.014em;
  line-height: 1.08;
  margin: 0;
  text-wrap: balance;
}
.cine-philosophy__sign { color: var(--on-dark-soft); font-size: clamp(0.95rem, 0.9rem + 0.3vw, 1.1rem); margin: clamp(1.6rem, 3vw, 2.4rem) auto 0; max-width: 46ch; }

/* ============================ ACT III : INVITE ============================ */
.cine-invite { align-items: center; display: flex; isolation: isolate; min-height: 96svh; overflow: hidden; position: relative; }
.cine-invite__bg { position: absolute; inset: 0; z-index: -1; background-size: cover; background-position: center; transform: scale(1.06); }
.cine-invite::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(180deg, rgba(12, 8, 5, 0.74), rgba(12, 8, 5, 0.5) 45%, rgba(12, 8, 5, 0.82));
}
.cine-invite__inner { margin: 0 auto; max-width: 860px; padding: clamp(3.5rem, 11vh, 8rem) var(--gutter); text-align: center; }
.cine-invite__title { color: #fcf8f1; font-size: clamp(2.1rem, 1.3rem + 3.4vw, 4.2rem); font-weight: 340; letter-spacing: -0.014em; line-height: 1.03; margin: 0.6rem 0 0; text-wrap: balance; }
.cine-invite__text { color: var(--on-dark); font-size: clamp(1rem, 0.95rem + 0.32vw, 1.18rem); line-height: 1.6; margin: 1.2rem auto 0; max-width: 50ch; }

/* Project inquiry form (lives in the final CTA, on the dusk background). */
.cine-form { margin-top: clamp(2.2rem, 4.5vw, 3.4rem); text-align: left; }
.cine-form__grid { display: grid; gap: clamp(1rem, 2vw, 1.4rem); grid-template-columns: 1fr 1fr; }
.cine-field { display: flex; flex-direction: column; gap: 0.5rem; }
.cine-field--full { grid-column: 1 / -1; }
.cine-field__label { color: var(--on-dark); font: 600 0.78rem/1.2 "Host Grotesk", sans-serif; letter-spacing: 0.03em; }
.cine-field__input {
  background: rgba(247, 242, 233, 0.06);
  border: 1px solid rgba(247, 242, 233, 0.2);
  border-radius: 9px;
  color: #fbf7f0;
  font: 400 1rem/1.4 "Host Grotesk", sans-serif;
  padding: 0.85rem 1rem;
  transition: border-color 220ms ease, background-color 220ms ease;
  width: 100%;
}
.cine-field__input::placeholder { color: rgba(247, 242, 233, 0.38); }
.cine-field__input:focus-visible { outline: none; border-color: var(--brass-bright); background: rgba(247, 242, 233, 0.1); }
.cine-field__input--select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'%3E%3Cpath d='M1 1.5 6 6.5l5-5' fill='none' stroke='%23d6ab68' stroke-width='1.4' stroke-linecap='round'/%3E%3C/svg%3E");
  background-position: right 1rem center;
  background-repeat: no-repeat;
  background-size: 12px;
  cursor: pointer;
  padding-right: 2.6rem;
}
.cine-field__input--select option { color: #1a120a; }
.cine-field__input--textarea { min-height: 110px; resize: vertical; }
.cine-form__footer { align-items: center; display: flex; flex-wrap: wrap; gap: 1.1rem 1.6rem; justify-content: space-between; margin-top: clamp(1.5rem, 2.8vw, 2.1rem); }
.cine-form__submit { border: 0; cursor: pointer; font-family: "Host Grotesk", sans-serif; }
.cine-form__alt { color: var(--on-dark-soft); font-size: 0.92rem; margin: 0; }
.cine-form__alt a { border-bottom: 1px solid rgba(214, 171, 104, 0.4); color: var(--brass-bright); padding-bottom: 1px; text-decoration: none; }
.cine-form__alt a:hover { border-color: var(--brass-bright); }
.cine-form__status:not(:empty) { color: var(--brass-bright); font-size: 0.98rem; margin: clamp(1rem, 2vw, 1.4rem) 0 0; }
.cine-form__status.is-error { color: #f0a98c; }
.cine-form__submit[disabled] { cursor: progress; opacity: 0.6; }

/* ============================ HEADER / FOOTER on cinematic pages ============================ */
/* Header overlays the full-bleed hero (no flow space) so the hero fills the first viewport. */
.nv-cinema .site-header { background: transparent; border-bottom-color: transparent; position: fixed; top: 0; left: 0; right: 0; z-index: 60; }
/* Content pages have no full-bleed hero, so push their content clear of the fixed header.
   Specificity matches body:not(.home-page) .site-main so this overrides its padding-top by order. */
body.nv-cinema--page .site-main { padding-top: clamp(80px, 10vh, 104px); }
.nv-cinema .site-header__brand-name, .nv-cinema .site-header__link { color: var(--on-dark); }
.nv-cinema .site-header__brand-line { color: var(--on-dark-soft); }
.nv-cinema .site-header__brand-mark { color: var(--on-dark); }
.nv-cinema .site-header.is-scrolled {
  background: rgba(244, 237, 225, 0.86);
  backdrop-filter: saturate(1.2) blur(16px);
  border-bottom-color: rgba(34, 27, 19, 0.08);
}
.nv-cinema .site-header.is-scrolled .site-header__brand-name,
.nv-cinema .site-header.is-scrolled .site-header__link,
.nv-cinema .site-header.is-scrolled .site-header__brand-mark { color: var(--warm-ink); }
.nv-cinema .site-header.is-scrolled .site-header__brand-line { color: var(--warm-muted); }
.nv-cinema .site-footer { background: var(--ink); color: var(--on-dark); }
.nv-cinema .site-footer__name { color: #f6efe2; font-family: var(--font-display); }
.nv-cinema .site-footer a { color: var(--on-dark); }
.nv-cinema .site-footer a:hover { color: var(--brass-bright); }
.nv-cinema .site-footer__line, .nv-cinema .site-footer__rights { color: var(--on-dark-soft); }

/* ============================ CONTENT PAGES variant (.nv-cinema--page) ============================ */
body.nv-cinema--page { background-color: var(--warm-bg); color: var(--warm-ink); }
.nv-cinema--page .site-header__brand-name, .nv-cinema--page .site-header__link, .nv-cinema--page .site-header__brand-mark { color: var(--warm-ink); }
.nv-cinema--page .site-header__brand-line { color: var(--warm-muted); }

/* kickers + display headings -> brass / Fraunces */
.nv-cinema--page .section-kicker { color: var(--terra); font: 600 0.72rem/1.3 "Host Grotesk", sans-serif; letter-spacing: 0.2em; text-transform: uppercase; }
.nv-cinema--page .page-hero__title { font-family: var(--font-display); font-optical-sizing: auto; font-weight: 350; letter-spacing: -0.014em; line-height: 1.03; color: var(--warm-ink); font-size: clamp(2.3rem, 1.3rem + 3.6vw, 4.6rem); text-wrap: balance; }
.nv-cinema--page .page-hero__text { color: var(--warm-muted); font-size: clamp(1.05rem, 0.98rem + 0.4vw, 1.25rem); }
.nv-cinema--page .section-title { font-family: var(--font-display); font-optical-sizing: auto; font-weight: 360; letter-spacing: -0.012em; line-height: 1.08; color: var(--warm-ink); }
.nv-cinema--page .content-section > .section-head p:not(.section-kicker), .nv-cinema--page .page-hero p:not(.section-kicker), .nv-cinema--page .content-section p:not(.section-kicker) { color: var(--warm-muted); }

/* cards -> warm panels */
.nv-cinema--page .value-card,
.nv-cinema--page .factor-card,
.nv-cinema--page .pricing-card {
  background: var(--warm-panel);
  border: 1px solid rgba(34, 27, 19, 0.1);
  border-radius: 12px;
  color: var(--warm-ink);
}
.nv-cinema--page .value-card__title,
.nv-cinema--page .factor-card h3,
.nv-cinema--page .pricing-card__name { font-family: var(--font-display); font-weight: 400; letter-spacing: -0.01em; color: var(--warm-ink); }
.nv-cinema--page .value-card p, .nv-cinema--page .factor-card p, .nv-cinema--page .pricing-card p, .nv-cinema--page .pricing-card__best, .nv-cinema--page .editorial-list li { color: var(--warm-muted); }
.nv-cinema--page .pricing-card--featured { border-color: var(--brass); box-shadow: 0 26px 64px rgba(120, 80, 30, 0.15); }
.nv-cinema--page .pricing-card__flag { color: var(--terra); }
.nv-cinema--page .pricing-card__price { color: var(--terra); font-family: var(--font-display); }
.nv-cinema--page .pricing-card__block h4 { color: var(--warm-ink); }
.nv-cinema--page .pricing-card__note strong { color: var(--warm-ink); }
.nv-cinema--page .factor-card span { color: var(--brass); font-family: var(--font-display); font-weight: 400; }

/* faqs */
.nv-cinema--page .faq-item { border-color: rgba(34, 27, 19, 0.12); }
.nv-cinema--page .faq-item summary { color: var(--warm-ink); }
.nv-cinema--page .faq-item p { color: var(--warm-muted); }

/* closing cta -> ink panel */
.nv-cinema--page .closing-cta { background: var(--ink); color: var(--on-dark); border-radius: 18px; }
.nv-cinema--page .closing-cta h2 { font-family: var(--font-display); font-weight: 340; color: #f6efe2; }
.nv-cinema--page .closing-cta p { color: var(--on-dark-soft); }

/* faq jump card */
.nv-cinema--page .faq-jump-card { background: var(--warm-panel); border: 1px solid rgba(34, 27, 19, 0.1); border-radius: 12px; }
.nv-cinema--page .faq-jump-card h3 { font-family: var(--font-display); font-weight: 400; color: var(--warm-ink); }
.nv-cinema--page .faq-jump-card p { color: var(--warm-muted); }

/* buttons -> cinematic */
.nv-cinema--page .ui-button {
  background: var(--ink);
  border: 0;
  border-radius: 999px;
  color: var(--paper);
  transition: transform 500ms var(--ease-cinematic), box-shadow 500ms var(--ease-cinematic), background-color 360ms ease;
}
.nv-cinema--page .ui-button:hover { transform: translateY(-3px); box-shadow: 0 18px 42px rgba(0, 0, 0, 0.3); }
.nv-cinema--page .ui-button--secondary { background: transparent; color: var(--warm-ink); box-shadow: inset 0 0 0 1px rgba(34, 27, 19, 0.32); }
.nv-cinema--page .ui-button--secondary:hover { background: rgba(34, 27, 19, 0.05); }
.nv-cinema--page .closing-cta .ui-button { background: var(--paper); color: var(--ink); }

/* ============================ HERO LOAD CHOREOGRAPHY ============================ */
@media (prefers-reduced-motion: no-preference) {
  .nv-cinema .cine-hero__eyebrow { animation: cineRise 1100ms var(--ease-cinematic) 220ms both; }
  .nv-cinema .cine-hero__title { animation: cineRise 1200ms var(--ease-cinematic) 360ms both; }
  .nv-cinema .cine-hero__lede { animation: cineRise 1200ms var(--ease-cinematic) 520ms both; }
  .nv-cinema .cine-hero__actions { animation: cineRise 1200ms var(--ease-cinematic) 680ms both; }
  .nv-cinema .cine-hero__meta { animation: cineFade 1400ms ease 1000ms both; }
}
@keyframes cineRise { from { opacity: 0; transform: translateY(28px); } to { opacity: 1; transform: none; } }
@keyframes cineFade { from { opacity: 0; } to { opacity: 1; } }

/* ============================ RESPONSIVE ============================ */
@media (max-width: 920px) {
  .cine-hero__meta { display: none; }
  .cine-journey__grid { grid-template-columns: 1fr; }
  .cine-journey__media { position: relative; height: 58vh; }
  .cine-journey__rail { padding: clamp(2.5rem, 7vh, 4rem) var(--gutter); }
  .cine-step { opacity: 1; }
  .cine-objects__row { grid-template-columns: 1fr; max-width: 460px; }
  .cine-form__grid { grid-template-columns: 1fr; }
  .cine-form__footer { gap: 1.2rem; }
  .cine-demo, .cine-demo:nth-child(even) { grid-template-columns: 1fr; }
  .cine-demo__media { min-height: 230px; }
  .cine-demo:nth-child(even) .cine-demo__media { order: 0; }
  .cine-transform { height: auto; }
  .cine-transform__sticky { position: relative; height: auto; min-height: 78svh; }
  .cine-transform__img--after { clip-path: none; opacity: var(--reveal, 1); }
}

@media (prefers-reduced-motion: reduce) {
  .nv-cinema { transition: none; }
  .cine-hero__frame { transition: opacity 400ms ease; transform: none; }
  .cine-hero__frame.is-active { transform: none; }
  .cine-transform__img--after { clip-path: none; opacity: 1; }
  .cine-journey__frame { transition: opacity 400ms ease; transform: none; }
  .cine-journey__frame.is-active { transform: none; }
  .cine-object__media, .cine-object__media img, .cine-demo, .cine-demo__media img, .cine-btn { transition: none; }
  .cine-invite__bg { transform: none; }
}

/* ============================================================================
   /demos/ GATEWAY  (.demo-world*)  -- three immersive panels, each its own world.
   Not nv-cinema scoped (the index is .nv-demos); palettes use explicit values.
   ============================================================================ */
.demo-world-gateway {
  display: grid;
  gap: clamp(1rem, 2vw, 1.6rem);
  margin: clamp(1.5rem, 4vw, 3rem) auto 0;
  max-width: 1320px;
  padding: 0 clamp(1.15rem, 5vw, 4rem);
}
.demo-world {
  border-radius: 10px;
  display: block;
  isolation: isolate;
  min-height: clamp(360px, 52vh, 600px);
  overflow: hidden;
  position: relative;
  text-decoration: none;
  transition: transform 600ms cubic-bezier(0.19, 1, 0.22, 1), box-shadow 600ms cubic-bezier(0.19, 1, 0.22, 1);
}
.demo-world__media { position: absolute; inset: 0; z-index: 0; }
.demo-world__media img {
  display: block;
  height: 100%;
  object-fit: cover;
  transition: transform 1300ms cubic-bezier(0.19, 1, 0.22, 1), filter 900ms ease;
  width: 100%;
}
.demo-world__scrim { position: absolute; inset: 0; z-index: 1; }
.demo-world__body {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: inherit;
  padding: clamp(1.6rem, 3vw, 2.8rem);
  position: relative;
  z-index: 2;
}
.demo-world__index { font: 600 0.72rem/1.2 "Host Grotesk", sans-serif; letter-spacing: 0.16em; margin: 0; }
.demo-world__copy { max-width: 44ch; }
.demo-world__place { font: 600 0.72rem/1.2 "Host Grotesk", sans-serif; letter-spacing: 0.16em; margin: 0 0 0.7rem; text-transform: uppercase; }
.demo-world__name {
  font-family: "Fraunces", Georgia, serif;
  font-optical-sizing: auto;
  font-size: clamp(1.9rem, 1.3rem + 2.4vw, 3.4rem);
  font-weight: 400;
  letter-spacing: -0.01em;
  line-height: 1.02;
  margin: 0;
}
.demo-world__mood { font-size: clamp(1rem, 0.95rem + 0.3vw, 1.15rem); line-height: 1.5; margin: 0.9rem 0 0; }
.demo-world__cta { align-items: center; display: inline-flex; font: 600 0.9rem/1 "Host Grotesk", sans-serif; gap: 0.6rem; margin-top: 1.6rem; }
.demo-world__cta svg { transition: transform 500ms cubic-bezier(0.19, 1, 0.22, 1); width: 24px; }
.demo-world:hover { transform: translateY(-4px); }
.demo-world:hover .demo-world__cta svg { transform: translateX(6px); }
.demo-world:focus-visible { outline: 2px solid currentColor; outline-offset: 3px; }

/* Atelier: bright, architectural, precise -> measured crisp scale, light scrim, dark text. */
.demo-world--atelier { box-shadow: 0 18px 50px rgba(40, 34, 24, 0.12); color: #2a2620; }
.demo-world--atelier .demo-world__scrim { background: linear-gradient(180deg, rgba(244, 241, 234, 0) 32%, rgba(244, 241, 234, 0.5) 68%, rgba(244, 241, 234, 0.93)); }
.demo-world--atelier .demo-world__index, .demo-world--atelier .demo-world__place, .demo-world--atelier .demo-world__cta { color: #8a7f6c; }
.demo-world--atelier .demo-world__name { color: #221f1a; }
.demo-world--atelier:hover { box-shadow: 0 26px 64px rgba(40, 34, 24, 0.18); }
.demo-world--atelier:hover .demo-world__media img { transform: scale(1.035); }

/* Vela: dark, cinematic, coastal -> image starts dimmed; on hover the sea brightens and reveals (slow). */
.demo-world--vela { color: #eef1f2; }
.demo-world--vela .demo-world__scrim { background: linear-gradient(180deg, rgba(8, 10, 13, 0.55) 0%, rgba(8, 10, 13, 0.2) 38%, rgba(8, 10, 13, 0.78)); transition: background 900ms ease; }
.demo-world--vela .demo-world__index { color: rgba(238, 241, 242, 0.6); }
.demo-world--vela .demo-world__place { color: #8fb4b0; }
.demo-world--vela .demo-world__name { color: #f4f6f6; }
.demo-world--vela .demo-world__mood { color: rgba(238, 241, 242, 0.82); }
.demo-world--vela .demo-world__cta { color: #9fc3bd; }
.demo-world--vela .demo-world__media img { filter: brightness(0.82); }
.demo-world--vela:hover .demo-world__media img { filter: brightness(1); transform: scale(1.04); }
.demo-world--vela:hover .demo-world__scrim { background: linear-gradient(180deg, rgba(8, 10, 13, 0.42) 0%, rgba(8, 10, 13, 0.1) 42%, rgba(8, 10, 13, 0.7)); }

/* Fjellro: warm, tactile, forest -> gentle warm drift (brightness + saturation lift). */
.demo-world--fjellro { color: #ede6d6; }
.demo-world--fjellro .demo-world__scrim { background: linear-gradient(180deg, rgba(20, 28, 22, 0.42) 0%, rgba(20, 28, 22, 0.14) 40%, rgba(20, 28, 22, 0.8)); }
.demo-world--fjellro .demo-world__index { color: rgba(237, 230, 214, 0.62); }
.demo-world--fjellro .demo-world__place { color: #b6cdae; }
.demo-world--fjellro .demo-world__name { color: #f2ece0; }
.demo-world--fjellro .demo-world__mood { color: rgba(237, 230, 214, 0.85); }
.demo-world--fjellro .demo-world__cta { color: #d49a5f; }
.demo-world--fjellro:hover .demo-world__media img { filter: brightness(1.05) saturate(1.05); transform: scale(1.03); }

@media (prefers-reduced-motion: reduce) {
  .demo-world, .demo-world__media img, .demo-world__cta svg, .demo-world--vela .demo-world__scrim { transition: none; }
  .demo-world:hover { transform: none; }
  .demo-world:hover .demo-world__media img { transform: none; }
}

/* ============================================================================
   DEMO DETAIL ADDITIONS  -- per-world, deliberately NOT shared in look or motion.
   ATELIER: bright / architectural / measured. (Cormorant identity serif.)
   ============================================================================ */
.atelier-atmos { margin: 0 auto; max-width: 1280px; padding: clamp(3rem, 7vw, 6rem) clamp(1.15rem, 5vw, 4rem); }
.atelier-atmos__head { margin-bottom: clamp(1.6rem, 3vw, 2.6rem); }
.atelier-atmos__head h2 { color: #221f1a; font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(1.8rem, 1.2rem + 2vw, 3rem); font-weight: 500; letter-spacing: -0.01em; line-height: 1.04; margin: 0.4rem 0 0; }
.atelier-atmos__grid { display: grid; gap: clamp(0.8rem, 1.6vw, 1.4rem); grid-template-columns: repeat(3, 1fr); }
.atelier-atmos__item { border-radius: 2px; margin: 0; overflow: hidden; position: relative; }
.atelier-atmos__item img { aspect-ratio: 3 / 4; display: block; object-fit: cover; transition: transform 900ms cubic-bezier(0.22, 0.61, 0.36, 1); width: 100%; }
.atelier-atmos__item:hover img { transform: scale(1.04); }
.atelier-atmos__item figcaption { bottom: 0; color: #fff; font: 600 0.72rem/1 "Host Grotesk", sans-serif; left: 0; letter-spacing: 0.14em; padding: 0.8rem 1.1rem; position: absolute; text-shadow: 0 1px 12px rgba(0, 0, 0, 0.55); text-transform: uppercase; }

.atelier-seq { align-items: stretch; background: #f4f1ea; display: grid; grid-template-columns: 1.4fr 1fr; }
.atelier-seq__stage { min-height: clamp(360px, 52vh, 620px); overflow: hidden; position: relative; }
.atelier-seq__frame { background-position: center; background-size: cover; inset: 0; opacity: 0; position: absolute; }
.atelier-seq__frame:nth-child(1) { opacity: 1; }
.atelier-seq__copy { display: flex; flex-direction: column; justify-content: center; padding: clamp(2rem, 4vw, 4rem); }
.atelier-seq__copy h2 { color: #221f1a; font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(1.8rem, 1.2rem + 2vw, 3rem); font-weight: 500; letter-spacing: -0.01em; line-height: 1.03; margin: 0.4rem 0 0; }
.atelier-seq__copy p { color: #4a4438; line-height: 1.6; margin: 1rem 0 0; max-width: 38ch; }
@media (prefers-reduced-motion: no-preference) {
  .atelier-seq__frame { animation: atelierSeq 18s linear infinite; }
  .atelier-seq__frame:nth-child(1) { animation-delay: -1s; }
  .atelier-seq__frame:nth-child(2) { animation-delay: 5s; }
  .atelier-seq__frame:nth-child(3) { animation-delay: 11s; }
}
@keyframes atelierSeq {
  0% { opacity: 0; }
  4% { opacity: 1; }
  30% { opacity: 1; }
  37% { opacity: 0; }
  100% { opacity: 0; }
}
@media (max-width: 860px) {
  .atelier-atmos__grid { grid-template-columns: 1fr; }
  .atelier-atmos__item img { aspect-ratio: 16 / 11; }
  .atelier-seq { grid-template-columns: 1fr; }
  .atelier-seq__stage { min-height: 56vh; }
}

/* VELA: dark / cinematic / slow. (clean grotesque, asymmetric grid, full-bleed sequence.) */
.vela-atmos { background: #0f1317; padding: clamp(3.5rem, 8vw, 7rem) clamp(1.15rem, 5vw, 4rem); }
.vela-atmos__head { margin: 0 auto clamp(1.8rem, 3vw, 3rem); max-width: 1280px; }
.vela-atmos__kicker { color: #8fb4b0; }
.vela-atmos__head h2 { color: #eef1f2; font-family: "Host Grotesk", sans-serif; font-size: clamp(1.7rem, 1.1rem + 2vw, 2.9rem); font-weight: 300; letter-spacing: -0.01em; line-height: 1.08; margin: 0.5rem 0 0; }
.vela-atmos__grid { display: grid; gap: clamp(0.7rem, 1.4vw, 1.2rem); grid-template-columns: 1.5fr 1fr; grid-template-rows: 1fr 1fr; margin: 0 auto; max-width: 1280px; min-height: clamp(420px, 50vw, 640px); }
.vela-atmos__item { border-radius: 3px; margin: 0; overflow: hidden; position: relative; }
.vela-atmos__item:nth-child(1) { grid-row: span 2; }
.vela-atmos__item img { display: block; filter: brightness(0.86); height: 100%; object-fit: cover; transition: filter 1100ms ease, transform 1600ms cubic-bezier(0.19, 1, 0.22, 1); width: 100%; }
.vela-atmos__item:hover img { filter: brightness(1.02); transform: scale(1.03); }
.vela-atmos__item figcaption { bottom: 0; color: #eef1f2; font: 600 0.72rem/1 "Host Grotesk", sans-serif; left: 0; letter-spacing: 0.16em; padding: 0.9rem 1.2rem; position: absolute; text-transform: uppercase; }

.vela-seq { align-items: flex-end; display: flex; isolation: isolate; min-height: clamp(420px, 80vh, 760px); overflow: hidden; position: relative; }
.vela-seq__stage { inset: 0; position: absolute; z-index: -2; }
.vela-seq__frame { background-position: center; background-size: cover; inset: 0; opacity: 0; position: absolute; transform: scale(1.04); }
.vela-seq__frame:nth-child(1) { opacity: 1; }
.vela-seq__veil { background: linear-gradient(180deg, rgba(8, 10, 13, 0.5) 0%, rgba(8, 10, 13, 0.15) 40%, rgba(8, 10, 13, 0.9)); inset: 0; position: absolute; z-index: -1; }
.vela-seq__copy { max-width: 640px; padding: clamp(2rem, 5vw, 5rem); }
.vela-seq__copy h2 { color: #f4f6f6; font-family: "Host Grotesk", sans-serif; font-size: clamp(1.9rem, 1.2rem + 2.6vw, 3.6rem); font-weight: 300; letter-spacing: -0.012em; line-height: 1.04; margin: 0.5rem 0 0; }
.vela-seq__copy p { color: rgba(238, 241, 242, 0.82); line-height: 1.6; margin: 1.1rem 0 0; max-width: 46ch; }
@media (prefers-reduced-motion: no-preference) {
  .vela-seq__frame { animation: velaSeq 24s ease-in-out infinite; }
  .vela-seq__frame:nth-child(1) { animation-delay: -1.5s; }
  .vela-seq__frame:nth-child(2) { animation-delay: 6.5s; }
  .vela-seq__frame:nth-child(3) { animation-delay: 14.5s; }
}
@keyframes velaSeq {
  0% { opacity: 0; transform: scale(1.08); }
  6% { opacity: 1; }
  30% { opacity: 1; }
  40% { opacity: 0; transform: scale(1); }
  100% { opacity: 0; }
}
@media (max-width: 860px) {
  .vela-atmos__grid { grid-template-columns: 1fr; grid-template-rows: none; min-height: 0; }
  .vela-atmos__item:nth-child(1) { grid-row: auto; }
  .vela-atmos__item img { aspect-ratio: 16 / 11; }
  .vela-seq { min-height: 64vh; }
}

/* FJELLRO: warm / tactile / forest / grounded. (sturdy sans, landscape grid, copy-left split, gentle drift.) */
.fjellro-atmos { background: #1f3329; padding: clamp(3.5rem, 8vw, 7rem) clamp(1.15rem, 5vw, 4rem); }
.fjellro-atmos__head { margin: 0 auto clamp(1.8rem, 3vw, 2.8rem); max-width: 1240px; }
.fjellro-atmos__kicker { color: #d49a5f; font: 600 0.72rem/1.2 "Host Grotesk", sans-serif; letter-spacing: 0.16em; margin: 0; text-transform: uppercase; }
.fjellro-atmos__head h2 { color: #f2ece0; font-family: "Host Grotesk", sans-serif; font-size: clamp(1.7rem, 1.1rem + 2vw, 2.8rem); font-weight: 600; letter-spacing: -0.01em; line-height: 1.1; margin: 0.5rem 0 0; max-width: 22ch; }
.fjellro-atmos__grid { display: grid; gap: clamp(0.8rem, 1.6vw, 1.4rem); grid-template-columns: repeat(3, 1fr); margin: 0 auto; max-width: 1240px; }
.fjellro-atmos__item { border-radius: 10px; box-shadow: 0 16px 40px rgba(0, 0, 0, 0.28); margin: 0; overflow: hidden; position: relative; }
.fjellro-atmos__item img { aspect-ratio: 4 / 3; display: block; object-fit: cover; transition: transform 1400ms ease, filter 1000ms ease; width: 100%; }
.fjellro-atmos__item:hover img { filter: brightness(1.06) saturate(1.05); transform: scale(1.04); }
.fjellro-atmos__item figcaption { bottom: 0; color: #f2ece0; font: 600 0.72rem/1 "Host Grotesk", sans-serif; left: 0; letter-spacing: 0.14em; padding: 0.8rem 1.1rem; position: absolute; text-shadow: 0 1px 12px rgba(0, 0, 0, 0.5); text-transform: uppercase; }

.fjellro-seq { align-items: stretch; background: #24382c; display: grid; grid-template-columns: 1fr 1.4fr; }
.fjellro-seq__copy { display: flex; flex-direction: column; justify-content: center; padding: clamp(2rem, 4vw, 4rem); }
.fjellro-seq__copy h2 { color: #f2ece0; font-family: "Host Grotesk", sans-serif; font-size: clamp(1.7rem, 1.1rem + 2vw, 2.8rem); font-weight: 600; letter-spacing: -0.01em; line-height: 1.08; margin: 0.5rem 0 0; }
.fjellro-seq__copy p { color: rgba(237, 230, 214, 0.82); line-height: 1.6; margin: 1.1rem 0 0; max-width: 40ch; }
.fjellro-seq__stage { min-height: clamp(360px, 52vh, 620px); overflow: hidden; position: relative; }
.fjellro-seq__frame { background-position: center; background-size: cover; inset: 0; opacity: 0; position: absolute; transform: scale(1.03); }
.fjellro-seq__frame:nth-child(1) { opacity: 1; }
@media (prefers-reduced-motion: no-preference) {
  .fjellro-seq__frame { animation: fjellroSeq 21s ease-in-out infinite; }
  .fjellro-seq__frame:nth-child(1) { animation-delay: -1s; }
  .fjellro-seq__frame:nth-child(2) { animation-delay: 6s; }
  .fjellro-seq__frame:nth-child(3) { animation-delay: 13s; }
}
@keyframes fjellroSeq {
  0% { opacity: 0; }
  5% { opacity: 1; }
  30% { opacity: 1; }
  38% { opacity: 0; }
  100% { opacity: 0; }
}
@media (max-width: 860px) {
  .fjellro-atmos__grid { grid-template-columns: 1fr; }
  .fjellro-seq { grid-template-columns: 1fr; }
  .fjellro-seq__copy { order: 1; }
  .fjellro-seq__stage { min-height: 54vh; order: 2; }
}

/* ---- ATELIER finishing: precise booking-clarity grid + restrained architectural hover tilt ---- */
.atelier-detail {
  align-items: start;
  display: grid;
  gap: clamp(1rem, 2.4vw, 2rem) clamp(1.2rem, 3vw, 2.6rem);
  grid-template-areas: "copy booking" "object booking";
  grid-template-columns: 1fr 1.25fr;
  margin: 0 auto;
  max-width: 1280px;
  padding: clamp(2rem, 5vw, 4rem) clamp(1.15rem, 5vw, 4rem) clamp(3rem, 7vw, 6rem);
}
.atelier-detail__copy { align-self: center; grid-area: copy; }
.atelier-detail__copy h2 { color: #221f1a; font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(1.7rem, 1.1rem + 1.8vw, 2.7rem); font-weight: 500; letter-spacing: -0.01em; line-height: 1.05; margin: 0.4rem 0 0; }
.atelier-detail__copy p { color: #4a4438; line-height: 1.6; margin: 1rem 0 0; max-width: 34ch; }
.atelier-detail__booking { border-radius: 3px; box-shadow: 0 18px 50px rgba(40, 34, 24, 0.14); grid-area: booking; margin: 0; overflow: hidden; }
.atelier-detail__booking img { display: block; height: 100%; object-fit: cover; width: 100%; }
.atelier-detail__object { border-radius: 3px; grid-area: object; margin: 0; overflow: hidden; transition: transform 700ms cubic-bezier(0.22, 0.61, 0.36, 1), box-shadow 700ms ease; }
.atelier-detail__object img { aspect-ratio: 16 / 9; display: block; object-fit: cover; width: 100%; }
.atelier-detail__object:hover { box-shadow: 0 22px 50px rgba(40, 34, 24, 0.2); transform: perspective(900px) rotateX(2deg) rotateY(-3deg) translateY(-2px); }

/* ---- VELA finishing: full-bleed moody reserve moment + candle glow + floating object ---- */
.vela-reserve { align-items: center; display: flex; isolation: isolate; min-height: clamp(460px, 84vh, 800px); overflow: hidden; position: relative; }
.vela-reserve__bg { inset: 0; margin: 0; position: absolute; z-index: -3; }
.vela-reserve__bg img { display: block; filter: brightness(0.62) saturate(0.95); height: 100%; object-fit: cover; width: 100%; }
.vela-reserve__veil { background: linear-gradient(110deg, rgba(8, 10, 13, 0.9) 0%, rgba(8, 10, 13, 0.55) 45%, rgba(8, 10, 13, 0.72)); inset: 0; position: absolute; z-index: -2; }
.vela-reserve__glow { background: radial-gradient(circle, rgba(214, 150, 70, 0.3), rgba(214, 150, 70, 0) 65%); filter: blur(8px); height: 38vw; left: 6%; max-height: 540px; max-width: 540px; position: absolute; top: 34%; width: 38vw; z-index: -1; }
.vela-reserve__panel { max-width: 560px; padding: clamp(2rem, 5vw, 5rem); position: relative; }
.vela-reserve__kicker { color: #9fc3bd; font: 600 0.72rem/1.2 "Host Grotesk", sans-serif; letter-spacing: 0.16em; margin: 0; text-transform: uppercase; }
.vela-reserve__panel h2 { color: #f4f6f6; font-family: "Host Grotesk", sans-serif; font-size: clamp(1.9rem, 1.2rem + 2.4vw, 3.4rem); font-weight: 300; letter-spacing: -0.012em; line-height: 1.05; margin: 0.5rem 0 0; }
.vela-reserve__panel p { color: rgba(238, 241, 242, 0.82); line-height: 1.6; margin: 1.1rem 0 1.8rem; max-width: 40ch; }
.vela-reserve__object { border-radius: 4px; bottom: clamp(1.5rem, 4vw, 4rem); box-shadow: 0 30px 70px rgba(0, 0, 0, 0.6); margin: 0; overflow: hidden; position: absolute; right: clamp(1.5rem, 4vw, 4rem); width: clamp(240px, 32vw, 440px); }
.vela-reserve__object img { aspect-ratio: 16 / 9; display: block; filter: brightness(0.92); object-fit: cover; transition: filter 1200ms ease; width: 100%; }
.vela-reserve__object:hover img { filter: brightness(1.05); }
@media (prefers-reduced-motion: no-preference) {
  .vela-reserve__glow { animation: velaCandle 6s ease-in-out infinite; }
}
@keyframes velaCandle {
  0%, 100% { opacity: 0.8; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.06); }
}

/* ---- FJELLRO finishing: tactile cards that paper-lift with a warm shadow ---- */
.fjellro-detail { background: #1f3329; padding: clamp(2.5rem, 6vw, 5rem) clamp(1.15rem, 5vw, 4rem); }
.fjellro-detail__inner { align-items: center; display: grid; gap: clamp(1.4rem, 3vw, 2.6rem); grid-template-columns: 0.82fr 1.18fr; margin: 0 auto; max-width: 1240px; }
.fjellro-detail__copy h2 { color: #f2ece0; font-family: "Host Grotesk", sans-serif; font-size: clamp(1.6rem, 1.1rem + 1.8vw, 2.6rem); font-weight: 600; letter-spacing: -0.01em; line-height: 1.1; margin: 0.5rem 0 0; max-width: 18ch; }
.fjellro-detail__copy p { color: rgba(237, 230, 214, 0.82); line-height: 1.6; margin: 1rem 0 0; max-width: 36ch; }
.fjellro-detail__cards { display: grid; gap: clamp(0.9rem, 1.8vw, 1.4rem); grid-template-columns: 1fr 1fr; }
.fjellro-detail__card { border-radius: 10px; box-shadow: 0 14px 32px rgba(0, 0, 0, 0.3); margin: 0; overflow: hidden; position: relative; transition: transform 600ms cubic-bezier(0.34, 1.2, 0.64, 1), box-shadow 600ms ease; }
.fjellro-detail__card img { aspect-ratio: 4 / 3; display: block; object-fit: cover; width: 100%; }
.fjellro-detail__card figcaption { bottom: 0; color: #f2ece0; font: 600 0.68rem/1.1 "Host Grotesk", sans-serif; left: 0; letter-spacing: 0.12em; padding: 0.7rem 1rem; position: absolute; text-shadow: 0 1px 10px rgba(0, 0, 0, 0.6); text-transform: uppercase; }
.fjellro-detail__card:hover { box-shadow: 0 28px 56px rgba(0, 0, 0, 0.42); transform: translateY(-8px); }

@media (max-width: 860px) {
  .atelier-detail { grid-template-areas: "copy" "booking" "object"; grid-template-columns: 1fr; }
  .vela-reserve { align-items: stretch; flex-direction: column; min-height: 0; }
  .vela-reserve__panel { max-width: none; }
  .vela-reserve__object { bottom: auto; margin: 0 clamp(1.15rem, 5vw, 4rem) clamp(2rem, 6vw, 3rem); position: relative; right: auto; width: auto; }
  .fjellro-detail__inner { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  .atelier-detail__object, .fjellro-detail__card, .vela-reserve__object img { transition: none; }
  .atelier-detail__object:hover { transform: none; }
  .fjellro-detail__card:hover { transform: none; }
}
