:root {
  --cl-space: #061724;
  --cl-orbit: #0B2B3A;
  --cl-orbit-2: #143C4C;
  --cl-blue: #0B5D7E;
  --cl-blue-dark: #084E68;
  --cl-blue-2: #2A89A6;
  --cl-cyan: #42C7D9;
  --cl-cyan-dark: #087CA7;
  --cl-gold: #C9861A;
  --cl-warning: #9A6A16;
  --cl-danger: #B85C38;
  --cl-success: #0B5D7E;
  --cl-complete: #0B5D7E;
  --cl-progress: #2A6F8C;
  --cl-status-neutral: #AFC1CB;
  --cl-sand: #F7F2E8;
  --cl-ice: #F3F8FA;
  --cl-cloud: #ffffff;
  --cl-ink: #102033;
  --cl-muted: #607381;
  --cl-line: rgba(16, 32, 51, 0.12);
  --cl-line-strong: rgba(16, 32, 51, 0.2);
  --cl-shadow-sm: 0 1px 2px rgba(6, 24, 38, 0.08), 0 8px 24px rgba(6, 24, 38, 0.06);
  --cl-shadow-md: 0 18px 45px rgba(6, 24, 38, 0.14);
  --cl-shadow-lg: 0 32px 90px rgba(6, 24, 38, 0.22);
  --cl-radius-sm: 0.55rem;
  --cl-radius-md: 1rem;
  --cl-radius-lg: 1.6rem;
  --cl-radius-xl: 2.2rem;
  --cl-max: 1180px;
  --cl-narrow: 780px;
  --cl-gutter: clamp(1rem, 4vw, 2.5rem);
  --cl-font-body: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --cl-font-heading: "Source Sans 3", Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --cl-font-mono: "IBM Plex Mono", "SFMono-Regular", Consolas, "Liberation Mono", monospace;
  --cl-ease: cubic-bezier(.2,.8,.2,1);

  /* Backwards-compatible aliases used by earlier template code. */
  --cl-teal: var(--cl-blue);
  --cl-teal-dark: var(--cl-blue-dark);
  --cl-coral: var(--cl-danger);
  --cl-amber: var(--cl-gold);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .001ms !important; }
}
body {
  margin: 0;
  background: var(--cl-ice);
  color: var(--cl-ink);
  font-family: var(--cl-font-body);
  font-size: clamp(1rem, 0.45vw + 0.92rem, 1.125rem);
  line-height: 1.65;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}
img, svg, video { max-width: 100%; height: auto; }
a { color: #0B5D7E; text-decoration-thickness: .08em; text-underline-offset: .2em; }
a:hover { color: var(--cl-blue-dark); }
:focus-visible { outline: 3px solid var(--cl-gold); outline-offset: 3px; }
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }
.screen-reader-text {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.screen-reader-text:focus {
  top: 1rem;
  left: 1rem;
  z-index: 100000;
  display: block;
  width: auto;
  height: auto;
  padding: .75rem 1rem;
  clip: auto;
  color: var(--cl-space);
  background: var(--cl-gold);
  border-radius: var(--cl-radius-sm);
}

.section-shell {
  width: min(var(--cl-max), calc(100% - (var(--cl-gutter) * 2)));
  margin-inline: auto;
}
.section-shell--narrow { width: min(var(--cl-narrow), calc(100% - (var(--cl-gutter) * 2))); }
.site-main { min-height: 62vh; }
.prose { max-width: var(--cl-narrow); }
.prose > * + * { margin-top: 1.1em; }
.prose h2, .prose h3, .prose h4 { margin-top: 1.6em; }
.prose h2 { font-size: clamp(1.75rem, 2.5vw, 2.5rem); }
.prose h3 { font-size: clamp(1.35rem, 2vw, 1.8rem); }
.prose table { width: 100%; border-collapse: collapse; overflow: hidden; border-radius: var(--cl-radius-md); }
.prose th, .prose td { padding: .85rem 1rem; border: 1px solid var(--cl-line); text-align: left; }
.prose th { background: #e9f3f5; }
.prose blockquote { margin-inline: 0; padding: 1rem 1.25rem; border-left: 4px solid var(--cl-blue); background: #eef8f8; border-radius: 0 var(--cl-radius-md) var(--cl-radius-md) 0; }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin: 0 0 .9rem;
  color: var(--cl-blue-dark);
  font-family: var(--cl-font-mono);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .12em;
  line-height: 1.2;
  text-transform: uppercase;
}
.eyebrow::before {
  content: "";
  display: inline-block;
  width: .6rem;
  height: .6rem;
  border-radius: 999px;
  background: var(--cl-blue);
  box-shadow: 0 0 0 .28rem rgba(11, 93, 126, .16);
}
.eyebrow--light { color: #bffcff; }
.eyebrow--light::before { background: var(--cl-cyan); box-shadow: 0 0 0 .28rem rgba(66, 199, 217, .18); }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--cl-font-heading);
  color: var(--cl-space);
  line-height: 1.08;
  letter-spacing: -.03em;
}
h1 { font-size: clamp(2.55rem, 7vw, 5.8rem); margin: 0 0 1rem; }
h2 { font-size: clamp(2rem, 4.8vw, 3.65rem); margin: 0 0 .8rem; }
h3 { font-size: clamp(1.35rem, 2.5vw, 2rem); margin: 0 0 .65rem; }
p { margin-top: 0; }

.button, .wp-block-button__link, button[type="submit"], input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  min-height: 2.85rem;
  padding: .82rem 1.15rem;
  border: 1px solid transparent;
  border-radius: 999px;
  font-weight: 800;
  line-height: 1.1;
  text-decoration: none;
  transition: transform .18s var(--cl-ease), background-color .18s var(--cl-ease), border-color .18s var(--cl-ease), box-shadow .18s var(--cl-ease);
}
.button:hover, .wp-block-button__link:hover, button[type="submit"]:hover, input[type="submit"]:hover { transform: translateY(-1px); }
.button--primary, .wp-block-button:not(.is-style-outline) .wp-block-button__link, button[type="submit"], input[type="submit"] {
  background: linear-gradient(135deg, var(--cl-space), var(--cl-orbit-2));
  color: #fff;
  box-shadow: 0 13px 30px rgba(6, 23, 36, .22);
}
.button--ghost {
  background: rgba(255,255,255,.08);
  color: #fff;
  border-color: rgba(255,255,255,.28);
  backdrop-filter: blur(12px);
}
.button-row { display: flex; flex-wrap: wrap; gap: .8rem; align-items: center; }
.text-link { font-weight: 800; color: #0B5D7E; text-decoration: none; }
.text-link::after { content: " →"; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(244,248,250,.86);
  border-bottom: 1px solid rgba(16,32,51,.08);
  backdrop-filter: blur(22px);
  transition: box-shadow .2s var(--cl-ease), background-color .2s var(--cl-ease);
}
.site-header.is-scrolled { box-shadow: var(--cl-shadow-sm); background: rgba(255,255,255,.9); }
.site-header__inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 1rem;
  align-items: center;
  min-height: 82px;
}
.site-branding {
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  color: var(--cl-space);
  text-decoration: none;
}
.site-branding__mark { width: 46px; height: 46px; filter: drop-shadow(0 10px 18px rgba(6,24,38,.16)); }
.site-branding__text { display: grid; line-height: 1.1; }
.site-branding__name { font-weight: 900; letter-spacing: -.03em; }
.site-branding__tagline { max-width: 22rem; color: var(--cl-muted); font-size: .78rem; line-height: 1.25; }
.main-navigation { justify-self: end; }
.primary-menu, .utility-menu, .footer-menu {
  display: flex;
  flex-wrap: wrap;
  gap: .2rem;
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
}
.primary-menu a, .utility-menu a {
  display: inline-flex;
  padding: .58rem .78rem;
  color: var(--cl-ink);
  border-radius: 999px;
  font-size: .94rem;
  font-weight: 760;
  text-decoration: none;
}
.primary-menu a:hover, .primary-menu .current-menu-item > a, .utility-menu a:hover {
  background: rgba(11,93,126,.1);
  color: var(--cl-blue-dark);
}
.utility-navigation { justify-self: end; }
.utility-menu a { background: var(--cl-space); color: #fff; }
.utility-menu a:hover { background: var(--cl-orbit-2); color: #fff; }
.menu-toggle { display: none; }

.site-footer {
  margin-top: clamp(4rem, 8vw, 7rem);
  background: var(--cl-space);
  color: rgba(255,255,255,.78);
  overflow: hidden;
}
.site-footer::before {
  content: "";
  display: block;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--cl-blue), var(--cl-cyan), transparent);
}
.site-footer__top, .site-footer__bottom {
  display: flex;
  justify-content: space-between;
  gap: 2rem;
}
.site-footer__top { padding-block: 3.5rem; }
.site-footer__bottom { padding-block: 1.15rem; border-top: 1px solid rgba(255,255,255,.12); }
.site-footer__brand { display: flex; gap: 1rem; align-items: center; max-width: 34rem; }
.site-footer__name { margin: 0; color: #fff; font-weight: 900; font-size: 1.25rem; }
.site-footer__description { margin: .25rem 0 0; color: rgba(255,255,255,.68); }
.footer-menu a { color: rgba(255,255,255,.78); text-decoration: none; font-size: .93rem; }
.footer-menu a:hover { color: #fff; }
.site-footer__widgets { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 2rem; min-width: 32%; }
.footer-widget__title { color: #fff; font-size: 1.05rem; }

.front-hero {
  position: relative;
  isolation: isolate;
  min-height: min(82vh, 850px);
  padding: clamp(4rem, 10vw, 8rem) 0;
  color: #fff;
  background: var(--cl-space);
  overflow: hidden;
}
.front-hero__background {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(6,24,38,.95) 0%, rgba(6,24,38,.88) 34%, rgba(6,24,38,.36) 100%),
    radial-gradient(circle at 82% 18%, rgba(42,199,228,.22), transparent 25%),
    url('../svg/hero-satellite-field.svg') center/cover no-repeat;
}
.front-hero::after {
  content: "";
  position: absolute;
  inset: auto -12% -34% -12%;
  height: 55%;
  z-index: -1;
  background: radial-gradient(closest-side, rgba(11,92,173,.26), transparent 70%);
}
.front-hero__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .75fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.front-hero h1 { color: #fff; max-width: 12ch; text-wrap: balance; }
.front-hero__copy > p:not(.eyebrow) { max-width: 42rem; color: rgba(255,255,255,.82); font-size: clamp(1.1rem, 1.2vw, 1.35rem); }
.front-hero__panel {
  display: grid;
  gap: .9rem;
  padding: .75rem;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: var(--cl-radius-xl);
  background: rgba(8, 36, 52, .52);
  box-shadow: var(--cl-shadow-lg);
  backdrop-filter: blur(18px);
}
.mission-card {
  display: grid;
  grid-template-columns: 3rem 1fr;
  gap: .4rem 1rem;
  padding: 1.05rem;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--cl-radius-lg);
  background: rgba(255,255,255,.06);
}
.mission-card span {
  grid-row: span 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: 999px;
  background: rgba(66,199,217,.13);
  color: var(--cl-cyan);
  font-family: var(--cl-font-mono);
  font-weight: 800;
}
.mission-card strong { color: #fff; font-size: 1.15rem; }
.mission-card p { margin: 0; color: rgba(255,255,255,.7); font-size: .95rem; }
.mission-card--active { border-color: rgba(42,199,228,.46); background: rgba(11,92,173,.16); }

.front-section { padding-block: clamp(4rem, 8vw, 7rem); }
.front-section + .front-section { padding-top: 0; }
.section-heading { max-width: 720px; margin-bottom: clamp(1.5rem, 4vw, 3rem); }
.feature-grid, .post-grid, .lms-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.4rem);
}
.feature-card, .entry-card, .lms-card, .not-found-card, .no-results, .widget {
  border: 1px solid var(--cl-line);
  border-radius: var(--cl-radius-lg);
  background: rgba(255,255,255,.92);
  box-shadow: var(--cl-shadow-sm);
}
.feature-card { padding: clamp(1.25rem, 2vw, 1.75rem); }
.feature-card img { display: block; margin-bottom: 1.1rem; }
.feature-card p { color: var(--cl-muted); margin-bottom: 0; }
.front-section--courses { border-top: 1px solid var(--cl-line); }

.entry, .entry--page { padding-block: clamp(3rem, 8vw, 6rem); }
.entry-header { margin-bottom: clamp(1.5rem, 4vw, 2.5rem); }
.entry-title { text-wrap: balance; }
.entry-media { margin: 0 0 1.2rem; overflow: hidden; border-radius: var(--cl-radius-md); background: var(--cl-orbit); }
.entry-media img { display: block; width: 100%; aspect-ratio: 16/10; object-fit: cover; transition: transform .4s var(--cl-ease); }
.entry-card:hover .entry-media img { transform: scale(1.035); }
.entry-card { display: flex; flex-direction: column; overflow: hidden; }
.entry-card .entry-header, .entry-card .entry-summary, .entry-card .text-link { padding-inline: 1.25rem; }
.entry-card .entry-header { margin: 0 0 .5rem; padding-top: .5rem; }
.entry-card .entry-title { margin: 0; font-size: 1.35rem; }
.entry-card .entry-title a { color: var(--cl-space); text-decoration: none; }
.entry-card .entry-summary { color: var(--cl-muted); }
.entry-card .text-link { margin: auto 0 1.25rem; }
.entry-meta, .posted-on { color: var(--cl-muted); font-size: .88rem; }
.archive-header, .lms-archive-header, .dashboard-hero { padding-block: clamp(3.5rem, 8vw, 6rem) clamp(2rem, 4vw, 3rem); }
.archive-title { margin: 0; }
.archive-description { color: var(--cl-muted); font-size: 1.12rem; }
.page-links, .post-navigation, .posts-navigation, .pagination { margin-top: 2rem; }
.nav-links { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between; }
.nav-links a, .page-numbers {
  display: inline-flex;
  align-items: center;
  min-height: 2.5rem;
  padding: .55rem .9rem;
  border: 1px solid var(--cl-line);
  border-radius: 999px;
  background: #fff;
  color: var(--cl-ink);
  text-decoration: none;
}
.page-numbers.current { background: var(--cl-space); color: #fff; }

.search-form { display: flex; gap: .5rem; max-width: 620px; }
.search-form label { flex: 1; }
.search-field, input[type="text"], input[type="email"], input[type="password"], input[type="url"], input[type="search"], textarea, select {
  width: 100%;
  min-height: 2.85rem;
  padding: .75rem .95rem;
  color: var(--cl-ink);
  background: #fff;
  border: 1px solid var(--cl-line-strong);
  border-radius: var(--cl-radius-sm);
}
textarea { min-height: 9rem; }
.not-found-card, .no-results { padding: clamp(1.5rem, 4vw, 3rem); margin-block: 4rem; }
.comments-area { margin-top: 4rem; padding-top: 2rem; border-top: 1px solid var(--cl-line); }
.comment-list { padding-left: 1.2rem; }
.comment-form input, .comment-form textarea { display: block; }

.lms-archive-header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 2rem;
}
.lms-archive-header__panel {
  display: grid;
  gap: .45rem;
  min-width: min(100%, 290px);
  padding: 1rem;
  border-radius: var(--cl-radius-lg);
  background: var(--cl-space);
  box-shadow: var(--cl-shadow-md);
}
.lms-archive-header__panel span {
  display: flex;
  justify-content: space-between;
  padding: .7rem .85rem;
  color: #fff;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--cl-radius-sm);
  font-family: var(--cl-font-mono);
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.lms-archive-header__panel span::after { content: "✓"; color: var(--cl-cyan); }
.lms-card { overflow: hidden; }
.lms-card__media { display: block; min-height: 190px; background: var(--cl-orbit); overflow: hidden; }
.lms-card__media img { display: block; width: 100%; aspect-ratio: 16/10; object-fit: cover; transition: transform .4s var(--cl-ease); }
.lms-card:hover .lms-card__media img { transform: scale(1.035); }
.lms-card__media--generated { background: url('../svg/card-orbit-pattern.svg') center/cover no-repeat, linear-gradient(135deg, var(--cl-orbit), var(--cl-blue-dark)); }
.lms-card__body { padding: 1.25rem; }
.lms-card__title { font-size: 1.35rem; }
.lms-card__title a { color: var(--cl-space); text-decoration: none; }
.lms-card__summary { color: var(--cl-muted); }

.dashboard-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, 360px); gap: 2rem; align-items: start; }
.dashboard-layout__main, .dashboard-layout__aside { min-width: 0; }
.dashboard-layout__aside { display: grid; gap: 1rem; }
.widget { padding: 1.25rem; }
.widget-title { font-size: 1.15rem; }

.pattern-hero, .activation-workflow, .role-path-cards > .wp-block-column {
  border-radius: var(--cl-radius-lg);
}
.pattern-hero {
  padding: clamp(3rem, 8vw, 6rem);
  color: #fff;
  background: linear-gradient(135deg, rgba(6,24,38,.98), rgba(8,70,82,.9)), url('../svg/hero-satellite-field.svg') center/cover no-repeat;
}
.pattern-hero h1 { color: #fff; }
.pattern-hero p:not(.eyebrow) { color: rgba(255,255,255,.8); }
.role-path-cards > .wp-block-column { padding: 1.25rem; background: #fff; border: 1px solid var(--cl-line); box-shadow: var(--cl-shadow-sm); }
.activation-workflow { padding: 1.5rem; background: #fff; border: 1px solid var(--cl-line); }

@media (max-width: 1080px) {
  .site-header__inner { grid-template-columns: auto auto; }
  .utility-navigation { display: none; }
  .front-hero__inner { grid-template-columns: 1fr; }
  .front-hero h1 { max-width: 14ch; }
  .feature-grid, .post-grid, .lms-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .lms-archive-header { align-items: start; flex-direction: column; }
}
@media (max-width: 760px) {
  h1 { font-size: clamp(2.35rem, 15vw, 3.6rem); }
  .site-header__inner { min-height: 70px; }
  .site-branding__tagline { display: none; }
  .menu-toggle {
    display: inline-grid;
    place-items: center;
    justify-self: end;
    width: 2.75rem;
    height: 2.75rem;
    padding: 0;
    background: var(--cl-space);
    border: 0;
    border-radius: 999px;
  }
  .menu-toggle__bar, .menu-toggle__bar::before, .menu-toggle__bar::after {
    display: block;
    width: 1.2rem;
    height: 2px;
    background: #fff;
    border-radius: 999px;
    content: "";
    transition: transform .2s var(--cl-ease), opacity .2s var(--cl-ease);
  }
  .menu-toggle__bar::before { transform: translateY(-6px); }
  .menu-toggle__bar::after { transform: translateY(4px); }
  .menu-toggle[aria-expanded="true"] .menu-toggle__bar { background: transparent; }
  .menu-toggle[aria-expanded="true"] .menu-toggle__bar::before { transform: translateY(2px) rotate(45deg); }
  .menu-toggle[aria-expanded="true"] .menu-toggle__bar::after { transform: translateY(0) rotate(-45deg); }
  .main-navigation {
    position: fixed;
    inset: 70px 0 auto 0;
    display: none;
    padding: 1rem var(--cl-gutter) 1.4rem;
    background: rgba(255,255,255,.98);
    border-bottom: 1px solid var(--cl-line);
    box-shadow: var(--cl-shadow-md);
  }
  .has-open-menu .main-navigation { display: block; }
  .primary-menu { display: grid; gap: .35rem; }
  .primary-menu a { padding: .8rem 0; border-radius: 0; }
  .feature-grid, .post-grid, .lms-card-grid, .dashboard-layout { grid-template-columns: 1fr; }
  .site-footer__top, .site-footer__bottom { flex-direction: column; }
  .site-footer__widgets { grid-template-columns: 1fr; min-width: 0; }
  .search-form { flex-direction: column; }
}
