/* KARETA.KZ r295 — forms / inputs normalization
   Contract: all inputs, selects, textareas, search fields and form groups follow UI_STANDARD_KARETA.md.
   This layer is visual only; it does not change submit/search/API logic. */

:root{
  --form-control-h: var(--ui-input-h, 44px);
  --form-control-radius: var(--ui-radius-field, 10px);
  --form-control-pad-x: var(--space-3, 12px);
  --form-control-gap: var(--space-2, 8px);
  --form-label-size: 13px;
  --form-help-size: 12px;
  --form-border: var(--ui-border, rgba(15,23,42,.12));
  --form-border-focus: color-mix(in srgb, var(--accent, #f97316) 54%, var(--form-border));
  --form-ring: 0 0 0 3px color-mix(in srgb, var(--accent, #f97316) 16%, transparent);
}

/* Base form control contract. */
.ui-input,
.ui-select,
.ui-textarea,
input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="file"]),
select,
textarea,
.bform-input,
.bform-select,
.bform-textarea,
.pf-input,
.pf-search-input,
.parts-search-input,
.mo-search-input,
.admin-search,
.chat-input,
.msng-textarea,
.owiz-input,
.k-select,
.k-textarea,
.nac-textarea,
.order-status-sel,
.news-compose-field input,
.news-compose-field select,
.news-compose-field textarea{
  box-sizing: border-box !important;
  width: auto;
  max-width: 100%;
  min-width: 0;
  min-height: var(--form-control-h) !important;
  border-radius: var(--form-control-radius) !important;
  border: 1px solid var(--form-border) !important;
  background: var(--ui-surface, var(--surface, #fff)) !important;
  color: var(--text, var(--text1, #111827)) !important;
  font: inherit;
  font-size: max(16px, var(--ui-text-md, 15px));
  line-height: 1.35;
  padding: 0 var(--form-control-pad-x);
  outline: none;
  box-shadow: none;
  -webkit-tap-highlight-color: transparent;
  transition: border-color .16s ease, box-shadow .16s ease, background-color .16s ease;
}

textarea,
.ui-textarea,
.bform-textarea,
.pf-input:is(textarea),
.msng-textarea,
.owiz-input:is(textarea),
.k-textarea,
.nac-textarea,
.news-compose-field textarea{
  min-height: 88px !important;
  padding-top: var(--space-3, 12px);
  padding-bottom: var(--space-3, 12px);
  resize: vertical;
  overflow: auto;
}

select,
.ui-select,
.bform-select,
.k-select,
.order-status-sel{
  cursor: pointer;
  padding-right: 36px;
}

input::placeholder,
textarea::placeholder,
.ui-input::placeholder,
.ui-textarea::placeholder,
.bform-input::placeholder,
.bform-textarea::placeholder,
.pf-search-input::placeholder,
.parts-search-input::placeholder,
.mo-search-input::placeholder,
.admin-search::placeholder,
.chat-input::placeholder,
.msng-textarea::placeholder{
  color: var(--text3, #94a3b8) !important;
  opacity: 1;
}

input:focus,
select:focus,
textarea:focus,
.ui-input:focus,
.ui-select:focus,
.ui-textarea:focus,
.bform-input:focus,
.bform-select:focus,
.bform-textarea:focus,
.pf-input:focus,
.pf-search-input:focus,
.parts-search-input:focus,
.mo-search-input:focus,
.admin-search:focus,
.chat-input:focus,
.msng-textarea:focus,
.owiz-input:focus,
.k-select:focus,
.k-textarea:focus,
.nac-textarea:focus{
  border-color: var(--form-border-focus) !important;
  box-shadow: var(--form-ring) !important;
}

input[disabled],
select[disabled],
textarea[disabled],
.ui-input.is-disabled,
.ui-select.is-disabled,
.ui-textarea.is-disabled{
  opacity: .58;
  cursor: not-allowed;
  background: var(--ui-surface-2, #f6f8fb) !important;
}

/* File inputs are controls, but should not be forced into text-field geometry. */
input[type="file"]{
  max-width: 100%;
  color: var(--text2, #475569);
  font: inherit;
  font-size: 14px;
}

input[type="checkbox"],
input[type="radio"]{
  accent-color: var(--accent, var(--orange, #f97316));
}

/* Form grouping contract. */
.ui-field,
.form-field,
.bform-group,
.owiz-field,
.news-compose-field,
.pof-field,
.nac-field,
.admin-field,
.settings-field{
  display: grid;
  gap: var(--form-control-gap);
  min-width: 0;
  max-width: 100%;
}

.ui-field label,
.form-field label,
.bform-group label,
.owiz-field label,
.news-compose-field label,
.pof-field label,
.nac-field label,
.admin-field label,
.settings-field label{
  color: var(--text2, #475569);
  font-size: var(--form-label-size);
  font-weight: 800;
  line-height: 1.25;
}

.ui-help,
.form-help,
.field-help,
.bform-hint,
.owiz-hint{
  color: var(--text3, #94a3b8);
  font-size: var(--form-help-size);
  line-height: 1.35;
}

.ui-error,
.form-error,
.field-error,
.input-error-msg{
  color: var(--danger, #ef4444);
  font-size: var(--form-help-size);
  font-weight: 700;
  line-height: 1.35;
}

.input-error,
.is-error input,
.is-error select,
.is-error textarea,
input.is-error,
select.is-error,
textarea.is-error{
  border-color: var(--danger, #ef4444) !important;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--danger, #ef4444) 14%, transparent) !important;
}

/* Search rows must not overflow the hero/tools cards. */
.catalog-tools__search,
.mo-search-action,
.mo-search-panel,
.news-toolbar__search,
.parts-search-wrap,
.msng-composer,
.msng-input-row{
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}

.mo-search-panel{
  display: flex;
  align-items: center;
  gap: var(--space-2, 8px);
}

.mo-search-panel .mo-search-input{
  flex: 1 1 auto;
  width: 100%;
}

.mo-search-panel .mo-search-clear,
.mo-search-panel .mo-search-submit{
  flex: 0 0 auto;
}

.msng-textarea,
.chat-input{
  width: 100%;
}

/* Admin forms often sit in flex rows; allow them to shrink instead of forcing horizontal scroll. */
.admin-search,
.order-status-sel,
.admin-field input,
.admin-field select,
.admin-field textarea{
  min-width: 0 !important;
}

/* Mobile safety: no accidental browser zoom, no clipped controls. */
@media (max-width: 640px){
  input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="file"]),
  select,
  textarea,
  .bform-input,
  .bform-select,
  .bform-textarea,
  .pf-input,
  .pf-search-input,
  .parts-search-input,
  .mo-search-input,
  .admin-search,
  .chat-input,
  .msng-textarea,
  .owiz-input{
    font-size: 16px !important;
    min-height: var(--ui-touch-target, 44px) !important;
  }

  .mo-search-panel{
    gap: var(--space-2, 8px);
  }

  textarea,
  .msng-textarea,
  .bform-textarea,
  .owiz-input:is(textarea){
    min-height: 96px !important;
  }
}
