form {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
  font-family: var(--font-family);
}

form label {
  font-weight: var(--form-label-font-weight);
  font-size: var(--form-label-font-size);
  color: var(--text-primary);
  margin-bottom: var(--form-label-margin-bottom);
  letter-spacing: var(--letter-spacing-wide);
  display: inline-block;
  cursor: pointer;
  transition: color var(--transition-fast);
}

form label:hover,
form label:focus {
  color: var(--accent);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

form label #strengthHint {
  font-size: var(--font-size-sm);
  margin-top: var(--spacing-sm);
  color: var(--text-muted);
  display: block;
  font-style: italic;
  letter-spacing: var(--letter-spacing-wide);
  transition: color var(--transition-fast);
}

form label #strengthHint.strong {
  color: var(--success);
  font-weight: var(--font-weight-bold);
}

form label #strengthHint.weak {
  color: var(--error);
  font-weight: var(--font-weight-medium);
}

form input[type='text'],
form input[type='password'],
form input[type='email'],
form textarea,
form select {
  width: 100%;
  box-sizing: border-box;
  padding: var(--form-input-padding-y) var(--form-input-padding-x);
  margin-top: var(--spacing-sm);
  border: var(--form-input-border-width) solid var(--border-secondary);
  border-radius: var(--form-input-border-radius);
  font-size: var(--font-size-base);
  background: var(--background-secondary);
  color: var(--text-primary);
  transition:
    border-color var(--transition-normal),
    box-shadow var(--transition-normal);
}

form input[type='text']:focus,
form input[type='password']:focus,
form input[type='email']:focus,
form textarea:focus,
form select:focus {
  border-color: var(--accent);
  outline: none;
  background: var(--background-primary);
  box-shadow: var(--focus-ring);
}

form input[type='checkbox'] {
  appearance: none;
  width: var(--checkbox-size);
  height: var(--checkbox-size);
  border: var(--checkbox-border-width) solid var(--border-secondary);
  border-radius: var(--checkbox-border-radius);
  background: var(--background-primary);
  margin-right: var(--spacing-sm);
  cursor: pointer;
  transition:
    background var(--transition-normal),
    border-color var(--transition-normal);
  display: inline-block;
  vertical-align: top;
  margin-top: 2px;
  flex-shrink: 0;
}

form input[type='checkbox']:checked {
  background-color: var(--success);
  border-color: var(--success);
  background-image: url("data:image/svg+xml;utf8,<svg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'><path d='M6.173 12.727L2.12 8.674l1.414-1.414 2.64 2.64L12.465 3.61l1.415 1.415z'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 12px;
  box-shadow: 0 0 0 2px rgba(40, 167, 69, 0.15);
}

form .checkbox-container {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-sm);
}

form .checkbox-container input[type='checkbox'] {
  margin-right: 0;
  margin-top: 2px;
}

form .checkbox-container label {
  cursor: pointer;
  line-height: 1.5;
  user-select: none;
}

form button {
  background: linear-gradient(
    90deg,
    var(--text-primary) 60%,
    var(--accent) 100%
  );
  color: var(--background-primary);
  padding: var(--button-padding-y-md) var(--button-padding-x-md);
  border: none;
  border-radius: var(--button-border-radius);
  cursor: pointer;
  font-weight: var(--button-font-weight);
  font-size: var(--font-size-base);
  letter-spacing: var(--letter-spacing-wider);
  transition:
    background var(--transition-normal),
    transform var(--transition-fast);
}

form button:hover,
form button:focus {
  transform: translateY(-2px) scale(1.02);
}

form .form-message {
  margin-bottom: var(--spacing-lg);
  padding: var(--padding-md) var(--padding-lg);
  border-radius: var(--border-radius-sm);
  font-size: var(--font-size-base);
  font-family: var(--font-family);
  line-height: var(--line-height-base);
  box-shadow: var(--shadow-sm);
  transition:
    background-color var(--transition-normal),
    color var(--transition-normal),
    border-color var(--transition-normal);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

form .form-message.success {
  background-color: var(--color-success-100);
  color: var(--color-success-800);
  border: var(--border-width-1) solid var(--color-success-300);
  box-shadow: var(--shadow-sm);
}

form .form-message.error {
  background-color: var(--color-error-100);
  color: var(--color-error-800);
  border: var(--border-width-1) solid var(--color-error-300);
  box-shadow: var(--shadow-sm);
}

form .form-message.error svg {
  fill: var(--error);
  margin-right: var(--spacing-sm);
  vertical-align: middle;
}

form .additional-links {
  text-align: center;
  font-size: var(--font-size-sm);
  margin-top: var(--spacing-sm);
  color: var(--text-muted);
  line-height: var(--line-height-loose);
}

@media (max-width: 480px) {
  form {
    gap: var(--spacing-md);
    padding: var(--padding-md) var(--padding-sm);
    max-width: 100%;
    box-sizing: border-box;
  }

  form label {
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-xs);
  }

  form input[type='text'],
  form input[type='password'],
  form input[type='email'] {
    font-size: var(--font-size-sm);
    padding: var(--padding-sm);
  }

  form select {
    font-size: var(--font-size-sm);
    padding: var(--padding-sm);
  }

  form button {
    font-size: var(--font-size-sm);
    padding: var(--padding-sm);
  }

  form .form-message {
    font-size: var(--font-size-sm);
    padding: var(--padding-sm) var(--padding-md);
  }

  form .additional-links {
    font-size: var(--font-size-sm);
    margin-top: var(--spacing-xs);
  }
}

@media (min-width: 480px) and (max-width: 768px) {
  form {
    padding: var(--padding-md);
  }
}
