/*
 * Form Components
 * Mobile-first: base styles are mobile, min-width scales up
 */

/* Base Form */
form {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* Form Container */
.form-container {
  background: var(--gray-900);
  border: 1px solid var(--gray-800);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  max-width: 600px;
  margin: 0 0 var(--space-8) 0;
}

@media (min-width: 768px) {
  .form-container {
    padding: var(--space-8);
  }
}

/* Form Group */
.form-group {
  margin-bottom: var(--space-6);
}

.form-group:last-child {
  margin-bottom: 0;
}

/* Form Label */
label {
  display: block;
  color: var(--gray-300);
  font-weight: 500;
  margin-bottom: var(--space-2);
  font-size: 0.875rem;
}

.form-label {
  display: block;
  color: var(--gray-200);
  font-weight: 600;
  margin-bottom: var(--space-2);
  font-size: 0.875rem;
}

/* Form Inputs - 44px min touch target, 16px font prevents iOS zoom */
input[type="email"],
input[type="password"],
input[type="text"],
input[type="number"],
input[type="datetime-local"],
textarea {
  width: 100%;
  padding: var(--space-4) var(--space-4);
  border: 1px solid var(--gray-800);
  border-radius: var(--radius-md);
  background: var(--gray-1000);
  color: var(--gray-100);
  font-size: 1rem;
  font-family: "Geist Mono", monospace;
  transition: border-color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
}

@media (min-width: 768px) {
  input[type="email"],
  input[type="password"],
  input[type="text"],
  input[type="number"],
  input[type="datetime-local"],
  textarea {
    padding: var(--space-3) var(--space-4);
    font-size: 0.9375rem;
  }
}

.form-input,
.form-select {
  width: 100%;
  padding: var(--space-4) var(--space-4);
  background: var(--gray-1000);
  border: 1px solid var(--gray-800);
  border-radius: var(--radius-md);
  color: var(--gray-200);
  font-family: "Geist Mono", monospace;
  font-size: 1rem;
  transition: all 0.15s ease;
  -webkit-appearance: none;
  appearance: none;
}

@media (min-width: 768px) {
  .form-input,
  .form-select {
    padding: var(--space-3) var(--space-4);
    font-size: 0.875rem;
  }
}

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

input::placeholder,
textarea::placeholder {
  color: var(--gray-600);
}

.form-input::placeholder {
  color: var(--gray-600);
}

input:focus,
textarea:focus {
  outline: none;
  border-color: var(--gray-600);
  background: var(--gray-900);
  box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.05);
}

.form-input:focus,
.form-select:focus {
  outline: none;
  border-color: var(--gray-600);
  background: var(--gray-900);
  box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.05);
}

/* Submit Buttons - 44px min touch target
   Scoped to .form-container so custom buttons elsewhere aren't affected */
.form-container input[type="submit"],
.form-container button[type="submit"],
input[type="submit"].form-submit,
button[type="submit"].form-submit {
  width: 100%;
  min-height: 44px;
  padding: var(--space-3) var(--space-6);
  background-color: #ffffff;
  color: #000000;
  border: none;
  border-radius: var(--radius-md);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: background-color 0.2s ease, box-shadow 0.2s ease;
  font-family: "Geist Mono", monospace;
  letter-spacing: 0.01em;
  -webkit-appearance: none;
  appearance: none;
}

/* Hover effects only for pointer devices */
@media (hover: hover) and (pointer: fine) {
  .form-container input[type="submit"]:hover,
  .form-container button[type="submit"]:hover,
  input[type="submit"].form-submit:hover,
  button[type="submit"].form-submit:hover {
    background-color: var(--gray-100);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(255, 255, 255, 0.15);
  }

  .form-container input[type="submit"]:active,
  .form-container button[type="submit"]:active,
  input[type="submit"].form-submit:active,
  button[type="submit"].form-submit:active {
    transform: translateY(0);
    box-shadow: 0 2px 8px rgba(255, 255, 255, 0.1);
  }
}

@media (min-width: 768px) {
  .form-container input[type="submit"],
  .form-container button[type="submit"],
  input[type="submit"].form-submit,
  button[type="submit"].form-submit {
    font-size: 0.9375rem;
  }
}

/* Radio Buttons */
input[type="radio"] {
  width: auto;
  accent-color: #ffffff;
  cursor: pointer;
}

/* General Button Reset */
button {
  background: none;
  border: none;
  color: inherit;
  cursor: pointer;
  padding: 0;
  font-family: "Geist Mono", monospace;
}

/* Form Help Text */
.form-help {
  font-size: 0.75rem;
  color: var(--gray-500);
  margin-top: var(--space-2);
  margin-bottom: 0;
}

.form-hint {
  margin-top: 0.5rem;
  font-size: 0.75rem;
  color: var(--gray-500);
}

/* Form Static (read-only display) */
.form-static {
  color: var(--gray-400);
  font-family: "Geist Mono", monospace;
}

/* Form Actions */
.form-actions {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-8);
}

.form-actions .button {
  flex: 1;
}
