/*
 Theme Name:   SOS Instal
 Theme URI:    https://generatepress.com
 Description:  Default GeneratePress child theme
 Author:       B&J
 Author URI:   https://okibobo.cz
 Template:     generatepress
 Version:      1.0.0
*/


/* ── Konfigurátor — Forminator Form #208 ──────────────── */

/* Farby (navy = #103966, border = #d8dfe8, surface = #f7f9fc) */

#forminator-module-208 {
  max-width: 80rem;
  margin-inline: auto;
  counter-reset: konfig-step;
  padding: 0 !important; /* 40px — rovnaké ako kontajner */
}

#forminator-module-208 .forminator-row {
  margin-bottom: 2.5rem;
}

/* Step labels s číslicami — span celý riadok gridu */
#forminator-module-208 .forminator-field-radio .forminator-label,
#forminator-module-208 .forminator-field-checkbox .forminator-label {
  grid-column: 1 / -1 !important;
  counter-increment: konfig-step;
  display: flex !important;
  align-items: center;
  gap: 0.625rem;
  font-size: 1.0625rem !important;
  font-weight: 600 !important;
  color: #1d2530;
  margin-bottom: 1rem;
}

#forminator-module-208 .forminator-field-radio .forminator-label::before,
#forminator-module-208 .forminator-field-checkbox .forminator-label::before {
  content: counter(konfig-step);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.75rem;
  width: 1.75rem;
  height: 1.75rem;
  background: #103966;
  color: #fff;
  border-radius: 50%;
  font-size: 0.875rem !important;
  font-weight: 700 !important;
  flex-shrink: 0;
  line-height: 1;
}

/* ── Step 1: Kategória — Radio karty ──────────────────── */

/* Kontajner radio skupiny → grid */
#forminator-module-208 .forminator-field-radio .forminator-field {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem; /* ~20px */
}

@media (min-width: 768px) {
  #forminator-module-208 .forminator-field-radio .forminator-field {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Každý radio label = karta */
.forminator-ui#forminator-module-208 .forminator-radio.forminator-radio-inline,
.forminator-ui#forminator-module-208.forminator-design--flat .forminator-radio.forminator-radio-inline {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.625rem;
  padding: 1.25rem 0.75rem;
  border-radius: 0.75rem;
  border: 2px solid #d8dfe8 !important;
  background: #fff !important;
  cursor: pointer;
  transition: all 0.3s ease;
  text-align: center;
  margin: 0;
  box-sizing: border-box;
  min-height: unset;
  width: 100%;
  padding-top: 1.25rem !important;
  position: relative;
}

/* Skrytý input pokrýva celú kartu → klik kdekoľvek funguje */
.forminator-ui#forminator-module-208 .forminator-radio.forminator-radio-inline input[type="radio"],
#forminator-module-208 .forminator-radio.forminator-radio-inline input[type="radio"] {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  opacity: 0 !important;
  cursor: pointer !important;
  margin: 0 !important;
  z-index: 1;
  pointer-events: auto !important;
}

/* Schovaj radio bullet */
#forminator-module-208 .forminator-radio .forminator-radio-bullet,
.forminator-ui#forminator-module-208 .forminator-radio .forminator-radio-bullet,
.forminator-ui#forminator-module-208.forminator-design--flat .forminator-radio .forminator-radio-bullet {
  display: none !important;
  visibility: hidden !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Ikona — background-image span */
#forminator-module-208 .forminator-radio .forminator-radio-image,
.forminator-ui#forminator-module-208 .forminator-radio.forminator-has_image.forminator-has_bullet .forminator-radio-image,
.forminator-ui#forminator-module-208.forminator-design--flat .forminator-radio.forminator-has_image.forminator-has_bullet .forminator-radio-image {
  display: block !important;
  position: static !important;
  width: 2rem !important;
  height: 2rem !important;
  background: transparent !important;
  order: -1;
}

#forminator-module-208 .forminator-radio .forminator-radio-image > span {
  display: block;
  width: 2rem;
  height: 2rem;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  filter: invert(14%) sepia(60%) saturate(1200%) hue-rotate(198deg) brightness(85%);
}

/* Text */
#forminator-module-208 .forminator-radio .forminator-radio-label {
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  color: #1d2530 !important;
  line-height: 1.3;
}

/* Hover */
.forminator-ui#forminator-module-208.forminator-design--flat .forminator-radio.forminator-radio-inline:hover,
#forminator-module-208 .forminator-radio.forminator-radio-inline:hover {
  background: #f7f9fc !important;
  border-color: rgba(16, 57, 102, 0.4) !important;
}

/* Označená karta */
.forminator-ui#forminator-module-208.forminator-design--flat .forminator-radio.forminator-radio-inline:has(input:checked),
#forminator-module-208 .forminator-radio.forminator-radio-inline:has(input:checked) {
  background: #103966 !important;
  border-color: #103966 !important;
}

#forminator-module-208 .forminator-radio:has(input:checked) .forminator-radio-label {
  color: #fff !important;
}

#forminator-module-208 .forminator-radio:has(input:checked) .forminator-radio-image > span {
  filter: brightness(0) invert(1);
}

/* ── Step 2+: Služby — Checkbox zoznam ───────────────── */

/* Kontajner checkbox skupiny → grid */
#forminator-module-208 .forminator-field-checkbox .forminator-field {
  display: grid !important;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 640px) {
  #forminator-module-208 .forminator-field-checkbox .forminator-field {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Každý checkbox label = riadok */
#forminator-module-208 .forminator-checkbox {
  display: flex !important;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem;
  border-radius: 0.5rem;
  border: 2px solid #d8dfe8 !important;
  background: #fff !important;
  cursor: pointer;
  transition: all 0.3s ease;
  text-align: left;
  margin: 0;
  box-sizing: border-box;
  min-height: unset;
  width: 100%;
}

/* Kruhový indikátor */
#forminator-module-208 .forminator-checkbox .forminator-checkbox-box {
  min-width: 1.25rem !important;
  width: 1.25rem !important;
  height: 1.25rem !important;
  border-radius: 50% !important;
  border: 2px solid #627084 !important;
  background: transparent !important;
  flex-shrink: 0;
  display: flex !important;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  box-shadow: none !important;
}

/* Schovaj default checkmark ikonu */
#forminator-module-208 .forminator-checkbox .forminator-checkbox-box .forminator-icon {
  display: none !important;
}

/* Text */
#forminator-module-208 .forminator-checkbox .forminator-checkbox-label {
  font-size: 0.9375rem !important;
  font-weight: 500 !important;
  color: #1d2530;
}

/* Hover */
#forminator-module-208 .forminator-checkbox:hover {
  border-color: rgba(16, 57, 102, 0.5) !important;
}

/* Označený */
#forminator-module-208 .forminator-checkbox:has(input:checked) {
  background: rgba(16, 57, 102, 0.08) !important;
  border-color: #103966 !important;
}

#forminator-module-208 .forminator-checkbox:has(input:checked) .forminator-checkbox-label {
  color: #103966;
  font-weight: 600 !important;
}

#forminator-module-208 .forminator-checkbox:has(input:checked) .forminator-checkbox-box {
  background: #103966 !important;
  border-color: #103966 !important;
}

/* Fajka */
#forminator-module-208 .forminator-checkbox:has(input:checked) .forminator-checkbox-box::after {
  content: '';
  display: block;
  width: 5px;
  height: 8px;
  border: 2px solid #fff;
  border-top: none;
  border-left: none;
  transform: rotate(45deg) translateY(-1px);
}

/* ── Textové inputy a textarea ─────────────────────────── */

#forminator-module-208 .forminator-input,
#forminator-module-208 .forminator-textarea,
.forminator-ui#forminator-module-208 .forminator-input,
.forminator-ui#forminator-module-208 .forminator-textarea {
  background-color: #fff !important;
  border: 2px solid #d8dfe8 !important;
  border-radius: 0.5rem !important;
}

/* ── Submit button ──────────────────────────────────────── */

#forminator-module-208 .forminator-button-submit {
  background: #103966 !important;
  color: #fff !important;
  border-radius: 0.75rem !important;
  padding: 1rem 2rem !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  width: 100%;
  transition: background 0.3s ease, transform 0.2s ease !important;
  border: none !important;
  min-height: 3.5rem;
  letter-spacing: 0.025em;
}

#forminator-module-208 .forminator-button-submit:hover {
  background: #174a7c !important;
  transform: translateY(-1px);
}

