{"js":"<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Vortex Altitude Assessment ~ The Summit ~ She Evolves Africa</title>
<meta name="description" content="Discover your digital sovereignty altitude. The Vortex Altitude Assessment by She Evolves Africa ~ find out where you truly stand and exactly where to go next.">
<meta name="theme-color" content="#1B3A6B">
<link rel="preconnect" href="https://fonts.googleapis.com">
<link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400&family=Outfit:wght@300;400;500;600;700&display=swap" rel="stylesheet">

<style>
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }

:root {
  --navy:      #1B3A6B;
  --navy-deep: #0D2247;
  --navy-mid:  #2C5282;
  --gold:      #C9951A;
  --gold2:     #E8B432;
  --gold3:     #F5D060;
  --grey:      #4A5568;
  --grey-mid:  #718096;
  --white:     #FFFFFF;
  --dark:      #070D1A;
  /* Level colours */
  --invisible:   #4A5568;
  --emerging:    #2C7A7B;
  --visible:     #2B6CB0;
  --influential: #6B46C1;
  --sovereign:   #C9951A;
}

body {
  font-family: 'Outfit', sans-serif;
  background: var(--dark);
  min-height: 100vh;
  overflow-x: hidden;
}

.page-bg {
  position: fixed; inset: 0; z-index: 0;
  background:
    radial-gradient(ellipse at 20% 15%, rgba(27,58,107,0.8) 0%, transparent 55%),
    radial-gradient(ellipse at 80% 85%, rgba(201,149,26,0.18) 0%, transparent 50%),
    #070D1A;
}

/* ── FLOATIES ── */
.floaties { position:fixed; inset:0; pointer-events:none; z-index:1; overflow:hidden; }
.floatie  { position:absolute; bottom:-60px; animation:floatUp linear infinite; opacity:0; }
@keyframes floatUp {
  0%   { transform:translateY(0) rotate(-3deg);    opacity:0; }
  6%   { opacity:0.4; }
  90%  { opacity:0.12; }
  100% { transform:translateY(-110vh) rotate(10deg); opacity:0; }
}

/* ── WRAP ── */
.wrap {
  position:relative; z-index:10;
  min-height:100vh;
  display:flex; flex-direction:column; align-items:center;
  padding:0 1rem 4rem;
}

/* ── HEADER ── */
.header {
  width:100%; max-width:620px;
  padding:2.5rem 1.5rem 1.8rem;
  text-align:center;
}
.header-brand {
  display:flex; align-items:center; justify-content:center; gap:0.5rem;
  margin-bottom:1.2rem;
}
.header-brand .crown { font-size:1.6rem; filter:drop-shadow(0 0 12px rgba(201,149,26,0.8)); }
.header-brand .brand-text { font-family:'Cormorant Garamond',serif; font-size:1rem; font-weight:600; color:var(--gold2); letter-spacing:0.15em; text-transform:uppercase; }

.header h1 { font-family:'Cormorant Garamond',serif; font-size:2.4rem; font-weight:700; color:var(--white); line-height:1.15; margin-bottom:0.5rem; }
.header h1 span { color:var(--gold2); }
.header p { font-size:0.85rem; color:var(--grey-mid); line-height:1.65; max-width:480px; margin:0 auto 1.2rem; }

/* altitude preview strip */
.altitude-strip {
  display:flex; justify-content:center; align-items:center; gap:0.3rem;
  flex-wrap:wrap; margin-bottom:0.5rem;
}
.alt-pip { display:flex; align-items:center; gap:0.3rem; }
.alt-dot { width:8px; height:8px; border-radius:50%; }
.alt-label { font-size:0.6rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--grey-mid); }
.alt-sep { font-size:0.6rem; color:rgba(255,255,255,0.15); }

/* ── PROGRESS BAR ── */
.progress-wrap { width:100%; max-width:620px; padding:0 1.5rem; margin-bottom:1.5rem; }
.progress-header { display:flex; justify-content:space-between; margin-bottom:0.4rem; }
.progress-header span { font-size:0.62rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--grey-mid); }
.progress-header .q-count { color:var(--gold); font-weight:600; }
.progress-track { height:4px; background:rgba(255,255,255,0.08); border-radius:4px; overflow:hidden; }
.progress-fill { height:100%; background:linear-gradient(90deg,var(--navy-mid),var(--gold)); border-radius:4px; transition:width 0.5s ease; width:0%; }

/* ── QUESTION CARD ── */
.q-stage { width:100%; max-width:620px; }

.q-card {
  background:linear-gradient(145deg, rgba(27,58,107,0.45) 0%, rgba(13,34,71,0.8) 100%);
  border:1px solid rgba(201,149,26,0.25);
  border-radius:18px;
  padding:1.8rem 1.6rem 1.4rem;
  margin-bottom:1rem;
  animation:cardIn 0.4s ease forwards;
}
@keyframes cardIn { from { opacity:0; transform:translateY(16px); } to { opacity:1; transform:translateY(0); } }

.q-dimension {
  font-size:0.58rem; font-weight:600; letter-spacing:0.25em;
  text-transform:uppercase; color:var(--gold); margin-bottom:0.6rem; display:block;
}
.q-number { font-size:0.65rem; color:var(--grey-mid); margin-bottom:0.3rem; display:block; }
.q-text {
  font-family:'Cormorant Garamond',serif;
  font-size:1.35rem; font-weight:600;
  color:var(--white); line-height:1.45; margin-bottom:1.4rem;
}

/* answer options */
.answers { display:flex; flex-direction:column; gap:0.55rem; }
.answer-btn {
  display:flex; align-items:flex-start; gap:0.85rem;
  padding:0.85rem 1rem;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:10px; cursor:pointer;
  text-align:left; transition:all 0.2s;
  width:100%;
}
.answer-btn:hover { background:rgba(27,58,107,0.5); border-color:rgba(201,149,26,0.4); transform:translateX(4px); }
.answer-btn.selected { background:rgba(201,149,26,0.15); border-color:var(--gold); }
.answer-btn.selected .a-letter { background:var(--gold); color:var(--dark); }

.a-letter {
  min-width:26px; height:26px;
  background:rgba(27,58,107,0.8);
  border:1px solid rgba(201,149,26,0.3);
  border-radius:6px;
  display:flex; align-items:center; justify-content:center;
  font-size:0.7rem; font-weight:700; color:var(--gold);
  flex-shrink:0; margin-top:1px; transition:all 0.2s;
}
.a-text { font-size:0.82rem; color:rgba(255,255,255,0.85); line-height:1.5; }

/* next button */
.next-btn {
  width:100%; padding:0.9rem;
  background:linear-gradient(135deg,var(--gold) 0%,#A87A12 100%);
  color:var(--dark); border:none; border-radius:10px;
  font-family:'Outfit',sans-serif; font-size:0.88rem; font-weight:700;
  cursor:pointer; letter-spacing:0.04em; text-transform:uppercase;
  transition:all 0.22s; opacity:0.4; pointer-events:none;
  box-shadow:0 4px 20px rgba(201,149,26,0.25);
}
.next-btn.active { opacity:1; pointer-events:auto; box-shadow:0 4px 24px rgba(201,149,26,0.4); }
.next-btn.active:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(201,149,26,0.5); }

/* ── INTRO SCREEN ── */
.intro-screen {
  width:100%; max-width:620px;
  background:linear-gradient(145deg, rgba(27,58,107,0.45) 0%, rgba(13,34,71,0.85) 100%);
  border:1px solid rgba(201,149,26,0.3);
  border-radius:20px; padding:2.2rem 1.8rem;
  text-align:center;
}
.intro-crown { font-size:3.5rem; display:block; margin-bottom:1rem; filter:drop-shadow(0 0 24px rgba(201,149,26,0.9)); animation:crownPulse 2.5s ease-in-out infinite; }
@keyframes crownPulse {
  0%,100% { filter:drop-shadow(0 0 20px rgba(201,149,26,0.7)); transform:scale(1); }
  50%      { filter:drop-shadow(0 0 40px rgba(201,149,26,1)); transform:scale(1.07); }
}
.intro-screen h2 { font-family:'Cormorant Garamond',serif; font-size:1.9rem; font-weight:700; color:var(--white); margin-bottom:0.5rem; line-height:1.2; }
.intro-screen h2 em { color:var(--gold2); font-style:italic; }
.intro-screen p { font-size:0.83rem; color:var(--grey-mid); line-height:1.7; margin-bottom:1.4rem; max-width:420px; margin-left:auto; margin-right:auto; }

.levels-preview { display:flex; flex-direction:column; gap:0.4rem; margin-bottom:1.6rem; text-align:left; }
.level-row {
  display:flex; align-items:center; gap:0.75rem;
  padding:0.5rem 0.75rem; border-radius:8px;
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.06);
}
.level-icon { font-size:1.1rem; width:24px; text-align:center; }
.level-name { font-size:0.78rem; font-weight:600; }
.level-desc { font-size:0.68rem; color:var(--grey-mid); margin-left:auto; text-align:right; max-width:180px; line-height:1.3; }

.start-btn {
  width:100%; padding:1rem;
  background:linear-gradient(135deg,var(--gold) 0%,#A87A12 100%);
  color:var(--dark); border:none; border-radius:12px;
  font-family:'Outfit',sans-serif; font-size:0.95rem; font-weight:700;
  cursor:pointer; letter-spacing:0.04em; text-transform:uppercase;
  box-shadow:0 6px 28px rgba(201,149,26,0.4); transition:all 0.22s;
}
.start-btn:hover { transform:translateY(-2px); box-shadow:0 10px 36px rgba(201,149,26,0.55); }

/* ── CAPTURE SCREEN ── */
.capture-screen {
  width:100%; max-width:620px;
  background:linear-gradient(145deg, rgba(27,58,107,0.45) 0%, rgba(13,34,71,0.85) 100%);
  border:1px solid rgba(201,149,26,0.3);
  border-radius:20px; padding:2rem 1.8rem;
}
.capture-screen h2 { font-family:'Cormorant Garamond',serif; font-size:1.6rem; font-weight:600; color:var(--white); margin-bottom:0.4rem; }
.capture-screen p { font-size:0.8rem; color:var(--grey-mid); margin-bottom:1.4rem; line-height:1.6; }
.field { margin-bottom:0.75rem; }
.field input {
  width:100%; padding:0.8rem 1rem;
  background:rgba(255,255,255,0.06); border:1px solid rgba(201,149,26,0.2);
  border-radius:9px; font-family:'Outfit',sans-serif; font-size:0.85rem;
  color:var(--white); outline:none; transition:border 0.2s;
}
.field input::placeholder { color:rgba(255,255,255,0.3); }
.field input:focus { border-color:var(--gold); }
.reveal-btn {
  width:100%; padding:0.95rem;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-deep) 100%);
  color:var(--gold); border:1px solid var(--gold);
  border-radius:10px; font-family:'Outfit',sans-serif;
  font-size:0.9rem; font-weight:700; cursor:pointer;
  letter-spacing:0.05em; text-transform:uppercase; transition:all 0.2s;
  margin-top:0.4rem;
}
.reveal-btn:hover { background:rgba(201,149,26,0.15); }
.skip-link { display:block; text-align:center; margin-top:0.75rem; font-size:0.68rem; color:var(--grey-mid); cursor:pointer; letter-spacing:0.1em; text-transform:uppercase; text-decoration:underline; text-underline-offset:3px; }
.skip-link:hover { color:var(--gold); }

/* ── RESULT SCREEN ── */
.result-screen { width:100%; max-width:620px; }

.result-hero {
  border-radius:18px; padding:2.2rem 1.8rem 1.8rem;
  text-align:center; margin-bottom:1rem;
  position:relative; overflow:hidden;
}
.result-hero::before { content:''; position:absolute; inset:0; background-image: repeating-linear-gradient(-45deg, transparent, transparent 18px, rgba(255,255,255,0.02) 18px, rgba(255,255,255,0.02) 19px); pointer-events:none; }

.result-level-badge {
  display:inline-block;
  padding:0.35rem 1rem; border-radius:20px;
  font-size:0.62rem; font-weight:700; letter-spacing:0.2em;
  text-transform:uppercase; margin-bottom:1rem;
}
.result-crown { font-size:3rem; display:block; margin-bottom:0.7rem; }
.result-screen h2 { font-family:'Cormorant Garamond',serif; font-size:2.2rem; font-weight:700; line-height:1.1; margin-bottom:0.5rem; }
.result-tagline { font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-style:italic; line-height:1.6; margin-bottom:1.2rem; opacity:0.9; }

/* score meter */
.score-meter { margin:1rem 0; }
.meter-label { display:flex; justify-content:space-between; margin-bottom:0.4rem; }
.meter-label span { font-size:0.62rem; letter-spacing:0.12em; text-transform:uppercase; }
.meter-track { height:8px; background:rgba(255,255,255,0.1); border-radius:8px; overflow:hidden; }
.meter-fill { height:100%; border-radius:8px; transition:width 1.5s ease; width:0%; }

/* dimension scores */
.dim-scores { display:grid; grid-template-columns:1fr 1fr; gap:0.5rem; margin:1rem 0; }
.dim-card { padding:0.7rem 0.8rem; border-radius:10px; background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.08); }
.dim-name { font-size:0.58rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--grey-mid); display:block; margin-bottom:0.3rem; }
.dim-bar-wrap { height:4px; background:rgba(255,255,255,0.08); border-radius:4px; overflow:hidden; }
.dim-bar { height:100%; border-radius:4px; transition:width 1.5s ease 0.3s; }

/* result body */
.result-body {
  background:rgba(13,34,71,0.6); border:1px solid rgba(201,149,26,0.2);
  border-radius:14px; padding:1.4rem; margin-bottom:1rem;
}
.result-body h3 { font-family:'Cormorant Garamond',serif; font-size:1.2rem; font-weight:600; color:var(--white); margin-bottom:0.6rem; }
.result-body p { font-size:0.82rem; color:rgba(255,255,255,0.8); line-height:1.7; margin-bottom:0.8rem; }
.result-body ul { list-style:none; }
.result-body ul li { font-size:0.8rem; color:rgba(255,255,255,0.75); padding:0.3rem 0; padding-left:1.2rem; position:relative; line-height:1.5; }
.result-body ul li::before { content:'✦'; position:absolute; left:0; color:var(--gold); font-size:0.6rem; top:0.4rem; }

/* CTA */
.result-cta { display:flex; flex-direction:column; gap:0.6rem; }
.r-btn {
  display:flex; align-items:center; justify-content:center; gap:0.6rem;
  padding:0.9rem 1.2rem; border-radius:10px; text-decoration:none;
  font-family:'Outfit',sans-serif; font-size:0.85rem; font-weight:600;
  transition:all 0.22s; cursor:pointer; border:none; width:100%; letter-spacing:0.02em;
}
.r-btn-primary { color:var(--dark); box-shadow:0 4px 20px rgba(201,149,26,0.35); }
.r-btn-primary:hover { transform:translateY(-2px); }
.r-btn-secondary { background:transparent; border:1px solid rgba(201,149,26,0.4); color:var(--gold2); }
.r-btn-secondary:hover { background:rgba(201,149,26,0.1); border-color:var(--gold); }

.retake-link { display:block; text-align:center; margin-top:0.8rem; font-size:0.68rem; color:var(--grey-mid); cursor:pointer; letter-spacing:0.1em; text-transform:uppercase; }
.retake-link:hover { color:var(--gold); }

/* share strip */
.share-strip { display:flex; align-items:center; gap:0.6rem; margin-top:1rem; padding:0.8rem 1rem; background:rgba(27,58,107,0.3); border:1px solid rgba(201,149,26,0.15); border-radius:10px; }
.share-text { font-size:0.72rem; color:var(--grey-mid); flex:1; line-height:1.4; }
.share-text strong { color:var(--gold2); display:block; font-size:0.75rem; margin-bottom:0.1rem; }
.share-btn { padding:0.45rem 0.9rem; background:var(--navy); border:1px solid var(--gold); border-radius:7px; color:var(--gold); font-size:0.7rem; font-weight:600; cursor:pointer; letter-spacing:0.08em; text-transform:uppercase; white-space:nowrap; transition:all 0.2s; }
.share-btn:hover { background:rgba(201,149,26,0.15); }

/* hidden utility */
.hidden { display:none !important; }

/* ── FOOTER ── */
.assessment-footer { width:100%; max-width:620px; text-align:center; padding:1.5rem 1rem; }
.assessment-footer p { font-size:0.62rem; color:var(--grey-mid); letter-spacing:0.1em; text-transform:uppercase; }
.assessment-footer span { color:var(--gold); }
</style>
</head>
<body>

<div class="page-bg"></div>
<div class="floaties" id="floaties"></div>

<div class="wrap">

  <!-- HEADER -->
  <div class="header">
    <div class="header-brand">
      <span class="crown">👑</span>
      <span class="brand-text">She Evolves Africa ~ Vortex Altitude</span>
    </div>
    <h1>Where Do You <span>Really</span> Stand?</h1>
    <p>LinkedIn profiles glow. Follower counts climb. But real digital sovereignty ~ the kind you own, the kind Google indexes, the kind that outlives any platform ~ tells a different story. Discover your true altitude.</p>
    <div class="altitude-strip">
      <div class="alt-pip"><span class="alt-dot" style="background:var(--invisible)"></span><span class="alt-label">Invisible</span></div>
      <span class="alt-sep">→</span>
      <div class="alt-pip"><span class="alt-dot" style="background:var(--emerging)"></span><span class="alt-label">Emerging</span></div>
      <span class="alt-sep">→</span>
      <div class="alt-pip"><span class="alt-dot" style="background:var(--visible)"></span><span class="alt-label">Visible</span></div>
      <span class="alt-sep">→</span>
      <div class="alt-pip"><span class="alt-dot" style="background:var(--influential)"></span><span class="alt-label">Influential</span></div>
      <span class="alt-sep">→</span>
      <div class="alt-pip"><span class="alt-dot" style="background:var(--sovereign)"></span><span class="alt-label">Sovereign</span></div>
    </div>
  </div>

  <!-- PROGRESS -->
  <div class="progress-wrap hidden" id="progressWrap">
    <div class="progress-header">
      <span>Your Altitude Assessment</span>
      <span class="q-count" id="qCount">Question 1 of 12</span>
    </div>
    <div class="progress-track"><div class="progress-fill" id="progressFill"></div></div>
  </div>

  <!-- INTRO SCREEN -->
  <div class="intro-screen" id="introScreen">
    <span class="intro-crown">👑</span>
    <h2>The <em>Vortex Altitude</em><br>Assessment</h2>
    <p>12 questions. 4 dimensions. One honest result. No vanity metrics. No flattery. Just the truth about where you stand ~ and a clear path to where you deserve to be.</p>

    <div class="levels-preview">
      <div class="level-row">
        <span class="level-icon">🌫️</span>
        <span class="level-name" style="color:var(--invisible)">Invisible</span>
        <span class="level-desc">The start ~ and a powerful place to begin</span>
      </div>
      <div class="level-row">
        <span class="level-icon">🌱</span>
        <span class="level-name" style="color:var(--emerging)">Emerging</span>
        <span class="level-desc">Digital foundations being laid</span>
      </div>
      <div class="level-row">
        <span class="level-icon">💡</span>
        <span class="level-name" style="color:var(--visible)">Visible</span>
        <span class="level-desc">Present online ~ building authority</span>
      </div>
      <div class="level-row">
        <span class="level-icon">⚡</span>
        <span class="level-name" style="color:var(--influential)">Influential</span>
        <span class="level-desc">Authority established ~ scaling presence</span>
      </div>
      <div class="level-row">
        <span class="level-icon">👑</span>
        <span class="level-name" style="color:var(--sovereign)">Sovereign</span>
        <span class="level-desc">Full digital ownership ~ the pinnacle</span>
      </div>
    </div>

    <button class="start-btn" onclick="startAssessment()">Begin My Altitude Assessment 👑</button>
  </div>

  <!-- QUESTION STAGE -->
  <div class="q-stage hidden" id="qStage">
    <div class="q-card" id="qCard">
      <span class="q-dimension" id="qDimension"></span>
      <span class="q-number" id="qNumber"></span>
      <p class="q-text" id="qText"></p>
      <div class="answers" id="answersWrap"></div>
    </div>
    <button class="next-btn" id="nextBtn" onclick="nextQuestion()">Continue →</button>
  </div>

  <!-- CAPTURE SCREEN -->
  <div class="capture-screen hidden" id="captureScreen">
    <h2>Almost there 👑</h2>
    <p>Your altitude result is ready. Enter your details to receive your personalised next steps ~ and to be added to the right She Evolves Africa community for where you are right now.</p>
    <div class="field"><input type="text" id="capName" placeholder="Your Name" autocomplete="name"></div>
    <div class="field"><input type="email" id="capEmail" placeholder="Your Email Address" autocomplete="email"></div>
    <div class="field"><input type="tel" id="capPhone" placeholder="Your WhatsApp Number (optional)" autocomplete="tel"></div>
    <button class="reveal-btn" onclick="revealResult()">Reveal My Altitude Result 👑</button>
    <span class="skip-link" onclick="revealResult()">Skip and see my result →</span>
  </div>

  <!-- RESULT SCREEN -->
  <div class="result-screen hidden" id="resultScreen">
    <div class="result-hero" id="resultHero">
      <div class="result-level-badge" id="resultBadge"></div>
      <span class="result-crown" id="resultCrown"></span>
      <h2 id="resultTitle"></h2>
      <p class="result-tagline" id="resultTagline"></p>
      <div class="score-meter">
        <div class="meter-label">
          <span>Digital Sovereignty Score</span>
          <span id="scoreDisplay" style="color:var(--gold);font-weight:600"></span>
        </div>
        <div class="meter-track"><div class="meter-fill" id="meterFill"></div></div>
      </div>
      <div class="dim-scores" id="dimScores"></div>
    </div>

    <div class="result-body" id="resultBody"></div>

    <div class="result-cta" id="resultCta"></div>

    <div class="share-strip">
      <div class="share-text">
        <strong>Share your altitude 👑</strong>
        Copy your result and share it ~ invite another woman to discover hers
      </div>
      <button class="share-btn" onclick="shareResult()">Copy Result</button>
    </div>

    <div style="text-align:center;margin-top:0.8rem">
      <span class="retake-link" onclick="resetAll()">↺ Retake the assessment</span>
    </div>
  </div>

  <!-- FOOTER -->
  <div class="assessment-footer">
    <p>👑 <span>She Evolves Africa</span> ~ Voices. Visions. Legacy. ~ <span>sheevolves.africa</span></p>
  </div>

</div><!-- /wrap -->

<script>
// ── QUESTIONS ──────────────────────────────────────────────────────────
const QUESTIONS = [
  // DIMENSION 1: OWNERSHIP (3 questions)
  {
    dim: 'Dimension 1 ~ Ownership',
    text: 'When someone searches your name on Google right now, what appears?',
    answers: [
      { text: 'Nothing. My name returns no meaningful results.', score: 0 },
      { text: 'My social media profiles ~ Instagram, LinkedIn, Facebook.', score: 1 },
      { text: 'Social profiles plus a website someone else built for me.', score: 2 },
      { text: 'A website I own, indexed articles, and professional profiles.', score: 3 },
      { text: 'A full digital estate ~ my domain, news coverage, authority profiles.', score: 4 },
    ]
  },
  {
    dim: 'Dimension 1 ~ Ownership',
    text: 'How much of your online presence do you truly OWN ~ as in, could not be deleted by a platform tomorrow?',
    answers: [
      { text: 'None. Everything I have is on platforms others control.', score: 0 },
      { text: 'Very little. Maybe an old website I barely update.', score: 1 },
      { text: 'Some. I have a website and an email list starting to grow.', score: 2 },
      { text: 'Quite a lot. I have owned platforms and a growing email audience.', score: 3 },
      { text: 'Most of it. My digital infrastructure is built on owned assets.', score: 4 },
    ]
  },
  {
    dim: 'Dimension 1 ~ Ownership',
    text: 'Do you have a personal domain ~ a URL with your name or brand that you own outright?',
    answers: [
      { text: 'No. I have never registered a domain in my name.', score: 0 },
      { text: 'No, but I have been thinking about it for a while.', score: 1 },
      { text: 'Yes, I own a domain but the website is basic or outdated.', score: 2 },
      { text: 'Yes, and my website reflects my professional identity well.', score: 3 },
      { text: 'Yes, and I have multiple domains serving different aspects of my work.', score: 4 },
    ]
  },

  // DIMENSION 2: SEARCHABILITY (3 questions)
  {
    dim: 'Dimension 2 ~ Searchability',
    text: 'If a collaborator, investor or client searched your area of expertise in your city or country, would they find YOU?',
    answers: [
      { text: 'No. My expertise is not documented anywhere online.', score: 0 },
      { text: 'Unlikely. I have social profiles but no keyword-rich content.', score: 1 },
      { text: 'Maybe. I have some content but it is not consistently searchable.', score: 2 },
      { text: 'Probably. I appear in searches for my niche with some regularity.', score: 3 },
      { text: 'Yes. I rank well and appear in searches across my areas of expertise.', score: 4 },
    ]
  },
  {
    dim: 'Dimension 2 ~ Searchability',
    text: 'Have you ever been featured, quoted, or profiled in an online article, news channel, or blog that lives permanently on the internet?',
    answers: [
      { text: 'No. I have never been featured anywhere online.', score: 0 },
      { text: 'Once or twice, years ago. Not recently.', score: 1 },
      { text: 'A few times, but not consistently and not on authority sites.', score: 2 },
      { text: 'Yes, I have been featured and some of it still ranks on Google.', score: 3 },
      { text: 'Yes, regularly. I have an active profile of media mentions and features.', score: 4 },
    ]
  },
  {
    dim: 'Dimension 2 ~ Searchability',
    text: 'How would you describe your SEO knowledge ~ your understanding of how Google finds and ranks content?',
    answers: [
      { text: 'I have no idea what SEO really means in practice.', score: 0 },
      { text: 'I have heard of it but never applied it to my own content.', score: 1 },
      { text: 'I understand the basics and apply them occasionally.', score: 2 },
      { text: 'I understand it well and create content with SEO in mind.', score: 3 },
      { text: 'I have a clear SEO strategy that drives real traffic to my platforms.', score: 4 },
    ]
  },

  // DIMENSION 3: AUTHORITY (3 questions)
  {
    dim: 'Dimension 3 ~ Authority',
    text: 'Is there a place on the internet where your professional expertise, story and credentials are documented in depth ~ beyond a LinkedIn profile?',
    answers: [
      { text: 'No. My only professional presence is LinkedIn or similar.', score: 0 },
      { text: 'I have a basic bio page but it does not reflect my full expertise.', score: 1 },
      { text: 'I have a website with some depth but it is not consistently updated.', score: 2 },
      { text: 'Yes. I have an authority platform where my expertise is well documented.', score: 3 },
      { text: 'Yes, and it is Google-indexed, regularly updated and drives inbound enquiries.', score: 4 },
    ]
  },
  {
    dim: 'Dimension 3 ~ Authority',
    text: 'How consistent is your personal brand across all your digital platforms ~ same message, same visuals, same story?',
    answers: [
      { text: 'Not consistent at all. Each platform looks different and tells a different story.', score: 0 },
      { text: 'Slightly consistent. Same photo but different bios and messaging everywhere.', score: 1 },
      { text: 'Reasonably consistent but I know it needs work.', score: 2 },
      { text: 'Very consistent. My brand message is clear and coherent across platforms.', score: 3 },
      { text: 'Completely consistent. My brand is a recognised identity online.', score: 4 },
    ]
  },
  {
    dim: 'Dimension 3 ~ Authority',
    text: 'Do you currently publish original content ~ articles, newsletters, audio or video ~ under your own name or brand?',
    answers: [
      { text: 'No. I have never published my own content.', score: 0 },
      { text: 'Rarely. I post on social media occasionally but nothing regular.', score: 1 },
      { text: 'Sometimes. I publish when I feel inspired but there is no system.', score: 2 },
      { text: 'Regularly. I have a content rhythm and an audience that follows it.', score: 3 },
      { text: 'Yes, consistently. I have a content ecosystem with multiple channels.', score: 4 },
    ]
  },

  // DIMENSION 4: READINESS (3 questions)
  {
    dim: 'Dimension 4 ~ Readiness',
    text: 'How urgent do you feel it is to build or upgrade your digital presence right now?',
    answers: [
      { text: 'Not urgent. I am comfortable where I am for now.', score: 0 },
      { text: 'Somewhat. I know I need to but other things always come first.', score: 1 },
      { text: 'Fairly urgent. I am starting to feel the cost of my digital invisibility.', score: 2 },
      { text: 'Very urgent. I am ready to act and looking for the right guidance.', score: 3 },
      { text: 'Extremely urgent. I am ready to invest seriously right now.', score: 4 },
    ]
  },
  {
    dim: 'Dimension 4 ~ Readiness',
    text: 'When it comes to AI tools for your business ~ content creation, automation, research ~ where are you?',
    answers: [
      { text: 'I have never used AI tools for my work.', score: 0 },
      { text: 'I have tried ChatGPT once or twice but have not made it a habit.', score: 1 },
      { text: 'I use AI tools occasionally and am starting to see the value.', score: 2 },
      { text: 'I use AI tools regularly and they have improved my output.', score: 3 },
      { text: 'AI is embedded in my workflow and I am ahead of most in my industry.', score: 4 },
    ]
  },
  {
    dim: 'Dimension 4 ~ Readiness',
    text: 'If the right programme, community or expert showed you exactly what to do ~ how ready are you to implement?',
    answers: [
      { text: 'I need more convincing before I invest time or money.', score: 0 },
      { text: 'I am interested but my schedule and budget are tight right now.', score: 1 },
      { text: 'I am ready to start learning and will implement at my own pace.', score: 2 },
      { text: 'I am ready and will implement within days, not months.', score: 3 },
      { text: 'I am all in. Show me the path and I will run it.', score: 4 },
    ]
  },
];

// ── RESULT DEFINITIONS ────────────────────────────────────────────────
const RESULTS = {
  invisible: {
    level: 'INVISIBLE',
    icon: '🌫️',
    colour: '#4A5568',
    bgGradient: 'linear-gradient(145deg, rgba(74,85,104,0.4) 0%, rgba(13,34,71,0.85) 100%)',
    title: 'The Invisible Force',
    tagline: '"Every sovereign started somewhere. Your story is not missing ~ it simply has not been told yet. That changes today."',
    description: 'You are building something real and valuable ~ but the digital world does not know you exist yet. Your expertise, your journey, your impact is invisible to the algorithms that determine who gets found. The great news: this is the most transformative stage. Going from invisible to visible is the most powerful leap in digital sovereignty.',
    strengths: ['You are self-aware enough to take this assessment ~ that is the first act of sovereignty', 'You have a story worth telling ~ it simply needs a platform', 'You have the most to gain from the journey ahead'],
    nextStep: 'Join the She Evolves Africa community and begin with the foundations. Your newsletter access is waiting.',
    ctaPrimary: { text: '👑 Join the She Evolves Africa Community', url: 'https://thesummit.sovereignmomentum.com/invitation' },
    ctaSecondary: { text: 'Explore She Evolves Africa News', url: 'https://sheevolves.africa/news' },
    prTag: 'VORTEX-INVISIBLE',
  },
  emerging: {
    level: 'EMERGING',
    icon: '🌱',
    colour: '#2C7A7B',
    bgGradient: 'linear-gradient(145deg, rgba(44,122,123,0.35) 0%, rgba(13,34,71,0.85) 100%)',
    title: 'The Emerging Sovereign',
    tagline: '"Your roots are growing. Your presence is beginning to take shape. What you need now is not more content ~ it is structure, strategy and the right first steps."',
    description: 'You have started the journey. You have some digital presence ~ perhaps a social profile, a LinkedIn, maybe an early website. But your digital foundation is fragile. You are visible on platforms you do not own, searchable in limited contexts, and your brand story is not yet fully documented. The Emerging stage is where great things begin ~ with the right roadmap.',
    strengths: ['You have already taken action ~ most people never start', 'You understand the value of digital presence', 'You are ready to move from renting to owning your digital space'],
    nextStep: 'Access the free She Evolves Africa webinar and discover exactly what your next three moves should be.',
    ctaPrimary: { text: '▷ Access Your Free Training', url: 'https://thesummit.sovereignmomentum.com/invitation' },
    ctaSecondary: { text: 'Get Your Digital Card ~ Code: WWWSUMMIT26', url: 'https://east.africafrontlinenexus.news/welcome' },
    prTag: 'VORTEX-EMERGING',
  },
  visible: {
    level: 'VISIBLE',
    icon: '💡',
    colour: '#2B6CB0',
    bgGradient: 'linear-gradient(145deg, rgba(43,108,176,0.35) 0%, rgba(13,34,71,0.85) 100%)',
    title: 'The Visible Architect',
    tagline: '"You have built real presence. Now it is time to build authority ~ the kind that makes you the first name that comes to mind and the first result that appears on Google."',
    description: 'You have a digital presence and people can find you. But your authority is not yet fully established ~ your expertise is not deeply documented, your content is not consistently driving inbound opportunity, and your digital estate has gaps that are costing you visibility. You are at the inflection point where the right strategy can rapidly accelerate your authority.',
    strengths: ['You have proven you can build ~ now you need to systematise', 'You understand the digital landscape better than most', 'You are positioned to move into Influential altitude quickly with the right support'],
    nextStep: 'The She Evolves Africa deeper webinar series is built for exactly where you are. Start there.',
    ctaPrimary: { text: '⚡ Access the Deeper Webinar Series', url: 'https://thesummit.sovereignmomentum.com/invitation' },
    ctaSecondary: { text: 'Have Your Story Documented ~ She Evolves Africa', url: 'https://thesummit.sovereignmomentum.com/invitation' },
    prTag: 'VORTEX-VISIBLE',
  },
  influential: {
    level: 'INFLUENTIAL',
    icon: '⚡',
    colour: '#6B46C1',
    bgGradient: 'linear-gradient(145deg, rgba(107,70,193,0.35) 0%, rgba(13,34,71,0.85) 100%)',
    title: 'The Influential Leader',
    tagline: '"You have built authority. What separates Influential from Sovereign is not more content ~ it is depth of ownership, consistency of ecosystem, and the infrastructure to scale what you have built."',
    description: 'You are operating at a high level. Your expertise is recognised, your presence is established and people seek you out. But there are gaps ~ perhaps inconsistency in your content ecosystem, platforms you do not fully own, or an audience that follows you on someone else\'s infrastructure. The Mastermind is your next environment.',
    strengths: ['You have genuine authority and a track record of building it', 'You understand strategy and can implement at pace', 'You are positioned to move into Sovereign altitude ~ the gap is specific and closable'],
    nextStep: 'The She Evolves Africa Mastermind is where Influential leaders become Sovereign ones. Let\'s talk.',
    ctaPrimary: { text: '👑 Join the She Evolves Mastermind', url: 'https://thesummit.sovereignmomentum.com/invitation' },
    ctaSecondary: { text: 'Connect with the Founder Directly', url: 'https://thesummit.sovereignmomentum.com/founder' },
    prTag: 'VORTEX-INFLUENTIAL',
  },
  sovereign: {
    level: 'SOVEREIGN',
    icon: '👑',
    colour: '#C9951A',
    bgGradient: 'linear-gradient(145deg, rgba(201,149,26,0.25) 0%, rgba(13,34,71,0.88) 100%)',
    title: 'The Digital Sovereign',
    tagline: '"You have done the work. You own your digital estate. The question now is not how to be found ~ it is how to build the infrastructure that makes your impact permanent and your legacy visible."',
    description: 'You are at the pinnacle. You understand digital sovereignty deeply, your presence is established and owned, your authority is recognised and your systems are working. You are exactly who She Evolves Africa documents ~ and potentially, exactly who can help us document others. A direct consultation is where we explore what is possible at the summit level.',
    strengths: ['You are a proven digital sovereign ~ your infrastructure reflects your vision', 'You have the knowledge, systems and authority to scale further', 'You are a role model whose story belongs in the She Evolves Africa archive'],
    nextStep: 'A direct consultation with the Founder. Your digital estate deserves a strategic partner, not a beginner programme.',
    ctaPrimary: { text: '👑 Book a Founder Consultation', url: 'https://thesummit.sovereignmomentum.com/invitation' },
    ctaSecondary: { text: 'Have Your Story Featured ~ She Evolves Africa', url: 'https://thesummit.sovereignmomentum.com/invitation' },
    prTag: 'VORTEX-SOVEREIGN',
  }
};

// ── STATE ──────────────────────────────────────────────────────────────
let currentQ     = 0;
let answers      = new Array(QUESTIONS.length).fill(null);
let selectedIdx  = null;
let finalResult  = null;

const DIM_NAMES = ['Ownership','Searchability','Authority','Readiness'];

// ── HELPERS ──────────────────────────────────────────────────────────
function getLevel(total) {
  const max = QUESTIONS.length * 4;
  const pct = total / max;
  if(pct < 0.2)  return 'invisible';
  if(pct < 0.4)  return 'emerging';
  if(pct < 0.6)  return 'visible';
  if(pct < 0.8)  return 'influential';
  return 'sovereign';
}

function getDimScores() {
  // 3 questions per dimension, 4 points max each
  return [0,1,2,3].map(d => {
    const start = d * 3;
    const sum   = answers.slice(start, start+3).reduce((a,b) => a + (b||0), 0);
    return Math.round((sum / 12) * 100);
  });
}

function show(id)   { document.getElementById(id).classList.remove('hidden'); }
function hide(id)   { document.getElementById(id).classList.add('hidden'); }
function scroll2top(){ window.scrollTo({top:0,behavior:'smooth'}); }

// ── FLOATIES ────────────────────────────────────────────────────────
(function(){
  const wrap = document.getElementById('floaties');
  const syms = ['👑','✦','◆','♦','◈'];
  for(let i=0;i<22;i++){
    const el = document.createElement('div');
    el.className = 'floatie';
    el.textContent = syms[i%syms.length];
    const s = 10 + Math.random()*16;
    el.style.cssText=`left:${Math.random()*100}%;font-size:${s}px;animation-duration:${14+Math.random()*22}s;animation-delay:${Math.random()*20}s;color:rgba(201,149,26,${0.18+Math.random()*0.28});`;
    wrap.appendChild(el);
  }
})();

// ── ASSESSMENT FLOW ──────────────────────────────────────────────────
function startAssessment(){
  hide('introScreen');
  show('progressWrap');
  show('qStage');
  renderQuestion();
  scroll2top();
}

function renderQuestion(){
  const q = QUESTIONS[currentQ];
  // animate out then in
  const card = document.getElementById('qCard');
  card.style.animation = 'none';
  card.offsetHeight; // reflow
  card.style.animation = '';

  document.getElementById('qDimension').textContent = q.dim;
  document.getElementById('qNumber').textContent    = `Question ${currentQ+1} of ${QUESTIONS.length}`;
  document.getElementById('qText').textContent      = q.text;
  document.getElementById('qCount').textContent     = `Question ${currentQ+1} of ${QUESTIONS.length}`;

  // progress
  const pct = ((currentQ) / QUESTIONS.length) * 100;
  document.getElementById('progressFill').style.width = pct + '%';

  // answers
  const wrap = document.getElementById('answersWrap');
  wrap.innerHTML = '';
  const letters = ['A','B','C','D','E'];
  q.answers.forEach((ans, i) => {
    const btn = document.createElement('button');
    btn.className = 'answer-btn' + (answers[currentQ] === ans.score && selectedIdx === i ? ' selected' : '');
    btn.innerHTML = `<span class="a-letter">${letters[i]}</span><span class="a-text">${ans.text}</span>`;
    btn.onclick = () => selectAnswer(i, ans.score, btn);
    wrap.appendChild(btn);
  });

  // next button
  const nextBtn = document.getElementById('nextBtn');
  nextBtn.textContent = currentQ < QUESTIONS.length - 1 ? 'Continue →' : 'See My Result 👑';
  if(answers[currentQ] !== null){
    nextBtn.classList.add('active');
    selectedIdx = answers[currentQ]; // restore visual
  } else {
    nextBtn.classList.remove('active');
    selectedIdx = null;
  }
}

function selectAnswer(idx, score, btn){
  document.querySelectorAll('.answer-btn').forEach(b => b.classList.remove('selected'));
  btn.classList.add('selected');
  answers[currentQ] = score;
  selectedIdx = idx;
  document.getElementById('nextBtn').classList.add('active');
}

function nextQuestion(){
  if(answers[currentQ] === null) return;
  if(currentQ < QUESTIONS.length - 1){
    currentQ++;
    renderQuestion();
    scroll2top();
  } else {
    // all done
    hide('qStage');
    hide('progressWrap');
    show('captureScreen');
    scroll2top();
  }
}

// ── RESULT ────────────────────────────────────────────────────────────
function revealResult(){
  hide('captureScreen');
  const total   = answers.reduce((a,b) => a + (b||0), 0);
  const level   = getLevel(total);
  const data    = RESULTS[level];
  const dimPcts = getDimScores();
  const scorePct= Math.round((total / (QUESTIONS.length * 4)) * 100);
  finalResult   = { level, data, scorePct };

  // Hero
  const hero = document.getElementById('resultHero');
  hero.style.background = data.bgGradient;
  hero.style.border = `1px solid ${data.colour}55`;

  const badge = document.getElementById('resultBadge');
  badge.textContent = `ALTITUDE LEVEL ~ ${data.level}`;
  badge.style.background = data.colour + '22';
  badge.style.border = `1px solid ${data.colour}66`;
  badge.style.color  = data.colour;

  document.getElementById('resultCrown').textContent = data.icon;
  document.getElementById('resultTitle').textContent = data.title;
  document.getElementById('resultTitle').style.color = data.colour;
  document.getElementById('resultTagline').textContent = data.tagline;

  document.getElementById('scoreDisplay').textContent = scorePct + '%';
  const mf = document.getElementById('meterFill');
  mf.style.background = `linear-gradient(90deg, var(--navy-mid), ${data.colour})`;
  setTimeout(() => mf.style.width = scorePct + '%', 100);

  // Dimension scores
  const dimWrap = document.getElementById('dimScores');
  dimWrap.innerHTML = '';
  DIM_NAMES.forEach((name, i) => {
    const card = document.createElement('div');
    card.className = 'dim-card';
    card.innerHTML = `
      <span class="dim-name">${name}</span>
      <div style="display:flex;align-items:center;gap:0.5rem;margin-bottom:0.3rem">
        <span style="font-size:0.85rem;font-weight:600;color:${data.colour}">${dimPcts[i]}%</span>
      </div>
      <div class="dim-bar-wrap"><div class="dim-bar" style="background:${data.colour};width:0%" data-w="${dimPcts[i]}%"></div></div>
    `;
    dimWrap.appendChild(card);
  });
  setTimeout(() => {
    document.querySelectorAll('.dim-bar').forEach(b => b.style.width = b.dataset.w);
  }, 200);

  // Body
  const body = document.getElementById('resultBody');
  body.innerHTML = `
    <h3>What This Means For You</h3>
    <p>${data.description}</p>
    <h3>Your Strengths at This Altitude</h3>
    <ul>${data.strengths.map(s => `<li>${s}</li>`).join('')}</ul>
    <br>
    <p style="font-size:0.78rem;color:var(--gold2);font-style:italic">👑 Your Next Step: ${data.nextStep}</p>
  `;

  // CTAs
  const cta = document.getElementById('resultCta');
  cta.innerHTML = `
    <a href="${data.ctaPrimary.url}" class="r-btn r-btn-primary" style="background:linear-gradient(135deg,${data.colour} 0%,${data.colour}99 100%)">${data.ctaPrimary.text}</a>
    <a href="${data.ctaSecondary.url}" class="r-btn r-btn-secondary">${data.ctaSecondary.text}</a>
    <a href="https://thesummit.sovereignmomentum.com/your-journey?altitude=${altKey}" class="r-btn r-btn-ghost">→ See Your Complete Sovereign Portrait</a>
  `;

  show('resultScreen');
  scroll2top();
  // animate meter
  setTimeout(() => document.getElementById('progressFill').style.width = '100%', 100);
}

// ── SHARE ──────────────────────────────────────────────────────────────
function shareResult(){
  if(!finalResult) return;
  const text = `I just took the Vortex Altitude Assessment by She Evolves Africa and discovered I am at the ${finalResult.data.level} altitude ~ ${finalResult.scorePct}% Digital Sovereignty Score.\n\nDiscover your altitude: https://thesummit.sovereignmomentum.com/vortex\n\n👑 She Evolves Africa ~ Voices. Visions. Legacy.`;
  navigator.clipboard.writeText(text).then(() => {
    const btn = document.querySelector('.share-btn');
    btn.textContent = 'Copied! ✓';
    setTimeout(() => btn.textContent = 'Copy Result', 2500);
  });
}

function resetAll(){
  currentQ = 0;
  answers  = new Array(QUESTIONS.length).fill(null);
  selectedIdx = null;
  finalResult = null;
  hide('resultScreen');
  hide('qStage');
  hide('progressWrap');
  hide('captureScreen');
  document.getElementById('progressFill').style.width = '0%';
  show('introScreen');
  scroll2top();
}
</script>
</body>
</html>","embed":""}
š
She Evolves Africa ~ Vortex Altitude
Where Do You Really Stand?
LinkedIn profiles glow. Follower counts climb. But real digital sovereignty ~ the kind you own, the kind Google indexes, the kind that outlives any platform ~ tells a different story. Discover your true altitude.
Invisible
ā
Emerging
ā
Visible
ā
Influential
ā
Sovereign
Your Altitude Assessment
Question 1 of 12
š
The Vortex Altitude
The Vortex Altitude
Assessment
12 questions. 4 dimensions. One honest result. No vanity metrics. No flattery. Just the truth about where you stand ~ and a clear path to where you deserve to be.
š«ļø
Invisible
The start ~ and a powerful place to begin
š±
Emerging
Digital foundations being laid
š”
Visible
Present online ~ building authority
ā”
Influential
Authority established ~ scaling presence
š
Sovereign
Full digital ownership ~ the pinnacle
Almost there š
Your altitude result is ready. Enter your details to receive your personalised next steps ~ and to be added to the right She Evolves Africa community for where you are right now.
Skip and see my result ā
Digital Sovereignty Score
Share your altitude š
Copy your result and share it ~ invite another woman to discover hers
āŗ Retake the assessment
š She Evolves Africa ~ Voices. Visions. Legacy. ~ sheevolves.africa