/* ═══════════════════════════════════════════════════════════════════════════
   SOULFORCE ARTS — ABOUT JOSEPH  (/about)
   Extends styles.css. Reuses brand tokens, buttons, kickers, enso, footer.
   ═══════════════════════════════════════════════════════════════════════════ */

/* Eyebrow sits 38px above its header — house rule */
.kicker + h1,
.kicker + h2 { margin-top: 38px !important; }

/* ═══ 01 HERO ═══════════════════════════════════════════════════════════════ */
.hero.v-about {
  min-height: clamp(580px, 84vh, 760px);
  padding-top: clamp(132px, 15vw, 176px);
  padding-bottom: clamp(5.5rem, 9vw, 8rem);
  background: var(--green-deeper);
  display: flex;
  align-items: center;
}
.hero.v-about .hero-photo {
  position: absolute;
  inset: 0;
  background: #0c1d1b url("assets/joseph-hero3.png") 60% 14% / 112% no-repeat;
  z-index: 0;
}
.hero.v-about .hero-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg,
      rgba(15,36,34,0.3) 0%,
      rgba(15,36,34,0.18) 20%,
      rgba(15,36,34,0.28) 38%,
      rgba(15,36,34,0.72) 54%,
      rgba(15,36,34,0.92) 70%,
      rgba(15,36,34,0.96) 100%),
    linear-gradient(180deg,
      rgba(15,36,34,0.14) 0%,
      transparent 20%,
      transparent 62%,
      rgba(15,36,34,0.72) 100%);
}
.hero.v-about .hero-wrap {
  position: relative;
  z-index: 2;
  max-width: var(--max-w);
  margin: 0 auto;
  width: 100%;
  padding: 0 var(--page-pad);
}
.hero.v-about .hero-copy { max-width: 560px; margin-left: auto; }
.hero.v-about .lead em.gold { font-style: normal; color: var(--gold); font-weight: 500; }
.hero-banner {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  z-index: 3;
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  gap: 0;
  padding: 16px var(--page-pad);
  background: var(--green-deeper);
  border-top: 1px solid rgba(222,190,81,0.28);
  border-bottom: 1px solid rgba(222,190,81,0.14);
}
.hero-banner span {
  position: relative;
  white-space: nowrap;
  font-family: var(--sans);
  font-weight: 600;
  font-size: clamp(10px, 1vw, 13px);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  padding: 6px clamp(0.85rem, 3vw, 2.6rem);
}
.hero-banner span:not(:last-child)::after {
  content: "";
  position: absolute;
  right: -2px; top: 50%;
  transform: translateY(-50%);
  width: 4px; height: 4px;
  border-radius: 50%;
  background: rgba(222,190,81,0.5);
}
@media (max-width: 700px) {
  .hero-banner { flex-direction: column; flex-wrap: wrap; gap: 0; padding: 14px var(--page-pad); }
  .hero-banner span { padding: 6px 0; }
  .hero-banner span:not(:last-child)::after { display: none; }
}
.hero.v-about .h-display {
  color: var(--gold);
  font-size: clamp(2.3rem, 4.6vw, 3.9rem);
  line-height: 1.05;
  margin: 0 0 26px;
}
.hero.v-about .h-display .hl { color: var(--paper-warm); }
.hero.v-about .lead { color: rgba(255,255,255,0.86); max-width: 52ch; margin: 0 0 30px; }
.promise-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 18px;
  font-family: var(--sans);
  font-weight: 600;
  font-size: 11.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
}
.promise-strip span { display: inline-flex; align-items: center; gap: 18px; }
.promise-strip span::after {
  content: "";
  width: 5px; height: 5px; border-radius: 50%;
  background: rgba(222,190,81,0.5);
}
.promise-strip span:last-child::after { display: none; }
.hero.v-about .enso-bg {
  right: -6%; left: auto; bottom: -300px; top: auto;
  width: 600px; height: 600px;
}
body.enso-subtle .hero.v-about .enso-bg { opacity: 0.26; }
body.enso-prominent .hero.v-about .enso-bg { opacity: 0.42; }

/* ═══ Shared story layout (photo + narrative) ═══════════════════════════════ */
.story .wrap {
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: clamp(2.5rem, 7vw, 6rem);
  align-items: center;
}
.story.flip .story-visual { order: 2; }
@media (max-width: 900px) {
  .story .wrap { grid-template-columns: 1fr; gap: 2.5rem; }
  .story .story-visual, .story.flip .story-visual { order: -1; max-width: 420px; }
}
.story-visual { position: relative; }
.story-photo {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 5;
  background-color: #0c1d1b;
  background-size: cover;
  background-position: center;
  box-shadow: 0 30px 60px -30px rgba(24,30,27,0.55);
}
.story-photo::after {
  content: "";
  position: absolute;
  inset: -18px 18px 18px -18px;
  border: 1px solid var(--gold-warm);
  opacity: 0.5;
  z-index: -1;
}
.on-dark .story-photo::after { border-color: var(--gold); }
.story-photo .photo-cap {
  position: absolute;
  left: 0; bottom: -34px;
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.on-dark .story-photo .photo-cap { color: rgba(255,255,255,0.5); }
.story-narrative {
  font-family: var(--sans);
  font-size: clamp(1.02rem, 1.3vw, 1.15rem);
  line-height: 1.85;
}
.story-narrative p { margin: 0 0 1.2em; }
.story-narrative p:last-child { margin-bottom: 0; }
.story-narrative em.gold { font-style: normal; color: var(--gold-warm); font-weight: 500; }
.on-dark .story-narrative em.gold { color: var(--gold); }
.story .h-section { margin: 0 0 26px; }
.story.on-dark .h-section { color: #fff; }
.story .story-narrative { color: var(--ink-soft); }
.story.on-dark .story-narrative { color: rgba(255,255,255,0.92); }
.story .pull {
  border-left: 2px solid var(--gold-warm);
  padding-left: 30px;
  margin: 36px 0 0;
  font-family: var(--serif);
  font-size: clamp(1.4rem, 2.3vw, 1.9rem);
  line-height: 1.25;
  letter-spacing: 0.012em;
  text-transform: uppercase;
  color: var(--ink);
}
.story.on-dark .pull { border-left-color: var(--gold); color: #fff; }

/* Section-specific photo crops */
.s-interrupted .story-photo { background-image: url("assets/joseph-boy.png"); background-position: center 30%; }
.s-turning .story-photo { background-image: url("assets/joseph-young.png"); background-position: center 20%; }
.s-welcome .story-photo { background-image: url("assets/joseph-welcome.jpg"); background-position: center 18%; }

.s-interrupted .enso-bg { right: -12%; top: -22%; width: 440px; height: 440px; }
.s-turning .enso-bg { left: -13%; bottom: -260px; width: 520px; height: 520px; }
.s-welcome .enso-bg { right: -6%; left: auto; top: -300px; bottom: auto; width: 600px; height: 600px; }

/* What-changed highlight inside the Turning section */
.what-changed {
  margin: clamp(2.5rem, 5vw, 3.75rem) 0 0;
  padding: clamp(28px, 4vw, 40px) 0 0;
  border-top: 1px solid rgba(255,255,255,0.14);
}
.what-changed .wc-flag {
  display: block;
  font-family: var(--sans);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 18px;
}
.what-changed p { font-family: var(--sans); color: rgba(255,255,255,0.92); font-size: 1.05rem; line-height: 1.8; margin: 0 0 1em; max-width: 60ch; }
.what-changed p:last-child { margin-bottom: 0; }
.what-changed em.gold { color: var(--gold); font-style: italic; font-weight: 400; }

/* ═══ CREDENTIALS & CRAFT ═══════════════════════════════════════════════════ */
.s-cred .wrap {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: clamp(2.5rem, 6vw, 5rem);
  align-items: start;
}
@media (max-width: 880px) { .s-cred .wrap { grid-template-columns: 1fr; } }
.s-cred .h-section { margin: 0 0 24px; max-width: 16ch; }
.s-cred .body { font-size: 1.05rem; color: var(--ink-soft); max-width: 54ch; }
.s-cred .body p { margin: 0 0 1.1em; }
.s-cred .body em.title-italic { font-style: italic; color: var(--ink); }
.cred-stats {
  list-style: none;
  margin: 32px 0 0;
  padding: 0;
  border-top: 1px solid var(--rule);
}
.cred-stats li {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 22px;
  align-items: baseline;
  padding: 16px 2px;
  border-bottom: 1px solid var(--rule);
}
.cred-stats .stat-num {
  font-family: var(--serif);
  font-size: 1.65rem;
  line-height: 1;
  color: var(--gold-warm);
  white-space: nowrap;
}
.cred-stats .stat-label {
  font-family: var(--sans);
  font-size: 0.96rem;
  line-height: 1.5;
  color: var(--ink-soft);
}
.cred-visual { position: relative; }
.cred-photo {
  position: relative;
  aspect-ratio: 4 / 3;
  width: 100%;
  background: #0c1d1b url("assets/joseph-omega.jpg") center / cover no-repeat;
  box-shadow: 0 30px 60px -30px rgba(24,30,27,0.55);
}
.cred-photo.cred-loft { background-image: url("assets/joseph-loft.jpg"); margin-top: 44px; }
.cred-cap {
  margin: 30px 0 0;
  font-family: var(--sans);
  font-size: 11.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  line-height: 1.5;
  color: var(--ink-mute);
  text-align: center;
}
.cred-photo::after {
  content: "";
  position: absolute;
  inset: -18px 18px 18px -18px;
  border: 1px solid var(--gold-warm);
  opacity: 0.5;
  z-index: -1;
}
.s-cred .enso-bg { left: -13%; top: -260px; width: 520px; height: 520px; }
.s-cred .enso-fill { right: -8%; left: auto; bottom: -260px; top: auto; width: 520px; height: 520px; }

/* ═══ WHERE I AM NOW ════════════════════════════════════════════════════════ */
.s-now .story-photo { background-image: url("assets/joseph-now.jpg"); background-position: center 30%; aspect-ratio: 4 / 5; }
.s-now .enso-bg { right: -12%; bottom: -22%; width: 460px; height: 460px; }
.s-now .enso-top { right: -8%; left: auto; top: -260px; bottom: auto; width: 520px; height: 520px; }
.s-now .now-tags {
  list-style: none;
  margin: 28px 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.s-now .now-tags li {
  font-family: var(--sans);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold-warm);
  padding: 8px 14px;
  border: 1px solid rgba(187,131,38,0.4);
  border-radius: 2px;
}
.inline-link {
  color: var(--gold-warm);
  border-bottom: 1px solid rgba(187,131,38,0.5);
  padding-bottom: 1px;
  transition: color .25s ease, border-color .25s ease;
}
.inline-link:hover { color: var(--ink); border-color: var(--ink); }
.on-dark .inline-link { color: var(--gold); border-bottom-color: rgba(222,190,81,0.5); }
.on-dark .inline-link:hover { color: #fff; border-color: #fff; }

/* ═══ THE VISION ════════════════════════════════════════════════════════════ */
.s-vision {
  position: relative;
  overflow: hidden;
}
.s-vision .vision-photo {
  position: absolute;
  inset: 0;
  background: #0c1d1b url("assets/hero-sunset.jpg") center 40% / cover no-repeat;
  z-index: 0;
  opacity: 0.5;
}
.s-vision .vision-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(15,36,34,0.86) 0%, rgba(15,36,34,0.72) 50%, rgba(15,36,34,0.9) 100%);
}
.s-vision .wrap { max-width: 880px; text-align: center; position: relative; z-index: 2; }
.s-vision .kicker { justify-content: center; }
.s-vision .kicker::after { content: ""; width: 36px; height: 1px; background: currentColor; display: inline-block; }
.s-vision .h-section { color: #fff; margin: 0 auto 26px; max-width: 18ch; }
.s-vision .body { color: rgba(255,255,255,0.88); font-size: clamp(1.1rem, 1.5vw, 1.3rem); line-height: 1.8; max-width: 60ch; margin: 0 auto; }
.s-vision .body em.gold { color: var(--gold); font-style: italic; }
.s-vision .enso-bg { right: -13%; bottom: -260px; left: auto; top: auto; width: 520px; height: 520px; }

/* ═══ FINAL CTA ═════════════════════════════════════════════════════════════ */
.s-about-cta { text-align: center; }
.s-about-cta .wrap { max-width: 760px; }
.s-about-cta .kicker { justify-content: center; display: inline-flex; }
.s-about-cta .kicker::after { content: ""; width: 36px; height: 1px; background: currentColor; display: inline-block; }
.s-about-cta .h-section { margin: 0 auto 20px; max-width: 18ch; }
.s-about-cta .lead { color: var(--ink-soft); margin: 0 auto 34px; max-width: 46ch; }
.s-about-cta .ctas { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; }
.about-tertiary {
  margin: 36px 0 0;
  padding-top: 28px;
  border-top: 1px solid var(--rule);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px 30px;
}
.about-tertiary .btn-link { color: var(--gold-warm); }
.about-tertiary .btn-link:hover { color: var(--ink); }
.s-about-cta .enso-bg { right: -13%; top: -260px; width: 520px; height: 520px; }

/* Welcome intro spacing */
.s-welcome .story-narrative .h-section { display: none; }
.s-welcome .intro-lead {
  font-family: var(--sans);
  font-size: clamp(1.1rem, 1.5vw, 1.3rem);
  line-height: 1.7;
  color: var(--ink);
  margin: 0 0 1.2em;
}
.s-welcome .intro-lead strong { color: var(--gold-warm); font-weight: 600; }

/* ─── Footer enso (reuse) ─── */
.footer { position: relative; }
.footer .cta-enso {
  position: absolute;
  top: clamp(-300px, -21vw, -210px);
  right: 3%;
  width: min(60vw, 600px);
  height: min(60vw, 600px);
  background: url("assets/enso.png") center / contain no-repeat;
  opacity: 0.13;
  pointer-events: none;
  z-index: 0;
}
.footer .wrap { position: relative; z-index: 1; }
body.enso-off .footer .cta-enso { display: none; }
body.enso-prominent .footer .cta-enso { opacity: 0.22; }

/* Modal outline (Close) buttons — match other pages */
.modal .btn.outline { border-color: rgba(24, 30, 27, 0.4); color: var(--ink); }
.modal .btn.outline:hover { background: rgba(24, 30, 27, 0.05); border-color: var(--ink); }

/* Inline link on book-title "Soulforce" mentions -> /book */
.soulforce-link { color: inherit; text-decoration: none; border-bottom: 1px solid currentColor; transition: opacity .2s ease; }
.soulforce-link:hover { opacity: 0.7; }
