/* ═══════════════════════════════════════════
   FORMS CSS — Formulários e inputs
   Todos os valores vêm de css/variables.css
═══════════════════════════════════════════ */


/* ─────────────────────────────────────────
   FORM GROUP & LABEL
───────────────────────────────────────── */

.form-group {
  margin-bottom: var(--space-4);
}

.form-label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-1-5);
}

.form-label .required {
  color: var(--color-danger);
  margin-left: var(--space-1);
}


/* ─────────────────────────────────────────
   INPUT BASE
───────────────────────────────────────── */

.form-input {
  width: 100%;
  height: var(--input-height);
  padding: 0 var(--input-padding-x);
  border: var(--border-width) var(--border-style) var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  color: var(--color-text-primary);
  background: var(--color-surface);
  transition: var(--transition-normal);
  font-family: inherit;
}

.form-input::placeholder {
  color: var(--color-text-muted);
}

.form-input:focus {
  border-color: var(--color-border-focus);
  box-shadow: var(--shadow-focus);
}

.form-input:disabled {
  background: var(--color-surface-3);
  cursor: not-allowed;
  opacity: 0.6;
}

.form-input.error {
  border-color: var(--color-danger);
  box-shadow: var(--shadow-focus-danger);
}


/* ─────────────────────────────────────────
   INPUT SIZES
───────────────────────────────────────── */

.form-input-sm {
  height: var(--input-height-sm);
  font-size: var(--font-size-sm);
}

.form-input-lg {
  height: var(--input-height-lg);
  font-size: var(--font-size-md);
}


/* ─────────────────────────────────────────
   TEXTAREA
───────────────────────────────────────── */

.form-textarea {
  width: 100%;
  height: auto;
  padding: var(--space-3) var(--input-padding-x);
  border: var(--border-width) var(--border-style) var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  color: var(--color-text-primary);
  background: var(--color-surface);
  transition: var(--transition-normal);
  font-family: inherit;
  min-height: var(--space-24);
  resize: vertical;
  line-height: var(--line-height-normal);
}

.form-textarea::placeholder {
  color: var(--color-text-muted);
}

.form-textarea:focus {
  border-color: var(--color-border-focus);
  box-shadow: var(--shadow-focus);
}

.form-textarea:disabled {
  background: var(--color-surface-3);
  cursor: not-allowed;
  opacity: 0.6;
}

.form-textarea.error {
  border-color: var(--color-danger);
  box-shadow: var(--shadow-focus-danger);
}


/* ─────────────────────────────────────────
   SELECT
───────────────────────────────────────── */

.form-select {
  width: 100%;
  height: var(--input-height);
  padding: 0 var(--input-padding-x);
  padding-right: var(--space-10);
  border: var(--border-width) var(--border-style) var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  color: var(--color-text-primary);
  background-color: var(--color-surface);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M2.5 4.5L6 8L9.5 4.5' stroke='%2364748b' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--input-padding-x) center;
  transition: var(--transition-normal);
  font-family: inherit;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

.form-select:focus {
  border-color: var(--color-border-focus);
  box-shadow: var(--shadow-focus);
}

.form-select:disabled {
  background-color: var(--color-surface-3);
  cursor: not-allowed;
  opacity: 0.6;
}

.form-select.error {
  border-color: var(--color-danger);
  box-shadow: var(--shadow-focus-danger);
}


/* ─────────────────────────────────────────
   HINT & ERROR
───────────────────────────────────────── */

.form-hint {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-1);
}

.form-error {
  font-size: var(--font-size-xs);
  color: var(--color-danger);
  margin-top: var(--space-1);
  display: flex;
  align-items: center;
  gap: var(--space-1);
}


/* ─────────────────────────────────────────
   FORM LAYOUT
───────────────────────────────────────── */

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}

.form-row-3 {
  grid-template-columns: 1fr 1fr 1fr;
}

.form-divider {
  height: var(--space-px);
  background: var(--color-border);
  margin: var(--space-6) 0;
}


/* ─────────────────────────────────────────
   CHECKBOX & RADIO
───────────────────────────────────────── */

.checkbox-group {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
}

.checkbox-group input[type="checkbox"],
.checkbox-group input[type="radio"] {
  width: var(--font-size-md);
  height: var(--font-size-md);
  accent-color: var(--color-primary);
  cursor: pointer;
  flex-shrink: 0;
}

.checkbox-label {
  font-size: var(--font-size-base);
  color: var(--color-text-secondary);
}


/* ─────────────────────────────────────────
   SEARCH INPUT
───────────────────────────────────────── */

.search-input-wrapper {
  position: relative;
}

.search-input-wrapper .search-icon {
  position: absolute;
  left: var(--input-padding-x);
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-muted);
  pointer-events: none;
  font-size: var(--font-size-md);
}

.search-input {
  width: 100%;
  height: var(--input-height);
  padding: 0 var(--input-padding-x);
  padding-left: var(--space-9);
  border: var(--border-width) var(--border-style) var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  color: var(--color-text-primary);
  background: var(--color-surface);
  transition: var(--transition-normal);
  font-family: inherit;
}

.search-input::placeholder {
  color: var(--color-text-muted);
}

.search-input:focus {
  border-color: var(--color-border-focus);
  box-shadow: var(--shadow-focus);
}


/* ─────────────────────────────────────────
   TOGGLE / SWITCH
───────────────────────────────────────── */

.toggle {
  position: relative;
  display: inline-flex;
  width: var(--space-10);
  height: var(--space-5);
  cursor: pointer;
}

.toggle input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.toggle-slider {
  position: absolute;
  inset: 0;
  background: var(--color-border-strong);
  border-radius: var(--radius-full);
  transition: var(--transition-normal);
}

.toggle-slider::before {
  content: '';
  position: absolute;
  left: var(--space-0-5);
  top: 50%;
  transform: translateY(-50%);
  width: var(--font-size-md);
  height: var(--font-size-md);
  background: var(--color-text-inverse);
  border-radius: var(--radius-full);
  transition: var(--transition-normal);
  box-shadow: var(--shadow-xs);
}

.toggle input:checked + .toggle-slider {
  background: var(--color-primary);
}

.toggle input:checked + .toggle-slider::before {
  left: calc(100% - var(--font-size-md) - var(--space-0-5));
}
