:root{
    --ai-green: #2f7a57;   /* headline green */
    --ai-blue:  #1f5f86;   /* section title blue */
    --soft-bg:  #eef4f2;   /* pale mint */
    --hero-bg:  #eef4fa;   /* pale blue/gray */
    --deep-teal:#0e5a74;   /* CTA bar */
    --nav-blue: #0b61c3;   /* jump link */
    --quote-bg: #0b5f91;   /* outcomes right */
  }
  
  body{
    color:#111;
  }

  #header {
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  }

  #nav-container a {
    color: var(--nav-blue);
    font-weight: 700;
    text-decoration: none;
  }

  #nav-container a:hover {
    text-decoration: underline;
  }

  /* Header logo - desktop (preserves original look) */
  .header-logo{
    max-height: 400px;
    margin-top: -1px;
  }
  
  /* Brand */
  .brand-mark{
    display:inline-flex;
    align-items:baseline;
    gap:.15rem;
    color:#111;
  }
  .brand-wordmark{
    font-style: italic;
    font-weight: 600;
    letter-spacing:.2px;
  }
  .brand-llc{
    font-size:.8rem;
    font-weight:600;
    opacity:.8;
  }
  
  /* Hero */
  .hero-wrap{
    background:#fff;
  }
  .hero-card{
    overflow:hidden;
    border-radius: 0;
    box-shadow: none;
  }
  .hero-left{
    background: var(--hero-bg);
  }
  .hero-title{
    font-size: clamp(2.2rem, 4vw, 4.1rem);
    line-height: 1.05;
    font-weight: 300;
    color: var(--ai-green);
    letter-spacing: .5px;
    text-align: center;
  }
  .hero-right{
    background:#ddd;
    min-height: 260px;
  }
  .hero-img{
    width: 100%;
    height: 100%;
    min-height: 260px;
    object-fit: cover;
    display:block;
  }

/* Hero intro paragraph width */
.hero-intro{
  margin-left: auto;
  margin-right: auto;
}
  
  /* Jump links */
  .jump-link{
    color: var(--nav-blue);
    text-decoration: underline;
    font-weight: 800;
    letter-spacing: .3px;
  }
  
  /* Sections */
  .section-soft{
    background: var(--soft-bg);
  }
  .section-title{
    color: var(--ai-blue);
    font-weight: 500;
    font-size: clamp(1.8rem, 2.5vw, 2.6rem);
  }
  .voices-subhead{
    color: var(--ai-blue);
    font-weight: 800;
    font-size: 1.05rem;
  }
  
  /* Impact list */
  .impact-subtitle{
    color: var(--ai-blue);
    font-weight: 700;
    margin-bottom: 1rem;
  }
  .impact-list{
    display: grid;
    gap: .9rem;
  }
  .impact-item{
    display:grid;
    grid-template-columns: 34px 1fr;
    gap: .75rem;
    align-items:start;
  }
  .checkmark{
    width: 28px;
    height: 28px;
    border-radius: 50%;
    position: relative;
    border: 3px solid var(--ai-blue);
    margin-top: .1rem;
  }
  .checkmark::after{
    content:"";
    position:absolute;
    left: 7px;
    top: 4px;
    width: 8px;
    height: 14px;
    border-right: 4px solid var(--ai-blue);
    border-bottom: 4px solid var(--ai-blue);
    transform: rotate(45deg);
  }
  
  /* School logos */
  .school-logo{
    max-height: 180px;
    width:auto;
  }
  .school-logo-sm{
    max-height: 90px;
    width:auto;
  }

  /* Impact: vertical logo stack on right */
  .impact-logos-vertical{
    display:flex;
    flex-direction:column;
    gap:1.25rem;
    align-items:flex-end;
    justify-content:flex-start;
  }
  @media (max-width: 991.98px){
    .impact-logos-vertical{
      align-items:center;
    }
  }
  
  /* CTA bar */
  .cta-bar{
    background: #198754;
    padding: 18px 16px;
    text-align: center;
  }
  .cta-link{
    color:#fff;
    font-weight: 800;
    text-decoration: underline;
    font-size: 2.3rem;
  }
  
  /* Video cards */
  .video-card{
    display:block;
    background: #0b4f6e;
    color:#fff;
    text-decoration:none;
    overflow:hidden;
  }
  .video-card:hover{
    filter: brightness(1.02);
  }
  .video-thumb{
    position: relative;
    height: 220px;
    background: linear-gradient(0deg, rgba(0,0,0,.15), rgba(0,0,0,.15));
  }
  .video-thumb.alt{
    background: linear-gradient(0deg, rgba(0,0,0,.10), rgba(0,0,0,.10));
  }
  .play-icon{
    width:78px;
    height:78px;
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%,-50%);
  }
  .video-caption{
    background:#073a52;
    color:#fff;
    padding: 10px 12px;
  }
  
  /* Medal blurbs */
  .medal-blurb{
    display:grid;
    grid-template-columns: 1fr 92px;
    gap: 14px;
    align-items:start;
  }
  .medal-text{
    font-size: .98rem;
    line-height: 1.45;
  }
  .medal-img{
    width:92px;
    height:auto;
    justify-self:end;
  }
  
  /* Outcomes band */
  .outcomes-band{
    background:#fff;
  }
  .outcomes-left{
    background: var(--soft-bg);
  }
  .outcomes-right{
    background: var(--quote-bg);
    color:#fff;
  }
  .outcomes-title{
    color: var(--ai-blue);
    font-weight: 800;
  }
  .outcome-item{
    display:grid;
    grid-template-columns: 56px 1fr;
    gap: 14px;
    align-items:start;
  }
  .outcome-icon-img{
    width:48px;
    height:48px;
  }
  .outcomes-kicker{
    color: var(--ai-green);
    font-weight: 800;
    font-size: 1.15rem;
    line-height: 1.25;
  }

  .voices-closing-kicker {
    font-size: 1.05rem;
    line-height: 1.35;
  }
  
  /* Quotes */
  .quote-block{
    font-style: italic;
    line-height: 1.55;
    margin: 0;
  }
  .quote-by{
    font-style: normal;
    font-weight: 700;
    margin-top: .4rem;
    opacity: .95;
    text-align: right;
  }
  .quote-by span{
    font-weight: 600;
    opacity: .95;
  }
  
  /* Responsive */
  @media (max-width: 991.98px){
    .medal-blurb{
      grid-template-columns: 1fr;
    }
    .medal-img{
      justify-self:start;
    }
  }

  /* ===== Voices section (aligned rows like screenshot) ===== */
.voices-title{
    color: var(--ai-blue);
    font-weight: 500;
    font-size: clamp(1.8rem, 2.5vw, 2.6rem);
    margin-bottom: .35rem;
  }
  
  .voices-intro{
    margin-bottom: 1.25rem;
  }
  
  .voices-subhead{
    color: var(--ai-blue);
    font-weight: 800;
    font-size: 1.05rem;
    margin-bottom: 1.25rem;
  }
  
  /* Each row is a paired set: left video, right paragraph+medals */
  .voices-row{
    display: grid;
    grid-template-columns: 620px 1fr;
    gap: 2.25rem;
    align-items: center;   /* <-- THIS is the magic */
    margin-bottom: 1.75rem;
  }
  
  /* Left column video tile */
  .voices-video{
    position: relative;
    display: block;
    width: 100%;
    height: 245px;               /* tune per your screenshot */
    background: #0b4f6e;
    overflow: hidden;
    text-decoration: none;
  }
  
  /* Option A: “thumbnail-like” tile (use a bg image if you want) */
  .voices-video--thumb{
    background: linear-gradient(0deg, rgba(0,0,0,.10), rgba(0,0,0,.10));
    /* If you have a screenshot thumbnail image, uncomment and set:
    background-image: url("img/video-1-thumb.jpg");
    background-size: cover;
    background-position: center;
    */
  }
  
  /* Option B: the solid blue blank video tile in the middle row */
  .voices-video--solid{
    background: #0a66d9; /* matches the bright blue box in screenshot */
  }
  
  /* Play button overlay */
  .voices-play{
    width: 78px;
    height: 78px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
  }
  
  /* Lower name bar (only on rows 1 and 3 in your screenshot) */
  .voices-lowerbar{
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 12px 14px;
    background: rgba(0,0,0,.55);
    color: #fff;
  }
  
  .voices-name{
    font-weight: 800;
    font-size: 1.1rem;
    line-height: 1.1;
  }
  
  .voices-role{
    font-size: .85rem;
    opacity: .95;
  }
  
  /* Right column: paragraph + medals column */
  .voices-copy{
    display: grid;
    grid-template-columns: 1fr 290px; /* text then medals */
    gap: 1.5rem;
    align-items: start;
  }

  .voices-copy-main {
    min-width: 0;
  }

  .voices-quote {
    font-style: italic;
    line-height: 1.5;
    margin: 1.25rem 0 0;
    padding: 0 0 0 1rem;
    border-left: 4px solid var(--ai-blue);
  }

  .voices-quote .voices-quote-by {
    display: block;
    font-style: normal;
    font-weight: 700;
    margin-top: 0.65rem;
    font-size: 0.95rem;
  }

  /* Navy banner quote + gold medal (River City profile) */
  .rc-quote-banner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) min(200px, 26vw);
    align-items: stretch;
    background: #142c45;
    color: #fff;
    margin: 1.75rem 0 2.25rem;
    min-height: 220px;
    overflow: visible;
  }

  .rc-quote-banner__content {
    padding: 2rem 1.25rem 2rem 2rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-width: 0;
  }

  .rc-quote-banner__quote {
    margin: 0;
    padding: 0;
    border: 0;
    max-width: 48rem;
  }

  .rc-quote-banner__quote p {
    margin: 0;
    font-family: Georgia, "Times New Roman", Times, serif;
    font-style: italic;
    font-weight: 400;
    font-size: clamp(1.02rem, 0.6vw + 0.95rem, 1.2rem);
    line-height: 1.55;
    color: #fff;
  }

  .rc-quote-banner__quote em {
    font-style: italic;
  }

  .rc-quote-banner__attr {
    margin: 1.5rem 0 0;
    padding: 0;
    width: 100%;
    text-align: right;
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 0.95rem;
    line-height: 1.45;
    color: #fff;
  }

  .rc-quote-banner__attr strong {
    font-weight: 700;
  }

  .rc-quote-banner__medal-wrap {
    display: flex;
    align-items: stretch;
    justify-content: flex-end;
    padding: 0;
    margin-right: clamp(-8px, -1.5vw, -20px);
    position: relative;
    z-index: 2;
  }

  .rc-quote-banner__medal {
    height: 100%;
    min-height: 220px;
    width: auto;
    max-width: min(240px, 32vw);
    object-fit: contain;
    object-position: top right;
    display: block;
    pointer-events: none;
    filter: drop-shadow(-4px 6px 12px rgba(0, 0, 0, 0.25));
  }

  @media (max-width: 767.98px) {
    .rc-quote-banner {
      grid-template-columns: 1fr;
      min-height: 0;
    }

    .rc-quote-banner__content {
      padding: 1.5rem 1.25rem 1.25rem;
      order: 2;
    }

    .rc-quote-banner__medal-wrap {
      order: 1;
      justify-content: center;
      margin: 0;
      padding: 1.25rem 1rem 0;
      min-height: 160px;
    }

    .rc-quote-banner__medal {
      min-height: 0;
      height: 200px;
      max-width: 200px;
      object-position: top center;
    }

  }
  
  .voices-paragraph{
    margin: 0;
    font-size: 1.02rem;
    line-height: 1.5;
  }
  
  /* Medals: right-aligned column; last row stacks 2 medals */
  .voices-medals{
    display: flex;
    flex-direction: column;
    gap: 18px;
  }
  
  .voices-medal{
    width: 200px;   /* matches your earlier sizing */
    height: auto;
  }
  
  /* Responsive: stack to one column on smaller screens */
  @media (max-width: 991.98px){
    .voices-row{
      grid-template-columns: 1fr;
    }
    .voices-copy{
      grid-template-columns: 1fr;
    }
    .voices-medals{
      align-items: flex-start;
      flex-direction: row;   /* medals side-by-side on mobile */
      flex-wrap: wrap;
    }
  }
  /* Video container (16:9 aspect; custom poster until play) */
.voices-video-wrap {
  position: relative;
  width: 100%;
  max-width: 620px;
  overflow: hidden;
}

.voices-video-wrap--center {
  margin-inline: auto;
}

.voices-video-aspect {
  position: relative;
  width: 100%;
  padding: 56.25% 0 0 0;
  height: 0;
  background: #000;
}

.voices-video-aspect iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
  pointer-events: none;
}

.voices-poster {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 6;
  cursor: pointer;
  border: 0;
  padding: 0;
  margin: 0;
  background: #000;
  appearance: none;
}

.voices-poster img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  pointer-events: none;
}

.voices-poster.is-hidden {
  display: none !important;
}

/* Play button overlay */
.voices-play-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 78px;
  height: 78px;
  cursor: pointer;
  z-index: 10;
  transition: transform .2s ease;
  pointer-events: auto;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  line-height: 0;
  appearance: none;
}

.voices-play-overlay img {
  display: block;
  width: 78px;
  height: 78px;
}

.voices-play-overlay:hover {
  transform: translate(-50%, -50%) scale(1.08);
}

/* ===== Alternative Schools Panel (matches screenshot) ===== */
.alt-schools-panel{
  background: #eef7f3;                 /* light mint */
}

.alt-grid{
  display: grid;
  grid-template-columns: 1fr 260px;    /* left text, right logo cluster */
  gap: 2rem;
  align-items: start;
}

.alt-title{
  color: var(--ai-blue, #1f5f86);
  font-weight: 800;
  font-size: clamp(1.4rem, 2.2vw, 2rem);
  line-height: 1.15;
  margin: 0 0 1.25rem 0;
}

/* Bullets */
.alt-bullets{
  display: grid;
  gap: 1.1rem;
  margin-bottom: 1.6rem;
}

.alt-bullet{
  display: grid;
  grid-template-columns: 52px 1fr;     /* icon + text */
  gap: 1rem;
  align-items: start;
  font-size: 1.1rem;
  line-height: 1.35;
}

.alt-check{
  width: 38px;
  height: 38px;
  border-radius: 999px;
  border: 4px solid var(--ai-blue, #1f5f86);
  position: relative;
  margin-top: 2px;
}

.alt-check::after{
  content:"";
  position:absolute;
  left: 10px;
  top: 7px;
  width: 10px;
  height: 16px;
  border-right: 4px solid var(--ai-blue, #1f5f86);
  border-bottom: 4px solid var(--ai-blue, #1f5f86);
  transform: rotate(45deg);
}

/* paragraph under bullets */
.alt-paragraph{
  margin: 0;
  font-size: 1.1rem;
  line-height: 1.45;
  max-width: 980px;
}

/* Right logo cluster */
.alt-right{
  display: flex;
}

.logo-cluster{
  position: relative;
  width: 240px;
  height: 220px;
}

/* Base logo styling */
.logo-cluster .logo{
  position: absolute;
  width: auto;
  max-width: 170px;
  max-height: 140px;
  filter: drop-shadow(0 8px 10px rgba(0,0,0,.20));
}

/* Position each logo to mimic the screenshot */
.logo-cluster .np{  /* compass */
  top: 0px;
  left: 0px;
  max-height: 186px;
}

.logo-cluster .ss{  /* silver S */
  top: 62px;
  left: 144px;
  max-height: 135px
}

.logo-cluster .ge{  /* feather G */
  top: 147px;
  left: 70px;
  max-height: 200px;
}
/* Position each logo to mimic the screenshot */
.logo-cluster .logo2{
  position: absolute;
  width: auto;
  max-width: 170px;
  max-height: 140px;
  filter: drop-shadow(0 8px 10px rgba(0,0,0,.20));
}
.logo-cluster .silver{  /* silver */
  top: -32px;
  left: 0px;
  max-height: 300px;
}

.logo-cluster .gold{  /* gold S */
  top: 62px;
  left: 110px;
  max-height: 300px;
}

/* Responsive: stack logos below text on smaller screens */
@media (max-width: 991.98px){
  .alt-grid{
    grid-template-columns: 1fr;
  }
  .alt-right{
    justify-content: flex-start;
  }
}
@media (min-width: 1200px) {
  .h3, h3 {
    font-size: 1.6rem;
  }
}

/* ===== Mobile compatibility (Bootstrap 5 breakpoints) ===== */
/* Desktop unchanged; mobile-only overrides below 992px */

@media (max-width: 991.98px) {
  /* Prevent horizontal scroll */
  body {
    overflow-x: hidden;
  }

  /* Header: compact logo, prevent overflow */
  .header-logo {
    max-height: 120px;
    width: auto;
  }
  .container-header {
    padding: 0.5rem 1rem;
  }
  #nav-container a {
    font-size: 0.95rem;
  }

  /* Hero: ensure image stacks nicely */
  .hero-right {
    min-height: 200px;
  }
  .hero-img {
    min-height: 200px;
  }
  .hero-title {
    text-align: center;
  }

  /* Impact: school logos centered, reasonable size */
  .school-logo {
    max-height: 120px;
    margin-bottom: 1rem;
  }

  /* Voices: video scales with width on small screens */
  .voices-video-wrap {
    max-width: 100%;
  }
  .voices-video--solid {
    min-height: 220px;
  }
  .voices-medal {
    width: 140px;
  }

  /* Alt grid logo cluster: scale for mobile */
  .logo-cluster {
    width: 200px;
    height: 180px;
    margin: 0 auto;
  }
  .logo-cluster .logo {
    max-width: 120px;
    max-height: 100px;
  }
  .logo-cluster .np { max-height: 130px; }
  .logo-cluster .ss { max-height: 95px; top: 45px; left: 100px; }
  .logo-cluster .ge { max-height: 140px; top: 105px; left: 50px; }
  .logo-cluster .logo2 {
    max-width: 120px;
    max-height: 100px;
  }
  .logo-cluster .silver { max-height: 200px; top: -20px; }
  .logo-cluster .gold { max-height: 200px; top: 45px; left: 75px; }

  /* Outcome items: slightly smaller icons on very narrow screens */
  .outcome-item {
    grid-template-columns: 44px 1fr;
    gap: 10px;
  }
  .outcome-icon-img {
    width: 40px;
    height: 40px;
  }

  /* CTA bar: comfortable padding */
  .cta-bar {
    padding: 16px 12px;
  }
}

@media (max-width: 575.98px) {
  /* Extra small: tighter spacing */
  .header-logo {
    max-height: 90px;
  }
  .hero-title {
    font-size: clamp(1.6rem, 6vw, 2.2rem);
  }
  .section-title,
  .voices-title {
    font-size: 1.5rem;
  }
  .impact-item {
    grid-template-columns: 28px 1fr;
    gap: 0.5rem;
  }
  .checkmark {
    width: 24px;
    height: 24px;
  }
  .checkmark::after {
    left: 5px;
    top: 2px;
    width: 6px;
    height: 11px;
  }
}