/*
 * This is a manifest file that'll be compiled into application.css
 */

/* Consistent form input styling — 44px minimum touch target */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="url"],
input[type="date"],
input[type="datetime-local"],
input[type="time"],
input[type="search"],
textarea,
select {
  padding: 0.75rem 1rem;
  font-size: 1rem;
  line-height: 1.5rem;
}

/* Ensure consistent height for single-line inputs (44px minimum) */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="url"],
input[type="date"],
input[type="datetime-local"],
input[type="time"],
input[type="search"],
select {
  min-height: 2.75rem;
}

/* Checkbox and radio styling */
input[type="checkbox"],
input[type="radio"] {
  padding: 0;
}

/* Radio tile visual states */
input[type="radio"]:checked + .radio-visual {
  border-color: #06b6d4;
  background-color: #ecfeff;
  color: #0e7490;
}

label:hover .radio-visual {
  border-color: #d1d5db;
}

/* Checkbox tile visual states */
input[type="checkbox"]:checked + .checkbox-visual {
  border-color: #06b6d4;
  background-color: #ecfeff;
  color: #0e7490;
}

input[type="checkbox"]:checked + .checkbox-visual svg {
  color: #06b6d4;
}

label:hover .checkbox-visual {
  border-color: #d1d5db;
}

/* Skip to content link */
.skip-to-content {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 10000;
  padding: 0.75rem 1.5rem;
  background-color: #0891b2;
  color: #fff;
  font-size: 0.875rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: 0 0 0.5rem 0;
}

.skip-to-content:focus {
  left: 0;
  outline: 2px solid #06b6d4;
  outline-offset: 2px;
}

/* Global visible focus styles for WCAG 2.1 AA */
*:focus-visible {
  outline: 2px solid #0891b2;
  outline-offset: 2px;
}

a:focus-visible,
button:focus-visible,
[role="button"]:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
summary:focus-visible {
  outline: 2px solid #0891b2;
  outline-offset: 2px;
  border-radius: 4px;
}

input[type="checkbox"]:focus-visible,
input[type="radio"]:focus-visible {
  outline: 2px solid #0891b2;
  outline-offset: 2px;
  box-shadow: 0 0 0 4px rgba(8, 145, 178, 0.2);
}

/* Focus styles for sr-only radio buttons (health questions yes/no) */
input.sr-only:focus-visible + div,
input.sr-only:focus + div {
  outline: 2px solid #0891b2;
  outline-offset: 2px;
}

/* Ensure peer focus works for file inputs */
.peer:focus-visible ~ label {
  outline: 2px solid #0891b2;
  outline-offset: 2px;
}
