/* ============================================================
   LBWO — Forms CSS
   ============================================================ */

/* ── Form layout ── */
.lbwo-form { max-width: 680px; }
.lbwo-form__section { margin-bottom: 28px; }
.lbwo-form__section h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--lbwo-text);
  border-bottom: 2px solid var(--lbwo-green);
  padding-bottom: 6px;
  margin-bottom: 16px;
}
.lbwo-form__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.lbwo-form__group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.lbwo-form__group--2 { grid-column: span 2; }

/* ── Labels ── */
.lbwo-form__label { font-weight: 600; font-size: .9rem; color: var(--lbwo-text); }

/* ── Inputs ── */
.lbwo-form__input,
.lbwo-form__select,
.lbwo-form__textarea {
  width: 100%;
  padding: 10px 14px;
  border: 2px solid var(--lbwo-border);
  border-radius: var(--lbwo-radius-sm);
  font-size: .9rem;
  font-family: var(--lbwo-font);
  color: var(--lbwo-text);
  background: var(--lbwo-white);
  transition: border-color var(--lbwo-transition), box-shadow var(--lbwo-transition);
  outline: none;
}
.lbwo-form__input:focus,
.lbwo-form__select:focus,
.lbwo-form__textarea:focus {
  border-color: var(--lbwo-green);
  box-shadow: 0 0 0 3px rgba(37,211,102,.15);
}
.lbwo-form__input:invalid:not(:placeholder-shown),
.lbwo-form__select:invalid:not(:placeholder-shown) {
  border-color: var(--lbwo-danger);
}
.lbwo-form__textarea { resize: vertical; min-height: 80px; }
.lbwo-form__select { appearance: none; 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='%236b7280' stroke-width='2' fill='none'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }

/* ── Radio group ── */
.lbwo-radio-group { display: flex; gap: 12px; flex-wrap: wrap; }
.lbwo-radio-option {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  border: 2px solid var(--lbwo-border);
  border-radius: var(--lbwo-radius-sm);
  cursor: pointer;
  font-weight: 500;
  transition: border-color var(--lbwo-transition), background var(--lbwo-transition);
  flex: 1;
  min-width: 140px;
}
.lbwo-radio-option input[type="radio"] { display: none; }
.lbwo-radio-option--selected,
.lbwo-radio-option:has(input:checked) {
  border-color: var(--lbwo-green);
  background: var(--lbwo-green-light);
}
.lbwo-radio-option__icon { font-size: 1.2rem; }

/* ── Checkbox ── */
.lbwo-checkbox-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-weight: 500;
  margin-bottom: 8px;
}
.lbwo-checkbox-label input[type="checkbox"] { accent-color: var(--lbwo-green); width: 16px; height: 16px; }

/* ── Image upload ── */
.lbwo-image-upload { position: relative; }
.lbwo-image-upload__input {
  display: block;
  width: 100%;
  padding: 8px;
  border: 2px dashed var(--lbwo-border);
  border-radius: var(--lbwo-radius-sm);
  cursor: pointer;
  background: var(--lbwo-bg);
}
.lbwo-image-upload__preview {
  max-width: 120px;
  max-height: 120px;
  border-radius: var(--lbwo-radius-sm);
  object-fit: cover;
  margin-top: 8px;
  display: block;
}
.lbwo-image-upload__preview--cover { max-width: 100%; max-height: 160px; }
.lbwo-image-upload__placeholder {
  width: 80px; height: 80px;
  border-radius: var(--lbwo-radius-sm);
  background: var(--lbwo-bg);
  border: 2px dashed var(--lbwo-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8rem;
  margin-top: 8px;
}

/* ── Form footer ── */
.lbwo-form__actions { display: flex; gap: 12px; margin-top: 20px; flex-wrap: wrap; }
.lbwo-form__submit  { margin-top: 24px; }
.lbwo-form__hint    { font-size: .8rem; color: var(--lbwo-muted); margin-top: 8px; text-align: center; }

/* ── Search bar ── */
.lbwo-search-bar { background: var(--lbwo-white); border: 1px solid var(--lbwo-border); border-radius: var(--lbwo-radius); padding: 16px; margin-bottom: 28px; box-shadow: var(--lbwo-shadow); }
.lbwo-search-bar__inner { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.lbwo-search-bar__field { position: relative; flex: 1; min-width: 200px; }
.lbwo-search-bar__icon { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--lbwo-muted); width: 16px; height: 16px; }
.lbwo-search-bar__input { width: 100%; padding: 10px 14px 10px 38px; border: 2px solid var(--lbwo-border); border-radius: var(--lbwo-radius-sm); font-size: .9rem; outline: none; }
.lbwo-search-bar__input:focus { border-color: var(--lbwo-green); }
.lbwo-search-bar__select { padding: 10px 36px 10px 14px; border: 2px solid var(--lbwo-border); border-radius: var(--lbwo-radius-sm); font-size: .9rem; outline: none; background: #fff; appearance: none; cursor: pointer; }

/* ── Order wrap ── */
.lbwo-order-wrap { max-width: 600px; margin: 0 auto; padding: 0 16px; }
.lbwo-order-vendor-header { display: flex; align-items: center; gap: 16px; background: var(--lbwo-white); border: 1px solid var(--lbwo-border); border-radius: var(--lbwo-radius); padding: 16px; margin-bottom: 24px; }
.lbwo-order-vendor-header__logo { width: 60px; height: 60px; border-radius: 50%; object-fit: cover; }
.lbwo-order-vendor-header__name { margin: 0 0 4px; font-size: 1.2rem; }
.lbwo-order-vendor-header__sub  { margin: 0; color: var(--lbwo-muted); font-size: .85rem; }
.lbwo-status-select { padding: 4px 8px; border: 1px solid var(--lbwo-border); border-radius: var(--lbwo-radius-sm); font-size: .82rem; cursor: pointer; }
