/* ============================================================
   eLightInfo — Page Sections
   Page headers, two-col layouts, content sections
   ============================================================ */

/* --- Page Header Banner (sub-pages) --- */
.page-header {
  background: var(--grad-hero);
  padding: var(--space-16) 0 var(--space-12);
  position: relative;
  overflow: hidden;
}
.page-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(29,106,235,0.06) 1px, transparent 1px);
  background-size: 36px 36px;
}
/* Glow accent */
.page-header::after {
  content: '';
  position: absolute;
  top: -100px;
  right: -100px;
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(0,194,255,0.12) 0%, transparent 70%);
  pointer-events: none;
}
.page-header .container { position: relative; z-index: 1; }
.page-header .service-icon {
  width: 72px;
  height: 72px;
  border-radius: var(--radius-xl);
  background: rgba(29,106,235,0.15);
  border: 1px solid rgba(0,194,255,0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  color: var(--color-cyan);
  margin-bottom: var(--space-5);
}
.page-header h1 {
  color: var(--color-white);
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  margin-bottom: var(--space-4);
}
.page-header .lead {
  font-size: 1.0625rem;
  color: rgba(255,255,255,0.72);
  max-width: 640px;
  line-height: 1.7;
}

/* --- Two Column Layout --- */
.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: center;
}
.two-col.reverse { direction: rtl; }
.two-col.reverse > * { direction: ltr; }

.two-col-text h2 { margin-bottom: var(--space-5); }
.two-col-text p {
  color: var(--color-text-mid);
  line-height: 1.7;
  margin-bottom: var(--space-4);
}
.two-col-text .btn { margin-top: var(--space-4); }

.two-col-visual {
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: var(--grad-card);
  min-height: 320px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.two-col-visual svg { max-width: 100%; height: auto; }

/* --- Visual Placeholder (for image replacement) --- */
.img-placeholder {
  width: 100%;
  aspect-ratio: 16/9;
  background: var(--grad-card);
  border-radius: var(--radius-xl);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.4);
  font-size: 0.875rem;
  border: 1px dashed rgba(255,255,255,0.1);
}
.img-placeholder i {
  font-size: 2rem;
  margin-bottom: var(--space-2);
  color: rgba(255,255,255,0.2);
}
/* When a real image is placed */
.img-placeholder img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-xl);
}

/* --- Intro Paragraph Block --- */
.intro-block {
  max-width: 800px;
  margin-inline: auto;
  text-align: center;
  margin-bottom: var(--space-12);
}
.intro-block h2 { margin-bottom: var(--space-5); }
.intro-block p {
  font-size: 1.0625rem;
  color: var(--color-text-mid);
  line-height: 1.7;
}

/* --- Info Grid (2-column text + icon list) --- */
.info-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
}

/* --- Phase / Timeline Steps --- */
.phase-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.phase-item {
  padding: var(--space-5) var(--space-6);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  border-left: 3px solid var(--color-border);
  transition: all var(--transition-normal);
}
.phase-item:hover, .phase-item.highlighted {
  border-left-color: var(--color-blue);
  background: white;
  box-shadow: var(--shadow-sm);
}
.phase-item-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}
.phase-number {
  font-family: var(--font-heading);
  font-size: 0.75rem;
  font-weight: 800;
  color: var(--color-blue);
  background: rgba(29,106,235,0.1);
  padding: 0.15rem 0.5rem;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.phase-item h4 { font-size: 1rem; }
.phase-item p { font-size: 0.9rem; color: var(--color-text-mid); line-height: 1.6; }

/* Dark variant */
.phase-item-dark {
  background: rgba(255,255,255,0.04);
  border-left-color: rgba(255,255,255,0.1);
}
.phase-item-dark:hover, .phase-item-dark.highlighted {
  border-left-color: var(--color-cyan);
  background: rgba(255,255,255,0.07);
}
.phase-item-dark h4 { color: var(--color-white); }
.phase-item-dark p { color: var(--color-text-light); }

/* --- Compliance Badge Grid --- */
.compliance-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}
.compliance-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.5rem 1rem;
  background: rgba(29,106,235,0.08);
  border: 1px solid rgba(29,106,235,0.2);
  border-radius: var(--radius-full);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-blue);
}
.compliance-badge i { font-size: 0.875rem; }

/* --- "On dark" compliance badges --- */
.compliance-badge-dark {
  background: rgba(0,194,255,0.08);
  border-color: rgba(0,194,255,0.2);
  color: var(--color-cyan);
}

/* --- Values List --- */
.values-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.value-item {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  transition: background var(--transition-normal);
}
.value-item:hover { background: var(--color-white); box-shadow: var(--shadow-sm); }
.value-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: rgba(29,106,235,0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  color: var(--color-blue);
  flex-shrink: 0;
}
.value-content h4 { margin-bottom: var(--space-1); font-size: 1rem; }
.value-content p { font-size: 0.875rem; color: var(--color-text-mid); }

/* Dark variant */
.values-list-dark .value-item { background: rgba(255,255,255,0.05); }
.values-list-dark .value-item:hover { background: rgba(255,255,255,0.08); box-shadow: none; }
.values-list-dark .value-content h4 { color: var(--color-white); }
.values-list-dark .value-content p { color: var(--color-text-light); }
.values-list-dark .value-icon { background: rgba(0,194,255,0.1); color: var(--color-cyan); }

/* --- Mission / Vision Card --- */
.mission-card {
  background: var(--grad-card);
  border-radius: var(--radius-xl);
  padding: var(--space-10);
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.06);
}
.mission-card::before {
  content: '"';
  position: absolute;
  top: -20px;
  left: 20px;
  font-size: 10rem;
  font-family: var(--font-heading);
  font-weight: 800;
  color: rgba(29,106,235,0.1);
  line-height: 1;
}
.mission-card .eyebrow {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-cyan);
  margin-bottom: var(--space-4);
}
.mission-card p {
  font-size: 1.125rem;
  font-weight: 500;
  color: rgba(255,255,255,0.9);
  line-height: 1.7;
  position: relative;
}

/* --- Support Tier Cards --- */
.support-tier {
  padding: var(--space-8);
  border-radius: var(--radius-xl);
  text-align: center;
  border: 1px solid var(--color-border);
  background: var(--color-white);
  transition: all var(--transition-normal);
}
.support-tier:hover { border-color: rgba(29,106,235,0.3); box-shadow: var(--shadow-md); }
.support-tier.highlighted {
  background: var(--grad-card);
  border-color: rgba(0,194,255,0.3);
}
.support-tier.highlighted h3 { color: var(--color-white); }
.support-tier.highlighted p { color: var(--color-text-light); }
.support-tier.highlighted .support-sla { color: var(--color-cyan); }
.support-tier h3 { margin-bottom: var(--space-3); }
.support-tier p { font-size: 0.9375rem; color: var(--color-text-mid); margin-bottom: var(--space-4); }
.support-sla {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--color-blue);
  margin-bottom: var(--space-2);
}
.support-sla-label { font-size: 0.75rem; color: var(--color-text-mid); text-transform: uppercase; letter-spacing: 0.05em; }

/* --- Coming Soon / Placeholder --- */
.coming-soon-page {
  min-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--grad-hero);
  padding: var(--space-12);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.coming-soon-page::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(29,106,235,0.06) 1px, transparent 1px);
  background-size: 36px 36px;
}
.coming-soon-content {
  position: relative;
  z-index: 1;
  max-width: 560px;
}
.coming-soon-content h1 { color: var(--color-white); margin-bottom: var(--space-5); }
.coming-soon-content p { color: rgba(255,255,255,0.7); margin-bottom: var(--space-8); }

/* --- Legal Page --- */
.legal-content {
  max-width: 720px;
  margin-inline: auto;
  padding: var(--space-12) var(--space-8);
}
.legal-content h1 { margin-bottom: var(--space-3); }
.legal-content .last-updated {
  font-size: 0.875rem;
  color: var(--color-text-mid);
  margin-bottom: var(--space-10);
}
.legal-content h2 {
  font-size: 1.25rem;
  margin-top: var(--space-10);
  margin-bottom: var(--space-4);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border);
}
.legal-content h2:first-of-type { border-top: none; }
.legal-content p {
  color: var(--color-text-mid);
  margin-bottom: var(--space-4);
  line-height: 1.75;
}
.legal-content ul {
  list-style: disc;
  padding-left: var(--space-6);
  margin-bottom: var(--space-4);
}
.legal-content li {
  color: var(--color-text-mid);
  margin-bottom: var(--space-2);
  line-height: 1.7;
}
.legal-content a { color: var(--color-blue); }
.legal-content strong { color: var(--color-text-dark); }

/* --- Resource Hub Header --- */
.resource-hub {
  padding: var(--space-12) 0 0;
}
.resource-hub .page-header {
  margin-bottom: 0;
}

/* --- Industry Use Case Block --- */
.use-case-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-5);
}
.use-case-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  transition: all var(--transition-normal);
}
.use-case-card:hover {
  border-color: rgba(29,106,235,0.25);
  box-shadow: var(--shadow-sm);
}
.use-case-card .uc-icon {
  font-size: 1.75rem;
  margin-bottom: var(--space-3);
  color: var(--color-blue);
}
.use-case-card h4 { font-size: 1rem; margin-bottom: var(--space-2); }
.use-case-card p { font-size: 0.875rem; color: var(--color-text-mid); line-height: 1.6; }

/* Dark use case card */
.use-case-card-dark {
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.07);
}
.use-case-card-dark:hover {
  background: rgba(255,255,255,0.07);
  border-color: rgba(0,194,255,0.2);
}
.use-case-card-dark h4 { color: var(--color-white); }
.use-case-card-dark p { color: var(--color-text-light); }
.use-case-card-dark .uc-icon { color: var(--color-cyan); }

/* --- "How It Works" numbered section --- */
.how-it-works-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
  position: relative;
}
.how-it-works-grid::before {
  content: '';
  position: absolute;
  top: 36px;
  left: 10%;
  right: 10%;
  height: 2px;
  background: linear-gradient(to right, var(--color-blue), var(--color-cyan));
  opacity: 0.3;
}
.how-step {
  text-align: center;
  position: relative;
}
.how-step-number {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: var(--grad-card);
  border: 2px solid rgba(0,194,255,0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--color-white);
  margin: 0 auto var(--space-5);
  position: relative;
  z-index: 1;
  box-shadow: 0 0 20px rgba(29,106,235,0.2);
}
.how-step h4 {
  color: var(--color-white);
  margin-bottom: var(--space-2);
}
.how-step p {
  font-size: 0.875rem;
  color: var(--color-text-light);
  line-height: 1.65;
}
