/* ===================================
   Forms & Upload UI
   =================================== */

input:not([type="checkbox"]):not([type="radio"]),
textarea,
select {
  width: 100%;
  box-sizing: border-box;
  padding: 1.2rem 3rem;
  border: 0;
  border-radius: 0.5rem;
  background: var(--color-bg-muted);
  font-size: 1rem;
  transition: all var(--transition-fast) ease-in-out;
}

#inp-uploads {
  padding-left: 1.2rem;
}

input:not([type="checkbox"]):not([type="radio"]):hover,
textarea:hover,
select:hover {
  outline: none;
  background: var(--color-bg-soft);
}

input:not([type="checkbox"]):not([type="radio"]):focus,
input:not([type="checkbox"]):not([type="radio"]):active,
input:not([type="checkbox"]):not([type="radio"]):focus-visible,
textarea:focus,
textarea:active,
textarea:focus-visible,
select:focus,
select:active,
select:focus-visible {
  outline: none;
  background: var(--color-bg-softer);
  box-shadow: 0 0 0 2px var(--color-primary-alt-16);
}

select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 2.5rem;
  background-image: url('data:image/svg+xml;utf8,<svg fill="%23000" height="16" viewBox="0 0 24 24" width="16" xmlns="http://www.w3.org/2000/svg"><path d="M7 10l5 5 5-5z"/></svg>');
  background-repeat: no-repeat;
  background-position: right 1rem center;
  background-size: 2rem;
}

input[type="checkbox"] {
  width: 2rem;
  height: 2rem;
  padding: 0;
  accent-color: var(--color-primary);
  cursor: pointer;
}

input[type="submit"]:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.form {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.form-col-100 { flex: 1 1 100%; }
.form-col-50 { flex: 1 1 calc(50% - 0.75rem); box-sizing: border-box; }

.checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  line-height: 1.5;
}

.checkbox-label input[type="checkbox"] {
  width: 1.5rem;
  height: 1.5rem;
  padding: 0;
  flex-shrink: 0;
  cursor: pointer;
}

.checkbox-label span {
  display: inline-block;
  max-width: 100%;
}

@media (max-width: 1199.98px) {
  #contact-form { margin-bottom: 6rem; }
}

.hp-field {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}

.upload-status { margin-top: 16px; }
.upload-status__text { margin-bottom: 8px; font-size: 14px; color: var(--color-text-muted-mid); }
.upload-status__percent { margin-top: 6px; font-size: 13px; color: var(--color-text-muted-strong); }

.upload-bar {
  width: 100%;
  height: 10px;
  background: var(--color-gray-eee);
  border-radius: 999px;
  overflow: hidden;
}

.upload-bar__fill {
  width: 0%;
  height: 100%;
  background: var(--color-upload-fill);
  border-radius: 999px;
  transition: width .15s linear;
}

@media (max-width: 767.98px) {
  .form-col-50 { flex: 1 1 100%; }

  input[type="file"] {
    font-size: 0;
  }

  input[type="file"]::file-selector-button {
    font-size: 14px;
  }
}
