/* KlevelScan — shared redesign content styles for survey / blocks / completion / report.
   Uses tokens from ecosystem.css: --eco-cream, --eco-navy, --eco-terracotta, --eco-font, --eco-max. */

.scan-main {
  padding: 24px 24px 96px;
  max-width: var(--eco-max);
  margin: 0 auto;
  color: var(--eco-navy);
}
@media (min-width: 768px) { .scan-main { padding: 32px 48px 120px; } }

.scan-eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--eco-terracotta);
}

.scan-display {
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 0.95;
  margin: 16px 0 20px;
}
.scan-display--xl { font-size: clamp(44px, 7vw, 88px); }
.scan-display--lg { font-size: clamp(36px, 5.5vw, 64px); }
.scan-display--md { font-size: clamp(28px, 4vw, 44px); }
.scan-display-accent { color: var(--eco-terracotta); }

.scan-lede {
  font-size: clamp(17px, 1.6vw, 20px);
  line-height: 1.55;
  color: rgba(27, 27, 27, 0.6);
  max-width: 58ch;
}

.scan-meta {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(27, 27, 27, 0.45);
}

.scan-card {
  background: #fff;
  border: 1px solid rgba(27, 27, 27, 0.06);
  border-radius: 24px;
  padding: 32px;
  box-shadow: 0 1px 2px rgba(27, 27, 27, 0.02);
}
.scan-card--dark {
  background: var(--eco-navy);
  color: #fff;
  border-color: transparent;
}
.scan-card--accent {
  border-color: rgba(200, 93, 68, 0.35);
  box-shadow: 0 12px 32px -16px rgba(200, 93, 68, 0.25);
}
.scan-card--muted {
  background: rgba(27, 27, 27, 0.03);
  border-color: rgba(27, 27, 27, 0.06);
  box-shadow: none;
}
.scan-card--locked {
  opacity: 0.55;
  filter: grayscale(0.6);
}

.scan-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 28px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-family: var(--eco-font);
  font-weight: 700;
  font-size: 14px;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, transform 0.15s, border-color 0.2s;
}
.scan-btn:active { transform: scale(0.97); }
.scan-btn--primary {
  background: var(--eco-navy);
  color: #fff;
}
.scan-btn--primary:hover { background: var(--eco-terracotta); }
.scan-btn--primary[disabled],
.scan-btn--primary:disabled {
  background: rgba(27, 27, 27, 0.12);
  color: rgba(27, 27, 27, 0.35);
  cursor: not-allowed;
  transform: none;
}
.scan-btn--accent {
  background: var(--eco-terracotta);
  color: #fff;
}
.scan-btn--accent:hover { background: #b44c36; }
.scan-btn--ghost {
  background: transparent;
  color: var(--eco-navy);
  border-color: rgba(27, 27, 27, 0.12);
}
.scan-btn--ghost:hover { background: rgba(27, 27, 27, 0.04); }
.scan-btn--text {
  background: transparent;
  color: rgba(27, 27, 27, 0.55);
  padding: 14px 16px;
}
.scan-btn--text:hover { color: var(--eco-navy); }
.scan-btn--block { width: 100%; }
.scan-btn--lg { padding: 20px 32px; font-size: 15px; }

.scan-progress-track {
  height: 6px;
  background: rgba(27, 27, 27, 0.06);
  border-radius: 999px;
  overflow: hidden;
}
.scan-progress-fill {
  height: 100%;
  background: var(--eco-terracotta);
  border-radius: 999px;
  transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.scan-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.scan-chip--done {
  background: rgba(34, 139, 94, 0.12);
  color: #228b5e;
}
.scan-chip--active {
  background: rgba(200, 93, 68, 0.12);
  color: var(--eco-terracotta);
}
.scan-chip--locked {
  background: rgba(27, 27, 27, 0.05);
  color: rgba(27, 27, 27, 0.4);
}

.scan-signature {
  font-style: italic;
  font-weight: 500;
  color: var(--eco-terracotta);
  font-size: 20px;
  line-height: 1.2;
}
.scan-signature-role {
  display: block;
  margin-top: 4px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(27, 27, 27, 0.4);
  font-style: normal;
}

.scan-divider {
  border: 0;
  border-top: 1px solid rgba(27, 27, 27, 0.08);
  margin: 40px 0;
}

.scan-hint {
  font-size: 12px;
  line-height: 1.6;
  color: rgba(27, 27, 27, 0.55);
  background: rgba(27, 27, 27, 0.03);
  border: 1px solid rgba(27, 27, 27, 0.06);
  border-radius: 16px;
  padding: 16px 20px;
}
