/* vorabpruefung.css : Vorabprüfungs-Seite (self-hosted, CSP style-src 'self').
   Theme-fähig: HELL als Standard, html.dark = dunkel (gesteuert von theme.js der Website).
   Brand: anthracite #0e0f12, papier #f5f3ee, sand #b89b6e (dunkel) / secondary #725b33 (hell, WCAG). */

:root {
  --vp-surface: #ffffff;
  --vp-text: #181c22;
  --vp-muted: #46464b;
  --vp-faint: #6a6a70;
  --vp-accent: #725b33;            /* WCAG-sicheres Sand auf Hell */
  --vp-border: #c7c6cb;
  --vp-field-border: #76787e;      /* Eingabefelder: >=3:1 Nicht-Text-Kontrast (WCAG 1.4.11) */
  --vp-line: #d8d7da;
  --vp-btn-bg: #0e0f12;
  --vp-btn-text: #f5f3ee;
  --vp-select-arrow: '%23725b33';
}
html.dark {
  --vp-surface: #14161a;
  --vp-text: #f5f3ee;
  --vp-muted: #b7b6bb;
  --vp-faint: #8a8990;
  --vp-accent: #b89b6e;
  --vp-border: rgb(199 198 203 / 0.40);
  --vp-field-border: rgb(199 198 203 / 0.62);
  --vp-line: rgb(199 198 203 / 0.22);
  --vp-btn-bg: #f5f3ee;
  --vp-btn-text: #0e0f12;
  --vp-select-arrow: '%23b89b6e';
}

/* ---------- Vertrauens-Punkte ---------- */
.vp-trust {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: 0.6rem 1.75rem;
  font-family: "Hanken Grotesk", system-ui, sans-serif;
  font-size: 0.92rem; color: var(--vp-muted);
}
.vp-trust li { position: relative; padding-left: 1.4rem; }
.vp-trust li::before {
  content: ""; position: absolute; left: 0; top: 0.55em;
  width: 6px; height: 6px; background: var(--vp-accent); border-radius: 50%;
}

/* ---------- Abschnitts-Abstand + Zwischenüberschrift ---------- */
.vp-section { margin-top: 5rem; }
@media (min-width: 768px) { .vp-section { margin-top: 7rem; } }
.vp-h2 {
  font-family: "Hanken Grotesk", system-ui, sans-serif;
  font-size: 1.9rem; line-height: 1.15; letter-spacing: 0.01em; font-weight: 500;
  color: var(--vp-text); margin: 0 0 3rem 0;
}
@media (min-width: 768px) { .vp-h2 { font-size: 2.4rem; } }

/* ---------- So funktioniert's ---------- */
.vp-steps {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px;
  background: var(--vp-border); border: 1px solid var(--vp-border);
}
@media (max-width: 760px) { .vp-steps { grid-template-columns: 1fr; } }
.vp-step { background: var(--vp-surface); padding: 1.75rem; }
.vp-step-num {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 0.72rem; letter-spacing: 0.12em; color: var(--vp-accent); display: block; margin-bottom: 0.9rem;
}
.vp-step-title {
  font-family: "Hanken Grotesk", system-ui, sans-serif;
  font-size: 1.12rem; color: var(--vp-text); margin: 0 0 0.5rem 0; font-weight: 500;
}
.vp-step-text {
  font-family: "Hanken Grotesk", system-ui, sans-serif;
  font-size: 0.92rem; color: var(--vp-muted); margin: 0; line-height: 1.55;
}

/* ---------- Formular ---------- */
.vp-form { max-width: 760px; }
.vp-field { margin-bottom: 1.75rem; }

.vp-label {
  display: block; font-family: "Inter", system-ui, sans-serif;
  font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--vp-accent); margin-bottom: 0.6rem;
}

.vp-input, .vp-textarea, .vp-select {
  width: 100%; background: transparent; color: var(--vp-text);
  border: 1px solid var(--vp-field-border); border-radius: 2px;
  padding: 0.85rem 1rem; font-family: "Hanken Grotesk", system-ui, sans-serif;
  font-size: 1rem; line-height: 1.5; transition: border-color 0.2s ease; box-sizing: border-box;
}
.vp-textarea { min-height: 150px; resize: vertical; }
.vp-input::placeholder, .vp-textarea::placeholder { color: var(--vp-faint); }
.vp-input:focus-visible, .vp-textarea:focus-visible, .vp-select:focus-visible {
  outline: 2px solid var(--vp-accent); outline-offset: 2px; border-color: var(--vp-accent);
}
.vp-input:focus, .vp-textarea:focus, .vp-select:focus { border-color: var(--vp-accent); }
.vp-btn:focus-visible { outline: 2px solid var(--vp-accent); outline-offset: 3px; }
.vp-consent input:focus-visible { outline: 2px solid var(--vp-accent); outline-offset: 2px; }
.vp-consent a:focus-visible, .vp-note a:focus-visible { outline: 2px solid var(--vp-accent); outline-offset: 2px; }
.vp-req { color: var(--vp-accent); margin-left: 2px; }
.vp-sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }
.vp-pflicht-hinweis { font-size:0.8rem; color:var(--vp-faint); margin:0 0 1.5rem; }

/* Select: eigener Pfeil (sand), Optionen in Flächenfarbe */
.vp-select {
  -webkit-appearance: none; -moz-appearance: none; appearance: none;
  padding-right: 2.4rem; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%23725b33' stroke-width='1.5'%3E%3Cpath d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 1rem center;
}
html.dark .vp-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%23b89b6e' stroke-width='1.5'%3E%3Cpath d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
}
.vp-select option { background: var(--vp-surface); color: var(--vp-text); }

.vp-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.vp-row-3 { grid-template-columns: 1fr 1fr 1fr; }
@media (max-width: 760px) { .vp-row, .vp-row-3 { grid-template-columns: 1fr; } }

/* Consent */
.vp-consent { display: flex; align-items: flex-start; gap: 0.7rem; }
.vp-consent input { margin-top: 0.25rem; width: 16px; height: 16px; flex-shrink: 0; accent-color: var(--vp-accent); }
.vp-consent label {
  font-family: "Hanken Grotesk", system-ui, sans-serif;
  font-size: 0.88rem; color: var(--vp-muted); line-height: 1.5; text-transform: none; letter-spacing: normal;
}
.vp-consent a { color: var(--vp-accent); text-decoration: underline; }

.vp-btn {
  display: inline-flex; align-items: center; gap: 0.6rem;
  background: var(--vp-btn-bg); color: var(--vp-btn-text); border: 1px solid var(--vp-btn-bg); border-radius: 999px;
  padding: 0.85rem 2rem; font-family: "Inter", system-ui, sans-serif;
  font-size: 0.78rem; letter-spacing: 0.1em; text-transform: uppercase; cursor: pointer;
  transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease, opacity 0.25s ease;
}
.vp-btn:hover { background: #b89b6e; border-color: #b89b6e; color: #0e0f12; }
.vp-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.vp-note {
  font-family: "Hanken Grotesk", system-ui, sans-serif;
  font-size: 0.82rem; color: var(--vp-faint); margin-top: 1.25rem; line-height: 1.5;
}
.vp-note a { color: var(--vp-accent); }

/* ---------- Ergebnis ---------- */
.vp-result {
  display: none; margin-top: 2rem; padding: 1.5rem 1.75rem; border-radius: 4px;
  border: 1px solid var(--vp-border); background: var(--vp-surface);
  font-family: "Hanken Grotesk", system-ui, sans-serif; font-size: 1rem; line-height: 1.6; color: var(--vp-text);
}
.vp-result.is-visible { display: block; }
.vp-result.is-ok { border-color: #4e7d3e; background: rgb(78 125 62 / 0.08); }
.vp-result.is-wait { border-color: var(--vp-accent); background: rgb(184 155 110 / 0.10); }
.vp-result.is-error { border-color: #b3604a; background: rgb(179 96 74 / 0.08); }

.vp-result-head { display: flex; align-items: center; gap: 0.7rem; margin-bottom: 0.6rem; }
.vp-result-title {
  font-family: "Inter", system-ui, sans-serif; font-size: 0.72rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--vp-accent); margin: 0;
}
.vp-ampel { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; background: var(--vp-faint); display: inline-block; }
.vp-result.is-ok .vp-ampel { background: #5b9242; box-shadow: 0 0 0 4px rgb(91 146 66 / 0.18); }
.vp-result.is-wait .vp-ampel { background: #c79a4e; box-shadow: 0 0 0 4px rgb(199 154 78 / 0.18); }
.vp-result.is-error .vp-ampel { background: #b3604a; box-shadow: 0 0 0 4px rgb(179 96 74 / 0.18); }

/* ---------- Spinner ---------- */
.vp-spinner {
  width: 14px; height: 14px; border: 2px solid rgba(245,243,238,0.35); border-top-color: var(--vp-btn-text);
  border-radius: 50%; animation: vp-spin 0.7s linear infinite; display: none;
}
.vp-btn.is-loading .vp-spinner { display: inline-block; }
@keyframes vp-spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .vp-spinner { animation: none; } }
