/* ====================================================================
   OTIVARA — Private wellness retreats, built into the home.
   A design-build studio for coastal San Diego.

   An editorial, scroll-driven, ultra-luxury stylesheet.
   Resting visual design + JS-toggled states. GSAP owns the motion.
   ==================================================================== */


/* ====================================================================
   1. RESET & TOKENS
   ==================================================================== */

*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

:root {
  /* Palette — quiet luxury, warm & muted */
  --bone:     #F4F1EA;
  --paper:    #FBFAF6;
  --ink:      #16150F;
  --ink-2:    #262219;
  --ink-soft: #3A372F;
  --stone:    #8C8579;
  --line:     #D9D3C7;
  --accent:   #9C6A45;  /* warm clay */
  --accent-2: #7E5436;

  /* Translucent helpers (over dark grounds) */
  --paper-80: rgba(251, 250, 246, 0.80);
  --paper-55: rgba(251, 250, 246, 0.55);
  --paper-35: rgba(251, 250, 246, 0.35);
  --paper-14: rgba(251, 250, 246, 0.14);
  --paper-08: rgba(251, 250, 246, 0.08);

  /* Type */
  --serif: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:  'Inter', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;

  /* Motion */
  --ease:      cubic-bezier(0.16, 1, 0.3, 1);
  --ease-soft: cubic-bezier(0.4, 0, 0.2, 1);

  /* Rhythm */
  --gutter:    clamp(1.4rem, 5vw, 5.5rem);
  --section-y: clamp(6rem, 14vw, 13rem);
  --maxw:      1560px;
}

html {
  /* NOTE: no scroll-behavior here — Lenis owns smooth scroll. */
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--sans);
  background: var(--bone);
  color: var(--ink);
  font-weight: 300;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

a   { color: inherit; text-decoration: none; }
ol, ul { list-style: none; }
img { display: block; max-width: 100%; }
button {
  background: none; border: 0; color: inherit; font: inherit; cursor: pointer;
}
input, textarea, select { font: inherit; color: inherit; }

::selection { background: var(--accent); color: var(--paper); }

/* Shared content wrapper */
.wrap {
  width: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
  padding-inline: var(--gutter);
}


/* ====================================================================
   2. SHARED — KICKERS, BUTTONS, LINKS
   ==================================================================== */

/* Kicker / label: Inter uppercase w/ hairline lead-in rule */
.manifesto__kicker,
.studio__kicker,
.work__kicker,
.process__kicker,
.consult__kicker,
.scene__kicker,
.hero__eyebrow,
.preloader__tag {
  font-family: var(--sans);
  font-size: 0.72rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  gap: 0.85em;
}
.manifesto__kicker::before,
.studio__kicker::before,
.work__kicker::before,
.process__kicker::before,
.consult__kicker::before,
.scene__kicker::before {
  content: '';
  width: clamp(28px, 4vw, 34px);
  height: 1px;
  background: currentColor;
  opacity: 0.7;
  flex: none;
}

/* ---- Buttons ---- */
.btn {
  --btn-fg: var(--ink);
  --btn-edge: var(--ink);
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--sans);
  font-size: 0.74rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--btn-fg);
  padding: 1.05em 1.7em;
  border: 1px solid var(--btn-edge);
  border-radius: 2px;
  overflow: hidden;
  isolation: isolate;
  transition: color 0.55s var(--ease), border-color 0.55s var(--ease);
}
.btn > * { position: relative; z-index: 1; }
.btn::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  background: var(--btn-edge);
  transform: scaleY(0);
  transform-origin: bottom;
  transition: transform 0.55s var(--ease);
}
.btn:hover::before { transform: scaleY(1); }

/* Light button — sits on dark grounds (hero) */
.btn--light {
  --btn-fg: var(--paper);
  --btn-edge: var(--paper);
}
.btn--light:hover { color: var(--ink); }

/* Dark button — sits inside the dark consult section */
.btn--dark {
  --btn-fg: var(--ink);
  --btn-edge: var(--paper);
  background: var(--paper);
}
.btn--dark::before { background: var(--accent); }
.btn--dark:hover { color: var(--paper); border-color: var(--accent); }

/* ---- Animated wipe underline ---- */
.link-underline {
  position: relative;
  color: var(--accent-2);
  white-space: nowrap;
  background-image: linear-gradient(var(--accent), var(--accent));
  background-repeat: no-repeat;
  background-position: 0 100%;
  background-size: 0% 1px;
  transition: background-size 0.5s var(--ease);
  padding-bottom: 1px;
}
.link-underline:hover { background-size: 100% 1px; }


/* ====================================================================
   3. FILM GRAIN
   ==================================================================== */

#grain {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 80;
  pointer-events: none;
  opacity: 0.05;
  mix-blend-mode: soft-light;
}


/* ====================================================================
   4. CUSTOM CURSOR
   ==================================================================== */

#cursor {
  position: fixed;
  top: 0; left: 0;
  z-index: 9000;
  pointer-events: none;
  transition: opacity 0.4s var(--ease-soft);
  mix-blend-mode: difference;
  will-change: transform;
}
#cursor.is-hidden { opacity: 0; }

.cursor__dot,
.cursor__ring {
  position: absolute;
  top: 0; left: 0;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}
.cursor__dot {
  width: 6px; height: 6px;
  background: var(--paper);
  transition: opacity 0.35s var(--ease-soft), transform 0.35s var(--ease-soft);
}
.cursor__ring {
  width: 38px; height: 38px;
  border: 1px solid var(--paper-55);
  transition: transform 0.45s var(--ease), border-color 0.45s var(--ease);
}
#cursor.is-hover .cursor__ring { transform: translate(-50%, -50%) scale(2.4); border-color: var(--paper-35); }
#cursor.is-hover .cursor__dot  { opacity: 0; transform: translate(-50%, -50%) scale(0.4); }


/* ====================================================================
   5. MAGNETIC
   ==================================================================== */

.magnetic {
  will-change: transform;
  transition: transform 0.6s var(--ease);
}


/* ====================================================================
   6. PRELOADER
   ==================================================================== */

#preloader {
  position: fixed;
  inset: 0;
  z-index: 8000;
  background: var(--ink);
  color: var(--paper);
  display: grid;
  place-items: center;
  overflow: hidden;
  transition: opacity 0.8s var(--ease), clip-path 0.9s var(--ease);
  clip-path: inset(0 0 0 0);
}
#preloader.is-done {
  opacity: 0;
  clip-path: inset(0 0 100% 0);
  pointer-events: none;
}

.preloader__inner {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}
.preloader__brand {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(3rem, 10vw, 7rem);
  line-height: 1;
  letter-spacing: 0.01em;
  color: var(--paper);
}
.preloader__tag {
  color: var(--paper-55);
}

.preloader__count {
  position: absolute;
  bottom: clamp(1.6rem, 4vw, 3rem);
  right: clamp(1.6rem, 4vw, 3.5rem);
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(3.5rem, 12vw, 9rem);
  line-height: 1;
  color: var(--paper);
}
.preloader__count i {
  font-style: normal;
  font-variant-numeric: tabular-nums;
}
.preloader__count::after {
  content: '%';
  font-size: 0.3em;
  vertical-align: super;
  color: var(--accent);
  margin-left: 0.1em;
}


/* ====================================================================
   7. NAV
   ==================================================================== */

#nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: clamp(1.3rem, 2.4vw, 2.1rem) var(--gutter);
  color: var(--paper);
  transition: background 0.6s var(--ease), color 0.6s var(--ease),
              padding 0.6s var(--ease), transform 0.55s var(--ease),
              border-color 0.6s var(--ease);
  border-bottom: 1px solid transparent;
}
#nav.is-scrolled {
  background: var(--paper);
  color: var(--ink);
  border-bottom-color: var(--line);
  padding-top: clamp(0.95rem, 1.6vw, 1.4rem);
  padding-bottom: clamp(0.95rem, 1.6vw, 1.4rem);
}
#nav.is-hidden { transform: translateY(-100%); }

.nav__brand {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.4rem, 2vw, 1.75rem);
  line-height: 1;
  letter-spacing: 0.01em;
}

.nav__links {
  display: flex;
  gap: clamp(1.5rem, 3vw, 2.8rem);
}
.nav__links a {
  position: relative;
  font-size: 0.74rem;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.16em;
}
.nav__links a::after {
  content: '';
  position: absolute;
  left: 0; bottom: -0.4rem;
  height: 1px; width: 0;
  background: currentColor;
  transition: width 0.5s var(--ease);
}
.nav__links a:hover::after { width: 100%; }

.nav__cta {
  position: relative;
  font-size: 0.74rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  padding: 0.7em 1.25em;
  border: 1px solid currentColor;
  border-radius: 2px;
  overflow: hidden;
  isolation: isolate;
  transition: color 0.5s var(--ease);
}
.nav__cta::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s var(--ease);
}
.nav__cta:hover { color: var(--paper); border-color: var(--accent); }
.nav__cta:hover::before { transform: scaleX(1); }


/* ====================================================================
   8. HERO — scroll-scrub canvas
   ==================================================================== */

.hero {
  position: relative;
  height: 500vh;          /* tall scroll track */
  background: var(--ink);
}
.hero__sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
}
.hero__canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  background: var(--ink);
}
.hero__scrim {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(to bottom,
      rgba(8, 8, 6, 0.55) 0%,
      rgba(8, 8, 6, 0.12) 26%,
      rgba(8, 8, 6, 0.05) 55%,
      rgba(8, 8, 6, 0.45) 86%,
      rgba(8, 8, 6, 0.62) 100%);
}

/* Intro (centered) */
.hero__intro {
  position: absolute;
  left: 0; right: 0;
  top: 50%;
  transform: translateY(-50%);
  padding-inline: var(--gutter);
  text-align: center;
  color: var(--paper);
  transition: opacity 0.8s var(--ease), filter 0.8s var(--ease), transform 0.8s var(--ease);
}
.hero__intro.is-hidden {
  opacity: 0;
  filter: blur(8px);
  transform: translateY(-58%);
  pointer-events: none;
}
.hero__eyebrow {
  justify-content: center;
  color: var(--paper-55);
  margin-bottom: clamp(1.1rem, 2.5vw, 1.8rem);
}
.hero__lede {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2.6rem, 6.8vw, 6.5rem);
  line-height: 1.02;
  letter-spacing: -0.01em;
  color: var(--paper);
}

/* Captions — stacked in the same grid cell, mid-screen */
.hero__captions {
  position: absolute;
  left: 0; right: 0;
  top: 50%;
  transform: translateY(-50%);
  display: grid;
  place-items: center;
  text-align: center;
  pointer-events: none;
}
.hero__caption {
  grid-area: 1 / 1;
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.28em;
  color: var(--paper);
  opacity: 0;
  transition: opacity 0.7s var(--ease);
}
.hero__caption.is-active { opacity: 0.85; }

/* Resolve — bottom-anchored final state */
.hero__resolve {
  position: absolute;
  left: 0; right: 0;
  bottom: clamp(4rem, 9vh, 8rem);
  padding-inline: var(--gutter);
  text-align: center;
  color: var(--paper);
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.9s var(--ease), transform 0.9s var(--ease);
  pointer-events: none;
}
.hero__resolve.is-shown { opacity: 1; transform: none; pointer-events: auto; }
.hero__resolve-mark {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2rem, 4.5vw, 3.4rem);
  line-height: 1;
  margin-bottom: 1rem;
}
.hero__sub {
  max-width: 46ch;
  margin: 0 auto 1.8rem;
  color: var(--paper-80);
  font-size: clamp(0.95rem, 1.2vw, 1.08rem);
  line-height: 1.65;
}

/* Scroll cue */
.hero__cue {
  position: absolute;
  bottom: clamp(1.3rem, 3vh, 2.2rem);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.85rem;
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.24em;
  color: var(--paper-55);
  transition: opacity 0.6s var(--ease);
}
.hero__cue.is-hidden { opacity: 0; }
.hero__cue span {
  display: block;
  width: 1px;
  height: 46px;
  background: linear-gradient(to bottom, var(--paper-55), transparent);
  animation: cueLine 2.4s var(--ease) infinite;
  transform-origin: top;
}
@keyframes cueLine {
  0%   { transform: scaleY(0); opacity: 0; }
  35%  { transform: scaleY(1); opacity: 1; }
  100% { transform: scaleY(1); opacity: 0; }
}


/* ====================================================================
   9. GLOBAL REVEAL (the ONLY pre-hidden group)
   ==================================================================== */

[data-reveal] {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity 0.9s var(--ease), transform 0.9s var(--ease);
}
[data-reveal].is-in { opacity: 1; transform: none; }


/* ====================================================================
   10. MANIFESTO
   ==================================================================== */

.manifesto {
  padding-block: var(--section-y);
  background: var(--bone);
}
.manifesto__kicker { margin-bottom: clamp(2.5rem, 6vw, 4.5rem); }
.manifesto__lines {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2rem, 5.4vw, 5rem);
  line-height: 1.08;
  letter-spacing: -0.01em;
  max-width: 22ch;
}
.manifesto__lines .line { display: block; }
.manifesto__lines .line--dim  { color: var(--stone); }
.manifesto__lines .line--lead { color: var(--ink); margin-top: 0.35em; }
.manifesto__body {
  margin-top: clamp(2.5rem, 6vw, 4.5rem);
  max-width: 58ch;
  font-size: clamp(1rem, 1.25vw, 1.15rem);
  line-height: 1.75;
  color: var(--ink-soft);
}


/* ====================================================================
   11. STUDIO — unified offering
   ==================================================================== */

.studio {
  padding-block: var(--section-y);
  background: var(--paper);
  border-top: 1px solid var(--line);
}
.studio__kicker { margin-bottom: clamp(1.6rem, 3.5vw, 2.6rem); }
.studio__head {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2.1rem, 5vw, 4.6rem);
  line-height: 1.08;
  letter-spacing: -0.01em;
  max-width: 18ch;
}
.studio__body {
  margin-top: clamp(1.8rem, 4vw, 3rem);
  max-width: 56ch;
  font-size: clamp(1rem, 1.2vw, 1.12rem);
  line-height: 1.75;
  color: var(--ink-soft);
}

.studio__steps {
  margin-top: clamp(3.5rem, 8vw, 6rem);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1.5rem, 3vw, 3rem);
}
.studio__step {
  border-top: 1px solid var(--line);
  padding-top: 1.4rem;
}
.studio__no {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.3rem;
  color: var(--accent);
  display: block;
  margin-bottom: 1.4rem;
}
.studio__step h3 {
  font-family: var(--sans);
  font-weight: 500;
  font-size: 1.02rem;
  letter-spacing: 0.01em;
  margin-bottom: 0.7rem;
}
.studio__step p {
  font-size: 0.92rem;
  line-height: 1.65;
  color: var(--ink-soft);
}

.studio__cta-line {
  margin-top: clamp(3rem, 6vw, 5rem);
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(1.5rem, 3vw, 2.4rem);
  line-height: 1.3;
  color: var(--ink-soft);
  max-width: 28ch;
}


/* ====================================================================
   12. SCENE — day/night dissolve
   ==================================================================== */

.scene {
  position: relative;
  height: 300vh;
  background: var(--ink);
}
.scene__sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
}
.scene__layer {
  position: absolute;
  inset: 0;
  background-size: auto 118%;
  background-position: 16% 50%;
  background-repeat: no-repeat;
  will-change: background-position, opacity;
}
.scene__layer--day   { background-image: url(assets/images/scene-day.jpg); }
.scene__layer--night {
  background-image: url(assets/images/scene-night.jpg);
  opacity: 0;
}
/* on portrait phones the landscape frame needs more height-fill so the pan
   still traverses the whole space from waterfall to sauna */
@media (max-width: 800px) {
  .scene__layer { background-size: auto 132%; }
}
.scene__veil {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(120% 90% at 50% 40%, transparent 35%, rgba(8,8,6,0.55) 100%),
    linear-gradient(to bottom, rgba(8,8,6,0.35), transparent 40%, rgba(8,8,6,0.55));
}
.scene__copy {
  position: absolute;
  left: 0; right: 0;
  top: 50%;
  transform: translateY(-50%);
  padding-inline: var(--gutter);
  text-align: center;
  color: var(--paper);
  display: grid;
  justify-items: center;
}
.scene__kicker {
  color: var(--paper-55);
  margin-bottom: clamp(1rem, 2.5vw, 1.8rem);
}
.scene__kicker::before { background: var(--paper-55); opacity: 1; }
.scene__line {
  grid-area: 2 / 1;
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2.2rem, 6vw, 5.5rem);
  line-height: 1.05;
  letter-spacing: -0.01em;
  max-width: 16ch;
}
.scene__line--night { opacity: 0; }
.scene__hint {
  position: absolute;
  bottom: clamp(1.6rem, 4vh, 3rem);
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.24em;
  color: var(--paper-35);
}


/* ====================================================================
   13. WORK — editorial gallery
   ==================================================================== */

.work {
  padding-block: var(--section-y);
  background: var(--bone);
}
.work__head-wrap { margin-bottom: clamp(3rem, 7vw, 5.5rem); }
.work__kicker { margin-bottom: clamp(1.2rem, 3vw, 2rem); }
.work__head {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2.2rem, 5.5vw, 5rem);
  line-height: 1.05;
  letter-spacing: -0.01em;
}

.work__grid {
  width: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
  padding-inline: var(--gutter);
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: clamp(2.5rem, 6vw, 7rem) clamp(1.5rem, 4vw, 4rem);
  align-items: start;
}

/* Asymmetric placement — not a uniform card grid */
.work__item              { grid-column: span 5; }
.work__item--tall        { grid-column: 1 / span 5; }
.work__item--tall .work__media { aspect-ratio: 4 / 5.4; }
.work__item--wide        { grid-column: 6 / span 7; margin-top: clamp(3rem, 10vw, 9rem); }
.work__item--wide .work__media { aspect-ratio: 16 / 10; }
.work__item:nth-child(3) { grid-column: 1 / span 5; margin-top: clamp(2rem, 7vw, 6rem); }
.work__item:nth-child(4) { grid-column: 8 / span 5; }

.work__media {
  position: relative;
  overflow: hidden;
  border-radius: 2px;
  background: var(--line);
  aspect-ratio: 4 / 3;
}
.work__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.06);   /* headroom for JS parallax */
  transition: transform 1.2s var(--ease), filter 1.2s var(--ease);
  filter: saturate(0.96) brightness(0.98);
}
.work__item:hover .work__media img {
  transform: scale(1.11);
  filter: saturate(1) brightness(1.02);
}
.work__item figcaption {
  display: flex;
  align-items: baseline;
  gap: 0.9rem;
  margin-top: 1.2rem;
  font-size: 0.98rem;
  line-height: 1.4;
  color: var(--ink-soft);
  max-width: 30ch;
}
.work__item figcaption span {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.15rem;
  color: var(--accent);
  flex: none;
}


/* ====================================================================
   14. CAPABILITIES — kinetic marquee
   ==================================================================== */

.caps {
  background: var(--ink);
  color: var(--paper);
  padding-block: clamp(4rem, 9vw, 8rem);
  overflow: hidden;
  border-top: 1px solid var(--paper-08);
  border-bottom: 1px solid var(--paper-08);
}
.caps__row {
  overflow: hidden;
  padding-block: clamp(0.4rem, 1.5vw, 1.1rem);
}
.caps__track {
  display: flex;
  flex-wrap: nowrap;
  white-space: nowrap;
  align-items: center;
  will-change: transform;
}
.caps__track span {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2.2rem, 6vw, 5.5rem);
  line-height: 1.1;
  padding-inline: clamp(1rem, 2.5vw, 2.2rem);
  color: var(--paper);
}
.caps__track i {
  font-style: normal;
  color: var(--accent);
  font-size: clamp(1.4rem, 3vw, 2.6rem);
}
.caps__row--alt .caps__track span {
  font-size: clamp(1.6rem, 4.5vw, 4rem);
  color: var(--paper-55);
}
.caps__row--alt .caps__track i { color: var(--accent-2); }


/* ====================================================================
   15. PROCESS
   ==================================================================== */

.process {
  padding-block: var(--section-y);
  background: var(--paper);
}
.process__kicker { margin-bottom: clamp(1.2rem, 3vw, 2rem); }
.process__head {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2.2rem, 5.2vw, 4.8rem);
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin-bottom: clamp(3rem, 7vw, 5.5rem);
}
.process__rows { display: flex; flex-direction: column; }
.process__row {
  display: grid;
  grid-template-columns: clamp(3rem, 8vw, 7rem) 1fr;
  gap: clamp(1.5rem, 5vw, 4rem);
  align-items: start;
  padding-block: clamp(2rem, 4vw, 3.2rem);
  border-top: 1px solid var(--line);
}
.process__row:last-child { border-bottom: 1px solid var(--line); }
.process__n {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.4rem, 2.5vw, 2.1rem);
  color: var(--accent);
}
.process__row h3 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(1.5rem, 3vw, 2.4rem);
  line-height: 1.2;
  margin-bottom: 0.7rem;
}
.process__row p {
  max-width: 56ch;
  font-size: clamp(0.96rem, 1.1vw, 1.08rem);
  line-height: 1.7;
  color: var(--ink-soft);
}


/* ====================================================================
   16. CONSULTATION — intimate dark section
   ==================================================================== */

.consult {
  background: var(--ink);
  color: var(--paper);
  padding-block: var(--section-y);
}
.consult__wrap {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: clamp(2.5rem, 7vw, 7rem);
  align-items: start;
}
.consult__kicker { color: var(--accent); margin-bottom: clamp(1.4rem, 3vw, 2.2rem); }
.consult__kicker::before { background: var(--accent); opacity: 1; }
.consult__title {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2.1rem, 4.5vw, 4rem);
  line-height: 1.08;
  letter-spacing: -0.01em;
  color: var(--paper);
  max-width: 14ch;
}
.consult__body {
  margin-top: clamp(1.6rem, 3.5vw, 2.6rem);
  max-width: 46ch;
  font-size: clamp(0.98rem, 1.1vw, 1.1rem);
  line-height: 1.75;
  color: var(--paper-80);
}
.consult__meta {
  margin-top: 1.8rem;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--paper-35);
}

/* Form — underline-only fields */
.consult__form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.6rem, 3vw, 2.4rem) clamp(1.5rem, 3vw, 2.4rem);
}
.field { position: relative; display: flex; flex-direction: column; }
.field--full { grid-column: 1 / -1; }
.field label {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--paper-55);
  margin-bottom: 0.7rem;
  transition: color 0.45s var(--ease);
}
.field input,
.field textarea {
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--paper-14);
  color: var(--paper);
  padding: 0.55rem 0;
  font-size: 1.02rem;
  font-weight: 300;
  transition: border-color 0.45s var(--ease);
  resize: none;
}
.field textarea { line-height: 1.6; }
.field input::placeholder,
.field textarea::placeholder { color: var(--paper-35); }
.field input:focus,
.field textarea:focus { outline: none; border-bottom-color: var(--accent); }
.field:focus-within label { color: var(--accent); }

.consult__form .btn {
  grid-column: 1 / -1;
  justify-self: start;
  margin-top: 0.6rem;
}

.consult__note {
  grid-column: 1 / -1;
  font-size: 0.9rem;
  color: var(--paper-80);
  margin-top: 0.4rem;
}
.consult__note.is-error { color: var(--accent); }


/* ====================================================================
   17. FOOTER
   ==================================================================== */

.foot {
  background: var(--bone);
  padding-top: clamp(4rem, 9vw, 8rem);
  padding-bottom: clamp(2.5rem, 5vw, 4rem);
  overflow: hidden;
}
.foot__brand {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(5rem, 26vw, 26rem);
  line-height: 0.82;
  letter-spacing: -0.02em;
  color: var(--ink);
  text-align: center;
  white-space: nowrap;
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
}
.foot__wrap {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  border-top: 1px solid var(--line);
  padding-top: clamp(1.6rem, 3vw, 2.4rem);
}
.foot__line {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(1.2rem, 2vw, 1.6rem);
  color: var(--ink-soft);
}
.foot__places { color: var(--stone); font-size: 0.9rem; letter-spacing: 0.02em; }
.foot__legal  { color: var(--stone); font-size: 0.78rem; letter-spacing: 0.04em; }


/* ====================================================================
   18. RESPONSIVE
   ==================================================================== */

@media (max-width: 1024px) {
  .studio__steps { grid-template-columns: repeat(2, 1fr); gap: clamp(2rem, 5vw, 3rem); }
  .consult__wrap { grid-template-columns: 1fr; gap: clamp(2.5rem, 6vw, 4rem); }
  .work__item--wide { margin-top: clamp(2rem, 6vw, 5rem); }
}

@media (max-width: 768px) {
  /* Hide center nav links — keep brand + CTA */
  .nav__links { display: none; }

  /* Stack work grid to single column */
  .work__grid { grid-template-columns: 1fr; gap: clamp(3rem, 9vw, 5rem); }
  .work__item,
  .work__item--tall,
  .work__item--wide,
  .work__item:nth-child(3),
  .work__item:nth-child(4) {
    grid-column: 1 / -1;
    margin-top: 0;
  }
  .work__item--tall .work__media { aspect-ratio: 4 / 5; }
  .work__item--wide .work__media { aspect-ratio: 16 / 11; }

  .consult__form { grid-template-columns: 1fr; }
  .field--full { grid-column: 1 / -1; }
}

@media (max-width: 480px) {
  .studio__steps { grid-template-columns: 1fr; }
  .process__row { grid-template-columns: 1fr; gap: 0.4rem; }
  .hero__lede { font-size: clamp(2.3rem, 11vw, 3.4rem); }
}


/* ====================================================================
   19. REDUCED MOTION
   ==================================================================== */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
  [data-reveal] { opacity: 1 !important; transform: none !important; }
  .hero__cue span { animation: none; transform: scaleY(1); }
}


/* ====================================================================
   20. TOUCH / COARSE POINTER — disable custom cursor
   ==================================================================== */

@media (hover: none), (pointer: coarse) {
  #cursor { display: none; }
  * { cursor: auto; }
}


/* ====================================================================
   21. OVERHAUL — Italiana display font · Approach · Studio · horizontal Work
   ==================================================================== */

:root { --serif: 'Italiana', 'Cormorant Garamond', Georgia, serif; }

/* Italiana ships a single (400) weight — keep all serif display at 400 */
.hero__lede, .hero__resolve-mark, .scene__line, .work__head,
.studio__head, .approach__head, .foot__brand, .preloader__brand,
.consult__title, .manifesto__lines { font-weight: 400; }

/* ---- APPROACH — "designed around you" (image-backed) ---- */
.approach {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding-block: clamp(6rem, 14vw, 12rem);
  overflow: hidden;
  background: var(--ink);
  color: var(--paper);
}
.approach__media { position: absolute; inset: 0; overflow: hidden; }
.approach__media img {
  position: absolute; inset: -8% 0; width: 100%; height: 116%;
  object-fit: cover; will-change: transform;
}
.approach__veil {
  position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(102deg, rgba(8,8,6,0.88) 0%, rgba(8,8,6,0.55) 42%, rgba(8,8,6,0.15) 100%),
    linear-gradient(to top, rgba(8,8,6,0.65), transparent 55%);
}
.approach__inner { position: relative; z-index: 2; max-width: 52rem; }
.approach__kicker {
  font-family: var(--sans); font-size: 0.72rem; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.18em;
  color: var(--paper-55); display: inline-flex; align-items: center; gap: 0.85em;
  margin-bottom: clamp(1.4rem, 3vw, 2.2rem);
}
.approach__kicker::before {
  content: ''; width: clamp(28px, 4vw, 34px); height: 1px;
  background: var(--paper-55); flex: none;
}
.approach__head {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(2.9rem, 8.5vw, 7rem); line-height: 1.0; letter-spacing: 0.005em;
}
.approach__body {
  margin-top: clamp(1.6rem, 3.5vw, 2.6rem); max-width: 38ch;
  font-family: var(--sans); font-weight: 300;
  font-size: clamp(1.1rem, 1.55vw, 1.45rem); line-height: 1.6; color: var(--paper-80);
}
.approach__hl {
  color: var(--paper);
  background-image: linear-gradient(var(--accent), var(--accent));
  background-repeat: no-repeat; background-position: 0 100%; background-size: 100% 1px;
  padding-bottom: 2px;
}
.approach .btn { margin-top: clamp(2rem, 4vw, 3rem); }

/* ---- STUDIO — single dark statement (overrides §11) ---- */
.studio {
  position: relative;
  padding-block: clamp(8rem, 18vw, 15rem);
  background: var(--ink);
  border-top: none;
  color: var(--paper);
  text-align: center;
}
.studio .wrap { display: grid; justify-items: center; }
.studio__kicker { color: var(--paper-55); margin-bottom: clamp(2rem, 5vw, 3.5rem); }
.studio__kicker::before { background: var(--paper-55); opacity: 1; }
.studio__head {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(2.7rem, 7.5vw, 6.4rem); line-height: 1.07; letter-spacing: 0.005em;
  color: var(--paper); max-width: 16ch;
}
.studio__breadth {
  margin-top: clamp(2.5rem, 6vw, 4rem);
  display: flex; flex-wrap: wrap; justify-content: center; align-items: center;
  gap: 0.6em 0;
}
.studio__breadth li {
  font-family: var(--sans); font-size: 0.74rem; font-weight: 400;
  text-transform: uppercase; letter-spacing: 0.16em; color: var(--paper-55);
  display: inline-flex; align-items: center;
}
.studio__breadth li:not(:last-child)::after {
  content: ''; width: 4px; height: 4px; border-radius: 50%;
  background: var(--accent); margin: 0 clamp(0.9em, 2vw, 1.5em);
}

/* ---- WORK — horizontal pinned gallery (overrides §13) ---- */
.work { background: var(--bone); padding-block: clamp(6rem, 12vw, 11rem) clamp(6rem, 12vw, 10rem); }
.work__intro { margin-bottom: clamp(3rem, 7vw, 5.5rem); }
.work__kicker { margin-bottom: clamp(1.2rem, 3vw, 2rem); }
.work__head {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(2.4rem, 6vw, 5.4rem); line-height: 1.05; letter-spacing: 0.005em;
}
.work__pin { height: 100vh; overflow: hidden; display: flex; align-items: center; }
.work__track {
  display: flex; align-items: center; gap: clamp(1.5rem, 4vw, 4rem);
  padding-inline: var(--gutter); height: 100%; will-change: transform;
}
.hcard { flex: none; width: clamp(300px, 44vw, 640px); }
.hcard--wide { width: clamp(420px, 64vw, 980px); }
.hcard__media {
  position: relative; overflow: hidden; border-radius: 2px; height: 64vh;
}
.hcard__media img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  transform: scale(1.05); transition: transform 1.3s var(--ease);
}
.hcard:hover .hcard__media img { transform: scale(1.0); }
/* keep the left-side sauna in frame when this card crops to portrait */
.hcard--left .hcard__media img { object-position: 22% 50%; }
.hcard figcaption {
  margin-top: 1.4rem; font-family: var(--sans); font-weight: 300;
  font-size: clamp(0.95rem, 1.3vw, 1.15rem); color: var(--ink-soft);
  display: flex; align-items: baseline; gap: 0.8em;
}
.hcard figcaption span { font-family: var(--serif); font-size: 1.15rem; color: var(--accent); }

/* swipe hint — only on touch/narrow screens where the gallery scrolls sideways */
.work__swipe { display: none; }

/* horizontal gallery — touch fallback: native horizontal swipe */
@media (max-width: 800px) {
  .work__pin {
    height: auto; overflow-x: auto; overflow-y: hidden;
    -webkit-overflow-scrolling: touch; scroll-snap-type: x proximity;
  }
  .work__track { transform: none !important; height: auto; }
  .hcard { scroll-snap-align: start; width: 78vw; }
  .hcard--wide { width: 86vw; }
  .hcard__media { height: 56vh; }

  .work__swipe {
    display: inline-flex; align-items: center; gap: 0.55em;
    margin-top: 1.5rem;
    font-family: var(--sans); font-weight: 500;
    font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase;
    color: var(--accent);
  }
  .work__swipe span {
    display: inline-block; font-size: 1.05rem;
    animation: swipeNudge 1.5s ease-in-out infinite;
  }
}
@keyframes swipeNudge {
  0%, 100% { transform: translateX(0); opacity: 0.55; }
  50%      { transform: translateX(7px); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .work__pin { height: auto; overflow-x: auto; }
  .work__track { transform: none !important; height: auto; }
}
@media (max-width: 768px) {
  .approach { min-height: 90vh; }
  .approach__body { font-size: clamp(1.05rem, 4.4vw, 1.3rem); }
}
