/* ============================================================
   Panamoure v2 — Utilities
   Section padding, container, heading defaults, responsive.
   ============================================================ */

/* --- Section framing (shared default) --- */
section {
  padding: 60px var(--page-pad-x);
}
.section-inner {
  max-width: var(--container-max);
  margin: 0 auto;
}
.section-header {
  max-width: 780px;
  margin-bottom: 44px;
}
.section-label {
  display: inline-block;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--pink);
  margin-bottom: 16px;
}
.section-label::before {
  content: '';
  display: inline-block;
  width: 24px;
  height: 1px;
  background: var(--pink);
  margin-right: 12px;
  vertical-align: middle;
}
.section-label--heading {
  font-size: 32px;
  font-weight: 800;
  letter-spacing: -0.5px;
  text-transform: none;
}
.section-label--heading::before { display: none; }
h2 {
  font-size: clamp(30px, 3.4vw, 48px);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.5px;
  color: var(--blue);
  margin-bottom: 20px;
}
h2 em {
  font-style: normal;
  color: var(--pink);
}
.section-intro {
  font-size: 17px;
  color: var(--small-text);
  line-height: 1.7;
  margin-top: 12px;
}

/* --- Spacing helpers --- */
.mt-0 { margin-top: 0 !important; }
.mt-16 { margin-top: 16px !important; }
.mt-32 { margin-top: 32px !important; }
.mt-56 { margin-top: 56px !important; }
.mt-80 { margin-top: 80px !important; }

.text-center { text-align: center; }
.text-pink { color: var(--pink) !important; }

/* --- Variant: dark section (when a generic .section sits on dark navy) --- */
.section-dark { background: var(--blue); color: var(--white); }
.section-dark h2 { color: var(--white); }
.section-dark .section-intro { color: rgba(255, 255, 255, 0.72); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  .nav {
    padding: 0 var(--page-pad-x-sm);
    height: 64px;
  }
  .nav-links { display: none; }
  .nav-cta { display: none; }

  .hero {
    padding: 80px var(--page-pad-x-sm) 64px;
  }
  .hero--home {
    padding: 90px var(--page-pad-x-sm) 72px;
  }
  .hero-proof,
  .proof-strip {
    padding: 40px var(--page-pad-x-sm);
  }
  .hero-proof-inner,
  .proof-inner {
    grid-template-columns: 1fr 1fr;
    gap: 28px;
  }

  section { padding: 56px var(--page-pad-x-sm); }

  .triad-section,
  .feature-band,
  .tagline-band,
  .article-section,
  .utility-section,
  .case-detail-section {
    padding: 72px var(--page-pad-x-sm);
  }

  .triad-grid { grid-template-columns: 1fr; gap: 36px; }
  .pillars-grid { grid-template-columns: 1fr; }
  .flow { grid-template-columns: 1fr; }
  .flow-step::after { display: none; }

  .case-grid { grid-template-columns: 1fr; }
  .case-stats { grid-template-columns: 1fr 1fr; }
  .more-work-grid { grid-template-columns: 1fr; }

  .feature-grid { grid-template-columns: 1fr; gap: 20px; }

  .principles-grid { grid-template-columns: 1fr; gap: 32px; }

  .lead-grid { grid-template-columns: 1fr; gap: 40px; }
  .stage { grid-template-columns: 1fr; gap: 24px; padding: 28px; }
  .layer { grid-template-columns: 1fr; gap: 16px; padding: 28px; }
  .spectrum-legend { grid-template-columns: 1fr 1fr; }
  .spec-seg { font-size: 10px; padding: 0 8px; }
  .frameworks-grid { grid-template-columns: 1fr 1fr; }
  .scale-grid { grid-template-columns: 1fr; gap: 36px; }
  .scale-stats { gap: 24px 32px; }
  .realisation-grid { grid-template-columns: 1fr; gap: 36px; }
  .challenge-grid { grid-template-columns: 1fr; }
  .barriers-grid { grid-template-columns: 1fr; }
  .pillars-3-grid { grid-template-columns: 1fr; }
  .proven-grid { grid-template-columns: 1fr; }
  .differentiators-list { grid-template-columns: 1fr; }
  .lets-talk-card { grid-template-columns: 1fr; gap: 24px; }

  .challenges-grid { grid-template-columns: 1fr; }
  .sector-stats-inner { grid-template-columns: 1fr; gap: 28px; }
  .index-grid { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 40px; }

  .cta { padding: 72px var(--page-pad-x-sm); }
  .footer { padding: 56px var(--page-pad-x-sm) 40px; }
  .footer-inner { grid-template-columns: 1fr 1fr; gap: 32px; }

  .eng-outcomes-grid { grid-template-columns: 1fr 1fr; gap: 20px; }
  .philosophy-grid { grid-template-columns: 1fr 1fr; }
  .philosophy-card { grid-column: span 1 !important; }
}

@media (max-width: 600px) {
  .proof-inner,
  .hero-proof-inner { grid-template-columns: 1fr; gap: 24px; }
  .footer-inner { grid-template-columns: 1fr; gap: 28px; }
  .scale-stats { grid-template-columns: 1fr; gap: 20px; }
  .eng-outcomes-grid { grid-template-columns: 1fr 1fr; }
  .philosophy-grid { grid-template-columns: 1fr; }
  .hero-actions { flex-direction: column; align-items: flex-start; }
  .lets-talk-actions { flex-direction: column; align-items: flex-start; }
  .frameworks-grid { grid-template-columns: 1fr;}
}


