/* ============================================================
   SD-Link — Stilbrücke Kontakt-Seite (PRODUKTIV / Vanilla)
   ------------------------------------------------------------
   Eigenständig. Nur auf der Kontakt-Seite enqueuen. Alles unter
   .sd-contact-page gescoped, damit der übrige Shop unberührt bleibt.
   Tokens identisch zum Design-System (colors_and_type.css).
   Liegt der Home-/FAQ-Token-Block bereits global vor, kann der
   :root-Block hier entfallen (Werte sind identisch).

   Das Formular wird von Contact Form 7 gerendert. Diese Datei
   trifft sowohl die CF7-Ausgabeklassen (.wpcf7, .wpcf7-form,
   input.wpcf7-text, …) als auch die optionalen Layout-Helfer
   aus cf7/kontakt-cf7-template.html (.cf7-grid, .cf7-field,
   .cf7-req, .cf7-opt, .cf7-consent, .cf7-submit). Ohne Template-
   Änderung sieht das Default-CF7-Formular trotzdem markenkonform
   aus; mit Template-Änderung kommen Grid + Pflicht-Häkchen dazu.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root {
  --sd-navy-900:#0a1b2e; --sd-navy-800:#0f2742; --sd-navy-700:#163558;
  --sd-navy-600:#1f4878; --sd-navy-500:#2c5e95; --sd-navy-400:#5384b6;
  --sd-navy-200:#cfdce9; --sd-navy-100:#e7eef5; --sd-navy-050:#f4f7fa;
  --sd-amber-700:#b3590e; --sd-amber-600:#d76b14; --sd-amber-500:#ee8127; --sd-amber-100:#fde9d4;
  --sd-sky-700:#0d6fb8; --sd-sky-600:#1a8cd8; --sd-sky-100:#d8edfb;
  --sd-ink:#0e1620; --sd-ink-2:#3b4654; --sd-ink-3:#6b7888; --sd-ink-4:#9aa6b4;
  --sd-line:#d7dde4; --sd-line-soft:#ebeef2;
  --sd-success:#1f8a5b; --sd-success-bg:#e6f4ee;
  --sd-danger:#b3322a; --sd-danger-bg:#f7e2df;
  --fg-1:var(--sd-ink); --fg-2:var(--sd-ink-2); --fg-3:var(--sd-ink-3); --fg-muted:var(--sd-ink-4);
  --fg-brand:var(--sd-navy-700); --fg-link:var(--sd-navy-600); --fg-link-hover:var(--sd-amber-600);
  --bg-surface:#ffffff;
  --font-display:'IBM Plex Sans',system-ui,-apple-system,'Segoe UI',Arial,sans-serif;
  --font-body:'IBM Plex Sans',system-ui,-apple-system,'Segoe UI',Arial,sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,'SF Mono',Menlo,monospace;
  --r-sm:4px; --r-md:8px; --r-lg:14px; --r-pill:999px;
  --shadow-1:0 1px 2px rgba(14,22,32,.06),0 1px 1px rgba(14,22,32,.04);
  --shadow-2:0 2px 6px rgba(14,22,32,.07),0 4px 12px rgba(14,22,32,.06);
  --shadow-focus:0 0 0 3px rgba(44,94,149,.32);
  --ease-out:cubic-bezier(0.22,0.61,0.36,1);
  --dur-fast:120ms; --dur-base:200ms;
}

/* --- Grundlayout -------------------------------------------- */
.sd-contact-page { font-family: var(--font-body); color: var(--fg-1); background: #fff; }
.sd-contact-page *, .sd-contact-page *::before, .sd-contact-page *::after { box-sizing: border-box; }

.sd-contact-page .sd-breadcrumb {
  max-width: 1080px; margin: 0 auto; padding: 18px 24px 0;
  font-size: 13px; color: var(--fg-3); display: flex; gap: 6px; align-items: center;
}
.sd-contact-page .sd-breadcrumb a { color: var(--fg-2); text-decoration: none; }
.sd-contact-page .sd-breadcrumb a:hover { color: var(--sd-navy-600); }
.sd-contact-page .sd-breadcrumb .sep { color: var(--sd-line); }

.sd-contact-page .sd-static { max-width: 1080px; margin: 0 auto; padding: 40px 24px 80px; }
.sd-contact-page .sd-static h1 {
  font-family: var(--font-display); font-weight: 700; font-size: 44px;
  margin: 0 0 18px; color: var(--fg-brand); letter-spacing: -0.02em; line-height: 1.1;
}
.sd-contact-page .contact-intro {
  max-width: 66ch; font-size: 17px; line-height: 1.65; color: var(--fg-2); margin: 0;
}

/* --- Buttons (gescoped) ------------------------------------- */
.sd-contact-page .btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--font-body); font-weight: 700; font-size: 15px;
  height: 44px; padding: 0 20px; border-radius: var(--r-md);
  cursor: pointer; user-select: none; text-decoration: none;
  border: 1px solid transparent; white-space: nowrap;
  transition: background var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
}
.sd-contact-page .btn svg { width: 18px; height: 18px; }
.sd-contact-page .btn:focus-visible { outline: 0; box-shadow: var(--shadow-focus); }
.sd-contact-page .btn-primary { background: var(--sd-amber-600); color: #fff; border-color: rgba(0,0,0,.08); box-shadow: var(--shadow-1); }
.sd-contact-page .btn-primary:hover { background: var(--sd-amber-500); box-shadow: var(--shadow-2); color: #fff; }
.sd-contact-page .btn-lg { height: 52px; font-size: 16px; padding: 0 28px; }

/* --- Zwei-Spalten-Raster ------------------------------------ */
.sd-contact-page .contact-grid {
  display: grid; grid-template-columns: 1.45fr 1fr;
  gap: 28px; align-items: start; margin-top: 32px;
}

/* ============================================================
   FORMULAR — Contact Form 7 Ausgabe + Layout-Helfer
   ============================================================ */
.sd-contact-page .contact-form-wrap {
  background: var(--bg-surface);
  border: 1px solid var(--sd-line);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-1);
  padding: 28px;
}
.sd-contact-page .wpcf7 { margin: 0; }
.sd-contact-page .wpcf7-form { display: grid; gap: 16px; }
/* CF7 packt Felder default in <p> — als Grid-Items neutralisieren */
.sd-contact-page .wpcf7-form > p { margin: 0; }

/* Optionales Feld-Grid (Name + E-Mail nebeneinander, CF7-Template) */
.sd-contact-page .cf7-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.sd-contact-page .cf7-field { margin: 0; }

/* Labels */
.sd-contact-page .wpcf7-form label {
  display: block; font-weight: 700; font-size: 13px; color: var(--fg-2);
}
.sd-contact-page .wpcf7-form-control-wrap { display: block; margin-top: 6px; }

/* Pflicht-/Optional-Marker */
.sd-contact-page .cf7-req, .sd-contact-page .cf7-opt {
  font-family: var(--font-body); font-weight: 600; font-size: 10.5px;
  letter-spacing: 0.05em; text-transform: uppercase;
  padding: 2px 7px; border-radius: var(--r-pill); margin-left: 7px; vertical-align: 1px;
}
.sd-contact-page .cf7-req { color: var(--sd-amber-700); background: var(--sd-amber-100); }
.sd-contact-page .cf7-opt { color: var(--fg-3); background: var(--sd-navy-050); }

/* Eingabefelder — trifft CF7-Klassen direkt */
.sd-contact-page input.wpcf7-text,
.sd-contact-page input.wpcf7-email,
.sd-contact-page textarea.wpcf7-textarea,
.sd-contact-page .wpcf7-form input[type="text"],
.sd-contact-page .wpcf7-form input[type="email"],
.sd-contact-page .wpcf7-form textarea {
  width: 100%; height: 44px; padding: 0 14px;
  font-family: var(--font-body); font-size: 15px; color: var(--fg-1);
  border: 1px solid var(--sd-line); border-radius: var(--r-md);
  background: #fff; outline: none;
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
}
.sd-contact-page textarea.wpcf7-textarea,
.sd-contact-page .wpcf7-form textarea {
  height: auto; min-height: 132px; padding: 12px 14px; line-height: 1.5; resize: vertical;
}
.sd-contact-page input.wpcf7-text::placeholder,
.sd-contact-page input.wpcf7-email::placeholder,
.sd-contact-page textarea.wpcf7-textarea::placeholder { color: var(--fg-muted); }
.sd-contact-page input.wpcf7-text:focus,
.sd-contact-page input.wpcf7-email:focus,
.sd-contact-page textarea.wpcf7-textarea:focus,
.sd-contact-page .wpcf7-form input:focus,
.sd-contact-page .wpcf7-form textarea:focus {
  border-color: var(--sd-navy-500); box-shadow: var(--shadow-focus);
}

/* Datenschutz-Häkchen (CF7 acceptance) */
.sd-contact-page .cf7-consent,
.sd-contact-page .wpcf7-acceptance .wpcf7-list-item {
  margin: 0; font-size: 13px; line-height: 1.5; color: var(--fg-2);
}
.sd-contact-page .wpcf7-acceptance .wpcf7-list-item { display: block; }
.sd-contact-page .wpcf7-acceptance label { display: flex; gap: 11px; align-items: flex-start; font-weight: 400; cursor: pointer; }
.sd-contact-page .wpcf7-acceptance input[type="checkbox"] {
  width: 18px; height: 18px; margin: 2px 0 0; flex: none;
  accent-color: var(--sd-amber-600); cursor: pointer;
}
.sd-contact-page .cf7-consent a,
.sd-contact-page .wpcf7-acceptance a { color: var(--fg-link); text-decoration: underline; text-underline-offset: 2px; }
.sd-contact-page .cf7-consent a:hover,
.sd-contact-page .wpcf7-acceptance a:hover { color: var(--fg-link-hover); }

/* Submit — Amber-Primär-CTA (auch ohne class:btn) */
.sd-contact-page .cf7-submit { margin: 0; }
.sd-contact-page input.wpcf7-submit,
.sd-contact-page .wpcf7-submit {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 52px; padding: 0 28px; border: 1px solid rgba(0,0,0,.08);
  border-radius: var(--r-md); cursor: pointer;
  font-family: var(--font-body); font-weight: 700; font-size: 16px;
  background: var(--sd-amber-600); color: #fff; box-shadow: var(--shadow-1);
  transition: background var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.sd-contact-page input.wpcf7-submit:hover,
.sd-contact-page .wpcf7-submit:hover { background: var(--sd-amber-500); box-shadow: var(--shadow-2); }
.sd-contact-page .wpcf7-submit:focus-visible { outline: 0; box-shadow: var(--shadow-focus); }

/* Validierung + Response-Output markenkonform */
.sd-contact-page .wpcf7-not-valid-tip {
  display: block; margin-top: 6px; font-size: 13px; font-weight: 600; color: var(--sd-danger);
}
.sd-contact-page .wpcf7-form input.wpcf7-not-valid,
.sd-contact-page .wpcf7-form textarea.wpcf7-not-valid { border-color: var(--sd-danger); }
.sd-contact-page .wpcf7-response-output {
  margin: 4px 0 0 !important; padding: 12px 14px !important;
  border: 1px solid transparent !important; border-radius: var(--r-md);
  font-size: 14px; font-weight: 600; line-height: 1.5;
}
.sd-contact-page .wpcf7-form.sent .wpcf7-response-output {
  background: var(--sd-success-bg); border-color: rgba(31,138,91,.28) !important; color: var(--sd-success);
}
.sd-contact-page .wpcf7-form.invalid .wpcf7-response-output,
.sd-contact-page .wpcf7-form.failed .wpcf7-response-output,
.sd-contact-page .wpcf7-form.spam .wpcf7-response-output {
  background: var(--sd-danger-bg); border-color: rgba(179,50,42,.28) !important; color: var(--sd-danger);
}
.sd-contact-page .wpcf7-spinner { background-color: var(--sd-amber-600); margin: 0 0 0 10px; }

/* ============================================================
   KONTAKT-KARTE
   ============================================================ */
.sd-contact-page .contact-card {
  background: var(--bg-surface); border: 1px solid var(--sd-line);
  border-radius: var(--r-lg); box-shadow: var(--shadow-1); padding: 24px;
}
.sd-contact-page .cc-eyebrow {
  font-family: var(--font-body); font-weight: 600; font-size: 12px;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--sd-amber-600);
}
.sd-contact-page .contact-card h2 {
  font-family: var(--font-display); font-weight: 700; font-size: 20px;
  line-height: 1.2; color: var(--fg-brand); letter-spacing: -0.01em; margin: 7px 0 0;
}
.sd-contact-page .contact-card h2 span {
  display: block; margin-top: 2px; font-size: 13px; font-weight: 600;
  letter-spacing: 0.02em; color: var(--fg-3);
}
.sd-contact-page .contact-rows { display: flex; flex-direction: column; gap: 4px; margin-top: 18px; }
.sd-contact-page .crow { display: flex; gap: 12px; align-items: flex-start; padding: 10px; border-radius: var(--r-md); color: inherit; text-decoration: none; }
.sd-contact-page .crow .ic {
  width: 40px; height: 40px; flex: none; border-radius: 10px;
  background: var(--sd-navy-100); color: var(--sd-navy-700);
  display: flex; align-items: center; justify-content: center;
}
.sd-contact-page .crow .ic svg { width: 18px; height: 18px; display: block; }
.sd-contact-page .crow .ct { display: flex; flex-direction: column; gap: 3px; padding-top: 1px; }
.sd-contact-page .crow .ck { font-size: 10.5px; font-weight: 600; letter-spacing: 0.09em; text-transform: uppercase; color: var(--fg-3); }
.sd-contact-page .crow .cv { font-size: 14px; line-height: 1.45; color: var(--fg-1); }
.sd-contact-page .contact-mono { font-family: var(--font-mono); font-weight: 500; font-size: 13.5px; }
.sd-contact-page .crow--link { transition: background var(--dur-fast) var(--ease-out); }
.sd-contact-page .crow--link:hover { background: var(--sd-navy-050); }
.sd-contact-page .crow--link:hover .cv { color: var(--sd-amber-600); }
.sd-contact-page .crow--link:focus-visible { outline: 0; box-shadow: var(--shadow-focus); }
.sd-contact-page .contact-card-note {
  margin: 18px 0 0; padding-top: 16px; border-top: 1px solid var(--sd-line-soft);
  font-size: 13px; line-height: 1.55; color: var(--fg-3);
}

/* ============================================================
   QUERLINK-BAND
   ============================================================ */
.sd-contact-page .contact-help { margin-top: 44px; }
.sd-contact-page .contact-help-title {
  font-family: var(--font-display); font-weight: 700; font-size: 22px;
  letter-spacing: -0.01em; color: var(--fg-brand); margin: 0 0 16px;
}
.sd-contact-page .help-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.sd-contact-page .help-card {
  display: flex; align-items: center; gap: 14px; text-align: left; padding: 16px 18px;
  background: var(--bg-surface); border: 1px solid var(--sd-line);
  border-radius: var(--r-lg); box-shadow: var(--shadow-1);
  cursor: pointer; text-decoration: none; color: inherit; font-family: var(--font-body);
  transition: box-shadow var(--dur-base) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
}
.sd-contact-page .help-card:hover { box-shadow: var(--shadow-2); border-color: var(--sd-navy-200); }
.sd-contact-page .help-card:focus-visible { outline: 0; box-shadow: var(--shadow-focus); }
.sd-contact-page .help-card .ic {
  width: 44px; height: 44px; flex: none; border-radius: 10px;
  background: var(--sd-navy-100); color: var(--sd-navy-700);
  display: flex; align-items: center; justify-content: center;
}
.sd-contact-page .help-card .ic svg { width: 20px; height: 20px; display: block; }
.sd-contact-page .hc-text { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.sd-contact-page .hc-title { font-weight: 700; font-size: 15px; color: var(--fg-1); }
.sd-contact-page .hc-sub { font-size: 13px; color: var(--fg-3); }
.sd-contact-page .hc-arrow { color: var(--fg-3); flex: none; display: flex; transition: transform var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.sd-contact-page .hc-arrow svg { width: 18px; height: 18px; display: block; }
.sd-contact-page .help-card:hover .hc-arrow { color: var(--sd-amber-600); transform: translateX(2px); }

/* --- Mobil --------------------------------------------------- */
@media (max-width: 720px) {
  .sd-contact-page .sd-static h1 { font-size: 34px; }
  .sd-contact-page .contact-grid { grid-template-columns: 1fr; gap: 20px; }
  .sd-contact-page .contact-form-wrap { padding: 22px; }
  .sd-contact-page .cf7-grid { grid-template-columns: 1fr; }
  .sd-contact-page .help-cards { grid-template-columns: 1fr; }
  .sd-contact-page input.wpcf7-submit,
  .sd-contact-page .wpcf7-submit { width: 100%; }
}

/* --- Reduced motion ----------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  .sd-contact-page .help-card, .sd-contact-page .hc-arrow, .sd-contact-page .crow--link { transition: none; }
  .sd-contact-page .help-card:hover .hc-arrow { transform: none; }
}

/* ============================================================
   INTEGRATIONS-OVERRIDE (Storefront/CF7 auf DEV)
   ------------------------------------------------------------
   Behebt die letzten Abweichungen zur Referenz
   (design_handoff_kontakt/reference/kontakt-vanilla-preview.html):
   1) ~150px Leerraum unter "Senden": Spalten nicht strecken +
      leere CF7-Response/leere <p> reservieren keine Hoehe.
   2) Radien: Theme ueberschreibt var(--r-*) -> per !important
      erzwingen (Form-Card 14px, Inputs/Textarea/Submit 8px).
   ============================================================ */

/* 1) Kein Stretch der Form-Spalte auf Karten-Hoehe */
.sd-contact-page .contact-grid { align-items: start !important; }

/* Form-Card bringt keine Fixhoehe mit; leere Knoten kollabieren */
.sd-contact-page .contact-form-wrap p:empty { display: none; }
.sd-contact-page .wpcf7-form > p:empty { display: none; margin: 0; }

/* Leere Response-Box (Default-Zustand) reserviert keine Hoehe.
   Padding/Border/Hintergrund erst, wenn CF7 sie befuellt (.sent/.invalid/…). */
.sd-contact-page .wpcf7-response-output {
  min-height: 0 !important; margin-top: 0 !important;
}
.sd-contact-page .wpcf7-response-output:empty {
  display: none !important; padding: 0 !important; border: 0 !important;
}

/* 2) Radien gegen Theme erzwingen */
.sd-contact-page .contact-form-wrap { border-radius: 14px !important; }
.sd-contact-page input.wpcf7-text,
.sd-contact-page input.wpcf7-email,
.sd-contact-page textarea.wpcf7-textarea { border-radius: 8px !important; }
.sd-contact-page input.wpcf7-submit,
.sd-contact-page .wpcf7-submit { border-radius: 8px !important; }
