/* Input styles that match the site's design language */
.input {
  width: 100%;
  padding: var(--space-3);
  border: 1px solid var(--color-neutral-4);
  border-radius: var(--radius-2);
  background-color: var(--color-neutral-3);
  color: var(--color-neutral-12);
  font-size: var(--font-size-2);
  transition: all 200ms ease;
  font-family: var(--font-system-ui);
  box-sizing: border-box;
  height: calc(2.5em + 2px); /* height + borders */
  margin: 0;
  min-height: 44px; /* Minimum touch target size */
}

.input:focus {
  outline: none;
  border-color: var(--color-accent-8);
  background: var(--color-neutral-3);
  box-shadow: 0 0 0 2px rgba(142, 78, 198, 0.2);
}

.input::placeholder {
  color: var(--color-neutral-9);
}

/* Required input styling */
.input[required] {
  border-left: 3px solid var(--color-accent-8);
}

/* Invalid input styling */
.input:invalid:not(:focus):not(:placeholder-shown) {
  border-color: var(--color-error-9);
  box-shadow: 0 0 0 2px rgba(230, 50, 50, 0.2);
}

/* Valid input styling */
.input:valid:not(:focus):not(:placeholder-shown) {
  border-color: var(--color-success-9);
}

/* Input wrapper for labels and inputs */
.input-wrapper {
  position: relative;
  display: flex;
  flex-direction: column;
  margin-bottom: var(--space-4);
}

/* Traditional input label styling */
.input-label {
  display: block;
  margin-bottom: var(--space-2);
  font-weight: 500;
  color: var(--color-neutral-12);
  font-size: var(--font-size-1);
}

/* Floating label styles */
.input-wrapper.has-floating-label {
  position: relative;
  margin-bottom: var(--space-4);
}

.input-wrapper.has-floating-label .input {
  padding-top: calc(var(--space-3) + 0.75em); /* Extra space for floating label */
  padding-bottom: var(--space-3);
}

.input-wrapper.has-floating-label .input-label.floating {
  position: absolute;
  top: 0;
  left: calc(var(--space-3) + 5px); /* Slightly to the right */
  padding: 0 5px;
  margin: 0;
  font-size: var(--font-size-1);
  color: var(--color-neutral-9);
  pointer-events: none;
  transform-origin: 0 0;
  transition: all 200ms ease;
  z-index: 1;
  background: transparent; /* No background */
  /* Remove any border */
  border: none;
}

.input-wrapper.has-floating-label .input:focus + .input-label.floating,
.input-wrapper.has-floating-label .input:not(:placeholder-shown) + .input-label.floating {
  transform: translateY(-50%) scale(0.85);
  background: var(--color-neutral-3); /* Match input background */
  top: 0;
  left: calc(var(--space-3) + 5px); /* Keep same position */
  /* Ensure no border appears */
  border: none;
  box-shadow: none;
}

.input-wrapper.has-floating-label .input:focus + .input-label.floating {
  color: var(--color-accent-9);
}

/* Hide placeholder when floating label is active */
.input-wrapper.has-floating-label .input:focus::placeholder {
  opacity: 0;
}

/* Disabled input styling */
.input:disabled {
  background-color: var(--color-neutral-2);
  color: var(--color-neutral-9);
  cursor: not-allowed;
}

/* Input group with icon */
.input-group {
  position: relative;
  display: flex;
  align-items: center;
}

.input-group .input {
  padding-left: calc(var(--space-3) + 1.5em);
}

.input-group-icon {
  position: absolute;
  left: var(--space-3);
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-neutral-9);
  pointer-events: none;
  min-width: 44px; /* Minimum touch target size */
  min-height: 44px; /* Minimum touch target size */
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Textarea variant */
.input.textarea {
  min-height: 100px;
  resize: vertical;
  padding: var(--space-3);
}

/* Input group with button */
.input-group-button {
  display: flex;
}

.input-group-button .input {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-right: none;
}

.input-group-button .button {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  min-height: 44px; /* Minimum touch target size */
}

/* Validation styles */
.input.input--error {
  border-color: var(--color-error-9);
}

.input.input--success {
  border-color: var(--color-success-9);
}

/* Form select styles to match input styling */
.form-select {
  width: 100%;
  padding: var(--space-3);
  border: 1px solid var(--color-neutral-4);
  border-radius: var(--radius-2);
  background-color: var(--color-neutral-3);
  color: var(--color-neutral-12);
  font-size: var(--font-size-2);
  transition: all 200ms ease;
  font-family: var(--font-system-ui);
  box-sizing: border-box;
  height: calc(2.5em + 2px); /* height + borders */
  margin: 0;
  appearance: none;
  min-height: 44px; /* Minimum touch target size */
}

.form-select:focus {
  outline: none;
  border-color: var(--color-accent-8);
  background: var(--color-neutral-3);
  box-shadow: 0 0 0 2px rgba(142, 78, 198, 0.2);
}

.form-select:disabled {
  background-color: var(--color-neutral-2);
  color: var(--color-neutral-9);
  cursor: not-allowed;
}

/* Small form select variant */
.form-select.form-select-sm {
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-size-1);
  height: calc(2em + 2px); /* height + borders */
  min-height: 36px; /* Minimum touch target size */
}

/* Mobile-specific styles */
@media (max-width: 768px) {
  .input {
    min-height: 48px;
    padding: var(--space-3);
    font-size: var(--font-size-2);
  }
  
  .input-wrapper.has-floating-label .input {
    padding-top: calc(var(--space-3) + 1em);
    padding-bottom: var(--space-3);
  }
  
  .input-label {
    font-size: var(--font-size-1);
  }
  
  .input-wrapper.has-floating-label .input-label.floating {
    font-size: var(--font-size-0);
  }
  
  .form-select {
    min-height: 48px;
    padding: var(--space-3);
    font-size: var(--font-size-2);
  }
  
  .form-select.form-select-sm {
    min-height: 40px;
    padding: var(--space-2) var(--space-3);
  }
  
  .input-group-button .button {
    min-height: 48px;
  }
  
  .input-group-icon {
    min-width: 48px;
    min-height: 48px;
  }
}

@media (max-width: 576px) {
  .input {
    min-height: 52px;
    padding: var(--space-3);
  }
  
  .form-select {
    min-height: 52px;
    padding: var(--space-3);
  }
  
  .form-select.form-select-sm {
    min-height: 44px;
  }
  
  .input-group-button .button {
    min-height: 52px;
  }
  
  .input-group-icon {
    min-width: 52px;
    min-height: 52px;
  }
}