/* ==========================================================================
   Forms — Inputs, Select, Checkbox, Consent
   ========================================================================== */

/* ---- Input (border-bottom style) ---- */

.form-input {
  display: flex;
  align-items: center;
  width: 100%;
  height: 40px;
  padding: 12px 0;
  font-family: var(--font-primary);
  font-size: var(--fs-body);
  font-weight: var(--fw-body);
  line-height: var(--lh-body);
  color: var(--color-primary);
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(0, 96, 183, 0.2);
  outline: none;
  transition: border-color var(--duration-normal) var(--ease-default);
}

.form-input::placeholder {
  color: var(--color-primary);
  opacity: 1;
}

.form-input:focus {
  border-bottom-color: var(--color-primary);
}

.form-input--white {
  color: var(--color-white);
  border-bottom-color: rgba(251, 253, 254, 0.3);
}

.form-input--white::placeholder {
  color: var(--color-white);
  opacity: 0.6;
}

.form-input--white:focus {
  border-bottom-color: var(--color-white);
}

/* ---- Select ---- */

.form-select {
  appearance: none;
  display: flex;
  align-items: center;
  width: 100%;
  height: 40px;
  padding: 12px 28px 12px 0;
  font-family: var(--font-primary);
  font-size: var(--fs-body);
  font-weight: var(--fw-body);
  line-height: var(--lh-body);
  color: var(--color-primary);
  background: transparent url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%230060b7' stroke-width='1.5'/%3E%3C/svg%3E") no-repeat right center;
  border: none;
  border-bottom: 1px solid rgba(0, 96, 183, 0.2);
  border-radius: 0;
  outline: none;
  cursor: pointer;
}

/* ---- Consent block ---- */

.consent {
  display: flex;
  gap: var(--gap-md);
  align-items: flex-start;
}

.consent__checkbox {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  appearance: none;
  border: 2px solid var(--color-primary);
  border-radius: var(--radius-xs);
  cursor: pointer;
  position: relative;
}

.consent__checkbox:checked {
  background-color: var(--color-primary);
}

.consent__checkbox:checked::after {
  content: '';
  position: absolute;
  left: 6px;
  top: 2px;
  width: 6px;
  height: 10px;
  border: solid var(--color-white);
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.consent__text {
  font-size: var(--fs-sm);
  font-weight: var(--fw-sm);
  font-style: italic;
  line-height: var(--lh-sm);
  color: var(--color-primary);
}

.consent__link {
  font-weight: var(--fw-body-bold);
  font-style: italic;
  color: var(--color-primary);
  text-decoration: underline;
  text-decoration-style: wavy;
  text-underline-offset: 2px;
}

.consent__link:hover {
  color: var(--color-accent);
}

/* ---- White variant consent ---- */

.consent--white .consent__checkbox {
  border-color: var(--color-white);
}

.consent--white .consent__checkbox:checked {
  background-color: var(--color-white);
}

.consent--white .consent__checkbox:checked::after {
  border-color: var(--color-primary);
}

.consent--white .consent__text {
  color: var(--color-white);
}

.consent--white .consent__link {
  color: var(--color-white);
}
