/* Protection Benefit Partner – Form Styles (Mobile First)
   Hohe Spezifität um Gravity Forms Theme zu überschreiben */

/* ── Base Wrapper ── */
body .gform_wrapper.gravity-theme,
body .gform_wrapper {
  --pb-blue: #2A3287;
  --pb-blue-hover: #3a45a0;
  --pb-blue-05: #F4F5FA;
  --pb-blue-10: #E8E9F5;
  --pb-blue-30: #BFC2E5;
  --pb-green: #1B5E20;
  --pb-green-light: #E8F5E9;
  --pb-radius: 8px;
  --pb-shadow: 0 4px 12px rgba(42,50,135,0.08);
  font-family: 'Open Sans', -apple-system, sans-serif;
  max-width: 800px;
  margin: 0 auto;
  padding: 0 1rem;
}

/* ── Progress Bar ── */
body .gform_wrapper .gf_progressbar_wrapper {
  margin-bottom: 2rem;
}
body .gform_wrapper .gf_progressbar {
  background: var(--pb-blue-10) !important;
  border-radius: 9999px !important;
  height: 8px !important;
  overflow: hidden !important;
  border: none !important;
  box-shadow: none !important;
}
body .gform_wrapper .gf_progressbar_percentage {
  background: var(--pb-blue) !important;
  border-radius: 9999px !important;
  height: 100% !important;
  transition: width 0.4s ease;
  text-indent: -9999px;
}
body .gform_wrapper .gf_progressbar_title {
  font-family: 'Open Sans', sans-serif;
  font-weight: 600;
  font-size: 0.8125rem;
  color: var(--pb-blue);
  margin-bottom: 0.5rem;
}
body .gform_wrapper .gf_page_steps {
  margin-bottom: 1.5rem;
}
body .gform_wrapper .gf_step {
  font-size: 0.75rem;
  font-weight: 600;
  color: #7A7A9A;
}
body .gform_wrapper .gf_step_active {
  color: var(--pb-blue);
}

/* ── Labels ── */
body .gform_wrapper .gfield_label,
body .gform_wrapper.gravity-theme .gfield_label {
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  color: #1A1A2E !important;
  margin-bottom: 6px !important;
  font-family: 'Open Sans', sans-serif !important;
}
body .gform_wrapper .gfield_required {
  color: var(--pb-blue) !important;
}

/* ── Inputs ── */
body .gform_wrapper.gravity-theme input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not([type="button"]):not([type="image"]):not([type="file"]),
body .gform_wrapper.gravity-theme select,
body .gform_wrapper.gravity-theme textarea {
  border: 2px solid var(--pb-blue-30) !important;
  border-radius: var(--pb-radius) !important;
  padding: 0.75rem 1rem !important;
  font-size: 1rem !important;
  font-family: 'Open Sans', sans-serif !important;
  color: #1A1A2E !important;
  background: #fff !important;
  width: 100% !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  min-height: 44px;
}
body .gform_wrapper.gravity-theme input:focus,
body .gform_wrapper.gravity-theme select:focus,
body .gform_wrapper.gravity-theme textarea:focus {
  border-color: var(--pb-blue) !important;
  box-shadow: 0 0 0 3px rgba(42,50,135,0.1) !important;
  outline: none !important;
}
body .gform_wrapper.gravity-theme textarea {
  min-height: 100px;
  resize: vertical;
}
body .gform_wrapper.gravity-theme select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%232A3287' stroke-width='2' fill='none'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 1rem center !important;
  padding-right: 2.5rem !important;
}

/* ── Checkboxes & Radios ── */
body .gform_wrapper.gravity-theme .gchoice {
  margin-bottom: 0.5rem;
  display: flex !important;
  align-items: flex-start !important;
  gap: 0.5rem;
}
body .gform_wrapper.gravity-theme input[type="checkbox"],
body .gform_wrapper.gravity-theme input[type="radio"],
body .gform_wrapper.gravity-theme .gfield-choice-input {
  accent-color: var(--pb-blue) !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  margin-top: 2px !important;
  cursor: pointer !important;
  -webkit-appearance: checkbox !important;
  appearance: checkbox !important;
  opacity: 1 !important;
  position: static !important;
  pointer-events: auto !important;
}
body .gform_wrapper.gravity-theme input[type="radio"] {
  -webkit-appearance: radio !important;
  appearance: radio !important;
}
body .gform_wrapper.gravity-theme .gchoice label,
body .gform_wrapper.gravity-theme .gfield_checkbox label,
body .gform_wrapper.gravity-theme .gfield_radio label {
  font-size: 0.9375rem !important;
  line-height: 1.5 !important;
  color: #1A1A2E !important;
  cursor: pointer !important;
  pointer-events: auto !important;
}
body .gform_wrapper.gravity-theme .gchoice label a {
  color: var(--pb-blue);
  text-decoration: underline;
}
/* Gravity Forms Theme überschreibt Checkboxen oft mit custom styling - zurücksetzen */
body .gform_wrapper.gravity-theme .gfield--type-checkbox .gchoice,
body .gform_wrapper.gravity-theme .gfield--type-radio .gchoice {
  position: relative !important;
  overflow: visible !important;
}

/* ── Section Titles ── */
body .gform_wrapper.gravity-theme .gsection {
  border-bottom: 2px solid var(--pb-blue) !important;
  padding-bottom: 0.75rem !important;
  margin-top: 0.5rem !important;
  margin-bottom: 1.5rem !important;
}
body .gform_wrapper.gravity-theme .gsection_title {
  font-size: 1.375rem !important;
  font-weight: 700 !important;
  color: var(--pb-blue) !important;
  font-family: 'Open Sans', sans-serif !important;
}
body .gform_wrapper.gravity-theme .gsection_description {
  font-size: 0.875rem;
  color: #4A4A6A;
  margin-top: 6px;
  line-height: 1.5;
}

/* ── BUTTONS (maximale Spezifität) ── */
body .gform_wrapper.gravity-theme .gform_footer input[type="submit"],
body .gform_wrapper.gravity-theme .gform_page_footer input[type="submit"],
body .gform_wrapper.gravity-theme .gform_footer .gform_button,
body .gform_wrapper.gravity-theme .gform_page_footer .gform_button,
body .gform_wrapper.gravity-theme .gform_page_footer .gform_next_button,
body .gform_wrapper .gform_button,
body .gform_wrapper .gform_next_button,
body .gform_wrapper input[type="submit"].gform_button,
body .gform_wrapper input.gform_next_button {
  font-family: 'Open Sans', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  padding: 0.875rem 2rem !important;
  border-radius: var(--pb-radius) !important;
  border: 2px solid var(--pb-blue) !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  min-height: 48px !important;
  min-width: 140px !important;
  background-color: var(--pb-blue) !important;
  color: #FFFFFF !important;
  text-decoration: none !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
body .gform_wrapper.gravity-theme .gform_footer input[type="submit"]:hover,
body .gform_wrapper.gravity-theme .gform_page_footer .gform_next_button:hover,
body .gform_wrapper .gform_button:hover,
body .gform_wrapper .gform_next_button:hover,
body .gform_wrapper input[type="submit"].gform_button:hover {
  background-color: var(--pb-blue-hover) !important;
  color: #FFFFFF !important;
  transform: translateY(-1px) !important;
  box-shadow: var(--pb-shadow) !important;
}

/* Previous Button (Outline) */
body .gform_wrapper.gravity-theme .gform_page_footer .gform_previous_button,
body .gform_wrapper .gform_previous_button,
body .gform_wrapper input.gform_previous_button {
  font-family: 'Open Sans', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  padding: 0.875rem 2rem !important;
  border-radius: var(--pb-radius) !important;
  border: 2px solid var(--pb-blue) !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  min-height: 48px !important;
  min-width: 120px !important;
  background-color: transparent !important;
  color: var(--pb-blue) !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
body .gform_wrapper.gravity-theme .gform_page_footer .gform_previous_button:hover,
body .gform_wrapper .gform_previous_button:hover {
  background-color: var(--pb-blue) !important;
  color: #FFFFFF !important;
}

/* ── Button Footer Layout ── */
body .gform_wrapper .gform_page_footer,
body .gform_wrapper.gravity-theme .gform_page_footer {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 1rem !important;
  margin-top: 2rem !important;
  padding-top: 1.5rem !important;
  border-top: 1px solid var(--pb-blue-10) !important;
}
body .gform_wrapper .gform_footer,
body .gform_wrapper.gravity-theme .gform_footer {
  margin-top: 2rem !important;
  padding-top: 1.5rem !important;
  border-top: 1px solid var(--pb-blue-10) !important;
}

/* ── Validation ── */
body .gform_wrapper.gravity-theme .gfield_error input,
body .gform_wrapper.gravity-theme .gfield_error select,
body .gform_wrapper.gravity-theme .gfield_error textarea {
  border-color: #f44336 !important;
}
body .gform_wrapper.gravity-theme .gfield_error .gfield_label {
  color: #f44336 !important;
}
body .gform_wrapper .validation_message,
body .gform_wrapper.gravity-theme .validation_message {
  color: #f44336 !important;
  font-size: 0.8125rem !important;
  margin-top: 4px !important;
  font-weight: 600;
}
body .gform_wrapper .gform_validation_errors,
body .gform_wrapper.gravity-theme .gform_validation_errors {
  background: #FFF3F3 !important;
  border: 1px solid #f44336 !important;
  border-radius: var(--pb-radius) !important;
  padding: 1rem !important;
  margin-bottom: 1.5rem !important;
}
body .gform_wrapper .gform_validation_errors h2 {
  color: #f44336 !important;
  font-size: 1rem !important;
}

/* ── Confirmation ── */
body .gform_confirmation_message {
  text-align: center;
  padding: 3rem 1.5rem;
}

/* ── Honeypot ── */
.gf_hidden,
body .gform_wrapper .gf_hidden {
  display: none !important;
  visibility: hidden !important;
  position: absolute !important;
  left: -9999px !important;
}

/* ── Description / Counter ── */
body .gform_wrapper .ginput_counter {
  font-size: 0.75rem;
  color: #7A7A9A;
  margin-top: 4px;
}
body .gform_wrapper .gfield_description {
  font-size: 0.8125rem;
  color: #4A4A6A;
  line-height: 1.5;
}

/* ── Placeholder ── */
body .gform_wrapper.gravity-theme input::placeholder,
body .gform_wrapper.gravity-theme textarea::placeholder {
  color: #BFC2E5 !important;
  font-weight: 400;
}

/* ══════════════════════════════════════
   MOBILE FIRST (Base: < 768px)
   ══════════════════════════════════════ */

body .gform_wrapper .gform_fields,
body .gform_wrapper.gravity-theme .gform_fields {
  grid-template-columns: 1fr !important;
  gap: 0.75rem !important;
}

body .gform_wrapper.gravity-theme .gform_page_footer {
  flex-direction: column-reverse !important;
  gap: 0.75rem !important;
}
body .gform_wrapper.gravity-theme .gform_page_footer input[type="button"],
body .gform_wrapper.gravity-theme .gform_page_footer input[type="submit"] {
  width: 100% !important;
}

body .gform_wrapper.gravity-theme .gsection_title {
  font-size: 1.125rem !important;
}

/* ══════════════════════════════════════
   TABLET+ (≥ 768px)
   ══════════════════════════════════════ */
@media (min-width: 768px) {
  body .gform_wrapper .gform_fields,
  body .gform_wrapper.gravity-theme .gform_fields {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 1rem !important;
  }
  body .gform_wrapper .gfield--width-full,
  body .gform_wrapper.gravity-theme .gsection,
  body .gform_wrapper.gravity-theme .gfield_html,
  body .gform_wrapper.gravity-theme .gfield_checkbox,
  body .gform_wrapper.gravity-theme .gfield_textarea {
    grid-column: 1 / -1 !important;
  }

  body .gform_wrapper.gravity-theme .gform_page_footer {
    flex-direction: row !important;
  }
  body .gform_wrapper.gravity-theme .gform_page_footer input[type="button"],
  body .gform_wrapper.gravity-theme .gform_page_footer input[type="submit"] {
    width: auto !important;
  }
}
