:root {
  --ink: #19343b;
  --teal: #087f95;
  --deep-teal: #176f76;
  --gold: #d49a35;
  --cream: #faf6ef;
  --paper: #fffbf4;
  --brown: #5a412f;
  --soft-brown: #7d5b3e;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: #fbfcfc; font-family: Arial, sans-serif; }
a { color: inherit; }
#top-bar {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(90,65,47,.97);
  border-bottom: 1px solid rgba(216,164,74,.28);
  box-shadow: 0 5px 18px rgba(47,31,22,.10);
  backdrop-filter: blur(14px);
}
.site-header-inner {
  box-sizing: border-box;
  width: min(100%, 1180px);
  min-height: 52px;
  margin: 0 auto;
  padding: 6px 26px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.brand-lockup {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: #fffaf2;
  font-size: 1.12rem;
  font-weight: 800;
  letter-spacing: -.035em;
  text-decoration: none;
  flex: 0 0 auto;
}
.brand-mark {
  width: 30px;
  height: 30px;
  object-fit: contain;
  filter: drop-shadow(0 4px 5px rgba(8,79,95,.13));
}
.brand-word { line-height: 1; }
.site-nav {
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: clamp(9px,1.35vw,17px);
  flex: 1 1 auto;
  align-self: stretch;
}
.site-nav-tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 0 3px;
  color: rgba(255,249,240,.82);
  font-size: .74rem;
  font-weight: 650;
  text-decoration: none;
  white-space: nowrap;
  transition: color .16s ease, transform .16s ease;
}
.site-nav-tab::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -5px;
  height: 3px;
  border-radius: 0 0 9px 9px;
  background: #d8a44a;
  box-shadow: 0 4px 0 rgba(216,164,74,.12);
  opacity: 0;
  transform: scaleX(.55);
  transition: opacity .16s ease, transform .16s ease;
}
.site-nav-tab:hover {
  color: #fff;
  transform: translateY(-1px);
}
.site-nav-tab.is-active {
  color: #fffaf2;
}
.site-nav-tab.is-active::after {
  opacity: 1;
  transform: scaleX(1);
}
.site-nav-icon {
  width: 14px;
  height: 15px;
  display: inline-grid;
  place-items: center;
  border: 1.6px solid #e88917;
  border-radius: 4px;
  color: #e88917;
  font-size: .58rem;
  font-weight: 900;
  line-height: 1;
}
.site-nav-icon-play { font-size: .45rem; }
.site-nav-coming {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: rgba(255,249,240,.62);
  font-size: .74rem;
  font-weight: 650;
  white-space: nowrap;
  cursor: default;
}
.site-nav-coming small {
  padding: 1px 5px;
  border-radius: 999px;
  color: #fff6e8;
  background: rgba(255,249,240,.14);
  font-size: .52rem;
  font-weight: 750;
}
.site-header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  min-width: 0;
}
.header-start-btn,
.pro-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 17px;
  border-radius: 999px;
  color: #fff;
  background: #087f73;
  box-shadow: 0 6px 14px rgba(8,127,115,.18);
  font-size: .86rem;
  font-weight: 750;
  text-decoration: none;
  white-space: nowrap;
  transition: transform .16s ease, box-shadow .16s ease;
}
.header-start-btn:hover,
.pro-primary:hover {
  color: #fff;
  text-decoration: none;
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(8,127,115,.24);
}
main { overflow: hidden; }
.pro-hero { max-width: 980px; margin: auto; padding: 84px 28px 82px; display: grid; grid-template-columns: 1.08fr .92fr; gap: 46px; align-items: center; }
.pro-eyebrow, .pro-section-heading > span, .pro-method-copy > span { color: #9a7027; font-size: .75rem; font-weight: 850; letter-spacing: .12em; }
.pro-hero h1 { max-width: 660px; margin: 16px 0 20px; font-size: clamp(2.2rem, 4.15vw, 3.85rem); line-height: 1.12; letter-spacing: -.052em; }
.pro-hero-copy > p { max-width: 650px; color: #52666b; font-size: 1.12rem; line-height: 1.8; }
.pro-actions { display: flex; gap: 12px; margin: 30px 0 25px; }
.pro-secondary { padding: 10px 20px; border: 1px solid rgba(8,127,149,.32); border-radius: 99px; color: var(--teal); text-decoration: none; font-weight: 750; }
.pro-proof { display: flex; flex-wrap: wrap; gap: 12px 20px; color: #52666b; font-size: .84rem; }
.pro-hero-card { padding: 28px; border: 1px solid rgba(212,154,53,.35); border-radius: 24px; background: linear-gradient(150deg,#fffaf0,#fff); box-shadow: 0 25px 65px rgba(72,52,32,.12); transform: rotate(1deg); }
.pro-card-label { display: inline-block; margin-bottom: 12px; padding: 5px 10px; border-radius: 99px; color: #8a621e; background: rgba(212,154,53,.13); font-size: .72rem; font-weight: 800; }
.pro-scenario { padding: 17px 4px; border-bottom: 1px solid rgba(90,65,47,.10); }
.pro-scenario:last-child { border: 0; }
.pro-scenario strong { font-size: 1.02rem; }
.pro-scenario p { margin: 6px 0 0; color: #69777a; line-height: 1.55; }
.pro-scenario p span { display: block; margin-bottom: 3px; color: #8a621e; font-weight: 850; }
.pro-section {
  padding: 52px 28px 64px;
  background:
    radial-gradient(circle at 12% 8%, rgba(40,111,104,.08), transparent 18rem),
    linear-gradient(180deg, #f7fbfa 0%, #ffffff 100%);
}
.pro-section-inner {
  width: min(100%, 760px);
  margin: 0 auto;
}
.pro-section-heading {
  max-width: 680px;
  margin: 0 auto 22px;
  text-align: center;
}
.pro-section h2, .pro-method h2, .pro-pricing h2 {
  margin: 8px 0 10px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.85rem,3.45vw,2.95rem);
  font-weight: 600;
  letter-spacing: -.045em;
}
.pro-section-heading p {
  max-width: 680px;
  margin: 0 auto;
  color: #6f6259;
  line-height: 1.85;
}
.pro-course-flow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 7px 16px;
  border: 1px solid rgba(40,111,104,.14);
  border-radius: 999px;
  background: rgba(255,255,255,.82);
  color: #36585b;
  font-size: .92rem;
  font-weight: 780;
  line-height: 1;
}
.pro-course-flow b {
  color: #9a7027;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1rem;
}
.pro-general-track,
.pro-tracks-panel {
  position: relative;
  border: 1px solid rgba(40,111,104,.14);
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(248,252,251,.98)),
    #fff;
  box-shadow: 0 24px 70px rgba(33,89,91,.08);
  overflow: hidden;
}
.pro-general-track {
  margin-bottom: 18px;
  padding: 30px 30px 32px;
  display: block;
}
.pro-general-track::before,
.pro-general-track::after,
.pro-tracks-panel::before,
.pro-tracks-panel::after {
  content: "";
  position: absolute;
  pointer-events: none;
}
.pro-general-track::before,
.pro-tracks-panel::before {
  inset: 12px;
  border: 1px solid rgba(40,111,104,.10);
  border-radius: 22px;
}
.pro-general-track::after,
.pro-tracks-panel::after {
  width: 180px;
  height: 180px;
  top: -76px;
  border-radius: 50%;
  background: rgba(40,111,104,.06);
}
.pro-general-track::after { right: -56px; }
.pro-tracks-panel::after { left: -64px; }
.pro-general-title-row {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
}
.pro-general-kicker {
  color: #9a7027;
  font-size: .68rem;
  font-weight: 850;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.pro-general-track h3 {
  margin: 0;
  font-family: inherit;
  font-size: clamp(1.22rem,1.7vw,1.55rem);
  font-weight: 760;
  letter-spacing: -.02em;
}
.pro-general-track ol {
  position: relative;
  margin: 30px 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.pro-general-track ol::before {
  content: "";
  position: absolute;
  left: 30px;
  right: 30px;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(125,91,62,.34), transparent);
}
.pro-general-track li {
  position: relative;
  z-index: 1;
  width: 96px;
  height: 96px;
  border: 1px solid rgba(255,255,255,.68);
  border-radius: 50%;
  color: #fffaf2;
  background: #8f4f45;
  box-shadow: 0 15px 34px rgba(72,52,32,.15);
  display: grid;
  place-items: center;
  text-align: center;
}
.pro-general-track li:nth-child(2) { background: #9a7027; }
.pro-general-track li:nth-child(3) { background: #4f715f; }
.pro-general-track li:nth-child(4) { background: #4f647a; }
.pro-general-track li:nth-child(5) { background: #6f4f73; }
.pro-general-track li span {
  display: block;
  max-width: 4.2em;
  font-size: .83rem;
  font-weight: 800;
  line-height: 1.25;
}
.pro-tracks-panel {
  max-width: 760px;
  margin: 0 auto;
  padding: 20px 22px 22px;
}
.pro-panel-heading {
  position: relative;
  z-index: 1;
  margin-bottom: 14px;
  padding: 0 6px 12px 14px;
  border-bottom: 1px solid rgba(40,111,104,.12);
  border-left: 3px solid #286f68;
}
.pro-panel-heading span {
  color: #9a7027;
  font-size: .7rem;
  font-weight: 850;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.pro-panel-heading h3 {
  margin: 6px 0 0;
  font-family: inherit;
  font-size: clamp(1.22rem,1.7vw,1.55rem);
  font-weight: 760;
  letter-spacing: -.02em;
}
.pro-tracks {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3,minmax(0,1fr));
  gap: 10px;
  max-width: none;
  margin: 0 auto;
}
.pro-track {
  min-height: 154px;
  padding: 14px 14px 13px;
  border: 1px solid rgba(40,111,104,.16);
  border-radius: 16px;
  background: rgba(255,255,255,.70);
  box-shadow: 0 14px 34px rgba(33,89,91,.055);
  display: flex;
  flex-direction: column;
  transition: border-color .16s ease, transform .16s ease, box-shadow .16s ease;
}
.pro-track:hover {
  border-color: rgba(40,111,104,.42);
  transform: translateY(-2px);
  box-shadow: 0 18px 42px rgba(33,89,91,.09);
}
.pro-track-number {
  width: 28px;
  height: 28px;
  margin-bottom: 10px;
  border-radius: 9px;
  color: #fffaf2;
  background: #286f68;
  font-family: inherit;
  font-size: .68rem;
  font-weight: 850;
  letter-spacing: .05em;
  display: grid;
  place-items: center;
}
.pro-track h3 {
  margin: 0 0 7px;
  font-family: inherit;
  font-size: .82rem;
  font-weight: 850;
  line-height: 1.35;
  letter-spacing: -.015em;
}
.pro-track p {
  margin: 0;
  color: #6d625b;
  font-size: .66rem;
  line-height: 1.5;
}
.pro-method {
  width: min(100%, 760px);
  margin: 0 auto;
  padding: 76px 0;
  background: #fff;
}
.pro-method-copy { max-width: 640px; margin: 0 auto 28px; text-align: center; }
.pro-levels { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.pro-levels article { padding: 22px 18px; border-radius: 18px; color: #fff; background: #286f68; }
.pro-levels b { color: #ffd98a; font-size: .8rem; }
.pro-levels h3 { margin: 12px 0 8px; }
.pro-levels p { margin: 0; color: rgba(255,255,255,.78); line-height: 1.6; font-size: .88rem; }
.pro-pricing { max-width: 760px; margin: 0 auto 82px; padding: 36px 38px; border-radius: 24px; color: #fff; background: var(--brown); display: flex; align-items: center; justify-content: space-between; gap: 32px; }
.pro-pricing-title span { display: block; white-space: nowrap; }
.pro-pricing p { color: rgba(255,255,255,.72); line-height: 1.6; }
.pro-price { min-width: 310px; text-align: center; }
.pro-price strong { font-size: 3.2rem; }
.pro-price > p { margin: 7px 0 5px; font-size: .82rem; }
.pro-price small { display: block; margin-bottom: 18px; color: rgba(255,255,255,.55); font-size: .7rem; }
.pro-price a { display: block; padding: 13px 18px; border-radius: 99px; color: var(--brown); background: #fffaf2; text-decoration: none; font-weight: 800; }
.pro-footer { padding: 40px 20px; color: rgba(255,255,255,.72); background: #173f45; text-align: center; }
.pro-footer a { display: inline-flex; align-items: center; gap: 8px; color: #fff; text-decoration: none; font-size: 1.2rem; font-weight: 800; }
.pro-footer img { width: 38px; }
@media (max-width: 760px) {
  .site-header-inner { min-height: 46px; padding: 5px 10px; gap: 8px; }
  .brand-lockup { font-size: .98rem; }
  .brand-mark { width: 28px; height: 28px; }
  .site-nav { display: none; }
  .header-start-btn { margin-left: auto; font-size: .76rem; padding: 8px 13px; }
  .pro-hero { padding: 60px 20px; grid-template-columns: 1fr; gap: 38px; }
  .pro-hero h1 { font-size: 2.25rem; }
  .pro-actions { flex-direction: column; align-items: stretch; text-align: center; }
  .pro-tracks, .pro-levels { grid-template-columns: 1fr; }
  .pro-tracks-panel { padding: 18px 10px 10px; border-radius: 24px; }
  .pro-panel-heading { padding: 0 12px 12px; }
  .pro-general-track { grid-template-columns: 1fr; padding: 22px; }
  .pro-general-track ol { align-items: stretch; overflow-x: auto; padding-bottom: 4px; }
  .pro-general-track ol::before { left: 20px; right: 20px; }
  .pro-general-track li { flex: 0 0 88px; width: 88px; height: 88px; }
  .pro-track { min-height: 0; }
  .pro-section { padding: 42px 20px; }
  .pro-method { width: auto; margin: 0 20px; padding: 60px 0; }
  .pro-pricing { margin: 0 16px 60px; padding: 30px 22px; flex-direction: column; text-align: center; }
  .pro-price { min-width: 0; width: 100%; }
}
