/* =====================================================================
   VXIT — AI Blueprint · The Vangärd Framework (long-form resource)
   Shared chrome lives in chrome.css; tokens in tokens.css.
   ===================================================================== */

:root {
  --lvl-gray:     #8C8C8E;
  --lvl-plum:     #993467;
  --lvl-magenta:  #DA138D;
  --lvl-orange:   #F26322;
  --lvl-graphite: #2B2B2E;   /* lightened from #1A1A1A so it reads on black */
}

/* ---------- Page shell ---------- */
.vg {
  flex: 1;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Smooth anchor jumps that land below the sticky sub-nav */
html { scroll-behavior: smooth; scroll-padding-top: 72px; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

/* Generic section rhythm */
.vg-section {
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
  padding: clamp(56px, 9vh, 120px) clamp(20px, 5vw, 40px);
  scroll-margin-top: 84px;
}
.vg-section--tight { padding-block: clamp(40px, 6vh, 80px); }

.vg-eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: var(--fw-regular);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: var(--vxit-orange);
  margin: 0 0 18px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.vg-eyebrow::before {
  content: "";
  width: 26px;
  height: 2px;
  background: var(--vxit-orange);
}
.vg-eyebrow--magenta { color: var(--vxit-pink); }
.vg-eyebrow--magenta::before { background: var(--vxit-pink); }
.vg-eyebrow--plum { color: #C76BA0; }
.vg-eyebrow--plum::before { background: var(--vxit-magenta-dark); }

.vg-h2 {
  font-family: var(--font-display);
  font-weight: var(--fw-black);
  font-size: clamp(2rem, 4.4vw, 3.25rem);
  line-height: 1.04;
  letter-spacing: -0.025em;
  color: var(--vxit-white);
  margin: 0 0 28px;
  text-wrap: balance;
}
.vg-h2 .grad {
  background: var(--vxit-gradient);
  -webkit-background-clip: text; background-clip: text;
  color: transparent; -webkit-text-fill-color: transparent;
}
.vg-h2 .hl-orange { color: var(--vxit-orange); }
.vg-h2 .hl-pink   { color: var(--vxit-pink); }

.vg-prose { max-width: 68ch; }
.vg-prose p {
  font-family: var(--font-sans);
  font-size: clamp(16px, 1.35vw, 19px);
  line-height: 1.62;
  color: rgba(255,255,255,0.72);
  margin: 0 0 20px;
}
.vg-prose p:last-child { margin-bottom: 0; }
.vg-prose strong { color: var(--vxit-white); font-weight: var(--fw-semibold); }
.vg-prose .q {
  color: rgba(255,255,255,0.92);
  font-weight: var(--fw-medium);
  font-style: italic;
}

/* Section pivot divider (Educate: training -> experimentation) */
.vg-pivot {
  display: flex;
  align-items: center;
  gap: 16px;
  margin: clamp(22px, 3vw, 34px) 0;
}
.vg-pivot::before,
.vg-pivot::after {
  content: "";
  height: 1px;
  background: rgba(255,255,255,0.12);
  flex: 1;
}
.vg-pivot::before { flex: 0 0 28px; background: var(--vxit-orange); height: 2px; }
.vg-pivot span {
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: clamp(1rem, 1.6vw, 1.25rem);
  letter-spacing: -0.01em;
  color: #C76BA0;
}

/* =====================================================================
   STICKY SUB-NAV
   ===================================================================== */
.vg-subnav {
  position: sticky;
  top: 0;
  z-index: 40;
  width: 100%;
  display: flex;
  justify-content: center;
  gap: clamp(14px, 2vw, 30px);
  padding: 14px clamp(16px, 4vw, 40px);
  background: rgba(6,6,8,0.78);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  overflow-x: auto;
  scrollbar-width: none;
}
.vg-subnav::-webkit-scrollbar { display: none; }
.vg-subnav a {
  flex: 0 0 auto;
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: rgba(255,255,255,0.52);
  white-space: nowrap;
  transition: color 200ms var(--ease-snap);
}
.vg-subnav a:hover { color: var(--vxit-white); }
.vg-subnav a.is-active { color: var(--vxit-orange); }

/* =====================================================================
   HERO
   ===================================================================== */
.vg-hero {
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
  padding: clamp(40px, 7vh, 88px) clamp(20px, 5vw, 40px) clamp(48px, 7vh, 80px);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.vg-hero__eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  margin-bottom: 22px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.vg-hero__eyebrow .pulse {
  width: 6px; height: 6px; border-radius: 999px;
  background: var(--vxit-orange);
  box-shadow: 0 0 12px var(--vxit-orange);
  animation: vxPulse 2.4s ease-in-out infinite;
}
.vg-hero__title {
  font-family: var(--font-display);
  font-weight: var(--fw-black);
  font-size: clamp(2.6rem, 6.4vw, 5.25rem);
  line-height: 0.96;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: var(--vxit-white);
  margin: 0 0 24px;
  max-width: 16ch;
  text-wrap: balance;
}
.vg-hero__title .grad {
  background: var(--vxit-gradient);
  -webkit-background-clip: text; background-clip: text;
  color: transparent; -webkit-text-fill-color: transparent;
}
.vg-hero__sub {
  font-family: var(--font-sans);
  font-size: clamp(17px, 1.7vw, 21px);
  line-height: 1.5;
  color: rgba(255,255,255,0.72);
  max-width: 52ch;
  margin: 0 0 40px;
}
.vg-hero__sub strong { color: var(--vxit-white); font-weight: var(--fw-semibold); }

/* Hero spectrum strip */
.vg-strip {
  width: 100%;
  max-width: 760px;
  margin: 0 auto 40px;
}
.vg-strip__bar {
  display: flex;
  width: 100%;
  height: 14px;
  border-radius: 999px;
  overflow: hidden;
  box-shadow: 0 10px 40px -12px rgba(218,19,141,0.5);
}
.vg-strip__seg { flex: 1; }
.vg-strip__nums {
  display: flex;
  margin-top: 10px;
}
.vg-strip__nums span {
  flex: 1;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 11px;
  color: rgba(255,255,255,0.45);
}
.vg-strip__ends {
  display: flex;
  justify-content: space-between;
  margin-top: 4px;
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
}
.vg-strip__phases {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 8px 14px;
  margin-top: 22px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.vg-strip__phases .dot { color: var(--vxit-pink); }

.vg-hero__cta-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
}

/* ---------- Buttons (page-local, on-brand) ---------- */
.vg-btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 17px 30px;
  border-radius: 4px;
  background: var(--vxit-orange);
  color: var(--vxit-white);
  font-family: var(--font-display);
  font-weight: var(--fw-black);
  font-size: 15px;
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  box-shadow: 0 14px 36px -10px rgba(242,99,34,0.6);
  cursor: pointer;
  transition: transform 240ms var(--ease-snap), background-color 240ms var(--ease-snap), box-shadow 240ms var(--ease-snap);
}
.vg-btn:hover, .vg-btn:focus-visible {
  transform: translateY(-2px);
  background: var(--vxit-pink);
  box-shadow: 0 18px 44px -10px rgba(218,19,141,0.7);
  outline: none;
}
.vg-btn svg { transition: transform 240ms var(--ease-snap); }
.vg-btn:hover svg { transform: translateX(4px); }
.vg-btn--lg { padding: 20px 38px; font-size: 17px; }
.vg-btn .vg-btn__hint {
  font-family: var(--font-mono);
  font-weight: var(--fw-regular);
  font-size: 12px;
  letter-spacing: 0.04em;
  text-transform: none;
  opacity: 0.85;
}
.vg-link {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: rgba(255,255,255,0.65);
  border-bottom: 1px solid rgba(255,255,255,0.25);
  padding-bottom: 3px;
  transition: color 200ms var(--ease-snap), border-color 200ms var(--ease-snap);
}
.vg-link:hover { color: var(--vxit-white); border-color: var(--vxit-orange); }

/* =====================================================================
   DIAGNOSTIC
   ===================================================================== */
.vg-diag {
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
  padding: clamp(40px, 6vh, 72px) clamp(20px, 5vw, 40px);
  scroll-margin-top: 84px;
}
.vg-diag__panel {
  position: relative;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255,255,255,0.045) 0%, rgba(255,255,255,0.012) 100%);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  overflow: hidden;
}
.vg-diag__panel::after {
  content: "";
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 50% 60% at 100% 0%, rgba(242,99,34,0.18), transparent 60%);
}
.vg-diag__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 0.92fr;
}
@media (max-width: 900px) { .vg-diag__grid { grid-template-columns: 1fr; } }

.vg-diag__form {
  padding: clamp(26px, 3vw, 44px);
  border-right: 1px solid rgba(255,255,255,0.08);
}
@media (max-width: 900px) { .vg-diag__form { border-right: 0; border-bottom: 1px solid rgba(255,255,255,0.08); } }

.vg-diag__teamfield { margin-bottom: 28px; }
.vg-diag__teamfield label {
  display: block;
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  margin-bottom: 8px;
}
.vg-diag__teamfield input {
  width: 100%;
  font-family: inherit;
  font-size: 16px;
  color: var(--vxit-white);
  background: rgba(0,0,0,0.35);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 4px;
  padding: 13px 15px;
  outline: none;
  transition: border-color 200ms var(--ease-snap), background 200ms var(--ease-snap);
}
.vg-diag__teamfield input::placeholder { color: rgba(255,255,255,0.32); }
.vg-diag__teamfield input:focus { border-color: var(--vxit-orange); background: rgba(0,0,0,0.5); }

/* ---- Stepper ---- */
.vg-stepper { display: flex; flex-direction: column; gap: 22px; }
.vg-stepper__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}
.vg-stepper__count {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}
.vg-step-dots { display: flex; gap: 6px; }
.vg-step-dot {
  width: 24px;
  height: 6px;
  border-radius: 999px;
  background: rgba(255,255,255,0.16);
  padding: 0;
  cursor: pointer;
}
.vg-step-dot.is-answered { background: var(--vxit-orange); }
.vg-step-dot.is-active { box-shadow: 0 0 0 2px rgba(255,255,255,0.55); }
.vg-step-dot.is-active.is-answered { box-shadow: 0 0 0 2px rgba(242,99,34,0.55); }

.vg-stepper__q { min-height: 268px; }
@media (max-width: 900px) { .vg-stepper__q { min-height: 0; } }

.vg-stepper__nav {
  display: flex;
  align-items: center;
  gap: 16px;
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 18px;
}
.vg-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 4px;
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: rgba(255,255,255,0.72);
  cursor: pointer;
}
.vg-back:hover:not(:disabled) { border-color: rgba(255,255,255,0.45); color: var(--vxit-white); }
.vg-back:disabled { opacity: 0.32; cursor: default; }
.vg-stepper__hint {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: var(--fw-medium);
  letter-spacing: 0.02em;
  color: var(--vxit-orange);
}

.vg-q { margin-bottom: 0; }
.vg-q:last-child { margin-bottom: 0; }
.vg-q__head {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 14px;
}
.vg-q__tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--vxit-orange);
  flex: 0 0 auto;
}
.vg-q__text {
  font-family: var(--font-sans);
  font-size: clamp(15px, 1.3vw, 17px);
  font-weight: var(--fw-semibold);
  color: var(--vxit-white);
  line-height: 1.35;
}
.vg-q__opts {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.vg-opt {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 48px;
  padding: 11px 16px;
  text-align: left;
  border: 1px solid rgba(255,255,255,0.13);
  border-radius: 4px;
  background: rgba(255,255,255,0.02);
  color: rgba(255,255,255,0.78);
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.35;
  cursor: pointer;
}
.vg-opt:hover { border-color: rgba(255,255,255,0.32); background: rgba(255,255,255,0.05); color: var(--vxit-white); }
.vg-opt__dot {
  flex: 0 0 auto;
  width: 16px; height: 16px;
  border-radius: 999px;
  border: 2px solid rgba(255,255,255,0.3);
}
.vg-opt[aria-checked="true"] {
  border-color: var(--vxit-orange);
  background: rgba(242,99,34,0.12);
  color: var(--vxit-white);
}
.vg-opt[aria-checked="true"] .vg-opt__dot {
  border-color: var(--vxit-orange);
  background: var(--vxit-orange);
  box-shadow: inset 0 0 0 3px rgba(0,0,0,0.45);
}
.vg-opt:focus-visible { outline: 2px solid var(--vxit-pink); outline-offset: 2px; }

/* Result rail */
.vg-result {
  padding: clamp(26px, 3vw, 44px);
  display: flex;
  flex-direction: column;
  position: sticky;
  top: 84px;
  align-self: start;
}
@media (max-width: 900px) { .vg-result { position: static; } }

.vg-result__empty {
  display: flex;
  flex-direction: column;
  gap: 14px;
  color: rgba(255,255,255,0.5);
}
.vg-result__empty .ring {
  width: 56px; height: 56px;
  border-radius: 999px;
  border: 2px dashed rgba(255,255,255,0.25);
  display: grid; place-items: center;
  font-family: var(--font-mono);
  font-size: 13px;
  color: rgba(255,255,255,0.5);
}
.vg-result__empty p {
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.5;
  margin: 0;
  max-width: 34ch;
}
.vg-result__progress {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
  margin-top: 6px;
}

.vg-result__card { display: flex; flex-direction: column; gap: 16px; }
.vg-result__badge {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
}
.vg-result__level {
  font-family: var(--font-display);
  font-weight: var(--fw-black);
  font-size: clamp(3rem, 6vw, 4.5rem);
  line-height: 0.9;
  letter-spacing: -0.03em;
  text-transform: uppercase;
}
.vg-result__name {
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: clamp(1.3rem, 2vw, 1.6rem);
  line-height: 1.05;
  color: var(--vxit-white);
  letter-spacing: -0.01em;
  margin: -6px 0 0;
}
.vg-result__means {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.5;
  color: rgba(255,255,255,0.74);
  margin: 0;
}
.vg-result__move {
  border-top: 1px solid rgba(255,255,255,0.1);
  padding-top: 16px;
}
.vg-result__move-label {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--vxit-orange);
  margin: 0 0 8px;
}
.vg-result__move p {
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.55;
  color: rgba(255,255,255,0.82);
  margin: 0;
}
.vg-risk {
  border: 1px solid rgba(218,19,141,0.5);
  background: rgba(218,19,141,0.12);
  border-left: 3px solid var(--vxit-pink);
  border-radius: 4px;
  padding: 14px 16px;
}
.vg-risk strong { color: #FF74C6; display: block; margin-bottom: 4px; font-family: var(--font-sans); font-weight: var(--fw-bold); font-size: 14px; }
.vg-risk span { font-family: var(--font-sans); font-size: 14px; line-height: 1.5; color: rgba(255,255,255,0.8); }
.vg-result__foot {
  font-family: var(--font-sans);
  font-size: 13px;
  line-height: 1.5;
  color: rgba(255,255,255,0.45);
  margin: 0;
}
.vg-result__btns { display: flex; flex-direction: column; gap: 12px; margin-top: 4px; }
.vg-result__again {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 13px 20px;
  border-radius: 4px;
  border: 1px solid rgba(255,255,255,0.22);
  background: transparent;
  color: var(--vxit-white);
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  cursor: pointer;
  transition: border-color 200ms var(--ease-snap), background-color 200ms var(--ease-snap);
}
.vg-result__again:hover { border-color: rgba(255,255,255,0.45); background: rgba(255,255,255,0.04); }

/* =====================================================================
   TWO FUNDAMENTALS
   ===================================================================== */
.vg-cards2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(16px, 2vw, 24px);
  margin-top: 8px;
}
@media (max-width: 760px) { .vg-cards2 { grid-template-columns: 1fr; } }
.vg-fcard {
  position: relative;
  padding: clamp(26px, 2.6vw, 36px);
  padding-left: clamp(28px, 2.6vw, 38px);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 6px;
  background: rgba(255,255,255,0.025);
  overflow: hidden;
}
.vg-fcard::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
}
.vg-fcard--orange::before { background: var(--vxit-orange); }
.vg-fcard--magenta::before { background: var(--vxit-pink); }
.vg-fcard__num {
  font-family: var(--font-display);
  font-weight: var(--fw-black);
  font-size: clamp(2.4rem, 4vw, 3.2rem);
  line-height: 1;
  margin-bottom: 8px;
}
.vg-fcard--orange .vg-fcard__num { color: var(--vxit-orange); }
.vg-fcard--magenta .vg-fcard__num { color: var(--vxit-pink); }
.vg-fcard__title {
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: clamp(1.25rem, 1.9vw, 1.6rem);
  line-height: 1.12;
  color: var(--vxit-white);
  letter-spacing: -0.01em;
  margin: 0 0 16px;
  text-wrap: balance;
}
.vg-fcard p {
  font-family: var(--font-sans);
  font-size: 15.5px;
  line-height: 1.6;
  color: rgba(255,255,255,0.7);
  margin: 0 0 14px;
}
.vg-fcard p:last-child { margin-bottom: 0; }
.vg-closing {
  margin-top: clamp(22px, 3vw, 32px);
  padding: clamp(20px, 2.4vw, 28px);
  border-radius: 6px;
  background: var(--vxit-gray-100);
  color: var(--fg-on-light);
}
.vg-closing p {
  font-family: var(--font-sans);
  font-size: clamp(15px, 1.3vw, 17px);
  line-height: 1.55;
  color: #2A2A2A;
  margin: 0;
}
.vg-closing strong { color: #010202; font-weight: var(--fw-bold); }

/* =====================================================================
   READINESS SPECTRUM — bar + 7 level cards
   ===================================================================== */
.vg-specbar {
  display: flex;
  width: 100%;
  border-radius: 6px;
  overflow: hidden;
  margin-bottom: clamp(28px, 4vw, 44px);
  border: 1px solid rgba(255,255,255,0.1);
}
.vg-specbar__seg {
  flex: 1;
  padding: 14px 10px;
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}
.vg-specbar__seg .n {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: var(--fw-bold);
  color: #fff;
}
.vg-specbar__seg .l {
  font-family: var(--font-sans);
  font-size: 9.5px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.82);
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 720px) {
  .vg-specbar { flex-wrap: wrap; }
  .vg-specbar__seg { flex: 1 1 25%; }
  .vg-specbar__seg .l { display: none; }
}

.vg-levels {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(12px, 1.6vw, 18px);
}
.vg-levels .vg-level:nth-child(5) { grid-column: 1; }
@media (max-width: 980px) { .vg-levels { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .vg-levels { grid-template-columns: 1fr; } }

.vg-level {
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 6px;
  background: rgba(255,255,255,0.025);
  overflow: hidden;
  transition: transform 280ms var(--ease-snap), border-color 280ms var(--ease-snap), box-shadow 280ms var(--ease-snap);
}
.vg-level:hover {
  transform: translateY(-5px);
  border-color: rgba(255,255,255,0.25);
  box-shadow: 0 20px 44px -22px rgba(0,0,0,0.8);
}
.vg-level__bar {
  padding: 11px 16px;
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: 13px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #fff;
  line-height: 1.15;
}
.vg-level__body {
  padding: 18px 18px 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}
.vg-level__tag {
  font-family: var(--font-sans);
  font-style: italic;
  font-size: 14.5px;
  line-height: 1.4;
  color: rgba(255,255,255,0.88);
  margin: 0;
}
.vg-level__signs {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.vg-level__signs li {
  position: relative;
  padding-left: 18px;
  font-family: var(--font-sans);
  font-size: 13.5px;
  line-height: 1.45;
  color: rgba(255,255,255,0.62);
}
.vg-level__signs li::before {
  content: "";
  position: absolute;
  left: 0; top: 8px;
  width: 6px; height: 6px;
  border-radius: 999px;
  background: currentColor;
  opacity: 0.6;
}
.vg-level__move {
  margin: 4px 0 0;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,0.08);
  font-family: var(--font-sans);
  font-size: 13px;
  line-height: 1.45;
  font-weight: var(--fw-medium);
}

/* =====================================================================
   FIVE PHASES
   ===================================================================== */
.vg-phases {
  display: flex;
  flex-direction: column;
  gap: clamp(14px, 1.8vw, 20px);
}
.vg-phase {
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 6px;
  background: rgba(255,255,255,0.022);
  overflow: hidden;
}
.vg-phase__bar {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 13px 22px;
}
.vg-phase__n {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--ls-wide);
  color: rgba(255,255,255,0.85);
}
.vg-phase__name {
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: #fff;
}
.vg-phase__body {
  padding: clamp(22px, 2.4vw, 32px);
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: clamp(16px, 3vw, 40px);
}
@media (max-width: 760px) { .vg-phase__body { grid-template-columns: 1fr; gap: 14px; } }
.vg-phase__essence {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: clamp(1.1rem, 1.6vw, 1.35rem);
  line-height: 1.25;
  color: var(--vxit-white);
  margin: 0;
  letter-spacing: -0.01em;
  text-wrap: balance;
}
.vg-phase__copy {
  font-family: var(--font-sans);
  font-size: 15.5px;
  line-height: 1.6;
  color: rgba(255,255,255,0.7);
  margin: 0;
}

/* Build fork */
.vg-fork {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 16px;
}
@media (max-width: 560px) { .vg-fork { grid-template-columns: 1fr; } }
.vg-fork__col {
  border-radius: 5px;
  padding: 18px 18px 20px;
  border: 1px solid rgba(255,255,255,0.12);
}
.vg-fork__col--operate { background: rgba(218,19,141,0.12); border-color: rgba(218,19,141,0.4); }
.vg-fork__col--engineer { background: rgba(153,52,103,0.16); border-color: rgba(153,52,103,0.5); }
.vg-fork__label {
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: 15px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin: 0 0 8px;
}
.vg-fork__col--operate .vg-fork__label { color: #FF74C6; }
.vg-fork__col--engineer .vg-fork__label { color: #D98BB8; }
.vg-fork__col p {
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.5;
  color: rgba(255,255,255,0.74);
  margin: 0;
}

/* Loop callout */
.vg-loop {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(16px, 2vw, 28px);
  margin-top: clamp(20px, 3vw, 32px);
  padding: clamp(22px, 2.6vw, 32px);
  border-radius: 6px;
  border: 1px solid rgba(242,99,34,0.3);
  border-left: 4px solid var(--vxit-orange);
  background: rgba(242,99,34,0.07);
}
@media (max-width: 640px) { .vg-loop { grid-template-columns: 1fr; gap: 16px; } }
.vg-loop__item strong {
  display: block;
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: clamp(1.05rem, 1.5vw, 1.25rem);
  color: var(--vxit-white);
  margin-bottom: 7px;
  letter-spacing: -0.01em;
}
.vg-loop__item p {
  font-family: var(--font-sans);
  font-size: 14.5px;
  line-height: 1.55;
  color: rgba(255,255,255,0.72);
  margin: 0;
}

/* =====================================================================
   SAFETY CALLOUT (Letting AI act)
   ===================================================================== */
.vg-safety-callout {
  margin-top: clamp(24px, 3vw, 36px);
  padding: clamp(24px, 3vw, 36px);
  border-radius: 6px;
  background: #FFF8F5;
  border-left: 4px solid var(--vxit-orange);
}
.vg-safety-callout h3 {
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: clamp(1.1rem, 1.7vw, 1.4rem);
  color: #010202;
  margin: 0 0 18px;
  letter-spacing: -0.01em;
}
.vg-safety-callout ol {
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: q;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.vg-safety-callout li {
  counter-increment: q;
  display: flex;
  align-items: flex-start;
  gap: 14px;
  font-family: var(--font-sans);
  font-size: clamp(15px, 1.3vw, 17px);
  line-height: 1.45;
  color: #2A2A2A;
  font-weight: var(--fw-medium);
}
.vg-safety-callout li::before {
  content: counter(q);
  flex: 0 0 auto;
  width: 28px; height: 28px;
  border-radius: 999px;
  background: var(--vxit-orange);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: var(--fw-bold);
  display: grid;
  place-items: center;
}

/* =====================================================================
   FOUNDATION (managed IT brief) — light inset
   ===================================================================== */
.vg-foundation {
  width: 100%;
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.012));
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

/* =====================================================================
   CEO ACCORDION
   ===================================================================== */
.vg-ceo {
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 6px;
  background: rgba(255,255,255,0.025);
  overflow: hidden;
}
.vg-ceo__btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: clamp(20px, 2.4vw, 28px) clamp(20px, 2.6vw, 32px);
  text-align: left;
  cursor: pointer;
}
.vg-ceo__btn-text {
  font-family: var(--font-display);
  font-weight: var(--fw-extrabold);
  font-size: clamp(1.1rem, 1.8vw, 1.5rem);
  color: var(--vxit-white);
  letter-spacing: -0.01em;
}
.vg-ceo__chev {
  flex: 0 0 auto;
  width: 40px; height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.22);
  display: grid; place-items: center;
  color: var(--vxit-white);
  transition: transform 320ms var(--ease-snap), background-color 220ms var(--ease-snap);
}
.vg-ceo__btn[aria-expanded="true"] .vg-ceo__chev { transform: rotate(180deg); background: var(--vxit-orange); border-color: transparent; }
.vg-ceo__panel {
  overflow: hidden;
  max-height: 0;
  transition: max-height 480ms var(--ease-in-out);
}
.vg-ceo__inner {
  padding: 0 clamp(20px, 2.6vw, 32px) clamp(24px, 2.8vw, 36px);
  border-top: 1px solid rgba(255,255,255,0.08);
}
.vg-ceo__inner > p:first-child { margin-top: 22px; }
.vg-ceo__inner p {
  font-family: var(--font-sans);
  font-size: clamp(15px, 1.3vw, 17px);
  line-height: 1.65;
  color: rgba(255,255,255,0.74);
  margin: 0 0 18px;
}
.vg-ceo__inner strong { color: var(--vxit-white); font-weight: var(--fw-bold); }
.vg-ceo__sig {
  font-family: var(--font-sans);
  font-size: 14px !important;
  font-weight: var(--fw-semibold);
  color: rgba(255,255,255,0.55) !important;
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  margin-top: 6px !important;
}

/* =====================================================================
   FINAL CTA
   ===================================================================== */
.vg-final {
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
  padding: clamp(20px, 5vw, 40px);
  scroll-margin-top: 84px;
}
.vg-final__inner {
  position: relative;
  text-align: center;
  padding: clamp(48px, 7vw, 88px) clamp(24px, 5vw, 64px);
  border-radius: 10px;
  border: 1px solid rgba(242,99,34,0.28);
  background: linear-gradient(135deg, rgba(242,99,34,0.12) 0%, rgba(218,19,141,0.08) 100%);
  overflow: hidden;
}
.vg-final__inner::after {
  content: "";
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 55% 60% at 12% 100%, rgba(242,99,34,0.28), transparent 60%),
              radial-gradient(ellipse 55% 60% at 90% 0%, rgba(218,19,141,0.24), transparent 62%);
}
.vg-final__inner > * { position: relative; z-index: 1; }
.vg-final__title {
  font-family: var(--font-display);
  font-weight: var(--fw-black);
  font-size: clamp(2.2rem, 5vw, 3.75rem);
  line-height: 0.98;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: var(--vxit-white);
  margin: 0 0 22px;
  text-wrap: balance;
}
.vg-final__body {
  font-family: var(--font-sans);
  font-size: clamp(16px, 1.5vw, 19px);
  line-height: 1.55;
  color: rgba(255,255,255,0.78);
  max-width: 56ch;
  margin: 0 auto 36px;
}
.vg-final__contact {
  margin-top: 26px;
  font-family: var(--font-mono);
  font-size: clamp(14px, 1.4vw, 17px);
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.8);
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
}
.vg-final__contact a { color: var(--vxit-white); border-bottom: 1px solid rgba(255,255,255,0.3); padding-bottom: 2px; }
.vg-final__contact a:hover { color: var(--vxit-orange); border-color: var(--vxit-orange); }
.vg-final__contact .sep { color: var(--vxit-pink); }

/* Visually-hidden utility */
.vg-sr { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
