/* =========================================================
   RevOps Impact Score survey. Token-only; sits on the
   site-main glass strip. Alpine drives panel visibility.
   ========================================================= */

[x-cloak] { display: none !important; }

.revops { padding-block: clamp(1.5rem, 3vw, 2.5rem); }
.revops__inner { position: relative; }

.revops__panel { animation: revops-fade var(--dur-slow) var(--ease) both; }
@keyframes revops-fade {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: none; }
}

.revops__accent {
  background: var(--brand-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* ───────── INTRO ───────── */
.revops__intro {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}
.revops__title {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 5vw, 3.5rem);
  font-weight: var(--font-weight-display);
  letter-spacing: -0.025em;
  line-height: 1.05;
  margin: 1rem 0 0;
  color: var(--color-foreground);
}
.revops__lead {
  margin: 1.25rem 0 0;
  font-size: var(--fs-lg);
  line-height: 1.5;
  color: var(--color-muted-foreground);
  max-width: 44ch;
}
.revops__steps {
  list-style: none;
  margin: 1.75rem 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}
.revops__steps li {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  color: var(--color-foreground);
  line-height: 1.4;
}
.revops__step-n {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--font-weight-medium);
  color: var(--brand-teal);
  letter-spacing: 0.1em;
  flex: 0 0 auto;
}
.revops__foot {
  margin: 1rem 0 0;
  font-size: var(--fs-sm);
  color: var(--color-muted-foreground);
}

.revops__layers {
  position: relative;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-card);
  padding: 2.25rem;
  box-shadow: var(--shadow-sm);
}
.revops__layers-head {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-muted-foreground);
  margin-bottom: 1.25rem;
}
.revops__layers-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 1rem; }
.revops__layers-list li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.25rem 0.75rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--color-border);
}
.revops__layers-list li:last-child { border-bottom: 0; padding-bottom: 0; }
.revops__layer-tag {
  grid-row: 1 / 3;
  align-self: start;
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: var(--font-weight-medium);
  color: var(--brand-teal);
  border: 1px solid color-mix(in oklch, var(--brand-teal) 22%, transparent);
  background: color-mix(in oklch, var(--brand-teal) 8%, transparent);
  border-radius: var(--radius-sm);
  padding: 0.2rem 0.45rem;
}
.revops__layer-name { font-weight: var(--font-weight-display); color: var(--color-foreground); }
.revops__layer-desc { font-size: var(--fs-sm); color: var(--color-muted-foreground); }

/* ───────── QUESTION ───────── */
.revops__question { max-width: 52rem; margin-inline: auto; }
.revops__q-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1.5rem;
}
.revops__q-dim {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--fs-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-muted-foreground);
}
.revops__q-tag {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  color: var(--brand-teal);
  border: 1px solid color-mix(in oklch, var(--brand-teal) 22%, transparent);
  background: color-mix(in oklch, var(--brand-teal) 8%, transparent);
  border-radius: var(--radius-sm);
  padding: 0.2rem 0.45rem;
  letter-spacing: 0.08em;
}
.revops__q-progress { display: inline-flex; align-items: center; gap: 0.75rem; }
.revops__q-bar {
  width: clamp(120px, 28vw, 220px);
  height: 6px;
  border-radius: 999px;
  background: var(--color-muted);
  overflow: hidden;
}
.revops__q-fill {
  height: 100%;
  border-radius: 999px;
  background: var(--brand-gradient);
  transition: width var(--dur-slow) var(--ease);
}
.revops__q-count { font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--color-muted-foreground); }
.revops__q-of { opacity: 0.6; }

.revops__prompt {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3.2vw, 2.25rem);
  font-weight: var(--font-weight-display);
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--color-foreground);
  margin: 0 0 2rem;
  text-wrap: balance;
}

.revops__opts { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0.75rem; }
.revops-opt {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.5rem;
  min-height: 7.5rem;
  padding: 1rem;
  text-align: left;
  cursor: pointer;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-card);
  color: var(--color-foreground);
  transition: border-color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.revops-opt:hover { border-color: color-mix(in oklch, var(--brand-teal) 45%, var(--color-border)); transform: translateY(-2px); }
.revops-opt:focus-visible { outline: 2px solid var(--brand-teal); outline-offset: 2px; }
.revops-opt.is-selected {
  border-color: var(--brand-teal);
  background: color-mix(in oklch, var(--brand-teal) 8%, var(--color-card));
  box-shadow: 0 8px 20px -12px color-mix(in oklch, var(--brand-teal) 60%, transparent);
}
.revops-opt__label { font-weight: var(--font-weight-medium); font-size: var(--fs-sm); line-height: 1.25; }
.revops-opt__val {
  font-family: var(--font-mono);
  font-size: 1.25rem;
  font-weight: var(--font-weight-display);
  color: var(--color-muted-foreground);
}
.revops-opt.is-selected .revops-opt__val { color: var(--brand-teal); }

.revops__q-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 1.75rem;
  flex-wrap: wrap;
}
.revops__back {
  background: none;
  border: 0;
  cursor: pointer;
  font: inherit;
  font-size: var(--fs-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-muted-foreground);
  padding: 0.5rem 0;
}
.revops__back::before { content: "\2190"; margin-right: 0.4rem; }
.revops__back:hover { color: var(--brand-teal); }
.revops__hint { font-size: var(--fs-xs); color: var(--color-muted-foreground); }
.revops__hint kbd {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  border: 1px solid var(--color-border);
  border-bottom-width: 2px;
  border-radius: 4px;
  padding: 0.05rem 0.35rem;
  background: var(--color-card);
}

/* ───────── CAPTURE ───────── */
.revops__capture { max-width: 40rem; margin-inline: auto; }
.revops__capture-inner {
  position: relative;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-card);
  padding: clamp(1.75rem, 4vw, 2.75rem);
  box-shadow: var(--shadow-sm);
}
.revops__capture-title {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: var(--font-weight-display);
  letter-spacing: -0.02em;
  margin: 1rem 0 0.5rem;
  color: var(--color-foreground);
}
.revops__capture-sub { margin: 0 0 1.75rem; color: var(--color-muted-foreground); line-height: 1.5; }
.revops__hp { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; }
.revops__form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.revops-field { display: flex; flex-direction: column; gap: 0.4rem; margin-bottom: 1rem; }
.revops-field__label { font-size: var(--fs-sm); font-weight: var(--font-weight-medium); color: var(--color-foreground); }
.revops-field__req { color: var(--brand-teal); }
.revops-field__input {
  font: inherit;
  font-size: var(--fs-base);
  color: var(--color-foreground);
  background: var(--color-background);
  border: 1px solid var(--color-input);
  border-radius: var(--radius-md);
  padding: 0.7rem 0.85rem;
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.revops-field__input:focus {
  outline: none;
  border-color: var(--brand-teal);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--brand-teal) 18%, transparent);
}
.revops__error {
  margin: 0 0 1rem;
  font-size: var(--fs-sm);
  color: var(--color-destructive);
}
.revops__capture-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 0.5rem;
  flex-wrap: wrap;
}

/* ───────── RESULTS ───────── */
.revops__r-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted-foreground);
  text-align: center;
  margin-bottom: 1.5rem;
}
.revops__r-score {
  display: flex;
  align-items: center;
  gap: clamp(1.5rem, 4vw, 3rem);
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 3rem;
}
.revops__ring { position: relative; flex: 0 0 auto; width: 220px; height: 220px; }
.revops__ring-arc { transition: stroke-dashoffset 1.6s cubic-bezier(0.2, 0.7, 0.2, 1); }
.revops__ring-num {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: baseline;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 3.5rem;
  font-weight: var(--font-weight-display);
  color: var(--color-foreground);
  letter-spacing: -0.03em;
}
.revops__ring-suffix { font-size: 1.25rem; color: var(--color-muted-foreground); margin-left: 0.15rem; }
.revops__r-body { flex: 1 1 320px; min-width: 0; max-width: 38rem; }
.revops__band {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.1em;
  padding: 0.25rem 0.6rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  color: var(--color-muted-foreground);
  margin-bottom: 0.75rem;
}
.revops__band[data-band="leaking"]    { color: var(--color-destructive); border-color: color-mix(in oklch, var(--color-destructive) 35%, transparent); background: color-mix(in oklch, var(--color-destructive) 8%, transparent); }
.revops__band[data-band="foundation"] { color: var(--brand-blue); border-color: color-mix(in oklch, var(--brand-blue) 35%, transparent); background: color-mix(in oklch, var(--brand-blue) 8%, transparent); }
.revops__band[data-band="optimizing"] { color: var(--brand-teal); border-color: color-mix(in oklch, var(--brand-teal) 35%, transparent); background: color-mix(in oklch, var(--brand-teal) 8%, transparent); }
.revops__band[data-band="humming"]    { color: var(--color-success); border-color: color-mix(in oklch, var(--color-success) 35%, transparent); background: color-mix(in oklch, var(--color-success) 8%, transparent); }
.revops__r-headline {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  font-weight: var(--font-weight-display);
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin: 0 0 0.75rem;
  color: var(--color-foreground);
}
.revops__r-summary { margin: 0; color: var(--color-muted-foreground); line-height: 1.6; }

.revops__r-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 4vw, 3rem); margin-bottom: 3rem; }
.revops__r-title {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: var(--font-weight-display);
  letter-spacing: -0.015em;
  margin: 0 0 1.25rem;
  color: var(--color-foreground);
}
.revops__r-tag { font-size: var(--fs-sm); font-weight: var(--font-weight-text); color: var(--color-muted-foreground); }

.revops__dim { padding: 0.875rem 0; border-bottom: 1px solid var(--color-border); }
.revops__dim:last-child { border-bottom: 0; }
.revops__dim-head { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.5rem; }
.revops__dim-tag { font-family: var(--font-mono); font-size: 0.6875rem; color: var(--color-muted-foreground); }
.revops__dim-name { font-weight: var(--font-weight-medium); color: var(--color-foreground); }
.revops__dim-flag {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-destructive);
  border: 1px solid color-mix(in oklch, var(--color-destructive) 35%, transparent);
  border-radius: 999px;
  padding: 0.1rem 0.5rem;
}
.revops__dim-score { margin-left: auto; font-family: var(--font-mono); font-weight: var(--font-weight-display); color: var(--color-foreground); }
.revops__dim-bar { height: 8px; border-radius: 999px; background: var(--color-muted); overflow: hidden; }
.revops__dim-bar > div { height: 100%; border-radius: 999px; background: var(--brand-gradient); transition: width var(--dur-slow) var(--ease); }
.revops__dim.is-weak .revops__dim-bar > div { background: var(--color-destructive); }
.revops__dim-desc { margin-top: 0.5rem; font-size: var(--fs-sm); color: var(--color-muted-foreground); }

.revops__leak-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.75rem; }
.revops__leak {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-card);
}
.revops__leak-n { font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--brand-teal); }
.revops__leak-dim { display: flex; align-items: center; gap: 0.4rem; font-size: var(--fs-xs); color: var(--color-muted-foreground); margin-bottom: 0.2rem; }
.revops__leak-tag { font-family: var(--font-mono); }
.revops__leak-text { font-size: var(--fs-sm); color: var(--color-foreground); line-height: 1.35; }
.revops__leak-score { font-family: var(--font-mono); font-size: 1.125rem; font-weight: var(--font-weight-display); color: var(--color-foreground); }

/* Recommendation */
.revops__rec { margin-bottom: 2.5rem; }
.revops__rec-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted-foreground);
  margin-bottom: 1rem;
}
.revops__rec-card {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: center;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-card);
  padding: clamp(1.75rem, 4vw, 2.75rem);
  box-shadow: var(--shadow-sm);
}
.revops__rec-title {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: var(--font-weight-display);
  letter-spacing: -0.02em;
  margin: 0 0 0.75rem;
  color: var(--color-foreground);
}
.revops__rec-body { margin: 0 0 1.25rem; color: var(--color-muted-foreground); line-height: 1.55; }
.revops__rec-service { display: flex; flex-direction: column; gap: 0.2rem; }
.revops__rec-service-label { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-muted-foreground); }
.revops__rec-service-name { font-weight: var(--font-weight-display); color: var(--brand-teal); }
.revops__rec-meta { display: flex; gap: 1.5rem; }
.revops__rec-stat { flex: 1; }
.revops__rec-stat-num { font-family: var(--font-display); font-size: 2.5rem; font-weight: var(--font-weight-display); color: var(--color-foreground); letter-spacing: -0.03em; line-height: 1; }
.revops__rec-stat-unit { font-size: 1rem; color: var(--color-muted-foreground); margin-left: 0.15rem; }
.revops__rec-stat-label { margin-top: 0.4rem; font-size: var(--fs-xs); color: var(--color-muted-foreground); line-height: 1.3; }

/* Results CTA: dark band */
.revops__cta {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: center;
  border-radius: var(--radius-xl);
  background: var(--surface-dark-gradient);
  padding: clamp(1.75rem, 4vw, 3rem);
  /* On-dark token remap so the buttons + text invert correctly. */
  --color-foreground: var(--on-dark-foreground);
  --color-muted-foreground: var(--on-dark-muted-foreground);
  --color-border: var(--on-dark-border);
  --color-primary: var(--on-dark-foreground);
  --color-primary-foreground: var(--surface-dark-999);
  --color-accent: var(--on-dark-accent);
  color: var(--on-dark-foreground);
}
.revops__cta-eyebrow { font-family: var(--font-mono); font-size: var(--fs-xs); letter-spacing: 0.12em; text-transform: uppercase; color: var(--brand-teal); margin-bottom: 0.75rem; }
.revops__cta-title { font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2rem); font-weight: var(--font-weight-display); letter-spacing: -0.02em; margin: 0 0 0.75rem; color: var(--on-dark-foreground); }
.revops__cta-sub { margin: 0; color: var(--on-dark-muted-foreground); line-height: 1.55; }
.revops__cta-actions { display: flex; flex-direction: column; gap: 0.75rem; align-items: stretch; }
.revops__cta-actions .btn { width: 100%; }

/* ───────── Responsive ───────── */
@media (max-width: 900px) {
  .revops__intro { grid-template-columns: 1fr; }
  .revops__r-grid { grid-template-columns: 1fr; }
  .revops__rec-card { grid-template-columns: 1fr; }
  .revops__cta { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .revops__opts { grid-template-columns: 1fr; }
  .revops-opt { flex-direction: row; align-items: center; justify-content: space-between; min-height: 0; gap: 1rem; }
  .revops__r-score { flex-direction: column; text-align: center; }
  .revops__form-row { grid-template-columns: 1fr; }
  .revops__rec-meta { gap: 1rem; }
}

@media (prefers-reduced-motion: reduce) {
  .revops__panel { animation: none; }
  .revops__ring-arc,
  .revops__q-fill,
  .revops__leak,
  .revops__dim-bar > div { transition: none; }
}

/* =========================================================
   Results cleanup: shadcn-inspired cards, tinted stat tiles,
   centered ring number. These override the earlier results
   rules above (later-in-file wins).
   ========================================================= */

/* Saved-result banner (returning visitors). */
.revops__restored {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  padding: 0.625rem 0.75rem 0.625rem 1rem;
  margin-bottom: 1.25rem;
  border: 1px solid color-mix(in oklch, var(--brand-teal) 30%, transparent);
  background: color-mix(in oklch, var(--brand-teal) 6%, transparent);
  border-radius: var(--radius-md);
}
.revops__restored-text { display: inline-flex; align-items: center; gap: 0.5rem; font-size: var(--fs-sm); color: var(--color-foreground); }
.revops__restored-dot { width: 8px; height: 8px; border-radius: 999px; background: var(--brand-teal); box-shadow: 0 0 0 4px color-mix(in oklch, var(--brand-teal) 18%, transparent); }
.revops__restored-retake {
  background: none; border: 0; cursor: pointer; font: inherit;
  font-size: var(--fs-sm); font-weight: var(--font-weight-medium);
  color: var(--brand-teal); padding: 0.3rem 0.6rem; border-radius: var(--radius-sm);
  transition: background var(--dur-fast) var(--ease);
}
.revops__restored-retake:hover { background: color-mix(in oklch, var(--brand-teal) 12%, transparent); }

/* Score header becomes a shadcn card. */
.revops__r-head {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  background: var(--color-card);
  box-shadow: var(--shadow-sm);
  padding: clamp(1.75rem, 4vw, 2.5rem);
  margin-bottom: 1.5rem;
}
.revops__r-eyebrow { text-align: left; margin-bottom: 1.25rem; }
.revops__r-score { justify-content: flex-start; margin-bottom: 0; }
.revops__r-body { max-width: 46rem; }

/* Centered ring number (stacked value + label). */
.revops__ring-num {
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.1rem;
}
.revops__ring-val {
  font-family: var(--font-display);
  font-size: 3.25rem;
  font-weight: var(--font-weight-display);
  color: var(--color-foreground);
  letter-spacing: -0.03em;
  line-height: 1;
}
.revops__ring-suffix {
  font-family: var(--font-mono);
  font-size: 0.625rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted-foreground);
  margin: 0;
}

/* "Score by layer" rows wrapped in a single bordered card. */
.revops__card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-card);
  box-shadow: var(--shadow-sm);
  padding: 0.25rem 1.25rem;
}
.revops__dims .revops__dim { padding: 1rem 0; }
.revops__dim.is-weak {
  background: color-mix(in oklch, var(--color-destructive) 5%, transparent);
  border-radius: var(--radius-sm);
  padding-inline: 0.75rem;
  margin-inline: -0.75rem;
}

/* Leak points: soft shadcn cards with teal hover. */
.revops__leak {
  border-radius: var(--radius-lg);
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-med) var(--ease), transform var(--dur-med) var(--ease);
}
.revops__leak:hover {
  transform: translateY(-2px);
  border-color: color-mix(in oklch, var(--brand-teal) 40%, var(--color-border));
  box-shadow: 0 10px 24px -16px color-mix(in oklch, var(--brand-teal) 55%, transparent);
}
.revops__leak-n { font-size: 1rem; font-weight: var(--font-weight-display); }

/* Recommendation: tinted teal-wash stat tiles, teal numbers. */
.revops__rec-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.revops__rec-stat {
  background: color-mix(in oklch, var(--brand-teal) 7%, var(--color-card));
  border: 1px solid color-mix(in oklch, var(--brand-teal) 18%, transparent);
  border-radius: var(--radius-md);
  padding: 1.25rem;
}
.revops__rec-stat-num { color: var(--brand-teal); }
.revops__rec-stat-unit { color: color-mix(in oklch, var(--brand-teal) 70%, var(--color-muted-foreground)); }

/* =========================================================
   Pass 2: teal-gradient stat tiles + calmer question flow.
   ========================================================= */

/* Stat tiles: teal->blue gradient (like the progress bars), white
   number, muted-white labels. Overrides the tinted version above. */
.revops__rec-stat {
  background: var(--brand-gradient);
  border: 0;
  box-shadow: 0 10px 24px -16px color-mix(in oklch, var(--brand-blue) 70%, transparent);
}
.revops__rec-stat-num { color: var(--on-dark-foreground); }
.revops__rec-stat-unit { color: color-mix(in oklch, white 72%, transparent); }
.revops__rec-stat-label { color: color-mix(in oklch, white 80%, transparent); }

/* Question flow: crossfade content + reserve prompt height so the
   options never jump when the prompt wraps to a different line count. */
.revops__q-content {
  transition: opacity 0.2s var(--ease), transform 0.2s var(--ease);
}
.revops__q-content.is-fading {
  opacity: 0;
  transform: translateY(6px);
}
.revops__prompt {
  min-height: 2.5em; /* reserve ~2 lines so short/long prompts align */
}
@media (min-width: 641px) {
  /* Keep the card a stable height across questions on larger screens. */
  .revops__question { min-height: 22rem; }
}
@media (prefers-reduced-motion: reduce) {
  .revops__q-content { transition: none; }
}
