/* ============================================================
   SHARED MODULE PAGE STYLES
   Used by: platform/web, platform/internal-network,
            platform/external-network, platform/mobile,
            platform/api
   ============================================================ */

/* --- Module feature list (capabilities grid) --- */
.module-feature-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.module-feature-item {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 10px;
  padding: 24px 20px;
  transition: border-color 0.2s ease;
}

.module-feature-item:hover { border-color: rgba(192, 0, 0, 0.3); }

.module-feature-title {
  font-family: var(--f-display);
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--primary-color);
  margin-bottom: 10px;
}

.module-feature-item p {
  color: var(--dark-text);
  font-size: 0.9rem;
  line-height: 1.65;
  margin: 0;
}

/* --- Module inline CTA banner --- */
.module-cta-banner {
  background: var(--dark-surface);
  padding: 56px 0;
}

.module-cta-quote {
  font-size: 1.375rem;
  font-weight: 600;
  color: var(--light-text);
  max-width: 640px;
  margin: 0 auto 12px;
  line-height: 1.35;
}

.module-cta-banner p {
  color: var(--muted-text);
  font-size: 1rem;
  margin: 0;
}

/* --- PT++ capability list (unordered) --- */
.ptpp-caps-list {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ptpp-caps-list li {
  color: var(--dark-text);
  font-size: 0.9375rem;
  line-height: 1.6;
  padding-left: 20px;
  position: relative;
}

.ptpp-caps-list li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--primary-color);
  font-size: 0.875rem;
}

/* --- Table wrapper --- */
.table-wrapper {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* --- Responsive --- */
@media (max-width: 768px) {
  .module-feature-list { grid-template-columns: 1fr; }
}
