/* ============================================================================
   AI READINESS DIAGNOSTIC, PRIORITY RANKING SCREENS (v2 extension)
   The two "bridge" screens shown after Q15, before results. Light world,
   continuation of the question flow. Depends on tokens.css + app.css +
   screens.css (reuses .scr, .scr-top, .option, .progress).
   ========================================================================== */

.scr-priority { background: var(--paper-50); color: var(--text-strong); }
.scr-priority .scr-top { color: var(--text-strong); border-bottom: 1px solid var(--paper-200); }
.scr-priority .scr-top__exit { margin-left: auto; font-size: var(--fs-sm); font-weight: var(--w-semibold); color: var(--text-muted); text-decoration: none; }

.scr-priority__body {
  padding: var(--space-6) var(--gutter-mobile) var(--space-10);
  max-width: 720px; margin: 0 auto; display: grid; gap: var(--space-6);
}

/* the "preparing your results" bridge progress -----------------------------*/
.progress--prep .progress__group { color: var(--brand-red); }
.progress--prep .progress__count { color: var(--text-muted); }
.progress--prep .progress__tick { background: var(--brand-red); opacity: 0.9; }

.scr-priority__q { display: grid; gap: var(--space-2); }
.scr-priority__num {
  font-size: var(--fs-eyebrow); font-weight: var(--w-bold); letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase; color: var(--text-muted);
}
.scr-priority h2 {
  font-size: clamp(1.4rem, 5cqi, 2rem); font-weight: var(--w-bold);
  line-height: 1.2; letter-spacing: var(--ls-heading); margin: 0; color: var(--text-strong); text-wrap: pretty;
}
.scr-priority__sub { font-size: var(--fs-lead); color: var(--text-body); margin: 0; line-height: 1.5; }
.scr-priority__hint { font-size: var(--fs-sm); color: var(--text-muted); margin: calc(var(--space-2) * -1) 0 0; }

/* the selectable / rankable cards -----------------------------------------*/
.priority-options { display: grid; gap: var(--space-3); }

.option.priority-option { cursor: pointer; align-items: center; box-sizing: border-box; min-width: 0; }
/* let the text wrap/shrink rather than push the card past its grid cell */
.priority-option .option__body { min-width: 0; }
/* unselected marker: an empty ring waiting for a rank */
.priority-option .option__marker { background: #fff; border-color: var(--paper-300); color: transparent; font-weight: var(--w-extrabold); }
/* selected: the rank badge , red fill, white number */
.priority-option.is-selected .option__marker {
  background: var(--brand-red); border-color: var(--brand-red); color: #fff;
}
.priority-option .option__text { font-weight: var(--w-medium); }

/* the up/down reorder control, only present when selected */
.prank {
  display: none; margin-left: auto; flex: none; align-self: center;
  flex-direction: column; gap: 3px;
}
.priority-option.is-selected .prank { display: flex; }
.prank__btn {
  width: 30px; height: 24px; display: grid; place-items: center;
  border: 1px solid var(--paper-300); background: #fff; border-radius: var(--radius-sm);
  color: var(--text-muted); cursor: pointer; padding: 0;
  transition: border-color var(--dur-instant), color var(--dur-instant), background var(--dur-instant);
}
.prank__btn:hover:not(:disabled) { border-color: var(--brand-red); color: var(--brand-red); }
.prank__btn:disabled { opacity: 0.32; cursor: default; }
.prank__btn svg { width: 14px; height: 14px; display: block; }

/* continue appears once at least one is chosen ----------------------------*/
.scr-priority__foot { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); }
.scr-priority__chosen { font-size: var(--fs-sm); color: var(--text-muted); font-weight: var(--w-semibold); }
.scr-priority__chosen b { color: var(--text-strong); }
.scr-priority__next {
  opacity: 0; transform: translateY(8px); pointer-events: none; margin-left: auto;
  transition: opacity var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.scr-priority.has-pick .scr-priority__next { opacity: 1; transform: none; pointer-events: auto; }

@container (min-width: 700px) {
  .scr-priority__body { padding-top: var(--space-12); gap: var(--space-8); }
  .priority-options { grid-template-columns: 1fr 1fr; }
  .scr-priority__next .btn { min-width: 200px; }
}

/* skip the prioritisation , default to weak foundations */
.scr-priority__skiprow { margin-top: calc(var(--space-4) * -1); }
.scr-priority.has-pick .scr-priority__skiprow { display: none; }
.scr-priority__skip {
  font-size: var(--fs-sm); font-weight: var(--w-semibold); color: var(--text-muted);
  text-decoration: underline; text-underline-offset: 3px; text-decoration-color: var(--paper-300);
  cursor: pointer;
}
.scr-priority__skip:hover { color: var(--brand-red); text-decoration-color: var(--brand-red); }
.scr-priority__skipnote {
  margin: var(--space-3) 0 0; font-size: var(--fs-sm); color: var(--text-body); line-height: 1.55; max-width: 56ch;
  padding-left: var(--space-4); border-left: 2px solid var(--rag-high);
}
