/**
 * LMO frontend CSS.
 *
 * Doel:
 * - Publieke weergave voor shortcode [lmo_homepage].
 * - De homepage volgt dezelfde componenten en design-tokens als Vormgeving > Homepage.
 * - Typografie gebruikt desktop- en mobiele waarden uit het dashboard.
 * - Titels worden kleiner via container queries in plaats van afgebroken met woordafbreking.
 */
.lmo-homepage {
  background: var(--lmo-color-background);
  color: var(--lmo-color-text);
  padding: var(--lmo-outer-padding-top) var(--lmo-outer-padding-right) var(--lmo-outer-padding-bottom) var(--lmo-outer-padding-left);
  font-family: var(--lmo-font-body);
  font-weight: var(--lmo-font-body-weight);
}

.lmo-homepage *,
.lmo-preview-surface * {
  box-sizing: border-box;
}

.lmo-hero {
  container-type: inline-size;
  min-height: 280px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
}

.lmo-homepage .lmo-container .lmo-hero h1,
.lmo-preview-surface .lmo-hero h3,
.lmo-hero h1,
.lmo-hero h3 {
  display: block;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  margin: 0 0 clamp(0.8rem, 2cqw, 1.15rem);
  padding: 0;
  color: var(--lmo-color-text);
  font-family: var(--lmo-font-heading);
  font-weight: var(--lmo-font-heading-weight);
  font-size: clamp(1.8rem, 8cqw, var(--lmo-heading-font-size));
  line-height: var(--lmo-heading-line-height);
  text-align: var(--lmo-heading-align);
  letter-spacing: clamp(-0.035em, -0.18cqw, -0.008em);
  overflow-wrap: normal;
  word-break: keep-all;
  hyphens: none;
  text-wrap: balance;
}

.lmo-homepage .lmo-container .lmo-hero .lmo-hero-content > p:not(.lmo-kicker),
.lmo-preview-surface .lmo-hero .lmo-hero-content > p:not(.lmo-kicker),
.lmo-hero .lmo-hero-content > p:not(.lmo-kicker) {
  width: 100%;
  max-width: min(640px, 100%);
  margin: 0;
  padding: 0;
  color: var(--lmo-color-muted);
  font-family: var(--lmo-font-body);
  font-weight: var(--lmo-font-body-weight);
  font-size: clamp(0.95rem, 2.2cqw, var(--lmo-body-font-size));
  line-height: var(--lmo-body-line-height);
  text-align: var(--lmo-body-align);
  overflow-wrap: break-word;
  hyphens: none;
}

.lmo-homepage .lmo-container .lmo-hero .lmo-kicker,
.lmo-preview-surface .lmo-hero .lmo-kicker {
  text-align: var(--lmo-heading-align);
}

.lmo-hero .lmo-button {
  align-self: var(--lmo-button-align);
  margin-top: 1.3rem;
}

.lmo-hero[style*="--lmo-heading-align:center"] .lmo-button,
.lmo-homepage .lmo-hero:has(h1) .lmo-button {
  max-width: 100%;
}

@container (max-width: 620px) {
  .lmo-homepage .lmo-container .lmo-hero h1,
  .lmo-preview-surface .lmo-hero h3,
  .lmo-hero h1,
  .lmo-hero h3 {
    font-size: clamp(1.65rem, 10cqw, min(var(--lmo-heading-font-size), 3.8rem));
    line-height: var(--lmo-heading-line-height);
  }
}

@media (max-width: 640px) {
  .lmo-homepage {
    padding: max(18px, calc(var(--lmo-outer-padding-top) * 0.55)) max(var(--lmo-mobile-margin), calc(var(--lmo-outer-padding-right) * 0.4)) max(18px, calc(var(--lmo-outer-padding-bottom) * 0.55)) max(var(--lmo-mobile-margin), calc(var(--lmo-outer-padding-left) * 0.4));
  }

  .lmo-hero.lmo-card {
    padding: max(22px, calc(var(--lmo-inner-padding-top) * 0.58)) max(20px, calc(var(--lmo-inner-padding-right) * 0.45)) max(22px, calc(var(--lmo-inner-padding-bottom) * 0.58)) max(20px, calc(var(--lmo-inner-padding-left) * 0.45));
  }

  .lmo-homepage .lmo-container .lmo-hero h1 {
    font-size: clamp(1.55rem, 11.5cqw, var(--lmo-mobile-heading-font-size));
    line-height: var(--lmo-mobile-heading-line-height);
    text-align: var(--lmo-mobile-heading-align);
  }

  .lmo-homepage .lmo-container .lmo-hero .lmo-hero-content > p:not(.lmo-kicker) {
    font-size: clamp(0.95rem, 5cqw, var(--lmo-mobile-body-font-size));
    line-height: var(--lmo-mobile-body-line-height);
    text-align: var(--lmo-mobile-body-align);
  }

  .lmo-homepage .lmo-container .lmo-hero .lmo-kicker {
    text-align: var(--lmo-mobile-heading-align);
  }

  .lmo-hero {
    min-height: 220px;
  }

  .lmo-hero .lmo-button {
    width: 100%;
    justify-content: center;
  }
}
