/* ---------------------------------------
   HyperCorse — Form Styles (Dark / Minimal)
   --------------------------------------- */

.form {
  --accent: #41d6ff;           /* Brand-Akzent (gern anpassen) */
  --surface: #14161b;          /* Input-Hintergrund */
  --surface-2: #0f1115;        /* Karten-Hintergrund falls nötig */
  --border: rgba(255,255,255,.08);
  --border-2: rgba(255,255,255,.14);
  --text:   #e7e7ea;
  --muted:  #a3a3ac;

  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* Zweispalter (Name/E-Mail etc.) */
.form .row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
@media (max-width: 820px) {
  .form .row-2 { grid-template-columns: 1fr; }
}

/* Feld + Label */
.form .field {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.form .field > span {
  font-size: .9rem;
  color: var(--muted);
  letter-spacing: .02em;
}

/* Inputs & Textarea */
.form .field input,
.form .field textarea {
  appearance: none;
  width: 100%;
  background: var(--surface);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: .8rem;
  padding: .9rem 1rem;
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.form .field textarea {
  resize: vertical;
  min-height: 10rem;
  line-height: 1.45;
}
.form .field input::placeholder,
.form .field textarea::placeholder { color: rgba(231,231,234,.35); }

/* Fokus-Ring (zugänglich) */
.form .field input:focus-visible,
.form .field textarea:focus-visible {
  border-color: color-mix(in oklab, var(--accent) 60%, white 0%);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 25%, transparent 75%);
}

/* Hover (nur dezent) */
@media (hover: hover) {
  .form .field input:hover,
  .form .field textarea:hover {
    border-color: var(--border-2);
  }
}

/* Label färbt sich bei Fokus mit */
.form .field:focus-within > span {
  color: color-mix(in oklab, var(--accent) 70%, white 0%);
}

/* Checkbox (nutzt modernes accent-color) */
.form .checkbox {
  display: flex;
  align-items: flex-start;
  gap: .6rem;
  line-height: 1.4;
  color: var(--muted);
}
.form .checkbox input[type="checkbox"] {
  margin-top: .15rem;
  width: 1.1rem; height: 1.1rem;
  accent-color: var(--accent);
}

/* Zeichen-Zähler */
.form .field .tiny.muted {
  text-align: right;
  margin-top: .25rem;
}

/* Fehler-/Erfolgszustände */
.card.success {
    border: 1px solid rgba(16,185,129,.28);
    background: rgba(16,185,129,.08);
    margin-bottom: 20px;    
}
.card.success .title { color: #5ee6b3; }

.card.danger {
    border: 1px solid rgba(244,63,94,.28);
    background: rgba(244,63,94,.08);
    margin-bottom: 20px;
}
.card.danger .title { color: #ff8ba1; }

/* Feld-Fehler (optional per .error auf .field setzen) */
.form .field.error input,
.form .field.error textarea {
  border-color: rgba(244,63,94,.55);
  box-shadow: 0 0 0 3px rgba(244,63,94,.18);
}
.form .field.error > span { color: #ff8ba1; }

/* Tap-Highlight aus (mobil) */
.form * { -webkit-tap-highlight-color: transparent; }

/* Autofill (Safari/Chrome) neutralisieren */
.form input:-webkit-autofill,
.form input:-webkit-autofill:hover,
.form input:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--text);
  transition: background-color 9999s ease-out 0s;
}

/* Buttons im Formular – etwas Abstand */
.form .row .btn { min-width: 11rem; }
@media (max-width: 560px) {
  .form .row { gap: .5rem; flex-wrap: wrap; }
  .form .row .btn + .btn { margin-left: 0; }
}
