/* ===================================================================
   File: forms.css
   Description: Layout, structure, and spacing for Local Leader forms.
   =================================================================== */

/* -------------------------
   Form container
   ------------------------- */
.ll-form,
#ll-business-form {
  display: block;
  width: 100%;
}

.ll-form-row {
  margin-bottom: 16px;
}

.ll-form-label {
  display: block;
  margin-bottom: 6px;
  font-weight: 600;
}

.ll-form-input,
.ll-form-textarea,
.ll-form-select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 14px;
  box-sizing: border-box;
}

.ll-form-textarea {
  min-height: 100px;
  resize: vertical;
}

/* -------------------------
   Generic field wrappers
   ------------------------- */
.ll-field,
.ll-field-control,
.ll-form-field {
  min-width: 0;
}

.ll-field label,
.ll-field-control label,
.ll-form-field label {
  display: block;
  margin-bottom: 6px;
  font-weight: 600;
}

/* Make common controls fill their grid cell */
.ll-field input[type="text"],
.ll-field input[type="email"],
.ll-field input[type="tel"],
.ll-field input[type="url"],
.ll-field input[type="number"],
.ll-field input[type="password"],
.ll-field select,
.ll-field textarea,
.ll-field-control input[type="text"],
.ll-field-control input[type="email"],
.ll-field-control input[type="tel"],
.ll-field-control input[type="url"],
.ll-field-control input[type="number"],
.ll-field-control input[type="password"],
.ll-field-control select,
.ll-field-control textarea {
  width: 100%;
  box-sizing: border-box;
}

/* -------------------------
   Field groups
   ------------------------- */
.ll-field-group {
  margin-bottom: 20px;
}

.ll-field-inline {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.ll-field-inline > * {
  flex: 1;
  min-width: 0;
}

/* -------------------------
   Two-column step layout
   ------------------------- */
#ll-business-form .ll-step-fields,
#ll-business-form .ll-edit-step-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 20px;
  align-items: start;
}

/* Default: every field uses one grid column */
#ll-business-form .ll-step-fields > .ll-field,
#ll-business-form .ll-edit-step-fields > .ll-field {
  grid-column: span 1;
  min-width: 0;
}

/* Explicit half-width utility */
#ll-business-form .ll-step-fields > .ll-col-6,
#ll-business-form .ll-edit-step-fields > .ll-col-6 {
  grid-column: span 1;
}

/* Explicit full-width utility */
#ll-business-form .ll-step-fields > .ll-span-2,
#ll-business-form .ll-edit-step-fields > .ll-span-2 {
  grid-column: 1 / -1;
}

/* Media fields sit cleanly in their own grid cells */
#ll-business-form .ll-media-field {
  align-self: start;
}

#ll-business-form .ll-media-field .ll-field-control,
#ll-business-form .ll-media-field.ll-field {
  min-width: 0;
}

/* -------------------------
   Locked fields
   ------------------------- */
.ll-field-lock-note {
  margin-top: 6px;
  font-size: 13px;
  color: #666;
}

.ll-form-section-heading.ll-section-locked {
  margin-bottom: 10px;
}

/* -------------------------
   Logo / Image fields
   ------------------------- */
.ll-field-control.ll-field-logo,
.ll-field-control.ll-field-images {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ll-logo-preview,
.ll-image-preview {
  max-width: 120px;
  border-radius: 6px;
  overflow: hidden;
}

.ll-logo-preview img,
.ll-image-preview img {
  width: 100%;
  height: auto;
  display: block;
}

/* -------------------------
   Step shells
   ------------------------- */
#ll-business-form .ll-step {
  display: none;
}

#ll-business-form .ll-step.ll-step-active {
  display: block;
}

/* -------------------------
   Progress labels / step heading
   ------------------------- */
#ll-business-form .ll-step-labels {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  list-style: none;
  padding: 0;
  margin: 0 0 14px;
}

#ll-business-form .ll-step-labels li {
  flex: 1 1 0;
  text-align: center;
  font-weight: 600;
  color: #666;
}

#ll-business-form .ll-step-labels li.active {
  color: #111;
}

#ll-business-form .ll-progress-bar {
  width: 100%;
  height: 8px;
  background: #e5e7eb;
  border-radius: 999px;
  overflow: hidden;
  margin: 0 0 22px;
}

#ll-business-form .ll-progress-indicator {
  height: 100%;
  background: #0073aa;
  border-radius: 999px;
  transition: width 0.2s ease;
}

#ll-business-form .ll-form-section-heading {
  margin: 0 0 18px;
  width: 100%;
}

#ll-business-form .ll-form-section-heading h3 {
  margin: 0 0 6px;
  font-size: 28px;
  line-height: 1.2;
  font-weight: 700;
}

#ll-business-form .ll-form-section-heading p {
  margin: 0;
  color: #666;
}

/* Optional subtitle if used elsewhere */
#ll-business-form .ll-step-subtitle {
  margin: 0 0 18px;
  font-size: 28px;
  line-height: 1.2;
  font-weight: 700;
  color: #111;
}

/* -------------------------
   Step navigation (multi-step forms)
   ------------------------- */
#ll-business-form .ll-step-buttons {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: 16px;
  margin-top: 28px;
  width: 100%;
}

#ll-business-form .ll-step-buttons .ll-btn,
#ll-business-form .ll-step-buttons button {
  width: 50%;
  max-width: 50%;
  flex: 0 0 50%;
}

#ll-business-form .ll-step-buttons:has(.prev-step) .ll-btn,
#ll-business-form .ll-step-buttons:has(.prev-step) button {
  width: calc(50% - 8px);
  max-width: calc(50% - 8px);
  flex: 0 0 calc(50% - 8px);
}

/* Fallback for browsers that do not support :has() */
#ll-business-form .ll-step-buttons .prev-step,
#ll-business-form .ll-step-buttons .next-step,
#ll-business-form .ll-step-buttons .final-step,
#ll-business-form .ll-step-buttons #ll-save-post-button {
  width: calc(50% - 8px);
  max-width: calc(50% - 8px);
  flex: 0 0 calc(50% - 8px);
}

/* -------------------------
   Flat submit row (non-step forms)
   ------------------------- */
.ll-flat-submit-row {
  display: flex;
  justify-content: flex-end;
  margin-top: 20px;
}

/* -------------------------
   Section headings / intro
   ------------------------- */
.ll-business-intro {
  margin-bottom: 18px;
}

/* -------------------------
   Validation / messages
   ------------------------- */
.ll-form-error {
  color: #d90000;
  font-size: 13px;
  margin-top: 4px;
}

.ll-form-success {
  color: #2e7d32;
  font-size: 14px;
  margin-top: 10px;
}

/* -------------------------
   Address label + inline checkbox
   ------------------------- */
.ll-address-label-row,
.ll-inline-checkbox-row {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  flex-wrap: nowrap;
  margin-bottom: 6px;
}

.ll-address-label-row label,
.ll-inline-checkbox-row label {
  margin-bottom: 0;
}

.ll-address-inline-toggle,
.ll-inline-checkbox-wrap {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 500;
  white-space: nowrap;
}

.ll-address-inline-toggle input[type="checkbox"],
.ll-inline-checkbox-wrap input[type="checkbox"] {
  margin: 0;
  width: auto;
  flex: 0 0 auto;
}

/* -------------------------
   Premium locked intro
   ------------------------- */
.ll-premium-step-intro {
  grid-column: 1 / -1;
  margin: 0 0 4px;
  padding: 0;
}

.ll-premium-step-intro p {
  margin: 0;
  color: #666;
}

/* -------------------------
   Utility spacing
   ------------------------- */
.ll-mt-sm { margin-top: 8px; }
.ll-mt-md { margin-top: 16px; }
.ll-mt-lg { margin-top: 24px; }

.ll-mb-sm { margin-bottom: 8px; }
.ll-mb-md { margin-bottom: 16px; }
.ll-mb-lg { margin-bottom: 24px; }

/* -------------------------
   Responsive
   ------------------------- */
@media (max-width: 767px) {
  #ll-business-form .ll-step-fields,
  #ll-business-form .ll-edit-step-fields {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  #ll-business-form .ll-span-2 {
    grid-column: auto;
  }

  #ll-business-form .ll-step-buttons {
    flex-direction: column;
    align-items: stretch;
  }

  #ll-business-form .ll-step-buttons .ll-btn,
  #ll-business-form .ll-step-buttons button,
  #ll-business-form .ll-step-buttons .prev-step,
  #ll-business-form .ll-step-buttons .next-step,
  #ll-business-form .ll-step-buttons .final-step,
  #ll-business-form .ll-step-buttons #ll-save-post-button {
    width: 100%;
    max-width: 100%;
    flex: 1 1 auto;
  }

  #ll-business-form .ll-form-section-heading h3,
  #ll-business-form .ll-step-subtitle {
    font-size: 24px;
  }
}




/* -------------------------
   Business form: logo + images side by side (ALL steps)
   ------------------------- */

#ll-business-form .ll-field-key-ll_logo,
#ll-business-form .ll-field-key-ll_images {
  grid-column: span 1 !important;
  align-self: start;
}

/* Ensure media fields fill their cell */
#ll-business-form .ll-field-key-ll_logo .ll-field-control,
#ll-business-form .ll-field-key-ll_images .ll-field-control {
  width: 100%;
  max-width: 100%;
}

/* Make previews responsive */
#ll-business-form .ll-field-key-ll_logo .ll-logo-preview,
#ll-business-form .ll-field-key-ll_images .ll-image-preview {
  max-width: 100%;
}

/* Mobile: stack */
@media (max-width: 767px) {
  #ll-business-form .ll-field-key-ll_logo,
  #ll-business-form .ll-field-key-ll_images {
    grid-column: 1 / -1 !important;
  }
}