
:root {
  --paper:#F7F5EF;
  --panel:#FFFFFF;
  --ink:#172223;
  --navy:#183642;
  --muted:#69706E;
  --line:#D7D1C3;
  --teal:#176D75;
  --cream:#FFF9EE;
}
* { box-sizing:border-box; }
body {
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:Georgia, serif;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.brand,.nav a,.hero-kicker,.button-link {
  font-family:"EB Garamond", Garamond, Georgia, serif;
}
.site-header {
  position:sticky;
  top:0;
  z-index:20;
  height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 clamp(24px,6vw,88px);
  background:rgba(247,245,239,.94);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(215,209,195,.75);
}
.brand {
  color:var(--teal);
  font-size:clamp(26px,2.2vw,34px);
  text-decoration:none;
  font-weight:500;
}
.nav {
  display:flex;
  gap:clamp(20px,2.5vw,38px);
  align-items:center;
}
.nav a {
  color:var(--navy);
  text-decoration:none;
  font-size:19px;
  border-bottom:1px solid transparent;
  padding-bottom:3px;
}
.nav a.active,.nav a:hover {
  color:var(--teal);
  border-color:var(--teal);
}

.hero {
  position:relative;
  background:#0f2730;
  overflow:hidden;
}
.hero img {
  display:block;
  width:100%;
  height:auto;
}
.hero:after {
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(to bottom, rgba(0,0,0,.04), rgba(0,0,0,.08) 55%, rgba(0,0,0,.28)),
    linear-gradient(to right, rgba(0,0,0,.40), rgba(0,0,0,.10) 45%, rgba(0,0,0,.02));
  pointer-events:none;
}
.hero-content {
  position:absolute;
  z-index:2;
  left:clamp(24px,6vw,88px);
  bottom:clamp(34px,6vw,82px);
  max-width:760px;
  color:#FFFFFF;
  text-shadow:0 2px 18px rgba(0,0,0,.35);
}
h1 {
  margin:0 0 14px;
  font-weight:500;
  font-size:clamp(58px,8vw,112px);
  line-height:.92;
  letter-spacing:-.015em;
  color:#FFFFFF;
}
.hero-kicker {
  font-style:italic;
  font-size:clamp(26px,3.1vw,42px);
  line-height:1.17;
  color:#FFFFFF;
  max-width:650px;
}
.hero-rule {
  width:min(380px,50vw);
  height:2px;
  background:#FFFFFF;
  margin-top:30px;
  opacity:.9;
}

.section {
  padding:clamp(72px,9vw,130px) clamp(24px,6vw,88px);
}
.intro {
  max-width: 900px;
  margin: 0 auto;
}
.bio {
  max-width: 820px;
  margin: 0 auto;
}
.bio p {
  text-align: left;
}
.side-image {
  margin: 40px auto 0;
  max-width: 760px;
}
.side-image img {
  width: 100%;
  display: block;
  object-fit: cover;
  border: 1px solid rgba(215,209,195,.9);
}
.small-caption {
  margin-top: 12px;
  font-size: 15px;
  line-height: 1.4;
  color: var(--muted);
  font-style: italic;
  text-align: center;
}


.bio p {
  font-size:clamp(20px,1.55vw,25px);
  line-height:1.68;
  margin:0 0 30px;
}
.bio p:first-of-type {
  font-size:clamp(22px,1.8vw,28px);
  line-height:1.58;
}




.teal-rule {
  height:1px;
  background:var(--teal);
  opacity:.72;
  width:100%;
}

.paths {
  padding-top:clamp(58px,7vw,90px);
  padding-bottom:clamp(72px,8vw,110px);
  padding-left:clamp(24px,6vw,88px);
  padding-right:clamp(24px,6vw,88px);
}

.pathway-tagline {
  font-family:"EB Garamond", Garamond, Georgia, serif;
  color:var(--teal);
  font-size:clamp(32px,3.2vw,52px);
  line-height:1.1;
  font-weight:500;
  text-align:center;
  margin:0 auto clamp(46px,5vw,72px);
  max-width:900px;
}

.paths-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(32px,5vw,72px);
}
.path {
  padding-top:28px;
  border-top:1.5px solid var(--teal);
}

.path {
  display:block;
  color:var(--ink);
  text-decoration:none;
}
.path:hover .path-title,
.path:focus .path-title {
  color:var(--teal);
}
.path:focus {
  outline:2px solid var(--teal);
  outline-offset:6px;
}
.path-title {
  font-weight:500;
  font-size:clamp(33px,3vw,46px);
  line-height:1.05;
  margin:0 0 20px;
}
.path p {
  margin:0;
  font-size:clamp(18px,1.35vw,22px);
  line-height:1.55;
}
.button-link {
  display:inline-block;
  margin-top:18px;
  font-size:22px;
  font-style:italic;
  color:var(--teal);
  text-decoration:none;
  border-bottom:1px solid transparent;
}
.button-link:hover {
  border-color:var(--teal);
}

footer {
  border-top:1px solid var(--teal);
  padding:38px clamp(24px,6vw,88px);
  display:flex;
  justify-content:space-between;
  gap:24px;
  color:var(--muted);
  font-size:17px;
}
footer a {
  color:var(--teal);
  text-decoration:none;
}

@media(max-width:900px) {
  .site-header {
    height:auto;
    padding-top:18px;
    padding-bottom:18px;
    align-items:flex-start;
    gap:14px;
    flex-direction:column;
  }
  .nav {
    flex-wrap:wrap;
    gap:16px 24px;
  }
  .hero-content {
    bottom:28px;
    left:24px;
    right:24px;
  }
  .hero:after {
    background:linear-gradient(to bottom,rgba(0,0,0,.08),rgba(0,0,0,.20) 55%,rgba(0,0,0,.42));
  }
  .paths-grid {
    grid-template-columns:1fr;
  }
  footer {
    flex-direction:column;
  }
}

.intro p {
  font-size: 22px !important;
  line-height: 1.55 !important;
}

.paths-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 22px !important;
}
.path {
  min-width: 0;
}
.path-title {
  font-size: 24px !important;
}
.button-link {
  font-size: 18px !important;
}

.path-subtitle {
  margin-top: 6px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.25;
  font-style: italic;
}
.path {
  text-align: center;
}

.paths-grid {
  display: grid !important;
  grid-template-columns: repeat(9, auto) !important;
  align-items: start !important;
  justify-content: center !important;
  column-gap: 16px !important;
}
.path {
  min-width: 0;
  text-align: center;
}
.path-arrow {
  align-self: center;
  color: var(--teal);
  font-size: 26px;
  line-height: 1;
  margin-top: 6px;
  opacity: .75;
}


.footer-contact {
  display:flex;
  align-items:center;
  gap:0;
  flex-wrap:wrap;
}
.social-links {
  display:inline-flex;
  align-items:center;
  gap:12px;
  margin-left:2px;
}
.social-icon {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--teal);
  line-height:1;
}
.social-icon:hover,
.social-icon:focus {
  opacity:.75;
}
.social-icon:focus {
  outline:1px solid var(--teal);
  outline-offset:4px;
}

.social-icon svg {
  display:block;
  width:20px;
  height:20px;
  flex:0 0 20px;
}


/* CP8 mobile pathway reset */
@media(max-width:900px) {
  .paths-grid {
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:22px !important;
    max-width:520px;
    margin:0 auto;
  }
  .path-arrow {
    display:none !important;
  }
  .path {
    padding-top:20px;
  }
}
