/* =========================
   FEDV – Kontakt IT (CF7)
   Datei: /assets/css/pages/fedv-contact-it.css
========================= */

.fedv-contact-it, .fedv-contact-it *{ box-sizing:border-box; }

.fedv-contact-it{
  --brand:#1B47DA;
  --brand2:#003d8f;

  --text:#1a1a1a;
  --muted:#4c5b66;
  --label:#7c8d9a;

  --border1:#dde4ea;
  --border2:#ccd8e3;

  --surface:#ffffff;

  --radius:18px;
  --radius2:22px;

  --shadow: 0 18px 44px rgba(15,23,42,.10);
  --shadow2: 0 10px 26px rgba(15,23,42,.08);

  /* Gradient wie gewünscht (typisch FEDV, leicht, nicht kitschig) */
  --gradA: linear-gradient(135deg,
    rgba(27,71,218,.10) 0%,
    rgba(0,61,143,.06) 45%,
    rgba(255,255,255,.88) 100%
  );

  color:var(--text);
}

/* Container/Section */
.fedv-contact-it .fedv-contact-wrap{
  max-width: 1540px;
  margin: 0 auto;
  padding: clamp(18px, 2.2vw, 26px) 16px 56px;
}

/* Headline + Lead */
.fedv-contact-it .fedv-contact-head{
  margin: 0 0 18px;
}
.fedv-contact-it .fedv-contact-head h2{
  margin:0 0 6px;
  font-size: clamp(22px, 2.2vw, 30px);
  letter-spacing: -.02em;
}
.fedv-contact-it .fedv-contact-head p{
  margin:0;
  color:var(--muted);
  max-width: 70ch;
}

/* Grid: Formular + Trust Box */
.fedv-contact-it .fedv-contact-grid{
  margin-top: 18px;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 16px;
  align-items:start;
}

@media (max-width: 920px){
  .fedv-contact-it .fedv-contact-grid{
    grid-template-columns: 1fr;
  }
}

/* Karten */
.fedv-contact-it .fedv-card{
  background: var(--surface);
  border: 1px solid rgba(15,23,42,.10);
  border-radius: var(--radius2);
  box-shadow: var(--shadow2);
  overflow:hidden;
}

/* Gradient Header/Top */
.fedv-contact-it .fedv-card--grad{
  background: var(--gradA);
  border: 1px solid rgba(27,71,218,.18);
  box-shadow: var(--shadow);
}

/* Card padding */
.fedv-contact-it .fedv-card .fedv-card-pad{
  padding: 18px;
}

@media (max-width: 600px){
  .fedv-contact-it .fedv-card .fedv-card-pad{
    padding: 14px;
  }
}

/* Trust Box */
.fedv-contact-it .fedv-trust h3{
  margin: 0 0 10px;
  font-size: 16px;
}
.fedv-contact-it .fedv-trust ul{
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  line-height: 1.6;
}
.fedv-contact-it .fedv-trust li{
  margin: 6px 0;
}

/* Kontakt Quicklinks */
.fedv-contact-it .fedv-quick{
  display:grid;
  gap: 10px;
  margin-top: 14px;
}
.fedv-contact-it .fedv-quick a{
  display:flex;
  gap:10px;
  align-items:center;
  text-decoration:none;
  color: var(--text);
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 14px;
  padding: 10px 12px;
  transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.fedv-contact-it .fedv-quick a:hover{
  transform: translateY(-1px);
  border-color: rgba(27,71,218,.35);
  box-shadow: 0 12px 28px rgba(15,23,42,.10);
}
.fedv-contact-it .fedv-quick .fedv-dot{
  width:10px;height:10px;border-radius:999px;
  background: var(--brand);
  box-shadow: 0 0 0 4px rgba(27,71,218,.14);
}

/* =========================
   CF7 – Basestyles
========================= */

.fedv-contact-it .wpcf7 form{
  margin:0;
}

/* Labels */
.fedv-contact-it .wpcf7 label{
  display:block;
  font-weight: 650;
  font-size: 14px;
  margin: 0 0 6px;
}

/* Helper paragraphs/Headings inside CF7 */
.fedv-contact-it .wpcf7 p{
  margin: 0 0 12px;
}

/* Inputs */
.fedv-contact-it .wpcf7 input[type="text"],
.fedv-contact-it .wpcf7 input[type="email"],
.fedv-contact-it .wpcf7 input[type="tel"],
.fedv-contact-it .wpcf7 textarea,
.fedv-contact-it .wpcf7 select{
  width: 100%;
  border: 1px solid rgba(15,23,42,.14);
  background: rgba(255,255,255,.92);
  border-radius: 14px;
  padding: 12px 12px;
  font-size: 15px;
  color: var(--text);
  outline: none;
  transition: box-shadow .15s ease, border-color .15s ease, transform .15s ease;
}

.fedv-contact-it .wpcf7 textarea{
  min-height: 140px;
  resize: vertical;
}

.fedv-contact-it .wpcf7 input:focus,
.fedv-contact-it .wpcf7 textarea:focus,
.fedv-contact-it .wpcf7 select:focus{
  border-color: rgba(27,71,218,.45);
  box-shadow: 0 0 0 4px rgba(27,71,218,.18);
}

/* Two-column row for company/name/email/phone */
.fedv-contact-it .fedv-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 680px){
  .fedv-contact-it .fedv-row{
    grid-template-columns: 1fr;
  }
}

/* Checkbox + Radio blocks */
.fedv-contact-it .wpcf7 .wpcf7-checkbox,
.fedv-contact-it .wpcf7 .wpcf7-radio{
  display:grid;
  gap: 8px;
  padding: 10px 10px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.78);
  border-radius: 14px;
}

.fedv-contact-it .wpcf7 .wpcf7-list-item{
  margin:0;
}
.fedv-contact-it .wpcf7 .wpcf7-list-item label{
  font-weight: 600;
  display:flex;
  align-items:flex-start;
  gap: 10px;
  margin: 0;
  cursor:pointer;
  color: var(--text);
}

.fedv-contact-it .wpcf7 input[type="checkbox"],
.fedv-contact-it .wpcf7 input[type="radio"]{
  margin-top: 3px;
  accent-color: var(--brand);
}

/* Acceptance */
.fedv-contact-it .wpcf7 .wpcf7-acceptance{
  display:block;
  padding: 10px 10px;
  border: 1px dashed rgba(27,71,218,.28);
  background: rgba(27,71,218,.06);
  border-radius: 14px;
}

/* Submit button – nutzt dein CTA-System wenn vorhanden, sonst fallback */
.fedv-contact-it .wpcf7 input[type="submit"]{
  width: 100%;
  appearance:none;
  border: 0;
  border-radius: 14px;
  padding: 12px 16px;
  font-weight: 800;
  font-size: 15px;
  cursor:pointer;
  background: var(--brand);
  color: #ffffff;
  box-shadow: 0 18px 38px rgba(27,71,218,.25);
  transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
}
.fedv-contact-it .wpcf7 input[type="submit"]:hover{
  transform: translateY(-1px);
  box-shadow: 0 22px 48px rgba(27,71,218,.28);
  filter: brightness(1.02);
}
.fedv-contact-it .wpcf7 input[type="submit"]:active{
  transform: translateY(0px);
}

/* Validation */
.fedv-contact-it .wpcf7-not-valid-tip{
  font-size: 13px;
  margin-top: 6px;
}
.fedv-contact-it .wpcf7-response-output{
  border-radius: 14px;
  margin: 14px 0 0;
  padding: 12px 12px;
}

/* Reduce layout shifts */
.fedv-contact-it .wpcf7-spinner{
  margin-left: 8px;
}