/* ==================================================
   BUTTON EXTENSION LAYER
   Canonical global .btn styles live in base.css.
   This file keeps product/landing-specific .ml-btn helpers
   plus shared form field utilities for pages that load core/*.
================================================== */

.ml-btn {
  min-height: var(--btn-height-md);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  max-width: 100%;
  padding: 0.75rem var(--btn-padding-x-md);
  border: 1px solid transparent;
  font-size: var(--font-size-sm);
  font-weight: var(--weight-bold, 700);
  line-height: 1.15;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  transition:
    transform var(--transition-fast),
    box-shadow var(--transition-fast),
    background-color var(--transition-fast),
    border-color var(--transition-fast),
    color var(--transition-fast);
}

.ml-btn {
  border-radius: var(--radius-pill);
}

.ml-btn:hover {
  transform: translateY(-1px);
}

.ml-btn:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}

.ml-btn-primary {
  background: var(--ml-primary);
  border-color: var(--ml-primary);
  color: var(--ml-on-primary);
  box-shadow: var(--shadow-soft, var(--shadow-sm));
}

.ml-btn-primary:hover {
  background: var(--ml-primary-hover);
  border-color: var(--ml-primary-hover);
  color: var(--ml-on-primary);
}

.ml-btn-secondary {
  background: var(--ml-surface);
  border-color: var(--ml-border);
  color: var(--ml-text);
}

.ml-btn-secondary:hover {
  background: var(--ml-surface-alt);
  color: var(--ml-text);
}

.ml-btn-ghost {
  background: transparent;
  border-color: transparent;
  color: var(--ml-text);
  box-shadow: none;
}

.ml-btn-ghost:hover {
  background: color-mix(in srgb, var(--ml-primary) 8%, transparent);
  color: var(--ml-text);
  box-shadow: none;
}

.ml-btn-small {
  min-height: var(--btn-height-sm);
  padding-inline: var(--btn-padding-x-sm);
  font-size: var(--text-xs);
}

.ml-btn-large {
  min-height: var(--btn-height-lg);
  padding-inline: var(--btn-padding-x-lg);
  font-size: var(--text-md);
}

.field,
.form-group,
.input-shell {
  display: flex;
  flex-direction: column;
  gap: var(--form-group-gap, var(--space-xs));
  min-width: 0;
}

.field label,
.form-label {
  color: var(--ml-text);
  font-size: var(--form-label-size, var(--text-sm));
  font-weight: var(--form-label-weight, var(--weight-semibold, 600));
  line-height: var(--line-snug);
}

.field small,
.form-help {
  color: var(--ml-text-muted);
  font-size: var(--text-xs);
  line-height: var(--line-normal);
}

.field input,
.field select,
.field textarea,
.input,
.form-input,
.form-select,
.form-textarea {
  width: 100%;
  min-height: var(--input-min-height, 2.875rem);
  padding: var(--input-padding, 0.65rem 0.75rem);
  border: 1px solid var(--input-border, var(--ml-border));
  border-radius: var(--input-radius, var(--radius-md));
  background: var(--input-bg, var(--ml-surface));
  color: var(--ml-text);
  font: inherit;
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    background-color var(--transition-fast);
}

.form-textarea {
  min-height: 12rem;
  line-height: var(--line-normal);
  resize: vertical;
}

.tool-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  align-items: center;
}

.input:focus,
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--ml-primary);
  box-shadow: var(--shadow-focus);
}

@media (max-width: 640px) {
  .ml-btn {
    width: 100%;
    min-height: var(--btn-height-lg);
    padding-inline: var(--btn-padding-x-sm);
  }
}
