/* ============================================================
   BigDot Landing Pages v2 — Custom Stylesheet
   Convention: bdPages prefix + camelCase BEM-like
   Bootstrap 5.3 companion file
   ============================================================ */

/* ── Google Fonts ────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Cormorant+Garamond:wght@400;500;600;700&family=Bricolage+Grotesque:wght@400;500;600;700;800&display=swap');

/* ── CSS Variables ───────────────────────────────────────── */
:root {
  --site-primary-font: "Plus Jakarta Sans", sans-serif;
  --site-secondary-font: 'Cormorant Garamond', Georgia, serif;
  --site-tertiary-font: "Bricolage Grotesque", sans-serif;
  --site-primary-color: #1c2d64;
  --site-secondary-color: #f2f4ff;
  --site-tertiary-color: #2255e8;
  --site-quaternary-color: #f15a25;
  --site-text-color: #1C1A16;
  --site-text-muted-color: #808080;

  /* Light mode tokens */
  --bdBg: #ffffff;
  --bdBgAlt: #f2f4ff;
  --bdBgCard: #ffffff;
  --bdBgCardHover: #f2f4ff;
  --bdText: #1C1A16;
  --bdTextMuted: #808080;
  --bdBorder: rgba(28, 45, 100, 0.12);
  --bdNavBg: rgba(255,255,255,0.92);
  --bdAccent: var(--site-primary-color);
  --bdAccentAlt: var(--site-tertiary-color);
  --bdCta: var(--site-quaternary-color);
  --bdCtaText: #ffffff;
  --bdHighlight: var(--site-primary-color);
  --bdHighlightAlt: var(--site-tertiary-color);

  /* Transition */
  --bdTransition: 0.3s ease;
}

/* ── Dark Mode Tokens ────────────────────────────────────── */
[data-theme="dark"] {
  --bdBg: #0a0a0f;
  --bdBgAlt: #13131c;
  --bdBgCard: #13131c;
  --bdBgCardHover: #1a1a28;
  --bdText: #fafaf8;
  --bdTextMuted: #6b6b7a;
  --bdBorder: rgba(255,255,255,0.08);
  --bdNavBg: rgba(10,10,15,0.88);
  --bdAccent: #c8f135;
  --bdAccentAlt: #1a1aff;
  --bdCta: #c8f135;
  --bdCtaText: #0a0a0f;
  --bdHighlight: #c8f135;
  --bdHighlightAlt: #ff3d8f;
}

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

html { scroll-behavior: smooth; }

body {
  font-family: var(--site-primary-font);
  background-color: var(--bdBg);
  color: var(--bdText);
  overflow-x: hidden;
  transition: background-color var(--bdTransition), color var(--bdTransition);
}

/* ── Custom Cursor (desktop only) ───────────────────────── */
@media (hover: hover) and (pointer: fine) {
  body { cursor: none; }
  .bdPagesCursor {
    width: 12px;
    height: 12px;
    background: var(--bdAccent);
    border-radius: 50%;
    position: fixed;
    pointer-events: none;
    z-index: 9999;
    transition: transform 0.15s ease;
    mix-blend-mode: difference;
  }
  .bdPagesCursorRing {
    width: 40px;
    height: 40px;
    border: 1.5px solid rgba(200,241,53,0.4);
    border-radius: 50%;
    position: fixed;
    pointer-events: none;
    z-index: 9998;
    transition: transform 0.4s ease, width 0.3s, height 0.3s;
  }
  [data-theme="light"] .bdPagesCursorRing {
    border-color: rgba(28, 45, 100, 0.25);
  }
}

/* ── Logo Image ──────────────────────────────────────────── */
.bdPagesLogoImg {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.bdPagesLogoImg__light,
.bdPagesLogoImg__dark {
  height: 32px;
  width: auto;
  display: block;
  transition: opacity 0.2s;
}

/* Light mode: show light logo, hide dark logo */
[data-theme="light"] .bdPagesLogoImg__dark { display: none; }
[data-theme="light"] .bdPagesLogoImg__light { display: block; }

/* Dark mode: show dark logo, hide light logo */
[data-theme="dark"] .bdPagesLogoImg__light { display: none; }
[data-theme="dark"] .bdPagesLogoImg__dark { display: block; }

/* ── Navigation ──────────────────────────────────────────── */
.bdPagesNav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: var(--bdNavBg);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--bdBorder);
  padding: 1rem 0;
  transition: background var(--bdTransition), border-color var(--bdTransition);
}

.bdPagesLogo {
  font-family: var(--site-tertiary-font);
  font-size: 1.4rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--bdText);
  text-decoration: none;
}

.bdPagesLogo__dot {
  color: var(--bdAccent);
}

[data-theme="light"] .bdPagesLogo__dot {
  color: var(--site-quaternary-color);
}

.bdPagesNavCta {
  background: var(--bdCta);
  color: var(--bdCtaText);
  font-family: var(--site-primary-font);
  font-weight: 700;
  font-size: 0.875rem;
  padding: 0.55rem 1.4rem;
  border-radius: 100px;
  text-decoration: none;
  letter-spacing: 0.01em;
  transition: transform 0.2s, box-shadow 0.2s;
  white-space: nowrap;
}

.bdPagesNavCta:hover {
  transform: scale(1.05);
  box-shadow: 0 0 24px rgba(200,241,53,0.35);
  color: var(--bdCtaText);
}

[data-theme="light"] .bdPagesNavCta:hover {
  box-shadow: 0 0 24px rgba(241,90,37,0.35);
}

/* Theme Toggle */
.bdPagesThemeToggle {
  width: 48px;
  height: 26px;
  background: var(--bdBorder);
  border: 1.5px solid var(--bdBorder);
  border-radius: 100px;
  cursor: pointer;
  position: relative;
  transition: background 0.3s;
  flex-shrink: 0;
}

.bdPagesThemeToggle:hover {
  border-color: var(--bdAccent);
}

[data-theme="light"] .bdPagesThemeToggle:hover {
  border-color: var(--site-tertiary-color);
}

.bdPagesThemeToggle__knob {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--bdText);
  position: absolute;
  top: 2px;
  left: 2px;
  transition: transform 0.3s, background 0.3s;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
}

[data-theme="dark"] .bdPagesThemeToggle__knob {
  transform: translateX(22px);
  background: var(--bdAccent);
}

.bdPagesThemeToggle__icon {
  line-height: 1;
}

/* ── Hero Section ────────────────────────────────────────── */
.bdPagesHero {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 7rem 1rem 4rem;
  position: relative;
  overflow: hidden;
}

.bdPagesHeroBg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(34,85,232,0.08) 0%, transparent 70%),
    radial-gradient(ellipse 60% 40% at 20% 80%, rgba(28,45,100,0.06) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 80% 70%, rgba(241,90,37,0.05) 0%, transparent 60%);
}

[data-theme="dark"] .bdPagesHeroBg {
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(200,241,53,0.08) 0%, transparent 70%),
    radial-gradient(ellipse 60% 40% at 20% 80%, rgba(26,26,255,0.06) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 80% 70%, rgba(255,61,143,0.05) 0%, transparent 60%);
}

.bdPagesHeroBadge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(34,85,232,0.08);
  border: 1px solid rgba(34,85,232,0.2);
  padding: 0.4rem 1rem;
  border-radius: 100px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--site-tertiary-color);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 2rem;
  animation: bdFadeUp 0.8s ease both;
}

[data-theme="dark"] .bdPagesHeroBadge {
  background: rgba(200,241,53,0.1);
  border-color: rgba(200,241,53,0.25);
  color: #c8f135;
}

.bdPagesHeroTitle {
  font-family: var(--site-tertiary-font);
  font-size: clamp(2.8rem, 8vw, 7rem);
  font-weight: 800;
  line-height: 0.95;
  letter-spacing: -0.04em;
  color: var(--bdText);
  margin-bottom: 1.5rem;
  animation: bdFadeUp 0.8s 0.1s ease both;
}

.bdPagesHeroTitle__accent {
  color: var(--site-tertiary-color);
}

[data-theme="dark"] .bdPagesHeroTitle__accent {
  color: #c8f135;
}

.bdPagesHeroTitle__strike {
  position: relative;
  color: var(--bdTextMuted);
  text-decoration: line-through;
  text-decoration-color: var(--site-quaternary-color);
  text-decoration-thickness: 3px;
}

[data-theme="dark"] .bdPagesHeroTitle__strike {
  text-decoration-color: #ff3d8f;
}

.bdPagesHeroSub {
  font-size: clamp(1rem, 2.5vw, 1.2rem);
  color: var(--bdTextMuted);
  max-width: 540px;
  line-height: 1.65;
  margin: 0 auto 2.5rem;
  animation: bdFadeUp 0.8s 0.2s ease both;
}

.bdPagesHeroActions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  justify-content: center;
  animation: bdFadeUp 0.8s 0.3s ease both;
}

/* Buttons */
.bdPagesBtnPrimary {
  background: var(--bdCta);
  color: var(--bdCtaText);
  font-family: var(--site-primary-font);
  font-weight: 700;
  font-size: 1rem;
  padding: 0.875rem 2.2rem;
  border-radius: 100px;
  text-decoration: none;
  transition: transform 0.2s, box-shadow 0.2s;
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.bdPagesBtnPrimary::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.25), transparent);
  opacity: 0;
  transition: opacity 0.2s;
}

.bdPagesBtnPrimary:hover {
  transform: translateY(-2px) scale(1.03);
  box-shadow: 0 8px 32px rgba(241,90,37,0.35);
  color: var(--bdCtaText);
}

[data-theme="dark"] .bdPagesBtnPrimary:hover {
  box-shadow: 0 8px 32px rgba(200,241,53,0.35);
}

.bdPagesBtnPrimary:hover::after { opacity: 1; }

.bdPagesBtnGhost {
  color: var(--bdText);
  font-family: var(--site-primary-font);
  font-weight: 600;
  font-size: 1rem;
  padding: 0.875rem 2.2rem;
  border-radius: 100px;
  text-decoration: none;
  border: 1.5px solid var(--bdBorder);
  transition: border-color 0.2s, background 0.2s;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.bdPagesBtnGhost:hover {
  border-color: var(--bdAccentAlt);
  background: rgba(34,85,232,0.06);
  color: var(--bdText);
}

[data-theme="dark"] .bdPagesBtnGhost:hover {
  border-color: rgba(255,255,255,0.4);
  background: rgba(255,255,255,0.05);
}

/* ── Hero Profile Cards ──────────────────────────────────── */
.bdPagesHeroCards {
  position: relative;
  width: 100%;
  max-width: 900px;
  height: 260px;
  margin: 3rem auto 0;
  animation: bdFadeUp 0.8s 0.4s ease both;
}

.bdPagesProfileCard {
  position: absolute;
  background: var(--bdBgCard);
  border: 1px solid var(--bdBorder);
  border-radius: 20px;
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  box-shadow: 0 24px 60px rgba(0,0,0,0.12);
}

[data-theme="dark"] .bdPagesProfileCard {
  box-shadow: 0 24px 60px rgba(0,0,0,0.5);
}

.bdPagesProfileCard--main {
  left: 50%;
  transform: translateX(-50%);
  width: 260px;
  animation: bdFloat 5s ease-in-out infinite;
}

.bdPagesProfileCard--left {
  left: 5%;
  top: 40px;
  width: 200px;
  animation: bdFloat 5s 1s ease-in-out infinite;
  opacity: 0.8;
}

.bdPagesProfileCard--right {
  right: 5%;
  top: 40px;
  width: 200px;
  animation: bdFloat 5s 2s ease-in-out infinite;
  opacity: 0.8;
}

.bdPagesCardAvatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 1rem;
  color: #ffffff;
  flex-shrink: 0;
}

.bdPagesCardName {
  font-family: var(--site-primary-font);
  font-weight: 700;
  font-size: 1rem;
  color: var(--bdText);
}

.bdPagesCardMeta {
  font-size: 0.78rem;
  color: var(--bdTextMuted);
}

.bdPagesCardTags {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
}

.bdPagesTag {
  font-size: 0.7rem;
  font-weight: 500;
  padding: 0.25rem 0.6rem;
  border-radius: 100px;
  background: rgba(28,45,100,0.07);
  color: var(--bdTextMuted);
}

[data-theme="dark"] .bdPagesTag {
  background: rgba(255,255,255,0.07);
  color: rgba(255,255,255,0.7);
}

.bdPagesTag--accent {
  background: rgba(34,85,232,0.1);
  color: var(--site-tertiary-color);
}

[data-theme="dark"] .bdPagesTag--accent {
  background: rgba(200,241,53,0.15);
  color: #c8f135;
}

.bdPagesCardStat {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: var(--bdTextMuted);
}

.bdPagesCardStatDot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.bdPagesCardAlert {
  background: rgba(34,85,232,0.08);
  border: 1px solid rgba(34,85,232,0.15);
  border-radius: 10px;
  padding: 0.6rem 0.8rem;
  font-size: 0.78rem;
  color: var(--site-tertiary-color);
}

[data-theme="dark"] .bdPagesCardAlert {
  background: rgba(200,241,53,0.08);
  border-color: rgba(200,241,53,0.2);
  color: #c8f135;
}

/* ── Marquee ─────────────────────────────────────────────── */
.bdPagesMarqueeWrap {
  overflow: hidden;
  padding: 1.25rem 0;
  background: rgba(28,45,100,0.03);
  border-top: 1px solid var(--bdBorder);
  border-bottom: 1px solid var(--bdBorder);
}

[data-theme="dark"] .bdPagesMarqueeWrap {
  background: rgba(255,255,255,0.02);
}

.bdPagesMarqueeTrack {
  display: flex;
  gap: 2.5rem;
  width: max-content;
  animation: bdMarquee 28s linear infinite;
}

.bdPagesMarqueeItem {
  font-family: var(--site-tertiary-font);
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--bdTextMuted);
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 1rem;
}

.bdPagesMarqueeDot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--site-tertiary-color);
  flex-shrink: 0;
}

[data-theme="dark"] .bdPagesMarqueeDot {
  background: #c8f135;
}

/* ── Section Common ──────────────────────────────────────── */
.bdPagesSection {
  padding: 5rem 0;
}

.bdPagesSectionLabel {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--site-tertiary-color);
  margin-bottom: 0.875rem;
  display: block;
}

[data-theme="dark"] .bdPagesSectionLabel {
  color: #c8f135;
}

.bdPagesSectionTitle {
  font-family: var(--site-tertiary-font);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--bdText);
}

.bdPagesSectionTitle__colored {
  color: var(--site-tertiary-color);
}

[data-theme="dark"] .bdPagesSectionTitle__colored {
  color: #c8f135;
}

.bdPagesSectionTitle__pink {
  color: var(--site-quaternary-color);
}

[data-theme="dark"] .bdPagesSectionTitle__pink {
  color: #ff3d8f;
}

/* ── Problem Section ─────────────────────────────────────── */
.bdPagesProblemSection {
  background: var(--bdBg);
}

.bdPagesProblemCard {
  background: var(--bdBgCard);
  border: 1px solid var(--bdBorder);
  border-radius: 20px;
  padding: 2rem;
  position: relative;
  overflow: hidden;
  transition: border-color var(--bdTransition), transform var(--bdTransition), box-shadow var(--bdTransition);
  height: 100%;
}

.bdPagesProblemCard:hover {
  border-color: var(--site-quaternary-color);
  transform: translateY(-4px);
  box-shadow: 0 8px 32px rgba(241,90,37,0.1);
}

[data-theme="dark"] .bdPagesProblemCard:hover {
  border-color: rgba(255,61,143,0.35);
  box-shadow: none;
}

.bdPagesProblemCard::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--site-quaternary-color);
  opacity: 0;
  transition: opacity var(--bdTransition);
}

[data-theme="dark"] .bdPagesProblemCard::before {
  background: #ff3d8f;
}

.bdPagesProblemCard:hover::before { opacity: 1; }

.bdPagesProblemNum {
  font-family: var(--site-secondary-font);
  font-size: 3.5rem;
  font-weight: 700;
  color: rgba(28,45,100,0.07);
  line-height: 1;
  margin-bottom: 1rem;
}

[data-theme="dark"] .bdPagesProblemNum {
  color: rgba(255,255,255,0.06);
}

.bdPagesProblemCard__title {
  font-family: var(--site-primary-font);
  font-size: 1.15rem;
  font-weight: 700;
  margin-bottom: 0.75rem;
  color: var(--bdText);
}

.bdPagesProblemCard__text {
  font-size: 0.9rem;
  color: var(--bdTextMuted);
  line-height: 1.65;
  margin: 0;
}

/* ── Solution Section ────────────────────────────────────── */
.bdPagesSolutionSection {
  background: rgba(34,85,232,0.03);
  border-top: 1px solid rgba(34,85,232,0.08);
  border-bottom: 1px solid rgba(34,85,232,0.08);
}

[data-theme="dark"] .bdPagesSolutionSection {
  background: rgba(200,241,53,0.03);
  border-top-color: rgba(200,241,53,0.08);
  border-bottom-color: rgba(200,241,53,0.08);
}

.bdPagesSolutionVisual {
  background: var(--bdBgCard);
  border: 1px solid rgba(34,85,232,0.15);
  border-radius: 24px;
  padding: 2rem;
  box-shadow: 0 0 60px rgba(34,85,232,0.06);
  position: relative;
}

[data-theme="dark"] .bdPagesSolutionVisual {
  border-color: rgba(200,241,53,0.15);
  box-shadow: 0 0 60px rgba(200,241,53,0.05);
}

.bdPagesProfilePreview {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.bdPagesPpHeader {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--bdBorder);
}

.bdPagesPpAvatar {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--site-tertiary-color), var(--site-primary-color));
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 1.2rem;
  color: #ffffff;
  flex-shrink: 0;
}

[data-theme="dark"] .bdPagesPpAvatar {
  background: linear-gradient(135deg, #c8f135, #1a1aff);
  color: #0a0a0f;
}

.bdPagesPpName {
  font-family: var(--site-primary-font);
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--bdText);
}

.bdPagesPpMeta {
  font-size: 0.8rem;
  color: var(--bdTextMuted);
}

.bdPagesPpSkills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.bdPagesPpSkill {
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.3rem 0.75rem;
  border-radius: 100px;
  background: rgba(34,85,232,0.08);
  color: var(--site-tertiary-color);
  border: 1px solid rgba(34,85,232,0.18);
}

[data-theme="dark"] .bdPagesPpSkill {
  background: rgba(200,241,53,0.1);
  color: #c8f135;
  border-color: rgba(200,241,53,0.2);
}

.bdPagesPpProjects {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.bdPagesPpProject {
  background: rgba(28,45,100,0.04);
  border-radius: 10px;
  padding: 0.75rem 1rem;
  font-size: 0.82rem;
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

[data-theme="dark"] .bdPagesPpProject {
  background: rgba(255,255,255,0.04);
}

.bdPagesPpProjectDot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--site-tertiary-color);
  flex-shrink: 0;
  margin-top: 4px;
}

[data-theme="dark"] .bdPagesPpProjectDot {
  background: #c8f135;
}

.bdPagesPpProjectName {
  font-weight: 600;
  color: var(--bdText);
}

.bdPagesPpProjectType {
  color: var(--bdTextMuted);
  font-size: 0.75rem;
  margin-top: 0.1rem;
}

.bdPagesPpQr {
  display: flex;
  align-items: center;
  gap: 1rem;
  background: rgba(28,45,100,0.03);
  border: 1px solid var(--bdBorder);
  border-radius: 12px;
  padding: 0.75rem 1rem;
  font-size: 0.82rem;
  color: var(--bdTextMuted);
}

[data-theme="dark"] .bdPagesPpQr {
  background: rgba(255,255,255,0.03);
}

.bdPagesQrBox {
  width: 40px;
  height: 40px;
  border-radius: 6px;
  background: var(--bdText);
  display: grid;
  grid-template-columns: repeat(5,1fr);
  gap: 2px;
  padding: 4px;
  flex-shrink: 0;
}

.bdPagesQrCell { background: var(--bdBg); border-radius: 1px; }
.bdPagesQrCell--w { background: transparent; }

.bdPagesSolutionPills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-top: 1.5rem;
}

.bdPagesPill {
  font-size: 0.8rem;
  font-weight: 600;
  padding: 0.4rem 1rem;
  border-radius: 100px;
  border: 1px solid var(--bdBorder);
  color: var(--bdTextMuted);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.bdPagesPill__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--site-tertiary-color);
}

[data-theme="dark"] .bdPagesPill__dot {
  background: #c8f135;
}

/* ── Benefits Section ────────────────────────────────────── */
.bdPagesBenefitCard {
  border-radius: 20px;
  padding: 2rem;
  position: relative;
  overflow: hidden;
  transition: transform var(--bdTransition);
  height: 100%;
}

.bdPagesBenefitCard:hover { transform: translateY(-6px); }

.bdPagesBenefitCard--blue {
  background: linear-gradient(135deg, rgba(34,85,232,0.1), rgba(34,85,232,0.03));
  border: 1px solid rgba(34,85,232,0.18);
}

.bdPagesBenefitCard--lime {
  background: linear-gradient(135deg, rgba(34,85,232,0.07), rgba(28,45,100,0.03));
  border: 1px solid rgba(28,45,100,0.12);
}

.bdPagesBenefitCard--pink {
  background: linear-gradient(135deg, rgba(241,90,37,0.1), rgba(241,90,37,0.03));
  border: 1px solid rgba(241,90,37,0.18);
}

.bdPagesBenefitCard--orange {
  background: linear-gradient(135deg, rgba(28,45,100,0.1), rgba(28,45,100,0.03));
  border: 1px solid rgba(28,45,100,0.15);
}

[data-theme="dark"] .bdPagesBenefitCard--blue {
  background: linear-gradient(135deg, #1a1aff22, #1a1aff08);
  border-color: rgba(26,26,255,0.2);
}
[data-theme="dark"] .bdPagesBenefitCard--lime {
  background: linear-gradient(135deg, rgba(200,241,53,0.12), rgba(200,241,53,0.03));
  border-color: rgba(200,241,53,0.2);
}
[data-theme="dark"] .bdPagesBenefitCard--pink {
  background: linear-gradient(135deg, rgba(255,61,143,0.12), rgba(255,61,143,0.03));
  border-color: rgba(255,61,143,0.2);
}
[data-theme="dark"] .bdPagesBenefitCard--orange {
  background: linear-gradient(135deg, rgba(255,107,43,0.12), rgba(255,107,43,0.03));
  border-color: rgba(255,107,43,0.2);
}

.bdPagesBenefitIcon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin-bottom: 1.25rem;
}

.bdPagesBenefitCard__title {
  font-family: var(--site-primary-font);
  font-weight: 700;
  font-size: 1.1rem;
  margin-bottom: 0.6rem;
  color: var(--bdText);
}

.bdPagesBenefitCard__text {
  font-size: 0.88rem;
  color: var(--bdTextMuted);
  line-height: 1.65;
  margin: 0;
}

/* ── How It Works ────────────────────────────────────────── */
.bdPagesHowSection {
  background: var(--bdBg);
}

.bdPagesStepsWrap {
  position: relative;
  margin-top: 4rem;
}

.bdPagesStepsLine {
  display: none;
}

@media (min-width: 768px) {
  .bdPagesStepsLine {
    display: block;
    position: absolute;
    top: 32px;
    left: calc(16.67% + 1rem);
    right: calc(16.67% + 1rem);
    height: 1px;
    background: linear-gradient(90deg, var(--site-tertiary-color), var(--site-primary-color));
  }
  [data-theme="dark"] .bdPagesStepsLine {
    background: linear-gradient(90deg, #c8f135, #1a1aff);
  }
}

.bdPagesStep {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 0 1.5rem;
}

.bdPagesStepNum {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--bdBgCard);
  border: 2px solid var(--site-tertiary-color);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--site-tertiary-font);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--site-tertiary-color);
  margin-bottom: 1.5rem;
  position: relative;
  z-index: 1;
  box-shadow: 0 0 24px rgba(34,85,232,0.2);
}

.bdPagesStepNum--blue {
  border-color: var(--site-primary-color);
  color: var(--site-primary-color);
  box-shadow: 0 0 24px rgba(28,45,100,0.25);
}

[data-theme="dark"] .bdPagesStepNum--blue {
  border-color: #1a1aff;
  color: #1a1aff;
  box-shadow: 0 0 24px rgba(26,26,255,0.3);
}

.bdPagesStepNum--lime {
  border-color: var(--site-tertiary-color);
  color: var(--site-tertiary-color);
  box-shadow: 0 0 24px rgba(34,85,232,0.2);
}

[data-theme="dark"] .bdPagesStepNum--lime {
  border-color: #c8f135;
  color: #c8f135;
  box-shadow: 0 0 24px rgba(200,241,53,0.2);
}

.bdPagesStepNum--pink {
  border-color: var(--site-quaternary-color);
  color: var(--site-quaternary-color);
  box-shadow: 0 0 24px rgba(241,90,37,0.2);
}

[data-theme="dark"] .bdPagesStepNum--pink {
  border-color: #ff3d8f;
  color: #ff3d8f;
  box-shadow: 0 0 24px rgba(255,61,143,0.2);
}

.bdPagesStep__title {
  font-family: var(--site-primary-font);
  font-weight: 700;
  font-size: 1.1rem;
  margin-bottom: 0.6rem;
  color: var(--bdText);
}

.bdPagesStep__text {
  font-size: 0.87rem;
  color: var(--bdTextMuted);
  line-height: 1.65;
  margin: 0;
}

/* ── Social Proof ────────────────────────────────────────── */
.bdPagesSocialSection {
  background: rgba(28,45,100,0.02);
}

[data-theme="dark"] .bdPagesSocialSection {
  background: rgba(255,255,255,0.01);
}

.bdPagesUseCard {
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid var(--bdBorder);
  transition: transform var(--bdTransition), border-color var(--bdTransition);
  height: 100%;
}

.bdPagesUseCard:hover {
  transform: translateY(-4px);
  border-color: rgba(34,85,232,0.25);
}

[data-theme="dark"] .bdPagesUseCard:hover {
  border-color: rgba(200,241,53,0.2);
}

.bdPagesUseCardImg {
  height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3.5rem;
}

.bdPagesUseCard--handshake .bdPagesUseCardImg {
  background: linear-gradient(135deg, rgba(28,45,100,0.12), rgba(34,85,232,0.2));
}

.bdPagesUseCard--briefcase .bdPagesUseCardImg {
  background: linear-gradient(135deg, rgba(34,85,232,0.08), rgba(28,45,100,0.15));
}

.bdPagesUseCard--globe .bdPagesUseCardImg {
  background: linear-gradient(135deg, rgba(241,90,37,0.08), rgba(241,90,37,0.18));
}

[data-theme="dark"] .bdPagesUseCard--handshake .bdPagesUseCardImg {
  background: linear-gradient(135deg, #0d0d2b, #1a1aff33);
}
[data-theme="dark"] .bdPagesUseCard--briefcase .bdPagesUseCardImg {
  background: linear-gradient(135deg, #0f1a0d, rgba(200,241,53,0.2));
}
[data-theme="dark"] .bdPagesUseCard--globe .bdPagesUseCardImg {
  background: linear-gradient(135deg, #1a0d1a, rgba(255,61,143,0.2));
}

.bdPagesUseCardBody {
  padding: 1.5rem;
  background: var(--bdBgCard);
}

.bdPagesUseCardBody__title {
  font-family: var(--site-primary-font);
  font-weight: 700;
  font-size: 1rem;
  margin-bottom: 0.5rem;
  color: var(--bdText);
}

.bdPagesUseCardBody__text {
  font-size: 0.83rem;
  color: var(--bdTextMuted);
  line-height: 1.6;
  margin: 0;
}

/* ── Testimonials ────────────────────────────────────────── */
.bdPagesTestiStrip {
  display: flex;
  gap: 1.5rem;
  overflow-x: auto;
  padding-bottom: 1rem;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.bdPagesTestiStrip::-webkit-scrollbar { display: none; }

.bdPagesTesti {
  background: var(--bdBgCard);
  border: 1px solid var(--bdBorder);
  border-radius: 16px;
  padding: 1.5rem;
  min-width: 280px;
  flex-shrink: 0;
  transition: border-color var(--bdTransition);
}

.bdPagesTesti:hover {
  border-color: rgba(34,85,232,0.25);
}

[data-theme="dark"] .bdPagesTesti:hover {
  border-color: rgba(200,241,53,0.2);
}

.bdPagesTestiText {
  font-size: 0.9rem;
  color: var(--bdTextMuted);
  line-height: 1.65;
  margin-bottom: 1rem;
  font-style: italic;
}

.bdPagesTestiAuthor {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.bdPagesTestiAvatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 0.85rem;
  color: #ffffff;
  flex-shrink: 0;
}

[data-theme="dark"] .bdPagesTestiAvatar {
  color: #0a0a0f;
}

.bdPagesTestiName {
  font-family: var(--site-primary-font);
  font-weight: 700;
  font-size: 0.88rem;
  color: var(--bdText);
}

.bdPagesTestiRole {
  font-size: 0.75rem;
  color: var(--bdTextMuted);
}

/* ── Features Section ────────────────────────────────────── */
.bdPagesFeaturesSection {
  background: var(--bdBgAlt);
}

[data-theme="dark"] .bdPagesFeaturesSection {
  background: var(--bdBg);
}

.bdPagesFeatureCard {
  background: var(--bdBgCard);
  border: 1px solid var(--bdBorder);
  border-radius: 20px;
  padding: 2rem;
  transition: border-color var(--bdTransition), transform var(--bdTransition);
  position: relative;
  overflow: hidden;
  height: 100%;
}

.bdPagesFeatureCard:hover {
  border-color: rgba(34,85,232,0.25);
  transform: translateY(-4px);
}

[data-theme="dark"] .bdPagesFeatureCard:hover {
  border-color: rgba(200,241,53,0.2);
}

.bdPagesFeatureCard::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--site-tertiary-color), transparent);
  opacity: 0;
  transition: opacity var(--bdTransition);
}

[data-theme="dark"] .bdPagesFeatureCard::after {
  background: linear-gradient(90deg, #c8f135, transparent);
}

.bdPagesFeatureCard:hover::after { opacity: 1; }

.bdPagesFeatureIcon {
  font-size: 2rem;
  margin-bottom: 1rem;
  display: block;
}

.bdPagesFeatureCard__title {
  font-family: var(--site-primary-font);
  font-weight: 700;
  font-size: 1.1rem;
  margin-bottom: 0.6rem;
  color: var(--bdText);
}

.bdPagesFeatureCard__text {
  font-size: 0.87rem;
  color: var(--bdTextMuted);
  line-height: 1.65;
  margin: 0;
}

.bdPagesFeatureCard--wide {
  display: flex;
  gap: 2rem;
  align-items: flex-start;
}

.bdPagesFeatureCard--wide .bdPagesFeatureIcon {
  font-size: 3rem;
  flex-shrink: 0;
  margin-bottom: 0;
}

@media (max-width: 576px) {
  .bdPagesFeatureCard--wide {
    flex-direction: column;
  }
}

/* ── CTA Section ─────────────────────────────────────────── */
.bdPagesCtaSection {
  padding: 7rem 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.bdPagesCtaGlow {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 600px;
  height: 400px;
  background: radial-gradient(ellipse, rgba(34,85,232,0.1) 0%, transparent 70%);
  pointer-events: none;
}

[data-theme="dark"] .bdPagesCtaGlow {
  background: radial-gradient(ellipse, rgba(200,241,53,0.12) 0%, transparent 70%);
}

.bdPagesCtaNote {
  font-size: 0.8rem;
  color: var(--bdTextMuted);
  margin-top: 0.5rem;
}

/* Stats row */
.bdPagesStatVal {
  font-family: var(--site-tertiary-font);
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--site-tertiary-color);
  line-height: 1;
}

[data-theme="dark"] .bdPagesStatVal {
  color: #c8f135;
}

.bdPagesStatLabel {
  font-size: 0.85rem;
  color: var(--bdTextMuted);
  margin-top: 0.25rem;
}

/* ── Footer ──────────────────────────────────────────────── */
.bdPagesFooter {
  padding: 1.75rem 0;
  border-top: 1px solid var(--bdBorder);
  font-size: 0.82rem;
  color: var(--bdTextMuted);
}

.bdPagesFooterLink {
  color: var(--bdTextMuted);
  text-decoration: none;
  transition: color var(--bdTransition);
}

.bdPagesFooterLink:hover {
  color: var(--bdText);
}

/* ── Scroll Reveal ───────────────────────────────────────── */
.bdPagesReveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.bdPagesReveal.bdPagesReveal--visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Animations ──────────────────────────────────────────── */
@keyframes bdFadeUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes bdFloat {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-12px); }
}

.bdPagesProfileCard--main {
  animation: bdFloat 5s ease-in-out infinite !important;
}

@keyframes bdMarquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ── Responsive Overrides ────────────────────────────────── */
@media (max-width: 767px) {
  .bdPagesProfileCard--left,
  .bdPagesProfileCard--right { display: none; }

  .bdPagesHeroCards { height: 200px; }

  .bdPagesSection { padding: 3.5rem 0; }

  .bdPagesCtaSection { padding: 4rem 0; }

  .bdPagesStep { margin-bottom: 2rem; }

  .bdPagesHeroTitle {
    letter-spacing: -0.03em;
  }
}

@media (max-width: 991px) {
  .bdPagesStepsLine { display: none; }
}

/* ============================================================
   BigDot Professional Page — bdPagesPro components
   ============================================================ */

/* ── Pro Color Tokens ────────────────────────────────────── */
:root {
  --pro-gold: #c9a84c;
  --pro-gold-light: #e8c97a;
  --pro-gold-dim: rgba(201,168,76,0.12);
  --pro-gold-border: rgba(201,168,76,0.2);
  --pro-bg: #0a0a0b;
  --pro-bg-card: #141418;
  --pro-bg-alt: #111114;
  --pro-border: rgba(255,255,255,0.08);
  --pro-border-hover: rgba(255,255,255,0.18);
  --pro-text: #f5f4f0;
  --pro-muted: #9ba3af;
  --pro-faint: #5a5a6a;
}

[data-theme="light"] {
  --pro-bg: #faf9f6;
  --pro-bg-card: #ffffff;
  --pro-bg-alt: #f3f1ec;
  --pro-border: rgba(28,45,100,0.1);
  --pro-border-hover: rgba(201,168,76,0.35);
  --pro-text: #1C1A16;
  --pro-muted: #6b6470;
  --pro-faint: #9b97a3;
}

/* ── Pro Noise Texture ───────────────────────────────────── */
.bdPagesProNoise::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
  opacity: 0.022;
  pointer-events: none;
  z-index: 9999;
}

/* ── Pro Nav ─────────────────────────────────────────────── */
.bdPagesProNav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  padding: 1.25rem 0;
  display: flex;
  align-items: center;
  border-bottom: 1px solid transparent;
  transition: background 0.4s ease, border-color 0.4s ease, backdrop-filter 0.4s ease;
}

.bdPagesProNav--scrolled {
  background: rgba(10,10,11,0.92);
  border-bottom-color: var(--pro-border);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

[data-theme="light"] .bdPagesProNav--scrolled {
  background: rgba(250,249,246,0.92);
}

.bdPagesProNavLink {
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--pro-muted);
  text-decoration: none;
  transition: color 0.2s;
}

.bdPagesProNavLink:hover { color: var(--pro-text); }

.bdPagesProNavCta {
  background: var(--pro-gold);
  color: #0a0a0b !important;
  font-family: var(--site-primary-font);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 0.6rem 1.4rem;
  border-radius: 2px;
  text-decoration: none;
  transition: background 0.2s, transform 0.2s;
  white-space: nowrap;
}

.bdPagesProNavCta:hover {
  background: var(--pro-gold-light);
  transform: translateY(-1px);
  color: #0a0a0b !important;
}

/* ── Pro Hero ────────────────────────────────────────────── */
.bdPagesProHero {
  min-height: 100vh;
  background: var(--pro-bg);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 8rem 0 5rem;
}

.bdPagesProHeroBg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 60% 50% at 70% 50%, rgba(201,168,76,0.07) 0%, transparent 70%),
    radial-gradient(ellipse 40% 60% at 20% 80%, rgba(201,168,76,0.04) 0%, transparent 60%);
}

[data-theme="light"] .bdPagesProHeroBg {
  background:
    radial-gradient(ellipse 60% 50% at 70% 50%, rgba(201,168,76,0.12) 0%, transparent 70%),
    radial-gradient(ellipse 40% 60% at 20% 80%, rgba(28,45,100,0.05) 0%, transparent 60%);
}

.bdPagesProHeroGrid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 0%, transparent 100%);
}

[data-theme="light"] .bdPagesProHeroGrid {
  background-image:
    linear-gradient(rgba(28,45,100,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(28,45,100,0.04) 1px, transparent 1px);
}

.bdPagesProHeroEyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--pro-gold);
  margin-bottom: 2rem;
  animation: bdFadeUp 0.8s ease 0.2s both;
}

.bdPagesProHeroEyebrow::before {
  content: '';
  width: 28px;
  height: 1px;
  background: var(--pro-gold);
}

.bdPagesProHeroTitle {
  font-family: var(--site-secondary-font);
  font-size: clamp(3rem, 6vw, 5.5rem);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -0.01em;
  color: var(--pro-text);
  margin-bottom: 1.75rem;
  animation: bdFadeUp 0.8s ease 0.35s both;
}

.bdPagesProHeroTitle em {
  font-style: italic;
  color: var(--pro-gold);
}

.bdPagesProHeroSub {
  font-size: 1.05rem;
  font-weight: 300;
  color: var(--pro-muted);
  max-width: 480px;
  line-height: 1.85;
  margin-bottom: 3rem;
  animation: bdFadeUp 0.8s ease 0.5s both;
}

.bdPagesProHeroActions {
  display: flex;
  align-items: center;
  gap: 1.75rem;
  flex-wrap: wrap;
  animation: bdFadeUp 0.8s ease 0.65s both;
}

.bdPagesProBtnPrimary {
  background: var(--pro-gold);
  color: #0a0a0b;
  font-family: var(--site-primary-font);
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 1rem 2.4rem;
  border-radius: 2px;
  text-decoration: none;
  display: inline-block;
  transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
}

.bdPagesProBtnPrimary:hover {
  background: var(--pro-gold-light);
  transform: translateY(-2px);
  box-shadow: 0 8px 40px rgba(201,168,76,0.28);
  color: #0a0a0b;
}

.bdPagesProBtnGhost {
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--pro-muted);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: color 0.2s;
}

.bdPagesProBtnGhost:hover { color: var(--pro-text); }

.bdPagesProBtnGhost svg { transition: transform 0.2s; }
.bdPagesProBtnGhost:hover svg { transform: translateX(4px); }

/* ── Pro Hero Visual ─────────────────────────────────────── */
.bdPagesProHeroVisual {
  animation: bdFadeUp 1.2s ease 0.8s both;
}

.bdPagesProProCard {
  width: 100%;
  max-width: 360px;
  background: var(--pro-bg-card);
  border: 1px solid var(--pro-border);
  border-radius: 12px;
  padding: 2.25rem;
  position: relative;
  box-shadow: 0 40px 80px rgba(0,0,0,0.4);
  margin: 0 auto;
}

[data-theme="light"] .bdPagesProProCard {
  box-shadow: 0 20px 60px rgba(28,45,100,0.12);
}

.bdPagesProProCard::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--pro-gold), transparent);
  border-radius: 12px 12px 0 0;
}

.bdPagesProCardHeader {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.75rem;
}

.bdPagesProCardAvatar {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--pro-gold) 0%, #8b5e1a 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--site-secondary-font);
  font-size: 1.3rem;
  font-weight: 600;
  color: #0a0a0b;
  flex-shrink: 0;
}

.bdPagesProCardName {
  font-family: var(--site-secondary-font);
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--pro-text);
}

.bdPagesProCardMeta {
  font-size: 0.72rem;
  color: var(--pro-muted);
  letter-spacing: 0.04em;
}

.bdPagesProCardStats {
  display: flex;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.bdPagesProCardStat {
  flex: 1;
  background: rgba(255,255,255,0.04);
  border-radius: 8px;
  padding: 0.75rem;
  text-align: center;
}

[data-theme="light"] .bdPagesProCardStat {
  background: rgba(28,45,100,0.04);
}

.bdPagesProCardStatVal {
  font-family: var(--site-secondary-font);
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--pro-gold);
  line-height: 1;
}

.bdPagesProCardStatLbl {
  font-size: 0.62rem;
  color: var(--pro-faint);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-top: 0.2rem;
}

.bdPagesProCardTags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}

.bdPagesProCardTag {
  font-size: 0.68rem;
  padding: 0.3rem 0.75rem;
  border: 1px solid var(--pro-border);
  border-radius: 100px;
  color: var(--pro-muted);
  letter-spacing: 0.04em;
}

.bdPagesProCardQr {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem;
  background: var(--pro-gold-dim);
  border: 1px solid var(--pro-gold-border);
  border-radius: 8px;
}

.bdPagesProQrBox {
  width: 44px;
  height: 44px;
  background: var(--pro-text);
  border-radius: 4px;
  display: grid;
  grid-template-columns: repeat(5,1fr);
  gap: 2px;
  padding: 5px;
  flex-shrink: 0;
}

.bdPagesProQrDot { background: var(--pro-bg); border-radius: 1px; }

.bdPagesProQrText {
  font-size: 0.72rem;
  color: var(--pro-gold);
  font-weight: 500;
}

.bdPagesProQrSub {
  font-size: 0.62rem;
  color: var(--pro-faint);
}

/* Float Badges */
.bdPagesProFloatBadge {
  position: absolute;
  background: var(--pro-bg-card);
  border: 1px solid var(--pro-border);
  border-radius: 8px;
  padding: 0.75rem 1rem;
  font-size: 0.72rem;
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--pro-muted);
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
}

.bdPagesProFloatBadge--top {
  top: -16px;
  right: -24px;
  animation: bdFloat 3s ease-in-out infinite;
}

.bdPagesProFloatBadge--bottom {
  bottom: 24px;
  left: -28px;
  animation: bdFloat 3.5s ease-in-out 0.5s infinite;
}

.bdPagesProBadgeDot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* ── Pro Section Common ──────────────────────────────────── */
.bdPagesProSection {
  padding: 5.5rem 0;
  background: var(--pro-bg);
}

.bdPagesProSection--alt {
  background: var(--pro-bg-alt);
}

.bdPagesProDivider {
  height: 1px;
  background: var(--pro-border);
}

.bdPagesProEyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--pro-gold);
  margin-bottom: 1.25rem;
}

.bdPagesProEyebrow::before {
  content: '';
  width: 20px;
  height: 1px;
  background: var(--pro-gold);
}

.bdPagesProEyebrow--center::before { display: none; }

.bdPagesProTitle {
  font-family: var(--site-secondary-font);
  font-size: clamp(2.2rem, 4vw, 3.5rem);
  font-weight: 600;
  line-height: 1.1;
  color: var(--pro-text);
}

.bdPagesProTitle em {
  font-style: italic;
  color: var(--pro-gold);
}

.bdPagesProBody {
  font-size: 1rem;
  color: var(--pro-muted);
  line-height: 1.85;
}

/* ── Problem Cards ───────────────────────────────────────── */
.bdPagesProProblemCard {
  border: 1px solid var(--pro-border);
  border-radius: 8px;
  padding: 1.75rem 2rem;
  position: relative;
  overflow: hidden;
  transition: border-color var(--bdTransition);
  height: 100%;
}

.bdPagesProProblemCard:hover { border-color: var(--pro-border-hover); }

.bdPagesProProblemCard::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 2px;
  background: var(--pro-gold);
  opacity: 0.5;
}

.bdPagesProProblemNum {
  font-family: 'DM Mono', 'Courier New', monospace;
  font-size: 0.68rem;
  color: var(--pro-faint);
  margin-bottom: 0.625rem;
  letter-spacing: 0.1em;
}

.bdPagesProProblemTitle {
  font-family: var(--site-secondary-font);
  font-size: 1.3rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: var(--pro-text);
}

.bdPagesProProblemDesc {
  font-size: 0.875rem;
  color: var(--pro-muted);
  line-height: 1.7;
}

/* ── Solution Visual ─────────────────────────────────────── */
.bdPagesProSolWrap {
  position: relative;
  height: 400px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.bdPagesProSolCircle {
  width: 280px;
  height: 280px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(201,168,76,0.1) 0%, transparent 70%);
  border: 1px solid var(--pro-gold-border);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.bdPagesProSolCircleInner {
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: var(--pro-bg-card);
  border: 1px solid rgba(201,168,76,0.3);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
}

.bdPagesProSolIcon { font-size: 2.5rem; }

.bdPagesProSolLabel {
  font-family: var(--site-secondary-font);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--pro-gold);
  text-align: center;
  letter-spacing: 0.05em;
}

.bdPagesProOrbitTag {
  position: absolute;
  background: var(--pro-bg-card);
  border: 1px solid var(--pro-border);
  padding: 0.5rem 0.875rem;
  border-radius: 100px;
  font-size: 0.7rem;
  color: var(--pro-muted);
  white-space: nowrap;
}

.bdPagesProOrbitTag--tr { top: 30px; right: 10px; }
.bdPagesProOrbitTag--br { bottom: 50px; right: 0; }
.bdPagesProOrbitTag--bl { bottom: 40px; left: 20px; }
.bdPagesProOrbitTag--tl { top: 60px; left: 10px; }

/* ── Benefits Table Grid ─────────────────────────────────── */
.bdPagesProBenefitsGrid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--pro-border);
  border: 1px solid var(--pro-border);
  border-radius: 8px;
  overflow: hidden;
  margin-top: 4rem;
}

@media (max-width: 991px) {
  .bdPagesProBenefitsGrid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 575px) {
  .bdPagesProBenefitsGrid { grid-template-columns: 1fr; }
}

.bdPagesProBenefitItem {
  background: var(--pro-bg-card);
  padding: 2.5rem 2rem;
  transition: background var(--bdTransition);
}

.bdPagesProBenefitItem:hover { background: var(--pro-bg-alt); }

.bdPagesProBenefitIcon {
  width: 48px;
  height: 48px;
  border-radius: 8px;
  background: var(--pro-gold-dim);
  border: 1px solid var(--pro-gold-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  margin-bottom: 1.5rem;
}

.bdPagesProBenefitTitle {
  font-family: var(--site-secondary-font);
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
  color: var(--pro-text);
}

.bdPagesProBenefitDesc {
  font-size: 0.85rem;
  color: var(--pro-muted);
  line-height: 1.7;
}

/* ── Steps ───────────────────────────────────────────────── */
.bdPagesProSteps { margin-top: 4rem; }

.bdPagesProStep {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 2.5rem;
  padding: 2.5rem 0;
  border-bottom: 1px solid var(--pro-border);
  align-items: start;
}

.bdPagesProStep:last-child { border-bottom: none; }

.bdPagesProStepNum {
  font-family: var(--site-secondary-font);
  font-size: 3.5rem;
  font-weight: 300;
  color: rgba(201,168,76,0.2);
  line-height: 1;
  padding-top: 4px;
}

.bdPagesProStepTitle {
  font-family: var(--site-secondary-font);
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 0.625rem;
  color: var(--pro-text);
}

.bdPagesProStepDesc {
  font-size: 0.9rem;
  color: var(--pro-muted);
  line-height: 1.75;
}

/* ── Use Case Cards ──────────────────────────────────────── */
.bdPagesProUseCaseCard {
  background: var(--pro-bg-card);
  border: 1px solid var(--pro-border);
  border-radius: 10px;
  padding: 2.25rem;
  transition: border-color var(--bdTransition), transform var(--bdTransition);
  position: relative;
  overflow: hidden;
  height: 100%;
}

.bdPagesProUseCaseCard:hover {
  border-color: var(--pro-gold-border);
  transform: translateY(-4px);
}

.bdPagesProUseCaseCard::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, var(--pro-gold), transparent);
  opacity: 0;
  transition: opacity var(--bdTransition);
}

.bdPagesProUseCaseCard:hover::after { opacity: 1; }

.bdPagesProUseCaseEmoji {
  font-size: 2rem;
  margin-bottom: 1.25rem;
  display: block;
}

.bdPagesProUseCaseTitle {
  font-family: var(--site-secondary-font);
  font-size: 1.35rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
  color: var(--pro-text);
}

.bdPagesProUseCaseDesc {
  font-size: 0.875rem;
  color: var(--pro-muted);
  line-height: 1.75;
}

/* ── Feature Cards ───────────────────────────────────────── */
.bdPagesProFeatureCard {
  border: 1px solid var(--pro-border);
  border-radius: 10px;
  padding: 2.25rem;
  position: relative;
  transition: border-color var(--bdTransition);
  height: 100%;
}

.bdPagesProFeatureCard:hover { border-color: rgba(201,168,76,0.25); }

.bdPagesProFeatureCard--featured {
  background: var(--pro-bg-card);
  border-color: var(--pro-gold-border);
  display: flex;
  gap: 3rem;
  align-items: flex-start;
}

@media (max-width: 767px) {
  .bdPagesProFeatureCard--featured { flex-direction: column; gap: 1.5rem; }
}

.bdPagesProFeatureBadge {
  display: inline-block;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--pro-gold);
  background: var(--pro-gold-dim);
  padding: 0.25rem 0.625rem;
  border-radius: 100px;
  margin-bottom: 0.75rem;
}

.bdPagesProFeatureIconLg {
  font-size: 3rem;
  width: 80px;
  height: 80px;
  background: var(--pro-gold-dim);
  border: 1px solid var(--pro-gold-border);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.bdPagesProFeatureIconSm {
  font-size: 1.5rem;
  width: 52px;
  height: 52px;
  background: rgba(255,255,255,0.04);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-bottom: 1.25rem;
}

[data-theme="light"] .bdPagesProFeatureIconSm {
  background: rgba(28,45,100,0.05);
}

.bdPagesProFeatureTitle {
  font-family: var(--site-secondary-font);
  font-size: 1.35rem;
  font-weight: 600;
  margin-bottom: 0.625rem;
  color: var(--pro-text);
}

.bdPagesProFeatureDesc {
  font-size: 0.875rem;
  color: var(--pro-muted);
  line-height: 1.75;
}

/* ── Trust Stats ─────────────────────────────────────────── */
.bdPagesProStatsGrid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--pro-border);
  border: 1px solid var(--pro-border);
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 3.5rem;
}

@media (max-width: 767px) {
  .bdPagesProStatsGrid { grid-template-columns: repeat(2, 1fr); }
}

.bdPagesProStatItem {
  background: var(--pro-bg-card);
  padding: 2.5rem 2rem;
  text-align: center;
}

.bdPagesProStatVal {
  font-family: var(--site-secondary-font);
  font-size: 3rem;
  font-weight: 600;
  color: var(--pro-gold);
  line-height: 1;
  margin-bottom: 0.5rem;
}

.bdPagesProStatLbl {
  font-size: 0.8rem;
  color: var(--pro-muted);
  letter-spacing: 0.04em;
}

/* ── Testimonials ────────────────────────────────────────── */
.bdPagesProTestimonial {
  background: var(--pro-bg-card);
  border: 1px solid var(--pro-border);
  border-radius: 10px;
  padding: 2rem;
  transition: border-color var(--bdTransition);
  height: 100%;
}

.bdPagesProTestimonial:hover { border-color: var(--pro-gold-border); }

.bdPagesProTestiStars {
  color: var(--pro-gold);
  font-size: 0.9rem;
  letter-spacing: 2px;
  margin-bottom: 1rem;
}

.bdPagesProTestiText {
  font-size: 0.9rem;
  color: var(--pro-muted);
  line-height: 1.8;
  margin-bottom: 1.5rem;
  font-style: italic;
}

.bdPagesProTestiPerson {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.bdPagesProTestiAvatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--site-secondary-font);
  font-size: 1rem;
  font-weight: 600;
  color: #0a0a0b;
  flex-shrink: 0;
}

.bdPagesProTestiName {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--pro-text);
}

.bdPagesProTestiRole {
  font-size: 0.72rem;
  color: var(--pro-faint);
}

/* ── Pro CTA Section ─────────────────────────────────────── */
.bdPagesProCtaSection {
  padding: 7rem 0;
  text-align: center;
  background: var(--pro-bg);
  position: relative;
  overflow: hidden;
}

.bdPagesProCtaBg {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 70% at 50% 50%, rgba(201,168,76,0.06) 0%, transparent 70%);
  pointer-events: none;
}

.bdPagesProCtaFrame {
  position: absolute;
  inset: 2.5rem;
  border: 1px solid var(--pro-border);
  border-radius: 16px;
  pointer-events: none;
}

.bdPagesProCtaNote {
  font-size: 0.78rem;
  color: var(--pro-faint);
  margin-top: 1.25rem;
  letter-spacing: 0.04em;
}

/* ── Pro Footer ──────────────────────────────────────────── */
.bdPagesProFooter {
  padding: 2.5rem 0;
  border-top: 1px solid var(--pro-border);
  background: var(--pro-bg);
}

.bdPagesProFooterLogo {
  font-family: var(--site-secondary-font);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--pro-muted);
  text-decoration: none;
}

.bdPagesProFooterLogo span { color: var(--pro-gold); }

.bdPagesProFooterLink {
  font-size: 0.75rem;
  color: var(--pro-faint);
  text-decoration: none;
  transition: color var(--bdTransition);
}

.bdPagesProFooterLink:hover { color: var(--pro-muted); }

.bdPagesProFooterCopy {
  font-size: 0.75rem;
  color: var(--pro-faint);
}

/* ── Pro Theme Toggle (reuses bdPages but with gold knob) ── */
.bdPagesProThemeToggle {
  width: 48px;
  height: 26px;
  background: rgba(201,168,76,0.15);
  border: 1.5px solid var(--pro-gold-border);
  border-radius: 100px;
  cursor: pointer;
  position: relative;
  transition: background 0.3s;
  flex-shrink: 0;
}

.bdPagesProThemeToggle:hover { border-color: var(--pro-gold); }

.bdPagesProThemeToggle__knob {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--pro-gold);
  position: absolute;
  top: 2px;
  left: 2px;
  transition: transform 0.3s;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
}

[data-theme="dark"] .bdPagesProThemeToggle__knob {
  transform: translateX(22px);
}

/* ============================================================
   BigDot Onboarding Pages — Shared Tokens
   Convention: bdPagesProOnboard* (pro) / bdPagesOnboard* (students)
   ============================================================ */

/* ── Onboarding Variables — Light Mode defaults ─────────── */
:root {
  --bdOnboard-bg: #f6f5f2;
  --bdOnboard-bgOff: #eeede9;
  --bdOnboard-bgCard: #ffffff;
  --bdOnboard-bgCard2: #f5f3ee;
  --bdOnboard-text: #1a1a1e;
  --bdOnboard-silver: #6b6b7a;
  --bdOnboard-muted: #9a9aaa;
  --bdOnboard-gold: #c9a84c;
  --bdOnboard-goldLight: #e8c97a;
  --bdOnboard-goldDim: rgba(201,168,76,0.08);
  --bdOnboard-goldGlow: rgba(201,168,76,0.10);
  --bdOnboard-goldBorder: rgba(201,168,76,0.18);
  --bdOnboard-border: rgba(0,0,0,0.08);
  --bdOnboard-borderFocus: rgba(201,168,76,0.4);
  --bdOnboard-green: #18a262;
  --bdOnboard-red: #e53e3e;
  --bdOnboard-error: rgba(229,62,62,0.08);
  --bdOnboard-linkedin: #0A66C2;
  --bdOnboard-linkedinDim: rgba(10,102,194,0.08);
  --bdOnboard-white60: rgba(26,26,30,0.55);
  --bdOnboard-white20: rgba(26,26,30,0.12);
  --bdOnboard-white08: rgba(26,26,30,0.05);
  --bdOnboard-ink2: #eae9e5;
  --bdOnboard-ink3: #f0ede8;
  --bdOnboard-ink4: #e8e5de;
  --bdOnboard-ease: cubic-bezier(0.22,1,0.36,1);
  --bdOnboard-radius: 14px;
}

/* ── Onboarding Variables — Dark Mode overrides ──────────── */
[data-theme="dark"] {
  --bdOnboard-bg: #09090b;
  --bdOnboard-bgOff: #111113;
  --bdOnboard-bgCard: #141417;
  --bdOnboard-bgCard2: #1a1a1f;
  --bdOnboard-text: #f2f0ea;
  --bdOnboard-silver: #8a9099;
  --bdOnboard-muted: #444454;
  --bdOnboard-goldDim: rgba(201,168,76,0.12);
  --bdOnboard-goldGlow: rgba(201,168,76,0.18);
  --bdOnboard-goldBorder: rgba(201,168,76,0.25);
  --bdOnboard-border: rgba(255,255,255,0.08);
  --bdOnboard-borderFocus: rgba(201,168,76,0.5);
  --bdOnboard-green: #4ade80;
  --bdOnboard-red: #f87171;
  --bdOnboard-error: rgba(248,113,113,0.1);
  --bdOnboard-linkedinDim: rgba(10,102,194,0.12);
  --bdOnboard-white60: rgba(242,240,234,0.6);
  --bdOnboard-white20: rgba(242,240,234,0.2);
  --bdOnboard-white08: rgba(242,240,234,0.08);
  --bdOnboard-ink2: #111119;
  --bdOnboard-ink3: #181824;
  --bdOnboard-ink4: #1E1E2C;
}

/* ============================================================
   Professional Onboarding (bdPagesProOnboard*)
   ============================================================ */

.bdPagesProOnboardBody {
  background: var(--bdOnboard-bg);
  color: var(--bdOnboard-text);
  font-family: 'DM Sans', sans-serif;
  font-weight: 300;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
  transition: background 0.3s, color 0.3s;
}

.bdPagesProOnboardBody::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity: 0.015;
  pointer-events: none;
  z-index: 9999;
}

.bdPagesProOnboardHeader {
  padding: 20px 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--bdOnboard-border);
  flex-shrink: 0;
  background: var(--bdOnboard-bg);
  transition: background 0.3s, border-color 0.3s;
}

.bdPagesProOnboardLogo {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.3rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--bdOnboard-text);
}

.bdPagesProOnboardLogo span { color: var(--bdOnboard-gold); }

.bdPagesProOnboardHeaderRight {
  font-size: 0.75rem;
  color: var(--bdOnboard-silver);
  letter-spacing: 0.05em;
}

.bdPagesProOnboardHeaderRight strong { color: var(--bdOnboard-gold); font-weight: 500; }

/* Theme toggle (reusable for onboarding pages) */
.bdPagesOnboardThemeToggle {
  width: 42px;
  height: 24px;
  background: var(--bdOnboard-border);
  border: 1.5px solid var(--bdOnboard-goldBorder);
  border-radius: 100px;
  cursor: pointer;
  position: relative;
  transition: background 0.3s, border-color 0.3s;
  flex-shrink: 0;
}

.bdPagesOnboardThemeToggle:hover { border-color: var(--bdOnboard-gold); }

.bdPagesOnboardThemeToggle__knob {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--bdOnboard-gold);
  position: absolute;
  top: 3px;
  left: 3px;
  transition: transform 0.3s;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.6rem;
}

[data-theme="dark"] .bdPagesOnboardThemeToggle__knob { transform: translateX(18px); }

/* Wizard Layout */
.bdPagesProOnboardWizardWrap {
  flex: 1;
  display: grid;
  grid-template-columns: 280px 1fr;
  min-height: 0;
}

/* Sidebar */
.bdPagesProOnboardSidebar {
  border-right: 1px solid var(--bdOnboard-border);
  padding: 48px 32px;
  display: flex;
  flex-direction: column;
  gap: 0;
  background: var(--bdOnboard-bgOff);
  position: relative;
  transition: background 0.3s, border-color 0.3s;
}

.bdPagesProOnboardSidebar::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 200px;
  background: linear-gradient(to top, rgba(201,168,76,0.04), transparent);
  pointer-events: none;
}

.bdPagesProOnboardSidebarTitle {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 600;
  color: var(--bdOnboard-silver);
  letter-spacing: 0.16em;
  margin-bottom: 36px;
  text-transform: uppercase;
  font-size: 0.7rem;
}

.bdPagesProOnboardStepNav { display: flex; flex-direction: column; gap: 4px; }

.bdPagesProOnboardStepItem {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 14px 16px;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.2s;
  position: relative;
}

.bdPagesProOnboardStepItem:hover:not(.active):not(.locked) { background: var(--bdOnboard-white08); }
.bdPagesProOnboardStepItem.active { background: var(--bdOnboard-goldDim); }
.bdPagesProOnboardStepItem.locked { opacity: 0.35; cursor: not-allowed; }

.bdPagesProOnboardStepBullet {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1px solid var(--bdOnboard-muted);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.65rem;
  font-weight: 600;
  color: var(--bdOnboard-silver);
  flex-shrink: 0;
  font-family: 'DM Mono', monospace;
  transition: all 0.3s;
  margin-top: 1px;
}

.bdPagesProOnboardStepItem.active .bdPagesProOnboardStepBullet {
  border-color: var(--bdOnboard-gold);
  background: var(--bdOnboard-gold);
  color: var(--bdOnboard-bg);
}

.bdPagesProOnboardStepItem.done .bdPagesProOnboardStepBullet {
  border-color: var(--bdOnboard-green);
  background: rgba(74,222,128,0.12);
  color: var(--bdOnboard-green);
}

.bdPagesProOnboardStepLabel {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--bdOnboard-silver);
  transition: color 0.2s;
  line-height: 1.3;
}

.bdPagesProOnboardStepItem.active .bdPagesProOnboardStepLabel { color: var(--bdOnboard-text); }
.bdPagesProOnboardStepItem.done .bdPagesProOnboardStepLabel { color: var(--bdOnboard-silver); }

.bdPagesProOnboardStepSub {
  font-size: 0.72rem;
  color: var(--bdOnboard-muted);
  margin-top: 3px;
  line-height: 1.4;
}

.bdPagesProOnboardStepItem.active .bdPagesProOnboardStepSub { color: rgba(201,168,76,0.7); }

.bdPagesProOnboardStepConnector {
  width: 1px;
  height: 20px;
  background: var(--bdOnboard-border);
  margin-left: 29px;
}

.bdPagesProOnboardStepConnector.done-line { background: rgba(74,222,128,0.3); }

.bdPagesProOnboardSidebarFooter {
  margin-top: auto;
  padding-top: 32px;
  border-top: 1px solid var(--bdOnboard-border);
}

.bdPagesProOnboardProgressLabel {
  display: flex;
  justify-content: space-between;
  font-size: 0.7rem;
  color: var(--bdOnboard-silver);
  margin-bottom: 10px;
  letter-spacing: 0.04em;
}

.bdPagesProOnboardProgressBar {
  height: 3px;
  background: var(--bdOnboard-border);
  border-radius: 100px;
  overflow: hidden;
}

.bdPagesProOnboardProgressFill {
  height: 100%;
  background: linear-gradient(90deg, var(--bdOnboard-gold), var(--bdOnboard-goldLight));
  border-radius: 100px;
  transition: width 0.6s cubic-bezier(0.4,0,0.2,1);
}

.bdPagesProOnboardSaveNote {
  font-size: 0.68rem;
  color: var(--bdOnboard-muted);
  margin-top: 14px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.bdPagesProOnboardSaveDot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--bdOnboard-green);
  animation: bdOnboardPulse 2s ease infinite;
}

/* Main content */
.bdPagesProOnboardMainContent {
  padding: 0;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

.bdPagesProOnboardStepPanel {
  display: none;
  flex: 1;
  flex-direction: column;
  animation: bdOnboardPanelIn 0.4s ease;
}

.bdPagesProOnboardStepPanel.active { display: flex; }

@keyframes bdOnboardPanelIn {
  from { opacity: 0; transform: translateX(20px); }
  to { opacity: 1; transform: translateX(0); }
}

.bdPagesProOnboardPanelHeader {
  padding: 48px 60px 36px;
  border-bottom: 1px solid var(--bdOnboard-border);
  background: linear-gradient(to bottom, var(--bdOnboard-goldDim), transparent);
}

.bdPagesProOnboardPanelEyebrow {
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--bdOnboard-gold);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.bdPagesProOnboardPanelEyebrow::before {
  content: '';
  width: 16px; height: 1px;
  background: var(--bdOnboard-gold);
}

.bdPagesProOnboardPanelTitle {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.2rem;
  font-weight: 600;
  line-height: 1.15;
  margin-bottom: 10px;
  color: var(--bdOnboard-text);
}

.bdPagesProOnboardPanelTitle em { font-style: italic; color: var(--bdOnboard-gold); }

.bdPagesProOnboardPanelDesc {
  font-size: 0.9rem;
  color: var(--bdOnboard-silver);
  max-width: 480px;
  line-height: 1.75;
}

.bdPagesProOnboardOptionalBadge {
  display: inline-block;
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--bdOnboard-silver);
  background: var(--bdOnboard-white08);
  padding: 3px 9px;
  border-radius: 100px;
  margin-left: 8px;
  vertical-align: middle;
  font-weight: 500;
}

.bdPagesProOnboardPanelBody {
  padding: 40px 60px;
  flex: 1;
}

/* Form grid */
.bdPagesProOnboardFormGrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-width: 680px;
}

.bdPagesProOnboardFormGrid.single { grid-template-columns: 1fr; }

.bdPagesProOnboardFieldGroup { display: flex; flex-direction: column; gap: 8px; }
.bdPagesProOnboardFieldGroup.full { grid-column: span 2; }

.bdPagesProOnboardFieldLabel {
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--bdOnboard-silver);
  display: flex;
  align-items: center;
  gap: 6px;
}

.bdPagesProOnboardReq { color: var(--bdOnboard-gold); font-size: 0.85rem; }

.bdPagesProOnboardOptTag {
  font-size: 0.6rem;
  color: var(--bdOnboard-muted);
  background: var(--bdOnboard-white08);
  padding: 2px 7px;
  border-radius: 100px;
  letter-spacing: 0.06em;
  font-weight: 400;
  text-transform: none;
}

/* Form inputs scoped to onboarding body */
.bdPagesProOnboardBody input,
.bdPagesProOnboardBody textarea,
.bdPagesProOnboardBody select {
  background: var(--bdOnboard-bgCard);
  border: 1px solid var(--bdOnboard-border);
  border-radius: 6px;
  color: var(--bdOnboard-text);
  font-family: 'DM Sans', sans-serif;
  font-size: 0.92rem;
  font-weight: 300;
  padding: 12px 16px;
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
  outline: none;
  width: 100%;
  -webkit-appearance: none;
}

.bdPagesProOnboardBody input:focus,
.bdPagesProOnboardBody textarea:focus,
.bdPagesProOnboardBody select:focus {
  border-color: var(--bdOnboard-borderFocus);
  background: var(--bdOnboard-bgCard2);
  box-shadow: 0 0 0 3px var(--bdOnboard-goldDim);
}

.bdPagesProOnboardBody input.error { border-color: var(--bdOnboard-red); background: var(--bdOnboard-error); }
.bdPagesProOnboardBody input::placeholder,
.bdPagesProOnboardBody textarea::placeholder { color: var(--bdOnboard-muted); }
.bdPagesProOnboardBody select { cursor: pointer; }
.bdPagesProOnboardBody select option { background: var(--bdOnboard-bgCard2); }
.bdPagesProOnboardBody textarea { resize: vertical; min-height: 90px; line-height: 1.6; }

.bdPagesProOnboardFieldHint {
  font-size: 0.72rem;
  color: var(--bdOnboard-muted);
  line-height: 1.5;
}

.bdPagesProOnboardFieldError {
  font-size: 0.72rem;
  color: var(--bdOnboard-red);
  display: none;
}

.bdPagesProOnboardFieldError.show { display: block; }

.bdPagesProOnboardFieldCounter {
  font-size: 0.68rem;
  color: var(--bdOnboard-muted);
  text-align: right;
  font-family: 'DM Mono', monospace;
}

/* Avatar upload */
.bdPagesProOnboardAvatarUpload {
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 20px;
  background: var(--bdOnboard-bgCard);
  border: 1px dashed var(--bdOnboard-border);
  border-radius: 8px;
  transition: border-color 0.2s;
  cursor: pointer;
  position: relative;
}

.bdPagesProOnboardAvatarUpload:hover { border-color: var(--bdOnboard-goldBorder); }

.bdPagesProOnboardAvatarPreview {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--bdOnboard-gold), #8b5e1a);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.8rem;
  font-weight: 600;
  color: #09090b;
  flex-shrink: 0;
  overflow: hidden;
  position: relative;
}

.bdPagesProOnboardAvatarPreview img {
  width: 100%; height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: none;
}

.bdPagesProOnboardAvatarUploadLabel {
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--bdOnboard-text);
  margin-bottom: 4px;
}

.bdPagesProOnboardAvatarUploadSub { font-size: 0.75rem; color: var(--bdOnboard-silver); }

.bdPagesProOnboardAvatarUploadOr {
  font-size: 0.78rem;
  color: var(--bdOnboard-muted);
  margin: 12px 0 6px;
}

.bdPagesProOnboardUrlInputWrap { position: relative; }
.bdPagesProOnboardUrlInputWrap input { padding-left: 36px; }

.bdPagesProOnboardUrlIcon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--bdOnboard-muted);
  font-size: 0.85rem;
  pointer-events: none;
}

/* Education section */
.bdPagesProOnboardEduList { display: flex; flex-direction: column; gap: 16px; max-width: 680px; }

.bdPagesProOnboardEduCard {
  background: var(--bdOnboard-bgCard);
  border: 1px solid var(--bdOnboard-border);
  border-radius: 8px;
  overflow: hidden;
}

.bdPagesProOnboardEduCardHeader {
  padding: 16px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  transition: background 0.2s;
}

.bdPagesProOnboardEduCardHeader:hover { background: var(--bdOnboard-white08); }
.bdPagesProOnboardEduCardTitle { font-size: 0.9rem; font-weight: 500; color: var(--bdOnboard-text); }
.bdPagesProOnboardEduCardSub { font-size: 0.75rem; color: var(--bdOnboard-silver); margin-top: 2px; }
.bdPagesProOnboardEduCardActions { display: flex; gap: 8px; }

.bdPagesProOnboardBtnIcon {
  width: 30px; height: 30px;
  border-radius: 6px;
  border: 1px solid var(--bdOnboard-border);
  background: transparent;
  color: var(--bdOnboard-silver);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.85rem;
  transition: all 0.2s;
}

.bdPagesProOnboardBtnIcon:hover { border-color: var(--bdOnboard-borderFocus); color: var(--bdOnboard-text); background: var(--bdOnboard-goldDim); }
.bdPagesProOnboardBtnIcon.danger:hover { border-color: var(--bdOnboard-red); color: var(--bdOnboard-red); background: var(--bdOnboard-error); }

.bdPagesProOnboardEduCardBody {
  padding: 0 20px 20px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

/* Add button */
.bdPagesProOnboardAddBtn {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 20px;
  background: transparent;
  border: 1px dashed var(--bdOnboard-goldBorder);
  border-radius: 8px;
  color: var(--bdOnboard-gold);
  font-family: 'DM Sans', sans-serif;
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
  width: 100%;
  max-width: 680px;
}

.bdPagesProOnboardAddBtn:hover { background: var(--bdOnboard-goldDim); border-color: var(--bdOnboard-gold); }

.bdPagesProOnboardAddBtnIcon {
  width: 24px; height: 24px;
  border-radius: 50%;
  border: 1px solid currentColor;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
  line-height: 1;
}

/* Profession pills */
.bdPagesProOnboardProfessionPills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 20px;
}

.bdPagesProOnboardPill {
  padding: 9px 18px;
  border: 1px solid var(--bdOnboard-border);
  border-radius: 100px;
  font-size: 0.8rem;
  color: var(--bdOnboard-silver);
  cursor: pointer;
  transition: all 0.2s;
  user-select: none;
}

.bdPagesProOnboardPill:hover { border-color: var(--bdOnboard-goldBorder); color: var(--bdOnboard-text); }
.bdPagesProOnboardPill.selected { border-color: var(--bdOnboard-gold); background: var(--bdOnboard-goldDim); color: var(--bdOnboard-gold); font-weight: 500; }

/* Panel footer */
.bdPagesProOnboardPanelFooter {
  padding: 28px 60px;
  border-top: 1px solid var(--bdOnboard-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--bdOnboard-white08);
  flex-shrink: 0;
}

.bdPagesProOnboardBtnBack {
  display: flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: 1px solid var(--bdOnboard-border);
  color: var(--bdOnboard-silver);
  padding: 12px 24px;
  border-radius: 6px;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
}

.bdPagesProOnboardBtnBack:hover { border-color: var(--bdOnboard-borderFocus); color: var(--bdOnboard-text); }

.bdPagesProOnboardBtnNext {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--bdOnboard-gold);
  border: none;
  color: #09090b;
  padding: 13px 32px;
  border-radius: 6px;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  letter-spacing: 0.02em;
}

.bdPagesProOnboardBtnNext:hover { background: var(--bdOnboard-goldLight); transform: translateY(-1px); box-shadow: 0 6px 24px rgba(201,168,76,0.22); }

.bdPagesProOnboardBtnSkip {
  background: transparent;
  border: none;
  color: var(--bdOnboard-muted);
  font-family: 'DM Sans', sans-serif;
  font-size: 0.8rem;
  cursor: pointer;
  padding: 12px 16px;
  transition: color 0.2s;
}

.bdPagesProOnboardBtnSkip:hover { color: var(--bdOnboard-silver); }
.bdPagesProOnboardFooterRight { display: flex; align-items: center; gap: 12px; }

/* LinkedIn section */
.bdPagesProOnboardLinkedinHero { max-width: 680px; margin: 0 auto; }

.bdPagesProOnboardLiCard {
  background: var(--bdOnboard-bgCard);
  border: 1px solid var(--bdOnboard-border);
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 24px;
}

.bdPagesProOnboardLiCardHeader {
  padding: 28px 32px;
  background: linear-gradient(135deg, var(--bdOnboard-linkedinDim) 0%, transparent 70%);
  border-bottom: 1px solid var(--bdOnboard-border);
  display: flex;
  align-items: center;
  gap: 20px;
}

.bdPagesProOnboardLiLogo {
  width: 52px; height: 52px;
  background: var(--bdOnboard-linkedin);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem;
  font-weight: 900;
  color: white;
  font-family: serif;
  flex-shrink: 0;
}

.bdPagesProOnboardLiTitle {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 4px;
  color: var(--bdOnboard-text);
}

.bdPagesProOnboardLiSub { font-size: 0.85rem; color: var(--bdOnboard-silver); line-height: 1.5; }

.bdPagesProOnboardLiDataPreview {
  padding: 24px 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.bdPagesProOnboardLiDataItem {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  background: rgba(10,102,194,0.06);
  border: 1px solid rgba(10,102,194,0.15);
  border-radius: 8px;
}

.bdPagesProOnboardLiDataIcon {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: rgba(10,102,194,0.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}

.bdPagesProOnboardLiDataText { flex: 1; }
.bdPagesProOnboardLiDataLabel { font-size: 0.82rem; font-weight: 500; color: var(--bdOnboard-text); }
.bdPagesProOnboardLiDataDesc { font-size: 0.72rem; color: var(--bdOnboard-silver); margin-top: 2px; }

.bdPagesProOnboardLiCheck {
  width: 20px; height: 20px;
  border-radius: 50%;
  border: 1px solid var(--bdOnboard-border);
  background: transparent;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.65rem;
  color: var(--bdOnboard-green);
  transition: all 0.3s;
}

.bdPagesProOnboardLiCheck.checked { border-color: var(--bdOnboard-green); background: rgba(74,222,128,0.12); }

.bdPagesProOnboardBtnLinkedin {
  width: 100%;
  background: var(--bdOnboard-linkedin);
  border: none;
  color: white;
  padding: 16px 32px;
  border-radius: 8px;
  font-family: 'DM Sans', sans-serif;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  transition: all 0.2s;
  letter-spacing: 0.01em;
}

.bdPagesProOnboardBtnLinkedin:hover { filter: brightness(1.1); transform: translateY(-2px); box-shadow: 0 8px 32px rgba(10,102,194,0.35); }
.bdPagesProOnboardBtnLinkedin:active { transform: translateY(0); }
.bdPagesProOnboardBtnLinkedin .li-icon { font-size: 1.3rem; font-weight: 900; font-family: serif; }

.bdPagesProOnboardLiConnecting {
  display: none;
  flex-direction: column;
  align-items: center;
  padding: 40px 32px;
  gap: 20px;
}

.bdPagesProOnboardLiConnecting.show { display: flex; }

.bdPagesProOnboardLiSpinner {
  width: 48px; height: 48px;
  border: 3px solid rgba(10,102,194,0.2);
  border-top-color: var(--bdOnboard-linkedin);
  border-radius: 50%;
  animation: bdOnboardSpin 0.8s linear infinite;
}

.bdPagesProOnboardLiConnectSteps { display: flex; flex-direction: column; gap: 12px; width: 100%; }

.bdPagesProOnboardLiConnectStep {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 0.85rem;
  color: var(--bdOnboard-muted);
  transition: color 0.3s;
}

.bdPagesProOnboardLiConnectStep.active { color: var(--bdOnboard-text); }
.bdPagesProOnboardLiConnectStep.done { color: var(--bdOnboard-green); }

.bdPagesProOnboardLiConnectDot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--bdOnboard-border);
  flex-shrink: 0;
  transition: background 0.3s;
}

.bdPagesProOnboardLiConnectStep.active .bdPagesProOnboardLiConnectDot { background: var(--bdOnboard-linkedin); animation: bdOnboardPulse 1s infinite; }
.bdPagesProOnboardLiConnectStep.done .bdPagesProOnboardLiConnectDot { background: var(--bdOnboard-green); }

.bdPagesProOnboardSecurityNote {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 20px;
  background: var(--bdOnboard-white08);
  border-radius: 8px;
  border: 1px solid var(--bdOnboard-border);
}

.bdPagesProOnboardSecurityIcon { font-size: 1rem; flex-shrink: 0; margin-top: 2px; }
.bdPagesProOnboardSecurityText { font-size: 0.76rem; color: var(--bdOnboard-silver); line-height: 1.6; }
.bdPagesProOnboardSecurityText strong { color: var(--bdOnboard-text); font-weight: 500; }

.bdPagesProOnboardLiSkipText {
  text-align: center;
  font-size: 0.78rem;
  color: var(--bdOnboard-muted);
  margin-top: 16px;
}

.bdPagesProOnboardLiSkipText button {
  background: none; border: none;
  color: var(--bdOnboard-silver);
  cursor: pointer;
  font-size: 0.78rem;
  font-family: 'DM Sans', sans-serif;
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color 0.2s;
}

.bdPagesProOnboardLiSkipText button:hover { color: var(--bdOnboard-text); }

/* Completion panel */
#bdProOnboardCompletionPanel {
  display: none;
  flex: 1;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 60px;
  flex-direction: column;
  gap: 28px;
  animation: bdOnboardPanelIn 0.5s ease;
}

#bdProOnboardCompletionPanel.show { display: flex; }

.bdPagesProOnboardCompletionIcon {
  width: 80px; height: 80px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--bdOnboard-gold), #8b5e1a);
  display: flex; align-items: center; justify-content: center;
  font-size: 2.5rem;
  animation: bdOnboardPopIn 0.5s cubic-bezier(0.175,0.885,0.32,1.275);
}

@keyframes bdOnboardPopIn {
  from { transform: scale(0); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}

.bdPagesProOnboardCompletionTitle {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.8rem;
  font-weight: 600;
  line-height: 1.2;
  color: var(--bdOnboard-text);
}

.bdPagesProOnboardCompletionTitle em { font-style: italic; color: var(--bdOnboard-gold); }
.bdPagesProOnboardCompletionSub { font-size: 1rem; color: var(--bdOnboard-silver); max-width: 400px; line-height: 1.75; }

.bdPagesProOnboardCompletionCard {
  background: var(--bdOnboard-bgCard);
  border: 1px solid var(--bdOnboard-goldBorder);
  border-radius: 10px;
  padding: 24px 32px;
  display: flex;
  align-items: center;
  gap: 20px;
  max-width: 400px;
  width: 100%;
}

.bdPagesProOnboardCompAvatar {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--bdOnboard-gold), #8b5e1a);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: #09090b;
  flex-shrink: 0;
}

.bdPagesProOnboardCompName { font-family: 'Cormorant Garamond', serif; font-size: 1.2rem; font-weight: 600; color: var(--bdOnboard-text); }
.bdPagesProOnboardCompRole { font-size: 0.75rem; color: var(--bdOnboard-silver); margin-top: 3px; }

.bdPagesProOnboardBtnViewProfile {
  background: var(--bdOnboard-gold);
  border: none;
  color: #09090b;
  padding: 14px 36px;
  border-radius: 6px;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  letter-spacing: 0.02em;
}

.bdPagesProOnboardBtnViewProfile:hover { background: var(--bdOnboard-goldLight); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(201,168,76,0.25); }

/* Keyframes */
@keyframes bdOnboardSpin { to { transform: rotate(360deg); } }
@keyframes bdOnboardPulse { 0%,100% { opacity:1; } 50% { opacity:0.4; } }

/* Mobile responsive */
@media (max-width: 768px) {
  .bdPagesProOnboardWizardWrap { grid-template-columns: 1fr; }
  .bdPagesProOnboardSidebar { display: none; }
  .bdPagesProOnboardPanelHeader,
  .bdPagesProOnboardPanelBody,
  .bdPagesProOnboardPanelFooter { padding-left: 24px; padding-right: 24px; }
  .bdPagesProOnboardFormGrid { grid-template-columns: 1fr; }
  .bdPagesProOnboardFieldGroup.full { grid-column: span 1; }
  .bdPagesProOnboardEduCardBody { grid-template-columns: 1fr; }
  .bdPagesProOnboardHeader { padding: 16px 24px; }
}

/* ============================================================
   Students Onboarding (bdPagesOnboard*)
   ============================================================ */

.bdPagesOnboardApp {
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto auto 1fr;
  background: var(--bdOnboard-bg);
  color: var(--bdOnboard-text);
  font-family: 'DM Sans', sans-serif;
  font-weight: 300;
  line-height: 1.6;
  overflow-x: hidden;
  transition: background 0.3s, color 0.3s;
}

.bdPagesOnboardTopNav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--bdOnboard-border);
  padding: 0 40px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: background 0.3s, border-color 0.3s;
}

[data-theme="dark"] .bdPagesOnboardTopNav {
  background: rgba(8,8,15,0.92);
}

.bdPagesOnboardNavBrand {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.4rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--bdOnboard-text);
}

.bdPagesOnboardNavDot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--bdOnboard-gold);
  box-shadow: 0 0 10px var(--bdOnboard-gold);
  animation: bdOnboardNavPulse 2.5s ease-in-out infinite;
}

@keyframes bdOnboardNavPulse {
  0%,100% { box-shadow: 0 0 8px var(--bdOnboard-gold); }
  50% { box-shadow: 0 0 20px var(--bdOnboard-gold), 0 0 40px rgba(200,168,75,0.3); }
}

.bdPagesOnboardNavHelp {
  font-size: 0.82rem;
  color: var(--bdOnboard-silver);
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  transition: color 0.2s;
}

.bdPagesOnboardNavHelp:hover { color: var(--bdOnboard-text); }

.bdPagesOnboardProgressBar {
  height: 3px;
  background: var(--bdOnboard-white08);
}

.bdPagesOnboardProgressFill {
  height: 100%;
  background: linear-gradient(90deg, var(--bdOnboard-gold), var(--bdOnboard-goldLight));
  transition: width 0.6s var(--bdOnboard-ease);
  border-radius: 0 2px 2px 0;
}

.bdPagesOnboardStepDots {
  display: flex;
  padding: 0 40px;
  background: var(--bdOnboard-ink2);
  border-bottom: 1px solid var(--bdOnboard-white08);
  overflow-x: auto;
  transition: background 0.3s;
}

.bdPagesOnboardStepDot {
  flex: 1;
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: default;
  transition: all 0.3s;
  white-space: nowrap;
  min-width: 100px;
  position: relative;
}

.bdPagesOnboardStepDot::after {
  content: '';
  position: absolute;
  right: 0; top: 20%;
  height: 60%; width: 1px;
  background: var(--bdOnboard-white08);
}

.bdPagesOnboardStepDot:last-child::after { display: none; }
.bdPagesOnboardStepDot.done { cursor: pointer; }

.bdPagesOnboardStepDotNum {
  width: 26px; height: 26px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'DM Mono', monospace;
  font-size: 0.68rem;
  background: var(--bdOnboard-white08);
  color: var(--bdOnboard-silver);
  transition: all 0.3s;
  flex-shrink: 0;
  border: 1px solid transparent;
}

.bdPagesOnboardStepDot.active .bdPagesOnboardStepDotNum { background: var(--bdOnboard-gold); color: var(--bdOnboard-bg); font-weight: 600; }
.bdPagesOnboardStepDot.done .bdPagesOnboardStepDotNum { background: var(--bdOnboard-goldDim); color: var(--bdOnboard-gold); border-color: var(--bdOnboard-goldBorder); }

.bdPagesOnboardStepDotLabel { font-size: 0.75rem; color: var(--bdOnboard-silver); }
.bdPagesOnboardStepDot.active .bdPagesOnboardStepDotLabel { color: var(--bdOnboard-text); font-weight: 500; }

.bdPagesOnboardMain {
  display: grid;
  grid-template-columns: 1fr 360px;
  min-height: calc(100vh - 115px);
}

.bdPagesOnboardContentArea {
  padding: 56px 56px 80px;
  overflow-y: auto;
  max-height: calc(100vh - 115px);
}

.bdPagesOnboardSidebar {
  background: var(--bdOnboard-ink2);
  border-left: 1px solid var(--bdOnboard-white08);
  padding: 40px 32px;
  position: sticky;
  top: 115px;
  max-height: calc(100vh - 115px);
  overflow-y: auto;
  transition: background 0.3s;
}

.bdPagesOnboardStepPanel {
  display: none;
  animation: bdOnboardSlideIn 0.4s var(--bdOnboard-ease) both;
}

.bdPagesOnboardStepPanel.active { display: block; }

@keyframes bdOnboardSlideIn {
  from { opacity: 0; transform: translateX(20px); }
  to { opacity: 1; transform: translateX(0); }
}

.bdPagesOnboardStepEyebrow {
  font-family: 'DM Mono', monospace;
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bdOnboard-gold);
  margin-bottom: 12px;
}

.bdPagesOnboardStepTitle {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.8rem;
  font-weight: 600;
  line-height: 1.1;
  margin-bottom: 10px;
  color: var(--bdOnboard-text);
}

.bdPagesOnboardStepSubtitle {
  font-size: 0.92rem;
  color: var(--bdOnboard-silver);
  margin-bottom: 48px;
  max-width: 460px;
}

/* Purpose cards */
.bdPagesOnboardPurposeGrid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }

.bdPagesOnboardPurposeCard {
  background: var(--bdOnboard-ink3);
  border: 1.5px solid var(--bdOnboard-white08);
  border-radius: var(--bdOnboard-radius);
  padding: 36px 28px;
  cursor: pointer;
  transition: all 0.3s var(--bdOnboard-ease);
  position: relative;
  overflow: hidden;
}

.bdPagesOnboardPurposeCard:hover { border-color: var(--bdOnboard-goldBorder); background: var(--bdOnboard-ink4); transform: translateY(-2px); }

.bdPagesOnboardPurposeCard.selected {
  border-color: var(--bdOnboard-gold);
  background: linear-gradient(150deg, var(--bdOnboard-ink4) 0%, var(--bdOnboard-ink3) 100%);
  box-shadow: 0 0 0 1px var(--bdOnboard-gold), 0 20px 40px rgba(200,168,75,0.1);
}

.bdPagesOnboardPurposeCard.selected::after {
  content: '✓';
  position: absolute;
  top: 14px; right: 16px;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--bdOnboard-gold);
  color: var(--bdOnboard-bg);
  font-size: 0.7rem;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}

.bdPagesOnboardPurposeIcon { font-size: 2.4rem; margin-bottom: 20px; display: block; }
.bdPagesOnboardPurposeName { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; font-weight: 600; margin-bottom: 8px; color: var(--bdOnboard-text); }
.bdPagesOnboardPurposeDesc { font-size: 0.82rem; color: var(--bdOnboard-silver); line-height: 1.6; }

.bdPagesOnboardPurposeRecommend {
  display: inline-block;
  margin-top: 16px;
  background: var(--bdOnboard-goldDim);
  color: var(--bdOnboard-gold);
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  font-family: 'DM Mono', monospace;
  padding: 3px 10px;
  border-radius: 100px;
  border: 1px solid var(--bdOnboard-goldBorder);
}

/* Plan cards */
.bdPagesOnboardPlanGrid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; }

.bdPagesOnboardPlanCard {
  background: var(--bdOnboard-ink3);
  border: 1.5px solid var(--bdOnboard-white08);
  border-radius: var(--bdOnboard-radius);
  padding: 28px 22px;
  cursor: pointer;
  transition: all 0.3s var(--bdOnboard-ease);
  position: relative;
}

.bdPagesOnboardPlanCard:hover { border-color: var(--bdOnboard-goldBorder); background: var(--bdOnboard-ink4); }

.bdPagesOnboardPlanCard.selected {
  border-color: var(--bdOnboard-gold);
  background: linear-gradient(150deg, var(--bdOnboard-ink4), var(--bdOnboard-ink3));
  box-shadow: 0 0 0 1px var(--bdOnboard-gold), 0 16px 32px rgba(200,168,75,0.1);
}

.bdPagesOnboardPlanCard.selected::after {
  content: '✓';
  position: absolute;
  top: 12px; right: 14px;
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--bdOnboard-gold);
  color: var(--bdOnboard-bg);
  font-size: 0.65rem;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}

.bdPagesOnboardPlanBadge {
  position: absolute;
  top: -1px; left: 50%;
  transform: translateX(-50%);
  background: var(--bdOnboard-gold);
  color: var(--bdOnboard-bg);
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  padding: 3px 12px;
  border-radius: 0 0 6px 6px;
  font-family: 'DM Mono', monospace;
  white-space: nowrap;
}

.bdPagesOnboardPlanName { font-family: 'DM Mono', monospace; font-size: 0.65rem; letter-spacing: 0.15em; color: var(--bdOnboard-gold); text-transform: uppercase; margin-bottom: 6px; }
.bdPagesOnboardPlanPrice { font-family: 'Cormorant Garamond', serif; font-size: 2.4rem; font-weight: 600; line-height: 1; margin-bottom: 2px; color: var(--bdOnboard-text); }
.bdPagesOnboardPlanPrice sup { font-size: 1rem; vertical-align: super; font-weight: 400; }
.bdPagesOnboardPlanPeriod { font-size: 0.72rem; color: var(--bdOnboard-silver); margin-bottom: 20px; }
.bdPagesOnboardPlanFreeText { font-family: 'Cormorant Garamond', serif; font-size: 2rem; color: var(--bdOnboard-green); font-weight: 600; margin-bottom: 2px; }
.bdPagesOnboardPlanFeatures { list-style: none; display: flex; flex-direction: column; gap: 7px; }
.bdPagesOnboardPlanFeatures li { font-size: 0.78rem; color: var(--bdOnboard-white60); display: flex; gap: 7px; align-items: flex-start; }
.bdPagesOnboardPlanFeatures li::before { content: '✦'; color: var(--bdOnboard-gold); font-size: 0.58rem; margin-top: 4px; flex-shrink: 0; }

/* Hardware cards */
.bdPagesOnboardHwGrid { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; }

.bdPagesOnboardHwCard {
  background: var(--bdOnboard-ink3);
  border: 1.5px solid var(--bdOnboard-white08);
  border-radius: var(--bdOnboard-radius);
  padding: 28px 24px;
  cursor: pointer;
  transition: all 0.3s var(--bdOnboard-ease);
  position: relative;
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 20px;
  align-items: center;
}

.bdPagesOnboardHwCard:hover { border-color: var(--bdOnboard-goldBorder); background: var(--bdOnboard-ink4); }

.bdPagesOnboardHwCard.selected {
  border-color: var(--bdOnboard-gold);
  background: linear-gradient(150deg, var(--bdOnboard-ink4), var(--bdOnboard-ink3));
  box-shadow: 0 0 0 1px var(--bdOnboard-gold), 0 16px 32px rgba(200,168,75,0.1);
}

.bdPagesOnboardHwCard.selected::after {
  content: '✓';
  position: absolute;
  top: 12px; right: 14px;
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--bdOnboard-gold);
  color: var(--bdOnboard-bg);
  font-size: 0.65rem;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}

.bdPagesOnboardHwCard.full-width { grid-column: span 2; grid-template-columns: 80px 1fr auto; }

.bdPagesOnboardHwVisual { width: 80px; height: 50px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 1.6rem; }
.bdPagesOnboardHwVisual.pvc { background: linear-gradient(135deg,#2A2A3D,#1A1A2A); }
.bdPagesOnboardHwVisual.metal { background: linear-gradient(135deg,#3A3A4A,#232330); box-shadow: inset 0 1px 0 rgba(255,255,255,0.1); }
.bdPagesOnboardHwVisual.wood { background: linear-gradient(135deg,#3D2A1A,#2A1A0D); }
.bdPagesOnboardHwVisual.sticker { background: linear-gradient(135deg,#1A2A1E,#101A12); }
.bdPagesOnboardHwVisual.combo { background: linear-gradient(135deg,#2A1A08,#1A1005); }

.bdPagesOnboardHwName { font-family: 'Cormorant Garamond', serif; font-size: 1.15rem; font-weight: 600; margin-bottom: 3px; color: var(--bdOnboard-text); }
.bdPagesOnboardHwDesc { font-size: 0.75rem; color: var(--bdOnboard-silver); line-height: 1.5; margin-bottom: 8px; }
.bdPagesOnboardHwPrice { font-family: 'DM Mono', monospace; font-size: 0.8rem; color: var(--bdOnboard-gold); }

.bdPagesOnboardHwTag {
  display: inline-block;
  margin-top: 4px;
  background: var(--bdOnboard-goldDim);
  color: var(--bdOnboard-gold);
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  padding: 2px 8px;
  border-radius: 100px;
  border: 1px solid var(--bdOnboard-goldBorder);
  font-family: 'DM Mono', monospace;
}

.bdPagesOnboardHwSaving { text-align: right; white-space: nowrap; }
.bdPagesOnboardSaveAmount { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; color: var(--bdOnboard-green); font-weight: 600; }
.bdPagesOnboardSaveLabel { font-size: 0.72rem; color: var(--bdOnboard-silver); }

/* Personalize step */
.bdPagesOnboardPersonalizeLayout { display: grid; grid-template-columns: 1fr 280px; gap: 48px; align-items: start; }

.bdPagesOnboardFormGroup { margin-bottom: 28px; }

.bdPagesOnboardFormLabel {
  display: block;
  font-size: 0.78rem;
  font-family: 'DM Mono', monospace;
  letter-spacing: 0.1em;
  color: var(--bdOnboard-silver);
  margin-bottom: 10px;
  text-transform: uppercase;
}

.bdPagesOnboardFormInput {
  width: 100%;
  background: var(--bdOnboard-ink3);
  border: 1.5px solid var(--bdOnboard-white08);
  border-radius: 10px;
  padding: 14px 18px;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.95rem;
  color: var(--bdOnboard-text);
  transition: all 0.2s;
  outline: none;
}

.bdPagesOnboardFormInput:focus { border-color: var(--bdOnboard-gold); box-shadow: 0 0 0 3px var(--bdOnboard-goldDim); }
.bdPagesOnboardFormInput::placeholder { color: var(--bdOnboard-silver); }

.bdPagesOnboardColorPicker { display: flex; gap: 10px; flex-wrap: wrap; }

.bdPagesOnboardColorOpt {
  width: 32px; height: 32px;
  border-radius: 50%;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all 0.2s;
}

.bdPagesOnboardColorOpt.active { border-color: var(--bdOnboard-text); box-shadow: 0 0 0 3px var(--bdOnboard-white20); transform: scale(1.1); }

/* Card preview */
.bdPagesOnboardCardPreviewWrap { position: sticky; top: 0; }

.bdPagesOnboardCardPreviewLabel {
  font-family: 'DM Mono', monospace;
  font-size: 0.68rem;
  letter-spacing: 0.15em;
  color: var(--bdOnboard-silver);
  text-align: center;
  margin-bottom: 20px;
  text-transform: uppercase;
}

.bdPagesOnboardCard3d {
  width: 100%;
  aspect-ratio: 1.586/1;
  border-radius: 14px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 30px 60px rgba(0,0,0,0.3), 0 0 0 1px var(--bdOnboard-white08);
  transition: all 0.5s var(--bdOnboard-ease);
  cursor: pointer;
}

.bdPagesOnboardCard3d:hover { transform: perspective(600px) rotateY(-8deg) rotateX(4deg); }
.bdPagesOnboardCardBg { position: absolute; inset: 0; transition: background 0.4s; background: linear-gradient(135deg,#1C1C28 0%,#2A2A3A 50%,#1A1A25 100%); }
.bdPagesOnboardCardNfcIcon { position: absolute; top: 16px; right: 18px; opacity: 0.4; font-size: 1.2rem; }

.bdPagesOnboardCardContent { position: absolute; inset: 0; padding: 22px 24px; display: flex; flex-direction: column; justify-content: flex-end; }

.bdPagesOnboardCardLogoCircle {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--bdOnboard-gold);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 700;
  font-size: 1.1rem;
  color: #08080F;
  margin-bottom: auto;
  transition: all 0.3s;
}

.bdPagesOnboardCardUserName { font-family: 'Cormorant Garamond', serif; font-size: 1.2rem; font-weight: 600; color: #F5F3EE; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: all 0.3s; }
.bdPagesOnboardCardUserTitle { font-size: 0.68rem; color: rgba(245,243,238,0.6); margin-top: 1px; transition: all 0.3s; }
.bdPagesOnboardCardBottom { position: absolute; bottom: 14px; right: 18px; font-family: 'DM Mono', monospace; font-size: 0.58rem; color: rgba(200,168,75,0.5); letter-spacing: 0.12em; }

.bdPagesOnboardPhonePreviewMini { margin-top: 24px; background: var(--bdOnboard-ink3); border-radius: var(--bdOnboard-radius); padding: 20px; border: 1px solid var(--bdOnboard-white08); }
.bdPagesOnboardPhonePreviewMiniLabel { font-size: 0.72rem; color: var(--bdOnboard-silver); text-align: center; margin-bottom: 14px; }
.bdPagesOnboardMiniProfile { display: flex; align-items: center; gap: 12px; }

.bdPagesOnboardMiniAvatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--bdOnboard-gold);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 700;
  font-size: 1.1rem;
  color: #08080F;
  flex-shrink: 0;
  transition: all 0.3s;
}

.bdPagesOnboardMiniName { font-size: 0.88rem; font-weight: 600; color: var(--bdOnboard-text); }
.bdPagesOnboardMiniRole { font-size: 0.72rem; color: var(--bdOnboard-silver); }
.bdPagesOnboardMiniActions { display: flex; gap: 8px; margin-top: 12px; }

.bdPagesOnboardMiniAction {
  flex: 1;
  background: var(--bdOnboard-white08);
  border-radius: 8px;
  padding: 7px;
  text-align: center;
  font-size: 0.65rem;
  color: var(--bdOnboard-silver);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
}

.bdPagesOnboardMiniActionIcon { font-size: 0.9rem; }

/* Bundle step */
.bdPagesOnboardBundleMain {
  background: var(--bdOnboard-ink3);
  border-radius: var(--bdOnboard-radius);
  border: 1.5px solid var(--bdOnboard-goldBorder);
  padding: 32px;
  margin-bottom: 20px;
  display: flex;
  gap: 24px;
  align-items: center;
}

.bdPagesOnboardBundleVisual { font-size: 3rem; }
.bdPagesOnboardBundleText h3 { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; margin-bottom: 6px; color: var(--bdOnboard-text); }
.bdPagesOnboardBundleText p { font-size: 0.85rem; color: var(--bdOnboard-silver); margin-bottom: 14px; }
.bdPagesOnboardBundleToggleRow { display: flex; align-items: center; justify-content: space-between; }
.bdPagesOnboardBundlePrice { font-family: 'DM Mono', monospace; color: var(--bdOnboard-gold); font-size: 0.9rem; }

.bdPagesOnboardToggleSwitch {
  width: 44px; height: 24px;
  border-radius: 100px;
  background: var(--bdOnboard-white08);
  border: 1px solid var(--bdOnboard-white20);
  cursor: pointer;
  position: relative;
  transition: all 0.3s;
}

.bdPagesOnboardToggleSwitch.on { background: var(--bdOnboard-gold); border-color: var(--bdOnboard-gold); }

.bdPagesOnboardToggleKnob {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: #ffffff;
  position: absolute;
  top: 2px; left: 2px;
  transition: all 0.3s var(--bdOnboard-ease);
}

.bdPagesOnboardToggleSwitch.on .bdPagesOnboardToggleKnob { left: 22px; }

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

.bdPagesOnboardCrossItem {
  background: var(--bdOnboard-ink3);
  border-radius: var(--bdOnboard-radius);
  border: 1.5px solid var(--bdOnboard-white08);
  padding: 20px;
  cursor: pointer;
  transition: all 0.3s;
}

.bdPagesOnboardCrossItem:hover { border-color: var(--bdOnboard-goldBorder); }
.bdPagesOnboardCrossItem.added { border-color: var(--bdOnboard-green); background: rgba(40,217,138,0.04); }

.bdPagesOnboardCrossItemName { font-size: 0.88rem; font-weight: 500; margin-bottom: 4px; color: var(--bdOnboard-text); }
.bdPagesOnboardCrossItemDesc { font-size: 0.75rem; color: var(--bdOnboard-silver); margin-bottom: 12px; }
.bdPagesOnboardCrossItemFooter { display: flex; align-items: center; justify-content: space-between; }
.bdPagesOnboardCrossItemPrice { font-family: 'DM Mono', monospace; font-size: 0.78rem; color: var(--bdOnboard-gold); }

.bdPagesOnboardAddBtn {
  padding: 4px 14px;
  border-radius: 100px;
  font-size: 0.72rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  border: none;
}

.bdPagesOnboardAddBtn.add { background: var(--bdOnboard-goldDim); color: var(--bdOnboard-gold); border: 1px solid var(--bdOnboard-goldBorder); }
.bdPagesOnboardAddBtn.added { background: rgba(40,217,138,0.1); color: var(--bdOnboard-green); border: 1px solid rgba(40,217,138,0.3); }

/* Checkout */
.bdPagesOnboardCheckoutGrid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }

.bdPagesOnboardSectionLabelSm {
  font-family: 'DM Mono', monospace;
  font-size: 0.68rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--bdOnboard-gold);
  margin-bottom: 18px;
  display: block;
}

.bdPagesOnboardPaymentMethods { display: flex; gap: 10px; margin-bottom: 24px; flex-wrap: wrap; }

.bdPagesOnboardPayOpt {
  padding: 10px 18px;
  border-radius: 8px;
  background: var(--bdOnboard-ink3);
  border: 1.5px solid var(--bdOnboard-white08);
  font-size: 0.8rem;
  cursor: pointer;
  transition: all 0.2s;
  color: var(--bdOnboard-text);
}

.bdPagesOnboardPayOpt.active { border-color: var(--bdOnboard-gold); color: var(--bdOnboard-gold); }

/* Success screen */
.bdPagesOnboardSuccessScreen { text-align: center; padding: 60px 0; }

.bdPagesOnboardSuccessIcon {
  width: 80px; height: 80px;
  border-radius: 50%;
  background: rgba(40,217,138,0.1);
  border: 2px solid var(--bdOnboard-green);
  display: flex; align-items: center; justify-content: center;
  font-size: 2rem;
  margin: 0 auto 32px;
  animation: bdOnboardSuccessPop 0.5s var(--bdOnboard-ease) both 0.2s;
}

@keyframes bdOnboardSuccessPop {
  from { opacity: 0; transform: scale(0.5); }
  to { opacity: 1; transform: scale(1); }
}

.bdPagesOnboardSuccessSteps { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin: 48px 0; text-align: left; }

.bdPagesOnboardSuccessStep {
  background: var(--bdOnboard-ink3);
  border-radius: var(--bdOnboard-radius);
  padding: 24px;
  border: 1px solid var(--bdOnboard-white08);
}

.bdPagesOnboardSuccessStepNum {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--bdOnboard-goldDim);
  border: 1px solid var(--bdOnboard-goldBorder);
  display: flex; align-items: center; justify-content: center;
  font-family: 'DM Mono', monospace;
  font-size: 0.68rem;
  color: var(--bdOnboard-gold);
  margin-bottom: 14px;
}

.bdPagesOnboardSuccessStep h4 { font-size: 0.92rem; margin-bottom: 6px; color: var(--bdOnboard-text); }
.bdPagesOnboardSuccessStep p { font-size: 0.78rem; color: var(--bdOnboard-silver); }

/* Sidebar order summary */
.bdPagesOnboardSidebarTitle { font-family: 'DM Mono', monospace; font-size: 0.65rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--bdOnboard-silver); margin-bottom: 20px; }

.bdPagesOnboardOrderItem { display: flex; align-items: flex-start; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--bdOnboard-white08); }
.bdPagesOnboardOrderItem:last-child { border-bottom: none; }

.bdPagesOnboardOrderItemIcon {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: var(--bdOnboard-goldDim);
  border: 1px solid var(--bdOnboard-goldBorder);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}

.bdPagesOnboardOrderItemName { font-size: 0.84rem; font-weight: 500; margin-bottom: 2px; color: var(--bdOnboard-text); }
.bdPagesOnboardOrderItemDetail { font-size: 0.72rem; color: var(--bdOnboard-silver); }
.bdPagesOnboardOrderItemPrice { margin-left: auto; font-family: 'DM Mono', monospace; font-size: 0.8rem; color: var(--bdOnboard-gold); white-space: nowrap; }

.bdPagesOnboardSidebarDivider { height: 1px; background: var(--bdOnboard-white08); margin: 20px 0; }

.bdPagesOnboardSummaryRow { display: flex; justify-content: space-between; align-items: center; font-size: 0.84rem; color: var(--bdOnboard-silver); margin-bottom: 8px; }
.bdPagesOnboardSummaryTotal { display: flex; justify-content: space-between; align-items: center; padding-top: 14px; }
.bdPagesOnboardSummaryTotalLabel { font-family: 'Cormorant Garamond', serif; font-size: 1.2rem; font-weight: 600; color: var(--bdOnboard-text); }
.bdPagesOnboardSummaryTotalAmount { font-family: 'Cormorant Garamond', serif; font-size: 1.6rem; font-weight: 700; color: var(--bdOnboard-gold); }

.bdPagesOnboardSidebarEmpty { text-align: center; padding: 32px 16px; color: var(--bdOnboard-silver); font-size: 0.82rem; }
.bdPagesOnboardSidebarEmptyIcon { font-size: 2rem; margin-bottom: 12px; opacity: 0.4; }

/* Continue/back buttons */
.bdPagesOnboardContinueWrap { margin-top: 48px; }

.bdPagesOnboardBtnContinue {
  background: var(--bdOnboard-gold);
  color: var(--bdOnboard-bg);
  padding: 16px 48px;
  border-radius: 100px;
  font-weight: 600;
  font-size: 1rem;
  border: none;
  cursor: pointer;
  transition: all 0.3s var(--bdOnboard-ease);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: 'DM Sans', sans-serif;
}

.bdPagesOnboardBtnContinue:hover { background: var(--bdOnboard-goldLight); transform: translateY(-2px); box-shadow: 0 16px 40px rgba(200,168,75,0.25); }
.bdPagesOnboardBtnContinue:disabled { opacity: 0.4; cursor: not-allowed; transform: none !important; box-shadow: none !important; }

.bdPagesOnboardBtnBack {
  background: transparent;
  color: var(--bdOnboard-silver);
  padding: 16px 24px;
  border-radius: 100px;
  font-size: 0.88rem;
  border: none;
  cursor: pointer;
  transition: all 0.2s;
  margin-right: 8px;
  font-family: 'DM Sans', sans-serif;
}

.bdPagesOnboardBtnBack:hover { color: var(--bdOnboard-text); }

/* Students onboarding responsive */
@media (max-width: 900px) {
  .bdPagesOnboardMain { grid-template-columns: 1fr; }
  .bdPagesOnboardSidebar { display: none; }
  .bdPagesOnboardContentArea { padding: 32px 24px; }
  .bdPagesOnboardPurposeGrid,
  .bdPagesOnboardPlanGrid { grid-template-columns: 1fr 1fr; }
  .bdPagesOnboardHwGrid { grid-template-columns: 1fr; }
  .bdPagesOnboardHwCard.full-width { grid-column: span 1; grid-template-columns: 80px 1fr; }
  .bdPagesOnboardPersonalizeLayout { grid-template-columns: 1fr; }
  .bdPagesOnboardCheckoutGrid { grid-template-columns: 1fr; }
  .bdPagesOnboardSuccessSteps { grid-template-columns: 1fr; }
  .bdPagesOnboardStepDots { padding: 0 20px; }
  .bdPagesOnboardTopNav { padding: 0 20px; }
  .bdPagesOnboardStepTitle { font-size: 2.2rem; }
}

@media (max-width: 600px) {
  .bdPagesOnboardPurposeGrid,
  .bdPagesOnboardPlanGrid,
  .bdPagesOnboardCrossSellGrid { grid-template-columns: 1fr; }
}
