:root {
  --bg: #f4f6fb;
  --surface: #ffffff;
  --ink: #0f1b2d;
  --muted: #526071;
  --primary: #1847c8;
  --primary-dark: #0f35a0;
  --primary-ink: #ffffff;
  --accent: #f5a623;
  --accent-dark: #d48a0c;
  --accent-ink: #1a0e00;
  --border: #dde3ef;
  --radius: 12px;
  --shadow: 0 12px 36px -14px rgba(24,71,200,.22);
  --shadow-md: 0 6px 18px -8px rgba(15,27,45,.18);
  --maxw: 1440px;
  --pad: clamp(1.25rem, 5vw, 3.5rem);
  --h1: clamp(3rem, 6.5vw, 5rem);
  --h2: clamp(2rem, 3.8vw, 3.1rem);
  --h3: clamp(1.25rem, 2.2vw, 1.55rem);
  --font-head: 'Outfit', system-ui, sans-serif;
  --font-body: 'Public Sans', system-ui, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 19px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}
.locked { overflow: hidden; }

h1, h2, h3 {
  font-family: var(--font-head);
  line-height: 1.08;
  font-weight: 700;
  letter-spacing: -.02em;
}
h1 { font-size: var(--h1); margin: 0 0 .45em; }
h2 { font-size: var(--h2); margin: 0 0 .5em; }
h3 { font-size: var(--h3); margin: 0 0 .4em; }
p { margin: 0 0 1rem; }
a { color: inherit; }
img { max-width: 100%; display: block; }
ul { margin: 0; padding: 0; }

.bound { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad); }
.block { padding: clamp(3.5rem, 9vw, 6.5rem) 0; }
.block--alt { background: var(--surface); border-block: 1px solid var(--border); }
.block--blue { background: var(--primary); color: #fff; }
.block--dark { background: var(--ink); color: #cbd5e8; }

.label {
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: .78rem;
  font-weight: 700;
  color: var(--accent);
  margin: 0 0 .7rem;
  font-family: var(--font-body);
}
.label--light { color: var(--accent); }
.intro { font-size: 1.15rem; color: var(--muted); max-width: 62ch; }
.intro--light { color: #b8c6e8; }
.mid { text-align: center; margin-inline: auto; }

.cta {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .9rem 1.7rem;
  border-radius: 8px;
  font-weight: 700;
  font-family: var(--font-body);
  text-decoration: none;
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
  font-size: 1rem;
  letter-spacing: -.01em;
}
.cta:hover { transform: translateY(-2px); }
.cta--primary {
  background: var(--primary);
  color: var(--primary-ink);
  border-color: var(--primary);
}
.cta--primary:hover { background: var(--primary-dark); border-color: var(--primary-dark); }
.cta--accent {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}
.cta--accent:hover { background: var(--accent-dark); border-color: var(--accent-dark); }
.cta--ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--border);
}
.cta--ghost:hover { border-color: var(--primary); color: var(--primary); }
.cta--ghost-lt {
  background: transparent;
  color: #fff;
  border-color: rgba(255,255,255,.5);
}
.cta--ghost-lt:hover { border-color: #fff; }

:focus-visible {
  outline: 3px solid var(--accent);
  outline-offset: 3px;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in srgb, var(--surface) 90%, transparent);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
.navrow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .85rem 0;
}
.logo {
  font-family: var(--font-head);
  font-weight: 800;
  font-size: 1.25rem;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: .5rem;
  color: var(--ink);
  letter-spacing: -.03em;
}
.logo__mark {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.logo__mark svg { display: block; }

.navset {
  display: flex;
  align-items: center;
  gap: 1.8rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
.navset a {
  text-decoration: none;
  font-weight: 500;
  color: var(--ink);
  font-size: .97rem;
  transition: color .15s;
}
.navset a:hover { color: var(--primary); }
.navset .cta { padding: .6rem 1.2rem; }

.navtoggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: 0;
  cursor: pointer;
  padding: 8px;
}
.navtoggle span {
  width: 26px;
  height: 2.5px;
  background: var(--ink);
  border-radius: 2px;
  transition: .25s;
  display: block;
}
.navtoggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
.navtoggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.navtoggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }

.banner {
  background: var(--primary);
  color: #fff;
  padding: clamp(3rem, 8vw, 6rem) 0;
  position: relative;
  overflow: hidden;
}
.banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 70% 50%, rgba(245,166,35,.18) 0%, transparent 70%);
  pointer-events: none;
}
.banner__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
  position: relative;
}
.banner__tag {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: rgba(245,166,35,.18);
  border: 1px solid rgba(245,166,35,.4);
  color: var(--accent);
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: .35rem .9rem;
  border-radius: 999px;
  margin-bottom: 1.2rem;
  font-family: var(--font-body);
}
.banner h1 { color: #fff; margin-bottom: .5em; }
.banner h1 em { color: var(--accent); font-style: normal; }
.banner .intro { color: #b3c4ef; max-width: 52ch; }
.banner__cta {
  display: flex;
  gap: .9rem;
  flex-wrap: wrap;
  margin-top: 1.6rem;
}
.banner__media {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: 0 24px 60px -20px rgba(0,0,0,.5);
}
.banner__media img {
  width: 100%;
  aspect-ratio: 16/11;
  object-fit: cover;
  display: block;
}
.banner__badge {
  position: absolute;
  right: 1rem;
  bottom: 1rem;
  background: var(--accent);
  color: var(--accent-ink);
  padding: .55rem 1rem;
  border-radius: 8px;
  font-size: .85rem;
  font-weight: 700;
  font-family: var(--font-body);
}

.figband {
  background: var(--ink);
  padding: clamp(2rem, 5vw, 3.5rem) 0;
  border: 0;
}
.figs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  text-align: center;
}
.fig__num {
  font-family: var(--font-head);
  font-size: clamp(2.2rem, 4.5vw, 3.2rem);
  color: var(--accent);
  font-weight: 800;
  letter-spacing: -.03em;
  line-height: 1;
}
.fig__cap { color: #8fa0be; font-size: .95rem; margin-top: .35rem; }

.cols { display: grid; gap: 1.5rem; }
.cols--3 { grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); }
.cols--2 { grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); }
.cols--4 { grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); }

.tile {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.7rem;
  box-shadow: var(--shadow-md);
  transition: transform .2s, box-shadow .2s;
}
.tile:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.tile--media { padding: 0; overflow: hidden; }
.tile--media img { width: 100%; height: 210px; object-fit: cover; }
.tile--media .tile__body { padding: 1.5rem; }
.tile ul { list-style: none; padding: 0; margin: .7rem 0 0; color: var(--muted); }
.tile li {
  padding: .2rem 0;
  padding-left: 1.2rem;
  position: relative;
}
.tile li::before {
  content: '';
  position: absolute;
  left: 0;
  top: .6em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
}

.pill {
  display: inline-block;
  font-size: .73rem;
  font-weight: 700;
  color: var(--primary);
  letter-spacing: .1em;
  text-transform: uppercase;
  background: rgba(24,71,200,.08);
  padding: .2rem .6rem;
  border-radius: 4px;
  margin-bottom: .5rem;
}

.duo {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}
.duo img {
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  width: 100%;
  object-fit: cover;
  aspect-ratio: 5/4;
}

.ladder {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  counter-reset: step;
}
.rung {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.7rem;
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-md);
}
.rung::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--accent);
}
.rung__num {
  font-family: var(--font-head);
  font-size: 3rem;
  font-weight: 800;
  color: rgba(24,71,200,.12);
  line-height: 1;
  margin-bottom: .3rem;
  letter-spacing: -.04em;
}
.rung h3 { font-size: 1.1rem; margin-bottom: .4rem; }

.edge {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius);
  padding: 1.7rem;
}
.edge h3 { color: #fff; font-size: 1.05rem; }
.edge p { color: #8fa0be; margin: 0; }
.edge__icon {
  width: 44px;
  height: 44px;
  background: rgba(245,166,35,.15);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: .9rem;
}
.edge__icon svg { color: var(--accent); }

.pullquote {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.8rem;
  box-shadow: var(--shadow-md);
  position: relative;
}
.pullquote::before {
  content: '\201C';
  font-family: var(--font-head);
  font-size: 4rem;
  color: rgba(24,71,200,.12);
  position: absolute;
  top: .5rem;
  left: 1.2rem;
  line-height: 1;
}
.pullquote p { font-size: 1.05rem; color: var(--muted); padding-top: 1.5rem; }
.pullquote footer { margin-top: .9rem; font-weight: 700; font-family: var(--font-head); }
.pullquote footer span { display: block; font-weight: 400; color: var(--muted); font-size: .88rem; font-family: var(--font-body); }

.accordion details {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.1rem 1.4rem;
  margin-bottom: .7rem;
  box-shadow: var(--shadow-md);
}
.accordion summary {
  cursor: pointer;
  font-weight: 600;
  list-style: none;
  font-family: var(--font-body);
  padding-right: 2rem;
  position: relative;
}
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary::after {
  content: '+';
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  color: var(--accent);
  font-size: 1.4rem;
  line-height: 1;
  font-family: var(--font-head);
}
.accordion details[open] summary::after { content: '\2212'; }
.accordion details p { margin-top: .7rem; color: var(--muted); }

.endcta {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  color: #fff;
  padding: clamp(3rem, 7vw, 5rem);
  text-align: center;
}
.endcta img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -2;
}
.endcta::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(24,71,200,.88) 0%, rgba(15,35,100,.92) 100%);
  z-index: -1;
}
.endcta h2 { color: #fff; max-width: 18ch; margin-inline: auto; }
.endcta .intro { color: #b3c4ef; margin-inline: auto; }

.pagetop {
  background: var(--primary);
  color: #fff;
  padding: clamp(3rem, 7vw, 5rem) 0;
  position: relative;
  overflow: hidden;
}
.pagetop::after {
  content: '';
  position: absolute;
  top: -50%;
  right: -10%;
  width: 60vmax;
  height: 60vmax;
  border-radius: 50%;
  background: rgba(245,166,35,.07);
  pointer-events: none;
}
.pagetop .label { color: var(--accent); }
.pagetop h1 { color: #fff; }
.pagetop p { color: #b3c4ef; max-width: 60ch; margin: 0; }

.reach {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: clamp(2rem, 5vw, 4rem);
}
.fld { margin-bottom: 1.1rem; }
.fld label { display: block; font-weight: 600; font-size: .92rem; margin-bottom: .35rem; }
.fld input,
.fld textarea,
.fld select {
  width: 100%;
  padding: .82rem 1rem;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  font: inherit;
  background: var(--surface);
  color: var(--ink);
  transition: border-color .15s;
}
.fld input:focus,
.fld textarea:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(24,71,200,.12); }
.agreebox { display: flex; gap: .7rem; align-items: flex-start; font-size: .92rem; color: var(--muted); }
.agreebox input { margin-top: .25rem; accent-color: var(--primary); flex-shrink: 0; }
.form-flash { margin-top: .6rem; font-size: .92rem; min-height: 1.3em; }
.form-flash.error { color: #c0392b; }
.form-flash.ok { color: #1e7a44; }
.info { list-style: none; padding: 0; margin: 0; }
.info li { padding: .8rem 0; border-bottom: 1px solid var(--border); }
.info strong {
  display: block;
  color: var(--primary);
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-bottom: .2rem;
}
.mapframe {
  margin-top: 1rem;
  height: 200px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: repeating-linear-gradient(
    45deg,
    #e8edf6,
    #e8edf6 14px,
    #dde4f0 14px,
    #dde4f0 28px
  );
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  font-size: .9rem;
  font-weight: 500;
}

.policy { max-width: 760px; margin: 0 auto; }
.policy h2 { margin-top: 2.2rem; color: var(--primary); }
.policy h3 { margin-top: 1.5rem; }
.policy ul { list-style: disc; padding-left: 1.4rem; color: var(--muted); }
.policy ul li { margin: .3rem 0; }
.policy .revised { color: var(--muted); font-size: .9rem; margin-bottom: 2rem; border-left: 3px solid var(--accent); padding-left: .75rem; }

.footzone {
  background: var(--ink);
  color: #8fa0be;
  padding: 4rem 0 1.5rem;
  margin-top: 0;
}
.footzone a { color: #8fa0be; text-decoration: none; transition: color .15s; }
.footzone a:hover { color: #fff; }
.footzone__cols {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: 2.5rem;
}
.footzone .logo { color: #fff; margin-bottom: .8rem; }
.footzone .logo__mark { background: var(--accent); }
.footzone__cols h4 {
  color: #fff;
  font-family: var(--font-head);
  font-size: 1rem;
  margin: 0 0 1rem;
  font-weight: 700;
}
.footzone__cols ul { list-style: none; padding: 0; margin: 0; }
.footzone__cols li { margin: .45rem 0; font-size: .95rem; }
.footzone__desc { font-size: .95rem; line-height: 1.6; max-width: 32ch; }
.footzone__base {
  border-top: 1px solid rgba(255,255,255,.1);
  margin-top: 3rem;
  padding-top: 1.2rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .8rem;
  font-size: .88rem;
  color: #526071;
}

.consent {
  position: fixed;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 80;
  background: var(--ink);
  color: #cbd5e8;
  border-radius: 12px;
  padding: 1.2rem 1.5rem;
  box-shadow: 0 20px 60px -20px rgba(0,0,0,.7);
  display: flex;
  gap: 1rem;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  max-width: 780px;
  margin-inline: auto;
  border: 1px solid rgba(255,255,255,.08);
}
.consent p { margin: 0; font-size: .92rem; }
.consent a { color: var(--accent); text-decoration: underline; }
.consent__btns { display: flex; gap: .6rem; flex-shrink: 0; }
.consent .cta { padding: .55rem 1.1rem; font-size: .9rem; }

.virtue {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.8rem;
  box-shadow: var(--shadow-md);
}
.virtue h3 {
  font-size: 1.05rem;
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: .4rem;
}
.virtue__n {
  display: inline-flex;
  width: 28px;
  height: 28px;
  align-items: center;
  justify-content: center;
  background: var(--primary);
  color: #fff;
  border-radius: 6px;
  font-size: .8rem;
  font-weight: 700;
  flex-shrink: 0;
}

.feature-shot {
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  width: 100%;
  object-fit: cover;
  aspect-ratio: 16/9;
  margin: 2rem 0;
}

@media (max-width: 900px) {
  .navtoggle { display: flex; }
  .navset {
    position: fixed;
    inset: 65px 0 auto 0;
    flex-direction: column;
    align-items: flex-start;
    gap: .3rem;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    padding: 1.2rem var(--pad) 1.5rem;
    transform: translateY(-130%);
    transition: transform .3s ease;
    box-shadow: var(--shadow);
    z-index: 40;
  }
  .navset.shown { transform: translateY(0); }
  .navset li { width: 100%; }
  .navset a { display: block; padding: .55rem 0; width: 100%; }
  .navset .cta { width: 100%; justify-content: center; margin-top: .5rem; }
  .banner__inner { grid-template-columns: 1fr; }
  .banner__media { order: -1; }
  .duo { grid-template-columns: 1fr; }
  .reach { grid-template-columns: 1fr; }
  .footzone__cols { grid-template-columns: 1fr 1fr; }
  .figs { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .footzone__cols { grid-template-columns: 1fr; }
  .footzone__base { flex-direction: column; }
  .banner__cta { flex-direction: column; }
  .banner__cta .cta { width: 100%; justify-content: center; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition: none !important; scroll-behavior: auto; }
}

.fld.agreebox{display:flex !important;gap:.6rem;align-items:flex-start;flex-wrap:nowrap}
.fld.agreebox input[type="checkbox"]{
  width:18px !important;height:18px !important;min-width:18px;max-width:18px;
  flex:0 0 18px;margin:.18rem 0 0 0;padding:0;box-sizing:border-box}
.fld.agreebox label{margin:0;font-weight:400;line-height:1.5;flex:1 1 auto}

.track {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.7rem;
  box-shadow: var(--shadow-md);
  transition: transform .2s, box-shadow .2s;
}
.track:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.track h3 { font-size: 1.05rem; margin-bottom: .35rem; }
.track p { color: var(--muted); margin: 0; font-size: .95rem; }
.track__icon {
  width: 48px;
  height: 48px;
  background: rgba(24,71,200,.08);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
  color: var(--primary);
  flex-shrink: 0;
}

.outcome {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.8rem;
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  transition: transform .2s, box-shadow .2s;
}
.outcome:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.outcome__metric {
  font-family: var(--font-head);
  font-size: clamp(2.2rem, 4vw, 2.8rem);
  font-weight: 800;
  color: var(--primary);
  letter-spacing: -.04em;
  line-height: 1;
}
.outcome__label {
  font-size: .83rem;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin: .3rem 0 .9rem;
  border-bottom: 2px solid var(--accent);
  padding-bottom: .7rem;
}
.outcome__body {
  color: var(--muted);
  font-size: .95rem;
  flex: 1;
  margin-bottom: .9rem;
}
.outcome__tag {
  font-size: .75rem;
  font-weight: 700;
  color: var(--primary);
  letter-spacing: .08em;
  text-transform: uppercase;
  background: rgba(24,71,200,.07);
  padding: .25rem .7rem;
  border-radius: 4px;
  display: inline-block;
  margin-top: auto;
}

.plans {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  align-items: start;
}
.plan {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 2rem;
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  position: relative;
}
.plan--featured {
  border-color: var(--primary);
  box-shadow: var(--shadow);
  transform: translateY(-6px);
}
@media (max-width: 900px) {
  .plan--featured { transform: none; }
}
.plan__flag {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--primary);
  color: #fff;
  font-size: .73rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .28rem .9rem;
  border-radius: 999px;
  white-space: nowrap;
}
.plan__name {
  font-family: var(--font-head);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: .5rem;
}
.plan__price {
  font-family: var(--font-head);
  font-size: clamp(2rem, 4vw, 2.5rem);
  font-weight: 800;
  color: var(--primary);
  letter-spacing: -.04em;
  line-height: 1;
  margin-bottom: .9rem;
}
.plan__price span {
  font-size: 1rem;
  font-weight: 500;
  color: var(--muted);
  letter-spacing: 0;
  font-family: var(--font-body);
}
.plan__desc {
  color: var(--muted);
  font-size: .95rem;
  margin-bottom: 1.2rem;
  border-bottom: 1px solid var(--border);
  padding-bottom: 1.2rem;
}
.plan__feats {
  list-style: none;
  padding: 0;
  margin: 0 0 1.6rem;
  flex: 1;
}
.plan__feats li {
  padding: .38rem 0 .38rem 1.5rem;
  position: relative;
  font-size: .95rem;
  color: var(--ink);
}
.plan__feats li::before {
  content: '';
  position: absolute;
  left: 0;
  top: .7em;
  width: 14px;
  height: 14px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14' fill='none'%3E%3Ccircle cx='7' cy='7' r='7' fill='%231847c8' opacity='.12'/%3E%3Cpath d='M4 7l2 2 4-4' stroke='%231847c8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;
}
.plan__feats li.is-off {
  color: var(--muted);
  opacity: .5;
}
.plan__feats li.is-off::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14' fill='none'%3E%3Ccircle cx='7' cy='7' r='7' fill='%23526071' opacity='.12'/%3E%3Cpath d='M5 9l4-4M9 9L5 5' stroke='%23526071' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
}
.plan .cta { width: 100%; justify-content: center; }
.plans-note {
  text-align: center;
  color: var(--muted);
  font-size: .92rem;
  margin-top: 1.8rem;
}

.mentor {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.7rem;
  box-shadow: var(--shadow-md);
  text-align: center;
  transition: transform .2s, box-shadow .2s;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.mentor:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.mentor__avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--av-bg, var(--primary));
  color: #fff;
  font-family: var(--font-head);
  font-size: 1.25rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
  letter-spacing: .01em;
  flex-shrink: 0;
}
.mentor__name {
  font-size: 1.05rem;
  margin-bottom: .2rem;
  text-align: center;
}
.mentor__role {
  font-size: .8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--primary);
  margin-bottom: .75rem;
}
.mentor__bio {
  color: var(--muted);
  font-size: .92rem;
  text-align: center;
  margin: 0;
}

.creds {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  align-items: stretch;
}
.cred {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.4rem 1.6rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .6rem;
  min-width: 140px;
  flex: 1 1 140px;
  max-width: 200px;
  box-shadow: var(--shadow-md);
  text-align: center;
  transition: transform .2s;
}
.cred:hover { transform: translateY(-2px); }
.cred__icon {
  font-family: var(--font-head);
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--primary);
  background: rgba(24,71,200,.08);
  width: 52px;
  height: 52px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: -.02em;
}
.cred__label {
  font-size: .78rem;
  font-weight: 600;
  color: var(--muted);
  line-height: 1.4;
}
.pledge {
  background: rgba(24,71,200,.04);
  border: 1px solid rgba(24,71,200,.15);
  border-left: 4px solid var(--accent);
  border-radius: var(--radius);
  padding: 1.4rem 1.8rem;
}
.pledge__inner {
  display: flex;
  gap: 1.2rem;
  align-items: flex-start;
  font-size: .97rem;
  color: var(--muted);
}
.pledge__inner strong { color: var(--ink); }

.post {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.8rem;
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  transition: transform .2s, box-shadow .2s;
}
.post:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.post__meta {
  display: flex;
  align-items: center;
  gap: .8rem;
  margin-bottom: .85rem;
  flex-wrap: wrap;
}
.post__meta time {
  font-size: .78rem;
  color: var(--muted);
  font-weight: 500;
}
.post h3 {
  font-size: 1.05rem;
  margin-bottom: .6rem;
  line-height: 1.3;
}
.post h3 a {
  text-decoration: none;
  color: var(--ink);
  transition: color .15s;
}
.post h3 a:hover { color: var(--primary); }
.post p {
  color: var(--muted);
  font-size: .93rem;
  flex: 1;
  margin-bottom: 1.1rem;
}
.post__link {
  font-size: .9rem;
  font-weight: 700;
  color: var(--primary);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  transition: gap .15s;
}
.post__link:hover { gap: .3rem; }

.story {
  position: relative;
  max-width: 860px;
  margin: 0 auto;
  padding-left: 3.5rem;
}
.story::before {
  content: '';
  position: absolute;
  left: 1.25rem;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--border);
}
.story__item {
  position: relative;
  margin-bottom: 2.5rem;
}
.story__item:last-child { margin-bottom: 0; }
.story__year {
  position: absolute;
  left: -3.5rem;
  top: .1rem;
  width: 2.5rem;
  text-align: center;
  font-family: var(--font-head);
  font-weight: 800;
  font-size: .78rem;
  color: var(--primary);
  letter-spacing: .02em;
}
.story__item::before {
  content: '';
  position: absolute;
  left: -2.4rem;
  top: .45rem;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--accent);
  border: 2px solid var(--surface);
  box-shadow: 0 0 0 2px var(--accent);
}
.story__body {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.4rem 1.6rem;
  box-shadow: var(--shadow-md);
}
.story__body h3 {
  font-size: 1rem;
  margin-bottom: .35rem;
  color: var(--ink);
}
.story__body p {
  color: var(--muted);
  font-size: .93rem;
  margin: 0;
}

.reachgrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
.reachgrid__heading {
  font-size: 1rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 1.2rem;
  padding-bottom: .6rem;
  border-bottom: 2px solid var(--accent);
}
.reachgrid__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: .9rem;
}
.reachgrid__list li {
  display: flex;
  gap: .9rem;
  align-items: flex-start;
  font-size: .95rem;
  color: var(--muted);
}
.reachgrid__list strong {
  color: var(--ink);
  font-weight: 600;
}
.reachgrid__dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: .3rem;
}
.reachgrid__dot--p { background: var(--primary); }
.reachgrid__dot--s {
  background: transparent;
  border: 2px solid var(--primary);
  opacity: .55;
}
.reachgrid__regions {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}
.region {
  background: rgba(24,71,200,.07);
  border: 1px solid rgba(24,71,200,.18);
  color: var(--primary);
  font-size: .8rem;
  font-weight: 600;
  padding: .3rem .75rem;
  border-radius: 999px;
}

@media (max-width: 900px) {
  .reachgrid { grid-template-columns: 1fr; }
  .story { padding-left: 2.8rem; }
  .story::before { left: .9rem; }
  .story__year { left: -2.8rem; width: 2rem; font-size: .7rem; }
  .story__item::before { left: -1.85rem; }
}
@media (max-width: 600px) {
  .cred { min-width: 120px; max-width: none; }
  .pledge__inner { flex-direction: column; }
}

.endcta{isolation:isolate;position:relative}
.banner{isolation:isolate}
.pagetop{isolation:isolate}
.banner__media,.banner-media{isolation:isolate}

.block .label,
.block--alt .label {
  color: var(--primary);
}

.block--blue .label,
.block--dark .label,
.banner .label,
.endcta .label,
.pagetop .label {
  color: var(--accent);
}

.figband {
  background:
    repeating-linear-gradient(
      120deg,
      rgba(255,255,255,.025) 0px,
      rgba(255,255,255,.025) 1px,
      transparent 1px,
      transparent 48px
    ),
    var(--ink);
}

#services {
  background:
    radial-gradient(ellipse 60% 50% at 95% 10%, rgba(24,71,200,.06) 0%, transparent 70%),
    var(--bg);
}

#results {
  background:
    radial-gradient(ellipse 55% 40% at 5% 15%, rgba(245,166,35,.07) 0%, transparent 65%),
    var(--bg);
}

.block--alt {
  background:
    linear-gradient(180deg, var(--surface) 0%, color-mix(in srgb, var(--surface) 94%, var(--primary)) 100%);
}

.block--blue {
  background:
    radial-gradient(ellipse 70% 80% at 15% 50%, rgba(245,166,35,.10) 0%, transparent 60%),
    radial-gradient(ellipse 50% 60% at 85% 80%, rgba(255,255,255,.04) 0%, transparent 55%),
    var(--primary);
}

.banner::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none;
  z-index: 0;
}

.block:has(.ladder) {
  border-top: 3px solid var(--accent);
}

#certifications {
  background:
    radial-gradient(ellipse 70% 50% at 50% 100%, rgba(24,71,200,.05) 0%, transparent 70%),
    var(--bg);
}

[hidden]{display:none!important}

.praise{display:flex;gap:1.2rem;overflow-x:auto;padding-bottom:1rem;scroll-snap-type:x mandatory}
.praise__card{flex:0 0 min(320px,80%);scroll-snap-align:start;background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:1.6rem;box-shadow:0 6px 20px rgba(0,0,0,.05)}
.praise__card p{color:var(--ink);margin:0 0 1rem;line-height:1.55}
.praise__card span{color:var(--accent);font-weight:700}

.reasons{display:grid;gap:1.2rem;max-width:62rem;margin:0 auto}
.reasons__item{padding:1.4rem 1.6rem;border-left:4px solid var(--accent);background:var(--surface);border-radius:0 10px 10px 0}
.reasons__item h3{margin:0 0 .3rem;color:var(--ink)}
.reasons__item p{margin:0;color:var(--muted);line-height:1.55}

.journey{list-style:none;margin:0 auto;padding:0;max-width:48rem;position:relative}
.journey__step{position:relative;display:grid;grid-template-columns:auto 1fr;gap:1.2rem;padding:0 0 2rem 0}
.journey__step::before{content:"";position:absolute;left:1.05rem;top:2.2rem;bottom:0;width:2px;background:var(--border)}
.journey__step:last-child::before{display:none}
.journey__n{width:2.2rem;height:2.2rem;border-radius:50%;display:grid;place-items:center;background:var(--accent);color:var(--bg);font-weight:800;position:relative;z-index:1}
.journey__step h3{margin:.2rem 0 .3rem;color:var(--ink)}
.journey__step p{margin:0;color:var(--muted);line-height:1.55}

.facrow{display:grid;grid-template-columns:1fr 1fr;gap:.4rem 2rem;max-width:62rem;margin:0 auto}
.facrow__p{display:flex;gap:1rem;align-items:center;padding:.9rem 0;border-bottom:1px solid var(--border)}
.facrow__av{flex:0 0 44px;height:44px;border-radius:50%;display:grid;place-items:center;background:var(--accent);color:var(--bg);font-weight:800}
.facrow__p h3{margin:0;color:var(--ink);font-size:1rem}
.facrow__p p{margin:0;color:var(--muted);font-size:.85rem}
@media(max-width:640px){.facrow{grid-template-columns:1fr}}

/* layout: w:1440,h:leftbar,s:twocol,n:wide,f:tworow,c:soft */
:root{--maxw:1440px}
.block .mid{text-align:left;margin-inline:0}
.block .intro.mid{max-width:74ch}
.block h2.mid{position:relative;padding-top:1.4rem}
.block h2.mid::before{content:"";position:absolute;top:0;left:0;width:64px;height:5px;background:var(--accent);border-radius:3px}
.navrow{padding:1.4rem 0}
.navset{gap:2.4rem}
.navset a{font-size:1.05rem}
.tile{border-radius:18px;box-shadow:0 14px 34px rgba(0,0,0,.08)}
#services .cols{display:grid !important;grid-template-columns:repeat(3,1fr) !important;gap:1.8rem}
#services .tile{border-left:5px solid var(--accent)}
#services .tile>img{aspect-ratio:16/9;object-fit:cover;width:100%}
@media(max-width:1024px){#services .cols{grid-template-columns:1fr 1fr !important}}
@media(max-width:680px){#services .cols{grid-template-columns:1fr !important}}
.footzone__cols{grid-template-columns:2fr 1fr 1fr;gap:2rem 4rem}
.footzone__cols>:first-child{max-width:46ch}
@media(max-width:760px){.footzone__cols{grid-template-columns:1fr !important;text-align:left !important}.footzone__cols>:first-child{grid-column:auto;order:0}}

.banner { padding: clamp(3.5rem, 8vw, 7rem) 0; }
.banner__inner { grid-template-columns: 1.05fr .95fr; gap: clamp(2.5rem, 5vw, 5rem); }
.banner .intro { font-size: 1.32rem; max-width: 56ch; line-height: 1.6; }
.banner__cta { margin-top: 2rem; }
.banner__media img { aspect-ratio: 4/3; }

.intro { font-size: 1.28rem; line-height: 1.6; }

.tile,
.track,
.outcome,
.virtue,
.mentor,
.post,
.pullquote { padding: 2.2rem; }
.tile--media .tile__body { padding: 1.9rem; }
.tile--media img { height: 240px; }
.tile h3, .post h3, .track h3, .virtue h3, .mentor__name { font-size: 1.4rem; }
.tile p, .post p, .track p, .outcome__body { font-size: 1.05rem; }
.tile li, .plan__feats li, .reachgrid__list li { font-size: 1.05rem; }

.cta { padding: 1.05rem 2rem; font-size: 1.08rem; }
.navset .cta { padding: .7rem 1.4rem; }

.cols { gap: 1.8rem; }
.cols--3 { grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); }
.cols--2 { grid-template-columns: repeat(auto-fit, minmax(440px, 1fr)); }
.cols--4 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }

.plans { grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); gap: 1.8rem; }
.plan { padding: 2.6rem; }
.plan__name { font-size: 1.4rem; }
.plan__feats li { padding: .5rem 0 .5rem 1.7rem; }

.fig__num { font-size: clamp(2.8rem, 5vw, 4rem); }
.fig__cap { font-size: 1.08rem; }

.reasons { max-width: 100%; grid-template-columns: 1fr 1fr; gap: 1.4rem; }
.reasons__item { padding: 1.8rem 2rem; }
.reasons__item h3 { font-size: 1.3rem; }
.reasons__item p { font-size: 1.05rem; }
@media(max-width:760px){ .reasons { grid-template-columns: 1fr; } }

.journey { max-width: 60rem; }
.journey__step h3 { font-size: 1.35rem; }
.journey__step p { font-size: 1.08rem; }

.praise__card { flex: 0 0 min(440px, 88%); padding: 2.2rem; }
.praise__card p { font-size: 1.12rem; line-height: 1.6; }

.facrow { max-width: 100%; gap: .4rem 3rem; }
.facrow__p h3 { font-size: 1.15rem; }
.facrow__p p { font-size: .98rem; }

.accordion summary { font-size: 1.15rem; }
.accordion details p { font-size: 1.05rem; }
.accordion details { padding: 1.35rem 1.7rem; }

.duo img { aspect-ratio: 4/3; }

.endcta h2 { max-width: 22ch; }

@media(min-width:1280px){
  .block { padding: clamp(4rem, 7vw, 6.5rem) 0; }
}

.fmt {
  background: var(--surface);
  border: 1px solid var(--border);
  border-top: 5px solid var(--primary);
  border-radius: 18px;
  padding: 2.4rem;
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  transition: transform .2s, box-shadow .2s;
}
.fmt:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.fmt--featured { border-top-color: var(--accent); background: linear-gradient(180deg,#fff, #fff7ec); }
.fmt__icon {
  width: 60px; height: 60px;
  border-radius: 14px;
  background: rgba(24,71,200,.09);
  color: var(--primary);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.2rem;
}
.fmt--featured .fmt__icon { background: rgba(245,166,35,.16); color: var(--accent-dark); }
.fmt h3 { font-size: 1.45rem; margin-bottom: .5rem; }
.fmt p { color: var(--muted); font-size: 1.05rem; }
.fmt__meta {
  margin-top: auto;
  padding-top: 1.2rem;
  border-top: 1px solid var(--border);
  font-weight: 700;
  font-family: var(--font-head);
  color: var(--primary);
  font-size: 1.05rem;
}

.sectors {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 1.2rem;
  margin-top: 2.5rem;
}
.sector {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 1.5rem 1rem;
  text-align: center;
  box-shadow: var(--shadow-md);
}
.sector__mark {
  font-family: var(--font-head);
  font-weight: 800;
  font-size: 1.6rem;
  color: var(--primary);
  letter-spacing: -.03em;
}
.sector__label {
  font-size: .92rem;
  color: var(--muted);
  margin-top: .35rem;
  font-weight: 500;
}

.intakes {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 2.5rem;
}
.intake {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr auto;
  gap: 1.5rem;
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 5px solid var(--accent);
  border-radius: 14px;
  padding: 1.6rem 2rem;
  box-shadow: var(--shadow-md);
  transition: transform .2s, box-shadow .2s;
}
.intake:hover { transform: translateX(4px); box-shadow: var(--shadow); }
.intake__course { font-family: var(--font-head); font-weight: 700; font-size: 1.25rem; color: var(--ink); }
.intake__field span {
  display: block;
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--muted);
  font-weight: 700;
  margin-bottom: .15rem;
}
.intake__field strong { font-size: 1.05rem; color: var(--ink); font-weight: 600; }
.intake__seats { color: var(--primary); }
@media(max-width:820px){
  .intake { grid-template-columns: 1fr 1fr; }
  .intake .cta { grid-column: 1/-1; justify-content: center; }
  .intake__course { grid-column: 1/-1; }
}
@media(max-width:480px){ .intake { grid-template-columns: 1fr; } }

.advise {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
  background:
    radial-gradient(ellipse 60% 90% at 12% 30%, rgba(245,166,35,.14) 0%, transparent 60%),
    var(--primary);
  color: #fff;
  border-radius: 22px;
  padding: clamp(2.5rem, 5vw, 4.5rem);
  isolation: isolate;
}
.advise h2 { color: #fff; font-size: clamp(2rem, 3.6vw, 3rem); }
.advise .intro { color: #c3d2f5; }
.advise__panel {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 16px;
  padding: 2rem;
}
.advise__panel ul { list-style: none; padding: 0; margin: 0 0 1.6rem; }
.advise__panel li {
  display: flex; gap: .7rem; align-items: flex-start;
  padding: .55rem 0;
  font-size: 1.05rem;
  color: #e7edfb;
}
.advise__panel li svg { color: var(--accent); flex-shrink: 0; margin-top: .25rem; }
.advise__panel .cta { width: 100%; justify-content: center; }
@media(max-width:820px){ .advise { grid-template-columns: 1fr; } }

.footzone { border-top: 4px solid var(--accent); padding-top: 4.5rem; }
.footzone__cols {
  grid-template-columns: 1.7fr 1fr 1fr 1fr 1.4fr;
  gap: 2.6rem 3rem;
}
.footzone__brand { max-width: 34ch; }
.footzone__cols h4 { font-size: 1.05rem; margin-bottom: 1.1rem; }
.footzone__cols li { font-size: 1rem; margin: .5rem 0; }
.footzone__badges { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.3rem; }
.footzone__badge {
  font-size: .8rem; font-weight: 600; color: #dbe4f7;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px; padding: .32rem .85rem;
}
.footzone__social { display: flex; gap: .7rem; margin-top: 1.3rem; }
.footzone__social a {
  width: 42px; height: 42px; border-radius: 11px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  display: flex; align-items: center; justify-content: center;
  color: #cbd5e8; transition: transform .2s, background .2s, color .2s, border-color .2s;
}
.footzone__social a:hover { background: var(--accent); border-color: var(--accent); color: var(--accent-ink); transform: translateY(-2px); }
.footzone__contact { list-style: none; padding: 0; margin: 0; }
.footzone__contact li {
  display: flex; gap: .7rem; align-items: flex-start;
  margin: .65rem 0; font-size: 1rem; line-height: 1.5; color: #aebbd4;
}
.footzone__contact li svg { flex-shrink: 0; margin-top: .15rem; color: var(--accent); }
.footzone__contact a { color: #aebbd4; }
.footzone__contact a:hover { color: #fff; }
@media (max-width: 1080px) {
  .footzone__cols { grid-template-columns: 1.4fr 1fr 1fr; }
  .footzone__brand { grid-column: 1 / -1; max-width: none; }
}
@media (max-width: 680px) {
  .footzone__cols { grid-template-columns: 1fr 1fr !important; }
  .footzone__brand { grid-column: 1 / -1; }
}
@media (max-width: 460px) {
  .footzone__cols { grid-template-columns: 1fr !important; }
}
