/* ============================================================
   UMANAH INSTITUTE — Applied Engineering Page Styles
   Based on aeg-main structure, reskinned in site token system.
   Light mode, navy accents, no cyan/dark backgrounds.
   Import after tokens.css and base.css.
   ============================================================ */

/* ── Hero ─────────────────────────────────────────────────── */
#ae-hero {
  position: relative;
  min-height: clamp(520px, 65vh, 800px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: clamp(var(--sp-9), 8vh, 120px) 0 var(--sp-8);
  text-align: center;
  overflow: hidden;
  background-color: var(--bg-base);
  border-bottom: 1px solid var(--border);
}

/* Subtle structural grid — replaces AEG animated glows */
.ae-hero-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(11, 31, 59, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(11, 31, 59, 0.035) 1px, transparent 1px);
  background-size: 64px 64px;
  pointer-events: none;
}

.ae-hero-content {
  position: relative;
  z-index: 1;
  max-width: 780px;
  padding: 0 var(--pad-desktop);
}

.ae-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--navy);
  background: var(--navy-tint);
  border: 1px solid var(--border-navy);
  border-radius: 100px;
  padding: 6px 16px;
  margin-bottom: var(--sp-5);
}

.ae-hero-title {
  font-size: clamp(2.4rem, 6vw, 3.8rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  margin-bottom: var(--sp-2);
}

.ae-hero-tagline {
  font-family: var(--font-heading);
  font-size: clamp(1rem, 2vw, 1.2rem);
  font-weight: 400;
  font-style: italic;
  color: var(--text-muted);
  margin-bottom: var(--sp-4);
}

.ae-hero-desc {
  font-size: 1rem;
  color: var(--text-secondary);
  line-height: 1.7;
  max-width: 60ch;
  margin: 0 auto var(--sp-6);
}

.ae-hero-actions {
  display: flex;
  gap: var(--sp-3);
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: var(--sp-7);
}

/* Stat row below hero */
.ae-hero-stats {
  position: relative;
  z-index: 1;
  display: flex;
  gap: var(--sp-6);
  flex-wrap: wrap;
  justify-content: center;
  padding: var(--sp-5) var(--pad-desktop);
  border-top: 1px solid var(--border);
  width: 100%;
  background-color: var(--bg-surface);
}

.ae-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
}

.ae-stat-icon {
  width: 48px;
  height: 48px;
  background: var(--navy-tint);
  border: 1px solid var(--border);
  border-radius: var(--card-radius);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--navy);
  transition: background 0.2s, border-color 0.2s;
}
.ae-stat:hover .ae-stat-icon {
  background: var(--navy-tint);
  border-color: var(--navy);
}

.ae-stat-label {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* ── Section Dark: navy-tinted bg for technical feel ─────── */
.section-tinted {
  background-color: #F0F2F7; /* very subtle blue-grey, same family */
}

/* ── Core Framing (Mission) ───────────────────────────────── */
.ae-mission-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-10);
  align-items: start;
}

.ae-mission-statement h2 {
  margin-bottom: var(--sp-4);
}

.ae-mission-lead {
  font-size: 1.05rem;
  color: var(--text-secondary);
  line-height: 1.75;
  margin-bottom: var(--sp-3);
}

.ae-mission-statement p:not(.ae-mission-lead) {
  color: var(--text-muted);
  font-size: 0.95rem;
  line-height: 1.7;
}

.ae-pillars {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.ae-pillar {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  padding: var(--sp-4);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--card-radius);
  transition: border-color 0.2s, transform 0.2s;
}
.ae-pillar:hover {
  border-color: var(--navy);
  transform: translateX(4px);
}

.ae-pillar-header {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}

.ae-pillar-icon {
  width: 40px;
  height: 40px;
  flex-shrink: 0;
  background: var(--navy-tint);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--navy);
}

.ae-pillar h3 {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-primary);
  font-family: var(--font-body);
}
.ae-pillar p {
  font-size: 0.875rem;
  color: var(--text-muted);
  line-height: 1.6;
  padding-left: calc(40px + var(--sp-3));
  max-width: 100%;
}

/* ── What We Do ───────────────────────────────────────────── */
.ae-eval-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
}

.ae-eval-card {
  padding: var(--sp-5) var(--sp-4);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--card-radius);
  text-align: center;
  transition: border-color 0.2s, transform 0.2s;
}
.ae-eval-card:hover {
  border-color: var(--navy);
  transform: translateY(-4px);
}

.ae-eval-icon {
  width: 52px;
  height: 52px;
  background: var(--navy-tint);
  border-radius: var(--card-radius);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--navy);
  margin: 0 auto var(--sp-3);
}

.ae-eval-card h3 {
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--sp-2);
}
.ae-eval-card p {
  font-size: 0.85rem;
  color: var(--text-muted);
  line-height: 1.6;
  max-width: 100%;
}

.ae-report-callout {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--sp-3);
  padding: var(--sp-5) var(--sp-6);
  background: var(--navy-tint);
  border: 1px solid var(--border-navy);
  border-radius: var(--card-radius);
  font-size: 0.95rem;
  color: var(--text-secondary);
}
.ae-report-callout-icon {
  width: 44px;
  height: 44px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--navy);
  flex-shrink: 0;
}
.ae-report-callout strong {
  color: var(--text-primary);
}

/* ── Approach / Steps ─────────────────────────────────────── */
.ae-steps {
  display: flex;
  align-items: flex-start;
  gap: 0;
  flex-wrap: wrap;
  justify-content: center;
}

.ae-step {
  flex: 1;
  min-width: 200px;
  max-width: 240px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.ae-step-number {
  font-family: var(--font-body);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--border);
  line-height: 1;
  margin-bottom: var(--sp-2);
  text-align: center;
  width: 100%;
  transition: color 0.2s;
}

.ae-step-content {
  padding: var(--sp-4);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--card-radius);
  text-align: center;
  width: 100%;
  transition: border-color 0.2s;
}
.ae-step:hover .ae-step-content {
  border-color: var(--navy);
}
.ae-step:hover .ae-step-number {
  color: var(--navy);
}

.ae-step-icon {
  width: 48px;
  height: 48px;
  background: var(--navy-tint);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--navy);
  margin: 0 auto var(--sp-3);
}

.ae-step-content h3 {
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--sp-2);
}
.ae-step-content p {
  font-size: 0.83rem;
  color: var(--text-muted);
  line-height: 1.6;
  max-width: 100%;
}

.ae-step-connector {
  flex-shrink: 0;
  color: var(--border);
  font-size: 1.2rem;
  padding: 0 8px;
  margin-top: 48px;
  font-weight: 300;
}

/* ── Current Status ───────────────────────────────────────── */
.ae-status-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--sp-10);
  align-items: start;
}

.ae-status-lead {
  font-size: 1.05rem;
  color: var(--text-secondary);
  margin-bottom: var(--sp-3);
  line-height: 1.7;
}

.ae-status-grid p:not(.ae-status-lead) {
  color: var(--text-muted);
  margin-bottom: var(--sp-3);
  font-size: 0.95rem;
  line-height: 1.65;
  max-width: 52ch;
}

.ae-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: var(--sp-4);
  padding: 10px 18px;
  background: var(--navy-tint);
  border: 1px solid var(--border-navy);
  border-radius: 100px;
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--navy);
}

.ae-badge-dot {
  width: 8px;
  height: 8px;
  background: #16a34a;
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.2);
  animation: ae-pulse 2s infinite;
}
@keyframes ae-pulse {
  0%, 100% { box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.2); }
  50%       { box-shadow: 0 0 0 6px rgba(22, 163, 74, 0.1); }
}

.ae-status-tracks {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

.ae-status-tracks h3 {
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--sp-2);
}

.ae-track {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ae-track-header {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-secondary);
}

.ae-track-bar {
  height: 6px;
  background: var(--border);
  border-radius: 100px;
  overflow: hidden;
}

.track-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--navy-mid), var(--navy));
  border-radius: 100px;
  width: 0%;
  transition: width 1.4s ease;
}

.ae-track-phase {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--navy);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* ── Accountability & Transparency ────────────────────────── */
.ae-gov-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-4);
  margin-top: var(--sp-2);
}

.ae-gov-card {
  padding: var(--sp-5) var(--sp-4);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--card-radius);
  transition: border-color 0.2s, transform 0.2s;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  box-shadow: var(--card-shadow);
}
.ae-gov-card:hover {
  border-color: var(--navy);
  transform: translateY(-4px);
}

.ae-gov-icon {
  width: 52px;
  height: 52px;
  background: var(--navy-tint);
  border-radius: var(--card-radius);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--navy);
  margin: 0 auto var(--sp-3);
}

.ae-gov-card h3 {
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--sp-2);
}
.ae-gov-card p {
  font-size: 0.875rem;
  color: var(--text-muted);
  line-height: 1.6;
  max-width: 100%;
}

/* ── Applied Engineering Inquiry Block ────────────────────── */
.ae-inquiry-section {
  background-color: var(--navy);
}

.ae-inquiry-block {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--sp-8);
  align-items: center;
}

.ae-inquiry-text .section-label {
  color: rgba(255,255,255,0.65);
}

.ae-inquiry-text h2 {
  color: #ffffff;
  margin-bottom: var(--sp-3);
}

.ae-inquiry-text p {
  color: rgba(255,255,255,0.75);
  font-size: 0.95rem;
  line-height: 1.7;
  max-width: 54ch;
}

.btn-white {
  background-color: #ffffff;
  color: var(--navy);
  border-color: #ffffff;
  font-weight: 600;
  white-space: nowrap;
}
.btn-white:hover {
  background-color: var(--navy-tint);
  border-color: var(--navy-tint);
  color: var(--navy-hover);
}

/* ── Contact ──────────────────────────────────────────────── */
.ae-contact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-3);
}

.ae-contact-card {
  padding: var(--sp-4);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--card-radius);
  text-align: center;
  box-shadow: var(--card-shadow);
}

.ae-contact-icon {
  width: 44px;
  height: 44px;
  background: var(--navy-tint);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--navy);
  margin: 0 auto var(--sp-3);
}

.ae-contact-card h3 {
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--sp-2);
}
.ae-contact-card p,
.ae-contact-card a {
  font-size: 0.875rem;
  color: var(--text-muted);
  line-height: 1.6;
  max-width: 100%;
}
.ae-contact-card a:hover {
  color: var(--navy);
}

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 1024px) {
  .ae-eval-grid {
    grid-template-columns: 1fr 1fr;
  }
  .ae-mission-grid,
  .ae-status-grid {
    grid-template-columns: 1fr;
    gap: var(--sp-7);
  }
  .ae-inquiry-block {
    grid-template-columns: 1fr;
    gap: var(--sp-5);
    text-align: center;
  }
  .ae-inquiry-text p {
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }
}

@media (max-width: 768px) {
  #ae-hero {
    min-height: auto;
    padding-top: var(--sp-9);
    padding-bottom: var(--sp-5);
  }
  .ae-hero-content {
    padding: 0 var(--pad-mobile);
  }
  .ae-hero-stats {
    padding: var(--sp-5) var(--pad-mobile);
    gap: var(--sp-4);
  }
  .ae-eval-grid {
    grid-template-columns: 1fr;
  }
  .ae-steps {
    flex-direction: column;
    align-items: center;
  }
  .ae-step {
    min-width: 100%;
    max-width: 100%;
  }
  .ae-step-connector {
    transform: rotate(90deg);
    margin: 0;
    padding: var(--sp-2) 0;
  }
  .ae-gov-grid {
    grid-template-columns: 1fr;
  }
  .ae-contact-grid {
    grid-template-columns: 1fr;
  }
  .ae-report-callout {
    flex-direction: column;
    text-align: center;
  }
  .ae-pillar p {
    padding-left: 0;
    text-align: center;
  }
  .ae-status-grid p:not(.ae-status-lead) {
    max-width: 100%;
  }
}
