/* ============================================================
   CoLe's Heart — kontakt.css
   Page-Composition für die KONTAKT-Seite (Page 127), Version E (Sidebar):
   links schmale, mitlaufende Info-Spalte (Eyebrow + Serif-H1 + Lead + Kontakt-
   Kanäle) · rechts breite Formular-Karte (Gravity Forms #2).
   Quelle: Claude-Design-Export „Kontakt – Finale (Version E)".
   Form-Atome aus brand.css; hier: Page-Layout + Retheme der GF-Orbital-
   Markup auf den flachen, eckigen .ch-*-Look. Lädt via assets/css-Auto-Loader.
   Info-Spalte sitzt oben bündig zur Formular-Karte (align-items:start),
   kein Sticky (Bereich zu kurz).
   ============================================================ */

/* ===================== Sektion + 2-Spalten-Grid ===================== */
.kt-contact { background: var(--ch-cream); }
.kt-contact > .row_inner {
  display: grid !important; grid-template-columns: .72fr 1.28fr; gap: 64px;
  align-items: start; max-width: 1180px; margin-inline: auto;
  padding: 64px 24px 96px; position: relative;
}
.kt-contact > .row_inner > .module_column {
  width: auto !important; float: none !important; margin: 0 !important; min-width: 0;
}
.kt-contact .module { margin: 0; }

/* ---- Info-Spalte (oben bündig zur Formular-Karte, kein Sticky) ---- */
.ke-aside { box-sizing: border-box; }
.ke-aside__inner { box-sizing: border-box; }
.ke-aside__eyebrow {
  font-family: var(--ch-font-body); font-weight: 700; font-size: 13px;
  letter-spacing: .16em; text-transform: uppercase; color: var(--ch-gold-600);
  display: block; margin-bottom: 14px;
}
.ke-aside__title {
  font-family: var(--ch-font-display) !important; font-weight: 600;
  font-size: clamp(30px, 3.2vw, 42px); line-height: 1.08;
  color: var(--ch-ink); margin: 0 0 16px;
}
.ke-aside__title em { font-style: italic; color: var(--ch-gold-500); }
.ke-aside__text {
  font-family: var(--ch-font-body); font-size: 17px; line-height: 1.65;
  color: var(--ch-ink-soft); margin: 0 0 30px;
}

/* ---- Kontakt-Kanäle (eckige Icon-Bubbles, inline-SVG) ---- */
.kt-channels { display: flex; flex-direction: column; gap: 20px; }
.kt-channel { display: flex; gap: 16px; align-items: flex-start; }
.kt-channel__ic {
  flex: none; width: 52px; height: 52px;
  background: var(--ch-gold-50); color: var(--ch-gold-600);
  display: flex; align-items: center; justify-content: center;
}
.kt-channel__ic svg { width: 24px; height: 24px; }
.kt-channel__k {
  font-family: var(--ch-font-body); font-weight: 700; font-size: 13px;
  letter-spacing: .08em; text-transform: uppercase; color: var(--ch-ink-mute);
  margin: 0 0 3px;
}
.kt-channel__v {
  font-family: var(--ch-font-body); font-weight: 600; font-size: 18px;
  line-height: 1.3; color: var(--ch-ink); margin: 0;
}
.kt-channel__v a { color: var(--ch-ink); text-decoration: none; }
.kt-channel__v a:hover { color: var(--ch-gold-600); }

/* ===================== Formular-Karte ===================== */
.ke-form {
  background: var(--ch-white); border: 1px solid var(--ch-line);
  padding: 40px 40px 44px;
}
.kt-formcard__title {
  font-family: var(--ch-font-display) !important; font-weight: 600;
  font-size: 28px; color: var(--ch-ink); margin: 0 0 6px;
}
.kt-formcard__sub {
  font-family: var(--ch-font-body); font-size: 15.5px; line-height: 1.6;
  color: var(--ch-ink-soft); margin: 0 0 26px;
}

/* ---- Gravity Forms (#2) auf .ch-*-Look umstylen ---- */
.ke-form .gform_wrapper { margin: 0; }
.ke-form .gform_validation_container,
.ke-form .gfield--type-honeypot { display: none !important; }

/* Felder-Raster: Name + E-Mail nebeneinander, Rest volle Breite
   (mit !important gegen GFs eigenes 12-Spalten-Orbital-Grid) */
.ke-form .gform_fields {
  display: grid !important; grid-template-columns: 1fr 1fr !important;
  gap: 18px !important; margin: 0; padding: 0;
}
.ke-form .gform_fields > .gfield { grid-column: 1 / -1 !important; margin: 0 !important; padding: 0 !important; }
.ke-form #field_2_1 { grid-column: 1 / 2 !important; }
.ke-form #field_2_2 { grid-column: 2 / 3 !important; }

.ke-form .gfield_label,
.ke-form .gform-field-label {
  font-family: var(--ch-font-body); font-weight: 500; font-size: 14px;
  color: var(--ch-ink); margin: 0 0 8px; padding: 0;
}
.ke-form .gfield_required_text { color: var(--ch-ink-mute); font-weight: 400; font-size: 12px; }

.ke-form .gfield input[type="text"],
.ke-form .gfield input[type="email"],
.ke-form .gfield textarea,
.ke-form .gfield select {
  font-family: var(--ch-font-body); font-size: 16px; color: var(--ch-ink);
  background: var(--ch-white) !important; border: 1.5px solid var(--ch-line) !important;
  border-radius: 0 !important; padding: 0.8em 1em !important; width: 100% !important;
  box-shadow: none; transition: border-color .2s ease, box-shadow .2s ease;
}
.ke-form .gfield textarea { min-height: 150px; resize: vertical; }
.ke-form .gfield input::placeholder,
.ke-form .gfield textarea::placeholder { color: var(--ch-ink-mute); }
.ke-form .gfield input:focus,
.ke-form .gfield textarea:focus,
.ke-form .gfield select:focus {
  outline: none; border-color: var(--ch-gold-300) !important; box-shadow: var(--ch-ring-gold);
}
.ke-form .ginput_container { margin-top: 0; }

/* Datenschutz-Checkbox — redundante Legende sr-only, mehr Luft */
.ke-form .kt-consent { border: 0; padding: 0; margin: 10px 0 0 !important; }
.ke-form .kt-consent > legend.gfield_label {
  position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
.ke-form .gfield_checkbox .gchoice {
  display: flex !important; align-items: flex-start; gap: 14px !important; margin: 0 !important;
}
/* GF-Orbital ersetzt die Checkbox durch eine eigene (blaue) Box → native zurückholen */
.ke-form .gfield_checkbox input[type="checkbox"] {
  appearance: auto !important; -webkit-appearance: auto !important;
  width: 18px !important; height: 18px !important; min-width: 18px;
  margin: 2px 0 0 !important; padding: 0 !important;
  accent-color: var(--ch-gold-500) !important;
  background: none !important; border: none !important; box-shadow: none !important;
  flex: 0 0 auto !important; position: static !important;
}
.ke-form .gfield_checkbox input[type="checkbox"]::before { content: none !important; }
.ke-form .gfield_checkbox label {
  font-family: var(--ch-font-body); font-size: 14px; line-height: 1.55;
  color: var(--ch-ink-soft); margin: 0 !important; padding: 0 !important; flex: 1 1 auto;
}
.ke-form .gfield_checkbox label a {
  color: var(--ch-gold-600); text-decoration: none; border-bottom: 1px solid var(--ch-gold-200);
}

/* Senden-Button (= .ch-btn--primary --lg) */
.ke-form .gform_footer { margin: 26px 0 0; padding: 0; }
.ke-form .gform_button {
  font-family: var(--ch-font-body); font-weight: 500; font-size: 16px;
  color: var(--ch-on-primary) !important; background: var(--ch-gold-400) !important;
  border: 1.5px solid var(--ch-gold-400) !important; border-radius: var(--ch-radius-md);
  padding: 0.85em 1.85em; cursor: pointer; width: auto;
  transition: background .2s ease, border-color .2s ease, transform .15s ease;
}
.ke-form .gform_button:hover { background: var(--ch-gold-500) !important; border-color: var(--ch-gold-500) !important; }
.ke-form .gform_button:active { transform: scale(0.98); }

/* Validierungs-/Bestätigungs-Hinweise dezent */
.ke-form .gfield_description.validation_message,
.ke-form .gform_validation_errors {
  font-family: var(--ch-font-body); font-size: 13.5px; color: #b4452f;
}
.ke-form .gform_confirmation_message {
  font-family: var(--ch-font-body); font-size: 17px; line-height: 1.6; color: var(--ch-ink-soft);
}

/* ===================== Responsive ===================== */
@media (max-width: 980px) {
  .kt-contact > .row_inner { grid-template-columns: 1fr; gap: 36px; padding: 48px 22px 70px; }
  .ke-aside__inner { position: static !important; top: auto !important; left: auto !important; width: auto !important; }
}
@media (max-width: 560px) {
  .ke-form { padding: 26px; }
  .ke-form .gform_fields { grid-template-columns: 1fr !important; }
  .ke-form #field_2_1, .ke-form #field_2_2 { grid-column: 1 / -1 !important; }
}
