/* =========================================
   ENELIS — Inner pages shared layout pieces
   ========================================= */

/* Section with 2-col split text+visual */
.split {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 80px;
  align-items: start;
}
.split-rev { grid-template-columns: 1.2fr 1fr; }
.split-rev .split-text { order: 2; }
.split-rev .split-visual { order: 1; }
@media (max-width: 920px) {
  .split, .split-rev { grid-template-columns: 1fr; gap: 40px; }
  .split-rev .split-text, .split-rev .split-visual { order: 0; }
}

/* Big anchor service block */
.service-block {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 80px;
  align-items: start;
  padding: 100px 0;
  border-top: 1px solid var(--line);
}
.service-block:nth-child(odd) {
  grid-template-columns: 1.2fr 1fr;
}
.service-block:nth-child(odd) .service-block-text { order: 2; }
.service-block:nth-child(odd) .service-block-visual { order: 1; }
@media (max-width: 920px) {
  .service-block,
  .service-block:nth-child(odd) { grid-template-columns: 1fr; gap: 40px; }
  .service-block:nth-child(odd) .service-block-text,
  .service-block:nth-child(odd) .service-block-visual { order: 0; }
}
.service-block-visual {
  position: relative;
  aspect-ratio: 4/5;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--ivory-warm);
}
.service-block-visual img { width: 100%; height: 100%; object-fit: cover; }
.service-block-text h2 .num-prefix {
  display: block;
  font-family: var(--serif);
  font-style: italic;
  font-size: 0.45em;
  color: var(--copper);
  font-weight: 400;
  margin-bottom: 10px;
}
.service-block-text .lede { margin: 24px 0 36px; }

.service-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 32px;
}
.service-detail-card {
  padding: 22px;
  background: var(--paper-pure);
  border: 1px solid var(--line);
  border-radius: 8px;
}
.service-detail-label {
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 8px;
  font-weight: 600;
}
.service-detail-value {
  font-family: var(--serif);
  font-size: 24px;
  color: var(--navy);
  line-height: 1.1;
}
.service-detail-sub { font-size: 13px; color: var(--ink-soft); margin-top: 4px; }

.service-feature-list {
  list-style: none;
  display: flex; flex-direction: column;
  gap: 20px;
  margin-bottom: 36px;
}
.service-feature-list li {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 16px;
  font-size: 15px;
  color: var(--ink-soft);
  line-height: 1.55;
}
.service-feature-list strong { color: var(--navy); font-weight: 600; display: block; margin-bottom: 4px; }
.service-feature-num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  color: var(--copper);
  line-height: 1;
  padding-top: 4px;
}

/* CTA inline */
.cta-band {
  background: var(--navy);
  color: var(--paper);
  border-radius: var(--radius-lg);
  padding: 64px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
}
.cta-band h3 {
  color: var(--paper);
  font-size: 32px;
  max-width: 22ch;
}
.cta-band p { color: rgba(255,255,255,0.7); margin-top: 12px; max-width: 50ch; }
@media (max-width: 820px) {
  .cta-band { flex-direction: column; align-items: flex-start; padding: 40px; }
}

/* Generic page intro */
.page-intro {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 80px;
  align-items: end;
}
@media (max-width: 920px) { .page-intro { grid-template-columns: 1fr; gap: 24px; } }


/* ===========================================================
   INNER PAGES — Mobile safety at 480px and below
   =========================================================== */
@media (max-width: 480px) {
  .split, .split-rev, .service-block, .page-intro {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }
  .service-block, .split { padding-top: 0; }
  .page-intro h1 { font-size: clamp(30px, 9vw, 42px); }
  .cta-band { padding: 32px 24px; }
  .cta-band h2 { font-size: clamp(24px, 7vw, 32px); }
  .indep-grid { grid-template-columns: 1fr !important; gap: 32px !important; }
  .indep-card { padding: 22px; }
  .service-detail-grid { grid-template-columns: 1fr !important; }
}
