/* =========================================================================
   Bedarfsanalyse — Premium Multi-Step Form
   Nutzt /css/tokens.css als Single Source of Truth für Farben, Spacing,
   Typografie. Page-specific Styles für Form-Flow + Field-Pattern.
   ========================================================================= */

/* Reset basics for this page (overrides shared base where needed) -------- */
.ba-body {
  background:
    radial-gradient(ellipse 80% 50% at 50% -20%, rgba(0, 212, 138, 0.10), transparent 70%),
    var(--color-bg-base);
  color: var(--color-text);
  font-family: var(--font-body);
  line-height: var(--lh-body);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Topbar ---------------------------------------------------------------- */
.ba-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-5) var(--container-pad);
  max-width: var(--container-max);
  margin: 0 auto;
  border-bottom: 1px solid var(--color-stroke-soft);
}
.ba-brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  color: inherit;
}
.ba-brand-mark {
  display: inline-block;
  width: 28px; height: 28px;
  border-radius: var(--radius-sm);
  background: var(--color-accent);
  box-shadow: var(--shadow-glow);
}
.ba-brand-name {
  font-family: var(--font-heading);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--tracking-snug);
  font-size: 1.05rem;
}
.ba-topbar-note {
  margin: 0;
  font-size: var(--fs-label);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--color-text-soft);
}

/* Layout shell ---------------------------------------------------------- */
.ba-main {
  max-width: 880px;
  margin: 0 auto;
  padding: var(--space-12) var(--container-pad) var(--space-24);
}
.ba-screen { animation: ba-fade 360ms var(--ease-out); }
@keyframes ba-fade {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Intro ----------------------------------------------------------------- */
.ba-intro { padding-top: var(--space-12); }
.ba-eyebrow {
  font-size: var(--fs-label);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--color-text-soft);
  margin: 0 0 var(--space-5);
}
.ba-headline {
  font-family: var(--font-heading);
  font-size: var(--fs-h1);
  line-height: var(--lh-heading);
  letter-spacing: var(--tracking-tight);
  margin: 0 0 var(--space-6);
  font-weight: var(--font-weight-semibold);
  max-width: 22ch;
}
.ba-lead {
  font-size: var(--fs-lead);
  color: var(--color-text-muted);
  max-width: 60ch;
  margin: 0 0 var(--space-8);
}
.ba-trust {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-8);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3) var(--space-6);
}
.ba-trust li {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-small);
  color: var(--color-text-muted);
}
.ba-trust-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--color-accent);
  box-shadow: 0 0 8px var(--color-accent-glow);
}
.ba-meta {
  font-size: var(--fs-small);
  color: var(--color-text-soft);
  margin: var(--space-4) 0 var(--space-10);
  max-width: 60ch;
}

/* Resume Banner --------------------------------------------------------- */
.ba-resume {
  margin: var(--space-8) 0;
  padding: var(--space-6);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-stroke-medium);
  border-left: 3px solid var(--color-accent);
  border-radius: var(--radius-lg);
}
.ba-resume p { margin: 0 0 var(--space-4); color: var(--color-text-muted); }
.ba-resume-actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }

/* Buttons --------------------------------------------------------------- */
.ba-btn {
  --btn-bg: transparent;
  --btn-fg: var(--color-text);
  --btn-border: var(--color-border-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.75rem 1.5rem;
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: var(--font-weight-medium);
  letter-spacing: var(--tracking-snug);
  background: var(--btn-bg);
  color: var(--btn-fg);
  border: 1px solid var(--btn-border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: transform var(--dur-fast) var(--ease-out),
              background var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out),
              box-shadow var(--dur-fast) var(--ease-out);
}
.ba-btn:hover:not(:disabled) { transform: translateY(-1px); }
.ba-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.ba-btn:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; }
.ba-btn-primary {
  --btn-bg: var(--color-accent);
  --btn-fg: var(--color-accent-ink);
  --btn-border: var(--color-accent);
  box-shadow: 0 8px 28px var(--color-accent-glow);
}
.ba-btn-primary:hover:not(:disabled) {
  --btn-bg: var(--color-accent-pressed);
  box-shadow: 0 12px 36px var(--color-accent-glow-strong);
}
.ba-btn-secondary {
  --btn-bg: var(--color-bg-elevated);
  --btn-border: var(--color-stroke-medium);
}
.ba-btn-secondary:hover { --btn-bg: var(--color-bg-overlay); }
.ba-btn-ghost {
  --btn-bg: transparent;
  --btn-border: var(--color-stroke-medium);
  color: var(--color-text-muted);
}
.ba-btn-ghost:hover:not(:disabled) { --btn-border: var(--color-border-strong); color: var(--color-text); }
.ba-btn-large { padding: 1rem 2rem; font-size: 1.05rem; }
.ba-btn-skip-warn {
  --btn-bg: var(--color-warning);
  --btn-fg: #1A1100;
  --btn-border: var(--color-warning);
  box-shadow: 0 8px 28px var(--color-warning-glow);
}
.ba-btn-skip-warn:hover:not(:disabled) { filter: brightness(1.05); }
.ba-skip-hint {
  margin: var(--space-4) 0 0;
  padding: var(--space-3) var(--space-4);
  background: rgba(245, 158, 11, 0.08);
  border: 1px solid rgba(245, 158, 11, 0.30);
  border-radius: var(--radius-md);
  font-size: var(--fs-small);
  color: var(--color-warning);
  text-align: center;
}
.ba-btn-link {
  background: none; border: none; padding: 0;
  color: var(--color-accent);
  font: inherit; cursor: pointer;
  font-size: var(--fs-small);
  letter-spacing: var(--tracking-snug);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.ba-btn-link:hover { border-bottom-color: var(--color-accent); }

/* Progress -------------------------------------------------------------- */
.ba-progress { margin-bottom: var(--space-8); }
.ba-progress-track {
  height: 6px;
  background: var(--color-bg-elevated);
  border-radius: var(--radius-pill);
  overflow: hidden;
  position: relative;
  border: 1px solid var(--color-stroke-soft);
}
.ba-progress-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--color-accent-pressed), var(--color-accent));
  width: 6%;
  transition: width var(--dur-slow) var(--ease-out);
  box-shadow: 0 0 10px var(--color-accent-glow);
}
.ba-progress-label {
  margin: var(--space-2) 0 0;
  font-size: var(--fs-label);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--color-text-soft);
}

/* Step ------------------------------------------------------------------ */
.ba-step-header { margin-bottom: var(--space-8); }
.ba-step-eyebrow {
  font-size: var(--fs-label);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--color-text-soft);
  margin: 0 0 var(--space-3);
}
.ba-step-title {
  font-family: var(--font-heading);
  font-size: var(--fs-h2);
  line-height: var(--lh-heading);
  letter-spacing: var(--tracking-tight);
  font-weight: var(--font-weight-semibold);
  margin: 0 0 var(--space-3);
  max-width: 22ch;
}
.ba-step-desc {
  color: var(--color-text-muted);
  max-width: 60ch;
  margin: 0;
}
.ba-step-body { display: flex; flex-direction: column; gap: var(--space-8); }

/* Field ----------------------------------------------------------------- */
.ba-field {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-stroke-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: border-color var(--dur-fast) var(--ease-out);
}
.ba-field:focus-within {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 4px var(--color-accent-tint-08);
}
.ba-field.has-error {
  border-color: var(--color-danger);
  box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.10);
}
.ba-field-label {
  display: block;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  font-size: 1rem;
  margin-bottom: var(--space-2);
  line-height: 1.35;
}
.ba-field-help {
  font-size: var(--fs-small);
  color: var(--color-text-soft);
  margin: 0 0 var(--space-4);
  line-height: 1.5;
}
.ba-required { color: var(--color-accent); margin-left: 2px; }
.ba-field-error {
  margin: var(--space-3) 0 0;
  font-size: var(--fs-small);
  color: var(--color-danger);
}
.ba-field-sub {
  padding: var(--space-4);
  background: var(--color-bg-overlay);
  border-color: var(--color-stroke-medium);
}

/* Inputs ---------------------------------------------------------------- */
.ba-input {
  width: 100%;
  padding: 0.875rem 1rem;
  background: var(--color-bg-overlay);
  border: 1px solid var(--color-stroke-medium);
  border-radius: var(--radius-md);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.4;
  transition: border-color var(--dur-fast) var(--ease-out),
              background var(--dur-fast) var(--ease-out);
}
.ba-input::placeholder { color: var(--color-text-soft); }
.ba-input:focus {
  outline: none;
  border-color: var(--color-accent);
  background: var(--color-bg-elevated);
}
.ba-textarea { min-height: 100px; resize: vertical; font-family: inherit; }
.ba-select { appearance: none; cursor: pointer; padding-right: 2.5rem;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%237A8599' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.85rem center;
  background-size: 18px;
}

/* Radio & Checkbox ------------------------------------------------------ */
.ba-radio-group, .ba-checkbox-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.ba-radio, .ba-checkbox {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4);
  background: var(--color-bg-overlay);
  border: 1px solid var(--color-stroke-medium);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: border-color var(--dur-fast) var(--ease-out),
              background var(--dur-fast) var(--ease-out);
}
.ba-radio:hover, .ba-checkbox:hover {
  border-color: var(--color-border-strong);
}
.ba-radio input, .ba-checkbox input {
  flex-shrink: 0;
  margin-top: 2px;
  width: 18px; height: 18px;
  accent-color: var(--color-accent);
  cursor: pointer;
}
.ba-radio input:checked + .ba-radio-label,
.ba-checkbox input:checked + .ba-checkbox-label {
  color: var(--color-text);
}
.ba-radio:has(input:checked), .ba-checkbox:has(input:checked) {
  border-color: var(--color-accent);
  background: var(--color-accent-tint-04);
}
.ba-radio-label, .ba-checkbox-label {
  color: var(--color-text-muted);
  font-size: 0.95rem;
  line-height: 1.45;
  user-select: none;
}

/* Repeater -------------------------------------------------------------- */
.ba-repeater-list { display: flex; flex-direction: column; gap: var(--space-4); }
.ba-repeater-item {
  background: var(--color-bg-overlay);
  border: 1px solid var(--color-stroke-medium);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  display: flex; flex-direction: column;
  gap: var(--space-4);
}
.ba-repeater-item-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-2);
}
.ba-repeater-item-header h4 {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: var(--font-weight-semibold);
  margin: 0;
}
.ba-repeater-add { margin-top: var(--space-4); }
.ba-repeater-remove { color: var(--color-text-soft); }
.ba-repeater-remove:hover { color: var(--color-danger); border-bottom-color: var(--color-danger); }

/* Nav ------------------------------------------------------------------- */
.ba-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  margin-top: var(--space-10);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-stroke-soft);
}
.ba-nav-summary { margin-top: var(--space-8); }
.ba-flow-note {
  margin-top: var(--space-6);
  font-size: var(--fs-small);
  color: var(--color-text-soft);
  text-align: center;
}

/* Summary --------------------------------------------------------------- */
.ba-summary-screen { padding-top: var(--space-4); }
.ba-summary-intro h2 {
  font-family: var(--font-heading);
  font-size: var(--fs-h2);
  letter-spacing: var(--tracking-tight);
  margin: 0 0 var(--space-3);
  font-weight: var(--font-weight-semibold);
}
.ba-summary-intro p { color: var(--color-text-muted); margin: 0 0 var(--space-10); }
.ba-summary-section {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-stroke-soft);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  margin-bottom: var(--space-4);
}
.ba-summary-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-stroke-soft);
}
.ba-summary-header h3 {
  margin: 0;
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: var(--font-weight-semibold);
}
.ba-summary-list { display: grid; grid-template-columns: minmax(200px, 1fr) 2fr; gap: var(--space-3) var(--space-6); margin: 0; }
.ba-summary-list dt { color: var(--color-text-soft); font-size: var(--fs-small); font-weight: var(--font-weight-medium); }
.ba-summary-list dd { margin: 0; color: var(--color-text); font-size: 0.95rem; word-break: break-word; }
.ba-summary-empty { color: var(--color-text-soft); font-style: italic; margin: 0; }
.ba-summary-repeater-item {
  background: var(--color-bg-overlay);
  border: 1px solid var(--color-stroke-medium);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  margin-bottom: var(--space-2);
}
.ba-summary-repeater-item strong {
  display: block;
  margin-bottom: var(--space-2);
  color: var(--color-accent);
  font-size: var(--fs-small);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
}
.ba-summary-repeater-item dl { display: grid; grid-template-columns: max-content 1fr; gap: var(--space-1) var(--space-4); margin: 0; }
.ba-summary-repeater-item dt { color: var(--color-text-soft); font-size: var(--fs-small); }
.ba-summary-repeater-item dd { margin: 0; font-size: var(--fs-small); }

/* Consent --------------------------------------------------------------- */
.ba-consent {
  margin: var(--space-8) 0 var(--space-6);
  display: flex; flex-direction: column;
  gap: var(--space-3);
}
.ba-consent-item {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-stroke-medium);
}

/* Error Banner ---------------------------------------------------------- */
.ba-error-banner {
  margin: var(--space-4) 0;
  padding: var(--space-4) var(--space-5);
  background: rgba(239, 68, 68, 0.08);
  border: 1px solid rgba(239, 68, 68, 0.30);
  border-radius: var(--radius-md);
  color: var(--color-danger);
  font-size: var(--fs-small);
}

/* Honeypot — visually hidden but technically present ------------------- */
.ba-honeypot {
  position: absolute;
  left: -9999px;
  width: 1px; height: 1px;
  overflow: hidden;
  opacity: 0;
}

/* Done ------------------------------------------------------------------ */
.ba-done { text-align: center; padding-top: var(--space-12); }
.ba-done-inner { max-width: 520px; margin: 0 auto; }
.ba-done-icon {
  display: inline-flex;
  width: 80px; height: 80px;
  align-items: center; justify-content: center;
  background: var(--color-accent-tint-08);
  border-radius: 50%;
  color: var(--color-accent);
  margin-bottom: var(--space-6);
  box-shadow: 0 0 32px var(--color-accent-glow);
}
.ba-done h2 {
  font-family: var(--font-heading);
  font-size: var(--fs-h2);
  letter-spacing: var(--tracking-tight);
  margin: 0 0 var(--space-4);
  font-weight: var(--font-weight-semibold);
}
.ba-done p { color: var(--color-text-muted); margin: 0 0 var(--space-4); }
.ba-done button { margin-top: var(--space-6); }

/* Footer ---------------------------------------------------------------- */
.ba-footer {
  text-align: center;
  padding: var(--space-8) var(--container-pad);
  border-top: 1px solid var(--color-stroke-soft);
  margin-top: var(--space-12);
  font-size: var(--fs-small);
  color: var(--color-text-soft);
}
.ba-footer a { color: var(--color-text-muted); text-decoration: none; border-bottom: 1px solid var(--color-stroke-medium); }
.ba-footer a:hover { color: var(--color-text); border-bottom-color: var(--color-accent); }

/* Responsive ------------------------------------------------------------ */
@media (max-width: 720px) {
  .ba-main { padding: var(--space-8) var(--container-pad) var(--space-16); }
  .ba-field { padding: var(--space-5); }
  .ba-headline { font-size: clamp(2rem, 8vw, 3rem); }
  .ba-step-title { font-size: clamp(1.5rem, 6vw, 2.25rem); }
  .ba-summary-list { grid-template-columns: 1fr; gap: var(--space-1) 0; }
  .ba-summary-list dt { margin-top: var(--space-3); }
  .ba-summary-list dt:first-child { margin-top: 0; }
  .ba-nav { flex-direction: column-reverse; align-items: stretch; }
  .ba-nav .ba-btn { width: 100%; }
  .ba-trust { gap: var(--space-2) var(--space-4); }
  .ba-summary-header { flex-direction: column; align-items: flex-start; gap: var(--space-2); }
}

/* Print — Summary printable -------------------------------------------- */
@media print {
  .ba-topbar, .ba-footer, .ba-nav, .ba-progress, .ba-resume, #ba-intro, #ba-flow, #ba-done, .ba-consent { display: none !important; }
  .ba-body { background: white; color: black; }
  .ba-summary-section { break-inside: avoid; border: 1px solid #ddd; box-shadow: none; }
}
