/* =========================================================
   VIDA EXPERIENCE — editorial luxury design system
   ========================================================= */

/* ---------- TOKENS ---------- */
:root {
  /* palette */
  --ink:        #0E0F0C;
  --ink-2:      #16180F;
  --ink-3:      #1F2118;
  --ink-4:      #2A2C21;
  --bone:       #F1EADC;
  --bone-2:     #E5DDC9;
  --bone-3:     #D4CBB5;
  --paper:      #FBF7EE;
  --ember:      #B8713C;
  --ember-soft: #CF8A54;
  --ember-deep: #7E4B23;
  --sage:       #5A6B52;
  --stone:      #8A8577;
  --line-dark:  rgba(241, 234, 220, 0.12);
  --line-light: rgba(14, 15, 12, 0.10);

  /* type */
  --font-display: "neue-haas-grotesk-display", sans-serif;
  --font-body:    "Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", sans-serif;
  --font-mono:    "JetBrains Mono", "SF Mono", ui-monospace, monospace;

  /* fluid type */
  --text-xs:  0.75rem;
  --text-sm:  0.8125rem;
  --text-md:  0.9375rem;
  --text-base:1rem;
  --text-lg:  1.125rem;
  --text-xl:  1.375rem;
  --text-2xl: clamp(1.5rem, 1.2rem + 1.4vw, 2rem);
  --text-3xl: clamp(2rem, 1.6rem + 1.8vw, 2.75rem);
  --text-4xl: clamp(2.5rem, 2rem + 2.5vw, 3.75rem);
  --text-5xl: clamp(3rem, 2.2rem + 4vw, 5.25rem);
  --text-6xl: clamp(3.5rem, 2.5rem + 6vw, 7rem);

  /* spacing (4px base) */
  --s-1: 0.25rem;
  --s-2: 0.5rem;
  --s-3: 0.75rem;
  --s-4: 1rem;
  --s-5: 1.5rem;
  --s-6: 2rem;
  --s-7: 3rem;
  --s-8: 4rem;
  --s-9: 6rem;
  --s-10:8rem;
  --s-11:12rem;

  /* layout */
  --wrap:       min(1280px, 92vw);
  --wrap-narrow:min(880px, 92vw);
  --wrap-wide:  min(1440px, 96vw);

  /* motion */
  --ease: cubic-bezier(.2,.7,.2,1);
}

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--ink);
  color: var(--bone);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.6;
  font-weight: 400;
  letter-spacing: 0.005em;
  overflow-x: hidden;
}
img, video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, textarea, select { font: inherit; color: inherit; }

/* ---------- TYPOGRAPHY ---------- */
h1, h2, h3, h4, .display {
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: -0.015em;
  line-height: 1.04;
  margin: 0;
  font-variation-settings: normal;
}
h1 { font-size: var(--text-6xl); font-weight: 600; }
h2 { font-size: var(--text-4xl); font-weight: 600; }
h3 { font-size: var(--text-2xl); font-family: "neue-haas-grotesk-display", sans-serif; font-weight: 400; font-style: normal; line-height: 1.15; }
h4 { font-size: var(--text-xl); font-family: "neue-haas-grotesk-display", sans-serif; font-weight: 400; font-style: normal; line-height: 1.25; }

p { margin: 0 0 var(--s-4); }

/* Heading reveal + underline-draw on "edge" */
.heading-reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.9s ease, transform 0.9s cubic-bezier(0.2, 0.7, 0.2, 1);
}
.heading-reveal.in {
  opacity: 1;
  transform: translateY(0);
}
.heading-edge {
  position: relative;
  display: inline-block;
  white-space: nowrap;
}
.heading-edge .ink-underline {
  position: absolute;
  left: -1%;
  right: -1%;
  width: 102%;
  bottom: -0.12em;
  height: 0.22em;
  overflow: visible;
  pointer-events: none;
}
.heading-edge .ink-underline path {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.1;
  stroke-linecap: round;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
  stroke-dasharray: 1200;
  stroke-dashoffset: 1200;
  transition: stroke-dashoffset 1.0s cubic-bezier(0.4, 0.05, 0.2, 1) 0.5s;
}
.heading-reveal.in .heading-edge .ink-underline path {
  stroke-dashoffset: 0;
}

.eyebrow {
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--ember-soft);
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
}
.eyebrow::before {
  content: "";
  width: 28px;
  height: 1px;
  background: var(--ember);
}
.eyebrow.no-rule::before { display: none; }

.section-label {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--stone);
}

.lead {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 1rem + 1vw, 1.625rem);
  line-height: 1.45;
  font-weight: 300;
  color: var(--bone);
  max-width: 60ch;
}

.muted { color: var(--bone-3); }
.dim   { color: var(--stone); }

/* ---------- LAYOUT PRIMITIVES ---------- */
.wrap         { width: var(--wrap); margin-inline: auto; }
.wrap-narrow  { width: var(--wrap-narrow); margin-inline: auto; }
.wrap-wide    { width: var(--wrap-wide); margin-inline: auto; }

section { padding-block: clamp(var(--s-8), 8vw, var(--s-11)); }
section.compact { padding-block: var(--s-8); }

.grid-2 { display: grid; grid-template-columns: 1fr; gap: var(--s-8); }
@media (min-width: 860px) {
  .grid-2 { grid-template-columns: 1fr 1fr; gap: var(--s-9); align-items: start; }
}

.grid-3 { display: grid; grid-template-columns: 1fr; gap: var(--s-6); }
@media (min-width: 720px) { .grid-3 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1040px){ .grid-3 { grid-template-columns: repeat(3, 1fr); } }

.grid-4 { display: grid; grid-template-columns: 1fr; gap: var(--s-6); }
@media (min-width: 720px) { .grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1040px){ .grid-4 { grid-template-columns: repeat(4, 1fr); } }

.stack-sm > * + * { margin-top: var(--s-3); }
.stack    > * + * { margin-top: var(--s-5); }
.stack-lg > * + * { margin-top: var(--s-7); }

.rule { height: 1px; background: var(--line-dark); width: 100%; border: 0; margin: 0; }
.rule.light { background: var(--line-light); }

/* ---------- NAV ---------- */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 60;
  padding: var(--s-4) 0;
  transition: background .35s var(--ease), border-color .35s var(--ease), padding .35s var(--ease);
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  background: rgba(14, 15, 12, 0.82);
  -webkit-backdrop-filter: blur(14px) saturate(120%);
  backdrop-filter: blur(14px) saturate(120%);
  border-bottom-color: var(--line-dark);
  padding: var(--s-3) 0;
}
.nav-inner {
  width: var(--wrap-wide);
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-6);
}
.brand {
  display: inline-flex;
  align-items: baseline;
  gap: 0.5em;
  font-family: var(--font-display);
  font-size: 1.35rem;
  letter-spacing: 0.01em;
  color: var(--bone);
  opacity: 0.8;
  transition: opacity 0.6s ease;
}
.brand:hover {
  opacity: 1;
}
.brand-v {
  display: inline;
  font-family: var(--font-display);
  font-size: 1.35rem;
  transition: opacity 0.6s ease, width 0.6s ease;
}
.brand-full {
  display: inline-flex;
  align-items: baseline;
  gap: 0.5em;
  overflow: hidden;
  max-width: 0;
  opacity: 0;
  transition: max-width 0.7s ease, opacity 0.6s ease;
  white-space: nowrap;
}
.brand:hover .brand-v {
  display: none;
}
.brand:hover .brand-full {
  max-width: 12rem;
  opacity: 1;
}
.brand .brand-mark {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.3em;
  color: var(--ember);
  text-transform: uppercase;
  transform: translateY(-2px);
}

/* Nav logo — static bone mark, no hover animation. */
.brand-logo {
  position: relative;
  display: inline-block;
  width: 96px;
  height: 28px;
  line-height: 0;
}
.brand-logo img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
}
.brand-logo .logo-shine {
  display: none;
}

.visually-hidden {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.nav-links {
  display: none;
  gap: var(--s-6);
  align-items: center;
}
.nav-links a {
  font-size: 0.875rem;
  letter-spacing: 0.06em;
  color: var(--bone-3);
  position: relative;
  padding: var(--s-2) 0;
  transition: color .2s var(--ease);
}
.nav-links a:hover,
.nav-links a[aria-current="page"] { color: var(--bone); }
.nav-links a[aria-current="page"]::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 1px;
  background: var(--ember);
}
.nav-actions { display: flex; align-items: center; gap: var(--s-4); }
.nav-toggle {
  display: inline-flex;
  flex-direction: column;
  gap: 5px;
  padding: var(--s-2);
}
.nav-toggle span { width: 22px; height: 1px; background: var(--bone); transition: transform .3s var(--ease); display: block; }
@media (min-width: 700px) {
  .nav-links { display: inline-flex; }
  .nav-toggle { display: none; }
}

/* mobile sheet */
.nav-sheet {
  position: fixed;
  inset: 0;
  min-height: 100vh;
  overflow: hidden;
  background: var(--ink);
  z-index: 70;
  padding: var(--s-8) var(--s-5);
  transform: translateY(-100%);
  transition: transform .45s var(--ease);
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
}
.nav-sheet.open { transform: translateY(0); }
.nav-sheet a {
  font-family: var(--font-display);
  font-size: 2rem;
  color: var(--bone);
  padding: var(--s-3) 0;
  border-bottom: 1px solid var(--line-dark);
}
.nav-sheet .close {
  align-self: flex-end;
  font-size: 0.8rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--stone);
}

/* ---------- BUTTONS ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  padding: 0.95rem 1.5rem;
  font-size: 0.8rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
  border: 1px solid transparent;
  transition: all .25s var(--ease);
  white-space: nowrap;
}
.btn-primary {
  background: var(--ember);
  color: var(--ink);
}
.btn-primary:hover { background: var(--ember-soft); transform: translateY(-1px); }
.btn-ghost {
  border-color: var(--line-dark);
  color: var(--bone);
}
.btn-ghost:hover { border-color: var(--bone-3); background: rgba(241,234,220,0.04); }
.btn-link {
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--bone);
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  font-size: 0.8rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
.btn-link .arrow {
  display: inline-block;
  transition: transform .25s var(--ease);
}
.btn-link:hover .arrow { transform: translateX(4px); }

/* ---------- HERO ---------- */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: flex-end;
  padding-block: 0;
  overflow: hidden;
}
.hero-media {
  position: absolute;
  top: -10%;
  left: 0;
  right: 0;
  bottom: -10%;
  background-color: var(--ink-2);
  background-size: cover;
  background-position: center;
  z-index: 0;
  will-change: transform;
  transform: translate3d(0, 0, 0) scale(1.08);
}
.hero-inner {
  will-change: transform;
}
.hero h1 {
  will-change: transform, opacity;
}
.hero-media::after {
  content: "";
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(14,15,12,0.35) 0%, rgba(14,15,12,0.15) 40%, rgba(14,15,12,0.85) 100%),
    linear-gradient(90deg, rgba(14,15,12,0.45) 0%, rgba(14,15,12,0.0) 50%);
}
.hero-inner {
  position: relative;
  z-index: 2;
  width: var(--wrap-wide);
  margin-inline: auto;
  padding-block: var(--s-10) var(--s-9);
}
.hero h1 {
  max-width: 16ch;
  margin-bottom: var(--s-5);
}
.hero .lead { margin-bottom: var(--s-7); }

.hero-meta {
  display: flex;
  gap: var(--s-8);
  flex-wrap: wrap;
  padding-top: var(--s-6);
  border-top: 1px solid var(--line-dark);
  color: var(--bone-3);
  font-size: 0.85rem;
}
.hero-meta dt {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--stone);
  margin-bottom: var(--s-1);
}
.hero-meta dd { margin: 0; color: var(--bone); }

.hero-scroll {
  position: absolute;
  right: var(--s-6);
  bottom: var(--s-6);
  z-index: 3;
  writing-mode: vertical-rl;
  font-size: 0.7rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--bone-3);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s-3);
}
.hero-scroll::after {
  content: "";
  width: 1px;
  height: 40px;
  background: var(--bone-3);
  animation: scrollLine 2.4s var(--ease) infinite;
  transform-origin: top;
}
@keyframes scrollLine {
  0%,100% { transform: scaleY(0.2); opacity: 0.4; }
  50%     { transform: scaleY(1);   opacity: 1; }
}

/* ---------- SECTIONS: DARK / LIGHT variants ---------- */
.section-light {
  background: var(--paper);
  color: var(--ink);
}
.section-light .eyebrow { color: var(--ember-deep); }
.section-light .eyebrow::before { background: var(--ember-deep); }
.section-light .dim, .section-light .muted { color: #4a4a40; }
.section-light .rule { background: var(--line-light); }
.section-light .btn-ghost { border-color: var(--line-light); color: var(--ink); }
.section-light .btn-ghost:hover { border-color: var(--ink); background: rgba(14,15,12,0.04); }
.section-light .btn-link { color: var(--ink); }

/* ---------- PILLAR CARD ---------- */
.pillar-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1px;
  background: var(--line-dark);
  border: 1px solid var(--line-dark);
}
@media (min-width: 720px) { .pillar-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1040px){ .pillar-grid { grid-template-columns: repeat(4, 1fr); } }

.pillar {
  position: relative;
  background: var(--ink-2);
  padding: var(--s-7) var(--s-6) var(--s-6);
  min-height: 440px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: hidden;
  transition: background .4s var(--ease);
}
.pillar::before {
  content: "";
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity .6s var(--ease);
  z-index: 0;
}
.pillar::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(14,15,12,0.2) 0%, rgba(14,15,12,0.85) 100%);
  opacity: 0;
  transition: opacity .6s var(--ease);
  z-index: 1;
}
.pillar:hover::before,
.pillar:hover::after { opacity: 1; }
.pillar > * { position: relative; z-index: 2; }

.pillar-num {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.3em;
  color: var(--ember);
}
.pillar h3 {
  font-size: 2.5rem;
  margin-top: var(--s-5);
  color: var(--bone);
}
.pillar p {
  color: var(--bone-3);
  font-size: 0.95rem;
  margin-top: var(--s-3);
  max-width: 30ch;
}
.pillar .pillar-link {
  margin-top: var(--s-5);
  font-size: 0.75rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--bone);
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
}
.pillar .pillar-link .arrow { transition: transform .25s var(--ease); }
.pillar:hover .pillar-link .arrow { transform: translateX(4px); }

/* pillar per-card backgrounds */
.pillar.endure::before  { background-image: url('greg-tactical.jpeg'); }
.pillar.engage::before  { background-image: url('mountain-biking-moab.jpg'); background-position: 78% 65%; }
.pillar.explore::before { background-image: url('https://images.unsplash.com/photo-1504280390367-361c6d9f38f4?auto=format&fit=crop&w=1400&q=80'); }
.pillar.evolve::before  { background-image: url('cold-plunge-river.png'); background-position: center 58%; }

/* ---------- FEATURE STRIP ---------- */
.feature-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--s-6);
  padding-block: var(--s-7);
  border-top: 1px solid var(--line-dark);
  border-bottom: 1px solid var(--line-dark);
}
.feature-strip .item {
  display: flex; flex-direction: column; gap: var(--s-2);
}
.feature-strip .num {
  font-family: var(--font-display);
  font-size: 3rem;
  color: var(--ember);
  line-height: 1;
  font-weight: 300;
}
.feature-strip .label {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--stone);
}

/* ---------- IMAGE FRAME ---------- */
.frame {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--ink-2);
}
.frame.wide { aspect-ratio: 16 / 10; }
.frame.tall { aspect-ratio: 3 / 4; }
.frame img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1.2s var(--ease);
}
.frame:hover img { transform: scale(1.03); }

/* ---------- ITINERARY ---------- */
.itinerary { border-top: 1px solid var(--line-dark); }
.itinerary .day {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--s-6);
  padding: var(--s-6) 0;
  border-bottom: 1px solid var(--line-dark);
  align-items: start;
}
@media (max-width: 720px) {
  .itinerary .day { grid-template-columns: 1fr; gap: var(--s-3); }
}
.itinerary .day-tag {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--ember);
  padding-top: 4px;
}
.itinerary .day h4 { margin-bottom: var(--s-3); font-size: 1.625rem; }
.itinerary .day p { color: var(--bone-3); }
.itinerary .day ul {
  list-style: none;
  padding: 0;
  margin: var(--s-3) 0 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--s-2) var(--s-5);
}
.itinerary .day li {
  font-size: 0.9rem;
  color: var(--bone-3);
  padding-left: var(--s-4);
  position: relative;
}
.itinerary .day li::before {
  content: "";
  position: absolute;
  left: 0; top: 0.7em;
  width: 8px; height: 1px;
  background: var(--ember);
}

/* ---------- QUOTE ---------- */
.quote {
  max-width: 60ch;
  margin-inline: auto;
  text-align: center;
  padding-block: var(--s-8);
}
.quote p {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1rem + 1.8vw, 2.25rem);
  line-height: 1.3;
  font-weight: 300;
  color: var(--bone);
  margin-bottom: var(--s-6);
}
.quote cite {
  font-style: normal;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--stone);
}
.quote cite b { color: var(--bone); font-weight: 500; margin-right: var(--s-2); }

/* ---------- TESTIMONIALS SECTION ---------- */
.section-testimonials {
  position: relative;
  isolation: isolate;
  background-color: var(--ink);
  overflow: hidden;
}
.section-testimonials::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url('men-around-campfire-photo.jpg');
  background-size: cover;
  background-position: center;
  opacity: 0.22;
  filter: grayscale(0.35) contrast(1.05);
  z-index: -2;
}
.section-testimonials::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 50% 40%, rgba(14,15,12,0.45) 0%, rgba(14,15,12,0.9) 75%),
    linear-gradient(180deg, rgba(14,15,12,0.6) 0%, rgba(14,15,12,0.3) 40%, rgba(14,15,12,0.85) 100%);
  z-index: -1;
}

/* ---------- TESTIMONIAL GRID ---------- */
.testimonial-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-7);
}
@media (min-width: 860px) {
  .testimonial-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--s-8) var(--s-9);
  }
}
.testimonial {
  margin: 0;
  padding-top: var(--s-5);
  border-top: 1px solid var(--line-dark);
}
.testimonial blockquote {
  margin: 0 0 var(--s-5);
  font-family: var(--font-display);
  font-size: clamp(1.15rem, 0.9rem + 0.7vw, 1.5rem);
  line-height: 1.4;
  font-weight: 300;
  color: var(--bone);
}
.testimonial figcaption {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--stone);
}
.testimonial figcaption b { color: var(--bone); font-weight: 500; margin-right: var(--s-2); }

/* ---------- RETREATS LIST ---------- */
.retreat-row {
  display: grid;
  grid-template-columns: 140px 1.4fr 1fr 1fr auto;
  gap: var(--s-5);
  padding: var(--s-5) 0;
  border-bottom: 1px solid var(--line-dark);
  align-items: center;
  transition: background .25s var(--ease);
}
.retreat-row:hover { background: rgba(241,234,220,0.03); }
.retreat-row .ret-tag {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ember);
}
.retreat-row h4 { font-size: 1.5rem; }
.retreat-row .ret-meta { font-size: 0.85rem; color: var(--bone-3); }
.retreat-row .ret-avail {
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--bone-3);
}
.retreat-row .ret-avail.low { color: var(--ember-soft); }
.retreat-row .ret-avail.full { color: var(--stone); }
@media (max-width: 860px) {
  .retreat-row { grid-template-columns: 1fr; gap: var(--s-2); padding: var(--s-5) 0; }
  .retreat-row .btn-link { justify-self: start; margin-top: var(--s-3); }
}

/* ---------- TRUST BAR ---------- */
.trust {
  padding-block: var(--s-6);
  border-top: 1px solid var(--line-dark);
  border-bottom: 1px solid var(--line-dark);
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-6) var(--s-8);
  justify-content: space-between;
  align-items: center;
}
.trust .section-label { white-space: nowrap; }
.trust .trust-items {
  display: flex;
  gap: var(--s-6) var(--s-8);
  flex-wrap: wrap;
  color: var(--bone-3);
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-style: italic;
  font-weight: 300;
}

/* ---------- FOOTER ---------- */
.site-footer {
  background: var(--ink-2);
  border-top: 1px solid var(--line-dark);
  padding-block: var(--s-9) var(--s-6);
}
.footer-top {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-7);
  padding-bottom: var(--s-8);
  border-bottom: 1px solid var(--line-dark);
}
@media (min-width: 860px) {
  .footer-top { grid-template-columns: 1.4fr 1fr 1fr 1fr; }
}
.footer-top h5 {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--stone);
  margin: 0 0 var(--s-4);
  font-weight: 500;
}
.footer-top ul { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--s-2); }
.footer-top a { color: var(--bone-3); font-size: 0.9rem; }
.footer-top a:hover { color: var(--bone); }
.footer-cta p {
  font-family: var(--font-display);
  font-size: 1.5rem;
  color: var(--bone);
  margin-bottom: var(--s-5);
  max-width: 28ch;
}
.footer-bottom {
  padding-top: var(--s-5);
  display: flex;
  justify-content: space-between;
  gap: var(--s-5);
  flex-wrap: wrap;
  font-size: 0.75rem;
  color: var(--stone);
  letter-spacing: 0.05em;
}

/* ---------- FORMS ---------- */
.form-field {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  margin-bottom: var(--s-5);
}
.form-field label {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--stone);
}
.form-field input,
.form-field select,
.form-field textarea {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--line-dark);
  padding: var(--s-3) 0;
  color: var(--bone);
  font-size: 1.05rem;
  transition: border-color .25s var(--ease);
  font-family: var(--font-body);
  border-radius: 0;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  outline: none;
  border-bottom-color: var(--ember);
}
.form-field textarea { resize: vertical; min-height: 120px; }
.form-field .hint {
  font-size: 0.8rem;
  color: var(--stone);
}
.form-field .error {
  font-size: 0.8rem;
  color: var(--ember-soft);
  display: none;
}
.form-field.invalid .error { display: block; }
.form-field.invalid input,
.form-field.invalid select,
.form-field.invalid textarea { border-bottom-color: var(--ember-soft); }
.form-field.invalid .calendar { border-color: var(--ember-soft); }

.form-submit-error {
  font-size: 0.9rem;
  color: var(--ember-soft);
  margin-top: var(--s-5);
  margin-bottom: 0;
}
.section-light .form-submit-error { color: var(--ember-deep); }
.form-submit-error[hidden] { display: none; }

/* ---------- Calendar (four-day block picker) ---------- */
.calendar {
  border: 1px solid var(--line-dark);
  padding: var(--s-4);
  background: rgba(241, 234, 220, 0.02);
  transition: border-color .25s var(--ease);
}
.calendar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--s-1) var(--s-4);
}
.calendar-title {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--bone);
}
.calendar-nav {
  appearance: none;
  background: transparent;
  border: 1px solid var(--line-dark);
  color: var(--bone-3);
  width: 34px;
  height: 34px;
  border-radius: 50%;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: border-color .25s var(--ease), color .25s var(--ease), opacity .25s var(--ease);
  padding: 0;
}
.calendar-nav:hover:not(:disabled) {
  border-color: var(--ember-soft);
  color: var(--ember-soft);
}
.calendar-nav:disabled {
  opacity: 0.25;
  cursor: not-allowed;
}
.calendar-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  padding: var(--s-2) 0;
  border-bottom: 1px solid var(--line-dark);
  margin-bottom: var(--s-2);
}
.calendar-weekdays span {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--stone);
}
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
}
.cal-day {
  appearance: none;
  background: transparent;
  border: 1px solid transparent;
  color: var(--bone);
  font-family: var(--font-body);
  font-size: 0.95rem;
  aspect-ratio: 1 / 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background-color .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease);
  border-radius: 2px;
  padding: 0;
}
.cal-day.empty {
  cursor: default;
  pointer-events: none;
}
.cal-day:hover:not(:disabled):not(.empty) {
  border-color: var(--ember-soft);
  color: var(--ember-soft);
}
.cal-day.disabled {
  color: var(--stone);
  opacity: 0.3;
  cursor: not-allowed;
}
.cal-day.in-range {
  background: rgba(184, 113, 60, 0.14);
  color: var(--bone);
}
.cal-day.range-start,
.cal-day.range-end {
  background: var(--ember);
  color: var(--bone);
  border-color: var(--ember);
}
.cal-day.range-start:hover,
.cal-day.range-end:hover {
  color: var(--bone);
  border-color: var(--ember);
}

.form-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0 var(--s-5);
}
@media (min-width: 720px) { .form-row { grid-template-columns: 1fr 1fr; } }
@media (min-width: 720px) { .form-row.three { grid-template-columns: 1fr 1fr 1fr; } }

.choice-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-3);
}
@media (min-width: 720px) { .choice-grid { grid-template-columns: repeat(2, 1fr); } }
.choice {
  position: relative;
  display: block;
  padding: var(--s-5);
  border: 1px solid var(--line-dark);
  transition: all .25s var(--ease);
  cursor: pointer;
}
.choice:hover { border-color: var(--bone-3); }
.choice input { position: absolute; opacity: 0; inset: 0; cursor: pointer; }
.choice .choice-name {
  font-family: var(--font-display);
  font-size: 1.75rem;
  line-height: 1;
  display: block;
  margin-bottom: var(--s-2);
}
.choice .choice-hint { font-size: 0.85rem; color: var(--bone-3); }
.choice input:checked + .choice-body,
.choice.selected { }
.choice.selected {
  border-color: var(--ember);
  background: rgba(184, 113, 60, 0.06);
}
.choice.selected .choice-name { color: var(--ember-soft); }

/* Dense/compact variant — for à la carte multi-select menus (commission form) */
.choice-grid.dense {
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-2);
}
@media (min-width: 720px) { .choice-grid.dense { grid-template-columns: repeat(3, 1fr); } }
.choice.compact { padding: var(--s-4); }
.choice.compact .choice-name {
  font-size: 1rem;
  line-height: 1.35;
  margin-bottom: 0;
}

/* stepper */
.stepper {
  display: flex;
  gap: var(--s-4);
  margin-bottom: var(--s-8);
  flex-wrap: wrap;
}
.stepper .step {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3) 0;
  color: var(--stone);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  border-top: 1px solid var(--line-dark);
  flex: 1;
  min-width: 180px;
  transition: color .25s var(--ease), border-color .25s var(--ease);
}
.stepper .step .step-num {
  font-family: var(--font-display);
  font-size: 1rem;
  color: var(--stone);
  font-variation-settings: "opsz" 24;
}
.stepper .step.active {
  color: var(--bone);
  border-top-color: var(--ember);
}
.stepper .step.active .step-num { color: var(--ember); }
.stepper .step.done { color: var(--bone-3); border-top-color: var(--ember-deep); }
.stepper .step.done .step-num { color: var(--ember-deep); }

.step-panel { display: none; }
.step-panel.active { display: block; animation: fadeUp .5s var(--ease); }
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

.form-actions {
  display: flex;
  justify-content: space-between;
  gap: var(--s-4);
  padding-top: var(--s-6);
  border-top: 1px solid var(--line-dark);
  margin-top: var(--s-8);
  flex-wrap: wrap;
}

.review-list {
  display: grid;
  gap: var(--s-3);
  padding: var(--s-5);
  border: 1px solid var(--line-dark);
  background: var(--ink-2);
  margin-bottom: var(--s-6);
}
.review-list dt {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--stone);
}
.review-list dd { margin: 0 0 var(--s-3); color: var(--bone); }

/* confirmation */
.confirm {
  text-align: center;
  padding: var(--s-10) 0;
  max-width: 60ch;
  margin-inline: auto;
}
.confirm .emblem {
  width: 72px; height: 72px;
  border: 1px solid var(--ember);
  border-radius: 50%;
  display: grid;
  place-items: center;
  margin: 0 auto var(--s-6);
  color: var(--ember);
  font-family: var(--font-display);
  font-size: 1.6rem;
}

/* ---------- UTILITIES ---------- */
.flex         { display: flex; }
.flex-between { display: flex; justify-content: space-between; align-items: center; gap: var(--s-4); flex-wrap: wrap; }
.flex-col     { display: flex; flex-direction: column; }
.gap-2        { gap: var(--s-2); }
.gap-4        { gap: var(--s-4); }
.gap-6        { gap: var(--s-6); }
.mt-0         { margin-top: 0 !important; }
.mt-4         { margin-top: var(--s-4); }
.mt-6         { margin-top: var(--s-6); }
.mt-8         { margin-top: var(--s-8); }
.mb-0         { margin-bottom: 0 !important; }
.hidden       { display: none !important; }
.text-center  { text-align: center; }

/* ---------- PROCESS TIMELINE ---------- */
.process-rail {
  position: relative;
  padding-block: var(--s-8);
}
.process-rail-track,
.process-rail-fill {
  position: absolute;
  top: 50%;
  height: 1px;
  pointer-events: none;
}
.process-rail-track {
  left: 10%;
  right: 10%;
  background: rgba(14, 15, 12, 0.14);
}
.process-rail-fill {
  left: 10%;
  width: 0;
  background: var(--ember);
  transition: width 1.1s var(--ease);
}
.process-rail-fill::after {
  content: "";
  position: absolute;
  right: -5px;
  top: 50%;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--ember);
  box-shadow: 0 0 18px 4px rgba(184, 113, 60, 0.40);
  transform: translateY(-50%);
  opacity: 0;
  transition: opacity 0.5s var(--ease);
}
.process-rail-fill.is-lit::after { opacity: 1; }

.process-rail-nodes {
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  align-items: center;
}
.process-rail-nodes > li {
  display: flex;
  justify-content: center;
  position: relative;
}

.process-node {
  position: relative;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--paper);
  border: 1px solid rgba(14, 15, 12, 0.30);
  padding: 0;
  cursor: pointer;
  transition: background 0.4s var(--ease), border-color 0.4s var(--ease),
              transform 0.4s var(--ease), box-shadow 0.4s var(--ease);
}
.process-node::before {
  content: "";
  position: absolute;
  inset: -18px;
}
.process-node:hover { border-color: var(--ember); }
.process-node.is-past {
  background: var(--ember);
  border-color: var(--ember);
}
.process-node.is-active {
  background: var(--ember);
  border-color: var(--ember);
  transform: scale(1.45);
  box-shadow: 0 0 0 5px rgba(184, 113, 60, 0.14);
}

.process-node-label,
.process-node-meta {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
  pointer-events: none;
  transition: opacity 0.5s var(--ease), color 0.5s var(--ease);
}
.process-node-label {
  bottom: calc(100% + var(--s-4));
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 0.9375rem;
  color: var(--ink);
  opacity: 0;
}
.process-node-meta {
  top: calc(100% + var(--s-4));
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--stone);
  opacity: 0.55;
}
.process-node.is-active .process-node-label { opacity: 1; }
.process-node.is-active .process-node-meta { color: var(--ember-deep); opacity: 1; }
.process-node.is-past .process-node-meta { color: var(--ink); opacity: 0.7; }

@media (max-width: 720px) {
  .process-node-label { display: none; }
  .process-node.is-active .process-node-label {
    display: block;
    bottom: calc(100% + var(--s-3));
    font-size: 0.8125rem;
  }
  .process-node-meta { font-size: 0.6rem; letter-spacing: 0.2em; }
}

/* body */
.process-body {
  display: grid;
  grid-template-columns: 1.05fr auto 1fr;
  gap: var(--s-7);
  align-items: start;
  margin-top: var(--s-9);
}
@media (max-width: 900px) {
  .process-body {
    grid-template-columns: 1fr;
    gap: var(--s-5);
    margin-top: var(--s-8);
  }
}

.process-bigtitle {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-5xl);
  line-height: 0.98;
  letter-spacing: -0.02em;
  color: var(--bone-3);
  max-width: 11ch;
  transition: opacity 0.35s var(--ease), transform 0.35s var(--ease);
}
.process-bigtitle.is-swapping { opacity: 0; transform: translateY(6px); }

.process-meta { padding-top: var(--s-3); }
.process-step-meta {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--stone);
  display: inline-block;
}
@media (max-width: 900px) {
  .process-meta { padding-top: 0; }
  .process-step-meta {
    writing-mode: horizontal-tb;
    transform: none;
  }
}

.process-panels {
  position: relative;
  min-height: clamp(12rem, 22vw, 16rem);
}
.process-panel {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.5s var(--ease), transform 0.5s var(--ease);
  pointer-events: none;
}
.process-panel[hidden] { display: block; }
.process-panel.is-active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.process-panel h3 {
  margin-bottom: var(--s-4);
  font-size: 1.625rem;
}
.process-panel p {
  max-width: 48ch;
  color: #3e3e34;
}

/* controls */
.process-controls {
  display: flex;
  align-items: center;
  gap: var(--s-5);
  margin-top: var(--s-7);
}
.process-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid var(--line-light);
  background: transparent;
  color: var(--ink);
  transition: background 0.3s var(--ease), border-color 0.3s var(--ease),
              color 0.3s var(--ease), opacity 0.3s var(--ease);
}
.process-arrow svg {
  width: 18px;
  height: 18px;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.process-arrow:hover:not(:disabled) {
  border-color: var(--ink);
  background: rgba(14, 15, 12, 0.04);
}
.process-arrow:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.process-counter {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--ink);
  min-width: 5ch;
  text-align: center;
}
.process-counter-sep { color: var(--stone); margin: 0 0.15em; }

/* ---------- MOTION ---------- */
[data-fade] {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 1s var(--ease), transform 1s var(--ease);
}
[data-fade].in { opacity: 1; transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
  html { scroll-behavior: auto; }
}
