/* [next]/internal/font/google/inter_c15e96cb.module.css [app-client] (css) */
@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/2c55a0e60120577a-s.0-dom-5bn10r2.woff2") format("woff2");
  unicode-range: U+460-52F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/9c72aa0f40e4eef8-s.1y4-pdgsjb-pw.woff2") format("woff2");
  unicode-range: U+301, U+400-45F, U+490-491, U+4B0-4B1, U+2116;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/ad66f9afd8947f86-s.3lvt2whj97whp.woff2") format("woff2");
  unicode-range: U+1F??;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/5476f68d60460930-s.2uwcyprjm3xu3.woff2") format("woff2");
  unicode-range: U+370-377, U+37A-37F, U+384-38A, U+38C, U+38E-3A1, U+3A3-3FF;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/2bbe8d2671613f1f-s.0k62hbripvv8p.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/1bffadaabf893a1e-s.3-6t-g6q0vh0a.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Inter;
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../media/83afe278b6a6bb3c-s.p.2bn3s6zvc0dyp.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Inter Fallback;
  src: local(Arial);
  ascent-override: 90.44%;
  descent-override: 22.52%;
  line-gap-override: 0.0%;
  size-adjust: 107.12%;
}

.inter_c15e96cb-module__0bjUvq__className {
  font-family: Inter, Inter Fallback;
  font-style: normal;
}

.inter_c15e96cb-module__0bjUvq__variable {
  --font-inter: "Inter", "Inter Fallback";
}

/* [next]/internal/font/google/newsreader_4dfb9ac6.module.css [app-client] (css) */
@font-face {
  font-family: Newsreader;
  font-style: italic;
  font-weight: 200 800;
  font-display: swap;
  src: url("../media/79e9e0e3b9220e46-s.3a-pd9010p_dh.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Newsreader;
  font-style: italic;
  font-weight: 200 800;
  font-display: swap;
  src: url("../media/e62850744c7f266e-s.0n7ulcr4ivksg.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Newsreader;
  font-style: italic;
  font-weight: 200 800;
  font-display: swap;
  src: url("../media/9433d1a810498265-s.p.1hij5ex6k3v9q.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Newsreader;
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url("../media/150f724d70372c02-s.1ljbalzvxyif7.woff2") format("woff2");
  unicode-range: U+102-103, U+110-111, U+128-129, U+168-169, U+1A0-1A1, U+1AF-1B0, U+300-301, U+303-304, U+308-309, U+323, U+329, U+1EA0-1EF9, U+20AB;
}

@font-face {
  font-family: Newsreader;
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url("../media/750c737482d9de2f-s.3ex3j6ahhvjry.woff2") format("woff2");
  unicode-range: U+100-2BA, U+2BD-2C5, U+2C7-2CC, U+2CE-2D7, U+2DD-2FF, U+304, U+308, U+329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
  font-family: Newsreader;
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url("../media/5f402bd2d8eef81a-s.p.40bho2kviej2o.woff2") format("woff2");
  unicode-range: U+??, U+131, U+152-153, U+2BB-2BC, U+2C6, U+2DA, U+2DC, U+304, U+308, U+329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: Newsreader Fallback;
  src: local(Times New Roman);
  ascent-override: 69.68%;
  descent-override: 25.12%;
  line-gap-override: 0.0%;
  size-adjust: 105.48%;
}

.newsreader_4dfb9ac6-module__Tx0qMG__className {
  font-family: Newsreader, Newsreader Fallback;
}

.newsreader_4dfb9ac6-module__Tx0qMG__variable {
  --font-newsreader: "Newsreader", "Newsreader Fallback";
}

/* [project]/src/app/(frontend)/globals.css [app-client] (css) */
:root {
  --navy: #16294a;
  --navy-2: #2b4a78;
  --navy-deep: #101e33;
  --yellow: #ffc341;
  --yellow-2: #ffd06b;
  --slate: #566174;
  --paper: #f0f1f1;
  --paper-2: #e6e7e8;
  --card: #fff;
  --graphite: #504c4d;
  --ink: #504c4d;
  --muted: #6c6862;
  --line: #1b253324;
  --line-soft: #1b253312;
  --serif: var(--font-newsreader),Georgia,"Times New Roman",serif;
  --sans: var(--font-inter),-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --maxw: 1240px;
  --rail: 244px;
}

*, :before, :after {
  box-sizing: border-box;
}

html, body {
  margin: 0;
  padding: 0;
}

body {
  font-family: var(--sans);
  background: var(--paper);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
}

h1, h2, h3, h4 {
  font-family: var(--serif);
  letter-spacing: -.012em;
  margin: 0;
  font-weight: 500;
  line-height: 1.05;
}

p {
  margin: 0;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  max-width: 100%;
  display: block;
}

ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.wrap {
  width: min(100% - 48px,var(--maxw));
  margin-inline: auto;
}

.eyebrow {
  font: 650 12px var(--sans);
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--navy-2);
  align-items: center;
  gap: 10px;
  display: inline-flex;
}

.eyebrow:before {
  content: "";
  background: var(--yellow);
  width: 26px;
  height: 1.5px;
}

.eyebrow.light {
  color: #fff;
}

.eyebrow.light:before {
  background: var(--yellow);
}

.eyebrow.center {
  justify-content: center;
}

.btn {
  font: 600 15px var(--sans);
  cursor: pointer;
  white-space: nowrap;
  border: 1.5px solid #0000;
  border-radius: 8px;
  align-items: center;
  gap: .55em;
  padding: .9em 1.55em;
  transition: all .18s;
  display: inline-flex;
}

.btn svg {
  width: 1.05em;
  height: 1.05em;
}

.btn-primary {
  background: var(--navy);
  color: #fff;
}

.btn-primary:hover {
  background: var(--navy-deep);
  transform: translateY(-1px);
}

.btn-yellow {
  background: var(--yellow);
  color: var(--navy);
}

.btn-yellow:hover {
  background: var(--yellow-2);
}

.btn-ghost {
  border-color: var(--line);
  color: var(--navy);
}

.btn-ghost:hover {
  border-color: var(--navy);
  background: #16294a0a;
}

.btn-light {
  color: #fff;
  border-color: #ffffff80;
}

.btn-light:hover {
  background: #ffffff24;
}

.btn-lg {
  padding: 1.02em 1.85em;
  font-size: 16px;
}

.larrow {
  font: 600 15px var(--sans);
  color: var(--navy-2);
  align-items: center;
  gap: 7px;
  display: inline-flex;
}

.larrow svg {
  width: 16px;
  height: 16px;
  transition: all .2s;
}

.larrow:hover svg {
  transform: translateX(4px);
}

.rail {
  width: var(--rail);
  background: var(--paper);
  border-right: 1px solid var(--line);
  z-index: 70;
  scrollbar-gutter: stable;
  flex-direction: column;
  padding: 24px 16px 22px 24px;
  display: flex;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  overflow-y: auto;
}

.rail-logo {
  margin-bottom: 34px;
  line-height: 0;
  display: block;
}

.rail-logo img {
  width: auto;
  height: 170px;
}

.rail-nav {
  flex-direction: column;
  gap: 1px;
  display: flex;
}

.rail-link {
  font: 500 22px var(--serif);
  color: var(--navy);
  text-align: left;
  cursor: pointer;
  width: 100%;
  font-family: var(--serif);
  background: none;
  border: 0;
  align-items: center;
  gap: 8px;
  padding: 9px 0;
  display: flex;
  position: relative;
}

.rail-link .chev {
  opacity: .45;
  width: 13px;
  height: 13px;
  transition: transform .2s;
}

.rail-link:before {
  content: "";
  transform-origin: center;
  background: var(--yellow);
  width: 4px;
  height: 26px;
  transition: transform .2s;
  position: absolute;
  top: 50%;
  left: -24px;
  transform: translateY(-50%)scaleY(0);
}

.rail-link:hover {
  color: var(--navy-2);
}

.rail-link:hover:before, .rail-link.active:before {
  transform: translateY(-50%)scaleY(1);
}

.rail-link.active .chev {
  opacity: .9;
  transform: rotate(90deg);
}

.rail-lang {
  font: 500 13px var(--sans);
  color: var(--muted);
  align-items: center;
  gap: 8px;
  margin-top: 15px;
  margin-bottom: 28px;
  display: flex;
}

.rail-lang a {
  color: var(--muted);
  transition: color .15s;
}

.rail-lang a:hover {
  color: var(--navy);
}

.rail-lang a.on {
  color: var(--navy);
  font-weight: 700;
}

.rail-lang .dot {
  opacity: .55;
}

.rail-bottom .rail-lang {
  margin: 0;
}

.rail-bottom {
  flex-direction: column;
  gap: 16px;
  margin-top: auto;
  display: flex;
}

.rail-feature {
  border-top: 1px solid var(--line);
  padding-top: 16px;
}

.rail-feature .lbl {
  font: 650 10px var(--sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  display: block;
}

.rail-feature b {
  font-family: var(--serif);
  color: var(--navy);
  margin: 4px 0 7px;
  font-size: 18px;
  display: block;
}

.rail-feature a {
  font: 600 13px var(--sans);
  color: var(--navy-2);
}

.rail-apply {
  justify-content: center;
  position: sticky;
  bottom: 0;
}

.rail, .mega, .mobile-nav {
  scrollbar-width: thin;
  scrollbar-color: #1b25334d transparent;
}

.rail::-webkit-scrollbar {
  width: 8px;
}

.mega::-webkit-scrollbar {
  width: 8px;
}

.mobile-nav::-webkit-scrollbar {
  width: 8px;
}

.rail::-webkit-scrollbar-track {
  background: none;
}

.mega::-webkit-scrollbar-track {
  background: none;
}

.mobile-nav::-webkit-scrollbar-track {
  background: none;
}

.rail::-webkit-scrollbar-thumb {
  background: #1b253338 padding-box content-box;
  border: 2px solid #0000;
  border-radius: 4px;
}

.mega::-webkit-scrollbar-thumb {
  background: #1b253338 padding-box content-box;
  border: 2px solid #0000;
  border-radius: 4px;
}

.mobile-nav::-webkit-scrollbar-thumb {
  background: #1b253338 padding-box content-box;
  border: 2px solid #0000;
  border-radius: 4px;
}

.rail::-webkit-scrollbar-thumb:hover {
  background: #1b25336b padding-box content-box;
}

.mega::-webkit-scrollbar-thumb:hover {
  background: #1b25336b padding-box content-box;
}

.mobile-nav::-webkit-scrollbar-thumb:hover {
  background: #1b25336b padding-box content-box;
}

@media (max-height: 760px) {
  .rail-feature {
    display: none;
  }
}

.main {
  margin-left: var(--rail);
  flex-direction: column;
  min-height: 100vh;
  display: flex;
}

.main-content {
  flex: 1 0 auto;
}

.main .wrap {
  width: min(1180px, 100% - 96px);
  margin-left: clamp(24px, 4vw, 72px);
  margin-right: auto;
}

.mega-backdrop {
  inset: 0 0 0 var(--rail);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  opacity: 0;
  visibility: hidden;
  z-index: 50;
  background: #101e334d;
  transition: opacity .3s, visibility .3s;
  position: fixed;
}

.mega-backdrop.open {
  opacity: 1;
  visibility: visible;
}

.mega {
  left: var(--rail);
  width: min(760px,calc(100vw - var(--rail) - 56px));
  background: var(--card);
  border-right: 1px solid var(--line);
  opacity: 0;
  visibility: hidden;
  z-index: 60;
  padding: clamp(28px, 3.4vw, 48px);
  transition: transform .32s cubic-bezier(.16, .7, .3, 1), opacity .25s, visibility .32s;
  position: fixed;
  top: 0;
  bottom: 0;
  overflow-y: auto;
  transform: translateX(-20px);
  box-shadow: 34px 0 90px #101e3333;
}

.mega.open {
  opacity: 1;
  visibility: visible;
  transform: none;
}

.mega-close {
  border: 1px solid var(--line);
  cursor: pointer;
  width: 40px;
  height: 40px;
  color: var(--navy);
  background: none;
  place-items: center;
  display: grid;
  position: absolute;
  top: 22px;
  right: 22px;
}

.mega-close svg {
  width: 18px;
  height: 18px;
}

.mega-head {
  max-width: 60%;
  margin-bottom: 28px;
}

.mega-head h3 {
  color: var(--navy);
  margin-top: 10px;
  font-size: clamp(24px, 2.4vw, 32px);
}

.mega-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 26px 32px;
  display: grid;
}

.mcol h4 {
  font: 650 11px var(--sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 12px;
}

.mcol a {
  font: 500 17px var(--serif);
  color: var(--navy);
  border-bottom: 1px solid var(--line-soft);
  padding: 8px 0;
  transition: all .15s;
  display: block;
}

.mcol a:hover {
  color: var(--navy-2);
  padding-left: 7px;
}

.mfeat {
  border: 1px solid var(--line);
  background: var(--paper);
  grid-column: 1 / -1;
  min-height: 128px;
  margin-top: 6px;
  transition: all .18s;
  display: flex;
}

.mfeat:hover {
  background: var(--paper-2);
}

.mfeat .mfeat-img {
  background: #33414f center / cover;
  flex: none;
  width: 210px;
}

.mfeat .mfeat-body {
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  padding: 0 26px;
  display: flex;
}

.mfeat .mfeat-body span {
  font: 600 11.5px var(--sans);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}

.mfeat .mfeat-body b {
  font-family: var(--serif);
  color: var(--navy);
  font-size: 23px;
}

.topbar, .mobile-nav {
  display: none;
}

.hero {
  background: var(--paper);
}

.hero .wrap {
  padding: clamp(50px, 8vh, 104px) 0 clamp(40px, 5vh, 68px);
}

.hero .eyebrow {
  margin-bottom: 20px;
}

.hero h1 {
  color: var(--navy);
  letter-spacing: -.025em;
  font-size: clamp(44px, 5.6vw, 82px);
  line-height: 1;
}

.hero h1 em {
  color: var(--navy-2);
  background-image: linear-gradient(#0000 58%, #ffc34199 58% 90%, #0000 90%);
  font-style: italic;
}

.hero .sub {
  color: var(--muted);
  max-width: 52ch;
  margin-top: 24px;
  font-size: clamp(17px, 1.5vw, 20px);
}

.hero-cta {
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 32px;
  display: flex;
}

.hero-stats {
  border-top: 1px solid var(--line);
  flex-wrap: wrap;
  margin-top: 52px;
  display: flex;
}

.hero-stats .s {
  margin-right: 8px;
  padding: 22px 36px 0 0;
}

.hero-stats .s b {
  font-family: var(--serif);
  color: var(--navy);
  font-size: 34px;
  line-height: 1;
  display: block;
}

.hero-stats .s span {
  color: var(--muted);
  font-size: 13px;
}

.bled-band {
  background: #33414f;
  width: 100%;
  height: clamp(320px, 40vw, 520px);
  position: relative;
  overflow: hidden;
}

.bled-band img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
}

.bled-band .cap {
  font: 600 11px var(--sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #ffffffeb;
  text-shadow: 0 1px 6px #00000080;
  position: absolute;
  bottom: 14px;
  right: clamp(16px, 4vw, 40px);
}

.btn, .pcard, .pillar, .pillar .ic, .split-media, .pill-tag, .news .th, .cta .wrap, .foot .accreds span, .mega-close, .rail-lang a, .topbar .burger, .tb-apply, .mfeat {
  border-radius: 0 !important;
}

@media (max-width: 980px) {
  .rail, .mega, .mega-backdrop {
    display: none;
  }

  .main {
    margin-left: 0;
    padding-top: 64px;
  }

  .main .wrap {
    width: min(1180px, 100% - 40px);
    margin-left: auto;
  }

  .topbar {
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--line);
    z-index: 80;
    background: #f0f1f1f2;
    align-items: center;
    gap: 14px;
    height: 64px;
    padding: 0 16px;
    display: flex;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
  }

  .topbar .burger {
    border: 1px solid var(--line);
    cursor: pointer;
    background: none;
    flex: none;
    place-items: center;
    width: 42px;
    height: 42px;
    display: grid;
  }

  .topbar .burger svg {
    width: 20px;
    height: 20px;
    color: var(--navy);
  }

  .topbar .tb-logo {
    flex: none;
    line-height: 0;
  }

  .topbar .tb-logo img {
    height: 42px;
  }

  .topbar .tb-title {
    font: 600 15px var(--serif);
    color: var(--navy);
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
  }

  .topbar .tb-apply {
    flex: none;
    margin-left: auto;
  }

  .mobile-nav {
    background: var(--paper);
    z-index: 79;
    opacity: 0;
    visibility: hidden;
    padding: 26px 22px;
    transition: all .26s;
    display: block;
    position: fixed;
    inset: 64px 0 0;
    overflow-y: auto;
    transform: translateY(-10px);
  }

  .mobile-nav.open {
    opacity: 1;
    visibility: visible;
    transform: none;
  }

  .mobile-nav a {
    font: 500 26px var(--serif);
    color: var(--navy);
    border-bottom: 1px solid var(--line-soft);
    padding: 15px 0;
    display: block;
  }

  .mobile-nav .mn-foot {
    align-items: center;
    gap: 16px;
    margin-top: 26px;
    display: flex;
  }
}

.sec {
  padding: clamp(60px, 7.5vw, 104px) 0;
}

.sec.grey {
  background: var(--paper-2);
}

.sec-h {
  max-width: 680px;
  margin-bottom: 44px;
}

.sec-h.center {
  text-align: center;
  margin-inline: auto;
}

.sec-h h2 {
  color: var(--navy);
  margin-top: 16px;
  font-size: clamp(30px, 4.2vw, 48px);
}

.sec-h p {
  color: var(--muted);
  margin-top: 16px;
  font-size: 18px;
}

.prog-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  display: grid;
}

.pcard {
  background: var(--card);
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  flex-direction: column;
  min-height: 236px;
  padding: 28px;
  transition: transform .22s, box-shadow .22s;
  display: flex;
}

.pcard:hover {
  transform: translateY(-5px);
  box-shadow: 0 22px 50px #1b253321;
}

.pcard .tag {
  font: 650 11.5px var(--sans);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--slate);
}

.pcard h3 {
  color: var(--navy);
  margin: 12px 0 8px;
  font-size: 25px;
}

.pcard p {
  color: var(--muted);
  flex: 1;
  font-size: 14.5px;
}

.pcard .meta {
  color: var(--ink);
  flex-wrap: wrap;
  gap: 16px;
  margin: 16px 0 14px;
  font-size: 13px;
  display: flex;
}

.pcard .meta span {
  align-items: center;
  gap: 6px;
  display: inline-flex;
}

.pcard .meta svg {
  width: 15px;
  height: 15px;
  color: var(--slate);
}

.pcard .go {
  font: 600 14.5px var(--sans);
  color: var(--navy-2);
  align-items: center;
  gap: 7px;
  display: inline-flex;
}

.pcard .go svg {
  width: 16px;
  height: 16px;
  transition: all .2s;
}

.pcard:hover .go svg {
  transform: translateX(4px);
}

.pcard.feat {
  background: var(--navy);
  border-color: #0000;
}

.pcard.feat h3 {
  color: #fff;
}

.pcard.feat p, .pcard.feat .meta {
  color: #fffc;
}

.pcard.feat .tag, .pcard.feat .meta svg, .pcard.feat .go {
  color: var(--yellow);
}

.pillars {
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  display: grid;
}

.pillar {
  background: var(--card);
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  padding: 32px;
}

.pillar .ic {
  background: var(--navy);
  width: 54px;
  height: 54px;
  color: var(--yellow);
  border-radius: 13px;
  place-items: center;
  margin-bottom: 20px;
  display: grid;
}

.pillar .ic svg {
  width: 25px;
  height: 25px;
}

.pillar .pmedia {
  aspect-ratio: 4 / 3;
  background: #33414f center / cover;
  width: calc(100% + 64px);
  margin: -32px -32px 22px;
  display: block;
}

.pillar h3 {
  color: var(--navy);
  margin-bottom: 10px;
  font-size: 23px;
}

.pillar p {
  color: var(--muted);
  font-size: 14.5px;
}

.bledband {
  background: #28323d url("/bled-hero.jpg") 50% 35% / cover;
  align-items: flex-end;
  min-height: clamp(340px, 46vw, 560px);
  display: flex;
  position: relative;
}

.bledband:after {
  content: "";
  background: linear-gradient(#101e330d, #101e33b8);
  position: absolute;
  inset: 0;
}

.bledband .wrap {
  z-index: 2;
  padding: 46px 0;
  position: relative;
}

.bledband h2 {
  color: #fff;
  max-width: 18ch;
  font-size: clamp(30px, 4.4vw, 52px);
}

.bledband p {
  color: #ffffffdb;
  max-width: 50ch;
  margin-top: 14px;
  font-size: 18px;
}

.split {
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: clamp(28px, 5vw, 64px);
  display: grid;
}

.split-media {
  aspect-ratio: 5 / 4;
  background: #33414f center / cover;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 20px 50px #1b253329;
}

.split h2 {
  color: var(--navy);
  font-size: clamp(28px, 3.6vw, 42px);
}

.split p {
  color: var(--muted);
  margin: 16px 0 22px;
  font-size: 17px;
}

.tick {
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 13px;
  font-size: 15px;
  display: flex;
}

.tick svg {
  width: 22px;
  height: 22px;
  color: var(--navy-2);
  flex: none;
  margin-top: 2px;
}

.dual {
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 4vw, 56px);
  display: grid;
}

.list-head {
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 22px;
  display: flex;
}

.list-head h2 {
  color: var(--navy);
  font-size: 30px;
}

.ev {
  border-top: 1px solid var(--line);
  gap: 20px;
  padding: 20px 0;
  display: flex;
}

.ev:first-of-type {
  border-top: 0;
}

.ev .date {
  text-align: center;
  flex: none;
  width: 60px;
}

.ev .date b {
  font-family: var(--serif);
  color: var(--navy);
  font-size: 28px;
  line-height: 1;
  display: block;
}

.ev .date span {
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  font-size: 12px;
}

.ev h4 {
  font-family: var(--sans);
  margin-bottom: 5px;
  font-size: 16.5px;
  font-weight: 600;
}

.ev .m {
  color: var(--muted);
  font-size: 13px;
}

.pill-tag {
  font: 650 11px var(--sans);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--navy-2);
  background: var(--paper-2);
  border-radius: 999px;
  margin-bottom: 7px;
  padding: 3px 10px;
  display: inline-block;
}

.news {
  border-top: 1px solid var(--line);
  gap: 18px;
  padding: 18px 0;
  display: flex;
}

.news:first-of-type {
  border-top: 0;
}

.news .th {
  background: var(--paper-2) center/cover;
  border-radius: 10px;
  flex: none;
  width: 104px;
  height: 78px;
}

.news h4 {
  font-family: var(--sans);
  font-size: 16px;
  font-weight: 600;
  line-height: 1.35;
}

.news .m {
  color: var(--muted);
  margin-top: 6px;
  font-size: 12.5px;
}

.quote {
  color: #fff;
  background: #28323d url("/bled-2.jpg") center / cover;
  position: relative;
}

.quote:after {
  content: "";
  background: linear-gradient(90deg, #101e33db, #101e338c);
  position: absolute;
  inset: 0;
}

.quote .wrap {
  z-index: 2;
  max-width: 880px;
  position: relative;
}

.quote blockquote {
  font-family: var(--serif);
  letter-spacing: -.01em;
  margin: 0;
  font-size: clamp(24px, 3.2vw, 38px);
  line-height: 1.22;
}

.quote blockquote em {
  color: var(--yellow);
  font-style: italic;
}

.quote .who {
  color: #ffffffc7;
  margin-top: 22px;
  font-size: 15px;
}

.quote .who b {
  color: #fff;
  font-weight: 600;
}

.cta .wrap {
  background: var(--card);
  border: 1px solid var(--line-soft);
  text-align: center;
  border-radius: 22px;
  padding: clamp(40px, 5vw, 66px);
}

.cta h2 {
  color: var(--navy);
  font-size: clamp(30px, 4vw, 48px);
}

.cta p {
  color: var(--muted);
  max-width: 46ch;
  margin: 16px auto 28px;
  font-size: 18px;
}

.cta .row {
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px;
  display: flex;
}

.foot {
  background: var(--navy-deep);
  color: #ffffffb8;
}

.foot a {
  color: #ffffffb8;
}

.foot a:hover {
  color: #fff;
}

.foot-top {
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 40px;
  padding: 68px 0 50px;
  display: grid;
}

.foot .fmark img {
  height: 92px;
  margin-bottom: 18px;
}

.foot .fbrand p {
  max-width: 30ch;
  margin-bottom: 18px;
  font-size: 14.5px;
}

.foot .contact {
  font-size: 14px;
  line-height: 1.9;
}

.foot .contact b {
  color: #fff;
}

.foot h4 {
  font: 680 12px var(--sans);
  letter-spacing: .15em;
  text-transform: uppercase;
  color: #ffffff80;
  margin-bottom: 16px;
}

.foot li {
  margin-bottom: 10px;
  font-size: 14.5px;
}

.foot .accreds {
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
  display: flex;
}

.foot .accreds span {
  font: 700 11px var(--sans);
  letter-spacing: .08em;
  color: #ffffffd9;
  border: 1px solid #ffffff38;
  border-radius: 7px;
  padding: 7px 11px;
}

.foot-bot {
  border-top: 1px solid #ffffff1f;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 14px;
  padding: 22px 0;
  font-size: 13px;
  display: flex;
}

.foot-bot .legal {
  flex-wrap: wrap;
  gap: 18px;
  display: flex;
}

.reveal {
  opacity: 0;
  transition: opacity .7s, transform .7s cubic-bezier(.16, .7, .3, 1);
  transform: translateY(22px);
}

.reveal.in {
  opacity: 1;
  transform: none;
}

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

@media (max-width: 920px) {
  .prog-grid, .pillars, .split, .dual, .foot-top {
    grid-template-columns: 1fr;
  }
}

.slider {
  background: #28323d;
  width: 100%;
  height: clamp(440px, 52vw, 600px);
  position: relative;
  overflow: hidden;
}

.slide {
  opacity: 0;
  visibility: hidden;
  background: #28323d center / cover;
  align-items: flex-end;
  transition: opacity .6s, visibility .6s;
  display: flex;
  position: absolute;
  inset: 0;
}

.slide.on {
  opacity: 1;
  visibility: visible;
}

.slide:after {
  content: "";
  background: linear-gradient(90deg, #101e33db, #101e336b 55%, #101e331f);
  position: absolute;
  inset: 0;
}

.slide .wrap {
  z-index: 2;
  padding: 0 0 58px;
  position: relative;
}

.slide h2 {
  color: #fff;
  max-width: 16ch;
  margin-top: 14px;
  font-size: clamp(30px, 4.4vw, 54px);
}

.slide p {
  color: #ffffffdb;
  max-width: 46ch;
  margin-top: 14px;
  font-size: clamp(16px, 1.4vw, 19px);
}

.slide .btn {
  margin-top: 24px;
}

.slider-nav {
  z-index: 4;
  align-items: center;
  gap: 18px;
  display: flex;
  position: absolute;
  bottom: 24px;
  right: clamp(20px, 4vw, 48px);
}

.slider-dots {
  gap: 8px;
  display: flex;
}

.slider-dots button {
  cursor: pointer;
  background: #ffffff73;
  border: 0;
  width: 10px;
  height: 10px;
  padding: 0;
  transition: all .2s;
}

.slider-dots button.on {
  background: var(--yellow);
  width: 24px;
}

.slider-arrows {
  gap: 8px;
  display: flex;
}

.slider-arrow {
  color: #fff;
  cursor: pointer;
  background: #101e3352;
  border: 1px solid #ffffff80;
  place-items: center;
  width: 44px;
  height: 44px;
  transition: all .18s;
  display: grid;
}

.slider-arrow:hover {
  background: #101e339e;
}

.slider-arrow svg {
  width: 20px;
  height: 20px;
}

@media (max-width: 560px) {
  .slider-nav {
    gap: 12px;
  }

  .slider-arrow {
    width: 40px;
    height: 40px;
  }
}

.accred {
  padding: clamp(34px, 4vw, 52px) 0;
}

.accred .wrap {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
  align-items: center;
  gap: clamp(20px, 4vw, 52px);
  padding-top: clamp(26px, 3vw, 38px);
  padding-bottom: clamp(26px, 3vw, 38px);
  display: flex;
}

.accred .lbl {
  font: 650 11px var(--sans);
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--muted);
  max-width: 9ch;
  line-height: 1.55;
}

.accred .marks {
  flex-wrap: wrap;
  align-items: center;
  gap: clamp(20px, 3.5vw, 48px);
  display: flex;
}

.accred .marks span {
  font-family: var(--serif);
  color: var(--navy);
  letter-spacing: .06em;
  font-size: clamp(20px, 2.2vw, 28px);
  font-weight: 600;
}

.rail-contact {
  border-top: 1px solid var(--line);
  padding-top: 16px;
}

.rail-contact .lbl {
  font: 650 10px var(--sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  display: block;
}

.rail-contact b {
  font-family: var(--serif);
  color: var(--navy);
  margin: 4px 0 7px;
  font-size: 18px;
  display: block;
}

.rail-contact a {
  font: 600 13px var(--sans);
  color: var(--navy-2);
  transition: color .15s;
}

.rail-contact a:hover {
  color: var(--navy);
}

@media (max-height: 860px) {
  .rail-contact {
    display: none;
  }
}

.pp-hero {
  background: var(--paper);
  padding-top: clamp(40px, 5vh, 72px);
}

.pp-hero-grid {
  grid-template-columns: 1.1fr .9fr;
  align-items: center;
  gap: clamp(28px, 4vw, 56px);
  display: grid;
}

.pp-hero .eyebrow {
  margin-bottom: 16px;
}

.pp-hero h1 {
  color: var(--navy);
  letter-spacing: -.022em;
  font-size: clamp(38px, 5vw, 66px);
  line-height: 1.02;
}

.pp-vp {
  color: var(--muted);
  max-width: 42ch;
  margin-top: 20px;
  font-size: clamp(17px, 1.5vw, 21px);
}

.pp-cta {
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 30px;
  display: flex;
}

.pp-hero-media {
  aspect-ratio: 4 / 3.4;
  background: #33414f center / cover;
  align-self: stretch;
  min-height: 300px;
}

.pp-facts {
  border-top: 1px solid var(--line);
  grid-template-columns: repeat(4, 1fr);
  margin-top: clamp(34px, 5vw, 58px);
  display: grid;
}

.pp-facts .f {
  border-right: 1px solid var(--line);
  padding: 22px 24px 4px 0;
}

.pp-facts .f:last-child {
  border-right: 0;
}

.pp-facts .f span {
  font: 650 11px var(--sans);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 6px;
  display: block;
}

.pp-facts .f b {
  font-family: var(--serif);
  color: var(--navy);
  font-size: 20px;
}

.pp-overview {
  grid-template-columns: 1.6fr 1fr;
  align-items: start;
  gap: clamp(28px, 5vw, 64px);
  display: grid;
}

.pp-lead {
  color: var(--muted);
  max-width: 60ch;
  margin-top: 18px;
  font-size: 18px;
}

.pp-whofor {
  background: var(--card);
  border: 1px solid var(--line-soft);
  padding: 28px;
}

.pp-whofor h4 {
  font: 650 12px var(--sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 16px;
}

.pp-whofor li {
  align-items: flex-start;
  gap: 11px;
  margin-bottom: 13px;
  font-size: 15px;
  display: flex;
}

.pp-whofor svg {
  width: 20px;
  height: 20px;
  color: var(--navy-2);
  flex: none;
  margin-top: 2px;
}

.pp-modules {
  flex-direction: column;
  gap: 16px;
  display: flex;
}

.pp-module {
  background: var(--card);
  border: 1px solid var(--line-soft);
  gap: 24px;
  padding: 26px 28px;
  transition: all .2s;
  display: flex;
}

.pp-module:hover {
  box-shadow: 0 18px 44px #1b25331a;
}

.pp-module-n {
  font-family: var(--serif);
  color: var(--yellow);
  flex: none;
  width: 48px;
  font-size: 34px;
  line-height: 1;
}

.pp-module-body {
  flex: 1;
}

.pp-module-top {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: baseline;
  gap: 16px;
  display: flex;
}

.pp-module-top h3 {
  color: var(--navy);
  font-size: 23px;
}

.pp-module-dates {
  font: 600 13px var(--sans);
  color: var(--navy-2);
  background: var(--paper-2);
  white-space: nowrap;
  padding: 5px 11px;
}

.pp-module-body p {
  color: var(--muted);
  margin: 8px 0 14px;
  font-size: 14.5px;
}

.pp-module-foot {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  display: flex;
}

.pp-module-price {
  font-family: var(--serif);
  color: var(--navy);
  font-size: 18px;
}

.pp-fullenrol {
  background: var(--navy);
  color: #fff;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  margin-top: 22px;
  padding: 26px 30px;
  display: flex;
}

.pp-fullenrol b {
  font-family: var(--serif);
  font-size: 21px;
  display: block;
}

.pp-fullenrol span {
  color: #ffffffbf;
  font-size: 14.5px;
}

.pp-curric {
  grid-template-columns: repeat(2, 1fr);
  gap: 0 48px;
  display: grid;
}

.pp-curric-item {
  border-top: 1px solid var(--line);
  color: var(--navy);
  font-size: 18px;
  font-family: var(--serif);
  align-items: baseline;
  gap: 18px;
  padding: 18px 0;
  display: flex;
}

.pp-curric-n {
  font: 650 12px var(--sans);
  color: var(--yellow);
  letter-spacing: .05em;
  font-family: var(--sans);
}

.pp-faculty {
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  display: grid;
}

.pp-fac-img {
  aspect-ratio: 1 / 1.1;
  background: #33414f center / cover;
  margin-bottom: 16px;
  display: block;
}

.pp-fac b {
  font-family: var(--serif);
  color: var(--navy);
  font-size: 19px;
  display: block;
}

.pp-fac-role {
  color: var(--muted);
  font-size: 13.5px;
}

.pp-outcomes {
  grid-template-columns: 1fr 1.3fr;
  align-items: start;
  gap: clamp(28px, 5vw, 64px);
  display: grid;
}

.pp-outcomes ul {
  gap: 16px;
  display: grid;
}

.pp-outcomes li {
  color: var(--ink);
  align-items: flex-start;
  gap: 13px;
  font-size: 17px;
  display: flex;
}

.pp-outcomes svg {
  width: 24px;
  height: 24px;
  color: var(--navy-2);
  flex: none;
  margin-top: 2px;
}

.pp-prices {
  flex-wrap: wrap;
  gap: 22px;
  display: flex;
}

.pp-price {
  background: var(--card);
  border: 1px solid var(--line);
  flex: 1;
  min-width: 260px;
  padding: 32px;
}

.pp-price.primary {
  background: var(--navy);
  color: #fff;
  border-color: #0000;
}

.pp-price-lbl {
  font: 650 11px var(--sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
}

.pp-price.primary .pp-price-lbl {
  color: var(--yellow);
}

.pp-price b {
  font-family: var(--serif);
  color: var(--navy);
  margin: 10px 0 6px;
  font-size: 40px;
  line-height: 1;
  display: block;
}

.pp-price.primary b {
  color: #fff;
}

.pp-price-note {
  color: var(--muted);
  margin-bottom: 20px;
  font-size: 13.5px;
  display: block;
}

.pp-price.primary .pp-price-note {
  color: #ffffffbf;
}

.pp-price .btn {
  justify-content: center;
  width: 100%;
}

.pp-faq {
  max-width: 820px;
}

.faq {
  margin-top: 30px;
}

.faq-item {
  border-top: 1px solid var(--line);
}

.faq-item:last-child {
  border-bottom: 1px solid var(--line);
}

.faq-q {
  text-align: left;
  cursor: pointer;
  width: 100%;
  font-family: var(--serif);
  color: var(--navy);
  background: none;
  border: 0;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 20px 0;
  font-size: 20px;
  display: flex;
}

.faq-ic {
  color: var(--navy-2);
  flex: none;
  line-height: 0;
  transition: transform .25s;
}

.faq-ic svg {
  width: 22px;
  height: 22px;
}

.faq-item.open .faq-ic {
  transform: rotate(180deg);
}

.faq-a {
  grid-template-rows: 0fr;
  transition: grid-template-rows .28s;
  display: grid;
}

.faq-item.open .faq-a {
  grid-template-rows: 1fr;
}

.faq-a > p {
  color: var(--muted);
  margin: 0;
  font-size: 16px;
  line-height: 1.65;
  overflow: hidden;
}

.faq-item.open .faq-a > p {
  padding-bottom: 22px;
}

@media (max-width: 920px) {
  .pp-hero-grid, .pp-overview, .pp-outcomes {
    grid-template-columns: 1fr;
  }

  .pp-facts, .pp-faculty {
    grid-template-columns: 1fr 1fr;
  }

  .pp-curric {
    grid-template-columns: 1fr;
  }

  .pp-hero-media {
    aspect-ratio: 16 / 9;
    order: -1;
    min-height: 240px;
  }

  .pp-module {
    flex-direction: column;
    gap: 10px;
  }
}

.quiz {
  padding: clamp(40px, 7vh, 84px) 0;
}

.quiz-inner {
  width: min(760px, 100% - 96px);
  margin-left: clamp(24px, 4vw, 72px);
}

.quiz h1 {
  color: var(--navy);
  margin-top: 14px;
  font-size: clamp(30px, 4vw, 46px);
  line-height: 1.06;
}

.quiz-sub {
  color: var(--muted);
  margin-top: 14px;
  font-size: 17px;
}

.quiz-intro p {
  color: var(--muted);
  max-width: 52ch;
  margin-top: 16px;
  font-size: 18px;
}

.quiz-steps {
  flex-wrap: wrap;
  gap: 12px;
  margin: 28px 0 30px;
  display: flex;
}

.quiz-steps li {
  font: 600 14px var(--sans);
  color: var(--navy);
  background: var(--card);
  border: 1px solid var(--line-soft);
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  display: flex;
}

.quiz-steps li span {
  background: var(--navy);
  color: #fff;
  width: 24px;
  height: 24px;
  font-size: 12px;
  font-family: var(--serif);
  place-items: center;
  display: grid;
}

.quiz-top {
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
  display: flex;
}

.quiz-count {
  font-family: var(--serif);
  color: var(--navy-2);
  font-size: 15px;
}

.quiz-count b {
  color: var(--navy);
  font-size: 17px;
}

.quiz-exit {
  cursor: pointer;
  font: 600 13px var(--sans);
  color: var(--muted);
  background: none;
  border: 0;
}

.quiz-exit:hover {
  color: var(--navy);
}

.quiz-bar {
  background: var(--paper-2);
  height: 5px;
  margin-bottom: 34px;
  overflow: hidden;
}

.quiz-bar i {
  background: var(--yellow);
  height: 100%;
  transition: width .4s cubic-bezier(.16, .7, .3, 1);
  display: block;
}

.quiz-step h2 {
  color: var(--navy);
  font-size: clamp(26px, 3.4vw, 38px);
}

.quiz-opts {
  flex-direction: column;
  gap: 11px;
  margin-top: 28px;
  display: flex;
}

.quiz-opt {
  text-align: left;
  background: var(--card);
  border: 1.6px solid var(--line);
  cursor: pointer;
  width: 100%;
  color: var(--ink);
  align-items: center;
  gap: 16px;
  padding: 18px 20px;
  transition: border-color .16s, box-shadow .16s;
  display: flex;
}

.quiz-opt:hover {
  border-color: var(--navy-2);
}

.quiz-opt.sel {
  border-color: var(--yellow);
  box-shadow: 0 0 0 3px #ffc3414d;
}

.qo-t b {
  font-family: var(--serif);
  color: var(--navy);
  font-size: 19px;
  display: block;
}

.qo-t span {
  color: var(--muted);
  font-size: 13.5px;
}

.qo-check {
  border: 2px solid var(--line);
  flex: none;
  place-items: center;
  width: 24px;
  height: 24px;
  margin-left: auto;
  display: grid;
}

.quiz-opt.sel .qo-check {
  border-color: var(--yellow);
  background: var(--yellow);
}

.qo-check svg {
  width: 14px;
  height: 14px;
  color: var(--navy);
  opacity: 0;
  transition: opacity .15s;
}

.quiz-opt.sel .qo-check svg {
  opacity: 1;
}

.quiz-nav {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  margin-top: 30px;
  display: flex;
}

.quiz-back {
  cursor: pointer;
  font: 600 15px var(--sans);
  color: var(--muted);
  background: none;
  border: 0;
  align-items: center;
  gap: 8px;
  display: inline-flex;
}

.quiz-back:hover {
  color: var(--navy);
}

.quiz-back svg {
  width: 18px;
  height: 18px;
}

.btn[disabled] {
  opacity: .4;
  pointer-events: none;
}

.quiz-grid {
  grid-template-columns: 1fr;
  gap: 14px;
  margin-top: 30px;
}

.quiz-result-card {
  position: relative;
}

.quiz-best {
  z-index: 2;
  background: var(--yellow);
  color: var(--navy);
  font: 700 10.5px var(--sans);
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 5px 11px;
  position: absolute;
  top: -9px;
  left: 18px;
}

.quiz-actions {
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
  display: flex;
}

.quiz-actions .btn {
  padding: .62em 1.15em;
  font-size: 13.5px;
}

.quiz-restart {
  cursor: pointer;
  color: var(--muted);
  font: 600 14px var(--sans);
  text-underline-offset: 3px;
  background: none;
  border: 0;
  margin-top: 28px;
  text-decoration: underline;
}

.quiz-restart:hover {
  color: var(--navy);
}

.appl {
  padding: clamp(36px, 5vh, 64px) 0;
}

.appl-inner {
  width: min(880px, 100% - 96px);
  margin-left: clamp(24px, 4vw, 72px);
}

.appl-head {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-end;
  gap: 20px;
  margin-bottom: 26px;
  display: flex;
}

.appl-head h1 {
  color: var(--navy);
  margin-top: 10px;
  font-size: clamp(30px, 3.6vw, 44px);
}

.appl-save {
  align-items: center;
  gap: 18px;
  display: flex;
}

.af-saved {
  font: 600 12.5px var(--sans);
  color: var(--muted);
  align-items: center;
  gap: 6px;
  display: inline-flex;
}

.af-saved svg {
  width: 14px;
  height: 14px;
  color: var(--navy-2);
}

.af-saved:not(.on) {
  opacity: .55;
}

.af-exit {
  font: 600 13px var(--sans);
  color: var(--navy-2);
}

.req {
  color: #c0492f;
}

.af-steps {
  margin-bottom: 28px;
  padding: 0;
  list-style: none;
  display: flex;
}

.af-steps li {
  text-align: center;
  flex: 1;
  min-width: 0;
  position: relative;
}

.af-steps li:not(:first-child):before {
  content: "";
  background: var(--line);
  z-index: 0;
  width: 100%;
  height: 2px;
  position: absolute;
  top: 17px;
  right: 50%;
}

.af-steps li.done:not(:first-child):before, .af-steps li.cur:not(:first-child):before {
  background: var(--navy-2);
}

.af-steps button {
  z-index: 1;
  width: 100%;
  color: inherit;
  background: none;
  border: 0;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 0;
  display: flex;
  position: relative;
}

.af-steps button:not([disabled]) {
  cursor: pointer;
}

.af-steps .n {
  border: 2px solid var(--line);
  background: var(--paper);
  width: 34px;
  height: 34px;
  font: 650 13px var(--sans);
  color: var(--muted);
  place-items: center;
  transition: all .2s;
  display: grid;
}

.af-steps .n svg {
  width: 15px;
  height: 15px;
}

.af-steps .l {
  font: 600 12px var(--sans);
  color: var(--muted);
}

.af-steps li.done .n {
  background: var(--navy-2);
  border-color: var(--navy-2);
  color: #fff;
}

.af-steps li.cur .n {
  border-color: var(--yellow);
  background: var(--yellow);
  color: var(--navy);
  box-shadow: 0 0 0 4px #ffc34140;
}

.af-steps li.cur .l, .af-steps li.done .l {
  color: var(--navy);
}

.af-panel {
  background: var(--card);
  border: 1px solid var(--line-soft);
  padding: clamp(26px, 3.4vw, 44px);
}

.af-stepn {
  font: 650 11px var(--sans);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--navy-2);
}

.af-step h2 {
  color: var(--navy);
  margin-top: 10px;
  font-size: clamp(24px, 3vw, 34px);
}

.af-lead {
  color: var(--muted);
  margin-top: 10px;
  font-size: 16px;
}

.af-lead a {
  color: var(--navy-2);
  font-weight: 600;
}

.af-grid {
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 26px;
  display: grid;
}

.af-field {
  flex-direction: column;
  gap: 7px;
  display: flex;
}

.af-field.full {
  grid-column: 1 / -1;
}

.af-field label {
  font: 600 13px var(--sans);
  color: var(--ink);
}

.af-input {
  font: inherit;
  border: 1.5px solid var(--line);
  background: var(--paper);
  color: var(--ink);
  width: 100%;
  padding: 13px 15px;
  font-size: 15px;
}

.af-input:focus {
  border-color: var(--navy-2);
  outline: none;
  box-shadow: 0 0 0 3px #2b4a7824;
}

.af-input.err {
  background: #fdf3f1;
  border-color: #c0492f;
}

.af-textarea {
  resize: vertical;
  min-height: 150px;
  line-height: 1.6;
  font-family: var(--sans);
}

.af-errmsg {
  font: 600 12.5px var(--sans);
  color: #c0492f;
}

.af-progpick {
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 24px;
  display: grid;
}

.af-prog {
  cursor: pointer;
  border: 1.6px solid var(--line);
  background: var(--paper);
  padding: 18px;
  display: block;
  position: relative;
}

.af-prog input {
  opacity: 0;
  position: absolute;
}

.af-prog.sel {
  border-color: var(--yellow);
  background: var(--card);
  box-shadow: 0 0 0 3px #ffc3414d;
}

.af-prog-name {
  font-family: var(--serif);
  color: var(--navy);
  font-size: 18px;
  display: block;
}

.af-prog-meta {
  color: var(--muted);
  margin-top: 4px;
  font-size: 13px;
  display: block;
}

.af-modular {
  border-top: 1px solid var(--line);
  margin-top: 24px;
  padding-top: 22px;
}

.af-modular h4 {
  font: 650 12px var(--sans);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 14px;
}

.af-modes {
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  display: grid;
}

.af-mode {
  cursor: pointer;
  border: 1.6px solid var(--line);
  background: var(--paper);
  padding: 16px 18px;
  display: block;
}

.af-mode.sel {
  border-color: var(--yellow);
  background: var(--card);
  box-shadow: 0 0 0 3px #ffc3414d;
}

.af-mode input {
  opacity: 0;
  position: absolute;
}

.af-mode b {
  font-family: var(--serif);
  color: var(--navy);
  font-size: 17px;
  display: block;
}

.af-mode span {
  color: var(--muted);
  font-size: 13px;
}

.af-drop {
  text-align: left;
  border: 1.6px dashed var(--line);
  background: var(--paper);
  cursor: pointer;
  width: 100%;
  color: var(--ink);
  align-items: center;
  gap: 16px;
  margin-top: 24px;
  padding: 22px;
  transition: all .16s;
  display: flex;
}

.af-drop:hover {
  border-color: var(--navy-2);
}

.af-drop.filled {
  border-style: solid;
  border-color: var(--navy-2);
  background: var(--card);
}

.af-drop.err {
  border-color: #c0492f;
}

.af-drop-ic {
  background: var(--paper-2);
  width: 46px;
  height: 46px;
  color: var(--navy-2);
  flex: none;
  place-items: center;
  display: grid;
}

.af-drop.filled .af-drop-ic {
  background: var(--navy-2);
  color: #fff;
}

.af-drop-ic svg {
  width: 20px;
  height: 20px;
}

.af-drop-t b {
  color: var(--navy);
  font-size: 15px;
  display: block;
}

.af-drop-t span {
  color: var(--muted);
  font-size: 13px;
}

.af-note {
  color: var(--muted);
  align-items: center;
  gap: 8px;
  margin-top: 18px;
  font-size: 13.5px;
  display: flex;
}

.af-note svg {
  flex: none;
  width: 16px;
  height: 16px;
}

.af-review {
  border: 1px solid var(--line);
  margin-top: 24px;
}

.af-rrow {
  border-bottom: 1px solid var(--line);
  grid-template-columns: 150px 1fr auto;
  align-items: start;
  gap: 16px;
  padding: 18px 22px;
  display: grid;
}

.af-rrow:last-child {
  border-bottom: 0;
}

.af-rk {
  font: 650 11.5px var(--sans);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}

.af-rv {
  color: var(--ink);
  font-size: 14.5px;
  line-height: 1.5;
}

.af-rv b {
  color: var(--navy);
  font-weight: 600;
}

.af-redit {
  cursor: pointer;
  font: 600 13px var(--sans);
  color: var(--navy-2);
  white-space: nowrap;
  background: none;
  border: 0;
}

.af-consent {
  color: var(--ink);
  align-items: flex-start;
  gap: 12px;
  margin-top: 22px;
  font-size: 14px;
  display: flex;
}

.af-consent input {
  width: 20px;
  height: 20px;
  accent-color: var(--navy);
  flex: none;
  margin-top: 1px;
}

.af-consent a {
  color: var(--navy-2);
  font-weight: 600;
}

.af-consent.err {
  color: #c0492f;
}

.af-payline {
  border-top: 1px solid var(--line);
  justify-content: space-between;
  align-items: center;
  margin-top: 24px;
  padding-top: 20px;
  display: flex;
}

.af-payline span {
  font: 650 12px var(--sans);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
}

.af-payline b {
  font-family: var(--serif);
  color: var(--navy);
  font-size: 28px;
}

.af-order {
  border: 1px solid var(--line);
  margin-top: 24px;
}

.af-order-row {
  border-bottom: 1px solid var(--line);
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px;
  display: flex;
}

.af-order-row:last-child {
  border-bottom: 0;
}

.af-order-row > div b {
  font-family: var(--serif);
  color: var(--navy);
  font-size: 17px;
}

.af-order-row > div span {
  color: var(--muted);
  font-size: 13px;
  display: block;
}

.af-order-price {
  font-family: var(--serif);
  color: var(--navy);
  font-size: 18px;
}

.af-order-total {
  background: var(--paper-2);
}

.af-order-total span {
  font: 650 12px var(--sans);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
}

.af-order-total b {
  font-family: var(--serif);
  color: var(--navy);
  font-size: 24px;
}

.af-nav {
  border-top: 1px solid var(--line);
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  margin-top: 32px;
  padding-top: 24px;
  display: flex;
}

.af-back {
  cursor: pointer;
  font: 600 15px var(--sans);
  color: var(--muted);
  background: none;
  border: 0;
  align-items: center;
  gap: 8px;
  display: inline-flex;
}

.af-back:hover {
  color: var(--navy);
}

.af-back svg {
  width: 18px;
  height: 18px;
}

.af-back[disabled] {
  opacity: 0;
  pointer-events: none;
}

.af-done {
  max-width: 640px;
  padding: clamp(8px, 2vw, 24px) 0;
}

.af-seal {
  background: var(--navy);
  place-items: center;
  width: 78px;
  height: 78px;
  margin-bottom: 24px;
  display: grid;
}

.af-seal svg {
  width: 36px;
  height: 36px;
  color: var(--yellow);
}

.af-done h1 {
  color: var(--navy);
  font-size: clamp(30px, 4vw, 46px);
}

.af-done p {
  color: var(--muted);
  max-width: 54ch;
  margin-top: 14px;
  font-size: 17px;
}

.af-done p b {
  color: var(--navy);
}

.af-ref {
  background: var(--paper-2);
  font: 600 14px var(--sans);
  color: var(--navy);
  margin-top: 20px;
  padding: 9px 16px;
  display: inline-block;
}

.af-next {
  gap: 13px;
  max-width: 480px;
  margin-top: 28px;
  padding: 0;
  list-style: none;
  display: grid;
}

.af-next li {
  align-items: flex-start;
  gap: 13px;
  font-size: 14.5px;
  display: flex;
}

.af-next i {
  background: var(--paper-2);
  width: 26px;
  height: 26px;
  color: var(--navy-2);
  flex: none;
  place-items: center;
  font-size: 13px;
  font-style: normal;
  font-weight: 700;
  display: grid;
}

.af-nav-row {
  flex-wrap: wrap;
  gap: 13px;
  margin-top: 30px;
  display: flex;
}

@media (max-width: 760px) {
  .af-grid, .af-modes {
    grid-template-columns: 1fr;
  }

  .af-progpick {
    grid-template-columns: 1fr 1fr;
  }

  .af-steps .l {
    display: none;
  }

  .af-rrow {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .af-redit {
    justify-self: start;
  }
}

/*# sourceMappingURL=%5Broot-of-the-server%5D__1c_-irt._.css.map*/