:root {
  --bg: #060913;
  --bg-soft: #0d1320;
  --panel: rgba(11, 16, 27, 0.88);
  --panel-strong: #0c1019;
  --panel-light: #d6edf3;
  --panel-light-text: #081018;
  --text: #f4f8fc;
  --muted: #a4b3c7;
  --muted-strong: #c3cfdd;
  --cyan: #80ecf7;
  --blue: #345dff;
  --magenta: #cb28ff;
  --border: rgba(128, 236, 247, 0.18);
  --shadow: 0 24px 80px rgba(0, 0, 0, 0.4);
  --radius-lg: 28px;
  --radius-md: 24px;
  --radius-sm: 18px;
  --max: 1220px;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-width: 320px;
  color: var(--text);
  font-family: "Inter", sans-serif;
  background:
    radial-gradient(circle at top left, rgba(52, 93, 255, 0.2), transparent 30%),
    radial-gradient(circle at top right, rgba(203, 40, 255, 0.18), transparent 24%),
    linear-gradient(180deg, #05070d 0%, #09111d 34%, #06080d 100%);
}

a {
  color: inherit;
}

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

button {
  font: inherit;
}

.page-shell {
  min-height: 100vh;
}

.app {
  width: min(var(--max), calc(100vw - 40px));
  margin: 0 auto;
  padding: 18px 0 80px;
}

.hero {
  position: relative;
  padding: 6px 0 10px;
}

.hero::before {
  content: "";
  position: absolute;
  inset: -10% -12% 0;
  background:
    radial-gradient(circle at 10% 16%, rgba(52, 93, 255, 0.2), transparent 24%),
    radial-gradient(circle at 88% 8%, rgba(203, 40, 255, 0.2), transparent 24%),
    radial-gradient(circle at 60% 100%, rgba(128, 236, 247, 0.08), transparent 38%);
  pointer-events: none;
}

.hero > * {
  position: relative;
  z-index: 1;
}

.brand-bar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 8px;
}

.brand-logo {
  width: clamp(180px, 24vw, 330px);
}

.brand-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.pill {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.035);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: rgba(195, 207, 221, 0.9);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.panel {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, rgba(13, 19, 30, 0.94), rgba(8, 12, 20, 0.96));
  box-shadow: var(--shadow);
}

.hero-shell {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  padding: 20px;
  align-items: start;
}

.hero-copy {
  max-width: 34rem;
}

.eyebrow {
  margin: 0 0 10px;
  color: var(--cyan);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.hero-title,
.section-title,
.tier-title,
.step-title,
.review-title {
  margin: 0;
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 0.95;
}

.hero-title {
  max-width: 9ch;
  font-size: clamp(2.5rem, 4.5vw, 3.9rem);
}

.hero-title-mobile {
  display: none;
}

.hero-lede,
.hero-support-copy,
.section-copy,
.step-copy,
.tier-copy,
.video-note,
.signal-list li,
.check-list li,
.card-copy,
.support-copy {
  color: var(--muted);
  line-height: 1.65;
}

.hero-lede {
  max-width: 34ch;
  margin: 10px 0 0;
  font-size: 0.98rem;
  color: rgba(228, 235, 245, 0.9);
  line-height: 1.55;
}

.hero-support-copy {
  max-width: 27ch;
  margin: 8px 0 0;
  font-size: 0.88rem;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 16px 0 12px;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 18px;
  border-radius: 999px;
  font-weight: 700;
  text-decoration: none;
  border: 1px solid transparent;
  transition: transform 160ms ease, box-shadow 160ms ease;
}

.button:hover,
.button:focus-visible {
  transform: translateY(-1px);
}

.button--primary {
  background: linear-gradient(135deg, var(--blue), var(--magenta));
  box-shadow: 0 14px 34px rgba(98, 73, 255, 0.35);
}

.button--secondary {
  border-color: rgba(128, 236, 247, 0.18);
  background: rgba(255, 255, 255, 0.015);
  color: rgba(232, 239, 247, 0.92);
}

.signal-list,
.check-list {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.signal-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin: 0;
  color: rgba(195, 207, 221, 0.78);
  font-size: 0.84rem;
  line-height: 1.45;
}

.signal-note {
  white-space: nowrap;
}

.signal-separator {
  color: rgba(128, 236, 247, 0.75);
}

.signal-list li::before,
.check-list li::before {
  content: "";
  display: inline-block;
  width: 9px;
  height: 9px;
  margin-right: 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--cyan), var(--magenta));
}

.video-slot {
  display: grid;
  gap: 12px;
  height: 100%;
}

.video-label {
  color: rgba(128, 236, 247, 0.9);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.video-frame {
  position: relative;
  min-height: 228px;
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid rgba(128, 236, 247, 0.12);
  background:
    linear-gradient(180deg, rgba(5, 10, 18, 0.08), rgba(5, 10, 18, 0.78)),
    url("./brand-assets/Global-Mentorship-Program-Logo-2.png") center/42% no-repeat,
    radial-gradient(circle at center, rgba(37, 76, 209, 0.42), rgba(7, 11, 18, 0.98));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 18px 40px rgba(0, 0, 0, 0.22);
}

.video-frame--secondary {
  min-height: 245px;
  background:
    linear-gradient(180deg, rgba(2, 8, 18, 0.35), rgba(2, 8, 18, 0.84)),
    linear-gradient(135deg, rgba(44, 64, 255, 0.38), rgba(0, 0, 0, 0.08));
}

.play-chip {
  position: absolute;
  left: 18px;
  bottom: 18px;
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(7, 10, 17, 0.76);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: #fff;
  font-size: 0.88rem;
  font-weight: 700;
}

.hero-top-actions {
  display: grid;
  gap: 12px;
  align-content: start;
  padding-top: 6px;
  border-top: 1px solid rgba(128, 236, 247, 0.08);
}

.hero-top-actions-head {
  max-width: 34rem;
}

.top-actions-title {
  margin: 0 0 8px;
  font-family: "Barlow Condensed", sans-serif;
  font-size: clamp(1.55rem, 2.3vw, 2rem);
  line-height: 0.95;
  letter-spacing: -0.01em;
}

.welcome-video {
  margin-top: 28px;
}

.video-intro {
  display: grid;
  grid-template-columns: minmax(0, 0.7fr) minmax(0, 1fr);
  gap: 22px;
  padding: 24px;
  align-items: start;
  background:
    linear-gradient(180deg, rgba(12, 18, 30, 0.97), rgba(8, 12, 20, 0.99)),
    radial-gradient(circle at top left, rgba(52, 93, 255, 0.08), transparent 30%);
}

.video-intro-copy {
  max-width: 24rem;
}

.accordion-stack {
  display: grid;
  gap: 14px;
}

.accordion-card {
  border: 1px solid rgba(128, 236, 247, 0.1);
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, rgba(11, 16, 26, 0.96), rgba(8, 12, 20, 0.98));
  overflow: hidden;
}

.accordion-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  cursor: pointer;
  list-style: none;
  font-family: "Barlow Condensed", sans-serif;
  font-size: 1.28rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.accordion-summary::-webkit-details-marker {
  display: none;
}

.accordion-plus {
  color: var(--cyan);
  font-size: 1.4rem;
  line-height: 1;
  transition: transform 160ms ease;
}

.accordion-card[open] .accordion-plus {
  transform: rotate(45deg);
}

.accordion-body {
  padding: 0 20px 18px;
}

.accordion-body p {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.section {
  margin-top: 60px;
}

.section-head {
  max-width: 48rem;
  margin-bottom: 20px;
}

.section-title {
  font-size: clamp(2.1rem, 3.8vw, 3.35rem);
  margin-bottom: 10px;
}

.top-action-grid,
.step-card-grid,
.tier-card-grid,
.support-grid,
.hub-grid {
  display: grid;
  gap: 16px;
}

.top-action-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
  gap: 16px;
}

.card {
  border-radius: var(--radius-md);
  text-decoration: none;
  padding: 16px;
}

.action-card {
  background:
    linear-gradient(180deg, rgba(13, 18, 28, 0.98), rgba(8, 12, 20, 0.98)),
    linear-gradient(135deg, rgba(48, 92, 255, 0.05), rgba(203, 40, 255, 0.03));
  border: 1px solid rgba(128, 236, 247, 0.12);
  min-height: 184px;
  transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

.hub-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.hub-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 210px;
  border: 1px solid rgba(128, 236, 247, 0.12);
  background:
    linear-gradient(180deg, rgba(13, 18, 28, 0.98), rgba(8, 12, 20, 0.98)),
    linear-gradient(135deg, rgba(48, 92, 255, 0.06), rgba(203, 40, 255, 0.04));
  transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease, background 160ms ease;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

.action-card:hover,
.action-card:focus-visible,
.hub-card:hover,
.hub-card:focus-visible,
.tier-link:hover,
.tier-link:focus-visible,
.card-link:hover,
.card-link:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(128, 236, 247, 0.24);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.2);
}

.card-kicker {
  color: var(--cyan);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.card-title,
.support-title {
  margin: 8px 0 8px;
  font-family: "Barlow Condensed", sans-serif;
  font-size: 1.24rem;
  line-height: 0.98;
  letter-spacing: -0.01em;
}

.action-card .card-copy {
  line-height: 1.6;
  max-width: 24ch;
}

.hub-card .card-copy {
  line-height: 1.6;
  max-width: 28ch;
}

.hub-support {
  margin-top: 18px;
  color: rgba(195, 207, 221, 0.74);
  font-size: 0.86rem;
  line-height: 1.45;
}

.step-stack {
  display: grid;
  gap: 18px;
}

.step-panel,
.tier-panel {
  padding: 24px;
}

.step-header {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 20px;
}

.step-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 17px;
  background: linear-gradient(135deg, rgba(48, 92, 255, 0.2), rgba(203, 40, 255, 0.2));
  border: 1px solid rgba(128, 236, 247, 0.22);
  color: var(--cyan);
  font-family: "Barlow Condensed", sans-serif;
  font-size: 1.65rem;
  font-weight: 700;
}

.step-title {
  font-size: 1.82rem;
}

.step-copy {
  margin: 6px 0 0;
}

.step-card-grid,
.tier-card-grid,
.support-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.light-card {
  background: var(--panel-light);
  color: var(--panel-light-text);
}

.light-card .card-copy,
.light-card .card-link {
  color: rgba(8, 16, 24, 0.8);
}

.dark-card {
  background: #0a0d14;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.dark-card .card-copy,
.dark-card .card-link {
  color: var(--muted-strong);
}

.card-link {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  margin-top: 14px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(128, 236, 247, 0.18);
  background: rgba(255, 255, 255, 0.04);
  font-size: 0.92rem;
  font-weight: 700;
  text-decoration: none;
}

.focus-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(260px, 0.75fr);
  gap: 18px;
}

.focus-notes {
  height: 100%;
  padding: 20px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(128, 236, 247, 0.1);
  background: rgba(255, 255, 255, 0.025);
}

.focus-title {
  margin: 0 0 14px;
  font-family: "Barlow Condensed", sans-serif;
  font-size: 1.65rem;
  letter-spacing: -0.01em;
}

.tier-tablist {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 22px;
  padding: 8px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(128, 236, 247, 0.1);
}

.tier-tab {
  min-height: 46px;
  padding: 0 18px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  font-weight: 700;
  cursor: pointer;
}

.tier-tab.is-active {
  background: linear-gradient(135deg, rgba(48, 92, 255, 0.28), rgba(203, 40, 255, 0.24));
  color: #fff;
}

.tier-panel {
  display: none;
  border: 1px solid rgba(128, 236, 247, 0.12);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, rgba(13, 19, 29, 0.94), rgba(9, 13, 20, 0.98));
}

.tier-panel.is-active {
  display: block;
}

.tier-panels--static {
  display: grid;
  gap: 18px;
}

.tier-route-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-bottom: 10px;
}

.tier-route-label {
  color: var(--cyan);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.tier-route-code {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(128, 236, 247, 0.1);
  color: rgba(219, 232, 242, 0.88);
  font-size: 0.82rem;
}

.tier-title {
  margin-bottom: 8px;
  font-size: 2.2rem;
}

.tier-copy {
  max-width: 48rem;
  margin: 0 0 18px;
}

.tier-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.tier-link {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(128, 236, 247, 0.16);
  background: rgba(255, 255, 255, 0.04);
  color: #dbe8f2;
  font-size: 0.94rem;
  font-weight: 600;
  text-decoration: none;
  transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.support-card {
  min-height: 220px;
}

.support-grid--four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.support-copy a {
  color: inherit;
}

.breadcrumb-bar {
  margin-top: 14px;
  padding: 16px 20px;
  border-radius: 18px;
  border: 1px solid rgba(128, 236, 247, 0.12);
  background: rgba(255, 255, 255, 0.03);
}

.breadcrumb-link {
  color: rgba(219, 232, 242, 0.88);
  font-size: 0.95rem;
  font-weight: 600;
  text-decoration: none;
}

.breadcrumb-link:hover,
.breadcrumb-link:focus-visible {
  color: #fff;
}

.subpage-hero {
  margin-top: 24px;
}

.subpage-title {
  margin: 0;
  font-family: "Barlow Condensed", sans-serif;
  font-size: clamp(2.4rem, 4.2vw, 3.8rem);
  line-height: 0.96;
  letter-spacing: -0.03em;
}

.subpage-copy {
  max-width: 48rem;
}

.subpage-section {
  margin-top: 24px;
}

.notes-panel {
  min-height: 0;
  padding: 22px;
}

.focus-layout--subpage {
  margin-top: 6px;
}

@media (max-width: 1120px) {
  .video-intro,
  .focus-layout {
    grid-template-columns: 1fr;
  }

  .top-action-grid,
  .step-card-grid,
  .tier-card-grid,
  .hub-grid,
  .support-grid,
  .support-grid--four {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .app {
    width: min(var(--max), calc(100vw - 28px));
    padding: 12px 0 56px;
  }

  .brand-bar {
    flex-direction: column;
    gap: 12px;
    margin-bottom: 12px;
  }

  .brand-badges {
    justify-content: flex-start;
  }

  .brand-logo {
    width: min(236px, 68vw);
  }

  .pill {
    min-height: 28px;
    padding: 0 9px;
    font-size: 0.67rem;
  }

  .hero-shell,
  .video-intro,
  .step-panel,
  .tier-panel,
  .focus-notes,
  .card {
    padding: 14px;
  }

  .accordion-summary {
    padding: 16px;
    font-size: 1.14rem;
  }

  .accordion-body {
    padding: 0 16px 16px;
  }

  .hero-title {
    max-width: 7.5ch;
    font-size: clamp(1.78rem, 8.6vw, 2.55rem);
  }

  .hero-title-desktop {
    display: none;
  }

  .hero-title-mobile {
    display: inline;
  }

  .hero-lede,
  .hero-support-copy {
    font-size: 0.88rem;
    line-height: 1.55;
  }

  .hero-support-copy {
    display: none;
  }

  .hero-actions {
    gap: 10px;
    margin: 14px 0 8px;
    flex-direction: column;
  }

  .button,
  .tier-link,
  .card-link {
    justify-content: center;
  }

  .button {
    width: 100%;
    flex: 0 0 auto;
    min-height: 44px;
  }

  .signal-row {
    display: none;
  }

  .hero-top-actions {
    gap: 10px;
    padding-top: 4px;
    border-top: 0;
  }

  .hero-top-actions .section-copy {
    display: none;
  }

  .top-action-grid,
  .step-card-grid,
  .tier-card-grid,
  .hub-grid,
  .support-grid,
  .support-grid--four {
    grid-template-columns: 1fr;
  }

  .section {
    margin-top: 44px;
  }

  .section-title,
  .step-title,
  .tier-title,
  .review-title {
    font-size: 1.95rem;
  }

  .top-actions-title {
    font-size: 1.42rem;
  }

  .step-header {
    flex-direction: column;
  }

  .video-frame {
    min-height: 180px;
  }

  .tier-tablist {
    display: grid;
    width: 100%;
    grid-template-columns: 1fr;
    border-radius: 24px;
  }

  .tier-tab {
    width: 100%;
  }
}
