/* ============================================================
   kontakt.css – Kontaktseite spezifische Styles
   ============================================================ */

/* Zusätzliches Formularfeld */
.form-optional {
  position: absolute;
  clip-path: inset(0 0 100% 0);
}

/* ---- Formular ---- */
.form { display: flex; flex-direction: column; gap: 1.25rem; }

.form-row { display: grid; gap: 1.25rem; }
.form-row--2 { grid-template-columns: 1fr; }
@media (min-width: 560px) { .form-row--2 { grid-template-columns: 1fr 1fr; } }

.form-group { display: flex; flex-direction: column; gap: 0.4rem; position: relative; }

.form-label { font-size: 0.875rem; font-weight: 600; color: var(--color-dark); }

.form-input,
.form-textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  color: var(--color-text);
  background: var(--color-bg-white);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: border-color var(--transition), box-shadow var(--transition);
  appearance: none;
}
.form-input:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--color-blue);
  box-shadow: 0 0 0 3px rgba(74,109,164,0.15);
}
.form-input::placeholder,
.form-textarea::placeholder { color: var(--color-text-muted); opacity: 0.7; }

.form-textarea { min-height: 140px; resize: vertical; line-height: 1.6; }

.form-checkbox { display: flex; align-items: flex-start; gap: 0.65rem; cursor: pointer; }
.form-checkbox input[type="checkbox"] { flex-shrink: 0; width: 18px; height: 18px; margin-top: 0.15rem; accent-color: var(--color-brand); cursor: pointer; }
.form-checkbox__label { font-size: 0.875rem; color: var(--color-text-muted); line-height: 1.55; }
.form-checkbox__label a { color: var(--color-brand); font-weight: 500; }
.form-checkbox__label a:hover { text-decoration: underline; }

.form-error { display: none; font-size: 0.8rem; color: var(--color-error); margin-top: 0.2rem; }
.form-group.has-error .form-input,
.form-group.has-error .form-textarea { border-color: var(--color-error); }
.form-group.has-error .form-error { display: block; }

.form-success {
  display: none;
  background: #f0fdf4;
  border: 1.5px solid #86efac;
  color: #166534;
  border-radius: var(--radius-lg);
  padding: 1.5rem 1.75rem;
  font-size: 0.95rem;
  line-height: 1.6;
}

.form-hint { font-size: 0.8rem; color: var(--color-text-muted); margin-top: 0.5rem; }

.required { color: var(--color-error); font-weight: 700; margin-left: 0.1rem; }

/* ---- Kontakt-Info-Box ---- */
.contact-info-box { background: var(--color-primary); border-radius: var(--radius-lg); padding: 1.75rem; color: #fff; }
.contact-info-box__title { font-size: 1rem; font-weight: 700; color: #fff; margin-bottom: 1.25rem; }

.contact-info-list { display: flex; flex-direction: column; gap: 1rem; }
.contact-info-item { display: flex; gap: 0.875rem; align-items: flex-start; }
.contact-info-item__icon { width: 36px; height: 36px; background: rgba(255,255,255,0.1); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.contact-info-item__icon svg { width: 16px; height: 16px; stroke: rgba(255,255,255,0.85); fill: none; stroke-width: 2; }
.contact-info-item__label { font-size: 0.75rem; color: rgba(255,255,255,0.45); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 0.15rem; }
.contact-info-item__value { color: rgba(255,255,255,0.9); }
.contact-info-item__value a { color: rgba(255,255,255,0.9); }
.contact-info-item__value a:hover { color: #FF9090; }

/* ---- Kartenplatzhalter ---- */
.map-placeholder { background: linear-gradient(135deg, #e8edf5 0%, #d0d9e8 100%); border-radius: var(--radius-lg); height: 320px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1rem; border: 1px solid var(--color-border); text-align: center; padding: 2rem; }
.map-placeholder__icon svg { width: 48px; height: 48px; stroke: var(--color-blue); fill: none; stroke-width: 1.5; opacity: 0.6; }
.map-placeholder p { font-size: 0.9rem; color: var(--color-text-muted); }
