/* Start custom CSS for html, class: .elementor-element-722ae5b *//* =========================================================
   HOME-BUTLER.CH – Kontakt (Formular) – gekapselt
   ========================================================= */

.hb-kontakt .wrap{
  max-width:1100px;
  margin:0 auto;
  padding:0 18px;
}

.hb-kontakt .page{
  padding:22px 0;
}

.hb-kontakt .section-head{
  margin:8px 0 18px;
}

.hb-kontakt .section-title{
  display:flex;
  align-items:center;
  gap:10px;
}

.hb-kontakt .section-title .icon{
  font-size:22px;
}

.hb-kontakt .card{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  box-shadow:0 10px 25px rgba(0,0,0,.08);
}

.hb-kontakt .pad{
  padding:22px;
}

.hb-kontakt .smallp{
  margin:0 0 14px;
  opacity:.85;
  line-height:1.6;
}

/* Formular Layout */
.hb-kontakt .form-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:14px;
}

@media (max-width:900px){
  .hb-kontakt .form-grid{
    grid-template-columns:1fr;
  }
}

/* Felder */
.hb-kontakt .field{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.hb-kontakt .field.full{
  grid-column:1 / -1;
}

.hb-kontakt label{
  font-weight:700;
  font-size:14px;
}

.hb-kontakt .input,
.hb-kontakt select,
.hb-kontakt textarea{
  width:100%;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  font-size:16px;
  outline:none;
}

.hb-kontakt textarea{
  min-height:120px;
  resize:vertical;
}

.hb-kontakt .input:focus,
.hb-kontakt select:focus,
.hb-kontakt textarea:focus{
  border-color:rgba(0,0,0,.35);
  box-shadow:0 0 0 4px rgba(0,0,0,.06);
}

/* Hinweise / Errors */
.hb-kontakt .hint{
  font-size:13px;
  opacity:.8;
  line-height:1.4;
}

.hb-kontakt .error{
  display:none;
  margin-top:6px;
  font-size:13px;
  color:#b91c1c;
  font-weight:700;
}

/* Checklist */
.hb-kontakt .checklist{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:10px;
}

@media (max-width:600px){
  .hb-kontakt .checklist{
    grid-template-columns:1fr;
  }
}

.hb-kontakt .check{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border:1px solid rgba(0,0,0,.10);
  border-radius:12px;
  background:#fafafa;
}

.hb-kontakt .check input{
  width:18px;
  height:18px;
}

/* Buttons */
.hb-kontakt .form-actions{
  margin-top:16px;
}

.hb-kontakt .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 18px;
  border-radius:12px;
  text-decoration:none;
  font-weight:800;
  border:1px solid rgba(0,0,0,.12);
  background:#e5e7eb;
  color:#111;
  cursor:pointer;
}

.hb-kontakt .btn:hover{
  opacity:.92;
}

.hb-kontakt .btn-primary{
  background:#000;
  color:#fff;
  border-color:#000;
}

/* optional: karten-breite auf kontakt */
.hb-kontakt .form-card{
  max-width:900px;
  margin:0 auto;
}/* End custom CSS */