@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@400;600;700;800&family=Lexend:wght@400;600&display=swap");
@import url("https://cdn.jsdelivr.net/npm/open-dyslexic@1.0.3/open-dyslexic-regular.min.css");

h1, h2, h3, .intro-title, .feature-title, .card-title, .q-title, .result-score-val {
  font-family: "Manrope", system-ui, sans-serif;
}

/* ============================================================
   RESET & TOKENS
   ============================================================ */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  /* â”€â”€ APP CHROME â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     Background, card, borders, text, and the main accent color.
     These affect the overall shell of the app.                        */
  --bg: #f2f8fb; /* page background                        */
  --card: #fff; /* card / panel background                */
  --border: #bcdae1be; /* default border color                   */
  --shadow: 0 16px 40px rgba(0, 0, 0, 0.04); /* Modern flat shadow */

  /* â”€â”€ TYPOGRAPHY â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     Primary text, muted/secondary text.                               */
  --text: #1e3a47; /* headings and body copy                 */
  --muted: #5a7e90; /* secondary text, labels, hints          */

  /* â”€â”€ ACCENT (buttons, links, highlights) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     Used on primary buttons, active states, section toggles, etc.    */
  --accent: #3fa8be; /* main accent                            */
  --accent2: #5bbecf; /* lighter accent (hover states)          */
  --accent-bg: #eaf7fa; /* very light accent tint (backgrounds)   */

  /* â”€â”€ SECONDARY ACCENT (used sparingly) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     Used on RSD insight card header, and a few highlight moments.    */
  --pink: #d4649a;
  --pink-bg: #fce9f4;

  /* â”€â”€ DIMENSION BARS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     Each of the 5 ADHD dimensions has its own color.
     col  = bar fill + percentage text
     bg   = badge pill background
     tc   = badge pill text                                            */
  --dim-i-col: #6fc2d1; /* Inattention */
  --dim-i-bg: #eaf7fa;
  --dim-i-tc: #2a7f8e;

  --dim-h-col: #c7c86a; /* Hyperactivity */
  --dim-h-bg: #f7f8e6;
  --dim-h-tc: #707421;

  --dim-p-col: #e7a96c; /* Impulsivity */
  --dim-p-bg: #fbf2e6;
  --dim-p-tc: #9b5b20;

  --dim-e-col: #d98a8a; /* Emotional Reg. */
  --dim-e-bg: #faecec;
  --dim-e-tc: #944242;

  --dim-o-col: #7b95d9; /* Executive Fn. */
  --dim-o-bg: #eef1fb;
  --dim-o-tc: #3c4fa3;

  /* â”€â”€ SCORE RING & TIER COLORS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     The ring and score label color changes based on overall score.
     Tiers go from lowest score â†’ highest score.                       */
  --tier-1: #8adaaa; /* Very few traits noticed   (0â€“19)       */
  --tier-2: #9dd8e4; /* A few traits noticed      (20â€“34)      */
  --tier-3: #d8e070; /* Moderate pattern          (35â€“49)      */
  --tier-4: #f0b878; /* Elevated trait pattern    (50â€“64)      */
  --tier-5: #f09080; /* Strong trait pattern      (65â€“79)      */
  --tier-6: #e87878; /* Very strong trait pattern (80â€“100)     */

  /* â”€â”€ SPECTRUM BAR â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     The gradient bar showing None â†’ Strong severity.
     Edit these 5 stops to change the spectrum colors.                */
  --spectrum-1: #8fd6a7; /* None */
  --spectrum-2: #cddc86; /* Mild */
  --spectrum-3: #f0c184; /* Moderate */
  --spectrum-4: #e9a184; /* Elevated */
  --spectrum-5: #de7f7f; /* Strong */

  /* â”€â”€ ANSWER OPTIONS (quiz rings) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     The 5 answer circles: Never â†’ Very Often.
     Each has a border color and a selected state background.         */
  --ans-1-border: #86efac; /* Never      ring border                 */
  --ans-2-border: #bbf7d0; /* Rarely     ring border                 */
  --ans-3-border: #cbd5e1; /* Sometimes  ring border                 */
  --ans-4-border: #fca5a5; /* Often      ring border                 */
  --ans-5-border: #f87171; /* Very Often ring border                 */

  --ans-1-sel-bg: #c6f6d5; /* Never      selected background         */
  --ans-1-sel-bd: #52c07a; /* Never      selected border             */
  --ans-2-sel-bg: #dcfce7; /* Rarely     selected background         */
  --ans-2-sel-bd: #86d8a0; /* Rarely     selected border             */
  --ans-3-sel-bg: #e9ecef; /* Sometimes  selected background         */
  --ans-3-sel-bd: #adb5bd; /* Sometimes  selected border             */
  --ans-4-sel-bg: #fee2e2; /* Often      selected background         */
  --ans-4-sel-bd: #f07070; /* Often      selected border             */
  --ans-5-sel-bg: #fecaca; /* Very Often selected background         */
  --ans-5-sel-bd: #e85050; /* Very Often selected border             */

  --ans-1-label: #3aac78; /* Never      label text color            */
  --ans-2-label: #68c48e; /* Rarely     label text color            */
  --ans-3-label: #8faebb; /* Sometimes  label text color            */
  --ans-4-label: #c07070; /* Often      label text color            */
  --ans-5-label: #d04040; /* Very Often label text color            */

  /* â”€â”€ INSIGHT CARDS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     The colored cards in the "What This Means" section.              */
  --ins-teal-bg: #eaf7fa; /* Teal card background                   */
  --ins-teal-bd: #b0dceb; /* Teal card border                       */
  --ins-teal-h: #3fa8be; /* Teal card heading                      */

  --ins-pink-bg: #fce9f4; /* Pink card background  (RSD)            */
  --ins-pink-bd: #e8c0d8; /* Pink card border                       */
  --ins-pink-h: #d4649a; /* Pink card heading                      */

  --ins-yellow-bg: #fffdf0; /* Yellow card background (Sleep)         */
  --ins-yellow-bd: #e8d888; /* Yellow card border                     */
  --ins-yellow-h: #8a6810; /* Yellow card heading                    */

  --ins-purple-bg: #f5f0ff; /* Purple card background (Hyperfocus)    */
  --ins-purple-bd: #ccc0f0; /* Purple card border                     */
  --ins-purple-h: #5c3aa0; /* Purple card heading                    */

  --ins-green-bg: #efffef; /* Green card background  (Task init)     */
  --ins-green-bd: #a8d8b0; /* Green card border                      */
  --ins-green-h: #1e6e3c; /* Green card heading                     */

  /* â”€â”€ BORDER RADIUS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     Controls how rounded corners are throughout the app.             */
  --r: 22px; /* large radius (cards, modals)           */
  --r-sm: 14px; /* small radius (sections, pills)         */

  font-family: "Lexend", system-ui, sans-serif;
  --font-ui: "Lexend", system-ui, sans-serif;
  --font-reading: "Lexend", system-ui, sans-serif;
}
html {
  font-size: 16px;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
html::-webkit-scrollbar {
  display: none;
}
body {
  font-family: var(--font-ui);
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
body::-webkit-scrollbar {
  display: none;
}

/* ============================================================
   LAYOUT
   ============================================================ */
.shell {
  width: 100%;
  max-width: 760px;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  padding: 0 16px;
}

/* â”€â”€ APP NAV BAR (replaces topbar) â”€â”€ */
.app-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 0 6px;
  flex-shrink: 0;
}
.app-nav-home {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.04em;
  padding: 5px 10px;
  border-radius: 9px;
  border: 1.5px solid transparent;
  transition:
    background 0.15s,
    color 0.15s,
    border-color 0.15s;
}
.app-nav-home:hover {
  background: var(--accent-bg);
  color: var(--accent);
  border-color: var(--border);
}
.app-nav-home svg {
  flex-shrink: 0;
}
.app-nav-label {
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  opacity: 0.7;
}

.card {
  background: var(--card);
  border-radius: var(--r);
  box-shadow: var(--shadow);
  border: 1.5px solid var(--border);
  padding: 24px 46px;
  position: relative;
  transition: box-shadow 0.3s, min-height 0.25s ease-out;
  flex: 1 0 auto;
}
.card.q-card {
  padding: 24px 46px;
  display: flex;
  flex-direction: column;
  min-height: 580px;
}
.card.q-card #app {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.card.q-card .q-img {
  width: auto;
  max-width: 100%;
  max-height: 180px;
  object-fit: contain;
  margin: 6px auto 12px;
  display: block;
}
.card.q-card .q-context {
  min-height: 56px;
  display: flex;
  align-items: center;
}
.q-bottom {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  gap: 0;
}

@media (max-width: 520px) {
  .card {
    padding: 22px 18px;
  }
  .card.q-card {
    padding: 18px 16px;
    min-height: auto;
  }
  .card.q-card .q-img {
    max-height: 140px;
  }
}

/* ============================================================
   TRANSITIONS
   ============================================================ */
#app {
  will-change: opacity, transform;
  opacity: 1;
  transform: translateZ(0);
  transition:
    opacity 0.22s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.22s cubic-bezier(0.4, 0, 0.2, 1);
}
#app.t-out {
  opacity: 0 !important;
  transform: translateX(10px) translateZ(0) !important;
  transition:
    opacity 0.16s ease-in,
    transform 0.16s ease-in !important;
}
#app.t-out-r {
  opacity: 0 !important;
  transform: translateX(-10px) translateZ(0) !important;
  transition:
    opacity 0.16s ease-in,
    transform 0.16s ease-in !important;
}
#app.t-out-fade {
  opacity: 0 !important;
  transform: translateY(4px) translateZ(0) !important;
  transition:
    opacity 0.16s ease-in,
    transform 0.16s ease-in !important;
}
#app.t-in {
  opacity: 1;
  transform: translateZ(0);
}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}
@keyframes selPop {
  0%,
  100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.18);
  }
}
@keyframes popIn {
  from {
    opacity: 0;
    transform: scale(0.4);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes countUp {
  from {
    opacity: 0;
    transform: translateY(8px) scale(0.9);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes _mFadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes _mSlideUp {
  from {
    opacity: 0;
    transform: translateY(18px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* ============================================================
   PROGRESS BAR
   ============================================================ */
.prog-wrap {
  margin-bottom: 16px;
}
.prog-top {
  display: flex;
  justify-content: space-between;
  font-size: 11.5px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 8px;
}
.prog-top strong, .prog-pct {
  color: var(--accent);
  font-weight: 800;
}
.prog-track {
  height: 8px;
  background: var(--bg);
  border-radius: 99px;
  overflow: hidden;
  box-shadow: inset 0 1px 3px rgba(0,0,0,0.04);
}
.prog-fill {
  height: 100%;
  border-radius: 99px;
  transition: width 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
  background: linear-gradient(90deg, var(--accent2), var(--accent));
  box-shadow: 0 1px 3px rgba(63, 168, 190, 0.2);
}

/* ============================================================
   BADGE
   ============================================================ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 13px;
  border-radius: 99px;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.b-i {
  background: #ddf0fb;
  color: #206e8a;
}
.b-h {
  background: #fef5dc;
  color: #8a5a10;
}
.b-p {
  background: #fce9f4;
  color: #943068;
}
.b-e {
  background: #f0ebff;
  color: #5c3aa0;
}
.b-o {
  background: #efffef;
  color: #1e6e3c;
}

/* ============================================================
   INTRO  (redesigned)
   ============================================================ */

/* ── Hero block ── */
.intro-hero {
  text-align: center;
  margin-bottom: 24px;
}
.intro-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--accent-bg);
  border: 1.5px solid var(--border);
  border-radius: 99px;
  padding: 5px 16px 5px 12px;
  font-size: 11px;
  font-weight: 800;
  color: var(--accent);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.intro-badge-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
  animation: badgePulse 2.4s ease-in-out infinite;
}
@keyframes badgePulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.5; transform: scale(0.75); }
}
.intro-title {
  font-size: 32px;
  font-weight: 900;
  color: var(--text);
  margin-bottom: 8px;
  line-height: 1.15;
  letter-spacing: -0.01em;
}
.intro-title span {
  color: var(--accent);
}
.intro-sub {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--muted);
  line-height: 1.6;
  max-width: 500px;
  margin: 0 auto;
}

/* ── Check list ── */
.intro-checks {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 16px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  overflow: hidden;
}
.intro-check-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  border-bottom: 1px solid var(--border);
  background: #fff;
  transition: background 0.15s;
}
.intro-check-item:last-child {
  border-bottom: none;
}
.intro-check-item:hover {
  background: var(--accent-bg);
}
.intro-check-icon {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* ── Stat cards ── */
.intro-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 16px;
}
.intro-stat {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  padding: 12px;
  transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s;
}
.intro-stat:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 16px rgba(63,168,190,0.1);
  transform: translateY(-2px);
}
.intro-stat-icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent);
  border-radius: 12px;
}
.intro-stat-icon .material-symbols-outlined {
  font-size: 22px;
  color: #fff;
  font-variation-settings: 'wght' 400;
}
.intro-stat-title {
  font-size: 12.5px;
  font-weight: 900;
  color: var(--text);
  margin-bottom: 2px;
}
.intro-stat-desc {
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  line-height: 1.45;
}

/* ── Notice ── */
.intro-notice {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: #fffdf0;
  border: 1.5px solid #f5e68a;
  border-radius: var(--r-sm);
  padding: 12px 14px;
  margin-bottom: 16px;
}
.intro-notice-icon {
  flex-shrink: 0;
  margin-top: 1px;
}
.intro-notice-icon .material-symbols-outlined {
  font-size: 22px;
  color: #a07820;
  font-variation-settings: 'wght' 500;
}
.intro-notice-text {
  font-size: 12px;
  font-weight: 600;
  color: #8a6810;
  line-height: 1.5;
}
.intro-notice-text strong {
  font-weight: 900;
  color: #7a5c10;
}

@media (max-width: 520px) {
  .intro-title { font-size: 27px; }
  .intro-stats { grid-template-columns: 1fr; }
}

/* Keep old classes in case anything else references them */
.notice {
  background: #fffdf0;
  border: 1.5px solid #f5e68a;
  border-radius: var(--r-sm);
  padding: 12px 15px;
  font-size: 12px;
  font-weight: 700;
  color: #8a6810;
  line-height: 1.65;
  margin-bottom: 22px;
}

/* ============================================================
   BUTTON SYSTEM
   Shared props via grouped selectors â€” zero HTML changes needed
   ============================================================ */

/* Shared base for all interactive buttons */
.btn-start,
.btn-next,
.btn-back,
.btn-unlock,
.btn-unlock-result,
.btn-save,
.btn-retake,
.btn-share,
.share-copy-btn,
.share-dl-btn,
.share-btn-item,
.share-modal-close,
.pstep-back {
  font-family: inherit;
  cursor: pointer;
  border-radius: var(--r-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Primary teal â€” start, next, unlock, unlock-result */
.btn-start,
.btn-next,
.btn-unlock,
.btn-unlock-result {
  border: none;
  background: var(--accent);
  color: #fff;
  font-weight: 900;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.08);
  transition:
    background 0.2s,
    transform 0.15s,
    box-shadow 0.2s;
}
.btn-start:hover,
.btn-next:hover:not(:disabled),
.btn-unlock:hover,
.btn-unlock-result:hover {
  background: var(--accent2);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
}
.btn-start:active,
.btn-next:active:not(:disabled),
.btn-unlock:active,
.btn-unlock-result:active {
  transform: scale(0.97);
}

/* Primary disabled states */
.btn-unlock:disabled,
.btn-unlock-result:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}
.btn-next:disabled {
  opacity: 0.28;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}

/* Size specifics */
.btn-start {
  width: 100%;
  padding: 14px;
  font-size: 15px;
  gap: 9px;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.08);
}
.btn-next {
  padding: 10px 26px;
  font-size: 15px;
  font-weight: 800;
  gap: 7px;
}
.btn-unlock {
  width: 100%;
  padding: 15px;
  font-size: 15px;
  gap: 8px;
}
.btn-unlock-result {
  width: 100%;
  padding: 14px;
  font-size: 15px;
  gap: 8px;
  margin-bottom: 10px;
  box-shadow: none;
  transition: background 0.2s;
}

/* Ghost outline â€” back, modal-close */
.btn-back,
.share-modal-close {
  border: 2px solid var(--border);
  background: transparent;
  color: var(--muted);
  transition:
    border-color 0.18s,
    color 0.18s,
    transform 0.1s;
}
.btn-back {
  padding: 9px 18px;
  font-size: 14px;
  font-weight: 700;
}
.btn-back:hover,
.share-modal-close:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.btn-back:active {
  transform: scale(0.96);
}
.btn-back:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.share-modal-close {
  width: 100%;
  padding: 10px;
  border-width: 1.5px;
  font-size: 13px;
  font-weight: 700;
  transition:
    border-color 0.15s,
    color 0.15s;
}

/* Result actions row */
.actions {
  display: flex;
  gap: 10px;
  margin-top: 10px;
  flex-wrap: wrap;
}

.btn-share {
  flex: 2;
  min-width: 120px;
  padding: 14px;
  border: none;
  background: var(--accent);
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  gap: 7px;
  box-shadow: 0 4px 16px rgba(102, 126, 234, 0.38);
  transition:
    opacity 0.15s,
    transform 0.12s;
}
.btn-share:hover {
  opacity: 0.88;
  transform: translateY(-1px);
}
.btn-share:active {
  transform: scale(0.97);
}

.btn-retake {
  flex: 1;
  min-width: 120px;
  padding: 14px;
  border: 1px solid var(--accent);
  background: transparent;
  font-size: 14px;
  font-weight: 800;
  color: var(--muted);
  gap: 6px;
  transition:
    border-color 0.15s,
    color 0.15s,
    transform 0.12s;
}
.btn-retake:hover {
  border-color: var(--accent);
  color: var(--accent);
  transform: translateY(-1px);
}
.btn-retake:active {
  transform: scale(0.97);
}

.btn-save {
  flex: 1;
  min-width: 120px;
  padding: 13px;
  border: 2px solid var(--accent);
  background: transparent;
  font-size: 14px;
  font-weight: 800;
  color: var(--muted);
  gap: 6px;
  transition:
    border-color 0.15s,
    color 0.15s,
    transform 0.12s;
}
.btn-save:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.btn-save:active {
  transform: scale(0.97);
}

.actions-secondary {
  margin-top: 10px;
}
.actions-secondary .btn-save {
  width: 100%;
  flex: unset;
  min-width: unset;
  padding: 12px;
  border-width: 1.5px;
  font-size: 13px;
  font-weight: 700;
}
.actions-secondary .btn-save:hover {
  border-color: var(--accent);
  color: var(--accent);
}

@media (max-width: 520px) {
  .actions {
    flex-direction: column;
  }
  .btn-save,
  .btn-retake,
  .btn-share {
    flex: unset;
    width: 100%;
    min-width: unset;
  }
}

/* Share modal buttons */
.share-copy-btn {
  padding: 9px 14px;
  border: none;
  background: var(--accent);
  font-size: 12px;
  font-weight: 800;
  color: #fff;
  white-space: nowrap;
  transition: background 0.15s;
}
.share-copy-btn:hover {
  background: var(--accent2);
}
.share-dl-btn {
  width: 100%;
  padding: 11px;
  border: none;
  background: var(--text);
  font-size: 13px;
  font-weight: 800;
  color: #fff;
  gap: 7px;
  margin-bottom: 10px;
  transition: opacity 0.15s;
}
.share-dl-btn:hover {
  opacity: 0.85;
}
.share-dl-btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}
.share-btns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 10px;
}
.share-btn-item {
  padding: 10px 8px;
  border: 1.5px solid var(--border);
  background: #fff;
  font-size: 12.5px;
  font-weight: 800;
  color: var(--text);
  gap: 6px;
  transition:
    border-color 0.15s,
    background 0.15s;
}
.share-btn-item:hover {
  border-color: var(--accent);
  background: var(--accent-bg);
}

/* ============================================================
   QUESTION ELEMENTS
   ============================================================ */
.q-num {
  font-size: 11px;
  font-weight: 800;
  color: var(--muted);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.q-text {
  font-size: 21px;
  font-weight: 800;
  line-height: 1.45;
  color: var(--text);
  margin-bottom: 10px;
}
@media (max-width: 520px) {
  .q-text {
    font-size: 18.5px;
  }
}
.q-img {
  display: block;
  width: 100%;
  max-width: 520px;
  height: auto;
  border-radius: 16px;
  margin: 4px 0 10px;
}
.q-context {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.6;
  margin-bottom: 24px;
  padding: 10px 14px;
  background: var(--bg);
  border-radius: 12px;
  border-left: 4px solid var(--accent);
  box-shadow: 0 2px 8px rgba(0,0,0,0.03);
}

/* ============================================================
   SCALE CIRCLES
   ============================================================ */
.scale-outer {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.scale-hint {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 16px;
  text-align: center;
}
.circles-group {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 18px;
}
.c-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  cursor: pointer;
  position: relative;
  -webkit-tap-highlight-color: transparent;
}
.c-ring {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 3px solid;
  background: var(--bg);
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition:
    transform 0.18s cubic-bezier(0.34, 1.56, 0.64, 1),
    background 0.15s,
    box-shadow 0.15s;
}
.c-ring::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: var(--ripple, #aaa);
  opacity: 0;
  transform: scale(0);
  transition:
    transform 0.4s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.4s;
}
.c-ring.ripple::after {
  transform: scale(2.5);
  opacity: 0.18;
  transition:
    transform 0s,
    opacity 0s;
}
.c-ring:hover {
  transform: scale(1.1);
}
.c-ring:focus {
  outline: none;
}
.c-ring:active {
  transform: scale(0.93);
}
.c-check {
  position: absolute;
  opacity: 0;
  transform: scale(0);
  transition:
    opacity 0.18s,
    transform 0.22s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.c-ring.sel .c-check {
  opacity: 1;
  transform: scale(1);
}
.c-ring.sel {
  animation: selPop 0.22s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.c-wrap:nth-child(1) .c-ring {
  border-color: var(--ans-1-border);
  --ripple: var(--ans-1-border);
}
.c-wrap:nth-child(2) .c-ring {
  border-color: var(--ans-2-border);
  --ripple: var(--ans-2-border);
}
.c-wrap:nth-child(3) .c-ring {
  border-color: var(--ans-3-border);
  --ripple: var(--ans-3-border);
}
.c-wrap:nth-child(4) .c-ring {
  border-color: var(--ans-4-border);
  --ripple: var(--ans-4-border);
}
.c-wrap:nth-child(5) .c-ring {
  border-color: var(--ans-5-border);
  --ripple: var(--ans-5-border);
}
.c-wrap:nth-child(1) .c-ring.sel {
  background: var(--ans-1-sel-bg);
  border-color: var(--ans-1-sel-bd);
  box-shadow: 0 0 0 5px rgba(134, 239, 172, 0.28);
}
.c-wrap:nth-child(2) .c-ring.sel {
  background: var(--ans-2-sel-bg);
  border-color: var(--ans-2-sel-bd);
  box-shadow: 0 0 0 5px rgba(187, 247, 208, 0.28);
}
.c-wrap:nth-child(3) .c-ring.sel {
  background: var(--ans-3-sel-bg);
  border-color: var(--ans-3-sel-bd);
  box-shadow: 0 0 0 5px rgba(173, 181, 189, 0.28);
}
.c-wrap:nth-child(4) .c-ring.sel {
  background: var(--ans-4-sel-bg);
  border-color: var(--ans-4-sel-bd);
  box-shadow: 0 0 0 5px rgba(252, 165, 165, 0.28);
}
.c-wrap:nth-child(5) .c-ring.sel {
  background: var(--ans-5-sel-bg);
  border-color: var(--ans-5-sel-bd);
  box-shadow: 0 0 0 5px rgba(248, 113, 113, 0.28);
}

.c-label {
  font-size: 9.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  text-align: center;
  line-height: 1.2;
  max-width: 52px;
  transition: color 0.15s;
}
.c-wrap:nth-child(1) .c-label {
  color: var(--ans-1-label);
}
.c-wrap:nth-child(2) .c-label {
  color: var(--ans-2-label);
}
.c-wrap:nth-child(3) .c-label {
  color: var(--ans-3-label);
}
.c-wrap:nth-child(4) .c-label {
  color: var(--ans-4-label);
}
.c-wrap:nth-child(5) .c-label {
  color: var(--ans-5-label);
}
.c-wrap.active .c-label {
  font-weight: 900;
}

@media (max-width: 480px) {
  .c-ring {
    width: 44px;
    height: 44px;
  }
  .circles-group {
    gap: 10px;
  }
  .c-label {
    font-size: 8px;
    max-width: 44px;
  }
}

/* ============================================================
   NAV
   ============================================================ */
.key-hint {
  text-align: center;
  font-size: 10px;
  font-weight: 700;
  color: var(--muted);
  opacity: 0.45;
  margin-top: 6px;
  letter-spacing: 0.04em;
}
.q-bottom .scale-outer {
  margin-bottom: 20px;
  margin-top: 16px;
}
.q-bottom .nav {
  margin-top: 0;
}
.nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: auto;
  padding-top: 14px;
  padding-bottom: 4px;
  border-top: 1px solid var(--border);
  gap: 12px;
}

/* ============================================================
   COMPLETION
   ============================================================ */
.complete-wrap {
  text-align: center;
  padding: 10px 0;
}
.complete-emoji {
  font-size: 62px;
  margin-bottom: 16px;
  display: block;
  animation: popIn 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
.complete-title {
  font-size: 24px;
  font-weight: 900;
  color: var(--text);
  margin-bottom: 8px;
}
.complete-sub {
  font-size: 14px;
  font-weight: 700;
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 28px;
}
.calc-bar-wrap {
  background: var(--accent-bg);
  border-radius: 99px;
  height: 10px;
  overflow: hidden;
  margin-bottom: 10px;
}
.calc-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent2), var(--accent));
  border-radius: 99px;
  width: 0%;
  transition: width 0.12s;
}
.calc-label {
  font-size: 11px;
  font-weight: 800;
  color: var(--accent);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
}

/* ============================================================
   EMAIL GATE (pre-result)
   ============================================================ */
.gate-wrap {
  text-align: center;
}
.gate-title {
  font-size: 21px;
  font-weight: 900;
  color: var(--text);
  margin-bottom: 8px;
}
.gate-sub {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 22px;
}
.partial-preview {
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  padding: 18px;
  margin-bottom: 22px;
  position: relative;
  overflow: hidden;
}
.partial-preview::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 80px;
  background: linear-gradient(transparent, #fff);
}
.preview-score-row {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 14px;
}
.preview-score-num {
  font-size: 48px;
  font-weight: 900;
  line-height: 1;
}
.preview-score-label {
  font-size: 14px;
  font-weight: 900;
  margin-bottom: 4px;
}
.preview-score-desc {
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  line-height: 1.5;
}
.preview-bars {
  opacity: 0.45;
  filter: blur(2px);
}
.hero-chart {
  display: flex;
  flex-direction: column;
  gap: 7px;
  padding: 14px 18px 16px;
}
.hc-row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.hc-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  width: 96px;
  flex-shrink: 0;
  font-family: var(--font-ui);
  text-align: right;
  line-height: 1.2;
}
.hc-track {
  flex: 1;
  height: 24px;
  background: #eef1f5;
  border-radius: 6px;
  overflow: hidden;
}
.hc-bar {
  height: 100%;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-width: 44px;
  transition: width 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}
.hc-val {
  font-size: 12px;
  font-weight: 800;
  width: 36px;
  text-align: right;
  flex-shrink: 0;
  font-family: var(--font-ui);
  letter-spacing: .01em;
  white-space: nowrap;
}
.lock-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--accent-bg);
  border: 1.5px solid var(--border);
  border-radius: 99px;
  padding: 5px 14px;
  font-size: 11.5px;
  font-weight: 800;
  color: var(--accent);
  margin-bottom: 16px;
}

/* Shared input style â€” one definition covers all three */
.email-input,
.gate-email-input,
.gate-name-row input {
  width: 100%;
  padding: 13px 16px;
  border-radius: var(--r-sm);
  border: 2px solid var(--border);
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  background: #fff;
  outline: none;
  box-sizing: border-box;
  display: block;
  transition:
    border-color 0.18s,
    box-shadow 0.18s;
}
.email-input {
  padding: 14px 18px;
  font-size: 15px;
} /* slightly larger on gate screen */
.email-input:focus,
.gate-email-input:focus,
.gate-name-row input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(91, 190, 207, 0.15);
}
.email-input.err,
.gate-email-input.err {
  border-color: #f08080;
}
.email-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.email-err,
.gate-err {
  font-size: 12px;
  font-weight: 700;
  color: #c05050;
  display: none;
  text-align: left;
  margin-bottom: 8px;
}
.email-privacy,
.gate-privacy {
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
  text-align: center;
  line-height: 1.6;
  margin-top: 10px;
}

/* ============================================================
   RESULT GATE
   ============================================================ */
.gated-section {
  position: relative;
  overflow: hidden;
  max-height: 220px;
}
.gated-section::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 140px;
  background: linear-gradient(transparent, #fff);
  pointer-events: none;
}
.gated-blur {
  filter: blur(5px);
  opacity: 0.4;
  pointer-events: none;
  user-select: none;
  padding: 4px 0 16px;
}
.result-gate-wrap {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  margin-top: 8px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0,0,0,0.06);
}
.gate-inner {
  padding: 24px 22px 20px;
}
.gate-eyebrow {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--muted);
  font-family: var(--font-ui);
  margin-bottom: 12px;
  opacity: .7;
}
.gate-title {
  font-size: 20px;
  font-weight: 900;
  color: var(--text);
  line-height: 1.3;
  margin-bottom: 8px;
  font-family: var(--font-ui);
}
.gate-sub {
  font-size: 13px;
  font-weight: 400;
  color: var(--muted);
  line-height: 1.6;
  margin-bottom: 18px;
  font-family: var(--font-reading);
}
.gate-benefits-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 20px;
}
.gate-benefit {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: #f8fafb;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 12px;
}
.gate-benefit-icon {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.gate-benefit-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
  font-family: var(--font-ui);
  margin-bottom: 2px;
}
.gate-benefit-desc {
  font-size: 11px;
  font-weight: 400;
  color: var(--muted);
  font-family: var(--font-reading);
  line-height: 1.4;
}
.gate-form {
  position: relative;
}
.gate-email-input {
  margin-bottom: 10px;
}
.gate-newsletter-opt {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--accent-bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 12px;
  cursor: pointer;
}
.gate-newsletter-opt input[type="checkbox"] {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  accent-color: var(--accent);
  cursor: pointer;
}
.gate-newsletter-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.gate-newsletter-label {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--text);
  font-family: var(--font-ui);
}
.gate-newsletter-desc {
  font-size: 11.5px;
  font-weight: 400;
  color: var(--muted);
  font-family: var(--font-reading);
  line-height: 1.5;
}
.gate-footer-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 14px;
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  font-family: var(--font-ui);
  opacity: .6;
  gap: 8px;
}
.gate-footer-row span {
  display: flex;
  align-items: center;
  gap: 4px;
}

@media (max-width: 520px) {
  .gate-benefits-grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   RESULT RING
   ============================================================ */
.ring-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 18px;
}
.score-ring {
  position: relative;
  width: 170px;
  height: 170px;
}
.ring-svg {
  width: 170px;
  height: 170px;
  transform: rotate(-90deg);
}
.ring-bg {
  fill: none;
  stroke: #edf2f4;
  stroke-width: 13;
}
.ring-fg {
  fill: none;
  stroke-width: 13;
  stroke-linecap: round;
  transition: stroke-dashoffset 1.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.ring-center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  pointer-events: none;
}
.ring-score {
  font-size: 40px;
  font-weight: 900;
  line-height: 1;
  display: block;
  animation: countUp 0.8s cubic-bezier(0.4, 0, 0.2, 1) both;
}
.ring-denom {
  font-size: 13px;
  font-weight: 700;
  color: var(--muted);
  display: block;
  margin-top: 2px;
}
.result-title {
  font-size: 22px;
  font-weight: 900;
  color: var(--text);
  text-align: center;
  margin: 10px 0 7px;
  animation: fadeUp 0.4s 0.2s cubic-bezier(0.4, 0, 0.2, 1) both;
}
.result-intro {
  font-size: 15px;
  font-weight: 500;
  color: var(--muted);
  text-align: center;
  line-height: 1.8;
  margin-bottom: 22px;
  font-family: var(--font-reading);
  animation: fadeUp 0.4s 0.35s cubic-bezier(0.4, 0, 0.2, 1) both;
}

/* ============================================================
   TYPE CARD
   ============================================================ */
.type-card {
  border-radius: 20px;
  margin-bottom: 24px;
  border: 1.5px solid var(--border);
  overflow: hidden;
  animation: fadeUp 0.4s 0.5s cubic-bezier(0.4, 0, 0.2, 1) both;
}
.type-card-body {
  padding: 24px 24px 22px;
}
.type-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid transparent;
  padding-bottom: 12px;
  margin-bottom: 16px;
}
.type-card-meta {
  font-size: 10px;
  font-weight: 700;
  color: var(--muted);
  font-family: var(--font-ui);
  letter-spacing: .06em;
  text-transform: uppercase;
  opacity: .6;
}
.type-report-badge {
  font-size: 9.5px;
  font-weight: 800;
  font-family: var(--font-ui);
  padding: 3px 10px;
  border-radius: 99px;
  letter-spacing: .03em;
  border: 1px solid transparent;
  text-transform: uppercase;
}
.type-kicker-wrap {
  margin-bottom: 6px;
}
.type-kicker {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-family: var(--font-ui);
}
.type-name-row {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 16px;
}
.type-icon-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  flex-shrink: 0;
}
.type-card .type-icon {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.type-name {
  font-size: 28px;
  font-weight: 900;
  line-height: 1.15;
  color: var(--text);
  font-family: var(--font-ui);
  letter-spacing: -0.02em;
}
.type-desc {
  font-size: 15.5px;
  font-weight: 400;
  line-height: 1.85;
  color: var(--text);
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
  font-family: var(--font-reading);
}
.type-personal {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13.5px;
  font-weight: 400;
  line-height: 1.7;
  color: var(--muted);
  font-family: var(--font-ui);
}
.type-sc-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  padding-top: 4px;
}
.type-sc-panel {
  border-radius: 14px;
  padding: 16px 18px 14px;
  border: 1px solid transparent;
  display: flex;
  flex-direction: column;
  height: 100%;
  box-sizing: border-box;
}
.type-sc-hdr {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 12px;
  font-family: var(--font-ui);
}
.type-sc-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.type-sc-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13.5px;
  font-weight: 500;
  line-height: 1.5;
  color: var(--text);
  padding: 0;
  border-bottom: none !important;
  font-family: var(--font-ui);
}
.type-sc-bullet {
  flex-shrink: 0;
  margin-top: 2px;
  font-weight: 800;
  user-select: none;
}
@media (max-width: 640px) {
  .type-sc-wrap {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

/* ============================================================
   SPECTRUM
   ============================================================ */
.spectrum-wrap {
  margin-bottom: 22px;
}
.spectrum-title {
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  margin-bottom: 10px;
}
.spectrum-track {
  position: relative;
  height: 13px;
  border-radius: 99px;
  background: linear-gradient(
    90deg,
    var(--spectrum-1),
    var(--spectrum-2),
    var(--spectrum-3),
    var(--spectrum-4),
    var(--spectrum-5)
  );
  margin-bottom: 7px;
}
.spectrum-thumb {
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 23px;
  height: 23px;
  border-radius: 50%;
  background: #fff;
  border: 2.5px solid var(--accent);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.14);
  transition: left 1.2s cubic-bezier(0.4, 0, 0.2, 1);
  left: 0%;
}
.spectrum-labels {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  font-weight: 700;
  color: var(--muted);
  padding: 0 2px;
}

/* ============================================================
   PART A
   ============================================================ */
.part-a {
  border-radius: var(--r-sm);
  padding: 16px 18px;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.75;
  margin-bottom: 22px;
  display: flex;
  align-items: flex-start;
  gap: 11px;
}
.part-a-pos {
  background: #fff8f8;
  border: 1.5px solid #fdd0d0;
}
.part-a-neg {
  background: #f6fff9;
  border: 1.5px solid #c6f6d5;
}
.pa-icon {
  font-size: 17px;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ============================================================
   COLLAPSIBLE SECTIONS
   ============================================================ */
.sec-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  padding: 15px 16px;
  border-radius: var(--r-sm);
  background: var(--accent-bg);
  border: 1.5px solid transparent;
  margin-top: 0;
  margin-bottom: 0;
  user-select: none;
  transition:
    border-color 0.32s cubic-bezier(0.4, 0, 0.2, 1),
    border-radius 0.32s cubic-bezier(0.4, 0, 0.2, 1),
    background 0.18s,
    transform 0.1s;
}
.sec-header:hover {
  border-color: var(--accent);
}
.sec-header:not(.is-open) {
  margin-bottom: 6px;
}
.sec-header.is-open {
  border-bottom: 1.5px solid var(--accent);
  background: var(--accent-bg);
}
.sec-header:active {
  transform: scale(0.99);
}
.sec-left {
  display: flex;
  align-items: center;
  gap: 9px;
}
.sec-icon {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
  transition: background 0.18s;
}
.sec-label {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}
.sec-sublabel {
  font-size: 12px;
  font-weight: 500;
  color: var(--muted);
  margin-top: 1px;
}
.sec-toggle {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  color: var(--accent);
  flex-shrink: 0;
  transition:
    transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1),
    background 0.18s,
    border-color 0.18s;
}
.sec-toggle.open {
  transform: rotate(45deg) scale(1.1);
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.sec-body {
  overflow: hidden;
  height: 0;
  transition:
    height 0.32s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.2s ease;
  opacity: 0;
  border-radius: 0 0 var(--r-sm) var(--r-sm);
  background: #fff;
  margin-bottom: 0;
  border: 1.5px solid transparent;
  border-top: none;
}
.sec-body.open,
.sec-body.is-open {
  opacity: 1;
  margin-bottom: 6px;
  border-color: var(--accent);
  /* height set by JS */
}
.sec-inner {
  padding: 12px 14px 10px;
}

/* ============================================================
   DOMAIN BARS
   ============================================================ */
.domain {
  margin-bottom: 15px;
}
.d-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 6px;
}
.d-name {
  font-size: 14px;
  font-weight: 800;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 5px;
}
.d-pct {
  font-size: 13px;
  font-weight: 900;
  margin-right: 4px;
}
.d-lv {
  font-size: 11px;
  font-weight: 800;
  padding: 3px 10px;
  border-radius: 99px;
}
.d-track {
  height: 9px;
  background: #edf2f4;
  border-radius: 99px;
  overflow: hidden;
}
.d-fill {
  height: 100%;
  border-radius: 99px;
  transition: width 1.1s 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
@media (max-width: 520px) {
  .d-lv {
    display: none;
  }
}

/* ============================================================
   TRAIT GROUPS (All 25 Traits)
   ============================================================ */
.trait-group {
  margin-bottom: 14px;
}
.trait-group:last-child {
  margin-bottom: 0;
}
.trait-group-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 6px;
  padding: 7px 10px;
  border-radius: 8px;
}
.trait-group-name {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-family: var(--font-ui);
}
.trait-group-pct {
  font-size: 12px;
  font-weight: 800;
  font-family: var(--font-ui);
}
.trait-group-bar {
  height: 4px;
  border-radius: 99px;
  background: var(--border);
  overflow: hidden;
  margin-bottom: 8px;
}
.trait-group-fill {
  height: 100%;
  border-radius: 99px;
  transition: width 0.6s ease;
}
.trait-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 5px 0;
  border-bottom: 1px solid #f0f4f8;
}
.trait-row:last-child {
  border-bottom: none;
}
.trait-row-name {
  font-size: 13px;
  font-weight: 400;
  color: var(--text);
  font-family: var(--font-ui);
  flex: 1;
}
.trait-row-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
  width: 150px;
}
.trait-row-ans {
  font-size: 12px;
  font-family: var(--font-ui);
  width: 68px;
  text-align: right;
  flex-shrink: 0;
}
.trait-row-bar {
  flex: 1;
  height: 5px;
  border-radius: 99px;
  background: #e8edf2;
  overflow: hidden;
}

/* ============================================================
   INSIGHTS
   ============================================================ */
.insight {
  border-radius: 10px;
  padding: 14px 16px;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.8;
  margin-bottom: 10px;
  background: #f8f9fa;
  border: 1px solid var(--border);
  font-family: var(--font-reading);
  transition: box-shadow 0.15s;
}
.insight:hover {
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}
.insight h4 {
  font-size: 12px;
  font-weight: 700;
  font-family: var(--font-ui);
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.ins-teal h4  { color: var(--ins-teal-h);   }
.ins-pink h4  { color: var(--ins-pink-h);   }
.ins-yellow h4{ color: var(--ins-yellow-h); }
.ins-purple h4{ color: var(--ins-purple-h); }
.ins-green h4 { color: var(--ins-green-h);  }

/* ============================================================
   STEPS
   ============================================================ */
.step {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 13px 15px;
  border-radius: var(--r-sm);
  background: rgba(250, 255, 255, 0.567);
  border: 1.5px solid var(--border);
  margin-bottom: 9px;
  transition:
    border-color 0.15s,
    transform 0.15s;
}
.step:hover {
  border-color: var(--accent);
}
.step-n {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: #41a6bd29;
  color: var(--text);
  font-size: 13px;
  font-weight: 900;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition:
    background 0.18s,
    color 0.18s;
}
.step-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
}
.step-body {
  font-size: 14px;
  font-weight: 400;
  font-family: var(--font-reading);
  color: var(--muted);
  line-height: 1.65;
}

/* ============================================================
   PATTERN SUMMARY
   ============================================================ */
.pattern-summary {
  font-size: 15px;
  font-weight: 400;
  font-family: var(--font-reading);
  line-height: 1.85;
  color: var(--text);
  padding: 0 0 14px 0;
  margin-bottom: 4px;
}

/* ============================================================
   THIS WEEK TIPS
   ============================================================ */
.tips-intro {
  font-size: 13px;
  font-weight: 600;
  color: var(--muted);
  line-height: 1.65;
  margin-bottom: 14px;
}
.tip-card {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 14px 16px;
  border-radius: var(--r-sm);
  background: #fff;
  border: 1.5px solid var(--border);
  margin-bottom: 9px;
  transition:
    border-color 0.15s,
    transform 0.15s,
    box-shadow 0.15s;
}
.tip-card:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.06);
}
.tip-icon {
  font-size: 22px;
  line-height: 1;
  flex-shrink: 0;
  margin-top: 1px;
}
.tip-body {
  flex: 1;
}
.tip-title {
  font-size: 13.5px;
  font-weight: 900;
  color: var(--text);
  margin-bottom: 4px;
}
.tip-text {
  font-size: 14px;
  font-weight: 400;
  font-family: var(--font-reading);
  color: var(--muted);
  line-height: 1.65;
}

/* ============================================================
   RESULT CLOSING
   ============================================================ */
.result-cta-card {
  background: var(--card);
  border: 1.5px solid var(--border);
  border-left: 4px solid var(--accent);
  border-radius: 14px;
  padding: 22px 20px 20px;
  margin: 28px 0 16px;
}
.result-closing {
  margin: 0 0 18px;
  padding: 0;
  border-top: none;
}
.result-closing p {
  font-size: 14.5px;
  font-weight: 400;
  line-height: 1.85;
  color: var(--muted);
  font-family: var(--font-reading);
  margin: 0 0 12px;
}
.result-closing p:last-child {
  margin-bottom: 0;
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.5;
}
.result-actions-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 0;
}
.result-action-btn {
  flex: 1;
  min-width: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 12px 14px;
  border-radius: 12px;
  font-size: 13.5px;
  font-weight: 600;
  font-family: var(--font-ui);
  cursor: pointer;
  transition: opacity 0.15s, transform 0.12s;
  background: var(--accent);
  color: #fff;
  border: none;
}
.result-action-btn.secondary {
  background: #fff;
  color: var(--text);
  border: 1.5px solid var(--border);
}
.result-action-btn:hover { opacity: 0.88; transform: translateY(-1px); }
.result-action-btn:active { transform: scale(0.97); }
.result-disclaimer {
  display: flex;
  align-items: flex-start;
  gap: 7px;
  font-size: 11.5px;
  font-weight: 400;
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 8px;
  opacity: 0.75;
  font-family: var(--font-ui);
}
@media (max-width: 480px) {
  .result-actions-row { flex-direction: column; }
}

/* ============================================================
   SHARE MODAL
   ============================================================ */
.share-modal {
  position: fixed;
  inset: 0;
  background: rgba(15, 30, 40, 0.72);
  backdrop-filter: blur(8px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.share-modal-inner {
  background: #fff;
  border-radius: 24px;
  padding: 26px 24px 20px;
  width: 100%;
  max-width: 440px;
  box-shadow: 0 32px 80px rgba(0, 0, 0, 0.28);
  max-height: 92vh;
  overflow-y: auto;
}
.share-modal-title {
  font-size: 16px;
  font-weight: 900;
  color: var(--text);
  margin-bottom: 3px;
  text-align: center;
  letter-spacing: -0.01em;
}
.share-modal-sub {
  font-size: 11.5px;
  font-weight: 700;
  color: var(--muted);
  text-align: center;
  margin-bottom: 16px;
  opacity: 0.8;
}
.share-card-preview {
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 14px;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.13);
  line-height: 1;
}
.share-copy-row {
  display: flex;
  gap: 8px;
  margin-bottom: 10px;
}
.share-copy-input {
  flex: 1;
  padding: 9px 12px;
  border-radius: var(--r-sm);
  border: 1.5px solid var(--border);
  font-family: inherit;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--muted);
  background: #f8fbfc;
  outline: none;
}

@media (max-width: 480px) {
  .share-btns {
    grid-template-columns: 1fr;
  }
  .share-modal-inner {
    padding: 18px 14px 16px;
    border-radius: 18px;
  }
}

/* ============================================================
   PRE-TEST PROFILE STEPS
   ============================================================ */
.pstep-wrap {
  padding: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
}

/* ── Topbar: progress + step counter ── */
.pstep-topbar {
  margin-bottom: 28px;
}
.pstep-stepctr {
  height: 8px;
  background: var(--bg);
  border-radius: 99px;
  overflow: hidden;
  margin-bottom: 10px;
  box-shadow: inset 0 1px 3px rgba(0,0,0,0.04);
}
.pstep-stepctr-fill {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--accent2), var(--accent));
  border-radius: 99px;
  transition: width 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
  box-shadow: 0 1px 3px rgba(63, 168, 190, 0.2);
}
.pstep-steplabel {
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.pstep-steplabel strong {
  color: var(--accent);
}

/* ── Old aliases (keep for safety) ── */
.pstep-head { margin-bottom: 24px; }
.pstep-progress { height: 5px; background: var(--border); border-radius: 3px; overflow: hidden; margin-bottom: 10px; }
.pstep-progress-fill { height: 100%; background: var(--accent); border-radius: 3px; transition: width 0.4s ease; }
.pstep-counter { font-size: 11px; font-weight: 800; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; }

.pstep-body {
  flex: 1;
  margin-bottom: 16px;
}
.pstep-label {
  font-size: 24px;
  font-weight: 900;
  color: var(--text);
  line-height: 1.2;
  margin-bottom: 8px;
  letter-spacing: -0.01em;
}
.pstep-hint {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--muted);
  margin-bottom: 20px;
  line-height: 1.6;
}
.pstep-grid {
  display: grid;
  gap: 10px;
  contain: layout style;
}
.pstep-grid-3 {
  grid-template-columns: repeat(3, 1fr);
}
.pstep-grid-2 {
  grid-template-columns: repeat(2, 1fr);
}
.pstep-opt {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 8px;
  border-radius: 16px;
  border: 1.5px solid var(--border);
  background: #fff;
  font-family: inherit;
  cursor: pointer;
  text-align: center;
  min-height: 84px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.03);
  transition:
    border-color 0.15s,
    background 0.15s,
    transform 0.12s,
    box-shadow 0.15s;
}
.pstep-opt:hover {
  border-color: var(--accent);
  background: var(--accent-bg);
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(63,168,190,0.12);
}
.pstep-opt.active {
  border-color: var(--accent);
  background: var(--accent-bg);
  box-shadow: 0 0 0 3px rgba(63, 168, 190, 0.18);
}
/* Icon bubble inside option card */
.pstep-opt-icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--accent-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-bottom: 4px;
  transition: transform 0.15s, background 0.15s;
}
.pstep-opt-icon .material-symbols-outlined {
  font-size: 28px;
  color: var(--accent);
  font-variation-settings: 'wght' 300;
  transition: color 0.15s;
}
.pstep-opt.active .pstep-opt-icon {
  background: var(--accent);
  transform: scale(1.06);
}
.pstep-opt.active .pstep-opt-icon .material-symbols-outlined {
  color: #fff;
}
/* Legacy emoji fallback */
.pstep-opt-emoji {
  font-size: 24px;
  line-height: 1;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pstep-opt-label {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
}
.pstep-opt.active .pstep-opt-label {
  color: var(--accent);
  font-weight: 800;
}
.pstep-opt-span {
  grid-column: 1 / -1;
  flex-direction: row;
  gap: 10px;
  min-height: 48px;
  padding: 12px 18px;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.03);
}
.pstep-opt-span .pstep-opt-label {
  font-weight: 600;
  color: var(--muted);
}
.pstep-opt-span.active {
  border-color: var(--accent);
  background: var(--accent-bg);
  box-shadow: 0 0 0 3px rgba(63, 168, 190, 0.18);
}
.pstep-opt-span.active .pstep-opt-label {
  color: var(--accent);
}
.pstep-opt-span:hover {
  border-color: var(--accent);
  background: var(--accent-bg);
  box-shadow: 0 4px 14px rgba(63,168,190,0.12);
  transform: translateY(-2px);
}

/* Nav bar — fixed to bottom of card, matches quiz screen */
.pstep-nav-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 0 0;
  margin-top: auto;
  border-top: 1.5px solid var(--border);
  background: #fff;
}
.pstep-err {
  font-size: 12px;
  font-weight: 700;
  color: #c05050;
  background: #fff0f0;
  border: 1.5px solid #f0c0c0;
  border-radius: var(--r-sm);
  padding: 10px 14px;
  display: none;
  margin-top: 14px;
}
.pstep-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 16px;
  border-top: 1.5px solid var(--border);
  margin-top: auto;
}
.pstep-back {
  font-size: 13px;
  font-weight: 700;
  color: var(--muted);
  background: none;
  border: none;
  padding: 8px 0;
  cursor: pointer;
  transition: color 0.15s;
}
.pstep-back:hover {
  color: var(--accent);
}
.pstep-next {
  min-width: 148px;
  justify-content: center;
}

@media (max-width: 480px) {
  .pstep-grid-3 {
    grid-template-columns: repeat(2, 1fr);
  }
  .pstep-label {
    font-size: 20px;
  }
  .pstep-opt {
    min-height: 68px;
    padding: 12px 6px;
  }
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  text-align: center;
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  line-height: 1.75;
  padding: 12px 12px 14px;
  flex-shrink: 0;
  margin-top: auto;
  border-top: 1.5px solid var(--border);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.footer-row {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 10.5px;
  font-weight: 700;
  color: var(--muted);
  opacity: 0.8;
  letter-spacing: 0.01em;
}
.footer-dot {
  opacity: 0.35;
}
.footer-disclaimer {
  font-size: 10px;
  font-weight: 600;
  color: var(--muted);
  opacity: 0.55;
  letter-spacing: 0.01em;
}
.footer a {
  color: var(--accent);
  text-decoration: none;
}
.footer a:hover {
  text-decoration: underline;
}

@media print {
  .print-break {
    break-before: page;
  }
  .sticky-action-bar,
  #reportProgress,
  #ctxNav {
    display: none !important;
  }
}

/* ============================================================
   UI REFINEMENTS â€” Answer Spacing, Nav, Restart
   ============================================================ */

/* More breathing room between answer circles */
.circles-group {
  gap: 28px !important;
}
@media (max-width: 520px) {
  .circles-group {
    gap: 14px !important;
  }
}

/* Nav bar: always at bottom of the card */
.nav .btn-back,
.nav .btn-next {
  min-width: 110px !important;
  flex-shrink: 0 !important;
}

/* Restart button visibility */
.nav + div button {
  opacity: 0.65 !important;
  font-size: 11.5px !important;
}

/* ============================================================
   REPORT META STRIP
   ============================================================ */
.report-meta-strip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 2px 10px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 14px;
}
.rms-left {
  display: flex;
  align-items: center;
  gap: 10px;
}
.rms-badge {
  background: var(--accent);
  color: #fff;
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 99px;
  font-family: var(--font-ui);
}
.rms-title {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--muted);
  font-family: var(--font-ui);
}
.rms-right {
  display: flex;
  align-items: center;
  gap: 8px;
  opacity: .45;
}
.rms-id {
  font-size: 10.5px;
  font-weight: 700;
  color: var(--muted);
  font-family: var(--font-ui);
  letter-spacing: .04em;
}
.rms-sep {
  color: var(--muted);
  font-size: 10px;
}
.rms-date {
  font-size: 10.5px;
  font-weight: 500;
  color: var(--muted);
  font-family: var(--font-ui);
}

/* ============================================================
   SCORE HERO — redesigned
   ============================================================ */
.score-hero {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 20px;
  padding: 0;
  margin-bottom: 16px;
  animation: fadeUp 0.4s 0.1s cubic-bezier(0.4, 0, 0.2, 1) both;
  box-shadow: 0 4px 28px rgba(0,0,0,0.07);
  overflow: hidden;
}

/* ── Banner: big score + tier label side by side ── */
.hero-banner {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 22px 22px 18px;
  border-bottom: 1px solid var(--border);
}
.hero-banner-score {
  font-size: 56px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -.03em;
  font-family: var(--font-ui);
  flex-shrink: 0;
  min-width: 72px;
}
.hero-banner-right {
  flex: 1;
  min-width: 0;
  border-left: 2px solid var(--border);
  padding-left: 18px;
}
.hero-banner-label {
  font-size: 18px;
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: 5px;
  font-family: var(--font-ui);
  letter-spacing: -.01em;
}
.hero-banner-desc {
  font-size: 13.5px;
  font-weight: 400;
  color: var(--muted);
  line-height: 1.6;
  font-family: var(--font-reading);
}

/* ── Chart toggle ── */
.chart-toggle-wrap {
  position: relative;
}
.chart-toggle-btns {
  display: flex;
  justify-content: flex-end;
  gap: 4px;
  padding: 10px 14px 2px;
}
.chart-toggle-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 99px;
  border: 1.5px solid var(--border);
  background: transparent;
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  font-family: var(--font-ui);
  cursor: pointer;
  transition: all 0.15s;
}
.chart-toggle-btn.active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.chart-toggle-btn:hover:not(.active) {
  border-color: var(--accent);
  color: var(--accent);
}

/* ── Radar / Spider chart ── */
.radar-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 8px 4px 12px;
}
.radar-svg {
  width: 100%;
  max-width: 320px;
  height: auto;
  overflow: visible;
}
.radar-grid {
  fill: none;
  stroke: #dde3ea;
  stroke-width: 1;
}
.radar-spoke {
  fill: none;
  stroke: #dde3ea;
  stroke-width: 1;
}
.radar-area {
  transition: opacity 0.3s;
}
.radar-dot {
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.15));
}
.radar-label {
  font-size: 11.5px;
  font-weight: 600;
  fill: #4a5568;
  font-family: var(--font-ui);
}
.radar-pct {
  font-size: 12px;
  font-weight: 800;
  font-family: var(--font-ui);
}

/* ── Score number wrap ── */
.hero-banner-score-wrap {
  display: flex;
  align-items: baseline;
  gap: 3px;
  flex-shrink: 0;
}
.hero-banner-score-denom {
  font-size: 18px;
  font-weight: 700;
  color: var(--muted);
  font-family: var(--font-ui);
  opacity: .55;
  margin-bottom: 2px;
}
.hero-banner-meta {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--muted);
  font-family: var(--font-ui);
  margin-top: 6px;
  opacity: .75;
}

/* ── Severity spectrum bar ── */
.severity-spectrum {
  margin-top: 10px;
  width: 100%;
}
.spec-track-wrap {
  position: relative;
  padding: 3px 0;
}
.spec-track {
  height: 7px;
  border-radius: 99px;
  overflow: hidden;
  display: flex;
}
.spec-seg {
  height: 100%;
}
.spec-marker {
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
}
.spec-marker-dot {
  width: 13px;
  height: 13px;
  border-radius: 50%;
  background: #fff;
  border: 2.5px solid;
  box-shadow: 0 1px 4px rgba(0,0,0,0.18);
}
.spec-labels {
  display: flex;
  justify-content: space-between;
  font-size: 9.5px;
  font-weight: 600;
  color: var(--muted);
  font-family: var(--font-ui);
  margin-top: 5px;
  opacity: .55;
}

/* ── Signal flags ── */
.signal-flags-wrap {
  margin-bottom: 14px;
}
.signal-flags-label {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--muted);
  margin-bottom: 8px;
  font-family: var(--font-ui);
}
.signal-flags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-bottom: 0;
}
.signal-flag {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px 4px 8px;
  border-radius: 99px;
  background: #f4f6f8;
  border: 1px solid #e4e8ec;
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  font-family: var(--font-ui);
}
.signal-flag-label {
  line-height: 1;
}

/* ── Section chevron ── */
.sec-chevron {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #f0f2f5;
  color: var(--muted);
  flex-shrink: 0;
  transition: transform 0.2s, background 0.15s;
}
.sec-chevron.open {
  transform: rotate(180deg);
  background: var(--accent-bg);
  color: var(--accent);
}
.sec-toggle {
  display: none;
}

/* ── Profile card meta line ── */
.type-card-meta {
  font-size: 10.5px;
  font-weight: 700;
  color: var(--muted);
  font-family: var(--font-ui);
  letter-spacing: .04em;
  text-transform: uppercase;
  opacity: .55;
  margin-bottom: 6px;
}

/* ── Report certificate footer ── */
.report-certificate {
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 16px;
  margin-top: 16px;
  background: #f9fafb;
}
.rc-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 20px;
  margin-bottom: 10px;
}
.rc-label {
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--muted);
  font-family: var(--font-ui);
  opacity: .6;
  margin-bottom: 2px;
}
.rc-val {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--text);
  font-family: var(--font-ui);
}
.rc-note {
  font-size: 11.5px;
  color: var(--muted);
  font-family: var(--font-reading);
  line-height: 1.6;
  border-top: 1px solid var(--border);
  padding-top: 10px;
  font-style: italic;
}

/* ── Part A block ── */
.hero-parta {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin: 0 18px 14px;
  padding: 8px 12px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.6;
  font-family: var(--font-reading);
  color: var(--muted);
}
.hero-parta-pos {
  background: #fff8f8;
  border: 1px solid #f0d0d0;
}
.hero-parta-neg {
  background: #f5fdf7;
  border: 1px solid #c0e8cc;
}
@media (max-width: 640px) {
  /* Main card wrapper - full width, no border/shadow on mobile */
  .shell > .card {
    background: transparent;
    border-radius: 0;
    box-shadow: none;
    padding: 0;
    margin: 0 -8px;
  }

  /* Cards inside the report - keep compact styling */
  .card {
    padding: 14px;
    border-radius: 14px;
  }
  .card.q-card {
    padding: 14px;
    min-height: auto;
  }

  /* Container - minimal side padding */
  .container {
    padding-left: 8px;
    padding-right: 8px;
  }

  /* App container - full width on mobile */
  #app {
    padding: 8px 0;
  }

  /* Hero banner - stack vertically on mobile for better readability */
  .hero-banner {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    padding: 16px 14px 14px;
    border-bottom: none;
  }
  .hero-banner-left {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
  }
  .hero-banner-score {
    font-size: 36px;
    min-width: auto;
    line-height: 1;
  }
  .hero-banner-score-wrap {
    align-items: baseline;
  }
  .hero-banner-score-denom {
    font-size: 14px;
  }
  .hero-banner-right {
    border-left: none;
    border-top: 1px solid var(--border);
    padding-left: 0;
    padding-top: 12px;
    width: 100%;
  }
  .hero-banner-label {
    font-size: 16px;
    line-height: 1.3;
    margin-bottom: 4px;
  }
  .hero-banner-desc {
    font-size: 12px;
    line-height: 1.45;
    margin-top: 2px;
  }
  .hero-banner-meta {
    font-size: 11px;
    margin-top: 6px;
  }

  /* Comparison bar - mobile optimized */
  .hero-compare {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid #e8f4f8;
  }
  .hero-compare-bar {
    height: 8px;
    border-radius: 4px;
  }
  .hero-compare-marker {
    width: 14px;
    height: 14px;
    border-width: 2px;
  }
  .hero-compare-labels {
    font-size: 11px;
    margin-top: 6px;
    font-weight: 500;
  }

  /* Part A warning block - mobile */
  .hero-parta {
    margin: 0 14px 12px;
    padding: 10px 12px;
    font-size: 12px;
    line-height: 1.5;
    border-radius: 10px;
  }
  .hero-parta-pos {
    background: #fff0f0;
    border: 1px solid #ffd0d0;
  }
  .hero-parta-neg {
    background: #f0fff4;
    border: 1px solid #c0f0d0;
  }

  /* Dimension bars - stacked vertically on mobile */
  .hero-dims {
    gap: 14px;
    margin-top: 16px;
  }
  .hero-dim {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
  .hero-dim-label {
    width: 100%;
    min-width: auto;
    font-size: 13px;
    font-weight: 600;
  }
  .hero-dim-bar-wrap {
    height: 12px;
    border-radius: 6px;
    width: 100%;
  }
  .hero-dim-bar {
    border-radius: 6px;
  }
  .hero-dim-value {
    font-size: 13px;
    min-width: auto;
    font-weight: 700;
    margin-left: auto;
  }

  /* Bar/Radar toggle tabs - mobile */
  .hero-tabs {
    gap: 6px;
    margin-bottom: 14px;
  }
  .hero-tab {
    font-size: 12px;
    padding: 6px 12px;
  }

  /* Part A block - compact */
  .hero-parta {
    margin: 0 14px 10px;
    padding: 6px 10px;
    font-size: 11px;
    line-height: 1.5;
    gap: 6px;
  }

  /* Section spacing */
  .section {
    margin-bottom: 16px;
  }
  .section + .section {
    margin-top: 16px;
  }

  /* Profile card */
  .type-card {
    margin: 0 0 10px !important;
  }
  .type-card-body {
    padding: 16px 16px 14px !important;
  }
  .type-card-header {
    flex-direction: row !important;
    align-items: flex-start !important;
    gap: 10px !important;
    margin-bottom: 12px !important;
  }
  .type-icon-wrapper {
    width: 42px !important;
    height: 42px !important;
    flex-shrink: 0 !important;
  }
  .type-card .type-icon {
    width: 30px !important;
    height: 30px !important;
    flex-shrink: 0 !important;
  }
  .type-name {
    font-size: 18px !important;
    line-height: 1.3 !important;
    margin: 0 !important;
  }
  .type-kicker {
    font-size: 11px !important;
    margin-bottom: 2px !important;
  }
  .type-desc {
    font-size: 13px !important;
    line-height: 1.6 !important;
    margin: 12px 0 !important;
  }

  /* Strengths/Challenges section */
  .type-sc-wrap {
    flex-direction: column !important;
    gap: 16px !important;
    margin-top: 16px !important;
  }
  .type-sc-col {
    width: 100% !important;
  }
  .type-sc-panel {
    border-top: none !important;
    border-right: none !important;
    border-bottom: none !important;
    border-radius: 0 !important;
    margin: 0 -16px !important;
    padding: 12px 16px !important;
  }
  .type-sc-hdr {
    font-size: 11px !important;
    margin-bottom: 8px !important;
    gap: 6px !important;
  }
  .type-sc-item {
    font-size: 13px !important;
    padding: 2px 0 !important;
    line-height: 1.4 !important;
  }

  /* Accordion/TLDR sections */
  .tldr-card {
    padding: 14px;
  }
  .tldr-header {
    padding: 12px 14px;
  }
  .tldr-title {
    font-size: 15px;
  }
  .tldr-subtitle {
    font-size: 12px;
  }

  /* Quick wins section */
  .quick-win-item {
    padding: 8px 0 !important;
  }
  .quick-win-num {
    width: 20px !important;
    height: 20px !important;
    font-size: 11px !important;
    flex-shrink: 0 !important;
  }
  .quick-win-text {
    font-size: 12px !important;
    line-height: 1.4 !important;
  }
  .quick-win-head {
    font-size: 11px !important;
    margin: 12px 0 6px !important;
  }

  /* TL;DR card mobile styles */
  .tldr-card {
    padding: 14px 12px !important;
    margin: 0 0 10px !important;
  }
  .tldr-header {
    padding: 0 0 10px !important;
    gap: 10px !important;
  }
  .tldr-title {
    font-size: 15px !important;
  }
  .tldr-subtitle {
    font-size: 11px !important;
  }
  .tldr-icon {
    width: 32px !important;
    height: 32px !important;
  }
  .tldr-row {
    padding: 10px 12px !important;
    align-items: flex-start !important;
  }
  .tldr-row-icon {
    margin-top: 2px !important;
  }
  .tldr-row-body {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 2px !important;
  }
  .tldr-row-label {
    font-size: 9.5px !important;
  }
  .tldr-row-value {
    font-size: 13px !important;
    line-height: 1.4 !important;
  }
  /* Start Here section */
  .start-here-section {
    margin-top: 14px !important;
    padding-top: 10px !important;
  }
  .start-here-title {
    font-size: 11px !important;
    margin-bottom: 10px !important;
  }

  /* What This Is Not grid moved to end of file to prevent overrides */

  /* Operating system steps - What to Do Next */
  .os-step {
    padding: 14px 0 !important;
    gap: 10px !important;
    border-top: 1px solid rgba(0,0,0,0.06) !important;
  }
  .os-step:first-of-type {
    border-top: none !important;
    padding-top: 0 !important;
  }
  .os-step-num {
    width: 26px !important;
    height: 26px !important;
    font-size: 12px !important;
    flex-shrink: 0 !important;
    font-weight: 700 !important;
  }
  .os-step-title {
    font-size: 15px !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
    flex: 1 !important;
  }
  .os-step-subtitle {
    font-size: 10px !important;
    letter-spacing: 0.08em !important;
    margin-top: 2px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
  }
  .os-items {
    gap: 10px !important;
    padding: 4px 0 0 32px !important;
    margin-top: 4px !important;
  }
  .os-item {
    font-size: 13px !important;
    line-height: 1.5 !important;
    padding-left: 4px !important;
  }
  .os-item::before {
    font-size: 13px !important;
    left: -20px !important;
    top: 2px !important;
  }

  /* Pattern breakdown section - improved mobile */
  .exp-breakdown {
    padding: 12px 14px 16px !important;
  }
  .pattern-intro {
    font-size: 13px !important;
    line-height: 1.6 !important;
    margin: 0 0 14px !important;
    padding: 0 !important;
  }
  .pattern-intro strong,
  .pattern-intro b {
    color: var(--text) !important;
  }
  .pattern-subsec {
    margin: 12px 0 !important;
    padding: 10px 0 !important;
    border-top: 1px solid rgba(0,0,0,0.06) !important;
  }
  .pattern-subsec:first-of-type {
    border-top: none !important;
    padding-top: 0 !important;
  }
  .pattern-subsec-header {
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
    margin-bottom: 6px !important;
  }
  .pattern-subsec-icon {
    width: 40px !important;
    height: 40px !important;
    border-radius: 10px !important;
    flex-shrink: 0 !important;
    margin-top: 0 !important;
  }
  .pattern-subsec-title {
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 1.35 !important;
    flex: 1 !important;
    color: var(--text) !important;
  }
  .pattern-subsec-body {
    font-size: 13px !important;
    line-height: 1.6 !important;
    padding-left: 50px !important;
    color: var(--muted) !important;
  }
  .pattern-subsec-body strong,
  .pattern-subsec-body b {
    color: var(--text) !important;
  }

  /* Action buttons */
  .share-btns {
    flex-direction: column;
    gap: 10px;
  }
  .share-btn {
    width: 100%;
    justify-content: center;
  }

  /* Signals tags - compact */
  .signal-flags {
    flex-wrap: wrap;
    gap: 4px;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
  .signal-flag {
    font-size: 11px;
    padding: 6px 10px;
    border-radius: 16px;
    background: #fff !important;
    border: 1px solid #e0e0e0 !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.08) !important;
    font-weight: 500 !important;
  }
  /* Detected signals section padding */
  .signal-flags-wrap {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
  .signal-flags-label {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  /* TL;DR rows section - stacked layout */
  .tldr-rows {
    padding: 4px 0 8px !important;
  }
  .tldr-row {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: flex-start !important;
    padding: 10px 12px !important;
    gap: 10px !important;
  }
  .tldr-row-icon {
    width: 28px !important;
    height: 28px !important;
    border-radius: 6px !important;
    flex-shrink: 0 !important;
    order: 1 !important;
    margin-top: 2px !important;
  }
  .tldr-row-icon .material-symbols-outlined {
    font-size: 15px !important;
  }
  .tldr-row-body {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    flex: 1 1 auto !important;
    order: 2 !important;
    min-width: 0 !important;
  }
  .tldr-row-label {
    font-size: 10px !important;
    letter-spacing: 0.05em !important;
    order: 1 !important;
    width: 100% !important;
  }
  .tldr-row-value {
    font-size: 13px !important;
    line-height: 1.4 !important;
    order: 2 !important;
    width: 100% !important;
  }

  /* 7 Days section */
  .day-card {
    padding: 14px;
  }
  .day-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }

  /* Info boxes - compact */
  .info-box {
    padding: 10px 12px;
    font-size: 12px;
    border-radius: 10px;
  }

  /* Section titles - compact */
  .section-title {
    font-size: 11px;
    margin-bottom: 8px;
    padding-bottom: 6px;
  }

  /* Tab buttons - compact */
  .hero-tabs {
    gap: 4px;
  }
  .hero-tab {
    font-size: 11px;
    padding: 4px 10px;
  }

  /* Recommended card */
  .rec-card {
    padding: 16px;
  }
  .rec-title {
    font-size: 18px;
  }

  /* Assessment complete section */
  .complete-card {
    padding: 16px;
  }
  .complete-title {
    font-size: 17px;
  }

  /* Mid-notion block - stack on mobile */
  .mid-notion-block {
    margin: 8px 0 16px;
  }
  .mid-notion-eyebrow {
    padding: 10px 12px;
    font-size: 11px;
  }
  .mid-notion-prescribe {
    padding: 12px 12px 4px;
    font-size: 13.5px;
    line-height: 1.5;
  }
  .mid-notion-body {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    padding: 12px;
  }
  .mid-notion-img-wrap {
    width: 100%;
    height: auto;
    max-height: 180px;
    border-radius: 8px;
    padding-top: 14px; /* Browser bar mockup gap */
  }
  .mid-notion-img-wrap::before {
    top: 4px;
    left: 8px;
  }
  .mid-notion-img {
    object-fit: contain;
    border-radius: 0 0 7px 7px;
  }
  .mid-notion-content {
    padding: 4px 0 0 0;
    width: 100%;
  }
  .mid-notion-badge {
    font-size: 10px;
    padding: 3px 8px;
    margin-bottom: 6px;
  }
  .mid-notion-title {
    font-size: 17px;
  }
  .mid-notion-subtitle {
    font-size: 12.5px;
    margin-bottom: 10px;
  }
  .mid-notion-features {
    gap: 6px;
  }
  .mid-notion-feature {
    font-size: 12.5px;
  }
  .mid-notion-footer {
    padding: 12px;
    flex-direction: column;
    gap: 10px;
    align-items: flex-start;
  }
  .mid-notion-btn {
    width: 100%;
    justify-content: center;
    font-size: 13px;
    padding: 10px 16px;
  }
  .mid-notion-note {
    font-size: 10px;
  }
}

/* ============================================================
   STICKY REPORT NAV
   ============================================================ */
.report-nav {
  position: sticky;
  top: 0;
  z-index: 80;
  background: rgba(242,248,251,0.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1.5px solid var(--border);
  margin: 0 -16px 20px;
  padding: 0 16px;
  display: flex;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.report-nav::-webkit-scrollbar { display: none; }
.report-nav-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 10px 14px;
  font-size: 12px;
  font-weight: 800;
  color: var(--muted);
  background: none;
  border: none;
  border-bottom: 2.5px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
  font-family: inherit;
}
.report-nav-btn:hover {
  color: var(--accent);
}
.report-nav-btn.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.report-nav-icon {
  font-size: 14px;
  line-height: 1;
}

/* ============================================================
   SECTION PREVIEW TEXT
   ============================================================ */
.sec-preview {
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  margin-top: 2px;
  opacity: 0.8;
  max-width: 260px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sec-header.is-open .sec-preview {
  display: none;
}

/* ============================================================
   ENHANCED DOMAIN BARS
   ============================================================ */
.d-track {
  height: 22px !important;
  border-radius: 10px !important;
  position: relative;
}
.d-fill {
  height: 100% !important;
  border-radius: 10px !important;
  display: flex;
  align-items: center;
  min-width: 36px;
  transition: width 1.1s 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}
.d-fill-label {
  font-size: 10px;
  font-weight: 900;
  color: #fff;
  padding-left: 8px;
  letter-spacing: .03em;
  white-space: nowrap;
  opacity: 0;
  transition: opacity 0.4s 1s;
}
.d-fill-label.visible {
  opacity: 1;
}
.d-meta {
  margin-bottom: 7px !important;
}
.domain {
  margin-bottom: 18px !important;
}

/* ============================================================
   DOT MATRIX TRAIT GRID
   ============================================================ */
.trait-dot-grid {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.trait-dot-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 10px;
  background: var(--bg);
  border: 1.5px solid var(--border);
}
.trait-dot-name {
  flex: 1;
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
  min-width: 0;
}
.trait-dot-pips {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}
.trait-pip {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #e2eff4;
  transition: background 0.2s;
}
.trait-pip.lit {
  background: var(--accent);
}
.trait-pip.lit-warn {
  background: #f0b878;
}
.trait-pip.lit-high {
  background: #e87878;
}
.trait-dot-label {
  font-size: 10.5px;
  font-weight: 800;
  color: var(--muted);
  min-width: 52px;
  text-align: right;
  flex-shrink: 0;
}

/* ============================================================
   BACK TO TOP BUTTON
   ============================================================ */
.back-to-top-btn {
  position: fixed;
  bottom: 24px;
  right: 20px;
  z-index: 100;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(63,168,190,0.35);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s, transform 0.2s;
}
.back-to-top-btn:hover { transform: translateY(-2px); }
.back-to-top-btn:active { transform: scale(0.93); }

.result-bottom-spacer {
  height: 32px;
}

/* ============================================================
   SECTION ANCHOR OFFSETS (for sticky nav)
   ============================================================ */
.report-section-anchor {
  scroll-margin-top: 52px;
}

/* ============================================================
   HYBRID UX — LAYER 1: Hero dim bars (always visible)
   ============================================================ */
.hl-dims {
  margin: 0 0 16px;
  display: flex;
  flex-direction: column;
  gap: 9px;
}
.hl-dim-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.hl-dim-label {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
}
.hl-dim-pct {
  font-size: 13px;
  font-weight: 800;
}
.hl-dim-track {
  height: 7px;
  background: var(--bg);
  border-radius: 4px;
  overflow: hidden;
  border: 1px solid var(--border);
}

/* ============================================================
   HYBRID UX — LAYER 2: Personalization hook
   ============================================================ */
.person-hook {
  background: #f8f9fa;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 18px;
}
.person-hook-line {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.6;
}
.person-hook-signals {
  font-size: 12.5px;
  font-weight: 500;
  color: var(--muted);
  margin-top: 6px;
  line-height: 1.6;
}

/* ============================================================
   HYBRID UX — LAYER 4: Action cards
   ============================================================ */
.action-cards {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 16px;
}
.action-card {
  padding: 20px;
  background: #ffffff !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px;
  box-shadow: 0 4px 20px rgba(63, 168, 190, 0.04);
  transition: all 0.2s ease;
}
.action-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(63, 168, 190, 0.08);
  border-color: var(--accent) !important;
}
.action-card-hdr {
  display: flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 12px;
  border-bottom: 1px solid rgba(63, 168, 190, 0.06);
  padding-bottom: 10px;
}
.action-card-label {
  font-size: 15px;
  font-weight: 800;
  color: var(--text);
  font-family: var(--font-ui);
  line-height: 1.2;
}
.action-card-sub {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  font-family: var(--font-ui);
  color: var(--accent);
  background: var(--accent-bg);
  padding: 4px 10px;
  border-radius: 20px;
  margin-left: auto;
}
.action-card-icon {
  font-size: 16px;
  color: var(--accent);
  font-variation-settings: 'FILL' 1;
  flex-shrink: 0;
}
.action-item-icon {
  font-size: 14px;
  color: var(--accent);
  font-variation-settings: 'FILL' 1;
  flex-shrink: 0;
  margin-top: 2px;
}
.action-card-items {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.action-card-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  line-height: 1.55;
  font-family: var(--font-reading);
  cursor: pointer;
  padding: 6px 8px;
  margin: -6px -8px;
  border-radius: 8px;
  transition: background 0.2s, opacity 0.25s;
}
.action-card-item:hover {
  background: rgba(63, 168, 190, 0.06);
}
.action-card-item.checked {
  opacity: 0.55;
}
.action-card-item.checked .action-item-text {
  text-decoration: line-through;
  color: var(--muted);
}
.action-item-text {
  transition: color 0.25s;
}
.action-item-bullet {
  flex-shrink: 0;
  color: var(--accent) !important;
  font-size: 16px !important;
  line-height: 1 !important;
  margin-top: 2px !important;
  user-select: none;
}

/* ============================================================
   7-DAY PLAN CARDS
   ============================================================ */
.day-plan-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.day-card {
  border-radius: 10px;
  background: #f8fbfc;
  padding: 11px 13px;
  border: 1px solid var(--border);
}
.day-card-start {
  background: #f3f4f6;
  border-color: #e2e5e9;
}
.day-card-skip {
  margin-left: auto;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--accent);
  background: var(--accent-bg);
  padding: 2px 8px;
  border-radius: 99px;
  font-family: var(--font-ui);
  flex-shrink: 0;
}
.day-card-tasks-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 12px;
}
.day-card-hdr {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 5px;
  margin-bottom: 12px;
}
.day-card-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  gap: 8px;
}
.day-card-meta-row {
  display: flex;
  align-items: center;
  gap: 6px;
}
.day-card-icon {
  font-size: 14px;
  color: var(--muted);
  flex-shrink: 0;
  opacity: .7;
}
.day-card-check {
  font-size: 13px;
  color: var(--muted);
  flex-shrink: 0;
  margin-top: 2px;
  opacity: .5;
}
.day-card-range {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .07em;
  text-transform: uppercase;
  font-family: var(--font-ui);
  color: var(--muted);
  flex-shrink: 0;
}
.day-card-title {
  font-size: 14.5px;
  font-weight: 700;
  color: var(--text);
  font-family: var(--font-ui);
  line-height: 1.35;
}
.day-card-tasks {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.day-card-task {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 14.5px;
  font-weight: 400;
  color: var(--text);
  line-height: 1.55;
  font-family: var(--font-reading);
}

/* ============================================================
   WHAT THIS IS NOT — pill grid
   ============================================================ */
.not-label {
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--muted);
  margin-bottom: 10px;
  font-family: var(--font-ui);
}
.not-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 9px;
  margin-bottom: 14px;
}
.not-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #fdf0f5;
  border: 1px solid #f5c0d4;
  border-radius: 20px;
  padding: 8px 12px;
  font-size: 13px;
  font-weight: 600;
  color: #5d1f3b;
  font-family: var(--font-ui);
  transition: all 0.2s ease;
}
.not-pill:hover {
  background: #fbe6ee;
  border-color: #f0a3c2;
  transform: translateY(-1px);
}
.not-specific {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  border: 1px solid rgba(192, 64, 122, 0.12);
  border-left: 4px solid #c0407a;
  border-radius: 4px 12px 12px 4px;
  background: rgba(192, 64, 122, 0.04);
  padding: 14px 16px;
  font-size: 13.5px;
  font-weight: 500;
  color: #5d1f3b;
  line-height: 1.6;
  margin-bottom: 16px;
  box-shadow: 0 2px 12px rgba(192, 64, 122, 0.02);
  font-family: var(--font-reading);
}
.mirror-quote {
  position: relative;
  background: linear-gradient(135deg, #fffcfd 0%, #fdf5f8 100%);
  border: 1px solid #f9dae5;
  border-radius: 12px;
  padding: 16px 20px;
  font-style: italic;
  font-size: 13.5px;
  font-weight: 600;
  color: #9f2d5e;
  line-height: 1.65;
  text-align: center;
  box-shadow: 0 4px 16px rgba(192, 64, 122, 0.03);
  margin-top: 16px;
  font-family: var(--font-reading);
}
.mirror-quote::before {
  content: '“';
  position: absolute;
  top: -12px;
  left: 20px;
  font-size: 48px;
  font-family: Georgia, serif;
  color: rgba(192, 64, 122, 0.12);
  line-height: 1;
}

/* ============================================================
   HYBRID UX — LAYER 5: Deep dive label separator
   ============================================================ */
.deep-dive-label {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .04em;
  color: var(--accent);
  text-align: center;
  padding: 20px 0 8px;
  opacity: 0.85;
  border-top: 1px solid var(--border);
  margin-top: 8px;
}

/* ============================================================
   REPORT PROGRESS BAR
   ============================================================ */
#reportProgress {
  position: fixed;
  top: 0;
  left: 0;
  width: 0%;
  height: 3px;
  background: var(--accent);
  z-index: 1000;
  transition: width 0.1s linear;
  border-radius: 0 2px 2px 0;
}

/* ============================================================
   CONTEXT NAV (sidebar, desktop only)
   ============================================================ */
#ctxNav {
  display: none;
  position: fixed;
  top: 50%;
  right: 12px;
  transform: translateY(-50%);
  z-index: 900;
  flex-direction: column;
  gap: 6px;
  width: 132px;
}
@media (min-width: 560px) {
  #ctxNav { display: flex; }
}
.ctx-nav-item {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 6px 10px 6px 8px;
  border-radius: 10px;
  cursor: pointer;
  text-decoration: none;
  background: rgba(255,255,255,0.85);
  border: 1.5px solid var(--border);
  backdrop-filter: blur(6px);
  transition: background 0.15s, border-color 0.15s, transform 0.15s;
  user-select: none;
}
.ctx-nav-item:hover {
  background: #fff;
  border-color: var(--accent);
  transform: translateX(-2px);
}
.ctx-nav-item.active {
  background: var(--accent);
  border-color: var(--accent);
}
.ctx-nav-item.active .ctx-nav-label,
.ctx-nav-item.active .material-symbols-outlined {
  color: #fff;
}
.ctx-nav-icon {
  font-size: 15px;
  line-height: 1;
  color: var(--accent);
  flex-shrink: 0;
}
.ctx-nav-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-family: var(--font-ui);
}

/* ============================================================
   BRAIN MECHANISM SECTION
   ============================================================ */
.brain-intro {
  font-size: 14px;
  font-weight: 400;
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 12px;
}
.brain-section {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 16px;
}
.brain-entry {
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 20px;
  box-shadow: 0 4px 20px rgba(63, 168, 190, 0.04);
  transition: all 0.2s ease;
}
.brain-entry:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(63, 168, 190, 0.08);
  border-color: var(--accent);
}
.brain-entry-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}
.brain-entry-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.brain-entry-title {
  font-size: 16px;
  font-weight: 800;
  color: var(--text);
  font-family: var(--font-ui);
}
.brain-entry-body {
  font-size: 14.5px;
  font-weight: 400;
  line-height: 1.75;
  color: var(--text);
  margin-top: 8px;
  font-family: var(--font-reading);
}
.brain-entry-callout {
  font-size: 13.5px;
  font-weight: 500;
  line-height: 1.65;
  color: var(--text);
  font-family: var(--font-ui);
  border-left: 3px solid;
  padding: 7px 12px;
  background: #f8f9fa;
  border-radius: 0 8px 8px 0;
}
.sys-why {
  display: flex;
  align-items: flex-start;
  gap: 7px;
  margin-top: 10px;
  padding: 8px 10px;
  background: #f8f9fa;
  border-radius: 8px;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--muted);
  line-height: 1.6;
  font-family: var(--font-ui);
}
.brain-entry-range {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 2px;
  font-family: var(--font-ui);
}
.plan-tasks {
  display: flex;
  flex-direction: column;
  gap: 3px;
  margin-top: 8px;
}
.plan-task {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 5px 8px;
  border-radius: 7px;
  background: transparent;
  transition: background 0.12s;
}
.plan-task:hover {
  background: #f5f7f9;
}
.plan-task-n {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 3px;
  font-family: var(--font-ui);
  color: var(--muted);
  border: none;
}
.plan-task-text {
  font-size: 14px;
  font-weight: 400;
  line-height: 1.65;
  color: var(--text);
  font-family: var(--font-reading);
}

/* ============================================================
   TL;DR SNAPSHOT CARD — redesign
   ============================================================ */
.tldr-card {
  margin-bottom: 8px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

/* ── Body white background ── */
.tldr-body {
  background: #fff;
}

/* ── Data rows (icon + label + value) ── */
.tldr-rows {
  padding: 4px 0 8px;
  border-bottom: 1px solid var(--border);
}
.tldr-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  border-bottom: 1px solid rgba(0,0,0,0.04);
}
.tldr-row:last-child {
  border-bottom: none;
}
.tldr-row-icon {
  width: 28px;
  height: 28px;
  border-radius: 7px;
  background: #f0f4f8;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--teal);
}
.tldr-row-icon .material-symbols-outlined {
  font-size: 15px;
  font-variation-settings: 'FILL' 1;
}
.tldr-row-body {
  display: flex;
  flex-direction: row;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
  flex-wrap: wrap;
}
.tldr-row-label {
  font-size: 10px;
  font-weight: 700;
  color: var(--muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-family: var(--font-ui);
  white-space: nowrap;
  flex-shrink: 0;
}
.tldr-row-value {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  font-family: var(--font-ui);
  line-height: 1.3;
}

/* ── Divider ── */
.tldr-divider {
  display: none;
}

/* ── Start here section ── */
.tldr-start-hdr {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 2px;
  padding: 14px 18px 10px;
  font-size: 12px;
  font-weight: 800;
  color: #c0407a;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-family: var(--font-ui);
}
.tldr-start-hdr .material-symbols-outlined {
  color: #c0407a;
}
.tldr-steps {
  padding: 6px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.tldr-step {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.tldr-step-num {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #fce8f0;
  color: #c0407a;
  font-size: 11px;
  font-weight: 800;
  font-family: var(--font-ui);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}
.tldr-step-text {
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--text);
  font-family: var(--font-reading);
}
.tldr-step-text strong {
  font-weight: 700;
  color: var(--text);
}

.action-text {
  font-size: 14px;
  font-weight: 400;
  font-family: var(--font-reading);
  line-height: 1.65;
}
.action-group-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 10px;
  padding-bottom: 6px;
  border-bottom: 1.5px solid var(--border);
}

/* ============================================================
   NL (not-laziness) block reading size
   ============================================================ */
.not-laziness-block {
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  padding: 18px;
}
.nl-title {
  font-size: 14px;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 12px;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.nl-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 14px;
}
.nl-item {
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text);
  display: flex;
  align-items: flex-start;
  gap: 6px;
}
.nl-x { color: var(--accent); font-weight: 900; }
.nl-specific {
  font-size: 15px;
  font-family: var(--font-reading);
  font-weight: 400;
  color: var(--text);
  line-height: 1.8;
  margin-bottom: 12px;
  padding: 12px 14px;
  background: #fff;
  border-radius: 10px;
  border-left: 3px solid var(--accent);
  border: 1px solid var(--border);
  border-left-width: 3px;
  border-left-color: var(--accent);
}
.nl-footer {
  font-size: 14px;
  font-family: var(--font-reading);
  font-weight: 400;
  color: var(--muted);
  line-height: 1.75;
  font-style: italic;
}

/* ============================================================
   MID-REPORT NOTION BLOCK
   Sits between "What to Do Next" and the deep-dive sections.
   Styled to stand out from content but feel native.
   ============================================================ */
.mid-notion-block {
  margin: 16px 0 24px;
  border-radius: 18px;
  border: 1px solid rgba(63, 168, 190, 0.25);
  background: linear-gradient(135deg, #f3fcfd 0%, #eaf8fa 100%);
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(63, 168, 190, 0.06);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1), border-color 0.3s;
}
.mid-notion-block:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(63, 168, 190, 0.11);
  border-color: rgba(63, 168, 190, 0.45);
}
.mid-notion-eyebrow {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 11px 18px 9px;
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  color: var(--accent);
  font-family: var(--font-ui);
  border-bottom: 1px solid rgba(63, 168, 190, 0.15);
  background: rgba(63, 168, 190, 0.02);
}
.mid-notion-eyebrow span.material-symbols-outlined {
  transition: transform 0.3s ease;
}
.mid-notion-block:hover .mid-notion-eyebrow span.material-symbols-outlined {
  transform: rotate(15deg) scale(1.15);
}
.mid-notion-prescribe {
  padding: 16px 18px 4px;
  font-size: 14.5px;
  font-weight: 600;
  color: var(--text);
  font-family: var(--font-reading);
  line-height: 1.55;
}
.mid-notion-card { background: transparent; }
.mid-notion-body {
  display: flex;
  gap: 20px;
  align-items: center;
  padding: 14px 18px 18px;
}
.mid-notion-img-wrap {
  flex-shrink: 0;
  width: 220px;
  height: 220px;
  background: #141416;
  overflow: hidden;
  border-radius: 12px;
  position: relative;
  padding-top: 18px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
  border: 1px solid rgba(255, 255, 255, 0.08);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.mid-notion-img-wrap::before {
  content: "";
  position: absolute;
  top: 6px;
  left: 10px;
  display: flex;
  gap: 4px;
  width: 32px;
  height: 6px;
  background: radial-gradient(circle, #ff5f56 2px, transparent 2.5px),
              radial-gradient(circle, #ffbd2e 2px, transparent 2.5px),
              radial-gradient(circle, #27c93f 2px, transparent 2.5px);
  background-size: 8px 6px;
  background-repeat: no-repeat;
  background-position: 0px 0, 10px 0, 20px 0;
  opacity: 0.85;
}
.mid-notion-block:hover .mid-notion-img-wrap {
  transform: translateY(-2px) scale(1.01);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.25);
}
.mid-notion-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  border-radius: 0 0 11px 11px;
}
.mid-notion-content {
  flex: 1;
  min-width: 0;
  padding: 0 0 0 10px;
}
.mid-notion-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 10.5px;
  font-weight: 700;
  color: var(--accent);
  font-family: var(--font-ui);
  margin-bottom: 8px;
  padding: 4px 10px;
  background: var(--accent-bg);
  border-radius: 6px;
  border: 1px solid rgba(63, 168, 190, 0.15);
}
.mid-notion-title {
  font-size: 19px;
  font-weight: 800;
  color: var(--text);
  font-family: var(--font-ui);
  line-height: 1.25;
  margin-bottom: 3px;
}
.mid-notion-subtitle {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--muted);
  font-family: var(--font-ui);
  margin-bottom: 12px;
}
.mid-notion-hook {
  font-size: 12.5px;
  color: var(--muted);
  font-family: var(--font-reading);
  line-height: 1.5;
  margin-bottom: 8px;
}
.mid-notion-features { display: flex; flex-direction: column; gap: 6px; }
.mid-notion-feature {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13px;
  color: var(--text);
  font-family: var(--font-ui);
  line-height: 1.4;
}
.mid-notion-feature span.material-symbols-outlined {
  font-size: 15px !important;
  margin-top: 1.5px;
  color: var(--accent) !important;
}
.mid-notion-footer {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 18px;
  border-top: 1px solid rgba(63, 168, 190, 0.15);
  background: rgba(255, 255, 255, 0.6);
  flex-wrap: wrap;
}
.mid-notion-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 22px;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent2) 100%);
  color: #fff;
  font-size: 13.5px;
  font-weight: 700;
  font-family: var(--font-ui);
  border-radius: 99px;
  text-decoration: none;
  box-shadow: 0 4px 14px rgba(63, 168, 190, 0.25);
  transition: transform 0.2s, box-shadow 0.2s, opacity 0.2s;
}
.mid-notion-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(63, 168, 190, 0.45);
  opacity: 0.98;
}
.mid-notion-btn:active {
  transform: translateY(1px) scale(0.98);
}
.mid-notion-note {
  font-size: 10.5px;
  color: var(--muted);
  font-family: var(--font-ui);
}

/* ── Closing card upgrades ── */
.result-closing-eyebrow {
  display: flex;
  align-items: center;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--accent);
  font-family: var(--font-ui);
  margin-bottom: 8px;
}
.result-closing-title {
  font-size: 18px;
  font-weight: 800;
  color: var(--text);
  font-family: var(--font-ui);
  line-height: 1.3;
  margin-bottom: 10px;
}
.result-closing-body {
  font-size: 14px;
  color: var(--muted);
  font-family: var(--font-reading);
  line-height: 1.6;
  margin-bottom: 12px;
}
.result-closing-hints {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-bottom: 18px;
  padding: 10px 12px;
  background: var(--accent-bg);
  border-radius: 8px;
}
.result-closing-hint {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 500;
  color: var(--accent);
  font-family: var(--font-ui);
  line-height: 1.4;
}
.result-closing-cta { margin-bottom: 16px; }
.result-closing-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 22px;
  background: var(--accent);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  font-family: var(--font-ui);
  border-radius: 99px;
  text-decoration: none;
  transition: opacity 0.15s, transform 0.15s;
}
.result-closing-btn:hover { opacity: 0.88; transform: translateY(-1px); }

/* ============================================================
   PROMO — Resources section (books + tools only)
   Notion is now mid-report; this is the secondary touchpoint.
   ============================================================ */

/* ── Section intro block ── */
.promo-intro {
  margin: 8px 0 20px;
  padding: 16px 18px;
  border-radius: 12px;
  background: #fff;
  border: 1.5px solid var(--border);
}
.promo-intro-heading {
  font-size: 16px;
  font-weight: 800;
  color: var(--text);
  font-family: var(--font-ui);
  margin-bottom: 7px;
}
.promo-intro-body {
  font-size: 14px;
  color: var(--muted);
  font-family: var(--font-reading);
  line-height: 1.65;
}
.promo-intro-body strong {
  color: var(--text);
  font-weight: 700;
}
.promo-intro-bridge {
  font-size: 13px;
  color: var(--muted);
  font-family: var(--font-ui);
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
  line-height: 1.5;
}
.promo-intro-bridge strong {
  color: var(--accent);
  font-weight: 700;
}

/* Prescriptive bridge above Notion card */
.promo-notion-prescribe {
  font-size: 13px;
  font-style: italic;
  color: var(--muted);
  font-family: var(--font-reading);
  line-height: 1.55;
  margin: 16px 0 8px;
  padding-left: 12px;
  border-left: 3px solid var(--accent);
}

/* ── Section subheading ── */
.promo-section-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  font-family: var(--font-ui);
  margin: 24px 0 10px;
}
.promo-section-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}

/* ── Notion card — matches report card style ── */
.promo-notion-card {
  border-radius: 14px;
  border: 1.5px solid var(--border);
  background: var(--accent-bg);
  overflow: hidden;
  margin: 0 0 20px;
}
.promo-notion-body {
  display: flex;
  gap: 14px;
  padding: 16px;
  align-items: flex-start;
}
.promo-notion-img-wrap {
  flex-shrink: 0;
  width: 68px;
  height: 68px;
  border-radius: 10px;
  overflow: hidden;
  background: #d0eef5;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
}
.promo-notion-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.promo-notion-content {
  flex: 1;
  min-width: 0;
}
.promo-notion-kicker {
  font-size: 9.5px;
  font-weight: 700;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-family: var(--font-ui);
  margin-bottom: 3px;
}
.promo-notion-title {
  font-size: 15px;
  font-weight: 800;
  color: var(--text);
  font-family: var(--font-ui);
  line-height: 1.25;
  margin-bottom: 4px;
}
.promo-notion-hook {
  font-size: 12px;
  color: var(--muted);
  font-family: var(--font-reading);
  line-height: 1.55;
  margin-bottom: 10px;
}
.promo-notion-features {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.promo-notion-feature {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10.5px;
  font-weight: 600;
  color: var(--text);
  font-family: var(--font-ui);
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 99px;
  padding: 3px 9px;
}
.promo-notion-footer {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  padding: 12px 16px;
  border-top: 1px solid var(--border);
  background: #fff;
}
.promo-notion-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 18px;
  background: var(--accent);
  color: #fff;
  border-radius: 99px;
  font-size: 12.5px;
  font-weight: 700;
  font-family: var(--font-ui);
  text-decoration: none;
  transition: opacity 0.15s, transform 0.12s;
  white-space: nowrap;
}
.promo-notion-btn:hover { opacity: 0.88; transform: translateY(-1px); }
.promo-notion-btn:active { transform: scale(0.97); }
.promo-notion-note {
  font-size: 10.5px;
  color: var(--muted);
  font-family: var(--font-ui);
  line-height: 1.5;
}

/* ── Resource list (table layout) ── */
.promo-carousel-wrap { display: block; }
.promo-carousel-btn { display: none; }

.promo-books-grid {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* ── List row ── */
.promo-book-card {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 14px;
  padding: 12px 8px;
  margin: 0 -8px;
  background: transparent;
  text-decoration: none;
  color: inherit;
  border-bottom: 1px solid var(--border);
  transition: background 0.15s, border-radius 0.15s;
  position: relative;
  border-radius: 8px;
}
.promo-book-card:last-child { border-bottom: none; }
.promo-book-card:hover { background: var(--accent-bg); }
.promo-book-card:active { background: #daf0f5; }

/* Thumbnail */
.promo-book-img-wrap {
  flex-shrink: 0;
  width: 62px;
  height: 80px;
  border-radius: 7px;
  overflow: hidden;
  background: var(--accent-bg);
  box-shadow: 0 1px 4px rgba(0,0,0,0.1);
  transition: transform 0.22s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.22s cubic-bezier(0.4, 0, 0.2, 1);
}
.promo-book-card:hover .promo-book-img-wrap {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 4px 10px rgba(0,0,0,0.14);
}
.promo-book-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 4px;
  background: #fff;
}

/* Row content */
.promo-book-body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.promo-book-tag {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 2px 8px;
  border-radius: 99px;
  font-family: var(--font-ui);
  width: fit-content;
  margin-bottom: 4px;
}
.promo-book-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  font-family: var(--font-ui);
  line-height: 1.3;
  white-space: normal;
  margin-bottom: 2px;
}
.promo-book-author {
  font-size: 12px;
  color: var(--muted);
  font-family: var(--font-ui);
  margin-bottom: 4px;
}
.promo-book-desc {
  font-size: 12.5px;
  color: var(--muted);
  font-family: var(--font-reading);
  line-height: 1.55;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.promo-book-card .promo-book-cta .material-symbols-outlined {
  transition: transform 0.22s cubic-bezier(0.4, 0, 0.2, 1);
}
.promo-book-card:hover .promo-book-cta .material-symbols-outlined {
  transform: translateX(3px);
}

/* Right side: CTA arrow */
.promo-book-meta-row {
  flex-shrink: 0;
  margin-left: auto;
  padding-left: 10px;
}
.promo-book-cta {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-size: 12px;
  font-weight: 700;
  color: var(--accent);
  font-family: var(--font-ui);
  white-space: nowrap;
}

/* ── Section block wrapper ── */
.promo-resource-block {
  border: none;
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  overflow: visible;
  margin-bottom: 24px;
}

/* Block header bar */
.promo-resource-block-hdr {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 0 10px 0;
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-family: var(--font-ui);
  border-bottom: 1.5px solid var(--border);
  color: var(--muted);
}
.promo-resource-block-hdr .material-symbols-outlined {
  font-size: 15px;
  font-variation-settings: 'FILL' 1;
}

/* Books — teal tint */
.promo-resource-block--books {
}
.promo-resource-block--books .promo-resource-block-hdr {
}

/* Tools — warm amber tint */
.promo-resource-block--tools {
}
.promo-resource-block--tools .promo-resource-block-hdr {
}

/* Rows inside block — no extra outer border */
.promo-resource-block .promo-books-grid {
  border: none;
  border-radius: 0;
  margin-bottom: 0;
  background: transparent;
}

/* Tools rows warm tint */
.promo-resource-block--tools .promo-books-grid {
  background: transparent;
}
.promo-resource-block--tools .promo-book-card {
  background: transparent;
  border-bottom-color: var(--border);
}
.promo-resource-block--tools .promo-book-card:hover {
  background: var(--accent-bg);
}

/* ============================================================
   AFFILIATE SIDEBAR — wide screens only (≥1140px)
   ============================================================ */
.aff-sidebar {
  display: none;
}
@media (min-width: 1140px) {
  .aff-sidebar {
    display: flex;
    flex-direction: column;
    gap: 0;
    position: fixed;
    top: 80px;
    right: calc(50% + 510px);
    width: 240px;
    max-height: calc(100vh - 100px);
    overflow-y: auto;
    scrollbar-width: none;
    z-index: 50;
  }
  .aff-sidebar::-webkit-scrollbar { display: none; }
}
@media (min-width: 1440px) {
  .aff-sidebar {
    width: 270px;
    right: calc(50% + 530px);
  }
}
.aff-sidebar-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
  font-family: var(--font-ui);
  padding: 4px 0 6px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 2px;
}
.aff-sidebar-label--books {
  margin-top: 16px;
}
.aff-notion-card {
  display: block;
  border-radius: 12px;
  overflow: hidden;
  border: 1.5px solid var(--border);
  background: var(--card-bg, #fff);
  text-decoration: none;
  transition: box-shadow 0.18s, border-color 0.18s;
}
.aff-notion-card:hover {
  box-shadow: 0 4px 20px rgba(63,168,190,0.15);
  border-color: var(--accent);
}
.aff-notion-img {
  width: 100%;
  height: 110px;
  object-fit: cover;
  object-position: top center;
  display: block;
  background: #1a1a1a;
}
.aff-notion-body {
  padding: 10px 12px 12px;
}
.aff-notion-kicker {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent);
  font-family: var(--font-ui);
  margin-bottom: 2px;
}
.aff-notion-title {
  font-size: 13px;
  font-weight: 800;
  color: var(--text);
  font-family: var(--font-ui);
  margin-bottom: 4px;
  line-height: 1.2;
}
.aff-notion-hook {
  font-size: 11.5px;
  color: var(--muted);
  font-family: var(--font-reading);
  line-height: 1.5;
  margin-bottom: 8px;
}
.aff-notion-cta {
  font-size: 11px;
  font-weight: 700;
  color: var(--accent);
  font-family: var(--font-ui);
}
.aff-book-row {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  color: inherit;
  transition: background 0.2s, padding-left 0.2s, border-radius 0.2s;
}
.aff-book-row:last-of-type { border-bottom: none; }
.aff-book-row:hover { background: var(--accent-bg); border-radius: 8px; padding-left: 8px; }
.aff-book-img {
  width: 44px;
  height: 58px;
  object-fit: contain;
  object-position: center;
  border-radius: 4px;
  flex-shrink: 0;
  background: #f5f7f9;
  transition: transform 0.2s, box-shadow 0.2s;
}
.aff-book-row:hover .aff-book-img {
  transform: scale(1.04);
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}
.aff-book-info { flex: 1; min-width: 0; }
.aff-book-tag {
  display: inline-flex;
  align-items: center;
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  font-family: var(--font-ui);
  padding: 2px 7px;
  border-radius: 99px;
  margin-bottom: 3px;
  white-space: nowrap;
  line-height: 1.3;
}
.aff-book-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  font-family: var(--font-ui);
  line-height: 1.3;
  margin-bottom: 4px;
}
.aff-book-link {
  font-size: 11px;
  font-weight: 600;
  color: var(--accent);
  font-family: var(--font-ui);
}

/* Affiliate note */
.promo-affiliate-note {
  font-size: 11px;
  color: var(--muted);
  font-family: var(--font-ui);
  text-align: center;
  margin-top: 12px;
  padding: 8px 12px;
  background: var(--accent-bg);
  border-radius: 8px;
  border: 1px solid var(--accent-border);
}


.c-icon {
  font-size: 32px;
  line-height: 1;
  user-select: none;
  opacity: 0.35;
  transition: opacity 0.25s, transform 0.25s;
  transform: scale(1);
}
.c-ring.sel .c-icon {
  opacity: 1;
  transform: scale(1.15);
}
.c-ring:hover .c-icon {
  opacity: 0.8;
}

/* ============================================================
   ANSWER PILLS  (replaces legacy .circles-group / .c-ring)
   ============================================================ */
.ans-pills-group {
  display: flex;
  flex-direction: column;
  gap: 9px;
  width: 100%;
  margin-bottom: 4px;
}
.ans-pill {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 13px 16px;
  border-radius: 14px;
  border: 1.5px solid var(--ans-border);
  background: var(--ans-bg);
  cursor: pointer;
  transition: border-color 0.18s, background 0.18s, transform 0.14s, box-shadow 0.18s;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
  position: relative;
}
.ans-pill:hover {
  border-color: var(--ans-fg);
  transform: translateX(3px);
}
.ans-pill:active {
  transform: scale(0.98);
}
.ans-pill.sel {
  background: var(--ans-sel-bg);
  border-color: var(--ans-sel-border);
  border-width: 2px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.07);
  transform: translateX(3px);
}
.ans-pill-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--ans-fg);
  opacity: 0.55;
  transition: opacity 0.18s, transform 0.18s;
  width: 26px;
}
.ans-pill.sel .ans-pill-icon {
  opacity: 1;
}
.ans-pill:hover .ans-pill-icon {
  opacity: 0.85;
}
.ans-pill-text {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.ans-pill-label {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
  transition: color 0.15s;
}
.ans-pill.sel .ans-pill-label {
  color: var(--ans-fg);
}
.ans-pill-sub {
  font-size: 11px;
  font-weight: 500;
  color: var(--muted);
  opacity: 0.7;
}
.ans-pill-check {
  flex-shrink: 0;
  color: var(--ans-fg);
  opacity: 0;
  transform: scale(0.4);
  transition: opacity 0.2s, transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.ans-pill.sel .ans-pill-check {
  opacity: 1;
  transform: scale(1);
}
@media (max-width: 480px) {
  .ans-pill {
    padding: 12px 13px;
    gap: 12px;
  }
  .ans-pill-label { font-size: 13.5px; }
}

/* Mobile chart bars - label + % same row, bar below */
@media (max-width: 640px) {
  .hero-chart {
    gap: 4px !important;
    padding: 6px 16px 14px !important;
    margin-top: 4px !important;
  }
  .hc-row {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 0 !important;
    padding: 0 !important;
  }
  /* Row 1: Label (left) + Percentage (right) */
  .hc-label {
    font-size: 12px !important;
    font-weight: 600 !important;
    color: var(--text) !important;
    flex: 1 1 auto !important;
    text-align: left !important;
    font-family: var(--font-ui) !important;
    line-height: 1 !important;
    order: 1 !important;
    margin: 0 8px 0 0 !important;
  }
  .hc-val {
    font-size: 12px !important;
    font-weight: 800 !important;
    width: 36px !important;
    flex: 0 0 36px !important;
    text-align: right !important;
    order: 2 !important;
    margin: 0 !important;
  }
  /* Row 2: Full width bar - flex-basis forces new line */
  .hc-track {
    flex: 0 0 100% !important;
    height: 24px !important;
    background: #eef1f5 !important;
    border-radius: 6px !important;
    overflow: hidden !important;
    order: 3 !important;
    margin-top: 2px !important;
  }
  .hc-bar {
    height: 100% !important;
    border-radius: 6px !important;
    display: block !important;
    min-width: 44px !important;
    transition: width 0.7s cubic-bezier(0.22, 1, 0.36, 1) !important;
  }

  /* Mobile radar chart - smaller and more compact */
  #chart-radar {
    padding: 4px 16px 14px !important;
    margin-top: 4px !important;
  }
  .radar-wrap {
    padding: 0 !important;
    margin: 0 !important;
  }
  .radar-svg {
    width: 100% !important;
    height: auto !important;
    max-width: 240px !important;
  }
  .radar-label {
    font-size: 12px !important;
    font-weight: 600 !important;
    fill: var(--text) !important;
  }
  .radar-pct {
    font-size: 11px !important;
    font-weight: 700 !important;
  }

  /* What to Do Next - Operating System mobile styles */
  .os-step {
    padding: 14px 0 !important;
    gap: 10px !important;
    border-top: 1px solid rgba(0,0,0,0.06) !important;
  }
  .os-step:first-of-type {
    border-top: none !important;
    padding-top: 0 !important;
  }
  .os-step-num {
    width: 26px !important;
    height: 26px !important;
    font-size: 12px !important;
    flex-shrink: 0 !important;
    font-weight: 700 !important;
  }
  .os-step-title {
    font-size: 15px !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
  }
  .os-step-subtitle {
    font-size: 10px !important;
    letter-spacing: 0.08em !important;
    margin-top: 2px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
  }
  .os-items {
    gap: 10px !important;
    padding: 4px 0 0 32px !important;
    margin-top: 4px !important;
  }
  .os-item {
    font-size: 13px !important;
    line-height: 1.5 !important;
  }

  /* Pattern breakdown - Your Pattern, Plainly */
  .exp-breakdown {
    padding: 14px 16px !important;
  }
  .pattern-intro {
    font-size: 13px !important;
    line-height: 1.6 !important;
    margin: 0 0 16px !important;
  }
  .pattern-subsec {
    margin: 14px 0 !important;
    padding: 12px 0 !important;
    border-top: 1px solid rgba(0,0,0,0.06) !important;
  }
  .pattern-subsec:first-of-type {
    border-top: none !important;
  }
  .pattern-subsec-header {
    display: flex !important;
    align-items: flex-start !important;
    gap: 12px !important;
    margin-bottom: 8px !important;
  }
  .pattern-subsec-icon {
    width: 40px !important;
    height: 40px !important;
    border-radius: 10px !important;
    flex-shrink: 0 !important;
  }
  .pattern-subsec-title {
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 1.35 !important;
    flex: 1 !important;
  }
  .pattern-subsec-body {
    font-size: 13px !important;
    line-height: 1.6 !important;
    padding-left: 52px !important;
  }

  /* Profile card mobile */
  .profile-desc {
    font-size: 12px !important;
    line-height: 1.5 !important;
    margin: 10px 0 !important;
  }
  .profile-title {
    font-size: 18px !important;
  }
  .profile-icon {
    width: 40px !important;
    height: 40px !important;
  }
}

/* What This Is Not grid - moved here to ensure it overrides desktop styles */
@media (max-width: 768px) {
  .not-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    margin-bottom: 16px !important;
    box-shadow: none !important;
  }
  .not-pill {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 12px 0 !important;
    border-bottom: 1px solid rgba(192, 64, 122, 0.08) !important;
    font-size: 13.5px !important;
    font-weight: 600 !important;
    color: #5d1f3b !important;
    transition: none !important;
  }
  .not-pill:last-child {
    border-bottom: none !important;
  }
  .not-pill:hover {
    background: transparent !important;
    transform: none !important;
    border-color: transparent !important;
  }
  .not-specific {
    padding: 12px 14px !important;
    font-size: 13px !important;
    line-height: 1.55 !important;
    margin-bottom: 12px !important;
  }
  .mirror-quote {
    padding: 12px 14px !important;
    font-size: 12.5px !important;
    margin-top: 12px !important;
  }
  .mirror-quote::before {
    font-size: 36px !important;
    top: -8px !important;
    left: 14px !important;
  }
}

/* ── ACCESSIBILITY: Dyslexic Font Override ─────────────────────────── */
html.dyslexic-font h1,
html.dyslexic-font h2,
html.dyslexic-font h3,
html.dyslexic-font .intro-title,
html.dyslexic-font .feature-title,
html.dyslexic-font .card-title,
html.dyslexic-font .q-title,
html.dyslexic-font .result-score-val,
html.dyslexic-font *:not(.material-symbols-outlined):not(.material-symbols-rounded):not(.material-icons) {
  font-family: "OpenDyslexic", "Comic Sans MS", sans-serif !important;
}
