/* ==========================================================================
   Modules page — Nortefy
   Eight module sections, editorial alternating layout via explicit
   .is-reverse modifier.
   ========================================================================== */

.modules-page {
  padding-top: var(--space-10);
  padding-bottom: var(--section-y);
}

/* Module section */
.module-section {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-10);
  align-items: center;
  padding: var(--space-12) 0;
  border-bottom: var(--hairline);
  scroll-margin-top: var(--space-10);
}

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

.module-section.is-reverse { direction: rtl; }
.module-section.is-reverse .module-info { direction: ltr; }

.module-info .module-icon {
  width: 56px;
  height: 56px;
  display: block;
  margin-bottom: var(--space-5);
}

.module-info h2 {
  font-family: var(--font-serif);
  font-size: var(--fs-h2);
  margin-bottom: var(--space-3);
  color: var(--ink);
  letter-spacing: var(--ls-heading);
  font-weight: var(--fw-medium);
}

.module-info h2 .accent {
  font-style: italic;
  color: var(--muted-color);
  font-weight: var(--fw-regular);
}

.module-info .module-tagline {
  font-family: var(--font-serif);
  font-size: var(--fs-lede);
  color: var(--muted-color);
  margin-bottom: var(--space-5);
  line-height: 1.4;
}

.module-info p {
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  margin-bottom: var(--space-4);
  color: var(--moss);
  max-width: 52ch;
}

.module-info p.module-tagline {
  font-family: var(--font-serif);
}

.module-image-container {
  border-radius: var(--radius);
  overflow: hidden;
  border: var(--hairline);
  background-color: var(--paper);
}

/* Cross-cutting block at the end of the page */
.cross-cutting {
  padding: var(--space-12) 0 var(--space-6);
  border-top: var(--hairline);
  margin-top: var(--space-6);
}

.cross-cutting h3 {
  font-family: var(--font-serif);
  font-size: var(--fs-h3);
  letter-spacing: var(--ls-heading);
  font-weight: var(--fw-medium);
  color: var(--ink);
  margin-bottom: var(--space-7);
  max-width: 32ch;
}

.cross-cutting-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-6) var(--space-7);
}

.cross-item {
  padding-top: var(--space-4);
  border-top: var(--hairline);
}

.cross-item h4 {
  font-family: var(--font-serif);
  font-size: var(--fs-h5);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-heading);
  color: var(--ink);
  margin-bottom: var(--space-2);
}

.cross-item p {
  font-family: var(--font-sans);
  font-size: var(--fs-body-sm);
  line-height: var(--lh-body);
  color: var(--moss);
  margin: 0;
}

@media (max-width: 768px) {
  .module-section {
    grid-template-columns: 1fr;
    gap: var(--space-6);
    direction: ltr !important;
    padding: var(--space-10) 0;
  }
}
