/*
 * Core V3 Contact Form
 * ------------------------------------------------------------
 * Frontend-Styles für das manuelle Shortcode-Formular.
 *
 * Ziel:
 * - Theme-aware Light/Dark
 * - klare, lesbare Struktur
 * - keine Inline-Styles im Template
 */

:root {
  --cv3-form-font-body: var(--font-body, var(--lh-font-body, var(--font-sans, 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif)));
  --cv3-form-font-heading: var(--font-heading, var(--lh-font-heading, var(--font-serif, 'Merriweather', Georgia, serif)));
  --cv3-form-font-ui: var(--font-ui, var(--lh-font-ui, var(--cv3-form-font-body)));

  --cv3-form-text: var(--c-form-text, var(--color-text, #182426));
  --cv3-form-text-soft: var(--c-form-muted, var(--color-text-soft, #5f6a6f));
  --cv3-form-line: var(--c-form-line, var(--color-border, rgba(24, 36, 38, 0.18)));
  --cv3-form-line-strong: var(--color-border-strong, rgba(24, 36, 38, 0.28));
  --cv3-form-surface: var(--c-form-bg, var(--color-surface-strong, #ffffff));
  --cv3-form-surface-alt: var(--color-surface-muted, #f7f5f1);
  --cv3-form-surface-soft: var(--color-card-alt, #f9fbfa);
  --cv3-form-placeholder: #728184;

  --cv3-form-accent: var(--color-accent-2, var(--lh-teal-2, #2f8b84));
  --cv3-form-accent-strong: var(--color-accent-3, var(--lh-teal-3, #216762));
  --cv3-form-focus: var(--lh-focus, var(--color-focus, #ffbf47));

  --cv3-form-button-top: var(--lh-btn-bg-top, var(--color-button-top, #2f8b84));
  --cv3-form-button-mid: var(--lh-btn-bg-mid, var(--color-button-mid, #277267));
  --cv3-form-button-bottom: var(--lh-btn-bg-bottom, var(--color-button-bottom, #1f5f55));
  --cv3-form-button-text: var(--lh-btn-text, var(--color-button-text, #ffffff));
  --cv3-form-button-shadow: var(--lh-btn-shadow, 0 0.875rem 1.75rem rgba(10, 24, 26, 0.12));
  --cv3-form-button-shadow-hover: var(--lh-btn-shadow-hover, 0 1.125rem 2.125rem rgba(10, 24, 26, 0.16));

  --cv3-form-notice-bg: #f4f6f5;
  --cv3-form-notice-text: var(--cv3-form-text);
  --cv3-form-error-bg: #fbefef;
  --cv3-form-error-text: #8a1f1f;
}

/* Dark Mode: unterstützt die Theme-Schalter, die im Projekt bereits verwendet werden. */
html[data-theme="dark"],
body.theme-dark,
body.is-theme-dark {
  --cv3-form-text: var(--c-form-text, var(--color-text, #edf2f1));
  --cv3-form-text-soft: var(--c-form-muted, var(--color-text-soft, #c4d1cf));
  --cv3-form-line: var(--c-form-line, var(--color-border, rgba(237, 242, 241, 0.18)));
  --cv3-form-line-strong: var(--color-border-strong, rgba(237, 242, 241, 0.26));
  --cv3-form-surface: var(--c-form-bg, var(--color-surface-strong, #1d2b2f));
  --cv3-form-surface-alt: var(--color-surface-muted, #162126);
  --cv3-form-surface-soft: var(--color-card-alt, #132024);
  --cv3-form-placeholder: #9bb0ac;
  --cv3-form-notice-bg: #1f2a2d;
  --cv3-form-notice-text: var(--cv3-form-text);
}

.core-v3-contact-form-wrap {
  width: min(100%, var(--layout-shell, var(--lh-shell-width, 1366px)));
  max-width: none;
  margin: 0 auto;
  color: var(--cv3-form-text);
  font-family: var(--cv3-form-font-body);
}

/*
 * Breiten-Fix: Das Formular darf nicht in der schmalen Textspalte hängen bleiben.
 * Auf klassischen Seiten-/Block-Inhalten wird es auf die Theme-Shell gezogen,
 * bleibt aber mobil sauber innerhalb des Viewports.
 */
@media (min-width: 64rem) {
  :where(.entry-content, .wp-block-post-content, .c-editable-area, .l-shell) .core-v3-contact-form-wrap {
    position: relative;
    left: 50%;
    width: min(calc(100vw - clamp(2rem, 6vw, 5rem)), var(--layout-shell, var(--lh-shell-width, 1366px)));
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    transform: translateX(-50%);
  }
}

.core-v3-contact-form,
.core-v3-contact-form * {
  box-sizing: border-box;
}

.core-v3-contact-form {
  display: grid;
  gap: 1.25rem;
}

.core-v3-contact-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.125rem 1.5rem;
}

.core-v3-contact-form__message-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 1.5rem;
  align-items: stretch;
}

.core-v3-contact-form__field {
  display: grid;
  gap: 0.5rem;
  min-width: 0;
  margin: 0;
}

.core-v3-contact-form__field--full {
  grid-column: 1 / -1;
}

.core-v3-contact-form__field--name-combo {
  align-content: start;
}

.core-v3-contact-form__name-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  min-width: 0;
}

.core-v3-contact-form__subfield {
  display: grid;
  gap: 0.375rem;
  min-width: 0;
  margin: 0;
}

.core-v3-contact-form__sub-label {
  color: var(--cv3-form-text);
  font-family: var(--cv3-form-font-ui);
  font-size: 0.8125rem;
  line-height: 1.35;
  font-weight: 700;
}

.core-v3-contact-form__label {
  display: block;
  color: var(--cv3-form-text);
  font-family: var(--cv3-form-font-ui);
  font-size: 0.875rem;
  line-height: 1.4;
  font-weight: 700;
}

.core-v3-contact-form__control {
  display: block;
  width: 100%;
  min-width: 0;
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid var(--cv3-form-line);
  background: var(--cv3-form-surface);
  color: var(--cv3-form-text);
  border-radius: 0 0.875rem 0.875rem 0.875rem;
  padding: 0.875rem 0.9375rem;
  font: inherit;
  font-family: var(--cv3-form-font-body);
  font-size: 1rem;
  line-height: 1.5;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
  transition: border-color 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.core-v3-contact-form__control::placeholder {
  color: var(--cv3-form-placeholder);
  opacity: 1;
}

.core-v3-contact-form__control:hover {
  border-color: var(--cv3-form-line-strong);
}

.core-v3-contact-form__control:focus,
.core-v3-contact-form__control:focus-visible {
  outline: none;
  border-color: var(--cv3-form-accent);
  box-shadow: 0 0 0 0.1875rem color-mix(in srgb, var(--cv3-form-accent) 20%, transparent);
}

select.core-v3-contact-form__control {
  padding-right: 2.5rem;
  background-image:
    linear-gradient(45deg, transparent 50%, currentColor 50%),
    linear-gradient(135deg, currentColor 50%, transparent 50%);
  background-position:
    calc(100% - 1.125rem) calc(50% - 0.125rem),
    calc(100% - 0.75rem) calc(50% - 0.125rem);
  background-size: 0.375rem 0.375rem, 0.375rem 0.375rem;
  background-repeat: no-repeat;
}

.core-v3-contact-form__textarea {
  min-height: 13.75rem;
  resize: vertical;
  height: 100%;
}

.core-v3-contact-form__upload-panel {
  display: grid;
  gap: 0.5rem;
  min-width: 0;
}

.core-v3-contact-form__upload-box {
  display: grid;
  gap: 0.75rem;
  align-content: start;
  min-height: 13.75rem;
  padding: 1.125rem;
  border: 1px dashed var(--cv3-form-line-strong);
  border-radius: 0 1.125rem 1.125rem 1.125rem;
  background: var(--cv3-form-surface-soft);
}

.core-v3-contact-form__file {
  display: block;
  width: 100%;
  font: inherit;
  color: var(--cv3-form-text);
}

.core-v3-contact-form__upload-copy {
  display: grid;
  gap: 0.5rem;
  align-content: start;
}

.core-v3-contact-form__upload-copy strong {
  color: var(--cv3-form-text);
  font-family: var(--cv3-form-font-ui);
  font-size: 1rem;
  line-height: 1.4;
  word-break: break-word;
}

.core-v3-contact-form__upload-copy span,
.core-v3-contact-form__upload-copy small {
  color: var(--cv3-form-text-soft);
  font-size: 0.9375rem;
  line-height: 1.65;
}

.core-v3-contact-form__quick-requests {
  display: grid;
  gap: 0.625rem;
  padding: 0.875rem;
  border: 1px solid color-mix(in srgb, var(--cv3-form-accent) 18%, var(--cv3-form-line));
  border-radius: 0 1rem 1rem 1rem;
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--cv3-form-accent) 9%, transparent), transparent 36%),
    var(--cv3-form-surface-soft);
}

.core-v3-contact-form__quick-requests-title {
  color: var(--cv3-form-text-soft);
  font-family: var(--cv3-form-font-ui);
  font-size: 0.8125rem;
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.core-v3-contact-form__quick-requests-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.core-v3-contact-form__quick-request {
  appearance: none;
  border: 1px solid color-mix(in srgb, var(--cv3-form-accent) 28%, var(--cv3-form-line));
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-width: 100%;
  min-height: 2.5rem;
  padding: 0.625rem 0.75rem;
  border-radius: 0 0.875rem 0.875rem 0.875rem;
  background: var(--cv3-form-surface);
  color: var(--cv3-form-accent-strong);
  font: inherit;
  font-family: var(--cv3-form-font-ui);
  font-size: 0.875rem;
  font-weight: 750;
  line-height: 1.2;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.18s ease, background-color 0.18s ease, color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.core-v3-contact-form__quick-request:hover {
  transform: translateY(-0.0625rem);
  border-color: var(--cv3-form-accent);
  box-shadow: 0 0.625rem 1.25rem rgba(10, 24, 26, 0.08);
}

.core-v3-contact-form__quick-request:focus-visible {
  outline: 0.1875rem solid color-mix(in srgb, var(--cv3-form-focus) 92%, white 8%);
  outline-offset: 0.125rem;
}

.core-v3-contact-form__quick-request[aria-pressed="true"] {
  background: color-mix(in srgb, var(--cv3-form-accent) 12%, var(--cv3-form-surface));
  border-color: var(--cv3-form-accent);
  color: var(--cv3-form-text);
}

.core-v3-contact-form__privacy {
  margin: 0;
}

.core-v3-contact-form__check {
  display: grid;
  grid-template-columns: 1.125rem 1fr;
  align-items: start;
  gap: 0.625rem;
  color: var(--cv3-form-text-soft);
  font-size: 0.875rem;
  line-height: 1.65;
  cursor: pointer;
}

.core-v3-contact-form__check input {
  margin: 0.125rem 0 0;
  width: 1rem;
  height: 1rem;
  accent-color: var(--cv3-form-accent);
}

.core-v3-contact-form__actions {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

.core-v3-contact-form__submit {
  appearance: none;
  border: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  padding: 0.8125rem 1.125rem;
  background: linear-gradient(180deg, var(--cv3-form-button-top) 0%, var(--cv3-form-button-mid) 56%, var(--cv3-form-button-bottom) 100%);
  color: var(--cv3-form-button-text);
  font: inherit;
  font-family: var(--cv3-form-font-ui);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.15;
  border-radius: 0 0.875rem 0.875rem 0.875rem;
  cursor: pointer;
  box-shadow: var(--cv3-form-button-shadow);
  transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease, opacity 0.18s ease;
}

.core-v3-contact-form__submit:hover {
  transform: translateY(-0.0625rem);
  box-shadow: var(--cv3-form-button-shadow-hover);
  filter: saturate(1.03) brightness(1.01);
}

.core-v3-contact-form__submit:focus-visible {
  outline: 0.1875rem solid color-mix(in srgb, var(--cv3-form-focus) 92%, white 8%);
  outline-offset: 0.125rem;
}

.core-v3-contact-form__notice {
  padding: 0.875rem 1rem;
  border-radius: 0.875rem;
  margin: 0 0 1.125rem;
  background: var(--cv3-form-notice-bg);
  color: var(--cv3-form-notice-text);
  border: 1px solid var(--cv3-form-line);
}

.core-v3-contact-form__notice--error {
  background: var(--cv3-form-error-bg);
  color: var(--cv3-form-error-text);
  border-color: color-mix(in srgb, var(--cv3-form-error-text) 18%, transparent);
}

.core-v3-contact-form__notice--success {
  background: var(--cv3-form-notice-bg);
}

.core-v3-contact-form__hp {
  position: absolute;
  left: -9999px;
  opacity: 0;
  pointer-events: none;
}

@media (max-width: 64rem) {
  .core-v3-contact-form__message-row {
    grid-template-columns: 1fr;
  }

  .core-v3-contact-form__upload-box,
  .core-v3-contact-form__textarea {
    min-height: 12.5rem;
  }
}

@media (max-width: 48.875rem) {
  .core-v3-contact-form__quick-requests {
    padding: 0.75rem;
  }

  .core-v3-contact-form__quick-requests-buttons {
    display: grid;
    grid-template-columns: 1fr;
  }

  .core-v3-contact-form__quick-request {
    width: 100%;
    justify-content: flex-start;
  }

  .core-v3-contact-form__grid,
  .core-v3-contact-form__message-row {
    grid-template-columns: 1fr;
  }

  .core-v3-contact-form__control {
    font-size: 1rem;
    min-height: 3.25rem;
    padding: 0.9375rem;
  }

  .core-v3-contact-form__upload-box,
  .core-v3-contact-form__textarea {
    min-height: 11.875rem;
  }

  .core-v3-contact-form__submit {
    width: 100%;
    min-height: 3.25rem;
  }

  .core-v3-contact-form__actions {
    justify-content: stretch;
  }
}

@media (max-width: 34rem) {
  .core-v3-contact-form__name-grid {
    grid-template-columns: 1fr;
  }
}

.core-v3-contact-form__context {
  display: grid;
  gap: 0.35rem;
  margin: 0 0 1.125rem;
  padding: 1rem 1.125rem;
  border: 1px solid color-mix(in srgb, var(--cv3-form-accent) 24%, var(--cv3-form-line));
  border-radius: 0 1.125rem 1.125rem 1.125rem;
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--cv3-form-accent) 12%, transparent), transparent 34%),
    var(--cv3-form-surface-soft);
  color: var(--cv3-form-text);
  box-shadow: 0 0.875rem 1.75rem rgba(10, 24, 26, 0.06);
}

.core-v3-contact-form__context-kicker {
  color: var(--cv3-form-accent-strong);
  font-family: var(--cv3-form-font-ui);
  font-size: 0.75rem;
  line-height: 1.35;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.core-v3-contact-form__context strong {
  color: var(--cv3-form-text);
  font-family: var(--cv3-form-font-heading);
  font-size: clamp(1.18rem, 2vw, 1.45rem);
  line-height: 1.15;
}

.core-v3-contact-form__context span:not(.core-v3-contact-form__context-kicker),
.core-v3-contact-form__context p {
  margin: 0;
  color: var(--cv3-form-text-soft);
  font-size: 0.95rem;
  line-height: 1.6;
}

/* Version 3.2.2: Layout-Tausch, Plausibilitätsmarkierung und Datenschutz-Overlay. */
:root {
  --cv3-form-valid: #2f8b5f;
  --cv3-form-valid-soft: #eef8f1;
  --cv3-form-valid-line: rgba(47, 139, 95, 0.42);
}

html[data-theme="dark"],
body.theme-dark,
body.is-theme-dark {
  --cv3-form-valid-soft: rgba(47, 139, 95, 0.13);
  --cv3-form-valid-line: rgba(80, 186, 128, 0.46);
}

.core-v3-contact-form__grid {
  align-items: start;
}

.core-v3-contact-form__field,
.core-v3-contact-form__subfield,
.core-v3-contact-form__upload-panel {
  align-content: start;
}

input.core-v3-contact-form__control,
select.core-v3-contact-form__control {
  min-height: 3.25rem;
}

@media (min-width: 64.001rem) {
  .core-v3-contact-form__message-row > .core-v3-contact-form__upload-panel {
    grid-column: 1;
    grid-row: 1;
  }

  .core-v3-contact-form__message-row > .core-v3-contact-form__field--message {
    grid-column: 2;
    grid-row: 1;
  }
}

@media (max-width: 64rem) {
  .core-v3-contact-form__message-row > .core-v3-contact-form__upload-panel,
  .core-v3-contact-form__message-row > .core-v3-contact-form__field--message {
    grid-column: auto;
    grid-row: auto;
  }
}

.core-v3-contact-form__control.is-plausible {
  border-color: var(--cv3-form-valid-line);
  background:
    linear-gradient(0deg, color-mix(in srgb, var(--cv3-form-valid-soft) 82%, transparent), color-mix(in srgb, var(--cv3-form-valid-soft) 82%, transparent)),
    var(--cv3-form-surface);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--cv3-form-valid) 18%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.core-v3-contact-form__control.is-plausible:focus,
.core-v3-contact-form__control.is-plausible:focus-visible {
  border-color: var(--cv3-form-valid);
  box-shadow:
    0 0 0 0.1875rem color-mix(in srgb, var(--cv3-form-valid) 21%, transparent),
    inset 0 0 0 1px color-mix(in srgb, var(--cv3-form-valid) 18%, transparent);
}

.core-v3-contact-form__upload-box.is-plausible {
  border-color: var(--cv3-form-valid-line);
  background:
    linear-gradient(0deg, color-mix(in srgb, var(--cv3-form-valid-soft) 78%, transparent), color-mix(in srgb, var(--cv3-form-valid-soft) 78%, transparent)),
    var(--cv3-form-surface-soft);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--cv3-form-valid) 14%, transparent);
}

.core-v3-contact-form__check.is-plausible {
  color: var(--cv3-form-text);
}

.core-v3-contact-form__check.is-plausible input {
  outline: 0.125rem solid color-mix(in srgb, var(--cv3-form-valid) 22%, transparent);
  outline-offset: 0.125rem;
}

.core-v3-contact-form__quick-request {
  background: linear-gradient(180deg, var(--cv3-form-button-top) 0%, var(--cv3-form-button-mid) 58%, var(--cv3-form-button-bottom) 100%);
  border-color: color-mix(in srgb, var(--cv3-form-button-bottom) 70%, black 30%);
  color: #ffffff;
  text-shadow:
    0 1px 0 rgba(0, 0, 0, 0.86),
    0 2px 0 rgba(0, 0, 0, 0.42),
    0 3px 3px rgba(0, 0, 0, 0.24);
  box-shadow: 0 0.625rem 1.25rem rgba(10, 24, 26, 0.1);
}

.core-v3-contact-form__quick-request:hover,
.core-v3-contact-form__quick-request[aria-pressed="true"] {
  background: linear-gradient(180deg, color-mix(in srgb, var(--cv3-form-button-top) 88%, white 12%) 0%, var(--cv3-form-button-mid) 56%, var(--cv3-form-button-bottom) 100%);
  border-color: color-mix(in srgb, var(--cv3-form-button-bottom) 78%, black 22%);
  color: #ffffff;
}

.core-v3-contact-form__submit,
.core-v3-contact-form__privacy-close {
  color: #ffffff;
  text-shadow:
    0 1px 0 rgba(0, 0, 0, 0.86),
    0 2px 0 rgba(0, 0, 0, 0.42),
    0 3px 3px rgba(0, 0, 0, 0.24);
}

html.core-v3-contact-form-privacy-open,
html.core-v3-contact-form-privacy-open body {
  overflow: hidden;
}

.core-v3-contact-form__privacy-modal {
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: none;
  place-items: center;
  padding: clamp(1rem, 3vw, 2.5rem);
}

.core-v3-contact-form__privacy-modal.is-open {
  display: grid;
}

.core-v3-contact-form__privacy-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(8, 14, 16, 0.68);
  backdrop-filter: blur(0.25rem);
}

.core-v3-contact-form__privacy-dialog {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto 1fr;
  width: min(100%, 72rem);
  height: min(100%, 82vh);
  min-height: 24rem;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--cv3-form-line-strong) 70%, white 30%);
  border-radius: 0 1.375rem 1.375rem 1.375rem;
  background: var(--cv3-form-surface);
  box-shadow: 0 1.875rem 5rem rgba(0, 0, 0, 0.32);
}

.core-v3-contact-form__privacy-dialog-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.875rem 1rem;
  border-bottom: 1px solid var(--cv3-form-line);
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--cv3-form-accent) 10%, transparent), transparent 38%),
    var(--cv3-form-surface-soft);
}

.core-v3-contact-form__privacy-dialog-head strong {
  color: var(--cv3-form-text);
  font-family: var(--cv3-form-font-ui);
  font-size: 1rem;
  line-height: 1.3;
}

.core-v3-contact-form__privacy-close {
  appearance: none;
  border: 1px solid color-mix(in srgb, var(--cv3-form-button-bottom) 72%, black 28%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.625rem;
  padding: 0.625rem 0.875rem;
  border-radius: 0 0.875rem 0.875rem 0.875rem;
  background: linear-gradient(180deg, var(--cv3-form-button-top) 0%, var(--cv3-form-button-mid) 56%, var(--cv3-form-button-bottom) 100%);
  font: inherit;
  font-family: var(--cv3-form-font-ui);
  font-size: 0.9rem;
  font-weight: 800;
  line-height: 1.1;
  cursor: pointer;
}

.core-v3-contact-form__privacy-close:focus-visible {
  outline: 0.1875rem solid color-mix(in srgb, var(--cv3-form-focus) 92%, white 8%);
  outline-offset: 0.125rem;
}

.core-v3-contact-form__privacy-content {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
  overflow: auto;
  padding: clamp(1rem, 2.4vw, 2rem);
  background: var(--cv3-form-surface);
  color: var(--cv3-form-text);
  font-family: var(--cv3-form-font-body);
  line-height: 1.72;
}

.core-v3-contact-form__privacy-content.is-loading,
.core-v3-contact-form__privacy-content.is-error {
  display: grid;
  align-content: center;
  justify-items: start;
  gap: 0.75rem;
  color: var(--cv3-form-text-soft);
}

.core-v3-contact-form__privacy-content > *:first-child {
  margin-top: 0;
}

.core-v3-contact-form__privacy-content > *:last-child {
  margin-bottom: 0;
}

.core-v3-contact-form__privacy-content h1,
.core-v3-contact-form__privacy-content h2,
.core-v3-contact-form__privacy-content h3,
.core-v3-contact-form__privacy-content h4 {
  color: var(--cv3-form-text);
}

.core-v3-contact-form__privacy-content a {
  color: var(--cv3-form-accent);
  text-decoration-thickness: 0.08em;
  text-underline-offset: 0.18em;
}

@media (max-width: 48.875rem) {
  .core-v3-contact-form__privacy-modal {
    padding: 0.75rem;
  }

  .core-v3-contact-form__privacy-dialog {
    height: min(100%, 88vh);
    min-height: 20rem;
  }

  .core-v3-contact-form__privacy-dialog-head {
    align-items: stretch;
    flex-direction: column;
  }

  .core-v3-contact-form__privacy-close {
    width: 100%;
  }
}


/* Version 4.0.1: Datenschutz-Overlay lädt nur Seiteninhalt per AJAX, ohne komplette WordPress-Seite. */
.core-v3-contact-form__intro {
  display: grid;
  gap: 0.75rem;
  margin: 0 0 1.25rem;
  padding: clamp(1rem, 2.5vw, 1.5rem);
  border: 1px solid color-mix(in srgb, var(--cv3-form-accent) 20%, var(--cv3-form-line));
  border-radius: 0 1.375rem 1.375rem 1.375rem;
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--cv3-form-accent) 11%, transparent), transparent 38%),
    var(--cv3-form-surface-soft);
  box-shadow: 0 0.875rem 1.75rem rgba(10, 24, 26, 0.06);
}

.core-v3-contact-form__eyebrow {
  color: var(--cv3-form-accent-strong);
  font-family: var(--cv3-form-font-ui);
  font-size: 0.75rem;
  font-weight: 850;
  letter-spacing: 0.09em;
  line-height: 1.35;
  text-transform: uppercase;
}

.core-v3-contact-form__intro h2 {
  margin: 0;
  color: var(--cv3-form-text);
  font-family: var(--cv3-form-font-heading);
  font-size: clamp(1.45rem, 3vw, 2.35rem);
  line-height: 1.08;
}

.core-v3-contact-form__intro p {
  max-width: 60rem;
  margin: 0;
  color: var(--cv3-form-text-soft);
  font-size: clamp(1rem, 1.35vw, 1.08rem);
  line-height: 1.65;
}

.core-v3-contact-form__promise-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.25rem;
}

.core-v3-contact-form__promise-list span {
  display: inline-flex;
  align-items: center;
  min-height: 2.25rem;
  padding: 0.5rem 0.7rem;
  border: 1px solid color-mix(in srgb, var(--cv3-form-accent) 18%, var(--cv3-form-line));
  border-radius: 999px;
  background: color-mix(in srgb, var(--cv3-form-surface) 88%, transparent);
  color: var(--cv3-form-text);
  font-family: var(--cv3-form-font-ui);
  font-size: 0.875rem;
  font-weight: 750;
  line-height: 1.2;
}

.core-v3-contact-form__upload-box {
  position: relative;
  align-content: center;
  justify-items: start;
  cursor: pointer;
  transition: border-color 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.core-v3-contact-form__upload-box:hover,
.core-v3-contact-form__upload-box.is-dragging {
  border-color: var(--cv3-form-accent);
  background:
    radial-gradient(circle at center, color-mix(in srgb, var(--cv3-form-accent) 10%, transparent), transparent 50%),
    var(--cv3-form-surface-soft);
  box-shadow: 0 0.875rem 1.75rem rgba(10, 24, 26, 0.08);
}

.core-v3-contact-form__upload-box.is-dragging {
  transform: translateY(-0.0625rem);
}

.core-v3-contact-form__upload-box:focus-visible {
  outline: 0.1875rem solid color-mix(in srgb, var(--cv3-form-focus) 92%, white 8%);
  outline-offset: 0.125rem;
}

.core-v3-contact-form__file {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
  padding: 0;
}

.core-v3-contact-form__upload-icon {
  display: grid;
  place-items: center;
  width: 3rem;
  height: 3rem;
  border: 1px solid color-mix(in srgb, var(--cv3-form-accent) 28%, var(--cv3-form-line));
  border-radius: 999px;
  background: color-mix(in srgb, var(--cv3-form-accent) 10%, var(--cv3-form-surface));
  color: var(--cv3-form-accent-strong);
  font-family: var(--cv3-form-font-ui);
  font-size: 1.65rem;
  font-weight: 900;
  line-height: 1;
}

.core-v3-contact-form__upload-trigger {
  appearance: none;
  border: 1px solid color-mix(in srgb, var(--cv3-form-accent) 28%, var(--cv3-form-line));
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.625rem;
  padding: 0.625rem 0.875rem;
  border-radius: 0 0.875rem 0.875rem 0.875rem;
  background: var(--cv3-form-surface);
  color: var(--cv3-form-accent-strong);
  font: inherit;
  font-family: var(--cv3-form-font-ui);
  font-size: 0.9rem;
  font-weight: 800;
  line-height: 1.1;
  cursor: pointer;
  transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.core-v3-contact-form__upload-trigger:hover {
  border-color: var(--cv3-form-accent);
  transform: translateY(-0.0625rem);
  box-shadow: 0 0.625rem 1.25rem rgba(10, 24, 26, 0.08);
}

.core-v3-contact-form__upload-trigger:focus-visible,
.core-v3-contact-form__file-remove:focus-visible {
  outline: 0.1875rem solid color-mix(in srgb, var(--cv3-form-focus) 92%, white 8%);
  outline-offset: 0.125rem;
}

.core-v3-contact-form__file-list {
  display: grid;
  gap: 0.5rem;
  width: 100%;
  margin: 0.25rem 0 0;
  padding: 0;
  list-style: none;
}

.core-v3-contact-form__file-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 0.5rem;
  align-items: center;
  width: 100%;
  padding: 0.55rem 0.65rem;
  border: 1px solid color-mix(in srgb, var(--cv3-form-accent) 18%, var(--cv3-form-line));
  border-radius: 0 0.75rem 0.75rem 0.75rem;
  background: var(--cv3-form-surface);
}

.core-v3-contact-form__file-name {
  min-width: 0;
  overflow: hidden;
  color: var(--cv3-form-text);
  font-family: var(--cv3-form-font-ui);
  font-size: 0.875rem;
  font-weight: 750;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.core-v3-contact-form__file-size {
  color: var(--cv3-form-text-soft);
  font-size: 0.8rem;
  line-height: 1.2;
  white-space: nowrap;
}

.core-v3-contact-form__file-remove {
  appearance: none;
  border: 0;
  padding: 0.25rem 0;
  background: transparent;
  color: var(--cv3-form-accent-strong);
  font: inherit;
  font-family: var(--cv3-form-font-ui);
  font-size: 0.8rem;
  font-weight: 800;
  line-height: 1.2;
  text-decoration: underline;
  cursor: pointer;
}

.core-v3-contact-form__file-feedback {
  min-height: 1.25rem;
  margin: 0;
  color: var(--cv3-form-text-soft);
  font-size: 0.875rem;
  line-height: 1.4;
}

.core-v3-contact-form__file-feedback.is-error {
  color: var(--cv3-form-error-text);
  font-weight: 750;
}

.core-v3-contact-form__actions {
  flex-wrap: wrap;
  gap: 0.875rem;
}

.core-v3-contact-form__after-submit {
  max-width: 36rem;
  color: var(--cv3-form-text-soft);
  font-size: 0.875rem;
  line-height: 1.5;
}

@media (max-width: 48.875rem) {
  .core-v3-contact-form__promise-list,
  .core-v3-contact-form__actions {
    display: grid;
  }

  .core-v3-contact-form__promise-list span {
    justify-content: center;
  }

  .core-v3-contact-form__file-item {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .core-v3-contact-form__file-remove {
    grid-column: 1 / -1;
    justify-self: start;
  }
}
