﻿/* New Dawn Initiative */
:root {
  --color-bg: #f8f7f4;
  --color-surface: #ffffff;
  --color-text: #1c2429;
  --color-text-muted: #4a5560;
  --color-heading: #5a6d7d;
  --color-accent: #e8b923;
  --color-accent-dark: #c99a12;
  --color-teal: #1a9aaa;
  --color-teal-dark: #0d7a88;
  --color-green: #6aab5a;
  --color-border: #e2e0da;
  --color-hero-overlay: rgba(20, 32, 40, 0.72);
  --font-sans: "Source Sans 3", system-ui, -apple-system, sans-serif;
  --max-width: 44rem;
  --max-width-wide: 52rem;
  --header-height: 4.25rem;
  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 2.5rem;
  --space-xl: 4rem;
  --space-2xl: 5.5rem;
  --radius: 0.5rem;
  --shadow: 0 2px 12px rgba(28, 36, 41, 0.08);
}
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 1.0625rem;
  line-height: 1.65;
  color: var(--color-text);
  background: var(--color-bg);
}
img { max-width: 100%; height: auto; display: block; }
a {
  color: var(--color-teal-dark);
  text-decoration-thickness: 1px;
  text-underline-offset: 0.15em;
}
a:hover { color: var(--color-teal); }
a:focus-visible { outline: 2px solid var(--color-teal); outline-offset: 3px; }
.skip-link {
  position: absolute; top: -100%; left: var(--space-sm); z-index: 200;
  padding: var(--space-xs) var(--space-sm);
  background: var(--color-surface); color: var(--color-text);
  border-radius: var(--radius); font-weight: 600;
}
.skip-link:focus { top: var(--space-sm); }
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(248, 247, 244, 0.95);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--color-border);
}
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-sm); max-width: 72rem; margin: 0 auto;
  padding: var(--space-xs) var(--space-md); min-height: var(--header-height);
}
.brand {
  display: flex; align-items: center; gap: var(--space-sm);
  text-decoration: none; color: var(--color-heading);
  font-weight: 700; font-size: 1rem; letter-spacing: 0.02em;
}
.brand img { width: 3rem; height: 3rem; border-radius: 50%; object-fit: cover; }
.brand-text { display: none; }
@media (min-width: 480px) { .brand-text { display: inline; } }
.site-nav ul {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: 0.25rem 1.25rem;
}
.site-nav a {
  text-decoration: none; font-weight: 600; font-size: 0.9375rem; color: var(--color-heading);
}
.site-nav a:hover { color: var(--color-teal-dark); }
.nav-toggle {
  display: none; flex-direction: column; justify-content: center; gap: 5px;
  width: 2.5rem; height: 2.5rem; padding: 0; border: none;
  background: transparent; cursor: pointer; border-radius: var(--radius);
}
.nav-toggle-bar {
  display: block; width: 1.5rem; height: 2px;
  background: var(--color-heading); margin: 0 auto;
}

@media (max-width: 719px) {
  .nav-toggle { display: flex; }
  .site-nav {
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    box-shadow: var(--shadow);
    padding: var(--space-sm) var(--space-md);
    display: none;
  }
  .site-nav.is-open { display: block; }
  .site-nav ul { flex-direction: column; gap: var(--space-sm); }
  .nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }
  .nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(2) { opacity: 0; }
  .nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }
}
.hero {
  position: relative;
  min-height: clamp(22rem, 55vh, 32rem);
  display: flex;
  align-items: flex-start;
  color: #fff;
}
.hero-media {
  position: absolute; inset: 0;
  background: var(--color-hero-overlay)
    url("../assets/alexander-schimmeck-hmBz6fWZB7k-unsplash.jpg") center / cover no-repeat;
}
.hero-content {
  position: relative; width: 100%; max-width: 72rem; margin: 0 auto;
  padding: calc(var(--space-xl) + 2rem) var(--space-md) var(--space-lg);
}
.hero-eyebrow {
  margin: 0 0 var(--space-sm);
  font-size: 1.5rem; font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent);
}
.hero-title {
  margin: 0 0 var(--space-md);
  font-size: clamp(2.25rem, 6vw, 3.75rem);
  font-weight: 700; line-height: 1.1; letter-spacing: -0.02em;
}
.hero-title-line { display: block; }
.hero-title-accent { color: var(--color-accent); }
.hero-lead { max-width: var(--max-width); }
.hero .hero-lead.prose p {
  margin: 0;
  font-size: 1.125rem;
  line-height: 1.6;
  color: #fff;
}
.section { padding: var(--space-2xl) var(--space-md); }
.container { max-width: var(--max-width-wide); margin: 0 auto; }
.section-context {
  background: var(--color-surface); border-bottom: 1px solid var(--color-border);
}
.section-label {
  margin: 0 0 var(--space-md);
  font-size: 0.8125rem; font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-teal-dark);
}
.display-heading {
  margin: 0 0 var(--space-lg);
  font-size: clamp(2.5rem, 8vw, 4.5rem);
  font-weight: 700; line-height: 0.95; letter-spacing: -0.03em; color: var(--color-heading);
}
.display-heading span { display: block; }
.display-heading-sm {
  font-size: clamp(2rem, 6vw, 3.25rem); margin-bottom: var(--space-md);
}
.section-objectives { background: linear-gradient(180deg, var(--color-bg) 0%, #eef5f0 100%); }
.section-programs { background: var(--color-surface); }
.section-about { background: var(--color-bg); }
.section-contact {
  background: var(--color-heading); color: #fff;
  padding: var(--space-xl) var(--space-md);
}
.section-contact .section-label { color: var(--color-accent); }
.section-contact a { color: #fff; font-weight: 600; }
.prose p { margin: 0 0 var(--space-md); color: var(--color-text-muted); }
.prose p:last-child { margin-bottom: 0; }
.objectives-list {
  list-style: none; margin: var(--space-lg) 0; padding: 0;
  display: grid; gap: var(--space-md); counter-reset: objective;
}
.objectives-list li {
  background: var(--color-surface); border-radius: var(--radius);
  padding: var(--space-md) var(--space-md) var(--space-md) calc(var(--space-md) + 2.5rem);
  box-shadow: var(--shadow); border-left: 4px solid var(--color-green);
  position: relative; counter-increment: objective;
}
.objectives-list li::before {
  content: counter(objective);
  position: absolute; left: var(--space-md); top: var(--space-md);
  font-size: 1.5rem; font-weight: 700; color: var(--color-accent-dark); line-height: 1;
}
.objectives-list h3 { margin: 0 0 var(--space-xs); font-size: 1.125rem; color: var(--color-text); }
.objectives-list p { margin: 0; font-size: 0.9875rem; color: var(--color-text-muted); }
.program {
  margin-bottom: var(--space-xl); padding-bottom: var(--space-xl);
  border-bottom: 1px solid var(--color-border);
}
.program:last-of-type {
  border-bottom: none; padding-bottom: 0; margin-bottom: var(--space-lg);
}
.program-title {
  margin: 0 0 var(--space-md); font-size: 1.25rem; font-weight: 700;
  color: var(--color-teal-dark); line-height: 1.35;
}
.program-details { margin: var(--space-md) 0; }
.program-details > div {
  margin-bottom: var(--space-md); padding: var(--space-md);
  background: var(--color-bg); border-radius: var(--radius); border-left: 3px solid var(--color-teal);
}
.program-details dt { font-weight: 700; color: var(--color-text); margin-bottom: var(--space-xs); }
.program-details dd { margin: 0; color: var(--color-text-muted); font-size: 0.9875rem; }
.methodology {
  margin-top: var(--space-xl); padding: var(--space-lg);
  background: linear-gradient(135deg, #f5f0e6 0%, #e8f4f0 100%); border-radius: var(--radius);
}
.methodology-heading { margin: 0 0 var(--space-sm); font-size: 1.5rem; color: var(--color-heading); }
.methodology-intro { margin: 0 0 var(--space-md); color: var(--color-text-muted); }
.methodology-list {
  margin: 0; padding: 0; list-style: none; display: grid; gap: var(--space-md);
}
.methodology-list li {
  padding-left: var(--space-md); border-left: 3px solid var(--color-accent);
  color: var(--color-text-muted); font-size: 0.9875rem;
}
.methodology-list strong { display: block; color: var(--color-text); margin-bottom: 0.35rem; }
.about-grid { display: grid; gap: var(--space-lg); align-items: center; }
@media (min-width: 720px) {
  .about-grid {
    grid-template-columns: minmax(12rem, 16rem) 1fr; gap: var(--space-xl);
  }
}
.about-logo-wrap { justify-self: center; }
.about-logo { width: min(280px, 100%); border-radius: 50%; box-shadow: var(--shadow); }
.contact-block { font-style: normal; font-size: 1.125rem; line-height: 1.8; }
.contact-block strong { display: block; margin-bottom: var(--space-xs); font-size: 1.25rem; }
.site-footer {
  padding: var(--space-md); text-align: center;
  font-size: 0.875rem; color: var(--color-text-muted);
  border-top: 1px solid var(--color-border);
}
.site-footer p { margin: 0; }
.site-footer .container { max-width: 72rem; }
