/* =============================================================================
   FORMS — Modern input styling
   ============================================================================= */

/* ---------------------------------------------------------------------------
   FORM ELEMENTS
--------------------------------------------------------------------------- */

.form-item {
  margin-bottom: var(--space-5);
}

.form-item label,
.form-item__label {
  display: block;
  margin-bottom: var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text);
}

.form-item label .form-required,
.form-required {
  color: var(--color-rose-500);
  margin-left: 2px;
}

/* Text inputs, textareas, selects */
.form-text,
.form-email,
.form-url,
.form-number,
.form-tel,
.form-search,
.form-textarea,
.form-select,
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
textarea,
select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-lg);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--color-text);
  line-height: var(--leading-normal);
  transition: border-color var(--transition-fast),
              box-shadow var(--transition-fast),
              background var(--transition-fast);
  -webkit-appearance: none;
  appearance: none;
}

.form-text:hover,
.form-email:hover,
input[type="text"]:hover,
input[type="email"]:hover,
textarea:hover {
  border-color: var(--color-border-strong);
}

.form-text:focus,
.form-email:focus,
.form-textarea:focus,
.form-select:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
  background: var(--color-surface);
}

textarea {
  min-height: 140px;
  resize: vertical;
}

/* Placeholder */
::placeholder {
  color: var(--color-text-disabled);
}

/* Select arrow */
select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748B' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-4) center;
  padding-right: var(--space-10);
}

/* Checkbox & Radio */
.form-checkbox,
.form-radio,
input[type="checkbox"],
input[type="radio"] {
  width: 18px;
  height: 18px;
  border: 1.5px solid var(--color-border-strong);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  cursor: pointer;
  transition: all var(--transition-fast);
  accent-color: var(--color-brand);
}

input[type="radio"] {
  border-radius: var(--radius-full);
}

/* Form description */
.form-item__description,
.description {
  margin-top: var(--space-1);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
}

/* Form errors */
.form-item--error .form-text,
.form-item--error input,
.form-item--error textarea {
  border-color: var(--color-rose-400);
  box-shadow: 0 0 0 3px rgba(244, 63, 94, 0.1);
}

.form-item--error .form-item__error-message {
  color: var(--color-rose-500);
  font-size: var(--text-xs);
  margin-top: var(--space-1);
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

/* ---------------------------------------------------------------------------
   SEARCH FORM
--------------------------------------------------------------------------- */

.search-form,
.block-search-form-block {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}

.search-form .form-search,
.block-search-form-block input[type="search"] {
  min-width: 0;
  padding-left: var(--space-4);
  padding-right: var(--space-4);
  border-radius: var(--radius-full);
}

.search-form .button,
.block-search-form-block input[type="submit"] {
  flex-shrink: 0;
  border-radius: var(--radius-full);
}

/* ---------------------------------------------------------------------------
   STATUS MESSAGES
--------------------------------------------------------------------------- */

.messages {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-xl);
  border: 1px solid;
  margin-bottom: var(--space-6);
  font-size: var(--text-sm);
}

.messages--status {
  background: rgba(16, 185, 129, 0.08);
  border-color: var(--color-emerald-500);
  color: var(--color-emerald-600);
}

.messages--warning {
  background: rgba(245, 158, 11, 0.08);
  border-color: var(--color-amber-500);
  color: #92400E;
}

.messages--error {
  background: rgba(244, 63, 94, 0.08);
  border-color: var(--color-rose-400);
  color: #9F1239;
}
