/* =========================================================
   6. Diagnosis common
   ========================================================= */

.wsn-diagnosis-app .diagnosis-section {
  padding: var(--space-10) 0 var(--space-18);
}

body:not(.wsn-running) .wsn-diagnosis-app .diagnosis-section {
  display: none;
}

.wsn-diagnosis-app .diagnosis-card {
  min-height: 520px;
  padding: clamp(22px, 4vw, 44px);
  border-radius: var(--radius-lg);
}

/* The start screen carries little content, so don't reserve the full quiz
   height there (it created a large empty card on the landing view). The
   520px reservation only matters once the quiz/result is running, where it
   keeps the card height stable between steps. */
body:not(.wsn-running) .wsn-diagnosis-app .diagnosis-card {
  min-height: auto;
}

/* Once the diagnosis is running, collapse the hero's reassurance cue so the
   eyebrow + H1 + lead remain only as a slim banner above the active
   question/result. The single start CTA lives in the card itself. */
body.wsn-running .wsn-diagnosis-app .hero {
  padding-top: var(--space-9);
  padding-bottom: 0;
}

body.wsn-running .wsn-diagnosis-app .hero-brand-cue {
  display: none;
}

body.wsn-running .wsn-diagnosis-app .hero-actions {
  display: none;
}

body.wsn-running .wsn-diagnosis-app .visitor-fields {
  display: none;
}

/* Start panel: one primary CTA, with the consult link as a secondary option. */
.wsn-diagnosis-app .start-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-top: var(--space-8);
}

.wsn-diagnosis-app .start-actions .start-secondary {
  align-self: center;
  width: auto;
}

.wsn-diagnosis-app .visitor-fields {
  margin-top: var(--space-8);
  padding: var(--space-6);
  background: var(--alpha-white-72);
  border: 1px solid var(--alpha-line-strong);
  border-radius: var(--radius-md);
}

.wsn-diagnosis-app .visitor-fields__title {
  margin: 0 0 var(--space-4);
  color: var(--primary-dark);
  font-size: .86rem;
  font-weight: 900;
}

.wsn-diagnosis-app .visitor-fields__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
}

.wsn-diagnosis-app .visitor-fields label {
  display: grid;
  gap: var(--space-2);
  min-width: 0;
  margin: 0;
}

.wsn-diagnosis-app .visitor-fields label span {
  color: var(--muted);
  font-size: .8rem;
  font-weight: 900;
}

.wsn-diagnosis-app .visitor-fields input,
.wsn-diagnosis-app .visitor-fields select {
  width: 100%;
  min-height: 44px;
  padding: 10px var(--space-4);
  color: var(--text);
  background: var(--color-white);
  border: 1px solid var(--line);
  border-radius: var(--space-3);
  font: inherit;
}

body.wsn-diagnosis-active .wsn-diagnosis-app .visitor-fields input[data-visitor-field],
body.wsn-diagnosis-active .wsn-diagnosis-app .visitor-fields select[data-visitor-field] {
  color: var(--text);
  -webkit-text-fill-color: var(--text);
  background-color: var(--color-white);
  border-color: var(--line);
  caret-color: var(--primary-dark);
}

body.wsn-diagnosis-active .wsn-diagnosis-app .visitor-fields input[data-visitor-field]::placeholder {
  color: #64748b;
  -webkit-text-fill-color: #64748b;
  opacity: 1;
}

body.wsn-diagnosis-active .wsn-diagnosis-app .visitor-fields input[data-visitor-field]::selection,
body.wsn-diagnosis-active .wsn-diagnosis-app .visitor-fields select[data-visitor-field]::selection {
  color: var(--text);
  -webkit-text-fill-color: var(--text);
  background: var(--alpha-primary-20);
}

body.wsn-diagnosis-active .wsn-diagnosis-app .visitor-fields input[data-visitor-field]:-webkit-autofill,
body.wsn-diagnosis-active .wsn-diagnosis-app .visitor-fields input[data-visitor-field]:-webkit-autofill:hover,
body.wsn-diagnosis-active .wsn-diagnosis-app .visitor-fields input[data-visitor-field]:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--text);
  box-shadow: 0 0 0 1000px var(--color-white) inset;
  transition: background-color 9999s ease-out;
}

body.wsn-diagnosis-active .wsn-diagnosis-app .visitor-fields select[data-visitor-field] option {
  color: var(--text);
  background: var(--color-white);
}

.wsn-diagnosis-app .visitor-fields input:focus,
.wsn-diagnosis-app .visitor-fields select:focus {
  color: var(--text);
  -webkit-text-fill-color: var(--text);
  background-color: var(--color-white);
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--alpha-primary-13);
  outline: none;
}

.wsn-diagnosis-app .visitor-fields__note {
  margin: var(--space-4) 0 0;
  color: var(--muted);
  font-size: .78rem;
  line-height: 1.6;
}

.wsn-diagnosis-app #start-screen .privacy-note {
  margin-top: var(--space-6);
}

.wsn-diagnosis-app .screen {
  display: none;
}

.wsn-diagnosis-app .screen.is-active {
  display: block;
  animation: wsnScreenLift var(--duration-ui) var(--ease-standard) both;
}

.wsn-diagnosis-app .screen h2 {
  margin: 0;
  font-size: clamp(1.7rem, 4vw, 2rem);
  line-height: 1.18;
  letter-spacing: var(--letter-tight);
}

body.wsn-diagnosis-active .wsn-diagnosis-app .screen h2,
body.wsn-diagnosis-active .wsn-diagnosis-app #question-title,
body.wsn-diagnosis-active .wsn-diagnosis-app #result-title,
body.wsn-diagnosis-active .wsn-diagnosis-app .recommendation h3,
body.wsn-diagnosis-active .wsn-diagnosis-app .cta-box h3 {
  color: var(--text);
  -webkit-text-fill-color: var(--text);
  background-image: none;
  -webkit-background-clip: border-box;
  background-clip: border-box;
}

.wsn-diagnosis-app .screen > p {
  color: var(--muted);
}

.wsn-diagnosis-app .feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-12);
}

.wsn-diagnosis-app .feature-box {
  padding: var(--space-8);
  background: var(--color-white);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
}

.wsn-diagnosis-app .feature-box span {
  font-size: 1.6rem;
}

.wsn-diagnosis-app .feature-box strong {
  display: block;
  margin-top: var(--space-3);
}

.wsn-diagnosis-app .feature-box p {
  margin: var(--space-2) 0 0;
  color: var(--muted);
  font-size: .92rem;
}

.wsn-diagnosis-app .progress-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-7);
  color: var(--muted);
  font-weight: 800;
}

.wsn-diagnosis-app #category-label {
  padding: var(--space-1) var(--space-4);
  color: var(--primary-dark);
  background: var(--bg-soft);
  border-radius: var(--radius-pill);
  font-size: .88rem;
}

.wsn-diagnosis-app .progress-track,
.wsn-diagnosis-app .meter-track {
  width: 100%;
  height: 12px;
  margin: var(--space-5) 0 30px;
  overflow: hidden;
  background: var(--color-progress-bg);
  border-radius: var(--radius-pill);
}

.wsn-diagnosis-app .progress-bar,
.wsn-diagnosis-app .meter-bar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--primary), var(--color-primary-light));
  border-radius: inherit;
  transition: width var(--duration-base) var(--ease-standard);
}

.wsn-diagnosis-app .progress-bar {
  position: relative;
  overflow: hidden;
}

.wsn-diagnosis-app .progress-bar::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, var(--alpha-white-58), transparent);
  transform: translateX(-110%);
}

.wsn-diagnosis-app .progress-bar.is-advancing::after {
  animation: progressShine .744s var(--ease-standard) both;
}

.wsn-diagnosis-app #question-title {
  margin-bottom: 26px;
}

/* =========================================================
   7. Choices / quiz actions
   ========================================================= */

.wsn-diagnosis-app .choices {
  display: grid;
  gap: var(--space-5);
}

.wsn-diagnosis-app .choice-button {
  position: relative;
  width: 100%;
  min-height: var(--choice-min-height);
  padding: var(--space-8) 54px var(--space-8) var(--space-9);
  overflow: hidden;
  color: var(--text);
  background: var(--color-white);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  text-align: left;
  cursor: pointer;
  will-change: transform, box-shadow;
  transition:
    transform var(--duration-fast) var(--ease-standard),
    border var(--duration-fast) var(--ease-standard),
    box-shadow var(--duration-fast) var(--ease-standard),
    background var(--duration-fast) var(--ease-standard);
}

.wsn-diagnosis-app .choice-button:hover,
.wsn-diagnosis-app .choice-button:focus-visible {
  transform: translateY(-1px);
  border-color: var(--alpha-primary-55);
  box-shadow: var(--shadow-soft);
  outline: none;
}

.wsn-diagnosis-app .choice-button::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at var(--tap-x, 50%) var(--tap-y, 50%), var(--alpha-primary-18), transparent 34%);
  opacity: 0;
  transform: scale(.9);
  transition:
    opacity var(--duration-ui) var(--ease-standard),
    transform var(--duration-ui) var(--ease-standard);
}

.wsn-diagnosis-app .choice-button::after {
  content: "→";
  position: absolute;
  right: var(--space-8);
  top: 50%;
  color: var(--primary);
  opacity: 0;
  font-weight: 900;
  transform: translateY(-50%) translateX(6px);
  transition:
    opacity var(--duration-fast) var(--ease-standard),
    transform var(--duration-fast) var(--ease-standard);
}

.wsn-diagnosis-app .choice-button:hover::after,
.wsn-diagnosis-app .choice-button:focus-visible::after,
.wsn-diagnosis-app .choice-button.is-selected::after {
  opacity: 1;
  transform: translateY(-50%) translateX(0);
}

.wsn-diagnosis-app .choice-button.is-selected {
  border-color: var(--alpha-primary-78);
  background: linear-gradient(180deg, var(--alpha-primary-pale-98), var(--color-white));
  box-shadow: var(--shadow-primary-soft);
  transform: translateY(-1px) scale(.997);
}

.wsn-diagnosis-app .choice-button.is-selected::before {
  opacity: 1;
  transform: scale(1.25);
}

.wsn-diagnosis-app .choice-button.is-disabled-after-choice {
  pointer-events: none;
}

.wsn-diagnosis-app .choice-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  margin-right: var(--space-4);
  color: var(--primary-dark);
  background: var(--bg-soft);
  border-radius: var(--radius-pill);
  font-weight: 900;
}

.wsn-diagnosis-app .choice-button.is-selected .choice-label {
  color: var(--color-white);
  background: var(--primary);
  box-shadow: 0 8px 18px var(--alpha-primary-22);
}

.wsn-diagnosis-app .quiz-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: 26px;
}

/* =========================================================
   9. Mascot / guide
   ========================================================= */

.wsn-diagnosis-app .mascot-stage {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 360px;
  isolation: isolate;
}

.wsn-diagnosis-app .mascot-stage::before {
  content: "";
  position: absolute;
  inset: 44px var(--space-8) var(--space-13);
  z-index: -2;
  background:
    radial-gradient(circle at 24% 22%, var(--alpha-primary-13), transparent 26%),
    radial-gradient(circle at 78% 18%, var(--alpha-accent-16), transparent 28%),
    var(--alpha-white-72);
  border: 1px solid var(--alpha-line-76);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
}

.wsn-diagnosis-app .mascot-stage::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 50px;
  z-index: -1;
  width: 220px;
  height: 34px;
  background: radial-gradient(ellipse, var(--alpha-dark-12), transparent 68%);
  border-radius: var(--radius-pill);
  transform: translateX(-50%);
  animation: mascotShadow var(--duration-float) ease-in-out infinite;
}

.wsn-diagnosis-app .mascot {
  width: min(86%, var(--mascot-size));
  height: auto;
  object-fit: contain;
  filter: var(--shadow-mascot);
  animation: mascotFloat var(--duration-float) ease-in-out infinite;
}

.wsn-diagnosis-app .mascot-small,
.wsn-diagnosis-app .mascot-result {
  flex: 0 0 auto;
  width: var(--mascot-small-size);
  height: var(--mascot-small-size);
  object-fit: contain;
  filter: var(--shadow-mascot-small);
  animation: mascotNod 1.6s ease-in-out infinite;
}

.wsn-diagnosis-app .mascot-result {
  width: var(--mascot-result-size);
  height: var(--mascot-result-size);
}

.wsn-diagnosis-app .mascot-small.is-cheering,
.wsn-diagnosis-app .mascot-result.is-cheering {
  animation: mascotCheer var(--duration-cheer) var(--ease-out) both;
}

.wsn-diagnosis-app .mascot-bubble {
  position: absolute;
  z-index: 2;
  max-width: 250px;
  padding: var(--space-4) var(--space-6);
  color: var(--primary-dark);
  background: var(--color-white);
  border: 1px solid var(--line);
  border-radius: 18px 18px 18px 4px;
  box-shadow: 0 14px 28px var(--alpha-dark-10);
  font-weight: 900;
}

.wsn-diagnosis-app .mascot-bubble-top {
  top: var(--space-9);
  left: var(--space-9);
  animation: bubblePop var(--duration-bubble) ease-in-out infinite;
}

.wsn-diagnosis-app .floating-icon {
  position: absolute;
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  color: var(--primary-dark);
  background: var(--alpha-white-88);
  border: 1px solid var(--alpha-line-80);
  border-radius: var(--radius-pill);
  box-shadow: 0 14px 28px var(--alpha-dark-10);
  font-weight: 900;
  animation: floatIcon 2.2s ease-in-out infinite;
}

.wsn-diagnosis-app .icon-check {
  right: 34px;
  top: 72px;
  color: var(--success);
}

.wsn-diagnosis-app .icon-gear {
  left: 36px;
  bottom: 98px;
  animation-delay: .3s;
}

.wsn-diagnosis-app .icon-lock {
  right: 54px;
  bottom: 70px;
  animation-delay: .55s;
}

.wsn-diagnosis-app .compact-card {
  box-shadow: var(--shadow-card);
}

.wsn-diagnosis-app .quiz-guide,
.wsn-diagnosis-app .result-mascot-row {
  display: flex;
  align-items: center;
  gap: var(--space-7);
  margin: 0 0 var(--space-10);
  padding: var(--space-6) var(--space-7);
  background: var(--alpha-primary-soft-86);
  border: 1px solid var(--alpha-line-strong);
  border-radius: var(--radius-lg);
}

.wsn-diagnosis-app .quiz-guide p,
.wsn-diagnosis-app .result-mascot-row p {
  margin: 0;
  color: var(--primary-dark);
  font-weight: 900;
}

.wsn-diagnosis-app .quiz-guide.is-cheering {
  background:
    radial-gradient(circle at 8% 35%, var(--alpha-accent-16), transparent 28%),
    var(--alpha-primary-soft-94);
  border-color: var(--alpha-accent-46);
  box-shadow: 0 14px 32px var(--alpha-accent-10);
}

.wsn-diagnosis-app .quiz-guide.is-cheering p {
  color: var(--color-warning-text);
}

.wsn-diagnosis-app .encourage-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin-left: var(--space-3);
  padding: 3px var(--space-3);
  color: var(--color-warning-text);
  background: var(--alpha-accent-13);
  border-radius: var(--radius-pill);
  font-size: .78rem;
  font-weight: 900;
  vertical-align: middle;
}

/* =========================================================
   10. Result
   ========================================================= */

.wsn-diagnosis-app .result-summary {
  display: grid;
  grid-template-columns: 190px minmax(0, 1fr);
  align-items: center;
  gap: var(--space-9);
  margin-top: var(--space-10);
  padding: var(--space-11);
  background: var(--bg-soft);
  border-radius: var(--radius-lg);
}

.wsn-diagnosis-app .result-score {
  text-align: center;
}

.wsn-diagnosis-app .result-score span {
  display: block;
  color: var(--primary-dark);
  font-size: 4rem;
  line-height: 1;
  font-weight: 950;
  letter-spacing: var(--letter-x-tight);
}

.wsn-diagnosis-app .result-score small {
  color: var(--muted);
  font-weight: 800;
}

.wsn-diagnosis-app .result-summary p {
  margin: 0;
  font-size: 1.06rem;
}

.wsn-diagnosis-app .risk-meter {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--space-5);
  margin-top: var(--space-8);
  color: var(--muted);
  font-weight: 800;
}

.wsn-diagnosis-app .meter-track {
  margin: 0;
}

.wsn-diagnosis-app .recommendation,
.wsn-diagnosis-app .cta-box {
  margin-top: var(--space-11);
  padding: var(--space-11);
  background: var(--color-white);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
}

.wsn-diagnosis-app .recommendation h3,
.wsn-diagnosis-app .cta-box h3 {
  margin: 0 0 var(--space-5);
}

body.wsn-diagnosis-active .wsn-diagnosis-app .section-kicker,
body.wsn-diagnosis-active .wsn-diagnosis-app .progress-row,
body.wsn-diagnosis-active .wsn-diagnosis-app .risk-meter,
body.wsn-diagnosis-active .wsn-diagnosis-app .result-score small,
body.wsn-diagnosis-active .wsn-diagnosis-app .cta-box p {
  -webkit-text-fill-color: currentColor;
}

.wsn-diagnosis-app .recommendation ul {
  margin: 0;
  padding-left: 1.3em;
}

.wsn-diagnosis-app .cta-label {
  display: inline-block;
  margin: 0 0 var(--space-4);
  color: var(--accent);
  font-weight: 900;
}

.wsn-diagnosis-app .cta-box p {
  color: var(--muted);
}

.wsn-diagnosis-app .copy-status {
  color: var(--success);
  font-weight: 800;
}

.wsn-diagnosis-app .score-detail,
.wsn-diagnosis-app .save-log,
.wsn-diagnosis-app .is-public-note {
  background: var(--color-result-surface);
}

.wsn-diagnosis-app .score-detail {
  border-color: var(--alpha-primary-16);
}

.wsn-diagnosis-app .score-detail h3::before {
  content: "";
}

.wsn-diagnosis-app .score-bars {
  display: grid;
  gap: var(--space-5);
  margin-top: var(--space-4);
}

.wsn-diagnosis-app .score-bar-row {
  display: grid;
  grid-template-columns: 92px 1fr 54px;
  align-items: center;
  gap: var(--space-5);
  font-size: .94rem;
}

.wsn-diagnosis-app .public-score-row {
  grid-template-columns: 148px 1fr 86px;
}

.wsn-diagnosis-app .public-score-row span {
  font-weight: 800;
}

.wsn-diagnosis-app .public-score-row strong {
  color: var(--primary-dark);
  font-size: .92rem;
  text-align: right;
  white-space: nowrap;
}

.wsn-diagnosis-app .score-bar-track {
  height: 12px;
  overflow: hidden;
  background: var(--color-progress-bg);
  border-radius: var(--radius-pill);
}

.wsn-diagnosis-app .score-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--primary), var(--color-primary-light));
  border-radius: inherit;
}

.wsn-diagnosis-app .confidence-label {
  margin: var(--space-6) 0 0;
  color: var(--primary-dark);
  font-weight: 900;
}

.wsn-diagnosis-app .save-log p,
.wsn-diagnosis-app .is-public-note p {
  color: var(--muted);
}

.wsn-diagnosis-app .is-public-note p {
  margin-bottom: 0;
}

.wsn-diagnosis-app .save-log ol,
.wsn-diagnosis-app #reason-list {
  margin: var(--space-4) 0 0;
  padding-left: 1.3em;
}

.wsn-diagnosis-app .save-log li,
.wsn-diagnosis-app #reason-list li {
  margin-top: var(--space-2);
}

.wsn-diagnosis-app .result-mascot-row {
  position: relative;
  overflow: hidden;
}

.wsn-diagnosis-app .result-mascot-row::after {
  content: "";
  position: absolute;
  top: -70px;
  right: -50px;
  width: 140px;
  height: 140px;
  background: radial-gradient(circle, var(--alpha-accent-26), transparent 68%);
  border-radius: var(--radius-pill);
}

/* =========================================================
   11. Explain section
   ========================================================= */

.wsn-diagnosis-app .explain-section {
  padding: 66px 0 var(--space-20);
  background: var(--alpha-white-52);
  border-top: 1px solid var(--alpha-line-soft);
}

.wsn-diagnosis-app .explain-grid {
  display: grid;
  grid-template-columns: minmax(0, .78fr) minmax(0, 1fr);
  gap: var(--space-12);
}

.wsn-diagnosis-app .explain-grid h2 {
  margin: 0;
  font-size: clamp(1.7rem, 3vw, 2.5rem);
  line-height: 1.2;
  letter-spacing: var(--letter-tight);
}

.wsn-diagnosis-app .explain-list {
  display: grid;
  gap: var(--space-6);
}

.wsn-diagnosis-app .explain-list article {
  padding: var(--space-9);
  background: var(--color-white);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
}

.wsn-diagnosis-app .explain-list h3,
.wsn-diagnosis-app .explain-list p {
  margin: 0;
}

.wsn-diagnosis-app .explain-list p {
  margin-top: var(--space-2);
  color: var(--muted);
}
