:root {
  --font-display: 'DM Serif Display', Georgia, serif;
  --font-body: 'DM Sans', system-ui, sans-serif;
}

body.participation {
  font-family: var(--font-body);
  background-color: var(--color-warm-50);
  background-image:
    radial-gradient(ellipse at 20% 0%, rgba(37, 99, 235, 0.03) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 100%, rgba(37, 99, 235, 0.02) 0%, transparent 60%);
  color: var(--color-ink);
}

.font-display { font-family: var(--font-display); }
.font-body { font-family: var(--font-body); }

.survey-card {
  background: white;
  border: 1px solid var(--color-warm-200);
  border-radius: 1rem;
  box-shadow:
    0 1px 2px rgba(30, 26, 22, 0.04),
    0 4px 16px rgba(30, 26, 22, 0.03);
}

.survey-card-elevated {
  box-shadow:
    0 1px 2px rgba(30, 26, 22, 0.06),
    0 8px 32px rgba(30, 26, 22, 0.06);
}

.option-card {
  border: 1.5px solid var(--color-warm-200);
  border-radius: 0.75rem;
  padding: 0.875rem 1rem;
  transition: all 0.15s ease;
  cursor: pointer;
  background: white;
}
.option-card:hover {
  border-color: var(--color-warm-300);
  background: var(--color-warm-50);
}
.option-card.selected {
  border-color: var(--color-accent);
  background: var(--color-accent-light);
}

.progress-track {
  height: 3px;
  background: var(--color-warm-200);
  border-radius: 2px;
  overflow: hidden;
}
.progress-fill {
  height: 100%;
  background: var(--color-accent);
  border-radius: 2px;
  transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.input-field {
  width: 100%;
  border: 1.5px solid var(--color-warm-200);
  border-radius: 0.75rem;
  padding: 0.75rem 1rem;
  font-size: 0.9375rem;
  font-family: var(--font-body);
  color: var(--color-ink);
  background: white;
  outline: none;
  transition: all 0.15s ease;
  resize: vertical;
}
.input-field::placeholder {
  color: var(--color-warm-400);
}
.input-field:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}
.animate-in {
  animation: fadeInUp 0.4s ease-out both;
}
.animate-delay-1 { animation-delay: 0.05s; }
.animate-delay-2 { animation-delay: 0.1s; }
.animate-delay-3 { animation-delay: 0.15s; }
