/* Casa M'xuma — /terms and /privacy
   Long-form legal pages. Restrained reading layout: narrow column,
   numbered sections, clear hierarchy, brand vocabulary kept light.
   Same component shape used by both pages — see includes/components/legal/. */

/* --- Intro -------------------------------------------------------- */

.legal-intro {
  position: relative;
  isolation: isolate;
  padding: var(--space-32) var(--space-6) var(--space-16);
  border-bottom: 1px solid var(--color-border-faint);
  text-align: center;
  overflow: hidden;
  min-height: 360px;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (min-width: 1024px) {
  .legal-intro {
    padding: var(--space-32) var(--space-12) var(--space-16);
    min-height: 440px;
  }
}

/* Atmosphere holds both the cinematic photograph and a fallback warm
   gradient. If the image fails to load, the gradient stays visible. */
.legal-intro__atmosphere {
  position: absolute;
  inset: 0;
  z-index: -1;
  overflow: hidden;
  background:
    radial-gradient(ellipse 60% 50% at 50% 50%, rgba(196, 122, 43, 0.08) 0%, transparent 70%),
    linear-gradient(180deg, var(--color-espresso) 0%, var(--color-char) 100%);
}

.legal-intro__image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* Scrim over the photograph: centered darken behind the heading stack
   plus a bottom-heavy gradient so the legal sections that follow read
   as a clean continuation. */
.legal-intro__scrim {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 50% 50%,
      rgba(8, 6, 4, 0.55) 0%,
      rgba(8, 6, 4, 0.35) 55%,
      rgba(8, 6, 4, 0.15) 90%
    ),
    linear-gradient(180deg,
      rgba(8, 6, 4, 0.40) 0%,
      rgba(8, 6, 4, 0.25) 35%,
      rgba(8, 6, 4, 0.30) 65%,
      rgba(8, 6, 4, 0.78) 100%
    );
}

.legal-intro__inner {
  position: relative;
  z-index: 1;
  max-width: 720px;
  margin-inline: auto;
}

.legal-intro__eyebrow {
  display: inline-block;
  font-family: var(--font-label);
  font-size: var(--font-size-micro);
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--color-aged-gold);
  margin-bottom: var(--space-6);
}

.legal-intro__heading {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(36px, 6vw, 64px);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--color-cream);
  margin: 0 0 var(--space-4);
}

.legal-intro__updated {
  font-family: var(--font-label);
  font-size: var(--font-size-micro);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: rgba(245, 239, 230, 0.45);
  margin: 0 0 var(--space-6);
}

.legal-intro__lede {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: clamp(15px, 1.5vw, 17px);
  line-height: var(--line-height-prose);
  color: var(--color-text-sand);
  max-width: 60ch;
  margin: var(--space-8) auto 0;
}

/* --- Long-form sections ----------------------------------------- */

.legal-body {
  padding-block: var(--space-16) var(--space-12);
}

@media (min-width: 1024px) {
  .legal-body { padding-block: var(--space-24); }
}

.legal-body__inner {
  max-width: 720px;
  margin-inline: auto;
  padding-inline: var(--space-6);
}

.legal-section {
  padding-block: var(--space-12);
  border-bottom: 1px solid var(--color-border-faint);
}

.legal-section:last-of-type {
  border-bottom: 0;
}

.legal-section__title {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
  font-family: var(--font-label);
  font-size: var(--font-size-micro);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--color-aged-gold);
  margin: 0 0 var(--space-6);
}

.legal-section__num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--font-size-md);
  color: var(--color-ember);
  letter-spacing: 0;
  text-transform: none;
  flex-shrink: 0;
  min-width: 28px;
}

.legal-section__title-text {
  flex: 1;
}

.legal-section p {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: var(--font-size-base);
  line-height: var(--line-height-prose);
  color: var(--color-text-sand);
  margin: 0 0 var(--space-4);
}

.legal-section p:last-child {
  margin-bottom: 0;
}

.legal-section ul {
  list-style: none;
  margin: var(--space-4) 0;
  padding: 0;
}

.legal-section ul li {
  position: relative;
  font-family: var(--font-body);
  font-weight: 300;
  font-size: var(--font-size-base);
  line-height: var(--line-height-prose);
  color: var(--color-text-sand);
  padding: var(--space-2) 0 var(--space-2) var(--space-6);
  border-bottom: 1px solid var(--color-border-faint);
}

.legal-section ul li:last-child {
  border-bottom: 0;
}

.legal-section ul li::before {
  content: '\25C6';
  position: absolute;
  left: 0;
  top: 12px;
  font-size: 6px;
  color: var(--color-ember);
  opacity: 0.7;
}

.legal-section__highlight {
  margin-top: var(--space-6);
  padding: var(--space-6) var(--space-8);
  border: 1px solid var(--color-border-gold);
  background: rgba(196, 122, 43, 0.04);
}

.legal-section__highlight p {
  font-size: var(--font-size-sm);
  color: var(--color-cream);
  margin: 0;
}

/* --- Closing contact block -------------------------------------- */

.legal-contact {
  margin: var(--space-12) auto var(--space-24);
  max-width: 720px;
  padding: var(--space-12) var(--space-8);
  border: 1px solid var(--color-border);
  text-align: center;
}

@media (min-width: 1024px) {
  .legal-contact { padding: var(--space-16); }
}

.legal-contact__eyebrow {
  display: inline-block;
  font-family: var(--font-label);
  font-size: var(--font-size-micro);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--color-aged-gold);
  margin-bottom: var(--space-3);
}

.legal-contact__heading {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(22px, 2.6vw, 28px);
  line-height: 1.2;
  color: var(--color-cream);
  margin: 0 0 var(--space-4);
}

.legal-contact__body {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: var(--font-size-sm);
  color: rgba(245, 239, 230, 0.55);
  margin: 0 0 var(--space-2);
}

.legal-contact__email {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--font-size-md);
  color: var(--color-cream);
  text-decoration: none;
  border-bottom: 1px solid var(--color-border-gold);
  padding-bottom: 4px;
  transition: color var(--duration-fast), border-color var(--duration-fast);
}

.legal-contact__email:hover,
.legal-contact__email:focus-visible {
  color: var(--color-ember);
  border-bottom-color: var(--color-ember);
}
