:root {
  --site-navy: #233746;
  --site-blue: #486b7c;
  --site-copper: #8a4f32;
  --site-gold: #b58a45;
  --site-cream: #f5efe4;
  --site-paper: #fffdf8;
  --site-ink: #251d18;
  --site-muted: #62584f;
  --site-line: #d7c9b7;
}

html { scroll-behavior: smooth; }
body { background: var(--site-cream); color: var(--site-ink); }
a { text-underline-offset: 0.18em; }
a:focus-visible, button:focus-visible, [tabindex]:focus-visible {
  outline: 3px solid #f3b83f;
  outline-offset: 4px;
}

.skip-link {
  position: fixed;
  left: 1rem;
  top: 1rem;
  z-index: 10000;
  padding: 0.8rem 1rem;
  background: #fff;
  color: #111;
  font-family: Inter, sans-serif;
  font-weight: 700;
  transform: translateY(-180%);
}
.skip-link:focus { transform: translateY(0); }
.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0);
  white-space: nowrap; border: 0;
}

.home-hero {
  background: linear-gradient(125deg, var(--site-navy), #39596a 72%, #6c4939);
  padding: clamp(2.4rem, 5vw, 3.6rem) 1.5rem;
  border-bottom-color: var(--site-gold);
}
.home-hero .banner-main-title,
.home-hero .banner-subtitle,
.home-hero .banner-quote { color: #fffaf0; text-shadow: none; }
.home-hero .banner-main-title { font-size: clamp(2.25rem, 5vw, 4.2rem); text-transform: none; line-height: 1.05; }
.home-hero .banner-subtitle { margin: 0.85rem 0; color: #eadcc8; }
.home-hero .banner-quote { color: #eadcc8; }
.eyebrow, .course-kicker, .modality-label {
  font-family: Inter, sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--site-copper);
}
.home-hero .eyebrow { color: #e8c98f; margin-bottom: 0.75rem; }
.main-nav { background: var(--site-navy); border-top: 0; display: flex; justify-content: center; flex-wrap: wrap; gap: 0.3rem; }
.nav-link { color: #fffaf0; margin: 0; padding: 0.7rem 1.15rem; }
.nav-link:hover { color: #ffe0a6; border-bottom-color: #ffe0a6; }
.compact-intro { padding: 1.5rem 1rem 2.5rem; margin-bottom: 1rem; }
.compact-intro .welcome-text { max-width: 880px; margin: 1rem auto; font-style: normal; }

.catalog-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1.5rem; }
.catalog-card {
  background: var(--site-paper);
  border: 1px solid var(--site-line);
  border-top: 5px solid var(--site-blue);
  border-radius: 10px;
  padding: 2rem;
  box-shadow: 0 7px 22px rgba(45, 34, 26, 0.09);
}
.catalog-card h3 { font: 900 clamp(1.7rem, 3vw, 2.4rem)/1.1 'Playfair Display', serif; margin: 0.35rem 0 0.1rem; color: var(--site-navy); }
.catalog-card h4 { font: 600 1.08rem/1.4 Lora, serif; margin-bottom: 0.9rem; }
.catalog-card p { color: var(--site-muted); }
.featured-course { grid-column: span 1; border-top-color: var(--site-copper); }
.modality-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.8rem; margin-top: 1.4rem; }
.modality-card {
  display: flex; flex-direction: column; gap: 0.35rem;
  min-height: 150px; padding: 1rem;
  background: #f8f2e8; color: var(--site-ink);
  border: 1px solid #d9c6ad; border-radius: 7px;
  text-decoration: none; transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.modality-card.online { background: #edf3f5; border-color: #b8ccd3; }
.modality-card strong { font: 700 1.05rem Inter, sans-serif; color: var(--site-navy); }
.modality-card span:last-child { font-size: 0.88rem; line-height: 1.45; color: var(--site-muted); }
.modality-card:hover { transform: translateY(-3px); box-shadow: 0 7px 16px rgba(35, 55, 70, 0.13); }
.course-button { margin-top: 1rem; background: var(--site-navy); color: #fff; }
.course-button:hover { background: var(--site-copper); }
.upcoming-course {
  border-top-color: var(--site-gold);
  background: linear-gradient(145deg, var(--site-paper), #f5ecdc);
}
.coming-soon-label {
  display: inline-block;
  margin-top: 1rem;
  padding: 0.5rem 0.8rem;
  border: 1px solid #b58a45;
  border-radius: 999px;
  color: #694817 !important;
  background: #fff6df;
  font-family: Inter, sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.lyceum-card { background: linear-gradient(145deg, #263b49, #172733); border-top-color: var(--site-gold); }
.lyceum-card h3, .lyceum-card h4, .lyceum-card p { color: #fffaf0; }
.lyceum-card .course-kicker, .access-note { color: #f0c87c !important; }

.resource-section { padding: 5rem 0 3rem; }
.resource-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1rem; }
.resource-card { display: flex; flex-direction: column; gap: 0.45rem; padding: 1.35rem; background: var(--site-paper); border: 1px solid var(--site-line); border-radius: 8px; color: var(--site-ink); text-decoration: none; }
.resource-card strong { color: var(--site-navy); font-family: 'Playfair Display', serif; font-size: 1.08rem; }
.resource-card span { color: var(--site-muted); font-size: 0.9rem; }
.resource-card:hover { border-color: var(--site-copper); box-shadow: 0 6px 15px rgba(45, 34, 26, 0.1); }
.left-aligned { text-align: left; }
.content-box { background: var(--site-paper); border-color: var(--site-line); }
.contact-item { background: #f4ede1; border-color: var(--site-line); }
.contact-item h3 { font-family: 'Playfair Display', serif; color: var(--site-navy); }
.site-footer { background: var(--site-navy); }
.footer-text, .footer-quote { color: #efe3d1; }

.modality-switcher {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 0.65rem;
  padding: 0.8rem 1rem; background: #f7f1e7; border-bottom: 1px solid #d8c9b6;
  font-family: Inter, sans-serif;
}
.modality-switcher strong { align-self: center; color: var(--site-navy); }
.modality-switcher a, .modality-switcher span {
  padding: 0.45rem 0.8rem; border-radius: 999px; border: 1px solid #9f8870;
  color: var(--site-navy); text-decoration: none; background: #fff;
}
.modality-switcher .current { background: var(--site-navy); color: #fff; border-color: var(--site-navy); }
.protected-note { font-family: Inter, sans-serif; font-size: 0.82rem; font-weight: 600; }
.availability-note { padding: 0.9rem 1rem; background: #fff8e8; border: 1px solid #d3b779; border-radius: 6px; color: #5a4218; }

@media (max-width: 850px) {
  .catalog-grid, .resource-grid { grid-template-columns: 1fr; }
  .main-nav { position: static; }
}
@media (max-width: 560px) {
  .container { padding-left: 1rem; padding-right: 1rem; }
  .main-nav { display: grid; grid-template-columns: repeat(2, 1fr); padding: 0.6rem; }
  .nav-link { display: block; text-align: center; padding: 0.65rem 0.35rem; font-size: 0.78rem; }
  .modality-grid { grid-template-columns: 1fr; }
  .catalog-card { padding: 1.35rem; }
  .content-box { padding: 1.5rem; }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
}
