@import url("https://cdn.jsdelivr.net/npm/open-dyslexic@1.0.3/open-dyslexic-regular.min.css");

:root {
  /* â”€â”€ APP CHROME â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
     Depression palette: cool slate-blue, quiet and serious.          */
  --bg: #f0f2f8;
  --card: #fff;
  --border: #c8cce0be;
  --shadow: 0 16px 40px rgba(0, 0, 0, 0.04); /* Modern flat shadow */

  --text: #2d2a40;
  --muted: #7070a0;

  --accent: #4a6898;
  --accent2: #6080b0;
  --accent-bg: #eaeef8;

  --pink: #b05878;
  --pink-bg: #f8eef2;

  /* Dimension bars: m=Mood e=Energy c=Cognitive s=Self-Worth f=Functioning d=Dark */
  --dim-m-col: #5a7898;
  --dim-m-bg: #eef2f8;
  --dim-m-tc: #304060;

  --dim-e-col: #6b6b8a;
  --dim-e-bg: #f0f0f8;
  --dim-e-tc: #404060;

  --dim-c-col: #5a6a88;
  --dim-c-bg: #eef2f8;
  --dim-c-tc: #303858;

  --dim-s-col: #7a5870;
  --dim-s-bg: #f8f0f5;
  --dim-s-tc: #503050;

  --dim-f-col: #5a7870;
  --dim-f-bg: #eef8f5;
  --dim-f-tc: #305048;

  --dim-d-col: #7a4858;
  --dim-d-bg: #f8f0f2;
  --dim-d-tc: #502030;

  --tier-1: #8adaaa;
  --tier-2: #9ab8d8;
  --tier-3: #a8b0c8;
  --tier-4: #c0a870;
  --tier-5: #b07888;
  --tier-6: #905878;

  --spectrum-1: #8fd6a7;
  --spectrum-2: #9ab8d8;
  --spectrum-3: #c0a870;
  --spectrum-4: #b07888;
  --spectrum-5: #905878;

  --ans-1-border: #86efac;
  --ans-2-border: #bbf7d0;
  --ans-3-border: #cbd5e1;
  --ans-4-border: #fca5a5;
  --ans-5-border: #f87171;

  --ans-1-sel-bg: #c6f6d5;
  --ans-1-sel-bd: #52c07a;
  --ans-2-sel-bg: #dcfce7;
  --ans-2-sel-bd: #86d8a0;
  --ans-3-sel-bg: #e9ecef;
  --ans-3-sel-bd: #adb5bd;
  --ans-4-sel-bg: #fee2e2;
  --ans-4-sel-bd: #f07070;
  --ans-5-sel-bg: #fecaca;
  --ans-5-sel-bd: #e85050;

  --ans-1-label: #3aac78;
  --ans-2-label: #68c48e;
  --ans-3-label: #8090a0;
  --ans-4-label: #c07070;
  --ans-5-label: #c03050;

  --ins-teal-bg: #eef2f8;
  --ins-teal-bd: #b8c8d8;
  --ins-teal-h: #3a5878;

  --ins-pink-bg: #fff0f0;
  --ins-pink-bd: #f5a0a8;
  --ins-pink-h: #a03050;

  --ins-yellow-bg: #fffdf0;
  --ins-yellow-bd: #e0d888;
  --ins-yellow-h: #8a6810;

  --ins-purple-bg: #f8f0f5;
  --ins-purple-bd: #d0b0c0;
  --ins-purple-h: #7a4060;

  --ins-green-bg: #eef8f5;
  --ins-green-bd: #a8d0c8;
  --ins-green-h: #305048;

  --r: 22px;
  --r-sm: 14px;

  --font-ui: "Lexend", system-ui, sans-serif;
  --font-reading: "Lexend", system-ui, sans-serif;

  font-family: "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 - compact padding on mobile */
  .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;
  }

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

  /* Dimension bars - compact */
  .hero-dim-label {
    width: auto;
    min-width: 70px;
    font-size: 11px;
  }
  .hero-dim-bar-wrap {
    height: 8px;
  }
  .hero-dim-value {
    font-size: 11px;
    min-width: 30px;
  }

  /* 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;
  }
  .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;
  }

  /* Quick wins section */
  .quick-win-item {
    padding: 10px 0;
  }
  .quick-win-text {
    font-size: 13px;
  }

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

  /* Operating system steps */
  .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;
  }

  /* 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;
  }

  /* 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;
  }

  /* 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;
  }

  /* 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: 10px 12px 4px;
    font-size: 13px;
  }
  .mid-notion-body {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    padding: 12px;
  }
  .mid-notion-img-wrap {
    width: 100%;
    height: auto;
    max-height: 200px;
    border-radius: 8px;
  }
  .mid-notion-img {
    object-fit: contain;
  }
  .mid-notion-content {
    padding: 0;
    width: 100%;
  }
  .mid-notion-badge {
    font-size: 10px;
    padding: 3px 8px;
  }
  .mid-notion-title {
    font-size: 16px;
  }
  .mid-notion-subtitle {
    font-size: 12px;
    margin-bottom: 8px;
  }
  .mid-notion-features {
    gap: 4px;
  }
  .mid-notion-feature {
    font-size: 12px;
  }
  .mid-notion-footer {
    padding: 10px 12px;
    flex-direction: column;
    gap: 10px;
    align-items: flex-start;
  }
  .mid-notion-btn {
    width: 100%;
    justify-content: center;
    font-size: 12px;
    padding: 8px 12px;
  }
  .mid-notion-note {
    font-size: 10px;
  }

  /* Brain Section Mobile Overrides */
  .brain-section {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    margin-top: 16px !important;
    border-top: none !important;
    padding-top: 0 !important;
  }
  .brain-entry {
    background: #ffffff !important;
    border: 1px solid var(--border) !important;
    border-radius: 14px !important;
    padding: 16px !important;
    box-shadow: 0 4px 16px rgba(74, 104, 152, 0.05) !important;
    border-bottom: none !important;
  }
  .brain-entry:last-of-type {
    border-bottom: 1px solid var(--border) !important;
    padding-bottom: 16px !important;
  }
  .brain-entry-head {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin-bottom: 4px !important;
  }
  .brain-entry-icon {
    width: 36px !important;
    height: 36px !important;
    border-radius: 8px !important;
    flex-shrink: 0 !important;
  }
  .brain-entry-icon .material-symbols-outlined {
    font-size: 18px !important;
  }
  .brain-entry-title {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--text) !important;
    line-height: 1.3 !important;
    flex: 1 !important;
  }
  .brain-entry-body {
    font-size: 13.5px !important;
    line-height: 1.6 !important;
    color: var(--text) !important;
    padding-left: 0 !important;
    margin-top: 6px !important;
  }

  /* Action Cards Mobile Overrides */
  .action-cards {
    gap: 12px !important;
  }
  .action-card {
    padding: 16px !important;
  }
}

/* ============================================================
   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(74, 104, 152, 0.04);
  transition: all 0.2s ease;
}
.action-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(74, 104, 152, 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(74, 104, 152, 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-pill .material-symbols-outlined {
  color: #c0407a !important;
  font-variation-settings: 'FILL' 1 !important;
}
.not-specific {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  border: 1px solid rgba(74, 104, 152, 0.12);
  border-left: 4px solid #4a6898;
  border-radius: 4px 12px 12px 4px;
  background: rgba(74, 104, 152, 0.04);
  padding: 14px 16px;
  font-size: 13.5px;
  font-weight: 500;
  color: #2d3d5a;
  line-height: 1.6;
  margin-bottom: 16px;
  box-shadow: 0 2px 12px rgba(74, 104, 152, 0.02);
  font-family: var(--font-reading);
}
.mirror-quote {
  position: relative;
  background: linear-gradient(135deg, #f7f9fc 0%, #f1f4f8 100%);
  border: 1px solid #c4d4e8;
  border-radius: 12px;
  padding: 16px 20px;
  font-style: italic;
  font-size: 13.5px;
  font-weight: 600;
  color: #4a6898;
  line-height: 1.65;
  text-align: center;
  box-shadow: 0 4px 16px rgba(74, 104, 152, 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(74, 104, 152, 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(74, 104, 152, 0.04);
  transition: all 0.2s ease;
}
.brain-entry:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(74, 104, 152, 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: 6px;
}

/* ── 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: 12px 0 20px;
  border-radius: 16px;
  border: 2px solid var(--accent);
  background: linear-gradient(135deg, #f0fbfd 0%, #e6f7fa 100%);
  overflow: hidden;
}
.mid-notion-eyebrow {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 16px 8px;
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent);
  font-family: var(--font-ui);
  border-bottom: 1px solid rgba(63,168,190,0.2);
}
.mid-notion-prescribe {
  padding: 12px 16px 4px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  font-family: var(--font-reading);
  line-height: 1.5;
}
.mid-notion-card { background: transparent; }
.mid-notion-body {
  display: flex;
  gap: 14px;
  align-items: center;
  padding: 14px 16px;
}
.mid-notion-img-wrap {
  flex-shrink: 0;
  width: 220px;
  height: 220px;
  background: #1a1a1a;
  overflow: hidden;
  border-radius: 10px;
}
.mid-notion-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
}
.mid-notion-content {
  flex: 1;
  min-width: 0;
  padding: 14px 16px 14px;
}
.mid-notion-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  color: var(--accent);
  font-family: var(--font-ui);
  margin-bottom: 6px;
  padding: 4px 10px;
  background: var(--accent-bg);
  border-radius: 6px;
  border: 1px solid var(--accent-border);
}
.mid-notion-title {
  font-size: 18px;
  font-weight: 800;
  color: var(--text);
  font-family: var(--font-ui);
  line-height: 1.2;
  margin-bottom: 2px;
}
.mid-notion-subtitle {
  font-size: 13px;
  font-weight: 600;
  color: var(--muted);
  font-family: var(--font-ui);
  margin-bottom: 10px;
}
.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: 3px; }
.mid-notion-feature {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11.5px;
  color: var(--text);
  font-family: var(--font-ui);
}
.mid-notion-footer {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  border-top: 1px solid rgba(63,168,190,0.2);
  background: rgba(255,255,255,0.5);
  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.12s;
}
.aff-book-row:last-of-type { border-bottom: none; }
.aff-book-row:hover { background: var(--accent-bg); border-radius: 8px; padding-left: 6px; }
.aff-book-img {
  width: 44px;
  height: 58px;
  object-fit: contain;
  object-position: center;
  border-radius: 4px;
  flex-shrink: 0;
  background: #f5f7f9;
}
.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-pill .material-symbols-outlined {
    color: #c0407a !important;
    font-variation-settings: 'FILL' 1 !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;
  }
}

/* ── Recommended Books & Tools Flat List ── */
.promo-books-grid {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.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; }

.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;
}
.promo-book-body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.promo-book-tag {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-family: var(--font-ui);
  padding: 2.5px 7px;
  border-radius: 99px;
  margin-bottom: 4px;
  line-height: 1;
}
.promo-book-title {
  font-size: 13.5px;
  font-weight: 800;
  color: var(--text);
  font-family: var(--font-ui);
  line-height: 1.3;
}
.promo-book-author {
  font-size: 11.5px;
  color: var(--muted);
  font-family: var(--font-ui);
  margin-bottom: 3px;
}
.promo-book-desc {
  font-size: 12.5px;
  color: var(--muted);
  font-family: var(--font-reading);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.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;
}
.promo-book-card:hover .promo-book-cta .material-symbols-outlined {
  transform: translateX(3px);
}

/* ── Sidebar Recommended Books ── */
.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);
}
.aff-sidebar-label {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
  font-family: var(--font-ui);
  margin-top: 24px;
  margin-bottom: 8px;
  opacity: .75;
}
.aff-sidebar-label--books {
  margin-top: 24px;
}

/* ── 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;
}

