.ha-wrap { margin: 24px 0; }
.ha-card {
  max-width: 720px;
  margin: 0 auto;
  padding: 28px;
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 10px 30px rgba(0,0,0,0.06);
}

.ha-header { margin-bottom: 18px; }
.ha-title { margin: 0 0 6px; font-size: 28px; line-height: 1.15; }
.ha-subtitle { margin: 0; opacity: 0.8; }

.ha-step { display: none; }
.ha-step.is-active { display: block; }

.ha-label { display: block; margin: 14px 0; font-weight: 600; }
.ha-input {
  width: 100%;
  margin-top: 6px;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.18);
  font: inherit;
}

.ha-question { margin: 12px 0 8px; font-weight: 700; }
.ha-option {
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 12px;
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 14px;
  margin: 10px 0;
  cursor: pointer;
}
.ha-option input { transform: scale(1.1); }

.ha-actions { display: flex; gap: 10px; margin-top: 16px; }
.ha-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 12px 16px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.15);
  text-decoration: none;
  cursor: pointer;
  font-weight: 700;
}
.ha-btn--ghost { background: transparent; }

.ha-privacy, .ha-note { margin-top: 14px; opacity: 0.75; font-size: 14px; }

.ha-result-title { margin-top: 0; }
.ha-result-text { font-size: 18px; line-height: 1.5; }

.ha-honey { position: absolute; left: -9999px; height: 0; overflow: hidden; }
