@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

/* ── Variables ─────────────────────────────────────────── */
:root {
  --bg: #F8F9FA;
  --black: #111111;
  --cyan: #00B4D8;
  --cyan-dark: #009BBB;
  --white: #FFFFFF;
  --gray-100: #F1F3F5;
  --gray-200: #e2e8f0;
  --gray-400: #ADB5BD;
  --gray-600: #6C757D;
  --nav-bg: #FFFFFF;

  --font: 'Plus Jakarta Sans', sans-serif;

  --space-xs:  0.5rem;
  --space-sm:  1rem;
  --space-md:  1.5rem;
  --space-lg:  2.5rem;
  --space-xl:  4rem;
  --space-2xl: 6rem;
  --space-3xl: 8rem;

  --r-sm: 6px;
  --r-md: 14px;
  --r-lg: 22px;

  --shadow-sm: 0 2px 8px rgba(0,0,0,.06);
  --shadow-md: 0 6px 24px rgba(0,0,0,.09);
  --shadow-lg: 0 12px 48px rgba(0,0,0,.14);

  --nav-h: 80px;
  --ease: 0.22s ease;
}

/* ── Reset ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--black);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font-family: var(--font); }

/* ── Typography ────────────────────────────────────────── */
h1 {
  font-size: clamp(2.25rem, 5vw, 3.5rem);
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: -.03em;
}
h2 {
  font-size: clamp(1.75rem, 3.5vw, 2.625rem);
  font-weight: 800;
  line-height: 1.18;
  letter-spacing: -.025em;
}
h3 { font-size: 1.25rem; font-weight: 700; line-height: 1.3; }
h4 { font-size: 1rem;    font-weight: 700; }
p  { color: var(--gray-600); font-size: 1.0625rem; line-height: 1.78; }

.label {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--cyan);
}

/* ── Layout ─────────────────────────────────────────────── */
.container {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 var(--space-md);
}

.section        { padding: var(--space-3xl) 0; }
.section--sm    { padding: var(--space-xl) 0; }
.section--tight { padding: var(--space-2xl) 0; }

.section--dark {
  background: var(--black);
  color: var(--white);
}
.section--dark h1,
.section--dark h2,
.section--dark h3,
.section--dark h4 { color: var(--white); }
.section--dark p   { color: rgba(255,255,255,.65); }

.section__label   { display: block; margin-bottom: var(--space-xs); }
.section__heading { margin-bottom: var(--space-md); }
.section__intro   { max-width: 600px; font-size: 1.125rem; margin-bottom: var(--space-xl); }
.section__header  { text-align: center; margin-bottom: var(--space-xl); }
.section__header h2 { margin-top: .5rem; }

.section--center { text-align: center; }
.section--center .section__intro { margin-left: auto; margin-right: auto; }

/* ── Grid ─────────────────────────────────────────────── */
.grid   { display: grid; gap: var(--space-md); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

/* ── Nav ──────────────────────────────────────────────── */
.nav {
  position: sticky;
  top: 0;
  z-index: 200;
  background: var(--nav-bg);
  height: var(--nav-h);
  border-bottom: 3px solid #00B4D8;
  transition: box-shadow var(--ease);
}
.nav--scrolled {
  border-bottom-color: transparent;
  box-shadow: 0 2px 20px rgba(0,0,0,.10);
}
.nav__container {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 var(--space-md);
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.nav__logo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 .5rem 0 var(--space-sm);
  text-decoration: none;
}
.nav__logo img {
  height: 44px;
  width: auto;
  display: block;
}
.nav__wordmark {
  font-size: 0.95rem;
  font-weight: 700;
  color: #111111;
  white-space: nowrap;
  line-height: 1.2;
  display: flex;
  flex-direction: row;
  align-items: center;
  align-self: center;
  letter-spacing: -0.01em;
}
.nav__wordmark-line {
  display: flex;
  gap: 0.35em;
}
.nav__wordmark-accent {
  color: var(--cyan);
}
.nav__wordmark-edu {
  font-size: 0.62em;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #334155;
  margin-left: 8px;
}
.nav__links {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}
.nav__links a {
  color: #111111;
  font-size: .9375rem;
  font-weight: 500;
  transition: color var(--ease);
}
.nav__links a:hover { color: var(--cyan); }
.nav__links a.active:not(.btn) { color: var(--cyan); }
.nav__links a.btn { color: inherit; }
.nav__links .nav__cta { margin-left: .5rem; }

.nav__links li:not(.nav__cta) a {
  padding: 6px 14px;
  border-radius: 20px;
  border: 1px solid transparent;
  transition: border-color 0.2s ease, color 0.2s ease;
}
.nav__links li:not(.nav__cta) a:hover {
  border-color: #00B4D8;
  color: #00B4D8;
}

/* Nav CTA contact button */
.nav__cta .btn {
  background: #00B4D8;
  color: #ffffff;
  border-color: #00B4D8;
  padding: 10px 24px;
  font-weight: 600;
  border-radius: 6px;
}
.nav__cta .btn:hover {
  background: #0099bb;
  border-color: #0099bb;
  box-shadow: none;
  transform: none;
}

.nav__toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
}
.nav__toggle span {
  display: block;
  width: 24px; height: 2px;
  background: var(--black);
  border-radius: 2px;
  transition: var(--ease);
}

/* ── Buttons ──────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .8125rem 1.875rem;
  border-radius: 6px;
  font-family: var(--font);
  font-size: .9375rem;
  font-weight: 700;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all var(--ease);
  white-space: nowrap;
  letter-spacing: -.01em;
}
.btn--lg  { padding: 1.0625rem 2.5rem; font-size: 1rem; }
.btn--sm  { padding: .5625rem 1.25rem; font-size: .875rem; }

.btn--primary {
  background: var(--cyan);
  color: var(--white);
  border-color: var(--cyan);
}
.btn--primary:hover {
  background: var(--cyan-dark);
  border-color: var(--cyan-dark);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(0,180,216,.35);
}

/* Outlined dark — nav Contact, pricing cards */
.btn--secondary {
  background: transparent;
  color: #111111;
  border-color: #111111;
}
.btn--secondary:hover {
  background: #111111;
  color: var(--white);
  border-color: #111111;
  transform: translateY(-1px);
}

/* Outlined cyan — tool "Try It Free" buttons */
.btn--outline-cyan {
  background: transparent;
  color: var(--cyan);
  border-color: var(--cyan);
}
.btn--outline-cyan:hover {
  background: var(--cyan);
  color: var(--white);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(0,180,216,.35);
}

/* Dark filled — path card buttons, CTA "Book" buttons */
.btn--dark {
  background: #111111;
  color: var(--white);
  border-color: #111111;
}
.btn--dark:hover {
  background: #222222;
  border-color: #222222;
  transform: translateY(-1px);
}

.btn--outline-white {
  background: transparent;
  color: var(--white);
  border-color: rgba(255,255,255,.5);
}
.btn--outline-white:hover {
  background: var(--white);
  color: var(--black);
  border-color: var(--white);
  transform: translateY(-1px);
}

/* ── Cards ────────────────────────────────────────────── */
.card {
  background: var(--white);
  border-radius: var(--r-md);
  padding: var(--space-lg);
  border: 1.5px solid #e2e8f0;
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
  transition: all .2s ease;
  position: relative;
  overflow: hidden;
}
.card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: transparent;
  transition: background var(--ease);
}
.card:hover { box-shadow: 0 8px 32px rgba(0,180,216,.12); transform: translateY(-2px); }
.card:hover::before { background: var(--cyan); }

.card__icon {
  width: 50px; height: 50px;
  background: rgba(0,180,216,.1);
  border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: var(--space-md);
  color: var(--cyan);
}

/* ── Link Arrow ───────────────────────────────────────── */
.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-weight: 700;
  color: var(--black);
  font-size: .9375rem;
  transition: gap var(--ease), color var(--ease);
}
.link-arrow::after { content: '→'; }
.link-arrow:hover  { gap: .75rem; color: var(--cyan); }

.link-arrow--white { color: var(--white); }
.link-arrow--white:hover { color: rgba(255,255,255,.75); }

.link-arrow--cyan { color: var(--cyan); font-weight: 600; }
.link-arrow--cyan:hover { color: var(--cyan-dark); text-decoration: underline; gap: .75rem; }

/* ── Home Hero ────────────────────────────────────────── */
.home-hero {
  background: #E8F8FC;
  min-height: unset;
  padding-top: 16px;
  padding-bottom: 24px;
  text-align: center;
  border-bottom: 2px solid rgba(0,180,216,.3);
  box-shadow: inset 0 -12px 40px rgba(0,180,216,.18);
}
.home-hero__logo {
  width: 100%;
  max-width: 280px;
  margin: 0 auto;
  display: block;
}
.home-hero__logo img {
  width: 100%;
  height: auto;
  display: block;
}
.home-hero__headline {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  color: #111111;
  line-height: 1.2;
  letter-spacing: -0.02em;
  margin: 12px auto 8px;
  text-align: center;
  max-width: 720px;
}
.home-hero__tagline {
  font-size: 1.0625rem;
  font-weight: 400;
  color: #6c757d;
  letter-spacing: 0.01em;
  text-shadow: none;
  margin: 0 0 24px;
  text-align: center;
}

/* ── Path Cards ───────────────────────────────────────── */
.path-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
  margin-top: 24px;
}
.path-card {
  background: var(--white);
  border-radius: 12px;
  padding: var(--space-lg);
  text-align: center;
  border: 1.5px solid #e2e8f0;
  box-shadow: 0 2px 12px rgba(0,0,0,.07);
  transition: all .2s ease;
  position: relative;
  overflow: hidden;
}
.path-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--cyan);
}
.path-card:hover { box-shadow: 0 8px 32px rgba(0,180,216,.15); transform: translateY(-2px); }

.path-card__icon   {
  margin: 0 auto var(--space-sm);
  width: 48px; height: 48px;
  background: rgba(0,180,216,.08);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: var(--cyan);
}
.path-card__who    { display: block; font-size: .75rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--cyan); margin-bottom: .5rem; }
.path-card h3      { font-size: 1.25rem; margin-bottom: .625rem; }
.path-card p       { font-size: .9375rem; margin-bottom: var(--space-md); }

/* ── About Split ──────────────────────────────────────── */
.about-split {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: var(--space-3xl);
  align-items: center;
}
.about-split__img {
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  height: 420px;
}
.about-split__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 20%;
}
.about-split__content .label { margin-bottom: var(--space-xs); }
.about-split__content h2     { margin-bottom: var(--space-md); }
.about-split__content p      { margin-bottom: var(--space-lg); }

/* ── Offer Columns ────────────────────────────────────── */
.offer-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1.5px solid #e2e8f0;
  box-shadow: var(--shadow-md);
}
.offer-col {
  padding: var(--space-xl);
  background: var(--white);
  border-left: 4px solid #111111;
}
.offer-col--alt {
  border-left-color: var(--cyan);
}
.offer-col .label { display: block; margin-bottom: var(--space-sm); }
.offer-col h3     { font-size: 1.875rem; margin-bottom: var(--space-sm); }
.offer-col > p    { margin-bottom: var(--space-lg); }

.offer-list li {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  padding: .6875rem 0;
  border-bottom: 1px solid #e2e8f0;
  font-size: .9375rem;
  color: var(--gray-600);
}
.offer-list li:last-child { border-bottom: none; }
.offer-list li::before {
  content: '✓';
  color: var(--cyan);
  font-weight: 800;
  flex-shrink: 0;
  margin-top: .125rem;
}

/* ── Tool Preview Cards ───────────────────────────────── */
.tool-preview {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
}

/* ── Page Hero (inner pages) ──────────────────────────── */
.page-hero {
  background: #E8F8FC;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 60px 0;
  color: #111111;
  border-bottom: 2px solid rgba(0,180,216,.3);
  box-shadow: inset 0 -12px 40px rgba(0,180,216,.18);
}
.page-hero .label  { display: block; margin-bottom: .875rem; }
.page-hero h1      { color: #111111; margin-bottom: 1.25rem; }
.page-hero p       { color: var(--gray-600); max-width: 600px; font-size: 1.125rem; }

/* ── About Hero ───────────────────────────────────────── */
.about-hero {
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: var(--space-3xl);
  align-items: center;
  padding: var(--space-3xl) 0;
}
.about-hero__photo {
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.about-hero__photo img {
  width: 100%; height: 540px;
  object-fit: cover;
  object-position: center top;
}
.about-hero__placeholder {
  width: 100%; height: 540px;
  display: flex; align-items: center; justify-content: center;
  background: #E8F8FC;
  color: var(--cyan);
  font-size: 6rem; font-weight: 800; letter-spacing: 0.04em;
}
.about-hero__content .label { display: block; margin-bottom: var(--space-sm); }
.about-hero__content h1,
.about-hero__content h2     { margin-bottom: var(--space-md); }
.about-hero__content p      { margin-bottom: var(--space-md); font-size: 1.0625rem; }

/* ── Credentials ──────────────────────────────────────── */
.credential-card {
  background: var(--white);
  border-radius: 10px;
  padding: var(--space-lg);
  border: 1.5px solid #e2e8f0;
  border-left: 4px solid var(--cyan);
  box-shadow: var(--shadow-sm);
  transition: all .2s ease;
}
.credential-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.credential-card__icon   { margin-bottom: var(--space-sm); color: var(--cyan); display: flex; }
.credential-card h4      { font-size: 1.0625rem; margin-bottom: .375rem; }
.credential-card p       { font-size: .9375rem; }

/* ── Pricing ──────────────────────────────────────────── */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--space-md);
}
.pricing-grid .pricing-card {
  grid-column: span 2;
}
.pricing-card {
  background: var(--white);
  border-radius: var(--r-md);
  padding: var(--space-lg);
  border: 1.5px solid #e2e8f0;
  box-shadow: 0 4px 20px rgba(0,0,0,.08);
  display: flex;
  flex-direction: column;
  transition: all .2s ease;
  position: relative;
  overflow: hidden;
}
.pricing-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: var(--cyan);
}
.pricing-card--featured { box-shadow: 0 6px 24px rgba(0,0,0,.1); }
.pricing-card:hover { box-shadow: 0 8px 32px rgba(0,180,216,.15); transform: translateY(-2px); }

.pricing-card__tier  { font-size: .75rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--cyan); margin-bottom: .5rem; }
.pricing-card__price { font-size: 2.375rem; font-weight: 800; color: var(--cyan); line-height: 1; margin-bottom: .25rem; letter-spacing: -.03em; }
.pricing-card__price sub { font-size: 1rem; font-weight: 500; color: var(--gray-600); vertical-align: baseline; }
.pricing-card__desc  { font-size: .9375rem; color: var(--gray-600); margin: var(--space-sm) 0 var(--space-md); padding-bottom: var(--space-md); border-bottom: 1px solid #e2e8f0; line-height: 1.6; flex-shrink: 0; }
.pricing-card__features { flex: 1; margin-bottom: var(--space-md); }
.pricing-card__features li {
  display: flex; align-items: flex-start; gap: .625rem;
  padding: .4375rem 0;
  font-size: .9375rem; color: var(--gray-600);
}
.pricing-card__features li::before { content: '✓'; color: var(--cyan); font-weight: 800; flex-shrink: 0; margin-top: .1rem; }

/* ── FAQ ─────────────────────────────────────────────── */
.faq { max-width: 740px; margin: 0 auto; }
.faq__item {
  border-bottom: 1px solid #e2e8f0;
  padding: var(--space-md) 0;
}
.faq__question {
  font-size: 1.0625rem;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-md);
  color: var(--black);
  list-style: none;
  -webkit-tap-highlight-color: transparent;
}
.faq__question::-webkit-details-marker { display: none; }
.faq__question::after { content: '+'; font-size: 1.75rem; font-weight: 300; color: var(--cyan); flex-shrink: 0; line-height: 1.1; }
details[open] .faq__question::after { content: '–'; }
.faq__answer { margin-top: .875rem; font-size: .9375rem; color: var(--gray-600); line-height: 1.78; }

/* ── Forms ───────────────────────────────────────────── */
.form-block { max-width: 620px; }
.form-block--wide { max-width: 100%; }

.form-group { margin-bottom: var(--space-md); }
.form-row   { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); }

.form-label {
  display: block;
  font-size: .875rem;
  font-weight: 600;
  margin-bottom: .4375rem;
  color: var(--black);
}
.form-input,
.form-select,
.form-textarea {
  width: 100%;
  padding: .9375rem 1.0625rem;
  border: 1.5px solid #e2e8f0;
  border-radius: var(--r-sm);
  font-family: var(--font);
  font-size: .9375rem;
  color: var(--black);
  background: var(--white);
  transition: border-color var(--ease), box-shadow var(--ease);
  -webkit-appearance: none;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--cyan);
  box-shadow: 0 0 0 3px rgba(0,180,216,.12);
}
.form-textarea { min-height: 150px; resize: vertical; }
.form-select {
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236C757D' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.75rem;
}

/* ── Resource Grid ───────────────────────────────────── */
.resource-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
}
.resource-card {
  background: var(--white);
  border-radius: var(--r-md);
  padding: var(--space-lg);
  border: 1.5px solid #e2e8f0;
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
  display: flex;
  flex-direction: column;
  transition: all .2s ease;
  position: relative;
  overflow: hidden;
}
.resource-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; bottom: 0;
  width: 4px;
  background: var(--cyan);
}
.resource-card:hover { box-shadow: 0 8px 32px rgba(0,180,216,.12); transform: translateY(-2px); }
.resource-card--disabled { opacity: .55; pointer-events: none; }

.badge--free,
.badge--available,
.badge--paid,
.badge--soon {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: var(--space-sm);
  width: fit-content;
}
.badge--free      { background: var(--cyan); color: #fff; }
.badge--available { background: #111111; color: #fff; }
.badge--paid      { background: rgba(17,17,17,.08); color: var(--black); }
.badge--soon      { background: #e2e8f0; color: var(--gray-600); }

.resource-card h3 { font-size: 1.0625rem; margin-bottom: .5rem; }
.resource-card p  { font-size: .9375rem; flex: 1; margin-bottom: var(--space-md); }

/* ── Tool Cards ──────────────────────────────────────── */
.tools-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-md);
}
.tool-card {
  background: var(--white);
  border-radius: var(--r-md);
  padding: var(--space-lg);
  border: 1.5px solid #e2e8f0;
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
  display: flex;
  flex-direction: column;
  transition: all .2s ease;
  position: relative;
  overflow: hidden;
}
.tool-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; bottom: 0;
  width: 4px;
  background: var(--cyan);
}
.tool-card:hover { box-shadow: 0 8px 32px rgba(0,180,216,.12); transform: translateY(-2px); }

.tool-card__icon     { margin-bottom: var(--space-sm); color: var(--cyan); display: flex; }
.tool-card__audience { font-size: .7rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--cyan); margin-bottom: .5rem; }
.tool-card h3        { font-size: 1.1875rem; margin-bottom: .625rem; }
.tool-card p         { font-size: .9375rem; flex: 1; margin-bottom: var(--space-md); }

/* ── Districts ───────────────────────────────────────── */
.offering-card {
  background: var(--white);
  border-radius: var(--r-md);
  padding: var(--space-lg);
  border: 1.5px solid #e2e8f0;
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
  transition: all .2s ease;
}
.offering-card:hover { box-shadow: 0 8px 32px rgba(0,180,216,.12); transform: translateY(-2px); }
.offering-card__icon  { margin-bottom: var(--space-sm); color: var(--cyan); display: flex; }
.offering-card h3     { margin-bottom: .5rem; }
.offering-card p      { font-size: .9375rem; }

/* ── CTA Banner ──────────────────────────────────────── */
.cta-banner {
  background: #E8F8FC;
  padding: var(--space-3xl) 0;
  text-align: center;
  color: var(--black);
}
.cta-banner h2      { color: var(--black); margin-bottom: var(--space-sm); }
.cta-banner p       { color: var(--gray-600); max-width: 500px; margin: 0 auto var(--space-xl); }
.cta-banner__btns   { display: flex; gap: var(--space-sm); justify-content: center; flex-wrap: wrap; }

/* ── Contact ─────────────────────────────────────────── */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: var(--space-3xl);
  align-items: start;
}
.contact-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}
.contact-item__icon {
  width: 46px; height: 46px;
  background: rgba(0,180,216,.1);
  border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  color: var(--cyan);
  flex-shrink: 0;
}
.contact-item__label { font-size: .75rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--gray-600); margin-bottom: .25rem; }
.contact-item__value { font-size: 1rem; font-weight: 600; color: var(--black); }

/* ── Social Links ────────────────────────────────────── */
.social-links {
  display: flex;
  gap: .75rem;
  align-items: center;
}
.social-link {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: #e2e8f0;
  display: flex; align-items: center; justify-content: center;
  color: #334155;
  transition: all var(--ease);
}
.social-link:hover { background: #0ea5e9; color: var(--white); transform: scale(1.05); }
.social-link svg   { width: 17px; height: 17px; }

.social-links--dark .social-link {
  background: var(--gray-100);
  color: var(--gray-600);
}
.social-links--dark .social-link:hover {
  background: var(--cyan);
  color: var(--white);
}

/* ── Footer ──────────────────────────────────────────── */
.footer {
  background: #f1f5f9;
  padding: 64px 0 32px;
  color: #334155;
  border-top: 3px solid rgb(0, 180, 216);
}
.footer__top {
  display: grid;
  grid-template-columns: 1.1fr 1.5fr 1fr;
  gap: var(--space-xl);
  padding-bottom: 32px;
  border-bottom: 1px solid #e2e8f0;
  margin-bottom: 24px;
  align-items: start;
}
.footer__logo      { display: flex; align-items: center; gap: 10px; margin-bottom: var(--space-md); text-decoration: none; }
.footer__logo img  { height: 48px; width: auto; display: block; }
.footer__tagline   { font-size: .9375rem; color: #64748b; line-height: 1.65; max-width: 260px; }
.footer__contact   { display: inline-block; margin-top: var(--space-sm); font-size: .9375rem; color: #334155; transition: color var(--ease); }
.footer__contact:hover { color: #0ea5e9; }

.footer__col-label { font-size: .6875rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: #94a3b8; margin-bottom: var(--space-sm); }

.footer__nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .5rem var(--space-lg);
}
.footer__nav a {
  font-size: .9375rem;
  color: #334155;
  transition: color var(--ease);
}
.footer__nav a:hover { color: #0ea5e9; }

.footer__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-sm);
}
.footer__legal {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  font-size: .875rem;
  color: #94a3b8;
}
.footer__legal a { color: #94a3b8; transition: color var(--ease); }
.footer__legal a:hover { color: #0ea5e9; }

/* ── Divider ─────────────────────────────────────────── */
.divider {
  width: 56px; height: 4px;
  background: var(--cyan);
  border-radius: 2px;
  margin-bottom: var(--space-md);
}

/* ── Prose (privacy/terms) ───────────────────────────── */
.prose h2      { font-size: 1.5rem; margin: var(--space-xl) 0 var(--space-sm); }
.prose h3      { font-size: 1.125rem; margin: var(--space-md) 0 .5rem; }
.prose p       { margin-bottom: var(--space-md); }
.prose ul      { list-style: disc; padding-left: 1.5rem; margin-bottom: var(--space-md); }
.prose ul li   { color: var(--gray-600); font-size: 1.0625rem; line-height: 1.75; margin-bottom: .5rem; }

/* ── Responsive ──────────────────────────────────────── */
@media (max-width: 1024px) {
  .grid-3      { grid-template-columns: repeat(2, 1fr); }
  .grid-4      { grid-template-columns: repeat(2, 1fr); }
  .path-cards  { grid-template-columns: repeat(2, 1fr); }
  .pricing-grid { grid-template-columns: repeat(2, 1fr); }
  .pricing-grid .pricing-card,
  .pricing-grid .pricing-card:nth-child(4),
  .pricing-grid .pricing-card:nth-child(5) { grid-column: span 1; }
  .resource-grid { grid-template-columns: repeat(2, 1fr); }
  .footer__top { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  :root {
    --space-3xl: 5rem;
    --space-2xl: 3.5rem;
    --space-xl: 2.75rem;
  }

  .nav__toggle { display: flex; }
  .nav__links {
    display: none;
    position: fixed;
    top: var(--nav-h); left: 0; right: 0;
    background: var(--white);
    flex-direction: column;
    padding: var(--space-md);
    gap: var(--space-sm);
    border-top: 1px solid #e2e8f0;
    box-shadow: 0 20px 40px rgba(0,0,0,.12);
  }
  .nav__links a { color: var(--black); }
  .nav__links.open { display: flex; }
  .nav__links .nav__cta { margin-left: 0; margin-top: .5rem; }

  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .path-cards   { grid-template-columns: 1fr; }
  .pricing-grid { grid-template-columns: 1fr; }
  .pricing-grid .pricing-card,
  .pricing-grid .pricing-card:nth-child(4),
  .pricing-grid .pricing-card:nth-child(5) { grid-column: span 1; }
  .resource-grid { grid-template-columns: 1fr; }
  .tools-grid   { grid-template-columns: 1fr; }
  .form-row     { grid-template-columns: 1fr; }

  .about-split    { grid-template-columns: 1fr; }
  .about-split__img img { height: 380px; }
  .about-hero     { grid-template-columns: 1fr; }
  .about-hero__photo img,
  .about-hero__placeholder { height: 380px; }
  .offer-grid     { grid-template-columns: 1fr; }
  .contact-layout { grid-template-columns: 1fr; }
  .tool-preview   { grid-template-columns: 1fr; }

  .footer__top    { grid-template-columns: 1fr; gap: var(--space-lg); }
  .footer__bottom { flex-direction: column; align-items: flex-start; }

  .home-hero__logo { max-width: 180px; }
  .cta-banner__btns { flex-direction: column; align-items: center; }
  .nav__wordmark { display: none; }
}

/* ── Skip Link ────────────────────────────────────────── */
.skip-link { position: absolute; left: -9999px; top: 0; padding: 8px 16px; background: #111; color: #fff; z-index: 9999; }
.skip-link:focus { left: 8px; top: 8px; }

/* ── Visually Hidden ──────────────────────────────────── */
.visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ── Trust Strip ──────────────────────────────────────── */
.trust-strip { padding: 32px 0; background: #ffffff; border-top: 1px solid #e2e8f0; border-bottom: 1px solid #e2e8f0; }
.trust-strip__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; text-align: center; }
.trust-strip__item { display: flex; flex-direction: column; gap: 2px; }
.trust-strip__item strong { font-size: 1.125rem; font-weight: 700; color: #111111; }
.trust-strip__item span { font-size: 0.875rem; color: #64748b; }
@media (max-width: 640px) {
  .trust-strip__grid { grid-template-columns: 1fr; gap: 16px; }
  .home-hero__logo { max-width: 240px; }
}

/* ── Districts Proof Block ────────────────────────────── */
.districts__proof { background: #E8F8FC; border-left: 3px solid #00B4D8; border-radius: 8px; padding: 24px 28px; margin: 40px auto; max-width: 720px; }
.districts__proof p { color: #334155; margin: 8px 0 16px; }

/* ── Districts Tool Pricing ───────────────────────────── */
.districts__tool-pricing { margin: 48px auto; max-width: 720px; }
.tool-pricing__grid { display: flex; flex-direction: column; gap: 12px; margin-top: 16px; }
.tool-pricing__item { display: grid; grid-template-columns: 1fr auto; gap: 4px 16px; padding: 16px 20px; background: #f8f9fa; border-radius: 8px; border: 1px solid #e2e8f0; align-items: center; }
.tool-pricing__item strong { font-size: 0.95rem; color: #111111; grid-column: 1; }
.tool-pricing__item span { font-size: 0.875rem; color: #64748b; grid-column: 1; grid-row: 2; }
.tool-pricing__item em { grid-column: 2; grid-row: 1 / 3; font-style: normal; font-weight: 600; color: #00B4D8; font-size: 1rem; }
.districts__tool-pricing-note { font-size: 0.875rem; color: #64748b; margin-top: 16px; text-align: center; }

/* ── Shop Page ────────────────────────────────────────── */
.shop-intro { text-align: center; max-width: 600px; margin: 0 auto 32px; color: #64748b; font-size: 1.0625rem; }
.shop-subscribe { background: #E8F8FC; border-radius: 12px; padding: 40px; margin: 48px auto; max-width: 640px; text-align: center; }
.shop-subscribe__form { display: flex; gap: 8px; margin-top: 20px; max-width: 420px; margin-left: auto; margin-right: auto; }
.shop-subscribe__form input { flex: 1; padding: 12px 16px; border: 1px solid #cbd5e1; border-radius: 6px; font-size: 0.9375rem; font-family: var(--font); }

/* ── Btn Outline (neutral) ────────────────────────────── */
.btn--outline { background: transparent; color: #111111; border-color: #111111; }
.btn--outline:hover { background: #111111; color: var(--white); border-color: #111111; transform: translateY(-1px); }

/* ── Footer Location ──────────────────────────────────── */
.footer__location { font-size: 0.8125rem; color: #94a3b8; text-align: center; margin: 16px 0 8px; }

/* ── Container Narrow (blog readability) ──────────────── */
.container--narrow {
  max-width: 720px;
}

/* ── Blog Index ───────────────────────────────────────── */
.blog-index-hero {
  background: #E8F8FC;
  padding: 80px 0 72px;
  text-align: center;
  border-bottom: 2px solid rgba(0,180,216,.3);
  box-shadow: inset 0 -12px 40px rgba(0,180,216,.18);
}
.blog-index-hero .label {
  margin-bottom: 16px;
}
.blog-index-hero h1 {
  font-size: clamp(2rem, 4vw, 3rem);
  margin: 0 auto 20px;
  max-width: 680px;
  color: var(--text);
}
.blog-index-hero p {
  font-size: 1.125rem;
  max-width: 580px;
  margin: 0 auto;
  color: var(--text-muted);
  line-height: 1.7;
}

.blog-grid-section {
  padding: 64px 0;
  background: #ffffff;
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 32px;
  max-width: 1080px;
  margin: 0 auto;
}

.blog-card {
  background: #f8f9fa;
  border-radius: 12px;
  border: 1px solid #e2e8f0;
  transition: transform 0.2s, box-shadow 0.2s;
}

.blog-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
}

.blog-card__link {
  display: block;
  padding: 28px;
  text-decoration: none;
  color: inherit;
}

.blog-card__category {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: #00B4D8;
  margin: 0 0 12px;
}

.blog-card__title {
  font-size: 1.375rem;
  font-weight: 700;
  color: #111111;
  margin: 0 0 12px;
  line-height: 1.3;
}

.blog-card__excerpt {
  font-size: 0.9375rem;
  color: #334155;
  line-height: 1.6;
  margin: 0 0 20px;
}

.blog-card__meta {
  font-size: 0.8125rem;
  color: #64748b;
  margin: 0;
}

/* ── Blog Post ────────────────────────────────────────── */
.blog-post {
  background: #ffffff;
}

.blog-post__header {
  background: #E8F8FC;
  padding: 64px 0 48px;
}

.blog-post__category {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: #00B4D8;
  margin: 0 0 12px;
}

.blog-post__title {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 700;
  color: #111111;
  line-height: 1.2;
  margin: 0 0 20px;
}

.blog-post__meta {
  font-size: 0.9375rem;
  color: #64748b;
  margin: 0;
}

.blog-post__body {
  padding: 48px 0 64px;
}

.blog-post__lede {
  font-size: 1.25rem;
  line-height: 1.6;
  color: #111111;
  font-weight: 400;
  margin: 0 0 32px;
}

.blog-post__body h2 {
  font-size: 1.5rem;
  margin: 40px 0 16px;
  color: #111111;
}

.blog-post__body p {
  font-size: 1.0625rem;
  line-height: 1.7;
  color: #334155;
  margin: 0 0 20px;
}

.blog-post__callout {
  background: #E8F8FC;
  border-left: 3px solid #00B4D8;
  padding: 20px 24px;
  border-radius: 6px;
  margin: 32px 0;
}

.blog-post__callout p {
  margin: 0;
}

.blog-post__footer {
  padding: 0 0 80px;
}

.blog-post__cta {
  background: #111111;
  color: #ffffff;
  padding: 40px;
  border-radius: 12px;
  text-align: center;
}

.blog-post__cta .label {
  color: #00B4D8;
}

.blog-post__cta h3 {
  color: #ffffff;
  margin: 12px 0 12px;
  font-size: 1.5rem;
}

.blog-post__cta p {
  color: #cbd5e1;
  margin-bottom: 24px;
}

/* ── Resource Card Price & Audience ──────────────────── */
.resource-card__price {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--cyan);
  letter-spacing: -.03em;
  margin: 4px 0 12px;
  line-height: 1;
}
.resource-card__audience {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gray-600);
  margin-bottom: .375rem;
}

/* ── Testimonials ─────────────────────────────────────── */
.testimonials {
  background: #ffffff;
  padding: 64px 0;
}

.testimonials__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  max-width: 960px;
  margin: 24px auto 0;
}

.testimonial-card {
  background: #f8f9fa;
  border-left: 3px solid #00B4D8;
  padding: 28px 32px;
  border-radius: 8px;
}

.testimonial-card blockquote {
  font-size: 1.0625rem;
  line-height: 1.6;
  color: #111111;
  font-weight: 400;
  margin: 0 0 16px;
  font-style: normal;
}

.testimonial-card__attribution {
  font-size: 0.875rem;
  color: #64748b;
  margin: 0;
}

.testimonial-card__attribution strong {
  color: #111111;
}

@media (max-width: 720px) {
  .testimonials__grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

/* ── Founder Intro ────────────────────────────────────── */
.founder-intro__layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: var(--space-3xl);
  align-items: center;
}
.founder-intro__photo img {
  width: 100%;
  border-radius: var(--r-md);
  object-fit: cover;
  object-position: 50% 15%;
  aspect-ratio: 3 / 4;
  display: block;
}
.founder-intro__text .label { display: block; margin-bottom: var(--space-sm); }
.founder-intro__text h2 { margin-bottom: var(--space-md); }
.founder-intro__text p { font-size: .9375rem; color: var(--gray-600); margin-bottom: var(--space-md); line-height: 1.75; }

/* ── Page Intro ───────────────────────────────────────── */
.page-intro__layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--space-3xl);
  align-items: center;
}
.page-intro__photo img {
  width: 100%;
  border-radius: var(--r-md);
  object-fit: cover;
  object-position: 50% 15%;
  aspect-ratio: 3 / 4;
  display: block;
}
.page-intro__text .label { display: block; margin-bottom: var(--space-sm); }
.page-intro__text h2 { margin-bottom: var(--space-md); }
.page-intro__text p { font-size: .9375rem; color: var(--gray-600); margin-bottom: var(--space-md); line-height: 1.75; }

/* ── Calendly Placeholder ─────────────────────────────── */
.calendly-placeholder {
  background: var(--bg);
  border: 2px dashed #cbd5e1;
  border-radius: var(--r-md);
  padding: var(--space-xl) var(--space-lg);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
}
.calendly-placeholder__label {
  font-size: .9375rem;
  color: var(--gray-600);
  margin: 0;
}

/* ── Tools Email Capture ──────────────────────────────── */
.tools-email-capture {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3xl);
  align-items: center;
  background: var(--white);
  border-radius: var(--r-lg);
  padding: var(--space-xl);
  box-shadow: var(--shadow-sm);
}
.tools-email-capture__text .label { display: block; margin-bottom: var(--space-sm); }
.tools-email-capture__text h2 { margin-bottom: var(--space-sm); }
.tools-email-capture__text p { color: var(--gray-600); font-size: .9375rem; }
.tools-email-capture__row {
  display: flex;
  gap: var(--space-sm);
  margin-bottom: var(--space-xs, .5rem);
}
.tools-email-capture__row .form-input { flex: 1; }

/* ── Responsive: Photo blocks ────────────────────────── */
@media (max-width: 768px) {
  .founder-intro__layout,
  .page-intro__layout { grid-template-columns: 1fr; }
  .founder-intro__photo img,
  .page-intro__photo img { aspect-ratio: 4 / 3; max-height: 320px; width: 100%; object-position: 50% 20%; }
  .tools-email-capture { grid-template-columns: 1fr; gap: var(--space-xl); }
  .tools-email-capture__row { flex-direction: column; }
}

/* ── Blog Author Bio ──────────────────────────────────── */
.blog-post__author {
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 32px;
  margin: 48px auto 0;
  background: #f8f9fa;
  border-radius: 12px;
  border: 1px solid #e2e8f0;
}

.blog-post__author-photo {
  flex-shrink: 0;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  overflow: hidden;
  border: 3px solid #00B4D8;
}

.blog-post__author-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 20%;
}

.blog-post__author-text { flex: 1; }
.blog-post__author-text h3 { margin: 4px 0 8px; font-size: 1.125rem; }
.blog-post__author-text p { margin: 0 0 12px; font-size: 0.9375rem; line-height: 1.5; color: #334155; }
.blog-post__author-link { color: #00B4D8; font-weight: 600; font-size: 0.875rem; text-decoration: none; }
.blog-post__author-link:hover { text-decoration: underline; }

@media (max-width: 640px) {
  .blog-post__author { flex-direction: column; text-align: center; }
}

/* ── Blog Newsletter ──────────────────────────────────── */
.blog-newsletter {
  padding: 64px 0;
  background: #f8f9fa;
}

.blog-newsletter__inner {
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
  background: #ffffff;
  padding: 40px;
  border-radius: 16px;
  border: 1px solid #e2e8f0;
}

.blog-newsletter__form {
  display: flex;
  gap: 8px;
  margin-top: 24px;
  max-width: 420px;
  margin-left: auto;
  margin-right: auto;
}

.blog-newsletter__form input[type="email"] {
  flex: 1;
  padding: 12px 16px;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  font-size: 0.9375rem;
  font-family: inherit;
}

@media (max-width: 540px) {
  .blog-newsletter__form { flex-direction: column; }
}
