/* =========================================================================
   Momentum — Bliv medlem af Insides
   ========================================================================= */

/* -------- Hero -------- */
.join-hero {
  position: relative;
  background: var(--bjg-forest);
  color: var(--bjg-cream);
  overflow: hidden;
  display: flex;
  align-items: center;
  min-height: 78vh;
}
.join-hero__photo {
  position: absolute; inset: 0;
  background-image: url('assets/images/family-office-dark.jpg');
  background-size: cover;
  background-position: center;
  opacity: 0.28;
  filter: grayscale(0.2);
}
.join-hero__veil {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(34,34,34,0.86) 0%, rgba(34,34,34,0.64) 100%);
}
.join-hero__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1480px;
  margin: 0 auto;
  padding: 200px var(--gutter) 120px;
}
.join-hero__content { max-width: 760px; }
.join-hero__eyebrow {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 11.5px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: rgba(255,255,255,0.78);
  display: flex; align-items: center; gap: 16px;
  margin-bottom: 32px;
}
.join-hero__eyebrow::before {
  content: ""; display: inline-block; width: 28px; height: 1px; background: currentColor; opacity: 0.7;
}
.join-hero__title {
  font-family: var(--font-display);
  font-size: 80px;
  line-height: 0.96;
  letter-spacing: -0.02em;
  color: #fff;
  margin: 0;
  max-width: 18ch;
  text-wrap: balance;
}
.join-hero__title em { font-style: italic; opacity: 0.78; }
.join-hero__lede {
  margin-top: 36px;
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: 16px;
  line-height: 1.6;
  color: rgba(245,241,237,0.80);
  max-width: 58ch;
}
.join-hero__benefits {
  list-style: none;
  padding: 0;
  margin: 36px 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 14px 32px;
}
.join-hero__benefits li {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: 15px;
  color: rgba(245,241,237,0.9);
}
.join-hero__benefits li svg { flex-shrink: 0; color: rgba(245,241,237,0.7); }

/* -------- Benefits strip (between hero and form) -------- */
.join-strip {
  background: var(--bjg-cream);
  border-bottom: 1px solid rgba(34,46,78,0.10);
}
.join-strip__inner {
  max-width: 1480px;
  margin: 0 auto;
  padding: 28px var(--gutter);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}
.join-strip__item {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 6px 24px;
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 14.5px;
  line-height: 1.4;
  white-space: nowrap;
  color: var(--bjg-forest);
  border-left: 1px solid rgba(34,46,78,0.12);
}
.join-strip__item:first-child { border-left: 0; }
.join-strip__item svg { flex-shrink: 0; color: var(--bjg-forest); }
@media (max-width: 760px) {
  .join-strip__inner { flex-direction: column; gap: 14px; padding: 24px; }
  .join-strip__item { border-left: 0; padding: 0; white-space: normal; }
}
.join-hero__cue {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-top: 48px;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 12px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--bjg-cream);
  text-decoration: none;
  border: 1px solid rgba(245,241,237,0.4);
  border-radius: 5px;
  padding: 14px 24px;
  transition: background var(--dur-2) var(--ease-out);
}
.join-hero__cue:hover { background: rgba(245,241,237,0.1); }
.join-hero__cue svg { transition: transform var(--dur-2) var(--ease-out); }
.join-hero__cue:hover svg { transform: translateY(3px); }

/* -------- Form section (light) -------- */
.join-form-section {
  background: var(--bjg-bone);
  padding: clamp(72px, 10vh, 140px) var(--gutter);
  display: flex;
  justify-content: center;
}
.join-form-wrap { width: 100%; max-width: 620px; }
.join-form-card {
  background: transparent;
  padding: 0;
}
.join-form-card__eyebrow {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--bjg-graphite);
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 32px;
}
.join-form-card__eyebrow::before {
  content: ""; display: inline-block; width: 24px; height: 1px; background: currentColor; opacity: 0.5;
}

/* -------- Multistep (light theme) -------- */
.q-progress { margin-bottom: 36px; }
.q-progress__meta {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--bjg-mute);
  margin-bottom: 12px;
}
.q-progress__meta span { white-space: nowrap; }
.q-progress__track {
  height: 2px;
  background: rgba(34,46,78,0.12);
  border-radius: 999px;
  overflow: hidden;
}
.q-progress__bar {
  height: 100%;
  background: var(--bjg-forest);
  border-radius: 999px;
  transition: width var(--dur-3, 360ms) var(--ease-out);
}
.q-step { display: block; }
.q-head {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 28px;
}
.q-num {
  flex-shrink: 0;
  width: 28px; height: 28px;
  border-radius: 6px;
  background: var(--bjg-forest);
  color: var(--bjg-cream);
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 13px;
  display: flex; align-items: center; justify-content: center;
  margin-top: 4px;
}
.q-title {
  font-family: var(--font-display);
  font-size: clamp(24px, 2.6vw, 32px);
  line-height: 1.16;
  letter-spacing: -0.01em;
  color: var(--bjg-forest);
  margin: 0;
  text-wrap: balance;
}
.q-desc {
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: 14px;
  color: var(--bjg-mute);
  margin: 0 0 18px;
}
.q-fields { display: flex; flex-direction: column; gap: 20px; }

/* Light-theme field overrides (site.css fields are dark) */
.join-form-card .field__label { color: var(--bjg-graphite); }
.join-form-card .field__input {
  color: var(--bjg-forest);
  border-bottom-color: rgba(34,46,78,0.25);
}
.join-form-card .field__input::placeholder { color: rgba(34,46,78,0.30); }
.join-form-card .field__input:focus { border-bottom-color: var(--bjg-forest); }

.q-options { display: flex; flex-direction: column; gap: 12px; }
.q-option {
  display: flex;
  align-items: center;
  gap: 16px;
  width: 100%;
  text-align: left;
  padding: 18px 20px;
  background: rgba(34,46,78,0.025);
  border: 1px solid rgba(34,46,78,0.16);
  border-radius: 12px 12px 16px 16px;
  color: var(--bjg-forest);
  cursor: pointer;
  font-family: var(--font-sans);
  transition: background var(--dur-2) var(--ease-out), border-color var(--dur-2) var(--ease-out);
}
.q-option:hover { background: rgba(34,46,78,0.05); }
.q-option.is-selected {
  background: rgba(34,46,78,0.06);
  border-color: var(--bjg-forest);
}
.q-option__badge {
  flex-shrink: 0;
  width: 28px; height: 28px;
  border-radius: 999px;
  border: 1px solid rgba(34,46,78,0.3);
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 12px;
  color: var(--bjg-graphite);
  display: flex; align-items: center; justify-content: center;
  transition: background var(--dur-2) var(--ease-out), color var(--dur-2) var(--ease-out), border-color var(--dur-2) var(--ease-out);
}
.q-option__badge--sq { border-radius: 7px; }
.q-option.is-selected .q-option__badge {
  background: var(--bjg-forest);
  color: var(--bjg-cream);
  border-color: var(--bjg-forest);
}
.q-option__label {
  flex: 1;
  font-weight: 300;
  font-size: 16px;
  line-height: 1.4;
  color: var(--bjg-forest);
}
.q-option__check { flex-shrink: 0; color: var(--bjg-forest); }

.q-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 36px;
  gap: 16px;
}
.q-back {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: transparent;
  border: 0;
  cursor: pointer;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 12px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--bjg-graphite);
  transition: color var(--dur-2) var(--ease-out);
}
.q-back:hover { color: var(--bjg-forest); }
.q-next {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: var(--bjg-forest);
  color: var(--bjg-cream);
  border: 0;
  border-radius: 5px;
  padding: 15px 26px;
  cursor: pointer;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 12px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  transition: opacity var(--dur-2) var(--ease-out);
}
.q-next:hover { opacity: 0.88; }
.q-next:disabled { opacity: 0.3; cursor: not-allowed; }

/* -------- Done state -------- */
.join__done {
  display: flex;
  gap: 18px;
  align-items: flex-start;
}
.join__done-mark {
  flex-shrink: 0;
  width: 44px; height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(34,46,78,0.25);
  display: flex; align-items: center; justify-content: center;
  color: var(--bjg-forest);
}
.join__done p {
  margin: 0;
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: 17px;
  line-height: 1.6;
  color: var(--bjg-forest);
}

@media (max-width: 700px) {
  .join-hero__inner { padding: 150px 24px 80px; }
  .join-hero__title { font-size: clamp(44px, 13vw, 80px); }
  .join-form-section { padding: 56px 20px; }
}
